/* ============================================
   CAP NUMERIK v5 — AUTOMATION & DASHBOARDS
   ============================================ */

:root {
  --cyan-300:#67e8f9; --cyan-400:#22d3ee; --cyan-500:#06b6d4; --cyan-600:#0891b2; --cyan-700:#0e7490;
  --green-400:#4ade80; --green-500:#22c55e;
  --rose-400:#fb7185; --rose-500:#f43f5e;
  --amber-400:#fbbf24; --amber-500:#f59e0b;
  --violet-400:#a78bfa; --violet-500:#8b5cf6;
  --orange-400:#fb923c;
  
  --bg-0:#050508; --bg-1:#0a0a10; --bg-2:#0f0f18; --bg-3:#151520;
  --text-1:#ededf0; --text-2:rgba(237,237,240,0.6); --text-3:rgba(237,237,240,0.3);
  --accent:var(--cyan-400); --accent-hover:var(--cyan-300);
  --accent-glow:rgba(34,211,238,0.15); --accent-glow-strong:rgba(34,211,238,0.3);
  --border:rgba(237,237,240,0.06); --border-hover:rgba(34,211,238,0.2);
  
  --font-display:'Sora',system-ui,sans-serif;
  --font-mono:'JetBrains Mono',monospace;
  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --ease-spring:cubic-bezier(0.34,1.56,0.64,1);
  --max-w:1200px;
}
[data-theme="light"] {
  --bg-0:#fafafa; --bg-1:#f2f2f5; --bg-2:#e8e8ee; --bg-3:#dddde5;
  --text-1:#0a0a12; --text-2:rgba(10,10,18,0.72); --text-3:rgba(10,10,18,0.45);
  --accent:var(--cyan-600); --accent-hover:var(--cyan-500);
  --accent-glow:rgba(6,182,212,0.1); --accent-glow-strong:rgba(6,182,212,0.18);
  --border:rgba(10,10,18,0.1); --border-hover:rgba(6,182,212,0.3);
}

