/* ===================================================
   Legal pages — matches style.css v9
   =================================================== */

body.legal-page{
  min-height:100vh;
  display:flex;
  flex-direction:column;
  background:
    radial-gradient(900px 540px at 88% -8%,rgba(202,162,88,.18),transparent 62%),
    radial-gradient(720px 520px at -10% 32%,rgba(127,176,155,.12),transparent 60%),
    linear-gradient(180deg,var(--paper-warm) 0%,var(--cream) 60%,#ece4cf 100%);
}

.legal-page main{flex:1}
.page-main.legal-main{display:block;width:100%}

/* ----- Top bar ----- */
.legal-top{
  text-align:center;
  padding:8px 16px;
  font-family:var(--mono);
  font-size:10px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:2.6px;
  color:var(--muted);
  background:linear-gradient(90deg,transparent,rgba(202,162,88,.22),transparent);
  border-bottom:1px solid rgba(202,162,88,.3);
}

/* ----- Header ----- */
.legal-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(251,246,236,.85);
  backdrop-filter:blur(34px) saturate(1.1);
  -webkit-backdrop-filter:blur(34px) saturate(1.1);
  border-bottom:1px solid rgba(15,31,26,.06);
}
.legal-header__row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
  min-height:78px;
  padding:12px 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:12.5px;
  font-weight:500;
  color:var(--charcoal-60);
  padding:9px 16px;
  border-radius:var(--r-full);
  transition:all var(--trans-fast) var(--ease);
  text-decoration:none;
}
.legal-header__nav a:hover{color:var(--ink);background:rgba(15,31,26,.04)}
.legal-header__nav a[aria-current="page"]{
  color:var(--ink);
  background:rgba(15,31,26,.06);
}
.legal-header__cta{
  font-size:13.5px;
  font-weight:600;
  color:var(--paper-warm);
  padding:11px 22px;
  background:var(--ink);
  border-radius:var(--r-full);
  text-decoration:none;
  transition:all var(--trans-fast) var(--ease);
  white-space:nowrap;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.legal-header__cta::after{content:'→';transition:transform var(--trans-fast) var(--ease)}
.legal-header__cta:hover{
  background:var(--forest);
  color:var(--paper-warm);
  transform:translateY(-1px);
  box-shadow:0 12px 28px rgba(15,31,26,.32);
}
.legal-header__cta:hover::after{transform:translateX(3px)}

/* ----- Hero strip ----- */
.legal-hero{
  background:
    radial-gradient(700px 480px at 12% 30%,rgba(127,176,155,.4),transparent 58%),
    radial-gradient(500px 380px at 95% 90%,rgba(199,87,42,.32),transparent 60%),
    linear-gradient(155deg,var(--ink),var(--forest) 60%,var(--moss));
  color:var(--paper-warm);
  padding:64px 0 84px;
  position:relative;
  overflow:hidden;
}
.legal-hero::before{
  content:'';
  position:absolute;
  width:480px;height:480px;
  border-radius:var(--r-blob);
  background:radial-gradient(circle,rgba(226,199,154,.22),transparent 65%);
  top:-200px;right:-120px;
  pointer-events:none;
  animation:floatBlob 22s ease-in-out infinite;
}
.legal-hero__inner{position:relative;z-index:2;max-width:780px}
.legal-hero__label{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--mono);
  font-size:10.5px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:2.8px;
  color:var(--sand);
  margin-bottom:18px;
  padding:8px 18px 8px 14px;
  border:1px solid rgba(226,199,154,.32);
  border-radius:var(--r-full);
  background:rgba(15,31,26,.32);
  backdrop-filter:blur(10px);
}
.legal-hero__label::before{
  content:'';width:6px;height:6px;border-radius:50%;background:var(--sand);
  box-shadow:0 0 0 3px rgba(226,199,154,.2);
}
.legal-hero h1{
  font-family:var(--display);
  font-size:clamp(32px,5.2vw,52px);
  line-height:1.04;
  font-weight:300;
  margin-bottom:14px;
  letter-spacing:-.035em;
  text-wrap:balance;
  font-variation-settings:"opsz" 144,"SOFT" 35,"WONK" 1;
}
.legal-hero h1 em{
  font-style:italic;color:var(--sand);
  font-variation-settings:"opsz" 144,"SOFT" 80,"WONK" 1;
}
.legal-hero__meta{
  font-size:14px;
  color:rgba(247,241,227,.6);
  font-family:var(--mono);
  letter-spacing:.04em;
}

