/**
 * Privacy Policy + Collection Page CSS
 * @package Modeka
 */

/* ═══════════════════════════════════════════════════════════════
   PRIVACY POLICY
   ═══════════════════════════════════════════════════════════════ */

.privacy-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: start;
}

@media (min-width: 1024px) {
  .privacy-layout {
    grid-template-columns: 260px 1fr;
    gap: 4rem;
  }
}

/* ─── Sidebar TOC ─────────────────────────────────────────────── */
.privacy-toc {
  order: -1;
}

@media (min-width: 1024px) {
  .privacy-toc {
    position: sticky;
    top: calc(120px + 2rem);
    order: 0;
  }
}

.privacy-toc__inner {
  background: var(--color-off-white);
  border-radius: var(--radius-xl);
  padding: 1.5rem;
}

.privacy-toc__heading {
  font-family: var(--font-display);
  font-size: var(--fs-xs);
  font-weight: 800;
  letter-spacing: var(--ls-mega, .12em);
  text-transform: uppercase;
  color: var(--color-black);
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: .5rem;
}

.privacy-toc__list {
  display: flex;
  flex-direction: column;
  gap: .125rem;
  counter-reset: toc;
}

.privacy-toc__item {
  counter-increment: toc;
}

.privacy-toc__link {
  display: flex;
  align-items: flex-start;
  gap: .625rem;
  padding: .5rem .625rem;
  border-radius: var(--radius-md);
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  color: var(--color-gray-dark);
  text-decoration: none;
  transition: background var(--dur-fast) ease, color var(--dur-fast) ease;
  line-height: 1.4;
}

.privacy-toc__link:hover,
.privacy-toc__link.is-active {
  background: var(--color-gray-ultra);
  color: var(--color-black);
}

.privacy-toc__link.is-active { font-weight: var(--fw-semi); }

.privacy-toc__num {
  font-family: var(--font-display);
  font-size: 10px;
  font-weight: 800;
  color: var(--color-gray);
  flex-shrink: 0;
  width: 20px;
  text-align: right;
  padding-top: .1rem;
  transition: color var(--dur-fast) ease;
}

.privacy-toc__link.is-active .privacy-toc__num { color: var(--color-black); }

.privacy-toc__meta {
  margin-top: 1.25rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--color-gray-ultra);
  font-size: var(--fs-xs);
  color: var(--color-gray);
  display: flex;
  align-items: flex-start;
  gap: .5rem;
  line-height: 1.6;
}

.privacy-toc__meta i { margin-top: .15rem; flex-shrink: 0; }

.privacy-toc__print {
  margin-top: 1rem;
}

/* ─── Intro callout ───────────────────────────────────────────── */
.privacy-intro {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  background: var(--color-off-white);
  border-left: 3px solid var(--color-black);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
  padding: 1.25rem 1.5rem;
  margin-bottom: 3rem;
  font-size: var(--fs-sm);
  color: var(--color-gray-dark);
  line-height: var(--lh-loose);
}

.privacy-intro__icon {
  font-size: 1.125rem;
  color: var(--color-black);
  flex-shrink: 0;
  margin-top: .1rem;
}

/* ─── Sections ────────────────────────────────────────────────── */
.privacy-section {
  margin-bottom: 3.5rem;
  padding-bottom: 3.5rem;
  border-bottom: 1px solid var(--color-gray-ultra);
}

.privacy-section:last-of-type {
  border-bottom: none;
  margin-bottom: 2rem;
}

.privacy-section__header {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.privacy-section__num {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2vw, 1.875rem);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--color-gray-ultra);
  flex-shrink: 0;
  min-width: 3rem;
  text-align: right;
}

.privacy-section__icon {
  width: 44px;
  height: 44px;
  background: var(--color-off-white);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-black);
  flex-shrink: 0;
}

.privacy-section__title {
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 2.5vw, 1.5rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--color-black);
  line-height: 1.15;
}

.privacy-section__body {
  padding-left: calc(3rem + 44px + 1rem + 1rem);
  font-size: var(--fs-sm);
  color: var(--color-gray-dark);
  line-height: var(--lh-loose);
}