/* ========== RESET ========== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--font-display);background:var(--bg-0);color:var(--text-1);line-height:1.6;overflow-x:hidden}

/* Grain */
body::before{content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");background-repeat:repeat;opacity:0.4}

/* ========== ANIMATIONS ========== */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes glowPulse{0%,100%{opacity:0.4}50%{opacity:0.8}}
@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes countUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes barGrow{from{transform:scaleY(0)}to{transform:scaleY(1)}}
@keyframes lineTrace{from{stroke-dashoffset:300}to{stroke-dashoffset:0}}
@keyframes dotPop{from{opacity:0;r:0}to{opacity:1;r:4}}
@keyframes flowLineIn{from{opacity:0;stroke-dasharray:400;stroke-dashoffset:400}to{opacity:1;stroke-dasharray:400;stroke-dashoffset:0}}
@keyframes hubSpin{to{transform:rotate(360deg)}}
@keyframes pulseDot{0%,100%{opacity:0.3;box-shadow:0 0 0 0 var(--cyan-400)}50%{opacity:1;box-shadow:0 0 0 6px transparent}}
@keyframes particleMove{0%{left:-8px;opacity:0}20%{opacity:1}80%{opacity:1}100%{left:100%;opacity:0}}
@keyframes nodeAppear{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}
@keyframes nodeAppearRight{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
@keyframes actionFloat{0%,100%{opacity:0.4;transform:translate(-50%,0)}50%{opacity:0.8;transform:translate(-50%,-3px)}}
@keyframes actionFloatH{0%,100%{opacity:0.4;transform:translateY(-50%)}50%{opacity:0.8;transform:translateY(calc(-50% - 3px))}}
@keyframes dashPulse{0%,100%{box-shadow:0 0 0 0 rgba(34,211,238,0.1)}50%{box-shadow:0 0 30px 4px rgba(34,211,238,0.08)}}

.reveal{opacity:0;transform:translateY(24px);transition:opacity 0.7s var(--ease-out),transform 0.7s var(--ease-out)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:0.1s}.reveal-delay-2{transition-delay:0.2s}
.reveal-delay-3{transition-delay:0.3s}.reveal-delay-4{transition-delay:0.4s}

/* ========== LAYOUT ========== */
.container{max-width:var(--max-w);margin:0 auto;padding:0 24px}
section{padding:100px 0}

/* ========== HEADER ========== */
header{position:fixed;top:0;left:0;right:0;z-index:100;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:rgba(5,5,8,0.7);border-bottom:1px solid var(--border)}
[data-theme="light"] header{background:rgba(250,250,250,0.8)}
.header-inner{max-width:var(--max-w);margin:0 auto;padding:0 24px;height:60px;display:flex;align-items:center;gap:32px}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-mark{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--cyan-400),var(--cyan-600));display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-weight:700;font-size:13px;color:#050508}
.logo-text{font-weight:700;font-size:17px;color:var(--text-1);letter-spacing:-0.02em}
nav{display:flex;gap:28px;margin-left:auto}
nav a{font-size:13.5px;color:var(--text-2);text-decoration:none;transition:color 0.2s;font-weight:450}
nav a:hover{color:var(--text-1)}
.header-actions{display:flex;align-items:center;gap:12px}
.theme-toggle{background:none;border:1px solid var(--border);color:var(--text-2);width:34px;height:34px;border-radius:8px;cursor:pointer;font-size:16px;transition:all 0.2s;display:flex;align-items:center;justify-content:center}
.theme-toggle:hover{border-color:var(--border-hover);color:var(--text-1)}
.btn-header{font-family:var(--font-mono);font-size:12.5px;font-weight:500;padding:8px 16px;border-radius:8px;background:var(--accent-glow);color:var(--accent);text-decoration:none;border:1px solid var(--border-hover);transition:all 0.2s;white-space:nowrap}
.btn-header:hover{background:var(--accent-glow-strong)}
.menu-toggle{display:none;background:none;border:none;color:var(--text-1);font-size:24px;cursor:pointer}
@media(max-width:768px){
  nav{display:none;position:absolute;top:60px;left:0;right:0;flex-direction:column;background:var(--bg-1);padding:16px;gap:8px;border-bottom:1px solid var(--border)}
  nav.open{display:flex}
  nav a{padding:12px 0}
  .menu-toggle{display:block}
  .btn-header{display:none}
}

/* ========== HERO ========== */
.hero{padding:140px 0 80px;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:50%;left:50%;width:800px;height:800px;transform:translate(-50%,-60%);background:radial-gradient(circle,var(--accent-glow) 0%,transparent 70%);animation:glowPulse 5s ease-in-out infinite;pointer-events:none}
.hero-content{position:relative;z-index:2}
.hero-badge{font-family:var(--font-mono);font-size:12px;color:var(--accent);text-transform:uppercase;letter-spacing:0.15em;margin-bottom:24px;animation:fadeUp 0.6s var(--ease-out) both}
h1{font-size:clamp(2.2rem,5.5vw,3.8rem);font-weight:800;line-height:1.08;letter-spacing:-0.04em;margin-bottom:24px;animation:fadeUp 0.7s var(--ease-out) 0.15s both}
.gradient{background:linear-gradient(135deg,var(--cyan-300),var(--cyan-500),var(--violet-400));background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 8s ease infinite}
.hero-sub{font-size:clamp(1.05rem,2vw,1.25rem);color:var(--text-2);max-width:580px;margin:0 auto 40px;line-height:1.7;font-weight:350;animation:fadeUp 0.8s var(--ease-out) 0.3s both}
.hero-ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;animation:fadeUp 0.8s var(--ease-out) 0.45s both}
.btn-primary{font-family:var(--font-display);font-size:15px;font-weight:600;padding:14px 28px;border-radius:10px;text-decoration:none;background:var(--accent);color:#050508;transition:all 0.3s var(--ease-out);border:none;cursor:pointer;position:relative;overflow:hidden}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px var(--accent-glow-strong)}
.btn-secondary{font-family:var(--font-display);font-size:15px;font-weight:500;padding:14px 28px;border-radius:10px;text-decoration:none;background:transparent;color:var(--text-1);border:1px solid var(--border);transition:all 0.3s var(--ease-out)}
.btn-secondary:hover{border-color:var(--border-hover);background:var(--accent-glow);transform:translateY(-2px)}

/* Hero Data Flow SVG */
.hero-flow{max-width:720px;margin:56px auto 0;animation:fadeUp 1s var(--ease-out) 0.6s both;position:relative}
.flow-svg{width:100%;height:auto;overflow:visible}
.flow-line{opacity:0;animation:flowLineIn 1s var(--ease-out) forwards}
.fl-1{animation-delay:1s}.fl-2{animation-delay:1.1s}.fl-3{animation-delay:1.2s}.fl-4{animation-delay:1.3s}
.fl-5{animation-delay:1.5s}.fl-6{animation-delay:1.6s}.fl-7{animation-delay:1.7s}.fl-8{animation-delay:1.8s}
.data-packet{filter:drop-shadow(0 0 6px var(--cyan-400))}
.dp-out{filter:drop-shadow(0 0 6px var(--green-400))}
.hub-glow-circle{animation:glowPulse 3s ease-in-out infinite}

/* ========== SECTION COMMON ========== */
.section-alt{background:var(--bg-1)}
.section-label{font-family:var(--font-mono);font-size:12px;color:var(--accent);text-transform:uppercase;letter-spacing:0.15em;margin-bottom:16px}
.section-title{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700;line-height:1.15;letter-spacing:-0.03em;margin-bottom:20px}
.section-desc{font-size:1.05rem;color:var(--text-2);max-width:600px;line-height:1.7;font-weight:350}

/* ========== PROBLEM / PAIN ========== */
.pain-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-top:48px}
.pain-card{padding:28px;border-radius:14px;border:1px solid var(--border);background:var(--bg-0);transition:all 0.3s var(--ease-out)}
.pain-card:hover{border-color:var(--border-hover);transform:translateY(-4px)}
.pain-icon{font-size:28px;margin-bottom:16px}
.pain-card h3{font-size:16px;font-weight:600;margin-bottom:8px}
.pain-card p{font-size:14px;color:var(--text-2);line-height:1.6}
.pain-tag{display:inline-block;font-family:var(--font-mono);font-size:10px;color:var(--rose-400);background:rgba(244,63,94,0.1);padding:3px 8px;border-radius:4px;margin-bottom:12px;text-transform:uppercase;letter-spacing:0.1em}

