/* ViArc v3 — video wall & sections */
/* ── VIDEO WALL PORTFOLIO ── */
.wall{padding:120px 0 60px;background:var(--bg);position:relative;overflow:hidden}
.wall .head{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:40px}
.wall h2{font-size:clamp(40px,5.6vw,84px);letter-spacing:-.03em;line-height:.95;font-weight:700;max-width:18ch}
.wall h2 .ital{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--amber)}
.wall h2 .ital.red{color:var(--red)}
.wall .head .right{display:flex;gap:10px;align-items:center;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}

/* layout: NOW SHOWING (40%) + WALL (60%) */
.wall-layout{display:grid;grid-template-columns:.95fr 1.05fr;gap:18px;align-items:start}

/* NOW SHOWING — the featured player */
.now{position:sticky;top:90px;background:var(--bg-2);border:1px solid var(--line-2);border-radius:22px;padding:18px;display:flex;flex-direction:column;gap:14px}
.now .stage{aspect-ratio:9/16;max-height:680px;border-radius:16px;background:#000;position:relative;overflow:hidden;border:1px solid var(--line-2)}
.now .stage .layer{position:absolute;inset:0;opacity:0;transition:opacity .6s ease}
.now .stage .layer.on{opacity:1}
.now .stage .layer .canvas{position:absolute;inset:0}
.now .stage .layer .grain{position:absolute;inset:0;background:repeating-linear-gradient(45deg, rgba(255,255,255,.05) 0 2px, transparent 2px 4px);mix-blend-mode:overlay;pointer-events:none}
.now .stage .layer .vignette{position:absolute;inset:0;background:radial-gradient(ellipse at center, transparent 35%, rgba(0,0,0,.65) 100%);pointer-events:none}
.now .stage .layer .scan{position:absolute;left:0;right:0;height:30%;background:linear-gradient(to bottom, transparent, rgba(255,255,255,.08), transparent);animation:scan 4s linear infinite;pointer-events:none}
@keyframes scan{0%{top:-30%}100%{top:100%}}
.now .stage .badge{position:absolute;top:14px;left:14px;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.08em;background:rgba(0,0,0,.55);color:var(--ink);padding:5px 9px;border-radius:6px;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);text-transform:uppercase;z-index:4}
.now .stage .badge.live::before{content:"●";color:var(--red);margin-right:6px;animation:pulse 1s infinite}
.now .stage .rec{position:absolute;top:14px;right:14px;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.08em;background:rgba(0,0,0,.55);color:var(--ink);padding:5px 9px;border-radius:6px;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);z-index:4}
.now .stage .caption{position:absolute;left:14px;right:14px;bottom:60px;color:var(--ink);font-family:"Instrument Serif",serif;font-style:italic;font-size:36px;line-height:.95;letter-spacing:-.02em;text-shadow:0 2px 14px rgba(0,0,0,.45);max-width:14ch;z-index:4}
.now .stage .play{position:absolute;left:14px;bottom:14px;width:48px;height:48px;border-radius:50%;background:var(--lime);color:var(--bg);display:flex;align-items:center;justify-content:center;font-size:16px;transition:.3s;z-index:5;cursor:pointer}
.now .stage .play:hover{background:var(--red);color:var(--ink);transform:scale(1.08)}
.now .stage .timeline{position:absolute;left:74px;right:14px;bottom:24px;height:4px;background:rgba(255,255,255,.18);border-radius:2px;overflow:hidden;z-index:5}
.now .stage .timeline::after{content:"";position:absolute;left:0;top:0;bottom:0;width:38%;background:var(--lime);animation:prog 6s ease-in-out infinite}
.now .stage .timecodes{position:absolute;left:74px;right:14px;bottom:6px;display:flex;justify-content:space-between;font-family:"JetBrains Mono",monospace;font-size:10px;color:rgba(255,255,255,.7);z-index:5}

