/* ══════════════════════════════════════════════════════════════════
   Green Edge Technologies — Artificial Intelligence Service Page
   artificial-intelligence.css
══════════════════════════════════════════════════════════════════ */

/* ── DESIGN TOKENS (identical across all pages) ──────────────────── */
:root {
  --bg:#0A0F1C; --bg-2:#121826; --bg-3:#0d1220;
  --surface:#1A2235; --surface-2:#202c42;
  --border:rgba(255,255,255,0.07); --border-g:rgba(0,200,83,0.22);
  --text:#FFFFFF; --text-muted:#B0B8C5; --text-faint:#6F7A8A;
  --green:#00C853; --green-dark:#006837;
  --green-glow:rgba(0,200,83,0.30); --green-subtle:rgba(0,200,83,0.08);
  --ai-blue:#00A8FF; --tech-purple:#6C63FF;
  --orange:#FF6B00; --neon:#39FF14;
  --grad-text:linear-gradient(120deg,#00C853 0%,#00A8FF 50%,#6C63FF 100%);
  --grad-btn:linear-gradient(135deg,#00C853,#006837);
  --font-d:'Manrope',sans-serif; --font-b:'Inter',sans-serif;
  --radius:14px; --radius-lg:22px;
  --ease:cubic-bezier(0.16,1,0.3,1);
  --nav-h:72px; --shadow:0 4px 30px rgba(0,0,0,.5)
}
body.light {
  --bg:#F5F7FA; --bg-2:#EBEEF3; --bg-3:#E0E5EE;
  --surface:#FFFFFF; --surface-2:#F0F3F8;
  --border:rgba(0,0,0,0.08); --border-g:rgba(0,200,83,0.30);
  --text:#0A0F1C; --text-muted:#4A5568; --text-faint:#9AA5B4;
  --green-subtle:rgba(0,200,83,0.10); --shadow:0 4px 30px rgba(0,0,0,.12)
}
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth; overflow-x:hidden }
body { background:var(--bg); color:var(--text); font-family:var(--font-b); font-size:16px; line-height:1.7; cursor:default; transition:background .4s,color .4s }
a { color:inherit; text-decoration:none }
ul { list-style:none }
button { border:none; background:none; font-family:inherit; cursor:pointer }
input,select,textarea { font-family:inherit; font-size:inherit; outline:none }

/* ── NOISE OVERLAY ───────────────────────────────────────────────── */

/* ── CUSTOM CURSOR ───────────────────────────────────────────────── */

/* ── CONTAINER ───────────────────────────────────────────────────── */
.container { max-max-width: 1240px; width: 100%; margin:0 auto; padding:0 28px }

/* ── BUTTONS ─────────────────────────────────────────────────────── */
.btn { display:inline-flex; align-items:center; gap:9px; padding:12px 26px; border-radius:9px; font-family:var(--font-d); font-weight:700; font-size:.9rem; letter-spacing:.01em; transition:all .3s var(--ease); position:relative; overflow:hidden; cursor:pointer }
.btn::after { content:''; position:absolute; inset:0; opacity:0; background:rgba(255,255,255,.1); border-radius:inherit; transition:opacity .25s }
.btn:hover::after { opacity:1 }
.btn-primary { background:var(--grad-btn); color:#fff; box-shadow:0 4px 22px var(--green-glow) }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 10px 40px var(--green-glow),0 0 0 1px rgba(0,200,83,.35) }
.btn-ghost { border:1.5px solid var(--green); color:var(--green); background:var(--green-subtle); backdrop-filter:blur(8px) }
.btn-ghost:hover { background:rgba(0,200,83,.16); transform:translateY(-2px); box-shadow:0 6px 26px var(--green-glow) }
.btn-lg { padding:15px 34px; font-size:1rem; border-radius:11px }
.btn-xl { padding:17px 42px; font-size:1.05rem; border-radius:12px }
.btn-sm { padding:9px 18px; font-size:.82rem }
.btn-pulse { animation:btnPulse 3s ease-in-out infinite }
.btn-pulse:hover { animation:none }
@keyframes btnPulse { 0%,100% { box-shadow:0 4px 22px var(--green-glow) } 50% { box-shadow:0 4px 44px rgba(0,200,83,.6),0 0 0 7px rgba(0,200,83,.07) } }

/* ── SECTIONS ────────────────────────────────────────────────────── */
.section { padding:110px 0; position:relative }
.section-tag { display:inline-block; font-family:var(--font-d); font-size:.7rem; font-weight:800; letter-spacing:.16em; text-transform:uppercase; color:var(--green); background:var(--green-subtle); border:1px solid var(--border-g); padding:4px 14px; border-radius:100px; margin-bottom:1.25rem }
.section-header { text-align:center; max-max-width: 700px; width: 100%; margin:0 auto 5rem }
.section-title { font-family:var(--font-d); font-size:clamp(1.875rem, 3.75vw, 3.0469rem); font-weight:800; line-height:1.12; letter-spacing:-.03em; margin-bottom:1.1rem }
.section-sub { font-size:1.05rem; color:var(--text-muted); max-max-width: 560px; width: 100%; margin:0 auto; line-height:1.75 }
.gradient-text { background:var(--grad-text); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text }

/* ── SCROLL REVEAL ───────────────────────────────────────────────── */
.reveal-up { opacity:0; transform:translateY(40px); animation:revealUp .85s var(--ease) forwards; animation-delay:var(--d,0s) }
@keyframes revealUp { to { opacity:1; transform:translateY(0) } }
.reveal-section,.reveal-card { opacity:0; transform:translateY(36px); transition:opacity .7s var(--ease),transform .7s var(--ease) }
.reveal-card { transition-delay:calc(var(--i,0)*.08s) }
.reveal-section.is-visible,.reveal-card.is-visible { opacity:1; transform:translateY(0) }

/* ── PROGRESS RING ───────────────────────────────────────────────── */
.progress-ring-wrap { position:fixed; bottom:2rem; right:2rem; z-index:1200; width:52px; height:52px; border-radius:50%; background:var(--surface); border:none; display:flex; align-items:center; justify-content:center; cursor:pointer; opacity:0; visibility:hidden; transform:translateY(14px) scale(.9); transition:opacity .35s,visibility .35s,transform .35s var(--ease); box-shadow:0 4px 24px rgba(0,0,0,.4) }
.progress-ring-wrap.visible { opacity:1; visibility:visible; transform:translateY(0) scale(1) }
.progress-ring-wrap:hover { transform:translateY(-3px) scale(1.06) }
.progress-ring { position:absolute; inset:0; transform:rotate(-90deg) }
.progress-ring__track { fill:none; stroke:rgba(255,255,255,.08); stroke-width:2.5 }
.progress-ring__fill { fill:none; stroke:var(--green); stroke-width:2.5; stroke-linecap:round; stroke-dasharray:125.66; stroke-dashoffset:125.66; transition:stroke-dashoffset .1s linear }
.progress-ring__icon { position:relative; z-index:1; color:var(--green) }

/* ══════════════════════════════════════════════════════════════════
   NAV — pixel-perfect match across all pages
══════════════════════════════════════════════════════════════════ */
/* ══════════════════════════════════════════════════════════════════
   1 · HERO
══════════════════════════════════════════════════════════════════ */
.svc-hero { min-height:92vh; display:flex; align-items:center; position:relative; overflow:hidden; padding-top:var(--nav-h); background:linear-gradient(160deg,var(--bg) 0%,var(--bg-2) 100%) }
.hero-canvas { position:absolute; inset:0; z-index:0; width:100%; height:100%; display:block }
.hero-glow { position:absolute; border-radius:50%; filter:blur(110px); pointer-events:none; animation:glowFloat 9s ease-in-out infinite }
.hero-glow-1 { max-width: 800px; width: 100%; height:800px; background:radial-gradient(circle,rgba(0,168,255,.07) 0%,transparent 70%); top:-220px; right:-140px }
.hero-glow-2 { max-width: 500px; width: 100%; height:500px; background:radial-gradient(circle,rgba(0,200,83,.07) 0%,transparent 70%); bottom:-80px; left:-80px; animation-delay:-4s }
@keyframes glowFloat { 0%,100% { transform:translate(0,0) scale(1) } 33% { transform:translate(28px,-20px) scale(1.05) } 66% { transform:translate(-18px,14px) scale(.97) } }
.svc-hero .container { position:relative; z-index:1; padding-top:4rem; padding-bottom:5rem }
.hero-inner { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center }

/* breadcrumb / badge */
.hero-breadcrumb { display:inline-flex; align-items:center; gap:7px; font-family:var(--font-d); font-size:.78rem; font-weight:600; color:var(--text-faint); margin-bottom:1.25rem }
.hero-breadcrumb a { color:var(--text-faint); transition:color .2s }
.hero-breadcrumb a:hover { color:var(--green) }
.hero-breadcrumb svg { opacity:.5 }
.breadcrumb-active { color:var(--ai-blue) }
.hero-service-badge { display:inline-flex; align-items:center; gap:8px; font-size:.8rem; font-weight:600; color:var(--ai-blue); background:rgba(0,168,255,.08); border:1px solid rgba(0,168,255,.25); padding:6px 16px; border-radius:100px; margin-bottom:1.5rem }
.badge-dot { width:7px; height:7px; border-radius:50%; background:var(--ai-blue); box-shadow:0 0 10px var(--ai-blue); animation:badgePulse 2s ease-in-out infinite; flex-shrink:0 }
@keyframes badgePulse { 0%,100% { box-shadow:0 0 4px var(--ai-blue) } 50% { box-shadow:0 0 18px var(--ai-blue),0 0 32px rgba(0,168,255,.3) } }

.hero-title { font-family:var(--font-d); font-size:clamp(2.625rem, 5.1562vw, 4.2188rem); font-weight:800; line-height:1.07; letter-spacing:-.035em; margin-bottom:1.25rem }
.hero-desc { font-size:1.05rem; color:var(--text-muted); line-height:1.78; margin-bottom:1.5rem; max-width:520px }
.hero-trust-row { display:flex; flex-wrap:wrap; gap:1rem; margin-bottom:2rem }
.hero-trust-row span { display:inline-flex; align-items:center; gap:6px; font-family:var(--font-d); font-size:.82rem; font-weight:600; color:var(--text-muted) }
.hero-ctas { display:flex; flex-wrap:wrap; gap:1rem; margin-bottom:2.5rem }
.hero-stats { display:flex; align-items:center; gap:1.5rem; background:var(--surface); border:1px solid var(--border); border-radius:14px; padding:1rem 1.5rem; width:fit-content }
.hs-item { display:flex; flex-direction:column; align-items:center; gap:2px }
.hs-n { font-family:var(--font-d); font-size:1.35rem; font-weight:800; color:var(--ai-blue) }
.hs-l { font-family:var(--font-d); font-size:.72rem; font-weight:600; color:var(--text-faint); letter-spacing:.06em; text-transform:uppercase }
.hs-sep { width:1px; height:36px; background:var(--border) }

/* ── BROWSER + CODE MOCKUP ───────────────────────────────────────── */
.hero-visual { position:relative }
.browser-mock { background:var(--surface); border:1px solid rgba(0,168,255,.2); border-radius:var(--radius-lg); overflow:hidden; box-shadow:0 40px 120px rgba(0,0,0,.6),0 0 0 1px rgba(0,168,255,.08),inset 0 1px 0 rgba(255,255,255,.04) }
.bm-topbar { display:flex; align-items:center; gap:.75rem; padding:.85rem 1.15rem; background:var(--surface-2); border-bottom:1px solid var(--border) }
.bm-dots { display:flex; gap:5px }
.bm-dots span { width:10px; height:10px; border-radius:50% }
.bm-dots span:nth-child(1) { background:#ff5f57 }
.bm-dots span:nth-child(2) { background:#febc2e }
.bm-dots span:nth-child(3) { background:#28c840 }
.bm-bar { display:flex; align-items:center; gap:6px; flex:1; background:var(--bg-3); border:1px solid var(--border); border-radius:6px; padding:5px 10px; font-family:var(--font-d); font-size:.7rem; color:var(--text-faint) }
.bm-bar svg { flex-shrink:0; color:var(--green) }
.bm-actions { color:var(--text-faint); flex-shrink:0 }
.bm-body { display:grid; grid-template-columns:1fr 1fr }

/* code panel */
.bm-code-panel { background:var(--bg-3); border-right:1px solid var(--border) }
.bm-code-tabs { display:flex; border-bottom:1px solid var(--border) }
.bm-ctab { font-family:var(--font-d); font-size:.65rem; font-weight:700; color:var(--text-faint); padding:6px 12px; border-right:1px solid var(--border); transition:all .2s; cursor:pointer }
.bm-ctab--active { color:var(--ai-blue); background:rgba(0,168,255,.07); border-bottom:1px solid var(--ai-blue) }
.bm-code { padding:.75rem .5rem; font-family:'Courier New',monospace; font-size:.63rem; line-height:1.7; overflow:hidden }
.bm-line { display:flex; align-items:baseline; gap:.5rem; padding:0 .25rem; border-radius:3px }
.bm-line--hl { background:rgba(0,168,255,.08); border-left:2px solid var(--ai-blue) }
.bm-line--active { background:rgba(0,200,83,.05) }
.bm-ln { color:var(--text-faint); min-width:18px; text-align:right; font-size:.58rem; user-select:none; flex-shrink:0 }
.tok-kw { color:#C586C0 }
.tok-str { color:#CE9178 }
.tok-fn { color:#DCDCAA }
.tok-type { color:#4EC9B0 }
.tok-tag { color:#4EC9B0 }
.tok-attr { color:#9CDCFE }
.tok-p { color:var(--text-muted) }
.bm-cursor-line { display:flex; align-items:baseline; gap:.5rem; padding:0 .25rem }
.bm-cursor { display:inline-block; width:7px; height:.9em; background:var(--ai-blue); border-radius:1px; animation:cursorBlink 1s step-end infinite }
@keyframes cursorBlink { 0%,100% { opacity:1 } 50% { opacity:0 } }

/* preview panel */
.bm-preview-panel { padding:.75rem; background:var(--surface); display:flex; flex-direction:column; gap:.65rem }
.bm-preview-label { font-family:var(--font-d); font-size:.6rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--text-faint) }
.bm-preview-site { background:var(--bg-3); border:1px solid var(--border); border-radius:7px; overflow:hidden; flex:1 }
.bmp-nav { display:flex; align-items:center; gap:.4rem; padding:.4rem .5rem; background:var(--surface-2); border-bottom:1px solid var(--border) }
.bmp-logo { width:14px; height:14px; border-radius:3px; background:var(--green); flex-shrink:0 }
.bmp-links { display:flex; gap:4px; flex:1 }
.bmp-links span { height:5px; background:var(--border); border-radius:3px; flex:1; max-width:20px }
.bmp-cta { width:24px; height:10px; border-radius:3px; background:rgba(0,200,83,.3) }
.bmp-hero { padding:.5rem .6rem .4rem }
.bmp-h1 { height:8px; background:var(--text-muted); border-radius:3px; width:80%; margin-bottom:4px; opacity:.6 }
.bmp-h2 { height:5px; background:var(--border); border-radius:3px; width:60%; margin-bottom:6px }
.bmp-btns { display:flex; gap:4px }
.bmp-btn-g { width:28px; height:9px; border-radius:3px; background:var(--green) }
.bmp-btn-o { width:22px; height:9px; border-radius:3px; background:var(--border) }
.bmp-cards { display:flex; gap:4px; padding:.4rem .6rem .5rem }
.bmp-cards span { flex:1; height:20px; background:var(--surface-2); border-radius:4px; border:1px solid var(--border) }
.bm-metrics { display:flex; gap:.5rem }
.bm-metric { flex:1; background:var(--surface-2); border:1px solid var(--border); border-radius:7px; padding:.5rem; text-align:center }
.bm-metric-n { display:block; font-family:var(--font-d); font-size:1rem; font-weight:800 }
.bm-metric-l { display:block; font-family:var(--font-d); font-size:.6rem; color:var(--text-faint) }

/* floating annotations */
.hero-ann { position:absolute; display:flex; align-items:center; gap:6px; font-family:var(--font-d); font-size:.72rem; font-weight:700; padding:6px 12px; border-radius:100px; box-shadow:0 8px 32px rgba(0,0,0,.4); backdrop-filter:blur(8px) }
.hero-ann-a { bottom:-16px; left:-18px; background:rgba(0,200,83,.12); border:1px solid rgba(0,200,83,.3); color:#00C853; animation:floatA 3.5s ease-in-out infinite }
.hero-ann-b { top:-14px; right:-14px; background:rgba(0,168,255,.12); border:1px solid rgba(0,168,255,.3); color:#00A8FF; animation:floatB 4s ease-in-out infinite }
@keyframes floatA { 0%,100% { transform:translateY(0) } 50% { transform:translateY(-7px) } }
@keyframes floatB { 0%,100% { transform:translateY(0) } 50% { transform:translateY(7px) } }

.hero-scroll-cue { position:absolute; bottom:2.5rem; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:8px; font-size:.68rem; letter-spacing:.12em; text-transform:uppercase; color:var(--text-faint) }
.scroll-line { width:1px; height:44px; background:linear-gradient(to bottom,var(--ai-blue),transparent); animation:scrollPulse 1.7s ease-in-out infinite }
@keyframes scrollPulse { 0% { transform:scaleY(1); transform-origin:top } 50% { transform:scaleY(0); transform-origin:top } 50.1% { transform-origin:bottom } 100% { transform:scaleY(1); transform-origin:bottom } }

/* ══════════════════════════════════════════════════════════════════
   2 · TYPES
══════════════════════════════════════════════════════════════════ */
.types-section { background:var(--bg-2) }
.types-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem }
.type-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); padding:2rem; display:flex; flex-direction:column; gap:.9rem; transition:border-color .3s,transform .4s var(--ease),box-shadow .4s; position:relative; overflow:hidden }
.type-card::after { content:''; position:absolute; inset:0; border-radius:var(--radius-lg); opacity:0; background:linear-gradient(135deg,rgba(0,168,255,.04),transparent); transition:opacity .3s; pointer-events:none }
.type-card:hover { transform:translateY(-8px); border-color:rgba(0,168,255,.3); box-shadow:0 28px 70px rgba(0,0,0,.4),0 0 0 1px rgba(0,168,255,.08) }
.type-card:hover::after { opacity:1 }
.tc-icon { width:52px; height:52px; border-radius:14px; background:var(--ci); color:var(--ct); display:flex; align-items:center; justify-content:center; flex-shrink:0 }
.type-card h3 { font-family:var(--font-d); font-size:1.05rem; font-weight:800 }
.type-card p { font-size:.87rem; color:var(--text-muted); line-height:1.72 }
.tc-list { display:flex; flex-direction:column; gap:.4rem; flex:1 }
.tc-list li { font-family:var(--font-d); font-size:.8rem; color:var(--text-faint); font-weight:600; padding-left:1rem; position:relative }
.tc-list li::before { content:'—'; position:absolute; left:0; color:var(--ai-blue); font-size:.75rem }
.tc-footer { display:flex; align-items:center; justify-content:space-between; padding-top:.75rem; border-top:1px solid var(--border); margin-top:auto }
.tc-time { display:inline-flex; align-items:center; gap:5px; font-family:var(--font-d); font-size:.75rem; font-weight:600; color:var(--text-faint) }
.tc-cta { font-family:var(--font-d); font-size:.8rem; font-weight:700; color:var(--ai-blue); transition:gap .2s; display:inline-flex; align-items:center; gap:4px }
.tc-cta:hover { gap:8px }

/* ══════════════════════════════════════════════════════════════════
   3 · PROCESS
══════════════════════════════════════════════════════════════════ */
.process-section { background:var(--bg) }
.process-track { position:relative; display:flex; gap:0; align-items:flex-start; margin-top:1rem }
.process-line { position:absolute; top:42px; left:60px; right:60px; height:2px; background:var(--border); z-index:0 }
.process-line-fill { height:100%; background:linear-gradient(90deg,var(--ai-blue),var(--green)); border-radius:2px; width:0; transition:width 1.4s var(--ease) }
.proc-step { flex:1; display:flex; flex-direction:column; align-items:center; text-align:center; gap:.75rem; padding:.5rem .75rem 1.5rem; position:relative; z-index:1 }
.proc-num { font-family:var(--font-d); font-size:.65rem; font-weight:800; letter-spacing:.1em; color:var(--text-faint); position:absolute; top:-1.2rem; left:50%; transform:translateX(-50%) }
.proc-num--active { color:var(--ai-blue) }
.proc-icon { width:52px; height:52px; border-radius:50%; background:var(--surface); border:2px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--text-muted); transition:all .4s var(--ease); flex-shrink:0; box-shadow:0 0 0 6px var(--bg) }
.proc-icon--active { background:rgba(0,168,255,.1); border-color:var(--ai-blue); color:var(--ai-blue); box-shadow:0 0 0 6px var(--bg),0 0 20px rgba(0,168,255,.3) }
.proc-step.is-active .proc-icon { background:rgba(0,168,255,.1); border-color:var(--ai-blue); color:var(--ai-blue); box-shadow:0 0 0 6px var(--bg),0 0 20px rgba(0,168,255,.3) }
.proc-step h3 { font-family:var(--font-d); font-size:.92rem; font-weight:800 }
.proc-step p { font-size:.8rem; color:var(--text-muted); line-height:1.62; max-width:160px }
.proc-tags { display:flex; flex-wrap:wrap; gap:4px; justify-content:center }
.proc-tags span { font-family:var(--font-d); font-size:.66rem; font-weight:700; padding:3px 8px; border-radius:100px; background:var(--surface-2); border:1px solid var(--border); color:var(--text-faint) }
.proc-step.is-active .proc-tags span { background:rgba(0,168,255,.1); border-color:rgba(0,168,255,.3); color:var(--ai-blue) }

/* ══════════════════════════════════════════════════════════════════
   4 · TECHNOLOGIES
══════════════════════════════════════════════════════════════════ */
.tech-section { background:var(--bg-2) }
.tech-groups { display:grid; grid-template-columns:repeat(2,1fr); gap:1.5rem }
.tech-group { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); padding:2rem; transition:border-color .3s,transform .35s var(--ease) }
.tech-group:hover { border-color:rgba(0,168,255,.25); transform:translateY(-4px) }
.tg-label { display:inline-flex; align-items:center; gap:8px; font-family:var(--font-d); font-size:.72rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--text-faint); margin-bottom:1.25rem; padding-bottom:1rem; border-bottom:1px solid var(--border); width:100% }
.tg-items { display:flex; flex-wrap:wrap; gap:.65rem }
.tech-pill { display:inline-flex; align-items:center; gap:.6rem; background:var(--surface-2); border:1px solid var(--border); border-radius:10px; padding:.55rem .9rem; cursor:pointer; transition:all .3s var(--ease); position:relative }
.tech-pill:hover { border-color:rgba(0,168,255,.35); transform:translateY(-3px) scale(1.04); box-shadow:0 8px 24px rgba(0,0,0,.3) }
.tp-icon { width:20px; height:20px; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:transform .3s var(--ease) }
.tech-pill:hover .tp-icon { transform:scale(1.2) rotate(-5deg) }
.tech-pill span { font-family:var(--font-d); font-size:.8rem; font-weight:700; color:var(--text-muted); white-space:nowrap }
.tech-pill:hover span { color:var(--text) }
.tech-pill .tool-tooltip { position:absolute; bottom:calc(100% + 8px); left:50%; transform:translateX(-50%) translateY(4px); background:var(--surface-2); border:1px solid rgba(0,168,255,.3); border-radius:8px; padding:5px 11px; font-family:var(--font-d); font-size:.7rem; color:var(--text); white-space:nowrap; opacity:0; pointer-events:none; transition:opacity .2s,transform .2s; box-shadow:0 6px 20px rgba(0,0,0,.3); z-index:10 }
.tech-pill:hover .tool-tooltip { opacity:1; transform:translateX(-50%) translateY(0) }

/* ══════════════════════════════════════════════════════════════════
   5 · PERFORMANCE & SECURITY
══════════════════════════════════════════════════════════════════ */
.perf-section { background:var(--bg) }
.perf-inner { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center }
.perf-desc { font-size:1rem; color:var(--text-muted); line-height:1.8; margin-bottom:2rem }
.perf-badges { display:flex; flex-direction:column; gap:1.1rem }
.perf-badge { display:flex; align-items:flex-start; gap:1rem }
.pb-icon { width:40px; height:40px; border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:2px }
.perf-badge strong { display:block; font-family:var(--font-d); font-size:.9rem; font-weight:800; margin-bottom:3px }
.perf-badge span { font-size:.82rem; color:var(--text-muted); line-height:1.6 }
/* Lighthouse score card */
.perf-score-card { background:var(--surface); border:1px solid var(--border-g); border-radius:var(--radius-lg); padding:2rem; box-shadow:0 32px 80px rgba(0,0,0,.45) }
.psc-label { font-family:var(--font-d); font-size:.72rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--text-faint); margin-bottom:1.5rem }
.psc-scores { display:grid; grid-template-columns:repeat(2,1fr); gap:1.25rem; margin-bottom:1.5rem }
.psc-score { display:flex; flex-direction:column; align-items:center; gap:.5rem; position:relative }
.psc-ring { width:80px; height:80px }
.psc-n { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); font-family:var(--font-d); font-size:1.2rem; font-weight:800; margin-top:-8px }
.psc-t { font-family:var(--font-d); font-size:.7rem; font-weight:700; color:var(--text-muted); text-align:center }
.psc-vitals { display:grid; grid-template-columns:repeat(4,1fr); gap:.75rem; padding-top:1.25rem; border-top:1px solid var(--border) }
.psc-vital { text-align:center }
.pscv-n { display:block; font-family:var(--font-d); font-size:.9rem; font-weight:800 }
.pscv-l { display:block; font-family:var(--font-d); font-size:.62rem; color:var(--text-faint) }

/* ══════════════════════════════════════════════════════════════════
   6 · PROJECTS
══════════════════════════════════════════════════════════════════ */
.proj-section { background:var(--bg-2) }
.proj-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem }
.proj-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; transition:border-color .3s,transform .4s var(--ease),box-shadow .4s }
.proj-card:hover { transform:translateY(-8px); border-color:rgba(0,168,255,.3); box-shadow:0 30px 70px rgba(0,0,0,.45) }
.proj-image { height:220px; position:relative; overflow:hidden }
.proj-visual { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; padding:1.25rem }
/* mini browser in project card */
.pv-browser { background:var(--surface); border:1px solid var(--border); border-radius:8px; overflow:hidden; width:100% }
.pvb-bar { display:flex; gap:4px; padding:.35rem .5rem; background:var(--surface-2); border-bottom:1px solid var(--border) }
.pvb-bar span { width:8px; height:8px; border-radius:50%; background:var(--border) }
.pvb-bar span:nth-child(1) { background:#ff5f57 }
.pvb-bar span:nth-child(2) { background:#febc2e }
.pvb-content { padding:.5rem }
.pvb-nav { height:8px; background:var(--surface-2); border-radius:4px; margin-bottom:.4rem }
.pvb-hero { background:var(--bg-3); border-radius:4px; padding:.5rem; margin-bottom:.4rem }
.pvb-h1 { height:7px; background:rgba(255,255,255,.2); border-radius:3px; width:70%; margin-bottom:3px }
.pvb-h2 { height:5px; background:var(--border); border-radius:3px; width:50% }
.pvb-cards { display:flex; gap:4px }
.pvb-cards span { flex:1; height:16px; background:var(--surface); border:1px solid var(--border); border-radius:4px }
/* ecomm visual */
.pv-ecomm { width:100% }
.pve-header { height:12px; background:rgba(108,99,255,.3); border-radius:4px; margin-bottom:.5rem }
.pve-grid { display:grid; grid-template-columns:1fr 1fr; gap:.5rem }
.pve-item { background:var(--surface); border:1px solid var(--border); border-radius:6px; padding:.5rem }
.pve-img { height:32px; background:rgba(108,99,255,.2); border-radius:4px; margin-bottom:.35rem }
.pve-price { font-family:var(--font-d); font-size:.75rem; font-weight:800 }
/* saas visual */
.pv-saas { display:flex; gap:.5rem; width:100% }
.pvs-sidebar { width:28px; background:var(--surface); border:1px solid var(--border); border-radius:5px; padding:.4rem .3rem; display:flex; flex-direction:column; gap:.3rem; flex-shrink:0 }
.pvs-sidebar span { height:5px; background:var(--border); border-radius:3px }
.pvs-main { flex:1 }
.pvs-kpi { background:var(--surface); border:1px solid var(--border); border-radius:5px; padding:.4rem .5rem; margin-bottom:.4rem; font-family:var(--font-d); font-size:.8rem; font-weight:800 }
.pvs-chart { display:flex; align-items:flex-end; gap:4px; height:40px; background:var(--surface); border:1px solid var(--border); border-radius:5px; padding:.4rem }
.pvsc-bar { flex:1; background:rgba(0,168,255,.25); border-radius:2px 2px 0 0 }
.pvsc-bar--a { background:var(--ai-blue) }
/* overlay + score */
.proj-overlay { position:absolute; inset:0; background:rgba(0,0,0,.65); backdrop-filter:blur(3px); display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity .35s var(--ease) }
.proj-card:hover .proj-overlay { opacity:1 }
.proj-score { position:absolute; top:.75rem; right:.75rem; background:rgba(0,0,0,.7); border:1px solid var(--border); border-radius:8px; padding:3px 10px; font-family:var(--font-d); font-size:.72rem; font-weight:800; color:var(--green); display:flex; align-items:center; gap:4px; backdrop-filter:blur(4px) }
.proj-score span { font-weight:600; color:var(--text-faint) }
.proj-body { padding:1.5rem }
.proj-cat { display:inline-block; font-family:var(--font-d); font-size:.66rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; padding:3px 10px; border-radius:100px; border:1px solid; margin-bottom:.75rem }
.proj-body h3 { font-family:var(--font-d); font-size:1rem; font-weight:800; line-height:1.3; margin-bottom:.5rem }
.proj-body p { font-size:.84rem; color:var(--text-muted); line-height:1.65; margin-bottom:.75rem }
.proj-meta { display:flex; justify-content:space-between; font-family:var(--font-d); font-size:.74rem; color:var(--text-faint); font-weight:600; padding-top:.65rem; border-top:1px solid var(--border) }

/* ══════════════════════════════════════════════════════════════════
   7 · RESULTS
══════════════════════════════════════════════════════════════════ */
.results-section { background:var(--bg); position:relative; overflow:hidden }
.results-bg { position:absolute; inset:0; background:radial-gradient(ellipse at 50% 0%,rgba(0,168,255,.05) 0%,transparent 70%); pointer-events:none }
.results-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; position:relative; z-index:1 }
.result-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); padding:2.25rem 1.75rem; text-align:center; display:flex; flex-direction:column; align-items:center; gap:.6rem; transition:border-color .3s,transform .4s var(--ease),box-shadow .4s; position:relative; overflow:hidden }
.result-card--featured { border-color:rgba(0,168,255,.3); background:rgba(0,168,255,.03) }
.result-card:hover { transform:translateY(-7px); border-color:rgba(0,168,255,.35); box-shadow:0 24px 60px rgba(0,0,0,.35) }
.rc-arrow { font-size:1.5rem; font-weight:900; line-height:1; color:var(--ai-blue) }
.rc-number { font-family:var(--font-d); font-size:3.25rem; font-weight:800; color:var(--ai-blue); line-height:1 }
.rc-pct { font-family:var(--font-d); font-size:1.4rem; font-weight:800; color:var(--text-muted); margin-top:-1rem }
.rc-label { font-family:var(--font-d); font-size:.88rem; font-weight:800; color:var(--text); margin-top:.25rem }
.rc-desc { font-size:.8rem; color:var(--text-faint); line-height:1.62; max-width:220px }

/* ══════════════════════════════════════════════════════════════════
   8 · PRICING
══════════════════════════════════════════════════════════════════ */
.pricing-section { background:var(--bg-2); position:relative; overflow:hidden }
.pricing-glow { position:absolute; top:-100px; left:50%; transform:translateX(-50%); max-width: 900px; width: 100%; height:500px; background:radial-gradient(ellipse at top,rgba(0,168,255,.06) 0%,transparent 70%); pointer-events:none }
.pricing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; align-items:start; position:relative; z-index:1 }
.pc { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); padding:2.25rem; display:flex; flex-direction:column; gap:1rem; transition:border-color .3s,transform .4s var(--ease),box-shadow .4s; position:relative }
.pc:hover { transform:translateY(-6px); box-shadow:0 28px 70px rgba(0,0,0,.35) }
.pc--featured { border-color:var(--green); background:rgba(0,200,83,.03); box-shadow:0 0 0 1px rgba(0,200,83,.2),0 24px 80px rgba(0,200,83,.1) }
.pc--featured:hover { box-shadow:0 0 0 1px var(--green),0 32px 80px rgba(0,200,83,.18) }
.pc-popular { position:absolute; top:-13px; left:50%; transform:translateX(-50%); font-family:var(--font-d); font-size:.68rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:#000; background:var(--green); padding:4px 16px; border-radius:100px; white-space:nowrap; box-shadow:0 4px 18px var(--green-glow) }
.pc-head { display:flex; align-items:center; gap:1rem }
.pc-icon { width:48px; height:48px; border-radius:12px; display:flex; align-items:center; justify-content:center; flex-shrink:0 }
.pc-head h3 { font-family:var(--font-d); font-size:1rem; font-weight:800; margin-bottom:2px }
.pc-sub { font-family:var(--font-d); font-size:.78rem; color:var(--text-faint) }
.pc-price { display:flex; align-items:baseline; gap:4px }
.pc-cur { font-family:var(--font-d); font-size:1.3rem; font-weight:800; color:var(--text-muted) }
.pc-amt { font-family:var(--font-d); font-size:3rem; font-weight:800; line-height:1; color:var(--ai-blue) }
.pc-price--custom { align-items:center }
.pc-custom { font-family:var(--font-d); font-size:2rem; font-weight:800; color:var(--tech-purple) }
.pc-period { font-family:var(--font-d); font-size:.78rem; color:var(--text-faint) }
.pc-feats { display:flex; flex-direction:column; gap:.55rem; flex:1 }
.pc-feats li { display:flex; align-items:center; gap:8px; font-family:var(--font-d); font-size:.83rem; color:var(--text-muted); font-weight:600 }

/* ══════════════════════════════════════════════════════════════════
   9 · FAQ
══════════════════════════════════════════════════════════════════ */
.faq-section { background:var(--bg) }
.faq-layout { display:grid; grid-template-columns:400px 1fr; gap:5rem; align-items:start }
.faq-left { position:sticky; top:calc(var(--nav-h) + 24px) }
.faq-left p { font-size:.95rem; color:var(--text-muted); line-height:1.75; margin-top:.75rem }
.faq-acc { display:flex; flex-direction:column; gap:.75rem }
.faq-item { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; transition:border-color .3s }
.faq-item:has(.faq-btn[aria-expanded="true"]) { border-color:rgba(0,168,255,.35) }
.faq-btn { width:100%; display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:1.15rem 1.35rem; cursor:pointer; font-family:var(--font-d); font-size:.95rem; font-weight:700; color:var(--text); text-align:left; transition:background .2s }
.faq-btn:hover { background:var(--surface-2) }
.faq-chev { flex-shrink:0; color:var(--text-faint); transition:transform .35s var(--ease),color .2s }
.faq-btn[aria-expanded="true"] .faq-chev { transform:rotate(180deg); color:var(--ai-blue) }
.faq-ans { overflow:hidden; transition:height .4s var(--ease) }
.faq-ans-inner { padding:.25rem 1.35rem 1.35rem; font-size:.88rem; color:var(--text-muted); line-height:1.78 }

/* ══════════════════════════════════════════════════════════════════
   10 · FINAL CTA
══════════════════════════════════════════════════════════════════ */
.final-cta { padding:110px 0; position:relative; overflow:hidden; background:var(--bg-3); text-align:center }
.fcta-glow-1 { position:absolute; top:-80px; left:50%; transform:translateX(-50%); max-width: 900px; width: 100%; height:400px; background:radial-gradient(ellipse at top,rgba(0,168,255,.1) 0%,transparent 70%); pointer-events:none }
.fcta-glow-2 { position:absolute; bottom:-80px; right:-100px; max-width: 500px; width: 100%; height:500px; background:radial-gradient(circle,rgba(0,200,83,.07) 0%,transparent 70%); pointer-events:none }
.fcta-inner { position:relative; z-index:1; max-max-width: 720px; width: 100%; margin:0 auto }
.fcta-btns { display:flex; justify-content:center; flex-wrap:wrap; gap:1.25rem; margin-bottom:2rem }
.fcta-trust { display:flex; gap:2rem; justify-content:center; flex-wrap:wrap }
.fcta-trust span { font-family:var(--font-d); font-size:.8rem; font-weight:700; color:var(--green) }

/* ══════════════════════════════════════════════════════════════════
   FOOTER — exact match across all pages
══════════════════════════════════════════════════════════════════ */
.footer { background:var(--bg-3); border-top:1px solid var(--border) }
.footer-top-bar { background:rgba(0,200,83,.05); border-bottom:1px solid var(--border-g); padding:13px 0 }
.footer-top-inner { display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:.8rem; color:var(--text-muted); font-family:var(--font-d); font-weight:600 }
.footer-socials { display:flex; gap:8px }
.social-link { width:34px; height:34px; border-radius:7px; background:var(--surface); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--text-muted); transition:all .2s; cursor:pointer }
.social-link:hover { background:var(--green-subtle); color:var(--green); border-color:var(--border-g); box-shadow:0 0 14px var(--green-glow) }
.footer-main { padding:60px 0 44px }
.footer-grid { display:grid; grid-template-columns:1.8fr 1fr 1fr 1fr 1fr; gap:3rem }
.footer-brand p { font-size:.875rem; color:var(--text-muted); line-height:1.75; margin-bottom:2rem; max-width:280px }
.newsletter-wrap { margin-top:1.5rem }
.newsletter-label { font-family:var(--font-d); font-size:.78rem; font-weight:700; letter-spacing:.05em; color:var(--text-muted); margin-bottom:.65rem; display:block }
.newsletter-form { display:flex; gap:8px }
.newsletter-form input { flex:1; background:var(--surface); border:1.5px solid var(--border); border-radius:8px; padding:10px 13px; color:var(--text); font-size:.85rem; transition:border-color .2s }
.newsletter-form input::placeholder { color:var(--text-faint) }
.newsletter-form input:focus { border-color:var(--green); box-shadow:0 0 0 2px var(--green-subtle) }
.footer-col h5 { font-family:var(--font-d); font-size:.73rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; margin-bottom:1.25rem }
.footer-col ul { display:flex; flex-direction:column; gap:9px }
.footer-col a { font-size:.875rem; color:var(--text-muted); transition:color .2s; cursor:pointer }
.footer-col a:hover { color:var(--green) }
.footer-bottom { border-top:1px solid var(--border); padding:22px 0 }
.footer-bottom-inner { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; font-size:.79rem; color:var(--text-faint) }
.footer-legal { display:flex; gap:1.5rem }
.footer-legal a { color:var(--text-faint); transition:color .2s; cursor:pointer }
.footer-legal a:hover { color:var(--green) }

