/* =============================================================
   Custom Sites — bespoke web studio
   A light, editorial-tech design system. Built from scratch
   (not the shared component CSS) so the studio's own site looks
   nothing like the sites in its portfolio.
   ============================================================= */

/* ---------- tokens ---------- */
:root{
  --paper:#f4f3ef;        /* warm paper canvas        */
  --paper-2:#fffefb;      /* raised card surface      */
  --ink:#131419;          /* near-black ink           */
  --ink-2:#1b1d25;        /* dark panel surface       */
  --ink-3:#23262f;        /* dark panel raised        */
  --muted:#54565f;        /* body muted               */
  --muted-2:#86888f;      /* faint                    */
  --line:#e3e1d9;         /* hairline on paper        */
  --line-2:#d8d5cc;       /* stronger hairline        */
  --line-ink:rgba(255,255,255,.12);
  --accent:#2f49ff;       /* electric cobalt          */
  --accent-ink:#1e31c9;   /* pressed cobalt           */
  --accent-tint:#eceefe;  /* cobalt wash              */
  --spark:#ff5a36;        /* vermilion micro-accent   */
  --on-ink:#eceae3;       /* text on dark             */
  --on-ink-muted:#a4a6af;

  --font-display:'Space Grotesk',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
  --font-mono:'Space Mono','IBM Plex Mono',ui-monospace,monospace;

  --radius:14px;
  --radius-lg:24px;
  --shadow:0 1px 2px rgba(20,21,26,.04),0 12px 32px -16px rgba(20,21,26,.18);
  --shadow-lg:0 2px 4px rgba(20,21,26,.05),0 32px 64px -28px rgba(20,21,26,.30);
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- reset/base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--font-body);font-size:17px;line-height:1.62;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.05;letter-spacing:-.02em;margin:0}
p{margin:0}
ul{margin:0;padding:0;list-style:none}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 26px}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;z-index:200}
.skip-link:focus{left:0}
.muted{color:var(--muted)}
.nowrap{white-space:nowrap}
.center{text-align:center}
.lead{font-size:1.2rem;line-height:1.6;color:var(--muted)}
:focus-visible{outline:2.5px solid var(--accent);outline-offset:3px;border-radius:3px}

/* ---------- mono eyebrow ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-mono);font-size:.72rem;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;color:var(--accent);
  margin:0 0 18px;
}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--accent);opacity:.6}
.eyebrow--plain{color:var(--muted-2)}
.eyebrow--plain::before{background:var(--muted-2)}
.eyebrow--light{color:#9fb0ff}
.eyebrow--light::before{background:#9fb0ff}
.eyebrow--center{justify-content:center}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--ink);--fg:#fff;--bd:var(--ink);
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  background:var(--bg);color:var(--fg);border:1.5px solid var(--bd);
  font-family:var(--font-display);font-weight:600;font-size:.96rem;letter-spacing:-.01em;
  padding:13px 24px;border-radius:10px;transition:transform .25s var(--ease),background .2s,box-shadow .25s,color .2s,border-color .2s;
  will-change:transform;
}
.btn:hover{transform:translateY(-2px)}
.btn--accent{--bg:var(--accent);--bd:var(--accent);--fg:#fff;box-shadow:0 10px 28px -12px rgba(47,73,255,.7)}
.btn--accent:hover{--bg:var(--accent-ink);--bd:var(--accent-ink)}
.btn--ink{--bg:var(--ink);--bd:var(--ink);--fg:#fff}
.btn--ghost{--bg:transparent;--bd:var(--line-2);--fg:var(--ink)}
.btn--ghost:hover{--bd:var(--ink)}
.btn--on-ink{--bg:#fff;--bd:#fff;--fg:var(--ink)}
.btn--on-ink-ghost{--bg:transparent;--bd:var(--line-ink);--fg:var(--on-ink)}
.btn--on-ink-ghost:hover{--bd:rgba(255,255,255,.45)}
.btn--lg{padding:16px 30px;font-size:1.02rem}
.btn__arrow{transition:transform .25s var(--ease)}
.btn:hover .btn__arrow{transform:translateX(4px)}

/* ---------- side rail + shell (the studio's own structure) ---------- */
:root{ --rail-w:236px }
.shell{ margin-left:var(--rail-w); min-height:100vh; display:flex; flex-direction:column }
.shell > main{ flex:1 0 auto }
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(52,210,123,.5)}70%{box-shadow:0 0 0 7px rgba(52,210,123,0)}100%{box-shadow:0 0 0 0 rgba(52,210,123,0)}}

