/* ==========================================================
   LumeX · Web stylesheet (shared across 5 pages)
   ========================================================== */

:root{
  /* brand accents — stable across themes */
  --lx-mint:#00E5A0;
  --lx-aqua:#00B4D8;
  --grad:linear-gradient(135deg,#00E5A0 0%,#00B4D8 100%);

  /* semantic tokens — flip in dark mode */
  --lx-bone:#F6F8F7;
  --lx-ink:#0A2540;
  --lx-white:#FFFFFF;
  --lx-mist:#E8F2EE;
  --lx-slate:#5A6B7B;
  --lx-line:#E2E8E5;
  --lx-coral:#FF6B6B;
  --lx-amber:#FFC857;

  /* deep surface — stays dark in both modes (sections, panels, footer) */
  --lx-deep:#0A2540;
  --lx-on-deep:#F6F8F7;
  --lx-deep-line:rgba(246,248,247,.08);

  --r:14px;
  --max:1320px;
}

/* ===== DARK MODE ===== */
[data-theme="dark"]{
  --lx-bone:#07121F;
  --lx-ink:#F0F4F2;
  --lx-white:#112638;
  --lx-mist:#0C1B2A;
  --lx-slate:#A4B5C6;
  --lx-line:rgba(246,248,247,.12);
  --lx-coral:#FF8A8A;
  --lx-amber:#FFD680;

  --lx-deep:#0A1C2E;
  --lx-on-deep:#F0F4F2;
  --lx-deep-line:rgba(246,248,247,.10);
}
[data-theme="dark"]{color-scheme:dark}
[data-theme="dark"] body{background:var(--lx-bone)}

/* Section-level dark color flips that don't fit the token model */
[data-theme="dark"] .priceCard.is-feature{color:var(--lx-deep)}
[data-theme="dark"] .priceCard.is-feature h3,
[data-theme="dark"] .priceCard.is-feature .price{color:var(--lx-deep)}
[data-theme="dark"] .priceCard.is-feature ul{color:rgba(10,34,56,.7)}
[data-theme="dark"] .priceCard.is-feature .price small{color:rgba(10,34,56,.55)}
[data-theme="dark"] .priceCard.is-feature .btn--mint{background:var(--lx-deep);color:var(--lx-on-deep)}

[data-theme="dark"] .btn--solid:hover{background:#D8E1E0}

/* keep ghost buttons readable in dark CTA blocks */
[data-theme="dark"] .ctaBlock .btn--ghost{color:var(--lx-on-deep) !important;border-color:rgba(246,248,247,.2) !important}

/* compare table feature column header — stays dark even in dark mode (no flip) */
[data-theme="dark"] .compareRow.is-head .featCol{color:var(--lx-on-deep)}

/* ===== Icon SVG color overrides in dark mode ===== */
/* Stroke-based icons are hardcoded #0A2540 (light-mode ink). Override the
   attribute colors via CSS attribute selectors so they flip with the theme. */
[data-theme="dark"] .svcCard__icon,
[data-theme="dark"] .relIcon,
[data-theme="dark"] .iconCard__stage{background:rgba(246,248,247,.04)}

[data-theme="dark"] .svcCard__icon svg[stroke="#0A2540"],
[data-theme="dark"] .relIcon svg[stroke="#0A2540"],
[data-theme="dark"] .iconCard__stage svg[stroke="#0A2540"],
[data-theme="dark"] .svcCard__icon svg [stroke="#0A2540"],
[data-theme="dark"] .relIcon svg [stroke="#0A2540"],
[data-theme="dark"] .iconCard__stage svg [stroke="#0A2540"]{stroke:#E8EEF2}

[data-theme="dark"] .svcCard__icon svg[fill="#0A2540"],
[data-theme="dark"] .relIcon svg[fill="#0A2540"],
[data-theme="dark"] .iconCard__stage svg[fill="#0A2540"],
[data-theme="dark"] .svcCard__icon svg [fill="#0A2540"],
[data-theme="dark"] .relIcon svg [fill="#0A2540"],
[data-theme="dark"] .iconCard__stage svg [fill="#0A2540"]{fill:#E8EEF2}

/* Inner "bone" details inside icons → keep visible but quiet */
[data-theme="dark"] .svcCard__icon svg [fill="#F6F8F7"],
[data-theme="dark"] .relIcon svg [fill="#F6F8F7"],
[data-theme="dark"] .iconCard__stage svg [fill="#F6F8F7"]{fill:rgba(246,248,247,.10)}

/* The lone "A" glyph in the translation icon uses text fill */
[data-theme="dark"] .svcCard__icon svg text[fill="#0A2540"],
[data-theme="dark"] .relIcon svg text[fill="#0A2540"]{fill:#E8EEF2}

/* Service-card icon container — give cards a bit more breathing room */
[data-theme="dark"] .svcCard{background:var(--lx-white)}
[data-theme="dark"] .svcCard:hover{border-color:rgba(0,229,160,.5)}

/* Stronger borders / mist surfaces */
[data-theme="dark"] .section--mist{background:#0A1A2A}
[data-theme="dark"] .trustBand{background:#0A1A2A;border-color:rgba(246,248,247,.06)}

/* Form fields more visible */
[data-theme="dark"] .form input,
[data-theme="dark"] .form select,
[data-theme="dark"] .form textarea{background:#0A1A2A;border-color:rgba(246,248,247,.14);color:var(--lx-ink)}
[data-theme="dark"] .form input:focus,
[data-theme="dark"] .form select:focus,
[data-theme="dark"] .form textarea:focus{background:#0F2238;border-color:var(--lx-mint)}

/* Misc surface tweaks for richer dark mode */
[data-theme="dark"] .panel__row strong,
[data-theme="dark"] .case-author strong{color:var(--lx-on-deep)}
[data-theme="dark"] .chip{background:rgba(246,248,247,.04);border-color:rgba(246,248,247,.12);color:var(--lx-slate)}
[data-theme="dark"] .webChip{background:rgba(246,248,247,.04);border-color:rgba(246,248,247,.12)}

/* Sticky header tinted for dark mode */
[data-theme="dark"] .site-header{background:rgba(7,18,31,.78);border-bottom-color:rgba(246,248,247,.08)}

/* eyebrow dots etc remain mint */

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--lx-bone);color:var(--lx-ink);scroll-behavior:smooth}
body{font-family:'Geist','Helvetica Neue',Arial,sans-serif;font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:geometricPrecision;line-height:1.55}

a{color:inherit;text-decoration:none}
em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400}
.mono{font-family:'Geist Mono',monospace}
.muted{color:var(--lx-slate)}
.small{font-size:13px}

img,svg{display:block}

/* ============ container ============ */
.wrap{max-width:var(--max);margin:0 auto;padding:0 32px;width:100%}

/* ============ shared header ============ */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(246,248,247,.85);backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--lx-line);
}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:14px 0}
.brand{display:flex;align-items:center;gap:10px}
.brand__word{font-weight:700;font-size:22px;letter-spacing:-.6px;color:var(--lx-ink)}
.brand__word .x{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.nav{display:flex;align-items:center;gap:30px}
.nav a{font-size:14.5px;color:var(--lx-ink);transition:color .15s}
.nav a:hover{color:var(--lx-aqua)}
.nav a.is-active{color:var(--lx-ink);font-weight:500;position:relative}
.nav a.is-active::after{content:"";position:absolute;left:0;right:0;bottom:-22px;height:2px;background:var(--lx-mint)}
.head-cta{display:flex;align-items:center;gap:10px}

/* ============ buttons ============ */
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border-radius:99px;font-size:14px;font-weight:500;border:1px solid transparent;cursor:pointer;transition:transform .12s, background .12s, color .12s}
.btn:hover{transform:translateY(-1px)}
.btn--solid{background:var(--lx-ink);color:var(--lx-bone)}
.btn--solid:hover{background:#06192C}
.btn--mint{background:var(--lx-mint);color:var(--lx-ink)}
.btn--ghost{background:transparent;color:var(--lx-ink);border-color:var(--lx-line)}
.btn--ghost:hover{border-color:var(--lx-ink);background:var(--lx-white)}
.btn--lg{padding:15px 24px;font-size:15px}
.btn .arr{display:inline-block;transition:transform .15s}
.btn:hover .arr{transform:translateX(3px)}

/* ============ chips / eyebrows ============ */
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--lx-slate);margin:0 0 22px}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--lx-mint)}
.chip{display:inline-flex;align-items:center;gap:8px;padding:6px 13px;background:var(--lx-white);border:1px solid var(--lx-line);border-radius:99px;font-size:12px;font-family:'Geist Mono',monospace;color:var(--lx-slate)}
.chip .dot{width:6px;height:6px;border-radius:50%;background:var(--lx-mint);display:inline-block}