/* ----- Content card ----- */
.legal-wrap{padding:0 0 96px;margin-top:-44px;position:relative;z-index:3}
.legal-card{
  position:relative;overflow:hidden;
  background:linear-gradient(180deg,var(--paper-warm) 0%,var(--cream) 100%);
  border:1px solid rgba(15,31,26,.06);
  border-radius:var(--r-xl);
  padding:48px 52px 56px;
  box-shadow:0 30px 78px rgba(15,31,26,.14),0 4px 12px rgba(15,31,26,.06);
  max-width:840px;
  margin:0 auto;
}
.legal-card::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:4px;border-radius:var(--r-xl) var(--r-xl) 0 0;
  background:linear-gradient(90deg,var(--clay),var(--sand-deep) 50%,var(--moss));
  box-shadow:0 0 16px rgba(202,162,88,.32);
}
.legal-card::after{
  content:'';position:absolute;width:280px;height:280px;border-radius:var(--r-blob);
  background:radial-gradient(circle,rgba(226,199,154,.22),transparent 70%);
  bottom:-140px;right:-120px;pointer-events:none;
}
.legal-back{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:13px;
  font-weight:600;
  color:var(--ink);
  margin-bottom:32px;
  text-decoration:none;
  padding:10px 0;
  border-bottom:1.5px solid transparent;
  transition:border-color var(--trans-fast) var(--ease),color var(--trans-fast) var(--ease);
  position:relative;z-index:1;
}
.legal-back::before{content:'←';transition:transform var(--trans-fast) var(--ease)}
.legal-back:hover{color:var(--clay);border-bottom-color:var(--sand-deep)}
.legal-back:hover::before{transform:translateX(-4px)}

.legal-doc{position:relative;z-index:1}
.legal-doc h2{
  font-family:var(--display);
  font-size:clamp(22px,2.6vw,28px);
  color:var(--ink);
  margin:48px 0 16px;
  padding-top:16px;
  border-top:1px solid var(--charcoal-08);
  font-weight:500;
  letter-spacing:-.02em;
  line-height:1.2;
  font-variation-settings:"opsz" 80,"SOFT" 30;
}
.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:32px 0 12px;
  letter-spacing:-.005em;
}
.legal-doc p,
.legal-doc li{
  font-size:15px;
  line-height:1.8;
  color:var(--charcoal-80);
  margin-bottom:14px;
}
.legal-doc ul,
.legal-doc ol{
  padding-left:1.4rem;
  margin:0 0 22px;
}
.legal-doc li{margin-bottom:10px}
.legal-doc li::marker{color:var(--moss)}
.legal-doc a{
  color:var(--forest);
  font-weight:600;
  text-decoration:underline;
  text-underline-offset:3px;
  text-decoration-color:rgba(31,77,63,.32);
  transition:text-decoration-color var(--trans-fast) var(--ease),color var(--trans-fast) var(--ease);
}
.legal-doc a:hover{color:var(--clay);text-decoration-color:var(--clay)}
.legal-doc a.btn--primary,
.legal-doc a.btn--primary:hover{
  color:var(--paper-warm);
  text-decoration:none;
}
.legal-doc strong{color:var(--ink);font-weight:600}

.legal-box{
  margin:24px 0;
  padding:22px 24px;
  background:
    radial-gradient(280px 180px at 100% 100%,rgba(127,176,155,.14),transparent 60%),
    linear-gradient(135deg,var(--sand-light),var(--cream));
  border-radius:var(--r-md);
  border-left:4px solid var(--moss);
  box-shadow:var(--shadow-xs);
}
.legal-box p:last-child{margin-bottom:0}

/* ----- Tables (cookies) ----- */
.legal-table-wrap{
  overflow-x:auto;
  margin:22px 0 32px;
  border-radius:var(--r-md);
  border:1px solid rgba(15,31,26,.08);
  box-shadow:var(--shadow-xs);
}
.legal-table{
  width:100%;
  border-collapse:collapse;
  font-size:14px;
  min-width:560px;
  background:var(--paper-warm);
}
.legal-table th,
.legal-table td{
  padding:16px 20px;
  text-align:left;
  border-bottom:1px solid var(--charcoal-08);
  vertical-align:top;
}
.legal-table th{
  font-family:var(--mono);
  font-size:10.5px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1.4px;
  color:var(--moss);
  background:var(--cream);
}
.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(--ink);font-weight:500}

/* ----- 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}
  .legal-card{padding:36px 28px 44px}
}

/* ----- Thank you page ----- */
.thankyou-doc{text-align:center;padding-top:8px;position:relative;z-index:1}
.thankyou-doc .thankyou-icon{
  width:84px;height:84px;margin:0 auto 28px;border-radius:var(--r-blob);
  background:linear-gradient(155deg,var(--moss),var(--ink));color:var(--sand);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:40px;font-weight:400;font-style:italic;line-height:1;
  font-variation-settings:"opsz" 144,"SOFT" 70,"WONK" 1;
  box-shadow:0 22px 52px rgba(15,31,26,.28);
  animation:popIn .7s var(--ease-bounce);
}
.thankyou-lead{font-size:18px;line-height:1.7;color:var(--charcoal-80);margin-bottom:18px;max-width:540px;margin-inline:auto}
.thankyou-note{font-size:13px;color:var(--muted);margin-top:24px;line-height:1.65}
.thankyou-actions{margin-top:32px}

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