/* ============================================================
   Legal pages — Terms / Privacy
   A reading codex: marginalia rail, drop caps, hairline gutters.
   Cohesive with the site palette; distinct in its compositional
   logic — long-form, calm, instrumented for actual reading.
   ============================================================ */

html,body{
  background:var(--cream);
  color:var(--ink);
}

/* ---------- Atmosphere: warm paper tint with a faint vignette --- */
body::after{
  content:""; position:fixed; inset:0; z-index:-1;
  background:
    radial-gradient(ellipse 90% 60% at 50% -10%, rgba(201,166,107,0.10), transparent 65%),
    radial-gradient(ellipse 70% 60% at 110% 110%, rgba(31,58,46,0.06), transparent 60%),
    linear-gradient(180deg, var(--cream) 0%, var(--cream-warm) 100%);
  pointer-events:none;
}

/* ---------- Reading-progress bar (CSS-only, scroll-linked) ---- */
@supports (animation-timeline: scroll()) {
  .progress{
    position:fixed; left:0; top:0; height:2px; width:100%;
    background:linear-gradient(90deg, var(--gold) 0 var(--p,0%), transparent 0);
    z-index:50; pointer-events:none;
  }
  .progress::after{
    content:""; position:absolute; left:0; top:0; height:100%;
    background:var(--gold);
    transform-origin:0 50%;
    animation: scroll-progress linear both;
    animation-timeline: scroll(root);
    width:100%;
    transform:scaleX(0);
  }
}
@keyframes scroll-progress{ to { transform:scaleX(1); } }

/* ---------- Page chrome ------------------------------------- */
.legal-nav{
  position:sticky; top:0; z-index:30;
  background:rgba(245,239,228,0.78);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--hairline-dark);
}
.legal-nav-inner{
  max-width:1180px; margin:0 auto;
  padding:18px 40px;
  display:flex; align-items:center; justify-content:space-between;
  gap:24px;
}
.legal-back{
  display:inline-flex; align-items:center; gap:10px;
  font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  font-weight:500; color:var(--forest);
  opacity:.78; transition:opacity .2s, gap .25s;
}
.legal-back:hover{ opacity:1; gap:14px; }
.legal-back::before{
  content:""; width:22px; height:1px; background:currentColor;
  position:relative;
}
.legal-nav .brand{ font-size:18px; }

/* ---------- Hero / masthead -------------------------------- */
.legal-hero{
  max-width:1180px; margin:0 auto;
  padding:88px 40px 64px;
  display:grid;
  grid-template-columns: 220px 1fr;
  gap:48px;
  border-bottom:1px solid var(--hairline-dark);
  position:relative;
}
.legal-hero::before{
  content:""; position:absolute; left:40px; right:40px; bottom:-1px; height:1px;
  background:linear-gradient(90deg, transparent, var(--gold) 18%, var(--gold) 82%, transparent);
  opacity:.55;
}
.legal-meta{
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--forest-soft);
  display:flex; flex-direction:column; gap:14px;
}
.legal-meta-item .k{
  display:block; opacity:.6; margin-bottom:4px; font-weight:500;
}
.legal-meta-item .v{
  display:block; font-family:var(--serif);
  font-size:18px; font-style:italic; letter-spacing:0;
  text-transform:none; color:var(--forest-deep);
}
.legal-title{
  font-family:var(--serif); font-weight:400;
  font-size:clamp(46px, 7vw, 92px);
  line-height:0.96; letter-spacing:-.02em;
  margin:0;
  color:var(--forest-deep);
}
.legal-title em{ font-style:italic; color:var(--gold); }
.legal-kicker{
  display:inline-flex; align-items:center; gap:14px;
  font-size:11px; letter-spacing:.28em; text-transform:uppercase;
  font-weight:500; color:var(--gold);
  margin-bottom:28px;
}
.legal-kicker .rule{
  width:42px; height:1px; background:currentColor;
}
.legal-lede{
  max-width:54ch; margin-top:32px;
  font-family:var(--serif); font-style:italic;
  font-size:22px; line-height:1.45;
  color:var(--forest);
}

