/* ===== TOKENS ===== */
:root{
  --bg:#f1f1f0;
  --card:#ffffff;
  --ink:#161513;
  --ink-2:#3a3833;
  --muted:#8c8980;
  --line:#e6e5e0;
  --acc:#ff5b29;
  --dark:#121110;
  --radius:24px;
  --radius-sm:18px;
  --shadow:0 1px 2px rgba(20,19,17,.04), 0 12px 30px -18px rgba(20,19,17,.18);
  --maxw:1160px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--bg)}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg);color:var(--ink);
  -webkit-font-smoothing:antialiased;line-height:1.55;overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Inter Tight',sans-serif;letter-spacing:-.03em;line-height:1.04;font-weight:700}
a{color:inherit;text-decoration:none}
.page{max-width:var(--maxw);margin:0 auto;padding:0 clamp(16px,4vw,40px)}
.acc{color:var(--acc)}
.soft{color:var(--muted)}
.hide-mob{display:inline}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 24px;border-radius:14px;
  font-weight:600;font-size:15px;border:none;cursor:pointer;font-family:'Inter';
  transition:transform .22s ease, box-shadow .22s ease, background .2s, color .2s;white-space:nowrap}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{transform:translateY(-2px);box-shadow:0 14px 26px -14px rgba(20,19,17,.6)}
