/* ════════════════════════════════════════════════════════════════════
   AqlData — Procurement Intelligence Desk · shared stylesheet
   Drives every /suppliers/* footprint page and the suppliers index.
   Design system mirrors the landing: Fraunces serif + IBM Plex Mono,
   gold-on-near-black, fine rules, tabular data treated as evidence.
   ════════════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,360;9..144,460;9..144,560;9..144,640&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root{
  --bg:#0a0c10; --bg2:#0c0f14; --panel:#10141c; --panel2:#131927;
  --line:#1c2330; --line2:#28313f;
  --ink:#ece7dd; --muted:#9a9b93; --dim:#646b75;
  --gold:#e0a341; --gold-d:#c98f30; --gold-soft:rgba(224,163,65,.10);
  --sage:#74b39c; --flag:#d97b57;
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,"SF Mono",Menlo,Consolas,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--ink);
  font:16px/1.65 var(--sans);-webkit-font-smoothing:antialiased;
  overflow-x:hidden;position:relative;
}
/* faint engraved grid — atmosphere, not noise */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;opacity:.16;
  -webkit-mask-image:radial-gradient(ellipse 90% 55% at 50% 0%,#000,transparent 72%);
  mask-image:radial-gradient(ellipse 90% 55% at 50% 0%,#000,transparent 72%);
}
.wrap{max-width:1000px;margin:0 auto;padding:0 28px;position:relative;z-index:1}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:#0a0c10}

/* ── header ── */
header{border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;
  background:rgba(10,12,16,.82);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.bar{display:flex;align-items:center;justify-content:space-between;height:60px}
.brand{font-family:var(--serif);font-weight:560;font-size:20px;letter-spacing:-.2px}
.brand span{color:var(--gold)}
.bar .meta{color:var(--muted);font-family:var(--mono);font-size:12.5px;letter-spacing:.2px;transition:color .18s}
.bar a.meta:hover{color:var(--gold)}

/* ── breadcrumb ── */
nav.crumb{font-family:var(--mono);font-size:12px;color:var(--dim);padding:24px 0 0;letter-spacing:.2px}
nav.crumb a{transition:color .18s}
nav.crumb a:hover{color:var(--gold)}

/* ── page head ── */
.kicker{font-family:var(--mono);color:var(--gold);font-size:11px;letter-spacing:3px;
  text-transform:uppercase;display:flex;align-items:center;gap:10px}
.kicker::before{content:"";width:24px;height:1px;background:var(--gold);display:inline-block}
h1{font-family:var(--serif);font-weight:360;font-size:clamp(30px,4vw,44px);line-height:1.08;
  letter-spacing:-.5px;margin:18px 0 0;max-width:22ch}
h1 b,h1 em{color:var(--gold)}
h1 em{font-style:italic}
.lead{margin-top:20px;color:var(--muted);font-size:17px;max-width:66ch;line-height:1.6}
.lead b{color:var(--ink);font-weight:600}

/* ── stat strip ── */
.stats{display:flex;flex-wrap:wrap;border:1px solid var(--line2);border-radius:6px;
  background:linear-gradient(180deg,var(--panel2),var(--panel));margin:32px 0 8px;
  box-shadow:0 24px 60px -34px rgba(0,0,0,.8);overflow:hidden}
.stat{flex:1;min-width:140px;padding:20px 22px;border-right:1px solid var(--line)}
.stat:last-child{border-right:0}
.stat .v{font-family:var(--serif);font-size:28px;font-weight:460;letter-spacing:-.4px;line-height:1}
.stat .v b{color:var(--gold);font-weight:560}
.stat .k{font-family:var(--mono);font-size:10px;color:var(--dim);text-transform:uppercase;
  letter-spacing:.7px;margin-top:9px}

/* ── sections ── */
section{margin:52px 0}
h2{font-family:var(--mono);font-size:11px;color:var(--gold);letter-spacing:2.2px;
  margin-bottom:18px;text-transform:uppercase;display:flex;align-items:center;gap:11px}
h2::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--line2),transparent)}
p.note{color:var(--muted);font-size:15px;max-width:66ch;line-height:1.6}
p.note b{color:var(--ink)}