/* ============ headings ============ */
.h-display{font-size:104px;line-height:.94;letter-spacing:-3.6px;font-weight:600;margin:0;text-wrap:pretty;color:var(--lx-ink)}
.h-1{font-size:64px;line-height:1.02;letter-spacing:-2.2px;font-weight:600;margin:0 0 22px;text-wrap:pretty}
.h-2{font-size:44px;line-height:1.1;letter-spacing:-1.4px;font-weight:600;margin:0 0 18px;text-wrap:pretty}
.h-3{font-size:24px;line-height:1.25;letter-spacing:-.5px;font-weight:600;margin:0 0 12px}
.lede{font-size:19px;line-height:1.55;color:var(--lx-slate);max-width:620px;text-wrap:pretty}
.lede strong{color:var(--lx-ink);font-weight:600}

/* ============ section spacing ============ */
.section{padding:96px 0}
.section--sm{padding:64px 0}
.section--lg{padding:120px 0}
.section--ink{background:var(--lx-deep);color:var(--lx-on-deep)}
.section--ink .h-1,.section--ink .h-2{color:var(--lx-on-deep)}
.section--ink .lede{color:rgba(246,248,247,.7)}
.section--ink .eyebrow{color:rgba(246,248,247,.6)}
.section--mist{background:var(--lx-mist)}
.section--white{background:var(--lx-white)}

.section__head{margin-bottom:48px;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:end}
.section__head .lede{margin:0}