.rail{
  position:fixed; top:0; left:0; bottom:0; width:var(--rail-w); z-index:60;
  background:var(--ink); color:var(--on-ink);
  display:flex; flex-direction:column; padding:28px 22px 24px;
  border-right:1px solid #23262f; overflow-y:auto;
}
.rail::-webkit-scrollbar{ width:0 }
.rail .mark{ width:34px; height:34px; flex:none; display:grid; place-items:center }
.rail__word{ display:block; margin-top:15px; font-family:var(--font-display); font-weight:700; font-size:1.3rem; letter-spacing:-.03em; color:#fff }
.rail__word .dot{ color:var(--accent) }
.rail__tag{ display:block; margin-top:7px; font-family:var(--font-mono); font-size:.64rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted-2) }

.rail__nav{ margin-top:42px }
.rail__nav ul{ display:flex; flex-direction:column; gap:2px }
.rail__nav a{ display:flex; align-items:baseline; gap:12px; padding:11px 12px; margin:0 -12px; border-radius:9px; color:var(--on-ink-muted); transition:background .2s,color .2s }
.rail__nav a:hover,.rail__nav a.is-active{ background:#1f222b; color:#fff }
.rail__nav a.is-active .rail__num{ color:var(--accent) }
.rail__num{ font-family:var(--font-mono); font-size:.72rem; color:var(--muted-2); width:1.5em; flex:none }
.rail__label{ font-family:var(--font-display); font-weight:500; font-size:1.05rem; letter-spacing:-.01em }

.rail__foot{ margin-top:auto; padding-top:26px }
.rail__status{ display:flex; align-items:center; gap:9px; font-family:var(--font-mono); font-size:.66rem; letter-spacing:.04em; color:var(--on-ink-muted); margin:0 0 13px }
.rail__dot{ width:7px; height:7px; border-radius:50%; background:#34d27b; box-shadow:0 0 0 0 rgba(52,210,123,.6); animation:pulse 2.4s infinite }
.rail__phone{ display:block; font-family:var(--font-display); font-weight:600; font-size:1.18rem; color:#fff; letter-spacing:-.02em; margin-bottom:14px }
.rail__phone:hover{ color:var(--accent) }
.rail__cta{ width:100%; justify-content:center }

/* mobile bar + drawer */
.railbar{ display:none }
.rail-scrim{ position:fixed; inset:0; background:rgba(10,11,15,.5); opacity:0; visibility:hidden; transition:opacity .3s,visibility .3s; z-index:55 }
body.rail-open .rail-scrim{ opacity:1; visibility:visible }

@media (max-width:1000px){
  :root{ --rail-w:0px }
  .shell{ margin-left:0; padding-top:58px }
  .railbar{
    display:flex; align-items:center; justify-content:space-between; gap:14px;
    position:fixed; top:0; left:0; right:0; height:58px; z-index:65; padding:0 18px;
    background:rgba(244,243,239,.92); backdrop-filter:blur(12px) saturate(1.4); border-bottom:1px solid var(--line);
  }
  .railbar__brand{ display:inline-flex; align-items:center; gap:10px }
  .railbar__word{ font-family:var(--font-display); font-weight:700; font-size:1.08rem; letter-spacing:-.03em; color:var(--ink) }
  .railbar__word .dot{ color:var(--accent) }
  .railbar__toggle{ display:flex; flex-direction:column; gap:5px; width:44px; height:44px; align-items:center; justify-content:center; background:transparent; border:1px solid var(--line-2); border-radius:10px }
  .railbar__toggle span:not(.visually-hidden){ width:19px; height:2px; background:var(--ink); border-radius:2px; transition:transform .3s,opacity .3s }
  .rail{ width:min(82vw,300px); transform:translateX(-100%); transition:transform .35s var(--ease); box-shadow:var(--shadow-lg); border-right:0 }
  body.rail-open .rail{ transform:translateX(0) }
  body.rail-open .railbar__toggle span:nth-child(1){ transform:translateY(7px) rotate(45deg) }
  body.rail-open .railbar__toggle span:nth-child(2){ opacity:0 }
  body.rail-open .railbar__toggle span:nth-child(3){ transform:translateY(-7px) rotate(-45deg) }
}

/* ---------- sections ---------- */
.section{padding:88px 0}
.section--tight{padding:60px 0}
.section--ink{background:var(--ink);color:var(--on-ink)}
.section--ink h1,.section--ink h2,.section--ink h3{color:#fff}
.section--ink .lead,.section--ink .muted{color:var(--on-ink-muted)}
.section--paper2{background:var(--paper-2)}
.section__head{max-width:680px;margin:0 0 48px}
.section__head--center{margin-left:auto;margin-right:auto;text-align:center}
.section__title{font-size:clamp(1.9rem,4vw,2.9rem)}
.section__intro{margin-top:18px;font-size:1.12rem;color:var(--muted)}
.section--ink .section__intro{color:var(--on-ink-muted)}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.is-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){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- blueprint grid backdrop ---------- */
.gridlines{position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:46px 46px;mask-image:radial-gradient(120% 90% at 70% 0,#000 30%,transparent 78%);opacity:.6}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;padding:64px 0 76px}
.hero__inner{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero__title{font-size:clamp(2.5rem,5.6vw,4.3rem);letter-spacing:-.035em}
.hero__title .typer{color:var(--accent)}
.hero__lead{margin:26px 0 0;font-size:1.22rem;line-height:1.55;color:var(--muted);max-width:33ch}
.hero__actions{display:flex;flex-wrap:wrap;gap:13px;margin-top:34px}
.hero__trust{display:flex;flex-wrap:wrap;gap:10px 22px;margin-top:34px;font-family:var(--font-mono);font-size:.74rem;letter-spacing:.04em;color:var(--muted)}
.hero__trust span{display:inline-flex;align-items:center;gap:8px}
.hero__trust svg{width:15px;height:15px;color:var(--accent)}

/* typewriter word */
.typer{color:var(--accent);white-space:nowrap}
.typer__caret{display:inline-block;width:.07em;height:.84em;background:var(--accent);margin-left:.03em;vertical-align:-.04em;animation:blink 1.05s steps(1) infinite}
.typer.is-typing .typer__caret{animation:none;opacity:1}
@keyframes blink{50%{opacity:0}}
@media (prefers-reduced-motion:reduce){.typer__caret{animation:none}}

/* code/browser window mock */
.window{position:relative;background:var(--ink);border-radius:16px;box-shadow:var(--shadow-lg);overflow:hidden;font-family:var(--font-mono)}
.window__bar{display:flex;align-items:center;gap:14px;padding:13px 16px;background:var(--ink-2);border-bottom:1px solid var(--line-ink)}
.window__dots{display:flex;gap:7px}
.window__dots i{width:11px;height:11px;border-radius:50%;background:#3a3d47}
.window__dots i:nth-child(1){background:#ff5f57}.window__dots i:nth-child(2){background:#febc2e}.window__dots i:nth-child(3){background:#28c840}
.window__url{flex:1;background:#0f1015;border-radius:7px;padding:6px 12px;font-size:.74rem;color:var(--on-ink-muted);display:flex;align-items:center;gap:8px}
.window__url svg{width:12px;height:12px;color:#34d27b}
.window__body{padding:22px 22px 26px;font-size:.82rem;line-height:1.95;color:#c7c9d2;min-height:286px}
.cl{display:block;white-space:pre}
.cl .k{color:#7c89ff}.cl .s{color:#5fd0a8}.cl .c{color:#6b6e7a}.cl .a{color:#ff9a6b}.cl .n{color:#e6c07b}
.cl--ind{padding-left:1.6em}.cl--ind2{padding-left:3.2em}
.window__tag{position:absolute;right:-12px;bottom:24px;background:var(--accent);color:#fff;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.05em;padding:8px 14px;border-radius:9px;box-shadow:0 12px 28px -10px rgba(47,73,255,.8);transform:rotate(-3deg)}

@media (max-width:920px){
  .hero__inner{grid-template-columns:1fr;gap:40px}
  .hero__lead{max-width:46ch}
  .window{max-width:520px}
}

/* ---------- stat strip ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.stat{background:var(--paper-2);padding:28px 24px}
.stat__num{font-family:var(--font-display);font-weight:700;font-size:2.2rem;letter-spacing:-.03em;line-height:1}
.stat__num em{color:var(--accent);font-style:normal}
.stat__label{margin-top:9px;font-size:.92rem;color:var(--muted)}
.section--ink .stats{background:var(--line-ink);border-color:var(--line-ink)}
.section--ink .stat{background:var(--ink-2)}
@media (max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}

/* ---------- generic grids ---------- */
.grid{display:grid;gap:22px}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
@media (max-width:900px){.grid--3,.grid--4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.grid--2,.grid--3,.grid--4{grid-template-columns:1fr}}

/* ---------- capability cards ---------- */
.card{position:relative;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:28px;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-2)}
.card__icon{width:46px;height:46px;border-radius:11px;display:grid;place-items:center;background:var(--accent-tint);color:var(--accent);margin-bottom:18px}
.card__icon svg{width:23px;height:23px}
.card__title{font-size:1.18rem;letter-spacing:-.02em}
.card__text{margin-top:10px;color:var(--muted);font-size:.98rem}
.card__num{position:absolute;top:24px;right:26px;font-family:var(--font-mono);font-size:.74rem;color:var(--muted-2)}
.section--ink .card{background:var(--ink-2);border-color:var(--line-ink)}
.section--ink .card:hover{border-color:rgba(255,255,255,.22)}
.section--ink .card__text{color:var(--on-ink-muted)}
.section--ink .card__icon{background:rgba(124,137,255,.16);color:#9fb0ff}

/* ---------- work / portfolio ---------- */
.filters{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:34px}
.chip{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.03em;color:var(--muted);background:var(--paper-2);border:1px solid var(--line-2);padding:8px 15px;border-radius:999px;transition:all .2s}
.chip:hover{border-color:var(--ink);color:var(--ink)}
.chip.is-active{background:var(--ink);border-color:var(--ink);color:#fff}

.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
@media (max-width:760px){.work-grid{grid-template-columns:1fr}}
.work-card{display:flex;flex-direction:column;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .3s}
.work-card.is-hidden{display:none}
.work-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--line-2)}
.work-card__media{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--ink-2)}
.work-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.work-card:hover .work-card__media img{transform:scale(1.045)}
.work-card__cat{position:absolute;top:14px;left:14px;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.05em;text-transform:uppercase;background:rgba(255,255,255,.92);color:var(--ink);padding:5px 11px;border-radius:999px;backdrop-filter:blur(4px)}
.work-card__body{padding:22px 24px 24px;display:flex;flex-direction:column;flex:1}
.work-card__title{font-size:1.34rem;letter-spacing:-.02em;display:flex;align-items:center;justify-content:space-between;gap:10px}
.work-card__arrow{flex:none;width:34px;height:34px;border-radius:50%;border:1.5px solid var(--line-2);display:grid;place-items:center;color:var(--muted);transition:all .25s var(--ease)}
.work-card:hover .work-card__arrow{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(-45deg)}
.work-card__arrow svg{width:15px;height:15px}
.work-card__text{margin-top:9px;color:var(--muted);font-size:.97rem;flex:1}
.work-card__meta{display:flex;flex-wrap:wrap;gap:7px;margin-top:18px}
.work-card__meta span{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.02em;color:var(--muted);background:var(--paper);border:1px solid var(--line);padding:4px 10px;border-radius:6px}

/* ---------- compare (custom vs template) ---------- */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media (max-width:700px){.compare{grid-template-columns:1fr}}
.compare__col{border-radius:var(--radius-lg);padding:32px 30px;border:1px solid var(--line)}
.compare__col--bad{background:var(--paper-2)}
.compare__col--good{background:var(--ink);color:var(--on-ink);border-color:var(--ink)}
.compare__tag{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:18px;color:var(--muted-2)}
.compare__col--good .compare__tag{color:#9fb0ff}
.compare__h{font-size:1.4rem;margin-bottom:20px}
.compare__col--good .compare__h{color:#fff}
.compare__list li{display:flex;gap:13px;padding:11px 0;border-top:1px solid var(--line);font-size:1rem;color:var(--muted)}
.compare__col--good .compare__list li{border-color:var(--line-ink);color:var(--on-ink-muted)}
.compare__list li:first-child{border-top:0}
.compare__list .ic{flex:none;width:21px;height:21px;margin-top:2px}
.compare__col--bad .ic{color:#c2473a}
.compare__col--good .ic{color:#34d27b}

/* ---------- feature split ---------- */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.feature--rev .feature__media{order:2}
@media (max-width:840px){.feature{grid-template-columns:1fr;gap:34px}.feature--rev .feature__media{order:0}}
.feature__media{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);aspect-ratio:4/3}
.feature__media img{width:100%;height:100%;object-fit:cover}
.feature__list{margin-top:24px;display:grid;gap:14px}
.feature__list li{display:flex;gap:13px;font-size:1.02rem}
.feature__list .ic{flex:none;width:24px;height:24px;border-radius:7px;background:var(--accent-tint);color:var(--accent);display:grid;place-items:center;margin-top:2px}
.feature__list .ic svg{width:14px;height:14px}

/* ---------- process steps ---------- */
.steps{position:relative;display:grid;gap:14px}
.step{position:relative;display:grid;grid-template-columns:auto 1fr;gap:24px;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:26px 28px;transition:border-color .3s,transform .3s var(--ease)}
.step:hover{border-color:var(--line-2);transform:translateX(4px)}
.step__num{font-family:var(--font-mono);font-size:.84rem;font-weight:700;color:var(--accent);width:42px;height:42px;border:1.5px solid var(--accent-tint);border-radius:11px;display:grid;place-items:center;background:var(--accent-tint)}
.step__title{font-size:1.22rem}
.step__text{margin-top:8px;color:var(--muted)}
.step__meta{margin-top:12px;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted-2)}

/* ---------- FAQ ---------- */
.faq{max-width:780px;margin:0 auto}
.faq__item{border-bottom:1px solid var(--line)}
.faq__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px;text-align:left;background:none;border:0;padding:24px 4px;font-family:var(--font-display);font-weight:600;font-size:1.12rem;letter-spacing:-.01em;color:var(--ink)}
.faq__sign{flex:none;width:24px;height:24px;position:relative}
.faq__sign::before,.faq__sign::after{content:"";position:absolute;inset:50% 2px auto;height:2px;background:var(--accent);transform:translateY(-50%);transition:transform .3s var(--ease)}
.faq__sign::after{transform:translateY(-50%) rotate(90deg)}
.faq__item.is-open .faq__sign::after{transform:translateY(-50%) rotate(0)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq__a-inner{padding:0 4px 24px;color:var(--muted)}
.faq__item.is-open .faq__a{max-height:340px}

/* ---------- CTA block ---------- */
.cta-block{position:relative;overflow:hidden;background:var(--ink);color:var(--on-ink);border-radius:var(--radius-lg);padding:60px 48px;text-align:center}
.cta-block h2{color:#fff;font-size:clamp(1.8rem,4vw,2.7rem)}
.cta-block p{max-width:560px;margin:18px auto 0;color:var(--on-ink-muted);font-size:1.1rem}
.cta-block__actions{display:flex;flex-wrap:wrap;gap:13px;justify-content:center;margin-top:34px}
.cta-block .gridlines{background-image:linear-gradient(var(--line-ink) 1px,transparent 1px),linear-gradient(90deg,var(--line-ink) 1px,transparent 1px);opacity:1}
@media (max-width:560px){.cta-block{padding:44px 24px}}

/* ---------- forms ---------- */
.form{display:grid;gap:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:560px){.form-row{grid-template-columns:1fr}}
.field{display:grid;gap:8px}
.field__label{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.field input,.field select,.field textarea{
  width:100%;font:inherit;font-size:1rem;color:var(--ink);background:var(--paper-2);
  border:1.5px solid var(--line-2);border-radius:10px;padding:13px 15px;transition:border-color .2s,box-shadow .2s;
}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-tint)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2354565f' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}
.honeypot{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-status{font-size:.96rem;margin:0;min-height:1.2em}
.form-status--ok{color:#1f8f54}
.form-status--err{color:#c2473a}
.form-actions{display:flex;align-items:center;gap:18px;flex-wrap:wrap}

/* form on dark panel */
.section--ink .field input,.section--ink .field select,.section--ink .field textarea{background:var(--ink-2);border-color:var(--line-ink);color:#fff}
.section--ink .field__label{color:var(--on-ink-muted)}
.section--ink .field input:focus,.section--ink .field select:focus,.section--ink .field textarea:focus{border-color:#7c89ff;box-shadow:0 0 0 4px rgba(124,137,255,.18)}
.section--ink .field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23a4a6af' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E")}
.section--ink .form-status--ok{color:#5fd0a8}

/* contact split */
.contact-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:54px;align-items:start}
@media (max-width:860px){.contact-grid{grid-template-columns:1fr;gap:40px}}
.contact-aside .lead{margin-top:18px}
.contact-cards{display:grid;gap:14px;margin-top:30px}
.contact-card{display:flex;gap:15px;align-items:flex-start;padding:18px 20px;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius)}
.section--ink .contact-card{background:var(--ink-2);border-color:var(--line-ink)}
.contact-card__ic{flex:none;width:40px;height:40px;border-radius:10px;background:var(--accent-tint);color:var(--accent);display:grid;place-items:center}
.contact-card__ic svg{width:19px;height:19px}
.contact-card h3{font-size:1.02rem}
.contact-card a,.contact-card p{color:var(--muted);font-size:.97rem}
.section--ink .contact-card a,.section--ink .contact-card p{color:var(--on-ink-muted)}
.contact-card a:hover{color:var(--accent)}

/* ---------- pill list / tags ---------- */
.taglist{display:flex;flex-wrap:wrap;gap:9px;margin-top:22px}
.taglist span{font-family:var(--font-mono);font-size:.78rem;color:var(--muted);background:var(--paper-2);border:1px solid var(--line-2);padding:7px 14px;border-radius:999px}

/* ---------- prose ---------- */
.prose{max-width:720px}
.prose p{margin-top:18px;color:var(--muted);font-size:1.06rem}
.prose h3{font-size:1.4rem;margin-top:38px}
.prose h3+p{margin-top:12px}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:var(--on-ink-muted);padding:64px 0 30px}
.site-footer__inner{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
@media (max-width:820px){.site-footer__inner{grid-template-columns:1fr 1fr;gap:34px}}
@media (max-width:480px){.site-footer__inner{grid-template-columns:1fr}}
.site-footer .brand__word{color:#fff}
.site-footer__tag{margin-top:16px;max-width:34ch;font-size:.97rem;color:var(--on-ink-muted)}
.site-footer__call{margin-top:18px}
.site-footer__call a{font-family:var(--font-display);font-weight:600;font-size:1.3rem;color:#fff;letter-spacing:-.02em}
.site-footer h4{font-family:var(--font-mono);font-weight:500;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);margin-bottom:16px}
.link-list li{margin-bottom:11px}
.link-list a{color:var(--on-ink-muted);font-size:.97rem;transition:color .2s}
.link-list a:hover{color:#fff}
.site-footer__base{margin-top:50px;padding-top:24px;border-top:1px solid var(--line-ink);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.84rem;color:var(--muted-2)}
.site-footer__base a{color:var(--muted-2)}.site-footer__base a:hover{color:var(--on-ink)}

/* ---------- misc page header ---------- */
.page-hero{padding:60px 0 8px}
.page-hero__title{font-size:clamp(2.2rem,5vw,3.4rem);max-width:16ch}
.page-hero__intro{margin-top:20px;font-size:1.18rem;color:var(--muted);max-width:60ch}

/* ---------- error / thanks ---------- */
.notice{min-height:64vh;display:flex;align-items:center}
.notice__inner{max-width:660px;margin:0 auto;text-align:center}
.notice h1{font-size:clamp(2.2rem,6vw,3.6rem);margin-top:14px}
.notice p{margin:18px auto 0;color:var(--muted);max-width:50ch}
.notice__actions{display:flex;gap:13px;justify-content:center;flex-wrap:wrap;margin-top:32px}
