/* ============================================================
   Dezvoltare Shopify — page-specific styles.
   Reuses tokens + .reveal + .timeline + .pf-* from the system.
   ============================================================ */

.sp-wrap { max-width: var(--maxw); margin: 0 auto; padding-inline: var(--pad); }

/* section heading helper */
.sec-head { max-width: 720px; margin: 0 auto clamp(34px, 4.5vw, 60px); text-align: center; }
.sec-eyebrow { font-family: var(--ff-mono); font-size: 12px; letter-spacing: .16em; text-transform: uppercase; color: var(--muted); margin-bottom: 14px; }
.sec-eyebrow .dot { display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: var(--signal); margin-right: 9px; vertical-align: middle; }
.sec-title { font-size: clamp(28px, 3.8vw, 48px); font-weight: 700; letter-spacing: -0.03em; line-height: 1.06; color: var(--ink); text-wrap: balance; }
.sec-title .hl { color: var(--signal); }
.sec-sub { margin: 16px auto 0; max-width: 56ch; font-size: clamp(16px, 1.7vw, 19px); color: var(--muted); line-height: 1.55; text-wrap: pretty; }

/* ---------- HERO ---------- */
.sp-hero { background: #000; padding: clamp(96px, 12vh, 150px) max(var(--pad), calc((100% - 1280px)/2)) clamp(56px, 8vw, 110px); }
/* full-bleed image hero */
.sp-hero.sp-hero-full { position: relative; padding: 0; min-height: clamp(560px, 84vh, 880px); display: flex; align-items: center; overflow: hidden; }
.sp-hero-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: 64% center; z-index: 0; }
.sp-hero-scrim { position: absolute; inset: 0; z-index: 1; pointer-events: none; background:
  linear-gradient(0deg, oklch(0 0 0 / .55) 0%, transparent 32%); }
.sp-hero-seo { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); clip-path: inset(50%); white-space: nowrap; border: 0; }
.sp-hero-inner { position: relative; z-index: 2; width: 100%; max-width: 1280px; margin: 0 auto; padding-inline: var(--pad); }
.sp-hero-full .he-copy { max-width: 600px; }
@media (max-width: 760px) {
  .sp-hero-bg { object-position: 72% center; }
}
.sp-hero-grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
@media (max-width: 900px) { .sp-hero-grid { grid-template-columns: 1fr; } }
.sp-hero .he-eyebrow { font-family: var(--ff-mono); font-size: 12px; letter-spacing: .16em; text-transform: uppercase; color: oklch(0.7 0.01 70); margin-bottom: 18px; }
.sp-hero .he-eyebrow .dot { display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: var(--signal); margin-right: 9px; vertical-align: middle; }
.sp-hero h1 { font-size: clamp(36px, 5vw, 68px); font-weight: 700; letter-spacing: -0.035em; line-height: 1.04; color: oklch(0.98 0 0); max-width: 14ch; }
.sp-hero h1 .soft { color: oklch(0.6 0.01 70); }
.sp-hero p { margin: 22px 0 30px; font-size: clamp(16px, 1.6vw, 20px); color: oklch(0.82 0.008 70); line-height: 1.5; max-width: 42ch; }
.sp-hero .he-cta { display: flex; gap: 16px; flex-wrap: wrap; align-items: center; }
.sp-hero .tlink { display: inline-flex; align-items: center; gap: 6px; text-decoration: none; font-size: 16px; font-weight: 600; color: oklch(0.96 0 0); }
.sp-shot { border-radius: 18px; overflow: hidden; border: 1px solid oklch(0.3 0.01 70); box-shadow: 0 60px 120px -50px oklch(0 0 0 / .7); aspect-ratio: 16 / 11; background: oklch(0.14 0.01 70); }
.sp-shot image-slot { display: block; width: 100%; height: 100%; }
/* browser mockup */
.sp-shot.browser { aspect-ratio: auto; background: oklch(0.17 0.01 70); animation: bwFloat 6.5s ease-in-out infinite; }
.bw-bar { display: flex; align-items: center; gap: 7px; padding: 11px 14px; background: oklch(0.15 0.01 70); border-bottom: 1px solid oklch(0.26 0.01 70); }
.bw-dot { width: 10px; height: 10px; border-radius: 50%; background: oklch(0.4 0.01 70); }
.bw-dot:nth-child(1) { background: #ff5f57; } .bw-dot:nth-child(2) { background: #febc2e; } .bw-dot:nth-child(3) { background: #28c840; }
.bw-url { margin-left: 10px; font-family: var(--ff-mono); font-size: 11px; color: oklch(0.62 0.01 70); background: oklch(0.11 0.01 70); padding: 5px 14px; border-radius: 6px; flex: 1; text-align: center; }
.bw-screen { aspect-ratio: 16 / 10; background: var(--paper-2); }
.bw-screen image-slot { display: block; width: 100%; height: 100%; }
@keyframes bwFloat { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
@media (prefers-reduced-motion: reduce) { .sp-shot.browser { animation: none; } }

/* ---------- COMPARISON ---------- */
.sp-section { padding-block: clamp(56px, 8vw, 110px); }
.sp-section.alt { background: var(--paper-2); border-block: 1px solid var(--line); }
/* globe section (dark) */
.globe-section { background: #000; }
.globe-section .sec-title { color: oklch(0.98 0 0); }
.globe-section .sec-title .hl { color: var(--signal); }
.globe-section .sec-sub { color: oklch(0.72 0.01 70); }
.globe-section .sec-eyebrow { color: oklch(0.7 0.01 70); }
.globe-section .gh-grid { margin-top: clamp(20px, 3vw, 40px); }
.gh-note { color: oklch(0.72 0.01 70); font-size: 16px; line-height: 1.6; max-width: 42ch; margin-top: 26px; }
.compare { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(14px, 1.8vw, 24px); align-items: start; }
@media (max-width: 860px) { .compare { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; } }
.cmp { border: 1px solid var(--line-2); border-radius: var(--r-lg); background: var(--surface); overflow: hidden; transition: transform .5s cubic-bezier(.2,.8,.2,1), box-shadow .3s; }
.reveal.in .cmp { } /* settle handled by .reveal parent */
.cmp.best { border-color: var(--signal); box-shadow: 0 40px 90px -50px oklch(0.6 0.13 250 / .45); position: relative; }
.cmp-head { padding: 22px 24px 18px; border-bottom: 1px solid var(--line); }
.cmp-tag { font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }
.cmp.best .cmp-tag { color: var(--signal); }
.cmp-name { font-size: clamp(19px, 2.2vw, 24px); font-weight: 700; letter-spacing: -0.02em; margin-top: 8px; }
.cmp-name .badge { font-family: var(--ff-mono); font-size: 9px; letter-spacing: .06em; background: var(--signal); color: #fff; padding: 3px 7px; border-radius: 5px; margin-left: 8px; vertical-align: middle; text-transform: uppercase; }
.cmp-rows { padding: 6px 24px 22px; }
.cmp-row { display: flex; align-items: flex-start; gap: 11px; padding: 13px 0; border-bottom: 1px solid var(--line); }
.cmp-row:last-child { border-bottom: none; }
.cmp-ic { width: 20px; height: 20px; border-radius: 50%; display: grid; place-items: center; font-size: 12px; flex: none; margin-top: 1px; font-family: var(--ff-mono); }
.cmp-ic.ok { background: var(--signal-bg); color: var(--signal); }
.cmp-ic.mid { background: oklch(0.92 0.03 80); color: oklch(0.55 0.12 70); }
.cmp-ic.no { background: oklch(0.94 0.02 25); color: oklch(0.55 0.16 25); }
.cmp-row .k { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); }
.cmp-row .v { font-size: 14px; color: var(--ink-2); line-height: 1.4; margin-top: 2px; }
.cmp-row .t { min-width: 0; }

/* ---------- COMPARISON TABLE ---------- */
.ctable { border: 1px solid var(--line-2); border-radius: var(--r-lg); overflow: hidden; background: var(--surface); box-shadow: 0 40px 90px -60px oklch(0.205 0.012 70 / .3); }
.ct-row { display: grid; grid-template-columns: 1.15fr 1fr 1fr 1.06fr; align-items: stretch; }
.ct-row + .ct-row { border-top: 1px solid var(--line); }
.ct-attr { padding: 18px 22px; font-family: var(--ff-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); display: flex; align-items: center; background: var(--paper-2); }
.ct-cell { padding: 16px 20px; display: flex; align-items: flex-start; gap: 10px; font-size: 14.5px; color: var(--ink-2); line-height: 1.4; border-left: 1px solid var(--line); }
.ct-cell i { width: 20px; height: 20px; border-radius: 50%; display: grid; place-items: center; font-size: 12px; flex: none; font-family: var(--ff-mono); font-style: normal; margin-top: 1px; }
.ct-cell i.ok { background: var(--signal-bg); color: var(--signal); }
.ct-cell i.mid { background: oklch(0.92 0.03 80); color: oklch(0.55 0.12 70); }
.ct-cell i.no { background: oklch(0.94 0.02 25); color: oklch(0.55 0.16 25); }
.ct-head .ct-attr { background: transparent; }
.ct-head .ct-col { padding: 20px; border-left: 1px solid var(--line); display: flex; flex-direction: column; gap: 4px; }
.ct-head .ct-col b { font-size: 18px; font-weight: 700; letter-spacing: -0.02em; color: var(--ink); }
.ct-head .ct-col small { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .06em; text-transform: uppercase; color: var(--muted); }
/* highlighted Shopify column */
.ct-row > .best { background: oklch(0.6 0.13 250 / .05); border-left: 1px solid oklch(0.6 0.13 250 / .25); position: relative; }
.ct-head .ct-col.best b { color: var(--signal); }
.ct-head .ct-col.best .ct-badge { align-self: flex-start; font-family: var(--ff-mono); font-size: 9px; letter-spacing: .06em; text-transform: uppercase; background: var(--signal); color: #fff; padding: 3px 7px; border-radius: 5px; margin-top: 4px; }
/* dynamic: icons pop row-by-row, score bars fill, scores count up */
.ct-cell i { transform: scale(.4); opacity: 0; transition: transform .45s cubic-bezier(.2,1.5,.4,1), opacity .3s; }
.ctable.in .ct-cell i { transform: scale(1); opacity: 1; }
.ctable.in .ct-row:nth-child(2) .ct-cell i { transition-delay: .12s; }
.ctable.in .ct-row:nth-child(3) .ct-cell i { transition-delay: .22s; }
.ctable.in .ct-row:nth-child(4) .ct-cell i { transition-delay: .32s; }
.ctable.in .ct-row:nth-child(5) .ct-cell i { transition-delay: .42s; }
.ctable.in .ct-row:nth-child(6) .ct-cell i { transition-delay: .52s; }
.ctable.in .ct-row:nth-child(7) .ct-cell i { transition-delay: .60s; }
.ctable.in .ct-row:nth-child(8) .ct-cell i { transition-delay: .68s; }
.ctable.in .ct-row:nth-child(9) .ct-cell i { transition-delay: .76s; }
.ctable.in .ct-row:nth-child(10) .ct-cell i { transition-delay: .84s; }
.ctable.in .ct-row:nth-child(11) .ct-cell i { transition-delay: .92s; }
/* row hover + stronger Shopify column */
.ct-cell, .ct-attr { transition: background .16s; }
.ct-row:not(.ct-head):not(.ct-verdict):hover > div { background: oklch(0.97 0.006 80); }
.ct-row:not(.ct-head):not(.ct-verdict):hover > .best { background: oklch(0.6 0.13 250 / .1); }
.ct-head .ct-col.best { background: oklch(0.6 0.13 250 / .07); }
.ct-head .ct-col.best::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--signal); z-index: 2; }
.ct-head .ct-col.best { position: relative; overflow: hidden; }
.ctable.in .ct-head .ct-col.best::after { content: ""; position: absolute; inset: 0; pointer-events: none; animation: ctglow 2.6s ease-out 1s 2; }
@keyframes ctglow { 0% { box-shadow: inset 0 0 0 0 oklch(0.6 0.13 250 / .4); } 50% { box-shadow: inset 0 0 24px 1px oklch(0.6 0.13 250 / .35); } 100% { box-shadow: inset 0 0 0 0 oklch(0.6 0.13 250 / 0); } }
/* verdict / score row */
.ct-verdict .ct-cell { flex-direction: column; align-items: stretch; padding: 18px 20px; gap: 10px; }
.ct-score { display: flex; flex-direction: column; gap: 10px; width: 100%; }
.ct-score b { font-family: var(--ff-mono); font-size: 28px; font-weight: 700; color: var(--ink-2); letter-spacing: -0.02em; line-height: 1; }
.ct-row > .best .ct-score b { color: var(--signal); }
.ct-bar { height: 6px; border-radius: 999px; background: var(--line); overflow: hidden; }
.ct-bar i { display: block; height: 100%; width: 0; border-radius: 999px; background: var(--ink-2); transition: width 1.2s cubic-bezier(.2,.8,.2,1) .35s; }
.ct-bar.best i { background: linear-gradient(90deg, var(--ink), var(--signal)); }
.ctable.in .ct-bar i { width: var(--f); }
@media (prefers-reduced-motion: reduce) { .ct-cell i { transform: none; opacity: 1; } }

@media (max-width: 820px) {
  .ctable { border: none; box-shadow: none; background: transparent; overflow: visible; }
  .ct-row { grid-template-columns: 1fr; border: 1px solid var(--line-2); border-radius: var(--r-md); margin-bottom: 14px; overflow: hidden; }
  .ct-row + .ct-row { border-top: 1px solid var(--line-2); }
  .ct-head { display: none; }
  .ct-attr { background: var(--paper-2); }
  .ct-cell { border-left: none; border-top: 1px solid var(--line); }
  .ct-cell::before { content: attr(data-p); font-family: var(--ff-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); margin-right: auto; align-self: center; }
  .ct-row > .best { background: oklch(0.6 0.13 250 / .06); }
}

/* ---------- BENEFITS ---------- */
.benefits { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(14px, 1.8vw, 22px); }
@media (max-width: 860px) { .benefits { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .benefits { grid-template-columns: 1fr; } }
.bcard { border: 1px solid var(--line-2); border-radius: var(--r-lg); background: var(--surface); padding: clamp(22px, 2.4vw, 30px); transition: transform .5s cubic-bezier(.2,.8,.2,1), box-shadow .3s; }
.bcard:hover { box-shadow: 0 40px 80px -50px oklch(0.205 0.012 70 / .4); }
.bcard .bi { width: 42px; height: 42px; border-radius: 11px; background: var(--signal-bg); color: var(--signal); display: grid; place-items: center; font-family: var(--ff-mono); font-size: 18px; margin-bottom: 16px; }
.bcard h3 { font-size: 18px; font-weight: 700; letter-spacing: -0.02em; }
.bcard p { margin-top: 8px; font-size: 14px; color: var(--muted); line-height: 1.55; }
.bcard .bstat { margin-top: 14px; font-family: var(--ff-mono); font-size: 12px; color: var(--signal); }
/* ---------- benefit mini-mockups ---------- */
.bviz { height: 72px; margin-bottom: 18px; display: flex; align-items: center; gap: 8px; }
.vz-speed { flex-direction: column; align-items: flex-start; justify-content: center; gap: 12px; }
.vz-bar { width: 100%; max-width: 160px; height: 8px; border-radius: 999px; background: var(--line); overflow: hidden; }
.vz-bar i { display: block; height: 100%; width: 0; border-radius: 999px; background: linear-gradient(90deg, var(--ink), var(--signal)); transition: width 1.1s cubic-bezier(.2,.9,.2,1) .2s; }
.stagger.in .vz-bar i { width: 88%; }
.vz-dots { display: flex; gap: 6px; }
.vz-dots span { width: 7px; height: 7px; border-radius: 50%; background: var(--signal); opacity: .35; }
.stagger.in .vz-dots span { animation: vzdot 1.4s ease-in-out infinite; }
.vz-dots span:nth-child(2){animation-delay:.2s}.vz-dots span:nth-child(3){animation-delay:.4s}.vz-dots span:nth-child(4){animation-delay:.6s}.vz-dots span:nth-child(5){animation-delay:.8s}
@keyframes vzdot { 0%,100%{opacity:.3} 50%{opacity:1} }
.vz-sec { gap: 12px; }
.vz-lock { width: 46px; height: 46px; border-radius: 12px; background: var(--signal-bg); color: var(--signal); display: grid; place-items: center; font-size: 20px; position: relative; }
.vz-lock::after { content: ""; position: absolute; inset: 0; border-radius: 12px; border: 2px solid var(--signal); opacity: 0; }
.stagger.in .vz-lock::after { animation: vzring 2.4s ease-out infinite; }
@keyframes vzring { 0%{opacity:.6;transform:scale(1)} 70%,100%{opacity:0;transform:scale(1.45)} }
.vz-pills { display: flex; flex-direction: column; gap: 6px; }
.vz-pills span { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .06em; background: var(--paper-2); border: 1px solid var(--line); border-radius: 6px; padding: 3px 9px; color: var(--ink-2); }
.vz-co { flex-direction: column; align-items: flex-start; gap: 9px; justify-content: center; }
.vz-ln { height: 8px; width: 78%; border-radius: 5px; background: var(--line); }
.vz-ln.s { width: 52%; }
.vz-pay { font-family: var(--ff-sans); font-weight: 700; font-size: 12px; color: #fff; background: #5a31f4; border-radius: 7px; padding: 7px 18px; box-shadow: 0 8px 18px -7px #5a31f4; }
.stagger.in .vz-pay { animation: vzpay 2.2s ease-in-out infinite; }
@keyframes vzpay { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-3px)} }
.vz-scale { align-items: flex-end; gap: 7px; height: 72px; }
.vz-scale span { width: 14px; border-radius: 4px 4px 0 0; background: var(--line-2); height: 0; transition: height .8s cubic-bezier(.2,.8,.2,1); }
.stagger.in .vz-scale span { height: var(--h); }
.vz-scale span.peak { background: linear-gradient(180deg, var(--signal), oklch(0.55 0.13 250)); }
.vz-scale span:nth-child(2){transition-delay:.08s}.vz-scale span:nth-child(3){transition-delay:.16s}.vz-scale span:nth-child(4){transition-delay:.24s}.vz-scale span:nth-child(5){transition-delay:.32s}
.vz-eco { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; width: 112px; height: auto; }
.vz-eco span { aspect-ratio: 1; border-radius: 9px; background: var(--paper-2); border: 1px solid var(--line); opacity: 0; transform: scale(.6); }
.stagger.in .vz-eco span { animation: vzeco .5s cubic-bezier(.2,1.5,.4,1) forwards; }
.vz-eco span:nth-child(1){animation-delay:.1s}.vz-eco span:nth-child(2){animation-delay:.18s;background:var(--signal-bg);border-color:transparent}.vz-eco span:nth-child(3){animation-delay:.26s}.vz-eco span:nth-child(4){animation-delay:.34s}.vz-eco span:nth-child(5){animation-delay:.42s;background:var(--signal-bg);border-color:transparent}.vz-eco span:nth-child(6){animation-delay:.5s}
@keyframes vzeco { to { opacity: 1; transform: none; } }
.vz-maint { gap: 12px; }
.vz-toggle { width: 46px; height: 26px; border-radius: 999px; background: var(--signal); position: relative; }
.vz-toggle i { position: absolute; top: 3px; left: 3px; width: 20px; height: 20px; border-radius: 50%; background: #fff; }
.stagger.in .vz-toggle i { animation: vztog 3s ease-in-out infinite; }
@keyframes vztog { 0%,40%{left:3px} 50%,90%{left:23px} 100%{left:3px} }
.vz-mt { font-family: var(--ff-mono); font-size: 11px; letter-spacing: .06em; color: var(--muted); text-transform: uppercase; }

/* ---------- benefit card WOW hover ---------- */
.bcard { position: relative; overflow: hidden; transition: transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .35s ease, border-color .3s ease; }
.bcard::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--signal), oklch(0.55 0.13 250)); transform: scaleX(0); transform-origin: left; transition: transform .45s cubic-bezier(.2,.8,.2,1); }
.bcard::after { content: ""; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(240px circle at var(--mx, 50%) var(--my, 0%), oklch(0.6 0.13 250 / .16), transparent 64%); opacity: 0; transition: opacity .35s; }
.bcard:hover { transform: translateY(-8px); box-shadow: 0 50px 95px -50px oklch(0.55 0.13 250 / .4); border-color: oklch(0.6 0.13 250 / .4); }
.bcard:hover::before { transform: scaleX(1); }
.bcard:hover::after { opacity: 1; }
.bcard h3 { transition: color .25s ease; position: relative; }
.bcard:hover h3 { color: var(--signal); }
.bcard:hover .vz-bar i { width: 96%; }
@media (prefers-reduced-motion: reduce) { .bviz *, .bviz { animation: none !important; transition: none !important; } .stagger.in .vz-bar i { width: 88%; } .stagger.in .vz-scale span { height: var(--h); } .stagger.in .vz-eco span { opacity: 1; transform: none; } }

