/* Dromos — shared stylesheet. Editorial paper-and-ledger. */
:root{
  --ink:#1A1816;
  --ink-soft:#4A463F;
  --muted:#8F8A81;
  --paper:#F7F5EF;          /* warm, very light */
  --paper-alt:#EFECE3;      /* slightly deeper for banded sections */
  --border:#DDD8CB;
  --rule:#C7C1B2;
  --accent:#D97642;
  --accent-ink:#B95A28;
  --max:1240px;
  --gutter:clamp(1.25rem,3vw,2.25rem);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;text-rendering:optimizeLegibility}
body{font-family:'Inter',-apple-system,system-ui,sans-serif;background:var(--paper);color:var(--ink);line-height:1.55;font-size:17px;text-wrap:pretty}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .15s,border-color .15s}
p{color:var(--ink-soft)}
::selection{background:var(--accent);color:var(--paper)}

/* Type scale — Fraunces for display, Inter for body, JetBrains Mono for meta */
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:400;line-height:1.04;letter-spacing:-.02em;color:var(--ink);font-variation-settings:"opsz" 144}
h1{font-size:clamp(2.75rem,6vw + .5rem,6rem);font-weight:400;letter-spacing:-.035em}
h2{font-size:clamp(2rem,3vw + 1rem,3.5rem);letter-spacing:-.025em}
h3{font-size:clamp(1.375rem,1vw + 1rem,1.75rem);letter-spacing:-.02em}
em,i{font-style:italic}

/* Mono meta */
.meta{font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.7rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.meta-accent{color:var(--accent-ink)}

/* The hair-rule motif — replaces icons + pill eyebrows */
.rule{display:flex;align-items:center;gap:.875rem;margin-bottom:1.75rem}
.rule::before{content:"";display:block;width:2.25rem;height:1px;background:var(--accent);flex-shrink:0}
.rule .meta{margin:0}

/* Shell */
.wrap{max-width:var(--max);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter)}

/* Nav — minimal, left-aligned lockup using real text for wordmark */
.nav{position:sticky;top:0;z-index:30;background:rgba(247,245,239,.92);backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid transparent;transition:border-color .2s}
.nav.scrolled{border-bottom-color:var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.15rem 0;max-width:var(--max);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter)}
.brand{display:inline-flex;align-items:center;gap:.7rem;color:var(--ink);line-height:1}
.brand-mark{width:30px;height:27px;flex-shrink:0}
.brand-stack{display:flex;flex-direction:column;gap:.3rem;line-height:1}
.brand-name{font-family:'Inter',sans-serif;font-weight:600;font-size:1.1875rem;letter-spacing:-.025em;color:var(--ink);line-height:1}
.brand-tag{font-family:'JetBrains Mono',monospace;font-size:.56rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);line-height:1;white-space:nowrap}
.nav-links{display:flex;gap:2.25rem;align-items:center;font-size:.9375rem}
.nav-links a{color:var(--ink-soft);font-weight:450;position:relative}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{content:"";position:absolute;left:-.05em;right:-.05em;bottom:-.4rem;height:1px;background:var(--accent)}
.nav-cta{display:inline-flex;align-items:center;gap:.5rem;font-family:'JetBrains Mono',monospace;font-size:.7rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:2px}
.nav-cta:hover{color:var(--accent-ink);border-color:var(--accent)}
.nav-toggle{display:none;background:transparent;border:none;width:36px;height:36px;cursor:pointer;color:var(--ink);padding:6px}

/* Buttons — quieter */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.95rem 1.5rem;border-radius:2px;font-family:'Inter',sans-serif;font-weight:500;font-size:.9375rem;transition:all .18s;border:1px solid transparent;cursor:pointer;white-space:nowrap;line-height:1}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--accent-ink);color:var(--paper)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-link{display:inline-flex;align-items:center;gap:.4rem;color:var(--ink);font-weight:500;border-bottom:1px solid var(--ink);padding-bottom:2px;font-size:.9375rem}
.btn-link:hover{color:var(--accent-ink);border-color:var(--accent)}
.arrow{display:inline-block;transition:transform .2s}
a:hover .arrow,.btn:hover .arrow{transform:translateX(3px)}

