/* ─────────────────────────────────────────────────────────────────────────────
 * legal.css — Shared stylesheet for legal/policy pages
 * Used by /legal-notice, /privacy-policy, /cookie-policy, /terms, /contact
 * ─────────────────────────────────────────────────────────────────────────── */

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

:root{
  --ink:#1a1408;
  --paper:#f2ede0;
  --paper2:#e8e0cc;
  --amber:#c8820a;
  --amber2:#e09a14;
  --amber3:#f5c040;
  --rust:#b03818;
  --cream:#fdf8ec;
  --sage:#2a5c2a;
  --sky:#1a4080;
  --hatch:rgba(26,20,8,.06);
}

html{scroll-behavior:smooth}
body{
  font-family:'Crimson Pro',Georgia,serif;
  background:var(--paper);color:var(--ink);
  overflow-x:hidden;min-height:100vh;
  display:flex;flex-direction:column;
}
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:
    repeating-linear-gradient(45deg,var(--hatch) 0,var(--hatch) 1px,transparent 1px,transparent 8px),
    repeating-linear-gradient(-45deg,var(--hatch) 0,var(--hatch) 1px,transparent 1px,transparent 8px);
}

/* ── NAV ── */
nav.site-nav{
  position:sticky;top:0;z-index:100;
  background:var(--amber);border-bottom:3px solid var(--ink);
  display:flex;align-items:center;justify-content:space-between;
  padding:.9rem 2.2rem;
}
.logo{
  font-family:'Oswald',sans-serif;font-weight:700;font-size:1.4rem;
  letter-spacing:.04em;color:var(--ink);text-decoration:none;
}
.logo em{font-style:normal;color:var(--rust)}
.nav-context{
  font-family:'Oswald',sans-serif;font-size:.8rem;font-weight:700;
  letter-spacing:.08em;color:var(--ink);
}
.nav-back{
  font-family:'Oswald',sans-serif;font-size:.8rem;font-weight:700;letter-spacing:.08em;
  color:var(--ink);text-decoration:none;opacity:.75;transition:opacity .15s;
}
.nav-back:hover{opacity:1}

/* ── PAGE LAYOUT ── */
main.page{
  position:relative;z-index:1;flex:1;
  max-width:880px;width:100%;margin:0 auto;
  padding:3rem 1.8rem 5rem;
}

/* ── HEADER STAMP ── */
.update-badge{
  display:inline-block;font-family:'Oswald',sans-serif;font-size:.65rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;background:var(--rust);color:var(--cream);
  border:2px solid var(--ink);border-radius:2px;padding:.2rem .7rem;box-shadow:2px 2px 0 var(--ink);
  margin-bottom:1.5rem;
}
.section-stamp{display:flex;align-items:center;gap:1rem;margin-bottom:1.4rem}
.stamp-num{
  font-family:'Oswald',sans-serif;font-size:1.7rem;font-weight:700;
  color:var(--cream);background:var(--rust);
  border:3px solid var(--ink);border-radius:3px;
  width:2.7rem;height:2.7rem;display:flex;align-items:center;justify-content:center;
  box-shadow:3px 3px 0 var(--ink);flex-shrink:0;
}
.stamp-title{
  font-family:'Oswald',sans-serif;font-size:1.9rem;font-weight:700;
  letter-spacing:.02em;color:var(--ink);line-height:1.05;
}
.stamp-sub{
  font-family:'Oswald',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:rgba(26,20,8,.5);
  margin-top:.2rem;
}

/* ── PROSE ── */
.prose p{font-size:1rem;line-height:1.8;color:rgba(26,20,8,.88);margin-bottom:1rem}
.prose p:last-child{margin-bottom:0}
.prose a{color:var(--rust);font-weight:600}
.prose a:hover{text-decoration:underline}
.prose strong{font-weight:600}
.prose em{font-style:italic}
.prose ul{padding-left:1.5rem;margin:.6rem 0 1.1rem}
.prose ul li{font-size:1rem;line-height:1.7;margin-bottom:.35rem;color:rgba(26,20,8,.88)}

.prose h3{
  font-family:'Oswald',sans-serif;font-size:1rem;font-weight:700;
  letter-spacing:.05em;color:var(--ink);
  margin:1.7rem 0 .6rem;padding-left:.7rem;
  border-left:4px solid var(--amber);
}

/* ── INFO / WARN BOXES ── */
.info-box{
  background:var(--cream);border:2.5px solid var(--ink);border-radius:3px;
  box-shadow:3px 3px 0 var(--ink);
  padding:1rem 1.2rem;margin:1.2rem 0;
}
.info-box p{margin-bottom:.6rem}
.info-box p:last-child{margin-bottom:0}
.info-box strong{font-family:'Oswald',sans-serif;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase}

.warn-box{
  background:#fff8f6;border:2.5px solid var(--rust);border-radius:3px;
  padding:1rem 1.2rem;margin:1.2rem 0;
}
.warn-box p{color:var(--rust)}