/* staggered reveal for grids */
.stagger.in > * { animation: spRise .6s cubic-bezier(.2,.8,.2,1) backwards; }
.stagger.in > *:nth-child(1){animation-delay:.04s}.stagger.in > *:nth-child(2){animation-delay:.1s}.stagger.in > *:nth-child(3){animation-delay:.16s}
.stagger.in > *:nth-child(4){animation-delay:.22s}.stagger.in > *:nth-child(5){animation-delay:.28s}.stagger.in > *:nth-child(6){animation-delay:.34s}
@keyframes spRise { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .stagger.in > * { animation: none; } }

/* ---------- DELIVER ---------- */
.deliver { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(12px, 1.4vw, 18px); }
@media (max-width: 760px) { .deliver { grid-template-columns: 1fr; } }
.dcard { border: 1px solid var(--line-2); border-radius: var(--r-md); padding: 20px 22px; background: var(--surface); display: flex; align-items: baseline; gap: 12px; }
.dcard .dn { font-family: var(--ff-mono); font-size: 12px; color: var(--faint); flex: none; }
/* ---------- Ce livrăm — device switcher ---------- */
.dsw { text-align: center; }
.dsw-tabs { display: inline-flex; gap: 4px; padding: 4px; border: 1px solid var(--line-2); border-radius: 999px; background: var(--surface); margin-bottom: clamp(24px, 3vw, 44px); }
.dsw-t { font-family: var(--ff-mono); font-size: 13px; padding: 9px 22px; border: none; background: none; border-radius: 999px; cursor: pointer; color: var(--muted); transition: all .2s; }
.dsw-t.active { background: var(--ink); color: var(--paper); }
.dsw-stage { display: flex; justify-content: center; align-items: flex-start; min-height: 430px; }
.dsw-frame { transition: width .55s cubic-bezier(.5,.1,.2,1); box-shadow: 0 50px 100px -50px oklch(0.205 0.012 70 / .45); border-radius: 14px; overflow: hidden; border: 1px solid var(--line-2); background: #fff; }
.dsw-frame.desk { width: min(760px, 100%); }
.dsw-frame.tab { width: 440px; }
.dsw-frame.mob { width: 250px; }
.dsw-note { margin-top: clamp(24px, 3vw, 38px); color: var(--muted); font-size: 15px; max-width: 50ch; margin-inline: auto; line-height: 1.55; }
.mk { border: 1px solid var(--line); border-radius: 10px; overflow: hidden; }
.mk-bar { display: flex; align-items: center; gap: 5px; padding: 8px 11px; background: var(--paper-2); border-bottom: 1px solid var(--line); }
.mk-bar i { width: 7px; height: 7px; border-radius: 50%; background: var(--line-2); }
.mk-bar span { margin-left: 7px; font-family: var(--ff-mono); font-size: 9px; color: var(--muted); }
.mko-body { background: #f4f3ef; }
.mko-head { text-align: center; font-family: Georgia, serif; font-weight: 700; color: #1a2a4a; padding: 10px; font-size: 14px; letter-spacing: .02em; }
.mko-nav { background: #1a2a4a; color: #fff; font-size: 7px; text-align: center; padding: 6px; letter-spacing: .06em; }
.mko-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 5px; padding: 8px; }
.mko-grid span { aspect-ratio: 1; background: repeating-linear-gradient(45deg, #dcdad4 0 4px, #e9e7e1 4px 8px); border-bottom: 3px solid #d23434; }
.mkn-body { background: #fff; }
.mkn-head { display: flex; justify-content: space-between; align-items: center; padding: 11px 13px; border-bottom: 1px solid #eee; }
.mkn-head b { font-size: 12px; letter-spacing: .12em; color: #111; } .mkn-head span { font-size: 7px; color: #999; }
.mkn-hero { padding: 14px; } .mkn-prod { aspect-ratio: 5 / 4; border-radius: 6px; background: linear-gradient(135deg, #ead6c1, #cda77f); margin: 0 auto; max-width: 58%; }
.mkn-info { padding: 0 14px 14px; } .mkn-info small { font-family: var(--ff-mono); font-size: 7px; color: #999; letter-spacing: .12em; } .mkn-info b { display: block; font-size: 13px; margin: 5px 0; color: #111; } .mkn-info > span { font-size: 11px; color: #555; }
.mkn-btn { margin-top: 9px; background: #111; color: #fff; text-align: center; font-size: 8px; letter-spacing: .12em; padding: 9px; border-radius: 5px; text-transform: uppercase; }
.dcard { position: relative; overflow: hidden; align-items: center; transition: transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .3s, border-color .3s; }
.dcard::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--signal), oklch(0.55 0.13 250)); transform: scaleX(0); transform-origin: left; transition: transform .4s cubic-bezier(.2,.8,.2,1); }
.dcard:hover { transform: translateY(-5px); box-shadow: 0 36px 70px -46px oklch(0.55 0.13 250 / .35); border-color: oklch(0.6 0.13 250 / .35); }
.dcard:hover::before { transform: scaleX(1); }
.dtxt { min-width: 0; }
.dviz { width: 50px; height: 50px; border-radius: 12px; background: var(--signal-bg); display: grid; place-items: center; flex: none; }
.dviz svg { width: 24px; height: 24px; fill: none; stroke: var(--signal); stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.d-shop { flex-direction: column; gap: 3px; align-items: flex-start; padding: 8px; }
.d-shop .dv-bar { display: flex; gap: 2px; } .d-shop .dv-bar i { width: 3px; height: 3px; border-radius: 50%; background: var(--line-2); }
.d-shop .dv-l { height: 4px; width: 30px; border-radius: 2px; background: var(--line-2); } .d-shop .dv-l.s { width: 18px; background: var(--signal); }
.d-mig .dv-box { width: 12px; height: 12px; border-radius: 3px; border: 1.5px solid var(--line-2); } .d-mig .dv-box.on { background: var(--signal); border-color: var(--signal); }
.d-mig .dv-arr { font-family: var(--ff-mono); color: var(--muted); font-size: 12px; }
.stagger.in .d-mig .dv-box.on { animation: dpop .6s cubic-bezier(.2,1.5,.4,1); }
.d-theme span { width: 11px; height: 18px; border-radius: 3px; }
.d-theme span:nth-child(1){background:var(--ink)} .d-theme span:nth-child(2){background:var(--signal)} .d-theme span:nth-child(3){background:var(--line-2)}
.d-head { font-family: var(--ff-mono); font-size: 15px; font-weight: 700; color: var(--signal); }
.d-cro { align-items: flex-end; gap: 3px; padding-bottom: 9px; }
.d-cro span { width: 8px; border-radius: 2px 2px 0 0; background: var(--line-2); height: 0; transition: height .7s cubic-bezier(.2,.8,.2,1); }
.d-cro span:nth-child(3){background:var(--signal)}
.stagger.in .d-cro span { height: var(--h); }
.d-cro span:nth-child(2){transition-delay:.1s} .d-cro span:nth-child(3){transition-delay:.2s}
.d-int .dv-c { width: 8px; height: 8px; border-radius: 50%; background: var(--signal); }
.d-int .dv-n { position: absolute; width: 5px; height: 5px; border-radius: 50%; background: var(--line-2); }
.d-int .n1 { top: 10px; left: 15px } .d-int .n2 { bottom: 11px; left: 13px } .d-int .n3 { top: 19px; right: 12px }
@keyframes dpop { 0%{transform:scale(.4)} 100%{transform:scale(1)} }
.dcard b { font-size: 16px; font-weight: 700; letter-spacing: -0.015em; }
.dcard small { display: block; font-size: 13px; color: var(--muted); margin-top: 4px; font-weight: 400; }

/* ---------- FAQ ---------- */
.faq { max-width: 760px; margin: 0 auto; }
.faq details { border-bottom: 1px solid var(--line); }
.faq summary { list-style: none; cursor: pointer; padding: 22px 4px; display: flex; align-items: center; justify-content: space-between; gap: 16px; font-size: clamp(16px, 1.9vw, 20px); font-weight: 600; letter-spacing: -0.015em; color: var(--ink); }
.faq summary::-webkit-details-marker { display: none; }
.faq summary .pm { width: 26px; height: 26px; border-radius: 50%; border: 1px solid var(--line-2); display: grid; place-items: center; flex: none; transition: transform .3s, background .2s; font-family: var(--ff-mono); }
.faq details[open] summary .pm { transform: rotate(45deg); background: var(--ink); color: var(--paper); border-color: var(--ink); }
.faq .ans { padding: 0 4px 24px; font-size: 15px; color: var(--muted); line-height: 1.6; max-width: 64ch; }

/* ---------- FINAL CTA ---------- */
.sp-cta { background: #000; text-align: center; padding: clamp(64px, 9vw, 120px) var(--pad); }
.sp-cta h2 { font-size: clamp(30px, 4.4vw, 60px); font-weight: 700; letter-spacing: -0.03em; color: oklch(0.98 0 0); max-width: 18ch; margin: 0 auto; text-wrap: balance; }
.sp-cta p { margin: 18px auto 30px; color: oklch(0.7 0.01 70); font-size: 17px; }
.sp-cta .btn-light { background: var(--paper); color: var(--ink); border-radius: 999px; padding: 16px 28px; font-weight: 600; text-decoration: none; display: inline-flex; align-items: center; gap: 10px; transition: transform .2s; }
.sp-cta .btn-light:hover { transform: translateY(-2px); }

/* ---------- GLOBE HERO ---------- */
.globe-hero { overflow: hidden; }
.gh-grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
@media (max-width: 900px) { .gh-grid { grid-template-columns: 1fr; } .gh-globe { order: -1; } }
.gh-stats { display: flex; flex-direction: column; gap: clamp(16px, 2vw, 26px); align-items: flex-start; margin: 0 0 28px; }
.ghs b { font-family: var(--ff-mono); font-size: clamp(54px, 7vw, 104px); font-weight: 700; letter-spacing: -0.04em; color: oklch(0.98 0 0); display: flex; align-items: baseline; gap: 3px; line-height: 1; }
.ghs .u { font-size: 0.34em; font-weight: 700; letter-spacing: 0; color: var(--signal); }
.ghs > span { font-family: var(--ff-mono); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: oklch(0.62 0.01 70); margin-top: 12px; display: block; }
.gh-globe { position: relative; width: min(480px, 92%); aspect-ratio: 1; margin-inline: auto; }
.globe-ring { position: absolute; inset: -7%; border-radius: 50%; border: 1px dashed oklch(0.42 0.05 255 / .45); animation: gspin2 34s linear infinite; }
@keyframes gspin2 { to { transform: rotate(360deg); } }
.globe { position: absolute; inset: 0; border-radius: 50%; overflow: hidden;
  background: radial-gradient(circle at 36% 30%, oklch(0.27 0.035 250) 0%, oklch(0.13 0.02 255) 56%, oklch(0.07 0.012 255) 100%);
  box-shadow: inset -26px -26px 75px oklch(0 0 0 / .72), inset 10px 10px 44px oklch(0.5 0.1 250 / .14), 0 0 90px oklch(0.5 0.13 250 / .22), 0 0 0 1px oklch(0.3 0.03 255); }
.globe-surface { position: absolute; top: -12%; bottom: -12%; left: 0; width: 200%;
  background-image: radial-gradient(circle, oklch(0.72 0.11 250 / .42) 1px, transparent 1.6px);
  background-size: 14px 14px; animation: gspin 22s linear infinite;
  -webkit-mask: radial-gradient(circle at 50% 50%, #000 56%, transparent 100%);
          mask: radial-gradient(circle at 50% 50%, #000 56%, transparent 100%); }
/* lat/long wireframe grid */
.globe-grid { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; pointer-events: none;
  -webkit-mask: radial-gradient(circle at 34% 30%, #000 64%, oklch(0 0 0 / .35) 100%);
          mask: radial-gradient(circle at 34% 30%, #000 64%, oklch(0 0 0 / .35) 100%); }
.globe-grid ellipse, .globe-grid line { fill: none; stroke: oklch(0.62 0.09 250 / .3); stroke-width: 0.3; }
.globe-grid .gg-edge { fill: none; stroke: oklch(0.66 0.12 250 / .55); stroke-width: 0.6; }
@keyframes gspin { to { transform: translateX(-25%); } }
.globe-shade { position: absolute; inset: 0; border-radius: 50%; pointer-events: none;
  background: radial-gradient(circle at 34% 27%, transparent 36%, oklch(0 0 0 / .55) 100%); }
.globe-hl { position: absolute; inset: 0; border-radius: 50%; pointer-events: none;
  background: radial-gradient(circle at 31% 25%, oklch(0.72 0.1 250 / .2) 0%, transparent 32%); }
.gpt { position: absolute; width: 7px; height: 7px; border-radius: 50%; background: oklch(0.92 0.05 200); transform: translate(-50%, -50%); animation: gpulse 2.6s ease-out infinite; box-shadow: 0 0 7px 1px oklch(0.8 0.12 200 / .9); }
.gpt:nth-child(2) { animation-delay: .6s; } .gpt:nth-child(3) { animation-delay: 1.2s; } .gpt:nth-child(4) { animation-delay: 1.8s; } .gpt:nth-child(5) { animation-delay: .9s; }
@keyframes gpulse { 0% { box-shadow: 0 0 7px 1px oklch(0.8 0.12 200 / .9), 0 0 0 0 oklch(0.6 0.13 250 / .55); } 70%, 100% { box-shadow: 0 0 7px 1px oklch(0.8 0.12 200 / .5), 0 0 0 15px oklch(0.6 0.13 250 / 0); } }
.garcs { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; pointer-events: none; }
.garcs path { fill: none; stroke: oklch(0.78 0.13 220); stroke-width: 0.9; stroke-linecap: round; stroke-dasharray: 240; stroke-dashoffset: 240; filter: drop-shadow(0 0 2px oklch(0.7 0.14 230 / .9)); animation: garc 4s ease-in-out infinite; }
.garcs path:nth-child(2) { animation-delay: 1s; } .garcs path:nth-child(3) { animation-delay: 2s; } .garcs path:nth-child(4) { animation-delay: 3s; }
@keyframes garc { 0% { stroke-dashoffset: 240; } 45% { stroke-dashoffset: 0; } 90%, 100% { stroke-dashoffset: -240; } }
.gh-chip { position: absolute; z-index: 3; background: oklch(0.16 0.012 255 / .9); backdrop-filter: blur(8px); border: 1px solid oklch(0.32 0.03 255); border-radius: 11px; padding: 8px 12px; display: flex; align-items: center; gap: 9px; box-shadow: 0 14px 34px -16px #000; }
.gh-chip b { font-family: var(--ff-mono); font-size: 14px; color: oklch(0.98 0 0); display: block; }
.gh-chip span { font-family: var(--ff-mono); font-size: 9.5px; letter-spacing: .06em; text-transform: uppercase; color: oklch(0.6 0.01 70); display: block; margin-top: 2px; }
.gh-chip .d { width: 7px; height: 7px; border-radius: 50%; background: var(--signal); box-shadow: 0 0 8px var(--signal); }
.gh-chip.c1 { top: 8%; right: -4%; } .gh-chip.c2 { bottom: 12%; left: -8%; }
@media (prefers-reduced-motion: reduce) { .globe-surface, .globe-ring, .gpt, .garcs path, .globe-grid { animation: none; } }

/* ============================================================
   CE LIVRĂM — deliverables manifest (scope sheet)
   ============================================================ */
.manifest {
  max-width: 1080px; margin: clamp(8px,1vw,16px) auto 0;
  border: 1px solid var(--line-2); border-radius: var(--r-lg);
  background: var(--surface); overflow: hidden;
  box-shadow: 0 50px 110px -60px oklch(0.205 0.012 70 / .4);
}
/* header strip */
.mf-head {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 20px clamp(20px,3vw,34px);
  border-bottom: 1px solid var(--line); background: var(--paper-2);
}
.mf-h-l { display: flex; flex-direction: column; gap: 5px; }
.mf-tag { font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: .16em; text-transform: uppercase; color: var(--muted); }
.mf-h-l b { font-size: clamp(17px,2vw,21px); font-weight: 700; letter-spacing: -.02em; color: var(--ink); }
.mf-stamp {
  font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--signal); border: 1.5px solid var(--signal); border-radius: 7px;
  padding: 8px 12px; transform: rotate(-3deg); position: relative;
  display: inline-flex; align-items: center; gap: 7px; background: var(--signal-bg);
}
.mf-stamp::before { content: "✓"; font-weight: 700; }
@media (max-width: 560px) { .mf-stamp { display: none; } }

/* groups grid */
.mf-grid { display: grid; grid-template-columns: repeat(3, 1fr); }
@media (max-width: 860px) { .mf-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .mf-grid { grid-template-columns: 1fr; } }
.mf-group {
  padding: clamp(20px,2.4vw,28px) clamp(20px,2.4vw,30px);
  border-right: 1px solid var(--line); border-bottom: 1px solid var(--line);
}
/* remove edge borders per row of 3 */
.mf-grid .mf-group:nth-child(3n) { border-right: none; }
.mf-grid .mf-group:nth-last-child(-n+3) { border-bottom: none; }
@media (max-width: 860px) {
  .mf-grid .mf-group { border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
  .mf-grid .mf-group:nth-child(3n) { border-right: 1px solid var(--line); }
  .mf-grid .mf-group:nth-child(2n) { border-right: none; }
  .mf-grid .mf-group:nth-last-child(-n+3) { border-bottom: 1px solid var(--line); }
  .mf-grid .mf-group:nth-last-child(-n+2) { border-bottom: none; }
}
@media (max-width: 560px) {
  .mf-grid .mf-group { border-right: none !important; border-bottom: 1px solid var(--line) !important; }
  .mf-grid .mf-group:last-child { border-bottom: none !important; }
}
.mf-g-head { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.mf-n { font-family: var(--ff-mono); font-size: 11px; font-weight: 600; color: var(--signal); letter-spacing: .04em; }
.mf-g-head b { font-size: 15px; font-weight: 700; letter-spacing: -.015em; color: var(--ink); white-space: nowrap; }
.mf-group ul { list-style: none; display: flex; flex-direction: column; gap: 11px; }
.mf-group li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 13.5px; color: var(--ink-2); line-height: 1.4; text-wrap: pretty;
}
.mf-group li::before {
  content: "✓"; flex: none; margin-top: 1px;
  width: 17px; height: 17px; border-radius: 50%;
  background: var(--signal); color: #fff;
  font-family: var(--ff-mono); font-size: 9px; font-weight: 700;
  display: grid; place-items: center;
}
/* check pop-in on reveal */
.manifest.in .mf-group li::before { animation: mfPop .5s cubic-bezier(.2,1.5,.4,1) backwards; }
.manifest.in .mf-group:nth-child(1) li::before { animation-delay: .05s; }
.manifest.in .mf-group:nth-child(2) li::before { animation-delay: .12s; }
.manifest.in .mf-group:nth-child(3) li::before { animation-delay: .19s; }
.manifest.in .mf-group:nth-child(4) li::before { animation-delay: .26s; }
.manifest.in .mf-group:nth-child(5) li::before { animation-delay: .33s; }
.manifest.in .mf-group:nth-child(6) li::before { animation-delay: .40s; }
@keyframes mfPop { from { transform: scale(.3); opacity: 0; } to { transform: scale(1); opacity: 1; } }
@media (prefers-reduced-motion: reduce) { .manifest.in .mf-group li::before { animation: none; } }

/* footer summary */
.mf-foot {
  display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
  padding: 18px clamp(20px,3vw,34px);
  border-top: 1px solid var(--line); background: var(--paper-2);
  font-size: 14.5px; color: var(--ink-2); line-height: 1.5;
}
.mf-foot .mf-seal {
  flex: none; width: 30px; height: 30px; border-radius: 8px;
  background: var(--ink); color: var(--paper);
  display: grid; place-items: center; font-size: 15px;
}
.mf-foot b { color: var(--ink); font-weight: 700; }
.mf-foot .mf-days { margin-left: auto; font-family: var(--ff-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--signal); white-space: nowrap; }
@media (max-width: 560px) { .mf-foot .mf-days { margin-left: 0; } }
/* ============================================================
   PROCESUL — vertical phased timeline with large visuals
   ============================================================ */
.flow { max-width: 1080px; margin: clamp(8px,1vw,16px) auto 0; position: relative; }

/* approval emphasis banner */
.flow-note {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  justify-content: center; text-align: center;
  margin: 0 auto clamp(40px,5vw,68px); max-width: 760px;
  font-size: 15px; color: var(--ink-2); line-height: 1.5;
}
.flow-note .fn-ic { flex: none; width: 26px; height: 26px; border-radius: 50%; background: var(--signal-bg); color: var(--signal); display: grid; place-items: center; font-family: var(--ff-mono); font-size: 13px; font-weight: 700; }
.flow-note b { color: var(--ink); font-weight: 700; }

/* central spine */
.flow-steps { position: relative; }
.flow-steps::before {
  content: ""; position: absolute; top: 8px; bottom: 60px; left: 50%; width: 2px; transform: translateX(-50%);
  background: repeating-linear-gradient(180deg, var(--line-2) 0 7px, transparent 7px 14px);
  z-index: 0;
}
@media (max-width: 880px) { .flow-steps::before { left: 27px; } }

/* one step row */
.flow-step {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1fr 64px 1fr; align-items: center;
  margin-bottom: clamp(36px,4.5vw,68px);
}
.flow-step:last-child { margin-bottom: 0; }
.flow-step .fs-art { grid-column: 1; }
.flow-step .fs-text { grid-column: 3; }
.flow-step .fs-art, .flow-step .fs-text, .flow-step .fs-node { grid-row: 1; }
.flow-step:nth-child(even) .fs-art { grid-column: 3; }
.flow-step:nth-child(even) .fs-text { grid-column: 1; text-align: right; }

/* node on spine */
.fs-node {
  grid-column: 2; justify-self: center; z-index: 2;
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--surface); border: 2px solid var(--signal); color: var(--signal);
  display: grid; place-items: center; font-family: var(--ff-mono); font-size: 17px; font-weight: 700;
  box-shadow: 0 0 0 7px var(--paper-2);
}
.flow-step.cont .fs-node { border-style: dashed; border-color: var(--line-2); color: var(--muted); }
.flow.in .fs-node { animation: rpPop .5s cubic-bezier(.2,1.5,.4,1) backwards; }
.flow.in .flow-step:nth-child(2) .fs-node { animation-delay: .08s; }
.flow.in .flow-step:nth-child(3) .fs-node { animation-delay: .16s; }
.flow.in .flow-step:nth-child(4) .fs-node { animation-delay: .24s; }
.flow.in .flow-step:nth-child(5) .fs-node { animation-delay: .32s; }
.flow.in .flow-step:nth-child(6) .fs-node { animation-delay: .40s; }
@keyframes rpPop { from { transform: scale(.3); opacity: 0; } to { transform: scale(1); opacity: 1; } }

/* text column */
.fs-text { min-width: 0; }
.fs-day { font-family: var(--ff-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--signal); margin-bottom: 7px; }
.flow-step.cont .fs-day { color: var(--muted); }
.fs-title { font-size: clamp(19px,2.1vw,24px); font-weight: 700; letter-spacing: -.02em; color: var(--ink); margin-bottom: 9px; line-height: 1.1; }
.fs-desc { font-size: 14.5px; color: var(--muted); line-height: 1.55; text-wrap: pretty; max-width: 42ch; }
.fs-deliver { margin-top: 14px; font-size: 13.5px; color: var(--ink-2); line-height: 1.45; }
.fs-deliver::before { content: "↳ "; color: var(--signal); font-family: var(--ff-mono); font-weight: 700; }
.fs-deliver b { color: var(--ink); font-weight: 600; }
.fs-gate {
  margin-top: 13px; font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: .06em; text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 6px; background: var(--signal-bg); color: var(--signal);
  padding: 6px 11px; border-radius: 7px; font-weight: 600;
}
.fs-gate::before { content: "✓"; font-weight: 700; }
.fs-gate.soft { background: var(--paper-2); color: var(--muted); border: 1px solid var(--line); }
.fs-gate.soft::before { content: "›"; }

/* ---------- the large art panels ---------- */
.fs-art {
  border: 1px solid var(--line-2); border-radius: 14px; background: var(--surface);
  box-shadow: 0 36px 80px -50px oklch(0.205 0.012 70 / .45); overflow: hidden;
  height: clamp(200px, 23vw, 248px); position: relative;
  display: flex; flex-direction: column;
}
.fa-bar { display: flex; align-items: center; gap: 6px; padding: 9px 13px; border-bottom: 1px solid var(--line); background: var(--paper-2); }
.fa-bar i { width: 8px; height: 8px; border-radius: 50%; background: var(--line-2); }
.fa-bar i:nth-child(1){background:#ff5f57}.fa-bar i:nth-child(2){background:#febc2e}.fa-bar i:nth-child(3){background:#28c840}
.fa-bar span { margin-left: 8px; font-family: var(--ff-mono); font-size: 9.5px; color: var(--muted); }

/* 1 — scope document */
.fa-doc { padding: 16px 22px 18px; display: flex; flex-direction: column; gap: 9px; flex: 1; min-height: 0; }
.fa-doc .d-h { font-family: var(--ff-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }
.fa-doc .d-l { height: 7px; border-radius: 4px; background: var(--line); }
.fa-doc .d-l.a{width:88%}.fa-doc .d-l.b{width:96%}.fa-doc .d-l.c{width:70%}
.fa-gantt { display: flex; gap: 6px; margin-top: 2px; }
.fa-gantt i { height: 9px; border-radius: 4px; }
.fa-gantt i:nth-child(1){flex:2;background:var(--line-2)}.fa-gantt i:nth-child(2){flex:3;background:oklch(0.8 0.04 158)}.fa-gantt i:nth-child(3){flex:4;background:var(--signal)}
.fa-sign { margin-top: auto; display: flex; align-items: center; justify-content: space-between; padding-top: 12px; border-top: 1px solid var(--line); }
.fa-sign .sg-line { width: 120px; height: 18px; border-bottom: 1.5px solid var(--line-2); position: relative; }
.fa-sign .sg-line::after { content: ""; position: absolute; left: 6px; bottom: 4px; width: 90px; height: 14px; border-radius: 40%; border: 1.5px solid var(--ink-2); border-color: transparent var(--ink-2) var(--ink-2) transparent; transform: rotate(-6deg); opacity: .5; }
.fa-stamp { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--signal); border: 1.5px solid var(--signal); background: var(--signal-bg); border-radius: 7px; padding: 6px 10px; transform: rotate(-4deg); display: inline-flex; gap: 6px; align-items: center; }
.fa-stamp::before { content: "✓"; font-weight: 700; }

/* 2 — wireframe → hi-fi */
.fa-design { display: flex; align-items: center; justify-content: center; gap: 18px; flex: 1; min-height: 0; padding: 20px; }
.fa-mini { width: 116px; height: 168px; border-radius: 8px; overflow: hidden; flex: none; display: flex; flex-direction: column; }
.fa-mini.wire { border: 1.5px dashed var(--line-2); padding: 8px; gap: 6px; background: var(--paper-2); }
.fa-mini.wire .w-h { height: 14px; background: var(--line); border-radius: 3px; }
.fa-mini.wire .w-hero { height: 44px; background: repeating-linear-gradient(45deg, var(--line) 0 5px, transparent 5px 10px); border: 1px dashed var(--line-2); border-radius: 3px; }
.fa-mini.wire .w-row { display: grid; grid-template-columns: 1fr 1fr; gap: 5px; flex: 1; }
.fa-mini.wire .w-row span { background: var(--paper); border: 1px dashed var(--line-2); border-radius: 3px; }
.fa-design .d-arrow { font-family: var(--ff-mono); color: var(--muted); font-size: 18px; flex: none; }
.fa-mini.hifi { border: 1px solid var(--line); background: var(--surface); box-shadow: 0 14px 30px -16px oklch(0.205 0.012 70 / .4); }
.fa-mini.hifi .h-h { height: 18px; background: var(--ink); }
.fa-mini.hifi .h-hero { height: 52px; background: linear-gradient(135deg, oklch(0.85 0.04 60), oklch(0.66 0.09 35)); }
.fa-mini.hifi .h-body { padding: 8px; display: grid; grid-template-columns: 1fr 1fr; gap: 6px; flex: 1; }
.fa-mini.hifi .h-body span { border-radius: 4px; background: var(--paper-2); border: 1px solid var(--line); }
.fa-mini.hifi .h-body span:nth-child(1){ background: var(--signal-bg); border-color: transparent; }

/* 3 — code editor */
.fa-code { background: oklch(0.20 0.012 260); flex: 1; min-height: 0; display: flex; flex-direction: column; }
.fa-code .c-bar { background: oklch(0.16 0.012 260); border-color: oklch(0.3 0.02 260); }
.fa-code .c-bar span { color: oklch(0.62 0.02 260); }
.fa-code .c-body { padding: 16px 16px 16px 40px; position: relative; flex: 1; display: flex; flex-direction: column; gap: 9px; }
.fa-code .c-body::before { content: "1 2 3 4 5 6 7"; position: absolute; left: 14px; top: 16px; white-space: pre; writing-mode: vertical-lr; font-family: var(--ff-mono); font-size: 9px; color: oklch(0.45 0.02 260); letter-spacing: 8px; }
.fa-code .c-ln { display: flex; gap: 6px; align-items: center; }
.fa-code .c-ln i { height: 7px; border-radius: 3px; }
.fa-code .tag{background:oklch(0.7 0.13 20);width:54px}.fa-code .var{background:oklch(0.78 0.11 250);width:40px}.fa-code .str{background:oklch(0.78 0.1 145);width:70px}.fa-code .txt{background:oklch(0.45 0.02 260);width:30px}.fa-code .kw{background:oklch(0.78 0.1 300);width:46px}
.fa-code .c-cursor { width: 8px; height: 14px; background: var(--signal); display: inline-block; border-radius: 1px; }
.flow.in .fa-code .c-cursor { animation: rvType 1.1s steps(1) infinite; }
@keyframes rvType { 0%,50%{opacity:1}51%,100%{opacity:0} }

/* 4 — migration */
.fa-mig { display: flex; align-items: center; justify-content: center; gap: 14px; flex: 1; min-height: 0; padding: 20px; }
.fa-store { width: 130px; border-radius: 9px; border: 1px solid var(--line); overflow: hidden; flex: none; background: var(--paper-2); }
.fa-store .s-h { font-family: var(--ff-mono); font-size: 9.5px; letter-spacing: .06em; text-transform: uppercase; padding: 7px 10px; color: var(--muted); border-bottom: 1px solid var(--line); background: var(--surface); }
.fa-store.to .s-h { color: var(--signal); }
.fa-store .s-row { display: flex; align-items: center; gap: 7px; padding: 8px 10px; }
.fa-store .s-row + .s-row { border-top: 1px solid var(--line); }
.fa-store .s-row b { width: 16px; height: 16px; border-radius: 4px; background: var(--line-2); flex: none; }
.fa-store.to .s-row b { background: var(--signal-bg); }
.fa-store .s-row i { height: 5px; border-radius: 3px; background: var(--line-2); flex: 1; }
.fa-store.to .s-row i { background: oklch(0.8 0.04 158); }
.fa-store .s-row .ck { width: 13px; height: 13px; border-radius: 50%; background: var(--signal); color: #fff; font-size: 7px; display: grid; place-items: center; flex: none; font-family: var(--ff-mono); }
.fa-mig .m-mid { display: flex; flex-direction: column; align-items: center; gap: 6px; flex: none; }
.fa-mig .m-mid .m-ar { font-family: var(--ff-mono); font-size: 20px; color: var(--signal); }
.fa-mig .m-mid .m-301 { font-family: var(--ff-mono); font-size: 9px; letter-spacing: .04em; color: var(--signal); background: var(--signal-bg); border-radius: 4px; padding: 2px 6px; }

/* 5 — QA + LIVE */
.fa-qa { padding: 18px 20px; display: flex; flex-direction: column; gap: 9px; flex: 1; min-height: 0; }
.fa-qa .q-row { display: flex; align-items: center; gap: 10px; font-family: var(--ff-mono); font-size: 11px; color: var(--ink-2); }
.fa-qa .q-row .qk { width: 17px; height: 17px; border-radius: 50%; background: var(--signal); color: #fff; font-size: 9px; display: grid; place-items: center; flex: none; font-weight: 700; }
.fa-qa .q-bar { margin-left: auto; height: 5px; width: 60px; border-radius: 3px; background: var(--signal); opacity: .35; }
.fa-qa .q-live { margin-top: auto; display: flex; align-items: center; gap: 9px; padding: 10px 12px; border: 1px solid var(--line); border-radius: 8px; background: var(--paper-2); }
.fa-qa .q-live .ld { width: 9px; height: 9px; border-radius: 50%; background: var(--signal); flex: none; }
.flow.in .fa-qa .q-live .ld { animation: rvPulse 2s ease-in-out infinite; }
@keyframes rvPulse { 0%,100%{ box-shadow: 0 0 0 0 oklch(0.56 0.072 158 / .55); } 60%{ box-shadow: 0 0 0 7px oklch(0.56 0.072 158 / 0); } }
.fa-qa .q-live .lu { font-family: var(--ff-mono); font-size: 10px; color: var(--muted); flex: 1; }
.fa-qa .q-live .lb { font-family: var(--ff-mono); font-size: 9.5px; font-weight: 700; letter-spacing: .08em; color: #fff; background: var(--signal); border-radius: 5px; padding: 4px 8px; }

/* 6 — analytics */
.fa-an { padding: 16px 18px; display: flex; flex-direction: column; gap: 12px; flex: 1; min-height: 0; }
.fa-an .a-kpis { display: flex; gap: 10px; }
.fa-an .a-kpi { flex: 1; border: 1px solid var(--line); border-radius: 8px; padding: 9px 11px; background: var(--paper-2); }
.fa-an .a-kpi .k-l { font-family: var(--ff-mono); font-size: 8.5px; letter-spacing: .06em; text-transform: uppercase; color: var(--muted); }
.fa-an .a-kpi .k-v { font-family: var(--ff-mono); font-size: 17px; font-weight: 700; color: var(--signal); margin-top: 3px; display: flex; align-items: baseline; gap: 4px; }
.fa-an .a-kpi .k-v::after { content: "↑"; font-size: 11px; }
.fa-an .a-chart { flex: 1; position: relative; border-bottom: 1px solid var(--line); border-left: 1px solid var(--line); }
.fa-an .a-chart svg { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; }
.fa-an .a-chart .area { fill: var(--signal); opacity: .12; }
.fa-an .a-chart .line { fill: none; stroke: var(--signal); stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }
.flow.in .fa-an .a-chart .line { stroke-dasharray: 360; stroke-dashoffset: 360; animation: anDraw 1.4s ease-out .2s forwards; }
@keyframes anDraw { to { stroke-dashoffset: 0; } }

/* ---------- footnote ---------- */
.flow-foot {
  margin-top: clamp(34px,4vw,52px); padding-top: 22px; border-top: 1px solid var(--line);
  text-align: center; font-family: var(--ff-mono); font-size: 12px; color: var(--muted); line-height: 1.6; letter-spacing: .02em;
  max-width: 70ch; margin-inline: auto;
}
.flow-foot b { color: var(--ink-2); font-weight: 600; }

/* ---------- responsive: stack ---------- */
@media (max-width: 880px) {
  .flow-step { grid-template-columns: 54px 1fr; align-items: start; gap: 18px; margin-bottom: 32px; }
  .fs-node { grid-column: 1; grid-row: 1 / span 2; justify-self: start; width: 44px; height: 44px; font-size: 15px; }
  .flow-step .fs-art, .flow-step:nth-child(even) .fs-art { grid-column: 2; margin-bottom: 16px; }
  .flow-step .fs-text, .flow-step:nth-child(even) .fs-text { grid-column: 2; text-align: left; align-items: flex-start; }
  .flow-step .fs-art, .flow-step .fs-text { grid-row: auto; }
  .flow-step:nth-child(even) .fs-deliver, .flow-step:nth-child(even) .fs-gate { align-self: flex-start; }
  .fs-art { height: clamp(180px, 42vw, 230px); }
}
@media (prefers-reduced-motion: reduce) {
  .flow.in .fs-node, .flow.in .fa-code .c-cursor, .flow.in .fa-qa .q-live .ld { animation: none; }
  .flow.in .fa-an .a-chart .line { stroke-dasharray: none; stroke-dashoffset: 0; animation: none; }
}


/* ============================================================
   COMPARISON — three "roads" as visual cards
   ============================================================ */
.paths { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(14px,1.8vw,22px); align-items: stretch; }
@media (max-width: 860px) { .paths { grid-template-columns: 1fr; max-width: 440px; margin-inline: auto; } }
.path { display: flex; flex-direction: column; border: 1px solid var(--line-2); border-radius: var(--r-lg); background: var(--surface); overflow: hidden; transition: transform .45s cubic-bezier(.2,.8,.2,1), box-shadow .3s; position: relative; }
.path:hover { transform: translateY(-6px); box-shadow: 0 44px 90px -54px oklch(0.205 0.012 70 / .4); }
.path.best { border-color: var(--signal); box-shadow: 0 44px 95px -50px oklch(0.56 0.072 158 / .45); }
.path.best::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--signal); z-index: 3; }
.path.best:hover { box-shadow: 0 54px 110px -50px oklch(0.56 0.072 158 / .5); }

.path-head { padding: 22px 22px 18px; }
.path-tag { font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }
.path.best .path-tag { color: var(--signal); }
.path-name { font-size: clamp(20px,2.3vw,26px); font-weight: 700; letter-spacing: -.02em; margin-top: 7px; display: flex; align-items: center; gap: 9px; color: var(--ink); }
.path-name .badge { font-family: var(--ff-mono); font-size: 9px; letter-spacing: .06em; text-transform: uppercase; background: var(--signal); color: #fff; padding: 3px 7px; border-radius: 5px; font-weight: 600; }
.path-sub { margin-top: 9px; font-size: 13.5px; color: var(--muted); line-height: 1.45; }

/* cost-over-time mini chart */
.path-chart { padding: 4px 22px 14px; }
.pc-label { display: flex; justify-content: space-between; font-family: var(--ff-mono); font-size: 9px; letter-spacing: .06em; text-transform: uppercase; color: var(--faint); margin-bottom: 8px; }
.pc-graph { height: 72px; position: relative; border-bottom: 1px solid var(--line); }
.pc-graph svg { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; }
.pc-graph .area { opacity: .13; }
.pc-graph .line { fill: none; stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }
.path .pc-graph .area { fill: var(--ink-2); } .path .pc-graph .line { stroke: var(--ink-2); }
.path.best .pc-graph .area { fill: var(--signal); } .path.best .pc-graph .line { stroke: var(--signal); }
.reveal.in .pc-graph .line { stroke-dasharray: 240; stroke-dashoffset: 240; animation: pcDraw 1.3s ease-out .25s forwards; }
.reveal.in .path:nth-child(2) .pc-graph .line { animation-delay: .4s; }
.reveal.in .path:nth-child(3) .pc-graph .line { animation-delay: .55s; }
@keyframes pcDraw { to { stroke-dashoffset: 0; } }
.pc-cap { margin-top: 9px; font-family: var(--ff-mono); font-size: 10px; letter-spacing: .02em; color: var(--muted); }
.pc-cap b { color: var(--ink-2); font-weight: 600; }
.path.best .pc-cap b { color: var(--signal); }

/* dimension rows */
.path-rows { padding: 6px 22px 8px; display: flex; flex-direction: column; }
.pr { display: flex; align-items: flex-start; gap: 11px; padding: 11px 0; border-bottom: 1px solid var(--line); }
.pr:last-child { border-bottom: none; }
.pr > i { width: 19px; height: 19px; border-radius: 50%; flex: none; display: grid; place-items: center; font-family: var(--ff-mono); font-size: 10px; font-style: normal; margin-top: 1px; }
.pr > i.ok { background: var(--signal-bg); color: var(--signal); }
.pr > i.mid { background: oklch(0.92 0.03 80); color: oklch(0.55 0.12 70); }
.pr > i.no { background: oklch(0.94 0.02 25); color: oklch(0.55 0.16 25); }
.pr .pr-t { min-width: 0; }
.pr .pr-k { font-family: var(--ff-mono); font-size: 9.5px; letter-spacing: .07em; text-transform: uppercase; color: var(--muted); }
.pr .pr-v { font-size: 13px; color: var(--ink-2); line-height: 1.35; margin-top: 2px; }
.path.best .pr .pr-v { color: var(--ink); }

/* verdict */
.path-verdict { margin-top: auto; padding: 16px 22px 22px; border-top: 1px solid var(--line); background: var(--paper-2); }
.pv-top { display: flex; align-items: baseline; justify-content: space-between; }
.pv-n { font-family: var(--ff-mono); font-size: 30px; font-weight: 700; letter-spacing: -.02em; color: var(--ink-2); line-height: 1; }
.path.best .pv-n { color: var(--signal); }
.pv-n small { font-size: 14px; color: var(--faint); font-weight: 500; }
.pv-l { font-family: var(--ff-mono); font-size: 9.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); }
.pv-bar { height: 6px; border-radius: 999px; background: var(--line); overflow: hidden; margin-top: 11px; }
.pv-bar i { display: block; height: 100%; width: 0; border-radius: 999px; background: var(--ink-2); transition: width 1.1s cubic-bezier(.2,.8,.2,1) .35s; }
.path.best .pv-bar i { background: linear-gradient(90deg, var(--ink), var(--signal)); }
.reveal.in .pv-bar i { width: var(--f); }
@media (prefers-reduced-motion: reduce) { .reveal.in .pc-graph .line { stroke-dasharray: none; stroke-dashoffset: 0; animation: none; } }


/* ============================================================
   SHOPIFY AI — Magic + Sidekick (dark section)
   ============================================================ */
.ai-section { background: #000; }
.ai-section .sec-title { color: oklch(0.98 0 0); }
.ai-section .sec-title .hl { color: var(--signal); }
.ai-section .sec-sub { color: oklch(0.72 0.01 70); }
.ai-section .sec-eyebrow { color: oklch(0.7 0.01 70); }

.ai-hero { display: grid; grid-template-columns: 1.02fr .98fr; gap: clamp(28px,4vw,60px); align-items: center; margin-bottom: clamp(38px,5vw,62px); }
@media (max-width: 900px) { .ai-hero { grid-template-columns: 1fr; } }

/* ---- Sidekick chat mockup ---- */
.ai-chat { background: oklch(0.155 0.012 255); border: 1px solid oklch(0.3 0.025 255); border-radius: 16px; overflow: hidden;
  box-shadow: 0 50px 110px -50px #000, 0 0 60px -20px oklch(0.5 0.13 250 / .3); }
.aic-bar { display: flex; align-items: center; gap: 10px; padding: 13px 16px; border-bottom: 1px solid oklch(0.26 0.02 255); background: oklch(0.13 0.012 255); }
.aic-ava { width: 30px; height: 30px; border-radius: 9px; background: linear-gradient(135deg, var(--signal), oklch(0.52 0.1 210)); display: grid; place-items: center; color: #fff; font-size: 15px; }
.aic-bar b { color: oklch(0.98 0 0); font-size: 14px; font-weight: 600; letter-spacing: -.01em; }
.aic-bar .on { font-family: var(--ff-mono); font-size: 9px; letter-spacing: .08em; text-transform: uppercase; color: var(--signal); display: inline-flex; align-items: center; gap: 6px; margin-left: auto; }
.aic-bar .on::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--signal); box-shadow: 0 0 8px var(--signal); }
.aic-body { padding: 18px 16px; display: flex; flex-direction: column; gap: 11px; }
.aic-msg { max-width: 86%; padding: 11px 14px; border-radius: 14px; font-size: 13.5px; line-height: 1.5; }
.aic-msg.user { align-self: flex-end; background: oklch(0.28 0.025 255); color: oklch(0.97 0 0); border-bottom-right-radius: 4px; }
.aic-msg.bot { align-self: flex-start; background: oklch(0.2 0.014 255); border: 1px solid oklch(0.3 0.02 255); color: oklch(0.9 0.008 255); border-bottom-left-radius: 4px; }
.aic-msg .gen { margin-top: 9px; padding-top: 9px; border-top: 1px solid oklch(0.3 0.02 255); display: flex; flex-direction: column; gap: 6px; }
.aic-msg .gen i { height: 6px; border-radius: 3px; background: oklch(0.36 0.02 255); display: block; }
.aic-msg .gen i:nth-child(1){width:94%}.aic-msg .gen i:nth-child(2){width:80%}.aic-msg .gen i:nth-child(3){width:88%;background:oklch(0.55 0.09 158)}
.aic-tag { display: inline-flex; align-items: center; gap: 6px; font-family: var(--ff-mono); font-size: 9.5px; letter-spacing: .04em; color: var(--signal); margin-top: 9px; }
.aic-stat { display: flex; align-items: baseline; gap: 8px; margin-top: 9px; }
.aic-stat b { font-family: var(--ff-mono); font-size: 22px; font-weight: 700; color: oklch(0.98 0 0); }
.aic-stat span { font-family: var(--ff-mono); font-size: 10px; color: var(--signal); }
.aic-typing { align-self: flex-start; display: inline-flex; gap: 4px; padding: 12px 14px; background: oklch(0.2 0.014 255); border: 1px solid oklch(0.3 0.02 255); border-radius: 14px; border-bottom-left-radius: 4px; }
.aic-typing span { width: 6px; height: 6px; border-radius: 50%; background: oklch(0.55 0.02 255); animation: aiType 1.3s ease-in-out infinite; }
.aic-typing span:nth-child(2){animation-delay:.18s}.aic-typing span:nth-child(3){animation-delay:.36s}
@keyframes aiType { 0%,60%,100%{opacity:.3;transform:translateY(0)} 30%{opacity:1;transform:translateY(-3px)} }
.aic-input { display: flex; align-items: center; gap: 10px; padding: 12px 14px; border-top: 1px solid oklch(0.26 0.02 255); background: oklch(0.13 0.012 255); }
.aic-input .f { flex: 1; font-family: var(--ff-mono); font-size: 11px; color: oklch(0.5 0.01 255); }
.aic-input .snd { width: 30px; height: 30px; border-radius: 9px; background: var(--signal); color: #fff; display: grid; place-items: center; font-size: 13px; flex: none; }

/* ---- intro side ---- */
.ai-intro { min-width: 0; }
.ai-badge { display: inline-flex; align-items: center; gap: 8px; font-family: var(--ff-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--signal); border: 1px solid oklch(0.4 0.06 158 / .5); background: oklch(0.5 0.08 158 / .1); padding: 6px 12px; border-radius: 999px; margin-bottom: 18px; }
.ai-intro h3 { font-size: clamp(22px,2.6vw,30px); font-weight: 700; letter-spacing: -.025em; color: oklch(0.98 0 0); line-height: 1.12; }
.ai-intro p { margin-top: 14px; font-size: 15.5px; line-height: 1.6; color: oklch(0.74 0.01 70); max-width: 44ch; }
.ai-points { list-style: none; display: flex; flex-wrap: wrap; gap: 8px; margin-top: 20px; }
.ai-points li { font-family: var(--ff-mono); font-size: 11px; color: oklch(0.86 0.01 255); background: oklch(0.18 0.014 255); border: 1px solid oklch(0.3 0.02 255); border-radius: 8px; padding: 7px 11px; display: inline-flex; align-items: center; gap: 7px; }
.ai-points li::before { content: "✦"; color: var(--signal); font-size: 10px; }

/* ---- Magic feature cards ---- */
.ai-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(12px,1.5vw,18px); }
@media (max-width: 900px) { .ai-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .ai-grid { grid-template-columns: 1fr; } }
.ai-card { background: oklch(0.15 0.012 255); border: 1px solid oklch(0.28 0.022 255); border-radius: var(--r-lg); padding: 20px; transition: transform .4s cubic-bezier(.2,.8,.2,1), border-color .3s, box-shadow .3s; }
.ai-card:hover { transform: translateY(-6px); border-color: oklch(0.5 0.08 158 / .6); box-shadow: 0 40px 80px -50px oklch(0.5 0.13 250 / .5); }
.ai-viz { height: 78px; border-radius: 10px; background: oklch(0.12 0.012 255); border: 1px solid oklch(0.26 0.02 255); margin-bottom: 16px; padding: 12px; display: flex; align-items: center; gap: 9px; overflow: hidden; position: relative; }
.ai-card h4 { font-size: 15px; font-weight: 700; letter-spacing: -.01em; color: oklch(0.97 0 0); display: flex; align-items: center; gap: 7px; }
.ai-card h4::before { content: "✦"; color: var(--signal); font-size: 11px; }
.ai-card p { margin-top: 7px; font-size: 12.5px; line-height: 1.5; color: oklch(0.66 0.01 70); }

/* viz 1 — descriptions: typing text lines */
.aiv-desc { flex-direction: column; align-items: stretch; justify-content: center; gap: 7px; }
.aiv-desc i { height: 6px; border-radius: 3px; background: oklch(0.34 0.02 255); }
.aiv-desc i:nth-child(1){width:90%}.aiv-desc i:nth-child(2){width:70%}.aiv-desc i:nth-child(3){width:82%;background:oklch(0.55 0.09 158)}
.ai-section.in .aiv-desc i:nth-child(3){animation:aiGrow 2.4s ease-in-out infinite}
@keyframes aiGrow { 0%,100%{width:40%} 50%{width:82%} }

/* viz 2 — photo background swap */
.aiv-photo { justify-content: center; }
.aiv-photo .ph { width: 46px; height: 50px; border-radius: 7px; flex: none; }
.aiv-photo .ph.a { background: oklch(0.26 0.02 255); position: relative; }
.aiv-photo .ph.a::after, .aiv-photo .ph.b::after { content: ""; position: absolute; inset: auto 0 6px; height: 40%; margin: 0 9px; border-radius: 4px 4px 0 0; background: oklch(0.5 0.02 255); }
.aiv-photo .ph.a { position: relative; } .aiv-photo .ph.a::after { background: oklch(0.45 0.015 255); }
.aiv-photo .ph.b { background: linear-gradient(150deg, oklch(0.7 0.09 158), oklch(0.55 0.1 210)); position: relative; }
.aiv-photo .ph.b::after { background: oklch(0.96 0 0); }
.aiv-photo .ar { color: var(--signal); font-family: var(--ff-mono); font-size: 13px; flex: none; }

/* viz 3 — email subject */
.aiv-mail { flex-direction: column; align-items: stretch; justify-content: center; gap: 6px; }
.aiv-mail .ml { font-family: var(--ff-mono); font-size: 8px; letter-spacing: .08em; text-transform: uppercase; color: oklch(0.5 0.01 255); }
.aiv-mail i { height: 6px; border-radius: 3px; background: oklch(0.34 0.02 255); display: block; }
.aiv-mail i.s { width: 86%; background: oklch(0.55 0.09 158); }
.aiv-mail i.b1{width:96%}.aiv-mail i.b2{width:74%}

/* viz 4 — inbox suggested reply */
.aiv-inbox { flex-direction: column; align-items: stretch; justify-content: center; gap: 6px; }
.aiv-inbox .bub { max-width: 70%; height: 12px; border-radius: 7px; }
.aiv-inbox .bub.q { align-self: flex-start; width: 60%; background: oklch(0.28 0.02 255); }
.aiv-inbox .sug { align-self: flex-end; font-family: var(--ff-mono); font-size: 8.5px; color: var(--signal); border: 1px solid oklch(0.4 0.06 158 / .5); background: oklch(0.5 0.08 158 / .12); border-radius: 7px; padding: 4px 8px; }

.ai-note { margin-top: clamp(28px,3.5vw,40px); text-align: center; font-family: var(--ff-mono); font-size: 12px; letter-spacing: .02em; color: oklch(0.6 0.01 70); line-height: 1.6; }
.ai-note b { color: oklch(0.92 0 0); font-weight: 600; }
.ai-note .star { color: var(--signal); }
@media (prefers-reduced-motion: reduce) { .aic-typing span, .ai-section.in .aiv-desc i:nth-child(3) { animation: none; } }


/* ============================================================
   DIAGNOSTIC — symptom checklist + before/after metrics
   ============================================================ */
.diag-grid { display: grid; grid-template-columns: 1.04fr .96fr; gap: clamp(14px,1.8vw,22px); align-items: start; }
@media (max-width: 900px) { .diag-grid { grid-template-columns: 1fr; } }
.diag-panel { border: 1px solid var(--line-2); border-radius: var(--r-lg); background: var(--surface); box-shadow: 0 40px 90px -60px oklch(0.205 0.012 70 / .3); }

/* left — checklist */
.diag-check { padding: clamp(24px,2.6vw,34px); }
.dc-eyebrow { font-family: var(--ff-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }
.dc-h { font-size: clamp(19px,2.1vw,25px); font-weight: 700; letter-spacing: -.02em; color: var(--ink); margin: 12px 0 16px; line-height: 1.15; }
.dc-list { display: flex; flex-direction: column; }
.dc-item { display: flex; align-items: flex-start; gap: 13px; padding: 14px 0; border-bottom: 1px solid var(--line); cursor: pointer; font-size: 14.5px; color: var(--ink-2); line-height: 1.4; transition: color .2s; -webkit-tap-highlight-color: transparent; }
.dc-item:last-of-type { border-bottom: none; }
.dc-box { width: 22px; height: 22px; border-radius: 6px; border: 1.5px solid var(--line-2); flex: none; display: grid; place-items: center; transition: all .2s cubic-bezier(.2,1.4,.4,1); margin-top: 1px; color: transparent; font-family: var(--ff-mono); font-size: 12px; font-weight: 700; }
.dc-item:hover .dc-box { border-color: var(--ink-2); }
.dc-item.on .dc-box { background: var(--ink); border-color: var(--ink); color: var(--paper); transform: scale(1.04); }
.dc-item.on { color: var(--ink); }
.dc-foot { margin-top: 18px; display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 15px 18px; background: var(--paper-2); border: 1px solid var(--line); border-radius: var(--r-md); font-size: 14px; color: var(--ink-2); line-height: 1.4; transition: background .3s, border-color .3s; }
.dc-foot.hot { background: var(--signal-bg); border-color: oklch(0.6 0.07 158 / .5); }
.dc-foot b { color: var(--ink); font-weight: 700; }
.dc-foot.hot b { color: var(--signal); }
.dc-count { font-family: var(--ff-mono); font-size: 13px; color: var(--muted); white-space: nowrap; flex: none; }
.dc-count b { color: var(--ink); }

/* right — before/after metrics */
.diag-metrics { display: grid; grid-template-columns: 1fr 1fr; overflow: hidden; }
.dm { padding: clamp(18px,2vw,26px); border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.dm:nth-child(2n) { border-right: none; }
.dm:nth-last-child(-n+2) { border-bottom: none; }
.dm-l { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); }
.dm-v { display: flex; align-items: baseline; gap: 9px; margin: 11px 0 9px; flex-wrap: wrap; }
.dm-v s { font-family: var(--ff-mono); font-size: 14px; color: var(--faint); text-decoration: line-through; }
.dm-v .ar { color: var(--muted); font-family: var(--ff-mono); }
.dm-v b { font-size: clamp(22px,2.4vw,30px); font-weight: 700; letter-spacing: -.025em; color: var(--ink); line-height: 1; }
.dm-v b.sig { color: var(--signal); }
.dm-d { font-size: 12.5px; color: var(--muted); line-height: 1.5; text-wrap: pretty; }
@media (max-width: 480px) { .diag-metrics { grid-template-columns: 1fr; } .dm { border-right: none; } .dm:nth-last-child(2) { border-bottom: 1px solid var(--line); } }


/* ============================================================
   DE CE SHOPIFY — bento grid (varied sizes + rich wide cards)
   ============================================================ */
.bento { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(14px,1.6vw,20px); }
.bento .wide { grid-column: span 2; }
@media (max-width: 900px) { .bento { grid-template-columns: 1fr 1fr; } .bento .wide { grid-column: 1 / -1; } }
@media (max-width: 560px) { .bento { grid-template-columns: 1fr; } .bento .wide { grid-column: auto; } }
.bento .bviz { height: 84px; }

/* horizontal wide card */
.bc-h { display: flex; align-items: center; gap: clamp(18px,2.4vw,32px); }
@media (max-width: 560px) { .bc-h { flex-direction: column; align-items: stretch; } }
.bc-h .bc-txt { flex: 1; min-width: 0; }
.bc-h .bc-art { flex: 1.05; min-width: 0; }

/* feature (highlighted) card */
.bcard.feat { background: linear-gradient(150deg, var(--surface) 30%, oklch(0.96 0.022 158)); border-color: oklch(0.6 0.07 158 / .45); }
.bcard.feat::before { transform: scaleX(1); }
.bcard.feat:hover { border-color: oklch(0.58 0.09 158 / .6); }

/* ---- checkout mockup ---- */
.ck-mock { background: var(--paper-2); border: 1px solid var(--line); border-radius: 12px; padding: 14px; display: flex; flex-direction: column; gap: 9px; }
.ck-row { display: flex; align-items: center; gap: 10px; }
.ck-th { width: 26px; height: 26px; border-radius: 6px; flex: none; background: linear-gradient(135deg, oklch(0.85 0.04 60), oklch(0.66 0.09 35)); }
.ck-row:nth-child(2) .ck-th { background: linear-gradient(135deg, oklch(0.9 0.015 200), oklch(0.72 0.05 210)); }
.ck-ln { flex: 1; height: 6px; border-radius: 3px; background: var(--line-2); }
.ck-pr { font-family: var(--ff-mono); font-size: 11px; color: var(--ink-2); }
.ck-tot { display: flex; justify-content: space-between; align-items: baseline; padding-top: 9px; border-top: 1px solid var(--line); }
.ck-tot span { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); }
.ck-tot b { font-size: 16px; font-weight: 700; color: var(--ink); }
.ck-pay { background: #5a31f4; color: #fff; text-align: center; font-size: 12px; font-weight: 700; padding: 10px; border-radius: 8px; box-shadow: 0 10px 22px -10px #5a31f4; }
.ck-pay b { font-weight: 800; font-style: italic; }
.stagger.in .ck-pay { animation: vzpay 2.4s ease-in-out infinite; }
.ck-1c { text-align: center; font-family: var(--ff-mono); font-size: 9.5px; color: var(--muted); letter-spacing: .02em; }

/* ---- maintenance status mockup ---- */
.mt-mock { display: flex; flex-direction: column; gap: 9px; }
.mt-row { display: flex; align-items: center; gap: 10px; font-size: 13px; color: var(--ink-2); background: var(--surface); border: 1px solid var(--line); border-radius: 9px; padding: 10px 12px; }
.mt-ck { width: 18px; height: 18px; border-radius: 50%; background: var(--signal); color: #fff; display: grid; place-items: center; font-family: var(--ff-mono); font-size: 10px; font-weight: 700; flex: none; }
.mt-tag { margin-left: auto; font-family: var(--ff-mono); font-size: 9.5px; letter-spacing: .04em; color: var(--signal); background: var(--signal-bg); border-radius: 5px; padding: 3px 7px; white-space: nowrap; }

/* ---- speed score (viteză) ---- */
.vz-speed .vz-score { display: flex; align-items: baseline; gap: 6px; }
.vz-score b { font-family: var(--ff-mono); font-size: 30px; font-weight: 700; letter-spacing: -.03em; color: var(--signal); line-height: 1; }
.vz-score em { font-family: var(--ff-mono); font-size: 12px; font-style: normal; color: var(--muted); }


/* ============================================================
   FULL-FUNNEL — funnel diagram (dark section)
   ============================================================ */
.ff-funnel { max-width: 940px; margin: clamp(8px,1vw,18px) auto 0; display: flex; flex-direction: column; gap: 12px; }
.ff-stage { margin: 0 auto; width: 100%; border: 1px solid oklch(0.3 0.025 255); border-radius: 14px; background: oklch(0.15 0.012 255); padding: clamp(16px,1.8vw,22px) clamp(20px,3vw,32px); display: flex; align-items: center; justify-content: space-between; gap: 22px; position: relative; transition: transform .4s cubic-bezier(.2,.8,.2,1), border-color .3s; }
.ff-funnel .ff-stage:nth-child(1) { width: 100%; }
.ff-funnel .ff-stage:nth-child(3) { width: 84%; }
.ff-funnel .ff-stage:nth-child(5) { width: 68%; }
.ff-funnel .ff-stage:nth-child(7) { width: 54%; border-color: oklch(0.5 0.08 158 / .55); background: linear-gradient(150deg, oklch(0.15 0.012 255) 40%, oklch(0.2 0.04 158)); }
.ff-stage:hover { border-color: oklch(0.5 0.08 158 / .6); transform: translateY(-3px); }
.ff-st-l { min-width: 0; }
.ff-st-n { font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--signal); }
.ff-st-h { font-size: clamp(16px,1.8vw,20px); font-weight: 700; letter-spacing: -.02em; color: oklch(0.98 0 0); margin: 5px 0 4px; }
.ff-st-d { font-size: 13px; color: oklch(0.7 0.01 70); line-height: 1.45; }
.ff-st-r { flex: none; text-align: right; }
.ff-plat { display: flex; flex-wrap: wrap; gap: 6px; justify-content: flex-end; max-width: 280px; }
.ff-plat span { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .02em; color: oklch(0.88 0.01 255); background: oklch(0.2 0.014 255); border: 1px solid oklch(0.32 0.02 255); border-radius: 7px; padding: 5px 9px; white-space: nowrap; }
.ff-metric { font-family: var(--ff-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--signal); margin-top: 9px; }
@media (max-width: 760px) {
  .ff-funnel .ff-stage { width: 100% !important; flex-direction: column; align-items: flex-start; gap: 12px; }
  .ff-plat { justify-content: flex-start; } .ff-st-r { text-align: left; } .ff-metric { margin-top: 0; }
}
.ff-arrow { text-align: center; color: oklch(0.4 0.02 255); font-family: var(--ff-mono); font-size: 14px; line-height: .4; }
/* ============================================================
   REZULTATE — portfolio page (big image cards + filter + modal)
   ============================================================ */
.rz-hero { background:#000; padding: clamp(84px,11vh,128px) var(--pad) clamp(34px,5vw,52px); text-align:center; }
.rz-hero .sec-eyebrow { color: oklch(0.7 0.01 70); }
.rz-hero h1 { font-size: clamp(34px,5vw,60px); font-weight:700; letter-spacing:-.03em; line-height:1.06; color: oklch(0.98 0 0); text-wrap:balance; max-width:20ch; margin:14px auto 0; }
.rz-hero h1 .hl { color: var(--signal); }
.rz-hero p { color: oklch(0.74 0.01 70); font-size: clamp(16px,1.7vw,19px); line-height:1.55; max-width:56ch; margin:16px auto 0; }
.rz-stats { display:flex; gap: clamp(22px,4vw,56px); justify-content:center; flex-wrap:wrap; margin-top: clamp(26px,3vw,40px); }
.rz-stats .s b { font-family:var(--ff-mono); font-size: clamp(26px,3.4vw,42px); font-weight:700; letter-spacing:-.03em; color: oklch(0.98 0 0); display:block; }
.rz-stats .s span { font-family:var(--ff-mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color: oklch(0.6 0.01 70); }
.rz-stats .s b .u { color: var(--signal); }

/* tools / filter bar — pastile cu simboluri, fără căutare */
.rz-tools { position: sticky; top: 66px; z-index: 20; background: oklch(0.985 0.004 80 / .92); backdrop-filter: blur(12px); border-bottom:1px solid var(--line); padding: 14px var(--pad); }
.rz-tools-in { max-width: var(--maxw); margin:0 auto; }
.rz-chips { display:flex; flex-wrap:wrap; gap:8px; align-items:center; }
.rz-chip {
  flex:none; display:inline-flex; align-items:center; gap:8px;
  padding:8px 15px 8px 11px;
  border:1px solid var(--line-2); border-radius:100px;
  background:var(--surface); cursor:pointer;
  font-family:var(--ff-sans); font-size:13.5px; font-weight:500; color:var(--ink-2);
  white-space:nowrap; transition: all .18s ease;
}
.rz-chip .ic {
  width:22px; height:22px; border-radius:50%; flex:none;
  display:grid; place-items:center;
  background:var(--paper-2);
  font-family:var(--ff-mono); font-size:11px; line-height:1; color:var(--muted);
  transition: all .18s ease;
}
.rz-chip .ct { font-family:var(--ff-mono); font-size:10.5px; color:var(--faint); transition: color .18s ease; }
.rz-chip:hover { border-color:var(--ink); color:var(--ink); transform:translateY(-1px); }
.rz-chip.active { background:var(--ink); border-color:var(--ink); color:var(--paper); font-weight:600; }
.rz-chip.active .ic { background: oklch(0.985 0.004 80 / .14); color:var(--paper); }
.rz-chip.active .ct { color: oklch(0.985 0.004 80 / .6); }

/* grid + big cards */
.rz-wrap { max-width: var(--maxw); margin:0 auto; padding: clamp(28px,4vw,52px) var(--pad) clamp(56px,8vw,100px); }
.rz-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(330px,1fr)); gap: clamp(16px,1.8vw,24px); }
.st-card { display:flex; flex-direction:column; border:1px solid var(--line-2); border-radius:var(--r-lg); background:var(--surface); overflow:hidden; cursor:pointer; text-align:left; padding:0; font:inherit; color:inherit; transition: transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .3s, border-color .3s; }
.st-card:hover { transform:translateY(-5px); box-shadow:0 40px 80px -45px oklch(0.205 0.012 70 / .42); border-color: var(--cdot, var(--line-2)); }
.st-img { aspect-ratio: 16/10; background: var(--cbg, var(--paper-2)); position:relative; overflow:hidden; border-bottom:1px solid var(--line); }
.st-img image-slot { display:block; width:100%; height:100%; }
.st-img .st-ph { position:absolute; inset:0; display:grid; place-items:center; }
.st-img .st-ph span { font-family:var(--ff-mono); font-size:34px; font-weight:700; color: var(--cfg, var(--muted)); opacity:.5; }
.st-badge { position:absolute; top:12px; left:12px; z-index:2; font-family:var(--ff-mono); font-size:10px; letter-spacing:.04em; text-transform:uppercase; background: oklch(1 0 0 / .92); backdrop-filter:blur(6px); color: var(--cfg, var(--ink-2)); padding:5px 9px; border-radius:7px; display:inline-flex; align-items:center; gap:6px; box-shadow:0 4px 12px -6px oklch(0 0 0 /.4); }
.st-badge .cd { width:7px; height:7px; border-radius:50%; background:var(--cdot,var(--muted)); }
.st-info { padding:18px 20px 20px; display:flex; flex-direction:column; gap:10px; flex:1; }
.st-domain { font-size:17px; font-weight:700; letter-spacing:-.015em; color:var(--ink); display:flex; align-items:center; gap:7px; }
.st-domain .arr { color: var(--faint); transition: color .2s, transform .2s; }
.st-card:hover .st-domain .arr { color: var(--cfg, var(--signal)); transform: translate(2px,-2px); }
.st-tagline { font-size:13.5px; color:var(--muted); line-height:1.5; text-wrap:pretty; }
.st-services { display:flex; flex-wrap:wrap; gap:6px; margin-top:auto; padding-top:4px; }
.sv { font-family:var(--ff-mono); font-size:10px; letter-spacing:.01em; padding:4px 9px 4px 7px; border-radius:6px; border:1px solid var(--line); background:var(--paper-2); color:var(--ink-2); display:inline-flex; align-items:center; gap:6px; white-space:nowrap; }
.sv::before { content:""; width:6px; height:6px; border-radius:50%; background: var(--svc,var(--muted)); }
.sv.shopify, .sv.meta, .sv.google, .sv.tiktok, .sv.funnel { --svc: var(--faint); }

.rz-empty { text-align:center; color:var(--muted); font-size:15px; padding: clamp(40px,8vw,90px) 0; display:none; }
.rz-empty.show { display:block; }

/* category palette — neutral paper/ink (fără culori pe carduri) */
.c-fashion, .c-casa, .c-alimente, .c-frumusete, .c-copii,
.c-electro, .c-sport, .c-auto, .c-beauty, .c-diverse {
  --cdot: var(--ink-2);
  --cbg: var(--paper-2);
  --cfg: var(--ink-2);
}

/* modal */
.rz-modal { position:fixed; inset:0; z-index:200; display:none; }
.rz-modal.open { display:block; }
.rz-modal-bg { position:absolute; inset:0; background: oklch(0.1 0.01 70 / .62); backdrop-filter: blur(5px); animation: rzFade .25s ease; }
@keyframes rzFade { from { opacity:0; } to { opacity:1; } }
.rz-modal-panel { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:min(940px,94vw); max-height:90vh; overflow:hidden; background:var(--surface); border:1px solid var(--line-2); border-radius:20px; box-shadow:0 60px 120px -40px oklch(0 0 0 /.6); display:grid; grid-template-columns: 1.1fr 1fr; animation: rzPop .3s cubic-bezier(.2,.9,.3,1); }
@keyframes rzPop { from { opacity:0; transform:translate(-50%,-46%) scale(.97); } to { opacity:1; transform:translate(-50%,-50%) scale(1); } }
@media (max-width:760px){ .rz-modal-panel { grid-template-columns:1fr; max-height:92vh; overflow:auto; } }
.rz-m-img { background:var(--cbg,var(--paper-2)); position:relative; min-height:320px; }
.rz-m-img image-slot { display:block; width:100%; height:100%; }
.rz-m-img .st-ph { position:absolute; inset:0; display:grid; place-items:center; }
.rz-m-img .st-ph span { font-family:var(--ff-mono); font-size:60px; font-weight:700; color:var(--cfg,var(--muted)); opacity:.45; }
@media (max-width:760px){ .rz-m-img { min-height:200px; aspect-ratio:16/10; } }
.rz-m-body { padding: clamp(24px,3vw,38px); overflow:auto; display:flex; flex-direction:column; gap:14px; }
.rz-m-badge { align-self:flex-start; font-family:var(--ff-mono); font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--cfg,var(--muted)); background:var(--cbg,var(--paper-2)); padding:6px 11px; border-radius:8px; display:inline-flex; align-items:center; gap:7px; }
.rz-m-badge .cd { width:7px; height:7px; border-radius:50%; background:var(--cdot,var(--muted)); }
.rz-m-domain { font-size: clamp(24px,3vw,34px); font-weight:700; letter-spacing:-.025em; color:var(--ink); line-height:1.1; }
.rz-m-services { display:flex; flex-wrap:wrap; gap:7px; }
.rz-m-story { font-size:15px; color:var(--ink-2); line-height:1.65; text-wrap:pretty; }
.rz-m-visit { margin-top:auto; align-self:flex-start; display:inline-flex; align-items:center; gap:9px; background:var(--ink); color:var(--paper); text-decoration:none; font-weight:600; font-size:14.5px; padding:13px 22px; border-radius:10px; transition:transform .2s; }
.rz-m-visit:hover { transform:translateY(-2px); }
.rz-m-close { position:absolute; top:14px; right:14px; z-index:3; width:38px; height:38px; border-radius:50%; border:none; background: oklch(1 0 0 / .9); backdrop-filter:blur(6px); color:var(--ink); font-size:18px; cursor:pointer; display:grid; place-items:center; box-shadow:0 6px 18px -8px oklch(0 0 0 /.5); transition: transform .2s, background .2s; }
.rz-m-close:hover { transform: rotate(90deg); background: var(--ink); color:var(--paper); }
body.rz-locked { overflow:hidden; }
@media (max-width:600px){ .rz-tools { top: 0; } }


/* ============================================================
   CONTACT
   ============================================================ */
.ct-hero { background:#000; padding: clamp(84px,11vh,128px) var(--pad) clamp(38px,5vw,58px); text-align:center; }
.ct-hero .sec-eyebrow { color:oklch(0.7 0.01 70); }
.ct-hero h1 { font-size:clamp(36px,5vw,64px); font-weight:700; letter-spacing:-.03em; color:oklch(0.98 0 0); margin:14px auto 0; max-width:16ch; line-height:1.05; }
.ct-hero h1 .hl { color:var(--signal); }
.ct-hero p { color:oklch(0.74 0.01 70); font-size:clamp(16px,1.7vw,19px); margin:16px auto 0; max-width:48ch; line-height:1.55; }
.ct-wrap { max-width:1080px; margin:0 auto; padding: clamp(36px,5vw,72px) var(--pad) clamp(56px,8vw,100px); }
.ct-grid { display:grid; grid-template-columns:1.25fr .85fr; gap:clamp(24px,4vw,52px); align-items:start; }
@media(max-width:820px){ .ct-grid { grid-template-columns:1fr; } }
.ct-form { display:flex; flex-direction:column; gap:18px; }
.ct-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media(max-width:520px){ .ct-row { grid-template-columns:1fr; } }
.ct-field { display:flex; flex-direction:column; gap:7px; }
.ct-label { font-family:var(--ff-mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); }
.ct-input { width:100%; border:1px solid var(--line-2); border-radius:10px; padding:13px 15px; font-family:var(--ff-sans); font-size:15px; color:var(--ink); background:var(--surface); transition:border-color .18s; }
.ct-input::placeholder { color:var(--faint); }
.ct-input:focus { border-color:var(--ink); outline:none; }
textarea.ct-input { min-height:130px; resize:vertical; }
.ct-svc { display:flex; flex-wrap:wrap; gap:8px; }
.ct-svc label { cursor:pointer; }
.ct-svc input { position:absolute; opacity:0; width:0; height:0; }
.ct-svc span { display:inline-block; font-family:var(--ff-mono); font-size:12px; padding:8px 13px; border:1px solid var(--line-2); border-radius:999px; color:var(--ink-2); transition:all .18s; }
.ct-svc label:hover span { border-color:var(--ink-2); }
.ct-svc input:checked + span { background:var(--ink); color:var(--paper); border-color:var(--ink); }
.ct-submit { align-self:flex-start; background:var(--ink); color:var(--paper); border:none; border-radius:10px; padding:15px 28px; font-family:var(--ff-sans); font-size:15px; font-weight:600; cursor:pointer; display:inline-flex; align-items:center; gap:10px; transition:transform .2s, box-shadow .25s; }
.ct-submit:hover { transform:translateY(-2px); box-shadow:0 14px 30px -14px oklch(0.205 0.012 70 /.6); }
.ct-ok { display:none; padding:15px 18px; border-radius:10px; background:var(--signal-bg); border:1px solid oklch(0.6 0.07 158 /.45); color:var(--signal); font-size:14.5px; line-height:1.5; }
.ct-ok.show { display:block; }
.ct-side { display:flex; flex-direction:column; gap:14px; }
.ct-card { border:1px solid var(--line-2); border-radius:var(--r-lg); background:var(--surface); padding:20px 22px; }
.ct-card .ic { width:38px; height:38px; border-radius:10px; background:var(--signal-bg); color:var(--signal); display:grid; place-items:center; font-family:var(--ff-mono); font-size:16px; margin-bottom:13px; }
.ct-card h3 { font-size:11px; font-family:var(--ff-mono); letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.ct-card a, .ct-card .v { display:block; font-size:15.5px; color:var(--ink); text-decoration:none; margin-top:7px; line-height:1.5; }
.ct-card a:hover { color:var(--signal); }
.ct-loc { margin-top:12px; }
.ct-loc:first-of-type { margin-top:7px; }
.ct-loc b { display:block; font-size:14.5px; color:var(--ink); }
.ct-loc span { font-size:13px; color:var(--muted); }
