/* ============================================================
   THE DISTRICT RECORD — design system
   Editorial records publication. Sourced, factual, defensible.
   Type: Fraunces (display) · Source Serif 4 (read) · Inter (UI) · IBM Plex Mono (labels)
   ============================================================ */

:root{
  --navy:#0c2236;
  --navy-2:#102a43;
  --navy-3:#16395a;
  --ink:#0b1a29;
  --paper:#f4f1e9;
  --paper-2:#faf8f2;
  --paper-3:#efece2;
  --accent:#9a6b1f;
  --accent-deep:#7c5417;
  --accent-bright:#c08a2e;
  --link:#2f5f8f;
  --text:#1c2733;
  --muted:#56656f;
  --dim:#8b9aa6;
  --line:rgba(12,34,54,0.14);
  --line-strong:rgba(12,34,54,0.28);
  --line-light:rgba(255,255,255,0.16);
  --verified:#1f4f6e;
  --pending:#7c5417;
  --reported:#9a6b1f;
  --display:'Fraunces','Source Serif 4',Georgia,serif;
  --h:'Source Serif 4',Georgia,serif;
  --b:'Inter',system-ui,-apple-system,sans-serif;
  --m:'IBM Plex Mono',ui-monospace,monospace;
  --ease:cubic-bezier(0.16,1,0.3,1);
  --wrap:1180px;
  --read:760px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;overflow-x:hidden}
body{
  background:var(--paper-2);color:var(--text);
  font-family:var(--b);font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit}
::selection{background:var(--navy);color:var(--paper-2)}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 32px}
.read{max-width:var(--read);margin:0 auto;padding:0 32px}

/* ---------- shared label / eyebrow ---------- */
.eyebrow{
  font-family:var(--m);font-size:.62rem;font-weight:600;
  letter-spacing:.28em;text-transform:uppercase;color:var(--accent);
  display:inline-flex;align-items:center;gap:12px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent);opacity:.6}

/* ---------- text-reveal primitives (GSAP/SplitType) ---------- */
.reveal-mask{overflow:hidden;display:block}
[data-split]{visibility:hidden}
.split-ready [data-split]{visibility:visible}
.fade-up{opacity:0;transform:translateY(22px)}
.is-in.fade-up{opacity:1;transform:none;transition:opacity .9s var(--ease),transform .9s var(--ease)}

/* ============================================================
   MASTHEAD
   ============================================================ */
