/* ═══════════════════════════════════════
   SHARED CSS VARIABLES & RESET
═══════════════════════════════════════ */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  --cream:     #f5f0e8;
  --warm:      #ede8de;
  --sand:      #d9d2c2;
  --stone:     #b8af9e;
  --charcoal:  #2a2722;
  --muted:     #7a7368;
  --accent:    #c4773a;
  --accent2:   #e8a06a;
  --offwhite:  #faf8f4;
  --dark-bg:   #1c1a17;
  --glass:     rgba(245,240,232,0.85);
  --ink:       #0f0e0c;
  --ink3:      #7c7770;
  --bg:        #faf8f4;
  --surf:      #f2ede4;
  --surf2:     #e8e1d5;
  --bdr:       rgba(60,54,44,0.12);
  --bdr2:      rgba(60,54,44,0.24);
  --rust:      #c4622d;
  --rust2:     #e0845a;
  --rust-lt:   #fdf1ea;
  --white:     #fff;
  --font-main:  'Montserrat', sans-serif;
  --font-serif: 'Cormorant Garamond', Georgia, serif;
  --sans:       'DM Sans', sans-serif;
  --serif-po:   'Playfair Display', Georgia, serif;
  --nav-h:  72px;
  --ticker-h: 34px;
  --radius: 2px;
  --ease:   cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

html { scroll-behavior: smooth; }
body {
  font-family: var(--font-main);
  background: var(--cream);
  color: var(--charcoal);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
a { text-decoration: none; color: inherit; }
img { display: block; max-width: 100%; }
button { font-family: var(--font-main); cursor: pointer; border: none; background: none; }

::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--warm); }
::-webkit-scrollbar-thumb { background: var(--stone); border-radius: 2px; }

/* ═══════════════════════════════════════
   ANNOUNCEMENT TICKER
═══════════════════════════════════════ */
.ticker {
  height: var(--ticker-h);
  background: var(--charcoal);
  color: var(--cream);
  display: flex;
  align-items: center;
  overflow: hidden;
  position: relative;
  z-index: 1;
}
.ticker__track {
  display: flex;
  gap: 0;
  animation: ticker 28s linear infinite;
  white-space: nowrap;
  flex-shrink: 0;
}
.ticker__item {
  font-size: 10px;
  letter-spacing: 0.18em;
  font-weight: 500;
  text-transform: uppercase;
  padding: 0 48px;
  display: flex;
  align-items: center;
  gap: 48px;
  flex-shrink: 0;
}
.ticker__item::after {
  content: '·';
  color: var(--accent);
  font-size: 18px;
}
@keyframes ticker {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ═══════════════════════════════════════
   NAVIGATION
═══════════════════════════════════════ */
.nav {
  position: sticky;
  top: 0;
  z-index: 200;
  height: var(--nav-h);
  background: var(--glass);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(184,175,158,0.25);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 0 40px;
  transition: background 0.3s var(--ease), box-shadow 0.3s;
}
.nav.scrolled {
  background: rgba(245,240,232,0.97);
  box-shadow: 0 1px 30px rgba(42,39,34,0.06);
}
.nav__left, .nav__right {
  display: flex;
  align-items: center;
  gap: 32px;
}
.nav__right { justify-content: flex-end; }
.nav__link {
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--muted);
  position: relative;
  transition: color 0.25s;
  white-space: nowrap;
}
.nav__link::after {
  content: '';
  position: absolute;
  bottom: -2px; left: 0;
  width: 0; height: 1px;
  background: var(--accent);
  transition: width 0.3s var(--ease);
}
.nav__link:hover { color: var(--charcoal); }
.nav__link:hover::after { width: 100%; }
.nav__logo {
  display: flex;
  align-items: center;
  justify-content: center;
}
.logo-video {
  height: 48px;
  width: auto;
  object-fit: contain;
  display: block;
}
.logo-text {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 400;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--charcoal);
}
.nav__bag {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--charcoal);
  padding: 8px 18px;
  border: 1px solid var(--charcoal);
  border-radius: 50px;
  transition: background 0.25s, color 0.25s;
  white-space: nowrap;
}
.nav__bag:hover { background: var(--charcoal); color: var(--cream); }
.nav__bag-count {
  width: 18px; height: 18px;
  background: var(--accent);
  color: #fff;
  border-radius: 50%;
  font-size: 9px;
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}
.nav__hamburger {
  display: none;
  flex-direction: column;
  gap: 6px;
  cursor: pointer;
  padding: 6px;
  z-index: 201;
}
.nav__hamburger span {
  display: block;
  width: 24px; height: 1.5px;
  background: var(--charcoal);
  border-radius: 2px;
  transition: all 0.35s var(--ease);
}
.nav__hamburger.open span:nth-child(1) { transform: translateY(7.5px) rotate(45deg); }
.nav__hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav__hamburger.open span:nth-child(3) { transform: translateY(-7.5px) rotate(-45deg); }

/* MOBILE MENU */
.mobile-menu {
  position: fixed;
  inset: 0;
  background: var(--cream);
  z-index: 300;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 28px;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-20px);
  transition: opacity 0.4s var(--ease), transform 0.4s var(--ease);
}
.mobile-menu.open { opacity: 1; pointer-events: all; transform: translateY(0); }
.mobile-menu a {
  font-family: var(--font-serif);
  font-size: 36px;
  font-weight: 300;
  font-style: italic;
  letter-spacing: 0.04em;
  color: var(--charcoal);
  transition: color 0.2s;
}
.mobile-menu a:hover { color: var(--accent); }
.mobile-menu__close {
  position: absolute;
  top: 24px; right: 28px;
  font-size: 24px;
  color: var(--muted);
  cursor: pointer;
  transition: color 0.2s;
}
.mobile-menu__close:hover { color: var(--charcoal); }

