/* @fonts:start — self-hosted brand fonts (latin subset). Regen: py scripts/selfhost_fonts.py */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/inter-400.woff2') format('woff2'); unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/inter-500.woff2') format('woff2'); unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/inter-600.woff2') format('woff2'); unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/inter-700.woff2') format('woff2'); unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/jetbrains-mono-400.woff2') format('woff2'); unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/jetbrains-mono-500.woff2') format('woff2'); unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/jetbrains-mono-700.woff2') format('woff2'); unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Rajdhani';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/rajdhani-500.woff2') format('woff2'); unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Rajdhani';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/rajdhani-600.woff2') format('woff2'); unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Rajdhani';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/rajdhani-700.woff2') format('woff2'); unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
/* @fonts:end */
/* =========================================================
   LVLUp / CYBERPUNK PATCH BUILD
   Vanilla CSS — no framework. Design tokens + components.
   ========================================================= */

:root {
    /* Brand */
    --c-bg:        #050811;
    --c-bg-2:      #0A0F1D;
    --c-bg-3:      #0E1424;
    --c-fg:        #EAF0FF;
    --c-muted:     #6D7793;
    --c-line:      rgba(234, 240, 255, .08);
    --c-line-2:    rgba(234, 240, 255, .14);

    --c-lime:      #B8FF2E;
    --c-lime-2:    #84CC16;
    --c-cyan:      #00E5FF;
    --c-cyan-2:    #06B6D4;
    --c-red:       #FF2D55;
    --c-yellow:    #F7F23A;

    /* Type */
    --f-display: 'Rajdhani', 'Space Grotesk', system-ui, sans-serif;
    --f-body:    'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
    --f-mono:    'JetBrains Mono', 'IBM Plex Mono', ui-monospace, monospace;

    /* Layout */
    --nav-w: 80px;
    --pad-x: clamp(1.25rem, 4vw, 3rem);

    /* Motion */
    --ease: cubic-bezier(.2, .8, .2, 1);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

html {
    background: var(--c-bg);
    color: var(--c-fg);
    font-family: var(--f-body);
    font-size: 16px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    scroll-behavior: smooth;
}

body {
    overflow-x: hidden;
    background:
        radial-gradient(1200px 800px at 80% -10%, rgba(0, 229, 255, .07), transparent 60%),
        radial-gradient(1200px 800px at -10% 30%, rgba(184, 255, 46, .05), transparent 60%),
        var(--c-bg);
    min-height: 100vh;
}

a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
ul { list-style: none; padding: 0; margin: 0; }

/* Paragraph copy — justified body text with auto-hyphenation so the
   inter-word gaps stay tight on narrow columns. Scoped to <main> so the
   footer/status-bar utility text keeps its natural alignment. */
main p {
    text-align: justify;
    text-justify: inter-word;
    hyphens: auto;
    -webkit-hyphens: auto;
}
/* Restore left-align for very short utility text where justify creates
   awkward stretching (1-2 word labels, metadata strips). */
main .meta,
main .save-foot {
    text-align: left;
    hyphens: manual;
    -webkit-hyphens: manual;
}

::selection { background: var(--c-lime); color: var(--c-bg); }

/* Visible focus rings for keyboard navigation (a11y) */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
summary:focus-visible {
    outline: 2px solid var(--c-lime);
    outline-offset: 2px;
}
a:focus:not(:focus-visible),
button:focus:not(:focus-visible) { outline: none; }

/* Skip-to-content link (WCAG 2.4.1) — visible only on keyboard focus */
.skip-link {
    position: absolute;
    left: 12px;
    top: -120px;
    z-index: 10000;
    padding: 12px 18px;
    background: var(--c-lime);
    color: #000;
    font-family: var(--f-mono);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    text-decoration: none;
    border: 2px solid #000;
    box-shadow: 4px 4px 0 #000;
    transition: top .2s ease-out;
}
.skip-link:focus {
    top: 12px;
    outline: 2px solid #000;
    outline-offset: 2px;
}

/* Visually hidden utility (for screen-reader-only text) */
.visually-hidden,
.sr-only {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

/* Scrollbar */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--c-bg-2); }
::-webkit-scrollbar-thumb { background: var(--c-line-2); }
::-webkit-scrollbar-thumb:hover { background: var(--c-lime); }

/* =========================================================
   Typography
   ========================================================= */

.h-eyebrow {
    font-family: var(--f-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .22em;
    color: var(--c-muted);
}

.h-title {
    font-family: var(--f-display);
    font-weight: 700;
    line-height: 1.05;
    letter-spacing: -.005em;
    text-transform: uppercase;
    font-size: clamp(2.2rem, 6vw, 5.2rem);
    margin: 0 0 .5em;
    text-wrap: balance;
}

.h-title .accent { color: var(--c-lime); }
.h-title .accent-cy { color: var(--c-cyan); }

.h-lead {
    font-size: clamp(1rem, 1.1vw, 1.125rem);
    color: rgba(234, 240, 255, .72);
    max-width: 56ch;
    margin: 0;
}

/* Pain-acknowledgment line that follows the hero lead.
   Smaller, italic, with a left cyan rail and subtle backdrop — reads as
   "an aside" without losing legibility on busy hero backgrounds (WebGL
   grid, scanlines, etc.). In light theme: dark text on subtle yellow. */
.hero-empathy {
    font-size: 14.5px;
    color: rgba(234, 240, 255, .92);
    max-width: 60ch;
    margin: 1.1rem 0 0;
    padding: .85rem 1rem .85rem 1.1rem;
    border-left: 2px solid var(--c-cyan);
    background: rgba(0, 229, 255, .07);
    font-style: italic;
    line-height: 1.6;
    /* Subtle shadow so the panel reads against animated/noisy backgrounds. */
    box-shadow: inset 0 0 0 1px rgba(0, 229, 255, .12);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
}
body[data-theme="light"] .hero-empathy {
    color: #1A1A1A;
    border-left-color: var(--c-fg);
    background: rgba(247, 242, 58, .35);
    box-shadow: inset 0 0 0 1px rgba(10, 10, 10, .12);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.mono { font-family: var(--f-mono); font-size: 12px; letter-spacing: .04em; }

/* =========================================================
   Top status bar
   ========================================================= */

.status-bar {
    position: fixed;
    top: 0; left: 0; right: 0;
    height: 36px;
    z-index: 60;
    background: rgba(5, 8, 17, .85);
    backdrop-filter: blur(8px);
    border-bottom: 1px solid var(--c-line);
    display: flex;
    align-items: center;
    gap: 1.5rem;
    padding: 0 1rem;
    font-family: var(--f-mono);
    font-size: 11px;
    color: var(--c-muted);
    text-transform: uppercase;
    letter-spacing: .18em;
}

.status-bar .dot {
    width: 6px; height: 6px;
    background: var(--c-lime);
    border-radius: 50%;
    box-shadow: 0 0 8px var(--c-lime);
    animation: pulse 1.6s ease-in-out infinite;
}

.status-bar .sep {
    width: 1px; height: 16px;
    background: var(--c-line-2);
}

.status-bar .right {
    margin-left: auto;
    display: flex;
    gap: 1.25rem;
}

.status-bar .right span::before {
    content: '';
    display: inline-block;
    width: 6px; height: 6px;
    background: var(--c-cyan);
    margin-right: .5rem;
    transform: translateY(-1px);
}

@keyframes pulse {
    0%,100% { opacity: 1; transform: scale(1); }
    50%     { opacity: .55; transform: scale(1.3); }
}

/* =========================================================
   Brand mark (top-left)
   ========================================================= */

.brand {
    position: fixed;
    top: 50px;
    left: 18px;
    z-index: 50;
    display: flex;
    align-items: center;
    gap: .55rem;
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 18px;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.brand-glyph {
    width: 44px;
    height: 36px;
    display: grid;
    place-items: center;
    background: #000000;
    padding: 4px 6px;
    clip-path: polygon(8% 0, 100% 0, 100% 78%, 92% 100%, 0 100%, 0 22%);
    transition: transform .2s var(--ease);
}

.brand-glyph svg {
    width: 100%;
    height: 100%;
    display: block;
}

.brand:hover .brand-glyph {
    transform: translateY(-1px);
}

/* In light theme: keep the black framed cyberpunk mark — high contrast on white bg */
body[data-theme="light"] .brand-glyph {
    background: #000000;
    box-shadow: 2px 2px 0 #0A0A0A;
}

.brand-text .sub {
    display: block;
    font-family: var(--f-mono);
    font-size: 9px;
    color: var(--c-muted);
    letter-spacing: .22em;
    margin-top: -2px;
}

/* =========================================================
   Side navigation
   ========================================================= */

.side-nav {
    position: fixed;
    top: 50%;
    transform: translateY(-50%);
    left: 0;
    z-index: 50;
    width: var(--nav-w);
    padding: 1rem 0;
    display: flex;
    flex-direction: column;
    gap: .25rem;
}

/* Hidden on desktop; revealed via @media (max-width: 768px) above. */
.mobile-nav-toggle,
.mobile-nav-overlay {
    display: none;
}

/* When the inventory drawer is open, hide the mobile-nav toggle and the
   cart FAB so the only X visible is the inventory's own close button.
   When the mobile-nav drawer is open, hide the cart FAB for the same reason. */
body[data-cart-open="true"] .mobile-nav-toggle,
body[data-cart-open="true"] .cp-cart-fab,
body[data-nav-open="true"] .cp-cart-fab {
    display: none !important;
}

.side-nav::before,
.side-nav::after {
    content: '';
    display: block;
    width: 1px;
    height: 24px;
    background: var(--c-line-2);
    margin: 0 auto;
}

.nav-item {
    display: grid;
    grid-template-columns: 36px 1fr;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    color: var(--c-muted);
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .14em;
    text-transform: uppercase;
    position: relative;
    transition: color .25s var(--ease);
}

.nav-item .n {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 14px;
    letter-spacing: .04em;
    color: var(--c-fg);
    opacity: .55;
    transition: opacity .25s var(--ease), color .25s var(--ease);
}

.nav-item .l {
    opacity: 0;
    transform: translateX(-6px);
    transition: opacity .25s var(--ease), transform .25s var(--ease);
    white-space: nowrap;
}

.nav-item .bar {
    position: absolute;
    left: 8px;
    top: 50%;
    transform: translateY(-50%);
    width: 2px;
    height: 14px;
    background: var(--c-line-2);
    transition: background .25s var(--ease), height .25s var(--ease);
}

.side-nav:hover .nav-item .l { opacity: 1; transform: translateX(0); }
.side-nav:hover { width: 220px; background: linear-gradient(90deg, rgba(5,8,17,.92), rgba(5,8,17,.0)); }

.nav-item:hover { color: var(--c-fg); }
.nav-item:hover .n { opacity: 1; color: var(--c-lime); }

.nav-item.is-active .n { opacity: 1; color: var(--c-lime); }
.nav-item.is-active .bar { background: var(--c-lime); height: 22px; box-shadow: 0 0 10px var(--c-lime); }
.nav-item.is-active { color: var(--c-fg); }

/* =========================================================
   Right utility column
   ========================================================= */

.right-rail {
    position: fixed;
    top: 50%;
    transform: translateY(-50%);
    right: 18px;
    z-index: 50;
    display: flex;
    flex-direction: column;
    gap: 18px;
    align-items: center;
    font-family: var(--f-mono);
    font-size: 10px;
    color: var(--c-muted);
    letter-spacing: .18em;
}

.right-rail .vline {
    width: 1px; height: 60px;
    background: var(--c-line-2);
}

.right-rail .rot {
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    text-transform: uppercase;
}

/* =========================================================
   Section frame (numbered patch-notes blocks)
   ========================================================= */

.section {
    position: relative;
    padding: clamp(4rem, 9vw, 7rem) var(--pad-x) clamp(4rem, 9vw, 7rem) calc(var(--nav-w) + var(--pad-x));
    min-height: 100vh;
    display: flex;
    align-items: center;
}

.section-inner {
    width: 100%;
    max-width: 1320px;
    margin: 0 auto;
}

.section-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 1rem;
    margin-bottom: clamp(2rem, 4vw, 3.5rem);
    border-top: 1px solid var(--c-line-2);
    padding-top: 1.5rem;
    position: relative;
}

.section-header::after {
    content: '';
    position: absolute;
    top: -1px; left: 0;
    width: 120px; height: 2px;
    background: var(--c-lime);
}

.section-tag {
    display: flex;
    gap: 1rem;
    align-items: baseline;
    flex-wrap: wrap;
}

.section-tag .num {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: clamp(2.2rem, 5vw, 3.5rem);
    line-height: 1;
    color: var(--c-lime);
    letter-spacing: .02em;
}

.section-tag .slash {
    font-family: var(--f-display);
    font-size: clamp(2.2rem, 5vw, 3.5rem);
    color: var(--c-muted);
    line-height: 1;
}

.section-tag .label {
    font-family: var(--f-mono);
    text-transform: uppercase;
    letter-spacing: .22em;
    font-size: 12px;
    color: var(--c-muted);
}

.section-tag .stamp {
    margin-left: auto;
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--c-cyan);
    border: 1px solid var(--c-cyan);
    padding: 3px 8px;
}

/* Corner brackets — reusable */
.bracket {
    position: relative;
}
.bracket::before,
.bracket::after {
    content: '';
    position: absolute;
    width: 14px; height: 14px;
    border: 1px solid var(--c-lime);
}
.bracket::before { top: -1px; left: -1px; border-right: 0; border-bottom: 0; }
.bracket::after  { bottom: -1px; right: -1px; border-left: 0; border-top: 0; }

.bracket-4 {
    position: relative;
}
.bracket-4 > i {
    position: absolute;
    width: 12px; height: 12px;
    border-color: var(--c-fg);
    opacity: .9;
    pointer-events: none;
}
.bracket-4 > i:nth-child(1) { top: -1px; left: -1px; border-top: 1px solid; border-left: 1px solid; }
.bracket-4 > i:nth-child(2) { top: -1px; right: -1px; border-top: 1px solid; border-right: 1px solid; }
.bracket-4 > i:nth-child(3) { bottom: -1px; left: -1px; border-bottom: 1px solid; border-left: 1px solid; }
.bracket-4 > i:nth-child(4) { bottom: -1px; right: -1px; border-bottom: 1px solid; border-right: 1px solid; }

/* =========================================================
   Hero / 00 INTRO
   ========================================================= */

#sec-00 {
    padding-top: 56px;
    min-height: 100vh;
    align-items: stretch;
    overflow: hidden;
}

.hero-wrap {
    width: 100%;
    display: grid;
    grid-template-rows: auto 1fr auto;
    gap: 2rem;
    position: relative;
}

.hero-shader {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.hero-shader canvas {
    width: 100%;
    height: 100%;
    display: block;
    opacity: 1;
}

.hero-shader::after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(5,8,17,.4) 0%, rgba(5,8,17,0) 30%, rgba(5,8,17,0) 70%, rgba(5,8,17,.95) 100%),
        repeating-linear-gradient(0deg, transparent 0, transparent 3px, rgba(0,0,0,.18) 3px, rgba(0,0,0,.18) 4px);
    pointer-events: none;
}

/* =========================================================
   Hero mascot — cyberpunk robot (Claude-Code style)
   ========================================================= */
.hero-robot {
    position: absolute;
    top: clamp(.5rem, 2vw, 1.75rem);
    right: clamp(.5rem, 2vw, 2.5rem);
    width: clamp(160px, 17vw, 248px);
    z-index: 1;
    pointer-events: none;
}
.hero-robot .rb-float {
    animation: rbFloat 4.6s var(--ease) infinite;
    will-change: transform;
}
.hero-robot svg {
    width: 100%;
    height: auto;
    overflow: visible;
    filter: drop-shadow(0 0 20px rgba(0, 229, 255, .28)) drop-shadow(0 0 7px rgba(184, 255, 46, .22));
}
.rb-head { transform-box: fill-box; transform-origin: center; transition: transform .25s ease-out; }
.rb-eyes { transform-box: fill-box; transform-origin: center; transition: transform .18s ease-out; }
.rb-eyes-inner { transform-box: fill-box; transform-origin: center; animation: rbEyes 6s infinite; }