/* ══════════════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════════════ */
@media (max-width:1100px) {
  .types-grid { grid-template-columns:repeat(2,1fr) }
  .tech-groups { grid-template-columns:1fr }
  .footer-grid { grid-template-columns:1fr 1fr; gap:2.5rem }
  .footer-brand { grid-column:span 2 }
  .perf-inner { gap:3rem }
}
@media (max-width:960px) {
  .hero-inner { grid-template-columns:1fr }
  .hero-visual { display:none }
  .process-track { flex-direction:column; gap:2rem; align-items:center }
  .process-line { display:none }
  .proc-step { width:100%; max-max-width: 360px; width: 100%; flex-direction:row; text-align:left; align-items:flex-start }
  .proc-num { position:static; transform:none; order:-1; width:auto }
  .proj-grid { grid-template-columns:1fr }
  .results-grid { grid-template-columns:repeat(2,1fr) }
  .pricing-grid { grid-template-columns:1fr }
  .perf-inner { grid-template-columns:1fr }
  .faq-layout { grid-template-columns:1fr; gap:3rem }
  .faq-left { position:static }
}
@media (max-width:768px) {
  :root { --nav-h:64px }
  body { cursor:default }
  .section { padding:75px 0 }
  .hero-stats { flex-wrap:wrap; gap:1rem }
  .hs-sep { display:none }
  .hero-ctas { flex-direction:column }
  .types-grid { grid-template-columns:1fr }
  .results-grid { grid-template-columns:1fr 1fr }
  .psc-scores { grid-template-columns:repeat(2,1fr) }
  .fcta-btns { flex-direction:column; align-items:center }
  .fcta-trust { gap:1rem }
  .footer-grid { grid-template-columns:1fr }
  .footer-brand { grid-column:span 1 }
  .footer-bottom-inner { flex-direction:column; text-align:center }
  .footer-legal { justify-content:center; flex-wrap:wrap }
  .footer-top-inner { flex-direction:column; text-align:center }
  .newsletter-form { flex-direction:column }
}
@media (max-width:480px) {
  .hero-title { font-size:clamp(2.25rem, 8.4375vw, 2.8125rem) }
  .results-grid { grid-template-columns:1fr }
  .proc-step { flex-direction:column; align-items:center; text-align:center }
  .bm-body { grid-template-columns:1fr }
  .bm-preview-panel { display:none }
}