/* ============ HOME · hero ============ */
.hero{padding:80px 0 96px}
.hero__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center}
.hero__title{font-size:96px;line-height:.98;letter-spacing:-3.4px;font-weight:600;margin:18px 0 22px;color:var(--lx-ink);text-wrap:pretty}
.hero__title em{color:var(--lx-mint);font-size:1em}
.hero__lede{font-size:20px;line-height:1.5;color:var(--lx-slate);margin:0 0 32px;max-width:540px}
.hero__cta{display:flex;gap:12px;margin-bottom:40px;flex-wrap:wrap}
.hero__trust{display:grid;grid-template-columns:auto 1fr;gap:0 24px;align-items:center}
.hero__trust .label{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--lx-slate)}
.hero__trust .logos{display:flex;gap:24px;flex-wrap:wrap;color:var(--lx-slate);font-size:14px;font-weight:500;opacity:.65}

/* dashboard panel */
.panel{background:var(--lx-deep);color:var(--lx-on-deep);border-radius:18px;padding:24px 26px;box-shadow:0 40px 80px -40px rgba(10,37,64,.45);position:relative;overflow:hidden}
.panel::after{content:"";position:absolute;top:-100px;right:-80px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(0,229,160,.25),transparent 70%);pointer-events:none}
.panel header{display:flex;align-items:center;gap:8px;padding-bottom:14px;border-bottom:1px solid rgba(246,248,247,.08);margin-bottom:6px;font-size:12px;position:relative;z-index:1}
.panel header .dot{width:8px;height:8px;border-radius:50%;background:var(--lx-mint)}
.panel header > *:last-child{margin-left:auto;color:rgba(246,248,247,.45);font-family:'Geist Mono',monospace;font-size:11px}
.panel__row{display:grid;grid-template-columns:1fr auto auto;gap:14px;align-items:center;padding:14px 0;border-bottom:1px solid rgba(246,248,247,.06);font-size:14px;position:relative;z-index:1}
.panel__row:last-of-type{border-bottom:0}
.panel__row span:first-child{color:rgba(246,248,247,.7)}
.panel__row strong{font-size:20px;font-weight:600;color:var(--lx-bone);font-family:'Geist Mono',monospace}
.panel__row .trend{font-family:'Geist Mono',monospace;font-size:11px;color:var(--lx-mint);padding:3px 9px;border:1px solid rgba(0,229,160,.3);border-radius:99px}
.panel__row .trend.is-warm{color:var(--lx-amber);border-color:rgba(255,200,87,.4)}
.panel__foot{padding-top:14px;border-top:1px solid rgba(246,248,247,.08);margin-top:6px;font-size:11px;color:rgba(246,248,247,.45);display:flex;justify-content:space-between;position:relative;z-index:1}

/* ============ trust band ============ */
.trustBand{padding:32px 0;border-top:1px solid var(--lx-line);border-bottom:1px solid var(--lx-line);background:var(--lx-bone)}
.trustBand__grid{display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:center}
.trustBand .label{font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--lx-slate)}
.trustBand__logos{display:flex;justify-content:space-between;align-items:center;gap:32px;color:var(--lx-slate);opacity:.6;font-weight:500;font-size:18px;flex-wrap:wrap}
.trustBand__logos span{letter-spacing:-.3px}