.now .info{display:grid;grid-template-columns:1fr auto;gap:14px;align-items:start;padding:10px 6px 0}
.now .info .name{font-size:22px;font-weight:700;letter-spacing:-.015em;line-height:1.1}
.now .info .brand{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.08em;color:var(--ink-2);text-transform:uppercase;margin-top:4px}
.now .info .ctr{text-align:right}
.now .info .ctr b{font-size:28px;font-weight:700;letter-spacing:-.02em;line-height:1;color:var(--lime)}
.now .info .ctr span{display:block;font-family:"JetBrains Mono",monospace;font-size:9px;letter-spacing:.08em;color:var(--ink-2);text-transform:uppercase;margin-top:2px}
.now .meta-row{display:flex;flex-wrap:wrap;gap:6px;padding:0 6px}
.now .meta-row .chip{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.06em;text-transform:uppercase;background:var(--bg-3);color:var(--ink);padding:6px 10px;border-radius:999px;border:1px solid var(--line)}
.now .desc{padding:0 6px;font-size:14px;line-height:1.5;color:var(--ink-2);max-width:46ch}

/* WALL — 3 columns scrolling */
.wall-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;height:760px;position:relative;mask-image:linear-gradient(to bottom, transparent 0%, #000 8%, #000 92%, transparent 100%);-webkit-mask-image:linear-gradient(to bottom, transparent 0%, #000 8%, #000 92%, transparent 100%)}
.wall-col{overflow:hidden;position:relative;border-radius:18px}
.wall-track{display:flex;flex-direction:column;gap:14px;animation:wall-up 38s linear infinite;will-change:transform}
.wall-col.down .wall-track{animation:wall-down 44s linear infinite}
.wall-col.fast .wall-track{animation-duration:30s}
.wall-grid:hover .wall-track{animation-play-state:paused}
@keyframes wall-up{from{transform:translateY(0)}to{transform:translateY(-50%)}}
@keyframes wall-down{from{transform:translateY(-50%)}to{transform:translateY(0)}}

.vcard{position:relative;aspect-ratio:9/16;border-radius:14px;overflow:hidden;cursor:pointer;flex-shrink:0;background:#000;border:1px solid var(--line-2);transition:transform .35s cubic-bezier(.2,.7,.2,1), border-color .25s}
.vcard:hover{transform:scale(1.02);border-color:var(--lime)}
.vcard.active{border-color:var(--red);box-shadow:0 0 0 2px var(--red), 0 20px 40px -10px rgba(255,61,46,.4)}
.vcard .canvas{position:absolute;inset:0}
.vcard .grain{position:absolute;inset:0;background:repeating-linear-gradient(45deg, rgba(255,255,255,.05) 0 2px, transparent 2px 4px);mix-blend-mode:overlay;pointer-events:none}
.vcard .vignette{position:absolute;inset:0;background:radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,.6) 100%);pointer-events:none}
.vcard .top{position:absolute;top:8px;left:8px;right:8px;display:flex;justify-content:space-between;font-family:"JetBrains Mono",monospace;font-size:9px;letter-spacing:.08em;color:rgba(255,255,255,.92);text-transform:uppercase;z-index:3}
.vcard .top span{background:rgba(0,0,0,.55);padding:3px 6px;border-radius:5px;backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.08)}
.vcard .bot{position:absolute;left:8px;right:8px;bottom:8px;color:var(--ink);font-family:"Instrument Serif",serif;font-style:italic;font-size:18px;line-height:1;letter-spacing:-.02em;text-shadow:0 2px 10px rgba(0,0,0,.45);z-index:3;display:flex;justify-content:space-between;align-items:flex-end;gap:8px}
.vcard .bot .play{width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.92);color:var(--bg);display:flex;align-items:center;justify-content:center;font-size:10px;flex-shrink:0;transition:.25s}
.vcard:hover .bot .play{background:var(--lime)}
.vcard.active .bot .play{background:var(--red);color:var(--ink)}

