/* =====================================================================
   IMC – Instituto Metabólico Corporal
   Global stylesheet (shared by all pages)
   ===================================================================== */

/* ============== TOKENS ============== */
:root{
  --navy:        #0B1F3B;
  --navy-2:      #0F2748;
  --navy-3:      #14305A;
  --blue:        #1E7CB5;
  --blue-2:      #2E94CF;
  --blue-3:      #5BB6E6;
  --turquesa:    #4B647A;
  --gray:        #6E6E70;
  --gray-2:      #A0A4AA;
  --gray-3:      #D7DCE3;
  --ink:         #11253F;
  --ink-2:       #3A4A60;
  --bg:          #FFFFFF;
  --bg-soft:     #F4F7FB;
  --bg-soft-2:   #EEF3F9;
  --coral:       #FF7A59;
  --coral-2:     #FF6B45;
  --green:       #2BB673;
  --warn:        #F2B940;
  --shadow-sm:   0 1px 2px rgba(11,31,59,.06), 0 1px 1px rgba(11,31,59,.04);
  --shadow-md:   0 8px 24px rgba(11,31,59,.08), 0 2px 6px rgba(11,31,59,.04);
  --shadow-lg:   0 24px 60px rgba(11,31,59,.14), 0 4px 14px rgba(11,31,59,.06);
  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 22px;
  --r-pill: 999px;
  --container: 1240px;
  --maxw: 1180px;
}

/* ============== RESET ============== */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Inter","Helvetica Neue",Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}
input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}
h1,h2,h3,h4{font-family:"Poppins",sans-serif;font-weight:700;color:var(--navy);letter-spacing:-.01em;margin:0;line-height:1.15}
h1{font-size:clamp(2.2rem,4.6vw,3.6rem);font-weight:800;letter-spacing:-.025em}
h2{font-size:clamp(1.8rem,3.2vw,2.6rem);letter-spacing:-.02em}
h3{font-size:1.25rem}
p{margin:0}
::selection{background:var(--blue);color:#fff}

.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{
  font-family:"Poppins",sans-serif;font-weight:600;font-size:.78rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--blue);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:28px;height:2px;background:var(--blue);display:inline-block;border-radius:2px}
.eyebrow.on-dark{color:var(--blue-3)}
.eyebrow.on-dark::before{background:var(--blue-3)}
.section{padding:clamp(56px,8vw,108px) 0}
.section-tight{padding:clamp(40px,5vw,72px) 0}
.section-head{max-width:760px;margin-bottom:48px}
.section-head h2{margin-top:14px}
.section-head p{color:var(--ink-2);margin-top:16px;font-size:1.05rem;max-width:62ch}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head.center .eyebrow{justify-content:center}
.section-head.center p{margin-left:auto;margin-right:auto}