/* ============ services grid ============ */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.svc-grid.is-cols-2{grid-template-columns:repeat(2,1fr)}
.svcCard{background:var(--lx-white);border:1px solid var(--lx-line);border-radius:var(--r);padding:28px;display:flex;flex-direction:column;gap:14px;transition:border-color .15s,transform .15s,box-shadow .2s;position:relative;overflow:hidden}
.svcCard:hover{border-color:var(--lx-ink);transform:translateY(-2px);box-shadow:0 24px 48px -28px rgba(10,37,64,.18)}
.svcCard__head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.svcCard__icon{width:56px;height:56px;background:var(--lx-bone);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.svcCard__icon svg{width:32px;height:32px}
.svcCard__num{font-family:'Geist Mono',monospace;font-size:11px;color:var(--lx-slate);letter-spacing:1px}
.svcCard h3{margin:0 0 4px;font-size:20px;font-weight:600;letter-spacing:-.4px;color:var(--lx-ink)}
.svcCard p{margin:0;font-size:14.5px;color:var(--lx-slate);line-height:1.55;text-wrap:pretty}
.svcCard__foot{margin-top:auto;display:flex;justify-content:space-between;align-items:center;padding-top:18px;border-top:1px solid var(--lx-line);font-size:13px;color:var(--lx-slate);font-family:'Geist Mono',monospace}
.svcCard__foot .price{color:var(--lx-ink);font-weight:600}
.svcCard__foot .arr{color:var(--lx-mint);transition:transform .15s}
.svcCard:hover .svcCard__foot .arr{transform:translateX(3px)}

/* ============ steps · how it works ============ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;position:relative}
.step{padding:32px 28px;background:var(--lx-white);border:1px solid var(--lx-line);border-radius:var(--r);position:relative}
.step + .step{margin-left:-1px}
.step__num{font-family:'Geist Mono',monospace;font-size:12px;letter-spacing:1.5px;color:var(--lx-mint);margin-bottom:14px;display:block}
.step h3{font-size:22px;font-weight:600;margin:0 0 12px;letter-spacing:-.4px;color:var(--lx-ink)}
.step p{margin:0;font-size:14.5px;color:var(--lx-slate);line-height:1.55}
.step__time{margin-top:16px;font-family:'Geist Mono',monospace;font-size:11px;color:var(--lx-slate);padding:5px 10px;background:var(--lx-mist);border-radius:99px;display:inline-block;letter-spacing:1px}

/* ============ case study ============ */
.case{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;background:var(--lx-white);border:1px solid var(--lx-line);border-radius:var(--r);overflow:hidden}
.case__left{padding:48px}
.case__quote{font-family:'Instrument Serif',serif;font-style:italic;font-size:34px;line-height:1.25;color:var(--lx-ink);margin:24px 0 32px;text-wrap:pretty}
.case__author{display:flex;align-items:center;gap:14px}
.case__avatar{width:48px;height:48px;border-radius:50%;background:var(--lx-mint);display:flex;align-items:center;justify-content:center;color:var(--lx-ink);font-weight:600}
.case__author strong{display:block;color:var(--lx-ink);font-size:15px;font-weight:600}
.case__author span{color:var(--lx-slate);font-size:13px}
.case__metrics{background:var(--lx-deep);color:var(--lx-on-deep);padding:48px;display:flex;flex-direction:column;justify-content:center;gap:30px}
.metric{}
.metric__num{font-size:64px;font-weight:600;letter-spacing:-2px;line-height:1;color:var(--lx-mint);font-family:'Geist',sans-serif;margin-bottom:8px}
.metric__num .unit{font-size:32px;color:rgba(0,229,160,.6)}
.metric__label{font-size:13px;color:rgba(246,248,247,.7);line-height:1.4;max-width:280px}
.metric__disclaimer{font-size:11px;color:rgba(246,248,247,.4);line-height:1.4;margin-top:16px;font-style:italic;grid-column:1/-1}

/* ============ manifesto editorial moment ============ */
.manifesto{padding:120px 0;text-align:left}
.manifesto__head{font-family:'Instrument Serif',serif;font-style:italic;font-size:68px;line-height:1.1;color:var(--lx-bone);max-width:1100px;margin:0;letter-spacing:-1.5px;text-wrap:pretty}
.manifesto__head .high{color:var(--lx-mint)}
.manifesto__sign{margin-top:48px;display:flex;justify-content:space-between;border-top:1px solid rgba(246,248,247,.1);padding-top:24px;font-family:'Geist Mono',monospace;font-size:12px;color:rgba(246,248,247,.5);letter-spacing:1px}

/* ============ pricing teaser ============ */
.priceTeaser{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.priceCard{background:var(--lx-white);border:1px solid var(--lx-line);border-radius:var(--r);padding:32px;display:flex;flex-direction:column;gap:14px}
.priceCard.is-feature{background:var(--lx-ink);color:var(--lx-bone);border-color:var(--lx-ink);transform:translateY(-12px);box-shadow:0 40px 80px -40px rgba(10,37,64,.4)}
.priceCard.is-feature h3,.priceCard.is-feature .price{color:var(--lx-bone)}
.priceCard.is-feature .priceCard__label{color:var(--lx-mint)}
.priceCard__label{font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--lx-slate)}
.priceCard h3{font-size:26px;font-weight:600;margin:0;letter-spacing:-.5px;color:var(--lx-ink)}
.priceCard .price{font-size:48px;font-weight:600;color:var(--lx-ink);letter-spacing:-1.4px;line-height:1}
.priceCard .price small{font-size:14px;color:var(--lx-slate);font-weight:400;letter-spacing:0}
.priceCard.is-feature .price small{color:rgba(246,248,247,.5)}
.priceCard ul{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:8px;font-size:14px;color:var(--lx-slate);flex:1}
.priceCard.is-feature ul{color:rgba(246,248,247,.8)}
.priceCard ul li{display:flex;gap:10px;align-items:start}
.priceCard ul li::before{content:"→";color:var(--lx-mint);font-family:'Geist Mono',monospace;flex-shrink:0}
.priceCard .btn{margin-top:14px;justify-content:center}

/* ============ faq ============ */
.faq{display:flex;flex-direction:column;gap:8px;max-width:880px;margin:0 auto}
.faqItem{background:var(--lx-white);border:1px solid var(--lx-line);border-radius:12px;padding:24px 28px}
.faqItem h4{margin:0 0 10px;font-size:18px;font-weight:600;letter-spacing:-.3px;color:var(--lx-ink);display:flex;justify-content:space-between;align-items:start;gap:24px}
.faqItem h4 .q{font-family:'Geist Mono',monospace;font-size:11px;color:var(--lx-slate);font-weight:400;letter-spacing:1px;flex-shrink:0}
.faqItem p{margin:0;color:var(--lx-slate);font-size:15px;line-height:1.55}

/* ============ footer ============ */
.site-footer{background:var(--lx-deep);color:var(--lx-on-deep);padding:80px 0 40px;margin-top:80px}
.site-footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:48px;margin-bottom:64px}
.site-footer h5{font-size:12px;font-family:'Geist Mono',monospace;letter-spacing:1.5px;text-transform:uppercase;color:rgba(246,248,247,.5);margin:0 0 16px}
.site-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;font-size:14px;color:rgba(246,248,247,.85)}
.site-footer ul a:hover{color:var(--lx-mint)}
.site-footer__brand{}
.site-footer__brand .lede{color:rgba(246,248,247,.65);font-size:15px;margin:16px 0 28px;max-width:340px}
.site-footer__newsletter{display:flex;gap:0;background:rgba(246,248,247,.05);border:1px solid rgba(246,248,247,.08);border-radius:99px;padding:6px;max-width:320px}
.site-footer__newsletter input{flex:1;background:transparent;border:0;outline:0;padding:8px 14px;color:var(--lx-bone);font-family:Geist,sans-serif;font-size:13px}
.site-footer__newsletter input::placeholder{color:rgba(246,248,247,.4)}
.site-footer__newsletter button{background:var(--lx-mint);color:var(--lx-ink);border:0;padding:8px 16px;border-radius:99px;font-weight:500;font-size:13px;cursor:pointer;font-family:Geist,sans-serif}
.site-footer__bottom{padding-top:32px;border-top:1px solid rgba(246,248,247,.08);display:flex;justify-content:space-between;font-family:'Geist Mono',monospace;font-size:11px;color:rgba(246,248,247,.45);letter-spacing:1px}