/* ---------- TOC ribbon ------------------------------------- */
.legal-toc{
  max-width:1180px; margin:0 auto;
  padding:34px 40px 10px;
}
.legal-toc-label{
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--forest-soft); opacity:.7; margin-bottom:14px;
}
.legal-toc-list{
  list-style:none; padding:0; margin:0;
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap:2px 28px;
  border-top:1px solid var(--hairline-dark);
}
.legal-toc-list li{
  border-bottom:1px dotted rgba(31,58,46,0.18);
}
.legal-toc-list a{
  display:flex; align-items:baseline; gap:12px;
  padding:10px 0;
  font-size:13.5px; color:var(--forest);
  transition:color .2s, padding-left .2s;
}
.legal-toc-list a:hover{
  color:var(--gold); padding-left:6px;
}
.legal-toc-list a .n{
  font-family:var(--serif); font-style:italic;
  color:var(--gold); font-size:14px;
  min-width:32px;
}

/* ---------- Body: marginalia layout ------------------------- */
.legal-body{
  max-width:1180px; margin:0 auto;
  padding:48px 40px 120px;
}

.legal-section{
  display:grid;
  grid-template-columns: 220px minmax(0,1fr);
  gap:48px;
  padding:56px 0;
  border-top:1px solid var(--hairline-dark);
  scroll-margin-top:90px;
}
.legal-section:first-of-type{ border-top:none; padding-top:24px; }

.legal-section-side{
  position:relative;
}
.legal-section-side .sec-num{
  font-family:var(--serif);
  font-size:54px; line-height:1; font-style:italic;
  color:var(--gold);
  display:block;
}
.legal-section-side .sec-tag{
  display:inline-block;
  margin-top:14px;
  font-size:10.5px; letter-spacing:.22em; text-transform:uppercase;
  font-weight:500;
  color:var(--forest-soft);
}
.legal-section-side .sec-aside{
  display:block; margin-top:22px;
  padding:14px 16px;
  border-left:2px solid var(--gold);
  background:rgba(201,166,107,0.06);
  font-family:var(--serif); font-style:italic;
  font-size:15.5px; line-height:1.5;
  color:var(--forest);
}
.legal-section-side .sec-aside .lab{
  display:block;
  font-family:var(--sans); font-style:normal;
  font-size:9.5px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold); opacity:.95;
  margin-bottom:8px; font-weight:600;
}

.legal-section-main h2{
  font-family:var(--serif); font-weight:400;
  font-size:34px; line-height:1.12; letter-spacing:-.01em;
  margin:0 0 22px;
  color:var(--forest-deep);
}
.legal-section-main h3{
  font-family:var(--sans); font-weight:600;
  font-size:13px; letter-spacing:.16em; text-transform:uppercase;
  margin:32px 0 12px; color:var(--forest-deep);
}
.legal-section-main p{
  font-size:16px; line-height:1.72;
  margin:0 0 14px; color:var(--ink);
}
.legal-section-main p + p{ margin-top:6px; }
.legal-section-main ul, .legal-section-main ol{
  padding-left:0; margin:8px 0 18px;
  list-style:none;
}
.legal-section-main li{
  position:relative;
  padding:6px 0 6px 30px;
  font-size:15.5px; line-height:1.65;
}
.legal-section-main li::before{
  content:"§"; position:absolute; left:6px; top:6px;
  font-family:var(--serif); font-style:italic;
  color:var(--gold); font-size:14px;
}
.legal-section-main ol{ counter-reset: legal-li; }
.legal-section-main ol > li::before{
  counter-increment: legal-li;
  content: counter(legal-li, lower-roman) ".";
  font-family:var(--serif); font-style:italic; color:var(--gold);
  font-size:14px; left:0; min-width:22px; text-align:right;
}
.legal-section-main strong{
  font-weight:600; color:var(--forest-deep);
}
.legal-section-main a{
  color:var(--forest-deep); text-decoration:underline;
  text-decoration-color:var(--gold);
  text-underline-offset:3px;
  text-decoration-thickness:1px;
}
.legal-section-main a:hover{
  color:var(--gold);
}

/* Drop cap on the first paragraph of each section */
.legal-section-main > p:first-of-type::first-letter{
  font-family:var(--serif); font-weight:400;
  float:left; font-size:62px; line-height:.86;
  padding:8px 12px 0 0;
  color:var(--gold);
}

