/* ============================================
   TERRABOT CLOUD — LANDING PAGE STYLES
   Editorial / Bento redesign
   ============================================ */

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

/* ===== DESIGN TOKENS ===== */
:root {
    --primary:      #2563eb;
    --primary-dim:  rgba(37,99,235,0.08);
    --primary-mid:  rgba(37,99,235,0.18);
    --primary-l:    rgba(37,99,235,0.10);
    --primary-m:    rgba(37,99,235,0.20);
    --accent:       #0891b2;
    --accent-dim:   rgba(8,145,178,0.08);
    --accent-l:     rgba(8,145,178,0.10);
    --accent-m:     rgba(8,145,178,0.20);
    --gold:         #d97706;
    --gold-dim:     rgba(217,119,6,0.1);
    --purple:       #7c3aed;
    --purple-dim:   rgba(124,58,237,0.08);
    --danger:       #dc2626;
    --warn:         #c94f1e;
    --success:      #16a34a;

    --bg:           #f8fafc;
    --bg2:          #f1f5f9;
    --surface-0:    #ffffff;
    --surface-1:    #f1f5f9;
    --surface-2:    #e2e8f0;

    --text-1:       #0f172a;
    --text-2:       #334155;
    --text-3:       #64748b;
    --text-d:       rgba(15,23,42,0.3);

    --border:       rgba(0,0,0,0.08);
    --border-mid:   rgba(0,0,0,0.14);
    --border-h:     rgba(0,0,0,0.22);

    --shadow-lifted: 0 8px 32px rgba(0,0,0,0.10);
    --shadow-strong: 0 16px 48px rgba(0,0,0,0.14);

    --radius-sm:  6px;
    --radius:     10px;
    --radius-lg:  16px;

    --navbar-bg:       rgba(248,250,252,0);
    --navbar-scrolled: rgba(248,250,252,0.92);

    --mono: 'JetBrains Mono', monospace;
    --sans: 'Syne', 'Outfit', system-ui, sans-serif;
    --body: 'Plus Jakarta Sans', 'Inter', system-ui, sans-serif;

    /* legacy compat */
    --text: #0f172a;
    --dim:  #64748b;
    --surface: rgba(255,255,255,0.97);
    --glass: rgba(0,0,0,0.025);
    --card-shadow: 0 8px 32px rgba(0,0,0,0.10);
    --table-border: rgba(0,0,0,0.05);
    --row-hover: rgba(37,99,235,0.04);
    --input-bg: rgba(0,0,0,0.04);
}

[data-theme="dark"] {
    --primary:      #3b82f6;
    --primary-dim:  rgba(59,130,246,0.12);
    --primary-mid:  rgba(59,130,246,0.22);
    --primary-l:    rgba(59,130,246,0.10);
    --primary-m:    rgba(59,130,246,0.20);
    --accent:       #06b6d4;
    --accent-dim:   rgba(6,182,212,0.12);
    --accent-l:     rgba(6,182,212,0.10);
    --accent-m:     rgba(6,182,212,0.20);
    --gold:         #f59e0b;
    --gold-dim:     rgba(245,158,11,0.12);
    --purple:       #8b5cf6;
    --purple-dim:   rgba(139,92,246,0.12);
    --danger:       #ef4444;
    --warn:         #f97316;
    --success:      #22c55e;

    --bg:           #0b1120;
    --bg2:          #111827;
    --surface-0:    #111827;
    --surface-1:    #1e293b;
    --surface-2:    #263344;

    --text-1:       #f1f5f9;
    --text-2:       #cbd5e1;
    --text-3:       #64748b;
    --text-d:       rgba(241,245,249,0.3);

    --border:       rgba(255,255,255,0.07);
    --border-mid:   rgba(255,255,255,0.12);
    --border-h:     rgba(255,255,255,0.22);

    --shadow-lifted: 0 8px 32px rgba(0,0,0,0.4);
    --shadow-strong: 0 16px 48px rgba(0,0,0,0.55);

    --navbar-bg:       rgba(11,17,32,0);
    --navbar-scrolled: rgba(11,17,32,0.92);

    /* legacy compat */
    --text: #f1f5f9;
    --dim:  #64748b;
    --surface: rgba(30,41,59,0.85);
    --glass: rgba(255,255,255,0.04);
    --table-border: rgba(255,255,255,0.04);
    --row-hover: rgba(59,130,246,0.03);
    --input-bg: rgba(0,0,0,0.3);
}

/* ===== BASE ===== */
html { scroll-behavior: smooth; overflow-x: hidden; }
body {
    background: var(--bg);
    color: var(--text-1);
    font-family: var(--body);
    font-size: clamp(15px, 1.6vw, 17px);
    line-height: 1.7;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
body.menu-open {
    overflow: hidden;
    position: fixed;
    width: 100%;
}
@keyframes pageIn { from { opacity:0; } to { opacity:1; } }
/* Page fade-in applied to content wrapper, not body (body transform breaks position:fixed) */
#page-wrap { opacity: 0; }
.page-fadein { animation: pageIn 0.35s ease both; }
h1,h2,h3,h4 {
    font-family: var(--sans);
    letter-spacing: -0.03em;
    color: var(--text-1);
    line-height: 1.25;
}
h1 { line-height: 1.15; }
h2 { line-height: 1.25; }
h3 { line-height: 1.3; }
h4 { line-height: 1.35; }

/* Vertical stretch for heading text */
.stretch {
    display: inline-block;
    transform: scaleY(1.18);
    transform-origin: bottom;
}

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--border-mid); border-radius: 3px; }