/* ═══════════════════════════════════════
   HERO VIDEO
═══════════════════════════════════════ */
.hero-video {
  position: relative;
  width: 100%;
  height: 100dvh;
  min-height: 500px;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
}
.hero-video video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
}
.hero-video__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(42,39,34,0.05) 0%,
    rgba(42,39,34,0) 35%,
    rgba(42,39,34,0.65) 100%
  );
  z-index: 1;
}
.hero-video__content {
  position: relative;
  z-index: 2;
  padding: 0 60px 70px;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  width: 100%;
  gap: 20px;
}
.hero-video__left .hero-tag {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.7);
  margin-bottom: 14px;
  opacity: 0;
  transform: translateY(20px);
  animation: fadeUp 0.8s 0.3s var(--ease) forwards;
}
.hero-video__left .hero-title {
  font-family: var(--font-serif);
  font-size: clamp(42px, 6vw, 96px);
  font-weight: 300;
  font-style: italic;
  color: var(--cream);
  line-height: 1.0;
  opacity: 0;
  transform: translateY(30px);
  animation: fadeUp 0.9s 0.5s var(--ease) forwards;
}
.hero-video__right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 20px;
  opacity: 0;
  transform: translateY(20px);
  animation: fadeUp 0.8s 0.7s var(--ease) forwards;
  flex-shrink: 0;
}
.hero-video__right p {
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.65);
  text-align: right;
}
.scroll-hint {
  position: absolute;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  opacity: 0;
  animation: fadeIn 1s 1.2s ease forwards;
}
.scroll-hint span {
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.55);
}
.scroll-hint__line {
  width: 1px; height: 40px;
  background: linear-gradient(to bottom, rgba(245,240,232,0.5), transparent);
  animation: scrollLine 2s ease-in-out infinite;
}
@keyframes scrollLine {
  0%, 100% { opacity: 0.4; transform: scaleY(1); }
  50% { opacity: 1; transform: scaleY(1.3); }
}

/* ═══════════════════════════════════════
   BUTTONS
═══════════════════════════════════════ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-main);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 14px 30px;
  border-radius: 50px;
  border: 1px solid transparent;
  transition: all 0.3s var(--ease);
  cursor: pointer;
  width: fit-content;
}
.btn--outline-light {
  border-color: rgba(245,240,232,0.6);
  color: var(--cream);
  background: rgba(245,240,232,0.08);
  backdrop-filter: blur(10px);
}
.btn--outline-light:hover { background: var(--cream); color: var(--charcoal); border-color: var(--cream); }
.btn--dark { background: var(--charcoal); color: var(--cream); border-color: var(--charcoal); }
.btn--dark:hover { background: #3e3a35; }
.btn--outline { border-color: var(--charcoal); color: var(--charcoal); background: transparent; }
.btn--outline:hover { background: var(--charcoal); color: var(--cream); }
.btn--accent { background: var(--accent); color: #fff; border-color: var(--accent); }
.btn--accent:hover { background: #b06830; }

/* ═══════════════════════════════════════
   CATEGORY BAR
═══════════════════════════════════════ */
.catbar {
  background: var(--warm);
  border-top: 1px solid rgba(184,175,158,0.3);
  border-bottom: 1px solid rgba(184,175,158,0.3);
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.catbar::-webkit-scrollbar { display: none; }
.catbar__inner {
  display: flex;
  white-space: nowrap;
  padding: 0 32px;
  width: max-content;
  min-width: 100%;
}
.catbar__item {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 16px 22px;
  border-bottom: 2px solid transparent;
  transition: color 0.25s, border-color 0.25s;
  cursor: pointer;
  flex-shrink: 0;
}
.catbar__item:hover,
.catbar__item.active { color: var(--charcoal); border-bottom-color: var(--accent); }

/* ═══════════════════════════════════════
   HERO SPLIT
═══════════════════════════════════════ */
.hero-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 80vh;
}
.hero-split__text {
  background: var(--warm);
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 80px 60px;
}
.hero-split__tag {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 18px;
  opacity: 0;
  transform: translateY(15px);
}
.hero-split__title {
  font-family: var(--font-serif);
  font-size: clamp(38px, 5vw, 76px);
  font-weight: 300;
  font-style: italic;
  line-height: 1.05;
  margin-bottom: 20px;
  opacity: 0;
  transform: translateY(20px);
}
.hero-split__sub {
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 40px;
  opacity: 0;
  transform: translateY(15px);
}
.hero-split__btn {
  opacity: 0;
  transform: translateY(15px);
}
.hero-split__visual {
  position: relative;
  background: var(--sand);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hero-split__visual::before {
  content: '';
  position: absolute;
  width: 60%; aspect-ratio: 1;
  border-radius: 50%;
  border: 1px solid rgba(42,39,34,0.1);
  top: 5%; right: -10%;
  pointer-events: none;
}
.hero-split__visual::after {
  content: '';
  position: absolute;
  width: 40%; aspect-ratio: 1;
  border-radius: 50%;
  border: 1px solid rgba(42,39,34,0.06);
  bottom: 10%; left: -5%;
  pointer-events: none;
}
.float-card {
  position: absolute;
  background: var(--glass);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.4);
  border-radius: 12px;
  padding: 12px 16px;
  box-shadow: 0 8px 32px rgba(42,39,34,0.12);
  animation: floatAnim 4s ease-in-out infinite;
  z-index: 5;
}
.float-card:nth-child(2) { animation-delay: -2s; }
.float-card--top { top: 12%; right: 8%; font-size: 10px; letter-spacing: 0.1em; font-weight: 600; }
.float-card--bottom { bottom: 12%; left: 8%; font-size: 10px; letter-spacing: 0.08em; }
.float-card__badge {
  display: inline-block;
  background: var(--accent);
  color: #fff;
  border-radius: 50px;
  font-size: 8px; font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 2px 8px;
  margin-bottom: 4px;
}
@keyframes floatAnim {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-8px); }
}

/* ═══════════════════════════════════════
   SECTIONS COMMON
═══════════════════════════════════════ */
.section { padding: 72px 48px; }
.section--alt { background: var(--offwhite); }
.section__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 40px;
  gap: 12px;
}
.section__title {
  font-family: var(--font-serif);
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 300;
  font-style: italic;
}
.section__link {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 6px;
  transition: color 0.25s, gap 0.25s;
  white-space: nowrap;
}
.section__link:hover { color: var(--accent); gap: 10px; }
.section__link::after { content: '→'; }