/* ============ secondary page heros ============ */
.pageHero{padding:64px 0 56px;border-bottom:1px solid var(--lx-line)}
.pageHero__grid{display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:end}
.pageHero h1{font-size:80px;line-height:.98;letter-spacing:-2.8px;font-weight:600;margin:18px 0 0;color:var(--lx-ink);text-wrap:pretty}
.pageHero h1 em{color:var(--lx-mint)}
.pageHero .lede{font-size:18px;margin:24px 0 0;max-width:520px}

/* ============ servicios page ============ */
.svcDetailGrid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px}
.svcDetailGrid__left h2{margin:0 0 18px}
.checks{list-style:none;margin:20px 0 0;padding:0;display:flex;flex-direction:column;gap:14px}
.checks li{display:grid;grid-template-columns:32px 1fr;gap:14px;font-size:15px;color:var(--lx-ink);line-height:1.5}
.checks li::before{content:"✓";color:var(--lx-mint);font-weight:700;font-size:18px;line-height:1}
.checks li strong{display:block;color:var(--lx-ink);font-weight:600;margin-bottom:2px}
.checks li span{color:var(--lx-slate);font-size:14px}

/* dashboard preview card */
.previewCard{background:var(--lx-white);border:1px solid var(--lx-line);border-radius:var(--r);padding:24px;display:flex;flex-direction:column;gap:18px}
.previewCard h4{font-size:14px;margin:0;display:flex;justify-content:space-between;align-items:center}
.previewCard h4 .badge{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:1px;padding:3px 8px;border-radius:99px;background:var(--lx-mint);color:var(--lx-ink)}
.sentBar{display:flex;height:24px;border-radius:6px;overflow:hidden}
.sentBar > div{display:flex;align-items:center;justify-content:center;font-family:'Geist Mono',monospace;font-size:10px;color:var(--lx-ink)}
.sentLabels{display:flex;justify-content:space-between;font-family:'Geist Mono',monospace;font-size:10px;color:var(--lx-slate);letter-spacing:1px;margin-top:-6px}
.sentList{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;font-size:13px}
.sentList li{display:grid;grid-template-columns:24px 1fr auto;gap:10px;align-items:center;padding:10px 0;border-bottom:1px solid var(--lx-line)}
.sentList li:last-child{border-bottom:0}
.sentList li .emoji{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px}
.sentList li.is-pos .emoji{background:rgba(0,229,160,.2)}
.sentList li.is-neu .emoji{background:rgba(0,180,216,.15)}
.sentList li.is-neg .emoji{background:rgba(255,107,107,.18)}
.sentList li .quote{color:var(--lx-ink);line-height:1.4}
.sentList li .meta{color:var(--lx-slate);font-family:'Geist Mono',monospace;font-size:11px}

/* ============ precios page table ============ */
.compare{background:var(--lx-white);border:1px solid var(--lx-line);border-radius:var(--r);overflow:hidden}
.compareRow{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;border-bottom:1px solid var(--lx-line)}
.compareRow:last-child{border-bottom:0}
.compareRow > div{padding:18px 24px;font-size:14px;color:var(--lx-ink);display:flex;align-items:center;gap:8px}
.compareRow > div + div{border-left:1px solid var(--lx-line);justify-content:center;color:var(--lx-slate)}
.compareRow.is-head > div{background:var(--lx-mist);color:var(--lx-ink);font-weight:600;font-size:13px}
.compareRow.is-head .featCol{background:var(--lx-deep);color:var(--lx-on-deep)}
.compareRow .featCol{background:rgba(0,229,160,.06)}
.compareRow .check{color:var(--lx-mint);font-weight:700;font-size:18px}
.compareRow .x{color:var(--lx-line);font-weight:700;font-size:16px}