.rb-fill { fill: #0E1424; stroke: var(--c-lime); stroke-width: 3; }
.rb-body { fill: #0A0F1D; }
.rb-leg { fill: #0C111F; }
.rb-ear { fill: var(--c-bg-3); }
.rb-eye { fill: none; stroke: var(--c-lime); stroke-width: 13; stroke-linecap: round; stroke-linejoin: round; }
.rb-eyes-glitch polyline { fill: none; stroke: var(--c-cyan); stroke-width: 13; stroke-linecap: round; stroke-linejoin: round; }
.rb-eyes-glitch { transform: translate(3px, 3px); animation: rbGlitchOp 6s infinite; }
.rb-led { fill: var(--c-lime); animation: rbLed 2.2s steps(1, end) infinite; }
.rb-grill line { stroke: var(--c-cyan); stroke-width: 2; opacity: .5; stroke-linecap: round; }
.rb-shadow { fill: rgba(184, 255, 46, .16); filter: blur(7px); }

@keyframes rbFloat { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-9px); } }
@keyframes rbLed { 0%, 60% { opacity: 1; } 61%, 100% { opacity: .25; } }
@keyframes rbGlitchOp { 0%, 86%, 100% { opacity: .5; } 87%, 90% { opacity: .92; } }
@keyframes rbEyes {
    0%, 24% { transform: none; }
    27% { transform: scaleY(.12); }       /* blink */
    30%, 85% { transform: scaleY(1); }
    87% { transform: translateX(-3px) skewX(4deg); }   /* glitch jitter */
    89% { transform: translateX(4px); }
    91%, 100% { transform: none; }
}

/* Robot lives in the always-dark hero band → keeps its neon-on-dark
   styling in both site themes (no light override needed). */

@media (max-width: 768px) { .hero-robot { display: none; } }
@media (prefers-reduced-motion: reduce) {
    .hero-robot .rb-float, .rb-eyes-inner, .rb-eyes-glitch, .rb-led { animation: none; }
}

.hero-meta {
    position: relative;
    z-index: 2;
    display: flex;
    gap: 1rem;
    align-items: center;
    padding-top: 1.5rem;
    flex-wrap: wrap;
}

.hero-meta .chip {
    font-family: var(--f-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: .2em;
    color: var(--c-fg);
    border: 1px solid var(--c-line-2);
    padding: 6px 10px;
}

.hero-meta .chip.hot {
    color: var(--c-bg);
    background: var(--c-lime);
    border-color: var(--c-lime);
}

.hero-content {
    position: relative;
    z-index: 2;
    align-self: end;
    max-width: 1200px;
}

.hero-title {
    font-family: var(--f-display);
    font-weight: 700;
    text-transform: uppercase;
    line-height: .9;
    letter-spacing: -.01em;
    font-size: clamp(2.6rem, 9vw, 8rem);
    margin: 0 0 1.5rem;
}

.hero-title .row { display: block; }
.hero-title .accent { color: var(--c-lime); }
.hero-title .outline {
    -webkit-text-stroke: 1.5px var(--c-fg);
    color: transparent;
}

.hero-sub {
    display: flex;
    gap: 1.25rem;
    align-items: center;
    color: var(--c-muted);
    font-family: var(--f-mono);
    font-size: 13px;
    margin-bottom: 2rem;
    flex-wrap: wrap;
}

.hero-sub .cursor,
.cursor {
    color: var(--c-lime);
    animation: blink 1s steps(2) infinite;
    display: inline-block;
}

@keyframes blink { 50% { opacity: 0; } }

.hero-lead {
    font-size: clamp(1rem, 1.2vw, 1.18rem);
    color: rgba(234, 240, 255, .78);
    max-width: 62ch;
    margin: 0 0 2.5rem;
}

.hero-ctas {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

.hero-foot {
    position: relative;
    z-index: 2;
    margin-top: 2rem;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    border-top: 1px solid var(--c-line-2);
    border-bottom: 1px solid var(--c-line-2);
}

.hero-foot .cell {
    padding: 1rem 1.25rem;
    border-right: 1px solid var(--c-line);
    display: flex;
    flex-direction: column;
    gap: .25rem;
}

.hero-foot .cell:last-child { border-right: 0; }
.hero-foot .cell .k {
    font-family: var(--f-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: .22em;
    color: var(--c-muted);
}
.hero-foot .cell .v {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: clamp(1.2rem, 2vw, 1.7rem);
    color: var(--c-fg);
}
.hero-foot .cell .v.lime { color: var(--c-lime); }
.hero-foot .cell .v.cyan { color: var(--c-cyan); }

/* =========================================================
   Buttons
   ========================================================= */

.btn {
    --bg: var(--c-lime);
    --fg: var(--c-bg);
    --bd: var(--c-lime);
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: .65rem;
    padding: 14px 22px;
    font-family: var(--f-mono);
    font-weight: 700;
    font-size: 12px;
    letter-spacing: .22em;
    text-transform: uppercase;
    background: var(--bg);
    color: var(--fg);
    border: 1px solid var(--bd);
    clip-path: polygon(8px 0, 100% 0, 100% calc(100% - 8px), calc(100% - 8px) 100%, 0 100%, 0 8px);
    transition: transform .2s var(--ease), background .2s var(--ease), color .2s var(--ease);
    overflow: hidden;
}

.btn::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.35) 50%, transparent 100%);
    transform: translateX(-110%);
    transition: transform .55s var(--ease);
    pointer-events: none;
}
.btn:hover::after { transform: translateX(110%); }

.btn:hover {
    transform: translateY(-2px);
}

.btn .arr {
    display: inline-block;
    transform: translateX(0);
    transition: transform .25s var(--ease);
}
.btn:hover .arr { transform: translateX(4px); }

/* Disabled / submitting state for buttons (used by form async submits) */
.btn:disabled,
.btn[aria-disabled="true"],
.btn[aria-busy="true"] {
    cursor: wait;
    opacity: .7;
    transform: none !important;
    pointer-events: none;
}
.btn:disabled::after,
.btn[aria-busy="true"]::after { display: none; }

.btn-spinner {
    width: 14px;
    height: 14px;
    border: 2px solid currentColor;
    border-top-color: transparent;
    border-radius: 50%;
    display: inline-block;
    animation: btn-spin .7s linear infinite;
    vertical-align: -2px;
}
@keyframes btn-spin {
    to { transform: rotate(360deg); }
}
@media (prefers-reduced-motion: reduce) {
    .btn-spinner { animation-duration: 2.4s; }
}

.btn-ghost {
    --bg: transparent;
    --fg: var(--c-fg);
    --bd: var(--c-line-2);
}
.btn-ghost:hover {
    --fg: var(--c-lime);
    --bd: var(--c-lime);
}

.btn-cyan {
    --bg: transparent;
    --fg: var(--c-cyan);
    --bd: var(--c-cyan);
}
.btn-cyan:hover {
    --bg: var(--c-cyan);
    --fg: var(--c-bg);
}

/* =========================================================
   Marquee
   ========================================================= */

.marquee {
    position: relative;
    overflow: hidden;
    border-top: 1px solid var(--c-line);
    border-bottom: 1px solid var(--c-line);
    background: var(--c-bg-2);
    padding: 16px 0;
}

.marquee-track {
    display: flex;
    gap: 3rem;
    width: max-content;
    animation: marquee 35s linear infinite;
    will-change: transform;
}

.marquee-item {
    display: inline-flex;
    align-items: center;
    gap: .75rem;
    font-family: var(--f-display);
    font-weight: 700;
    font-size: clamp(1.25rem, 2vw, 1.6rem);
    text-transform: uppercase;
    color: var(--c-fg);
    letter-spacing: .04em;
    white-space: nowrap;
}

.marquee-item .dot {
    width: 8px; height: 8px;
    background: var(--c-lime);
    transform: rotate(45deg);
    box-shadow: 0 0 8px var(--c-lime);
}

.marquee-item.faded { color: var(--c-muted); }

@keyframes marquee {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}

.marquee:hover .marquee-track { animation-play-state: paused; }

/* =========================================================
   Services grid (01 SYSTEMS)
   ========================================================= */

.services-grid {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 1rem;
}

.svc {
    position: relative;
    grid-column: span 4;
    background: var(--c-bg-2);
    border: 1px solid var(--c-line);
    padding: 1.75rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    min-height: 360px;
    transition: border-color .25s var(--ease), transform .35s var(--ease), background .25s var(--ease);
    overflow: hidden;
    clip-path: polygon(0 0, calc(100% - 18px) 0, 100% 18px, 100% 100%, 18px 100%, 0 calc(100% - 18px));
}

.svc:hover {
    border-color: var(--c-lime);
    background:
        radial-gradient(280px 280px at var(--gx, 50%) var(--gy, 50%),
                        rgba(184,255,46,.08), transparent 70%),
        var(--c-bg-3);
}

.svc::before {
    content: '';
    position: absolute;
    top: 0; right: 0;
    width: 28px; height: 28px;
    background: linear-gradient(135deg, transparent 50%, var(--c-line-2) 50%);
    transition: background .25s var(--ease);
}

.svc:hover::before {
    background: linear-gradient(135deg, transparent 50%, var(--c-lime) 50%);
}

.svc.feat {
    grid-column: span 8;
    background: linear-gradient(135deg, rgba(184,255,46,.06), transparent 60%), var(--c-bg-2);
    border-color: rgba(184,255,46,.25);
}
.svc.feat:hover { border-color: var(--c-lime); }

.svc.wide {
    grid-column: span 8;
    /* keep same vertical structure as a normal .svc but spanning 2x width */
}

.svc.wide .svc-foot {
    border-top: 1px dashed var(--c-line-2);
    padding-top: 1rem;
    margin-top: auto;
    margin-left: 0;
    flex-direction: row;
    align-items: end;
    justify-content: space-between;
}

/* Wide card on small screens — full width */
@media (max-width: 980px) {
    .svc.wide { grid-column: span 12; }
}

@media (max-width: 980px) {
    .svc { grid-column: span 12; }
    .svc.feat { grid-column: span 12; }
}

.svc-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
}

.svc-tag {
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: .22em;
    color: var(--c-muted);
    text-transform: uppercase;
}

.svc-pill {
    font-family: var(--f-mono);
    font-size: 9px;
    letter-spacing: .22em;
    text-transform: uppercase;
    padding: 4px 8px;
    border: 1px solid var(--c-lime);
    color: var(--c-lime);
}

.svc-pill.cyan { border-color: var(--c-cyan); color: var(--c-cyan); }
.svc-pill.solid { background: var(--c-lime); color: var(--c-bg); border-color: var(--c-lime); }

.svc h3 {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: clamp(1.5rem, 2vw, 1.9rem);
    text-transform: uppercase;
    letter-spacing: .01em;
    margin: 0;
    line-height: 1;
}

.svc.feat h3 { font-size: clamp(1.8rem, 2.6vw, 2.4rem); }

.svc p {
    color: rgba(234, 240, 255, .7);
    margin: 0;
    font-size: 14px;
}

.svc ul.feats {
    display: flex;
    flex-direction: column;
    gap: .35rem;
    margin: .25rem 0 0;
}

.svc ul.feats li {
    font-family: var(--f-mono);
    font-size: 11px;
    color: var(--c-muted);
    letter-spacing: .04em;
    display: flex;
    gap: .5rem;
    align-items: flex-start;
}
.svc ul.feats li::before {
    content: '>';
    color: var(--c-lime);
    flex-shrink: 0;
}

.svc-foot {
    margin-top: auto;
    display: flex;
    align-items: end;
    justify-content: space-between;
    padding-top: 1rem;
    border-top: 1px dashed var(--c-line-2);
    gap: 1rem;
}

.svc-price {
    display: flex;
    align-items: baseline;
    gap: .25rem;
}

.svc-price .v {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: clamp(1.6rem, 2.4vw, 2rem);
    color: var(--c-fg);
    line-height: 1;
}
.svc.feat .svc-price .v { color: var(--c-lime); }

.svc-price .u {
    font-family: var(--f-mono);
    font-size: 11px;
    color: var(--c-muted);
    letter-spacing: .14em;
}

.svc-link {
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--c-fg);
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    border-bottom: 1px solid var(--c-line-2);
    padding-bottom: 4px;
    transition: color .2s, border-color .2s, gap .2s var(--ease);
}
.svc-link:hover {
    color: var(--c-lime);
    border-color: var(--c-lime);
    gap: .8rem;
}

.svc.wide .svc-foot {
    border-top: 0;
    padding-top: 0;
    margin-left: auto;
    flex-direction: column;
    align-items: flex-end;
}

/* =========================================================
   Studio / 02 ABOUT
   ========================================================= */

.studio {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: clamp(2rem, 4vw, 4rem);
    align-items: start;
}

@media (max-width: 980px) { .studio { grid-template-columns: 1fr; } }

.studio-side {
    position: relative;
    border: 1px solid var(--c-line-2);
    padding: 1.5rem;
    background: var(--c-bg-2);
    min-height: 360px;
    overflow: hidden;
}

.studio-side .log {
    display: flex;
    flex-direction: column;
    gap: .55rem;
    font-family: var(--f-mono);
    font-size: 12px;
    color: rgba(234,240,255,.6);
}

.studio-side .log .row {
    display: grid;
    grid-template-columns: 90px 60px 1fr;
    gap: 1rem;
    align-items: baseline;
    padding: .35rem 0;
    border-bottom: 1px dashed var(--c-line);
}

.studio-side .log .row .ts { color: var(--c-muted); }
.studio-side .log .row .lv {
    color: var(--c-lime);
    text-transform: uppercase;
    letter-spacing: .16em;
    font-size: 10px;
}
.studio-side .log .row .lv.warn { color: var(--c-yellow); }
.studio-side .log .row .lv.crit { color: var(--c-red); }
.studio-side .log .row .lv.info { color: var(--c-cyan); }

.studio-content h3 {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: clamp(1.6rem, 2.4vw, 2.2rem);
    text-transform: uppercase;
    margin: 0 0 1rem;
}

.studio-content p {
    color: rgba(234, 240, 255, .75);
    margin: 0 0 1rem;
    font-size: 15px;
}

