/* ==========================================================================
   Mantenimiento WordPress (AyudaWP) — rediseño 3.0
   Sistema visual «De cabecera» · acento verde · tema claro/oscuro · un solo DOM
   ========================================================================== */

/* -------- Fuentes autoalojadas (sin Google Fonts) ------------------------ */
@font-face{font-family:'IBM Plex Sans';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/ibm-plex-sans-400.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Sans';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/ibm-plex-sans-500.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Sans';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/ibm-plex-sans-600.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/ibm-plex-mono-400.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/ibm-plex-mono-500.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/ibm-plex-mono-600.woff2') format('woff2')}
@font-face{font-family:'Bricolage Grotesque';font-style:normal;font-weight:400 800;font-display:swap;src:url('../fonts/bricolage-grotesque-var.woff2') format('woff2')}

/* -------- Tokens --------------------------------------------------------- */
:root{
  color-scheme:light dark;
  --bg:#fbf6ee; --surface:#fff; --panel:#fff;
  --ink:#262019; --ink-2:#5d5342; --ink-hi:#3d372c; --meta:#77694e; --meta-2:#7c6f54;
  --line:#e8ddc8; --line-2:#e0d5c0;
  --accent:#2d9484; --accent-deep:#1f6b60; --marker:#ffe45c; --ok:#1f9d7a;
  --tint:#f2fbf8; --star:#b87814;
  --shadow:rgba(38,32,25,.10); --shadow-hard:rgba(38,32,25,.16); --accent-shadow:rgba(45,148,132,.22);
  --btn-bg:#262019; --btn-ink:#fbf6ee; --outline-ink:#262019; --btn-hover:#1f6b60;
  --focus:#1f6b60;
}
@media (prefers-color-scheme:dark){
  :root{
    --bg:#171310; --surface:#211b14; --panel:#1d1812;
    --ink:#f0e9db; --ink-2:#b3a68e; --ink-hi:#d8cfc0; --meta:#9a8b6f; --meta-2:#a0937c;
    --line:#3a3226; --line-2:#3a3226;
    --accent:#3fbfa8; --accent-deep:#3fbfa8; --marker:#ffe45c; --ok:#57e6a8;
    --tint:#16241f; --star:#e0a94b;
    --shadow:rgba(0,0,0,.45); --shadow-hard:rgba(0,0,0,.45); --accent-shadow:rgba(45,148,132,.28);
    --btn-bg:#f0e9db; --btn-ink:#14100b; --outline-ink:#f0e9db; --btn-hover:#3fbfa8;
    --focus:#3fbfa8;
  }
}
html.light{
  --bg:#fbf6ee; --surface:#fff; --panel:#fff;
  --ink:#262019; --ink-2:#5d5342; --ink-hi:#3d372c; --meta:#77694e; --meta-2:#7c6f54;
  --line:#e8ddc8; --line-2:#e0d5c0;
  --accent:#2d9484; --accent-deep:#1f6b60; --marker:#ffe45c; --ok:#1f9d7a;
  --tint:#f2fbf8; --star:#b87814;
  --shadow:rgba(38,32,25,.10); --shadow-hard:rgba(38,32,25,.16); --accent-shadow:rgba(45,148,132,.22);
  --btn-bg:#262019; --btn-ink:#fbf6ee; --outline-ink:#262019; --btn-hover:#1f6b60; --focus:#1f6b60;
}
html.dark{
  --bg:#171310; --surface:#211b14; --panel:#1d1812;
  --ink:#f0e9db; --ink-2:#b3a68e; --ink-hi:#d8cfc0; --meta:#9a8b6f; --meta-2:#a0937c;
  --line:#3a3226; --line-2:#3a3226;
  --accent:#3fbfa8; --accent-deep:#3fbfa8; --marker:#ffe45c; --ok:#57e6a8;
  --tint:#16241f; --star:#e0a94b;
  --shadow:rgba(0,0,0,.45); --shadow-hard:rgba(0,0,0,.45); --accent-shadow:rgba(45,148,132,.28);
  --btn-bg:#f0e9db; --btn-ink:#14100b; --outline-ink:#f0e9db; --btn-hover:#3fbfa8; --focus:#3fbfa8;
}

/* -------- Base ----------------------------------------------------------- */
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);font:400 17px/1.6 'IBM Plex Sans',system-ui,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
h1,h2,h3{font-family:'Bricolage Grotesque','IBM Plex Sans',sans-serif;margin:0}
p{margin:0}
figure,blockquote{margin:0}
.container{max-width:1200px;margin:0 auto;padding:0 48px}
.mono{font-family:'IBM Plex Mono',ui-monospace,monospace}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--bg);padding:10px 16px;font:600 13px/1 'Bricolage Grotesque',sans-serif;z-index:200}
.skip-link:focus{left:8px;top:8px}
a:focus-visible,button:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--focus);outline-offset:2px;border-radius:0}