/* ============ contacto ============ */
.contactGrid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px}
.form{background:var(--lx-white);border:1px solid var(--lx-line);border-radius:var(--r);padding:36px;display:flex;flex-direction:column;gap:18px}
.form__row{display:flex;flex-direction:column;gap:6px}
.form__row.is-split{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form label{font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--lx-slate)}
.form input,.form select,.form textarea{font-family:Geist,sans-serif;font-size:15px;padding:13px 14px;background:var(--lx-bone);border:1px solid var(--lx-line);border-radius:8px;color:var(--lx-ink);outline:0;transition:border-color .15s,background .15s}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--lx-ink);background:var(--lx-white)}
.form textarea{min-height:140px;resize:vertical;font-family:Geist,sans-serif}
.form__hint{font-size:12px;color:var(--lx-slate)}
.form__check{display:flex;gap:10px;align-items:start;font-size:13px;color:var(--lx-slate);line-height:1.5}
.form__check input{width:18px;height:18px;margin-top:1px}
.form .btn{align-self:flex-start;margin-top:8px}

.contactSide{display:flex;flex-direction:column;gap:24px}
.contactBlock{background:var(--lx-white);border:1px solid var(--lx-line);border-radius:var(--r);padding:24px}
.contactBlock h5{margin:0 0 12px;font-size:12px;font-family:'Geist Mono',monospace;letter-spacing:1.5px;text-transform:uppercase;color:var(--lx-slate)}
.contactBlock p{margin:0 0 6px;font-size:15px;color:var(--lx-ink)}
.contactBlock .big{font-size:22px;font-weight:600;letter-spacing:-.4px}
.contactBlock a{color:var(--lx-aqua);border-bottom:1px solid var(--lx-line)}

/* ============ cta block ============ */
.ctaBlock{background:var(--lx-deep);color:var(--lx-on-deep);border-radius:var(--r);padding:80px 64px;position:relative;overflow:hidden;display:grid;grid-template-columns:1.4fr .6fr;gap:48px;align-items:center}
.ctaBlock::after{content:"";position:absolute;right:-100px;top:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(0,229,160,.18),transparent 60%);pointer-events:none}
.ctaBlock h2{font-size:56px;line-height:1.02;letter-spacing:-1.8px;font-weight:600;color:var(--lx-on-deep);margin:0 0 20px;text-wrap:pretty;position:relative;z-index:1}
.ctaBlock h2 em{color:var(--lx-mint)}
.ctaBlock p{margin:0 0 28px;color:rgba(246,248,247,.7);font-size:18px;line-height:1.5;max-width:520px;position:relative;z-index:1}
.ctaBlock .actions{display:flex;gap:12px;flex-wrap:wrap;position:relative;z-index:1}
.ctaBlock .ap{position:relative;z-index:1}

/* ============ related services rail ============ */
.relRail{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.relCard{background:var(--lx-white);border:1px solid var(--lx-line);border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:10px;transition:border-color .15s,transform .15s}
.relCard:hover{border-color:var(--lx-ink);transform:translateY(-2px)}
.relCard .relIcon{width:40px;height:40px;background:var(--lx-bone);border-radius:8px;display:flex;align-items:center;justify-content:center}
.relCard .relIcon svg{width:24px;height:24px}
.relCard h4{margin:0;font-size:15px;font-weight:600;color:var(--lx-ink)}
.relCard span{font-size:12px;color:var(--lx-slate);font-family:'Geist Mono',monospace}




/* ============ theme toggle ============ */
.theme-toggle{
  width:36px;height:36px;border-radius:50%;background:transparent;border:1px solid var(--lx-line);
  display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--lx-ink);padding:0;
  transition:background .15s,border-color .15s,transform .12s;
}
.theme-toggle:hover{background:var(--lx-white);border-color:var(--lx-ink);transform:translateY(-1px)}
.theme-toggle svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}
.theme-toggle .icon-moon{display:block}
.theme-toggle .icon-sun{display:none}
[data-theme="dark"] .theme-toggle .icon-moon{display:none}
[data-theme="dark"] .theme-toggle .icon-sun{display:block}

@media (max-width: 960px){
  .theme-toggle{order:2;width:34px;height:34px}
  .theme-toggle svg{width:16px;height:16px}
}

/* ==========================================================
   MOBILE STYLES · break at 960 (tablet) and 640 (phone)
   ========================================================== */

/* Hamburger toggle — hidden on desktop */
.nav-toggle{display:none}
.nav-toggle-label{display:none}

