/* =====================================================================
   HarmoniMD — sitio unificado · Sistema de diseño (guía HarmoniMD, estilo Apple)
   Paleta: Yale #204273 · Denim #1164C2 · Pumpkin #FF6D02 · Gris #E6E9EC
   Tipografía: DM Sans
   ===================================================================== */
:root{
  --yale:#204273; --gris:#E6E9EC; --denim:#1164C2; --pumpkin:#FF6D02;
  --ink:#16243b; --muted:#5b6b82; --line:#e6eaf0; --white:#fff;
  --bg-soft:#eef2f9; --yale-2:#16335c; --yale-3:#1b3a66;
  --r:22px; --r-lg:30px;
  --shadow:0 24px 60px rgba(22,40,70,.12); --shadow-sm:0 10px 30px rgba(22,40,70,.08);
  --shadow-lg:0 40px 90px rgba(22,40,70,.18);
  --grad-dark:linear-gradient(155deg,#1b3a66 0%,var(--yale) 52%,#13315a 100%);
  --grad-denim:linear-gradient(150deg,var(--denim),var(--yale));
  --maxw:1200px; --ease:cubic-bezier(.16,.7,.3,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:'DM Sans',system-ui,-apple-system,sans-serif;color:var(--ink);background:var(--white);
  line-height:1.6;font-weight:400;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4,h5{font-weight:600;line-height:1.1;color:var(--yale);letter-spacing:-.02em}
h1{font-size:clamp(2.3rem,4.8vw,3.7rem);font-weight:700;letter-spacing:-.03em}
h2{font-size:clamp(1.75rem,3.6vw,2.8rem);font-weight:700;letter-spacing:-.02em}
h3{font-size:clamp(1.25rem,2vw,1.5rem)}
h4{font-size:1.05rem}
p{color:var(--muted)}
a{text-decoration:none;color:inherit}
img,svg{max-width:100%;display:block}
/* Los atributos width/height (anti-CLS) reservan el espacio pero NO deben fijar la
   altura: height:auto deja que el aspect-ratio/proporción natural manden. Las imágenes
   de tamaño fijo (avatares, premios) conservan su height por mayor especificidad. */
img{height:auto}
b,strong{font-weight:600;color:inherit}
::selection{background:var(--pumpkin);color:#fff}

.wrap{width:min(var(--maxw),92%);margin-inline:auto}
.wrap-wide{width:min(1340px,94%);margin-inline:auto}
.section{padding:clamp(3.6rem,8vw,7rem) 0}
.section-tight{padding:clamp(2.6rem,5vw,4rem) 0}
.center{text-align:center}
.eyebrow{display:inline-block;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--denim);font-size:.78rem;margin-bottom:1rem}
.eyebrow.on-dark{color:#ff9a52}
.lead{font-size:clamp(1.08rem,1.6vw,1.32rem);color:var(--muted);max-width:680px;line-height:1.55}
.center .lead{margin-inline:auto}
.mt1{margin-top:1rem}.mt2{margin-top:1.8rem}.mt3{margin-top:2.6rem}
.kicker{color:var(--muted);font-size:1.05rem;max-width:640px}

/* ---------- Botones ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:1rem;
  padding:.9rem 1.7rem;border-radius:999px;border:2px solid transparent;cursor:pointer;
  transition:transform .25s var(--ease),background .2s,box-shadow .25s,color .2s;white-space:nowrap;position:relative;overflow:hidden}
.btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.2;flex:0 0 auto;transition:transform .3s var(--ease)}
.btn:hover svg{transform:translateX(3px)}
.btn-primary{background:var(--pumpkin);color:#fff;box-shadow:0 12px 26px rgba(255,109,2,.30)}
.btn-primary:hover{background:#ec6100;transform:translateY(-2px);box-shadow:0 18px 34px rgba(255,109,2,.36)}
.btn-primary:after{content:"";position:absolute;top:0;left:-120%;width:55%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.4),transparent);transform:skewX(-18deg);transition:left .6s ease}
.btn-primary:hover:after{left:140%}
.btn-dark{background:var(--yale);color:#fff;box-shadow:0 12px 26px rgba(32,66,115,.26)}
.btn-dark:hover{background:var(--yale-2);transform:translateY(-2px)}
.btn-ghost{background:transparent;border-color:rgba(255,255,255,.55);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.14);transform:translateY(-2px)}
.btn-outline{background:#fff;border-color:var(--denim);color:var(--denim)}
.btn-outline:hover{background:var(--denim);color:#fff;transform:translateY(-2px)}
.btn-text{padding:.4rem 0;color:var(--denim);font-weight:600;border:none}
.btn-text:hover{color:var(--yale)}
.btn-lg{padding:1.05rem 2rem;font-size:1.06rem}
.actions{display:flex;gap:.9rem;flex-wrap:wrap}
.center .actions{justify-content:center}

/* ---------- Foco visible (accesibilidad por teclado) ---------- */
a:focus-visible,button:focus-visible,summary:focus-visible,input:focus-visible,[tabindex]:focus-visible{
  outline:3px solid var(--denim);outline-offset:2px;border-radius:6px}
.btn-primary:focus-visible,.btn-dark:focus-visible,.btn-ghost:focus-visible,.edition .btn-white:focus-visible,
.edition .btn-line:focus-visible,.hero .btn:focus-visible,.cta .btn:focus-visible{outline-color:#fff}
.mega-trigger:focus-visible{outline-offset:1px}

/* ================= HEADER / NAV (con mega-menú) ================= */
header{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.88);
  backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s,background .3s}
header.scrolled{border-bottom-color:var(--line);box-shadow:0 4px 24px rgba(22,40,70,.07)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{font-weight:700;font-size:1.55rem;color:var(--yale);letter-spacing:-.03em;display:flex;align-items:center}
.brand .md{color:var(--pumpkin)}
.menu{display:flex;gap:.4rem;align-items:center}
.menu>a,.mega-trigger{font-weight:500;color:var(--ink);font-size:.96rem;padding:.5rem .8rem;border-radius:10px;
  display:inline-flex;align-items:center;gap:.35rem;cursor:pointer;transition:color .2s,background .2s;
  background:none;border:none;font-family:inherit;line-height:1.4}
.menu>a:hover,.mega-trigger:hover{color:var(--denim);background:rgba(17,100,194,.06)}
.menu>a.active{color:var(--denim)}
.mega-trigger svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2.2;transition:transform .3s}
.has-mega{position:relative}
.has-mega.open .mega-trigger svg{transform:rotate(180deg)}
.menu a.menu-cta{display:none}

/* mega panel */
.mega{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(10px);
  width:min(720px,90vw);background:#fff;border:1px solid var(--line);border-radius:24px;
  box-shadow:var(--shadow-lg);padding:1.1rem;opacity:0;visibility:hidden;transition:opacity .28s var(--ease),transform .28s var(--ease);
  display:grid;grid-template-columns:1fr 1fr;gap:.7rem;z-index:210}
.has-mega.open .mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.mega:before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
.mega-card{display:flex;gap:.9rem;padding:1rem;border-radius:16px;transition:background .2s;align-items:flex-start}
.mega-card:hover{background:var(--bg-soft)}
.mega-card.full{grid-column:1 / -1;background:var(--gris)}
.mega-card.full:hover{background:#dde3ec}
.mega-ic{width:44px;height:44px;border-radius:12px;flex:0 0 auto;display:grid;place-items:center;color:#fff}
.mega-ic.his{background:var(--grad-denim)}
.mega-ic.go{background:linear-gradient(150deg,var(--pumpkin),#e85f00)}
.mega-ic.cmp{background:var(--yale)}
.mega-ic svg{width:24px;height:24px;stroke:#fff;fill:none;stroke-width:1.8}
.mega-card h4{color:var(--yale);font-size:1.02rem;margin-bottom:.15rem}
.mega-card p{font-size:.86rem;color:var(--muted);line-height:1.45}
.nav-right{display:flex;align-items:center;gap:.7rem}
.burger{display:none;width:44px;height:44px;border:none;background:transparent;cursor:pointer;
  flex-direction:column;justify-content:center;gap:5px;padding:9px}
.burger span{display:block;height:2.5px;width:100%;background:var(--yale);border-radius:2px;transition:.3s ease}
.burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ================= HERO ================= */
.hero{position:relative;background:var(--grad-dark);color:#fff;overflow:hidden}
.hero:before{content:"";position:absolute;right:-12%;top:-30%;width:60vw;height:60vw;max-width:760px;max-height:760px;
  background:radial-gradient(circle,rgba(255,109,2,.26),transparent 65%);border-radius:50%;pointer-events:none}
.hero:after{content:"";position:absolute;left:-15%;bottom:-40%;width:55vw;height:55vw;max-width:640px;max-height:640px;
  background:radial-gradient(circle,rgba(17,100,194,.40),transparent 68%);border-radius:50%;pointer-events:none}
.hero .wrap{position:relative;z-index:2}
.hero-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,4vw,3rem);align-items:center;
  padding:clamp(2.2rem,4.5vw,3.6rem) 0 clamp(2.2rem,4vw,3.2rem)}
.hero h1{color:#fff;max-width:16ch}
.hero .lead{color:rgba(255,255,255,.82);max-width:38ch;margin-top:1.1rem;font-size:clamp(1.05rem,1.5vw,1.24rem)}
.hero .actions{margin-top:1.6rem}
.hero-art{position:relative}
.hero-art img{border-radius:var(--r-lg);box-shadow:var(--shadow-lg);width:100%;aspect-ratio:5/4;object-fit:cover}
.hero-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.4rem}
.chip{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;color:rgba(255,255,255,.9);
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);padding:.42rem .85rem;border-radius:999px;backdrop-filter:blur(6px)}
.chip svg{width:14px;height:14px;stroke:#ff9a52;fill:none;stroke-width:2.2}
/* floating stat card on hero art */
.hero-float{position:absolute;background:rgba(255,255,255,.96);border-radius:18px;padding:1rem 1.2rem;
  box-shadow:var(--shadow);backdrop-filter:blur(8px);max-width:190px}
.hero-float .big{font-size:1.6rem;font-weight:700;color:var(--yale);line-height:1}
.hero-float small{color:var(--muted);font-size:.78rem}
.hero-float.a{left:-6%;bottom:8%}
.hero-float.b{right:-5%;top:10%}

/* ================= GENERIC SECTIONS ================= */
.soft{background:var(--bg-soft)}
.dark{background:var(--grad-dark);color:#fff}
.dark h2,.dark h3{color:#fff}
.dark p{color:rgba(255,255,255,.82)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.split.rev .col-txt{order:2}
.media{border-radius:var(--r);box-shadow:var(--shadow);width:100%;object-fit:cover;overflow:hidden}
.media-frame{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);background:#0d1f3a}
.media-frame img{width:100%;display:block;transition:transform 1s var(--ease)}
.media-frame:hover img{transform:scale(1.035)}
.grid{display:grid;gap:1.4rem}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}

/* ---------- Cards ---------- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.9rem;
  box-shadow:var(--shadow-sm);transition:transform .35s var(--ease),box-shadow .35s,border-color .35s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:#d4dded}
.card .ic{width:58px;height:58px;border-radius:15px;background:var(--bg-soft);color:var(--denim);
  display:grid;place-items:center;margin-bottom:1.1rem}
.card .ic svg{width:30px;height:30px;stroke:currentColor;fill:none;stroke-width:1.7}
.card h3{margin-bottom:.4rem;font-size:1.16rem}
.card p{font-size:.96rem;line-height:1.55}
.card .tag{display:inline-block;font-size:.7rem;font-weight:600;color:var(--pumpkin);
  background:rgba(255,109,2,.1);border-radius:999px;padding:.22rem .7rem;margin-bottom:.7rem}
.card-link{display:inline-flex;align-items:center;gap:.35rem;margin-top:1rem;color:var(--denim);font-weight:600;font-size:.92rem}
.card-link svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2.4;transition:transform .3s var(--ease)}
.card:hover .card-link svg{transform:translateX(4px)}

/* ================= EDITION SELECTOR (HIS vs GO) ================= */
.editions{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;margin-top:2.8rem}
.edition{position:relative;border-radius:var(--r-lg);padding:2.4rem;overflow:hidden;color:#fff;
  display:flex;flex-direction:column;min-height:430px;transition:transform .4s var(--ease),box-shadow .4s}
.edition:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.edition.his{background:var(--grad-dark)}
.edition.go{background:linear-gradient(155deg,#ff8a3d 0%,var(--pumpkin) 55%,#d95800 100%)}
.edition:before{content:"";position:absolute;right:-60px;top:-60px;width:240px;height:240px;
  background:radial-gradient(circle,rgba(255,255,255,.18),transparent 70%);border-radius:50%}
.edition .etag{font-size:.76rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.85);position:relative}
.edition h3{color:#fff;font-size:clamp(1.6rem,2.6vw,2.1rem);font-weight:700;margin:.5rem 0 .2rem;position:relative}
.edition .for{color:rgba(255,255,255,.85);font-size:1rem;position:relative}
.edition ul{list-style:none;margin:1.4rem 0;display:grid;gap:.6rem;position:relative}
.edition li{padding-left:1.7rem;position:relative;color:rgba(255,255,255,.94);font-size:.96rem}
.edition li:before{content:"";position:absolute;left:0;top:.5em;width:11px;height:6px;
  border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg)}
.edition .actions{margin-top:auto;position:relative}
.edition .btn-white{background:#fff;color:var(--yale)}
.edition.go .btn-white{color:#c2410c}
.edition .btn-white:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(0,0,0,.2)}
.edition .btn-line{background:transparent;border-color:rgba(255,255,255,.6);color:#fff}
.edition .btn-line:hover{background:rgba(255,255,255,.15)}

/* ================= STATS BAND ================= */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}
.stat .num{font-size:clamp(2.2rem,4.2vw,3.4rem);font-weight:700;color:var(--yale);line-height:1;letter-spacing:-.03em}
.dark .stat .num{color:#fff}
.stat .lbl{color:var(--muted);font-size:.95rem;margin-top:.5rem;display:block}
.dark .stat .lbl{color:rgba(255,255,255,.7)}

/* ================= CLARA band ================= */
.clara-band{position:relative;background:var(--grad-dark);color:#fff;border-radius:var(--r-lg);
  padding:clamp(2.2rem,5vw,3.6rem);display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center;overflow:hidden}
.clara-band:before{content:"";position:absolute;right:-10%;top:-30%;width:420px;height:420px;
  background:radial-gradient(circle,rgba(255,109,2,.28),transparent 68%);border-radius:50%}
.clara-band h2{color:#fff}.clara-band p{color:rgba(255,255,255,.85)}
.clara-band .col-txt{position:relative;z-index:2}
.clarabullets{list-style:none;margin:1.6rem 0 0;display:grid;gap:.8rem}
.clarabullets li{padding-left:1.9rem;position:relative;color:rgba(255,255,255,.92);font-size:1rem}
.clarabullets li b{color:#fff}
.clarabullets li:before{content:"✦";position:absolute;left:0;color:var(--pumpkin);font-weight:700}
.clara-band .media-frame{position:relative;z-index:2}

/* by area cards */
.byarea{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;margin-top:2.6rem}
.byarea .card h3{color:var(--denim);font-size:1.1rem;display:flex;align-items:center;gap:.6rem}

/* ================= HORIZONTAL MODULE GALLERY ================= */
.h-rail{display:flex;gap:1.3rem;overflow-x:auto;padding:.5rem .2rem 2rem;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;scrollbar-width:none}
.h-rail::-webkit-scrollbar{display:none}
.h-card{flex:0 0 320px;scroll-snap-align:start;background:#fff;border:1px solid var(--line);
  border-radius:var(--r);padding:1.9rem;box-shadow:var(--shadow-sm);transition:transform .35s var(--ease),box-shadow .35s}
.h-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.h-card .ic{width:54px;height:54px;border-radius:14px;background:var(--bg-soft);color:var(--denim);display:grid;place-items:center;margin-bottom:1rem}
.h-card .ic svg{width:28px;height:28px;stroke:currentColor;fill:none;stroke-width:1.7}
.h-card h4{font-size:1.1rem;color:var(--yale);margin-bottom:.4rem}
.h-card p{font-size:.92rem;line-height:1.5}
.rail-hint{display:flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.86rem;margin-top:.2rem}
.rail-hint svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}

/* ================= MODULE DETAIL (feature grid) ================= */
.mod-block{padding:clamp(2rem,4vw,3rem) 0;border-top:1px solid var(--line)}
.mod-head{display:flex;gap:1.1rem;align-items:flex-start;margin-bottom:1.6rem}
.mod-head .ic{width:62px;height:62px;border-radius:16px;background:var(--bg-soft);color:var(--denim);display:grid;place-items:center;flex:0 0 auto}
.mod-head .ic svg{width:32px;height:32px;stroke:currentColor;fill:none;stroke-width:1.7}
.mod-head h3{font-size:clamp(1.3rem,2.2vw,1.7rem)}
.mod-head .tag{display:inline-block;font-size:.7rem;font-weight:600;color:var(--pumpkin);
  background:rgba(255,109,2,.1);border-radius:999px;padding:.2rem .7rem;margin-top:.4rem}
.feats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem 1.8rem}
.feat{padding-left:1.1rem;border-left:2px solid var(--gris)}
.feat h4{font-size:1rem;color:var(--yale);margin-bottom:.2rem}
.feat p{font-size:.9rem;line-height:1.5}

/* chips list (HIS module names) */
.modlist{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.4rem}
.modlist span{display:inline-flex;align-items:center;gap:.5rem;background:#fff;border:1px solid var(--line);
  border-radius:999px;padding:.55rem 1rem;font-size:.92rem;color:var(--ink);font-weight:500;box-shadow:var(--shadow-sm)}
.modlist span:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--denim);flex:0 0 auto}
.modgroup{margin-top:2.4rem}
.modgroup .gh{display:flex;align-items:center;gap:.8rem;margin-bottom:.4rem}
.modgroup .gh .ic{width:46px;height:46px;border-radius:12px;background:var(--grad-denim);color:#fff;display:grid;place-items:center;flex:0 0 auto}
.modgroup .gh .ic svg{width:24px;height:24px;stroke:#fff;fill:none;stroke-width:1.8}
.modgroup .gh h3{font-size:1.2rem}
.modgroup .gh small{color:var(--muted);font-weight:500}

/* ================= STICKY SUB-NAV (product pages) ================= */
.subnav{position:sticky;top:74px;z-index:90;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--line)}
.subnav .in{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:58px;overflow:hidden}
.subnav .title{font-weight:600;color:var(--yale);font-size:1rem;white-space:nowrap}
.subnav .title b{color:var(--pumpkin)}
.subnav .links{display:flex;gap:.3rem;overflow-x:auto;scrollbar-width:none}
.subnav .links::-webkit-scrollbar{display:none}
.subnav .links a{font-size:.9rem;color:var(--muted);padding:.55rem .9rem;border-radius:8px;white-space:nowrap;font-weight:500;transition:.2s;display:inline-flex;align-items:center}
.subnav .links a:hover,.subnav .links a.on{color:var(--denim);background:rgba(17,100,194,.07)}

/* ================= AWARDS ================= */
.awardcard{text-align:center}
.awardcard img{height:84px;width:auto;margin:0 auto 1.2rem;object-fit:contain;background:#fff;
  border:1px solid var(--line);border-radius:14px;padding:.7rem 1.1rem;box-sizing:content-box;transition:transform .4s var(--ease)}
.awardcard:hover img{transform:translateY(-4px) scale(1.05)}
.awardcard h3{margin-bottom:.4rem;font-size:1.15rem}
.awardcard p{font-size:.94rem}

/* ================= TESTIMONIALS (Swiper) ================= */
.tswiper{padding:.5rem .3rem 3.4rem!important;overflow:visible}
.tquote{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2.2rem;
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column;height:100%}
.tquote .stars{color:var(--pumpkin);letter-spacing:3px;margin-bottom:.9rem;font-size:1.05rem}
.tquote p{color:var(--ink);font-size:1.04rem;font-style:italic;line-height:1.6;flex:1}
.tquote .who{display:flex;gap:1.1rem;align-items:center;margin-top:1.6rem}
.tquote .who img,.tquote .who .mono{width:96px;height:96px;border-radius:50%;object-fit:cover;flex:0 0 auto;
  box-shadow:var(--shadow)}
.tquote .who .mono{background:var(--grad-denim);color:#fff;display:grid;place-items:center;font-weight:600;font-size:1.5rem}
.tquote .who b{color:var(--yale);display:block;font-size:1.05rem}
.tquote .who small{color:var(--muted);font-size:.9rem}
.swiper-pagination-bullet{background:var(--yale);opacity:.25}
.swiper-pagination-bullet-active{background:var(--pumpkin);opacity:1;width:22px;border-radius:5px}
.tnav{display:flex;gap:.6rem;justify-content:center;margin-top:.4rem}
.tnav button{width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:#fff;
  color:var(--yale);cursor:pointer;display:grid;place-items:center;transition:.2s;box-shadow:var(--shadow-sm)}
.tnav button:hover{background:var(--yale);color:#fff;border-color:var(--yale)}
.tnav svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2}

/* ================= PRICING ================= */
.prices{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2.8rem;align-items:stretch}
.price{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2.2rem 1.95rem;
  display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:transform .35s var(--ease),box-shadow .35s}
.price:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.price.feat2{border:2px solid var(--pumpkin);box-shadow:var(--shadow);position:relative}
.price.feat2:before{content:"Más elegido";position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--pumpkin);color:#fff;font-size:.72rem;font-weight:600;padding:.32rem .95rem;border-radius:999px}
.price .pname{font-weight:700;color:var(--yale);font-size:1.22rem}
.price .beds{font-weight:500;color:var(--muted);font-size:.92rem;margin-top:.25rem}
.price .amt{font-size:2.4rem;font-weight:700;color:var(--yale);margin:.9rem 0 0;letter-spacing:-.02em}
.price .amt span{font-size:.9rem;font-weight:500;color:var(--muted)}
.price .base{font-size:.85rem;color:var(--denim);margin-top:.35rem;font-weight:500}
.price ul{list-style:none;margin:1.3rem 0;display:grid;gap:.6rem}
.price li{font-size:.93rem;color:var(--ink);padding-left:1.7rem;position:relative}
.price li:before{content:"";position:absolute;left:0;top:.45em;width:11px;height:6px;
  border-left:2px solid var(--denim);border-bottom:2px solid var(--denim);transform:rotate(-45deg)}
.price .btn{margin-top:auto;justify-content:center}
/* enterprise / HIS pricing card */
.price.ent{background:var(--grad-dark);color:#fff;border:none}
.price.ent .pname,.price.ent .amt{color:#fff}
.price.ent .beds{color:rgba(255,255,255,.8)}
.price.ent li{color:rgba(255,255,255,.92)}
.price.ent li:before{border-color:#ff9a52}
.price.ent .btn-white{background:#fff;color:var(--yale)}

/* ================= COMPARE TABLE ================= */
.toggle-wrap{display:flex;justify-content:center;margin-top:1.6rem}
.toggle{display:inline-flex;background:var(--gris);border-radius:999px;padding:.35rem}
.toggle button{border:none;background:transparent;padding:.6rem 1.4rem;border-radius:999px;font-weight:600;
  font-size:.95rem;color:var(--muted);cursor:pointer;transition:.25s}
.toggle button.on{background:#fff;color:var(--yale);box-shadow:var(--shadow-sm)}
.ctable-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:18px;margin-top:2.4rem}
.ctable{width:100%;border-collapse:collapse;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff}
.ctable th,.ctable td{padding:1.1rem 1.2rem;text-align:left;border-top:1px solid var(--line);vertical-align:top;font-size:.96rem}
.ctable thead th{background:var(--yale);color:#fff;border:none;font-size:.92rem}
.ctable thead th:first-child{background:var(--yale-2)}
.ctable tbody th{font-weight:600;color:var(--yale);background:var(--bg-soft);width:26%}
.ctable td b{color:var(--ink)}
.ctable .hl{color:var(--denim);font-weight:600}
.ctable tr:hover td,.ctable tr:hover th{background:#f0f5fc}
.col-his,.col-go{transition:opacity .3s,background .2s}
.ctable.show-his .col-go{opacity:.4}
.ctable.show-go .col-his{opacity:.4}

/* edition picker (¿cuál es para ti?) */
.picker{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.8rem,4vw,2.8rem);box-shadow:var(--shadow-sm);margin-top:2.6rem}
.picker .opts{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.4rem}
.picker .opt{border:2px solid var(--line);border-radius:16px;padding:1.4rem;cursor:pointer;text-align:center;transition:.25s;background:#fff}
.picker .opt:hover{border-color:var(--denim);transform:translateY(-3px)}
.picker .opt.sel{border-color:var(--pumpkin);background:rgba(255,109,2,.05)}
.picker .opt .b{font-size:1.5rem;font-weight:700;color:var(--yale)}
.picker .opt small{color:var(--muted)}
.picker-out{margin-top:1.8rem;border-radius:18px;padding:1.6rem 1.8rem;background:var(--bg-soft);
  display:none;align-items:center;gap:1.2rem;flex-wrap:wrap;justify-content:space-between}
.picker-out.show{display:flex}
.picker-out .rec b{color:var(--yale);font-size:1.15rem}
.picker-out .rec p{font-size:.92rem;margin-top:.2rem}

/* ================= ACCORDIONS (FAQ / términos) ================= */
.acc{margin-top:1.6rem;display:grid;gap:.8rem}
details.fa{background:#fff;border:1px solid var(--line);border-radius:16px;padding:0 1.5rem;box-shadow:var(--shadow-sm);transition:box-shadow .3s}
details.fa[open]{box-shadow:var(--shadow)}
details.fa summary{cursor:pointer;font-weight:600;color:var(--yale);padding:1.2rem 0;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;font-size:1.04rem}
details.fa summary::-webkit-details-marker{display:none}
details.fa summary:after{content:"";width:13px;height:13px;flex:0 0 auto;
  background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23FF6D02' stroke-width='2.4' stroke-linecap='round'%3E%3Cpath d='M12 5v14M5 12h14'/%3E%3C/svg%3E");transition:transform .3s}
details.fa[open] summary:after{transform:rotate(135deg)}
details.fa .body{padding:0 0 1.3rem;color:var(--muted);font-size:.98rem;line-height:1.65}
details.fa .body ul{margin:.5rem 0 0 1.2rem}
details.fa .body li{margin-bottom:.35rem}

/* ================= CTA band ================= */
.cta{position:relative;background:var(--grad-dark);color:#fff;border-radius:var(--r-lg);
  padding:clamp(2.4rem,5vw,4rem);text-align:center;overflow:hidden}
.cta:before{content:"";position:absolute;left:50%;top:-40%;width:600px;height:600px;transform:translateX(-50%);
  background:radial-gradient(circle,rgba(255,109,2,.22),transparent 65%);border-radius:50%}
.cta>*{position:relative;z-index:2}
.cta h2{color:#fff}.cta p{color:rgba(255,255,255,.85);max-width:620px;margin:.8rem auto 1.7rem}
.section-cta{background:var(--gris);border-radius:var(--r-lg);padding:clamp(1.9rem,3.6vw,2.8rem);
  display:flex;gap:1.4rem;align-items:center;justify-content:space-between;flex-wrap:wrap}
.section-cta h3{font-size:clamp(1.3rem,2.2vw,1.7rem)}
.section-cta p{margin-top:.3rem}

/* ================= PAGE HERO (internal) ================= */
.pagehero{position:relative;background:var(--grad-dark);color:#fff;overflow:hidden;
  padding:clamp(3rem,6vw,5rem) 0 clamp(2.6rem,5vw,4rem)}
.pagehero:before{content:"";position:absolute;right:-10%;top:-40%;width:46vw;height:46vw;max-width:560px;max-height:560px;
  background:radial-gradient(circle,rgba(255,109,2,.22),transparent 66%);border-radius:50%}
.pagehero .wrap{position:relative;z-index:2}
.pagehero h1{color:#fff;max-width:18ch}
.pagehero .lead{color:rgba(255,255,255,.85);max-width:60ch;margin-top:1rem;font-size:clamp(1.05rem,1.6vw,1.28rem)}
.crumbs{font-size:.85rem;color:rgba(255,255,255,.6);margin-bottom:1rem}
.crumbs a{color:rgba(255,255,255,.78)}
.crumbs a:hover{color:#fff}
.pagehero.go{background:linear-gradient(150deg,#ff8a3d 0%,var(--pumpkin) 50%,#cf5600 100%)}
.pagehero.go .eyebrow.on-dark{color:#fff}

/* ================= CONTACT / Calendly ================= */
.cal-wrap{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.cal-wrap .calendly-inline-widget{width:100%}
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:2.6rem;align-items:start}
.contact-pts{display:grid;gap:1.2rem;margin-top:1.6rem}
.contact-pt{display:flex;gap:.9rem;align-items:flex-start}
.contact-pt .ci{width:44px;height:44px;border-radius:12px;background:var(--bg-soft);color:var(--denim);display:grid;place-items:center;flex:0 0 auto}
.contact-pt .ci svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8}
.contact-pt h4{color:var(--yale);font-size:1rem;margin-bottom:.15rem}
.contact-pt p{font-size:.92rem}

/* ================= LEGAL ================= */
.legal{max-width:820px}
.legal h2{font-size:1.4rem;margin:2rem 0 .6rem}
.legal h3{margin:1.6rem 0 .5rem;font-size:1.12rem;color:var(--yale)}
.legal p{margin-bottom:.9rem;font-size:.98rem;line-height:1.7;color:var(--ink)}
.legal ul{margin:.4rem 0 1rem 1.3rem}
.legal li{margin-bottom:.4rem;line-height:1.6}
.legal .meta{color:var(--muted);font-size:.9rem;font-style:italic;margin-bottom:1.4rem}
.legal .box{background:var(--gris);border-radius:14px;padding:1.2rem 1.4rem;margin:1.4rem 0;font-size:.95rem;color:var(--ink)}
.oidtable{width:100%;border-collapse:collapse;margin-top:1.4rem;font-size:.9rem;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.oidtable th{background:var(--yale);color:#fff;text-align:left;padding:.85rem 1rem;font-size:.74rem;letter-spacing:.05em;text-transform:uppercase}
.oidtable td{padding:.95rem 1rem;border-top:1px solid var(--line);vertical-align:top;color:var(--ink);line-height:1.55}
.oidtable tr:nth-child(even) td{background:#f7f9fc}
.oidtable .oid{font-family:ui-monospace,Menlo,monospace;font-weight:600;color:var(--denim);white-space:nowrap;font-size:.82rem}

/* ================= FOOTER ================= */
footer{background:#11233f;color:rgba(255,255,255,.72);padding:3.6rem 0 2rem}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2.2rem}
footer .brand{color:#fff;font-size:1.5rem}
footer .brand .md{color:var(--pumpkin)}
footer h5{color:#fff;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1rem}
footer .fcol a{display:block;color:rgba(255,255,255,.7);margin-bottom:.55rem;font-size:.94rem;transition:color .2s}
footer .fcol a:hover{color:var(--pumpkin)}
footer .fdesc{margin-top:1rem;color:rgba(255,255,255,.62);font-size:.95rem;max-width:30ch;line-height:1.6}
.social{display:flex;gap:.6rem;margin-top:1.2rem}
.social a{width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.09);display:grid;place-items:center;transition:.2s}
.social a:hover{background:var(--pumpkin);transform:translateY(-2px)}
.social svg{width:18px;height:18px;fill:#fff}
.copy{border-top:1px solid rgba(255,255,255,.12);margin-top:2.6rem;padding-top:1.5rem;
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.86rem;color:rgba(255,255,255,.5)}
.copy a{color:rgba(255,255,255,.6)}.copy a:hover{color:var(--pumpkin)}

/* ================= Módulos con captura real del sistema ================= */
.checklist{list-style:none;display:grid;gap:.55rem;margin:0}
.checklist li{padding-left:1.7rem;position:relative;color:var(--ink);font-size:.98rem}
.checklist li:before{content:"";position:absolute;left:0;top:.45em;width:11px;height:6px;
  border-left:2px solid var(--denim);border-bottom:2px solid var(--denim);transform:rotate(-45deg)}
.mod-block.has-shot{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.6rem,3.5vw,3rem);
  align-items:center;padding:clamp(2rem,4vw,3rem) 0;border-top:1px solid var(--line)}
.mod-block.has-shot.rev .mod-main{order:2}
.mod-block.has-shot .feats{grid-template-columns:1fr 1fr;gap:1rem 1.4rem}
.mod-desc{color:var(--muted);margin:.3rem 0 1.2rem;font-size:1rem;max-width:60ch}
.mod-shot,.acc-shot{border-radius:16px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);background:#0d1f3a}
.mod-shot img,.acc-shot img{width:100%;display:block}
.modgroup2{margin-top:2.8rem}
.gh2{display:flex;align-items:center;gap:.75rem;font-size:1.35rem;margin-bottom:1rem}
.gh2 small{color:var(--muted);font-weight:600;font-size:.82rem;background:var(--gris);border-radius:999px;padding:.15rem .7rem}
.mic2{width:40px;height:40px;border-radius:11px;background:var(--grad-denim);color:#fff;display:inline-grid;place-items:center;flex:0 0 auto}
.mic2 svg{width:22px;height:22px;stroke:#fff;fill:none;stroke-width:1.8}
.modacc summary .msum{display:flex;align-items:center;gap:.8rem}
.modacc summary .mic2{width:34px;height:34px;border-radius:9px}
.modacc summary .mic2 svg{width:19px;height:19px}
.modacc-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}
.featlist{list-style:none;display:grid;gap:.5rem;margin:0}
.featlist li{padding-left:1.5rem;position:relative;font-size:.94rem;color:var(--ink)}
.featlist li:before{content:"";position:absolute;left:0;top:.5em;width:7px;height:7px;border-radius:50%;background:var(--denim)}
.shots .shotcard{margin:0;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform .35s var(--ease),box-shadow .35s}
.shots .shotcard:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.shots .shotcard img{width:100%;display:block;background:#0d1f3a;aspect-ratio:16/10;object-fit:cover;object-position:top}
.shots .shotcard figcaption{padding:.9rem 1.1rem;font-weight:600;color:var(--yale);font-size:.96rem}
@media(max-width:860px){
  .mod-block.has-shot{grid-template-columns:1fr}
  .mod-block.has-shot.rev .mod-main{order:0}
  .mod-block.has-shot .mod-shot{order:-1}
  .modacc-grid{grid-template-columns:1fr}
}
@media(max-width:560px){.mod-block.has-shot .feats{grid-template-columns:1fr}}

/* ================= Beneficios (iconos + texto) ================= */
.benefits{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem 2.2rem;margin-top:2rem}
.benefit{display:flex;gap:1rem;align-items:flex-start}
.benefit .bi{flex:0 0 48px;height:48px;border-radius:12px;background:var(--bg-soft);color:var(--denim);display:grid;place-items:center}
.benefit .bi svg{width:26px;height:26px;stroke:currentColor;fill:none;stroke-width:1.7}
.benefit h4{font-size:1.05rem;color:var(--yale);margin-bottom:.15rem}
.benefit p{font-size:.93rem;line-height:1.5}
@media(max-width:860px){.benefits{grid-template-columns:1fr}}

/* ================= Test de edición (selector) ================= */
.etest{display:grid;grid-template-columns:1.1fr .9fr;gap:1.6rem;margin-top:.4rem;align-items:start}
.et-qs{display:grid;gap:.9rem}
.et-q{background:#fff;border:1px solid var(--line);border-radius:16px;padding:1.1rem 1.3rem;box-shadow:var(--shadow-sm)}
.et-qh{display:flex;align-items:center;gap:.7rem;font-weight:600;color:var(--yale);margin-bottom:.8rem;font-size:1.02rem}
.et-n{width:26px;height:26px;flex:0 0 auto;border-radius:50%;background:var(--grad-denim);color:#fff;display:grid;place-items:center;font-size:.85rem;font-weight:700}
.et-opts{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.et-opt{border:2px solid var(--line);background:#fff;border-radius:12px;padding:.7rem .9rem;font-family:inherit;font-size:.92rem;
  color:var(--ink);cursor:pointer;text-align:left;transition:.2s;line-height:1.3}
.et-opt:hover{border-color:var(--denim)}
.et-opt.sel{border-color:var(--pumpkin);background:rgba(255,109,2,.06);color:var(--yale);font-weight:600}
.et-result{position:sticky;top:96px}
.et-empty{background:#fff;border:1px dashed #cfd9e6;border-radius:18px;padding:2.2rem 1.6rem;color:var(--muted);text-align:center;font-size:1rem}
.et-rec{border-radius:18px;padding:1.9rem;color:#fff;box-shadow:var(--shadow)}
.et-rec.et-go{background:linear-gradient(155deg,#ff8a3d,var(--pumpkin) 60%,#d95800)}
.et-rec.et-his{background:var(--grad-dark)}
.et-rec.et-tie{background:linear-gradient(150deg,var(--denim),var(--yale))}
.et-tag{font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.85)}
.et-rec h3{color:#fff;font-size:1.7rem;margin:.4rem 0 .3rem}
.et-rec p{color:rgba(255,255,255,.92);font-size:.98rem}
.et-rec .actions{margin-top:1.3rem}
.et-rec .btn-primary{background:#fff;color:var(--yale);box-shadow:none}
.et-rec.et-go .btn-primary{color:#c2410c}
.et-rec .btn-outline{background:transparent;border-color:rgba(255,255,255,.6);color:#fff}
.et-rec .btn-outline:hover{background:rgba(255,255,255,.15);color:#fff}

/* ================= Equipo ================= */
.teamcard{display:grid;grid-template-columns:auto 1fr;gap:.2rem 1.1rem;align-items:center}
.teamcard .tavatar{width:62px;height:62px;border-radius:50%;background:var(--grad-denim);color:#fff;
  display:grid;place-items:center;font-weight:700;font-size:1.3rem;overflow:hidden}
.teamcard .tavatar img{width:100%;height:100%;object-fit:cover;object-position:top}

/* ================= Rentabilidad (home) ================= */
.roi-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.roi-pts{display:grid;gap:1.4rem;margin-top:1.8rem}
.roi-pt{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:start}
.roi-pt .ic{width:46px;height:46px;border-radius:14px;background:var(--gris);color:var(--denim);
  display:grid;place-items:center;flex:0 0 auto}
.roi-pt h3{font-size:1.08rem;margin:0 0 .25rem}
.roi-pt p{font-size:.95rem}
.roi-close{margin-top:1.8rem;padding-top:1.4rem;border-top:1px solid var(--gris)}
.roi-close p{font-weight:600;color:var(--ink);margin-bottom:1rem}
.roi-art{position:relative}
.roi-float{position:absolute;left:-8%;bottom:7%;background:rgba(255,255,255,.97);border-radius:18px;
  padding:1rem 1.2rem;box-shadow:var(--shadow-lg);max-width:240px}
.roi-float .big{font-size:1.6rem;font-weight:700;color:var(--pumpkin);line-height:1}
.roi-float small{color:var(--muted);font-size:.78rem}
@media(max-width:860px){.roi-grid{grid-template-columns:1fr}.roi-art{order:-1}.roi-float{left:4%;bottom:-1rem}}

/* ================= Expertos (home + contacto) ================= */
.experts{display:grid;grid-template-columns:auto 1fr;gap:clamp(1.8rem,4vw,3.2rem);align-items:center;
  background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow);padding:clamp(1.8rem,4vw,2.8rem)}
.exp-photo img{width:clamp(180px,22vw,250px);border-radius:var(--r);object-fit:cover;aspect-ratio:4/5;object-position:top}
.exp-txt h2{font-size:clamp(1.5rem,2.6vw,2rem)}
.exp-who{display:grid;gap:.1rem;margin:1.2rem 0 1.4rem;padding-left:1rem;border-left:3px solid var(--pumpkin)}
.exp-who b{color:var(--ink)}
.exp-who span{color:var(--denim);font-weight:600;font-size:.92rem}
.exp-who small{color:var(--muted);font-size:.88rem;margin-top:.3rem}
@media(max-width:760px){.experts{grid-template-columns:1fr}.exp-photo img{width:min(240px,60vw)}}

.expert-mini{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:center;margin-top:1.6rem;
  background:var(--gris);border-radius:var(--r);padding:1rem 1.2rem}
.expert-mini img{width:58px;height:58px;border-radius:50%;object-fit:cover;object-position:top}
.expert-mini b{display:block;color:var(--ink);font-size:.98rem}
.expert-mini span{color:var(--denim);font-weight:600;font-size:.85rem}
.expert-mini small{display:block;color:var(--muted);font-size:.85rem;margin-top:.25rem}

.roles-banner{max-width:920px;margin-inline:auto}
.roles-banner img{aspect-ratio:21/9;object-fit:cover}
.teamcard h3{font-size:1.2rem;margin:0}
.teamcard .trole{color:var(--denim);font-weight:600;font-size:.9rem}
.teamcard p{grid-column:1 / -1;margin-top:.7rem;font-size:.95rem}

/* ================= Proceso de implementación ================= */
.steps{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem 1.6rem}
.step{display:flex;gap:1rem;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:14px;padding:1.1rem 1.3rem;box-shadow:var(--shadow-sm)}
.step-n{width:34px;height:34px;flex:0 0 auto;border-radius:10px;background:var(--yale);color:#fff;display:grid;place-items:center;font-weight:700;font-size:.95rem}
.step-b h4{color:var(--yale);font-size:1rem;margin-bottom:.15rem}
.step-b p{font-size:.92rem;line-height:1.5}

/* float sutil en tarjetas del hero (continuo, respeta reduced-motion) */
@media(prefers-reduced-motion:no-preference){
  .hero-float.a{animation:floaty 6s ease-in-out infinite}
  .hero-float.b{animation:floaty 7.5s ease-in-out infinite reverse}
}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

@media(max-width:860px){
  .etest{grid-template-columns:1fr}
  .et-result{position:static}
  .steps{grid-template-columns:1fr}
  .teamcard{grid-template-columns:1fr;text-align:center;justify-items:center}
  .teamcard p{text-align:center}
}
@media(max-width:560px){.et-opts{grid-template-columns:1fr}}

/* ================= Por qué + costo de no hacer nada ================= */
.cost{background:var(--grad-dark);color:#fff;border-radius:var(--r-lg);padding:clamp(1.8rem,4vw,2.8rem);
  display:grid;grid-template-columns:.92fr 1.08fr;gap:2rem;align-items:start;overflow:hidden;position:relative}
.cost:before{content:"";position:absolute;right:-8%;top:-30%;width:360px;height:360px;
  background:radial-gradient(circle,rgba(255,109,2,.22),transparent 68%);border-radius:50%}
.cost-head{position:relative;z-index:2}
.cost-head h3{color:#fff;font-size:clamp(1.4rem,2.4vw,1.9rem);margin:.4rem 0 .6rem}
.cost-head p{color:rgba(255,255,255,.85)}
.cost-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem 1.6rem;position:relative;z-index:2}
.cost-item h4{color:#fff;font-size:1rem;margin-bottom:.2rem;padding-left:1.1rem;position:relative}
.cost-item h4:before{content:"";position:absolute;left:0;top:.45em;width:8px;height:8px;border-radius:50%;background:var(--pumpkin)}
.cost-item p{color:rgba(255,255,255,.78);font-size:.9rem;padding-left:1.1rem;line-height:1.5}
@media(max-width:860px){.cost{grid-template-columns:1fr}.cost-grid{grid-template-columns:1fr}}

/* ================= role cards ================= */
.rolecard .rtag{display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  color:var(--denim);background:#eaf1fb;border-radius:999px;padding:.2rem .7rem;margin-bottom:.55rem}
.rolecard h3{font-size:1.08rem}

/* ================= caso de éxito ================= */
.case{display:grid;grid-template-columns:1.4fr .6fr;gap:0;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);box-shadow:var(--shadow);overflow:hidden;align-items:stretch}
.case-body{padding:clamp(1.7rem,3.5vw,2.6rem)}
.case-tag{display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--pumpkin);background:rgba(255,109,2,.1);border-radius:999px;padding:.25rem .8rem;margin-bottom:1.1rem}
.case-step{font-size:1rem;color:var(--ink);margin-bottom:.7rem;line-height:1.55}
.case-step b{color:var(--yale)}
.case-quote{margin-top:1.3rem;padding:1.2rem 1.4rem;background:var(--bg-soft);border-left:3px solid var(--pumpkin);
  border-radius:0 14px 14px 0;font-style:italic;color:var(--ink);font-size:1rem;line-height:1.6}
.case-who{display:flex;gap:.8rem;align-items:center;margin-top:1rem;font-style:normal}
.case-who img{width:68px;height:68px;border-radius:50%;object-fit:cover;flex:0 0 auto;box-shadow:var(--shadow)}
.case-who b{color:var(--yale);display:block;font-size:.95rem}
.case-who small{color:var(--muted);font-size:.85rem}
.case-metric{background:var(--grad-dark);color:#fff;display:flex;flex-direction:column;justify-content:center;
  align-items:center;text-align:center;padding:2rem 1.4rem}
.cm-num{font-size:clamp(2.6rem,5vw,3.8rem);font-weight:700;line-height:1;letter-spacing:-.03em}
.cm-label{color:rgba(255,255,255,.85);font-size:.95rem;margin-top:.5rem;max-width:16ch}
@media(max-width:860px){.case{grid-template-columns:1fr}.case-metric{padding:1.8rem;flex-direction:row;gap:1rem}}

/* ================= Selector de idioma ================= */
.langtog{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 .7rem;
  border-radius:11px;border:1px solid var(--line);color:var(--yale);font-weight:700;font-size:.82rem;letter-spacing:.04em;transition:.2s}
.langtog:hover{background:var(--yale);color:#fff;border-color:var(--yale)}
@media(max-width:600px){.langtog{min-width:38px;height:38px;font-size:.78rem;padding:0 .55rem}}

/* ================= Comparativo vs tradicional ================= */
.vstable thead th.vs-newh{background:var(--denim)}
.vstable td.vs-old{color:var(--muted)}
.vstable td.vs-new{background:rgba(17,100,194,.06);color:var(--ink);font-weight:500}
.vstable .vs-new svg{display:inline-block;width:16px;height:16px;stroke:#16a34a;fill:none;stroke-width:2.6;
  vertical-align:-3px;margin-right:.4rem;flex:0 0 auto}
.vstable tbody tr:hover td.vs-new{background:rgba(17,100,194,.1)}

/* ================= Aviso de cookies ================= */
.cookie{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);z-index:300;
  width:min(820px,calc(100% - 32px));background:#fff;border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow-lg);padding:1rem 1.2rem;display:flex;gap:1rem;align-items:center;justify-content:space-between;flex-wrap:wrap}
.cookie[hidden]{display:none}
.cookie p{font-size:.9rem;color:var(--ink);margin:0;flex:1;min-width:240px;line-height:1.45}
.cookie a{color:var(--denim);font-weight:600}
.cookie .btn{padding:.65rem 1.4rem;font-size:.95rem;flex:0 0 auto}
@media(max-width:560px){.cookie{bottom:0;left:0;transform:none;width:100%;border-radius:16px 16px 0 0}}

/* ================= MOTION (Apple-like) ================= */
html.js .reveal{opacity:0;transform:translateY(16px);transition:opacity .65s ease-out,transform .65s ease-out}
html.js .reveal.in{opacity:1;transform:none}
html.js .hero-grid>*{opacity:0;transform:translateY(28px);animation:heroIn 1s var(--ease) forwards}
html.js .hero-grid .col-txt{animation-delay:.08s}
html.js .hero-grid .hero-art{animation-delay:.22s}
@keyframes heroIn{to{opacity:1;transform:none}}

/* ================= RESPONSIVE ================= */
@media(max-width:1024px) and (min-width:861px){
  .cols-4{grid-template-columns:repeat(2,1fr)}
  .cols-3{grid-template-columns:repeat(2,1fr)}
  .feats{grid-template-columns:repeat(2,1fr)}
  .mega{width:min(640px,92vw)}
}
@media(max-width:860px){
  .menu{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:rgba(255,255,255,.98);backdrop-filter:blur(16px);padding:.5rem 6% 1.4rem;
    border-bottom:1px solid var(--line);box-shadow:0 22px 44px rgba(22,40,70,.14);
    transform:translateY(-12px);opacity:0;pointer-events:none;transition:transform .3s var(--ease),opacity .3s;max-height:84vh;overflow-y:auto}
  .menu.open{display:flex;transform:none;opacity:1;pointer-events:auto}
  .menu>a,.mega-trigger{width:100%;padding:1rem .3rem;border-bottom:1px solid var(--line);border-radius:0;font-size:1.06rem;justify-content:space-between}
  .nav{position:relative}
  .burger{display:flex}
  .menu a.menu-cta{display:inline-flex;margin:1rem .3rem .2rem!important;justify-content:center;border-bottom:none!important}
  .has-mega{width:100%}
  .mega{position:static;transform:none;width:100%;box-shadow:none;border:none;opacity:1;visibility:visible;
    display:none;grid-template-columns:1fr;padding:.3rem 0 .6rem;background:transparent}
  .has-mega.open .mega{display:grid;transform:none}
  .mega-card{padding:.7rem .3rem;border-radius:12px}
  .mega-card.full{background:var(--bg-soft)}
  .hero-grid,.split,.clara-band,.contact-grid{grid-template-columns:1fr;gap:2.2rem}
  .split.rev .col-txt{order:0}
  .hero-art{order:-1}
  .editions{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr);gap:2rem 1rem}
  .cols-2,.cols-3,.cols-4{grid-template-columns:1fr}
  .feats{grid-template-columns:1fr 1fr}
  .byarea{grid-template-columns:1fr}
  .prices{grid-template-columns:1fr}
  .picker .opts{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr 1fr;gap:1.8rem}
  .fcol.brandcol{grid-column:1 / -1}
  .subnav{display:none}
  .hero-float{display:none}
}
@media(max-width:560px){
  .feats{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr}
  .nav-right .btn{display:none}
  .brand{font-size:1.35rem}
  .actions .btn{flex:1 1 auto;justify-content:center}
  .edition{padding:1.9rem}
  .section-cta{flex-direction:column;align-items:flex-start}
  .ctable{min-width:540px}
  .ctable th,.ctable td{padding:.85rem .7rem;font-size:.88rem}
  .ctable tbody th{width:34%}
  .card,.price,.h-card{padding:1.4rem}
  .edition{padding:1.6rem}
}

/* reduced motion */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  html.js .reveal{opacity:1!important;transform:none!important;transition:none!important}
  html.js .hero-grid>*{animation:none!important;opacity:1!important;transform:none!important}
  .btn-primary:after{display:none}
  *{scroll-behavior:auto!important}
}