.masthead{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.masthead::after{content:"";position:absolute;inset:0;background:
  radial-gradient(120% 90% at 50% -20%,rgba(192,138,46,0.18),transparent 60%);pointer-events:none}
.masthead-inner{max-width:var(--wrap);margin:0 auto;padding:26px 32px;position:relative;z-index:2}

/* home masthead */
.mh-home{text-align:center;padding:72px 32px 64px}
.mh-rule{
  display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;
  font-family:var(--m);font-size:.58rem;font-weight:600;letter-spacing:.34em;
  text-transform:uppercase;color:rgba(255,255,255,0.55);margin-bottom:30px;
}
.mh-rule span{white-space:nowrap}
.mh-rule::before,.mh-rule::after{content:"";height:1px;width:70px;background:rgba(255,255,255,0.24)}
.wordmark{
  font-family:var(--display);font-weight:600;font-optical-sizing:auto;
  font-size:clamp(2.3rem,8.5vw,6.2rem);line-height:.96;letter-spacing:-.02em;color:#fff;
}
.wordmark .word{display:inline-block}
.mh-tag{
  font-family:var(--h);font-size:clamp(1rem,2.4vw,1.35rem);font-style:italic;
  color:rgba(255,255,255,0.74);margin-top:26px;
}
.mh-meta{
  display:flex;align-items:center;justify-content:center;gap:26px;flex-wrap:wrap;
  font-family:var(--m);font-size:.6rem;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;color:rgba(255,255,255,0.5);margin-top:34px;
}
.mh-meta b{color:rgba(255,255,255,0.78);font-weight:600}

/* record-page masthead (compact bar) */
.mh-bar{display:flex;align-items:center;justify-content:space-between;gap:20px}
.mh-wm{font-family:var(--display);font-size:1.35rem;font-weight:600;letter-spacing:-.01em;color:#fff;text-decoration:none;line-height:1}
.mh-wm small{display:block;font-family:var(--m);font-size:.5rem;font-weight:500;letter-spacing:.26em;text-transform:uppercase;color:rgba(255,255,255,0.5);margin-top:7px}
.mh-back{
  font-family:var(--m);font-size:.62rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,0.65);text-decoration:none;display:inline-flex;align-items:center;gap:9px;
  white-space:nowrap;transition:color .25s,gap .25s var(--ease);
}
.mh-back:hover{color:#fff;gap:13px}
.mh-back svg{width:13px;height:13px}

/* ============================================================
   MISSION / STANDFIRST
   ============================================================ */
.mission{padding:78px 0 8px;border-bottom:1px solid var(--line)}
.mission .read{padding:0 32px}
.mission .eyebrow{margin-bottom:26px}
.mission p{
  font-family:var(--h);font-size:clamp(1.25rem,3vw,1.7rem);line-height:1.5;color:var(--ink);
}
.mission p+p{margin-top:22px;font-size:clamp(1rem,2vw,1.12rem);color:var(--muted)}
.mission em{font-style:italic;color:var(--accent-deep)}
.mission-foot{padding:40px 0 0}

/* ============================================================
   FEATURED / LEAD RECORD
   ============================================================ */
.featured{padding:78px 0}
.feat-head{display:flex;align-items:baseline;justify-content:space-between;gap:20px;margin-bottom:36px;flex-wrap:wrap}
.feat-head h2{font-family:var(--m);font-size:.7rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--muted)}
.feat-card{
  display:grid;grid-template-columns:300px 1fr;gap:48px;align-items:stretch;
  background:#fff;border:1px solid var(--line);border-top:3px solid var(--navy);
  box-shadow:0 1px 0 rgba(12,34,54,0.04),0 40px 80px -56px rgba(12,34,54,0.5);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease);
}
.feat-card:hover{transform:translateY(-4px);box-shadow:0 1px 0 rgba(12,34,54,0.04),0 56px 90px -50px rgba(12,34,54,0.55)}
.feat-photo{position:relative;overflow:hidden;background:var(--paper)}
.feat-photo img{width:100%;height:100%;object-fit:cover;filter:grayscale(.18) contrast(1.02);transition:transform .8s var(--ease),filter .8s var(--ease)}
.feat-card:hover .feat-photo img{transform:scale(1.04);filter:grayscale(0) contrast(1.02)}
.feat-photo figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:14px 16px;
  font-family:var(--m);font-size:.54rem;letter-spacing:.04em;color:rgba(255,255,255,0.9);
  background:linear-gradient(to top,rgba(11,26,41,0.92),transparent);line-height:1.5;
}
.feat-body{padding:40px 44px 40px 0;display:flex;flex-direction:column}
.feat-eyebrow{font-family:var(--m);font-size:.6rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--accent);margin-bottom:18px}
.feat-name{font-family:var(--display);font-weight:600;font-size:clamp(2rem,4.4vw,3rem);line-height:1.02;letter-spacing:-.02em;color:var(--ink);margin-bottom:14px}
.feat-role{font-size:.86rem;font-weight:600;color:var(--accent-deep);line-height:1.55;margin-bottom:22px}
.feat-line{font-family:var(--h);font-size:1.08rem;color:var(--muted);line-height:1.7;margin-bottom:auto}
.feat-status{display:flex;gap:10px;flex-wrap:wrap;margin:26px 0}