@media (max-width: 960px){
  /* container padding */
  .wrap{padding:0 20px}

  /* Header — hamburger replaces nav links */
  .site-header__inner{padding:14px 0;gap:12px;flex-wrap:wrap;position:relative}
  .nav-toggle-label{
    display:flex;flex-direction:column;justify-content:space-between;
    width:32px;height:22px;cursor:pointer;
    order:3;margin-left:auto;
  }
  .nav-toggle-label span{
    display:block;height:2px;width:100%;background:var(--lx-ink);border-radius:2px;
    transition:transform .2s ease, opacity .2s ease;transform-origin:center;
  }
  .nav-toggle:checked ~ .nav-toggle-label span:nth-child(1){transform:translateY(10px) rotate(45deg)}
  .nav-toggle:checked ~ .nav-toggle-label span:nth-child(2){opacity:0}
  .nav-toggle:checked ~ .nav-toggle-label span:nth-child(3){transform:translateY(-10px) rotate(-45deg)}

  .nav{
    order:5;flex-basis:100%;
    display:none;flex-direction:column;gap:0;
    padding:12px 0 8px;border-top:1px solid var(--lx-line);
    margin-top:6px;
  }
  .nav-toggle:checked ~ .nav{display:flex}
  .nav a{padding:14px 0;font-size:16px;border-bottom:1px solid var(--lx-line)}
  .nav a:last-child{border-bottom:0}
  .nav a.is-active::after{display:none}
  .nav a.is-active{color:var(--lx-mint)}

  .head-cta{order:4}
  .head-cta .btn--ghost{display:none}
  .head-cta .btn{padding:9px 14px;font-size:13px}

  /* Headings */
  .h-display{font-size:64px;letter-spacing:-2px}
  .h-1{font-size:44px;letter-spacing:-1.4px}
  .h-2{font-size:32px;letter-spacing:-1px}

  /* Hero */
  .hero{padding:48px 0 64px}
  .hero__grid{grid-template-columns:1fr;gap:40px}
  .hero__title{font-size:56px;letter-spacing:-2px;line-height:1}
  .hero__lede{font-size:17px}
  .hero__cta{gap:10px}
  .hero__trust{grid-template-columns:1fr;gap:12px}
  .hero__trust .logos{gap:14px;font-size:13px}

  /* Sections */
  .section{padding:64px 0}
  .section--lg{padding:80px 0}
  .section--sm{padding:48px 0}
  .section__head{grid-template-columns:1fr;gap:18px;margin-bottom:32px}

  /* Trust band */
  .trustBand__grid{grid-template-columns:1fr;gap:14px}
  .trustBand__logos{gap:14px;font-size:14px;justify-content:flex-start}

  /* Services grid */
  .svc-grid{grid-template-columns:1fr 1fr;gap:10px}
  .svc-grid.is-cols-2{grid-template-columns:1fr}
  .svcCard{padding:20px}
  .svcCard h3{font-size:18px}
  .svcCard p{font-size:13px}
  .svcCard__foot{font-size:12px}

  /* Steps */
  .steps{grid-template-columns:1fr;gap:10px}
  .step + .step{margin-left:0;margin-top:-1px}
  .step{padding:24px 22px}

  /* Case study */
  .case{grid-template-columns:1fr}
  .case__left{padding:32px 24px}
  .case__quote{font-size:24px}
  .case__metrics{padding:32px 24px;gap:22px}
  .metric__num{font-size:48px}
  .metric__num .unit{font-size:24px}

  /* Manifesto */
  .manifesto{padding:72px 0}
  .manifesto__head{font-size:34px;letter-spacing:-.8px;line-height:1.15}
  .manifesto__sign{flex-direction:column;gap:8px}

  /* Pricing teaser */
  .priceTeaser{grid-template-columns:1fr;gap:14px}
  .priceCard.is-feature{transform:none}
  .priceCard{padding:24px}

  /* FAQ */
  .faq{padding:0}
  .faqItem{padding:20px 22px}
  .faqItem h4{font-size:16px;gap:12px}
  .faqItem h4 .q{font-size:10px}

  /* Footer */
  .site-footer{padding:56px 0 28px;margin-top:48px}
  .site-footer__grid{grid-template-columns:1fr 1fr;gap:36px;margin-bottom:40px}
  .site-footer__brand{grid-column:1 / -1}
  .site-footer__brand .lede{font-size:14px}
  .site-footer__newsletter{max-width:100%}
  .site-footer__bottom{flex-direction:column;gap:8px;text-align:left;align-items:flex-start}

  /* Page heroes */
  .pageHero{padding:40px 0 32px}
  .pageHero__grid{grid-template-columns:1fr;gap:18px}
  .pageHero h1{font-size:48px;letter-spacing:-1.6px}
  .pageHero .lede{font-size:16px}

  /* Service detail */
  .svcDetailGrid{grid-template-columns:1fr;gap:40px}
  .checks li{font-size:14px}

  /* Compare table → scrollable card stack */
  .compare{border-radius:10px}
  .compareRow{grid-template-columns:1.3fr .9fr .9fr .9fr;font-size:12px}
  .compareRow > div{padding:14px 12px;font-size:12px}
  .compareRow.is-head > div{font-size:11px}

  /* Contact */
  .contactGrid{grid-template-columns:1fr;gap:32px}
  .form{padding:28px 24px}
  .form__row.is-split{grid-template-columns:1fr;gap:14px}

  /* CTA Block */
  .ctaBlock{padding:48px 32px;grid-template-columns:1fr;gap:24px;text-align:left}
  .ctaBlock h2{font-size:40px;letter-spacing:-1.2px}
  .ctaBlock p{font-size:16px}
  .ctaBlock .ap{display:none}

  /* Related rail */
  .relRail{grid-template-columns:1fr 1fr;gap:10px}

  /* Panel */
  .panel{padding:20px 18px}
  .panel__row strong{font-size:18px}

  /* Preview cards */
  .previewCard{padding:18px}

  /* Hide compare columns on tiny screens? Keep for now */
}

