/* ============================================================
   CELLWAN — Design System
   Aesthetic: editorial-precise network infrastructure
   Signature: petal-peach -> blue gradient, topology nodes,
   hairline borders, warm canvas, mono micro-labels.
   Themeable via [data-theme="peach"|"blue"|"midnight"].
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* brand spectrum */
  --peach-50:#fef3f1; --peach-100:#fde2dd; --peach-200:#fac8c0;
  --peach-300:#f6a89c; --peach-400:#ef8475; --peach-500:#e35d4d;
  --blue-50:#eef3ff; --blue-100:#dbe5ff; --blue-200:#b8caff;
  --blue-300:#8aa6ff; --blue-400:#4f78f0; --blue-500:#2d52d8;
  --blue-600:#1d3bb0; --ink-900:#14141b; --ink-700:#2c2c38;
  --ink-500:#5a5a6b; --ink-300:#9a9aab;

  --radius:16px; --radius-lg:24px; --radius-sm:10px;
  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow-sm:0 1px 2px rgba(20,20,27,.06), 0 2px 8px rgba(20,20,27,.04);
  --shadow-md:0 8px 30px rgba(20,20,27,.10), 0 2px 8px rgba(20,20,27,.05);
  --shadow-lg:0 30px 80px rgba(20,20,27,.18);
  --font-display:"Clash Display","Hanken Grotesk",sans-serif;
  --font-body:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,monospace;
}