.btn-light{background:var(--bg);color:var(--ink)}
.btn-light:hover{background:var(--ink);color:#fff}
.btn-orange{background:var(--acc);color:#fff}
.btn-orange:hover{transform:translateY(-2px);box-shadow:0 14px 26px -12px rgba(255,91,41,.6)}
.arrow{display:inline-flex;align-items:center;transition:transform .22s}
.arrow svg{width:16px;height:16px}
.btn:hover .arrow{transform:translateX(4px)}

/* ===== TOP BAR ===== */
.bar{display:flex;align-items:center;gap:20px;padding:14px 0 12px}
.brand{display:flex;align-items:center;gap:12px}
/* ===== LOGO — wordmark inside a little window ===== */
.logo-win{display:inline-flex;flex-direction:column;background:var(--card);border:1px solid var(--line);
  border-radius:14px;box-shadow:var(--shadow);overflow:hidden;
  transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s;
  animation:winOpen .5s cubic-bezier(.34,1.4,.64,1) backwards}
.brand:hover .logo-win{transform:translateY(-2px);
  box-shadow:0 1px 2px rgba(20,19,17,.05),0 18px 34px -20px rgba(20,19,17,.42)}
.win-bar{display:flex;align-items:center;gap:6px;padding:7px 12px;background:var(--bg);
  border-bottom:1px solid var(--line)}
.win-bar i{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.win-bar i:nth-child(1){background:#ff5f57}
.win-bar i:nth-child(2){background:#febc2e}
.win-bar i:nth-child(3){background:#28c840}
.logo{display:inline-flex;align-items:baseline;padding:9px 16px 12px;
  font-family:'Inter Tight',sans-serif;font-weight:800;
  font-size:clamp(26px,3.6vw,38px);letter-spacing:-.045em;line-height:1;color:var(--ink);white-space:nowrap}
.logo>*{display:inline-block;transform-origin:50% 78%;
  animation:logoPop .62s cubic-bezier(.34,1.56,.64,1) backwards;animation-delay:calc(.24s + var(--i,0)*.06s)}
.logo .lg-dim{color:var(--muted)}
.logo-dot{align-self:flex-end;width:.19em;height:.19em;margin:0 .1em .05em;border-radius:50%;background:var(--acc);
  box-shadow:0 0 3px 0 rgba(255,91,41,.3);
  animation:logoPop .62s cubic-bezier(.34,1.56,.64,1) calc(.24s + var(--i,0)*.06s) backwards,
            logoDotGlow 4.5s ease-in-out 1.7s infinite}
@keyframes winOpen{0%{opacity:0;transform:scale(.85) translateY(-6px)}100%{opacity:1;transform:scale(1) translateY(0)}}
@keyframes logoPop{
  0%{opacity:0;transform:scale(0) translateY(.18em)}
  55%{opacity:1;transform:scale(1.2) translateY(-.03em)}
  75%{transform:scale(.93)}
  100%{opacity:1;transform:scale(1) translateY(0)}
}
@keyframes logoDotGlow{
  0%,100%{box-shadow:0 0 2px 0 rgba(255,91,41,.25)}
  50%{box-shadow:0 0 9px 1px rgba(255,91,41,.6)}
}
.bar-links{display:flex;gap:10px;margin-left:auto;font-size:14px;font-weight:600}
.bar-links a{padding:9px 16px;border-radius:10px;background:var(--card);border:1px solid var(--line);
  color:var(--ink-2);transition:background .2s,color .2s,border-color .2s}
.bar-links a:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.menu-btn{width:44px;height:44px;margin-left:auto;border-radius:50%;background:var(--card);border:1px solid var(--line);
  display:none;flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:pointer}
.menu-btn span{width:16px;height:2px;background:var(--ink);border-radius:2px;
  transition:transform .25s ease, opacity .2s ease}
/* hamburger → X when menu open */
.menu-btn[aria-expanded="true"] span:nth-child(1){transform:translateY(3.5px) rotate(45deg)}
.menu-btn[aria-expanded="true"] span:nth-child(2){transform:translateY(-3.5px) rotate(-45deg)}

/* ===== HERO ===== */
.hero{padding:12px 0 clamp(20px,3vw,30px)}
.hero h1{font-size:clamp(34px,5.6vw,60px);font-weight:700;max-width:none}
.hero h1 .strong{font-weight:800}
.avatar{display:inline-grid;place-items:center;vertical-align:middle;margin:0 .14em;
  width:1.05em;height:1.05em;transform:translateY(-.04em)}
.avatar img{width:100%;height:100%;box-sizing:border-box;object-fit:cover;border-radius:.32em;
  border:4px solid #fff;box-shadow:0 6px 16px -5px rgba(20,19,17,.35)}
/* hero reveal — soft de-blur word-by-word fade-in (JS-driven) */
.hero h1 .wd,.hero h1 .avatar{
  transition:opacity 1.1s cubic-bezier(.22,.61,.36,1),filter 1.1s cubic-bezier(.22,.61,.36,1)}
.hero-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:24px}
.badge{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--card);
  border:1px solid var(--line);border-radius:14px;font-weight:600;font-size:14px;height:52px;padding:0 20px}
.badge .dot{width:9px;height:9px;border-radius:50%;background:#27c93f;box-shadow:0 0 0 0 rgba(39,201,63,.5);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(39,201,63,.5)}70%{box-shadow:0 0 0 7px rgba(39,201,63,0)}100%{box-shadow:0 0 0 0 rgba(39,201,63,0)}}
.hero-row .btn-dark{height:52px;padding:0 24px}
/* nav moved into the hero — sits right after the buttons, aligned to pill height */
.hero-row .bar-links{gap:8px;margin-left:0}
.hero-row .bar-links a{display:inline-flex;align-items:center;height:52px;padding:0 18px;border-radius:14px}

/* ===== BENTO ===== */
.bento{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:minmax(0,auto);gap:16px;padding-bottom:clamp(50px,7vw,90px)}
.cell{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);
  transition:transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s}
.cell:hover{transform:translateY(-4px);box-shadow:0 1px 2px rgba(20,19,17,.04),0 22px 44px -22px rgba(20,19,17,.28)}
.cell-tag{display:inline-block;font-size:12px;font-weight:600;letter-spacing:.03em;color:var(--muted);
  text-transform:uppercase;margin-bottom:18px}

.cell-dir{grid-row:span 2;display:flex;flex-direction:column}
.pill-tag{display:inline-flex;align-items:center;align-self:flex-start;padding:7px 14px;
  font-size:11px;font-weight:600;letter-spacing:.05em;text-indent:.05em;text-transform:uppercase;
  color:var(--muted);background:var(--bg);border:1px solid var(--line);border-radius:100px;margin-bottom:8px}
.pill-tag.on-dark{color:rgba(255,255,255,.55);background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.12)}
.dir-list{list-style:none;flex:1;display:flex;flex-direction:column}
.dir-list li{flex:1;display:flex;gap:14px;align-items:center;padding:16px 0}
.dir-list li+li{border-top:1px solid var(--line)}
.dir-ic{width:48px;height:48px;display:grid;place-items:center;background:var(--bg);
  border:1px solid var(--line);border-radius:14px;flex-shrink:0;transition:background .2s,transform .25s}
.cell-dir li:hover .dir-ic{background:#fff;transform:translateY(-2px)}
.dir-img{width:24px;height:24px;display:block}
.dir-list b{font-family:'Inter Tight';font-size:18px;font-weight:700;display:block;margin-bottom:2px}
.dir-list small{color:var(--muted);font-size:13px;line-height:1.35}

.cell-now{background:#0b0a09;color:#fff;position:relative;overflow:hidden;
  display:flex;flex-direction:column;border-color:rgba(255,255,255,.08)}
/* animated orange code behind glass */
.now-code{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none;
  display:flex;flex-direction:column;align-items:flex-end;justify-content:flex-end}
.now-code pre{margin:0;padding:16px 18px;white-space:pre-wrap;word-break:break-word;text-align:right;
  font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace;font-size:11.5px;line-height:1.7;
  color:rgba(255,128,72,1);text-shadow:0 0 9px rgba(255,91,41,.55)}
.caret{display:inline-block;width:.55em;color:#ff8a4c;animation:blink 1.05s steps(1) infinite}
@keyframes blink{0%,50%{opacity:1}50.01%,100%{opacity:0}}
.now-glass{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(11,10,9,.42),rgba(11,10,9,.3));
  -webkit-backdrop-filter:blur(3px) saturate(125%);backdrop-filter:blur(3px) saturate(125%)}
.cell-now .pill-tag,.cell-now h3,.cell-now .now-tags,.cell-now .status{position:relative;z-index:2}
.cell-now .pill-tag{margin-bottom:0}
.cell-now h3{font-size:28px;color:#fff;margin:24px 0}
.cell-now .status{margin-top:34px}
.now-tags{display:flex;flex-wrap:wrap;gap:7px}
.now-tags span{padding:5px 11px;font-size:12px;font-weight:500;border-radius:100px;
  color:rgba(255,255,255,.72);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.13);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.status{display:inline-flex;align-items:center;gap:9px;align-self:flex-start;margin-top:24px;
  padding:8px 15px;border-radius:100px;font-size:12.5px;font-weight:500;letter-spacing:.02em;
  font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace;color:rgba(255,255,255,.72);
  background:rgba(0,0,0,.32);border:1px solid rgba(255,255,255,.15);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.status-dots{display:inline-flex;gap:4px}
.status-dots i{width:5px;height:5px;border-radius:50%;background:var(--acc);animation:loadDot 1.2s ease-in-out infinite}
.status-dots i:nth-child(2){animation-delay:.15s}
.status-dots i:nth-child(3){animation-delay:.3s}
@keyframes loadDot{0%,100%{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(-4px)}}
@keyframes pulse2{0%,100%{opacity:1}50%{opacity:.3}}

.cell-stat{display:flex;flex-direction:column}
.stickers{flex:1;display:flex;flex-wrap:wrap;align-content:center;justify-content:center;
  gap:14px;margin-top:22px}
.sticky{position:relative;width:calc(50% - 7px);min-height:96px;display:flex;flex-direction:column;
  justify-content:center;padding:16px;border-radius:12px;background:#fff;border:1px solid var(--line);
  box-shadow:0 10px 20px -12px rgba(20,19,17,.3);transition:transform .28s cubic-bezier(.2,.8,.2,1)}
.sticky::before{content:"";position:absolute;top:-7px;left:50%;width:40px;height:15px;border-radius:2px;
  background:rgba(20,19,17,.08);transform:translateX(-50%) rotate(-5deg)}
.sticky:nth-child(1){transform:rotate(-3deg)}
.sticky:nth-child(2){transform:rotate(2.6deg)}
.sticky:nth-child(3){transform:rotate(-1.6deg);width:62%}
.sticky:hover{transform:rotate(0) translateY(-4px);z-index:3}
.sticky b{font-family:'Inter Tight';font-size:34px;font-weight:800;line-height:1;letter-spacing:-.02em}
.sticky>span{display:flex;align-items:center;color:var(--muted);font-size:12.5px;margin-top:6px}
.sticky-acc{background:rgba(255,91,41,.1);border-color:rgba(255,91,41,.28);
  box-shadow:0 12px 22px -16px rgba(255,91,41,.4)}
.sticky-acc b{color:var(--acc)}
.live{width:7px;height:7px;border-radius:50%;background:var(--acc);display:inline-block;
  margin-right:7px;animation:pulse2 1.5s ease-in-out infinite}

.cell-stack{grid-column:span 2}
.chips{display:flex;flex-wrap:wrap;gap:9px}
.chips span{background:var(--bg);border:1px solid var(--line);border-radius:100px;padding:8px 15px;font-size:13px;font-weight:600}

.timeline{list-style:none;display:flex;flex-direction:column;gap:16px;position:relative;padding-left:18px}
.timeline::before{content:"";position:absolute;left:4px;top:6px;bottom:6px;width:2px;background:var(--line)}
.timeline li{position:relative}
.timeline li::before{content:"";position:absolute;left:-18px;top:5px;width:9px;height:9px;border-radius:50%;background:var(--ink)}
.timeline li:first-child::before{background:var(--acc);animation:dotPulse 2s ease-out infinite}
@keyframes dotPulse{0%{box-shadow:0 0 0 0 rgba(255,91,41,.5)}70%{box-shadow:0 0 0 8px rgba(255,91,41,0)}100%{box-shadow:0 0 0 0 rgba(255,91,41,0)}}
.timeline b{font-family:'Inter Tight';font-size:16px;font-weight:700;display:block}
.timeline small{color:var(--muted);font-size:13px}
/* fade older entries: top dark → bottom lighter */
.timeline li:not(:first-child) b{color:var(--muted)}
.timeline li:last-child b{color:#c2bfb6}
.timeline li:last-child small{color:#cecbc2}

.cell-exp .pill-tag{margin-bottom:20px}

/* CTA card with mini-terminal + bottom-right button */
.cell-cta{position:relative;overflow:hidden;display:flex;flex-direction:column;
  background:var(--acc);color:#fff;border-color:transparent}
.cell-cta h3{font-size:28px;color:#fff}
.cta-code{align-self:flex-start;margin-top:16px;display:inline-flex;align-items:center;
  font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace;font-size:13px;color:rgba(255,255,255,.92);
  background:rgba(0,0,0,.16);padding:7px 12px;border-radius:9px;white-space:nowrap}
.cta-code .cta-cmd{min-width:1px}
.cta-code i{width:7px;height:14px;margin-left:4px;background:rgba(255,255,255,.9);border-radius:1px;
  animation:caretBlink 1.05s steps(1) infinite}
@keyframes caretBlink{0%,50%{opacity:1}50.01%,100%{opacity:0}}
.cell-cta .btn{align-self:flex-end;margin-top:auto}

/* ===== WORK (dark) ===== */
.work{background:var(--dark);color:#fff;margin:0 calc(-1*clamp(16px,4vw,40px));
  padding:clamp(22px,4vw,40px);border-radius:36px}
.work-head{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;flex-wrap:wrap;
  max-width:var(--maxw);margin:0 auto 22px}
.work-head h2{font-size:clamp(30px,4.4vw,52px);color:#fff;line-height:1}
.work-badge{display:inline-flex;align-items:center;justify-content:center;padding:9px 16px 8px;
  font-size:12px;font-weight:600;line-height:1;letter-spacing:.04em;text-indent:.04em;text-transform:uppercase;
  color:rgba(255,255,255,.7);background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);border-radius:100px}
.filters-bar{display:flex;gap:10px;align-items:stretch;flex-wrap:wrap;max-width:var(--maxw);margin:0 auto 26px}
.filters{display:flex;gap:10px;flex-wrap:wrap}
.filter-hint{flex:1 1 280px;min-height:40px;display:flex;align-items:center;gap:14px;overflow:hidden;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:100px;padding:0 10px 0 22px}
.filter-hint p{flex-shrink:0;color:rgba(255,255,255,.6);font-size:13px;font-weight:500;white-space:nowrap}
.hint-anim{flex:1;min-width:0;overflow:hidden;
  -webkit-mask:linear-gradient(90deg,transparent,#000 14%,#000 86%,transparent);
  mask:linear-gradient(90deg,transparent,#000 14%,#000 86%,transparent)}
.hint-marquee{display:inline-flex;align-items:center;gap:22px;width:max-content;
  font-size:19px;animation:hintscroll 20s linear infinite}
.hint-marquee span{filter:grayscale(.15);opacity:.85}
@keyframes hintscroll{to{transform:translateX(-50%)}}
.filters-bar:hover .hint-marquee{animation-play-state:paused}
.pill{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:100px;
  padding:9px 20px;font-weight:600;font-size:14px;cursor:pointer;color:rgba(255,255,255,.8);font-family:'Inter';transition:.2s}
.pill:hover{border-color:rgba(255,255,255,.4);color:#fff}
.pill.is-active{background:#fff;color:var(--ink);border-color:#fff}

.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:var(--maxw);margin:0 auto}
.proj{position:relative;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);
  overflow:hidden;cursor:pointer;transition:transform .3s cubic-bezier(.2,.8,.2,1),background .3s,border-color .3s}
/* stretch the corner link across the whole card so the entire card is clickable */
a.open-btn::after{content:"";position:absolute;inset:0;z-index:2}
.proj:hover{transform:translateY(-6px);background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.22)}
.proj.hide{display:none}
.proj-thumb{height:150px;padding-top:26px;display:grid;place-items:center;position:relative;overflow:hidden;
  background:radial-gradient(120% 120% at 30% 20%,#2a2926,#141312)}
.proj-thumb::before{content:"";position:absolute;left:50%;top:calc(50% + 13px);width:150px;height:150px;
  border-radius:50%;background:radial-gradient(circle,rgba(var(--glow,255 91 41)/.6),transparent 64%);filter:blur(6px);
  transform:translate(-50%,-50%) scale(.5);opacity:0;z-index:0;transition:opacity .35s ease}
.proj:hover .proj-thumb::before{opacity:1;animation:glowPulse 2.4s ease-in-out infinite}
@keyframes glowPulse{
  0%,100%{transform:translate(-50%,-50%) scale(.9)}
  50%{transform:translate(-50%,-50%) scale(1.15)}
}
.proj-thumb .emoji,.proj-logo{position:relative;z-index:1}
.proj-thumb .emoji{font-size:50px;filter:drop-shadow(0 6px 12px rgba(0,0,0,.4));transition:transform .35s}
.proj:hover .emoji{transform:scale(1.14) rotate(-6deg)}
.proj-logo{width:72px;height:72px;object-fit:contain;border-radius:18px;
  filter:drop-shadow(0 8px 18px rgba(0,0,0,.45));transition:transform .35s cubic-bezier(.2,.8,.2,1)}
.proj:hover .proj-logo{transform:scale(1.08) rotate(-3deg)}
.tag{position:absolute;top:12px;left:12px;display:inline-flex;align-items:center;line-height:1;
  height:26px;padding:0 12px;font-size:11px;font-weight:600;letter-spacing:.01em;
  background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.18);
  border-radius:100px;backdrop-filter:blur(6px)}
.proj-body{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;
  padding:16px 18px 18px;border-top:1px solid rgba(255,255,255,.13)}
.proj:hover .proj-body{border-top-color:rgba(255,255,255,.22)}
.proj-text{min-width:0}
.proj-text h3{font-size:18px;color:#fff;margin-bottom:6px}
.proj-text p{font-size:13px;line-height:1.45;color:rgba(255,255,255,.5);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  min-height:calc(1.45em * 2)}
.open-btn{flex-shrink:0;width:34px;height:34px;display:grid;place-items:center;
  background:rgba(255,255,255,.07);color:rgba(255,255,255,.65);
  border:1px solid rgba(255,255,255,.16);border-radius:50%;
  transition:background .2s,color .2s,border-color .2s}
.open-btn svg{width:16px;height:16px}
.proj:hover .open-btn{background:#fff;color:var(--ink);border-color:#fff}
/* arrow flies out to the top-right, returns from the bottom-left, settles in the center */
.proj:hover .open-btn:not(.open-static) svg{animation:arrowFly .55s cubic-bezier(.5,0,.2,1)}
@keyframes arrowFly{
  0%{transform:translate(0,0);opacity:1}
  40%{transform:translate(170%,-170%);opacity:0}
  41%{transform:translate(-170%,170%);opacity:0}
  100%{transform:translate(0,0);opacity:1}
}

/* tag variants */
.tag.dev{gap:6px;background:rgba(255,91,41,.16);border-color:rgba(255,91,41,.45);color:#ffb59b}
.tag.dev .tag-dot{width:6px;height:6px;border-radius:50%;background:var(--acc);animation:pulse2 1.6s infinite}
.tag.free{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.16);color:rgba(255,255,255,.55)}

/* in-development card */
.proj.is-dev{cursor:default}
.proj.is-dev .open-static{pointer-events:none}

/* invite "your project" cards */
.proj.is-empty{border-style:dashed;border-color:rgba(255,255,255,.22);background:transparent}
.proj.is-empty:hover{border-color:rgba(255,255,255,.4);background:rgba(255,255,255,.03)}
.proj-link{display:flex;flex-direction:column;height:100%;color:inherit}
.proj.is-empty .proj-thumb{background:rgba(255,255,255,.025)}
.proj.is-empty .emoji{opacity:.4;font-weight:300;color:#fff}
.proj.is-empty .proj-body{border-top-color:rgba(255,255,255,.12);flex:1}
.proj.is-empty .proj-text p{color:rgba(255,255,255,.42)}

/* ===== PRICING ===== */
.pricing{padding:clamp(56px,8vw,96px) 0}
.price-head{text-align:center;max-width:600px;margin:0 auto 46px}
.price-head h2{font-size:clamp(30px,4.4vw,52px);margin:14px 0 16px}
.price-head>p{color:var(--muted);font-size:16px;max-width:42ch;margin:0 auto 28px}
.toggle{position:relative;display:inline-flex;background:var(--card);border:1px solid var(--line);
  border-radius:100px;padding:5px;box-shadow:var(--shadow)}
.toggle-slider{position:absolute;top:5px;bottom:5px;left:5px;width:calc(50% - 5px);
  background:var(--ink);border-radius:100px;transition:transform .3s cubic-bezier(.2,.8,.2,1)}
.toggle.fix .toggle-slider{transform:translateX(100%)}
.toggle-opt{flex:1 1 0;min-width:150px;position:relative;z-index:1;border:none;background:none;cursor:pointer;
  font-family:'Inter';font-weight:600;font-size:14px;color:var(--ink-2);padding:12px 20px;border-radius:100px;
  transition:color .25s;display:flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap}
.toggle-opt.is-active{color:#fff}

/* сцена: обе сетки в одной grid-ячейке → высота постоянная, без скачков */
.price-stage{display:grid;max-width:var(--maxw);margin:0 auto}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:stretch;
  grid-area:1 / 1;align-self:start;
  transition:opacity .4s ease, transform .5s cubic-bezier(.22,.8,.32,1);will-change:opacity,transform}
.price-grid.is-hidden{opacity:0;transform:translateY(16px) scale(.985);pointer-events:none}
.plan{position:relative;height:100%}
/* card */
.plan-card{height:100%;display:flex;flex-direction:column;text-align:left;background:var(--card);
  border:1px solid var(--line);border-radius:24px;padding:30px 28px;box-shadow:var(--shadow);
  transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s}
.plan:hover .plan-card{transform:translateY(-6px);box-shadow:0 1px 2px rgba(20,19,17,.04),0 28px 52px -26px rgba(20,19,17,.32)}
.plan-top{display:flex;align-items:center;gap:13px;margin-bottom:14px}
.plan-ic{display:grid;place-items:center;width:46px;height:46px;flex-shrink:0;border-radius:14px;
  background:var(--bg);border:1px solid var(--line);color:var(--ink)}
.plan-ic svg{width:23px;height:23px}
.plan-top h3{font-size:20px;font-weight:700}
.plan-desc{color:var(--muted);font-size:14px;line-height:1.5;margin-bottom:20px;min-height:42px}
.plan-price{display:flex;align-items:baseline;gap:7px;margin-bottom:22px}
.plan-price b{font-family:'Inter Tight';font-size:40px;font-weight:800;letter-spacing:-.03em;line-height:1}
.plan-price b small{font-size:18px;font-weight:600;color:var(--muted);margin-right:4px}
.plan-price span{color:var(--muted);font-size:14px;font-weight:500}
.plan-btn{justify-content:center;width:100%;background:var(--bg);color:var(--ink);border:1px solid var(--line)}
.plan-btn:hover{background:#e9e7e0;transform:translateY(-1px);box-shadow:none}
.feat-label{display:block;font-size:13px;font-weight:600;color:var(--ink);
  margin-top:26px;padding-top:24px;border-top:1px solid var(--line);margin-bottom:18px}
.feat{list-style:none;display:flex;flex-direction:column;gap:13px;flex:1;text-align:left}
.feat li{display:flex;align-items:flex-start;gap:11px;font-size:14px;color:var(--ink-2)}
.feat li::before{content:"";width:20px;height:20px;border-radius:50%;flex-shrink:0;margin-top:1px;
  background:var(--bg) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23161513' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/12px no-repeat;border:1px solid var(--line)}
/* popular: dark card */
.plan-pop .plan-card{position:relative;overflow:hidden;background:var(--ink);border:1px solid var(--ink);
  box-shadow:0 30px 60px -28px rgba(20,19,17,.6)}
.plan-pop .plan-top,.plan-pop .plan-desc,.plan-pop .plan-price,
.plan-pop .plan-btn,.plan-pop .feat-label,.plan-pop .feat{position:relative;z-index:1}
.plan-pop .plan-btn{background:rgba(255,91,41,.2);color:var(--acc);border:1px solid rgba(255,91,41,.45)}
.plan-pop .plan-btn:hover{background:rgba(255,91,41,.32)}
/* rising binary code background */
.rise{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.rise span{position:absolute;bottom:-26px;font-family:ui-monospace,'SF Mono',Menlo,monospace;font-weight:700;
  color:rgba(255,140,80,.2);animation-name:riseUp;animation-timing-function:linear;animation-iteration-count:infinite}
@keyframes riseUp{0%{transform:translateY(0);opacity:0}12%{opacity:.85}85%{opacity:.85}100%{transform:translateY(-460px);opacity:0}}
.plan-pop .plan-top h3{color:#fff}
.plan-pop .plan-desc{color:rgba(255,255,255,.58)}
.plan-pop .plan-price b{color:#fff}
.plan-pop .plan-price b small,.plan-pop .plan-price span{color:rgba(255,255,255,.55)}
.plan-pop .feat-label{color:#fff;border-top-color:rgba(255,255,255,.14)}
.plan-pop .feat li{color:rgba(255,255,255,.72)}
.plan-pop .plan-ic{background:rgba(255,91,41,.2);border-color:rgba(255,91,41,.45);color:var(--acc)}
.plan-pop .feat li::before{border-color:rgba(255,91,41,.45);
  background:rgba(255,91,41,.18) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ff5b29' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/12px no-repeat}
.pop-star{position:absolute;top:18px;right:18px;z-index:3;width:42px;height:42px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:var(--acc);
  background:rgba(255,91,41,.2);border:1px solid rgba(255,91,41,.45)}
.pop-star svg{width:21px;height:21px;display:block}
.plan-pop .plan-top{padding-right:46px}

/* ===== FAQ ===== */
.faq-wrap{display:grid;grid-template-columns:.8fr 1.2fr;gap:40px;padding:clamp(56px,8vw,100px) 0}
.faq-head h2{font-size:clamp(28px,3.6vw,44px);margin-top:14px}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;background:none;border:none;
  cursor:pointer;text-align:left;font-family:'Inter Tight';font-size:19px;font-weight:600;color:var(--ink);padding:22px 2px}
.chev{flex-shrink:0;width:24px;height:24px;color:var(--muted);transition:transform .3s,color .3s}
.faq-item.is-open .chev{transform:rotate(180deg);color:var(--acc)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
/* no-JS fallback: keep the opened answer visible even without scripts */
.faq-item.is-open .faq-a{max-height:none}
.faq-a p{padding:0 2px 22px;color:var(--ink-2);font-size:15px;max-width:54ch}

/* ===== FOOTER ===== */
.footer{background:var(--dark);color:#fff;margin:0 calc(-1*clamp(16px,4vw,40px));
  padding:clamp(56px,7vw,90px) clamp(24px,5vw,56px) 30px;border-radius:36px 36px 0 0}
.foot-cta{display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap;
  max-width:var(--maxw);margin:0 auto;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.12)}
.foot-cta h2{font-size:clamp(30px,4.6vw,56px);color:#fff}
.foot-cta-btns{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.foot-grid{display:grid;grid-template-columns:1fr 1fr 1.4fr;gap:30px;max-width:var(--maxw);margin:0 auto;padding:46px 0}
.foot-col{display:flex;flex-direction:column;gap:12px}
.foot-col h4{font-family:'Inter Tight';font-size:15px;color:#fff;margin-bottom:6px}
.foot-col a{color:rgba(255,255,255,.55);font-size:14px;transition:color .2s;width:fit-content}
.foot-col a:hover{color:#fff}
.foot-news p{color:rgba(255,255,255,.55);font-size:14px;margin-bottom:6px}
.news-form{display:flex;gap:6px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);
  border-radius:100px;padding:5px 5px 5px 18px;max-width:300px}
.news-form input{flex:1;background:none;border:none;color:#fff;font-size:14px;outline:none;font-family:'Inter'}
.news-form input::placeholder{color:rgba(255,255,255,.4)}
.news-form button{width:38px;height:38px;border-radius:50%;border:none;background:var(--acc);color:#fff;cursor:pointer;
  display:grid;place-items:center;transition:transform .2s}
.news-form button svg{width:16px;height:16px}
.news-form button:hover{transform:scale(1.08)}
.news-msg{font-size:13px;color:#27c93f;min-height:18px;margin-top:8px}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;max-width:var(--maxw);
  margin:24px auto 0;font-size:13px;color:rgba(255,255,255,.45)}

/* ===== REVEAL ===== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease, transform .6s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ===== FOCUS (keyboard accessibility) ===== */
:focus-visible{outline:2px solid var(--acc);outline-offset:3px}
.bar-links a:focus-visible,.pill:focus-visible,.open-btn:focus-visible,
.toggle-opt:focus-visible,.faq-q:focus-visible{outline-offset:2px}
.news-form:focus-within{border-color:rgba(255,255,255,.35)}

/* ===== RESPONSIVE ===== */
@media(max-width:900px){
  .bento{grid-template-columns:repeat(2,1fr)}
  .cell-dir{grid-row:span 2}
  .cell-stack{grid-column:span 2}
  .grid{grid-template-columns:repeat(2,1fr)}
  .price-grid{grid-template-columns:1fr;max-width:440px;margin:0 auto}
  .plan+.plan{border-left:none;border-top:1px solid rgba(255,255,255,.1)}
  .plan-pop .plan-card{margin:0}
  .plan-desc{min-height:0}
  .faq-wrap{grid-template-columns:1fr;gap:8px}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .bar-links{display:none}
  .menu-btn{display:flex}
  .bar-links.open{display:flex;position:absolute;top:104px;left:16px;right:16px;flex-direction:column;align-items:stretch;
    background:var(--card);border:1px solid var(--line);border-radius:18px;padding:14px;gap:8px;z-index:40;box-shadow:var(--shadow)}
  .hero-row .bar-links a{height:48px}
  .hide-mob{display:none}
  .bento{grid-template-columns:1fr}
  .cell-dir,.cell-stack{grid-column:auto;grid-row:auto}
  .grid{grid-template-columns:1fr}
  .toggle-opt{min-width:120px;padding:12px 16px}
  .foot-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}html{scroll-behavior:auto}
}