/* ═══════════════════════════════════════
   PRODUCT GRID
═══════════════════════════════════════ */
.products { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.products--3 { grid-template-columns: repeat(3, 1fr); }
.card { cursor: pointer; }
.card__thumb {
  aspect-ratio: 3 / 4;
  background: var(--warm);
  position: relative;
  overflow: hidden;
  margin-bottom: 16px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.card__thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--ease);
}
.card__thumb .placeholder {
  width: 100%; height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--stone);
  text-transform: uppercase;
  gap: 8px;
  transition: transform 0.6s var(--ease);
}
.card__thumb .placeholder img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.placeholder__icon { font-size: 28px; opacity: 0.35; }
.card:hover .card__thumb img,
.card:hover .card__thumb .placeholder { transform: scale(1.05); }
.card__thumb::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(42,39,34,0.4) 0%, transparent 50%);
  opacity: 0;
  transition: opacity 0.35s var(--ease);
  border-radius: 8px;
}
.card:hover .card__thumb::after { opacity: 1; }
.card__badge {
  position: absolute;
  top: 12px; left: 12px;
  font-size: 8px; font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 50px;
  z-index: 2;
}
.card__badge--new    { background: var(--charcoal); color: var(--cream); }
.card__badge--seller { background: #7a5c3a; color: #fff; }
.card__badge--sale   { background: var(--accent); color: #fff; }
.card__wishlist {
  position: absolute;
  top: 12px; right: 12px;
  width: 34px; height: 34px;
  border-radius: 50%;
  background: rgba(245,240,232,0.85);
  backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  z-index: 2;
  opacity: 0;
  transform: scale(0.8);
  transition: opacity 0.25s, transform 0.25s var(--ease);
  cursor: pointer;
}
.card:hover .card__wishlist { opacity: 1; transform: scale(1); }
.card__quick {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: var(--charcoal);
  color: var(--cream);
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-align: center;
  padding: 14px;
  transform: translateY(100%);
  transition: transform 0.35s var(--ease);
  z-index: 2;
  border-radius: 0 0 8px 8px;
}
.card:hover .card__quick { transform: translateY(0); }
.card__info { padding: 0 2px; }
.card__brand { font-size: 10px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--stone); margin-bottom: 4px; }
.card__name  { font-size: 13px; font-weight: 400; letter-spacing: 0.02em; margin-bottom: 6px; }
.card__price { font-size: 14px; font-weight: 600; color: var(--charcoal); }
.card__price s { font-weight: 300; color: var(--stone); font-size: 12px; margin-right: 6px; }
.card__size  { font-size: 10px; color: var(--stone); letter-spacing: 0.08em; margin-top: 3px; }

/* ═══════════════════════════════════════
   EDITORIAL STRIP
═══════════════════════════════════════ */
.editorial {
  background: var(--dark-bg);
  color: var(--cream);
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 420px;
  position: relative;
  overflow: hidden;
}
.editorial__image {
  background: linear-gradient(135deg, #2a2722 0%, #3e3228 60%, #2a2722 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  min-height: 300px;
}
.editorial__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.editorial__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 72px 60px;
  position: relative;
}
.editorial__content::before {
  content: '';
  position: absolute;
  width: 300px; height: 300px;
  border-radius: 50%;
  border: 1px solid rgba(245,240,232,0.06);
  top: -80px; right: -80px;
  pointer-events: none;
}
.editorial__tag {
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--accent2);
  margin-bottom: 20px;
}
.editorial__title {
  font-family: var(--font-serif);
  font-size: clamp(32px, 4vw, 60px);
  font-weight: 300; font-style: italic;
  line-height: 1.08;
  margin-bottom: 20px;
}
.editorial__sub {
  font-size: 12px;
  color: rgba(245,240,232,0.55);
  line-height: 1.8;
  max-width: 280px;
  margin-bottom: 36px;
}

/* ═══════════════════════════════════════
   CATEGORY TILES
═══════════════════════════════════════ */
.cattiles {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  background: var(--sand);
}
.cattile {
  position: relative;
  overflow: hidden;
  cursor: pointer;
  height: 320px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 28px;
  transform-style: preserve-3d;
  background-size: cover;
  background-position: center;
}
.cattile--tops    { background-image: url('images/indian4.jpg'); }
.cattile--denim   { background-image: url('images/demin.jpg'); }
.cattile--knits   { background-image: url('images/knits.jpg'); }
.cattile--jackets { background-image: url('images/jacket.jpg'); }
.cattile::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(28,26,23,0.6) 0%, transparent 65%);
  z-index: 1;
}
.cattile__inner {
  position: relative; z-index: 2;
  transform: translateY(8px);
  transition: transform 0.35s var(--ease);
}
.cattile:hover .cattile__inner { transform: translateY(0); }
.cattile__label {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.75);
  margin-bottom: 8px;
}
.cattile__name {
  font-family: var(--font-serif);
  font-size: 28px; font-weight: 300; font-style: italic;
  color: var(--cream); line-height: 1.1;
}
.cattile__cta {
  font-size: 9.5px; font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.65);
  margin-top: 10px;
  display: flex; align-items: center; gap: 6px;
  opacity: 0; transform: translateY(6px);
  transition: opacity 0.3s var(--ease), transform 0.3s var(--ease);
}
.cattile:hover .cattile__cta { opacity: 1; transform: translateY(0); }

/* ═══════════════════════════════════════
   USP ROW
═══════════════════════════════════════ */
.usp {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: var(--cream);
}
.usp__item {
  padding: 48px 32px;
  border-right: 1px solid rgba(184,175,158,0.3);
  text-align: center;
  transition: background 0.3s;
}
.usp__item:last-child { border-right: none; }
.usp__item:hover { background: var(--warm); }
.usp__icon { font-size: 26px; margin-bottom: 14px; display: block; }
.usp__number {
  font-family: var(--font-serif);
  font-size: 36px; font-weight: 300; font-style: italic;
  color: var(--accent);
  display: block; margin-bottom: 6px;
}
.usp__title { font-size: 10px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; margin-bottom: 8px; }
.usp__text { font-size: 11.5px; color: var(--muted); line-height: 1.7; }

