/* ============================================================
   AI Field Guide · afg.css  (v2 "Field Guide" system)
   Single source of truth. No page redefines these tokens.
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --paper:#fbfaf7; --white:#ffffff;
  --ink:#161412; --ink-2:#4b463f; --ink-3:#6b6560;
  --accent:#34503f; --accent-soft:#34503f14;
  --line:#1614121f; --rule:#161412;
  --max:1180px; --gutter:clamp(20px,4vw,48px);
  --s2:8px;--s3:12px;--s4:16px;--s5:20px;--s6:24px;--s8:32px;--s10:40px;--s12:48px;--s16:64px;
  --section:clamp(56px,7vw,96px);
  --radius:3px; --ease:cubic-bezier(.22,1,.36,1); --dur:200ms;
}

html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,sans-serif;
  font-size:18px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ---- layout ---- */
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--gutter)}
.section{padding:var(--section) 0}
.rule{border:0;border-top:1.5px solid var(--rule)}
.rule-thin{border:0;border-top:1px solid var(--line)}

/* ---- type ---- */
.h1{font-family:Fraunces,Georgia,serif;font-weight:900;font-size:clamp(36px,4.6vw,62px);line-height:1.02;letter-spacing:-.015em}
.h1 em{font-style:italic;font-weight:500;color:var(--accent)}
.h2{font-family:Fraunces,Georgia,serif;font-weight:900;font-size:clamp(28px,3vw,44px);line-height:1.08;letter-spacing:-.01em}
.h3{font-family:Fraunces,Georgia,serif;font-weight:600;font-size:clamp(20px,2vw,28px);line-height:1.15}
.lead{font-size:19px;line-height:1.65;font-weight:600;color:var(--ink);border-left:2px solid var(--accent);padding-left:14px}
.body{font-size:17px;line-height:1.72;color:var(--ink-2)}
.label{font-family:Inter;font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3)}
.fig{font-family:Fraunces,serif;font-size:16px;font-weight:600}
.muted{color:var(--ink-3)}
.accent{color:var(--accent)}

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:50;background:var(--paper);border-bottom:1.5px solid var(--ink)}
.nav-inner{max-width:var(--max);margin:0 auto;padding:0 var(--gutter);height:78px;display:flex;align-items:center;justify-content:space-between;gap:var(--s5)}
.brand{font-family:Fraunces,serif;font-size:24px;font-weight:900;letter-spacing:-.01em;white-space:nowrap}
.brand .g{color:var(--accent)}
.nav-links{display:flex;align-items:center;gap:26px}
.nav-links a{font-size:15px;font-weight:500;color:var(--ink-2);transition:color var(--dur) var(--ease)}
.nav-links a:hover{color:var(--ink)}
.nav-no{font-family:Fraunces,serif;font-size:15px;color:var(--ink-3)}
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:30px;height:30px;background:none;border:0;cursor:pointer;padding:0}
.nav-toggle span{display:block;width:24px;height:1.5px;background:var(--ink);transition:transform var(--dur) var(--ease),opacity var(--dur) var(--ease)}
@media(max-width:760px){
  .nav-toggle{display:flex}
  .nav-no{display:none}
  .nav-links{position:absolute;top:78px;left:0;right:0;background:var(--paper);border-bottom:1.5px solid var(--ink);flex-direction:column;align-items:stretch;gap:0;padding:0 var(--gutter);max-height:0;overflow:hidden;visibility:hidden;transition:max-height var(--dur) var(--ease),visibility var(--dur) var(--ease)}
  .nav.open .nav-links{max-height:360px;visibility:visible}
  .nav-links a{padding:17px 0;border-bottom:1px solid var(--line);font-size:16px;font-weight:500}
  .nav-links a:last-child{border-bottom:0}
  .nav.open .nav-toggle span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
  .nav.open .nav-toggle span:nth-child(2){opacity:0}
  .nav.open .nav-toggle span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
}

/* ---- field entry header ---- */
.entry{display:flex;align-items:baseline;gap:14px;margin-bottom:22px}
.entry-no{font-family:Fraunces,serif;font-size:40px;font-weight:900;color:var(--accent);line-height:.8}

/* ---- specimen plate ---- */
.plate{border:1.5px solid var(--ink);padding:14px 14px 0;background:var(--white);position:relative}
.plate::before{content:'';position:absolute;inset:5px;border:1px solid var(--line);pointer-events:none}
.plate img{width:100%;height:auto;display:block;filter:saturate(.94) contrast(1.02)}
.plate .cap{border-top:1.5px solid var(--ink);margin-top:14px;padding:12px 4px;display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.anno{position:absolute;right:-12px;top:64px;display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-2);background:var(--paper);padding:3px 6px}
.anno .dot{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--accent);color:var(--accent);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* ---- trade band ---- */
.trade-band{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s6);margin-top:var(--s10)}
.plate-sm{padding:8px 8px 0;margin:0}
.plate-sm .cap{margin-top:8px;padding:9px 2px}
.plate-sm .fig{font-size:13px}
@media(max-width:760px){.trade-band{grid-template-columns:repeat(2,1fr);gap:16px}.plate-sm .cap{flex-direction:column;align-items:flex-start;gap:3px}}

/* ---- buttons ---- */
.ctas{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.btn{display:inline-block;font-size:14px;font-weight:600;padding:14px 26px;border-radius:var(--radius);transition:transform var(--dur) var(--ease),background var(--dur) var(--ease);white-space:nowrap}
.btn:active{transform:scale(.98)}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--accent)}
.btn-ghost{border:1.5px solid var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.fine{font-size:12px;color:var(--ink-3);letter-spacing:.04em;text-transform:uppercase}

/* ---- grids ---- */
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.two{display:grid;grid-template-columns:1fr 1fr;gap:var(--s12)}
.three{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s8)}
.hero-grid>*,.two>*,.three>*{min-width:0}
@media(max-width:860px){.hero-grid,.two{grid-template-columns:1fr;gap:var(--s10)}.three{grid-template-columns:1fr}.anno{right:8px}}

/* ---- cards (field-note style) ---- */
.card{border:1px solid var(--line);background:var(--white);padding:var(--s8)}
.card .h3{margin:var(--s3) 0}

/* ---- footer ---- */
.foot{border-top:1.5px solid var(--ink);padding:var(--s12) 0;color:var(--ink-3);font-size:14px}

/* ---- focus ---- */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px}

/* ---- skip link ---- */
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:16px;top:16px;width:auto;height:auto;z-index:9999;background:var(--paper);color:var(--ink);padding:10px 18px;border:2px solid var(--accent);font-weight:600;font-size:15px;text-decoration:none;overflow:visible}

/* ---- motion ---- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
}