@media (max-width: 639px) {
  .privacy-section__body { padding-left: 0; }
  .privacy-section__num { display: none; }
}

.privacy-section__body ul,
.privacy-section__body ol { padding-left: 1.25rem; margin-top: .75rem; }
.privacy-section__body li + li { margin-top: .5rem; }
.privacy-section__body p + p { margin-top: .875rem; }
.privacy-section__body a { color: var(--color-black); text-decoration: underline; text-underline-offset: 3px; }
.privacy-section__body strong { font-weight: var(--fw-semi); color: var(--color-black); }

/* Contact box */
.privacy-contact-box {
  background: var(--color-black);
  color: var(--color-white);
  border-radius: var(--radius-xl);
  padding: 2rem;
  display: flex;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap;
  margin-top: 3rem;
}

.privacy-contact-box__icon {
  font-size: 2rem;
  opacity: .5;
  flex-shrink: 0;
}

.privacy-contact-box__title {
  font-family: var(--font-display);
  font-size: var(--fs-base);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  margin-bottom: .25rem;
}

.privacy-contact-box__desc {
  font-size: var(--fs-xs);
  opacity: .65;
}

.privacy-contact-box .btn { margin-left: auto; white-space: nowrap; }

@media (max-width: 639px) {
  .privacy-contact-box { flex-direction: column; text-align: center; }
  .privacy-contact-box .btn { margin-left: 0; width: 100%; justify-content: center; }
  .privacy-contact-box__icon { display: none; }
}

/* Print */
@media print {
  .site-header, .topbar, .footer, .breadcrumb,
  .privacy-toc__print, .privacy-contact-box, .back-to-top { display: none !important; }
  .privacy-layout { grid-template-columns: 1fr; }
  .privacy-toc { display: none; }
  .privacy-section__body { padding-left: 0; }
}

/* ═══════════════════════════════════════════════════════════════
   COLLECTION PAGE
   ═══════════════════════════════════════════════════════════════ */

/* ─── Hero ────────────────────────────────────────────────────── */
.col-hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background: var(--color-black);
}

.col-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.col-hero__bg img,
.col-hero__video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.col-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(0,0,0,.85) 0%,
    rgba(0,0,0,.35) 50%,
    rgba(0,0,0,.15) 100%
  );
  z-index: 1;
}

.col-hero__content {
  position: relative;
  z-index: 2;
  padding-bottom: clamp(4rem, 10vh, 7rem);
  padding-top: clamp(3rem, 8vh, 5rem);
}

.col-hero__eyebrow {
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semi);
  letter-spacing: .15em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
  margin-bottom: 1rem;
}

.col-hero__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 4rem);
  font-weight: 900;
  line-height: .9;
  letter-spacing: -0.04em;
  text-transform: uppercase;
  color: var(--color-white);
  margin-bottom: 1.5rem;
  max-width: 14ch;
}

.col-hero__desc {
  font-size: clamp(var(--fs-base), 2vw, var(--fs-md));
  font-weight: var(--fw-light);
  color: rgba(255,255,255,.7);
  max-width: 48ch;
  line-height: var(--lh-loose);
  margin-bottom: 2.5rem;
}

.col-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

/* Scroll indicator */
.col-hero__scroll {
  position: absolute;
  bottom: 2rem;
  right: var(--gutter);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  z-index: 2;
  color: rgba(255,255,255,.4);
  font-size: 9px;
  font-weight: var(--fw-semi);
  letter-spacing: .15em;
  text-transform: uppercase;
}

.col-hero__scroll-line {
  width: 1px;
  height: 50px;
  background: linear-gradient(to bottom, rgba(255,255,255,.4), transparent);
  animation: scrollPulse 2s ease-in-out infinite;
}

@keyframes scrollPulse {
  0%, 100% { transform: scaleY(1); opacity: .5; }
  50% { transform: scaleY(.6); opacity: .2; }
}

@media (max-width: 639px) { .col-hero__scroll { display: none; } }

/* ─── Highlights strip ────────────────────────────────────────── */
.col-highlights {
  background: var(--color-black);
  color: var(--color-white);
  border-top: 1px solid rgba(255,255,255,.08);
}

.col-highlights__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
}