/* ═══════════════════════════════════════
   NEWSLETTER
═══════════════════════════════════════ */
.newsletter {
  background: var(--charcoal);
  color: var(--cream);
  padding: 100px 48px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.newsletter::before,
.newsletter::after {
  content: '';
  position: absolute;
  border-radius: 50%;
  background: rgba(196,119,58,0.08);
  pointer-events: none;
}
.newsletter::before { width: 500px; height: 500px; top: -200px; left: -150px; }
.newsletter::after  { width: 400px; height: 400px; bottom: -150px; right: -100px; }
.newsletter__tag {
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--accent2);
  margin-bottom: 16px;
}
.newsletter__title {
  font-family: var(--font-serif);
  font-size: clamp(28px, 4vw, 52px);
  font-weight: 300; font-style: italic;
  margin-bottom: 10px;
}
.newsletter__sub {
  font-size: 11px; font-weight: 400;
  letter-spacing: 0.12em;
  color: rgba(245,240,232,0.5);
  text-transform: uppercase;
  margin-bottom: 44px;
}
.newsletter__form {
  display: flex;
  max-width: 480px;
  margin: 0 auto;
  border: 1px solid rgba(245,240,232,0.2);
  border-radius: 50px;
  overflow: hidden;
  background: rgba(245,240,232,0.06);
  backdrop-filter: blur(10px);
}
.newsletter__input {
  flex: 1;
  background: transparent;
  padding: 16px 24px;
  font-family: var(--font-main);
  font-size: 12px;
  color: var(--cream);
  outline: none; border: none;
  min-width: 0;
}
.newsletter__input::placeholder { color: rgba(245,240,232,0.35); letter-spacing: 0.08em; }
.newsletter__btn {
  background: var(--accent);
  color: #fff; border: none;
  padding: 16px 28px;
  font-family: var(--font-main);
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 50px; margin: 4px;
  transition: background 0.25s;
  flex-shrink: 0;
}
.newsletter__btn:hover { background: #b06830; }

/* ═══════════════════════════════════════
   FOOTER — BASE (Desktop)
═══════════════════════════════════════ */
footer {
  background: var(--dark-bg);
  color: var(--cream);
  padding: 80px 48px 32px;
}
.footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 56px;
  padding-bottom: 56px;
  border-bottom: 1px solid rgba(245,240,232,0.08);
  margin-bottom: 32px;
}
.footer__logo {
  font-family: var(--font-serif);
  font-size: 22px; font-weight: 400;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.footer__about {
  font-size: 12px;
  color: #7a7672;
  line-height: 1.9;
  max-width: 220px;
  margin-bottom: 28px;
}
.footer__social { display: flex; gap: 12px; }
.footer__social a {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(245,240,232,0.12);
  display: flex; align-items: center; justify-content: center;
  font-size: 13px;
  color: rgba(245,240,232,0.4);
  transition: border-color 0.25s, color 0.25s;
}
.footer__social a:hover { border-color: var(--accent); color: var(--accent); }
.footer__col h4 {
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.35);
  margin-bottom: 22px;
}
.footer__col a {
  display: block;
  font-size: 12.5px;
  color: #7a7672;
  margin-bottom: 12px;
  transition: color 0.2s;
}
.footer__col a:hover { color: var(--cream); }
.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 10.5px;
  letter-spacing: 0.08em;
  color: #4a4642;
  flex-wrap: wrap;
  gap: 12px;
}
.footer__bottom-links { display: flex; gap: 28px; flex-wrap: wrap; }
.footer__bottom-links a { color: #4a4642; transition: color 0.2s; }
.footer__bottom-links a:hover { color: var(--stone); }

/* ═══════════════════════════════════════
   SCROLL TO TOP
═══════════════════════════════════════ */
.scroll-top {
  position: fixed;
  bottom: 32px; right: 32px;
  width: 48px; height: 48px;
  background: var(--charcoal);
  color: var(--cream);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px;
  opacity: 0; pointer-events: none;
  transform: translateY(10px);
  transition: opacity 0.3s, transform 0.3s var(--ease);
  z-index: 50; cursor: pointer;
  box-shadow: 0 4px 20px rgba(42,39,34,0.2);
  border: 1px solid rgba(245,240,232,0.1);
}
.scroll-top.visible { opacity: 1; pointer-events: all; transform: translateY(0); }
.scroll-top:hover { background: var(--accent); }

/* ═══════════════════════════════════════
   ANIMATIONS
═══════════════════════════════════════ */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(25px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.75s var(--ease), transform 0.75s var(--ease);
}
.reveal.in-view { opacity: 1; transform: translateY(0); }
.reveal-d1 { transition-delay: 0.1s; }
.reveal-d2 { transition-delay: 0.2s; }
.reveal-d3 { transition-delay: 0.3s; }
.reveal-d4 { transition-delay: 0.4s; }

/* ═══════════════════════════════════════
   BETA TRY-ON SECTION
═══════════════════════════════════════ */
.beta-tryon {
  background: var(--dark-bg);
  color: var(--cream);
  padding: 100px 48px;
  position: relative;
  overflow: hidden;
}
.beta-tryon::before {
  content: '';
  position: absolute;
  width: 600px; height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(196,98,45,0.12) 0%, transparent 70%);
  top: -200px; right: -150px;
  pointer-events: none;
}
.beta-tryon::after {
  content: '';
  position: absolute;
  width: 400px; height: 400px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(196,98,45,0.08) 0%, transparent 70%);
  bottom: -100px; left: -100px;
  pointer-events: none;
}
.beta-tryon__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  position: relative;
  z-index: 2;
}
.beta-tryon__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--rust2);
  margin-bottom: 24px;
}
.beta-tryon__eyebrow-badge {
  background: var(--rust);
  color: #fff;
  font-size: 7px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 50px;
  animation: betaPulse 2.5s ease-in-out infinite;
}
@keyframes betaPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(196,98,45,0.5); }
  50% { box-shadow: 0 0 0 8px rgba(196,98,45,0); }
}
.beta-tryon__title {
  font-family: var(--font-serif);
  font-size: clamp(36px, 5vw, 68px);
  font-weight: 300;
  font-style: italic;
  line-height: 1.05;
  margin-bottom: 20px;
  color: var(--cream);
}
.beta-tryon__title span { color: var(--rust2); display: block; }
.beta-tryon__desc {
  font-size: 13px;
  color: rgba(245,240,232,0.55);
  line-height: 1.9;
  max-width: 360px;
  margin-bottom: 40px;
}
.beta-tryon__features {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 44px;
}
.beta-feature {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  font-size: 12px;
  color: rgba(245,240,232,0.7);
  line-height: 1.5;
}
.beta-feature__dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--rust);
  flex-shrink: 0;
  margin-top: 5px;
}
.beta-tryon__cta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 16px 40px;
  background: var(--rust);
  color: #fff;
  border-radius: 50px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
  border: none;
  font-family: var(--font-main);
  position: relative;
  overflow: hidden;
  transition: transform 0.28s var(--ease), box-shadow 0.28s var(--ease);
  text-decoration: none;
}
.beta-tryon__cta::before {
  content: '';
  position: absolute; inset: 0;
  background: rgba(255,255,255,0.12);
  transform: translateX(-101%);
  transition: transform 0.38s var(--ease);
}
.beta-tryon__cta:hover::before { transform: translateX(0); }
.beta-tryon__cta:hover { transform: translateY(-3px); box-shadow: 0 12px 32px rgba(196,98,45,0.45); }
.beta-tryon__cta:active { transform: translateY(0); box-shadow: none; }
.beta-tryon__visual { position: relative; }
.beta-mockup {
  background: rgba(245,240,232,0.04);
  border: 1px solid rgba(245,240,232,0.08);
  border-radius: 20px;
  overflow: hidden;
  backdrop-filter: blur(10px);
}
.beta-mockup__bar {
  height: 36px;
  background: rgba(245,240,232,0.06);
  border-bottom: 1px solid rgba(245,240,232,0.06);
  display: flex;
  align-items: center;
  padding: 0 14px;
  gap: 6px;
}
.bm-dot { width: 8px; height: 8px; border-radius: 50%; }
.bm-dot:nth-child(1) { background: rgba(255,100,80,0.5); }
.bm-dot:nth-child(2) { background: rgba(255,200,60,0.5); }
.bm-dot:nth-child(3) { background: rgba(80,200,100,0.5); }
.bm-title {
  margin-left: auto; margin-right: auto;
  font-size: 9px; font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.3);
}
.beta-mockup__panels {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  height: 280px;
  gap: 1px;
  background: rgba(245,240,232,0.04);
}
.bm-panel {
  background: rgba(245,240,232,0.03);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 16px;
  position: relative;
}
.bm-panel:nth-child(2) { background: rgba(245,240,232,0.05); }
.bm-panel-label {
  position: absolute;
  top: 10px; left: 10px;
  font-size: 7px; font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.25);
}
.bm-icon-wrap {
  width: 60px; height: 80px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
}
.bm-panel:nth-child(1) .bm-icon-wrap { background: rgba(196,98,45,0.12); }
.bm-panel:nth-child(2) .bm-icon-wrap { background: rgba(245,240,232,0.06); }
.bm-panel:nth-child(3) .bm-icon-wrap { background: rgba(90,154,106,0.12); }
.bm-icon-wrap svg { width: 28px; height: 28px; stroke: rgba(245,240,232,0.3); fill: none; stroke-width: 1; }
.bm-panel:nth-child(3) .bm-icon-wrap svg { stroke: rgba(90,154,106,0.7); }
.bm-progress {
  width: 80%; height: 2px;
  background: rgba(245,240,232,0.08);
  border-radius: 2px; overflow: hidden;
}
.bm-progress__fill {
  height: 100%; background: var(--rust);
  border-radius: 2px;
  animation: bmProgress 2.5s ease-in-out infinite;
}
@keyframes bmProgress {
  0% { width: 0%; } 60% { width: 85%; } 80% { width: 85%; } 100% { width: 0%; }
}
.beta-mockup__actions {
  height: 44px;
  background: rgba(245,240,232,0.03);
  border-top: 1px solid rgba(245,240,232,0.06);
  display: flex; align-items: center; justify-content: center;
  gap: 8px; padding: 0 14px;
}
.bm-btn { padding: 5px 14px; border-radius: 20px; font-size: 7px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; }
.bm-btn--main { background: var(--rust); color: #fff; }
.bm-btn--sec { background: rgba(245,240,232,0.07); color: rgba(245,240,232,0.45); }
.beta-mockup__badge {
  position: absolute;
  top: -14px; right: -14px;
  background: var(--rust); color: #fff;
  padding: 6px 16px; border-radius: 50px;
  font-size: 8px; font-weight: 800;
  letter-spacing: 0.14em; text-transform: uppercase;
  box-shadow: 0 4px 16px rgba(196,98,45,0.4);
  animation: floatAnim 3s ease-in-out infinite;
}

/* ═══════════════════════════════════════
   VIRTUAL.HTML STYLES
═══════════════════════════════════════ */
.vt-nav {
  height: 54px; background: var(--white);
  border-bottom: 1px solid var(--bdr);
  display: flex; align-items: center;
  padding: 0 32px; position: relative; z-index: 50;
}
.vt-logo { font-family: var(--serif-po); font-size: 16px; letter-spacing: .22em; text-transform: uppercase; color: var(--ink); margin-right: 36px; }
.vt-nav-links { display: flex; gap: 26px; flex: 1; }
.vt-nl { font-size: 10px; font-weight: 500; letter-spacing: .13em; text-transform: uppercase; color: var(--ink3); cursor: pointer; position: relative; padding-bottom: 3px; transition: color .22s; }
.vt-nl::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 1.5px; background: var(--rust); transform: scaleX(0); transform-origin: left; transition: transform .28s var(--ease); }
.vt-nl:hover { color: var(--ink); }
.vt-nl:hover::after, .vt-nl.act::after { transform: scaleX(1); }
.vt-nl.act { color: var(--ink); }
.vt-bag-pill { margin-left: auto; display: flex; align-items: center; gap: 8px; padding: 6px 18px; border: 1px solid var(--bdr2); border-radius: 40px; font-size: 10px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; cursor: pointer; background: var(--white); transition: all .28s var(--ease); font-family: var(--sans); }
.vt-bag-pill:hover { background: var(--ink); color: var(--white); border-color: var(--ink); }
.vt-bag-pill:hover .vt-bdot { background: var(--white); color: var(--rust); }
.vt-bdot { width: 17px; height: 17px; background: var(--rust); border-radius: 50%; color: var(--white); font-size: 8px; font-weight: 700; display: flex; align-items: center; justify-content: center; transition: all .28s; }
.vt-tabs { height: 42px; background: var(--surf); border-bottom: 1px solid var(--bdr); display: flex; align-items: flex-end; padding: 0 32px; }
.vt-tab { height: 100%; display: flex; align-items: center; gap: 7px; padding: 0 18px; font-size: 10px; font-weight: 600; letter-spacing: .13em; text-transform: uppercase; color: var(--ink3); border-bottom: 2.5px solid transparent; cursor: pointer; white-space: nowrap; font-family: var(--sans); transition: color .22s, border-color .22s; }
.vt-tab:hover { color: var(--ink); }
.vt-tab.act { color: var(--ink); border-bottom-color: var(--rust); }
.vt-status-bar { height: 30px; background: var(--surf); border-bottom: 1px solid var(--bdr); display: flex; align-items: center; padding: 0 22px; gap: 9px; font-size: 9px; letter-spacing: .06em; color: var(--ink3); font-family: var(--sans); }
.sdot { width: 7px; height: 7px; border-radius: 50%; background: #5a9a6a; flex-shrink: 0; transition: background .3s; }
.sdot.busy { background: var(--rust); animation: pulse 1s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:1;} 50%{opacity:.25;} }
.vt-workspace { height: calc(100vh - 54px - 42px - 30px - 78px); display: flex; overflow: hidden; }
.vt-panel { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; position: relative; overflow: hidden; transition: background .3s; }
.panel-product { background: var(--white); border-right: 1px solid var(--bdr); }
.panel-model   { background: var(--surf);  border-right: 1px solid var(--bdr); }
.panel-result  { background: var(--bg); }
.panel-head { position: absolute; top: 0; left: 0; right: 0; height: 44px; padding: 0 16px; display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--bdr); background: inherit; z-index: 5; }
.panel-lbl { font-size: 9px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--ink3); font-family: var(--sans); }
.icon-btn { width: 30px; height: 30px; border: 1px solid var(--bdr2); border-radius: 50%; background: var(--white); display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--ink3); font-size: 13px; transition: all .24s var(--ease); }
.icon-btn:hover { border-color: var(--rust); background: var(--rust-lt); color: var(--rust); transform: scale(1.1) rotate(12deg); }
.icon-btn:active { transform: scale(.96); }
.drop-zone { width: calc(100% - 32px); height: calc(100% - 80px); margin-top: 44px; border: 1.5px dashed var(--surf2); border-radius: 16px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 16px; cursor: pointer; text-align: center; padding: 24px; transition: border-color .25s, background .25s, transform .2s; }
.drop-zone:hover { border-color: var(--rust); background: var(--rust-lt); transform: scale(1.01); }
.drop-zone:active { transform: scale(.99); }
.fan-stack { position: relative; width: 180px; height: 180px; margin-bottom: 8px; }
.fan-card { position: absolute; width: 100px; height: 140px; border-radius: 14px; overflow: hidden; display: flex; align-items: center; justify-content: center; transition: transform .38s var(--ease), box-shadow .38s; }
.drop-zone:hover .fc1 { transform: rotate(-20deg) translate(-52px,14px); }
.drop-zone:hover .fc2 { transform: rotate(0deg) translate(-8px,-8px); }
.drop-zone:hover .fc3 { transform: rotate(20deg) translate(44px,14px); }
.fc1 { transform: rotate(-13deg) translate(-42px,10px); z-index: 1; background: #f9e8e0; }
.fc2 { transform: rotate(-2deg) translate(-8px,0); z-index: 3; background: #f5f0ea; }
.fc3 { transform: rotate(11deg) translate(34px,8px); z-index: 1; background: #e8eef9; }
.dz-upload-icon { width: 56px; height: 56px; border-radius: 50%; background: var(--surf2); display: flex; align-items: center; justify-content: center; transition: background .25s, transform .25s; }
.drop-zone:hover .dz-upload-icon { background: #f0d5c8; transform: scale(1.08); }
.dz-upload-icon svg { width: 24px; height: 24px; stroke: var(--ink3); fill: none; stroke-width: 1.5; transition: stroke .25s; }
.drop-zone:hover .dz-upload-icon svg { stroke: var(--rust); }
.dz-title { font-family: var(--serif-po); font-size: 16px; font-style: italic; color: var(--ink); opacity: .5; }
.dz-sub { font-size: 9px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink3); opacity: .55; font-family: var(--sans); }
.dz-pills { display: flex; gap: 8px; margin-top: 4px; flex-wrap: wrap; justify-content: center; }
.dz-pill { display: flex; align-items: center; gap: 7px; padding: 9px 16px; border: 1px solid var(--bdr2); border-radius: 40px; font-family: var(--sans); font-size: 10px; font-weight: 500; color: var(--ink); background: var(--white); cursor: pointer; white-space: nowrap; position: relative; overflow: hidden; transition: border-color .24s, color .24s, transform .2s, box-shadow .24s; }
.dz-pill::before { content:''; position: absolute; inset:0; background: var(--ink); transform: translateY(101%); transition: transform .3s var(--ease); }
.dz-pill:hover::before { transform: translateY(0); }
.dz-pill:hover { color: var(--white); border-color: var(--ink); transform: translateY(-2px); box-shadow: 0 6px 16px rgba(15,14,12,.12); }
.dz-pill:active { transform: translateY(0); box-shadow: none; }
.dz-pill svg, .dz-pill span { position: relative; z-index: 1; }
.dz-pill svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 1.5; }
.drop-text { font-size: 10px; color: var(--ink3); opacity: .55; margin-top: -4px; font-family: var(--sans); }
.swap-col { width: 54px; display: flex; align-items: center; justify-content: center; border-right: 1px solid var(--bdr); flex-shrink: 0; background: var(--white); }
.swap-btn { width: 40px; height: 40px; border: 1px solid var(--bdr2); border-radius: 50%; background: var(--white); display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--ink3); transition: all .28s var(--ease); }
.swap-btn svg { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 1.5; transition: transform .5s var(--ease); }
.swap-btn:hover { border-color: var(--rust); background: var(--rust-lt); color: var(--rust); }
.swap-btn:hover svg { transform: rotate(180deg); }
.swap-btn:active { transform: scale(.92); }
.panel-preview { position: absolute; inset: 44px 0 0; display: flex; align-items: center; justify-content: center; padding: 16px; }
.panel-preview img { max-width: 100%; max-height: 100%; object-fit: contain; border-radius: 12px; animation: vfadeIn .35s var(--ease); }
@keyframes vfadeIn { from{opacity:0;transform:scale(.97);} to{opacity:1;transform:scale(1);} }
.panel-controls { position: absolute; top: 54px; right: 12px; display: flex; gap: 6px; z-index: 10; }
.result-idle { display: flex; flex-direction: column; align-items: center; gap: 16px; text-align: center; padding: 28px; margin-top: 44px; animation: vfadeIn .4s var(--ease); }
.ri-ring { width: 80px; height: 80px; border: 1px solid var(--bdr2); border-radius: 50%; display: flex; align-items: center; justify-content: center; opacity: .2; }
.ri-ring svg { width: 36px; height: 36px; stroke: var(--ink); fill: none; stroke-width: 1; }
.result-spinning { position: absolute; inset: 44px 0 0; display: none; flex-direction: column; align-items: center; justify-content: center; gap: 16px; background: rgba(250,248,244,.96); }
.spinner { width: 48px; height: 48px; border: 2.5px solid var(--surf2); border-top-color: var(--rust); border-radius: 50%; animation: spin .7s linear infinite; }
@keyframes spin { to{transform:rotate(360deg);} }
.spin-title { font-family: var(--serif-po); font-size: 18px; font-style: italic; color: var(--ink); }
.spin-sub { font-size: 9px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink3); font-family: var(--sans); }
.result-shown { position: absolute; inset: 44px 0 48px; display: none; align-items: center; justify-content: center; padding: 16px; }
.result-shown img { max-width: 100%; max-height: 100%; object-fit: contain; border-radius: 12px; animation: vfadeIn .45s var(--ease); }
.result-badge-wrap { position: absolute; bottom: 58px; left: 50%; transform: translateX(-50%); background: var(--ink); color: var(--white); padding: 5px 18px; border-radius: 40px; font-size: 9px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; white-space: nowrap; font-family: var(--sans); animation: slideUp .4s var(--ease); }
@keyframes slideUp { from{opacity:0;transform:translateX(-50%) translateY(10px);} to{opacity:1;transform:translateX(-50%) translateY(0);} }
.result-float { position: absolute; top: 54px; right: 12px; display: flex; gap: 6px; z-index: 10; }
.rf-btn { display: flex; align-items: center; gap: 5px; padding: 6px 13px; background: rgba(255,255,255,.9); border: 1px solid var(--bdr2); border-radius: 20px; font-size: 9px; font-weight: 600; letter-spacing: .07em; text-transform: uppercase; color: var(--ink); cursor: pointer; backdrop-filter: blur(6px); font-family: var(--sans); transition: all .24s var(--ease); animation: vfadeIn .4s var(--ease); }
.rf-btn:hover { background: var(--ink); color: var(--white); border-color: var(--ink); transform: translateY(-1px); }
.rf-btn:active { transform: translateY(0); }
.result-action-bar { position: absolute; bottom: 0; left: 0; right: 0; height: 48px; border-top: 1px solid var(--bdr); background: var(--bg); display: none; align-items: center; justify-content: center; gap: 10px; }
.rab-btn { display: flex; align-items: center; gap: 6px; padding: 7px 16px; border: 1px solid var(--bdr2); border-radius: 40px; font-size: 9px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--ink); background: var(--white); cursor: pointer; font-family: var(--sans); transition: all .24s var(--ease); }
.rab-btn:hover { background: var(--ink); color: var(--white); border-color: var(--ink); transform: translateY(-1px); }
.rab-btn:active { transform: translateY(0); }
.vt-bottom-strip { height: 78px; background: var(--white); border-top: 1px solid var(--bdr); display: flex; align-items: center; justify-content: center; gap: 18px; flex-shrink: 0; padding: 0 32px; }
.sec-btn { display: flex; align-items: center; gap: 8px; padding: 13px 28px; background: transparent; color: var(--ink); border: 1.5px solid var(--bdr2); border-radius: 40px; font-family: var(--sans); font-size: 10px; font-weight: 600; letter-spacing: .13em; text-transform: uppercase; cursor: pointer; transition: all .28s var(--ease); position: relative; overflow: hidden; }
.sec-btn::before { content: ''; position: absolute; inset:0; background: var(--surf); transform: scaleX(0); transform-origin: left; transition: transform .3s var(--ease); }
.sec-btn:hover::before { transform: scaleX(1); }
.sec-btn:hover { border-color: var(--ink); transform: translateY(-2px); box-shadow: 0 5px 14px rgba(15,14,12,.09); }
.sec-btn:active { transform: translateY(0); box-shadow: none; }
.sec-btn svg, .sec-btn span { position: relative; z-index: 1; }
.sec-btn svg { width: 15px; height: 15px; stroke: currentColor; fill: none; stroke-width: 1.5; }
.try-btn { display: flex; align-items: center; gap: 10px; padding: 15px 56px; background: var(--ink); color: var(--white); border: none; border-radius: 40px; font-family: var(--sans); font-size: 12px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; cursor: pointer; position: relative; overflow: hidden; transition: transform .24s var(--ease), box-shadow .24s var(--ease); }
.try-btn::before { content: ''; position: absolute; inset:0; background: var(--rust); transform: translateX(-101%); transition: transform .42s var(--ease); }
.try-btn:hover::before { transform: translateX(0); }
.try-btn:hover { transform: translateY(-3px); box-shadow: 0 10px 28px rgba(196,98,45,.38); }
.try-btn:active { transform: translateY(0); box-shadow: none; }
.try-btn-inner { position: relative; z-index: 1; display: flex; align-items: center; gap: 10px; }
.try-btn-inner svg { width: 15px; height: 15px; stroke: currentColor; fill: none; stroke-width: 2; }
.ripple { position: absolute; border-radius: 50%; background: rgba(255,255,255,.25); transform: scale(0); animation: ripple-anim .5s linear; pointer-events: none; }
@keyframes ripple-anim { to{transform:scale(4);opacity:0;} }
.vt-panel.drag-over .drop-zone { border-color: var(--rust); background: var(--rust-lt); }