/* ========== PIPELINE FLOW ========== */
.section-flow{background:var(--bg-1);overflow:hidden}
.flow-pipeline{display:flex;align-items:stretch;gap:0;margin-top:56px;position:relative;min-height:460px}
@media(max-width:900px){.flow-pipeline{flex-direction:column;align-items:center;gap:24px;min-height:auto}.flow-connectors{display:none}}
.flow-column{flex:1;display:flex;flex-direction:column;gap:12px;max-width:220px}
.flow-col-label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.2em;color:var(--text-3);margin-bottom:8px;padding-left:4px}
.flow-node{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:10px;border:1px solid var(--border);background:var(--bg-0);position:relative;overflow:hidden;transition:all 0.3s var(--ease-out);animation:nodeAppear 0.5s var(--ease-out) calc(0.3s + var(--delay) * 0.15s) both}
.fn-output{animation-name:nodeAppearRight}
.flow-node:hover{border-color:var(--border-hover);transform:translateY(-2px)}
.fn-icon{font-size:18px;flex-shrink:0}
.fn-info{flex:1;min-width:0}
.fn-name{font-size:12px;font-weight:600;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fn-desc{font-size:10px;color:var(--text-3);font-family:var(--font-mono);margin-top:2px}
.fn-pulse{position:absolute;right:8px;top:50%;width:5px;height:5px;border-radius:50%;background:var(--cyan-400);transform:translateY(-50%);animation:pulseDot 2s ease-in-out infinite;animation-delay:calc(var(--delay) * 0.4s)}
.fn-pulse-green{background:var(--green-400)}

/* Connectors */
.flow-connectors{width:60px;display:flex;flex-direction:column;justify-content:space-around;padding:20px 0;flex-shrink:0}
.connector-line{height:2px;width:100%;background:linear-gradient(90deg,var(--cyan-400) 0%,transparent 50%,var(--cyan-400) 100%);opacity:0.2;position:relative;border-radius:1px}
.connector-particle{position:absolute;top:-2px;left:0;width:8px;height:6px;background:var(--cyan-400);border-radius:3px;filter:blur(1px);animation:particleMove 2s linear infinite;animation-delay:var(--cd,0s);box-shadow:0 0 8px var(--cyan-400)}
.cp-out{background:var(--green-400);box-shadow:0 0 8px var(--green-400)}
.cl-out{background:linear-gradient(90deg,var(--green-400) 0%,transparent 50%,var(--green-400) 100%)}

/* Hub */
.flow-hub{width:180px;flex-shrink:0;display:flex;align-items:center;justify-content:center;position:relative}
.hub-ring{position:absolute;border-radius:50%;border:1px solid var(--accent)}
.hub-ring-outer{width:170px;height:170px;opacity:0.1;animation:hubSpin 20s linear infinite;border-style:dashed}
.hub-ring-inner{width:130px;height:130px;opacity:0.15;animation:hubSpin 15s linear infinite reverse;border-style:dotted}
.hub-core{width:100px;height:100px;border-radius:50%;background:radial-gradient(circle,var(--bg-0) 40%,rgba(34,211,238,0.08) 100%);border:1.5px solid rgba(34,211,238,0.4);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;z-index:2;box-shadow:0 0 40px rgba(34,211,238,0.15),inset 0 0 20px rgba(34,211,238,0.05)}
.hub-logo{font-family:var(--font-mono);font-weight:800;font-size:18px;background:linear-gradient(135deg,var(--cyan-300),var(--cyan-500));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hub-label{font-family:var(--font-mono);font-size:8px;color:var(--accent);text-transform:uppercase;letter-spacing:0.15em;margin-top:2px}
.hub-sublabel{font-size:6.5px;color:var(--text-3);font-family:var(--font-mono);margin-top:2px;text-align:center;line-height:1.2}
.hub-actions{position:absolute;width:220px;height:220px}
.hub-action{position:absolute;font-family:var(--font-mono);font-size:8px;color:var(--accent);opacity:0.5;padding:2px 6px;border:1px solid var(--accent-glow);border-radius:3px;background:var(--bg-0);white-space:nowrap;animation:actionFloat 3s ease-in-out infinite}
.ha-1{top:-16px;left:50%;transform:translateX(-50%);animation-delay:0s}
.ha-2{right:-44px;top:50%;transform:translateY(-50%);animation-delay:0.7s}
.ha-3{bottom:-16px;left:50%;transform:translateX(-50%);animation-delay:1.4s}
.ha-4{left:-36px;top:50%;transform:translateY(-50%);animation-delay:2.1s}
.ha-2,.ha-4{animation-name:actionFloatH}

/* Flow stats */
.flow-bottom{display:flex;justify-content:center;gap:48px;margin-top:56px;padding-top:32px;border-top:1px solid var(--border)}
@media(max-width:768px){.flow-bottom{flex-direction:column;align-items:center;gap:20px}}
.flow-stat{text-align:center}
.flow-stat-num{font-family:var(--font-mono);font-size:32px;font-weight:800;background:linear-gradient(135deg,var(--cyan-400),var(--green-400));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:block}
.flow-stat-label{font-size:13px;color:var(--text-3);margin-top:4px}

/* ========== DASHBOARD LIVE ========== */
.dash-preview{margin-top:56px;border-radius:16px;border:1px solid var(--border);background:var(--bg-0);overflow:hidden;position:relative;box-shadow:0 24px 80px rgba(0,0,0,0.4)}
[data-theme="light"] .dash-preview{box-shadow:0 12px 40px rgba(0,0,0,0.08)}
.dash-header{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border);background:var(--bg-2)}
.dash-dots{display:flex;gap:5px}
.dash-dots span{width:8px;height:8px;border-radius:50%}
.dash-dots span:nth-child(1){background:#f43f5e}
.dash-dots span:nth-child(2){background:#fbbf24}
.dash-dots span:nth-child(3){background:#4ade80}
.dash-title{font-family:var(--font-mono);font-size:11px;color:var(--text-3);flex:1;text-align:center}
.dash-live{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10px;color:var(--green-400)}
.dash-live::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--green-400);animation:livePulse 1.5s ease-in-out infinite}
@keyframes livePulse{0%,100%{opacity:0.4;box-shadow:0 0 0 0 rgba(74,222,128,0.4)}50%{opacity:1;box-shadow:0 0 0 6px rgba(74,222,128,0)}}

/* KPI cards */
.dash-body{padding:20px 24px;display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:768px){.dash-body{grid-template-columns:1fr 1fr}}
.dash-kpi{padding:16px;border-radius:10px;border:1px solid var(--border);background:var(--bg-1);text-align:center;transition:all 0.4s var(--ease-out)}
.dash-kpi:hover{border-color:var(--border-hover)}
.kpi-label{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:0.12em;color:var(--text-3);margin-bottom:8px}
.kpi-value{font-family:var(--font-mono);font-size:28px;font-weight:800;transition:color 0.3s}
.kpi-cyan{color:var(--cyan-400)}
.kpi-green{color:var(--green-400)}
.kpi-violet{color:var(--violet-400)}
.kpi-amber{color:var(--amber-400)}
.kpi-trend{font-family:var(--font-mono);font-size:10px;margin-top:4px}
.kpi-up{color:var(--green-400)}
.kpi-down{color:var(--rose-400)}
.kpi-flash{animation:kpiFlash 0.6s ease-out}
@keyframes kpiFlash{0%{background:rgba(34,211,238,0.12)}100%{background:transparent}}

/* Charts row */
.dash-charts{padding:0 24px 16px;display:grid;grid-template-columns:2.5fr 1fr;gap:12px}
@media(max-width:768px){.dash-charts{grid-template-columns:1fr}}
.dash-chart-box{padding:16px;border-radius:10px;border:1px solid var(--border);background:var(--bg-1);position:relative;overflow:hidden}
.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.chart-label{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:0.1em;color:var(--text-3)}
.chart-legend{display:flex;gap:12px}
.chart-legend-item{display:flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:9px;color:var(--text-3)}
.chart-legend-line{width:12px;height:2px;border-radius:1px}

/* Live SVG chart canvas */
.live-chart{width:100%;height:140px;display:block}

/* Donut */
.donut-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px}
.donut-box{position:relative;width:90px;height:90px}
.donut-svg{width:100%;height:100%;transform:rotate(-90deg)}
.donut-svg circle{transition:stroke-dashoffset 1.5s var(--ease-out)}
.donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.donut-val{font-family:var(--font-mono);font-size:18px;font-weight:700;color:var(--text-1)}
.donut-sub{font-family:var(--font-mono);font-size:8px;color:var(--text-3)}
.donut-legend{display:flex;flex-direction:column;gap:4px;width:100%}
.donut-legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-2)}
.donut-legend-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}

