/* ============================================================================
   Flash-AI.pro — "Liquid Glass" system  (v7)
   A translucent, Apple-2026-leaning redesign: frosted glass panels floating
   over a slow living aurora, hairline iridescent borders, specular highlights,
   restrained gradient (reserved for thin accents — no more rainbow surfaces).
   All legacy class names preserved so every page lifts at once.
   ========================================================================== */

:root {
  /* base */
  --bg: #EEF1FB;
  --bg-2: #E6EAF8;
  --ink: #0A102E;
  --ink-soft: #1B2350;
  --dim: #515C86;
  --dim-2: #6B76A0;

  /* glass tokens */
  --glass: rgba(255,255,255,.55);
  --glass-strong: rgba(255,255,255,.72);
  --glass-dim: rgba(255,255,255,.40);
  --hair: rgba(255,255,255,.65);          /* top specular hairline */
  --line: rgba(20,30,80,.10);
  --line-bright: rgba(106,72,255,.32);

  /* accent ramp */
  --violet: #6A48FF;
  --violet-2: #8E6BFF;
  --cyan: #1597D6;
  --cyan-bright: #36D6FF;
  --mint: #0CC99B;

  /* restrained two-tone for type accents; full triad reserved for thin lines */
  --grad: linear-gradient(104deg, #6A48FF, #2BAAE2 58%, #0CC99B);
  --grad-soft: linear-gradient(104deg, #7C5CFF, #2BAAE2 70%);
  --grad-line: linear-gradient(100deg,#6A48FF,#2BAAE2 50%,#0CC99B);

  --stage: #060A1C;
  --max: 1160px;

  /* elevation */
  --e1: 0 2px 10px rgba(10,16,46,.05), 0 12px 34px rgba(10,16,46,.06);
  --e2: 0 1px 0 rgba(255,255,255,.6) inset, 0 12px 40px rgba(10,16,46,.10), 0 30px 70px rgba(10,16,46,.08);
  --e3: 0 1px 0 rgba(255,255,255,.7) inset, 0 24px 70px rgba(20,30,90,.16);
  --rad: 22px;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; background:var(--bg); }
body {
  background: var(--bg); color: var(--ink);
  font-family:'Outfit',system-ui,sans-serif; font-size:17px; line-height:1.66;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
  text-rendering:optimizeLegibility;
}

/* ===== living aurora field ===== */
body::before {
  content:''; position:fixed; inset:-25%; z-index:0; pointer-events:none;
  background:
    radial-gradient(38% 32% at 12% 6%,  rgba(106,72,255,.20), transparent 62%),
    radial-gradient(34% 30% at 90% 12%, rgba(43,170,226,.18), transparent 62%),
    radial-gradient(42% 36% at 78% 92%, rgba(12,201,155,.16), transparent 64%),
    radial-gradient(40% 34% at 18% 88%, rgba(124,92,255,.13), transparent 64%);
  filter:saturate(1.05);
  animation:auroraDrift 26s ease-in-out infinite alternate;
}
body::after { /* fine grain so the glass reads as glass, not flat fill */
  content:''; position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
}
@keyframes auroraDrift {
  0%   { transform:translate3d(0,0,0) scale(1);      }
  50%  { transform:translate3d(2.5%, -2%, 0) scale(1.08); }
  100% { transform:translate3d(-2%, 2.5%, 0) scale(1.04); }
}

/* floating glass orbs (injected by fx.js into .orbs) */
.orbs { position:fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden; }
.orb { position:absolute; border-radius:50%; filter:blur(2px);
  background:radial-gradient(circle at 32% 28%, rgba(255,255,255,.9), rgba(255,255,255,.05) 42%, transparent 60%);
  box-shadow:0 20px 60px rgba(40,40,120,.10); opacity:.5; mix-blend-mode:screen;
  animation:orbFloat linear infinite; }
@keyframes orbFloat { to { transform:translateY(-120vh) translateX(var(--drift,20px)); } }

main, nav, header, section, footer, .strip { position:relative; z-index:1; }
.display { font-family:'Unbounded',sans-serif; font-weight:400; }
.mono { font-family:'JetBrains Mono',monospace; }
.wrap { max-width:var(--max); margin:0 auto; padding:0 24px; }
.grad-text {
  background:var(--grad); background-size:200% 100%;
  -webkit-background-clip:text; background-clip:text; color:transparent;
  animation:gradShift 9s ease-in-out infinite;
}
@keyframes gradShift { 0%,100% { background-position:0% 50%; } 50% { background-position:100% 50%; } }

/* scroll progress (injected by fx.js) */
.scroll-prog { position:fixed; top:0; left:0; height:2.5px; width:0; z-index:99;
  background:var(--grad-line); box-shadow:0 0 12px rgba(106,72,255,.6); transition:width .08s linear; }

/* ============================ NAV ============================ */
nav { position:fixed; top:0; left:0; right:0; z-index:60;
  backdrop-filter:blur(22px) saturate(1.4); -webkit-backdrop-filter:blur(22px) saturate(1.4);
  background:rgba(255,255,255,.55); border-bottom:1px solid transparent;
  transition:background .35s, box-shadow .35s, border-color .35s, height .35s; }
nav::after { content:''; position:absolute; left:0; right:0; bottom:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(106,72,255,.25),rgba(12,201,155,.25),transparent); opacity:.0; transition:opacity .35s; }
nav.scrolled { background:rgba(255,255,255,.72); box-shadow:0 8px 30px rgba(10,16,46,.08); }
nav.scrolled::after { opacity:1; }
.nav-in { display:flex; align-items:center; justify-content:space-between; height:72px; gap:18px;
  transition:height .35s; }
nav.scrolled .nav-in { height:62px; }
.logo { display:flex; align-items:center; gap:11px; text-decoration:none; }
.logo svg { width:34px; height:34px; flex:none; transition:transform .5s cubic-bezier(.2,.8,.2,1); }
.logo:hover svg { transform:rotate(-8deg) scale(1.06); }
.logo .wordmark { font-family:'Unbounded',sans-serif; font-weight:400; font-size:1.02rem;
  letter-spacing:.05em; color:var(--ink); }
.logo .wordmark em { font-style:normal; background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.nav-center { display:flex; gap:30px; align-items:center; }
.nav-center a { color:var(--dim); text-decoration:none; font-size:.9rem; font-weight:500;
  padding:6px 2px; position:relative; transition:color .2s; }
.nav-center a::after { content:''; position:absolute; left:0; right:100%; bottom:0; height:2px;
  background:var(--grad-line); border-radius:2px; transition:right .3s cubic-bezier(.2,.8,.2,1); }
.nav-center a:hover, .nav-center a.here { color:var(--ink); }
.nav-center a:hover::after, .nav-center a.here::after { right:0; }
.nav-right { display:flex; align-items:center; gap:14px; }

.lang-dd { position:relative; }
.lang-dd summary { list-style:none; cursor:pointer; display:flex; align-items:center; gap:7px;
  font-family:'JetBrains Mono',monospace; font-size:.76rem; color:var(--ink); font-weight:500;
  border:1px solid var(--line); border-radius:10px; padding:8px 13px;
  background:var(--glass); backdrop-filter:blur(8px);
  transition:border-color .2s, background .2s; user-select:none; }
.lang-dd summary::-webkit-details-marker { display:none; }
.lang-dd summary::after { content:''; width:7px; height:7px; border-right:1.6px solid var(--dim);
  border-bottom:1.6px solid var(--dim); transform:rotate(45deg) translateY(-2px); transition:transform .2s; }
.lang-dd[open] summary::after { transform:rotate(225deg) translateY(-1px); }
.lang-dd summary:hover { border-color:var(--line-bright); background:var(--glass-strong); }
.lang-menu { position:absolute; right:0; top:calc(100% + 8px);
  background:var(--glass-strong); backdrop-filter:blur(20px) saturate(1.4);
  border:1px solid var(--hair); border-radius:14px; padding:6px; min-width:132px;
  box-shadow:var(--e2); animation:popIn .22s cubic-bezier(.2,.8,.2,1); }
@keyframes popIn { from { opacity:0; transform:translateY(-6px) scale(.98); } to { opacity:1; transform:none; } }
.lang-menu a { display:flex; justify-content:space-between; align-items:center; gap:14px;
  padding:9px 12px; border-radius:9px; text-decoration:none; color:var(--dim);
  font-size:.86rem; font-weight:500; transition:background .18s,color .18s; }
.lang-menu a:hover { background:rgba(106,72,255,.09); color:var(--ink); }
.lang-menu a.on { color:var(--violet); }
.lang-menu a.on::after { content:'✓'; font-size:.75rem; }

/* ============================ BUTTONS ============================ */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:13px 26px;
  border-radius:13px; text-decoration:none; font-size:.92rem; font-weight:600;
  white-space:nowrap; position:relative; overflow:hidden; isolation:isolate;
  transition:transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s; will-change:transform; }
.btn-grad { background:var(--grad); background-size:160% 100%; color:#fff;
  box-shadow:0 6px 22px rgba(106,72,255,.32), 0 1px 0 rgba(255,255,255,.4) inset; }
.btn-grad::before { /* sweeping specular sheen */
  content:''; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(115deg,transparent 20%,rgba(255,255,255,.45) 48%,transparent 70%);
  transform:translateX(-120%); transition:transform .7s cubic-bezier(.2,.8,.2,1); }
.btn-grad:hover { transform:translateY(-2px); box-shadow:0 14px 36px rgba(106,72,255,.46), 0 1px 0 rgba(255,255,255,.5) inset; background-position:100% 50%; }
.btn-grad:hover::before { transform:translateX(120%); }
.btn-line { border:1.5px solid var(--line-bright); color:var(--violet);
  background:var(--glass); backdrop-filter:blur(8px); }
.btn-line:hover { background:rgba(106,72,255,.08); transform:translateY(-2px); box-shadow:0 10px 26px rgba(106,72,255,.16); }
.nav-cta { padding:10px 20px; font-size:.84rem; }
@media (max-width:920px){ .nav-center { display:none; } }
@media (max-width:480px){ .logo .wordmark { font-size:.9rem; } .nav-cta { padding:9px 14px; font-size:.78rem; } }

/* ============================ HERO ============================ */
.hero { padding:160px 0 96px; }
.hero-grid { display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center; }
@media (max-width:980px){ .hero-grid { grid-template-columns:1fr; gap:42px; } }
.eyebrow { font-family:'JetBrains Mono',monospace; font-size:.72rem; letter-spacing:.24em;
  text-transform:uppercase; color:var(--violet); margin-bottom:20px; display:flex; align-items:center; gap:12px; font-weight:500; }
.eyebrow::before { content:''; width:30px; height:2px; background:var(--grad-line); border-radius:2px;
  box-shadow:0 0 8px rgba(106,72,255,.5); }
h1 { font-family:'Unbounded',sans-serif; font-weight:400; font-size:clamp(1.95rem,4.6vw,3.45rem);
  line-height:1.13; letter-spacing:-.015em; color:var(--ink); }
h2, h3, h4 { color:var(--ink); }
.hero-sub { margin-top:24px; max-width:50ch; color:var(--dim); font-size:1.06rem; }
.hero-cta { margin-top:38px; display:flex; gap:14px; flex-wrap:wrap; }
.hero-meta { margin-top:48px; display:flex; gap:18px; flex-wrap:wrap; }
.hm { font-family:'JetBrains Mono',monospace; font-size:.7rem; color:var(--dim); letter-spacing:.1em;
  padding:14px 18px; border-radius:14px; background:var(--glass); border:1px solid var(--hair);
  backdrop-filter:blur(10px); box-shadow:var(--e1); }
.hm b { display:block; font-size:1.05rem; color:var(--ink); font-weight:600; letter-spacing:0; margin-bottom:3px; }

/* hero word reveal hooks (set by fx.js) */
.h1-line { display:block; overflow:hidden; }
.h1-line > span { display:inline-block; transform:translateY(110%); transition:transform .9s cubic-bezier(.16,1,.3,1); }
.reveal-up .h1-line > span { transform:none; }

/* ===== HOLO STAGE (deep glass, stays dark) ===== */
.holo-stage { position:relative; aspect-ratio:1/1.02; max-width:560px; margin:0 auto; width:100%;
  border-radius:26px; overflow:hidden; background:
    radial-gradient(62% 55% at 50% 40%, rgba(106,72,255,.22), transparent 75%), var(--stage);
  box-shadow:0 40px 90px rgba(10,16,46,.32), 0 2px 0 rgba(255,255,255,.06) inset;
  transform:perspective(1200px) rotateX(var(--tx,0deg)) rotateY(var(--ty,0deg)) translateY(var(--plx,0px));
  transition:transform .25s ease-out; will-change:transform; }
.holo-stage::before { content:''; position:absolute; inset:0; border-radius:26px; padding:1.5px;
  background:linear-gradient(140deg, rgba(106,72,255,.9), rgba(54,214,255,.3) 40%, rgba(54,214,255,.3) 60%, rgba(12,201,155,.9));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none; }
.holo-stage::after { /* glass glare sweeping across the panel */
  content:''; position:absolute; inset:0; border-radius:26px; pointer-events:none;
  background:linear-gradient(125deg,rgba(255,255,255,.14),transparent 30%,transparent 70%,rgba(255,255,255,.06));
  mix-blend-mode:screen; }
#holo { position:absolute; inset:0; width:100%; height:100%; }
.holo-hud { position:absolute; left:18px; top:16px; right:18px; display:flex; justify-content:space-between;
  font-family:'JetBrains Mono',monospace; font-size:.62rem; letter-spacing:.18em; color:rgba(255,255,255,.5); z-index:2; }
.holo-hud .live { color:#5CFFC9; display:flex; align-items:center; gap:7px; }
.holo-hud .live::before { content:''; width:6px; height:6px; border-radius:50%; background:#5CFFC9;
  box-shadow:0 0 10px #5CFFC9; animation:blink 1.6s infinite; }
@keyframes blink { 50% { opacity:.25; } }
.holo-label { position:absolute; bottom:16px; left:0; right:0; text-align:center; z-index:2;
  font-family:'JetBrains Mono',monospace; font-size:.68rem; letter-spacing:.32em; color:#36D6FF;
  text-transform:uppercase; transition:opacity .5s; text-shadow:0 0 18px rgba(54,214,255,.7); }

/* ============================ SECTIONS ============================ */
section { padding:108px 0; }
.sec-head { max-width:720px; margin-bottom:56px; }
.sec-head h2 { font-family:'Unbounded',sans-serif; font-weight:400; font-size:clamp(1.5rem,3vw,2.3rem); line-height:1.22; margin-top:14px; letter-spacing:-.01em; }
.sec-head p { margin-top:16px; color:var(--dim); }
.center { text-align:center; margin-left:auto; margin-right:auto; }
.center .eyebrow { justify-content:center; }
.center .eyebrow::before { display:none; }

/* shared glass panel surface */
.cell, .acc, .step, .form-wrap, .hm,
.strip, footer { backdrop-filter:blur(14px) saturate(1.25); -webkit-backdrop-filter:blur(14px) saturate(1.25); }

/* bento */
.bento { display:grid; grid-template-columns:repeat(6,1fr); gap:20px; }
.cell { border:1px solid var(--hair); border-radius:var(--rad); padding:36px 32px;
  background:var(--glass); box-shadow:var(--e1); position:relative; overflow:hidden;
  transform:perspective(1100px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(var(--lift,0px));
  transition:box-shadow .4s cubic-bezier(.2,.8,.2,1), transform .3s cubic-bezier(.2,.8,.2,1), border-color .4s; }
/* cursor spotlight (vars set by fx.js) */
.cell::before, .acc::before { content:''; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  opacity:0; transition:opacity .4s;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,50%), rgba(106,72,255,.14), transparent 42%); }
.cell:hover::before, .acc:hover::before { opacity:1; }
.cell:hover { --lift:-6px; box-shadow:var(--e3); border-color:var(--line-bright); }
.cell.big { grid-column:span 6; display:grid; grid-template-columns:1fr 1fr; gap:36px; align-items:center; }
.cell.half { grid-column:span 3; }
@media (max-width:880px){ .cell.big { grid-template-columns:1fr; } .cell.half { grid-column:span 6; } }
.cell .ico { width:50px; height:50px; border-radius:15px; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(140deg, rgba(106,72,255,.16), rgba(43,170,226,.14));
  border:1px solid var(--line-bright); margin-bottom:20px; position:relative;
  box-shadow:0 8px 20px rgba(106,72,255,.14), 0 1px 0 rgba(255,255,255,.6) inset;
  transition:transform .4s cubic-bezier(.2,.8,.2,1); }
.cell:hover .ico { transform:translateY(-2px) scale(1.05) rotate(-3deg); }
.cell .ico svg { width:24px; height:24px; stroke:var(--violet); fill:none; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
.cell h3 { font-family:'Unbounded',sans-serif; font-weight:400; font-size:1.18rem; line-height:1.3; margin-bottom:12px; }
.cell p { font-size:.94rem; color:var(--dim); }
.cell ul { margin-top:16px; list-style:none; }
.cell li { font-size:.88rem; color:var(--dim); padding:9px 0 9px 26px; position:relative; border-top:1px solid var(--line); }
.cell li::before { content:'▸'; position:absolute; left:4px; color:var(--cyan); }
.cell .more { margin-top:20px; display:inline-flex; align-items:center; gap:7px; font-size:.88rem;
  color:var(--violet); font-weight:600; text-decoration:none; transition:gap .25s; }
.cell .more:hover { gap:11px; }

/* strip — glass band with count-up stats */
.strip { border-top:1px solid var(--hair); border-bottom:1px solid var(--line);
  background:var(--glass-dim); padding:36px 0; }
.strip-in { display:flex; justify-content:space-between; flex-wrap:wrap; gap:26px; }
.tk { font-family:'JetBrains Mono',monospace; font-size:.68rem; letter-spacing:.14em; color:var(--dim);
  position:relative; padding-left:18px; }
.tk::before { content:''; position:absolute; left:0; top:4px; bottom:4px; width:2px; border-radius:2px;
  background:var(--grad-line); opacity:.5; }
.tk b { display:block; font-family:'Unbounded',sans-serif; font-weight:400; font-size:1.5rem;
  color:var(--ink); margin-bottom:4px; letter-spacing:0; }

/* accord cards */
.acc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
@media (max-width:880px){ .acc-grid { grid-template-columns:1fr; } }
.acc { border:1px solid var(--hair); border-radius:var(--rad); padding:34px 30px; background:var(--glass);
  box-shadow:var(--e1); text-decoration:none; color:var(--ink); display:block;
  transform:perspective(1100px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(var(--lift,0px));
  transition:box-shadow .4s cubic-bezier(.2,.8,.2,1), transform .3s cubic-bezier(.2,.8,.2,1); position:relative; overflow:hidden; }
.acc:hover { --lift:-6px; box-shadow:var(--e3); }
.acc::after { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--grad-line); opacity:0; transition:opacity .35s; }
.acc:hover::after { opacity:1; }
.acc .mono-top { font-family:'JetBrains Mono',monospace; font-size:.66rem; color:var(--dim);
  letter-spacing:.14em; display:flex; justify-content:space-between; position:relative; z-index:1; }
.acc .mono-top span:last-child { color:var(--mint); font-weight:600; }
.acc h3 { font-family:'Unbounded',sans-serif; font-weight:400; font-size:1.18rem; margin:18px 0 12px; line-height:1.3; position:relative; z-index:1; }
.acc p { font-size:.92rem; color:var(--dim); position:relative; z-index:1; }

/* page hero */
.page-hero { padding:170px 0 64px; }
.page-hero h1 { max-width:20ch; }
.crumbs { font-family:'JetBrains Mono',monospace; font-size:.7rem; color:var(--dim); margin-bottom:26px; letter-spacing:.12em; }
.crumbs a { color:var(--dim); text-decoration:none; } .crumbs a:hover { color:var(--violet); }

/* prose / duo */
.duo { display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:start; }
@media (max-width:880px){ .duo { grid-template-columns:1fr; gap:36px; } }
.prose p + p { margin-top:16px; }
.prose p { color:var(--dim); font-size:.99rem; }
.prose strong { color:var(--ink); font-weight:600; }
.prose h3 { font-family:'Unbounded',sans-serif; font-weight:400; font-size:1.18rem; margin:36px 0 14px; }
.callout { border-left:3px solid; border-image:var(--grad-line) 1; padding:18px 24px; margin:28px 0;
  background:var(--glass); border-radius:0 16px 16px 0; font-size:.95rem; color:var(--ink);
  box-shadow:var(--e1); backdrop-filter:blur(10px); }

/* diagram panel (deep glass) */
.diagram { border-radius:var(--rad); background:
    radial-gradient(60% 50% at 50% 0%, rgba(106,72,255,.18), transparent 70%), var(--stage);
  padding:30px; position:sticky; top:96px;
  box-shadow:0 30px 70px rgba(10,16,46,.26), 0 1px 0 rgba(255,255,255,.06) inset; }
.diagram svg { width:100%; height:auto; display:block; }
.diagram .cap { margin-top:14px; font-family:'JetBrains Mono',monospace; font-size:.66rem;
  letter-spacing:.16em; color:rgba(255,255,255,.5); text-align:center; text-transform:uppercase; }
@media (max-width:880px){ .diagram { position:static; } }

/* steps */
.steps { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; counter-reset:s; }
@media (max-width:880px){ .steps { grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .steps { grid-template-columns:1fr; } }
.step { border:1px solid var(--hair); border-radius:18px; padding:28px 24px; background:var(--glass);
  transform:perspective(1100px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(var(--lift,0px));
  box-shadow:var(--e1); transition:transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .35s; }
.step:hover { --lift:-4px; box-shadow:var(--e2); }
.step::before { counter-increment:s; content:counter(s,decimal-leading-zero);
  font-family:'JetBrains Mono',monospace; font-size:.74rem; color:var(--violet); letter-spacing:.2em; font-weight:600; }
.step h4 { font-family:'Unbounded',sans-serif; font-weight:400; font-size:.96rem; margin:12px 0 8px; }
.step p { font-size:.86rem; color:var(--dim); }

/* form */
.form-wrap { max-width:680px; margin:0 auto; border:1px solid var(--hair); border-radius:var(--rad);
  padding:46px; background:var(--glass-strong); box-shadow:var(--e2); position:relative; }
.f-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:16px; }
@media (max-width:600px){ .f-row { grid-template-columns:1fr; } .form-wrap { padding:32px 22px; } }
label { display:block; font-family:'JetBrains Mono',monospace; font-size:.66rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--dim); margin-bottom:8px; font-weight:500; }
input, select, textarea { width:100%; background:rgba(255,255,255,.6); border:1.5px solid var(--line);
  border-radius:12px; padding:13px 16px; color:var(--ink); font-family:'Outfit',sans-serif;
  font-size:.95rem; transition:border-color .25s, box-shadow .25s, background .25s; }
input:focus, select:focus, textarea:focus { outline:none; border-color:var(--violet);
  box-shadow:0 0 0 4px rgba(106,72,255,.14); background:#fff; }
textarea { resize:vertical; min-height:110px; }
.f-submit { width:100%; border:none; cursor:pointer; margin-top:8px; font-family:'Outfit',sans-serif; }

/* footer */
footer { border-top:1px solid var(--hair); padding:44px 0; background:var(--glass-dim); }
.foot-in { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px;
  font-size:.82rem; color:var(--dim); }
.foot-links { display:flex; gap:24px; }
.foot-links a { color:var(--dim); text-decoration:none; font-size:.84rem; font-weight:500; transition:color .2s; }
.foot-links a:hover { color:var(--violet); }

/* ===== lifecycle visual — two rotating wheels, steps lighting one by one ===== */
.lifecycle-wrap { max-width:980px; margin:0 auto 64px; border-radius:26px; padding:34px 30px 26px;
  background:radial-gradient(70% 50% at 50% 0%, rgba(106,72,255,.16), transparent 70%), var(--stage);
  box-shadow:0 30px 70px rgba(10,16,46,.30), 0 1px 0 rgba(255,255,255,.06) inset;
  position:relative; overflow:hidden; }
.lifecycle-wrap::before { content:''; position:absolute; inset:0; border-radius:26px; padding:1.5px;
  background:linear-gradient(140deg, rgba(106,72,255,.7), rgba(54,214,255,.2) 45%, rgba(12,201,155,.7));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none; }
.lc-head { display:flex; justify-content:space-between; align-items:flex-end; gap:18px;
  margin-bottom:20px; flex-wrap:wrap; }
.lc-head h3 { font-family:'Unbounded',sans-serif; font-weight:400; font-size:1.12rem; color:#fff; line-height:1.3; }
.lc-head p { color:#8E96B8; font-size:.85rem; margin-top:7px; max-width:52ch; }
.lc-now { font-family:'JetBrains Mono',monospace; font-size:.66rem; letter-spacing:.16em;
  color:#8E96B8; display:flex; gap:14px; align-items:baseline; white-space:nowrap; }
.lc-now b { color:#5CFFC9; font-weight:500; font-size:.78rem; letter-spacing:.22em; text-transform:uppercase;
  text-shadow:0 0 14px rgba(92,255,201,.5); transition:opacity .3s; }
#lifecycle { width:100%; height:auto; display:block; }
#lifecycle text { user-select:none; }
#lifecycle .lc-center { font-family:'Unbounded',sans-serif; font-size:15px; fill:#fff; letter-spacing:.04em; }
#lifecycle .lc-centersub { font-family:'Outfit',sans-serif; font-size:9.5px; fill:#8E96B8; }
#lifecycle .spin { animation:lcspin 30s linear infinite; }
@keyframes lcspin { to { transform:rotate(360deg); } }
#lifecycle .ring-dash { opacity:.4; }
#lifecycle .arr { fill:#7FD8FF; opacity:.75; }
#lifecycle .ring-glow { opacity:.09; transition:opacity .7s; }
#lifecycle .ring-main { opacity:.5; transition:opacity .7s; }
#lifecycle .wheel.live .ring-glow { opacity:.22; }
#lifecycle .wheel.live .ring-main { opacity:1; }
#lifecycle .st .halo { opacity:0; transition:opacity .5s; }
#lifecycle .st .dot { transition:transform .5s cubic-bezier(.2,.8,.2,1), fill .5s;
  transform-box:fill-box; transform-origin:center; }
#lifecycle .st .num { font-family:'JetBrains Mono',monospace; font-size:9.5px; fill:#5A6690;
  letter-spacing:.08em; transition:fill .5s; }
#lifecycle .st .lbl { font-family:'Outfit',sans-serif; font-size:13.5px; font-weight:600;
  fill:#8E96B8; transition:fill .5s, font-size .5s; }
#lifecycle .st.on .halo { opacity:.16; }
#lifecycle .st.on .dot { transform:scale(1.75); fill:#fff; }
#lifecycle .st.on .num { fill:#9F86FF; }
#lifecycle .st.on .lbl { fill:#fff; }
#lifecycle .flow { stroke-dasharray:5 9; animation:lcflow 1.1s linear infinite;
  opacity:.45; transition:opacity .5s, filter .5s; }
#lifecycle .flow.hot { opacity:1; filter:drop-shadow(0 0 6px rgba(92,255,201,.8)); }
@keyframes lcflow { to { stroke-dashoffset:-14; } }
#lifecycle .core-t { font-family:'JetBrains Mono',monospace; font-size:8.5px; letter-spacing:.18em; fill:#C8D0F0; }
#lifecycle .row-n { font-family:'Outfit',sans-serif; font-size:11px; font-weight:600; fill:#E8ECFF; }
#lifecycle .row-t { font-family:'Outfit',sans-serif; font-size:9.5px; fill:#8E96B8; }
#lifecycle .bar-text { font-family:'JetBrains Mono',monospace; font-size:10.5px; letter-spacing:1.5px; fill:#C8D0F0; }
@media (max-width:640px){ .lifecycle-wrap { padding:24px 14px 18px; } .lc-now { display:none; } }

/* ===== reveal (cascade, blur-in) — uses `translate` so `transform` stays free for tilt ===== */
.rv { opacity:0; translate:0 26px; filter:blur(8px);
  transition:opacity .8s cubic-bezier(.16,1,.3,1), translate .8s cubic-bezier(.16,1,.3,1), filter .8s ease;
  transition-delay:var(--rvd,0ms); }
.rv.in { opacity:1; translate:0 0; filter:none; }

/* ===== kinetic title — words rise out of a blur ===== */
h1.kinetic .w { display:inline-block;
  transform:translateY(.9em) rotate(4deg); opacity:0; filter:blur(10px);
  transition:transform .95s cubic-bezier(.16,1,.3,1), opacity .6s ease, filter .85s ease; }
h1.kinetic.go .w { transform:none; opacity:1; filter:none; }
h1 .gw { background:var(--grad); background-size:200% 100%;
  -webkit-background-clip:text; background-clip:text; color:transparent;
  animation:gradShift 9s ease-in-out infinite; }

/* ===== tech marquee (injected on home pages) ===== */
.marquee { position:relative; z-index:1; overflow:hidden; padding:20px 0;
  -webkit-mask:linear-gradient(90deg,transparent,#000 14%,#000 86%,transparent);
  mask:linear-gradient(90deg,transparent,#000 14%,#000 86%,transparent); }
.mq-track { display:flex; align-items:center; gap:36px; width:max-content;
  font-family:'JetBrains Mono',monospace; font-size:.72rem; letter-spacing:.24em;
  color:var(--dim-2); white-space:nowrap; animation:mq 30s linear infinite; }
.mq-track i { font-style:normal; color:var(--violet); opacity:.55; font-size:.6rem; }
.marquee:hover .mq-track { animation-play-state:paused; }
@keyframes mq { to { transform:translateX(-50%); } }

/* ===== button ripple ===== */
.btn .ripple { position:absolute; border-radius:50%; pointer-events:none;
  background:radial-gradient(circle, rgba(255,255,255,.55), rgba(255,255,255,0) 65%);
  transform:scale(0); animation:rip .6s ease-out forwards; }
@keyframes rip { to { transform:scale(3.2); opacity:0; } }

/* ===== cursor aura ===== */
.cursor-aura { position:fixed; left:0; top:0; width:430px; height:430px; border-radius:50%;
  pointer-events:none; z-index:2; opacity:.8; will-change:transform;
  background:radial-gradient(circle, rgba(106,72,255,.09), rgba(54,214,255,.05) 42%, transparent 66%); }

/* ===== soft page transitions ===== */
@keyframes pageIn { from { opacity:0; } to { opacity:1; } }
body { animation:pageIn .5s ease both; }
body.page-leave { opacity:0; transition:opacity .24s ease; }

@media (prefers-reduced-motion: reduce) {
  .rv { opacity:1; translate:none; filter:none; transition:none; }
  body { animation:none; }
  body::before, .orb, .grad-text, .btn-grad, .holo-stage, .mq-track,
  #lifecycle .spin, #lifecycle .flow { animation:none !important; }
  html { scroll-behavior:auto; }
  h1.kinetic .w { transform:none !important; opacity:1 !important; filter:none !important; }
}
:focus-visible { outline:2.5px solid var(--violet); outline-offset:3px; }