/* ===== KEYFRAME ANIMATIONS ===== */
@keyframes pulse-dot { 0%,100%{box-shadow:0 0 0 0 rgba(37,99,235,0.5)} 50%{box-shadow:0 0 0 7px rgba(37,99,235,0)} }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }
@keyframes bar-grow { from{transform:scaleX(0)} to{transform:scaleX(1)} }
@keyframes fade-up { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:none} }
@keyframes statusPulse {
    0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(22,163,74,.4);}
    50%{opacity:.8;box-shadow:0 0 0 5px rgba(22,163,74,0);}
}
@keyframes pulse { 0%,100%{opacity:1;}50%{opacity:.4;} }
@keyframes termIn { to { opacity:1; transform:none; } }
@keyframes skPulse { 0%,100%{opacity:.3;transform:scale(.92);}50%{opacity:1;transform:scale(1);} }
@keyframes skSlide { 0%{transform:translateX(-120%);}100%{transform:translateX(400%);} }
@keyframes heroIn { to { opacity:1; transform:none; } }
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
@keyframes shimmer { 0%{background-position:-200% 0} 100%{background-position:200% 0} }
@keyframes countUp { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:none} }
@keyframes gridPulse { 0%,100%{opacity:.5} 50%{opacity:.8} }
@keyframes slideInLeft { from{opacity:0;transform:translateX(-30px)} to{opacity:1;transform:none} }
@keyframes slideInRight { from{opacity:0;transform:translateX(30px)} to{opacity:1;transform:none} }
@keyframes scaleIn { from{opacity:0;transform:scale(0.9)} to{opacity:1;transform:scale(1)} }
@keyframes borderGlow { 0%,100%{border-color:var(--primary-mid);box-shadow:0 0 0 0 rgba(37,99,235,0)} 50%{border-color:var(--primary);box-shadow:0 0 20px rgba(37,99,235,0.12)} }

/* ===== SKELETON LOADER ===== */
#skeleton-loader {
    position:fixed; inset:0; z-index:9999;
    background: var(--bg);
    display:flex; align-items:center; justify-content:center;
    transition: opacity 0.35s ease;
}
.sk-inner { text-align:center; }
.sk-logo img { width:48px; height:48px; object-fit:contain; animation:skPulse 1.5s ease-in-out infinite; }
.sk-text { font-family:var(--mono); font-size:12px; font-weight:600; color:var(--text-3); letter-spacing:.2em; text-transform:uppercase; margin:16px 0 20px; }
.sk-bar { width:140px; height:2px; background:var(--border); border-radius:2px; overflow:hidden; margin:0 auto; }
.sk-bar-fill { width:45%; height:100%; background:var(--primary); border-radius:2px; animation:skSlide 1.1s ease-in-out infinite; }

/* ===== NAVBAR ===== */
.navbar {
    position:fixed; top:0; left:0; right:0; z-index:100;
    display:flex; align-items:center; justify-content:space-between;
    padding:16px 48px;
    background: var(--navbar-bg);
    border-bottom: 1px solid transparent;
    transform: translateY(0);
    transition: background .35s ease, border-color .35s ease, padding .3s ease, transform .4s cubic-bezier(.4,0,.2,1);
}
.navbar.scrolled {
    background: var(--navbar-scrolled);
    border-color: var(--border);
    padding:14px 48px;
    backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
    box-shadow: 0 1px 0 var(--border);
}
.navbar.nav-hidden { transform:translateY(-100%) !important; }
body.menu-open .navbar { transform:translateY(0) !important; }
.nav-brand { display:flex; align-items:center; gap:10px; text-decoration:none; cursor:pointer; flex-shrink:0; }
.nav-brand img { width:28px; height:28px; object-fit:contain; }
.nav-brand-text { display:flex; flex-direction:column; line-height:1.1; }
.nav-brand-title {
    font-family: var(--mono); font-size:15px; font-weight:700; color:var(--text-1);
    letter-spacing:-0.5px; display:flex; align-items:center; gap:8px;
}
.nav-brand-dot {
    width:7px; height:7px; border-radius:50%; background:var(--primary);
    animation: pulse-dot 2s ease-in-out infinite; flex-shrink:0;
}
.nav-brand-title .brand-accent { color: var(--primary); }
.nav-brand-sub { font-family:var(--mono); font-size:9px; font-weight:500; color:var(--text-3); letter-spacing:.06em; }
.nav-links { display:flex; gap:8px; align-items:center; }
.nav-links a {
    font-family: var(--mono); font-size:11px; font-weight:500;
    letter-spacing:0.5px; text-transform:uppercase;
    color:var(--text-3); text-decoration:none;
    padding:6px 10px; transition: color .2s;
}
.nav-links a:hover { color:var(--primary); }
.btn-login,
.nav-links .btn-login,
.nav-links a.btn-login {
    font-family:var(--mono); font-size:11px; font-weight:700; letter-spacing:0.5px;
    padding:10px 22px; text-decoration:none;
    background:var(--primary); color:#ffffff !important;
    border:none; cursor:pointer; transition:box-shadow .2s, background .2s; margin-left:8px;
}
.btn-login:hover,
.nav-links .btn-login:hover,
.nav-links a.btn-login:hover { box-shadow:0 4px 24px rgba(37,99,235,0.35); background:#1d4ed8; color:#ffffff !important; }
.nav-hamburger {
    display:none; flex-direction:column; justify-content:center; align-items:center;
    gap:5px; width:40px; height:40px;
    background:none; border:none; cursor:pointer; padding:4px;
    transition:background .2s;
}
.nav-hamburger:hover { background:var(--surface-1); }
.nav-hamburger span {
    display:block; width:22px; height:2px;
    background:var(--text-2); border-radius:2px;
    transition:transform .25s ease, opacity .2s ease;
}
.nav-hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity:0; }
.nav-hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
.nav-mobile-menu {
    position:fixed; top:0; left:0; right:0; z-index:99;
    background:var(--surface-0); border-bottom:1px solid var(--border);
    padding:80px 24px 28px;
    display:flex; flex-direction:column; gap:4px;
    transform:translateY(-110%);
    transition:transform .3s cubic-bezier(.4,0,.2,1);
    backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
}
.nav-mobile-menu.open { transform:translateY(0); }

/* Backdrop that blurs main content behind the open menu */
#menu-backdrop {
    display:none;
    position:fixed; inset:0; z-index:98;
    background:rgba(0,0,0,0.3);
    backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px);
    opacity:0; transition:opacity .3s ease;
}
#menu-backdrop.open { display:block; opacity:1; }
.nav-mobile-menu a {
    display:block; padding:12px 16px; font-size:16px; font-weight:500;
    color:var(--text-2); text-decoration:none; transition:color .2s, background .2s;
}
.nav-mobile-menu a:hover { color:var(--text-1); background:var(--surface-1); }
.nav-mobile-menu .mobile-login {
    margin-top:12px; padding:13px 16px; text-align:center;
    font-size:15px; font-weight:600; color:#fff; background:var(--primary);
    font-family:var(--mono);
}
.nav-mobile-menu .mobile-login:hover { opacity:0.9; }
.nav-mobile-menu .mobile-theme-toggle {
    display:flex; align-items:center; justify-content: center; gap:12px; padding:12px 16px;
    font-size:14px; color:var(--text-3); background:none; border:none;
    cursor:pointer; font-family:var(--body); font-weight:500;
    width:100%; text-align:left; transition:background .2s;
}
.nav-mobile-menu .mobile-theme-toggle:hover { background:var(--surface-1); color:var(--text-1); }
.theme-toggle {
    display:flex; align-items:center; justify-content:center;
    width:36px; height:36px;
    background:transparent; border:1px solid var(--border);
    cursor:pointer; color:var(--text-3); transition:all .2s; flex-shrink:0; margin-left:4px;
}
.theme-toggle:hover { border-color:var(--primary); color:var(--primary); background:var(--primary-dim); }