/* Activity feed */
.dash-feed{padding:0 24px 24px}
.feed-box{padding:14px 16px;border-radius:10px;border:1px solid var(--border);background:var(--bg-1);max-height:140px;overflow:hidden;position:relative}
.feed-box::after{content:'';position:absolute;bottom:0;left:0;right:0;height:40px;background:linear-gradient(transparent,var(--bg-1));pointer-events:none}
.feed-title{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:0.12em;color:var(--text-3);margin-bottom:10px}
.feed-item{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:12px;color:var(--text-2);border-bottom:1px solid var(--border);transition:all 0.4s var(--ease-out)}
.feed-item:last-child{border:none}
.feed-new{animation:feedIn 0.5s var(--ease-out)}
@keyframes feedIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
.feed-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.feed-time{font-family:var(--font-mono);font-size:9px;color:var(--text-3);margin-left:auto;white-space:nowrap}

/* ========== SOLUTIONS ========== */
.solutions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:48px}
.solution-card{padding:32px;border-radius:14px;border:1px solid var(--border);background:var(--bg-0);transition:all 0.3s var(--ease-out);position:relative;overflow:hidden}
.solution-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--cyan-400);opacity:0;transition:opacity 0.3s}
.solution-card:hover{border-color:var(--border-hover);transform:translateY(-6px)}
.solution-card:hover::before{opacity:1}
.solution-tag{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.12em;color:var(--accent);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.solution-tag::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--accent);opacity:0.5}
.solution-card h3{font-size:20px;font-weight:700;margin-bottom:10px;letter-spacing:-0.02em}
.solution-card p{font-size:14px;color:var(--text-2);line-height:1.65;margin-bottom:20px}
.solution-price{font-family:var(--font-mono);font-size:13px;color:var(--text-3);margin-bottom:16px}
.solution-link{font-family:var(--font-mono);font-size:13px;color:var(--accent);text-decoration:none;transition:all 0.2s}
.solution-link:hover{color:var(--accent-hover)}

