/* ──────────────────────────────────────────────────────────────────────────
   ONIX Boats — Generic model page CSS overlay
   Loads after onix-850.css. Adds:
   - Green color dot for 800 Aero Cabin
   - Black color dot variant (for 12X / 680)
   - Footer legal block
   - Catalog page styles
   - Homepage / About / Contacts page styles
   ────────────────────────────────────────────────────────────────────────── */

/* Color dots — extra colors */
.color-dot--green  { background: linear-gradient(160deg, #2d4a2d 0%, #3a5d3a 50%, #1f3520 100%); }
.color-dot--black  { background: linear-gradient(160deg, #1a1a1a 0%, #2d2d2d 50%, #0a0a0a 100%); }

/* Footer legal — small line under main footer */
.footer__legal {
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 1.75rem clamp(1.5rem, 5vw, 4.5rem);
  font-size: .8125rem;
  color: rgba(255,255,255,.45);
  text-align: center;
}
.footer__legal p { margin: 0; }

/* ────────────────────────────────────────────────────────
   HOMEPAGE — catalog grid of models
   ──────────────────────────────────────────────────────── */
.home-hero {
  position: relative;
  height: 100vh;
  min-height: 720px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.home-hero__bg {
  position: absolute; inset: 0;
}
.home-hero__bg img {
  width: 100%; height: 100%; object-fit: cover;
}
.home-hero__bg::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(11,11,11,0.3) 0%, rgba(11,11,11,0.55) 70%, rgba(11,11,11,0.85) 100%);
}
.home-hero__content {
  position: relative;
  z-index: 1;
  text-align: center;
  padding: 0 clamp(1.5rem, 5vw, 4rem);
  max-width: 56rem;
}
.home-hero__eyebrow {
  font-size: .75rem;
  font-weight: 500;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--sw-gold, #b8935a);
  margin: 0 0 1.5rem;
}
.home-hero__title {
  font-size: clamp(3rem, 9vw, 7rem);
  font-weight: 800;
  letter-spacing: -.04em;
  line-height: .95;
  color: #fff;
  margin: 0 0 1.5rem;
  text-transform: uppercase;
}
.home-hero__sub {
  font-size: clamp(1.0625rem, 1.6vw, 1.25rem);
  font-weight: 300;
  line-height: 1.55;
  color: rgba(255,255,255,.85);
  max-width: 40rem;
  margin: 0 auto 2.75rem;
}
.home-hero__actions {
  display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap;
}

/* Catalog section */
.catalog {
  background: var(--sw-bg, #fafaf8);
  padding: clamp(5rem, 10vw, 9rem) clamp(1.5rem, 5vw, 4.5rem);
}
.catalog__header {
  max-width: 88rem; margin: 0 auto clamp(3rem, 6vw, 5rem);
}
.catalog__grid {
  max-width: 88rem; margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 22rem), 1fr));
  gap: 1.75rem;
}
.catalog-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,.06);
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  position: relative;
  overflow: hidden;
  transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.catalog-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 40px -16px rgba(0,0,0,.18);
  border-color: rgba(0,0,0,.14);
}
.catalog-card__image {
  aspect-ratio: 16/10;
  overflow: hidden;
  background: #f0eee9;
  position: relative;
}
.catalog-card__image img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .8s ease;
}
.catalog-card:hover .catalog-card__image img {
  transform: scale(1.05);
}
.catalog-card__body {
  padding: 1.5rem 1.75rem 1.75rem;
  display: flex; flex-direction: column;
  flex: 1;
}
.catalog-card__category {
  font-size: .6875rem;
  font-weight: 500;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--sw-gold, #b8935a);
  margin: 0 0 .5rem;
}
.catalog-card__title {
  font-size: 1.625rem;
  font-weight: 700;
  letter-spacing: -.02em;
  line-height: 1.05;
  margin: 0 0 .25rem;
  color: #0b0b0b;
}
.catalog-card__subtitle {
  font-size: 1rem;
  font-weight: 400;
  color: #555;
  margin: 0 0 1rem;
}
.catalog-card__specs {
  display: flex;
  gap: 1.25rem;
  font-size: .8125rem;
  color: #777;
  border-top: 1px solid rgba(0,0,0,.06);
  padding-top: 1rem;
  margin: auto 0 1rem;
}
.catalog-card__spec {
  display: flex; flex-direction: column; gap: 2px;
}
.catalog-card__spec-value {
  font-size: 1rem;
  font-weight: 600;
  color: #0b0b0b;
  letter-spacing: -.01em;
}
.catalog-card__spec-label {
  font-size: .6875rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.catalog-card__price {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-top: 1rem;
  border-top: 1px solid rgba(0,0,0,.06);
}
.catalog-card__price-value {
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: -.01em;
  color: #0b0b0b;
}
.catalog-card__cta {
  font-size: .8125rem;
  font-weight: 500;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--sw-gold, #b8935a);
  display: inline-flex; align-items: center; gap: .35rem;
}
.catalog-card__cta::after {
  content: '→';
  font-size: 1rem;
  transition: transform .3s ease;
}
.catalog-card:hover .catalog-card__cta::after {
  transform: translateX(4px);
}

/* Featured large card (first model) */
.catalog-card--featured {
  grid-column: 1 / -1;
}
.catalog-card--featured .catalog-card__image {
  aspect-ratio: 16/7;
}
.catalog-card--featured .catalog-card__title {
  font-size: clamp(2rem, 4vw, 3rem);
}

@media (min-width: 1100px) {
  .catalog__grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .catalog-card--featured {
    grid-column: 1 / -1;
  }
}

/* ────────────────────────────────────────────────────────
   ABOUT page
   ──────────────────────────────────────────────────────── */
.about-hero {
  position: relative;
  min-height: 80vh;
  padding: clamp(8rem, 18vh, 14rem) clamp(1.5rem, 5vw, 4.5rem) clamp(5rem, 10vh, 8rem);
  background: #0b0b0b;
  color: #fff;
  display: flex;
  align-items: center;
}
.about-hero__inner {
  max-width: 88rem; margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 4rem;
  width: 100%;
}
@media (min-width: 900px) {
  .about-hero__inner {
    grid-template-columns: 1fr 1.2fr;
    align-items: end;
  }
}
.about-hero__eyebrow {
  font-size: .75rem;
  font-weight: 500;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--sw-gold, #b8935a);
  margin: 0 0 1.25rem;
}
.about-hero__title {
  font-size: clamp(2.5rem, 7vw, 5.5rem);
  font-weight: 800;
  letter-spacing: -.035em;
  line-height: 1;
  margin: 0;
}
.about-hero__lead {
  font-size: clamp(1.0625rem, 1.6vw, 1.25rem);
  line-height: 1.65;
  font-weight: 300;
  color: rgba(255,255,255,.82);
  max-width: 36rem;
  margin: 0;
}

.about-philosophy,
.about-process,
.about-numbers {
  padding: clamp(5rem, 10vw, 9rem) clamp(1.5rem, 5vw, 4.5rem);
}
.about-philosophy { background: var(--sw-bg, #fafaf8); }
.about-process { background: #fff; }
.about-numbers {
  background: #0b0b0b;
  color: #fff;
}
.about-section__inner {
  max-width: 88rem; margin: 0 auto;
}
.about-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  margin-top: 3rem;
}
@media (min-width: 900px) {
  .about-grid { grid-template-columns: repeat(3, 1fr); }
}
.about-card {
  border-top: 2px solid var(--sw-gold, #b8935a);
  padding-top: 1.5rem;
}
.about-card__num {
  font-size: 3rem;
  font-weight: 800;
  letter-spacing: -.04em;
  color: #0b0b0b;
  margin: 0 0 1rem;
  line-height: 1;
}
.about-numbers .about-card__num { color: #fff; }
.about-card__title {
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: -.01em;
  margin: 0 0 .75rem;
}
.about-card__text {
  font-size: .9375rem;
  line-height: 1.65;
  color: #555;
}
.about-numbers .about-card__text { color: rgba(255,255,255,.7); }

/* Process timeline */
.about-process__steps {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  margin-top: 3rem;
}
@media (min-width: 900px) {
  .about-process__steps { grid-template-columns: repeat(4, 1fr); }
}
.about-step {
  position: relative;
}
.about-step__num {
  font-size: .75rem;
  font-weight: 500;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--sw-gold, #b8935a);
  display: block;
  margin: 0 0 1rem;
}
.about-step__title {
  font-size: 1.125rem;
  font-weight: 700;
  margin: 0 0 .75rem;
  letter-spacing: -.01em;
}
.about-step__text {
  font-size: .875rem;
  line-height: 1.6;
  color: #555;
}

/* Numbers grid */
.about-numbers__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3rem 2rem;
  margin-top: 3rem;
}
@media (min-width: 900px) {
  .about-numbers__grid { grid-template-columns: repeat(4, 1fr); }
}
.about-number {
  text-align: left;
}
.about-number__value {
  font-size: clamp(3rem, 6vw, 4.5rem);
  font-weight: 800;
  letter-spacing: -.04em;
  line-height: 1;
  color: #fff;
  display: block;
  margin: 0 0 .5rem;
}
.about-number__label {
  font-size: .8125rem;
  font-weight: 500;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: rgba(255,255,255,.6);
}

/* About full-bleed image strip */
.about-strip {
  height: 60vh;
  min-height: 480px;
  position: relative;
  overflow: hidden;
}
.about-strip img {
  width: 100%; height: 100%; object-fit: cover;
}

/* ────────────────────────────────────────────────────────
   CONTACTS page
   ──────────────────────────────────────────────────────── */
.contacts-hero {
  background: #0b0b0b;
  color: #fff;
  padding: clamp(8rem, 18vh, 12rem) clamp(1.5rem, 5vw, 4.5rem) clamp(4rem, 8vh, 6rem);
}
.contacts-hero__inner {
  max-width: 88rem; margin: 0 auto;
}
.contacts-hero__eyebrow {
  font-size: .75rem;
  font-weight: 500;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--sw-gold, #b8935a);
  margin: 0 0 1.25rem;
}
.contacts-hero__title {
  font-size: clamp(2.5rem, 7vw, 5rem);
  font-weight: 800;
  letter-spacing: -.035em;
  line-height: 1;
  margin: 0 0 1.5rem;
}
.contacts-hero__sub {
  font-size: 1.125rem;
  line-height: 1.6;
  font-weight: 300;
  color: rgba(255,255,255,.75);
  max-width: 32rem;
  margin: 0;
}

.contacts-body {
  padding: clamp(5rem, 10vw, 8rem) clamp(1.5rem, 5vw, 4.5rem);
  background: #fff;
}
.contacts-body__inner {
  max-width: 88rem; margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 4rem;
}
@media (min-width: 900px) {
  .contacts-body__inner { grid-template-columns: 1fr 1.2fr; }
}

.contacts-list {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}
.contacts-block {
  border-top: 1px solid rgba(0,0,0,.1);
  padding-top: 1.5rem;
}
.contacts-block__label {
  font-size: .6875rem;
  font-weight: 500;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--sw-gold, #b8935a);
  margin: 0 0 .75rem;
}
.contacts-block__value {
  font-size: 1.5rem;
  font-weight: 600;
  letter-spacing: -.015em;
  line-height: 1.3;
  color: #0b0b0b;
  margin: 0;
}
.contacts-block__value a {
  color: inherit; text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color .25s ease;
}
.contacts-block__value a:hover {
  border-bottom-color: var(--sw-gold, #b8935a);
}
.contacts-block__hint {
  font-size: .875rem;
  color: #777;
  line-height: 1.55;
  margin: .5rem 0 0;
}

.contacts-channels {
  display: flex;
  gap: .75rem;
  flex-wrap: wrap;
  margin-top: 1rem;
}
.contacts-channel {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .65rem 1.1rem;
  background: #0b0b0b;
  color: #fff;
  text-decoration: none;
  font-size: .8125rem;
  font-weight: 500;
  letter-spacing: .08em;
  text-transform: uppercase;
  border-radius: 999px;
  transition: background .25s ease, transform .25s ease;
}
.contacts-channel:hover {
  background: var(--sw-gold, #b8935a);
  transform: translateY(-2px);
}

.contacts-map {
  min-height: 540px;
  background: #f3f1ec;
  position: relative;
}
.contacts-map iframe {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border: 0;
}

/* Contacts dealer section */
.contacts-dealer {
  background: var(--sw-bg, #fafaf8);
  padding: clamp(5rem, 10vw, 8rem) clamp(1.5rem, 5vw, 4.5rem);
}
.contacts-dealer__grid {
  max-width: 88rem; margin: 3rem auto 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.75rem;
}
@media (min-width: 900px) {
  .contacts-dealer__grid { grid-template-columns: repeat(3, 1fr); }
}
.dealer-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  padding: 2rem 2rem 2.25rem;
}
.dealer-card__city {
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: -.02em;
  margin: 0 0 .5rem;
}
.dealer-card__name {
  font-size: .9375rem;
  color: #555;
  margin: 0 0 1.25rem;
}
.dealer-card__contacts {
  display: flex; flex-direction: column; gap: .5rem;
  font-size: .9375rem;
  color: #0b0b0b;
}
.dealer-card__contacts a {
  color: inherit;
  text-decoration: none;
}
.dealer-card__contacts a:hover {
  color: var(--sw-gold, #b8935a);
}

/* shared section helpers */
.section-headline--white { color: #fff; }
.section-label--gold { color: var(--sw-gold, #b8935a); }

/* ────────────────────────────────────────────────────────
   NAV — unified frosted-dark backdrop on all pages
   Default state on every page is subtle dark glass so menu
   is readable above light hero pages too. The 'is-scrolled'
   class kicks in extra clarity.
   ──────────────────────────────────────────────────────── */
.nav {
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.22);
  transition: background .35s ease, height .35s ease, border-color .35s ease, backdrop-filter .35s ease;
}
/* Light text by default (sits over dark hero on every page that has hero) */
.nav .nav__menu a,
.nav .nav__logo .logo-svg__main { fill: #fff; }
.nav .nav__menu a { color: rgba(255, 255, 255, 0.92); }
.nav .nav__menu a:hover { color: var(--sw-gold, #b8935a); }
.nav .nav__cta {
  background: var(--sw-gold, #b8935a);
  color: #0b0b0b;
}
.nav .nav__cta:hover { background: #d6ad6c; color: #0b0b0b; }
.nav__burger { color: #fff; }

/* When scrolled (>40px) — switch to bright frosted glass for legibility */
.nav.is-scrolled {
  background: rgba(245, 244, 240, 0.82);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  border-bottom: 1px solid rgba(226, 224, 218, 0.6);
}
.nav.is-scrolled .nav__menu a,
.nav.is-scrolled .nav__logo .logo-svg__main { color: #0b0b0b; fill: #0b0b0b; }
.nav.is-scrolled .nav__burger { color: #0b0b0b; }
.nav.is-scrolled .nav__menu a:hover { color: var(--sw-gold, #b8935a); }

/* Pages with light backgrounds (privacy, etc.) — force scrolled-style nav so
   menu remains readable when there is no dark hero behind it */
body.page-light .nav,
body.page-light .nav.is-scrolled {
  background: rgba(245, 244, 240, 0.92);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  border-bottom: 1px solid rgba(226, 224, 218, 0.6);
}
body.page-light .nav .nav__menu a,
body.page-light .nav .nav__logo .logo-svg__main { color: #0b0b0b; fill: #0b0b0b; }
body.page-light .nav .nav__burger { color: #0b0b0b; }

/* ────────────────────────────────────────────────────────
   COLOR BUTTONS — fix iOS double-tap issue
   On touch devices, :hover sticks on first tap (requires 2nd tap to click).
   We disable hover styles when device has no real hover support.
   ──────────────────────────────────────────────────────── */
@media (hover: none), (pointer: coarse) {
  .color-btn:hover,
  .color-btn:focus { transform: none !important; }
  .color-btn:hover .color-dot::after,
  .color-btn:focus .color-dot::after {
    opacity: 0 !important;
    transform: translateX(-100%) skewX(-12deg) !important;
  }
  .color-btn { -webkit-tap-highlight-color: transparent; }
}

/* ────────────────────────────────────────────────────────
   CONFIGURATOR — bigger image on mobile
   Default 21:9 aspect on desktop is too thin/short on phones.
   Switch to 4:3 on mobile so the boat fills the viewport better.
   ──────────────────────────────────────────────────────── */
@media (max-width: 720px) {
  .configurator__stage {
    aspect-ratio: 4 / 3 !important;
    max-height: none !important;
  }
  .configurator__img {
    padding: clamp(0.5rem, 2vw, 1rem) !important;
  }
}
@media (max-width: 480px) {
  .configurator__stage {
    aspect-ratio: 5 / 4 !important;
  }
}

/* ────────────────────────────────────────────────────────
   INTERIOR PANELS — override for 4-panel layout
   (replaces 850-swiss 5-panel widths: 24% × 4 ≈ 100%)
   ──────────────────────────────────────────────────────── */
.interior-panel { width: 24%; }
.interior__panels:hover .interior-panel { width: 17%; }
.interior-panel:hover { width: 49% !important; }

@media (max-width: 1024px) {
  .interior-panel { width: 24%; }
  .interior__panels:hover .interior-panel { width: 17%; }
  .interior-panel:hover { width: 49% !important; }
}

/* ────────────────────────────────────────────────────────
   COOKIE CONSENT
   ──────────────────────────────────────────────────────── */
.cookie-consent {
  position: fixed;
  bottom: 1.25rem;
  left: 1.25rem;
  right: 1.25rem;
  max-width: 56rem;
  margin: 0 auto;
  background: #0b0b0b;
  color: #fff;
  border: 1px solid rgba(255,255,255,.1);
  padding: 1.25rem 1.5rem;
  z-index: 9999;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .35s ease, transform .35s ease;
  pointer-events: none;
  box-shadow: 0 20px 60px -10px rgba(0,0,0,.5);
}
.cookie-consent.is-visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.cookie-consent__inner {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: flex-start;
}
@media (min-width: 700px) {
  .cookie-consent__inner {
    flex-direction: row;
    align-items: center;
  }
}
.cookie-consent__text {
  flex: 1;
}
.cookie-consent__text strong {
  display: block;
  font-size: .9375rem;
  font-weight: 600;
  letter-spacing: -.005em;
  margin-bottom: .35rem;
}
.cookie-consent__text p {
  margin: 0;
  font-size: .8125rem;
  line-height: 1.55;
  color: rgba(255,255,255,.78);
}
.cookie-consent__text a {
  color: var(--sw-gold, #b8935a);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.cookie-consent__actions {
  flex-shrink: 0;
}
.cookie-consent__btn {
  appearance: none;
  background: var(--sw-gold, #b8935a);
  color: #0b0b0b;
  border: 0;
  padding: .85rem 1.75rem;
  font-family: inherit;
  font-size: .8125rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .25s ease, transform .25s ease;
}
.cookie-consent__btn:hover {
  background: #d6ad6c;
  transform: translateY(-1px);
}

/* ────────────────────────────────────────────────────────
   FOOTER additions: nav links
   ──────────────────────────────────────────────────────── */
.footer__links {
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem;
  margin: 1.25rem 0;
  font-size: .8125rem;
}
.footer__links a {
  color: rgba(255,255,255,.7);
  text-decoration: none;
  letter-spacing: .03em;
  transition: color .2s ease;
}
.footer__links a:hover {
  color: var(--sw-gold, #b8935a);
}
.footer__legal a {
  color: rgba(255,255,255,.7);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.footer__legal a:hover { color: var(--sw-gold, #b8935a); }

/* ────────────────────────────────────────────────────────
   MOBILE NAV — hamburger + slide-down menu
   ──────────────────────────────────────────────────────── */
.nav__burger {
  display: none;
  position: absolute;
  top: 50%;
  right: 1.25rem;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  background: transparent;
  border: 0;
  cursor: pointer;
  z-index: 10;
  padding: 0;
}
.nav__burger span {
  display: block;
  position: absolute;
  left: 6px;
  right: 6px;
  height: 1.5px;
  background: currentColor;
  transition: transform .35s ease, opacity .25s ease, top .35s ease;
}
.nav__burger span:nth-child(1) { top: 11px; }
.nav__burger span:nth-child(2) { top: 50%; transform: translateY(-50%); }
.nav__burger span:nth-child(3) { top: 23px; }
.nav.is-menu-open .nav__burger span:nth-child(1) { top: 50%; transform: translateY(-50%) rotate(45deg); }
.nav.is-menu-open .nav__burger span:nth-child(2) { opacity: 0; }
.nav.is-menu-open .nav__burger span:nth-child(3) { top: 50%; transform: translateY(-50%) rotate(-45deg); }

@media (max-width: 900px) {
  .nav__burger { display: block; }
  .nav__menu {
    display: none;
    position: absolute;
    left: 0; right: 0;
    top: 100%;
    background: #0b0b0b;
    flex-direction: column;
    padding: 1rem 1.5rem;
    gap: .5rem;
    border-top: 1px solid rgba(255,255,255,.08);
  }
  .nav__menu li { padding: .65rem 0; border-bottom: 1px solid rgba(255,255,255,.05); }
  .nav__menu li:last-child { border-bottom: 0; }
  .nav.is-menu-open .nav__menu { display: flex; }
  .nav__phone { display: block; }
}

/* ────────────────────────────────────────────────────────
   PRIVACY page
   ──────────────────────────────────────────────────────── */
.privacy {
  background: var(--sw-bg, #fafaf8);
  padding: clamp(8rem, 18vh, 12rem) clamp(1.5rem, 5vw, 4rem) clamp(5rem, 10vh, 8rem);
}
.privacy__inner {
  max-width: 56rem;
  margin: 0 auto;
}
.privacy__eyebrow {
  font-size: .75rem;
  font-weight: 500;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--sw-gold, #b8935a);
  margin: 0 0 1rem;
}
.privacy__title {
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 800;
  letter-spacing: -.03em;
  line-height: 1.05;
  margin: 0 0 2rem;
  color: #0b0b0b;
}
.privacy__updated {
  font-size: .8125rem;
  color: #777;
  margin: 0 0 3rem;
  letter-spacing: .03em;
}
.privacy__content {
  font-size: .9375rem;
  line-height: 1.7;
  color: #2a2a2a;
}
.privacy__content h2 {
  font-size: 1.375rem;
  font-weight: 700;
  letter-spacing: -.015em;
  margin: 2.5rem 0 1rem;
  color: #0b0b0b;
}
.privacy__content h3 {
  font-size: 1.0625rem;
  font-weight: 600;
  margin: 1.75rem 0 .75rem;
  color: #0b0b0b;
}
.privacy__content p { margin: 0 0 1rem; }
.privacy__content ul, .privacy__content ol {
  margin: 0 0 1rem;
  padding-left: 1.5rem;
}
.privacy__content li { margin-bottom: .35rem; }
.privacy__content a {
  color: var(--sw-gold, #b8935a);
  text-decoration: underline;
  text-underline-offset: 2px;
}