/* ──────────────────────────────────────────────────────────────────
   AI PAGE — Hero colour identity: Neon Green #39FF14
─────────────────────────────────────────────────────────────────── */
.hero-service-badge { color:var(--neon) !important; background:rgba(57,255,20,.07) !important; border-color:rgba(57,255,20,.25) !important }
.badge-dot { background:var(--neon) !important; box-shadow:0 0 10px var(--neon) !important }
@keyframes badgePulse { 0%,100% { box-shadow:0 0 4px var(--neon) } 50% { box-shadow:0 0 18px var(--neon),0 0 32px rgba(57,255,20,.3) } }
.hero-glow-1 { background:radial-gradient(circle,rgba(57,255,20,.05) 0%,transparent 70%) !important }
.hero-glow-2 { background:radial-gradient(circle,rgba(0,168,255,.06) 0%,transparent 70%) !important }
.hero-glow-3 { max-width: 600px; width: 100%; height:600px; background:radial-gradient(circle,rgba(0,168,255,.05) 0%,transparent 70%); top:200px; left:-200px; position:absolute; border-radius:50%; filter:blur(110px); pointer-events:none; animation:glowFloat 11s ease-in-out infinite }
.scroll-line { background:linear-gradient(to bottom,var(--neon),transparent) !important }