/* ========== WHY / COMPARISON ========== */
.why-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:32px;margin-top:48px;align-items:start}
@media(max-width:768px){.why-grid{grid-template-columns:1fr}}
.comparison-table{width:100%;border-collapse:collapse;font-size:14px}
.comparison-table th{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.1em;padding:12px 16px;text-align:left;border-bottom:1px solid var(--border);color:var(--text-3)}
.comparison-table td{padding:12px 16px;border-bottom:1px solid var(--border)}
.is-col{color:var(--green-400)}
.not-col{color:var(--text-3);opacity:0.6}
.check,.cross{font-weight:700;margin-right:8px}
.bio-card{padding:28px;border-radius:14px;border:1px solid var(--border);background:var(--bg-0)}
.bio-name{font-family:var(--font-mono);font-size:28px;font-weight:700;margin-bottom:4px}
.bio-role{font-family:var(--font-mono);font-size:13px;color:var(--accent);margin-bottom:16px}
.bio-text{font-size:14px;color:var(--text-2);line-height:1.7;margin-bottom:24px}
.bio-stats{display:flex;gap:24px}
.stat-item{text-align:center}
.stat-number{font-family:var(--font-mono);font-size:28px;font-weight:700}
.stat-label{font-size:11px;color:var(--text-3);font-family:var(--font-mono)}