/* ── tables (evidence) ── */
table{width:100%;border-collapse:collapse;font-size:13.5px;
  border:1px solid var(--line2);border-radius:6px;overflow:hidden}
thead th{background:var(--bg2)}
th{text-align:left;color:var(--dim);padding:11px 16px;font-family:var(--mono);font-size:10px;
  text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid var(--line2)}
th.r,td.r{text-align:right;font-variant-numeric:tabular-nums;font-family:var(--mono)}
td{padding:11px 16px;border-bottom:1px solid var(--line);color:var(--ink);transition:background .15s}
tbody tr:hover td{background:rgba(224,163,65,.04)}
tr:last-child td{border-bottom:0}
td.r{color:var(--ink)}
.gate{color:var(--dim);font-style:italic}
.gate.r{color:var(--dim)}

/* ── timeline ── */
.tl{margin-top:6px}
.tl .row{display:flex;align-items:center;gap:12px;margin:5px 0}
.tl .y{width:38px;font-family:var(--mono);font-size:10.5px;color:var(--dim)}
.tl .bar{height:9px;border-radius:2px;min-width:2px;
  background:linear-gradient(90deg,var(--gold-d),var(--gold));opacity:.92;
  box-shadow:0 0 16px -4px rgba(224,163,65,.5)}
.tl .v{font-family:var(--mono);font-size:10.5px;color:var(--muted);font-variant-numeric:tabular-nums}

/* ── CTA box (the desk) ── */
.ctabox{border:1px solid var(--line2);border-radius:8px;
  background:linear-gradient(120deg,var(--panel2),var(--panel));
  padding:28px 28px;margin:52px 0 0;position:relative;overflow:hidden}
.ctabox::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--gold)}
.ctabox h3{font-family:var(--serif);font-size:22px;font-weight:560;margin-bottom:9px;letter-spacing:-.2px}
.ctabox p{color:var(--muted);font-size:14.5px;line-height:1.6;margin-bottom:18px;max-width:64ch}
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 22px;border-radius:3px;
  font-family:var(--mono);font-size:13px;font-weight:500;letter-spacing:.2px;
  border:1px solid var(--line2);transition:.2s cubic-bezier(.4,0,.2,1);margin-right:10px}
.btn-1{background:var(--gold);color:#0a0c10;border-color:var(--gold);font-weight:600}
.btn-1:hover{background:var(--gold-d);border-color:var(--gold-d);transform:translateY(-1px)}
.btn-2{background:transparent;color:var(--ink)}
.btn-2:hover{border-color:var(--gold);color:var(--gold)}

/* ── supplier index grid ── */
.idx{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:30px 0}
.idx a{display:block;border:1px solid var(--line2);border-radius:6px;padding:18px 20px;
  background:var(--panel);transition:.22s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}
.idx a::after{content:"";position:absolute;left:0;top:0;height:2px;width:0;background:var(--gold);transition:width .3s}
.idx a:hover{border-color:var(--line2);transform:translateY(-3px);background:var(--panel2)}
.idx a:hover::after{width:100%}
.idx .nm{font-family:var(--serif);font-weight:560;font-size:17px;letter-spacing:-.2px}
.idx .mt{font-family:var(--mono);font-size:11px;color:var(--dim);margin-top:5px;letter-spacing:.2px}

/* ── footer ── */
footer{border-top:1px solid var(--line);padding:30px 0 56px;color:var(--dim);
  font-size:12px;line-height:1.75;font-family:var(--mono);margin-top:56px}
footer b{color:var(--muted);font-weight:500}

@media(max-width:760px){
  .idx{grid-template-columns:1fr 1fr}
  .stat{min-width:50%}
}
@media(max-width:640px){
  /* evidence tables scroll rather than crush on phones */
  table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
}
@media(max-width:560px){
  .idx{grid-template-columns:1fr}
  .stat{min-width:100%;border-right:0;border-bottom:1px solid var(--line)}
  .stat:last-child{border-bottom:0}
}