/* ---------- Themes ---------- */
[data-theme="peach"]{
  --bg:#fbf7f4; --bg-2:#fff; --surface:#ffffff; --surface-2:#fdf1ee;
  --text:#14141b; --text-soft:#5a5a6b; --text-mute:#8d8d9c;
  --line:#eaddd8; --line-strong:#e0cdc6;
  --primary:#e35d4d; --primary-ink:#fff; --primary-soft:#fde2dd;
  --accent:#2d52d8;
  --grad: linear-gradient(110deg,#f6a89c 0%, #ef8475 26%, #6d7ce6 70%, #2d52d8 100%);
  --grad-soft: linear-gradient(135deg,#fde2dd 0%, #e7ecff 100%);
  --halo: radial-gradient(60% 60% at 70% 20%, rgba(239,132,117,.35), transparent 70%),
          radial-gradient(50% 50% at 20% 80%, rgba(45,82,216,.28), transparent 70%);
  --dot:#e7d6d0;
}
[data-theme="blue"]{
  --bg:#f4f7fc; --bg-2:#fff; --surface:#ffffff; --surface-2:#eaf1ff;
  --text:#101626; --text-soft:#4a5570; --text-mute:#8189a3;
  --line:#dde6f5; --line-strong:#cdd9ef;
  --primary:#2d52d8; --primary-ink:#fff; --primary-soft:#dbe5ff;
  --accent:#ef8475;
  --grad: linear-gradient(110deg,#2d52d8 0%, #4f78f0 36%, #c79bd6 78%, #f6a89c 100%);
  --grad-soft: linear-gradient(135deg,#dbe5ff 0%, #fde2dd 100%);
  --halo: radial-gradient(60% 60% at 72% 18%, rgba(79,120,240,.34), transparent 70%),
          radial-gradient(52% 52% at 18% 82%, rgba(239,132,117,.26), transparent 70%);
  --dot:#d2deef;
}
[data-theme="midnight"]{
  --bg:#0e0f16; --bg-2:#13141f; --surface:#181a26; --surface-2:#1f2233;
  --text:#f3f1ef; --text-soft:#b6b8c8; --text-mute:#7e8197;
  --line:#262a3b; --line-strong:#333851;
  --primary:#f6a89c; --primary-ink:#1a1018; --primary-soft:#2a2230;
  --accent:#8aa6ff;
  --grad: linear-gradient(110deg,#f6a89c 0%, #ef8475 24%, #6d7ce6 66%, #4f78f0 100%);
  --grad-soft: linear-gradient(135deg,#2a2230 0%, #1d2440 100%);
  --halo: radial-gradient(60% 60% at 72% 16%, rgba(239,132,117,.28), transparent 70%),
          radial-gradient(54% 54% at 16% 84%, rgba(79,120,240,.26), transparent 70%);
  --dot:#23273a;
  --shadow-md:0 10px 40px rgba(0,0,0,.5);
  --shadow-lg:0 40px 90px rgba(0,0,0,.6);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body); background:var(--bg); color:var(--text);
  line-height:1.6; font-size:17px; letter-spacing:-.005em;
  overflow-x:hidden; transition:background .4s var(--ease), color .4s var(--ease);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
/* Fallback size for any inline icon not covered by a container rule.
   Element-selector specificity (0,0,1) so every .class svg rule below still wins. */
svg{width:1.15em;height:1.15em;flex:none}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}

/* subtle topology dot grid behind everything */
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:radial-gradient(var(--dot) 1px, transparent 1px);
  background-size:30px 30px; opacity:.5;
  mask-image:radial-gradient(circle at 50% 30%, #000 0%, transparent 78%);
}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;position:relative;z-index:1}
.section{padding:96px 0;position:relative;z-index:1}
.section--tight{padding:64px 0}
@media(max-width:720px){.section{padding:64px 0}}

/* ---------- Type ---------- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.04;letter-spacing:-.02em;color:var(--text)}
.display{font-size:clamp(2.6rem,6.4vw,5.1rem);font-weight:600;line-height:.98}
.h2{font-size:clamp(2rem,4vw,3.1rem)}
.h3{font-size:clamp(1.4rem,2.4vw,1.9rem)}
.lead{font-size:clamp(1.1rem,1.6vw,1.32rem);color:var(--text-soft);max-width:60ch}
.eyebrow{
  font-family:var(--font-mono);font-size:.74rem;font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;color:var(--primary);display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--grad);display:inline-block}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.muted{color:var(--text-soft)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;font-weight:600;font-size:1rem;
  padding:.85em 1.5em;border-radius:999px;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s;
  letter-spacing:-.01em;line-height:1;white-space:nowrap;
}
.btn svg{width:1.05em;height:1.05em}
.btn--primary{background:var(--text);color:var(--bg);box-shadow:var(--shadow-sm)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn--grad{background:var(--grad);color:#fff;background-size:180% 180%;animation:flow 7s ease infinite}
.btn--grad:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(227,93,77,.32)}
.btn--ghost{border:1.5px solid var(--line-strong);color:var(--text);background:var(--surface)}
.btn--ghost:hover{border-color:var(--text);transform:translateY(-2px)}
.btn--lg{padding:1.05em 1.9em;font-size:1.06rem}
@keyframes flow{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* ---------- Nav ---------- */
.nav{position:sticky;top:0;z-index:60;backdrop-filter:saturate(140%) blur(14px);
  background:color-mix(in srgb,var(--bg) 78%,transparent);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s}
.nav.scrolled{border-bottom-color:var(--line);background:color-mix(in srgb,var(--bg) 92%,transparent)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:74px;gap:24px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:600;font-size:1.34rem;letter-spacing:-.02em}
.brand__mark{width:34px;height:34px;flex:none;border-radius:9px;background:var(--grad);background-size:160% 160%;
  animation:flow 8s ease infinite;display:grid;place-items:center;color:#fff;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.brand__mark svg{width:20px;height:20px}
.nav__links{display:flex;align-items:center;gap:6px}
.nav__links a{padding:.5em .85em;border-radius:9px;font-size:.97rem;font-weight:500;color:var(--text-soft);transition:color .2s,background .2s}
.nav__links a:hover,.nav__links a.active{color:var(--text);background:var(--surface-2)}
.nav__cta{display:flex;align-items:center;gap:10px}
.theme-toggle{display:flex;gap:5px;padding:5px;border:1px solid var(--line);border-radius:999px;background:var(--surface)}
.theme-toggle button{width:22px;height:22px;border-radius:50%;border:2px solid transparent;transition:transform .2s,border-color .2s}
.theme-toggle button:hover{transform:scale(1.12)}
.theme-toggle button[aria-pressed="true"]{border-color:var(--text)}
.tt-peach{background:linear-gradient(135deg,#f6a89c,#ef8475)}
.tt-blue{background:linear-gradient(135deg,#4f78f0,#2d52d8)}
.tt-midnight{background:linear-gradient(135deg,#2c2c38,#14141b)}
.nav__burger{display:none;flex-direction:column;gap:5px;padding:8px}
.nav__burger span{width:22px;height:2px;background:var(--text);border-radius:2px;transition:.3s}
@media(max-width:940px){
  .nav__links{position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;
    background:var(--bg);border-bottom:1px solid var(--line);padding:14px 24px 22px;gap:2px;
    transform:translateY(-130%);transition:transform .4s var(--ease);box-shadow:var(--shadow-md)}
  .nav__links.open{transform:translateY(0)}
  .nav__links a{padding:.8em .6em;font-size:1.05rem}
  .nav__burger{display:flex}
  .nav__cta .btn{display:none}
}

/* ---------- Hero ---------- */
.hero{position:relative;padding:72px 0 40px;overflow:hidden}
.hero::after{content:"";position:absolute;inset:-20% -10% auto -10%;height:120%;z-index:0;background:var(--halo);filter:blur(8px);pointer-events:none}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;position:relative;z-index:1}
.hero__status{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-mono);font-size:.78rem;
  letter-spacing:.12em;text-transform:uppercase;color:var(--text-soft);background:var(--surface);
  border:1px solid var(--line);padding:.5em .9em;border-radius:999px;margin-bottom:22px;box-shadow:var(--shadow-sm)}
.pulse{width:9px;height:9px;border-radius:50%;background:#2bbf6a;position:relative}
.pulse::after{content:"";position:absolute;inset:0;border-radius:50%;background:#2bbf6a;animation:ping 1.8s var(--ease) infinite}
@keyframes ping{0%{transform:scale(1);opacity:.7}80%,100%{transform:scale(3.2);opacity:0}}
.hero h1{margin-bottom:22px}
.hero .lead{margin-bottom:30px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero__note{font-size:.92rem;color:var(--text-mute);margin-top:18px;font-family:var(--font-mono);letter-spacing:.01em}
.hero__visual{position:relative}
.hero__shot{border-radius:var(--radius-lg);border:1px solid var(--line);box-shadow:var(--shadow-lg);
  overflow:hidden;transform:perspective(1600px) rotateY(-9deg) rotateX(3deg);transition:transform .6s var(--ease);background:var(--surface)}
.hero__shot:hover{transform:perspective(1600px) rotateY(-4deg) rotateX(1deg)}
.hero__shot img{display:block}
.hero__chip{position:absolute;background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:12px 15px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:11px}
.hero__chip .k{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-mute)}
.hero__chip .v{font-family:var(--font-display);font-weight:600;font-size:1.2rem}
.hero__chip--a{top:-22px;left:-26px;animation:float 6s ease-in-out infinite}
.hero__chip--b{bottom:-20px;right:-18px;animation:float 6s ease-in-out infinite .8s}
.hero__chip i{width:34px;height:34px;border-radius:9px;background:var(--grad-soft);display:grid;place-items:center;color:var(--primary)}
.hero__chip i svg{width:18px;height:18px}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@media(max-width:940px){
  .hero__grid{grid-template-columns:1fr;gap:54px}
  .hero__shot{transform:none}
  .hero__chip--a{left:8px}.hero__chip--b{right:8px}
}

/* ---------- Logo marquee ---------- */
.marquee{overflow:hidden;border-block:1px solid var(--line);padding:22px 0;background:var(--surface);position:relative;z-index:1}
.marquee__label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-mute);text-align:center;margin-bottom:14px}
.marquee__track{display:flex;gap:60px;width:max-content;animation:scrollx 26s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__track span{font-family:var(--font-display);font-weight:600;font-size:1.25rem;color:var(--text-mute);white-space:nowrap;opacity:.7}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ---------- Section head ---------- */
.shead{max-width:64ch;margin-bottom:52px}
.shead.center{margin-inline:auto;text-align:center}
.shead .h2{margin:14px 0 16px}

/* ---------- Feature cards ---------- */
.grid{display:grid;gap:20px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:920px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .3s;position:relative;overflow:hidden}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--line-strong)}
.card__icon{width:48px;height:48px;border-radius:12px;background:var(--grad-soft);display:grid;place-items:center;
  color:var(--primary);margin-bottom:18px}
.card__icon svg{width:24px;height:24px}
.card h3{font-size:1.22rem;margin-bottom:8px}
.card p{color:var(--text-soft);font-size:.98rem}
.card__num{position:absolute;top:18px;right:22px;font-family:var(--font-mono);font-size:.78rem;color:var(--text-mute);letter-spacing:.1em}
/* bullet icons inside card lists (e.g. hardware CPE specs) */
.card li{display:flex;gap:10px;align-items:flex-start}
.card li svg{width:19px;height:19px;flex:none;color:var(--primary);margin-top:2px}

/* feature card with top gradient hairline */
.card--line::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad);
  transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.card--line:hover::before{transform:scaleX(1)}

/* ---------- Dark band ---------- */
.band{background:var(--ink-900);color:#f3f1ef;position:relative;z-index:1;overflow:hidden}
[data-theme="midnight"] .band{background:#080912}
.band::before{content:"";position:absolute;inset:0;background:var(--halo);opacity:.7;pointer-events:none}
.band .eyebrow{color:#f6a89c}
.band h2,.band h3{color:#fff}
.band .lead,.band p{color:#c3c4d4}
.stat{display:flex;flex-direction:column;gap:6px}
.stat__v{font-family:var(--font-display);font-weight:600;font-size:clamp(2.4rem,5vw,3.6rem);line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat__k{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:#9a9bb0}

/* ---------- Showcase (dashboards) ---------- */
.showcase{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.showcase--rev{direction:rtl}.showcase--rev>*{direction:ltr}
.showcase__media{border-radius:var(--radius-lg);border:1px solid var(--line);overflow:hidden;box-shadow:var(--shadow-md);background:var(--surface)}
.showcase ul{margin-top:22px;display:grid;gap:12px}
.showcase li{display:flex;gap:12px;align-items:flex-start;color:var(--text-soft)}
.showcase li svg{width:21px;height:21px;flex:none;color:var(--primary);margin-top:2px}
@media(max-width:860px){.showcase,.showcase--rev{grid-template-columns:1fr;direction:ltr}}

/* ---------- Hardware ---------- */
.hw{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px;text-align:center;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.hw:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.hw__img{height:230px;display:grid;place-items:center;margin-bottom:18px;background:var(--grad-soft);border-radius:var(--radius);padding:18px}
.hw__img img{max-height:100%;width:auto;object-fit:contain;mix-blend-mode:multiply}
[data-theme="midnight"] .hw__img img{mix-blend-mode:normal}
.hw h3{font-size:1.2rem;margin-bottom:6px}
.hw .tag{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--primary)}

/* ---------- Pricing ---------- */
.price{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px;
  display:flex;flex-direction:column;transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .3s;position:relative}
.price:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.price--featured{border-color:transparent;box-shadow:var(--shadow-md)}
.price--featured::before{content:"";position:absolute;inset:0;border-radius:var(--radius-lg);padding:1.5px;
  background:var(--grad);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.price__badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--grad);color:#fff;
  font-family:var(--font-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;padding:.45em 1em;border-radius:999px}
.price__name{font-family:var(--font-display);font-weight:600;font-size:1.35rem;margin-bottom:6px}
.price__desc{color:var(--text-soft);font-size:.94rem;min-height:48px}
.price__amt{display:flex;align-items:baseline;gap:6px;margin:18px 0}
.price__amt b{font-family:var(--font-display);font-size:3rem;font-weight:600;line-height:1}
.price__amt span{color:var(--text-mute);font-family:var(--font-mono);font-size:.82rem}
.price ul{display:grid;gap:11px;margin:18px 0 26px;font-size:.95rem}
.price li{display:flex;gap:10px;align-items:flex-start;color:var(--text-soft)}
.price li svg{width:18px;height:18px;flex:none;color:var(--primary);margin-top:3px}
.price li.off{color:var(--text-mute);opacity:.6;text-decoration:line-through}
.price li.off svg{color:var(--text-mute)}
.price .btn{margin-top:auto;justify-content:center}

/* ---------- Forms ---------- */
.form{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(24px,4vw,42px);box-shadow:var(--shadow-md)}
.field{margin-bottom:18px}
.field label{display:block;font-size:.86rem;font-weight:600;margin-bottom:7px;color:var(--text)}
.field label .req{color:var(--primary)}
.field input,.field select,.field textarea{
  width:100%;font-family:inherit;font-size:1rem;color:var(--text);background:var(--bg-2);
  border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:.8em .95em;transition:border-color .25s,box-shadow .25s}
.field textarea{resize:vertical;min-height:96px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--primary);
  box-shadow:0 0 0 4px color-mix(in srgb,var(--primary) 14%,transparent)}
.field--row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.field--row{grid-template-columns:1fr}}
.field--error input,.field--error select{border-color:#e0483b}
.err{display:none;color:#e0483b;font-size:.82rem;margin-top:5px}
.field--error .err{display:block}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;overflow:hidden} /* honeypot */

.check{display:flex;gap:11px;align-items:flex-start;font-size:.92rem;color:var(--text-soft);margin-bottom:14px}
.check input{width:18px;height:18px;margin-top:3px;flex:none;accent-color:var(--primary)}
.check a{color:var(--primary);font-weight:600}

.captcha{display:flex;gap:12px;align-items:stretch;margin-bottom:6px}
.captcha__img{height:50px;border-radius:var(--radius-sm);border:1.5px solid var(--line);overflow:hidden;background:#fff;flex:none}
.captcha__img img{height:100%;width:auto;display:block}
.captcha__refresh{border:1.5px solid var(--line);border-radius:var(--radius-sm);width:48px;display:grid;place-items:center;
  background:var(--bg-2);color:var(--text-soft);transition:.25s;flex:none}
.captcha__refresh:hover{color:var(--primary);border-color:var(--primary);transform:rotate(90deg)}
.captcha__refresh svg{width:20px;height:20px}

.alert{padding:14px 18px;border-radius:var(--radius-sm);margin-bottom:20px;font-size:.94rem;display:none}
.alert--show{display:block}
.alert--success{background:#e9f9ef;color:#0d6b39;border:1px solid #b6e9c9}
.alert--error{background:#fdecea;color:#a01b10;border:1px solid #f6c5bf}
[data-theme="midnight"] .alert--success{background:#10261a;color:#7ee0a6}
[data-theme="midnight"] .alert--error{background:#2a1513;color:#ffae9f}

/* ---------- CTA band ---------- */
.cta{position:relative;border-radius:var(--radius-lg);overflow:hidden;padding:clamp(40px,6vw,72px);
  background:var(--ink-900);color:#fff;text-align:center;z-index:1}
.cta::before{content:"";position:absolute;inset:0;background:var(--halo);opacity:.85}
.cta>*{position:relative;z-index:1}
.cta h2{color:#fff;margin-bottom:14px}
.cta p{color:#c3c4d4;max-width:54ch;margin:0 auto 28px}

/* ---------- Footer ---------- */
.footer{background:var(--bg-2);border-top:1px solid var(--line);padding:64px 0 30px;position:relative;z-index:1}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;margin-bottom:44px}
@media(max-width:820px){.footer__grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer__grid{grid-template-columns:1fr}}
.footer h4{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-mute);margin-bottom:16px;font-weight:600}
.footer ul{display:grid;gap:10px}
.footer a{color:var(--text-soft);font-size:.95rem;transition:color .2s}
.footer a:hover{color:var(--primary)}
.footer__about p{color:var(--text-soft);font-size:.95rem;margin:14px 0;max-width:34ch}
.footer__contact{font-family:var(--font-mono);font-size:.84rem;color:var(--text-soft);display:grid;gap:8px}
.footer__contact span{display:inline-flex;align-items:center;gap:9px}
.footer__contact span svg{width:17px;height:17px;flex:none;color:var(--primary)}
.footer__bottom{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;padding-top:24px;border-top:1px solid var(--line);
  font-size:.86rem;color:var(--text-mute)}
.footer__bottom a{color:var(--text-mute)}
.footer__bottom .links{display:flex;gap:18px;flex-wrap:wrap}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}

/* ---------- Page hero (interior) ---------- */
.phero{padding:72px 0 28px;position:relative;overflow:hidden}
.phero::after{content:"";position:absolute;inset:-30% 0 auto 0;height:90%;background:var(--halo);opacity:.6;z-index:0;pointer-events:none}
.phero .wrap{position:relative;z-index:1}
.crumbs{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em;color:var(--text-mute);margin-bottom:18px}
.crumbs a:hover{color:var(--primary)}

/* prose for blog/legal */
.prose{max-width:72ch;margin:0 auto}
.prose h2{font-size:1.7rem;margin:38px 0 14px}
.prose h3{font-size:1.3rem;margin:28px 0 10px}
.prose p{margin-bottom:18px;color:var(--text-soft)}
.prose ul{list-style:disc;padding-left:1.3em;margin-bottom:18px;color:var(--text-soft);display:grid;gap:8px}
.prose a{color:var(--primary);font-weight:600;text-decoration:underline;text-underline-offset:3px}
.prose blockquote{border-left:3px solid var(--primary);padding:6px 0 6px 20px;margin:22px 0;font-size:1.15rem;color:var(--text)}

/* blog cards */
.post{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.post:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.post__cover{aspect-ratio:16/9;background:var(--grad);background-size:200% 200%;animation:flow 9s ease infinite;position:relative}
.post__cover span{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--font-display);font-weight:600;color:#fff;font-size:1.3rem;padding:20px;text-align:center}
.post__body{padding:24px;display:flex;flex-direction:column;gap:10px;flex:1}
.post__meta{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-mute)}
.post__body h3{font-size:1.2rem}
.post__body p{color:var(--text-soft);font-size:.95rem;flex:1}
.post__more{color:var(--primary);font-weight:600;font-size:.92rem}

/* utility */
.center{text-align:center}
.mt-s{margin-top:14px}.mt-m{margin-top:28px}.mt-l{margin-top:48px}
.tilt-card{will-change:transform}