/* ===== HERO ===== */
.hero {
    position:relative; min-height:auto;
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    padding:clamp(140px, 16vw, 200px) 48px clamp(80px, 8vw, 100px);
    text-align:center; overflow:hidden;
}
.hero-grid {
    position:absolute; inset:0; pointer-events:none; z-index:0;
    background-image:
        linear-gradient(var(--border) 1px, transparent 1px),
        linear-gradient(90deg, var(--border) 1px, transparent 1px);
    background-size:40px 40px;
    mask-image:radial-gradient(ellipse 80% 60% at 50% 40%, black 10%, transparent 75%);
    opacity:.6;
    animation:gridPulse 6s ease-in-out infinite;
}
.hero-content { position:relative; z-index:2; max-width:1200px; width:100%; }

/* Hero eyebrow tag */
.hero-eyebrow {
    display:inline-flex; align-items:center; gap:8px;
    font-family:var(--mono); font-size:10px; font-weight:600;
    letter-spacing:2px; text-transform:uppercase;
    color:var(--primary); padding:6px 14px;
    border:1px solid var(--primary-mid);
    background:var(--primary-l);
    margin-bottom:28px;
    animation: fade-up 0.6s ease forwards, borderGlow 3s ease-in-out 2s infinite;
}
.hero-eyebrow .dot {
    width:5px; height:5px; border-radius:50%; background:var(--primary);
    animation:blink 1.2s step-end infinite;
}

/* Hero headline */
.hero h1 {
    font-family:var(--sans); font-size:clamp(42px,6vw,82px); font-weight:800;
    letter-spacing:-2px; line-height:1.18; margin-bottom:24px;
    animation:fade-up 0.7s ease 0.1s both;
}
.hero-headline-accent {
    display:block; font-style:normal; color:var(--primary);
}
.hero-headline-accent::after { display:none; }
.hero p {
    font-family:var(--body); font-size:16px; color:var(--text-2);
    line-height:1.7; max-width:620px; margin:0 auto 44px;
    animation:fade-up 0.7s ease 0.2s both;
}

/* Hero status card — hidden, replaced by eyebrow */
.hero-status-card { display:none; }

/* Hero buttons */
.hero-buttons {
    display:flex; gap:14px; justify-content:center; margin-bottom:64px;
    animation:fade-up 0.7s ease 0.3s both;
}

/* ===== BUTTONS ===== */
.btn-primary {
    display:inline-flex; align-items:center; gap:8px;
    font-family:var(--mono); font-size:12px; font-weight:700; letter-spacing:0.5px;
    text-transform:uppercase;
    padding:14px 32px; background:var(--primary); color:#fff;
    text-decoration:none; border:none; cursor:pointer;
    position:relative; overflow:hidden;
    transition: box-shadow 0.3s;
}
.btn-primary:hover { box-shadow:0 6px 28px rgba(37,99,235,0.4); }
.btn-primary:active { transform:scale(.97); }
.btn-primary::after { display:none; }
.btn-outline {
    display:inline-flex; align-items:center; gap:8px;
    font-family:var(--mono); font-size:12px; font-weight:500; letter-spacing:0.5px;
    text-transform:uppercase;
    padding:14px 24px; background:transparent; color:var(--text-3);
    border:1px solid var(--border); text-decoration:none; cursor:pointer;
    transition:all .2s;
}
.btn-outline:hover { border-color:var(--border-h); color:var(--text-1); }
.btn-outline:active { transform:scale(.97); }