/* Footer */
.site-footer{margin-top:6rem;border-top:1px solid var(--border);padding:4rem 0 2rem}
.site-footer .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:3rem}
.footer-brand{max-width:320px}
.footer-brand .brand{margin-bottom:1.25rem}
.footer-brand p{font-size:.9375rem;color:var(--muted);line-height:1.55;margin-bottom:1rem}
.footer-tagline{font-family:'JetBrains Mono',monospace;font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.footer-col h5{font-family:'JetBrains Mono',monospace;font-size:.65rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);margin-bottom:1.25rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.85rem}
.footer-col a{color:var(--ink-soft);font-size:.9375rem}
.footer-col a:hover{color:var(--accent-ink)}
.footer-bottom{max-width:var(--max);margin:3.5rem auto 0;padding:1.5rem var(--gutter) 0;border-top:1px solid var(--border);color:var(--muted);font-size:.7rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-family:'JetBrains Mono',monospace;letter-spacing:.18em;text-transform:uppercase}

/* Mobile */
@media(max-width:860px){
  .site-footer .wrap{grid-template-columns:1fr 1fr;gap:2.5rem}
  .footer-brand{grid-column:1 / -1}
}
@media(max-width:720px){
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--paper);border-bottom:1px solid var(--border);flex-direction:column;gap:0;padding:.25rem 0;box-shadow:0 16px 40px -22px rgba(26,24,22,.25)}
  body.nav-open .nav-links{display:flex}
  .nav-links a,.nav-links .nav-cta{padding:1.1rem 1.5rem;width:100%;font-size:1rem;border-bottom:1px solid var(--border);border-radius:0}
  .nav-links a:last-child{border:none}
  .nav-links a.active::after{display:none}
  .nav-links a.active{color:var(--accent-ink)}
  .nav-toggle{display:block}
  .site-footer .wrap{grid-template-columns:1fr;gap:2.5rem}
}

@media(prefers-reduced-motion:reduce){
  *{transition-duration:.01ms !important;animation-duration:.01ms !important}
}

a:focus-visible,.btn:focus-visible,button:focus-visible{outline:2px solid var(--accent);outline-offset:3px}

/* ─── Shared page patterns (used by services / about / contact) ────── */

/* Masthead + page header */
.masthead{border-bottom:1px solid var(--border);padding:.75rem 0;font-family:'JetBrains Mono',monospace;font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.masthead .wrap{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.masthead .dot{color:var(--accent);padding:0 .4rem}

.page-head{padding:4.5rem 0 3.5rem;border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.page-head .wrap{display:grid;grid-template-columns:minmax(0,.4fr) minmax(0,1fr);gap:clamp(2rem,5vw,5rem);align-items:end;position:relative;z-index:2}
.page-head .meta-side{font-family:'JetBrains Mono',monospace;font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);line-height:1.8}
.page-head .meta-side .key{color:var(--accent-ink);display:block;margin-top:.3rem;margin-bottom:.9rem}
.page-head h1{font-size:clamp(2.5rem,5vw + .5rem,5rem);letter-spacing:-.035em;max-width:14ch;margin-bottom:0}
.page-head h1 em{font-style:italic;color:var(--accent-ink);font-weight:400}
.page-head .deck{margin-top:1.5rem;font-size:1.125rem;line-height:1.5;color:var(--ink-soft);max-width:52ch}
@media(max-width:780px){.page-head .wrap{grid-template-columns:1fr;gap:1.25rem}.page-head .meta-side{line-height:1.6}}

.rule{display:flex;align-items:center;gap:.875rem;margin-bottom:1.75rem}
.rule::before{content:"";display:block;width:2.25rem;height:1px;background:var(--accent);flex-shrink:0}

/* Generic closer */
.closer{padding:7rem 0 6rem;border-top:1px solid var(--border);margin-top:2rem}
.closer .wrap{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:clamp(2rem,5vw,5rem);align-items:center}
.closer h2{font-size:clamp(2.25rem,3vw + 1rem,3.75rem);letter-spacing:-.03em;line-height:1.05;max-width:14ch}
.closer h2 em{font-style:italic;color:var(--accent-ink);font-weight:400}
.closer-side{font-size:1.0625rem;color:var(--ink-soft);line-height:1.55}
.closer-side p{margin-bottom:1.75rem}
.closer-actions{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}
.closer-note{font-family:'JetBrains Mono',monospace;font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:.25rem}
@media(max-width:860px){.closer .wrap{grid-template-columns:1fr;gap:2.5rem}}
