/* Legal page layout — Privacy, Terms, Cookies share this */

.legal-body { background: var(--c-bg); }

.nav--solid {
  position: static;
  background: var(--c-bg);
  border-bottom: 1px solid var(--c-rule);
  padding: 14px 0;
}
.nav--solid .nav__logo { height: 36px; }

.legal {
  position: relative;
  padding: clamp(var(--sp-9), 9vw, var(--sp-11)) 0 var(--sp-11);
  isolation: isolate;
  overflow: hidden;
}
/* Same subtle logo pattern used on the home page sections */
.legal::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 220 220'><g fill='none' stroke='%23c9a86b' stroke-width='1' opacity='0.06'><ellipse cx='60' cy='90' rx='30' ry='42'/><path d='M48 70 V110 M72 70 V110 M48 70 L60 92 L72 70'/><ellipse cx='170' cy='160' rx='30' ry='42'/><path d='M158 140 V180 M182 140 V180 M158 140 L170 162 L182 140'/></g></svg>");
  background-repeat: repeat;
  background-size: 220px 220px;
  -webkit-mask-image: radial-gradient(140% 80% at 50% 30%, #000 30%, transparent 80%);
          mask-image: radial-gradient(140% 80% at 50% 30%, #000 30%, transparent 80%);
  pointer-events: none;
}

.legal__article {
  max-width: 760px;
}
.legal__head {
  margin-bottom: var(--sp-8);
  padding-bottom: var(--sp-6);
  border-bottom: 1px solid var(--c-rule);
}
.legal__head .display {
  margin: 0 0 var(--sp-3);
  font-size: clamp(2rem, 5vw, 3.6rem);
}
.legal__meta {
  margin: 0;
  font-size: .85rem;
  color: var(--c-ink-3);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.legal section {
  margin-bottom: var(--sp-8);
}
.legal h2 {
  font-family: var(--f-display);
  font-weight: 400;
  font-size: clamp(1.4rem, 2.4vw, 1.9rem);
  margin: 0 0 var(--sp-4);
  letter-spacing: -0.01em;
  color: var(--c-ink);
}
.legal h3 {
  font-family: var(--f-display);
  font-weight: 500;
  font-size: 1.15rem;
  margin: 0 0 var(--sp-2);
  color: var(--c-ink);
}
.legal p,
.legal li {
  color: var(--c-ink-2);
  font-size: 1rem;
  line-height: 1.7;
}
.legal p { margin: 0 0 var(--sp-4); }
.legal ul {
  margin: 0 0 var(--sp-5);
  padding-left: var(--sp-5);
  list-style: none;
}
.legal ul li {
  position: relative;
  padding-left: var(--sp-4);
  margin-bottom: var(--sp-3);
}
.legal ul li::before {
  content: "";
  position: absolute;
  left: 0; top: .75em;
  width: 6px; height: 1px;
  background: var(--c-gold);
}
.legal strong { color: var(--c-ink); font-weight: 600; }

.legal__back {
  margin-top: var(--sp-8);
  padding-top: var(--sp-6);
  border-top: 1px solid var(--c-rule);
  font-size: .95rem;
}

.legal__callout {
  background: linear-gradient(180deg, rgba(20, 42, 26, .55) 0%, rgba(13, 31, 18, .35) 100%);
  border: 1px solid rgba(201, 168, 107, .25);
  border-radius: var(--r-lg);
  padding: var(--sp-6);
  margin: 0 0 var(--sp-8);
  position: relative;
}
.legal__callout-title {
  font-family: var(--f-display);
  font-size: .82rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--c-gold-3);
  margin: 0 0 var(--sp-3);
  font-weight: 500;
}
.legal__callout p {
  margin: 0;
  color: var(--c-ink-2);
  font-size: 1rem;
  line-height: 1.65;
}
.legal__disclaimer {
  margin-top: var(--sp-5);
  padding: var(--sp-4) var(--sp-5);
  background: rgba(244, 237, 224, .04);
  border-left: 2px solid var(--c-gold);
  border-radius: 4px;
  font-size: .88rem;
  color: var(--c-ink-3);
}
.legal code {
  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-size: .85em;
  background: rgba(244, 237, 224, .08);
  padding: 1px 6px;
  border-radius: 4px;
  color: var(--c-gold-3);
}

.inventory {
  overflow-x: auto;
  margin: 0 0 var(--sp-5);
  border: 1px solid var(--c-rule);
  border-radius: var(--r-lg);
}
.inventory__table {
  width: 100%;
  border-collapse: collapse;
  font-size: .9rem;
}
.inventory__table th,
.inventory__table td {
  padding: var(--sp-3) var(--sp-4);
  text-align: left;
  border-bottom: 1px solid var(--c-rule);
  vertical-align: top;
}
.inventory__table th {
  background: rgba(13, 31, 18, .55);
  color: var(--c-gold-3);
  font-weight: 500;
  font-size: .75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.inventory__table tr:last-child td { border-bottom: none; }
.inventory__table code {
  font-size: .8rem;
  white-space: nowrap;
}
@media (max-width: 720px) {
  .inventory__table { font-size: .82rem; }
  .inventory__table th,
  .inventory__table td { padding: var(--sp-2) var(--sp-3); }
}

.legal__footer { border-top: 1px solid var(--c-rule); }

/* Cookie preference UI */
.cookie {
  padding: var(--sp-5);
  margin-bottom: var(--sp-4);
  border: 1px solid var(--c-rule);
  border-radius: var(--r-lg);
  background: rgba(13, 31, 18, .4);
}
.cookie__head {
  display: flex;
  gap: var(--sp-5);
  align-items: center;
  justify-content: space-between;
}
.cookie__name { margin: 0 0 var(--sp-2); }
.cookie__desc { margin: 0; font-size: .92rem; }

.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  border-radius: var(--r-pill);
  font-size: .75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 500;
}
.badge--locked {
  background: rgba(125, 163, 122, .14);
  color: var(--c-leaf);
  border: 1px solid rgba(125, 163, 122, .3);
}

.switch {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  /* 44pt hit area, visual track stays sleek */
  width: 56px; min-width: 56px;
  height: 44px;
  cursor: pointer;
  touch-action: manipulation;
}
.switch input {
  position: absolute;
  opacity: 0;
  inset: 0;
  width: 100%; height: 100%;
  margin: 0;
  cursor: pointer;
}
.switch__track {
  display: block;
  width: 52px; height: 30px;
  background: rgba(244, 237, 224, .12);
  border: 1px solid var(--c-rule-strong);
  border-radius: var(--r-pill);
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease);
  position: relative;
}
.switch__thumb {
  position: absolute;
  top: 3px; left: 3px;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--c-ink-2);
  transition: transform var(--dur) var(--ease), background var(--dur) var(--ease);
}
.switch input:checked ~ .switch__track {
  background: linear-gradient(180deg, var(--c-gold-2) 0%, var(--c-gold) 100%);
  border-color: var(--c-gold);
}
.switch input:checked ~ .switch__track .switch__thumb {
  background: #0a1f0d;
  transform: translateX(22px);
}
.switch input:focus-visible ~ .switch__track {
  outline: 2px solid var(--c-gold);
  outline-offset: 3px;
}
.switch input:disabled { cursor: not-allowed; }
.switch input:disabled ~ .switch__track { opacity: .4; }

.cookie__actions {
  display: flex;
  gap: var(--sp-4);
  align-items: center;
  margin-top: var(--sp-6);
  flex-wrap: wrap;
}
.cookie__status {
  margin: 0;
  font-size: .85rem;
  color: var(--c-leaf);
}

@media (max-width: 600px) {
  .cookie__head { flex-direction: column; align-items: flex-start; gap: var(--sp-3); }
}