/* ============== BUTTONS ============== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 24px;border-radius:var(--r-pill);
  font-family:"Poppins",sans-serif;font-weight:600;font-size:.95rem;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
  white-space:nowrap;border:1.5px solid transparent;
}
.btn:hover{transform:translateY(-1px)}
.btn:focus-visible{outline:3px solid rgba(30,124,181,.4);outline-offset:2px}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 8px 20px rgba(30,124,181,.28)}
.btn-primary:hover{background:#1A6FA3;box-shadow:0 10px 26px rgba(30,124,181,.36)}
.btn-coral{background:var(--coral);color:#fff;box-shadow:0 8px 22px rgba(255,122,89,.32)}
.btn-coral:hover{background:var(--coral-2);box-shadow:0 12px 28px rgba(255,122,89,.4)}
.btn-ghost{background:transparent;color:var(--navy);border-color:var(--gray-3)}
.btn-ghost:hover{border-color:var(--navy);background:#fff}
.btn-onDark{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.btn-onDark:hover{background:#fff;color:var(--navy)}
.btn-white{background:#fff;color:var(--navy)}
.btn-white:hover{background:#F4F7FB}
.btn-link{color:var(--blue);font-weight:600;display:inline-flex;align-items:center;gap:6px;padding:8px 0;font-family:"Poppins",sans-serif}
.btn-link:hover{color:var(--navy)}
.btn-link .lucide{width:18px;height:18px;transition:transform .2s}
.btn-link:hover .lucide{transform:translateX(3px)}
.btn-link.on-dark{color:#7FD0F2}
.btn-link.on-dark:hover{color:#fff}

/* ============== TOP BAR + HEADER (injected by partials.js) ============== */
.topbar{background:var(--navy);color:#cdd6e3;font-size:.82rem}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-top:10px;padding-bottom:10px}
.topbar-left{display:flex;flex-wrap:wrap;gap:18px;align-items:center}
.topbar-left a, .topbar-left span{display:inline-flex;align-items:center;gap:6px;color:#cdd6e3}
.topbar-left a:hover{color:#fff}
.topbar-left .lucide{width:14px;height:14px;color:var(--blue-3)}
.topbar-right{display:flex;gap:10px;align-items:center}
.topbar-right a{
  width:30px;height:30px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.06);color:#cdd6e3;transition:background .2s, color .2s;
}
.topbar-right a:hover{background:var(--blue);color:#fff}
.topbar-right .lucide{width:15px;height:15px}

header.site{
  position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid rgba(11,31,59,.06);
  transition:box-shadow .2s, background .2s;
}
header.site.is-scrolled{box-shadow:0 6px 22px rgba(11,31,59,.07);background:rgba(255,255,255,.98)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-top:14px;padding-bottom:14px}

.logo{display:inline-flex;align-items:center;gap:12px;color:var(--navy)}
.logo-img{display:block;height:50px;width:auto;max-width:240px}
.logo-img.on-dark{filter:brightness(0) invert(1);opacity:.95}
@media (max-width:640px){.logo-img{height:42px}}

nav.primary{display:flex;align-items:center;gap:6px}
nav.primary > ul{list-style:none;display:flex;gap:2px;margin:0;padding:0}
nav.primary > ul > li{position:relative}
nav.primary a.item{
  display:inline-flex;align-items:center;gap:5px;padding:10px 14px;border-radius:var(--r-pill);
  font-size:.93rem;font-weight:500;color:var(--ink-2);transition:color .15s, background .15s;
}
nav.primary a.item:hover, nav.primary a.item.active{color:var(--navy);background:var(--bg-soft)}
nav.primary .has-drop > a::after{content:"";width:6px;height:6px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);margin-left:4px;margin-top:-3px;opacity:.6}
.dropdown{
  position:absolute;top:100%;left:0;min-width:280px;background:#fff;border-radius:var(--r-md);
  box-shadow:var(--shadow-lg);padding:10px;display:none;border:1px solid rgba(11,31,59,.06);
  margin-top:8px;
}
.dropdown a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;font-size:.92rem;color:var(--ink-2)}
.dropdown a:hover{background:var(--bg-soft);color:var(--navy)}
.dropdown a .lucide{width:18px;height:18px;color:var(--blue);flex:none}
.has-drop:hover .dropdown, .has-drop:focus-within .dropdown{display:block}

.header-cta{display:flex;align-items:center;gap:10px}
.hamburger{display:none;width:42px;height:42px;border-radius:10px;border:1px solid var(--gray-3);align-items:center;justify-content:center;background:#fff}
.hamburger .lucide{width:22px;height:22px;color:var(--navy)}

.mobile-nav{position:fixed;inset:0;background:rgba(11,31,59,.55);z-index:200;opacity:0;pointer-events:none;transition:opacity .2s}
.mobile-nav.open{opacity:1;pointer-events:auto}
.mobile-nav .panel{
  position:absolute;top:0;right:0;bottom:0;width:min(360px,86vw);background:#fff;
  padding:24px;overflow-y:auto;transform:translateX(100%);transition:transform .25s ease;
  display:flex;flex-direction:column;gap:6px;
}
.mobile-nav.open .panel{transform:translateX(0)}
.mobile-nav .close{align-self:flex-end;width:42px;height:42px;border-radius:10px;border:1px solid var(--gray-3);display:inline-flex;align-items:center;justify-content:center}
.mobile-nav a{padding:14px 12px;border-radius:10px;font-weight:500;color:var(--ink);border-bottom:1px solid #eef2f7}
.mobile-nav a:hover{background:var(--bg-soft)}
.mobile-nav a.active{color:var(--blue);font-weight:600}
.mobile-nav .btn{margin-top:16px}

/* ============== HERO (landing) ============== */
.hero{
  position:relative;color:#fff;overflow:hidden;isolation:isolate;
  background:
    radial-gradient(1100px 600px at 80% -10%, rgba(30,124,181,.55), transparent 60%),
    radial-gradient(900px 600px at -10% 80%, rgba(20,48,90,.65), transparent 70%),
    linear-gradient(180deg, #0B1F3B 0%, #0E2952 100%);
  padding:clamp(56px,7vw,96px) 0 clamp(96px,10vw,140px);
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='140' viewBox='0 0 160 140'><g fill='none' stroke='rgba(255,255,255,0.06)' stroke-width='1'><polygon points='40,5 75,25 75,65 40,85 5,65 5,25'/><polygon points='120,5 155,25 155,65 120,85 85,65 85,25'/><polygon points='80,75 115,95 115,135 80,155 45,135 45,95'/></g></svg>");
  background-size:200px 175px;opacity:.7;
}
.hero .wrap{position:relative}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:64px;align-items:center}
.hero-eyebrow{color:var(--blue-3);font-weight:600;letter-spacing:.2em;font-size:.78rem;text-transform:uppercase;display:inline-flex;align-items:center;gap:10px;background:rgba(30,124,181,.18);border:1px solid rgba(91,182,230,.25);padding:8px 14px;border-radius:var(--r-pill)}
.hero h1{color:#fff;margin-top:22px}
.hero h1 .accent{background:linear-gradient(120deg,#5BB6E6,#7FD0F2);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero .lede{color:#C7D2E1;font-size:1.12rem;margin-top:18px;max-width:560px}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px;align-items:center}
.hero-trust{
  margin-top:42px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;
  border-top:1px solid rgba(255,255,255,.12);padding-top:22px;
}
.trust-item{padding-right:22px;border-right:1px solid rgba(255,255,255,.12)}
.trust-item:last-child{border-right:0;padding-right:0}
.trust-num{font-family:"Poppins",sans-serif;font-weight:800;font-size:clamp(1.6rem,2.6vw,2.1rem);color:#fff;letter-spacing:-.02em;line-height:1}
.trust-label{color:#9FB0C8;font-size:.86rem;margin-top:6px;letter-spacing:.02em}

.hero-visual{position:relative}
.hero-card{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-lg);padding:22px;backdrop-filter:blur(8px);
  box-shadow:0 30px 60px rgba(0,0,0,.3);
}
.hero-card-title{display:flex;align-items:center;justify-content:space-between;color:#fff}
.hero-card-title .badge{
  font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  background:rgba(43,182,115,.18);color:#7FE0B0;border:1px solid rgba(43,182,115,.35);
  padding:4px 10px;border-radius:var(--r-pill);
}
.hero-card-title strong{font-family:"Poppins",sans-serif;font-weight:700}
.composition{display:flex;flex-direction:column;gap:14px;margin-top:18px}
.comp-row{display:flex;align-items:center;gap:12px;color:#fff}
.comp-label{width:130px;font-size:.86rem;color:#C7D2E1}
.comp-bar{flex:1;height:8px;background:rgba(255,255,255,.08);border-radius:99px;overflow:hidden}
.comp-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--blue-3),var(--blue));width:0;transition:width 1.2s ease}
.comp-val{font-family:"Poppins",sans-serif;font-weight:700;font-size:.92rem;width:54px;text-align:right;color:#fff}
.hero-card-foot{
  margin-top:18px;border-top:1px dashed rgba(255,255,255,.16);padding-top:14px;
  display:flex;justify-content:space-between;align-items:center;color:#9FB0C8;font-size:.82rem;
}
.hero-card-foot .lucide{width:14px;height:14px;color:var(--blue-3)}

.floating-stat{
  position:absolute;left:-22px;bottom:-28px;background:#fff;color:var(--navy);
  padding:14px 16px;border-radius:var(--r-md);box-shadow:var(--shadow-lg);
  display:flex;align-items:center;gap:12px;max-width:240px;
}
.floating-stat .ic{width:38px;height:38px;border-radius:10px;background:rgba(43,182,115,.12);color:var(--green);display:inline-flex;align-items:center;justify-content:center;flex:none}
.floating-stat strong{font-family:"Poppins",sans-serif;font-weight:700;display:block;font-size:1.02rem}
.floating-stat span{font-size:.78rem;color:var(--ink-2)}

/* ============== PAGE HERO (interior pages) ============== */
.page-hero{
  position:relative;color:#fff;overflow:hidden;isolation:isolate;
  background:
    radial-gradient(900px 500px at 80% -10%, rgba(30,124,181,.45), transparent 60%),
    radial-gradient(700px 500px at -10% 110%, rgba(20,48,90,.55), transparent 70%),
    linear-gradient(180deg, #0B1F3B 0%, #0E2952 100%);
  padding:clamp(36px,5vw,56px) 0 clamp(56px,7vw,84px);
}
.page-hero::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='140' viewBox='0 0 160 140'><g fill='none' stroke='rgba(255,255,255,0.05)' stroke-width='1'><polygon points='40,5 75,25 75,65 40,85 5,65 5,25'/><polygon points='120,5 155,25 155,65 120,85 85,65 85,25'/><polygon points='80,75 115,95 115,135 80,155 45,135 45,95'/></g></svg>");
  background-size:200px 175px;opacity:.7;
}
.page-hero .wrap{position:relative}
.page-hero h1{color:#fff;max-width:24ch}
.page-hero .lede{color:#C7D2E1;font-size:1.1rem;margin-top:18px;max-width:60ch}
.page-hero .eyebrow{color:var(--blue-3)}
.page-hero .eyebrow::before{background:var(--blue-3)}
.page-hero-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:64px;align-items:end;margin-top:24px}
.page-hero-grid .meta{display:flex;flex-direction:column;gap:18px}
.page-hero-grid .meta-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-md);padding:18px;color:#fff;display:flex;gap:14px;align-items:center}
.page-hero-grid .meta-card .ic{width:42px;height:42px;border-radius:12px;background:rgba(91,182,230,.18);color:var(--blue-3);display:inline-flex;align-items:center;justify-content:center;flex:none}
.page-hero-grid .meta-card strong{font-family:"Poppins",sans-serif;display:block;font-size:.95rem}
.page-hero-grid .meta-card span{color:#9FB0C8;font-size:.82rem}

/* ============== BREADCRUMBS ============== */
.breadcrumbs{
  display:flex;flex-wrap:wrap;align-items:center;gap:8px;
  color:#9FB0C8;font-size:.84rem;
}
.breadcrumbs a{color:#9FB0C8;transition:color .15s}
.breadcrumbs a:hover{color:#fff}
.breadcrumbs .sep{opacity:.5}
.breadcrumbs .current{color:#fff}

.breadcrumbs.on-light{color:var(--ink-2)}
.breadcrumbs.on-light a{color:var(--ink-2)}
.breadcrumbs.on-light a:hover{color:var(--navy)}
.breadcrumbs.on-light .current{color:var(--navy)}

/* ============== BMI CALC ============== */
.bmi-section{
  background:var(--bg-soft);
  margin-top:-60px;position:relative;z-index:1;
  border-top-left-radius:24px;border-top-right-radius:24px;
}
.bmi-card{
  background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);
  padding:clamp(28px,4vw,44px);
  display:grid;grid-template-columns:1fr 1.05fr;gap:40px;align-items:center;
}
.bmi-card .left .eyebrow{margin-bottom:8px}
.bmi-card h2{margin-top:8px}
.bmi-card .left p{color:var(--ink-2);margin-top:12px}
.bmi-inputs{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:22px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:.82rem;font-weight:600;color:var(--ink-2)}
.field input, .field textarea, .field select{
  padding:14px 14px;border:1.5px solid var(--gray-3);border-radius:var(--r-sm);
  background:#fff;transition:border-color .15s, box-shadow .15s;font-size:.95rem;
}
.field input:focus, .field textarea:focus, .field select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 4px rgba(30,124,181,.12)}
.bmi-card .actions{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap}

.bmi-result{
  background:linear-gradient(160deg, var(--navy) 0%, var(--navy-3) 100%);
  color:#fff;border-radius:var(--r-md);padding:28px;position:relative;overflow:hidden;
}
.bmi-result::before{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle, rgba(91,182,230,.35), transparent 65%)}
.bmi-out{display:grid;grid-template-columns:1.1fr 1fr;gap:18px;align-items:end}
.bmi-number{font-family:"Poppins",sans-serif;font-weight:800;font-size:clamp(3.4rem,7vw,5.2rem);line-height:1;letter-spacing:-.03em;color:#fff}
.bmi-number small{font-size:.32em;color:#9FB0C8;font-weight:500;margin-left:6px;letter-spacing:0}
.bmi-cat{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--r-pill);background:rgba(91,182,230,.15);color:#7FD0F2;font-weight:600;font-size:.86rem;border:1px solid rgba(91,182,230,.3)}
.bmi-cat .dot{width:8px;height:8px;border-radius:50%;background:currentColor}
.bmi-scale{margin-top:22px}
.bmi-bar{height:10px;border-radius:99px;background:linear-gradient(90deg,#7FD0F2 0% 20%, #2BB673 20% 45%, #F2B940 45% 70%, #F26B5E 70% 100%);position:relative}
.bmi-marker{position:absolute;top:-6px;width:22px;height:22px;border-radius:50%;background:#fff;border:3px solid var(--navy);transform:translateX(-50%);transition:left .6s cubic-bezier(.2,.7,.2,1);box-shadow:0 4px 10px rgba(0,0,0,.3)}
.bmi-legend{display:flex;justify-content:space-between;margin-top:10px;color:#9FB0C8;font-size:.74rem}
.bmi-note{margin-top:22px;background:rgba(255,255,255,.05);border:1px dashed rgba(255,255,255,.18);padding:14px 16px;border-radius:var(--r-sm);color:#C7D2E1;font-size:.86rem;display:flex;gap:12px;align-items:flex-start}
.bmi-note .lucide{width:18px;height:18px;color:var(--blue-3);flex:none;margin-top:2px}
.bmi-note a{color:#7FD0F2;font-weight:600;text-decoration:underline;text-underline-offset:3px}

/* ============== SOBRE NOSOTROS ============== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about ul.checks{list-style:none;padding:0;margin:24px 0 0;display:flex;flex-direction:column;gap:14px}
.about ul.checks li{display:flex;align-items:flex-start;gap:14px}
.about ul.checks .ic{width:44px;height:44px;border-radius:12px;background:rgba(30,124,181,.1);color:var(--blue);flex:none;display:inline-flex;align-items:center;justify-content:center}
.about ul.checks strong{display:block;color:var(--navy);font-family:"Poppins",sans-serif;font-weight:600;font-size:1rem}
.about ul.checks p{color:var(--ink-2);font-size:.94rem;margin-top:2px}
.about-cta{margin-top:32px}

.stack-images{position:relative;aspect-ratio:5/6}
.stack-images .ph{position:absolute;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
.stack-images .ph.a{top:0;left:0;width:72%;height:72%;z-index:2}
.stack-images .ph.b{bottom:0;right:0;width:62%;height:58%;z-index:3;border:6px solid #fff}
.stack-images .ph-badge{position:absolute;bottom:-22px;left:18px;background:#fff;padding:14px 18px;border-radius:var(--r-md);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:12px;z-index:4}
.stack-images .ph-badge .ic{width:42px;height:42px;border-radius:50%;background:var(--navy);color:#fff;display:inline-flex;align-items:center;justify-content:center}
.stack-images .ph-badge strong{font-family:"Poppins",sans-serif;display:block;font-size:.95rem}
.stack-images .ph-badge span{font-size:.78rem;color:var(--ink-2)}

.photo-ph{
  width:100%;height:100%;
  background:linear-gradient(160deg, #DCE7F2 0%, #C9D8EA 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  color:var(--navy);padding:24px;text-align:center;position:relative;
}
.photo-ph::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(45deg, rgba(11,31,59,.04) 0 2px, transparent 2px 18px)}
.photo-ph .ic{width:72px;height:72px;border-radius:50%;background:rgba(11,31,59,.08);color:var(--navy);display:inline-flex;align-items:center;justify-content:center;position:relative}
.photo-ph .ic .lucide{width:34px;height:34px}
.photo-ph .lbl{font-family:"JetBrains Mono","SF Mono",Menlo,monospace;font-size:.74rem;letter-spacing:.04em;color:var(--ink-2);background:rgba(255,255,255,.7);padding:6px 12px;border-radius:var(--r-pill);position:relative}

/* ============== METHOD ============== */
.method-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative;margin-top:42px}
.method-grid::before{content:"";position:absolute;top:46px;left:14%;right:14%;height:2px;background:repeating-linear-gradient(90deg, var(--gray-3) 0 8px, transparent 8px 16px);z-index:0}
.method-card{background:#fff;border:1px solid #eef2f7;border-radius:var(--r-lg);padding:32px 28px;position:relative;z-index:1;transition:transform .2s, box-shadow .2s, border-color .2s}
.method-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:transparent}
.method-step{display:inline-flex;align-items:center;gap:10px;margin-bottom:18px}
.method-num{width:54px;height:54px;border-radius:50%;background:var(--navy);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-family:"Poppins",sans-serif;font-weight:800;font-size:1.3rem;letter-spacing:-.02em;box-shadow:0 6px 14px rgba(11,31,59,.25)}
.method-card.featured .method-num{background:var(--blue)}
.method-card .ic{width:48px;height:48px;border-radius:12px;background:rgba(30,124,181,.1);color:var(--blue);display:inline-flex;align-items:center;justify-content:center;margin-bottom:14px}
.method-card h3{margin-bottom:8px;font-size:1.18rem}
.method-card p{color:var(--ink-2);font-size:.95rem}

/* ============== SERVICES (TABS) ============== */
.services{background:var(--bg-soft)}
.tabs{display:grid;grid-template-columns:300px 1fr;gap:40px;margin-top:42px;align-items:start}
.tab-list{display:flex;flex-direction:column;gap:6px;background:#fff;border-radius:var(--r-md);padding:10px;box-shadow:var(--shadow-sm)}
.tab-btn{display:flex;align-items:center;gap:14px;padding:16px 16px;border-radius:10px;text-align:left;color:var(--ink-2);transition:all .15s;font-weight:500;border-left:3px solid transparent}
.tab-btn:hover{background:var(--bg-soft)}
.tab-btn[aria-selected="true"]{background:var(--navy);color:#fff;border-left-color:var(--blue-3)}
.tab-btn[aria-selected="true"] .ic{background:rgba(255,255,255,.12);color:#fff}
.tab-btn .ic{width:36px;height:36px;border-radius:10px;background:rgba(30,124,181,.1);color:var(--blue);display:inline-flex;align-items:center;justify-content:center;flex:none;transition:all .15s}
.tab-btn .meta{display:flex;flex-direction:column;gap:2px;line-height:1.15}
.tab-btn .meta small{font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;opacity:.7}
.tab-btn .meta strong{font-family:"Poppins",sans-serif;font-weight:600;font-size:.98rem}

.tab-panels{position:relative;min-height:480px}
.tab-panel{display:none;background:#fff;border-radius:var(--r-lg);padding:14px;box-shadow:var(--shadow-md);grid-template-columns:1fr 1fr;gap:24px;align-items:stretch}
.tab-panel.active{display:grid;animation:fadeUp .3s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.panel-media{border-radius:var(--r-md);overflow:hidden;min-height:380px}
.panel-body{padding:18px 14px 22px 18px;display:flex;flex-direction:column;gap:14px}
.panel-body .eyebrow{margin-bottom:0}
.panel-body h3{font-size:1.45rem;margin-top:4px}
.panel-body > p{color:var(--ink-2)}
.panel-features{list-style:none;padding:0;margin:6px 0 0;display:flex;flex-direction:column;gap:8px}
.panel-features li{display:flex;gap:10px;align-items:center;color:var(--ink);font-size:.94rem}
.panel-features li .lucide{width:18px;height:18px;color:var(--green);flex:none}
.panel-pro{margin-top:auto;background:var(--bg-soft);border-radius:var(--r-md);padding:14px;display:flex;align-items:center;gap:14px}
.panel-pro .av{width:46px;height:46px;border-radius:50%;background:var(--navy);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-family:"Poppins",sans-serif;font-weight:700}
.panel-pro .meta strong{font-family:"Poppins",sans-serif;display:block;font-size:.95rem;color:var(--navy)}
.panel-pro .meta span{font-size:.82rem;color:var(--ink-2)}
.panel-pro .meta a{color:var(--blue);font-weight:600}
.panel-cta{margin-top:8px}
.accordion{display:none}

/* ============== SERVICE GRID OVERVIEW ============== */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:42px}
.svc-card{background:#fff;border:1px solid #eef2f7;border-radius:var(--r-lg);padding:30px;display:flex;flex-direction:column;gap:14px;transition:transform .2s, box-shadow .2s, border-color .2s}
.svc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:transparent}
.svc-card .ic{width:52px;height:52px;border-radius:14px;background:rgba(30,124,181,.1);color:var(--blue);display:inline-flex;align-items:center;justify-content:center}
.svc-card h3{font-size:1.2rem}
.svc-card p{color:var(--ink-2);font-size:.94rem;flex:1}
.svc-card .btn-link{align-self:flex-start}

/* ============== WHY US ============== */
.why-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:center}
.why-features{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:32px}
.why-feat{background:#fff;border:1px solid #eef2f7;border-radius:var(--r-md);padding:18px;display:flex;flex-direction:column;gap:8px;transition:transform .2s, box-shadow .2s}
.why-feat:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.why-feat .ic{width:38px;height:38px;border-radius:10px;background:rgba(30,124,181,.1);color:var(--blue);display:inline-flex;align-items:center;justify-content:center}
.why-feat strong{font-family:"Poppins",sans-serif;font-weight:600;color:var(--navy);font-size:.98rem}
.why-feat p{color:var(--ink-2);font-size:.86rem}
.why-ctas{display:flex;gap:12px;margin-top:32px;flex-wrap:wrap}
.why-visual{position:relative;aspect-ratio:4/5;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
.why-visual .badge-vo{position:absolute;left:20px;top:20px;background:rgba(11,31,59,.85);color:#fff;padding:10px 14px;border-radius:var(--r-pill);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px}
.why-visual .badge-vo .lucide{width:14px;height:14px;color:var(--blue-3)}

/* ============== TEAM ============== */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:42px}
.team-card{text-align:center;background:#fff;border-radius:var(--r-lg);padding:24px;border:1px solid #eef2f7;transition:transform .2s, box-shadow .2s}
.team-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.avatar{width:120px;height:120px;border-radius:50%;margin:0 auto 18px;background:linear-gradient(160deg,#DCE7F2,#B7CCE2);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;color:var(--navy);border:4px solid #fff;box-shadow:0 0 0 1px var(--gray-3)}
.avatar .lucide{width:44px;height:44px;opacity:.5}
.avatar .initials{font-family:"Poppins",sans-serif;font-weight:700;font-size:2rem;letter-spacing:-.02em}
.team-card strong{font-family:"Poppins",sans-serif;font-weight:700;color:var(--navy);font-size:1.05rem}
.team-role{display:block;color:var(--blue);font-size:.84rem;font-weight:600;margin-top:4px;letter-spacing:.02em}
.team-bio{font-size:.85rem;color:var(--ink-2);margin-top:10px;min-height:42px}
.team-links{display:inline-flex;gap:8px;margin-top:14px}
.team-links a{width:34px;height:34px;border-radius:50%;background:var(--bg-soft);color:var(--navy);display:inline-flex;align-items:center;justify-content:center;transition:all .15s}
.team-links a:hover{background:var(--blue);color:#fff}
.team-links .lucide{width:16px;height:16px}

/* ============== PRICING ============== */
.pricing{background:var(--bg-soft)}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:42px;align-items:stretch}
.plan{background:#fff;border-radius:var(--r-lg);padding:32px 28px;display:flex;flex-direction:column;border:1px solid #eef2f7;position:relative;transition:transform .2s, box-shadow .2s}
.plan:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
/* Reservar espacio arriba para que el badge .price-corner no se sobreponga con el título */
.plan .plan-name{padding-right:96px;min-height:24px}
.plan h3{padding-right:96px}
.plan.featured{background:var(--navy);color:#fff;border:0;box-shadow:var(--shadow-lg);transform:translateY(-6px)}
.plan.featured:hover{transform:translateY(-10px)}
.plan .tag{position:absolute;top:-12px;left:24px;background:var(--coral);color:#fff;font-size:.72rem;padding:5px 12px;border-radius:var(--r-pill);font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.plan-name{font-family:"Poppins",sans-serif;font-weight:600;font-size:.92rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2)}
.plan.featured .plan-name{color:#9FB0C8}
.price-corner{position:absolute;top:-1px;right:-1px;background:var(--blue);color:#fff;padding:14px 18px;border-radius:0 var(--r-lg) 0 var(--r-lg);font-family:"Poppins",sans-serif;text-align:center;min-width:90px}
.plan.featured .price-corner{background:var(--blue-3);color:var(--navy)}
.price-corner .num{font-weight:800;font-size:1.5rem;letter-spacing:-.02em;display:inline-flex;align-items:baseline;gap:2px;line-height:1.1}
.price-corner .num small{font-size:.65rem;font-weight:600;opacity:.9}
.price-corner .per{font-size:.7rem;opacity:.85;display:block;letter-spacing:.04em;margin-top:-2px}
.plan h3{font-family:"Poppins",sans-serif;font-size:1.6rem;color:var(--navy);margin-top:12px}
.plan.featured h3{color:#fff}
.plan-lede{color:var(--ink-2);font-size:.92rem;margin-top:8px;min-height:42px}
.plan.featured .plan-lede{color:#C7D2E1}
.plan ul{list-style:none;padding:0;margin:22px 0 28px;display:flex;flex-direction:column;gap:11px}
.plan li{display:flex;gap:10px;align-items:flex-start;font-size:.94rem;color:var(--ink)}
.plan.featured li{color:#fff}
.plan li .lucide{width:18px;height:18px;color:var(--green);flex:none;margin-top:2px}
.plan.featured li .lucide{color:#7FD0F2}
.plan .btn{margin-top:auto;width:100%}
.plan.featured .btn-primary{background:var(--coral)}
.plan.featured .btn-primary:hover{background:var(--coral-2)}

/* Comparison table (planes.html) */
.compare-wrap{margin-top:48px;background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-md);overflow:hidden;border:1px solid #eef2f7}
.compare-table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;table-layout:fixed}
.compare-table colgroup col:first-child{width:38%}
.compare-table colgroup col:not(:first-child){width:auto}
.compare-table thead th{background:#fff;text-align:center;padding:22px 18px;font-family:"Poppins",sans-serif;color:var(--ink-2);font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;border-bottom:1px solid #eef2f7;vertical-align:top}
.compare-table thead th:first-child{text-align:left}
.compare-table thead th .plan-h{display:flex;flex-direction:column;gap:6px;align-items:center}
.compare-table thead th .plan-h strong{font-family:"Poppins",sans-serif;font-weight:700;font-size:1.05rem;color:var(--navy);letter-spacing:-.01em;text-transform:none}
.compare-table thead th .plan-h .price{font-size:.78rem;font-weight:500;color:var(--ink-2);letter-spacing:0;text-transform:none}
.compare-table thead th.popular{background:linear-gradient(180deg, rgba(30,124,181,.06) 0%, transparent 100%);position:relative}
.compare-table thead th.popular .plan-h strong{color:var(--blue)}
.compare-table thead th .col-tag{display:inline-block;font-size:.65rem;background:var(--coral);color:#fff;padding:3px 10px;border-radius:var(--r-pill);font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-top:4px}
.compare-table tbody td{padding:16px 18px;border-bottom:1px solid #eef2f7;color:var(--ink);font-size:.94rem;text-align:center;vertical-align:middle}
.compare-table tbody td:first-child{text-align:left;font-weight:500;color:var(--navy);background:var(--bg-soft);font-size:.92rem}
.compare-table tbody td.popular{background:rgba(30,124,181,.04)}
.compare-table tbody tr:last-child td{border-bottom:0}
.compare-table .check{color:var(--green);width:20px;height:20px;display:inline-block}
.compare-table .dash{color:var(--gray-2)}
@media (max-width: 760px){
  .compare-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .compare-table{min-width:640px}
  .compare-table colgroup col:first-child{width:180px}
}

/* ============== TESTIMONIALS ============== */
.reviews{position:relative}
.reviews-rail{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;padding:8px 4px 24px;scrollbar-width:thin;margin-top:42px}
.reviews-rail::-webkit-scrollbar{height:6px}
.reviews-rail::-webkit-scrollbar-thumb{background:var(--gray-3);border-radius:99px}
.review{flex:0 0 calc(33.333% - 16px);min-width:300px;scroll-snap-align:start;background:#fff;border-radius:var(--r-lg);padding:28px;border:1px solid #eef2f7;display:flex;flex-direction:column;gap:14px}
.review .stars{display:inline-flex;gap:3px;color:#F2B940}
.review .stars .lucide{width:18px;height:18px;fill:#F2B940;stroke:#F2B940}
.review blockquote{margin:0;font-size:1rem;color:var(--ink);line-height:1.6;text-transform:none !important}
.review-foot{display:flex;align-items:center;gap:12px;margin-top:auto;padding-top:14px;border-top:1px solid #eef2f7}
.review-foot .av{width:46px;height:46px;border-radius:50%;background:linear-gradient(160deg,#DCE7F2,#B7CCE2);display:inline-flex;align-items:center;justify-content:center;font-family:"Poppins",sans-serif;font-weight:700;color:var(--navy)}
.review-foot .meta strong{display:block;font-family:"Poppins",sans-serif;color:var(--navy);font-size:.95rem;text-transform:none}
.review-foot .meta span{font-size:.8rem;color:var(--ink-2);text-transform:none}
.reviews-nav{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}
.reviews-nav button{width:46px;height:46px;border-radius:50%;background:#fff;border:1.5px solid var(--gray-3);display:inline-flex;align-items:center;justify-content:center;transition:all .15s;color:var(--navy)}
.reviews-nav button:hover{background:var(--navy);color:#fff;border-color:var(--navy)}

/* ============== BLOG ============== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:42px}
.blog-grid.lg{grid-template-columns:repeat(3,1fr)}
.post{background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1px solid #eef2f7;display:flex;flex-direction:column;transition:transform .2s, box-shadow .2s}
.post:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.post-media{aspect-ratio:5/3}
.post-body{padding:22px 22px 24px;display:flex;flex-direction:column;gap:10px;flex:1}
.post-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:.78rem;color:var(--ink-2);align-items:center}
.post-meta .author{display:inline-flex;align-items:center;gap:6px}
.post-meta .author .lucide{width:14px;height:14px;color:var(--blue)}
.post-meta .sep{width:3px;height:3px;border-radius:50%;background:var(--gray-2)}
.post-meta .cat{background:rgba(30,124,181,.1);color:var(--blue);padding:3px 10px;border-radius:var(--r-pill);font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:.7rem}
.post h3{font-size:1.15rem;color:var(--navy);margin-top:4px}
.post p{color:var(--ink-2);font-size:.94rem;flex:1}
.post .btn-link{margin-top:8px;align-self:flex-start}

/* Article / prose */
.article{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:56px;margin-top:24px}
.prose{color:var(--ink);font-size:1.05rem;line-height:1.75;max-width:68ch}
.prose h2{font-size:1.6rem;margin-top:48px}
.prose h3{font-size:1.2rem;margin-top:32px}
.prose p{margin-top:18px}
.prose ul, .prose ol{margin-top:18px;padding-left:1.4em;display:flex;flex-direction:column;gap:8px}
.prose blockquote{margin:32px 0;padding:20px 24px;border-left:4px solid var(--blue);background:var(--bg-soft);border-radius:0 var(--r-md) var(--r-md) 0;font-style:italic;color:var(--ink-2)}
.prose strong{color:var(--navy)}
.prose a{color:var(--blue);text-decoration:underline;text-underline-offset:3px}
.prose hr{border:0;border-top:1px solid #eef2f7;margin:48px 0}
.prose .key-stat{background:linear-gradient(160deg, var(--navy), var(--navy-3));color:#fff;border-radius:var(--r-lg);padding:32px;margin:32px 0;display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:center}
.prose .key-stat .ic{width:56px;height:56px;border-radius:14px;background:rgba(91,182,230,.18);color:var(--blue-3);display:inline-flex;align-items:center;justify-content:center}
.prose .key-stat strong{font-family:"Poppins",sans-serif;font-size:1.6rem;color:#fff;display:block;letter-spacing:-.02em}
.prose .key-stat span{color:#C7D2E1;font-size:.94rem}

.article-aside{display:flex;flex-direction:column;gap:24px;position:sticky;top:104px;height:fit-content}
.aside-card{background:#fff;border:1px solid #eef2f7;border-radius:var(--r-lg);padding:22px}
.aside-card h4{font-family:"Poppins",sans-serif;font-size:.85rem;color:var(--ink-2);letter-spacing:.12em;text-transform:uppercase;margin-bottom:12px}
.aside-card.author{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px}
.aside-card.author .av{width:72px;height:72px;border-radius:50%;background:linear-gradient(160deg,#DCE7F2,#B7CCE2);display:inline-flex;align-items:center;justify-content:center;font-family:"Poppins",sans-serif;font-weight:700;color:var(--navy);font-size:1.5rem}
.aside-card.author strong{font-family:"Poppins",sans-serif;font-size:1.05rem;color:var(--navy)}
.aside-card.author .role{color:var(--blue);font-size:.84rem;font-weight:600}
.aside-card.author p{color:var(--ink-2);font-size:.9rem;margin-top:6px}
.aside-toc{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.aside-toc a{color:var(--ink-2);font-size:.92rem;display:block;padding:6px 0;border-left:2px solid transparent;padding-left:12px;transition:all .15s}
.aside-toc a:hover{color:var(--navy);border-left-color:var(--blue)}
.aside-cta{background:var(--navy);color:#fff}
.aside-cta h4{color:#9FB0C8}
.aside-cta p{color:#C7D2E1;font-size:.92rem}
.aside-cta .btn{margin-top:14px;width:100%}

/* ============== CONTACT ============== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:42px}
.contact-info{background:var(--navy);color:#fff;border-radius:var(--r-lg);padding:36px;position:relative;overflow:hidden}
.contact-info::before{content:"";position:absolute;right:-30px;bottom:-30px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle, rgba(30,124,181,.4), transparent 65%)}
.contact-info h3{color:#fff;font-size:1.4rem}
.contact-info p{color:#C7D2E1;margin-top:8px;position:relative}
.info-list{list-style:none;padding:0;margin:26px 0 0;display:flex;flex-direction:column;gap:18px;position:relative}
.info-list li{display:flex;gap:14px;align-items:flex-start}
.info-list .ic{width:42px;height:42px;border-radius:12px;background:rgba(91,182,230,.15);color:var(--blue-3);display:inline-flex;align-items:center;justify-content:center;flex:none}
.info-list strong{font-family:"Poppins",sans-serif;font-weight:600;color:#fff;display:block;font-size:.92rem;letter-spacing:.04em;text-transform:uppercase}
.info-list span,.info-list a{color:#C7D2E1;font-size:.95rem;display:block;margin-top:2px}
.info-list a:hover{color:#fff}
.contact-form{background:#fff;border:1px solid #eef2f7;border-radius:var(--r-lg);padding:36px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.contact-form .field{margin-top:14px}
.contact-form textarea{padding:14px;border:1.5px solid var(--gray-3);border-radius:var(--r-sm);min-height:140px;resize:vertical}
.contact-form textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 4px rgba(30,124,181,.12)}
.contact-form .btn{margin-top:18px;width:100%}
.map-wrap{border-radius:var(--r-lg);overflow:hidden;border:1px solid #eef2f7;margin-top:42px;height:420px}
.map-wrap iframe{width:100%;height:100%;border:0;display:block}

/* ============== FAQ (accordion) ============== */
.faq-list{display:flex;flex-direction:column;gap:12px;margin-top:32px}
.faq-item{background:#fff;border:1px solid #eef2f7;border-radius:var(--r-md);overflow:hidden}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:20px 22px;text-align:left;font-family:"Poppins",sans-serif;font-weight:600;color:var(--navy);font-size:1rem}
.faq-q .chev{transition:transform .2s;color:var(--blue);flex:none}
.faq-item.open .faq-q .chev{transform:rotate(180deg)}
.faq-a{padding:0 22px 22px;color:var(--ink-2);font-size:.96rem;display:none;line-height:1.7}
.faq-item.open .faq-a{display:block}
.faq-cats{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.faq-cat{padding:8px 16px;border-radius:var(--r-pill);background:#fff;border:1.5px solid var(--gray-3);font-size:.85rem;font-weight:500;color:var(--ink-2);transition:all .15s;font-family:"Poppins",sans-serif}
.faq-cat:hover{border-color:var(--navy);color:var(--navy)}
.faq-cat.active{background:var(--navy);color:#fff;border-color:var(--navy)}

/* ============== CASES (before/after) ============== */
.cases-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:42px}
.case-card{background:#fff;border:1px solid #eef2f7;border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s, box-shadow .2s}
.case-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.case-head{display:grid;grid-template-columns:1fr 1fr;gap:0}
.case-side{padding:22px 22px 20px;border-bottom:1px solid #eef2f7;position:relative;background:var(--bg-soft)}
.case-side.after{background:var(--navy);color:#fff;border-bottom-color:transparent}
.case-side small{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);font-weight:700}
.case-side.after small{color:#7FD0F2}
.case-side .big{font-family:"Poppins",sans-serif;font-weight:800;font-size:2rem;color:var(--navy);letter-spacing:-.02em;line-height:1;margin-top:8px}
.case-side.after .big{color:#fff}
.case-side .lbl{font-size:.82rem;color:var(--ink-2);margin-top:6px}
.case-side.after .lbl{color:#C7D2E1}
.case-stats{display:flex;gap:16px;flex-wrap:wrap;margin-top:14px}
.case-stat{font-size:.82rem}
.case-stat strong{font-family:"Poppins",sans-serif;font-weight:700;color:var(--navy);display:block;font-size:1.05rem}
.case-side.after .case-stat strong{color:#fff}
.case-body{padding:24px;display:flex;flex-direction:column;gap:10px;flex:1}
.case-meta{display:flex;align-items:center;gap:10px}
.case-meta .av{width:42px;height:42px;border-radius:50%;background:linear-gradient(160deg,#DCE7F2,#B7CCE2);display:inline-flex;align-items:center;justify-content:center;font-family:"Poppins",sans-serif;font-weight:700;color:var(--navy)}
.case-meta strong{font-family:"Poppins",sans-serif;display:block;color:var(--navy)}
.case-meta span{font-size:.82rem;color:var(--ink-2)}
.case-body blockquote{margin:0;font-size:.96rem;color:var(--ink);line-height:1.6}
.case-body .program{font-size:.78rem;color:var(--blue);font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-family:"Poppins",sans-serif}

/* ============== LEGAL / 404 ============== */
.legal{padding:64px 0 96px}
.legal .prose{margin:0}
.legal h1{font-size:clamp(1.8rem,3.2vw,2.6rem)}
.legal .meta{color:var(--ink-2);font-size:.88rem;margin:8px 0 32px}

.notfound{min-height:70vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:80px 24px;background:linear-gradient(180deg, #fff 0%, var(--bg-soft) 100%)}
.notfound .big404{font-family:"Poppins",sans-serif;font-weight:800;font-size:clamp(6rem,16vw,10rem);letter-spacing:-.04em;line-height:1;background:linear-gradient(120deg, var(--navy), var(--blue));-webkit-background-clip:text;background-clip:text;color:transparent}
.notfound h1{margin-top:14px}
.notfound p{color:var(--ink-2);margin-top:14px;max-width:48ch;margin-left:auto;margin-right:auto}
.notfound .btns{margin-top:32px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ============== CTA BAND (used across pages) ============== */
.cta-band{
  background:linear-gradient(160deg, var(--navy) 0%, var(--navy-3) 100%);color:#fff;
  border-radius:var(--r-lg);padding:48px;display:grid;grid-template-columns:1.4fr auto;gap:24px;align-items:center;
  position:relative;overflow:hidden;
}
.cta-band::before{content:"";position:absolute;right:-30px;top:-30px;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle, rgba(30,124,181,.4), transparent 65%)}
.cta-band h3{color:#fff;font-size:clamp(1.4rem,2.4vw,1.9rem);position:relative}
.cta-band p{color:#C7D2E1;margin-top:8px;position:relative}
.cta-band .actions{display:flex;gap:12px;flex-wrap:wrap;position:relative}

/* ============== FOOTER ============== */
footer.site{background:var(--navy);color:#C7D2E1;padding:72px 0 0;margin-top:60px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px}
.footer-brand .logo-img{height:64px;max-width:280px}
.footer-brand p{margin-top:18px;font-size:.92rem;color:#9FB0C8;max-width:42ch}
.footer h4{color:#fff;font-family:"Poppins",sans-serif;font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:18px}
.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:.94rem}
.footer a{color:#9FB0C8;transition:color .15s}
.footer a:hover{color:#fff}
.newsletter{margin-top:6px}
.newsletter form{display:flex;gap:8px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-pill);padding:5px}
.newsletter input{flex:1;background:transparent;color:#fff;padding:10px 14px;border:0}
.newsletter input::placeholder{color:#9FB0C8}
.newsletter input:focus{outline:none}
.newsletter button{background:var(--blue);color:#fff;padding:10px 18px;border-radius:var(--r-pill);font-weight:600;font-family:"Poppins",sans-serif;font-size:.88rem;transition:background .15s}
.newsletter button:hover{background:#2E94CF}
.socials{display:flex;gap:10px;margin-top:22px}
.socials a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:inline-flex;align-items:center;justify-content:center;color:#fff;transition:all .15s}
.socials a:hover{background:var(--blue);transform:translateY(-2px)}
.socials .lucide{width:18px;height:18px}
.footer-bottom{margin-top:56px;padding:22px 0;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.84rem;color:#9FB0C8}
.footer-bottom a{color:#C7D2E1}

/* ============== FLOATING ============== */
.float-stack{position:fixed;right:22px;bottom:22px;z-index:90;display:flex;flex-direction:column;gap:12px;align-items:flex-end}
.float-btn{width:54px;height:54px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 12px 28px rgba(0,0,0,.25);transition:transform .15s, box-shadow .15s}
.float-btn:hover{transform:translateY(-3px)}
.float-btn.wa{background:#25D366}
.float-btn.top{background:var(--navy);opacity:0;pointer-events:none;transform:translateY(8px);transition:all .2s}
.float-btn.top.show{opacity:1;pointer-events:auto;transform:none}
.wa-bubble{background:#fff;color:var(--navy);padding:10px 14px;border-radius:var(--r-md);font-size:.86rem;box-shadow:var(--shadow-md);max-width:200px;opacity:0;transform:translateX(8px);transition:all .2s;pointer-events:none}
.wa-bubble strong{display:block;color:var(--navy);font-family:"Poppins",sans-serif;font-weight:700;font-size:.92rem}
.wa-bubble span{color:var(--ink-2);font-size:.8rem}
.float-stack .wa-wrap{display:flex;align-items:center;gap:10px}
.float-stack .wa-wrap:hover .wa-bubble, .float-stack .wa-wrap:focus-within .wa-bubble{opacity:1;transform:none}

/* ============== RESPONSIVE ============== */
@media (max-width: 1024px){
  .hero-grid{grid-template-columns:1fr;gap:42px}
  .hero-visual{max-width:520px;margin:0 auto}
  .bmi-card{grid-template-columns:1fr;gap:28px}
  .about-grid{grid-template-columns:1fr;gap:42px}
  .why-grid{grid-template-columns:1fr;gap:42px}
  .why-visual{aspect-ratio:5/4;max-width:560px;margin:0 auto}
  .tabs{grid-template-columns:1fr;gap:0}
  .tab-list{display:none}
  .accordion{display:flex;flex-direction:column;gap:10px;margin-top:42px}
  .tab-panels{display:none}
  .acc-item{background:#fff;border-radius:var(--r-md);border:1px solid #eef2f7;overflow:hidden}
  .acc-head{width:100%;display:flex;align-items:center;gap:14px;padding:18px;text-align:left;font-family:"Poppins",sans-serif;font-weight:600;color:var(--navy)}
  .acc-head .ic{width:36px;height:36px;border-radius:10px;background:rgba(30,124,181,.1);color:var(--blue);display:inline-flex;align-items:center;justify-content:center;flex:none}
  .acc-head .chev{margin-left:auto;transition:transform .2s}
  .acc-item.open .acc-head .chev{transform:rotate(180deg)}
  .acc-body{padding:0 18px 22px;display:none;flex-direction:column;gap:14px}
  .acc-item.open .acc-body{display:flex}
  .acc-body .photo-ph{aspect-ratio:5/3;border-radius:var(--r-md);overflow:hidden}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .pricing-grid{grid-template-columns:1fr;gap:28px}
  .plan.featured{transform:none}
  .plan.featured:hover{transform:translateY(-4px)}
  .review{flex:0 0 calc(50% - 12px)}
  .blog-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr;gap:24px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  nav.primary{display:none}
  .hamburger{display:inline-flex}
  .header-cta .btn-primary{display:none}
  .method-grid{grid-template-columns:1fr;gap:18px}
  .method-grid::before{display:none}
  .bmi-inputs{grid-template-columns:1fr 1fr}
  .bmi-out{grid-template-columns:1fr;gap:14px;align-items:flex-start}
  .svc-grid{grid-template-columns:1fr 1fr}
  .article{grid-template-columns:1fr;gap:24px}
  .article-aside{position:static;flex-direction:column}
  .page-hero-grid{grid-template-columns:1fr;gap:32px}
  .cta-band{grid-template-columns:1fr;padding:32px}
  .cases-grid{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .topbar .wrap{flex-wrap:wrap}
  .topbar-left{font-size:.76rem;gap:12px}
  .topbar-left .hide-sm{display:none}
  .team-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .svc-grid{grid-template-columns:1fr}
  .review{flex:0 0 calc(100% - 8px)}
  .form-row{grid-template-columns:1fr}
  .hero-trust{grid-template-columns:1fr;gap:14px}
  .trust-item{border-right:0;border-bottom:1px solid rgba(255,255,255,.12);padding-right:0;padding-bottom:14px}
  .trust-item:last-child{border-bottom:0;padding-bottom:0}
  .floating-stat{left:50%;transform:translateX(-50%);bottom:-32px}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{justify-content:flex-start;flex-direction:column}
  .bmi-inputs{grid-template-columns:1fr}
  .case-head{grid-template-columns:1fr}
}

/* ============================================================
   ANIMACIONES SUTILES — Paquete básico
   1. Fade-in al hacer scroll (vía clase .reveal + IntersectionObserver)
   2. Hover refinado en cards e imágenes
   3. Animación de barras del reporte InBody en el hero
   ============================================================ */

/* Respetar usuarios que prefieren menos animaciones */
@media (prefers-reduced-motion: reduce){
  .reveal, .reveal.is-visible, .bar-fill{transition: none !important; animation: none !important}
}

/* === 1. REVEAL ON SCROLL === */
.reveal{
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .7s cubic-bezier(.16,.84,.42,1), transform .7s cubic-bezier(.16,.84,.42,1);
  will-change: opacity, transform;
}
.reveal.is-visible{
  opacity: 1;
  transform: translateY(0);
}
/* Variantes con retraso para efecto cascada en grids */
.reveal[data-delay="1"]{transition-delay: .08s}
.reveal[data-delay="2"]{transition-delay: .16s}
.reveal[data-delay="3"]{transition-delay: .24s}
.reveal[data-delay="4"]{transition-delay: .32s}
.reveal[data-delay="5"]{transition-delay: .40s}

/* === 2. HOVER REFINADO === */

/* Team cards: ya tienen translateY al hover. Le agregamos zoom al avatar */
.team-card{transition: transform .3s cubic-bezier(.2,.8,.3,1), box-shadow .3s ease}
.team-card .avatar{transition: transform .35s cubic-bezier(.2,.8,.3,1)}
.team-card:hover .avatar{transform: scale(1.05)}

/* Image containers: hacer zoom sutil al hover en panel-media y post-media */
.panel-media, .post-media, .stack-images .ph, .why-visual{overflow: hidden}
.panel-media img, .post-media img, .stack-images .ph img, .why-visual img{
  transition: transform .55s cubic-bezier(.2,.8,.3,1);
  will-change: transform;
}
.panel-media:hover img,
.post-media:hover img,
.stack-images:hover .ph img,
.why-visual:hover img{transform: scale(1.04)}

/* Reseñas (reviews): card lift sutil */
.review{transition: transform .25s ease, box-shadow .25s ease}
.review:hover{transform: translateY(-3px); box-shadow: var(--shadow-md)}

/* Tab buttons: hover state suave */
.tab-btn{transition: all .25s ease}

/* CTAs primarios: pulse sutil de sombra al hacer hover */
.btn-primary{transition: transform .2s ease, box-shadow .25s ease, background .2s ease}
.btn-primary:hover{transform: translateY(-2px)}

/* Why features: pequeño lift al hover */
.why-feat{transition: transform .25s ease}
.why-feat:hover{transform: translateY(-2px)}

/* Service cards en página servicios (overview) */
.service-card{transition: transform .3s ease, box-shadow .3s ease}
.service-card:hover{transform: translateY(-4px); box-shadow: var(--shadow-md)}

/* Nota: las barras del reporte InBody en el hero ya se animan vía partials.js
   (función bindComposition) que asigna el width al entrar en pantalla. */

/* ============================================================
   HERO CINEMATOGRÁFICO — Glassmorphism + fondo fluido + shimmer
   ============================================================ */

/* El hero debe ser relative para contener el fondo fluido absoluto */
.hero{position:relative;overflow:hidden}
.hero .wrap{position:relative;z-index:2}

/* === 1. FONDO FLUIDO ANIMADO === */
.hero-bg-fluid{
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  opacity:.85;
}
.hero-bg-fluid svg{width:100%;height:100%}
.fluid-blob{transform-origin:center;animation:fluidFloat 14s ease-in-out infinite}
.fluid-blob.blob-2{animation:fluidFloat2 18s ease-in-out infinite;animation-delay:-3s}
@keyframes fluidFloat{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(-30px,20px) scale(1.05)}
  66%{transform:translate(40px,-15px) scale(.96)}
}
@keyframes fluidFloat2{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(50px,-30px) scale(1.08)}
}

/* === 2. PILL SUPERIOR === */
.hero-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 14px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  border-radius:99px;
  font-size:.78rem;
  font-weight:500;
  color:rgba(255,255,255,.9);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  margin-bottom:18px;
  letter-spacing:.01em;
}
.hero-pill .dot{
  width:6px;height:6px;
  border-radius:50%;
  background:#7FD0F2;
  box-shadow:0 0 8px #7FD0F2;
  animation:pulseDot 2s ease-in-out infinite;
}
@keyframes pulseDot{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.6;transform:scale(1.4)}
}

/* === 3. SHIMMER EN PALABRA CLAVE === */
.accent-shimmer{
  background:linear-gradient(
    90deg,
    #7FD0F2 0%,
    #ffffff 25%,
    #7FD0F2 50%,
    #ffffff 75%,
    #7FD0F2 100%
  );
  background-size:200% auto;
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
  animation:shimmer 6s linear infinite;
}
@keyframes shimmer{
  0%{background-position:200% center}
  100%{background-position:-200% center}
}

/* === 4. GLASSMORPHISM EN EL REPORTE INBODY === */
.hero-card{
  background:linear-gradient(135deg,
    rgba(255,255,255,.06) 0%,
    rgba(255,255,255,.02) 100%) !important;
  backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  border:1px solid rgba(255,255,255,.12) !important;
  box-shadow:
    0 20px 60px rgba(0,0,0,.4),
    inset 0 1px 0 rgba(255,255,255,.15) !important;
  position:relative;
  overflow:hidden;
}
/* Reflexión luminosa en el borde superior del card */
.hero-card::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:1px;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(255,255,255,.4) 50%,
    transparent 100%);
  pointer-events:none;
}
/* Glow sutil que respira */
.hero-card::after{
  content:'';
  position:absolute;
  inset:-50%;
  background:radial-gradient(circle at 30% 0%,
    rgba(127,208,242,.12) 0%,
    transparent 50%);
  pointer-events:none;
  animation:breathe 6s ease-in-out infinite;
}
@keyframes breathe{
  0%,100%{opacity:.6}
  50%{opacity:1}
}

/* === 5. FLECHA ANIMADA EN CTA === */
.btn-arrow{position:relative;overflow:hidden}
.btn-arrow .arrow{
  width:18px;height:18px;
  margin-left:4px;
  transition:transform .35s cubic-bezier(.2,.8,.3,1);
}
.btn-arrow:hover .arrow{transform:translateX(6px)}

/* Pulse sutil del CTA principal cada 8s */
.btn-coral{
  animation:ctaPulse 8s ease-in-out infinite;
  animation-delay:3s;
}
@keyframes ctaPulse{
  0%,90%,100%{box-shadow:0 4px 14px rgba(255,107,82,.35)}
  92%{box-shadow:0 4px 14px rgba(255,107,82,.35), 0 0 0 0 rgba(255,107,82,.5)}
  95%{box-shadow:0 4px 14px rgba(255,107,82,.35), 0 0 0 14px rgba(255,107,82,0)}
}

/* === FLOATING STAT con glassmorphism === */
.floating-stat{
  background:rgba(255,255,255,.92) !important;
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.6) !important;
  box-shadow:
    0 20px 50px rgba(0,0,0,.25),
    inset 0 1px 0 rgba(255,255,255,.8) !important;
}

/* === Responsive: en móvil simplificamos === */
@media (max-width:768px){
  .hero-bg-fluid{opacity:.55}
  .fluid-blob{animation-duration:20s}
  .hero-pill{font-size:.72rem;padding:6px 12px}
}

/* Respeta prefer-reduced-motion */
@media (prefers-reduced-motion: reduce){
  .fluid-blob, .accent-shimmer, .hero-card::after,
  .btn-coral, .hero-pill .dot{animation:none !important}
}

/* ============================================================
   HERO ILUMINADO — Spotlight + glow cards + grain
   Destilado de Visualjoy + Aura + Glow cards + Sentinel
   ============================================================ */

/* === SPOTLIGHTS DE COLOR (iluminación dramática) === */
/* Tres luces de colores que iluminan el fondo del hero */
.hero::before{
  content:'';
  position:absolute;
  top:-200px;
  left:-150px;
  width:700px;
  height:700px;
  background:radial-gradient(circle,
    rgba(127,208,242,.35) 0%,
    rgba(77,168,218,.18) 30%,
    transparent 60%);
  filter:blur(60px);
  z-index:1;
  pointer-events:none;
  animation:spotlightMove 16s ease-in-out infinite;
}
.hero::after{
  content:'';
  position:absolute;
  bottom:-250px;
  right:-200px;
  width:800px;
  height:800px;
  background:radial-gradient(circle,
    rgba(255,107,82,.20) 0%,
    rgba(30,124,181,.12) 35%,
    transparent 65%);
  filter:blur(80px);
  z-index:1;
  pointer-events:none;
  animation:spotlightMove2 20s ease-in-out infinite;
}
@keyframes spotlightMove{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(80px,40px) scale(1.1)}
  66%{transform:translate(-60px,80px) scale(.95)}
}
@keyframes spotlightMove2{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-100px,-60px) scale(1.15)}
}

/* === GRAIN TEXTURE sutil (estilo Sentinel) === */
.hero-grain{
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:none;
  opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

/* === GLOW PULSANTE EN EL REPORTE INBODY (cards style) === */
.hero-card{
  position:relative;
}
/* Anillo de luz que respira alrededor del card */
.hero-card{
  box-shadow:
    0 20px 60px rgba(0,0,0,.4),
    inset 0 1px 0 rgba(255,255,255,.15),
    0 0 80px rgba(77,168,218,.18),
    0 0 40px rgba(127,208,242,.12) !important;
  animation:cardGlow 5s ease-in-out infinite;
}
@keyframes cardGlow{
  0%,100%{
    box-shadow:
      0 20px 60px rgba(0,0,0,.4),
      inset 0 1px 0 rgba(255,255,255,.15),
      0 0 80px rgba(77,168,218,.18),
      0 0 40px rgba(127,208,242,.12);
  }
  50%{
    box-shadow:
      0 20px 60px rgba(0,0,0,.4),
      inset 0 1px 0 rgba(255,255,255,.2),
      0 0 120px rgba(77,168,218,.30),
      0 0 60px rgba(127,208,242,.22);
  }
}

/* === BORDE GRADIENTE animado en el reporte (estilo cards glow) === */
.hero-card::before{
  content:'';
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  padding:1px;
  background:linear-gradient(135deg,
    rgba(127,208,242,.5) 0%,
    rgba(255,255,255,.05) 30%,
    rgba(255,107,82,.3) 60%,
    rgba(127,208,242,.4) 100%);
  background-size:300% 300%;
  -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  pointer-events:none;
  animation:borderShift 8s ease-in-out infinite;
}
@keyframes borderShift{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}

/* === Mejorar contraste del headline con la nueva iluminación === */
.hero h1{
  text-shadow:0 2px 30px rgba(0,0,0,.3);
}

/* En móvil reducimos intensidad para no recargar */
@media (max-width:768px){
  .hero::before, .hero::after{opacity:.6}
  .hero-grain{opacity:.02}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .hero::before, .hero::after,
  .hero-card, .hero-card::before{animation:none !important}
}

/* ============================================================
   SECCIÓN OSCURA + GLOW CARDS — "Por qué somos"
   Inspirado en cards glow gradient con paleta IMC
   ============================================================ */

/* Fondo oscuro de la sección con gradiente sutil */
.section-dark{
  background:linear-gradient(180deg, #0A0A0B 0%, #11141C 50%, #0A0A0B 100%);
  position:relative;
  overflow:hidden;
}
.section-dark .wrap{position:relative;z-index:2}

/* Aurora boreal sutil de fondo */
.why-bg-glow{
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background:
    radial-gradient(800px circle at 20% 30%, rgba(127,208,242,.08) 0%, transparent 50%),
    radial-gradient(700px circle at 80% 70%, rgba(255,107,82,.06) 0%, transparent 50%);
}

/* Encabezado centrado de la sección */
.why-head{
  max-width:720px;
  margin:0 auto;
  text-align:center;
  padding-bottom:48px;
}
.why-head .eyebrow.on-dark{
  color:#7FD0F2;
}
.why-head .eyebrow.on-dark::before{
  background:#7FD0F2;
}
.why-title{
  color:#fff;
  margin-top:14px;
  font-size:clamp(1.8rem, 3.5vw, 2.6rem);
}
.why-lede{
  color:rgba(255,255,255,.65);
  margin-top:18px;
  font-size:1rem;
  line-height:1.65;
}

/* Grid de 6 cards: 3 columnas x 2 filas */
.why-features-glow{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:28px;
  max-width:1080px;
  margin:0 auto;
}

/* Wrapper del card con glow */
.glow-card{
  position:relative;
  width:100%;
  min-height:240px;
  isolation:isolate;
}

/* GLOW BACKGROUND: el difuminado de gradiente que ilumina detrás */
.glow-card .glow-bg{
  position:absolute;
  inset:0;
  border-radius:32px;
  background:var(--glow-grad);
  filter:blur(40px);
  opacity:.55;
  z-index:0;
  pointer-events:none;
  transition:opacity .4s ease, filter .4s ease;
}

/* INNER CARD con borde gradient (técnica background-clip) */
.glow-card .glow-inner{
  position:relative;
  z-index:1;
  height:100%;
  min-height:240px;
  border-radius:32px;
  padding:28px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  gap:18px;
  /* Borde gradient: padding-box mostraría el fondo, border-box muestra el gradient en el borde */
  border:2px solid transparent;
  background:
    linear-gradient(#1A1A1C, #1A1A1C) padding-box,
    var(--glow-grad) border-box;
  transition:transform .4s cubic-bezier(.2,.8,.3,1), border-color .3s ease;
  overflow:hidden;
}

/* Reflejo luminoso interior superior */
.glow-card .glow-inner::before{
  content:'';
  position:absolute;
  top:0; left:0; right:0;
  height:1px;
  background:linear-gradient(90deg, transparent 0%, rgba(255,255,255,.4) 50%, transparent 100%);
  pointer-events:none;
}

/* Hover: glow se intensifica + card se eleva */
.glow-card:hover .glow-bg{
  opacity:.85;
  filter:blur(50px);
}
.glow-card:hover .glow-inner{
  transform:translateY(-4px);
}

/* Ícono del card */
.glow-card .glow-ic{
  width:44px;
  height:44px;
  border-radius:12px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.95);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.glow-card .glow-ic .lucide{
  width:22px;
  height:22px;
  stroke-width:2.2;
}

/* Texto del card */
.glow-card strong{
  font-family:"Poppins", sans-serif;
  font-weight:600;
  color:#fff;
  font-size:1.05rem;
  letter-spacing:-.01em;
  display:block;
  margin-bottom:8px;
  line-height:1.3;
}
.glow-card p{
  color:rgba(255,255,255,.55);
  font-size:.88rem;
  line-height:1.6;
}

/* CTAs de la sección oscura */
.why-ctas-dark{
  display:flex;
  gap:14px;
  margin-top:48px;
  justify-content:center;
  flex-wrap:wrap;
}
.btn-ghost-light{
  background:rgba(255,255,255,.06);
  color:#fff;
  border:1px solid rgba(255,255,255,.15);
  padding:14px 26px;
  border-radius:99px;
  font-weight:600;
  font-size:.92rem;
  transition:background .25s ease, border-color .25s ease;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.btn-ghost-light:hover{
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.3);
}

/* Responsive */
@media (max-width:980px){
  .why-features-glow{grid-template-columns:repeat(2, 1fr);gap:24px}
}
@media (max-width:640px){
  .why-features-glow{grid-template-columns:1fr;gap:32px;max-width:340px}
  .why-head{padding-bottom:36px}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .glow-card .glow-bg, .glow-card .glow-inner{transition:none !important}
}

/* ============================================================
   SECCIÓN MÉTODO IMC — Fondo navy (separación con Servicios)
   ============================================================ */

/* Fondo navy con gradiente sutil */
.section-navy{
  background:linear-gradient(180deg, #0A1B3D 0%, #102A52 50%, #0A1B3D 100%);
  position:relative;
  overflow:hidden;
  color:#fff;
}
.section-navy .wrap{position:relative;z-index:2}

/* Glow sutil de fondo */
.method-bg-glow{
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background:
    radial-gradient(700px circle at 25% 40%, rgba(77,168,218,.12) 0%, transparent 55%),
    radial-gradient(600px circle at 75% 60%, rgba(127,208,242,.08) 0%, transparent 55%);
}

/* Patrón hexagonal sutil de fondo */
.section-navy::before{
  content:'';
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 52' opacity='0.04'%3E%3Cpath d='M30 0 L60 17.32 L60 51.96 L30 69.28 L0 51.96 L0 17.32 Z' fill='none' stroke='%23ffffff' stroke-width='1'/%3E%3C/svg%3E");
  background-size:60px 52px;
  opacity:.6;
}

/* === Tarjetas method en versión dark === */
.method-card-dark{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.method-card-dark h3{
  color:#fff;
}
.method-card-dark p{
  color:rgba(255,255,255,.65);
}
.method-card-dark .method-num{
  color:rgba(127,208,242,.7);
}
.method-card-dark .ic{
  background:rgba(127,208,242,.15);
  color:#7FD0F2;
  border:1px solid rgba(127,208,242,.25);
}
/* Featured (segunda card) destaca más */
.method-card-dark.featured{
  background:linear-gradient(135deg, rgba(127,208,242,.18) 0%, rgba(30,124,181,.10) 100%);
  border-color:rgba(127,208,242,.35);
  box-shadow:
    0 20px 50px rgba(0,0,0,.25),
    0 0 60px rgba(127,208,242,.15),
    inset 0 1px 0 rgba(255,255,255,.1);
}
.method-card-dark.featured .ic{
  background:rgba(127,208,242,.25);
  color:#fff;
  border-color:rgba(127,208,242,.4);
}

/* === DIVIDERS entre secciones === */
/* Wave divider entre Método (navy) y Servicios (blanco) */
.section-navy + .section.services::before{
  content:'';
  display:block;
  position:absolute;
  top:-1px;
  left:0;
  right:0;
  height:60px;
  background:#fff;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60' preserveAspectRatio='none'%3E%3Cpath d='M0,30 Q360,0 720,30 T1440,30 L1440,0 L0,0 Z' fill='%23000'/%3E%3C/svg%3E") center / cover no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60' preserveAspectRatio='none'%3E%3Cpath d='M0,30 Q360,0 720,30 T1440,30 L1440,0 L0,0 Z' fill='%23000'/%3E%3C/svg%3E") center / cover no-repeat;
  pointer-events:none;
  z-index:5;
  transform:scaleY(-1);
}
/* La section services debe ser relative para el ::before del divider */
.section.services{position:relative}
.section.services > .wrap{position:relative;z-index:2;padding-top:30px}

/* on-dark eyebrow (cyan brillante sobre fondo navy) */
.eyebrow.on-dark{color:#7FD0F2}
.eyebrow.on-dark::before{background:#7FD0F2}

/* ============================================================
   ANIMACIONES METHOD CARDS DARK — Hover + glow respirante
   ============================================================ */

/* Transición base */
.method-card-dark{
  transition:transform .4s cubic-bezier(.2,.8,.3,1),
             border-color .3s ease,
             box-shadow .4s ease,
             background .3s ease;
  position:relative;
  overflow:hidden;
}

/* Hover: las 3 cards se elevan + glow + cambio borde */
.method-card-dark:hover{
  transform:translateY(-6px);
  border-color:rgba(127,208,242,.35);
  background:rgba(255,255,255,.07);
  box-shadow:
    0 25px 50px rgba(0,0,0,.4),
    0 0 60px rgba(127,208,242,.18),
    inset 0 1px 0 rgba(255,255,255,.12);
}

/* La card destacada (Intervención) ya tiene glow base — al hover crece */
.method-card-dark.featured:hover{
  transform:translateY(-8px);
  border-color:rgba(127,208,242,.55);
  box-shadow:
    0 30px 60px rgba(0,0,0,.45),
    0 0 80px rgba(127,208,242,.28),
    inset 0 1px 0 rgba(255,255,255,.15);
}

/* El número 01/02/03 también pulsa cuando hace hover */
.method-card-dark .method-num{
  transition:transform .35s cubic-bezier(.2,.8,.3,1), color .3s ease;
}
.method-card-dark:hover .method-num{
  transform:scale(1.1);
  color:#7FD0F2;
}

/* El ícono también se ilumina al hover */
.method-card-dark .ic{
  transition:transform .35s cubic-bezier(.2,.8,.3,1),
             background .3s ease,
             box-shadow .3s ease;
}
.method-card-dark:hover .ic{
  transform:scale(1.08) rotate(-4deg);
  background:rgba(127,208,242,.28);
  box-shadow:0 0 20px rgba(127,208,242,.25);
}

/* Borde gradient sutil que respira (sólo en featured) */
.method-card-dark.featured::before{
  content:'';
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  padding:1px;
  background:linear-gradient(135deg,
    rgba(127,208,242,.5) 0%,
    rgba(255,255,255,.1) 50%,
    rgba(127,208,242,.5) 100%);
  background-size:200% 200%;
  -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  pointer-events:none;
  animation:methodBorderShift 6s ease-in-out infinite;
  opacity:.7;
}
@keyframes methodBorderShift{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .method-card-dark, .method-card-dark .method-num,
  .method-card-dark .ic, .method-card-dark.featured::before{
    transition:none !important;
    animation:none !important;
  }
}

/* ============================================================
   AJUSTES — Coral en Método + Levitación neon del reporte InBody
   ============================================================ */

/* === 1. CARD DESTACADA "02" CON ACENTOS CORAL === */
/* La card del medio (Intervención Personalizada) ahora tiene tonos coral en lugar de solo cyan */
.method-card-dark.featured{
  background:linear-gradient(135deg,
    rgba(255,107,82,.15) 0%,
    rgba(127,208,242,.08) 60%,
    rgba(30,124,181,.10) 100%);
  border-color:rgba(255,107,82,.30);
  box-shadow:
    0 20px 50px rgba(0,0,0,.25),
    0 0 60px rgba(255,107,82,.15),
    inset 0 1px 0 rgba(255,255,255,.1);
}
.method-card-dark.featured:hover{
  border-color:rgba(255,107,82,.55);
  box-shadow:
    0 30px 60px rgba(0,0,0,.45),
    0 0 80px rgba(255,107,82,.30),
    inset 0 1px 0 rgba(255,255,255,.15);
}
.method-card-dark.featured .ic{
  background:rgba(255,107,82,.20);
  color:#FFB1A8;
  border-color:rgba(255,107,82,.35);
}
.method-card-dark.featured:hover .ic{
  background:rgba(255,107,82,.32);
  color:#fff;
  box-shadow:0 0 20px rgba(255,107,82,.30);
}
.method-card-dark.featured .method-num{
  color:rgba(255,177,168,.85) !important;
}
.method-card-dark.featured:hover .method-num{
  color:#FFB1A8 !important;
}

/* Borde gradient cyan→coral respirando (mejora del existente) */
.method-card-dark.featured::before{
  background:linear-gradient(135deg,
    rgba(127,208,242,.5) 0%,
    rgba(255,255,255,.15) 40%,
    rgba(255,107,82,.5) 100%) !important;
  background-size:200% 200% !important;
}

/* === 2. REPORTE INBODY FLOTANTE CON NEÓN === */

/* Levitación: el card se mueve suavemente arriba/abajo */
.hero-card{
  animation:floatLevitate 6s ease-in-out infinite,
            cardGlow 5s ease-in-out infinite;
  will-change:transform;
}
@keyframes floatLevitate{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}

/* Mejorar el glow para que se vea más "neón" — cyan + coral pulsando alternado */
@keyframes cardGlow{
  0%,100%{
    box-shadow:
      0 30px 80px rgba(0,0,0,.5),
      inset 0 1px 0 rgba(255,255,255,.15),
      0 0 100px rgba(77,168,218,.35),
      0 0 60px rgba(127,208,242,.25),
      0 0 30px rgba(127,208,242,.15);
  }
  50%{
    box-shadow:
      0 30px 80px rgba(0,0,0,.5),
      inset 0 1px 0 rgba(255,255,255,.20),
      0 0 120px rgba(255,107,82,.30),
      0 0 80px rgba(127,208,242,.32),
      0 0 40px rgba(255,107,82,.18);
  }
}

/* Sombra adicional bajo el card para reforzar "flotación" */
.hero-visual{
  position:relative;
}
.hero-visual::after{
  content:'';
  position:absolute;
  bottom:-30px;
  left:50%;
  transform:translateX(-50%);
  width:60%;
  height:30px;
  background:radial-gradient(ellipse,
    rgba(0,0,0,.4) 0%,
    rgba(0,0,0,.15) 40%,
    transparent 70%);
  filter:blur(20px);
  z-index:-1;
  animation:shadowPulse 6s ease-in-out infinite;
  pointer-events:none;
}
@keyframes shadowPulse{
  0%,100%{transform:translateX(-50%) scaleX(1);opacity:.5}
  50%{transform:translateX(-50%) scaleX(.85);opacity:.7}
}

/* Floating stat también flota pero con un ritmo diferente para crear interés */
.floating-stat{
  animation:floatLevitate2 7s ease-in-out infinite;
  animation-delay:-2s;
}
@keyframes floatLevitate2{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-6px)}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .hero-card, .floating-stat, .hero-visual::after{animation:none !important}
}

/* ============================================================
   TEAM CARDS — Glow neón cyan/coral (en todas las páginas)
   ============================================================ */

/* Wrapper relative para contener pseudo-elementos */
.team-card{
  position:relative;
  isolation:isolate;
  overflow:visible;
  transition:transform .4s cubic-bezier(.2,.8,.3,1),
             box-shadow .4s ease,
             border-color .3s ease;
}

/* Glow background detrás del card (gradiente difuminado) */
.team-card::before{
  content:'';
  position:absolute;
  inset:-8px;
  border-radius:calc(var(--r-lg) + 8px);
  background:linear-gradient(135deg,
    rgba(127,208,242,.45) 0%,
    rgba(255,255,255,.10) 45%,
    rgba(255,107,82,.40) 100%);
  filter:blur(20px);
  opacity:.35;
  z-index:-1;
  transition:opacity .4s ease, filter .4s ease;
  animation:teamGlowPulse 6s ease-in-out infinite;
}

@keyframes teamGlowPulse{
  0%,100%{opacity:.30;filter:blur(20px)}
  50%{opacity:.50;filter:blur(28px)}
}

/* Variantes de gradientes para crear ritmo entre cards */
.team-grid .team-card:nth-child(4n+1)::before{
  background:linear-gradient(135deg,
    rgba(127,208,242,.55) 0%,
    rgba(77,168,218,.30) 50%,
    rgba(30,124,181,.45) 100%);
}
.team-grid .team-card:nth-child(4n+2)::before{
  background:linear-gradient(135deg,
    rgba(255,255,255,.45) 0%,
    rgba(127,208,242,.40) 50%,
    rgba(30,124,181,.40) 100%);
}
.team-grid .team-card:nth-child(4n+3)::before{
  background:linear-gradient(135deg,
    rgba(255,107,82,.45) 0%,
    rgba(255,177,168,.30) 50%,
    rgba(127,208,242,.35) 100%);
}
.team-grid .team-card:nth-child(4n+4)::before{
  background:linear-gradient(135deg,
    rgba(127,208,242,.45) 0%,
    rgba(255,255,255,.30) 50%,
    rgba(255,107,82,.40) 100%);
}

/* Card hover: el glow se intensifica + lift más alto */
.team-card:hover{
  transform:translateY(-6px);
  border-color:rgba(127,208,242,.4);
  box-shadow:
    0 25px 60px rgba(0,0,0,.12),
    0 0 0 1px rgba(127,208,242,.15);
}
.team-card:hover::before{
  opacity:.70;
  filter:blur(28px);
}

/* Borde sutil iluminado en la parte superior (línea decorativa) */
.team-card::after{
  content:'';
  position:absolute;
  top:0;
  left:20%;
  right:20%;
  height:1px;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(127,208,242,.6) 50%,
    transparent 100%);
  opacity:.5;
  transition:opacity .3s ease;
  pointer-events:none;
}
.team-card:hover::after{
  opacity:1;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .team-card, .team-card::before{animation:none !important;transition:none !important}
}

/* ============================================================
   SECCIÓN EQUIPO NAVY SUAVE — Transición visual con Planes
   ============================================================ */

/* Navy suave (más claro que Método) para crear variedad visual */
.section-navy-soft{
  background:linear-gradient(180deg, #0F1F3D 0%, #142849 50%, #0F1F3D 100%);
  position:relative;
  overflow:hidden;
  color:#fff;
}
.section-navy-soft .wrap{position:relative;z-index:2}

/* Glow sutil de fondo para Equipo */
.team-bg-glow{
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background:
    radial-gradient(700px circle at 30% 30%, rgba(127,208,242,.10) 0%, transparent 55%),
    radial-gradient(600px circle at 70% 70%, rgba(255,107,82,.08) 0%, transparent 55%);
}

/* Patrón hexagonal sutil */
.section-navy-soft::before{
  content:'';
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 52' opacity='0.04'%3E%3Cpath d='M30 0 L60 17.32 L60 51.96 L30 69.28 L0 51.96 L0 17.32 Z' fill='none' stroke='%23ffffff' stroke-width='1'/%3E%3C/svg%3E");
  background-size:60px 52px;
  opacity:.5;
}

/* === TEAM CARDS SOBRE FONDO NAVY === */
/* Las cards mantienen fondo blanco para legibilidad y contraste */
.section-navy-soft .team-card{
  background:#fff;
  /* glow gradient se mantiene del bloque anterior */
}

/* El borde se ve mejor con un toque cyan luminoso */
.section-navy-soft .team-card{
  border:1px solid rgba(255,255,255,.15);
  box-shadow:
    0 10px 30px rgba(0,0,0,.25),
    inset 0 1px 0 rgba(255,255,255,.05);
}

.section-navy-soft .team-card:hover{
  border-color:rgba(127,208,242,.4);
  box-shadow:
    0 25px 50px rgba(0,0,0,.35),
    0 0 0 1px rgba(127,208,242,.25);
}

/* Glow más fuerte para que destaque sobre el navy */
.section-navy-soft .team-card::before{
  opacity:.55;
  filter:blur(28px);
}
.section-navy-soft .team-card:hover::before{
  opacity:.85;
  filter:blur(35px);
}

/* === WAVE DIVIDER entre Equipo (navy) y Planes (blanco) === */
.section-navy-soft + .section.pricing{position:relative}
.section-navy-soft + .section.pricing::before{
  content:'';
  display:block;
  position:absolute;
  top:-1px;
  left:0;
  right:0;
  height:60px;
  background:#fff;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60' preserveAspectRatio='none'%3E%3Cpath d='M0,30 Q360,0 720,30 T1440,30 L1440,0 L0,0 Z' fill='%23000'/%3E%3C/svg%3E") center / cover no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60' preserveAspectRatio='none'%3E%3Cpath d='M0,30 Q360,0 720,30 T1440,30 L1440,0 L0,0 Z' fill='%23000'/%3E%3C/svg%3E") center / cover no-repeat;
  pointer-events:none;
  z-index:5;
  transform:scaleY(-1);
}
.section-navy-soft + .section.pricing > .wrap{position:relative;z-index:2;padding-top:50px}

/* ============================================================
   AUDITORÍA GLOBAL — Transiciones y glow universal
   Resuelve sin tocar 20 archivos HTML
   ============================================================ */

/* === 1. MEJORAR CONTRASTE bg-soft vs blanco === */
/* Antes era casi igual. Ahora un gris azulado muy claro perceptible */
:root{
  --bg-soft: #EEF2F7;       /* gris azulado claro — perceptible */
  --bg-soft-blue: #E8EFF7;  /* variante con tinte cyan más visible */
}

/* === 2. DIVIDER UNIVERSAL: separador entre toda sección bg-soft y la siguiente === */
/* Línea fina decorativa con gradient cyan que aparece al cambiar de fondo */
.section[style*="bg-soft"] + .section:not([style*="bg-soft"])::before,
.section:not([style*="bg-soft"]) + .section[style*="bg-soft"]::before{
  content:'';
  position:absolute;
  top:0;
  left:50%;
  transform:translateX(-50%);
  width:120px;
  height:3px;
  background:linear-gradient(90deg, transparent, var(--blue-3, #4DA8DA), transparent);
  opacity:.5;
  border-radius:99px;
}
/* Cada section needs to be relative for the ::before to position */
section.section{position:relative}

/* === 3. GLOW NEÓN UNIVERSAL EN CARDS === */
/* Aplicado a: service-card, plan, review, post, method-card (blanco), case-card, step-card */

/* Wrapper común — todas estas cards reciben glow detrás */
.service-card,
.plan,
.review,
.post,
.method-card:not(.method-card-dark),
.case-card,
.step-card{
  position:relative;
  isolation:isolate;
  transition:transform .4s cubic-bezier(.2,.8,.3,1),
             box-shadow .4s ease,
             border-color .3s ease;
}

/* Glow gradient detrás */
.service-card::before,
.plan::before,
.review::before,
.post::before,
.method-card:not(.method-card-dark)::before,
.case-card::before,
.step-card::before{
  content:'';
  position:absolute;
  inset:-6px;
  border-radius:calc(var(--r-lg, 16px) + 6px);
  background:linear-gradient(135deg,
    rgba(127,208,242,.35) 0%,
    rgba(255,255,255,.10) 45%,
    rgba(255,107,82,.30) 100%);
  filter:blur(18px);
  opacity:.25;
  z-index:-1;
  transition:opacity .4s ease, filter .4s ease;
  pointer-events:none;
}

/* Variantes de gradiente cíclicas para crear ritmo */
/* Service cards y plans suelen ir en grupos de 3-4 */
.services-grid > .service-card:nth-child(3n+1)::before,
.plans-grid > .plan:nth-child(3n+1)::before,
.pricing-grid > .plan:nth-child(3n+1)::before,
.cases-grid > .case-card:nth-child(3n+1)::before,
.posts-grid > .post:nth-child(3n+1)::before{
  background:linear-gradient(135deg,
    rgba(127,208,242,.45) 0%,
    rgba(77,168,218,.20) 50%,
    rgba(30,124,181,.35) 100%);
}
.services-grid > .service-card:nth-child(3n+2)::before,
.plans-grid > .plan:nth-child(3n+2)::before,
.pricing-grid > .plan:nth-child(3n+2)::before,
.cases-grid > .case-card:nth-child(3n+2)::before,
.posts-grid > .post:nth-child(3n+2)::before{
  background:linear-gradient(135deg,
    rgba(255,255,255,.30) 0%,
    rgba(127,208,242,.40) 50%,
    rgba(30,124,181,.30) 100%);
}
.services-grid > .service-card:nth-child(3n+3)::before,
.plans-grid > .plan:nth-child(3n+3)::before,
.pricing-grid > .plan:nth-child(3n+3)::before,
.cases-grid > .case-card:nth-child(3n+3)::before,
.posts-grid > .post:nth-child(3n+3)::before{
  background:linear-gradient(135deg,
    rgba(255,107,82,.40) 0%,
    rgba(255,177,168,.25) 50%,
    rgba(127,208,242,.30) 100%);
}

/* Method cards (blancos, en metodo.html) — siempre 3 */
.method-grid > .method-card:not(.method-card-dark):nth-child(3n+1)::before{
  background:linear-gradient(135deg, rgba(127,208,242,.40) 0%, rgba(30,124,181,.30) 100%);
}
.method-grid > .method-card:not(.method-card-dark):nth-child(3n+2)::before{
  background:linear-gradient(135deg, rgba(127,208,242,.35) 0%, rgba(255,107,82,.30) 100%);
}
.method-grid > .method-card:not(.method-card-dark):nth-child(3n+3)::before{
  background:linear-gradient(135deg, rgba(255,107,82,.35) 0%, rgba(127,208,242,.30) 100%);
}

/* Reviews — variantes */
.reviews-rail > .review:nth-child(3n+1)::before,
.reviews-grid > .review:nth-child(3n+1)::before{
  background:linear-gradient(135deg, rgba(127,208,242,.40) 0%, rgba(30,124,181,.25) 100%);
}
.reviews-rail > .review:nth-child(3n+2)::before,
.reviews-grid > .review:nth-child(3n+2)::before{
  background:linear-gradient(135deg, rgba(255,107,82,.35) 0%, rgba(255,177,168,.25) 100%);
}
.reviews-rail > .review:nth-child(3n+3)::before,
.reviews-grid > .review:nth-child(3n+3)::before{
  background:linear-gradient(135deg, rgba(127,208,242,.35) 0%, rgba(255,107,82,.30) 100%);
}

/* === HOVER: glow intensifica + lift === */
.service-card:hover,
.plan:hover,
.review:hover,
.post:hover,
.method-card:not(.method-card-dark):hover,
.case-card:hover,
.step-card:hover{
  transform:translateY(-5px);
  box-shadow:
    0 25px 50px rgba(0,0,0,.10),
    0 0 0 1px rgba(127,208,242,.15);
}

.service-card:hover::before,
.plan:hover::before,
.review:hover::before,
.post:hover::before,
.method-card:not(.method-card-dark):hover::before,
.case-card:hover::before,
.step-card:hover::before{
  opacity:.55;
  filter:blur(24px);
}

/* === Plan featured (Standard) — más prominente === */
.plan.featured::before{
  opacity:.40;
  background:linear-gradient(135deg,
    rgba(255,107,82,.45) 0%,
    rgba(127,208,242,.35) 50%,
    rgba(255,107,82,.40) 100%) !important;
}
.plan.featured:hover::before{
  opacity:.70;
}

/* Asegurar que cards mantengan fondo blanco visible sobre el glow */
.service-card, .plan, .review, .post, .case-card, .step-card,
.method-card:not(.method-card-dark){
  background:#fff;
  position:relative;
  z-index:1;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .service-card, .plan, .review, .post, .case-card, .step-card,
  .method-card:not(.method-card-dark),
  .service-card::before, .plan::before, .review::before, .post::before,
  .case-card::before, .step-card::before,
  .method-card:not(.method-card-dark)::before{
    transition:none !important;
    animation:none !important;
  }
}

/* ============================================================
   AUDITORÍA — Cards faltantes (why-feat, case-card, faq-item)
   ============================================================ */

/* === WHY-FEAT cards (boxes blancas con ícono pequeño) === */
.why-feat{
  position:relative;
  isolation:isolate;
  background:#fff;
  border:1px solid rgba(0,0,0,.04);
  transition:transform .35s cubic-bezier(.2,.8,.3,1),
             box-shadow .35s ease;
}

.why-feat::before{
  content:'';
  position:absolute;
  inset:-5px;
  border-radius:calc(var(--r-md, 12px) + 5px);
  background:linear-gradient(135deg,
    rgba(127,208,242,.30) 0%,
    rgba(255,255,255,.15) 45%,
    rgba(255,107,82,.25) 100%);
  filter:blur(15px);
  opacity:.20;
  z-index:-1;
  transition:opacity .35s ease, filter .35s ease;
  pointer-events:none;
}

/* Variantes para crear ritmo entre las why-feat cards */
.why-features > .why-feat:nth-child(3n+1)::before{
  background:linear-gradient(135deg, rgba(127,208,242,.35) 0%, rgba(30,124,181,.20) 100%);
}
.why-features > .why-feat:nth-child(3n+2)::before{
  background:linear-gradient(135deg, rgba(127,208,242,.30) 0%, rgba(255,107,82,.25) 100%);
}
.why-features > .why-feat:nth-child(3n+3)::before{
  background:linear-gradient(135deg, rgba(255,107,82,.30) 0%, rgba(127,208,242,.25) 100%);
}

.why-feat:hover{
  transform:translateY(-3px);
  box-shadow:0 15px 35px rgba(0,0,0,.08), 0 0 0 1px rgba(127,208,242,.15);
}
.why-feat:hover::before{
  opacity:.50;
  filter:blur(22px);
}

/* === CASE CARDS (en casos-exito.html) === */
.case-card{
  position:relative;
  isolation:isolate;
  background:#fff;
  transition:transform .4s cubic-bezier(.2,.8,.3,1),
             box-shadow .4s ease;
}

.case-card::before{
  content:'';
  position:absolute;
  inset:-6px;
  border-radius:calc(var(--r-lg, 16px) + 6px);
  background:linear-gradient(135deg,
    rgba(127,208,242,.35) 0%,
    rgba(255,255,255,.10) 45%,
    rgba(255,107,82,.30) 100%);
  filter:blur(20px);
  opacity:.25;
  z-index:-1;
  transition:opacity .4s ease, filter .4s ease;
  pointer-events:none;
}

.cases-grid > .case-card:nth-child(4n+1)::before{
  background:linear-gradient(135deg, rgba(127,208,242,.40) 0%, rgba(30,124,181,.25) 100%);
}
.cases-grid > .case-card:nth-child(4n+2)::before{
  background:linear-gradient(135deg, rgba(255,255,255,.30) 0%, rgba(127,208,242,.40) 100%);
}
.cases-grid > .case-card:nth-child(4n+3)::before{
  background:linear-gradient(135deg, rgba(255,107,82,.35) 0%, rgba(255,177,168,.20) 100%);
}
.cases-grid > .case-card:nth-child(4n+4)::before{
  background:linear-gradient(135deg, rgba(127,208,242,.35) 0%, rgba(255,107,82,.30) 100%);
}

.case-card:hover{
  transform:translateY(-5px);
  box-shadow:0 25px 50px rgba(0,0,0,.10), 0 0 0 1px rgba(127,208,242,.20);
}
.case-card:hover::before{
  opacity:.55;
  filter:blur(26px);
}

/* === FAQ ITEMS — glow sutil al hacer hover === */
.faq-item{
  position:relative;
  background:#fff;
  border:1px solid rgba(0,0,0,.05);
  transition:border-color .3s ease, box-shadow .3s ease;
}

.faq-item:hover{
  border-color:rgba(127,208,242,.4);
  box-shadow:0 8px 20px rgba(0,0,0,.06), 0 0 20px rgba(127,208,242,.10);
}

.faq-item.open{
  border-color:rgba(127,208,242,.5);
  box-shadow:0 10px 25px rgba(0,0,0,.08), 0 0 25px rgba(127,208,242,.12);
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .why-feat, .why-feat::before,
  .case-card, .case-card::before,
  .faq-item{transition:none !important}
}

/* ============================================================
   RESPONSIVE — Audit móvil: imágenes y secciones
   Corrige: imágenes cortadas, contenedores demasiado altos,
   scroll horizontal, sidebars sticky en móvil.
   ============================================================ */

/* Prevenir scroll horizontal global (floating-stat, glows, etc.) */
html, body{overflow-x:hidden}

/* Imágenes dentro de avatares: que hereden la forma circular */
.avatar img,
.panel-pro .av img,
.case-meta .av img,
.review-foot .av img,
.aside-card.author .av img,
.page-hero-grid .meta-card .ic img{
  width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block;
}

/* === TABLET (≤1024px) === */
@media (max-width:1024px){
  /* tab-panel: pasar a una sola columna en tablet/móvil */
  .tab-panel{grid-template-columns:1fr;gap:0}
  /* panel-media: ratio vertical (4/5) y crop desde arriba para no cortar
     cabezas ni equipos verticales (InBody, EMSzero) */
  .panel-media{min-height:auto;aspect-ratio:4/5;max-height:520px}
  .panel-media img{object-position:center top}
  .panel-body{padding:24px 22px}
  /* Article aside: dejar de ser sticky, va debajo del contenido */
  .article-aside{position:static}
}

/* === MÓVIL TABLET (≤768px) === */
@media (max-width:768px){
  /* stack-images: convertir overlap absoluto en stack vertical
     Aspect-ratio 4/5 (vertical) y object-position superior porque las
     fotos originales son retrato y deben mostrar cabeza completa */
  .stack-images{aspect-ratio:auto;display:flex;flex-direction:column;gap:14px;padding-bottom:0}
  .stack-images .ph{position:relative;border-radius:var(--r-md)}
  .stack-images .ph.a,
  .stack-images .ph.b{width:100%;height:auto;aspect-ratio:4/5;top:auto;left:auto;right:auto;bottom:auto}
  .stack-images .ph img{object-position:center top}
  .stack-images .ph.b{border-width:4px}
  .stack-images .ph-badge{position:relative;bottom:auto;left:auto;margin:6px auto 0;align-self:flex-start}
  /* Map iframe más bajo */
  .map-wrap{height:300px}
}

/* === MÓVIL (≤640px) === */
@media (max-width:640px){
  /* Padding general más compacto */
  .wrap{padding:0 18px}
  .section{padding:56px 0}
  .section-head{margin-bottom:32px}
  /* Hero más compacto */
  .hero{padding:48px 0 80px}
  .hero h1{margin-top:14px}
  .hero .lede{font-size:1rem}
  .hero-ctas{margin-top:24px;gap:10px}
  .hero-visual{max-width:100%;padding:0}
  .hero-card{padding:18px}
  .composition{gap:10px}
  .comp-label{width:110px;font-size:.78rem}
  .comp-val{width:46px;font-size:.84rem}
  /* Floating stat: queda dentro del flujo, sin solapar */
  .floating-stat{position:static;transform:none;margin:24px auto 0;max-width:280px;left:auto;bottom:auto;width:fit-content}
  /* Why-visual: ratio vertical y crop desde arriba para mantener
     cabezas y partes superiores de equipos visibles */
  .why-visual{aspect-ratio:4/5;max-width:100%;max-height:520px}
  .why-visual img{object-position:center top}
  /* Team cards más compactas */
  .avatar{width:100px;height:100px}
  .team-card{padding:20px 18px}
  /* Method cards */
  .method-card{padding:24px 22px}
  /* Glow cards (Por qué somos) */
  .glow-card{min-height:200px}
  .glow-card .glow-inner{min-height:200px;padding:22px}
  /* CTA band centrado */
  .cta-band{padding:28px 22px;text-align:center;gap:18px}
  .cta-band .actions{justify-content:center}
  /* Contact: padding y mapa */
  .contact-info,.contact-form{padding:24px}
  .map-wrap{height:260px}
  /* Article prose key-stat */
  .prose .key-stat{grid-template-columns:1fr;padding:24px;gap:14px}
  .prose .key-stat .ic{width:48px;height:48px}
  /* Page hero meta cards más compactas */
  .page-hero-grid{gap:24px}
  .page-hero-grid .meta-card{padding:14px;gap:10px}
  /* Footer: padding inferior */
  footer.site{padding-top:48px}
  /* Reseñas: card al ancho casi completo */
  .review{padding:22px}
}

/* === MÓVIL PEQUEÑO (≤480px) === */
@media (max-width:480px){
  .logo-img{height:36px}
  .header-cta{gap:8px}
  .topbar-left{gap:10px;font-size:.72rem}
  .hero-pill{font-size:.7rem;padding:5px 11px}
  .hero h1{font-size:clamp(1.8rem,7vw,2.4rem)}
  /* Hero card: que el header del card no rompa */
  .hero-card-title{flex-wrap:wrap;gap:8px}
  .hero-card-title .badge{font-size:.62rem;padding:3px 8px}
  .hero-card-foot{flex-direction:column;align-items:flex-start;gap:6px}
  /* BMI calc */
  .bmi-card{padding:24px 20px}
  .bmi-number{font-size:clamp(2.6rem,11vw,3.6rem)}
  /* Aside author avatar más chico */
  .aside-card.author .av{width:64px;height:64px;font-size:1.2rem}
}