/* Marcador amarillo. Cubre toda la altura del glifo (legible también en oscuro)
   y se «dibuja» cuando el texto entra en pantalla (la clase .in la pone el JS
   con IntersectionObserver). Sin JS o con «reducir movimiento» se ve completo. */
.mark{background-image:linear-gradient(var(--marker),var(--marker));background-repeat:no-repeat;background-position:0 center;background-size:100% 1.05em;color:#262019;padding:.04em .14em;-webkit-box-decoration-break:clone;box-decoration-break:clone}
html.js .mark{background-size:0 1.05em}
html.js .mark.in{animation:draw .9s ease both}
@keyframes draw{from{background-size:0 1.05em}to{background-size:100% 1.05em}}
.cursor{display:inline-block;width:9px;height:15px;background:var(--accent);animation:blink 1.15s steps(1) infinite;vertical-align:middle}
@keyframes blink{50%{opacity:0}}

/* -------- Botones -------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font:600 15px/1 'Bricolage Grotesque',sans-serif;text-decoration:none;cursor:pointer;border:1.5px solid transparent;border-radius:0;padding:16px 26px;transition:background-color .15s,border-color .15s,color .15s}
.btn--sm{font-size:13px;padding:10px 16px}
.btn--block{display:flex;width:100%;text-align:center}
.btn--primary{background:var(--btn-bg);color:var(--btn-ink);border-color:var(--btn-bg)}
.btn--primary:hover{background:var(--btn-hover);border-color:var(--btn-hover);color:#fff}
html.dark .btn--primary:hover{color:#14100b}
@media (prefers-color-scheme:dark){:root:not(.light) .btn--primary:hover{color:#14100b}}
.btn--outline{background:transparent;color:var(--outline-ink);border-color:var(--outline-ink)}
html.light .btn--outline:hover,:root:not(.dark) .btn--outline:hover{background:rgba(38,32,25,.06)}
html.dark .btn--outline:hover{background:rgba(240,233,219,.10)}
.btn--accent{background:var(--accent);color:#08201c;border-color:var(--accent)}
.btn--accent:hover{background:var(--marker);border-color:var(--marker);color:#262019}
.btn--ink{background:#262019;color:#fbf6ee;border-color:#262019}
.btn--ink:hover{background:#08201c;border-color:#08201c}

/* -------- Cabecera ------------------------------------------------------- */
.site-header{background:var(--bg);border-bottom:1px solid var(--line);position:relative}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:20px;padding-top:15px;padding-bottom:15px}
.brand{display:inline-flex;align-items:baseline;gap:2px;text-decoration:none;color:var(--ink)}
.brand b{font:800 19px/1 'Bricolage Grotesque',sans-serif}
.brand span{font:600 13px/1 'IBM Plex Mono',monospace;color:var(--accent)}
.nav{display:flex;align-items:center;gap:24px}
.nav a{font:500 13.5px/1 'IBM Plex Sans',sans-serif;color:var(--ink-2);text-decoration:none}
.nav a:hover{color:var(--ink)}
.nav a.is-active{color:var(--ink);border-bottom:2px solid var(--accent);padding-bottom:3px}
.header-actions{display:flex;align-items:center;gap:14px}
.header-phone{font:500 12.5px/1 'IBM Plex Mono',monospace;color:var(--ink-2);text-decoration:none;white-space:nowrap}
.header-phone:hover{color:var(--ink)}
.lang{font:500 11px/1 'IBM Plex Mono',monospace;color:var(--meta)}
.lang a{color:var(--meta);text-decoration:none}
.lang a:hover{color:var(--ink)}
.lang .on{color:var(--ink)}
.nav-only{display:none}
.nav-toggle{display:none;width:44px;height:44px;align-items:center;justify-content:center;background:transparent;border:1.5px solid var(--ink);color:var(--ink);font-size:18px;cursor:pointer}

