/* ════════════════════════════════════════════════════════
   SEVEN RABBIT — "The Soi Journal" design system
   Editorial / newspaper language. Edit tokens once here.
   ════════════════════════════════════════════════════════ */
:root{
  --paper:#F7F4EC;
  --soft:#E8E3D3;          /* light hairlines, image bg */
  --ink:#23241F;           /* heavy rules, dark band */
  --moss:#50603F;          /* cafe-side accent */
  --terra:#A65A3A;         /* stay-side accent (from the roof tiles) */
  --mute:#79745F;
  --paper-inv:#F3F0E6;
  --mute-inv:rgba(243,240,230,.62);
  --line-inv:rgba(243,240,230,.18);
  --serif:'Newsreader',Georgia,serif;
  --sans:'Archivo',-apple-system,sans-serif;
  --pad:clamp(20px,4vw,52px);
  --max:1280px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{transition:none!important}}
body{font-family:var(--sans);background:var(--paper);color:var(--ink);font-size:15.5px;line-height:1.6;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit}
::selection{background:var(--terra);color:var(--paper)}
/* ── coming-soon banner ── */
.soon{background:var(--terra);color:var(--paper-inv);border-top:2px solid var(--ink);border-bottom:2px solid var(--ink)}
.soon .wrap{display:flex;align-items:baseline;gap:14px 22px;flex-wrap:wrap;padding-top:18px;padding-bottom:18px}
.soon .tag{font-family:var(--sans);font-weight:700;font-size:11px;letter-spacing:.22em;text-transform:uppercase;white-space:nowrap;border:1.5px solid var(--paper-inv);padding:5px 11px;border-radius:2px}
.soon .msg{font-family:var(--serif);font-size:clamp(16px,2vw,20px);line-height:1.45;margin:0;flex:1;min-width:220px}
.soon .msg em{font-style:italic}
@media(max-width:600px){.soon .wrap{gap:11px}}
/* ── prominent coming-soon hero ── */
.soon-hero{background:var(--terra);color:var(--paper-inv);border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);text-align:center}
.soon-hero .wrap{max-width:660px;padding-top:clamp(52px,8vw,96px);padding-bottom:clamp(52px,8vw,96px)}
.soon-hero .tag{display:inline-block;font-family:var(--sans);font-weight:700;font-size:11px;letter-spacing:.3em;text-transform:uppercase;border:1.5px solid var(--paper-inv);padding:7px 15px;border-radius:2px;margin-bottom:24px}
.soon-hero h1{font-family:var(--serif);font-weight:400;font-size:clamp(40px,8vw,76px);line-height:1;margin:0 0 20px;color:var(--paper-inv)}
.soon-hero h1 em{font-style:italic}
.soon-hero p{font-size:clamp(15px,2vw,18.5px);line-height:1.6;margin:0 auto 32px;max-width:500px;opacity:.94}
.soon-hero .btn{background:var(--paper-inv);color:var(--ink);border-color:var(--paper-inv)}
.soon-hero .btn:hover{background:var(--ink);color:var(--paper-inv);border-color:var(--ink)}
.soon-hero .btn.g{background:transparent;color:var(--paper-inv);border-color:var(--paper-inv)}
.soon-hero .btn.g:hover{background:var(--paper-inv);color:var(--terra)}
:focus-visible{outline:2px solid var(--terra);outline-offset:3px}

/* ── type roles ── */
.cap{font-size:10.5px;font-weight:600;letter-spacing:.2em;text-transform:uppercase}
.kick{font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--moss)}
.kick.t{color:var(--terra)}
.dateline{font-size:11.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--mute)}
.head{font-family:var(--serif);font-weight:420;line-height:1.1;letter-spacing:0}
.head em{font-style:italic;font-weight:380}
.body-text{font-size:14.5px;color:var(--mute);line-height:1.8}
.lede{font-family:var(--serif);font-size:18px;font-weight:380;line-height:1.65;color:var(--mute)}