/* ========== PORTFOLIO ========== */
.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-top:48px}
.portfolio-card{padding:24px;border-radius:12px;border:1px solid var(--border);background:var(--bg-0);transition:all 0.3s var(--ease-out)}
.portfolio-card:hover{border-color:var(--border-hover);transform:translateY(-4px)}
.portfolio-card h3{font-size:16px;font-weight:600;margin:10px 0 6px}
.portfolio-card p{font-size:13px;color:var(--text-2);line-height:1.5}
.portfolio-type{font-family:var(--font-mono);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;padding:3px 8px;border-radius:4px;display:inline-block}
.type-ia{color:var(--cyan-400);background:rgba(34,211,238,0.1)}
.type-app{color:var(--violet-400);background:rgba(167,139,250,0.1)}
.type-both{color:var(--green-400);background:rgba(74,222,128,0.1)}
.type-auto{color:var(--amber,#fbbf24);background:rgba(251,191,36,0.1)}
.btn-portfolio{display:inline-block;margin-top:16px;font-family:var(--font-display);font-size:13px;font-weight:600;padding:10px 20px;border-radius:10px;text-decoration:none;text-align:center;background:var(--accent);color:#050508;border:none;cursor:pointer;transition:all 0.3s var(--ease-out)}
.btn-portfolio:hover{transform:translateY(-2px);box-shadow:0 8px 32px var(--accent-glow-strong);filter:brightness(1.1)}

/* ========== ECOSYSTEM ========== */
.ecosystem-banner{padding:32px 36px;border-radius:14px;margin-top:48px;background:linear-gradient(135deg,rgba(251,191,36,0.1),rgba(251,191,36,0.04));border:1px solid rgba(251,191,36,0.2);display:flex;align-items:center;gap:24px}
@media(max-width:768px){.ecosystem-banner{flex-direction:column;text-align:center}}
.eco-icon{width:48px;height:48px;border-radius:10px;background:linear-gradient(135deg,var(--amber-400),var(--amber-500));display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-weight:700;font-size:14px;color:#050508;flex-shrink:0}
.eco-text{flex:1}
.eco-text strong{color:var(--amber-500)}
.eco-text p{font-size:14.5px;color:var(--text-2);line-height:1.6}
.eco-link{font-family:var(--font-mono);font-size:13px;color:var(--amber-500);text-decoration:none;white-space:nowrap;padding:10px 20px;border-radius:8px;border:1px solid rgba(251,191,36,0.25);transition:all 0.25s}
.eco-link:hover{background:rgba(251,191,36,0.1);border-color:rgba(251,191,36,0.4)}
[data-theme="light"] .ecosystem-banner{background:linear-gradient(135deg,rgba(180,120,0,0.08),rgba(180,120,0,0.03));border-color:rgba(180,120,0,0.2)}
[data-theme="light"] .eco-text strong{color:#b47800}
[data-theme="light"] .eco-link{color:#946300;border-color:rgba(148,99,0,0.3)}
[data-theme="light"] .eco-link:hover{background:rgba(148,99,0,0.08);border-color:rgba(148,99,0,0.45)}

/* ========== CTA FINAL ========== */
.section-cta{text-align:center;position:relative;overflow:hidden}
.section-cta::before{content:'';position:absolute;top:50%;left:50%;width:600px;height:600px;transform:translate(-50%,-50%);background:radial-gradient(circle,var(--accent-glow) 0%,transparent 70%);pointer-events:none}
.cta-title{font-size:clamp(2rem,4.5vw,3rem);font-weight:800;line-height:1.1;letter-spacing:-0.04em;position:relative}
.cta-sub{font-size:1.05rem;color:var(--text-2);margin:20px auto 40px;max-width:480px;position:relative}
.cta-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;position:relative}

/* ========== FOOTER ========== */
footer{border-top:1px solid var(--border);padding:48px 0 32px;background:var(--bg-1)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr}}
.footer-brand .logo{margin-bottom:16px}
.footer-brand p{font-size:13px;color:var(--text-3);line-height:1.6;max-width:280px}
.footer-col h4{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.12em;color:var(--text-3);margin-bottom:16px}
.footer-col a{display:block;font-size:13.5px;color:var(--text-2);text-decoration:none;padding:4px 0;transition:color 0.2s}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--border);font-size:12px;color:var(--text-3)}
.footer-legal{display:flex;gap:20px}
.footer-legal a{color:var(--text-3);text-decoration:none;transition:color 0.2s}
.footer-legal a:hover{color:var(--text-2)}

/* Cookie */
.cookie-banner{position:fixed;bottom:20px;left:20px;background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:16px 20px;display:flex;align-items:center;gap:16px;z-index:200;max-width:440px;animation:fadeUp 0.5s var(--ease-out) 1s both;font-size:13px;color:var(--text-2)}
.cookie-banner.hidden{display:none}
.cookie-banner a{color:var(--accent)}
.cookie-accept{font-family:var(--font-mono);font-size:12px;padding:8px 16px;border-radius:6px;border:none;background:var(--accent);color:#050508;cursor:pointer;font-weight:600;flex-shrink:0}

/* ========== LIGHT MODE OVERRIDES ========== */
[data-theme="light"] .pain-card p,[data-theme="light"] .solution-card p,[data-theme="light"] .bio-text,
[data-theme="light"] .portfolio-card p,[data-theme="light"] .eco-text p,[data-theme="light"] .hero-sub,
[data-theme="light"] .section-desc,[data-theme="light"] .cta-sub{color:rgba(10,10,18,0.72)}
[data-theme="light"] .data-packet{filter:drop-shadow(0 0 4px var(--cyan-600))}
[data-theme="light"] .comparison-table .not-col{opacity:0.85}
[data-theme="light"] .footer-brand p,[data-theme="light"] .footer-col a{color:rgba(10,10,18,0.55)}
[data-theme="light"] .solution-price{color:rgba(10,10,18,0.5)}
[data-theme="light"] .stat-label{color:rgba(10,10,18,0.5)}
[data-theme="light"] .section-label{color:var(--cyan-700)}
[data-theme="light"] .pain-card,[data-theme="light"] .solution-card,[data-theme="light"] .bio-card,
[data-theme="light"] .portfolio-card,[data-theme="light"] .dash-preview{box-shadow:0 2px 12px rgba(0,0,0,0.04)}
[data-theme="light"] .pain-card:hover,[data-theme="light"] .solution-card:hover,
[data-theme="light"] .portfolio-card:hover{box-shadow:0 12px 40px rgba(0,0,0,0.08)}
[data-theme="light"] .flow-node{background:var(--bg-0);box-shadow:0 2px 8px rgba(0,0,0,0.04)}
[data-theme="light"] .hub-core{box-shadow:0 0 40px rgba(6,182,212,0.1),inset 0 0 20px rgba(6,182,212,0.03)}
[data-theme="light"] .hub-action{background:var(--bg-1)}
[data-theme="light"] .dash-kpi,[data-theme="light"] .dash-chart-box,[data-theme="light"] .feed-box{background:white}

/* ========== BREADCRUMB ========== */
.breadcrumb{padding:80px 0 0;font-family:var(--font-mono);font-size:12px;color:var(--text-3)}
.breadcrumb a{color:var(--text-3);text-decoration:none;transition:color .2s}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb span{margin:0 8px;opacity:.5}

/* ========== TERMINAL ========== */
.terminal{background:var(--bg-0);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-top:40px}
.terminal-header{display:flex;align-items:center;gap:6px;padding:10px 14px;background:var(--bg-2);border-bottom:1px solid var(--border)}
.terminal-dot{width:8px;height:8px;border-radius:50%}
.terminal-title{font-family:var(--font-mono);font-size:10px;color:var(--text-3);margin-left:8px}
.terminal-body{padding:16px 20px;font-family:var(--font-mono);font-size:12.5px;line-height:2}
.t-line{opacity:0;animation:fadeUp .3s var(--ease-out) forwards}
.t-prompt{color:var(--cyan-400)}.t-comment{color:var(--text-3);font-style:italic}.t-green{color:var(--green-400)}.t-amber{color:var(--amber-400)}.t-violet{color:var(--violet-400)}.t-rose{color:var(--rose-400)}.t-result{color:var(--text-2)}

/* ========== CAPABILITY / METHOD / OFFER CARDS ========== */
.cap-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-top:40px}
.cap-card{padding:24px;border-radius:12px;border:1px solid var(--border);background:var(--bg-0);transition:all .3s var(--ease-out)}
.cap-card:hover{border-color:var(--border-hover);transform:translateY(-4px)}
.cap-card h3{font-size:15px;font-weight:600;margin:12px 0 6px}.cap-card p{font-size:13px;color:var(--text-2);line-height:1.6}.cap-icon{font-size:24px}
.method-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-top:48px;counter-reset:step}
.method-step{padding:28px 24px;border-radius:12px;border:1px solid var(--border);background:var(--bg-0);position:relative;transition:all .3s var(--ease-out)}
.method-step:hover{border-color:var(--border-hover);transform:translateY(-4px)}
.method-step::before{counter-increment:step;content:counter(step);font-family:var(--font-mono);font-size:36px;font-weight:800;color:var(--accent);opacity:.15;position:absolute;top:12px;right:16px}
.method-step h3{font-size:15px;font-weight:600;margin-bottom:6px}.method-step p{font-size:13px;color:var(--text-2);line-height:1.6}.method-step .step-duration{font-family:var(--font-mono);font-size:11px;color:var(--accent);margin-top:8px}
.offer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:40px}
.offer-card{padding:32px;border-radius:14px;border:1px solid var(--border);background:var(--bg-0);transition:all .3s var(--ease-out)}
.offer-card:hover{border-color:var(--border-hover);transform:translateY(-4px)}
.offer-card h3{font-size:18px;font-weight:700;margin-bottom:8px}.offer-card p{font-size:14px;color:var(--text-2);line-height:1.6;margin-bottom:16px}
.offer-price{font-family:var(--font-mono);font-size:18px;font-weight:700;color:var(--accent);margin-bottom:4px}.offer-duration{font-family:var(--font-mono);font-size:12px;color:var(--text-3)}
.offer-features{list-style:none;margin:16px 0;padding:0}.offer-features li{font-size:13px;color:var(--text-2);padding:4px 0 4px 20px;position:relative}.offer-features li::before{content:'✓';position:absolute;left:0;color:var(--green-400);font-weight:700}