/* ── AI Neural Brain Visual ──────────────────────────────────────── */
.hero-visual { position:relative; display:flex; justify-content:center; align-items:center }
.ai-brain-wrap { position:relative; width:100%; max-max-width: 500px; width: 100%; height:420px }
.neural-canvas { position:absolute; inset:0; width:100%; height:100%; border-radius:var(--radius-lg) }

/* Floating AI info cards */
.ai-card { position:absolute; display:flex; align-items:center; gap:8px; padding:10px 14px; border-radius:12px; backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px); box-shadow:0 8px 32px rgba(0,0,0,.55); font-family:var(--font-d); font-size:.76rem; font-weight:700; z-index:10 }
.ai-card--terminal { bottom:16px; left:-8px; background:rgba(7,12,24,.92); border:1px solid rgba(57,255,20,.35); color:var(--neon); flex-direction:column; align-items:flex-start; gap:3px; min-max-width: 215px; width: 100%; font-family:'JetBrains Mono',monospace; font-size:.67rem; line-height:1.65 }
.aic-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0 }
.aic-dot--green { background:var(--neon); box-shadow:0 0 8px var(--neon); animation:badgePulse 1.5s ease-in-out infinite }
.aic-cursor { display:inline-block; animation:blink .7s steps(1) infinite; color:var(--neon); font-size:.76rem; margin-left:1px }
@keyframes blink { 0%,50% { opacity:1 } 51%,100% { opacity:0 } }
.ai-card--metric { top:18px; right:-14px; background:rgba(12,18,35,.92); border:1px solid rgba(0,168,255,.3); flex-direction:column; align-items:flex-start; gap:5px; min-width:162px }
.aim-label { font-size:.63rem; font-weight:700; color:var(--text-faint); letter-spacing:.05em; text-transform:uppercase }
.aim-value { font-size:1.45rem; font-weight:800; color:var(--ai-blue); line-height:1 }
.aim-bar { width:100%; height:4px; background:rgba(0,168,255,.15); border-radius:2px; overflow:hidden }
.aim-fill { height:100%; background:linear-gradient(90deg,var(--ai-blue),var(--neon)); border-radius:2px; animation:fillGrow 2.5s ease-out 0.5s both }
@keyframes fillGrow { from { width:0 } }
.ai-card--confidence { top:46%; right:-16px; transform:translateY(-50%); background:rgba(57,255,20,.08); border:1px solid rgba(57,255,20,.3); color:var(--neon); gap:6px; white-space:nowrap; animation:aiFloatConf 3.5s ease-in-out infinite }
@keyframes aiFloatConf { 0%,100% { transform:translateY(-50%) } 50% { transform:translateY(calc(-50% - 9px)) } }