/* Phone-specific */
@media (max-width: 560px){
  .wrap{padding:0 18px}

  /* Services + related stack to single column */
  .svc-grid{grid-template-columns:1fr}
  .relRail{grid-template-columns:1fr 1fr}

  /* Headings */
  .h-display{font-size:48px;letter-spacing:-1.6px}
  .h-1{font-size:36px;letter-spacing:-1.2px;line-height:1.05}
  .h-2{font-size:28px;letter-spacing:-.8px}
  .hero__title{font-size:44px;letter-spacing:-1.4px}
  .pageHero h1{font-size:40px;letter-spacing:-1.3px}
  .ctaBlock h2{font-size:32px;letter-spacing:-1px}

  /* Manifesto */
  .manifesto__head{font-size:26px}

  /* Footer columns */
  .site-footer__grid{grid-template-columns:1fr;gap:32px}

  /* Trust band logos wrap */
  .trustBand__logos{font-size:13px;gap:10px 18px}

  /* Compare → scroll horizontally */
  .compare{overflow-x:auto;border-radius:10px}
  .compareRow{min-width:520px}

  /* Buttons */
  .btn{padding:10px 16px;font-size:13px}
  .btn--lg{padding:13px 20px;font-size:14px}
  .hero__cta{flex-direction:column;align-items:stretch}
  .hero__cta .btn{justify-content:center}
  .ctaBlock .actions{flex-direction:column;align-items:stretch}
  .ctaBlock .actions .btn{justify-content:center}

  /* Sections */
  .section{padding:48px 0}
  .section--lg{padding:56px 0}

  /* Case metrics */
  .metric__num{font-size:40px}
  .metric__num .unit{font-size:20px}

  /* CTA block padding */
  .ctaBlock{padding:36px 24px}

  /* Form */
  .form{padding:22px 20px}

  /* Tagline chips wrap */
  .chip{font-size:11px;padding:5px 11px}
}

/* ==========================================================
   MOBILE FIXES · inline grids sin fallback responsive
   ========================================================== */

/* --- blog.html · featured post 2 cols --- */
.blog-featured{display:grid;grid-template-columns:1fr 1fr;gap:0;background:var(--lx-deep);color:var(--lx-on-deep);border-radius:var(--r);overflow:hidden;text-decoration:none}
.blog-featured__visual{background:radial-gradient(circle at 70% 30%,rgba(0,229,160,.25),transparent 60%),linear-gradient(135deg,#0A2540,#06192C);display:flex;align-items:center;justify-content:center;padding:48px;position:relative}

@media (max-width:768px){
  .blog-featured{grid-template-columns:1fr}
  .blog-featured__visual{display:none}
}

/* --- sobre.html · métricas 4 cols --- */
.sobre-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:var(--lx-white);border:1px solid var(--lx-line);border-radius:var(--r);overflow:hidden}

@media (max-width:768px){
  .sobre-metrics{grid-template-columns:repeat(2,1fr)}
  .sobre-metrics > div{border-right:1px solid var(--lx-line) !important;border-bottom:1px solid var(--lx-line)}
  .sobre-metrics > div:nth-child(2n){border-right:0 !important}
  .sobre-metrics > div:last-child,.sobre-metrics > div:nth-last-child(2){border-bottom:0}
}
@media (max-width:420px){
  .sobre-metrics > div{padding:24px 18px}
  .sobre-metrics > div > p:first-child{font-size:52px !important;letter-spacing:-1.8px !important}
}

/* --- sobre.html · equipo 4 cols --- */
.sobre-team{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}

@media (max-width:768px){.sobre-team{grid-template-columns:repeat(2,1fr)}}
@media (max-width:400px){.sobre-team{grid-template-columns:1fr}}

/* --- sobre.html · principios 5 cols --- */
.sobre-principles{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--lx-line);border:1px solid var(--lx-line);border-radius:var(--r);overflow:hidden}

@media (max-width:960px){.sobre-principles{grid-template-columns:repeat(3,1fr)}}
@media (max-width:560px){.sobre-principles{grid-template-columns:repeat(2,1fr)}}

/* --- contacto.html · métricas 3 cols --- */
.contacto-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;text-align:center}

@media (max-width:560px){
  .contacto-metrics{grid-template-columns:1fr;gap:16px}
  .contacto-metrics .metric__num{font-size:48px !important}
}

/* --- servicio-creacion-webs.html · Lighthouse 4 cols --- */
.lighthouse-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}

@media (max-width:560px){.lighthouse-grid{grid-template-columns:repeat(2,1fr)}}

/* --- servicio-web-scraping.html · tabla de datos --- */
.scraping-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:8px}
.scraping-table-wrap > *{min-width:440px}