/* ── layout ── */
.wrap{max-width:var(--max);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.sec{padding-top:clamp(48px,7vw,88px);padding-bottom:clamp(48px,7vw,88px)}
.rule2{display:flex;justify-content:space-between;align-items:baseline;gap:16px;border-top:2px solid var(--ink);padding-top:12px;margin-bottom:clamp(24px,3.5vw,40px);flex-wrap:wrap}
.rule2 .kick{flex-shrink:0}
.rule2 .dateline{text-align:right}
.hair{border-top:1px solid var(--soft)}

/* ── compact masthead bar (all pages; index adds full masthead below it) ── */
.bar{position:sticky;top:0;z-index:90;background:var(--paper);border-bottom:2px solid var(--ink)}
.bar-in{max-width:var(--max);margin:0 auto;padding:0 var(--pad);height:60px;display:flex;justify-content:space-between;align-items:center;gap:16px}
.bar-brand{font-family:var(--serif);font-weight:420;font-size:17px;letter-spacing:.16em;text-transform:uppercase;text-decoration:none;display:flex;align-items:center;gap:10px}
.bar-brand img{height:34px;width:auto;font-size:0;color:transparent}
.bar-nav{display:flex;gap:clamp(14px,2.4vw,30px);align-items:center}
.bar-nav a{text-decoration:none;font-size:11.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase}
.bar-nav a:hover,.bar-nav a[aria-current=page]{color:var(--terra)}
.bar-nav a.b{border:2px solid var(--ink);padding:8px 16px}
.bar-nav a.b:hover{background:var(--ink);color:var(--paper-inv)}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.burger span{display:block;width:22px;height:2px;background:var(--ink);margin:5px 0;transition:.22s}
.menu{display:none}
body.menu-open .menu{display:flex;position:fixed;inset:60px 0 0 0;background:var(--paper);z-index:89;flex-direction:column;padding:32px var(--pad)}
.menu a{text-decoration:none;font-family:var(--serif);font-size:30px;font-weight:400;padding:13px 0;border-bottom:1px solid var(--soft)}
.menu a:last-child{margin-top:22px;border:2px solid var(--ink);font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;text-align:center;padding:15px}
body.menu-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── full ceremonial masthead (index only) ── */
.mast{border-bottom:2px solid var(--ink)}
.mast-top{display:flex;justify-content:space-between;padding:12px 0;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);border-bottom:1px solid var(--soft)}
.mast-mid{text-align:center;padding:clamp(18px,3vw,32px) 0 clamp(12px,2vw,20px)}
.mast-mid img{height:54px;margin:0 auto 10px;font-size:0;color:transparent}
.mast-mid .wordmark{font-family:var(--serif);font-weight:380;font-size:clamp(36px,5.4vw,62px);letter-spacing:.14em;text-transform:uppercase;line-height:1}
.mast-mid p{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--moss);margin-top:8px}

/* ── page section-front (interior page headers) ── */
.front{border-bottom:2px solid var(--ink);padding-top:clamp(30px,4.5vw,52px);padding-bottom:clamp(26px,4vw,44px)}
.front .rule2{margin-bottom:clamp(18px,2.5vw,30px)}
.front h1{font-family:var(--serif);font-weight:400;font-size:clamp(40px,6vw,72px);line-height:1.02}
.front h1 em{font-style:italic;font-weight:360}
.front .lede{margin-top:16px;max-width:600px}

/* ── ticker ── */
.ticker{border-top:2px solid var(--ink);border-bottom:1px solid var(--ink);display:grid;grid-template-columns:repeat(4,1fr)}
.tick{padding:16px clamp(14px,2vw,26px);border-right:1px solid var(--soft);font-size:12.5px;color:var(--mute)}
.tick:last-child{border-right:0}
.tick strong{display:block;font-family:var(--serif);font-size:21px;font-weight:430;font-style:italic;color:var(--ink);margin-bottom:2px}

/* ── buttons & links ── */
.go{display:inline-block;font-size:11.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;border-bottom:2px solid var(--terra);padding-bottom:4px}
.go:hover{color:var(--terra)}
.btn{display:inline-block;background:var(--ink);color:var(--paper-inv);font-size:11.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;padding:15px 32px;border:2px solid var(--ink);cursor:pointer;font-family:var(--sans)}
.btn:hover{background:var(--terra);border-color:var(--terra)}
.btn.g{background:transparent;color:var(--ink)}
.btn.g:hover{background:var(--ink);color:var(--paper-inv)}
.band .btn{background:var(--paper-inv);color:var(--ink);border-color:var(--paper-inv)}
.band .btn:hover{background:var(--terra);color:var(--paper-inv);border-color:var(--terra)}
.band .btn.g{background:transparent;color:var(--paper-inv);border-color:var(--line-inv)}
.band .btn.g:hover{border-color:var(--paper-inv)}

/* ── photography ── */
figure.ph{position:relative;overflow:hidden;background:var(--soft)}
figure.ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;font-size:0;color:transparent}
a:hover figure.ph img{transform:scale(1.025)}
figcaption{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);padding-top:9px}
.pl{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;padding:12px;font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute)}