.pillars {
    margin-top: 2rem;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

@media (max-width: 600px) { .pillars { grid-template-columns: 1fr; } }

.pillar {
    border: 1px solid var(--c-line-2);
    padding: 1rem;
    transition: border-color .25s var(--ease), background .25s var(--ease);
}

.pillar:hover { border-color: var(--c-lime); background: var(--c-bg-3); }

.pillar .k {
    font-family: var(--f-mono);
    font-size: 10px;
    color: var(--c-lime);
    letter-spacing: .22em;
    text-transform: uppercase;
    margin-bottom: .35rem;
}

.pillar h4 {
    font-family: var(--f-display);
    font-weight: 700;
    text-transform: uppercase;
    font-size: 1.1rem;
    margin: 0 0 .25rem;
}
.pillar p { font-size: 13px; color: var(--c-muted); margin: 0; }

/* =========================================================
   Ops Log / 03 CASES
   ========================================================= */

.ops-log {
    border: 1px solid var(--c-line-2);
    background: var(--c-bg-2);
}

.ops-row {
    display: grid;
    grid-template-columns: 80px 1fr 220px 140px;
    gap: 1.5rem;
    align-items: center;
    padding: 1.5rem 1.75rem;
    border-bottom: 1px solid var(--c-line);
    transition: background .25s var(--ease);
    position: relative;
}

.ops-row:last-child { border-bottom: 0; }
.ops-row:hover { background: var(--c-bg-3); }

.ops-row .id {
    font-family: var(--f-mono);
    font-size: 11px;
    color: var(--c-muted);
    letter-spacing: .18em;
}

.ops-row h4 {
    font-family: var(--f-display);
    font-weight: 700;
    text-transform: uppercase;
    font-size: 1.15rem;
    margin: 0 0 .25rem;
    letter-spacing: .01em;
}

.ops-row p {
    color: rgba(234, 240, 255, .65);
    font-size: 13px;
    margin: 0;
}

.ops-row .tags {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
}

.ops-row .tags span {
    font-family: var(--f-mono);
    font-size: 9.5px;
    letter-spacing: .14em;
    color: var(--c-muted);
    border: 1px solid var(--c-line-2);
    padding: 3px 7px;
    text-transform: uppercase;
}

.ops-row .badge {
    justify-self: end;
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: .22em;
    text-transform: uppercase;
    padding: 6px 10px;
    border: 1px solid;
}

.ops-row .badge.high  { color: var(--c-lime); border-color: var(--c-lime); }
.ops-row .badge.med   { color: var(--c-cyan); border-color: var(--c-cyan); }

@media (max-width: 900px) {
    .ops-row {
        grid-template-columns: 60px 1fr;
        gap: .75rem 1rem;
    }
    .ops-row .tags, .ops-row .badge { grid-column: 2; }
}

/* =========================================================
   Save Point / 04 NEWSLETTER
   ========================================================= */

.save-point {
    position: relative;
    border: 1px solid var(--c-line-2);
    background:
        radial-gradient(600px 300px at 100% 0%, rgba(0,229,255,.08), transparent 60%),
        linear-gradient(180deg, var(--c-bg-2), var(--c-bg));
    padding: clamp(2rem, 4vw, 3.5rem);
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 3rem;
    align-items: center;
}

@media (max-width: 900px) { .save-point { grid-template-columns: 1fr; } }

.save-point h3 {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    text-transform: uppercase;
    margin: 0 0 1rem;
    line-height: 1;
}

.save-point p {
    color: rgba(234, 240, 255, .72);
    margin: 0;
    font-size: 15px;
}

.save-form {
    display: flex;
    gap: .75rem;
    align-items: stretch;
    flex-wrap: wrap;
}

.save-field {
    position: relative;
    flex: 1;
    min-width: 220px;
}

.save-form input {
    width: 100%;
    background: transparent;
    color: var(--c-fg);
    border: 1px solid var(--c-line-2);
    padding: 14px 16px 14px 38px;
    font-family: var(--f-mono);
    font-size: 13px;
    letter-spacing: .04em;
    outline: 0;
    transition: border-color .2s, background .2s, box-shadow .2s;
    caret-color: var(--c-lime);
}

.save-form input:focus {
    border-color: var(--c-lime);
    background: rgba(184, 255, 46, .04);
    box-shadow: 0 0 0 2px rgba(184, 255, 46, .12);
}

.save-form input:valid:not(:placeholder-shown) {
    border-color: var(--c-lime);
}

.save-form input::placeholder {
    color: var(--c-muted);
    text-transform: lowercase;
    letter-spacing: .04em;
    font-size: 12px;
}

/* Blinking terminal cursor inside the input when empty */
.save-cursor {
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    font-family: var(--f-mono);
    font-size: 16px;
    line-height: 1;
    color: var(--c-lime);
    pointer-events: none;
    animation: save-blink 1s steps(2, jump-none) infinite;
}

@keyframes save-blink {
    0%, 49.99% { opacity: 1; }
    50%, 100%  { opacity: 0; }
}

/* Hide cursor as soon as user types */
.save-field input:not(:placeholder-shown) ~ .save-cursor {
    display: none;
}

/* Submit button: visual states driven by JS via `aria-disabled` */
.save-form button[aria-disabled="true"].btn,
.save-form button[aria-disabled="true"].btn:hover {
    background-color: #14191F;
    background-image: none;
    color: #6D7793;
    border: 1px solid rgba(234, 240, 255, .14);
    pointer-events: none;
    cursor: not-allowed;
    transform: none;
}
.save-form button[aria-disabled="true"].btn::after { display: none; }
.save-form button[aria-disabled="true"].btn .arr { color: #6D7793; }

/* Red border when user typed an invalid email */
.save-form.is-invalid input { border-color: var(--c-red); }

/* Light-theme variant of the disabled button */
body[data-theme="light"] .save-form button[aria-disabled="true"].btn,
body[data-theme="light"] .save-form button[aria-disabled="true"].btn:hover {
    background-color: #EFE5CF;
    color: #6B5F4F;
    border-color: rgba(26, 22, 17, .18);
}
body[data-theme="light"] .save-form button[aria-disabled="true"].btn .arr { color: #6B5F4F; }

.save-foot {
    margin-top: 1rem;
    font-family: var(--f-mono);
    font-size: 10px;
    color: var(--c-muted);
    letter-spacing: .14em;
}

/* =========================================================
   Init Project / 05 CONTACT
   ========================================================= */

.init {
    text-align: center;
    padding: clamp(3rem, 6vw, 5rem) 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
}

.init .label {
    font-family: var(--f-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .3em;
    color: var(--c-muted);
}

.init h3 {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: clamp(2.5rem, 7vw, 6rem);
    text-transform: uppercase;
    line-height: 1.02;
    letter-spacing: -.01em;
    margin: 0;
    max-width: 18ch;
    text-wrap: balance;
}

.init h3 .accent { color: var(--c-lime); }

.init-ctas {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 1rem;
}

.init-meta {
    margin-top: 2rem;
    font-family: var(--f-mono);
    font-size: 11px;
    color: var(--c-muted);
    letter-spacing: .18em;
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
}

.init-meta span::before {
    content: '◆ ';
    color: var(--c-lime);
}

/* =========================================================
   Footer
   ========================================================= */

.footer {
    padding: 3rem var(--pad-x) 2rem calc(var(--nav-w) + var(--pad-x));
    border-top: 1px solid var(--c-line-2);
    margin-top: 4rem;
}

.footer-inner {
    max-width: 1320px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1.5rem 2rem;
}
.footer-inner h5 {
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--c-lime);
    margin: 0 0 .75rem;
}
.footer-inner ul li { padding: 3px 0; }
body[data-theme="light"] .footer-inner h5 { color: var(--c-fg); }

@media (max-width: 900px) { .footer-inner { grid-template-columns: 1fr 1fr; } }

.footer h5 {
    font-family: var(--f-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: .25em;
    color: var(--c-muted);
    margin: 0 0 1rem;
}

.footer ul li {
    padding: .25rem 0;
    font-size: 14px;
    color: rgba(234,240,255,.7);
}
.footer ul li a:hover { color: var(--c-lime); }

.footer-bottom {
    margin-top: 2.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--c-line);
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    font-family: var(--f-mono);
    font-size: 11px;
    color: var(--c-muted);
    letter-spacing: .15em;
}

.footer-bottom .tagline { color: var(--c-lime); }

/* =========================================================
   Reveal & scramble
   Initial state is applied by JS via gsap.set() when GSAP loads.
   This way, if JS fails or is slow, content shows at full opacity
   (a11y: no content stuck invisible on screen).
   ========================================================= */

.reveal,
.reveal-diag {
    will-change: transform, opacity;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    backface-visibility: hidden;
}

html.js-ready .reveal,
html.js-ready .reveal-diag {
    /* opacity/transform managed by GSAP after init */
}

/* Respect reduced-motion */
@media (prefers-reduced-motion: reduce) {
    .reveal, .reveal-diag {
        opacity: 1 !important;
        transform: none !important;
    }
}

/* Hero entrance — CSS-driven so the LCP (hero title) paints at first render
   and is NEVER gated by GSAP or window.load. JS only adds the scramble. */
@media (prefers-reduced-motion: no-preference) {
    #sec-00 .hero-title .row { animation: heroIn .6s cubic-bezier(.16, 1, .3, 1) both; }
    #sec-00 .hero-title .row:nth-child(2) { animation-delay: .09s; }
    #sec-00 .hero-title .row:nth-child(3) { animation-delay: .18s; }
    #sec-00 .hero-meta,
    #sec-00 .hero-sub,
    #sec-00 .hero-lead,
    #sec-00 .hero-empathy,
    #sec-00 .hero-ctas { animation: heroFade .6s ease-out .3s both; }
    #sec-00 .hero-foot .cell { animation: heroFade .55s ease-out both; }
    #sec-00 .hero-foot .cell:nth-child(n+2) { animation-delay: .4s; }
}
@keyframes heroIn { from { opacity: 0; transform: translateY(40%); } to { opacity: 1; transform: none; } }
@keyframes heroFade { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }

/* Defer rendering of below-the-fold sections so the initial main-thread
   layout/paint work (and FCP/LCP) is not blocked by content the user can't
   see yet. contain-intrinsic-size keeps the scrollbar stable (CLS-safe). */
@supports (content-visibility: auto) {
    #sec-01, #sec-02, #sec-03, #sec-04, #sec-05, .footer {
        content-visibility: auto;
        contain-intrinsic-size: auto 720px;
    }
}

.split-line {
    display: inline-block;
    overflow: hidden;
    line-height: 1.0;
}

.split-line > span {
    display: inline-block;
    transform: translateY(110%);
    will-change: transform;
}

/* =========================================================
   Mobile adjustments
   ========================================================= */

@media (max-width: 768px) {
    .side-nav {
        position: fixed;
        top: 0;
        right: 0;
        left: auto;
        width: min(280px, 84vw);
        height: 100vh;
        height: 100dvh;
        padding: 84px 1.25rem 1.5rem;
        background: var(--c-bg-2);
        border-left: 1px solid var(--c-line);
        border-right: 0;
        transform: translateX(100%);
        transition: transform .35s cubic-bezier(.16, 1, .3, 1);
        z-index: 95;
        overflow-y: auto;
        flex-direction: column;
        align-items: stretch;
        gap: .25rem;
        display: flex;
    }
    body[data-nav-open="true"] .side-nav { transform: translateX(0); }
    .side-nav::before,
    .side-nav::after { display: none; }
    .side-nav .nav-item {
        position: relative;
        width: 100%;
        padding: .85rem 1rem;
        border: 1px solid var(--c-line);
        background: var(--c-bg-3);
        display: grid;
        grid-template-columns: 32px 1fr;
        gap: .75rem;
        align-items: center;
        z-index: 0;
    }
    /* Neutralize the desktop yellow-bar pseudo that all nav-items carry in
       light theme — we want the drawer's own backgrounds instead. */
    .side-nav .nav-item::before { display: none !important; }
    .side-nav .nav-item .bar { display: none; }
    .side-nav .nav-item .n {
        font-family: var(--f-mono);
        font-size: 12px;
        color: var(--c-lime);
        opacity: 1;
        transform: none;
    }
    /* Force-reveal labels — desktop hides them at opacity:0 until :hover,
       but touch devices don't get hover. */
    .side-nav .nav-item .l {
        font-family: var(--f-mono);
        font-size: 13px;
        letter-spacing: .12em;
        color: var(--c-fg);
        opacity: 1 !important;
        transform: none !important;
        white-space: nowrap;
    }
    body[data-theme="light"] .side-nav {
        background: #FFFFFF;
        border-left: 1px solid var(--c-fg);
        border-right: 0;
    }
    body[data-theme="light"] .side-nav .nav-item {
        background: #FFFFFF;
        border: 1px solid var(--c-fg);
    }
    body[data-theme="light"] .side-nav .nav-item .n { color: var(--c-fg); opacity: 1; }
    body[data-theme="light"] .side-nav .nav-item .l { color: var(--c-fg); }
    /* Active page — only the current page gets the yellow highlight on mobile. */
    body[data-theme="light"][data-page="home"]       .side-nav .nav-item[data-page="home"],
    body[data-theme="light"][data-page="soluciones"] .side-nav .nav-item[data-page="soluciones"],
    body[data-theme="light"][data-page="studio"]     .side-nav .nav-item[data-page="studio"],
    body[data-theme="light"][data-page="clientes"]   .side-nav .nav-item[data-page="clientes"],
    body[data-theme="light"][data-page="blog"]       .side-nav .nav-item[data-page="blog"],
    body[data-theme="light"][data-page="contacto"]   .side-nav .nav-item[data-page="contacto"] {
        background: var(--c-yellow);
    }
    body[data-page="home"]       .side-nav .nav-item[data-page="home"] .n,
    body[data-page="soluciones"] .side-nav .nav-item[data-page="soluciones"] .n,
    body[data-page="studio"]     .side-nav .nav-item[data-page="studio"] .n,
    body[data-page="clientes"]   .side-nav .nav-item[data-page="clientes"] .n,
    body[data-page="blog"]       .side-nav .nav-item[data-page="blog"] .n,
    body[data-page="contacto"]   .side-nav .nav-item[data-page="contacto"] .n {
        font-weight: 700;
    }

    .mobile-nav-toggle {
        display: flex;
        align-items: center;
        justify-content: center;
        position: fixed;
        /* Vertically aligned with the .brand logo's container (top: 46px,
           ~44px tall). Both share the same top so their centers match. */
        top: 46px;
        right: 14px;
        left: auto;
        width: 44px;
        height: 44px;
        background: var(--c-bg-2);
        border: 1px solid var(--c-line);
        color: var(--c-fg);
        z-index: 96;
        cursor: pointer;
        padding: 0;
    }
    .mobile-nav-toggle svg { width: 22px; height: 22px; pointer-events: none; }
    body[data-theme="light"] .mobile-nav-toggle {
        background: #FFFFFF;
        border: 1px solid var(--c-fg);
        box-shadow: 2px 2px 0 var(--c-fg);
    }
    .brand { left: 14px; top: 46px; }
    body[data-nav-open="true"] .mobile-nav-overlay {
        opacity: 1;
        pointer-events: auto;
    }
    .mobile-nav-overlay {
        position: fixed;
        inset: 0;
        background: rgba(5, 8, 17, .55);
        z-index: 94;
        opacity: 0;
        pointer-events: none;
        transition: opacity .25s ease;
        backdrop-filter: blur(2px);
    }

    .right-rail { display: none; }
    .brand-text .sub { display: none; }
    .section { padding-left: var(--pad-x); padding-right: var(--pad-x); }
    .footer { padding-left: var(--pad-x); padding-right: var(--pad-x); }

    #sec-00 { padding-top: 96px; }
    .hero-meta { padding-top: 0; gap: .5rem; }
    .hero-meta .chip { font-size: 9px; padding: 5px 8px; }

    .services-grid { gap: .75rem; }
    .ops-row { padding: 1.1rem 1.2rem; }

    .status-bar { font-size: 9px; gap: .75rem; }
    .status-bar .right { display: none; }

    .hero-foot { grid-template-columns: 1fr 1fr; }
    .hero-foot .cell:nth-child(2) { border-right: 0; }
}

/* =========================================================
   Light theme (campaigns)
   Paleta: WHITE / BLACK / YELLOW / LIME · Cyberpunk + Google ML
   Activated by body[data-theme="light"]
   ========================================================= */

body[data-theme="light"] {
    --c-bg:     #FFFFFF;      /* pure white base */
    --c-bg-2:   #FFFFFF;      /* cards */
    --c-bg-3:   #FAFAF7;      /* hover · subtle off-white */
    --c-fg:     #0A0A0A;      /* near-black ink */
    --c-muted:  #4A4A4A;      /* dark gray — 9:1 on white */
    --c-line:   rgba(10, 10, 10, .12);
    --c-line-2: #0A0A0A;      /* hard black borders — cyberpunk */

    --c-lime:   #84CC16;      /* brand lime — CTAs + accents */
    --c-lime-2: #65A30D;
    --c-cyan:   #0A0A0A;      /* swap cyan for solid black */
    --c-cyan-2: #1F1F1F;
    --c-yellow: #F2EE03;      /* cyberpunk signature yellow */
    --c-red:    #FF003C;

    background: #FFFFFF;
    color: var(--c-fg);
}

/* Top status bar — yellow strip */
body[data-theme="light"] .status-bar {
    background: var(--c-yellow);
    color: var(--c-fg);
    border-bottom: 1px solid var(--c-fg);
}
body[data-theme="light"] .status-bar .dot {
    background: var(--c-fg);
    box-shadow: none;
}
body[data-theme="light"] .status-bar .sep { background: rgba(10, 10, 10, .3); }
body[data-theme="light"] .status-bar .right span::before { background: var(--c-fg); }

/* Brand: framed card with shadow, like the INVENTARIO button */
body[data-theme="light"] .brand {
    background: #FFFFFF;
    padding: 6px 12px 6px 6px;
    border: 1px solid var(--c-fg);
    box-shadow: 3px 3px 0 var(--c-fg);
    align-items: center;
    gap: .65rem;
    border-radius: 0;
    clip-path: polygon(6px 0, 100% 0, 100% calc(100% - 6px), calc(100% - 6px) 100%, 0 100%, 0 6px);
}
body[data-theme="light"] .brand-glyph {
    background: var(--c-fg);
    color: var(--c-yellow);
    box-shadow: none;
}
body[data-theme="light"] .brand-text {
    color: var(--c-fg);
    font-weight: 700;
}
body[data-theme="light"] .brand-text .sub {
    color: var(--c-fg);
    opacity: .75;
}

/* Side nav — visible black numbers with hover/active highlights */
body[data-theme="light"] .side-nav {
    background: linear-gradient(90deg, rgba(255, 255, 255, .95) 0%, rgba(255, 255, 255, .85) 60%, rgba(255, 255, 255, 0) 100%);
    backdrop-filter: blur(4px);
}
body[data-theme="light"] .side-nav::before,
body[data-theme="light"] .side-nav::after { background: var(--c-fg); opacity: .35; }
body[data-theme="light"] .side-nav:hover {
    background: #FFFFFF;
}
body[data-theme="light"] .nav-item { color: #4A4A4A; }
body[data-theme="light"] .nav-item .n { color: var(--c-fg); opacity: .8; font-weight: 700; }
body[data-theme="light"] .nav-item .bar {
    background: var(--c-fg);
    opacity: .35;
}
body[data-theme="light"] .nav-item:hover {
    color: var(--c-fg);
}
body[data-theme="light"] .nav-item:hover .n { opacity: 1; color: var(--c-fg); }
body[data-theme="light"] .nav-item:hover .bar { opacity: 1; }
body[data-theme="light"] .nav-item.is-active .bar,
body[data-theme="light"] .nav-item[data-page]:is(
    [data-page="soluciones"], [data-page="home"], [data-page="studio"],
    [data-page="clientes"], [data-page="blog"], [data-page="contacto"]
) .bar {
    background: var(--c-fg);
    opacity: 1;
    box-shadow: none;
}
body[data-theme="light"] .nav-item.is-active::before,
body[data-theme="light"] .nav-item[data-page]:is(
    [data-page="soluciones"], [data-page="home"], [data-page="studio"],
    [data-page="clientes"], [data-page="blog"], [data-page="contacto"]
)::before {
    content: '';
    position: absolute;
    inset: 4px 0 4px 22px;
    background: var(--c-yellow);
    z-index: -1;
}
body[data-theme="light"] .nav-item { position: relative; z-index: 0; }

/* Cross-page active state recolor */
body[data-theme="light"][data-page="soluciones"] .nav-item[data-page="soluciones"] .n,
body[data-theme="light"][data-page="home"] .nav-item[data-page="home"] .n,
body[data-theme="light"][data-page="studio"] .nav-item[data-page="studio"] .n,
body[data-theme="light"][data-page="clientes"] .nav-item[data-page="clientes"] .n,
body[data-theme="light"][data-page="blog"] .nav-item[data-page="blog"] .n,
body[data-theme="light"][data-page="contacto"] .nav-item[data-page="contacto"] .n {
    color: var(--c-fg);
}

/* Section header — solid black bar accent */
body[data-theme="light"] .section-header { border-top-color: var(--c-fg); border-top-width: 2px; }
body[data-theme="light"] .section-header::after {
    background: var(--c-yellow);
    height: 8px;
    top: -3px;
}
body[data-theme="light"] .section-tag .num { color: var(--c-fg); }
body[data-theme="light"] .section-tag .slash { color: var(--c-muted); }
body[data-theme="light"] .section-tag .label { color: var(--c-muted); }
body[data-theme="light"] .section-tag .stamp {
    color: var(--c-fg);
    border-color: var(--c-fg);
    background: var(--c-yellow);
}

/* Page hero — yellow banner block effect */
body[data-theme="light"] .page-hero::before {
    background:
        linear-gradient(180deg, var(--c-yellow) 0%, var(--c-yellow) 55%, transparent 55%);
    opacity: .55;
}

/* Page hero side card — black on yellow */
body[data-theme="light"] .page-hero-side {
    background: var(--c-fg);
    border: 2px solid var(--c-fg);
    color: #FFFFFF;
    box-shadow: 6px 6px 0 var(--c-yellow);
}
body[data-theme="light"] .page-hero-side .k { color: rgba(255, 255, 255, .65); }
body[data-theme="light"] .page-hero-side .v { color: var(--c-yellow); }

/* Hero stat cells override (the inline-styled grid in conocenos hero — also used in this theme via page-hero-side div nesting) */
body[data-theme="light"] .page-hero-side .v { color: var(--c-yellow); }

/* Headlines: pure black */
body[data-theme="light"] .page-hero-title { color: var(--c-fg); }
body[data-theme="light"] .page-hero-title .accent,
body[data-theme="light"] .page-hero-title .accent-cy,
body[data-theme="light"] .h-title .accent,
body[data-theme="light"] .h-title .accent-cy {
    color: var(--c-fg);
    background-color: var(--c-yellow);
    padding: 0 .25em;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
}

body[data-theme="light"] .h-lead { color: #1A1A1A; }

/* Info cards — white block with hard black border + yellow hover sweep
   Force GPU layer upfront so subpixel text rendering stays identical
   between rest and hover states (avoids visible "font change" jitter). */
body[data-theme="light"] .info-card {
    background: #FFFFFF;
    border: 1px solid var(--c-fg);
    box-shadow: 4px 4px 0 var(--c-fg);
    transition: transform .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
    transform: translate3d(0, 0, 0);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    backface-visibility: hidden;
}
body[data-theme="light"] .info-card:hover {
    background: var(--c-yellow);
    transform: translate3d(-2px, -2px, 0);
    box-shadow: 6px 6px 0 var(--c-fg);
}
body[data-theme="light"] .info-card .k { color: var(--c-fg); font-weight: 700; }
body[data-theme="light"] .info-card h4 { color: var(--c-fg); }
body[data-theme="light"] .info-card p { color: #1A1A1A; }
body[data-theme="light"] .info-card:hover p,
body[data-theme="light"] .info-card:hover .k,
body[data-theme="light"] .info-card:hover h4 { color: var(--c-fg); }

/* Steps cards — white with hard black borders */
body[data-theme="light"] .step {
    background: #FFFFFF;
    border: 1px solid var(--c-fg);
    box-shadow: 4px 4px 0 var(--c-fg);
    transition: transform .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
    transform: translate3d(0, 0, 0);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    backface-visibility: hidden;
}
body[data-theme="light"] .step:hover {
    background: var(--c-yellow);
    transform: translate3d(-2px, -2px, 0);
    box-shadow: 6px 6px 0 var(--c-fg);
}
body[data-theme="light"] .step .num { color: var(--c-fg); opacity: .12; }
body[data-theme="light"] .step .k { color: var(--c-fg); font-weight: 700; }
body[data-theme="light"] .step h4 { color: var(--c-fg); }
body[data-theme="light"] .step p { color: #1A1A1A; }
body[data-theme="light"] .step:hover p { color: var(--c-fg); }

/* Service cards */
body[data-theme="light"] .svc {
    background: #FFFFFF;
    border: 1px solid var(--c-fg);
    box-shadow: 4px 4px 0 var(--c-fg);
    transform: translate3d(0, 0, 0);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    backface-visibility: hidden;
}
body[data-theme="light"] .svc:hover {
    background: #FAFAF7;
    transform: translate3d(-2px, -2px, 0);
    box-shadow: 6px 6px 0 var(--c-fg);
    border-color: var(--c-fg);
}
body[data-theme="light"] .svc.feat {
    background: var(--c-yellow);
    border-color: var(--c-fg);
}
body[data-theme="light"] .svc.feat h3,
body[data-theme="light"] .svc.feat p,
body[data-theme="light"] .svc.feat .svc-tag,
body[data-theme="light"] .svc.feat ul.feats li { color: var(--c-fg); }
body[data-theme="light"] .svc.feat .svc-price .v { color: var(--c-fg); }

body[data-theme="light"] .svc h3 { color: var(--c-fg); }
body[data-theme="light"] .svc p { color: #1A1A1A; }
body[data-theme="light"] .svc-tag,
body[data-theme="light"] .svc ul.feats li { color: var(--c-muted); }
body[data-theme="light"] .svc ul.feats li::before { color: var(--c-fg); }

body[data-theme="light"] .svc-price .v { color: var(--c-fg); }
body[data-theme="light"] .svc-price .u { color: var(--c-muted); }
body[data-theme="light"] .svc-link { color: var(--c-fg); border-bottom-color: var(--c-fg); }
body[data-theme="light"] .svc-link:hover { color: var(--c-fg); border-bottom-color: var(--c-yellow); background: var(--c-yellow); }

/* Pills */
body[data-theme="light"] .svc-pill {
    color: var(--c-fg);
    border-color: var(--c-fg);
    background: #FFFFFF;
}
body[data-theme="light"] .svc-pill.cyan {
    color: var(--c-fg);
    border-color: var(--c-fg);
    background: var(--c-yellow);
}
body[data-theme="light"] .svc-pill.solid {
    background: var(--c-fg);
    color: var(--c-yellow);
    border-color: var(--c-fg);
}

/* Buttons — yellow primary (cyberpunk signature), black ghost */
body[data-theme="light"] .btn {
    background: var(--c-yellow);
    color: var(--c-fg);
    border: 1px solid var(--c-fg);
    box-shadow: 4px 4px 0 var(--c-fg);
    transition: transform .15s var(--ease), box-shadow .15s var(--ease), background .15s var(--ease);
    transform: translate3d(0, 0, 0);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    backface-visibility: hidden;
}
body[data-theme="light"] .btn:hover {
    background: var(--c-fg);
    color: var(--c-yellow);
    transform: translate3d(-2px, -2px, 0);
    box-shadow: 6px 6px 0 var(--c-yellow);
}
body[data-theme="light"] .btn:active {
    transform: translate3d(0, 0, 0);
    box-shadow: 0 0 0 var(--c-fg);
}
body[data-theme="light"] .btn::after { display: none; }

body[data-theme="light"] .btn-ghost {
    background: #FFFFFF;
    color: var(--c-fg);
    border: 1px solid var(--c-fg);
    box-shadow: 4px 4px 0 var(--c-fg);
}
body[data-theme="light"] .btn-ghost:hover {
    background: var(--c-fg);
    color: #FFFFFF;
}

body[data-theme="light"] .btn-cyan {
    background: var(--c-fg);
    color: #FFFFFF;
    border: 1px solid var(--c-fg);
    box-shadow: 4px 4px 0 var(--c-lime);
}
body[data-theme="light"] .btn-cyan:hover {
    background: var(--c-lime);
    color: var(--c-fg);
    border-color: var(--c-fg);
}

/* Patch line */
body[data-theme="light"] .patch-line { color: var(--c-muted); }
body[data-theme="light"] .patch-line .here {
    background: var(--c-yellow);
    color: var(--c-fg);
    padding: 2px 8px;
    font-weight: 700;
}
body[data-theme="light"] .patch-line a { color: var(--c-fg); }
body[data-theme="light"] .patch-line a:hover { background: var(--c-yellow); padding: 2px 8px; }

/* Ops log */
body[data-theme="light"] .ops-log { background: #FFFFFF; border: 1px solid var(--c-fg); box-shadow: 4px 4px 0 var(--c-fg); }
body[data-theme="light"] .ops-row { border-color: var(--c-line); }
body[data-theme="light"] .ops-row:hover { background: var(--c-yellow); }
body[data-theme="light"] .ops-row h4 { color: var(--c-fg); }
body[data-theme="light"] .ops-row p { color: #1A1A1A; }
body[data-theme="light"] .ops-row:hover p,
body[data-theme="light"] .ops-row:hover .id,
body[data-theme="light"] .ops-row:hover .tags span { color: var(--c-fg); }
body[data-theme="light"] .ops-row .tags span { color: var(--c-muted); border-color: var(--c-line-2); background: #FFFFFF; }
body[data-theme="light"] .ops-row .badge.high { color: var(--c-fg); border-color: var(--c-fg); background: var(--c-yellow); }
body[data-theme="light"] .ops-row .badge.med  { color: var(--c-fg); border-color: var(--c-fg); background: #FFFFFF; }
body[data-theme="light"] .ops-row .id { color: var(--c-muted); }

/* Marquee */
body[data-theme="light"] .marquee {
    background: var(--c-yellow);
    border-top: 1px solid var(--c-fg);
    border-bottom: 1px solid var(--c-fg);
}
body[data-theme="light"] .marquee-item { color: var(--c-fg); }
body[data-theme="light"] .marquee-item.faded { color: rgba(10, 10, 10, .55); }
body[data-theme="light"] .marquee-item .dot { background: var(--c-fg); box-shadow: none; }

/* Footer in light */
body[data-theme="light"] .footer { background: transparent; border-top: 2px solid var(--c-fg); }
body[data-theme="light"] .footer h5 { color: var(--c-fg); }
body[data-theme="light"] .footer ul li { color: var(--c-muted); }
body[data-theme="light"] .footer ul li a { color: var(--c-fg); }
body[data-theme="light"] .footer ul li a:hover { background: var(--c-yellow); padding: 1px 4px; }
body[data-theme="light"] .footer-bottom { color: var(--c-muted); border-top-color: var(--c-line); }
body[data-theme="light"] .footer-bottom .tagline {
    background: var(--c-fg);
    color: var(--c-yellow);
    padding: 4px 10px;
}
body[data-theme="light"] .footer-social { border-top-color: var(--c-line) !important; }

/* Save form (newsletter) */
body[data-theme="light"] .save-point {
    background: #FFFFFF;
    border: 1px solid var(--c-fg);
    box-shadow: 6px 6px 0 var(--c-yellow);
}
body[data-theme="light"] .save-form input {
    background: #FFFFFF;
    color: var(--c-fg);
    border: 1px solid var(--c-fg);
}
body[data-theme="light"] .save-form input:focus {
    background: #FFFFFF;
    border-color: var(--c-fg);
    box-shadow: 0 0 0 2px var(--c-yellow);
}
body[data-theme="light"] .save-form input::placeholder { color: var(--c-muted); }
body[data-theme="light"] .save-cursor { color: var(--c-fg); }
body[data-theme="light"] .save-foot { color: var(--c-muted); }
body[data-theme="light"] .save-point h3 .accent,
body[data-theme="light"] .save-point span[style*="lime"] {
    color: var(--c-fg) !important;
    background: var(--c-yellow);
    padding: 0 .25em;
}

/* Init / CTA section */
body[data-theme="light"] .init .label { color: var(--c-muted); }
body[data-theme="light"] .init h3 { color: var(--c-fg); }
body[data-theme="light"] .init h3 .accent {
    color: var(--c-fg);
    background: var(--c-yellow);
    padding: 0 .25em;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
}
body[data-theme="light"] .init-meta { color: var(--c-muted); }
body[data-theme="light"] .init-meta span::before { color: var(--c-fg); }

/* Consent / forms / choices */
body[data-theme="light"] .consent { color: var(--c-muted); }
body[data-theme="light"] .consent a { color: var(--c-fg); border-bottom-color: var(--c-fg); }
body[data-theme="light"] .consent a:hover { background: var(--c-yellow); }

body[data-theme="light"] .field input,
body[data-theme="light"] .field textarea,
body[data-theme="light"] .field select {
    background: #FFFFFF;
    color: var(--c-fg);
    border: 1px solid var(--c-fg);
}
body[data-theme="light"] .field label { color: var(--c-fg); font-weight: 700; }
body[data-theme="light"] .field input:focus,
body[data-theme="light"] .field textarea:focus,
body[data-theme="light"] .field select:focus {
    border-color: var(--c-fg);
    background: #FFFFFF;
    box-shadow: 0 0 0 2px var(--c-yellow);
}
body[data-theme="light"] .field select { color-scheme: light; }
body[data-theme="light"] .field select option { background: #FFFFFF; color: var(--c-fg); }

body[data-theme="light"] .choice {
    background: #FFFFFF;
    border: 1px solid var(--c-fg);
    color: var(--c-fg);
}
body[data-theme="light"] .choice:hover { background: var(--c-yellow); color: var(--c-fg); }
body[data-theme="light"] .choice.is-active {
    background: var(--c-fg);
    color: var(--c-yellow);
    border-color: var(--c-fg);
}

/* Compare cards */
body[data-theme="light"] .compare-col {
    background: #FFFFFF;
    border: 1px solid var(--c-fg);
    box-shadow: 4px 4px 0 var(--c-fg);
}
body[data-theme="light"] .compare-col.bad { background: #FFFFFF; }
body[data-theme="light"] .compare-col.bad h4 { color: var(--c-red); }
body[data-theme="light"] .compare-col.good { background: var(--c-yellow); }
body[data-theme="light"] .compare-col.good h4 { color: var(--c-fg); }
body[data-theme="light"] .compare-col ul li { color: var(--c-fg); }
body[data-theme="light"] .compare-col ul li::before { color: var(--c-red); }
body[data-theme="light"] .compare-col.good ul li::before { color: var(--c-fg); }

/* Right rail / brand */
body[data-theme="light"] .right-rail { color: var(--c-muted); }
body[data-theme="light"] .right-rail .vline { background: var(--c-fg); }
body[data-theme="light"] .brand-text { color: var(--c-fg); }
body[data-theme="light"] .brand-text .sub { color: var(--c-muted); }

/* Focus rings — black on yellow / white */
body[data-theme="light"] a:focus-visible,
body[data-theme="light"] button:focus-visible,
body[data-theme="light"] input:focus-visible,
body[data-theme="light"] select:focus-visible,
body[data-theme="light"] textarea:focus-visible {
    outline: 3px solid var(--c-yellow);
    outline-offset: 2px;
}

/* Cart FAB + cookies */
body[data-theme="light"] .cp-cart-fab {
    background: #FFFFFF;
    border: 1px solid var(--c-fg);
    color: var(--c-fg);
    box-shadow: 3px 3px 0 var(--c-fg);
}
body[data-theme="light"] .cp-cart-fab:hover {
    background: var(--c-yellow);
    border-color: var(--c-fg);
    color: var(--c-fg);
}
body[data-theme="light"] .cp-cart-fab-glyph { color: var(--c-fg); }
body[data-theme="light"] .cp-cart-fab-count { background: var(--c-fg); color: var(--c-yellow); }
body[data-theme="light"] .cp-cookie-fab {
    background: #FFFFFF;
    border: 1px solid var(--c-fg);
    color: var(--c-fg);
    box-shadow: 3px 3px 0 var(--c-fg);
}

body[data-theme="light"] .cp-cookies {
    background: var(--c-yellow);
    border-top: 2px solid var(--c-fg);
}
body[data-theme="light"] .cp-cookies-text strong { color: var(--c-fg); }
body[data-theme="light"] .cp-cookies-text p { color: var(--c-fg); }
body[data-theme="light"] .cp-cookies-btn {
    border-color: var(--c-fg);
    color: var(--c-fg);
    background: transparent;
}
body[data-theme="light"] .cp-cookies-btn:hover { background: var(--c-fg); color: var(--c-yellow); border-color: var(--c-fg); }
body[data-theme="light"] .cp-cookies-btn.solid {
    background: var(--c-fg);
    color: var(--c-yellow);
    border-color: var(--c-fg);
}
body[data-theme="light"] .cp-cookies-btn.solid:hover { background: var(--c-lime); color: var(--c-fg); }
body[data-theme="light"] .cp-cookies-dot { background: var(--c-fg); box-shadow: none; }

/* Cookies / Settings dialog — light theme overrides */
body[data-theme="light"] .cp-cookies-dialog {
    background: #FFFFFF;
    border: 2px solid var(--c-fg);
    box-shadow: 8px 8px 0 var(--c-yellow);
}
body[data-theme="light"] .cp-cookies-eyebrow { color: var(--c-muted); }
body[data-theme="light"] .cp-cookies-dialog h3 { color: var(--c-fg); }
body[data-theme="light"] .cp-cookies-dialog-lead {
    color: #1A1A1A;                     /* near-black · 16:1 on white */
    font-weight: 500;
}
body[data-theme="light"] .cp-cookies-cat-row {
    background: #FFFFFF;
    border: 1px solid var(--c-fg);
}
body[data-theme="light"] .cp-cookies-cat-row:hover {
    background: var(--c-yellow);
    border-color: var(--c-fg);
}
body[data-theme="light"] .cp-cookies-cat-row[data-disabled]:hover {
    background: #FAFAF7;
    border-color: var(--c-fg);
}
body[data-theme="light"] .cp-cookies-cat-name { color: var(--c-fg); }
body[data-theme="light"] .cp-cookies-cat-row p { color: #1A1A1A; }

/* Toggle in light theme */
body[data-theme="light"] .cp-tog {
    background: #FAFAF7;
    border: 1px solid var(--c-fg);
}
body[data-theme="light"] .cp-tog::before { background: var(--c-fg); }
body[data-theme="light"] .cp-tog.is-on {
    background: var(--c-fg);
    border-color: var(--c-fg);
}
body[data-theme="light"] .cp-tog.is-on::before { background: var(--c-yellow); }
body[data-theme="light"] .cp-tog.locked {
    background: var(--c-yellow);
    border-color: var(--c-fg);
}
body[data-theme="light"] .cp-tog.locked::before { background: var(--c-fg); }

body[data-theme="light"] .cp-cart-x {
    border-color: var(--c-fg);
    color: var(--c-fg);
}
body[data-theme="light"] .cp-cart-x:hover {
    border-color: var(--c-red);
    color: var(--c-red);
}

/* Theme switcher inside dialog — light theme */
body[data-theme="light"] .cp-theme-block { border-bottom-color: var(--c-line); }
body[data-theme="light"] .cp-theme-row {
    background: #FFFFFF;
    border: 1px solid var(--c-fg);
}
body[data-theme="light"] .cp-theme-row p { color: #1A1A1A; }
body[data-theme="light"] .cp-theme-switch {
    border: 1px solid var(--c-fg);
    background: #FFFFFF;
}
body[data-theme="light"] .cp-theme-btn {
    color: var(--c-muted);
    border-right-color: var(--c-fg);
}
body[data-theme="light"] .cp-theme-btn:hover {
    background: rgba(242, 238, 3, .3);
    color: var(--c-fg);
}
body[data-theme="light"] .cp-theme-btn.is-active {
    background: var(--c-yellow);
    color: var(--c-fg);
}
body[data-theme="light"] .cp-cookies-section-head .cp-cookies-eyebrow { color: var(--c-fg); }
body[data-theme="light"] .cp-cookies-section-head::after { background: var(--c-line); }

/* Cart drawer — light theme */
body[data-theme="light"] .cp-cart {
    background: #FFFFFF;
    border-left: 2px solid var(--c-fg);
}
body[data-theme="light"] .cp-cart-head { border-bottom-color: var(--c-fg); }
body[data-theme="light"] .cp-cart-eyebrow { color: var(--c-muted); }
body[data-theme="light"] .cp-cart-title { color: var(--c-fg); }
body[data-theme="light"] .cp-cart-empty-title { color: var(--c-fg); }
body[data-theme="light"] .cp-cart-empty-sub { color: var(--c-muted); }
body[data-theme="light"] .cp-cart-empty-glyph { color: var(--c-line); }
body[data-theme="light"] .cp-cart-item { border-bottom-color: var(--c-line); }
body[data-theme="light"] .cp-cart-item-glyph { background: var(--c-yellow); color: var(--c-fg); }
body[data-theme="light"] .cp-cart-item-name { color: var(--c-fg); }
body[data-theme="light"] .cp-cart-item-meta { color: var(--c-muted); }
body[data-theme="light"] .cp-cart-item-price { color: var(--c-fg); }
body[data-theme="light"] .cp-qb { background: #FFFFFF; border-color: var(--c-fg); color: var(--c-fg); }
body[data-theme="light"] .cp-qb:hover { background: var(--c-yellow); border-color: var(--c-fg); }
body[data-theme="light"] .cp-cart-foot { border-top-color: var(--c-fg); }
body[data-theme="light"] .cp-cart-total-k { color: var(--c-muted); }
body[data-theme="light"] .cp-cart-total-v { color: var(--c-fg); }
body[data-theme="light"] .cp-cart-clear { color: var(--c-muted); }
body[data-theme="light"] .cp-cart-clear:hover { color: var(--c-red); }

/* Cart "+ ADD" button on service cards — light theme */
body[data-theme="light"] .cp-add {
    background: var(--c-yellow);
    color: var(--c-fg);
    border: 1px solid var(--c-fg);
}
body[data-theme="light"] .cp-add:hover {
    background: var(--c-fg);
    color: var(--c-yellow);
    border-color: var(--c-fg);
}

/* =========================================================
   Light theme · global text contrast (covers all pages, not just campaigns)
   ========================================================= */

/* Studio section (conocenos + home) — paragraphs use near-black for max legibility */
body[data-theme="light"] .studio-content p { color: #1A1A1A; }
body[data-theme="light"] .studio-content strong { color: var(--c-fg); font-weight: 700; }
body[data-theme="light"] .studio-content blockquote { color: var(--c-fg); }
body[data-theme="light"] .studio-content blockquote p { color: var(--c-fg); }
body[data-theme="light"] .studio-side {
    background: #FFFFFF;
    border: 1px solid var(--c-fg);
    box-shadow: 4px 4px 0 var(--c-yellow);
}
body[data-theme="light"] .studio-side .log { color: var(--c-muted); }
body[data-theme="light"] .studio-side .row { border-bottom-color: var(--c-line); }
body[data-theme="light"] .studio-side .ts { color: var(--c-muted); }
body[data-theme="light"] .studio-side .mono { color: var(--c-fg) !important; }

/* Pillars (conocenos) */
body[data-theme="light"] .pillar {
    background: #FFFFFF;
    border: 1px solid var(--c-fg);
}
body[data-theme="light"] .pillar:hover {
    background: var(--c-yellow);
    border-color: var(--c-fg);
}
body[data-theme="light"] .pillar .k { color: var(--c-fg); }
body[data-theme="light"] .pillar h4 { color: var(--c-fg); }
body[data-theme="light"] .pillar p { color: #1A1A1A; }
body[data-theme="light"] .pillar:hover p { color: var(--c-fg); }

/* Save point newsletter */
body[data-theme="light"] .save-point p { color: #1A1A1A; }
body[data-theme="light"] .save-point h3 { color: var(--c-fg); }

/* FAQ details */
body[data-theme="light"] .faq-item { border-bottom-color: var(--c-line); }
body[data-theme="light"] .faq-item .q-id { color: var(--c-muted); }
body[data-theme="light"] .faq-item .q-text { color: var(--c-fg); }
body[data-theme="light"] .faq-item .q-icon { color: var(--c-fg); }
body[data-theme="light"] .faq-item .q-answer { color: var(--c-muted); }
body[data-theme="light"] .faq-item summary:hover { color: var(--c-fg); }
body[data-theme="light"] .faq-item summary:hover .q-icon { color: var(--c-fg); }
body[data-theme="light"] .faq { border-top-color: var(--c-fg); }

/* Blog cards */
body[data-theme="light"] .blog-card {
    background: #FFFFFF;
    border: 1px solid var(--c-fg);
    box-shadow: 4px 4px 0 var(--c-fg);
    transform: translate3d(0, 0, 0);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    backface-visibility: hidden;
}
body[data-theme="light"] .blog-card:hover {
    background: var(--c-yellow);
    transform: translate3d(-2px, -2px, 0);
    box-shadow: 6px 6px 0 var(--c-fg);
}
body[data-theme="light"] .blog-card .meta span { color: var(--c-muted); }
body[data-theme="light"] .blog-card h3 { color: var(--c-fg); }
body[data-theme="light"] .blog-card p { color: #1A1A1A; }
body[data-theme="light"] .blog-card .read { color: var(--c-fg); border-bottom-color: var(--c-fg); }
body[data-theme="light"] .blog-card:hover p,
body[data-theme="light"] .blog-card:hover .meta span { color: var(--c-fg); }

/* Blog post article body */
body[data-theme="light"] .cp-article { color: var(--c-fg); }
body[data-theme="light"] .cp-article p { color: #1A1A1A; }
body[data-theme="light"] .cp-article strong,
body[data-theme="light"] .cp-article b { color: var(--c-fg); }
body[data-theme="light"] .cp-article em,
body[data-theme="light"] .cp-article i { color: var(--c-fg); font-style: italic; }
body[data-theme="light"] .cp-article h1,
body[data-theme="light"] .cp-article h2,
body[data-theme="light"] .cp-article h4 { color: var(--c-fg); }
body[data-theme="light"] .cp-article h3 { color: var(--c-fg); }
body[data-theme="light"] .cp-article h2 { border-top-color: var(--c-fg); }
body[data-theme="light"] .cp-article h2::before { background: var(--c-yellow); height: 4px; }
body[data-theme="light"] .cp-article a {
    color: var(--c-fg);
    background: var(--c-yellow);
    border-bottom: 0;
    padding: 0 .1em;
}
body[data-theme="light"] .cp-article a:hover {
    background: var(--c-fg);
    color: var(--c-yellow);
}
body[data-theme="light"] .cp-article ul li,
body[data-theme="light"] .cp-article ol > li { color: var(--c-muted); }
body[data-theme="light"] .cp-article ul li::marker { color: var(--c-fg); }
body[data-theme="light"] .cp-article ol > li::before { color: var(--c-fg); }
body[data-theme="light"] .cp-article blockquote {
    background: var(--c-yellow);
    border-left-color: var(--c-fg);
    color: var(--c-fg);
}
body[data-theme="light"] .cp-article code {
    background: #FAFAF7;
    border: 1px solid var(--c-fg);
    color: var(--c-fg);
}
body[data-theme="light"] .cp-article pre {
    background: var(--c-fg);
    color: var(--c-yellow);
    border-color: var(--c-fg);
}
body[data-theme="light"] .cp-article pre code {
    background: transparent;
    color: var(--c-yellow);
    border: 0;
}
body[data-theme="light"] .cp-article hr { border-top-color: var(--c-line-2); }
body[data-theme="light"] .cp-article table { border-color: var(--c-fg); }
body[data-theme="light"] .cp-article th {
    background: var(--c-fg);
    color: var(--c-yellow);
}
body[data-theme="light"] .cp-article td { border-bottom-color: var(--c-line); }
body[data-theme="light"] .cp-article .callout {
    background: var(--c-yellow);
    border-left-color: var(--c-fg);
    color: var(--c-fg);
}
body[data-theme="light"] .cp-article .callout strong:first-child { color: var(--c-fg); }

/* Blog post hero */
body[data-theme="light"] .cp-post-hero { padding-top: 96px; padding-bottom: 2rem; }
body[data-theme="light"] .cp-post-meta { color: var(--c-muted); }
body[data-theme="light"] .cp-post-meta .cat { color: var(--c-fg); background: var(--c-yellow); padding: 2px 8px; }
body[data-theme="light"] .cp-post-meta .dot { background: var(--c-fg); }
body[data-theme="light"] .cp-post-title { color: var(--c-fg); }
body[data-theme="light"] .cp-post-title .accent { color: var(--c-fg); background: var(--c-yellow); padding: 0 .2em; }
body[data-theme="light"] .cp-post-lead { color: var(--c-muted); }

/* Hero section on home — keep dark canvas readable */
body[data-theme="light"] #sec-00 {
    background: var(--c-fg);  /* dark inset for the WebGL hero */
    color: #FFFFFF;
}
body[data-theme="light"] #sec-00 .hero-title { color: #FFFFFF; }
body[data-theme="light"] #sec-00 .hero-title .accent { color: var(--c-yellow); background: transparent; padding: 0; }
body[data-theme="light"] #sec-00 .hero-title .outline { color: transparent; -webkit-text-stroke-color: #FFFFFF; }
body[data-theme="light"] #sec-00 .hero-lead { color: rgba(255, 255, 255, .78); }
body[data-theme="light"] #sec-00 .hero-sub { color: rgba(255, 255, 255, .65); }
body[data-theme="light"] #sec-00 .hero-meta .chip {
    color: #FFFFFF;
    border-color: rgba(255, 255, 255, .25);
    background: rgba(255, 255, 255, .05);
}
body[data-theme="light"] #sec-00 .hero-meta .chip.hot {
    background: var(--c-yellow);
    color: var(--c-fg);
    border-color: var(--c-yellow);
}
body[data-theme="light"] #sec-00 .hero-foot { border-color: rgba(255, 255, 255, .14); }
body[data-theme="light"] #sec-00 .hero-foot .cell { border-right-color: rgba(255, 255, 255, .08); }
body[data-theme="light"] #sec-00 .hero-foot .k { color: rgba(255, 255, 255, .55); }
body[data-theme="light"] #sec-00 .hero-foot .v { color: #FFFFFF; }
body[data-theme="light"] #sec-00 .hero-foot .v.lime { color: var(--c-yellow); }
body[data-theme="light"] #sec-00 .hero-foot .v.cyan { color: var(--c-yellow); }
body[data-theme="light"] #sec-00 .btn {
    background: var(--c-yellow);
    color: var(--c-fg);
    border-color: var(--c-yellow);
    box-shadow: 4px 4px 0 #FFFFFF;
}
body[data-theme="light"] #sec-00 .btn:hover {
    background: #FFFFFF;
    color: var(--c-fg);
    border-color: #FFFFFF;
    box-shadow: 6px 6px 0 var(--c-yellow);
}
body[data-theme="light"] #sec-00 .btn-ghost {
    background: transparent;
    color: #FFFFFF;
    border-color: rgba(255, 255, 255, .35);
    box-shadow: none;
}
body[data-theme="light"] #sec-00 .btn-ghost:hover {
    background: #FFFFFF;
    color: var(--c-fg);
}
body[data-theme="light"] #sec-00 .cursor { color: var(--c-yellow); }
body[data-theme="light"] #sec-00 #typewriter { color: #FFFFFF; }

/* Social links — yellow chip with black icons */
body[data-theme="light"] .social-link {
    color: var(--c-fg);
    background: var(--c-yellow);
    border: 1px solid var(--c-fg);
    box-shadow: 3px 3px 0 var(--c-fg);
}
body[data-theme="light"] .social-link:hover,
body[data-theme="light"] .social-link:focus-visible {
    background: var(--c-fg);
    color: var(--c-yellow);
    transform: translate(-2px, -2px);
    box-shadow: 5px 5px 0 var(--c-yellow);
}
body[data-theme="light"] .social-links-label { color: var(--c-fg); }

/* Tech grid */
body[data-theme="light"] .tech-grid .t {
    background: #FFFFFF;
    border: 1px solid var(--c-fg);
    color: var(--c-fg);
}
body[data-theme="light"] .tech-grid .t::before { background: var(--c-fg); }

/* Save form button disabled state — yellow disabled */
body[data-theme="light"] .save-form button[aria-disabled="true"].btn,
body[data-theme="light"] .save-form button[aria-disabled="true"].btn:hover {
    background-color: #FAFAF7;
    color: var(--c-muted);
    border-color: var(--c-line);
    box-shadow: none;
    transform: none;
}
body[data-theme="light"] .save-form button[aria-disabled="true"].btn .arr { color: var(--c-muted); }

/* Scrollbar */
body[data-theme="light"]::-webkit-scrollbar-track { background: #FAFAF7; }
body[data-theme="light"]::-webkit-scrollbar-thumb { background: var(--c-fg); }
body[data-theme="light"]::-webkit-scrollbar-thumb:hover { background: var(--c-lime); }

/* =========================================================
   Inner page hero (no shader)
   ========================================================= */

.page-hero {
    position: relative;
    padding-top: 96px;
    min-height: auto;
    align-items: flex-start;
    overflow: hidden;
}

.page-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(800px 400px at 20% 10%, rgba(184,255,46,.06), transparent 60%),
        radial-gradient(900px 500px at 80% 80%, rgba(0,229,255,.05), transparent 60%);
    pointer-events: none;
    z-index: 0;
}

.page-hero .section-inner { position: relative; z-index: 1; }

.page-hero-grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: clamp(2rem, 5vw, 5rem);
    align-items: end;
    padding: clamp(2rem, 5vw, 4rem) 0;
}

@media (max-width: 980px) { .page-hero-grid { grid-template-columns: 1fr; } }

.page-hero-title {
    font-family: var(--f-display);
    font-weight: 700;
    text-transform: uppercase;
    line-height: 1.02;
    letter-spacing: -.005em;
    font-size: clamp(2.5rem, 7vw, 5.5rem);
    margin: 0 0 1.5rem;
    text-wrap: balance;
}

.page-hero-title .accent { color: var(--c-lime); }
.page-hero-title .accent-cy { color: var(--c-cyan); }

.page-hero-side {
    border: 1px solid var(--c-line-2);
    padding: 1.5rem;
    background: var(--c-bg-2);
    font-family: var(--f-mono);
    font-size: 12px;
    color: rgba(234,240,255,.7);
}

.page-hero-side .k {
    display: block;
    font-size: 10px;
    color: var(--c-muted);
    letter-spacing: .22em;
    text-transform: uppercase;
    margin-bottom: .35rem;
}

.page-hero-side .v {
    display: block;
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 1.4rem;
    color: var(--c-lime);
    margin-bottom: 1rem;
    text-transform: uppercase;
    letter-spacing: .02em;
}

.page-hero-side .v:last-child { margin-bottom: 0; }

.patch-line {
    font-family: var(--f-mono);
    font-size: 11px;
    color: var(--c-muted);
    letter-spacing: .22em;
    text-transform: uppercase;
    margin-bottom: 1.5rem;
}
.patch-line a { color: var(--c-fg); }
.patch-line a:hover { color: var(--c-lime); }
.patch-line .sep { color: var(--c-line-2); margin: 0 .5rem; }
.patch-line .here { color: var(--c-lime); }

/* =========================================================
   Steps / process flow
   ========================================================= */

.steps {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
}

@media (max-width: 900px) { .steps { grid-template-columns: 1fr; } }

.step {
    position: relative;
    background: var(--c-bg-2);
    border: 1px solid var(--c-line-2);
    padding: 1.75rem;
    display: flex;
    flex-direction: column;
    gap: .75rem;
    min-height: 220px;
    clip-path: polygon(0 0, calc(100% - 18px) 0, 100% 18px, 100% 100%, 0 100%);
    transition: border-color .25s var(--ease), background .25s var(--ease);
}

.step:hover { border-color: var(--c-lime); }

.step .k {
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--c-lime);
}

.step h4 {
    font-family: var(--f-display);
    font-weight: 700;
    text-transform: uppercase;
    font-size: 1.3rem;
    margin: 0;
    letter-spacing: .01em;
}

.step p { color: rgba(234,240,255,.7); font-size: 14px; margin: 0; }

.step .num {
    position: absolute;
    top: .75rem;
    right: 1rem;
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 2.4rem;
    color: var(--c-fg);
    opacity: .1;
}

/* =========================================================
   FAQ / accordion
   ========================================================= */

.faq { display: flex; flex-direction: column; border-top: 1px solid var(--c-line-2); }

.faq-item {
    border-bottom: 1px solid var(--c-line);
    overflow: hidden;
}

.faq-item summary {
    padding: 1.25rem 0;
    list-style: none;
    cursor: pointer;
    display: grid;
    grid-template-columns: 32px 1fr 32px;
    gap: 1rem;
    align-items: center;
    transition: color .2s;
}

.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary:hover { color: var(--c-lime); }

.faq-item .q-id {
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .14em;
    color: var(--c-muted);
}

.faq-item .q-text {
    font-family: var(--f-display);
    font-weight: 600;
    font-size: 1.05rem;
    text-transform: uppercase;
    letter-spacing: .01em;
}

.faq-item .q-icon {
    font-family: var(--f-mono);
    color: var(--c-lime);
    font-size: 1.2rem;
    transition: transform .25s var(--ease);
    text-align: center;
}

.faq-item[open] .q-icon { transform: rotate(45deg); }

.faq-item .q-answer {
    padding: 0 0 1.25rem 48px;
    color: rgba(234,240,255,.72);
    font-size: 14.5px;
    max-width: 80ch;
}
.faq-item .q-answer p { margin: 0 0 .75rem; }
.faq-item .q-answer p:last-child { margin-bottom: 0; }

/* =========================================================
   Comparison
   ========================================================= */

.compare { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 800px) { .compare { grid-template-columns: 1fr; } }

.compare-col {
    border: 1px solid var(--c-line-2);
    background: var(--c-bg-2);
    padding: 1.75rem;
}
.compare-col.bad { border-color: rgba(255,45,85,.25); }
.compare-col.good {
    border-color: rgba(184,255,46,.25);
    background: linear-gradient(135deg, rgba(184,255,46,.04), transparent 60%), var(--c-bg-2);
}
.compare-col h4 {
    font-family: var(--f-display);
    font-weight: 700;
    text-transform: uppercase;
    font-size: 1.1rem;
    letter-spacing: .04em;
    margin: 0 0 1rem;
}
.compare-col.bad h4 { color: var(--c-red); }
.compare-col.good h4 { color: var(--c-lime); }
.compare-col ul li {
    padding: .75rem 0;
    border-bottom: 1px dashed var(--c-line);
    display: flex;
    gap: .75rem;
    align-items: flex-start;
    font-size: 14px;
    color: rgba(234,240,255,.72);
}
.compare-col ul li:last-child { border-bottom: 0; }
.compare-col ul li::before { content: '✕'; color: var(--c-red); flex-shrink: 0; margin-top: 1px; }
.compare-col.good ul li::before { content: '✓'; color: var(--c-lime); }

/* =========================================================
   Blog cards
   ========================================================= */

.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
@media (max-width: 900px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .blog-grid { grid-template-columns: 1fr; } }

.blog-card {
    background: var(--c-bg-2);
    border: 1px solid var(--c-line-2);
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: .75rem;
    clip-path: polygon(0 0, calc(100% - 14px) 0, 100% 14px, 100% 100%, 14px 100%, 0 calc(100% - 14px));
    transition: border-color .25s var(--ease), background .25s var(--ease);
    min-height: 240px;
}
.blog-card:hover { border-color: var(--c-lime); background: var(--c-bg-3); }

.blog-card .meta {
    display: flex;
    gap: 1rem;
    font-family: var(--f-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: .22em;
    color: var(--c-muted);
}
.blog-card h3 {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 1.2rem;
    text-transform: uppercase;
    line-height: 1.1;
    margin: 0;
}
.blog-card p {
    color: rgba(234,240,255,.65);
    font-size: 13.5px;
    margin: 0;
    flex-grow: 1;
}
.blog-card .read {
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--c-fg);
    border-bottom: 1px solid var(--c-line-2);
    padding-bottom: 4px;
    margin-top: .5rem;
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    width: max-content;
    transition: color .2s, gap .2s var(--ease), border-color .2s;
}
.blog-card:hover .read { color: var(--c-lime); border-color: var(--c-lime); gap: .65rem; }

/* =========================================================
   Forms
   ========================================================= */

.form { display: grid; gap: 1.25rem; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 700px) { .form-row { grid-template-columns: 1fr; } }

.field { display: flex; flex-direction: column; gap: .35rem; }

.field label {
    font-family: var(--f-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: .22em;
    color: var(--c-muted);
}

.field input,
.field textarea,
.field select {
    background: var(--c-bg-2);
    color: var(--c-fg);
    border: 1px solid var(--c-line-2);
    padding: 13px 14px;
    font-family: var(--f-mono);
    font-size: 13px;
    letter-spacing: .03em;
    outline: 0;
    transition: border-color .2s, background .2s;
    width: 100%;
    border-radius: 0;
}

.field input:focus,
.field textarea:focus,
.field select:focus {
    border-color: var(--c-lime);
    background: rgba(184,255,46,.04);
}

.field textarea { resize: vertical; min-height: 120px; font-family: var(--f-body); }

.field select {
    appearance: none;
    background-color: var(--c-bg-2);
    background-image: linear-gradient(45deg, transparent 50%, var(--c-lime) 50%), linear-gradient(135deg, var(--c-lime) 50%, transparent 50%);
    background-position: calc(100% - 18px) 50%, calc(100% - 13px) 50%;
    background-size: 5px 5px, 5px 5px;
    background-repeat: no-repeat;
    padding-right: 30px;
    cursor: pointer;
    color-scheme: dark;
}

/* <option> dropdown items — force readable native styling */
.field select option {
    background: var(--c-bg-2);
    color: var(--c-fg);
    font-family: var(--f-mono);
    font-size: 13px;
    padding: 8px 10px;
}
.field select option:hover,
.field select option:checked,
.field select option:focus {
    background: var(--c-lime) !important;
    color: var(--c-bg) !important;
}
.field select option:disabled {
    color: var(--c-muted);
}

.choices { display: flex; flex-wrap: wrap; gap: .5rem; }

.choice {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: 8px 14px;
    border: 1px solid var(--c-line-2);
    font-family: var(--f-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--c-fg);
    cursor: pointer;
    transition: all .2s;
}
.choice:hover { border-color: var(--c-lime); color: var(--c-lime); }
.choice input { display: none; }
.choice.is-active { background: var(--c-lime); border-color: var(--c-lime); color: var(--c-bg); }

.consent {
    font-family: var(--f-mono);
    font-size: 11px;
    color: var(--c-muted);
    display: flex;
    gap: .65rem;
    align-items: flex-start;
    cursor: pointer;
    line-height: 1.5;
}
.consent input { margin-top: 3px; }
.consent a { color: var(--c-cyan); border-bottom: 1px solid var(--c-cyan); }

/* =========================================================
   Info cards / generic
   ========================================================= */

.info-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
@media (max-width: 900px) { .info-grid { grid-template-columns: 1fr; } }

.info-card {
    border: 1px solid var(--c-line-2);
    background: var(--c-bg-2);
    padding: 1.5rem;
    transition: border-color .25s var(--ease), background .25s var(--ease);
    transform: translate3d(0, 0, 0);
    backface-visibility: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.info-card:hover { border-color: var(--c-lime); background: var(--c-bg-3); }

.info-card .k {
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--c-lime);
    margin-bottom: .35rem;
}
.info-card h4 {
    font-family: var(--f-display);
    font-weight: 700;
    text-transform: uppercase;
    font-size: 1.15rem;
    margin: 0 0 .5rem;
}
.info-card p { color: rgba(234,240,255,.7); font-size: 14px; margin: 0; }

/* =========================================================
   HUD stats grid — used in /conocenos hero
   ========================================================= */
.hud-stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .75rem;
}
.hud-stat {
    padding: .75rem;
    border: 1px solid var(--c-line-2);
    background: var(--c-bg-2);
    position: relative;
}
.hud-stat[data-accent="lime"]   { border-color: rgba(184,255,46,.45); background: rgba(184,255,46,.06); }
.hud-stat[data-accent="cyan"]   { border-color: rgba(0,229,255,.45);  background: rgba(0,229,255,.06); }
.hud-stat[data-accent="purple"] { border-color: rgba(168,85,247,.45); background: rgba(168,85,247,.08); }
.hud-stat[data-accent="yellow"] { border-color: rgba(247,242,58,.45); background: rgba(247,242,58,.08); }

.hud-stat-label {
    font-family: var(--f-mono);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: rgba(234,240,255,.92);
}
.hud-stat[data-accent="lime"]   .hud-stat-label { color: #B8FF2E; }
.hud-stat[data-accent="cyan"]   .hud-stat-label { color: #5EE6FF; }
.hud-stat[data-accent="purple"] .hud-stat-label { color: #C99CFF; }
.hud-stat[data-accent="yellow"] .hud-stat-label { color: #F2EE3A; }

.hud-stat-value {
    font-family: var(--f-display);
    font-weight: 800;
    font-size: 1.6rem;
    color: var(--c-fg);
    line-height: 1.1;
    margin-top: 4px;
}

/* Light theme — flip to neo-brutalist: white card, black border, dark text */
body[data-theme="light"] .hud-stat {
    background: #FFFFFF;
    border: 1px solid var(--c-fg);
    box-shadow: 3px 3px 0 var(--c-fg);
}
body[data-theme="light"] .hud-stat[data-accent="lime"]   { background: #F4FFD9; }
body[data-theme="light"] .hud-stat[data-accent="cyan"]   { background: #DFF8FF; }
body[data-theme="light"] .hud-stat[data-accent="purple"] { background: #F1E4FF; }
body[data-theme="light"] .hud-stat[data-accent="yellow"] { background: #FFFCB8; }
/* Light-theme label overrides — these need accent-level specificity (0,3,1)
   to beat the dark-theme accent rules above at (0,3,0). Without this, the
   labels paint themselves in the same pastel hue as their card background
   and become illegible. */
body[data-theme="light"] .hud-stat[data-accent="lime"]   .hud-stat-label,
body[data-theme="light"] .hud-stat[data-accent="cyan"]   .hud-stat-label,
body[data-theme="light"] .hud-stat[data-accent="purple"] .hud-stat-label,
body[data-theme="light"] .hud-stat[data-accent="yellow"] .hud-stat-label,
body[data-theme="light"] .hud-stat-label {
    color: #1A1A1A;
}
body[data-theme="light"] .hud-stat-value { color: var(--c-fg); }

/* =========================================================
   Armory — Stack loadout like a video game inventory
   ========================================================= */

.armory {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    counter-reset: armory-slot;
}

.armory-loadout {
    position: relative;
    padding: 1.25rem 1.5rem 1.5rem;
    border: 1px solid var(--c-line-2);
    background:
        linear-gradient(180deg, rgba(184, 255, 46, .02) 0%, transparent 100%),
        var(--c-bg-2);
    overflow: hidden;
    transition: border-color .25s var(--ease);
}

/* Scanline overlay — animated horizontal sweep */
.armory-loadout::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg,
        transparent 0,
        transparent 49.5%,
        rgba(184, 255, 46, .04) 50%,
        transparent 50.5%,
        transparent 100%);
    background-size: 100% 4px;
    pointer-events: none;
    opacity: .5;
}

/* Corner brackets */
.armory-loadout::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    pointer-events: none;
    background:
        linear-gradient(135deg, var(--c-lime) 0 8px, transparent 8px) top left / 14px 14px no-repeat,
        linear-gradient(225deg, var(--c-lime) 0 8px, transparent 8px) top right / 14px 14px no-repeat,
        linear-gradient(45deg,  var(--c-lime) 0 8px, transparent 8px) bottom left / 14px 14px no-repeat,
        linear-gradient(315deg, var(--c-lime) 0 8px, transparent 8px) bottom right / 14px 14px no-repeat;
    opacity: .35;
}

/* Loadout categories: tinted accents */
.armory-loadout[data-loadout="backend"]  { --acc: #B8FF2E; }   /* lime */
.armory-loadout[data-loadout="frontend"] { --acc: #00E5FF; }   /* cyan */
.armory-loadout[data-loadout="ai"]       { --acc: #B266FF; }   /* purple */
.armory-loadout[data-loadout="cloud"]    { --acc: #F7F23A; }   /* yellow */

.armory-loadout-head {
    display: grid;
    grid-template-columns: 32px auto 1fr auto;
    gap: 1rem;
    align-items: center;
    padding-bottom: .85rem;
    margin-bottom: 1rem;
    border-bottom: 1px solid var(--c-line-2);
    position: relative;
    z-index: 1;
}

.armory-glyph {
    width: 32px; height: 32px;
    display: grid; place-items: center;
    background: var(--acc, var(--c-lime));
    color: var(--c-bg);
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 18px;
    clip-path: polygon(6px 0, 100% 0, 100% calc(100% - 6px), calc(100% - 6px) 100%, 0 100%, 0 6px);
    flex-shrink: 0;
}
.armory-glyph svg {
    width: 18px;
    height: 18px;
    display: block;
}

.armory-name {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 1.05rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--c-fg);
}

.armory-meta {
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: .25em;
    text-transform: uppercase;
    color: var(--c-muted);
    justify-self: start;
}

.armory-count {
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .2em;
    color: var(--c-fg);
    background: var(--acc, var(--c-lime));
    padding: 3px 8px;
}

/* Slot grid */
.armory-slots {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: .65rem;
    position: relative;
    z-index: 1;
}

.armory-slot {
    --slot-acc: var(--acc, var(--c-lime));
    position: relative;
    padding: 12px 14px 12px 28px;
    border: 1px solid var(--c-line-2);
    background: var(--c-bg-3);
    color: var(--c-fg);
    display: flex;
    flex-direction: column;
    gap: 2px;
    cursor: default;
    overflow: hidden;
    transition: border-color .2s var(--ease), background .2s var(--ease), transform .2s var(--ease);
    clip-path: polygon(6px 0, 100% 0, 100% calc(100% - 6px), calc(100% - 6px) 100%, 0 100%, 0 6px);
    transform: translate3d(0, 0, 0);
    -webkit-font-smoothing: antialiased;
    backface-visibility: hidden;
}

.armory-slot::before {
    /* left rarity bar */
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 4px;
    background: var(--slot-acc);
    opacity: .55;
    transition: opacity .2s var(--ease);
}

.armory-slot::after {
    /* hover sweep */
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.06) 50%, transparent 100%);
    transform: translateX(-110%);
    transition: transform .55s var(--ease);
    pointer-events: none;
}

.armory-slot:hover {
    border-color: var(--slot-acc);
    background: rgba(255, 255, 255, .04);
    transform: translate3d(0, -2px, 0);
}
.armory-slot:hover::before { opacity: 1; }
.armory-slot:hover::after { transform: translateX(110%); }

/* LED status indicator */
.armory-led {
    position: absolute;
    top: 12px; right: 10px;
    width: 6px; height: 6px;
    background: var(--slot-acc);
    border-radius: 50%;
    box-shadow: 0 0 5px var(--slot-acc);
    animation: armory-pulse 1.8s ease-in-out infinite;
}

@keyframes armory-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: .35; transform: scale(.85); }
}

.armory-tech {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: .03em;
    color: var(--c-fg);
    line-height: 1.15;
}

.armory-tier {
    font-family: var(--f-mono);
    font-size: 9px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--c-muted);
}

/* Rarity tiers — special styling */
.armory-slot.rare {
    background: linear-gradient(135deg, rgba(178, 102, 255, .12), var(--c-bg-3));
}
.armory-slot.rare::before { background: #B266FF; }
.armory-slot.rare .armory-led { background: #B266FF; box-shadow: 0 0 8px #B266FF; }

.armory-slot.legendary {
    background: linear-gradient(135deg, rgba(247, 242, 58, .12), var(--c-bg-3));
}
.armory-slot.legendary::before {
    background: var(--c-yellow);
    width: 5px;
}
.armory-slot.legendary .armory-led {
    background: var(--c-yellow);
    box-shadow: 0 0 10px var(--c-yellow);
}
.armory-slot.legendary .armory-tech {
    color: var(--c-yellow);
}

/* Hidden initial state — JS will animate in */
.armory-slot { will-change: transform, opacity; }

.armory-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 1.25rem;
    padding-top: 1rem;
    border-top: 1px dashed var(--c-line-2);
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--c-muted);
    flex-wrap: wrap;
    gap: 1rem;
}

.armory-status {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
}

.armory-status-dot {
    width: 8px; height: 8px;
    background: var(--c-lime);
    border-radius: 50%;
    box-shadow: 0 0 8px var(--c-lime);
    animation: armory-pulse 1.4s ease-in-out infinite;
}

.armory-hint {
    color: var(--c-muted);
    font-style: italic;
    text-transform: none;
    letter-spacing: .04em;
}

@media (max-width: 600px) {
    .armory-loadout-head {
        grid-template-columns: 28px 1fr auto;
        gap: .65rem;
    }
    .armory-meta { display: none; }
    .armory-slots { grid-template-columns: repeat(2, 1fr); }
}

/* Light theme: re-tint background and add neo-brutalist shadow */
body[data-theme="light"] .armory-loadout {
    background:
        linear-gradient(180deg, rgba(247, 242, 58, .12) 0%, transparent 60%),
        #FFFFFF;
    border: 1px solid var(--c-fg);
    box-shadow: 4px 4px 0 var(--c-fg);
}
body[data-theme="light"] .armory-loadout::before {
    background: linear-gradient(180deg,
        transparent 0,
        transparent 49.5%,
        rgba(10, 10, 10, .04) 50%,
        transparent 50.5%,
        transparent 100%);
    background-size: 100% 4px;
}
body[data-theme="light"] .armory-loadout::after { opacity: .65; }
body[data-theme="light"] .armory-glyph { color: var(--c-fg); }
body[data-theme="light"] .armory-name { color: var(--c-fg); }
body[data-theme="light"] .armory-meta { color: #4A4A4A; }
body[data-theme="light"] .armory-count { color: var(--c-fg); }
body[data-theme="light"] .armory-loadout-head { border-bottom-color: var(--c-fg); }

body[data-theme="light"] .armory-slot {
    background: #FAFAF7;
    border: 1px solid var(--c-fg);
    color: var(--c-fg);
}
body[data-theme="light"] .armory-slot:hover {
    background: var(--slot-acc);
    color: var(--c-fg);
}
body[data-theme="light"] .armory-slot:hover .armory-tier { color: var(--c-fg); }
body[data-theme="light"] .armory-tech { color: var(--c-fg); }
body[data-theme="light"] .armory-tier { color: #4A4A4A; }

body[data-theme="light"] .armory-slot.rare {
    background: linear-gradient(135deg, rgba(178, 102, 255, .18), #FAFAF7);
}
body[data-theme="light"] .armory-slot.legendary {
    background: linear-gradient(135deg, rgba(247, 242, 58, .35), #FFFAEC);
}
body[data-theme="light"] .armory-slot.legendary .armory-tech { color: var(--c-fg); }

body[data-theme="light"] .armory-footer {
    color: #4A4A4A;
    border-top-color: var(--c-fg);
}
body[data-theme="light"] .armory-status-dot {
    background: var(--c-fg);
    box-shadow: none;
}

/* =========================================================
   Customer reviews
   ========================================================= */

/* Dark theme defaults (hardcoded fallback to bypass var() rendering quirks) */
.review {
    background-color: #0A0F1D;
    border: 1px solid rgba(234, 240, 255, .14);
    padding: 1.75rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    transition: border-color .25s var(--ease), background-color .25s var(--ease);
}

.review:hover {
    border-color: #B8FF2E;
    background-color: #0E1424;
}

.review-stars {
    color: #F7F23A;                 /* yellow */
    font-size: 18px;
    letter-spacing: .15em;
    line-height: 1;
}

.review-quote {
    font-family: var(--f-body);
    font-size: 15.5px;
    line-height: 1.6;
    color: #EAF0FF;                 /* near-white — 18:1 on #0A0F1D */
    margin: 0;
    padding: 0;
    border: 0;
    background: none;
    font-style: normal;
    position: relative;
    padding-left: 1rem;
    border-left: 2px solid #B8FF2E;
}

.review-quote::before { content: '"'; }
.review-quote::after  { content: '"'; }

.review-author {
    border-top: 1px dashed rgba(234, 240, 255, .08);
    padding-top: .75rem;
}

.review-name {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 14px;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: #EAF0FF;
    margin-bottom: .15rem;
}

.review-role {
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .12em;
    color: #6D7793;
    text-transform: uppercase;
}

/* Light theme reviews — high contrast on white */
body[data-theme="light"] .review {
    background-color: #FFFFFF;
    border: 1px solid var(--c-fg);
    box-shadow: 4px 4px 0 var(--c-fg);
    transform: translate3d(0, 0, 0);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    backface-visibility: hidden;
}
body[data-theme="light"] .review:hover {
    background-color: var(--c-yellow);
    transform: translate3d(-2px, -2px, 0);
    box-shadow: 6px 6px 0 var(--c-fg);
}
body[data-theme="light"] .review-stars { color: #876200; }     /* deep gold · 7:1 on white */
body[data-theme="light"] .review:hover .review-stars { color: var(--c-fg); }
body[data-theme="light"] .review-quote {
    color: #0A0A0A;                                            /* 19:1 on white */
    border-left-color: var(--c-fg);
}
body[data-theme="light"] .review-author { border-top-color: var(--c-line); }
body[data-theme="light"] .review-name { color: var(--c-fg); }
body[data-theme="light"] .review-role { color: #4A4A4A; }       /* 9:1 on white */

/* =========================================================
   Client logo grid — neutral white chip, full color logos
   ========================================================= */

.logo-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 1rem;
}

.logo-cell {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .65rem;
}

.logo-chip {
    width: 100%;
    aspect-ratio: 3 / 2;
    box-sizing: border-box;
    background: #FFFFFF;
    border: 1px solid var(--c-line-2);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.25rem;
    overflow: hidden;
    transition: border-color .25s var(--ease), transform .25s var(--ease);
    clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
    box-shadow: 0 6px 18px rgba(0, 0, 0, .35);
}

.logo-chip:hover {
    border-color: var(--c-lime);
    transform: translateY(-2px);
}

.logo-chip img {
    /* Cap to 75% of the chip so logos with tight crops don't dominate */
    max-width: 78%;
    max-height: 70%;
    width: auto;
    height: auto;
    object-fit: contain;
    display: block;
}

/* Per-logo overrides for files with abnormal aspect ratios */
.logo-chip img[src*="sathogar"] {
    max-width: 60%;
    max-height: 60%;
}
.logo-chip img[src*="ayto-tres-cantos"],
.logo-chip img[src*="fuga-de-flamencos"],
.logo-chip img[src*="ministerio-sanidad"] {
    max-height: 65%;
}

.logo-meta {
    font-family: var(--f-mono);
    font-size: 10px;
    color: var(--c-muted);
    letter-spacing: .18em;
    text-transform: uppercase;
}

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

/* =========================================================
   Tech grid
   ========================================================= */

.tech-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: .75rem;
}
.tech-grid .t {
    border: 1px solid var(--c-line-2);
    background: var(--c-bg-2);
    padding: .75rem 1rem;
    font-family: var(--f-mono);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: rgba(234,240,255,.7);
    display: flex;
    align-items: center;
    gap: .5rem;
}
.tech-grid .t::before {
    content: '';
    width: 6px; height: 6px;
    background: var(--c-lime);
    transform: rotate(45deg);
    flex-shrink: 0;
}

/* =========================================================
   Cross-page side nav active state by body[data-page]
   ========================================================= */

body[data-page="home"]       .nav-item[data-page="home"],
body[data-page="soluciones"] .nav-item[data-page="soluciones"],
body[data-page="studio"]     .nav-item[data-page="studio"],
body[data-page="clientes"]   .nav-item[data-page="clientes"],
body[data-page="blog"]       .nav-item[data-page="blog"],
body[data-page="contacto"]   .nav-item[data-page="contacto"] {
    color: var(--c-fg);
}

body[data-page="home"]       .nav-item[data-page="home"] .n,
body[data-page="soluciones"] .nav-item[data-page="soluciones"] .n,
body[data-page="studio"]     .nav-item[data-page="studio"] .n,
body[data-page="clientes"]   .nav-item[data-page="clientes"] .n,
body[data-page="blog"]       .nav-item[data-page="blog"] .n,
body[data-page="contacto"]   .nav-item[data-page="contacto"] .n {
    opacity: 1;
    color: var(--c-lime);
}

body[data-page="home"]       .nav-item[data-page="home"] .bar,
body[data-page="soluciones"] .nav-item[data-page="soluciones"] .bar,
body[data-page="studio"]     .nav-item[data-page="studio"] .bar,
body[data-page="clientes"]   .nav-item[data-page="clientes"] .bar,
body[data-page="blog"]       .nav-item[data-page="blog"] .bar,
body[data-page="contacto"]   .nav-item[data-page="contacto"] .bar {
    background: var(--c-lime);
    height: 22px;
    box-shadow: 0 0 10px var(--c-lime);
}

/* =========================================================
   Cart pill (preserved)
   ========================================================= */

.cart-btn {
    position: fixed;
    top: 48px;
    right: 18px;
    z-index: 50;
    padding: 10px 14px;
    background: var(--c-bg-2);
    border: 1px solid var(--c-line-2);
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--c-fg);
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    transition: border-color .2s, color .2s;
}
.cart-btn:hover { border-color: var(--c-lime); color: var(--c-lime); }
.cart-btn .count {
    background: var(--c-lime);
    color: var(--c-bg);
    padding: 1px 6px;
    font-weight: 700;
    font-size: 10px;
}

/* =========================================================
   Article body (blog posts)
   ========================================================= */

.cp-article {
    max-width: 760px;
    margin: 0 auto;
    color: rgba(234, 240, 255, .82);
    font-size: 16px;
    line-height: 1.7;
}

.cp-article > * + * { margin-top: 1.25rem; }

.cp-article h1, .cp-article h2, .cp-article h3, .cp-article h4 {
    font-family: var(--f-display);
    font-weight: 700;
    color: var(--c-fg);
    text-transform: uppercase;
    letter-spacing: .01em;
    line-height: 1.15;
}

.cp-article h1 { font-size: clamp(2rem, 5vw, 3rem); margin: 2.5rem 0 1rem; }
.cp-article h2 {
    font-size: clamp(1.5rem, 3vw, 2rem);
    margin: 3rem 0 1rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--c-line-2);
    position: relative;
}
.cp-article h2::before {
    content: '';
    position: absolute;
    top: -1px; left: 0;
    width: 60px; height: 2px;
    background: var(--c-lime);
}
.cp-article h3 { font-size: clamp(1.2rem, 2vw, 1.5rem); margin: 2rem 0 .75rem; color: var(--c-lime); }
.cp-article h4 { font-size: 1.1rem; margin: 1.5rem 0 .5rem; }

.cp-article p { margin: 0 0 1rem; }
.cp-article strong, .cp-article b { color: var(--c-fg); font-weight: 700; }
.cp-article em, .cp-article i { color: rgba(234, 240, 255, .9); }

.cp-article a {
    color: var(--c-lime);
    border-bottom: 1px solid rgba(184, 255, 46, .35);
    transition: border-color .2s, color .2s;
}
.cp-article a:hover { color: var(--c-cyan); border-bottom-color: var(--c-cyan); }

.cp-article ul, .cp-article ol {
    margin: 1rem 0 1.25rem;
    padding-left: 1.5rem;
}
.cp-article ul li, .cp-article ol li {
    margin-bottom: .5rem;
    padding-left: .25rem;
}
.cp-article ul li::marker { color: var(--c-lime); content: '› '; }
.cp-article ol { list-style: none; counter-reset: ol; padding-left: 0; }
.cp-article ol > li {
    counter-increment: ol;
    padding-left: 2.5rem;
    position: relative;
}
.cp-article ol > li::before {
    content: counter(ol, decimal-leading-zero);
    position: absolute;
    left: 0; top: 0;
    font-family: var(--f-mono);
    font-size: 12px;
    color: var(--c-lime);
    letter-spacing: .05em;
    padding-top: 5px;
}

.cp-article blockquote {
    margin: 2rem 0;
    padding: 1.25rem 1.5rem;
    border-left: 2px solid var(--c-lime);
    background: rgba(184, 255, 46, .04);
    font-size: 17px;
    color: var(--c-fg);
    font-style: normal;
}
.cp-article blockquote p:last-child { margin-bottom: 0; }

.cp-article code {
    font-family: var(--f-mono);
    background: var(--c-bg-3);
    color: var(--c-lime);
    padding: 2px 6px;
    font-size: .9em;
    border: 1px solid var(--c-line);
}

.cp-article pre {
    background: var(--c-bg-3);
    border: 1px solid var(--c-line-2);
    padding: 1.25rem;
    overflow-x: auto;
    font-family: var(--f-mono);
    font-size: 13px;
    line-height: 1.55;
    margin: 1.5rem 0;
}
.cp-article pre code {
    background: transparent;
    border: 0;
    padding: 0;
    color: var(--c-fg);
}

.cp-article hr {
    border: 0;
    border-top: 1px dashed var(--c-line-2);
    margin: 2.5rem 0;
}

.cp-article img {
    max-width: 100%;
    height: auto;
    margin: 1.5rem 0;
    border: 1px solid var(--c-line-2);
}

.cp-article table {
    width: 100%;
    margin: 1.5rem 0;
    border-collapse: collapse;
    font-size: 14px;
    border: 1px solid var(--c-line-2);
}
.cp-article th, .cp-article td {
    padding: .75rem 1rem;
    text-align: left;
    border-bottom: 1px solid var(--c-line);
}
.cp-article th {
    background: var(--c-bg-3);
    color: var(--c-lime);
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .18em;
    text-transform: uppercase;
}
.cp-article tr:last-child td { border-bottom: 0; }

/* =========================================================
   Blog visual enhancements — applied automatically to any
   page that uses .cp-article (all blog posts).
   ========================================================= */

/* Reading progress bar — injected by cyberpunk-main.js on blog pages */
.reading-progress {
    position: fixed;
    top: 0; left: 0;
    height: 3px;
    width: 0;
    background: linear-gradient(90deg, var(--c-lime), var(--c-cyan));
    z-index: 999;
    pointer-events: none;
    box-shadow: 0 0 12px rgba(184, 255, 46, .6);
    transition: width .08s linear;
}
body[data-theme="light"] .reading-progress {
    background: linear-gradient(90deg, var(--c-yellow), var(--c-fg));
    box-shadow: 0 0 8px rgba(247, 242, 58, .8);
}

/* Drop-cap on the first paragraph of the article (tagged by JS) */
.cp-article p[data-drop-cap]::first-letter {
    font-family: var(--f-display);
    font-size: 3.4em;
    font-weight: 700;
    float: left;
    line-height: .85;
    padding: .1em .15em 0 0;
    color: var(--c-lime);
    margin-top: .05em;
}
body[data-theme="light"] .cp-article p[data-drop-cap]::first-letter {
    color: var(--c-fg);
    background: var(--c-yellow);
    padding: .05em .15em;
    margin-right: .1em;
}

/* h2 decoration — animated tracer line that draws in on scroll */
.cp-article h2 {
    overflow: visible;
}
.cp-article h2::after {
    content: '';
    position: absolute;
    left: 0; bottom: -.5rem;
    height: 1px;
    width: 0;
    background: linear-gradient(90deg, var(--c-lime), transparent);
    transition: width 1.2s cubic-bezier(.16, 1, .3, 1);
}
.cp-article h2.in-view::after {
    width: 100%;
}
body[data-theme="light"] .cp-article h2::after {
    background: linear-gradient(90deg, var(--c-fg), transparent);
}

/* Subtle hover-glow on emphasis terms */
.cp-article strong {
    position: relative;
    transition: text-shadow .25s, color .25s;
}
.cp-article p:hover > strong {
    text-shadow: 0 0 12px rgba(184, 255, 46, .35);
}
body[data-theme="light"] .cp-article p:hover > strong {
    text-shadow: none;
    background: var(--c-yellow);
    padding: 0 .15em;
}

/* =========================================================
   Article content components — applied per-article via class
   names. Each maps to a recurring pattern in blog posts.
   ========================================================= */

/* — Warning / spotlight callout (Advertencia / Dato clave / Spoiler) */
.article-warning {
    position: relative;
    margin: 1.75rem 0 2rem;
    padding: 1.25rem 1.5rem 1.25rem 3.25rem;
    background: rgba(247, 110, 17, .07);
    border: 1px solid rgba(247, 110, 17, .35);
    border-left: 3px solid #F76E11;
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 12px), calc(100% - 12px) 100%, 0 100%);
}
.article-warning::before {
    content: '!';
    position: absolute;
    left: 1.1rem;
    top: 1.15rem;
    width: 22px; height: 22px;
    display: grid; place-items: center;
    background: #F76E11;
    color: #0A0F1D;
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 14px;
    clip-path: polygon(4px 0, 100% 0, 100% calc(100% - 4px), calc(100% - 4px) 100%, 0 100%, 0 4px);
}
.article-warning p {
    margin: 0 !important;
    color: rgba(234, 240, 255, .92);
    text-align: left !important;
}
.article-warning p strong:first-child {
    display: inline-block;
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: #FFB37A;
    margin-right: .5em;
}
body[data-theme="light"] .article-warning {
    background: #FFF6EE;
    border-color: #C04A00;
}
body[data-theme="light"] .article-warning p { color: #1A1A1A; }
body[data-theme="light"] .article-warning p strong:first-child { color: #C04A00; }

/* — Checklist (✓ pros / ✗ cons) with cyberpunk badges */
.article-checklist {
    list-style: none !important;
    padding-left: 0 !important;
    margin: 1.25rem 0 1.5rem !important;
    display: grid;
    gap: .65rem;
}
.article-checklist li {
    display: grid !important;
    grid-template-columns: 26px 1fr;
    gap: .85rem;
    padding: .65rem .85rem !important;
    background: var(--c-bg-2);
    border: 1px solid var(--c-line);
    border-left-width: 3px;
    align-items: start;
    margin-bottom: 0 !important;
}
.article-checklist li::before { display: none !important; content: none !important; }
.article-checklist li::marker { content: none !important; }
.article-checklist li > span:first-child {
    width: 26px; height: 26px;
    display: grid; place-items: center;
    background: var(--c-line);
    color: var(--c-fg);
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 14px;
    line-height: 1;
}
.article-checklist li > span:last-child {
    color: rgba(234, 240, 255, .88);
    line-height: 1.55;
    align-self: center;
    text-align: left;
}
.article-checklist li > span:last-child strong:first-child {
    color: var(--c-fg);
}
.article-checklist--pro li { border-left-color: var(--c-lime); }
.article-checklist--pro li > span:first-child {
    background: var(--c-lime);
    color: var(--c-bg);
}
.article-checklist--con li { border-left-color: #FF4564; }
.article-checklist--con li > span:first-child {
    background: #FF4564;
    color: #0A0F1D;
}
body[data-theme="light"] .article-checklist li {
    background: #FFFFFF;
    border-color: var(--c-fg);
    box-shadow: 3px 3px 0 var(--c-fg);
}
body[data-theme="light"] .article-checklist li > span:last-child { color: #1A1A1A; }
body[data-theme="light"] .article-checklist--pro li > span:first-child { background: var(--c-yellow); color: var(--c-fg); }
body[data-theme="light"] .article-checklist--con li { border-left-color: #C00020; }
body[data-theme="light"] .article-checklist--con li > span:first-child { background: #C00020; color: #FFFFFF; }

/* — Numbered step cards */
.article-steps {
    display: grid !important;
    gap: 1rem;
    margin: 1.5rem 0 !important;
    padding: 0 !important;
    grid-template-columns: 1fr;
}
@media (min-width: 720px) {
    .article-steps { grid-template-columns: repeat(3, 1fr); }
    .article-steps--2 { grid-template-columns: repeat(2, 1fr); }
    .article-steps--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1000px) {
    .article-steps--4 { grid-template-columns: repeat(4, 1fr); }
}
.article-steps .article-step {
    position: relative;
    padding: 1.25rem 1.25rem 1.25rem 3.5rem;
    background: var(--c-bg-2);
    border: 1px solid var(--c-line);
    margin-top: 0 !important;
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 10px), calc(100% - 10px) 100%, 0 100%);
}
.article-steps .article-step > div:first-child,
.article-steps .article-step > span:first-child {
    position: absolute;
    left: 1rem; top: 1.15rem;
    width: 28px; height: 28px;
    display: grid; place-items: center;
    background: var(--c-lime);
    color: var(--c-bg);
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 14px;
    line-height: 1;
    clip-path: polygon(4px 0, 100% 0, 100% calc(100% - 4px), calc(100% - 4px) 100%, 0 100%, 0 4px);
}
.article-steps .article-step h3,
.article-steps .article-step h4 {
    margin: 0 0 .35rem !important;
    font-size: 1rem !important;
    text-transform: uppercase;
    color: var(--c-fg) !important;
}
.article-steps .article-step p {
    margin: 0 !important;
    font-size: 14px;
    color: rgba(234, 240, 255, .8);
    line-height: 1.55;
}
body[data-theme="light"] .article-steps .article-step {
    background: #FFFFFF;
    border-color: var(--c-fg);
    box-shadow: 3px 3px 0 var(--c-fg);
}
body[data-theme="light"] .article-steps .article-step > div:first-child,
body[data-theme="light"] .article-steps .article-step > span:first-child {
    background: var(--c-yellow);
    color: var(--c-fg);
}
body[data-theme="light"] .article-steps .article-step p { color: #1A1A1A; }

/* — Terminal-style block (// comment + bullet list) */
.article-terminal {
    margin: 1.75rem 0;
    padding: 1.25rem 1.5rem;
    background: #06080F;
    border: 1px solid var(--c-line-2);
    border-left: 2px solid var(--c-cyan);
    font-family: var(--f-mono);
    font-size: 13px;
    line-height: 1.7;
    color: rgba(234, 240, 255, .88);
    overflow-x: auto;
}
.article-terminal p:first-child {
    color: var(--c-cyan);
    margin: 0 0 .35rem !important;
    font-size: 11px;
    letter-spacing: .12em;
    text-transform: uppercase;
    opacity: .85;
    text-align: left !important;
}
.article-terminal ul {
    list-style: none !important;
    padding-left: 0 !important;
    margin: 0 !important;
}
.article-terminal li {
    margin: 0 !important;
    padding-left: 0 !important;
}
.article-terminal li::marker,
.article-terminal li::before { content: none !important; }
body[data-theme="light"] .article-terminal {
    background: #0A0F1D;
    color: #E0E6F0;
    border-color: var(--c-fg);
    border-left-color: var(--c-yellow);
    box-shadow: 4px 4px 0 var(--c-fg);
}

/* — Mid-article CTA banner */
.article-mid-cta {
    position: relative;
    margin: 2.5rem 0 !important;
    padding: 1.75rem 2rem;
    background: linear-gradient(135deg, rgba(184,255,46,.08), transparent 70%), var(--c-bg-2);
    border: 1px solid var(--c-lime);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 16px), calc(100% - 16px) 100%, 0 100%);
}
.article-mid-cta::before {
    content: '// CTA · 01';
    position: absolute;
    top: .85rem; right: 1.25rem;
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: .18em;
    color: var(--c-lime);
    opacity: .6;
}
.article-mid-cta h2,
.article-mid-cta h3 {
    margin: 0 0 .5rem !important;
    padding: 0 !important;
    border: 0 !important;
    font-size: clamp(1.15rem, 2vw, 1.45rem) !important;
    line-height: 1.15 !important;
    color: var(--c-fg) !important;
}
.article-mid-cta h2::before,
.article-mid-cta h2::after,
.article-mid-cta h3::before,
.article-mid-cta h3::after { display: none !important; }
.article-mid-cta p {
    margin: 0 0 1rem !important;
    font-size: 15px;
    color: rgba(234, 240, 255, .82);
}
.article-mid-cta a {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .65rem 1.1rem;
    background: var(--c-lime);
    color: var(--c-bg) !important;
    font-family: var(--f-mono);
    font-size: 12px;
    letter-spacing: .12em;
    text-transform: uppercase;
    border: 0 !important;
    transition: background .2s;
}
.article-mid-cta a:hover {
    background: var(--c-cyan);
    color: var(--c-bg) !important;
    border-bottom: 0 !important;
}
body[data-theme="light"] .article-mid-cta {
    background: var(--c-yellow);
    border-color: var(--c-fg);
    box-shadow: 6px 6px 0 var(--c-fg);
}
body[data-theme="light"] .article-mid-cta::before { color: var(--c-fg); opacity: .7; }
body[data-theme="light"] .article-mid-cta p { color: #1A1A1A; }
body[data-theme="light"] .article-mid-cta a {
    background: var(--c-fg);
    color: var(--c-yellow) !important;
}
body[data-theme="light"] .article-mid-cta a:hover {
    background: #1A1A1A;
}

/* — Hero illustration block (sits above .cp-post-title) */
.article-hero-art {
    max-width: 760px;
    margin: 0 auto 1.5rem;
    height: 180px;
    position: relative;
    overflow: hidden;
    background: var(--c-bg-2);
    border: 1px solid var(--c-line);
    display: grid;
    place-items: center;
}
.article-hero-art svg {
    width: 100%;
    height: 100%;
    display: block;
}
@media (prefers-reduced-motion: no-preference) {
    .article-hero-art svg circle[fill="#FF4564"],
    .article-hero-art svg circle[fill="#B8FF2E"],
    .article-hero-art svg circle[fill="#00E5FF"] {
        animation: art-node-pulse 2.4s ease-in-out infinite;
        transform-origin: center;
        transform-box: fill-box;
    }
    .article-hero-art svg circle[fill="#FF4564"] { animation-duration: 1.6s; }
    .article-hero-art svg circle[fill="#00E5FF"] { animation-delay: .4s; }
}
@keyframes art-node-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%      { opacity: .55; transform: scale(.78); }
}
body[data-theme="light"] .article-hero-art {
    background: var(--c-yellow);
    border: 1px solid var(--c-fg);
    box-shadow: 4px 4px 0 var(--c-fg);
}

/* "Key fact" callout — common pattern in posts */
.cp-article .callout {
    background: rgba(0, 229, 255, .06);
    border-left: 2px solid var(--c-cyan);
    padding: 1.25rem 1.5rem;
    margin: 1.5rem 0;
}
.cp-article .callout strong:first-child {
    display: block;
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--c-cyan);
    margin-bottom: .35rem;
}

/* Post hero block */
.cp-post-hero {
    padding-top: 96px;
    padding-bottom: 2rem;
}

.cp-post-meta {
    display: flex;
    gap: 1rem;
    align-items: center;
    flex-wrap: wrap;
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--c-muted);
    margin-bottom: 1.5rem;
}
.cp-post-meta .cat { color: var(--c-lime); }
.cp-post-meta .dot {
    width: 4px; height: 4px;
    background: var(--c-line-2);
    transform: rotate(45deg);
}

.cp-post-title {
    font-family: var(--f-display);
    font-weight: 700;
    text-transform: uppercase;
    line-height: 1;
    letter-spacing: -.005em;
    font-size: clamp(2rem, 5vw, 3.5rem);
    margin: 0 0 1.25rem;
    color: var(--c-fg);
}
.cp-post-title .accent { color: var(--c-lime); }

.cp-post-lead {
    font-size: clamp(1rem, 1.2vw, 1.15rem);
    color: rgba(234, 240, 255, .75);
    max-width: 70ch;
    margin: 0 0 2rem;
}

/* =========================================================
   End-of-article CTA — "¿Tienes un reto similar?"
   Themed properly in both dark & light modes so the lead
   paragraph stays legible (4.5:1 min contrast).
   ========================================================= */

.article-cta {
    max-width: 760px;
    margin: 4rem auto 0;
    padding: 2rem 0 0;
    border-top: 1px solid var(--c-line-2);
}
.article-cta__tag {
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--c-muted);
    margin-bottom: 1rem;
}
.article-cta__title {
    font-family: var(--f-display);
    font-weight: 700;
    text-transform: uppercase;
    font-size: 1.5rem;
    line-height: 1.1;
    margin: 0 0 .5rem;
    color: var(--c-fg);
}
.article-cta__lead {
    color: rgba(234, 240, 255, .82);
    margin: 0 0 1.5rem;
    font-size: 15px;
    line-height: 1.6;
}
.article-cta__actions {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

/* Light theme — high-contrast lead text */
body[data-theme="light"] .article-cta {
    border-top-color: var(--c-fg);
}
body[data-theme="light"] .article-cta__tag { color: #4A4A4A; }
body[data-theme="light"] .article-cta__title { color: var(--c-fg); }
body[data-theme="light"] .article-cta__lead { color: #1A1A1A; }

/* =========================================================
   Social links — "FIND US ON" Cyberpunk-style
   ========================================================= */

.social-links {
    display: flex;
    gap: 1rem;
    align-items: center;
    flex-wrap: wrap;
}

.social-links-label {
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .28em;
    text-transform: uppercase;
    color: var(--c-muted);
}

.social-links-row {
    display: inline-flex;
    gap: .5rem;
    align-items: center;
    flex-wrap: wrap;
}

.social-link {
    --sz: 44px;
    width: var(--sz);
    height: var(--sz);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--c-cyan);
    border: 1px solid transparent;
    transition: color .2s var(--ease), background .2s var(--ease), border-color .2s var(--ease), transform .2s var(--ease);
    text-decoration: none;
    clip-path: polygon(6px 0, 100% 0, 100% calc(100% - 6px), calc(100% - 6px) 100%, 0 100%, 0 6px);
    background: rgba(0, 229, 255, .04);
}

.social-link svg {
    width: 22px;
    height: 22px;
    fill: currentColor;
    display: block;
}

.social-link:hover,
.social-link:focus-visible {
    color: var(--c-bg);
    background: var(--c-cyan);
    border-color: var(--c-cyan);
    transform: translateY(-2px);
}

/* Light theme variants for .social-link live in the main light-theme block above */

/* Compact variant for footer */
.social-links.compact {
    gap: .5rem;
}
.social-links.compact .social-link { --sz: 40px; }
.social-links.compact .social-link svg { width: 18px; height: 18px; }

/* Mobile: enforce 44px touch target even in compact mode */
@media (max-width: 768px) {
    .social-links.compact .social-link { --sz: 44px; }
    .social-links.compact { gap: .65rem; }
}

/* =========================================================
   Cart (Inventario) — floating FAB + drawer
   ========================================================= */

.cp-cart-fab {
    position: fixed;
    top: 48px;
    right: 18px;
    z-index: 55;
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: 10px 14px 10px 12px;
    background: var(--c-bg-2);
    border: 1px solid var(--c-line-2);
    color: var(--c-fg);
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .18em;
    text-transform: uppercase;
    cursor: pointer;
    transition: border-color .2s, color .2s, transform .2s var(--ease);
    clip-path: polygon(8px 0, 100% 0, 100% calc(100% - 8px), calc(100% - 8px) 100%, 0 100%, 0 8px);
}

.cp-cart-fab:hover { border-color: var(--c-lime); color: var(--c-lime); }
.cp-cart-fab.cp-pulse { animation: cp-pulse .5s ease-out; }
@keyframes cp-pulse {
    0%   { transform: scale(1); box-shadow: 0 0 0 0 rgba(184, 255, 46, 0); }
    35%  { transform: scale(1.06); box-shadow: 0 0 16px 6px rgba(184, 255, 46, .35); }
    100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(184, 255, 46, 0); }
}

.cp-cart-fab-glyph { color: var(--c-lime); font-size: 14px; }
.cp-cart-fab-count {
    background: var(--c-lime);
    color: var(--c-bg);
    padding: 1px 7px;
    font-family: var(--f-mono);
    font-weight: 700;
    font-size: 10px;
    margin-left: .25rem;
}
.cp-cart-fab-count.cp-hide { display: none; }

@media (max-width: 768px) {
    .cp-cart-fab { top: auto; bottom: 18px; right: 12px; padding: 10px 12px; }
    .cp-cart-fab-label { display: none; }
}

/* Cart overlay + drawer */

.cp-cart-overlay {
    position: fixed;
    inset: 0;
    z-index: 80;
    background: rgba(5, 8, 17, .65);
    backdrop-filter: blur(4px);
    opacity: 0;
    transition: opacity .25s var(--ease);
    display: flex;
    justify-content: flex-end;
}

.cp-cart-overlay.is-open { opacity: 1; }
.cp-cart-overlay[hidden] { display: none; }

.cp-cart {
    width: min(420px, 92vw);
    height: 100%;
    background: var(--c-bg-2);
    border-left: 1px solid var(--c-line-2);
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform .3s var(--ease);
    overflow: hidden;
}

.cp-cart-overlay.is-open .cp-cart { transform: translateX(0); }

.cp-cart-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 1.25rem 1.5rem 1rem;
    border-bottom: 1px solid var(--c-line-2);
    position: relative;
}
/* Scan-line accent under the header */
.cp-cart-head::after {
    content: '';
    position: absolute;
    left: 1.5rem; right: 1.5rem; bottom: -1px;
    height: 2px;
    background: linear-gradient(90deg, var(--c-lime) 0, var(--c-lime) 32px, transparent 32px, transparent 36px, var(--c-cyan) 36px, var(--c-cyan) 56px, transparent 56px);
    pointer-events: none;
}
body[data-theme="light"] .cp-cart-head::after {
    background: linear-gradient(90deg, var(--c-fg) 0, var(--c-fg) 32px, transparent 32px, transparent 36px, var(--c-yellow) 36px, var(--c-yellow) 56px, transparent 56px);
}

.cp-cart-eyebrow {
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--c-muted);
    margin-bottom: .35rem;
}

.cp-cart-title {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 1.4rem;
    letter-spacing: .02em;
    text-transform: uppercase;
    margin: 0;
}

.cp-cart-x {
    background: var(--c-bg-3);
    border: 1px solid var(--c-line-2);
    color: var(--c-fg);
    width: 36px;
    height: 36px;
    cursor: pointer;
    font-family: var(--f-mono);
    font-size: 14px;
    line-height: 1;
    display: grid;
    place-items: center;
    clip-path: polygon(5px 0, 100% 0, 100% calc(100% - 5px), calc(100% - 5px) 100%, 0 100%, 0 5px);
    transition: background .2s, color .2s, transform .15s;
    flex-shrink: 0;
}
.cp-cart-x:hover {
    background: #FF4564;
    color: #0A0F1D;
    border-color: #FF4564;
    transform: translateY(-1px);
}
body[data-theme="light"] .cp-cart-x {
    background: #FFFFFF;
    box-shadow: 2px 2px 0 var(--c-fg);
}
body[data-theme="light"] .cp-cart-x:hover {
    background: var(--c-fg);
    color: var(--c-yellow);
    box-shadow: 3px 3px 0 var(--c-fg);
}

.cp-cart-body {
    flex: 1;
    overflow-y: auto;
    padding: 1rem 1.5rem;
}

.cp-cart-empty {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--c-muted);
    font-family: var(--f-mono);
}

.cp-cart-empty-glyph {
    font-size: 3rem;
    color: var(--c-line-2);
    margin-bottom: 1rem;
}

.cp-cart-empty-title {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 1.1rem;
    text-transform: uppercase;
    color: var(--c-fg);
    margin: 0 0 .5rem;
    letter-spacing: .02em;
}

.cp-cart-empty-sub {
    font-family: var(--f-body);
    font-size: 13px;
    line-height: 1.5;
    text-transform: none;
    letter-spacing: 0;
    color: var(--c-muted);
    margin: 0;
}

.cp-cart-item {
    display: grid;
    grid-template-columns: 38px 1fr auto auto 28px;
    gap: .75rem;
    align-items: center;
    padding: .85rem .75rem;
    margin: 0 -.75rem;
    border-bottom: 1px dashed var(--c-line);
    transition: background .2s;
}
.cp-cart-item:hover {
    background: rgba(184, 255, 46, .04);
}
body[data-theme="light"] .cp-cart-item:hover {
    background: var(--c-yellow);
}
body[data-theme="light"] .cp-cart-item:hover .cp-cart-item-price {
    color: var(--c-fg);
}

.cp-cart-item-glyph {
    width: 38px;
    height: 38px;
    background: var(--c-lime);
    color: var(--c-bg);
    display: grid;
    place-items: center;
    font-family: var(--f-mono);
    font-weight: 700;
    font-size: 11px;
    letter-spacing: .04em;
    clip-path: polygon(6px 0, 100% 0, 100% calc(100% - 6px), calc(100% - 6px) 100%, 0 100%, 0 6px);
}

.cp-cart-item-info { min-width: 0; }
.cp-cart-item-name {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 14px;
    color: var(--c-fg);
    line-height: 1.2;
    text-transform: uppercase;
    letter-spacing: .01em;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.cp-cart-item-meta {
    font-family: var(--f-mono);
    font-size: 9px;
    letter-spacing: .15em;
    color: var(--c-muted);
    text-transform: uppercase;
    margin-top: 2px;
}

.cp-cart-item-qty {
    display: flex;
    align-items: center;
    gap: .35rem;
    font-family: var(--f-mono);
    font-size: 12px;
    color: var(--c-fg);
}
.cp-qb {
    width: 28px;
    height: 28px;
    background: var(--c-bg-3);
    color: var(--c-fg);
    border: 1px solid var(--c-line-2);
    cursor: pointer;
    font-family: var(--f-mono);
    font-size: 14px;
    line-height: 1;
    display: grid;
    place-items: center;
    transition: background .15s, border-color .15s, color .15s, transform .1s;
}
.cp-qb:hover { border-color: var(--c-lime); color: var(--c-lime); background: rgba(184, 255, 46, .08); }
.cp-qb:active { transform: scale(.92); }
body[data-theme="light"] .cp-qb {
    background: #FFFFFF;
    border-color: var(--c-fg);
    color: var(--c-fg);
}
body[data-theme="light"] .cp-qb:hover {
    background: var(--c-yellow);
    color: var(--c-fg);
    border-color: var(--c-fg);
}
.cp-q { min-width: 22px; text-align: center; font-weight: 700; }

.cp-cart-item-price {
    font-family: var(--f-mono);
    font-size: 13px;
    color: var(--c-lime);
    font-weight: 700;
}

.cp-cart-item-rm {
    background: transparent;
    border: 0;
    color: var(--c-muted);
    cursor: pointer;
    transition: color .15s, background .15s, transform .1s;
    font-family: var(--f-mono);
    font-size: 14px;
    line-height: 1;
    width: 28px;
    height: 28px;
    display: grid;
    place-items: center;
    border-radius: 0;
}
.cp-cart-item-rm:hover { color: #FF4564; background: rgba(255, 69, 100, .1); }
.cp-cart-item-rm:active { transform: scale(.92); }

.cp-cart-foot {
    border-top: 1px solid var(--c-line-2);
    padding: 1.25rem 1.5rem 1.5rem;
    display: flex;
    flex-direction: column;
    gap: .85rem;
    position: relative;
    background: linear-gradient(180deg, transparent 0%, rgba(184, 255, 46, .03) 100%);
}
.cp-cart-foot::before {
    content: '';
    position: absolute;
    left: 1.5rem; right: 1.5rem; top: -1px;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--c-lime), transparent);
    pointer-events: none;
}
body[data-theme="light"] .cp-cart-foot {
    background: var(--c-yellow);
    border-top: 2px solid var(--c-fg);
}
body[data-theme="light"] .cp-cart-foot::before { display: none; }

.cp-cart-total {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
}
.cp-cart-total-k {
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .22em;
    color: var(--c-muted);
    text-transform: uppercase;
}
.cp-cart-total-v {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 1.75rem;
    color: var(--c-lime);
    letter-spacing: -.01em;
}
body[data-theme="light"] .cp-cart-total-k { color: var(--c-fg); }
body[data-theme="light"] .cp-cart-total-v { color: var(--c-fg); }

.cp-cart-cta { width: 100%; justify-content: center; }
.cp-cart-clear {
    background: none;
    border: 0;
    color: var(--c-muted);
    cursor: pointer;
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: .18em;
    text-transform: uppercase;
    padding: 6px 0;
    transition: color .2s;
}
.cp-cart-clear:hover { color: var(--c-red); }

/* Add-to-cart button on service cards */

.cp-add {
    background: transparent;
    border: 1px solid var(--c-line-2);
    color: var(--c-fg);
    padding: 6px 10px;
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: .22em;
    text-transform: uppercase;
    cursor: pointer;
    margin-left: .75rem;
    transition: border-color .2s, color .2s, background .2s;
}
.cp-add:hover {
    border-color: var(--c-lime);
    color: var(--c-lime);
}
.cp-add:active {
    background: var(--c-lime);
    color: var(--c-bg);
}

/* =========================================================
   Cookies banner (bottom)
   ========================================================= */

.cp-cookies {
    position: fixed;
    left: 0; right: 0; bottom: 0;
    z-index: 70;
    background: rgba(5, 8, 17, .96);
    backdrop-filter: blur(8px);
    border-top: 1px solid var(--c-lime);
    transform: translateY(100%);
    transition: transform .35s var(--ease);
    box-shadow: 0 -12px 40px rgba(0, 0, 0, .5);
}

.cp-cookies.is-open { transform: translateY(0); }

.cp-cookies-row {
    display: grid;
    grid-template-columns: 12px 1fr auto;
    gap: 1.25rem;
    align-items: center;
    max-width: 1320px;
    margin: 0 auto;
    padding: 1rem 1.5rem;
}

.cp-cookies-dot {
    width: 8px;
    height: 8px;
    background: var(--c-lime);
    border-radius: 50%;
    box-shadow: 0 0 8px var(--c-lime);
    animation: pulse 1.6s ease-in-out infinite;
}

.cp-cookies-text {
    color: var(--c-fg);
    font-size: 13.5px;
    line-height: 1.45;
}
.cp-cookies-text strong {
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: .25em;
    text-transform: uppercase;
    color: var(--c-lime);
    display: block;
    margin-bottom: .15rem;
}
.cp-cookies-text p { margin: 0; color: rgba(234, 240, 255, .7); }

.cp-cookies-actions {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
}

.cp-cookies-btn {
    padding: 9px 14px;
    background: transparent;
    border: 1px solid var(--c-line-2);
    color: var(--c-fg);
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .18em;
    text-transform: uppercase;
    cursor: pointer;
    transition: border-color .2s, color .2s, background .2s;
}
.cp-cookies-btn:hover { border-color: var(--c-lime); color: var(--c-lime); }
.cp-cookies-btn.solid {
    background: var(--c-lime);
    color: var(--c-bg);
    border-color: var(--c-lime);
}
.cp-cookies-btn.solid:hover {
    background: var(--c-fg);
    border-color: var(--c-fg);
    color: var(--c-bg);
}

@media (max-width: 760px) {
    .cp-cookies-row {
        grid-template-columns: 1fr;
        gap: .75rem;
    }
    .cp-cookies-dot { display: none; }
    .cp-cookies-actions { justify-content: stretch; }
    .cp-cookies-btn { flex: 1; }
}

/* Cookie floater (settings re-open) */

.cp-cookie-fab {
    position: fixed;
    left: 18px;
    bottom: 18px;
    z-index: 55;
    width: 38px;
    height: 38px;
    background: var(--c-bg-2);
    border: 1px solid var(--c-line-2);
    color: var(--c-fg);
    cursor: pointer;
    font-size: 14px;
    display: grid;
    place-items: center;
    transition: border-color .2s, color .2s, transform .2s var(--ease);
    clip-path: polygon(6px 0, 100% 0, 100% calc(100% - 6px), calc(100% - 6px) 100%, 0 100%, 0 6px);
}
.cp-cookie-fab:hover { border-color: var(--c-cyan); color: var(--c-cyan); transform: rotate(45deg); }

@media (max-width: 768px) { .cp-cookie-fab { display: none; } }

/* Cookies dialog (config) */

.cp-cookies-dialog-overlay {
    position: fixed;
    inset: 0;
    z-index: 90;
    background: rgba(5, 8, 17, .75);
    backdrop-filter: blur(6px);
    opacity: 0;
    transition: opacity .25s var(--ease);
    display: grid;
    place-items: center;
    padding: 1rem;
}

.cp-cookies-dialog-overlay.is-open { opacity: 1; }
.cp-cookies-dialog-overlay[hidden] { display: none; }

.cp-cookies-dialog {
    width: min(620px, 100%);
    max-height: 88vh;
    overflow-y: auto;
    background: var(--c-bg-2);
    border: 1px solid var(--c-line-2);
    padding: 1.75rem;
    transform: scale(.95);
    transition: transform .3s var(--ease);
}

.cp-cookies-dialog-overlay.is-open .cp-cookies-dialog { transform: scale(1); }

.cp-cookies-dialog-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1rem;
}
.cp-cookies-eyebrow {
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--c-muted);
    margin-bottom: .35rem;
}
.cp-cookies-dialog h3 {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 1.4rem;
    text-transform: uppercase;
    letter-spacing: .02em;
    margin: 0;
}

.cp-cookies-dialog-lead {
    color: rgba(234, 240, 255, .8);
    font-size: 13.5px;
    margin: 0 0 1.5rem;
    line-height: 1.5;
}

/* Theme switcher block (inside settings dialog) */
.cp-theme-block {
    margin-bottom: 1.25rem;
    padding-bottom: 1.25rem;
    border-bottom: 1px dashed var(--c-line-2);
}

.cp-theme-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 1rem;
    align-items: center;
    padding: 1rem;
    border: 1px solid var(--c-line);
    background: rgba(184, 255, 46, .04);
}

.cp-theme-row p {
    margin: 0;
    color: rgba(234, 240, 255, .65);
    font-size: 12.5px;
    line-height: 1.4;
}

.cp-theme-switch {
    display: inline-flex;
    border: 1px solid var(--c-line-2);
    overflow: hidden;
}

.cp-theme-btn {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: 8px 14px;
    background: transparent;
    color: rgba(234, 240, 255, .65);
    border: 0;
    border-right: 1px solid var(--c-line-2);
    cursor: pointer;
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .14em;
    text-transform: uppercase;
    transition: background .2s var(--ease), color .2s var(--ease);
    min-height: 36px;
}

.cp-theme-btn:last-child { border-right: 0; }
.cp-theme-btn:hover { color: var(--c-fg); background: rgba(184, 255, 46, .08); }

.cp-theme-btn.is-active {
    background: var(--c-lime);
    color: var(--c-bg);
    font-weight: 700;
}

.cp-theme-glyph {
    font-size: 14px;
    line-height: 1;
}

/* Section header inside dialog */
.cp-cookies-section-head {
    display: flex;
    align-items: center;
    gap: .5rem;
    margin-bottom: .75rem;
    padding-top: .25rem;
}
.cp-cookies-section-head .cp-cookies-eyebrow {
    margin: 0;
    color: var(--c-lime);
}
.cp-cookies-section-head::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--c-line);
}

.cp-cookies-cat {
    display: flex;
    flex-direction: column;
    gap: .5rem;
    margin-bottom: 1.5rem;
}

.cp-cookies-cat-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 1rem;
    align-items: center;
    padding: 1rem;
    border: 1px solid var(--c-line);
    cursor: pointer;
    transition: border-color .2s, background .2s;
}
.cp-cookies-cat-row:hover { border-color: var(--c-lime); background: rgba(184, 255, 46, .03); }
.cp-cookies-cat-row[data-disabled] { cursor: default; opacity: .85; }
.cp-cookies-cat-row[data-disabled]:hover { border-color: var(--c-line); background: transparent; }

.cp-cookies-cat-name {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: .02em;
    color: var(--c-fg);
    margin-bottom: .15rem;
}
.cp-cookies-cat-row p {
    margin: 0;
    color: var(--c-muted);
    font-size: 12.5px;
    line-height: 1.4;
}

.cp-tog-input { position: absolute; opacity: 0; pointer-events: none; }
.cp-tog {
    width: 40px;
    height: 22px;
    background: var(--c-bg-3);
    border: 1px solid var(--c-line-2);
    position: relative;
    flex-shrink: 0;
    transition: background .2s, border-color .2s;
}
.cp-tog::before {
    content: '';
    position: absolute;
    top: 2px; left: 2px;
    width: 14px; height: 14px;
    background: var(--c-muted);
    transition: transform .25s var(--ease), background .25s var(--ease);
}
.cp-tog.is-on {
    background: var(--c-lime);
    border-color: var(--c-lime);
}
.cp-tog.is-on::before {
    transform: translateX(18px);
    background: var(--c-bg);
}
/* Locked toggle — "always on" state, visually distinct from active/inactive */
.cp-tog.locked {
    background: rgba(184, 255, 46, .25);
    border-color: var(--c-lime);
    cursor: not-allowed;
}
.cp-tog.locked::before {
    background: var(--c-lime);
    transform: translateX(18px);
}
.cp-tog.is-on.locked { background: rgba(184, 255, 46, .25); }

.cp-cookies-dialog-foot {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

@media (max-width: 600px) {
    .cp-cookies-dialog-foot { flex-direction: column; }
    .cp-cookies-dialog-foot .cp-cookies-btn { width: 100%; }
}

/* =========================================================
   Reduced motion
   ========================================================= */

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .01ms !important;
    }
    .marquee-track { animation: none; }
}

/* =========================================================
   Business — Capacidades enterprise + Stack categorías
   ========================================================= */

.capability-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
}
@media (max-width: 900px) {
    .capability-grid { grid-template-columns: 1fr; }
}

.capability {
    position: relative;
    background: var(--c-bg-2);
    border: 1px solid var(--c-line);
    padding: 1.75rem 1.75rem 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    transition: border-color .2s var(--ease), transform .2s var(--ease);
}
.capability:hover {
    border-color: var(--c-lime);
    transform: translate3d(0, -2px, 0);
}
.capability::before {
    content: '';
    position: absolute;
    top: 0; right: 0;
    width: 24px; height: 24px;
    background: linear-gradient(135deg, transparent 50%, var(--c-line-2) 50%);
}
.capability:hover::before {
    background: linear-gradient(135deg, transparent 50%, var(--c-lime) 50%);
}

.capability-head {
    display: flex;
    align-items: center;
    gap: 1rem;
}
.capability-num {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 2.25rem;
    line-height: 1;
    color: var(--c-lime);
    background: var(--c-bg-3);
    padding: .65rem .85rem;
    border: 1px solid var(--c-line-2);
    clip-path: polygon(6px 0, 100% 0, 100% calc(100% - 6px), calc(100% - 6px) 100%, 0 100%, 0 6px);
    flex-shrink: 0;
}
.capability-tag {
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--c-lime);
    margin-bottom: 4px;
}
.capability h3 {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: clamp(1.25rem, 2vw, 1.6rem);
    text-transform: uppercase;
    line-height: 1.1;
    margin: 0;
    color: var(--c-fg);
    letter-spacing: -.005em;
}

.capability-lead {
    color: rgba(234, 240, 255, .78);
    margin: 0;
    font-size: 15px;
    line-height: 1.6;
}

.capability-list {
    list-style: none;
    padding: 0;
    margin: 0;
    border-top: 1px dashed var(--c-line-2);
    padding-top: 1rem;
}
.capability-list li {
    position: relative;
    padding: .5rem 0 .5rem 1.4rem;
    font-size: 14px;
    line-height: 1.6;
    color: rgba(234, 240, 255, .8);
    border-bottom: 1px dashed var(--c-line);
}
.capability-list li:last-child { border-bottom: 0; }
.capability-list li::before {
    content: '›';
    position: absolute;
    left: 0;
    top: .5rem;
    color: var(--c-lime);
    font-family: var(--f-mono);
    font-weight: 700;
}
.capability-list li strong {
    color: var(--c-fg);
    font-weight: 700;
}

/* Light theme — neo-brutalist */
body[data-theme="light"] .capability {
    background: #FFFFFF;
    border: 1px solid var(--c-fg);
    box-shadow: 4px 4px 0 var(--c-fg);
}
body[data-theme="light"] .capability:hover {
    box-shadow: 6px 6px 0 var(--c-fg);
    border-color: var(--c-fg);
}
body[data-theme="light"] .capability::before {
    background: linear-gradient(135deg, transparent 50%, var(--c-fg) 50%);
}
body[data-theme="light"] .capability-num {
    background: var(--c-yellow);
    color: var(--c-fg);
    border-color: var(--c-fg);
}
body[data-theme="light"] .capability-tag { color: var(--c-fg); }
body[data-theme="light"] .capability-lead { color: #1A1A1A; }
body[data-theme="light"] .capability-list { border-top-color: var(--c-fg); }
body[data-theme="light"] .capability-list li {
    color: #1A1A1A;
    border-bottom-color: rgba(10, 10, 10, .15);
}
body[data-theme="light"] .capability-list li::before { color: var(--c-fg); }

/* Stack categories — grouped tech chips */
.stack-categories {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}
.stack-cat {
    border: 1px solid var(--c-line);
    background: var(--c-bg-2);
    padding: 1.25rem 1.5rem;
}
.stack-cat-head { margin-bottom: 1rem; }
.stack-cat-tag {
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--c-lime);
    font-weight: 700;
}
body[data-theme="light"] .stack-cat {
    background: #FFFFFF;
    border: 1px solid var(--c-fg);
    box-shadow: 3px 3px 0 var(--c-fg);
}
body[data-theme="light"] .stack-cat-tag { color: var(--c-fg); }