@media (min-width: 768px) {
  .col-highlights__grid { grid-template-columns: repeat(4, 1fr); }
}

.col-highlight {
  display: flex;
  align-items: flex-start;
  gap: .875rem;
  padding: 1.75rem 1.5rem;
  border-right: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.col-highlight:last-child { border-right: none; }

@media (min-width: 768px) {
  .col-highlight { border-bottom: none; }
}

.col-highlight__icon {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.08);
  border-radius: var(--radius-md);
  font-size: .875rem;
  color: var(--color-white);
  flex-shrink: 0;
}

.col-highlight__title {
  font-family: var(--font-display);
  font-size: var(--fs-sm);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: -.01em;
  margin-bottom: .2rem;
}

.col-highlight__desc {
  font-size: var(--fs-xs);
  color: rgba(255,255,255,.5);
  letter-spacing: var(--ls-wide);
}

/* ─── Intro ───────────────────────────────────────────────────── */
.col-intro__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3.5rem;
  align-items: center;
}

@media (min-width: 900px) {
  .col-intro__layout { grid-template-columns: 1fr 1fr; gap: 5rem; }
}

.col-intro__image {
  border-radius: var(--radius-xl);
  overflow: hidden;
  aspect-ratio: 4/5;
  min-width: 0;
}

.col-intro__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.col-intro__body {
  font-size: var(--fs-md);
  font-weight: var(--fw-light);
  color: var(--color-gray-dark);
  line-height: var(--lh-loose);
  margin-top: 1.25rem;
}

/* ─── Editorial blocks ────────────────────────────────────────── */
.col-block {
  display: grid;
  grid-template-columns: 1fr;
  min-height: clamp(460px, 60vh, 700px);
}

@media (min-width: 900px) {
  .col-block { grid-template-columns: 1fr 1fr; }
  .col-block--img-left .col-block__image { order: -1; }
  .col-block--img-right .col-block__image { order: 1; }
}

.col-block__image {
  overflow: hidden;
  min-height: 300px;
}

@media (min-width: 900px) { .col-block__image { min-height: 0; } }

.col-block__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--dur-slower) var(--ease-out);
}

.col-block:hover .col-block__image img { transform: scale(1.03); }

.col-block__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(2.5rem, 6vw, 5rem);
  background: var(--color-off-white);
}

.col-block--dark .col-block__content {
  background: var(--color-black);
  color: var(--color-white);
}

.col-block__title {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2.5vw, 2rem);
  font-weight: 900;
  line-height: .95;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  margin-top: .75rem;
  margin-bottom: 1.25rem;
  color: inherit;
}

.col-block__body {
  font-size: var(--fs-md);
  font-weight: var(--fw-light);
  line-height: var(--lh-loose);
  color: var(--color-gray-dark);
}

.col-block--dark .col-block__body { color: rgba(255,255,255,.65); }

.section-label--light {
  color: rgba(255,255,255,.45);
}

/* ─── Products grid ───────────────────────────────────────────── */
.col-products__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem;
}

@media (min-width: 640px) {
  .col-products__grid { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 960px) {
  .col-products__grid { grid-template-columns: repeat(4, 1fr); }
}

/* ─── CTA ─────────────────────────────────────────────────────── */
.col-cta {
  position: relative;
  background: var(--color-black);
  color: var(--color-white);
  overflow: hidden;
  padding-block: clamp(5rem, 12vw, 8rem);
  text-align: center;
}

.col-cta__bg {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 60% 50%, rgba(255,255,255,.04) 0%, transparent 70%);
  pointer-events: none;
}

.col-cta__content { position: relative; z-index: 1; }

.col-cta__title {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3vw, 2.5rem);
  font-weight: 900;
  line-height: .95;
  letter-spacing: -0.04em;
  text-transform: uppercase;
  margin-bottom: 1.25rem;
}

.col-cta__desc {
  font-size: var(--fs-md);
  font-weight: var(--fw-light);
  color: rgba(255,255,255,.6);
  max-width: 48ch;
  margin-inline: auto;
  line-height: var(--lh-loose);
}

/* ─── Section label light variant ────────────────────────────── */
.col-block--dark .section-label { color: rgba(255,255,255,.4); }