/* ===== COMPARISON TABLE ===== */
.compare-wrap {
    display:grid; grid-template-columns:1fr 1fr; gap:2px;
    max-width:840px; width:100%; margin:0 auto;
    border:1px solid var(--border-mid);
    background:var(--border-mid); position:relative;
    animation:fade-up 0.7s ease 0.4s both;
}
.compare-vs {
    font-family:var(--mono); font-size:10px; font-weight:700;
    letter-spacing:2px; color:var(--text-3);
    background:var(--surface-0); padding:6px 10px;
    position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); z-index:2;
}
.compare-col { background:var(--surface-0); padding:32px 28px; }
.compare-col.bad { border-top:2px solid var(--warn); }
.compare-col.good { border-top:2px solid var(--primary); }
.compare-col-title {
    font-family:var(--mono); font-size:12px; font-weight:700;
    letter-spacing:1.5px; text-transform:uppercase; margin-bottom:16px;
}
.compare-col.bad .compare-col-title { color:var(--warn); }
.compare-col.good .compare-col-title { color:var(--primary); }
[data-theme="dark"] .compare-col.bad .compare-col-title { color:#fb923c; }
[data-theme="dark"] .compare-col.good .compare-col-title { color:#93bbfd; }
.compare-item {
    font-family:var(--body); font-size:14px; color:var(--text-1);
    line-height:1.6; margin-bottom:10px; display:flex; gap:10px;
}
.compare-item .ci-marker { flex-shrink:0; font-weight:700; }
.compare-col.bad .ci-marker { color:var(--warn); }
.compare-col.good .ci-marker { color:var(--primary); }
[data-theme="dark"] .compare-col.bad .ci-marker { color:#fb923c; }
[data-theme="dark"] .compare-col.good .ci-marker { color:#60a5fa; }

/* ===== STATS BAR ===== */
.stats-bar {
    border-top:2px solid var(--primary-mid); border-bottom:1px solid var(--border);
    background:var(--bg2); padding:44px 48px;
    display:flex; justify-content:center; align-items:center;
    flex-wrap:wrap; gap:32px;
}
.stats-bar.visible .stats-bar-value {
    animation:countUp 0.6s ease both;
}
.stats-bar.visible .stats-bar-item:nth-child(1) .stats-bar-value { animation-delay:0s; }
.stats-bar.visible .stats-bar-item:nth-child(3) .stats-bar-value { animation-delay:0.15s; }
.stats-bar.visible .stats-bar-item:nth-child(5) .stats-bar-value { animation-delay:0.3s; }
.stats-bar.visible .stats-bar-item:nth-child(7) .stats-bar-value { animation-delay:0.45s; }
.stats-bar-item {
    display:flex; align-items:center; gap:24px;
}
.stats-bar-inner { text-align:center; padding:12px 20px; }
.stats-bar-value {
    font-family:var(--mono); font-size:clamp(32px,4.5vw,48px);
    font-weight:700; color:var(--primary); letter-spacing:-1.5px; line-height:1;
}
.stats-bar-label {
    font-family:var(--body); font-size:12px; font-weight:600;
    letter-spacing:1px; text-transform:uppercase;
    color:var(--text-2); margin-top:8px;
}
.stats-bar-divider {
    width:1px; height:44px; background:var(--border);
}

/* ===== SECTION HELPERS ===== */
section { padding:96px 48px; position:relative; z-index:1; max-width:100vw; overflow-x:hidden; }
.inner { max-width:1200px; margin:0 auto; }
.section-head {
    display:flex; justify-content:space-between; align-items:flex-end;
    margin-bottom:48px; flex-wrap:wrap; gap:16px;
}
.section-tag {
    font-family:var(--mono); font-size:11px; font-weight:700;
    letter-spacing:2.5px; text-transform:uppercase;
    color:var(--primary); margin-bottom:10px;
}
[data-theme="dark"] .section-tag { color:#93bbfd; }
.section-heading {
    font-family:var(--sans); font-size:clamp(26px,3vw,40px);
    font-weight:800; letter-spacing:-1px; line-height:1.3;
    display:inline-block; transform:scaleY(1.18); transform-origin:bottom;
}
.section-note {
    font-family:var(--body); font-size:14px; color:var(--text-2);
    max-width:280px; text-align:right; line-height:1.7;
}
/* Legacy section label */
.section-label {
    font-family:var(--mono); font-size:10px; font-weight:600;
    letter-spacing:2.5px; text-transform:uppercase;
    color:var(--primary); margin-bottom:10px;
}
.section-sub {
    font-size:clamp(15px,1.5vw,17px); color:var(--text-2);
    max-width:560px; line-height:1.7; font-family:var(--body);
    margin:0 auto;
}

/* ===== TAG BADGE ===== */
.tag {
    font-family:var(--mono); font-size:10px; font-weight:600;
    letter-spacing:2px; text-transform:uppercase;
    padding:4px 12px; display:inline-block;
    border:1px solid var(--primary); color:var(--primary);
    background:var(--primary-l);
}
.tag.accent { border-color:var(--accent); color:var(--accent); background:var(--accent-l); }
.tag.gold { border-color:var(--gold); color:var(--gold); background:var(--gold-dim); }
[data-theme="dark"] .tag { color:#93bbfd; border-color:rgba(59,130,246,0.4); background:rgba(59,130,246,0.15); }
[data-theme="dark"] .tag.accent { color:#67e8f9; border-color:rgba(6,182,212,0.4); background:rgba(6,182,212,0.15); }
[data-theme="dark"] .tag.gold { color:#fcd34d; border-color:rgba(245,158,11,0.4); background:rgba(245,158,11,0.15); }

/* ===== HOW IT WORKS ===== */
#how { background:var(--surface-1); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.steps-header { margin-bottom:56px; text-align:center; }
.steps-row {
    display:grid; grid-template-columns:repeat(3,1fr); gap:3px;
}
.step {
    padding:36px 32px; position:relative; z-index:1;
    background:var(--surface-0); border:1px solid var(--border);
    overflow:hidden;
    transition:transform 0.3s, border-color 0.3s, box-shadow 0.3s;
}
.step::after {
    content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
    background:linear-gradient(90deg,var(--primary),var(--accent));
    transform:scaleX(0); transform-origin:left;
    transition:transform 0.4s ease;
}
.step:hover::after { transform:scaleX(1); }
.step:hover {
    transform:translateY(-4px); border-color:var(--primary-mid);
    box-shadow:0 8px 24px rgba(37,99,235,0.08);
}
.step-number {
    font-family:var(--sans); font-size:clamp(52px,7vw,80px);
    font-weight:200; letter-spacing:-.05em; line-height:1;
    color:var(--border-mid); margin-bottom:18px; transition:color .3s;
}
.step:hover .step-number { color:var(--primary); }
.step-title { font-family:var(--sans); font-size:20px; font-weight:700; margin-bottom:10px; color:var(--text-1); line-height:1.35; display:inline-block; transform:scaleY(1.15); transform-origin:bottom; }
.step-desc { font-family:var(--body); font-size:14px; color:var(--text-2); line-height:1.7; }

/* ===== BENTO FEATURES ===== */
#features { background:var(--bg); }
.bento-grid {
    display:grid; grid-template-columns:repeat(12,1fr); gap:3px;
}
.bento-card {
    background:var(--surface-0); border:1px solid var(--border);
    padding:28px; position:relative; overflow:hidden;
    transition:border-color 0.3s, box-shadow 0.3s, transform 0.3s;
}
.bento-card:hover {
    border-color:var(--primary-mid);
    box-shadow:0 0 28px rgba(37,99,235,0.08);
    transform:translateY(-3px);
}
.bento-card:hover .bento-glow {
    opacity:1;
}
.bento-glow {
    position:absolute; inset:0;
    background:linear-gradient(135deg,rgba(37,99,235,0.04),transparent);
    pointer-events:none; opacity:0; transition:opacity 0.3s;
}
.bento-card .tag { margin-bottom:14px; }
.bento-icon {
    margin-bottom:10px;
    color: var(--primary);
    display: flex;
    align-items: center;
}
.bento-icon svg {
    flex-shrink: 0;
}
.bento-title {
    font-family:var(--sans); font-size:17px; font-weight:700;
    letter-spacing:-0.3px; margin-bottom:8px; color:var(--text-1);
    line-height:1.35;
    display:inline-block; transform:scaleY(1.15); transform-origin:bottom;
}
.bento-title.lg { font-size:19px; }
.bento-desc {
    font-family:var(--body); font-size:13px; color:var(--text-2); line-height:1.7;
}

/* Battle probability panel */
.battle-panel {
    background:var(--bg2); border:1px solid var(--border);
    padding:16px; margin-top:20px;
}
.battle-panel-title {
    font-family:var(--mono); font-size:9px; font-weight:600;
    letter-spacing:1.5px; text-transform:uppercase;
    color:var(--text-3); margin-bottom:12px;
}
.battle-bar {
    display:flex; align-items:center; gap:10px; margin-bottom:8px;
}
.battle-bar-label {
    font-family:var(--mono); font-size:10px; color:var(--text-3);
    width:100px; flex-shrink:0;
}
.battle-bar-track {
    flex:1; height:5px; background:rgba(0,0,0,0.06);
}
[data-theme="dark"] .battle-bar-track { background:rgba(255,255,255,0.06); }
.battle-bar-fill {
    height:100%; transform-origin:left;
    animation:bar-grow 1.5s ease forwards;
}
.battle-bar-fill.primary { background:var(--primary); }
.battle-bar-fill.accent { background:var(--accent); }
.battle-bar-fill.gold { background:var(--gold); }
.battle-bar-pct {
    font-family:var(--mono); font-size:10px; font-weight:600;
    width:36px; text-align:right;
}
.battle-panel-footer {
    border-top:1px solid var(--border); margin-top:12px; padding-top:12px;
    display:flex; justify-content:space-between; align-items:center;
}
.battle-panel-footer .label {
    font-family:var(--mono); font-size:10px; color:var(--text-3);
}
.battle-panel-footer .score {
    font-family:var(--mono); font-size:20px; font-weight:700; color:var(--primary);
}

/* RC Monitor card */
.rc-display { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:6px; }
.rc-value {
    font-family:var(--mono); font-size:30px; font-weight:700;
    color:var(--primary); letter-spacing:-1px;
}
.rc-max { font-family:var(--mono); font-size:11px; color:var(--text-3); }
.rc-bar-track { height:4px; background:rgba(0,0,0,0.06); margin-bottom:12px; }
[data-theme="dark"] .rc-bar-track { background:rgba(255,255,255,0.06); }
.rc-bar-fill { height:100%; background:linear-gradient(90deg,var(--primary),var(--accent)); }

/* Telegram alert preview */
.tg-preview {
    background:var(--primary-dim); border:1px solid var(--primary-mid);
    padding:12px 14px;
}
[data-theme="dark"] .tg-preview { background:rgba(59,130,246,0.08); border-color:rgba(59,130,246,0.2); }
.tg-header {
    font-family:var(--mono); font-size:10px; color:var(--primary);
    font-weight:600; margin-bottom:8px;
    display:flex; align-items:center; gap:6px;
}
.tg-body {
    font-family:var(--mono); font-size:10px; color:var(--text-3); line-height:1.6;
}
.tg-body strong { color:var(--text-1); }
.tg-body .tg-accent { color:var(--primary); font-weight:600; }
.tg-body code { font-family:var(--mono); font-size:10px; }
.tg-footer { font-family:var(--mono); font-size:9px; color:var(--text-d); margin-top:6px; }

/* Account pills */
.acc-pills { display:flex; gap:5px; flex-wrap:wrap; }
.acc-pill {
    font-family:var(--mono); font-size:9px; padding:4px 8px;
    border:1px solid var(--primary); color:var(--primary);
    background:var(--primary-l);
}
.acc-pill.inactive { border-color:var(--border); color:var(--text-3); background:transparent; }
[data-theme="dark"] .acc-pill { color:#93bbfd; border-color:rgba(59,130,246,0.45); background:rgba(59,130,246,0.12); }
[data-theme="dark"] .acc-pill.inactive { color:var(--text-3); border-color:var(--border); background:transparent; }

/* Uptime chart */
.uptime-big {
    font-family:var(--mono); font-size:38px; font-weight:700;
    color:var(--primary); letter-spacing:-2px; line-height:1; margin:8px 0;
}
.uptime-big .unit { font-size:18px; }
.uptime-label { font-family:var(--mono); font-size:10px; color:var(--text-3); margin-bottom:10px; }
.uptime-bars { display:flex; gap:2px; flex-wrap:wrap; }
.uptime-bar { width:8px; height:18px; }
.uptime-bar.up { background:var(--primary); opacity:0.7; }
.uptime-bar.down { background:rgba(0,0,0,0.12); }
[data-theme="dark"] .uptime-bar.down { background:rgba(255,255,255,0.12); }

/* ===== TERMINAL / LIVE PROOF — SPLIT LAYOUT ===== */
#live-proof { border-top:1px solid var(--border); background:var(--bg2); }
.live-split {
    display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center;
    margin-bottom:48px;
}
.live-text-side .section-tag { margin-bottom:12px; }
.live-text-side h2 {
    font-family:var(--sans); font-size:clamp(26px,3vw,40px);
    font-weight:800; letter-spacing:-1px; line-height:1.3;
    margin-bottom:20px;
    display:inline-block; transform:scaleY(1.18); transform-origin:bottom;
}
.live-text-side p {
    font-family:var(--body); font-size:15px; color:var(--text-2);
    line-height:1.7; margin-bottom:28px;
}
.live-spec {
    font-family:var(--mono); font-size:11px; color:var(--text-3);
    margin-bottom:10px; display:flex; align-items:center; gap:12px;
}
.live-spec-key { font-weight:700; min-width:20px; }
.live-spec-key.cyan { color:var(--accent); }
.live-spec-key.primary { color:var(--primary); }
.live-spec-key.gold { color:var(--gold); }

/* Terminal */
.terminal-wrap {
    background:#0d1117; border:1px solid rgba(255,255,255,.06);
    overflow:hidden;
}
.terminal-topbar {
    display:flex; align-items:center; gap:6px;
    padding:10px 14px; border-bottom:1px solid rgba(255,255,255,.045);
    background:rgba(255,255,255,.018);
}
.terminal-dot { width:9px; height:9px; border-radius:50%; }
.terminal-dot.red { background:#ff5f57; }
.terminal-dot.yellow { background:#febc2e; }
.terminal-dot.green { background:#28c840; }
.terminal-title-text {
    font-family:var(--mono); font-size:10px; font-weight:500;
    color:#4b5563; letter-spacing:1px; margin-left:6px;
}
.terminal-body {
    padding:16px; font-family:var(--mono);
    font-size:11px; line-height:2; color:#6b7280;
    max-height:300px; overflow-y:auto;
}
.terminal-body .green  { color:#4ade80; }
.terminal-body .cyan   { color:#22d3ee; }
.terminal-body .gold   { color:#fbbf24; }
.terminal-body .purple { color:#a78bfa; }
.terminal-body .red    { color:#f87171; }
.terminal-body .dim    { color:#374151; }
.term-line {
    opacity:0; transform:translateY(3px); white-space:nowrap;
    animation:termIn .25s ease forwards;
}
.terminal-cursor {
    display:inline-block; width:7px; height:13px; background:#4ade80;
    vertical-align:middle; animation:blink 0.8s step-end infinite;
}

/* Leaderboard */
.leaderboard-wrap {
    background:var(--surface-0); border:1px solid var(--border);
    overflow:hidden; margin-top:0;
}
.lb-header {
    display:flex; align-items:center; justify-content:space-between;
    padding:14px 20px; border-bottom:1px solid var(--border);
}
.lb-title {
    font-family:var(--mono); font-size:13px; font-weight:700; color:var(--text-1);
    display:flex; align-items:center; gap:7px;
}
.lb-title::before {
    content:''; width:7px; height:7px; border-radius:50%;
    background:var(--primary); animation:pulse 2s infinite;
}
.lb-updated { font-family:var(--mono); font-size:11px; color:var(--text-3); }
.lb-list { width:100%; border-collapse:collapse; }
.lb-list thead th {
    padding:10px 16px; text-align:left; font-family:var(--mono);
    font-size:10px; font-weight:700; text-transform:uppercase;
    letter-spacing:.1em; color:var(--text-3);
    background:var(--surface-1); border-bottom:1px solid var(--border);
}
.lb-list tbody td {
    padding:12px 16px; font-size:13px; border-bottom:1px solid var(--border);
    font-family:var(--mono); color:var(--text-2); vertical-align:middle;
}
.lb-list tbody tr:last-child td { border-bottom:none; }
.lb-list tbody tr { transition:background .15s; }
.lb-list tbody tr:hover { background:var(--surface-1); }
.rank-cell { display:flex; align-items:center; gap:6px; }
.rank-bar { display:inline-block; width:3px; height:26px; border-radius:2px; background:var(--border-mid); flex-shrink:0; }
.rank-num { font-family:var(--mono); font-size:12px; font-weight:700; color:var(--text-3); }
.rank-1 .rank-bar { background:var(--gold); }
.rank-2 .rank-bar { background:#94a3b8; }
.rank-3 .rank-bar { background:#b08d6a; }
.scrap-val { color:var(--primary) !important; font-weight:600; }
.no-data { text-align:center; padding:40px; color:var(--text-3); font-size:13px; font-family:var(--body); }

/* ===== INFRASTRUCTURE ===== */
#infrastructure { border-top:1px solid var(--border); background:var(--bg2); }
.infra-grid {
    display:grid; grid-template-columns:repeat(3,1fr); gap:3px;
}
.infra-card {
    background:var(--surface-0); border:1px solid var(--border);
    padding:32px; position:relative; overflow:hidden;
    transition:all 0.3s;
}
.infra-card:hover {
    border-color:var(--primary-mid);
    box-shadow:0 0 28px rgba(37,99,235,0.07);
    transform:translateY(-3px);
}
.infra-card .infra-line {
    position:absolute; bottom:0; left:0; right:0; height:2px;
    background:linear-gradient(90deg,var(--primary),var(--accent));
    transform:scaleX(0); transform-origin:left;
    transition:transform 0.4s ease;
}
.infra-card:hover .infra-line { transform:scaleX(1); }
.infra-icon {
    width:44px; height:44px; border:1px solid var(--border);
    background:var(--primary-l); display:flex; align-items:center;
    justify-content:center; font-size:18px; margin-bottom:20px;
    transition:transform 0.3s, background 0.3s;
}
.infra-card:hover .infra-icon {
    transform:scale(1.1);
    background:var(--primary-m);
}
.infra-title {
    font-family:var(--sans); font-size:18px; font-weight:700;
    letter-spacing:-0.3px; margin-bottom:10px; color:var(--text-1);
    line-height:1.35;
    display:inline-block; transform:scaleY(1.15); transform-origin:bottom;
}
.infra-desc {
    font-family:var(--body); font-size:13px; color:var(--text-2);
    line-height:1.7; margin-bottom:16px;
}
.infra-spec {
    font-family:var(--mono); font-size:10px; font-weight:600;
    color:var(--primary); display:flex; align-items:center; gap:8px;
}
.infra-spec-line { width:14px; height:1px; background:var(--primary); }

/* ===== DEVELOPERS ===== */
#developers { border-top:1px solid var(--border); }
.dev-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; max-width:900px; margin:0 auto; }
.dev-card {
    display:flex; flex-direction:column; align-items:center; text-align:center;
    padding:40px 28px 32px; background:var(--surface-0); border:1px solid var(--border);
    transition:border-color .3s, box-shadow .3s, transform .3s;
    position:relative; overflow:hidden;
}
.dev-card::before {
    content:''; position:absolute; top:0; left:0; right:0; height:3px;
    background:linear-gradient(90deg,var(--primary),var(--accent));
    transform:scaleX(0); transform-origin:left;
    transition:transform 0.4s ease;
}
.dev-card:hover::before { transform:scaleX(1); }
.dev-card:hover { border-color:var(--primary); box-shadow:var(--shadow-lifted); transform:translateY(-4px); }
.dev-avatar {
    width:96px; height:96px; flex-shrink:0; overflow:hidden;
    border:2px solid var(--border); background:var(--bg2);
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    transition:all 0.4s; margin-bottom:20px;
}
.dev-card:hover .dev-avatar { border-color:var(--primary); box-shadow:0 0 0 4px var(--primary-l); transform:scale(1.05); }
.dev-card:hover .dev-avatar img { filter:brightness(1.05); }
.dev-avatar img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.dev-info { flex:1; min-width:0; }
.dev-name { font-family:var(--sans); font-size:18px; font-weight:700; margin-bottom:4px; color:var(--text-1); line-height:1.3; }
.dev-role {
    font-family:var(--mono); font-size:10px; font-weight:600;
    letter-spacing:1.5px; text-transform:uppercase;
    color:var(--primary); margin-bottom:16px;
}
.dev-bio { font-family:var(--body); font-size:13px; color:var(--text-2); line-height:1.7; margin-bottom:16px; }
.dev-stack {
    font-family:var(--mono); font-size:10px; color:var(--text-d);
    padding:5px 12px; background:var(--bg2); border:1px solid var(--border);
    display:inline-block; margin-bottom:14px;
}
.dev-links { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; }
.dev-link {
    display:inline-flex; align-items:center; gap:5px;
    padding:7px 16px; font-family:var(--mono); font-size:11px; font-weight:600;
    text-decoration:none; border:1px solid var(--border); color:var(--text-2);
    background:var(--surface-1); transition:all .2s;
}
.dev-link:hover { border-color:var(--primary); color:var(--primary); background:var(--primary-dim); }

/* ===== CONTACT / CTA ===== */
#contact { border-top:1px solid var(--border); background:var(--bg); }

/* CTA banner above contact form */
.cta-banner {
    text-align:center; margin-bottom:64px; padding-bottom:64px;
    border-bottom:1px solid var(--border);
}
.cta-banner .section-tag { margin-bottom:16px; }
.cta-banner h2 {
    font-family:var(--sans); font-size:clamp(30px,4vw,56px);
    font-weight:800; letter-spacing:-2px; line-height:1.2;
    margin-bottom:20px;
    display:inline-block; transform:scaleY(1.18); transform-origin:bottom;
}
.cta-banner .cta-accent { font-style:normal; color:var(--primary); }
.cta-banner p {
    font-family:var(--body); font-size:16px; color:var(--text-2);
    line-height:1.7; max-width:520px; margin:0 auto 44px;
}
.cta-banner-buttons {
    display:flex; gap:14px; justify-content:center; flex-wrap:wrap;
}
.cta-banner .cta-note {
    font-family:var(--mono); font-size:10px; color:var(--text-3);
    margin-top:28px; letter-spacing:1px;
}

/* Contact grid */
.contact-grid {
    display:grid; grid-template-columns:1fr 1fr; gap:56px;
    max-width:960px; margin:0 auto; align-items:start;
}
.contact-info-head { margin-bottom:24px; }
.contact-info-head p { font-family:var(--body); font-size:15px; color:var(--text-2); line-height:1.7; margin-top:12px; }
.apply-status {
    display:inline-flex; align-items:center; gap:8px;
    padding:8px 14px;
    background:rgba(22,163,74,.07); border:1px solid rgba(22,163,74,.2);
    font-family:var(--mono); font-size:12px; font-weight:600; color:#16a34a;
    margin-bottom:24px; letter-spacing:.04em;
}
.apply-status::before {
    content:''; width:6px; height:6px; border-radius:50%;
    background:#16a34a; flex-shrink:0; animation:statusPulse 2.5s ease-in-out infinite;
}
[data-theme="dark"] .apply-status { color:#4ade80; border-color:rgba(74,222,128,.25); background:rgba(74,222,128,.07); }
[data-theme="dark"] .apply-status::before { background:#4ade80; }
.contact-links { display:flex; flex-direction:column; gap:10px; }
.contact-link {
    display:flex; align-items:center; gap:14px; padding:14px 16px;
    background:var(--surface-0); border:1px solid var(--border);
    text-decoration:none; color:var(--text-1);
    transition:border-color .2s, transform .2s, box-shadow .2s;
}
.contact-link:hover { border-color:var(--primary); transform:translateX(6px); box-shadow:0 3px 14px rgba(37,99,235,.08); }
.contact-link-icon {
    width:38px; height:38px; display:flex; align-items:center;
    justify-content:center; flex-shrink:0;
}
.contact-link-label { font-family:var(--mono); font-size:11px; color:var(--text-3); font-weight:500; }
.contact-link-value { font-family:var(--mono); font-size:13px; font-weight:600; }
.contact-form-wrap {
    background:var(--surface-0); border:1px solid var(--border);
    padding:32px 28px;
}
.contact-form-wrap h3 { font-family:var(--sans); font-size:19px; font-weight:800; margin-bottom:22px; line-height:1.35; }
.form-group { margin-bottom:16px; }
.form-group label {
    display:block; font-family:var(--mono); font-size:11px; font-weight:700;
    color:var(--text-3); margin-bottom:6px;
    letter-spacing:.05em; text-transform:uppercase;
}
.form-group input, .form-group textarea {
    width:100%; padding:11px 14px;
    background:var(--surface-1); border:1px solid var(--border);
    color:var(--text-1); font-family:var(--mono); font-size:13px;
    outline:none; resize:vertical; transition:border-color .2s, background .2s;
}
.form-group input:focus, .form-group textarea:focus {
    border-color:var(--primary); background:var(--surface-0);
}
.form-group textarea { min-height:110px; }
.form-char-count { font-family:var(--mono); font-size:11px; color:var(--text-3); text-align:right; margin-top:4px; }
.btn-send {
    width:100%; padding:13px;
    font-family:var(--mono); font-size:13px; font-weight:700;
    border:none; cursor:pointer; background:var(--primary); color:#fff;
    transition:box-shadow .2s, transform .15s;
    box-shadow:0 2px 12px rgba(37,99,235,.24);
    display:flex; align-items:center; justify-content:center; gap:8px;
}
.btn-send:hover { box-shadow:0 4px 20px rgba(37,99,235,.35); transform:translateY(-1px); }
.btn-send:active { transform:scale(.98); }
.btn-send:disabled { opacity:.5; cursor:not-allowed; transform:none; box-shadow:none; }
.form-status { margin-top:12px; font-family:var(--mono); font-size:13px; text-align:center; min-height:20px; }
.form-status.success { color:var(--success); }
.form-status.error { color:var(--danger); }

/* ===== FOOTER ===== */
footer {
    border-top:1px solid var(--border); padding:28px 48px;
    display:flex; justify-content:space-between; align-items:center;
    background:var(--surface-0); flex-wrap:wrap; gap:12px;
}
.footer-brand {
    font-family:var(--mono); font-size:14px; font-weight:700;
    display:flex; align-items:center; gap:8px; color:var(--text-1);
}
.footer-brand-dot {
    width:6px; height:6px; border-radius:50%; background:var(--primary);
}
.footer-brand .brand-accent { color:var(--primary); }
.footer-copy {
    font-family:var(--mono); font-size:10px; color:var(--text-3);
}
.footer-copy a { color:var(--text-3); font-weight:600; text-decoration:none; transition:color .2s; }
.footer-copy a:hover { color:var(--text-1); }
.footer-copy .ic { color:var(--purple); }
.footer-status {
    font-family:var(--mono); font-size:10px; color:var(--primary);
    display:flex; align-items:center; gap:6px;
}
.footer-status-dot {
    display:inline-block; width:6px; height:6px; border-radius:50%;
    background:var(--success); animation:pulse-dot 2s infinite;
}

/* ===== REVEAL ===== */
.reveal-up {
    opacity:0; transform:translateY(22px);
    transition:opacity .65s cubic-bezier(.16,1,.3,1), transform .65s cubic-bezier(.16,1,.3,1);
}
.reveal-up.visible { opacity:1; transform:none; }
.reveal-up.delay-1 { transition-delay:.1s; }
.reveal-up.delay-2 { transition-delay:.2s; }
.reveal-up.delay-3 { transition-delay:.3s; }
.hero-reveal { opacity:0; transform:translateY(18px); animation:heroIn .8s cubic-bezier(.16,1,.3,1) forwards; animation-delay:.25s; }
.hero-reveal-2 { animation-delay:.5s; }
.hero-reveal-3 { animation-delay:.75s; }
.hero-reveal-4 { animation-delay:1s; }
.hero-reveal-5 { animation-delay:1.25s; }

/* Staggered reveal variants */
.reveal-left {
    opacity:0; transform:translateX(-30px);
    transition:opacity .65s cubic-bezier(.16,1,.3,1), transform .65s cubic-bezier(.16,1,.3,1);
}
.reveal-left.visible { opacity:1; transform:none; }
.reveal-right {
    opacity:0; transform:translateX(30px);
    transition:opacity .65s cubic-bezier(.16,1,.3,1), transform .65s cubic-bezier(.16,1,.3,1);
}
.reveal-right.visible { opacity:1; transform:none; }
.reveal-scale {
    opacity:0; transform:scale(0.92);
    transition:opacity .65s cubic-bezier(.16,1,.3,1), transform .65s cubic-bezier(.16,1,.3,1);
}
.reveal-scale.visible { opacity:1; transform:none; }
.reveal-left.delay-1, .reveal-right.delay-1, .reveal-scale.delay-1 { transition-delay:.1s; }
.reveal-left.delay-2, .reveal-right.delay-2, .reveal-scale.delay-2 { transition-delay:.2s; }
.reveal-left.delay-3, .reveal-right.delay-3, .reveal-scale.delay-3 { transition-delay:.3s; }

/* ===== AMBIENT ===== */
#features::before, #live-proof::before, #contact::before { content:''; position:absolute; top:0; left:0; right:0; bottom:0; z-index:-1; pointer-events:none; }
#features::before { background:radial-gradient(ellipse 60% 50% at 80% 20%,rgba(37,99,235,.04) 0%,transparent 60%); }
#live-proof::before { background:radial-gradient(ellipse 50% 40% at 20% 80%,rgba(8,145,178,.04) 0%,transparent 55%); }
#contact::before { background:radial-gradient(ellipse 50% 50% at 70% 50%,rgba(124,58,237,.04) 0%,transparent 55%); }

/* ===== REDUCED MOTION ===== */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
    .reveal-up, .reveal-left, .reveal-right, .reveal-scale { opacity:1; transform:none; }
    .hero-reveal { opacity:1; transform:none; }
}

/* ===== RESPONSIVE ===== */
@media (max-width:1024px) {
    .bento-grid { grid-template-columns:1fr; }
    .bento-card { grid-column:span 1 !important; grid-row:span 1 !important; }
    .infra-grid { grid-template-columns:1fr; }
}

@media (max-width:768px) {
    .navbar { padding:14px 20px; }
    .navbar.scrolled { padding:12px 20px; }
    .nav-links { display:none; }
    .nav-hamburger { display:flex; }
    section { padding:56px 20px; }
    .hero { padding:clamp(100px,18vw,130px) 20px 56px; }
    .hero-buttons { flex-direction:column; align-items:stretch; }
    .hero-buttons .btn-primary, .hero-buttons .btn-outline { width:100%; justify-content:center; }
    .compare-wrap { grid-template-columns:1fr; }
    .compare-vs { display:none; }
    .stats-bar { padding:32px 20px; justify-content:center; }
    .stats-bar-item { flex:1 1 calc(50% - 12px); justify-content:center; }
    .stats-bar-divider:nth-child(4), .stats-bar-divider:nth-child(8) { display:none; }
    .steps-row { grid-template-columns:1fr; gap:12px; }
    .step { padding:28px 24px; }
    .bento-grid { grid-template-columns:1fr; }
    .bento-card { grid-column:span 1 !important; grid-row:span 1 !important; }
    .live-split { grid-template-columns:1fr; gap:32px; }
    .infra-grid { grid-template-columns:1fr; }
    .dev-grid { grid-template-columns:1fr; max-width:400px; }
    .contact-grid { grid-template-columns:1fr; gap:32px; }
    .cta-banner-buttons { flex-direction:column; align-items:stretch; }
    .cta-banner-buttons .btn-primary, .cta-banner-buttons .btn-outline { width:100%; justify-content:center; }
    footer { flex-direction:column; align-items:center; text-align:center; padding:28px 20px; }
}

@media (max-width:480px) {
    .navbar { padding:12px 16px; }
    section { padding:48px 16px; }
    .stats-bar { padding:28px 16px; justify-content:center; }
    .stats-bar-item { flex:100%; justify-content:center; }
    .stats-bar-divider { display:none; }
    .contact-form-wrap { padding:18px 14px; }
    .terminal-body { font-size:10px; }
    .hero h1 { letter-spacing:-1px; }
}

@media (max-width:360px) {
    .navbar { padding:10px 12px; }
    section { padding:40px 12px; }
    .hero h1 { font-size:30px; }
    .dev-avatar { width:80px; height:80px; }
}