/* Inline definition pill (used in Definitions section) */
.legal-def{
  display:inline-block;
  font-family:var(--serif); font-style:italic;
  color:var(--forest-deep);
}

/* Callouts for hard limits / important notices */
.legal-callout{
  margin:20px 0 22px;
  padding:18px 22px;
  border:1px solid rgba(31,58,46,0.18);
  background:rgba(245,239,228,0.45);
  position:relative;
}
.legal-callout::before{
  content:""; position:absolute; left:-1px; top:-1px; bottom:-1px;
  width:3px; background:var(--gold);
}
.legal-callout .clab{
  display:block;
  font-size:10.5px; letter-spacing:.22em; text-transform:uppercase;
  font-weight:600; color:var(--gold);
  margin-bottom:8px;
}
.legal-callout p{ margin:0; font-size:15px; line-height:1.65; }

/* All-caps block for warranty/liability — convention is meaningful */
.legal-caps{
  text-transform:uppercase;
  font-size:13px !important; letter-spacing:.04em;
  line-height:1.7 !important;
  color:var(--forest-deep) !important;
}

/* ---------- Colophon / footer ------------------------------ */
.legal-colophon{
  max-width:1180px; margin:0 auto;
  padding:48px 40px 80px;
  border-top:1px solid var(--hairline-dark);
  display:grid;
  grid-template-columns: 220px 1fr;
  gap:48px;
  align-items:start;
}
.legal-colophon-meta{
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--forest-soft); opacity:.8;
}
.legal-colophon-body{
  font-family:var(--serif); font-style:italic;
  font-size:18px; line-height:1.6; color:var(--forest);
  max-width:60ch;
}
.legal-colophon-body p{ margin:0 0 10px; }
.legal-colophon-mark{
  margin-top:18px;
  font-family:var(--serif); font-style:italic; font-size:22px;
  color:var(--forest-deep);
}
.legal-colophon-mark em{ color:var(--gold); }
.legal-colophon-links{
  margin-top:18px;
  display:flex; flex-wrap:wrap; gap:18px;
  font-family:var(--sans); font-style:normal;
  font-size:11.5px; letter-spacing:.16em; text-transform:uppercase;
}
.legal-colophon-links a{
  color:var(--forest); text-decoration:none;
  border-bottom:1px solid transparent;
  padding-bottom:2px; transition:border-color .2s, color .2s;
}
.legal-colophon-links a:hover{
  color:var(--gold); border-color:var(--gold);
}

/* ---------- Page-load reveal ------------------------------- */
.rise{
  opacity:0; transform:translateY(14px);
  animation: legal-rise .9s cubic-bezier(.2,.7,.2,1) forwards;
}
.rise.d1{ animation-delay:.08s }
.rise.d2{ animation-delay:.16s }
.rise.d3{ animation-delay:.24s }
.rise.d4{ animation-delay:.32s }
.rise.d5{ animation-delay:.4s }
@keyframes legal-rise{
  to{ opacity:1; transform:none; }
}
@media (prefers-reduced-motion: reduce){
  .rise{ opacity:1; transform:none; animation:none; }
}

/* ---------- Responsive ------------------------------------- */
@media (max-width: 900px){
  .legal-hero{
    grid-template-columns: 1fr;
    padding:64px 22px 48px;
    gap:24px;
  }
  .legal-hero::before{ left:22px; right:22px; }
  .legal-meta{ flex-direction:row; flex-wrap:wrap; gap:18px 28px; }
  .legal-toc, .legal-body, .legal-colophon{
    padding-left:22px; padding-right:22px;
  }
  .legal-nav-inner{ padding:14px 22px; }
  .legal-section{
    grid-template-columns: 1fr;
    gap:20px;
    padding:44px 0;
  }
  .legal-section-side{
    display:flex; align-items:baseline; gap:16px; flex-wrap:wrap;
  }
  .legal-section-side .sec-num{ font-size:38px; }
  .legal-section-side .sec-tag{ margin-top:0; }
  .legal-section-side .sec-aside{ flex-basis:100%; margin-top:8px; }
  .legal-section-main h2{ font-size:26px; }
  .legal-colophon{
    grid-template-columns:1fr; gap:18px;
    padding:36px 22px 64px;
  }
}