/* ========== PRICING / ROI / FINANCEMENT ========== */
.pricing-box{padding:32px;border-radius:14px;border:1px solid var(--border-hover);background:var(--accent-glow);margin-top:40px;text-align:center}
.pricing-box .offer-price{font-size:24px;margin-bottom:8px}.pricing-box p{color:var(--text-2);font-size:14px}
.roi-note{padding:20px 24px;border-radius:10px;border-left:3px solid var(--amber-400);background:rgba(251,191,36,.06);margin-top:24px}
.roi-note p{font-size:14px;color:var(--text-2);line-height:1.6}.roi-note strong{color:var(--amber-400)}
.fin-box{padding:20px 24px;border-radius:10px;border-left:3px solid var(--green-400);background:rgba(74,222,128,.06);margin-top:24px}
.fin-box p{font-size:14px;color:var(--text-2);line-height:1.6}.fin-box strong{color:var(--green-400)}
.badge-green{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:12px;color:var(--green-400);background:rgba(74,222,128,.1);padding:6px 12px;border-radius:6px;border:1px solid rgba(74,222,128,.2)}

/* ========== FAQ ========== */
.faq-list{margin-top:40px;max-width:700px}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:20px 0;cursor:pointer;font-size:15px;font-weight:600;color:var(--text-1);transition:color .2s}
.faq-q:hover{color:var(--accent)}.faq-q::after{content:'+';font-family:var(--font-mono);font-size:20px;color:var(--accent);transition:transform .3s}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease-out)}.faq-a-inner{padding:0 0 20px;font-size:14px;color:var(--text-2);line-height:1.7}.faq-item.open .faq-a{max-height:300px}