/* -------- Secciones ------------------------------------------------------ */
.section{padding:52px 0}
.section--panel{background:var(--panel);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section__head{display:flex;justify-content:space-between;align-items:baseline;gap:16px;margin-bottom:28px;flex-wrap:wrap}
.section__head--stack{display:block}
.section h2{font-size:clamp(24px,4vw,32px);line-height:1.1;font-weight:800;letter-spacing:-.015em}
.section__lead{font-size:15px;line-height:1.5;color:var(--ink-2);margin-top:6px}
.section__note{font:400 12px/1.4 'IBM Plex Mono',monospace;color:var(--meta-2)}

/* -------- Hero ----------------------------------------------------------- */
.hero .container{padding-top:60px;padding-bottom:54px}
.hero__grid{display:flex;gap:56px;align-items:center}
.hero__text{flex:1.25}
.eyebrow{font:500 11px/1.4 'IBM Plex Mono',monospace;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:18px}
.hero h1{font-size:clamp(32px,5.4vw,56px);line-height:1.04;font-weight:800;letter-spacing:-.02em;margin-bottom:18px}
.hero__text>p{font-size:clamp(15px,2.1vw,17px);line-height:1.6;color:var(--ink-2);max-width:520px;margin-bottom:28px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.hero__note{font:400 11.5px/1.5 'IBM Plex Mono',monospace;color:var(--meta);margin-top:18px}
.hero__aside{flex:1;display:flex;flex-direction:column;gap:22px;min-width:0}
.avatars{display:flex;align-items:center;gap:18px}
.avatars__stack{display:flex;align-items:center}
.avatars__stack img{width:66px;height:66px;border-radius:50%;object-fit:cover;border:3px solid var(--bg);background:var(--line);box-shadow:4px 4px 0 var(--shadow)}
.avatars__stack img:first-child{width:84px;height:84px}
.avatars__stack img:not(:first-child){margin-left:-16px}
.avatars__stack img:nth-child(1){transform:rotate(-4deg)}
.avatars__stack img:nth-child(2){transform:rotate(3deg)}
.avatars__stack img:nth-child(3){transform:rotate(-3deg)}
.avatars__stack img:nth-child(4){transform:rotate(4deg)}
.avatars__cap{font:400 11.5px/1.5 'IBM Plex Mono',monospace;color:var(--meta)}
.status{display:flex;flex-direction:column;gap:8px;max-width:340px}
.status__row{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);padding:11px 14px;font:400 12px/1 'IBM Plex Mono',monospace;color:var(--ink)}
.status__row .ok{color:var(--ok)}
.status__row .cursor{margin-left:auto}

/* -------- Selector ------------------------------------------------------- */
.selector__grid{display:flex;gap:28px;align-items:stretch}
.selector__opts{flex:1;display:flex;flex-direction:column;gap:10px}
.sel-label{font:500 10.5px/1 'IBM Plex Mono',monospace;letter-spacing:.12em;color:var(--meta);margin-bottom:4px}
.selopt{border:1.5px solid var(--line-2);background:var(--bg);padding:15px 18px;font:600 15px/1.2 'Bricolage Grotesque',sans-serif;color:var(--ink-2);cursor:pointer;text-align:left;display:flex;justify-content:space-between;align-items:center;gap:10px;transition:border-color .15s}
.selopt:hover{border-color:var(--ink)}
.selopt[aria-pressed="true"]{border-color:var(--ink);background:var(--ink);color:var(--btn-ink)}
.selopt .tag{font:400 12px/1 'IBM Plex Mono',monospace;color:var(--accent);opacity:0}
.selopt[aria-pressed="true"] .tag{color:#3fbfa8;opacity:1}
.selector__hint{font:400 12px/1.6 'IBM Plex Mono',monospace;color:var(--meta);margin-top:10px}
.selector__hint a{color:var(--accent-deep)}
.selector__reco{flex:1.35;background:var(--bg);border:1.5px solid var(--ink);padding:26px 30px;position:relative;box-shadow:6px 6px 0 var(--accent-shadow)}
.reco__badge{position:absolute;top:-13px;left:24px;background:var(--marker);color:#262019;font:600 11px/1 'IBM Plex Mono',monospace;letter-spacing:.08em;padding:7px 10px;transform:rotate(-1.5deg)}
.reco__cols{display:flex;gap:24px;margin-top:8px}
.reco__c{flex:1}
.reco__c+.reco__c{border-left:1px dashed var(--line-2);padding-left:24px;display:flex;flex-direction:column}
.reco__k{font:600 11px/1 'IBM Plex Mono',monospace;color:var(--accent-deep);letter-spacing:.08em;margin-bottom:8px}
.reco__c p{font-size:13.5px;line-height:1.55;color:var(--ink-hi);margin-bottom:16px}
.reco__feats{font:400 12.5px/2 'IBM Plex Mono',monospace;color:var(--ink-hi)}
.reco__cta{margin-top:auto;padding-top:16px}

/* -------- Planes --------------------------------------------------------- */
.plans{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;align-items:stretch}
.plan{background:var(--surface);border:1.5px solid var(--line-2);padding:26px 26px 24px;display:flex;flex-direction:column;position:relative}
.plan--featured{border:2px solid var(--accent);box-shadow:7px 7px 0 var(--accent-shadow)}
.plan__badge{position:absolute;top:-13px;right:20px;background:var(--marker);color:#262019;font:600 10.5px/1 'IBM Plex Mono',monospace;letter-spacing:.08em;padding:7px 10px;transform:rotate(1.5deg)}
.plan h3{font:700 20px/1 'Bricolage Grotesque',sans-serif;margin-bottom:4px}
.plan__for{font-size:12.5px;line-height:1.5;color:var(--meta);margin-bottom:16px}
.plan__price{font:800 42px/1 'Bricolage Grotesque',sans-serif}
.plan--featured .plan__price{color:var(--accent-deep)}
.plan__price small{font:400 12px/1 'IBM Plex Mono',monospace;color:var(--meta)}
.plan hr{border:none;border-top:1px dashed var(--line-2);margin:18px 0 14px}
.plan__feats{font-size:13px;line-height:2.1;color:var(--ink-hi);margin:0}
.plan__feats .ok{color:var(--ok)}
.plan__more{font:400 11px/1.4 'IBM Plex Mono',monospace;color:var(--meta);margin:10px 0 18px}
.plan .btn{margin-top:auto}
.plans__foot{text-align:center;font:400 12px/1.7 'IBM Plex Mono',monospace;color:var(--meta);padding-top:20px}
.plans__foot .mark{font-family:inherit}

/* -------- Incluye siempre ------------------------------------------------ */
.grid8{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1px;background:var(--line-2);border:1px solid var(--line-2)}
.g8{background:var(--bg);padding:18px 20px}
.g8 .num{font:500 11px/1 'IBM Plex Mono',monospace;color:var(--accent-deep);margin-bottom:8px}
.g8 h3{font:700 15px/1.2 'Bricolage Grotesque',sans-serif;margin-bottom:6px}
.g8 p{font-size:12px;line-height:1.5;color:var(--meta)}

/* -------- Humanos vs (tabla comparativa) --------------------------------- */
.compare__grid{display:flex;gap:48px;align-items:flex-start}
.compare__intro{flex:1}
.compare__intro p{font-size:14.5px;line-height:1.65;color:var(--ink-2);max-width:360px;margin:12px 0 0}
.compare__intro .mono{display:block;font-size:12px;line-height:1.6;color:var(--meta);margin-top:16px}
.compare__wrap{flex:1.3;overflow-x:auto}
.compare{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;border:1.5px solid var(--ink);background:var(--surface);min-width:460px}
.compare>div{border-bottom:1px solid var(--line)}
.compare .hcell{padding:12px 16px;border-bottom:1.5px solid var(--ink);font:500 10.5px/1.2 'IBM Plex Mono',monospace;letter-spacing:.06em;color:var(--meta)}
.compare .hcell--us{background:#262019;color:#fbf6ee;font:700 12px/1.2 'Bricolage Grotesque',sans-serif;text-align:center}
.compare .hcell--o{text-align:center;color:var(--meta);font:500 11px/1.2 'IBM Plex Sans',sans-serif}
.compare .rlabel{padding:11px 16px;font-size:13px;line-height:1.3}
.compare .cell{padding:11px 8px;text-align:center;font-size:12px;letter-spacing:.06em}
.compare .cell--us{background:var(--tint);color:var(--accent-deep)}
.compare .cell--mid{color:#b3a891}
.compare .cell--no{color:#c9bda4}
html.dark .compare .cell--mid{color:#8a7c62}
html.dark .compare .cell--no{color:#6b5f45}
.compare>div:nth-last-child(-n+4){border-bottom:none}

/* -------- Testimonios ---------------------------------------------------- */
.tgrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:26px}
.tcard{background:var(--surface);border:1px solid var(--line-2);padding:26px 24px 20px;position:relative;box-shadow:4px 4px 0 var(--shadow);transition:transform .18s}
.tcard--a{transform:rotate(-1deg)} .tcard--b{transform:rotate(.8deg)} .tcard--c{transform:rotate(-.6deg)}
.tcard:hover{transform:rotate(0)}
.tcard__tab{position:absolute;top:-9px;left:50%;width:74px;height:20px;background:var(--marker);opacity:.85;transform:translateX(-50%) rotate(-2deg)}
.tcard__stars{color:var(--star);font-size:13px;letter-spacing:.1em;margin-bottom:12px}
.tcard p{font-size:13.5px;line-height:1.6;color:var(--ink-hi);margin:0 0 16px}
.tcard__who{font:500 11.5px/1 'IBM Plex Mono',monospace;color:var(--meta)}
.tclients{font:400 11.5px/1.8 'IBM Plex Mono',monospace;color:var(--meta-2);text-align:center;margin-top:30px}

/* -------- Equipo --------------------------------------------------------- */
.team{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:20px;align-items:start}
.tmember{min-width:0;background:var(--bg);border:1px solid var(--line-2);padding:10px 10px 12px;box-shadow:4px 4px 0 var(--shadow);transition:transform .18s ease,box-shadow .18s ease}
.tmember:nth-child(1){transform:rotate(-1.6deg)}
.tmember:nth-child(2){transform:rotate(1.2deg)}
.tmember:nth-child(3){transform:rotate(-.9deg)}
.tmember:nth-child(4){transform:rotate(1.6deg)}
.tmember:nth-child(5){transform:rotate(-1.2deg)}
.tmember:nth-child(6){transform:rotate(.9deg)}
.tmember:hover,.tmember:focus-within{transform:rotate(0);box-shadow:6px 6px 0 var(--shadow)}
.tmember img{display:block;width:100%;min-width:0;height:auto;aspect-ratio:1/1;object-fit:cover;object-position:center 20%;background:var(--line)}
.tmember h3{font:700 13.5px/1.2 'Bricolage Grotesque',sans-serif;margin:10px 0 3px}
.tmember .role{font:400 10px/1.4 'IBM Plex Mono',monospace;color:var(--meta)}

/* -------- FAQ ------------------------------------------------------------ */
.faq{display:grid;grid-template-columns:1fr 1fr;gap:26px 48px}
.faq__item{border-top:1.5px solid var(--ink);padding-top:14px}
.faq__item h3{font:700 16px/1.3 'Bricolage Grotesque',sans-serif;margin-bottom:8px}
.faq__item p{font-size:13.5px;line-height:1.6;color:var(--ink-2)}

/* -------- Banda CTA (verde, fija) ---------------------------------------- */
.cta{background:#2d9484}
.cta .container{display:flex;align-items:center;justify-content:space-between;gap:30px;padding-top:44px;padding-bottom:44px;flex-wrap:wrap}
.cta h2{font-size:clamp(26px,4vw,34px);line-height:1.1;font-weight:800;letter-spacing:-.015em;color:#08201c;margin-bottom:8px}
.cta p{font-size:14.5px;line-height:1.5;color:#08201c;max-width:440px}
.cta__actions{display:flex;gap:14px;align-items:center}
.cta__phone{font:500 14px/1 'IBM Plex Mono',monospace;color:#08201c}

/* -------- Footer terminal (teal profundo, fijo) -------------------------- */
.site-footer{background:#1f6b60;color:#fff}
.site-footer .container{padding-top:34px;padding-bottom:26px}
.footer__bar{display:flex;align-items:center;gap:14px;margin-bottom:26px;flex-wrap:wrap}
.termline{flex:1;min-width:260px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:#fff;border:1.5px solid rgba(38,32,25,.18);padding:14px 16px;font:400 13px/1 'IBM Plex Mono',monospace}
.termline .u{color:#1f7a5c}.termline .c{color:#a0937c}.termline .t{color:#2d9484}.termline .d{color:#8a7c62}.termline .cmd{color:#262019}
.termline .cursor{background:#2d9484}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{font:400 11px/1 'IBM Plex Mono',monospace;color:#262019;background:#fff;border:1px solid #fff;padding:10px 12px;text-decoration:none;transition:background-color .15s,border-color .15s}
.chip:hover{background:var(--marker);border-color:var(--marker)}
.footer__cols{display:flex;gap:48px;padding-bottom:22px;border-bottom:1px solid rgba(255,255,255,.32);flex-wrap:wrap}
.footer__brand{flex:1.4;min-width:260px}
.footer__brand .flogo{display:flex;align-items:baseline;gap:2px;margin-bottom:10px}
.footer__brand .flogo b{font:800 16px/1 'Bricolage Grotesque',sans-serif;color:#fff}
.footer__brand .flogo span{font:600 11px/1 'IBM Plex Mono',monospace;color:rgba(255,255,255,.82)}
.footer__brand p{font-size:12.5px;line-height:1.6;color:rgba(255,255,255,.9);max-width:340px}
.footer__label{font:500 10px/1 'IBM Plex Mono',monospace;letter-spacing:.14em;color:rgba(255,255,255,.82);margin:0 0 12px}
.footer__col .lines{font:400 12.5px/2 'IBM Plex Mono',monospace;color:#fff}
.footer__col a{color:#fff;text-decoration:none}
.footer__col a:hover{text-decoration:underline}
.footer__col .lang{color:rgba(255,255,255,.72)}
.footer__col .lang .on{color:#fff}
.footer__legal{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;padding-top:16px;font:400 11px/1.6 'IBM Plex Mono',monospace;color:rgba(255,255,255,.88)}
.footer__legal nav{display:flex;gap:6px 14px;flex-wrap:wrap}
.footer__legal a{color:#fff;text-decoration:none}
.footer__legal a:hover{text-decoration:underline}
.site-footer a:focus-visible,.site-footer button:focus-visible{outline-color:#fff}
.cta a:focus-visible{outline-color:#08201c}

/* -------- Consola de comandos (popup del footer) ------------------------ */
.termline{cursor:pointer;transition:box-shadow .15s}
.termline:hover,.termline:focus-visible{box-shadow:0 0 0 2px var(--marker);outline:none}
.term-overlay{position:fixed;inset:0;z-index:300;display:flex;align-items:flex-start;justify-content:center;padding:12vh 18px 18px;background:rgba(15,12,8,.62)}
.term-overlay[hidden]{display:none}
.term-win{width:min(560px,94vw);max-height:80vh;display:flex;flex-direction:column;background:#171310;border:1.5px solid var(--accent);box-shadow:8px 8px 0 rgba(0,0,0,.4);font-family:'IBM Plex Mono',ui-monospace,monospace;color:#f0e9db}
.term-winbar{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#211b14;border-bottom:1px solid #3a3226}
.term-winbar .b{width:11px;height:11px;border-radius:50%;flex:none}
.term-winbar .b.r{background:#F87171}.term-winbar .b.y{background:#ffe45c}.term-winbar .b.g{background:#2d9484}
.term-winbar .tt{flex:1;font-size:11.5px;color:#b3a68e;margin-left:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.term-winbar .x{background:transparent;border:none;color:#b3a68e;font-size:18px;line-height:1;cursor:pointer;padding:0 4px}
.term-winbar .x:hover{color:#f0e9db}
.term-out{padding:16px;font-size:13px;line-height:1.7;overflow-y:auto}
.term-out .pr{color:#3fbfa8}
.term-chips{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}
.term-chip{font:400 12px/1 'IBM Plex Mono',monospace;color:#f0e9db;background:transparent;border:1px solid #3a3226;padding:8px 11px;cursor:pointer;transition:background-color .12s,color .12s,border-color .12s}
.term-chip:hover{background:var(--accent);border-color:var(--accent);color:#08201c}
.t-hint{color:#8a7c62;font-size:12px}
.term-inrow{display:flex;align-items:center;gap:8px;padding:12px 16px;border-top:1px solid #3a3226}
.term-inrow .pr{color:#3fbfa8;font-size:13px}
.term-in{flex:1;min-width:0;background:transparent;border:none;outline:none;color:#f0e9db;font:400 13px/1.4 'IBM Plex Mono',monospace}
.term-overlay :focus-visible{outline:2px solid #3fbfa8;outline-offset:2px}

/* -------- Conmutador de tema --------------------------------------------- */
.tema{position:fixed;right:14px;bottom:14px;z-index:99;display:flex;background:var(--surface);border:1.5px solid var(--ink);box-shadow:4px 4px 0 var(--shadow-hard)}
.tema button{font:600 11px/1 'IBM Plex Mono',monospace;padding:11px 13px;border:none;background:transparent;color:var(--meta);cursor:pointer;border-left:1px solid rgba(38,32,25,.15)}
.tema button:first-child{border-left:none}
.tema button[aria-pressed="true"]{background:var(--ink);color:var(--surface)}
html.dark .tema button{border-left-color:rgba(240,233,219,.15)}
@media (prefers-color-scheme:dark){:root:not(.light) .tema button{border-left-color:rgba(240,233,219,.15)}}

/* -------- Responsive ----------------------------------------------------- */
@media (min-width:641px) and (max-width:960px){
  .plans{grid-template-columns:1fr}
  .team{grid-template-columns:repeat(3,minmax(0,1fr))}
  .grid8{grid-template-columns:repeat(2,minmax(0,1fr))}
  .selector__grid,.compare__grid,.hero__grid{flex-direction:column}
  .faq{grid-template-columns:1fr}
}
@media (max-width:640px){
  .container{padding:0 18px}
  .nav-toggle{display:inline-flex}
  .nav{position:absolute;left:0;right:0;top:100%;flex-direction:column;align-items:stretch;gap:0;background:var(--panel);border-bottom:1px solid var(--line);padding:6px 18px 16px;display:none;box-shadow:0 12px 24px var(--shadow);z-index:50}
  .site-header.nav-open .nav{display:flex}
  .nav a:not(.btn){padding:13px 0;border-top:1px solid var(--line);font-size:15px;color:var(--ink)}
  .nav a:not(.btn):first-child{border-top:none}
  .nav a.is-active{border-bottom:none}
  .nav .nav-only{display:block}
  .nav .btn.nav-only{display:flex;margin-top:12px}
  .header-actions .header-phone,.header-actions .lang,.header-actions .btn{display:none}

  .hero__grid,.selector__grid,.compare__grid{flex-direction:column;gap:26px}
  .hero .container{padding-top:30px;padding-bottom:26px}
  .section{padding:28px 0}
  .plans{grid-template-columns:1fr;gap:14px}
  .grid8{grid-template-columns:repeat(2,minmax(0,1fr))}
  .team{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
  .tgrid{grid-template-columns:1fr;gap:22px}
  .faq{grid-template-columns:1fr;gap:20px}
  .reco__cols{flex-direction:column;gap:16px}
  .reco__c+.reco__c{border-left:none;border-top:1px dashed var(--line-2);padding-left:0;padding-top:16px}
  .cta .container{flex-direction:column;align-items:flex-start;gap:18px}
  .tema{right:10px;bottom:10px}
}

/* -------- Movimiento reducido ------------------------------------------- */
@media (prefers-reduced-motion:reduce){
  .mark,html.js .mark{animation:none;background-size:100% 1.05em}
  .cursor{animation:none}
  .tcard,.tmember{transform:none !important}
  *{transition:none !important}
}
