/* ===================================================
   Legal pages — layout & typography (uses :root from style.css)
   =================================================== */

body.legal-page{
  min-height:100vh;
  display:flex;
  flex-direction:column;
  background:var(--cream);
}

.legal-page main{flex:1}

/* ----- Top bar ----- */
.legal-top{
  text-align:center;
  padding:6px 16px;
  font-family:var(--mono);
  font-size:10px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:2.5px;
  color:var(--muted);
  background:var(--sand-light);
  border-bottom:1px solid var(--charcoal-08);
}

/* ----- Header ----- */
.legal-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(253,250,245,.92);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--charcoal-08);
}
.legal-header__row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  min-height:68px;
  padding:10px 0;
}
.legal-header .logo{text-decoration:none}
.legal-header__nav{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
}
.legal-header__nav a{
  font-size:12px;
  font-weight:600;
  color:var(--charcoal-50);
  padding:8px 14px;
  border-radius:var(--r-full);
  transition:all var(--trans) var(--ease);
  text-decoration:none;
}
.legal-header__nav a:hover{color:var(--forest);background:var(--forest-08)}
.legal-header__nav a[aria-current="page"]{
  color:var(--forest);
  background:var(--forest-08);
}
.legal-header__cta{
  font-size:13px;
  font-weight:600;
  color:var(--white);
  padding:9px 20px;
  background:var(--forest);
  border-radius:var(--r-full);
  text-decoration:none;
  transition:all var(--trans) var(--ease);
  white-space:nowrap;
}
.legal-header__cta:hover{
  background:var(--sage);
  color:var(--white);
  transform:translateY(-1px);
  box-shadow:0 6px 20px rgba(27,67,50,.2);
}

/* ----- Hero strip ----- */
.legal-hero{
  background:linear-gradient(135deg,var(--forest) 0%,#234d3a 50%,var(--sage) 100%);
  color:var(--white);
  padding:48px 0 56px;
  position:relative;
  overflow:hidden;
}
.legal-hero::before{
  content:'';
  position:absolute;
  width:420px;height:420px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(196,167,125,.15),transparent 65%);
  top:-180px;right:-100px;
  pointer-events:none;
}
.legal-hero__inner{position:relative;z-index:2;max-width:760px}
.legal-hero__label{
  display:inline-block;
  font-family:var(--mono);
  font-size:10px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:3px;
  color:rgba(255,255,255,.55);
  margin-bottom:14px;
  padding:5px 14px;
  border:1px solid rgba(255,255,255,.15);
  border-radius:var(--r-full);
}
.legal-hero h1{
  font-family:var(--heading);
  font-size:clamp(28px,4.5vw,44px);
  line-height:1.12;
  font-weight:600;
  margin-bottom:12px;
  letter-spacing:-.5px;
}
.legal-hero h1 em{font-style:italic;color:var(--sand)}
.legal-hero__meta{
  font-size:14px;
  color:rgba(255,255,255,.55);
}

/* ----- Content card ----- */
.legal-wrap{padding:0 0 88px;margin-top:-28px;position:relative;z-index:3}
.legal-card{
  background:var(--white);
  border:1px solid var(--charcoal-08);
  border-radius:var(--r-xl);
  padding:40px 44px 48px;
  box-shadow:0 24px 60px rgba(27,67,50,.08);
  max-width:820px;
  margin:0 auto;
}
.legal-back{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  font-weight:600;
  color:var(--forest);
  margin-bottom:28px;
  text-decoration:none;
  padding:8px 0;
  border-bottom:2px solid transparent;
  transition:border-color var(--trans) var(--ease),color var(--trans) var(--ease);
}
.legal-back:hover{
  color:var(--terra);
  border-bottom-color:var(--sand);
}

.legal-doc h2{
  font-family:var(--heading);
  font-size:clamp(20px,2.4vw,24px);
  color:var(--charcoal);
  margin:40px 0 14px;
  padding-top:8px;
  border-top:1px solid var(--charcoal-08);
}
.legal-doc h2:first-of-type{margin-top:8px;border-top:none;padding-top:0}
.legal-doc h3{
  font-family:var(--body);
  font-size:16px;
  font-weight:700;
  color:var(--forest);
  margin:28px 0 10px;
}
.legal-doc p,
.legal-doc li{
  font-size:15px;
  line-height:1.75;
  color:var(--charcoal-80);
  margin-bottom:12px;
}
.legal-doc ul,
.legal-doc ol{
  padding-left:1.35rem;
  margin:0 0 18px;
}
.legal-doc li{margin-bottom:8px}
.legal-doc li::marker{color:var(--sage)}
.legal-doc a{
  color:var(--forest);
  font-weight:600;
  text-decoration:underline;
  text-underline-offset:3px;
}
.legal-doc a:hover{color:var(--terra)}
.legal-doc a.btn--primary,
.legal-doc a.btn--primary:hover{
  color:var(--white);
  text-decoration:none;
}
.legal-doc strong{color:var(--charcoal)}

.legal-box{
  margin:20px 0;
  padding:20px 22px;
  background:var(--sand-light);
  border-radius:var(--r-md);
  border-left:4px solid var(--forest);
}
.legal-box p:last-child{margin-bottom:0}

/* ----- Tables (cookies) ----- */
.legal-table-wrap{
  overflow-x:auto;
  margin:18px 0 28px;
  border-radius:var(--r-md);
  border:1px solid var(--charcoal-08);
}
.legal-table{
  width:100%;
  border-collapse:collapse;
  font-size:14px;
  min-width:520px;
}
.legal-table th,
.legal-table td{
  padding:14px 18px;
  text-align:left;
  border-bottom:1px solid var(--charcoal-08);
  vertical-align:top;
}
.legal-table th{
  font-family:var(--mono);
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1px;
  color:var(--forest);
  background:var(--forest-08);
}
.legal-table tr:last-child td{border-bottom:none}
.legal-table td{font-family:var(--body);color:var(--charcoal-80)}
.legal-table td:first-child{font-family:var(--mono);font-size:13px;color:var(--charcoal)}

/* ----- Footer variant ----- */
.legal-page .footer{margin-top:auto}
.legal-page .footer__brand .logo{pointer-events:auto}

@media(max-width:900px){
  .legal-header__row{justify-content:center}
  .legal-header__nav{order:3;width:100%;justify-content:center}
}
/* ----- Thank you page ----- */
.thankyou-doc{text-align:center;padding-top:8px}
.thankyou-doc .thankyou-icon{
  width:72px;height:72px;margin:0 auto 24px;border-radius:50%;
  background:var(--forest);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-size:32px;font-weight:700;line-height:1;
  box-shadow:0 12px 32px rgba(27,67,50,.2);
}
.thankyou-lead{font-size:17px;line-height:1.65;color:var(--charcoal-80);margin-bottom:16px}
.thankyou-note{font-size:13px;color:var(--muted);margin-top:20px;line-height:1.6}
.thankyou-actions{margin-top:28px}

@media(max-width:640px){
  .legal-card{padding:28px 22px 36px}
  .legal-hero{padding:36px 0 44px}
  .legal-doc h2{margin-top:32px}
}