/* canvases — varied gradient styles per "video" */
.canvas-1{background:linear-gradient(135deg,#FF3D2E 0%,#2A1E5C 100%)}
.canvas-2{background:conic-gradient(from 30deg at 50% 50%, #FFC56B, #FF3D2E, #2A1E5C, #FFC56B)}
.canvas-3{background:radial-gradient(circle at 30% 30%, #D6F23C, #0D0C0F 70%)}
.canvas-4{background:linear-gradient(200deg,#2A1E5C 0%,#FF3D2E 100%)}
.canvas-5{background:linear-gradient(135deg,#FFC56B 0%,#FF3D2E 70%,#1F1A28 100%)}
.canvas-6{background:radial-gradient(circle at 70% 30%, #FF3D2E, #0D0C0F 65%)}
.canvas-7{background:conic-gradient(from 200deg at 50% 50%, #D6F23C, #2A1E5C, #FF3D2E, #D6F23C)}
.canvas-8{background:linear-gradient(160deg,#0D0C0F 0%,#FF3D2E 130%)}
.canvas-9{background:linear-gradient(135deg,#FFC56B 0%,#2A1E5C 90%)}
.canvas-10{background:radial-gradient(circle at 50% 70%, #D6F23C 0%, #2A1E5C 65%)}
.canvas-11{background:linear-gradient(200deg, #FF3D2E, #FFC56B 80%, #D6F23C)}
.canvas-12{background:conic-gradient(from 90deg at 30% 30%, #2A1E5C, #FF3D2E, #FFC56B, #2A1E5C)}

/* gentle animated overlay on each canvas */
.vcard .canvas::after{content:"";position:absolute;inset:-20%;background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.18), transparent 50%);animation:swirl 18s linear infinite;pointer-events:none}

.wall .ledger{margin-top:36px;display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.wall .ledger .cell{padding:18px 20px;border:1px solid var(--line-2);border-radius:14px;background:var(--bg-2)}
.wall .ledger .cell .k{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.08em;color:var(--ink-2);text-transform:uppercase}
.wall .ledger .cell .v{font-size:30px;font-weight:700;letter-spacing:-.02em;line-height:1;margin-top:8px}
.wall .ledger .cell .v .ital{color:var(--red);font-weight:400}

/* ── PROCESS ── */
.process{padding:140px 0;background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.process .head{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:48px}
.process h2{font-size:clamp(40px,5.6vw,84px);letter-spacing:-.03em;line-height:.95;font-weight:700;max-width:20ch}
.process h2 .ital{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--lime)}
.process h2 .ital.red{color:var(--red)}

.timeline{position:relative;padding:60px 0 20px}
.timeline .bar{position:absolute;left:0;right:0;top:74px;height:2px;background:var(--line-2)}
.timeline .bar::after{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:var(--red);animation:drawline 6s ease-in-out infinite alternate}
@keyframes drawline{from{width:0}to{width:100%}}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;position:relative;z-index:2}
.step{display:flex;flex-direction:column;gap:14px}
.step .dot{width:18px;height:18px;border-radius:50%;background:var(--bg);border:2px solid var(--ink-2);position:relative;transition:.3s}
.step .dot::after{content:"";position:absolute;inset:3px;border-radius:50%;background:transparent;transition:.3s}
.step:hover .dot{border-color:var(--red);transform:scale(1.2)}
.step:hover .dot::after{background:var(--red)}
.step .time{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.08em;color:var(--ink-2);text-transform:uppercase}
.step .num{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;font-size:64px;color:var(--red);line-height:1;letter-spacing:-.02em}
.step h3{font-size:24px;font-weight:700;letter-spacing:-.015em;line-height:1.1;margin-top:4px}
.step p{font-size:14.5px;line-height:1.5;color:var(--ink-2);max-width:32ch}
.step .vis{margin-top:8px;height:100px;border-radius:12px;border:1px solid var(--line-2);background:var(--bg);position:relative;overflow:hidden}
.step .vis .v-inner{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.step.s1 .v-inner{background:linear-gradient(90deg, transparent 0%, var(--bg) 100%)}
.step.s1 .v-inner::before{content:"BRIEF";font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.2em;color:var(--ink-2);text-transform:uppercase;position:absolute;left:14px;top:14px}
.step.s1 .v-inner::after{content:"";width:80%;height:6px;background:linear-gradient(90deg, var(--lime) 0%, var(--ink-3) 100%);border-radius:3px;position:absolute;left:14px;bottom:18px}
.step.s2 .v-inner{display:flex;gap:5px;justify-content:center;align-items:flex-end;padding:14px}
.step.s2 .v-inner i{display:block;width:6px;background:var(--ink-3);border-radius:3px;animation:bar 1.4s ease-in-out infinite}
.step.s2 .v-inner i:nth-child(1){height:25%}
.step.s2 .v-inner i:nth-child(2){height:55%;background:var(--red);animation-delay:.1s}
.step.s2 .v-inner i:nth-child(3){height:40%;animation-delay:.2s}
.step.s2 .v-inner i:nth-child(4){height:70%;background:var(--lime);animation-delay:.3s}
.step.s2 .v-inner i:nth-child(5){height:45%;animation-delay:.4s}
.step.s2 .v-inner i:nth-child(6){height:60%;background:var(--red);animation-delay:.5s}
.step.s2 .v-inner i:nth-child(7){height:35%;animation-delay:.6s}
.step.s2 .v-inner i:nth-child(8){height:50%;animation-delay:.7s}
.step.s2 .v-inner i:nth-child(9){height:65%;background:var(--amber);animation-delay:.8s}
.step.s2 .v-inner i:nth-child(10){height:30%;animation-delay:.9s}
@keyframes bar{50%{transform:scaleY(1.4)}}
.step.s3 .v-inner{display:grid;grid-template-columns:repeat(8,1fr);gap:3px;padding:14px}
.step.s3 .v-inner i{display:block;aspect-ratio:1;background:var(--ink-3);border-radius:3px;animation:flicker 3s ease-in-out infinite}
.step.s3 .v-inner i:nth-child(3){background:var(--red);animation-delay:.4s}
.step.s3 .v-inner i:nth-child(7){background:var(--lime);animation-delay:.7s}
.step.s3 .v-inner i:nth-child(10){background:var(--amber);animation-delay:1s}
.step.s3 .v-inner i:nth-child(14){background:var(--red);animation-delay:1.3s}
@keyframes flicker{50%{opacity:.35}}
.step.s4 .v-inner{padding:14px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.step.s4 .v-inner span{font-family:"JetBrains Mono",monospace;font-size:10px;padding:5px 8px;border-radius:6px;background:var(--bg-3);color:var(--ink);letter-spacing:.06em}
.step.s4 .v-inner span.a{background:var(--red);color:var(--ink)}
.step.s4 .v-inner span.b{background:var(--lime);color:var(--bg)}

/* ── CAPABILITIES (bento) ── */
.caps{padding:120px 0;background:var(--bg);position:relative;overflow:hidden}
.caps .head{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:40px}
.caps h2{font-size:clamp(40px,5.6vw,84px);letter-spacing:-.03em;line-height:.95;font-weight:700;max-width:22ch}
.caps h2 .ital{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--amber)}

.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.bx{background:var(--bg-2);border:1px solid var(--line-2);border-radius:20px;padding:24px;display:flex;flex-direction:column;gap:14px;position:relative;overflow:hidden;transition:.35s}
.bx:hover{border-color:var(--ink);transform:translateY(-4px)}
.bx h4{font-size:22px;font-weight:700;letter-spacing:-.015em;line-height:1.15;max-width:18ch}
.bx h4 .ital{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400}
.bx p{font-size:14px;line-height:1.5;color:var(--ink-2);margin-top:auto;max-width:38ch}
.bx .lbl{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.08em;color:var(--ink-2);text-transform:uppercase}
.bx.b1{grid-column:span 2;grid-row:span 2;background:var(--ink);color:var(--bg);border-color:var(--ink)}
.bx.b1 p{color:color-mix(in oklab, var(--bg) 70%, transparent)}
.bx.b1 .lbl{color:color-mix(in oklab, var(--bg) 60%, transparent)}
.bx.b1 h4{font-size:42px;line-height:1;letter-spacing:-.025em;max-width:13ch;font-weight:700}
.bx.b1 h4 .ital{color:var(--red)}
.bx.b2{grid-column:span 2;grid-row:span 1;background:var(--red);color:var(--ink);border-color:var(--red)}
.bx.b2 p{color:color-mix(in oklab, var(--ink) 80%, transparent)}
.bx.b2 .lbl{color:color-mix(in oklab, var(--ink) 65%, transparent)}
.bx.b3{grid-column:span 1;grid-row:span 1}
.bx.b4{grid-column:span 1;grid-row:span 1;background:var(--lime);color:var(--bg);border-color:var(--lime)}
.bx.b4 p{color:color-mix(in oklab, var(--bg) 75%, transparent)}
.bx.b4 .lbl{color:color-mix(in oklab, var(--bg) 70%, transparent)}
.bx.b5{grid-column:span 1;grid-row:span 1}
.bx.b6{grid-column:span 1;grid-row:span 1}
.bx.b7{grid-column:span 2;grid-row:span 1;background:var(--amber);color:var(--bg);border-color:var(--amber)}
.bx.b7 p{color:color-mix(in oklab, var(--bg) 75%, transparent)}
.bx.b7 .lbl{color:color-mix(in oklab, var(--bg) 65%, transparent)}

/* small visualization elements within bento */
.lang-orbit{position:relative;width:100%;flex:1;min-height:120px}
.lang-orbit .core{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:74px;height:74px;border-radius:50%;background:var(--lime);color:var(--bg);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:20px;letter-spacing:-.02em;font-family:"Instrument Serif",serif;font-style:italic;animation:bob 4s ease-in-out infinite}
.lang-orbit .ring{position:absolute;left:50%;top:50%;border:1px dashed rgba(241,236,224,.22);border-radius:50%;transform:translate(-50%,-50%);animation:spinslow 26s linear infinite}
.lang-orbit .ring.r1{width:150px;height:150px}
.lang-orbit .ring.r2{width:250px;height:250px;animation-duration:38s;animation-direction:reverse}
.lang-orbit .chip{position:absolute;background:rgba(241,236,224,.06);border:1px solid rgba(241,236,224,.22);color:var(--bg);font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.06em;padding:5px 9px;border-radius:8px;color:var(--ink)}
.lang-orbit .chip.hot{background:var(--red);color:var(--ink);border-color:var(--red)}
.lang-orbit .chip.c1{left:50%;top:6px;transform:translateX(-50%)}
.lang-orbit .chip.c2{right:6px;top:38%}
.lang-orbit .chip.c3{left:50%;bottom:6px;transform:translateX(-50%)}
.lang-orbit .chip.c4{left:6px;top:55%}
.lang-orbit .chip.c5{right:20%;top:12%}

.ar-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;width:100%;margin-top:auto}
.ar-grid div{aspect-ratio:1;border-radius:6px;background:rgba(13,12,15,.18);display:flex;align-items:center;justify-content:center;font-family:"JetBrains Mono",monospace;font-size:9px;color:var(--bg);font-weight:500}
.ar-grid div.a{background:var(--bg);color:var(--lime)}

.brand-tick{display:flex;gap:6px;margin-top:auto;flex-wrap:wrap}
.brand-tick span{font-family:"JetBrains Mono",monospace;font-size:9px;padding:5px 8px;border-radius:5px;background:rgba(0,0,0,.18);color:var(--bg);letter-spacing:.06em}

.rhythm-vis{display:flex;align-items:flex-end;gap:4px;height:60px;margin-top:auto}
.rhythm-vis i{flex:1;background:currentColor;border-radius:3px;opacity:.4;animation:bar 1.6s ease-in-out infinite}
.rhythm-vis i:nth-child(2n){opacity:.7}
.rhythm-vis i:nth-child(3n){opacity:1}
.rhythm-vis i:nth-child(1){height:30%;animation-delay:0s}
.rhythm-vis i:nth-child(2){height:55%;animation-delay:.1s}
.rhythm-vis i:nth-child(3){height:80%;animation-delay:.2s}
.rhythm-vis i:nth-child(4){height:45%;animation-delay:.3s}
.rhythm-vis i:nth-child(5){height:70%;animation-delay:.4s}
.rhythm-vis i:nth-child(6){height:35%;animation-delay:.5s}
.rhythm-vis i:nth-child(7){height:60%;animation-delay:.6s}
.rhythm-vis i:nth-child(8){height:90%;animation-delay:.7s}
.rhythm-vis i:nth-child(9){height:40%;animation-delay:.8s}
.rhythm-vis i:nth-child(10){height:55%;animation-delay:.9s}

.safe-vis{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:auto;font-family:"JetBrains Mono",monospace;font-size:10px}
.safe-vis div{display:flex;justify-content:space-between;padding:6px 8px;background:rgba(13,12,15,.08);border-radius:6px;color:var(--bg)}
.safe-vis div::after{content:"✓";color:var(--bg);font-weight:700}

.cost-vis{margin-top:auto;display:flex;align-items:baseline;gap:6px}
.cost-vis .from{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--ink-2);text-decoration:line-through}
.cost-vis .to{font-size:36px;font-weight:700;letter-spacing:-.02em;color:var(--ink)}
.cost-vis .to .ital{font-family:"Instrument Serif",serif;font-style:italic;color:var(--red);font-weight:400}

/* ── METRICS ── */
.metrics{padding:140px 0;background:var(--ink);color:var(--bg);position:relative;overflow:hidden}
.metrics::before{content:"";position:absolute;right:-30vmax;top:-20vmax;width:80vmax;height:80vmax;background:radial-gradient(circle, var(--red), transparent 60%);opacity:.08;filter:blur(60px);pointer-events:none}
.metrics .head{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:48px;position:relative;z-index:2}
.metrics h2{font-size:clamp(40px,5.6vw,84px);letter-spacing:-.03em;line-height:.95;font-weight:700;max-width:18ch;color:var(--bg)}
.metrics h2 .ital{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--red)}
.metrics .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;position:relative;z-index:2}
.met{background:color-mix(in oklab, var(--ink) 92%, var(--bg));border:1px solid color-mix(in oklab, var(--bg) 14%, var(--ink));border-radius:20px;padding:28px;display:flex;flex-direction:column;gap:14px;transition:.3s;min-height:240px}
.met:hover{background:var(--red);color:var(--ink);border-color:var(--red);transform:translateY(-4px)}
.met:hover p,.met:hover .mono{color:color-mix(in oklab, var(--ink) 85%, transparent)}
.met:hover b .ital{color:var(--lime)}
.met b{font-size:84px;font-weight:700;letter-spacing:-.04em;line-height:1;color:var(--bg)}
.met:hover b{color:var(--ink)}
.met b .ital{color:var(--red);font-weight:400}
.met p{font-size:14px;color:color-mix(in oklab, var(--bg) 65%, transparent);line-height:1.5;max-width:26ch;margin-top:auto}
.met .mono{color:color-mix(in oklab, var(--bg) 60%, transparent)}

/* ── TESTIMONIAL ── */
.test{padding:140px 0;background:var(--red);color:var(--ink);position:relative;overflow:hidden}
.test::before{content:"";position:absolute;left:-15vmax;bottom:-15vmax;width:50vmax;height:50vmax;background:radial-gradient(circle, var(--amber), transparent 65%);opacity:.45;filter:blur(60px);pointer-events:none}
.test .container{position:relative;z-index:2;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:end}
.test .body{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;font-size:clamp(38px,5.4vw,82px);line-height:1.02;letter-spacing:-.02em;max-width:24ch}
.test .body em{color:var(--lime);font-style:italic}
.test .meta{display:flex;flex-direction:column;gap:18px;min-width:240px}
.test .who{display:flex;gap:14px;align-items:center}
.test .who .av{width:56px;height:56px;border-radius:50%;background:conic-gradient(from 0deg, var(--lime), var(--plum), var(--ink), var(--lime));border:2px solid var(--ink)}
.test .who b{display:block;font-weight:700;font-size:16px}
.test .who span{font-size:13px;color:color-mix(in oklab, var(--ink) 75%, transparent)}
.test .stat{padding-top:18px;border-top:1px solid color-mix(in oklab, var(--ink) 30%, transparent)}
.test .stat b{font-size:64px;font-weight:700;letter-spacing:-.03em;line-height:1;display:block}
.test .stat b .ital{font-family:"Instrument Serif",serif;font-style:italic;color:var(--lime);font-weight:400}
.test .stat span{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:color-mix(in oklab, var(--ink) 80%, transparent);margin-top:4px;display:block}
.test .bigq{position:absolute;right:4vw;top:60px;font-family:"Instrument Serif",serif;font-style:italic;font-size:340px;line-height:.8;color:color-mix(in oklab, var(--ink) 22%, transparent);user-select:none;pointer-events:none}

/* ── PRICING ── */
.pricing{padding:140px 0;background:var(--bg);position:relative}
.pricing .head{text-align:center;margin-bottom:48px}
.pricing .head .tag{margin-bottom:18px}
.pricing .head h2{font-size:clamp(50px,7vw,128px);letter-spacing:-.045em;font-weight:700;line-height:.92}
.pricing .head h2 .ital{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--red)}
.pricing .head p{margin:16px auto 0;max-width:52ch;font-size:17px;line-height:1.5;color:var(--ink-2)}

.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:32px}
.plan{background:var(--bg-2);border:1px solid var(--line-2);border-radius:22px;padding:30px;display:flex;flex-direction:column;gap:22px;transition:.35s;position:relative;overflow:hidden;min-height:560px}
.plan:hover{transform:translateY(-6px);border-color:var(--ink)}
.plan.feature{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.plan.feature::before{content:"";position:absolute;inset:auto -40% -50% auto;width:260px;height:260px;background:radial-gradient(circle, var(--red), transparent 60%);opacity:.55;filter:blur(20px);pointer-events:none}
.plan .top{display:flex;justify-content:space-between;align-items:flex-start}
.plan .top h3{font-size:26px;font-weight:700;letter-spacing:-.01em}
.plan .top .badge{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:6px 10px;border-radius:999px;border:1px solid var(--line-2)}
.plan.feature .top .badge{background:var(--red);border-color:var(--red);color:var(--ink)}
.plan.feature .top .badge::before{content:"● ";animation:pulse 1.4s infinite}
.plan .price{display:flex;align-items:baseline;gap:8px}
.plan .price b{font-size:64px;font-weight:700;letter-spacing:-.03em;line-height:1}
.plan .price b .ital{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--red)}
.plan.feature .price b .ital{color:var(--lime)}
.plan .price span{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--ink-2)}
.plan.feature .price span{color:color-mix(in oklab, var(--bg) 65%, transparent)}
.plan .price .strike{color:var(--ink-2);text-decoration:line-through;text-decoration-color:var(--red);font-size:18px;font-weight:500}
.plan ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:14.5px;line-height:1.4;position:relative;z-index:1}
.plan ul li{display:flex;gap:10px;align-items:flex-start}
.plan ul li::before{content:"+";width:18px;height:18px;border-radius:50%;background:var(--ink);color:var(--bg);flex:0 0 18px;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;margin-top:1px}
.plan.feature ul li::before{background:var(--red);color:var(--ink)}
.plan .pcta{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-radius:14px;border:1px solid var(--line-2);transition:.25s;cursor:pointer;font-weight:600;position:relative;z-index:1}
.plan .pcta:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.plan.feature .pcta{background:var(--red);color:var(--ink);border-color:var(--red)}
.plan.feature .pcta:hover{background:var(--lime);color:var(--bg);border-color:var(--lime)}
.plan .pcta .arr{width:22px;height:22px;border-radius:50%;background:currentColor;display:inline-flex;align-items:center;justify-content:center}
.plan .pcta .arr::after{content:"→";color:var(--bg);font-size:11px;font-weight:600}
.plan.feature .pcta .arr::after{color:var(--red)}
.plan.feature .pcta:hover .arr::after{color:var(--lime)}

.guarantee{margin-top:32px;display:flex;justify-content:center;gap:24px;flex-wrap:wrap;color:var(--ink-2);font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase}
.guarantee span{display:inline-flex;align-items:center;gap:8px}
.guarantee span::before{content:"✓";color:var(--lime);font-weight:700}

/* ── FAQ ── */
.faq{padding:140px 0;background:var(--bg-2);border-top:1px solid var(--line)}
.faq .layout{display:grid;grid-template-columns:1fr 1.6fr;gap:64px}
.faq h2{font-size:clamp(40px,5.4vw,84px);letter-spacing:-.03em;font-weight:700;line-height:.95;max-width:14ch}
.faq h2 .ital{font-family:"Instrument Serif",serif;font-style:italic;color:var(--red);font-weight:400}
.faq .left p{margin-top:18px;color:var(--ink-2);font-size:15px;line-height:1.5;max-width:38ch}
.faq .list{display:flex;flex-direction:column}
.faq details{border-top:1px solid var(--line-2);padding:24px 0;cursor:pointer}
.faq details:last-of-type{border-bottom:1px solid var(--line-2)}
.faq summary{list-style:none;display:flex;justify-content:space-between;align-items:center;gap:24px;font-size:22px;font-weight:600;letter-spacing:-.01em;line-height:1.2;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary .plus{width:32px;height:32px;border-radius:50%;border:1px solid var(--line-2);display:inline-flex;align-items:center;justify-content:center;font-weight:500;font-size:18px;transition:.3s;flex-shrink:0;color:var(--ink)}
.faq details[open] summary .plus{transform:rotate(45deg);background:var(--red);color:var(--ink);border-color:var(--red)}
.faq details p{margin-top:14px;font-size:15px;line-height:1.55;color:var(--ink-2);max-width:60ch}

/* ── FINAL CTA ── */
.final{padding:140px 0;background:var(--lime);color:var(--bg);position:relative;overflow:hidden;text-align:center}
.final::before{content:"";position:absolute;left:50%;top:-30%;width:60vw;height:60vw;border-radius:50%;background:var(--red);opacity:.18;filter:blur(40px);transform:translateX(-50%);pointer-events:none}
.final h2{font-size:clamp(70px,12vw,232px);letter-spacing:-.045em;line-height:.84;font-weight:700;position:relative}
.final h2 .ital{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--red)}
.final h2 .stroke{-webkit-text-stroke:2px var(--bg);color:transparent}
.final p{margin:32px auto 0;max-width:52ch;font-size:18px;color:color-mix(in oklab, var(--bg) 78%, transparent);line-height:1.5;position:relative}
.final .actions{margin-top:38px;display:flex;gap:12px;justify-content:center;position:relative;flex-wrap:wrap}
.final .btn-primary{background:var(--bg);color:var(--lime)}
.final .btn-primary::before{background:var(--red)}
.final .btn-primary:hover{color:var(--ink)}
.final .btn-primary .arrow{background:var(--red);color:var(--ink)}
.final .btn-primary:hover .arrow{background:var(--ink);color:var(--red)}
.final .btn-ghost{background:transparent;border-color:var(--bg);color:var(--bg)}
.final .btn-ghost:hover{background:var(--bg);color:var(--lime);border-color:var(--bg)}
.final .slots{margin-top:32px;display:inline-flex;gap:8px;align-items:center;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:color-mix(in oklab, var(--bg) 70%, transparent);position:relative}
.final .slots .dot{width:8px;height:8px;border-radius:50%;background:var(--red);animation:pulse 1.4s infinite}

/* ── FOOTER ── */
footer{background:var(--bg);color:var(--ink);padding:64px 0 32px;border-top:1px solid var(--line-2)}
footer .grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:56px}
footer h5{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.08em;color:var(--ink-2);text-transform:uppercase;margin-bottom:16px}
footer ul{list-style:none;display:flex;flex-direction:column;gap:10px}
footer ul a{font-size:15px;transition:.2s;color:var(--ink)}
footer ul a:hover{color:var(--red)}
footer .brandcol p{margin:18px 0 24px;color:var(--ink-2);font-size:15px;line-height:1.5;max-width:36ch}
footer .baseline{font-family:"Bricolage Grotesque",sans-serif;font-size:clamp(48px,8vw,128px);font-weight:700;letter-spacing:-.04em;line-height:.9;padding:32px 0;border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);text-align:center}
footer .baseline .ital{font-family:"Instrument Serif",serif;font-style:italic;color:var(--red);font-weight:400}
footer .baseline .lime{color:var(--lime)}
footer .legal{display:flex;justify-content:space-between;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);padding-top:32px;gap:24px;flex-wrap:wrap}

/* ── Reveal animation ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ── Responsive ── */
@media (max-width: 1100px){
  .hero-grid{grid-template-columns:1fr;gap:60px}
  .compare{grid-template-columns:1fr;gap:18px}
  .compare .vs{display:none}
  .wall-layout{grid-template-columns:1fr}
  .now{position:relative;top:0}
  .now .stage{max-height:520px}
  .wall-grid{height:600px}
  .steps,.bento,.metrics .grid,.plans,footer .grid,.hero .quickstats,.wall .ledger{grid-template-columns:1fr 1fr}
  .bento{grid-auto-rows:auto}
  .bx.b1,.bx.b2,.bx.b7{grid-column:span 2}
  .bx.b1{grid-row:auto}
  .nav ul{display:none}
  .faq .layout{grid-template-columns:1fr;gap:32px}
  .test .container{grid-template-columns:1fr}
  .test .bigq{display:none}
  .pain .head{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .container{padding:0 18px}
  .hero{padding:100px 0 40px}
  .wall-grid{grid-template-columns:repeat(2,1fr);height:520px}
  .wall-col.col-3{display:none}
  .steps,.bento,.metrics .grid,.plans,footer .grid,.hero .quickstats,.wall .ledger{grid-template-columns:1fr}
  .bx.b1,.bx.b2,.bx.b7{grid-column:span 1}
}