/* ── COOKIE TABLE ── */
.cookie-table{
  width:100%;border-collapse:collapse;margin:1rem 0 1.5rem;
  font-size:.88rem;
}
.cookie-table th{
  font-family:'Oswald',sans-serif;font-size:.75rem;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;
  background:var(--ink);color:var(--amber3);
  padding:.6rem .9rem;text-align:left;
}
.cookie-table td{
  padding:.6rem .9rem;border-bottom:1.5px solid rgba(26,20,8,.15);
  vertical-align:top;line-height:1.6;
}
.cookie-table tr:nth-child(even) td{background:var(--cream)}
.cookie-table tr:last-child td{border-bottom:none}

.cat-label{
  font-family:'Oswald',sans-serif;font-size:.6rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  border:1.5px solid var(--ink);border-radius:2px;
  padding:.15rem .45rem;white-space:nowrap;display:inline-block;
}
.cat-label.necessary{background:var(--ink);color:var(--amber3)}
.cat-label.marketing{background:var(--rust);color:var(--cream)}
.cat-label.analytics{background:var(--sage);color:var(--cream)}

/* ── RIGHTS GRID ── */
.rights-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin:1rem 0;
}
.right-card{
  background:var(--cream);border:2px solid var(--ink);border-radius:3px;
  padding:.75rem 1rem;box-shadow:2px 2px 0 var(--ink);
}
.right-card .r-icon{font-size:1.1rem;margin-bottom:.3rem}
.right-card .r-title{
  font-family:'Oswald',sans-serif;font-size:.82rem;font-weight:700;
  letter-spacing:.05em;margin-bottom:.25rem;
}
.right-card .r-desc{font-size:.85rem;line-height:1.55;color:rgba(26,20,8,.75)}

/* ── CONTACT CARDS ── */
.cards-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.info-card{
  background:var(--cream);border:2.5px solid var(--ink);border-radius:3px;
  box-shadow:3px 3px 0 var(--ink);padding:1.4rem 1.5rem;
}
.info-card.full{grid-column:1/-1}
.info-card h3{
  font-family:'Oswald',sans-serif;font-size:.85rem;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;color:var(--ink);
  margin-bottom:.9rem;padding-bottom:.5rem;
  border-bottom:2px dashed rgba(26,20,8,.2);
  border-left:none;padding-left:0;
}
.info-item{display:flex;gap:.75rem;align-items:flex-start;margin-bottom:.85rem}
.info-item:last-child{margin-bottom:0}
.info-icon{font-size:1.1rem;flex-shrink:0;margin-top:.1rem}
.info-text{font-size:.9rem;line-height:1.65;color:rgba(26,20,8,.82)}
.info-text strong{display:block;font-family:'Oswald',sans-serif;font-size:.75rem;font-weight:700;letter-spacing:.05em;color:var(--ink);margin-bottom:.15rem}
.info-text a{color:var(--rust);font-weight:600;word-break:break-all;text-decoration:none}
.info-text a:hover{text-decoration:underline}

.notice-box{
  background:var(--cream);border:2.5px solid var(--amber);border-radius:3px;
  box-shadow:4px 4px 0 var(--ink);padding:1.2rem 1.5rem;
  margin-bottom:2.2rem;font-size:.95rem;line-height:1.75;
  color:rgba(26,20,8,.82);
}
.notice-box strong{font-family:'Oswald',sans-serif;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;display:block;margin-bottom:.4rem;color:var(--ink)}

.resp-badge{
  font-family:'Oswald',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;background:var(--sage);color:var(--cream);
  border:2px solid var(--ink);border-radius:2px;padding:.2rem .6rem;
  box-shadow:2px 2px 0 var(--ink);display:inline-block;margin-top:.35rem;
}

/* ── INTER-PAGE NAVIGATION (legal pages cross-link bar) ── */
.legal-nav{
  display:flex;flex-wrap:wrap;gap:.6rem;
  margin:2rem 0 1rem;padding:.9rem 1rem;
  background:var(--paper2);border:2px solid var(--ink);
}
.legal-nav a{
  font-family:'Oswald',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink);text-decoration:none;
  padding:.2rem .55rem;border-radius:2px;
  transition:background .15s;
}
.legal-nav a:hover{background:var(--cream)}
.legal-nav a.current{background:var(--rust);color:var(--cream)}

/* ── FOOTER ── */
footer{
  position:relative;z-index:1;
  background:var(--ink);color:rgba(253,248,236,.55);
  border-top:3px solid var(--ink);
  padding:1.4rem 2.2rem;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  font-family:'Oswald',sans-serif;font-size:.75rem;letter-spacing:.06em;
}
footer .footer-nav{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;flex:1}
footer a{color:rgba(253,248,236,.5);text-decoration:none;text-transform:uppercase;transition:color .15s}
footer a:hover{color:rgba(253,248,236,.9)}
footer .footer-brand{color:rgba(253,248,236,.7)}

/* ── RESPONSIVE ── */
@media(max-width:720px){
  main.page{padding:2rem 1.2rem 4rem}
  .rights-grid{grid-template-columns:1fr}
  .cards-grid{grid-template-columns:1fr}
  .stamp-title{font-size:1.6rem}
  nav.site-nav{padding:.8rem 1.3rem}
}