/* ── dotted-leader menus ── */
.menu-cat{margin-bottom:clamp(36px,5vw,56px)}
.menu-cat h3{font-family:var(--serif);font-weight:430;font-size:clamp(24px,2.6vw,32px);margin-bottom:2px}
.cat-note{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--mute);margin-bottom:18px}
.menu-cols{display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(36px,5vw,80px)}
.mi{display:flex;align-items:baseline;gap:9px;padding:10px 0}
.mi .n{font-weight:500;font-size:15px}
.mi .d{display:block;font-size:12.5px;color:var(--mute);font-weight:400;margin-top:1px}
.mi .dots{flex:1;border-bottom:1px dotted var(--mute);opacity:.55;transform:translateY(-4px);min-width:20px}
.mi .p{font-size:14px;font-weight:600;color:var(--moss);white-space:nowrap;font-variant-numeric:tabular-nums}
.sub-head{font-size:10.5px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);padding:16px 0 5px}
.band .mi .p{color:#C9A06B}
.band .mi .dots{border-color:var(--mute-inv)}

/* ── dark ink band ── */
.band{background:var(--ink);color:var(--paper-inv)}
.band .rule2{border-top-color:var(--paper-inv)}
.band .kick{color:#C9A06B}
.band .dateline{color:var(--mute-inv)}
.band .body-text,.band .lede{color:var(--mute-inv)}
.band .hair{border-color:var(--line-inv)}

/* ── ledger ── */
.ledger{display:grid;grid-template-columns:repeat(3,1fr);gap:0 clamp(28px,4vw,52px)}
.ledger>div{padding:16px 0;border-bottom:1px solid var(--soft)}
.ledger dt{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;margin-bottom:3px}
.ledger dd{font-size:13px;color:var(--mute)}
.band .ledger>div{border-color:var(--line-inv)}
.band .ledger dd{color:var(--mute-inv)}

/* ── side stories ── */
.side-story{border-top:2px solid var(--ink);padding-top:13px;margin-bottom:26px}
.side-story:last-child{margin-bottom:0}
.side-story h4{font-family:var(--serif);font-weight:430;font-size:21px;margin:5px 0 6px}
.side-story p{font-size:13.5px;color:var(--mute);line-height:1.7;margin-bottom:9px}

/* ── forms ── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.f-full{grid-column:1/-1}
label{display:block;font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);margin-bottom:7px}
input,select,textarea{width:100%;padding:13px 15px;border:1px solid var(--mute);background:var(--paper);font-family:var(--sans);font-size:15px;color:var(--ink);border-radius:0;-webkit-appearance:none}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--terra);border-width:1px}
textarea{min-height:104px;resize:vertical}
.form-note{font-size:13px;color:var(--mute);margin-top:13px;line-height:1.7}
.band input,.band select,.band textarea{background:transparent;color:var(--paper-inv);border-color:var(--mute-inv)}
.band label{color:var(--mute-inv)}
.band .form-note{color:var(--mute-inv)}

/* ── quote band ── */
.quote-band{border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);padding-top:clamp(34px,5vw,54px);padding-bottom:clamp(34px,5vw,54px);text-align:center}
.quote-band q{font-family:var(--serif);font-style:italic;font-weight:380;font-size:clamp(22px,3vw,34px);line-height:1.5;display:block;max-width:780px;margin:0 auto 13px;quotes:'"' '"'}

/* ── footer (light, journal smallprint) ── */
footer{border-top:2px solid var(--ink);background:var(--paper)}
.foot-in{max-width:var(--max);margin:0 auto;padding:clamp(36px,5vw,52px) var(--pad) 24px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px}
.foot-brand{font-family:var(--serif);font-size:20px;font-weight:420;letter-spacing:.14em;text-transform:uppercase;margin-bottom:10px}
.foot-tag{font-size:13px;line-height:1.75;color:var(--mute);max-width:240px}
.fh{font-size:10px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--terra);margin-bottom:14px}
footer ul{list-style:none}
footer li{font-size:13px;color:var(--mute);margin-bottom:8px}
footer a{color:var(--mute);text-decoration:none}
footer a:hover{color:var(--ink)}
.foot-bottom{border-top:1px solid var(--soft)}
.foot-bottom div{max-width:var(--max);margin:0 auto;padding:14px var(--pad);display:flex;justify-content:space-between;gap:14px;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute)}

/* ── responsive ── */
@media(max-width:900px){
  .bar-nav{display:none}
  .burger{display:block}
  .menu-cols{grid-template-columns:1fr}
  .ledger{grid-template-columns:1fr 1fr}
  .ticker{grid-template-columns:1fr 1fr}
  .tick:nth-child(2){border-right:0}
  .foot-in{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .rule2{flex-direction:column;align-items:flex-start;gap:3px}
  .form-grid,.ledger{grid-template-columns:1fr}
  .foot-bottom div{flex-direction:column;gap:5px}
  .mast-top{flex-direction:column;gap:3px;text-align:center}
}