/* button */
.btn{
  display:inline-flex;align-items:center;gap:11px;align-self:flex-start;
  font-family:var(--b);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:#fff;background:var(--navy);padding:16px 32px;text-decoration:none;border:1px solid var(--navy);
  transition:background .3s,gap .3s var(--ease);
}
.btn:hover{background:var(--navy-2);gap:16px}
.btn svg{width:14px;height:14px}
.btn-ghost{color:var(--navy);background:transparent}
.btn-ghost:hover{background:var(--navy);color:#fff}

/* ============================================================
   THE RECORD — index (grid / list toggle)
   ============================================================ */
.index{padding:8px 0 92px}
.index-head{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:40px;flex-wrap:wrap}
.index-head h2{font-family:var(--m);font-size:.7rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--muted)}
.toggle{display:inline-flex;border:1px solid var(--line-strong);background:#fff}
.toggle button{
  font-family:var(--m);font-size:.58rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);background:transparent;border:0;padding:9px 16px;cursor:pointer;transition:background .25s,color .25s;
}
.toggle button.active{background:var(--navy);color:#fff}

.records{display:grid;gap:1px;background:var(--line);border:1px solid var(--line)}
.records.is-grid{grid-template-columns:repeat(3,1fr)}
.records.is-list{grid-template-columns:1fr}

.rec-item{
  background:var(--paper-2);text-decoration:none;color:inherit;
  display:flex;flex-direction:column;padding:30px;min-height:230px;
  transition:background .35s var(--ease);position:relative;
}
.rec-item:hover{background:#fff}
.rec-item .num{font-family:var(--m);font-size:.6rem;font-weight:600;letter-spacing:.14em;color:var(--dim)}
.rec-item .rname{font-family:var(--display);font-weight:600;font-size:1.5rem;line-height:1.08;letter-spacing:-.01em;color:var(--ink);margin:18px 0 10px}
.rec-item .rrole{font-size:.78rem;color:var(--muted);line-height:1.5;margin-bottom:auto}
.rec-item .rfoot{display:flex;align-items:center;justify-content:space-between;margin-top:24px;font-family:var(--m);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}
.rec-item .rfoot svg{width:14px;height:14px;transition:transform .3s var(--ease)}
.rec-item:hover .rfoot svg{transform:translateX(5px)}

/* list view tweaks */
.records.is-list .rec-item{flex-direction:row;align-items:center;gap:30px;min-height:0;padding:26px 30px}
.records.is-list .rec-item .num{width:34px;flex:none}
.records.is-list .rec-item .rname{margin:0;font-size:1.5rem;flex:none;width:30%}
.records.is-list .rec-item .rrole{margin:0;flex:1}
.records.is-list .rec-item .rfoot{margin:0}

/* upcoming / placeholder slot */
.rec-soon{background:var(--paper-3);color:var(--dim);cursor:default;justify-content:center;align-items:flex-start}
.rec-soon:hover{background:var(--paper-3)}
.rec-soon .rname{color:var(--dim);font-style:italic}

/* ============================================================
   STANDARDS strip
   ============================================================ */
.standards{background:var(--navy);color:rgba(255,255,255,0.82)}
.standards-inner{max-width:var(--wrap);margin:0 auto;padding:74px 32px}
.standards .eyebrow{color:var(--accent-bright);margin-bottom:34px}
.std-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-light);border:1px solid var(--line-light)}
.std-cell{background:var(--navy);padding:34px 30px}
.std-cell h3{font-family:var(--display);font-weight:600;font-size:1.3rem;color:#fff;margin-bottom:14px;letter-spacing:-.01em}
.std-cell p{font-size:.92rem;line-height:1.7;color:rgba(255,255,255,0.66)}
.std-cell .n{font-family:var(--m);font-size:.6rem;letter-spacing:.16em;color:var(--accent-bright);display:block;margin-bottom:18px}

/* ============================================================
   RECORD PAGE — subject + timeline
   ============================================================ */
.subject{padding:64px 0 52px;border-bottom:1px solid var(--line)}
.subject-grid{display:grid;grid-template-columns:230px 1fr;gap:48px;align-items:start}
.subject-photo{position:relative}
.subject-photo img{width:100%;border:1px solid var(--line-strong);background:var(--paper);filter:grayscale(.18) contrast(1.02)}
.subject-photo figcaption{font-family:var(--m);font-size:.56rem;letter-spacing:.04em;color:var(--dim);margin-top:11px;line-height:1.5}
.subject-name{font-family:var(--display);font-weight:600;font-size:clamp(2.1rem,5.6vw,3.4rem);line-height:1.02;letter-spacing:-.02em;color:var(--ink);margin-bottom:14px}
.subject-role{font-size:.9rem;font-weight:600;color:var(--accent-deep);line-height:1.55;margin-bottom:24px}
.subject-note{font-family:var(--h);font-size:1rem;font-style:italic;color:var(--muted);line-height:1.65;max-width:560px;padding:18px 22px;border-left:2px solid var(--accent);background:#fff}

.timeline{padding:62px 0 20px}
.timeline-head{font-family:var(--m);font-size:.64rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--accent);margin-bottom:42px}
.record{position:relative;padding:0 0 44px 36px;border-left:1px solid var(--line-strong)}
.record:last-of-type{border-left-color:transparent;padding-bottom:10px}
.record::before{content:"";position:absolute;left:-6px;top:6px;width:11px;height:11px;border-radius:50%;background:var(--navy);border:2px solid var(--paper-2)}
.record-top{display:flex;flex-wrap:wrap;align-items:center;gap:13px;margin-bottom:16px}
.badge{font-family:var(--b);font-size:.58rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:6px 13px;border-radius:3px;white-space:nowrap}
.badge-verified{background:var(--verified);color:#fff;border:1px solid var(--verified)}
.badge-pending{background:var(--pending);color:#fff;border:1px solid var(--pending)}
.badge-reported{background:rgba(154,107,31,0.1);color:var(--accent-deep);border:1px solid rgba(154,107,31,0.42)}
.record-date{font-family:var(--m);font-size:.66rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.record-text{font-family:var(--h);font-size:1.08rem;line-height:1.7;color:var(--ink);margin-bottom:16px}
.record-text+.record-text{margin-top:-4px}
.record-src{font-family:var(--m);font-size:.66rem;letter-spacing:.02em;color:var(--muted);line-height:1.8}
.record-src .src-label{color:var(--dim);text-transform:uppercase;letter-spacing:.12em;font-size:.56rem;display:block;margin-bottom:5px}
.record-src a{color:var(--link);text-decoration:none;border-bottom:1px solid rgba(47,95,143,0.35);word-break:break-word;transition:border-color .2s}
.record-src a:hover{border-bottom-color:var(--link)}

/* corrections */
.corrections{margin-top:30px;background:#fff;border:1px solid var(--line);border-left:3px solid var(--accent);padding:32px 34px}
.corrections h2{font-family:var(--display);font-weight:600;font-size:1.3rem;color:var(--ink);margin-bottom:12px;letter-spacing:-.01em}
.corrections p{font-size:.94rem;color:var(--muted);line-height:1.7;margin-bottom:18px;max-width:600px}

/* next up */
.nextup{border-top:1px solid var(--line);margin-top:8px}
.nextup a{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:46px 0;text-decoration:none;color:inherit;transition:padding .4s var(--ease)}
.nextup a:hover{padding-left:10px}
.nextup .nu-label{font-family:var(--m);font-size:.62rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin-bottom:12px;display:block}
.nextup .nu-name{font-family:var(--display);font-weight:600;font-size:clamp(1.6rem,4vw,2.4rem);line-height:1.04;letter-spacing:-.01em;color:var(--ink)}
.nextup .nu-arrow{width:46px;height:46px;flex:none;border:1px solid var(--line-strong);border-radius:50%;display:grid;place-items:center;transition:background .3s,border-color .3s}
.nextup a:hover .nu-arrow{background:var(--navy);border-color:var(--navy)}
.nextup .nu-arrow svg{width:18px;height:18px;transition:transform .3s var(--ease)}
.nextup a:hover .nu-arrow svg{transform:translateX(4px)}
.nextup a:hover .nu-arrow svg path{stroke:#fff}

/* ============================================================
   FOOTER
   ============================================================ */
footer{background:var(--navy);color:rgba(255,255,255,0.7);border-top:3px double rgba(255,255,255,0.22)}
.footer-inner{max-width:var(--wrap);margin:0 auto;padding:56px 32px 60px;display:grid;grid-template-columns:1.4fr 1fr;gap:40px}
.footer-wm{font-family:var(--display);font-weight:600;font-size:1.5rem;color:#fff;letter-spacing:-.01em;margin-bottom:18px}
.footer-disc{font-family:var(--h);font-size:.95rem;line-height:1.7;color:rgba(255,255,255,0.78);max-width:480px}
.footer-meta{font-family:var(--m);font-size:.64rem;letter-spacing:.06em;color:rgba(255,255,255,0.5);text-transform:uppercase;line-height:2}
.footer-meta a{color:rgba(255,255,255,0.82);text-decoration:none;border-bottom:1px solid rgba(255,255,255,0.25)}
.footer-meta a:hover{color:#fff}
.footer-bar{border-top:1px solid var(--line-light)}
.footer-bar div{max-width:var(--wrap);margin:0 auto;padding:20px 32px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-family:var(--m);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,0.42)}

/* ============================================================
   PROGRESS BAR
   ============================================================ */
.progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--accent-bright);z-index:90;transition:width .1s linear}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:900px){
  .feat-card{grid-template-columns:1fr}
  .feat-photo{height:280px}
  .feat-body{padding:34px 30px}
  .records.is-grid{grid-template-columns:1fr 1fr}
  .std-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
  .subject-grid{grid-template-columns:1fr;gap:26px}
  .subject-photo{max-width:230px}
}
@media (max-width:600px){
  .wrap,.read{padding:0 22px}
  .wordmark{font-size:clamp(1.85rem,8.2vw,2.5rem)}
  .mh-home{padding:54px 22px 48px}
  .mh-rule{gap:10px;font-size:.52rem;letter-spacing:.22em}
  .mh-rule::before,.mh-rule::after{width:34px}
  .mission{padding:54px 0 8px}
  .featured,.index{padding:54px 0}
  .records.is-grid{grid-template-columns:1fr}
  .records.is-list .rec-item{flex-direction:column;align-items:flex-start;gap:12px}
  .records.is-list .rec-item .rname,.records.is-list .rec-item .rrole{width:auto}
  .mh-bar{flex-direction:column;align-items:flex-start;gap:14px}
  .standards-inner{padding:54px 22px}
  .footer-inner{padding:44px 22px}
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  [data-split],.fade-up{visibility:visible!important;opacity:1!important;transform:none!important}
}