/* ========== COMPARE TABLE / FILTER / CHIPS ========== */
.compare-table{width:100%;border-collapse:collapse;margin-top:40px}
.compare-table th{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;padding:14px 16px;text-align:left;border-bottom:1px solid var(--border);color:var(--text-3)}
.compare-table td{padding:14px 16px;border-bottom:1px solid var(--border);font-size:14px;color:var(--text-2)}.compare-table tr:hover{background:var(--accent-glow)}
.td-green{color:var(--green-400)}.td-amber{color:var(--amber-400)}.td-rose{color:var(--rose-400)}
.filter-bar{display:flex;gap:8px;margin-top:24px;flex-wrap:wrap}
.filter-btn{font-family:var(--font-mono);font-size:12px;padding:8px 16px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text-2);cursor:pointer;transition:all .2s}
.filter-btn:hover,.filter-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}
.stack-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.stack-chip{font-family:var(--font-mono);font-size:11px;padding:4px 10px;border-radius:4px;border:1px solid var(--border);color:var(--text-3);background:var(--bg-0)}
.pedagogy-bar{display:flex;height:24px;border-radius:6px;overflow:hidden;margin-top:16px;border:1px solid var(--border)}
.pedagogy-practice{background:var(--accent);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:10px;font-weight:700;color:#050508}
.pedagogy-theory{background:var(--bg-2);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:10px;color:var(--text-3)}

/* ========== CONTACT FORM ========== */
.contact-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:40px;margin-top:48px;align-items:start}
@media(max-width:768px){.contact-grid{grid-template-columns:1fr}}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-family:var(--font-mono);font-size:12px;color:var(--text-3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border-radius:8px;border:1px solid var(--border);background:var(--bg-0);color:var(--text-1);font-family:var(--font-display);font-size:14px;transition:border-color .2s;outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent)}
.form-group textarea{resize:vertical;min-height:120px}
.form-group select{cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2322d3ee' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:768px){.form-row{grid-template-columns:1fr}}
.form-check{display:flex;align-items:flex-start;gap:10px;margin:16px 0}.form-check input{width:auto;margin-top:3px}.form-check label{font-size:12px;color:var(--text-3);text-transform:none;letter-spacing:normal}
.form-error{border-color:var(--rose-400) !important;animation:shake .4s ease}
.form-success{padding:24px;border-radius:12px;border:1px solid var(--green-400);background:rgba(74,222,128,.08);text-align:center;display:none}.form-success.show{display:block}.form-success h3{color:var(--green-400);margin-bottom:8px}
.contact-info{padding:28px;border-radius:14px;border:1px solid var(--border);background:var(--bg-0)}.contact-info h3{font-size:16px;font-weight:600;margin-bottom:20px}
.contact-info-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);font-size:14px;color:var(--text-2)}.contact-info-item:last-child{border:none}.contact-info-item a{color:var(--accent);text-decoration:none}.contact-info-item a:hover{color:var(--accent-hover)}
.contact-note{margin-top:20px;padding:16px;border-radius:8px;background:var(--accent-glow);font-size:13px;color:var(--text-2);line-height:1.6}

/* ========== LEGAL / 404 ========== */
.legal-content{padding:120px 0 80px}
.legal-content h1{font-size:clamp(1.8rem,4vw,2.4rem);animation:none;margin-bottom:32px}
.legal-content h2{font-size:18px;font-weight:700;margin:32px 0 12px;color:var(--text-1)}
.legal-content h3{font-size:15px;font-weight:600;margin:20px 0 8px;color:var(--text-2)}
.legal-content p{font-size:14px;color:var(--text-2);line-height:1.7;margin-bottom:12px}
.legal-content ul{margin:12px 0;padding-left:24px}.legal-content li{font-size:14px;color:var(--text-2);line-height:1.6;margin-bottom:6px}
.legal-content a{color:var(--accent);text-decoration:none}.legal-content a:hover{text-decoration:underline}
.page-404{padding:200px 0 120px;text-align:center}.page-404 h1{animation:none}
.page-404 .terminal{max-width:500px;margin:40px auto;text-align:left}
.numbered-steps{counter-reset:nstep;margin-top:48px}
.n-step{display:flex;gap:24px;padding:32px 0;border-bottom:1px solid var(--border);align-items:flex-start}.n-step:last-child{border:none}
.n-step-num{counter-increment:nstep;font-family:var(--font-mono);font-size:48px;font-weight:800;color:var(--accent);opacity:.2;line-height:1;min-width:60px;text-align:center}.n-step-num::before{content:counter(nstep, decimal-leading-zero)}
.n-step-content h3{font-size:18px;font-weight:700;margin-bottom:8px}.n-step-content p{font-size:14px;color:var(--text-2);line-height:1.6}
.n-step-meta{display:flex;gap:16px;margin-top:12px;flex-wrap:wrap}
.n-step-meta span{font-family:var(--font-mono);font-size:12px;padding:4px 10px;border-radius:4px;border:1px solid var(--border)}
.n-step-meta .meta-price{color:var(--accent);border-color:var(--border-hover)}.n-step-meta .meta-duration{color:var(--text-3)}
.scenario-table{width:100%;border-collapse:collapse;margin-top:32px;font-size:13px}
.scenario-table th{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;padding:12px;text-align:left;border-bottom:2px solid var(--accent);color:var(--accent)}
.scenario-table td{padding:12px;border-bottom:1px solid var(--border);color:var(--text-2)}.scenario-table tr:hover{background:var(--accent-glow)}
.type-auto{color:var(--amber-400);background:rgba(251,191,36,.1)}