/* ── Process active node — neon green ────────────────────────────── */
.proc-num--active { background:linear-gradient(135deg,var(--neon),#00C853) !important; color:#000 !important; box-shadow:0 0 22px rgba(57,255,20,.4) !important }
.proc-icon--active { border-color:rgba(57,255,20,.4) !important; color:var(--neon) !important; box-shadow:0 0 16px rgba(57,255,20,.2) !important }
.process-line-fill { background:linear-gradient(90deg,var(--neon),var(--green)) !important }

/* ── Results — neon accents ──────────────────────────────────────── */
.result-card--featured { border-color:rgba(57,255,20,.3) !important; background:rgba(57,255,20,.03) !important }
.result-card--featured .rc-number { color:var(--neon) !important }
.rc-number { color:var(--neon) !important }
.rc-arrow--up { color:var(--neon) !important }
.rc-arrow--down { color:var(--ai-blue) !important }

/* ── Pricing featured — green ────────────────────────────────────── */
.pc--featured { border-color:var(--green) !important; background:rgba(0,200,83,.03) !important; box-shadow:0 0 0 1px rgba(0,200,83,.2),0 24px 80px rgba(0,200,83,.1) !important }
.pc--featured:hover { box-shadow:0 0 0 1px var(--green),0 32px 80px rgba(0,200,83,.18) !important }
.pc-popular { background:var(--green) !important; color:#000 !important; box-shadow:0 4px 18px var(--green-glow) !important }

/* ── AI Project preview panels ───────────────────────────────────── */
.proj-ai-preview { position:absolute; inset:0; padding:1rem; display:flex; flex-direction:column; gap:.5rem }
.pap-header { display:flex; align-items:center; gap:.5rem; padding:.4rem .7rem; border-radius:8px; font-family:var(--font-d); font-size:.72rem; font-weight:700; color:var(--text-muted) }
.pap-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0 }
.pap-dot-g { background:#00C853; box-shadow:0 0 8px #00C853 }
.pap-dot-p { background:#6C63FF; box-shadow:0 0 8px #6C63FF }
.pap-dot-b { background:#00A8FF; box-shadow:0 0 8px #00A8FF }
/* chat preview */
.pap-msgs { display:flex; flex-direction:column; gap:.4rem; flex:1; overflow:hidden }
.pap-msg { font-size:.6rem; font-weight:600; line-height:1.4; padding:.35rem .6rem; border-radius:10px; max-width:86%; word-break:break-word }
.pap-msg-u { background:rgba(255,255,255,.08); align-self:flex-start; color:var(--text-muted); border-radius:10px 10px 10px 2px }
.pap-msg-a { background:rgba(0,200,83,.15); align-self:flex-end; color:#a8ffca; border:1px solid rgba(0,200,83,.2); border-radius:10px 10px 2px 10px }
.pap-typing { display:flex; gap:3px; align-items:center; padding:.2rem .5rem }
.pap-typing span { width:5px; height:5px; border-radius:50%; background:rgba(0,200,83,.5); animation:typingBounce 1.2s ease-in-out infinite }
.pap-typing span:nth-child(2) { animation-delay:.2s }
.pap-typing span:nth-child(3) { animation-delay:.4s }
@keyframes typingBounce { 0%,60%,100%{transform:translateY(0)} 30%{transform:translateY(-4px)} }
/* ML chart preview */
.pap-chart-area { flex:1; display:flex; flex-direction:column; justify-content:flex-end; gap:.5rem; padding:.2rem 0 }
.pap-chart-bars { display:flex; align-items:flex-end; gap:4px; height:80px }
.pap-chart-bars div { flex:1; border-radius:3px 3px 0 0 }
.pap-bar-active { box-shadow:0 0 12px rgba(108,99,255,.6) }
.pap-prediction { display:flex; align-items:center; gap:.4rem; font-family:var(--font-d); font-size:.65rem; font-weight:700; color:var(--text-muted); background:rgba(0,200,83,.1); border:1px solid rgba(0,200,83,.2); border-radius:8px; padding:.35rem .6rem }
/* recommendation preview */
.pap-recs { display:flex; flex-direction:column; gap:.4rem; flex:1; overflow:hidden }
.pap-rec-item { display:flex; align-items:center; gap:.5rem; background:rgba(255,255,255,.05); border-radius:8px; padding:.4rem .5rem }
.pap-rec-img { width:32px; height:32px; border-radius:6px; flex-shrink:0 }
.pap-rec-info { flex:1 }
.pap-rec-name { height:5px; background:rgba(255,255,255,.2); border-radius:3px; width:75%; margin-bottom:5px }
.pap-rec-score { font-size:.55rem; font-weight:800; font-family:var(--font-d) }

/* ── Feature cards (AI page uses 3-col like web-dev) ─────────────── */
.features-section { background:var(--bg) }
.features-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem }
.feat-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:1.65rem; display:flex; flex-direction:column; gap:.75rem; transition:border-color .3s,transform .35s var(--ease),box-shadow .35s }
.feat-card:hover { transform:translateY(-6px); border-color:rgba(57,255,20,.3); box-shadow:0 20px 50px rgba(0,0,0,.35) }
.fc-icon { width:48px; height:48px; border-radius:12px; background:var(--fi); color:var(--ft); display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:transform .3s var(--ease) }
.feat-card:hover .fc-icon { transform:scale(1.1) rotate(-5deg) }
.feat-card h4 { font-family:var(--font-d); font-size:.92rem; font-weight:800 }
.feat-card p { font-size:.84rem; color:var(--text-muted); line-height:1.65 }

/* ── Hero scroll cue ─────────────────────────────────────────────── */
.hero-scroll-cue { position:absolute; bottom:2.5rem; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:8px; font-size:.68rem; letter-spacing:.12em; text-transform:uppercase; color:var(--text-faint) }
.scroll-line { width:1px; height:44px; background:linear-gradient(to bottom,var(--neon),transparent); animation:scrollPulse 1.7s ease-in-out infinite }
@keyframes scrollPulse { 0%{transform:scaleY(1);transform-origin:top} 50%{transform:scaleY(0);transform-origin:top} 50.1%{transform-origin:bottom} 100%{transform:scaleY(1);transform-origin:bottom} }

/* ── Responsive additions ────────────────────────────────────────── */
@media (max-width:1100px) { .features-grid { grid-template-columns:repeat(2,1fr) } .ai-brain-wrap { max-max-width: 400px; width: 100%; height:350px } }
@media (max-width:768px)  { .features-grid { grid-template-columns:1fr } .ai-card { display:none } .ai-brain-wrap { max-width:100%; height:260px } }

/* Logo Fix */

/* Logo sizing is controlled via Appearance → Customize → Logo & Branding.
   CSS custom properties are set by greenedge_logo_inline_css() in functions.php
   and consumed by components.css. Do not add hardcoded overrides here. */