/* ═══════════════════════════════════════
   RESPONSIVE — TABLET (max 1024px)
═══════════════════════════════════════ */
@media (max-width: 1024px) {
  .nav { padding: 0 28px; }
  .nav__left, .nav__right { gap: 20px; }
  .products { grid-template-columns: repeat(3, 1fr); }
  .products--3 { grid-template-columns: repeat(2, 1fr); }
  .cattiles { grid-template-columns: repeat(2, 1fr); }
  .cattile { height: 260px; }
  .footer__grid { grid-template-columns: 1fr 1fr; gap: 36px; }
  .editorial { grid-template-columns: 1fr; }
  .editorial__image { min-height: 300px; }
  .beta-tryon__inner { grid-template-columns: 1fr; gap: 48px; }
  .beta-tryon { padding: 72px 40px; }
  .hero-split { min-height: auto; }
  .hero-split__text { padding: 60px 40px; }
}

/* ═══════════════════════════════════════
   RESPONSIVE — MOBILE (max 768px)
═══════════════════════════════════════ */
@media (max-width: 768px) {

  /* NAV */
  .nav {
    padding: 0 20px;
    grid-template-columns: auto 1fr auto;
    height: 60px;
  }
  .nav__left, .nav__right { display: none; }
  .nav__hamburger { display: flex; }
  .nav__logo { justify-self: center; }
  .logo-video { height: 36px; }

  /* HERO VIDEO */
  .hero-video {
    height: 100dvh;
    min-height: 480px;
    align-items: flex-end;
  }
  .hero-video video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
  }
  .hero-video__overlay {
    background: linear-gradient(
      to bottom,
      rgba(42,39,34,0.1) 0%,
      rgba(42,39,34,0) 30%,
      rgba(42,39,34,0.75) 100%
    );
  }
  .hero-video__content {
    padding: 0 24px 50px;
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }
  .hero-video__left .hero-title {
    font-size: clamp(36px, 10vw, 56px);
  }
  .hero-video__right {
    align-items: flex-start;
    width: 100%;
  }
  .hero-video__right p { text-align: left; }
  .scroll-hint { display: none; }

  /* HERO SPLIT */
  .hero-split { grid-template-columns: 1fr; min-height: auto; }
  .hero-split__visual { order: -1; height: 260px; min-height: 260px; }
  .hero-split__visual .float-card { display: none; }
  .hero-split__text { padding: 40px 24px; }
  .hero-split__title { font-size: clamp(32px, 8vw, 48px); }

  /* SECTIONS */
  .section { padding: 48px 20px; }
  .section--alt { padding: 48px 20px; }

  /* PRODUCTS */
  .products { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .products--3 { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .card__quick { display: none; }
  .card__wishlist { opacity: 1; transform: scale(1); }

  /* CATEGORY BAR */
  .catbar__inner { padding: 0 16px; }
  .catbar__item { padding: 14px 16px; font-size: 9px; }

  /* EDITORIAL */
  .editorial { grid-template-columns: 1fr; }
  .editorial__image { min-height: 240px; height: 240px; }
  .editorial__content { padding: 40px 24px; }
  .editorial__title { font-size: clamp(28px, 7vw, 44px); }
  .editorial__sub { max-width: 100%; }

  /* CATEGORY TILES */
  .cattiles { grid-template-columns: 1fr 1fr; gap: 2px; }
  .cattile { height: 180px; padding: 18px; }
  .cattile__name { font-size: 20px; }

  /* USP */
  .usp { grid-template-columns: repeat(2, 1fr); }
  .usp__item { padding: 32px 20px; border-right: 1px solid rgba(184,175,158,0.3); }
  .usp__item:nth-child(2) { border-right: none; }
  .usp__item:nth-child(3) { border-top: 1px solid rgba(184,175,158,0.3); }
  .usp__item:nth-child(4) { border-top: 1px solid rgba(184,175,158,0.3); border-right: none; }
  .usp__number { font-size: 28px; }

  /* NEWSLETTER */
  .newsletter { padding: 64px 24px; }
  .newsletter__form {
    flex-direction: column;
    border-radius: 16px;
    overflow: hidden;
    max-width: 100%;
  }
  .newsletter__input { padding: 14px 20px; border-radius: 16px 16px 0 0; }
  .newsletter__btn { border-radius: 0 0 16px 16px; margin: 0; padding: 14px; }

  /* ─────────────────────────────────────
     FOOTER — MOBILE 2 COLUMNS FIX
  ───────────────────────────────────── */
  footer {
    padding: 48px 20px 28px;
  }

  /* 2 columns: brand left, links right — exactly like desktop */
  .footer__grid {
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    padding-bottom: 40px;
    border-bottom: 1px solid rgba(245,240,232,0.08);
    margin-bottom: 24px;
  }

  .footer__about {
    max-width: 100%;
    font-size: 12px;
    line-height: 1.85;
  }

  .footer__logo {
    font-size: 17px;
    letter-spacing: 0.16em;
    margin-bottom: 12px;
  }

  .footer__social a {
    width: 32px;
    height: 32px;
    font-size: 12px;
  }

  .footer__col h4 {
    font-size: 8.5px;
    letter-spacing: 0.16em;
    margin-bottom: 14px;
  }

  .footer__col a {
    font-size: 11.5px;
    margin-bottom: 10px;
  }

  /* Bottom bar */
  .footer__bottom {
    flex-direction: column;
    text-align: center;
    gap: 10px;
    font-size: 10px;
  }
  .footer__bottom-links {
    justify-content: center;
    gap: 18px;
    flex-wrap: wrap;
  }

  /* BETA TRY-ON */
  .beta-tryon { padding: 60px 24px; }
  .beta-tryon__inner { grid-template-columns: 1fr; gap: 40px; }
  .beta-tryon__visual { display: none; }
  .beta-tryon__desc { max-width: 100%; }
  .beta-tryon__title { font-size: clamp(32px, 8vw, 52px); }

  /* VIRTUAL.HTML */
  .vt-workspace { height: calc(100vh - 54px - 42px - 30px - 68px); flex-direction: column; overflow-y: auto; }
  .vt-panel { min-height: 300px; flex-shrink: 0; border-right: none; border-bottom: 1px solid var(--bdr); }
  .swap-col { width: 100%; height: 44px; border-right: none; border-bottom: 1px solid var(--bdr); flex-direction: row; justify-content: center; }
  .vt-bottom-strip { padding: 0 16px; gap: 10px; }
  .try-btn { padding: 13px 28px; font-size: 10px; }
  .vt-nav { padding: 0 16px; }
  .vt-nav-links { display: none; }
}

/* ═══════════════════════════════════════
   RESPONSIVE — SMALL MOBILE (max 480px)
═══════════════════════════════════════ */
@media (max-width: 480px) {

  /* HERO VIDEO */
  .hero-video {
    height: 50svh;
    min-height: 280px;
  }
  .hero-video__left .hero-title { font-size: clamp(30px, 9vw, 44px); }
  .hero-video__content { padding: 0 18px 44px; }

  /* PRODUCTS */
  .products { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .products--3 { grid-template-columns: 1fr 1fr; }

  /* USP — single column */
  .usp { grid-template-columns: 1fr; }
  .usp__item { border-right: none !important; border-bottom: 1px solid rgba(184,175,158,0.3); }
  .usp__item:last-child { border-bottom: none; }
  .usp__item:nth-child(3), .usp__item:nth-child(4) { border-top: none; }

  /* CATTILES */
  .cattiles { grid-template-columns: 1fr 1fr; }
  .cattile { height: 160px; }

  /* FOOTER — small mobile: keep 2 columns, tighten spacing */
  footer { padding: 40px 16px 24px; }

  .footer__grid {
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }

  .footer__logo {
    font-size: 15px;
    letter-spacing: 0.14em;
    margin-bottom: 10px;
  }

  .footer__about {
    font-size: 11px;
    margin-bottom: 18px;
  }

  .footer__social { gap: 8px; }
  .footer__social a { width: 28px; height: 28px; font-size: 11px; }

  .footer__col h4 {
    font-size: 8px;
    letter-spacing: 0.13em;
    margin-bottom: 12px;
  }

  .footer__col a {
    font-size: 11px;
    margin-bottom: 9px;
  }

  .footer__bottom { font-size: 9.5px; }
  .footer__bottom-links { gap: 12px; }

  /* NAV */
  .nav { padding: 0 16px; }
  .logo-video { height: 30px; }

  /* NEWSLETTER */
  .newsletter { padding: 48px 18px; }

  /* SECTION */
  .section { padding: 40px 16px; }
}