/*
Theme Name: HUS
Theme URI: https://hus-shop.com
Author: HUS Berlin
Description: HUS — slow-fashion streetwear. Built slowly. Made to last.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 8.0
Text Domain: hus
WooCommerce: true
*/

@import url("https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Inter:wght@400;500;600;700&family=Anton&family=Pirata+One&display=swap");

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  --color-ink:            #111111;
  --color-on-primary:     #ffffff;
  --color-canvas:         #ffffff;
  --color-soft-cloud:     #f5f5f5;
  --color-hairline:       #cacacb;
  --color-hairline-soft:  #e5e5e5;
  --color-text-ink:       #111111;
  --color-text-charcoal:  #39393b;
  --color-text-ash:       #4b4b4d;
  --color-text-mute:      #707072;
  --color-text-stone:     #9e9ea0;
  --color-sale:           #d30005;
  --color-sale-deep:      #780700;
  --color-success:        #007d48;
  --color-success-bright: #1eaa52;
  --color-info:           #1151ff;

  --font-display: "Bebas Neue", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --font-text:    "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --font-mono:    ui-monospace, "SF Mono", Menlo, Consolas, monospace;

  --gutter: 40px;
  --maxw:   1440px;

  --radius-sm:   18px;
  --radius-md:   24px;
  --radius-lg:   30px;
  --radius-full: 9999px;

  --hairline-divider: 1px solid var(--color-hairline);
  --hairline-inset:   inset 0 -1px 0 var(--color-hairline-soft);
}

/* ============================================================
   BASE RESET
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html, body {
  margin: 0;
  background: var(--color-canvas);
  color: var(--color-text-ink);
  font-family: var(--font-text);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
::selection { background: var(--color-ink); color: var(--color-on-primary); }
h1, h2, h3, h4, h5, h6 { margin: 0; }
p { margin: 0; }
ul { list-style: none; margin: 0; padding: 0; }

.wrap { max-width: var(--maxw); margin: 0 auto; width: 100%; }
.pad  { padding-left: var(--gutter); padding-right: var(--gutter); }

/* ============================================================
   TYPOGRAPHY HELPERS
   ============================================================ */
.display {
  font-family: var(--font-display);
  font-weight: 500;
  text-transform: uppercase;
  line-height: 0.86;
  letter-spacing: -0.005em;
  margin: 0;
}
.eyebrow {
  font: 500 12px/1 var(--font-text);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-text-mute);
  margin: 0;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-text);
  font-size: 16px;
  font-weight: 500;
  line-height: 1;
  padding: 16px 32px;
  height: 48px;
  border-radius: var(--radius-lg);
  border: 0;
  cursor: pointer;
  transition: transform 120ms ease, opacity 120ms ease;
  white-space: nowrap;
  text-decoration: none;
}
.btn:active { transform: scale(0.95); opacity: 0.7; }
.btn-primary   { background: var(--color-ink); color: var(--color-on-primary); }
.btn-secondary { background: var(--color-soft-cloud); color: var(--color-ink); }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: sticky; top: 0; z-index: 40;
  background: var(--color-canvas);
  box-shadow: var(--hairline-inset);
}
.nav-inner {
  height: 72px;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
}
.nav-links { display: flex; gap: 26px; align-items: center; }
.nav-links a {
  font: 500 13px/1 var(--font-text);
  letter-spacing: 0.04em;
  color: var(--color-ink);
  padding: 6px 0;
  border-bottom: 1.5px solid transparent;
  transition: border-color 120ms ease, opacity 120ms ease;
}
.nav-links a:hover { opacity: 0.55; }
.nav-links a.active { border-bottom-color: var(--color-ink); }

.brand-badge {
  justify-self: center;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1.5px solid var(--color-ink);
  border-radius: var(--radius-lg);
  padding: 8px 26px;
  font-family: var(--font-display);
  font-size: 26px; line-height: 1;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-ink);
}
.brand-badge .reg { font-size: 9px; vertical-align: super; margin-left: 2px; letter-spacing: 0; }
.brand-logo { justify-self: center; display: inline-flex; align-items: center; }
.brand-logo img { height: 44px; width: auto; display: block; max-width: 180px; }

/* WP custom logo */
.brand-logo .custom-logo-link { display: inline-flex; align-items: center; }
.brand-logo .custom-logo { height: 44px !important; width: auto !important; max-width: 180px; object-fit: contain; }

.nav-right { display: flex; gap: 4px; align-items: center; justify-self: end; }
.iconbtn {
  width: 42px; height: 42px; border-radius: var(--radius-full);
  background: transparent; border: 0; cursor: pointer; position: relative;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--color-ink);
  transition: background 120ms ease;
  text-decoration: none;
}
.iconbtn:hover { background: var(--color-soft-cloud); }
.iconbtn svg { width: 20px; height: 20px; stroke: currentColor; fill: none; stroke-width: 1.7; }
.iconbtn .count {
  position: absolute; top: 4px; right: 4px;
  min-width: 16px; height: 16px; padding: 0 4px;
  background: var(--color-ink); color: var(--color-on-primary);
  border-radius: var(--radius-full);
  font: 600 10px/16px var(--font-text); text-align: center;
}
.nav-burger { display: none; }

/* ============================================================
   HOME — HERO
   ============================================================ */
.hero {
  position: relative;
  background: var(--color-canvas);
  overflow: hidden;
  min-height: 86vh;
  display: flex; flex-direction: column; justify-content: center;
  padding: 60px var(--gutter) 40px;
}
.hero-bg { position: absolute; inset: 0; z-index: 0; background-size: cover; background-position: center top; }
.hero::after {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: rgba(17,17,17,0.04);
}
.hero-wordwrap {
  position: absolute; left: 0; right: 0; top: 50%;
  transform: translateY(-52%);
  display: grid; justify-items: center;
  z-index: 2; pointer-events: none; user-select: none;
}
.hero-wordwrap > * { grid-area: 1 / 1; margin: 0; text-align: center; }
.hero-layer {
  font-family: var(--font-display);
  font-weight: 500; text-transform: uppercase;
  font-size: 40vw; line-height: 0.8; letter-spacing: -0.01em;
}

.hero-glass {
  background-size: cover; background-position: center top;
  -webkit-background-clip: text; background-clip: text;
  color: transparent; -webkit-text-fill-color: transparent;
  filter: blur(11px) brightness(0.5) saturate(0.8) contrast(1.05);
  opacity: 0.7;
}
.hero-sheen {
  background: linear-gradient(176deg, rgba(255,255,255,0.40) 0%, rgba(255,255,255,0.04) 16%, rgba(17,17,17,0.30) 60%, rgba(17,17,17,0.46) 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent; -webkit-text-fill-color: transparent;
}
.hero-word {
  color: rgba(17,17,17,0.30);
  -webkit-text-stroke: 1.5px rgba(255,255,255,0.42);
  text-shadow: 0 10px 55px rgba(0,0,0,0.42), 0 0 1px rgba(255,255,255,0.30);
}
.hero-caustic {
  background: linear-gradient(118deg,
    transparent 34%,
    rgba(255,255,255,0.10) 42%,
    rgba(214,238,255,0.62) 49%,
    rgba(255,255,255,0.85) 50.5%,
    rgba(190,226,255,0.58) 52%,
    transparent 60%);
  background-size: 280% 280%;
  -webkit-background-clip: text; background-clip: text;
  color: transparent; -webkit-text-fill-color: transparent;
  mix-blend-mode: screen;
  background-position: 50% 50%;
}

.hero-foot {
  position: relative; z-index: 3;
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-top: auto; padding-top: 28px;
}
.hero-foot .tag {
  font-family: var(--font-display); font-size: clamp(20px,2.4vw,34px);
  line-height: 0.92; text-transform: uppercase;
  color: #fff;
}

/* ============================================================
   CATEGORY EDITORIAL BLOCKS
   ============================================================ */
.cat-grid { display: grid; grid-template-columns: 1fr 1fr; min-height: 74vh; }
.cat-block { position: relative; min-height: 78vh; }
.cat-media {
  background: var(--color-soft-cloud); position: relative; overflow: hidden;
}
.cat-media img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: center;
}
.cat-copy {
  display: flex; flex-direction: column; justify-content: center;
  padding: 64px clamp(40px,7vw,110px);
  position: relative;
}
.cat-copy .huge {
  font-family: var(--font-display); text-transform: uppercase;
  font-size: clamp(64px,10vw,150px); line-height: 0.82;
  color: var(--color-ink); margin: 0 0 28px; letter-spacing: -0.01em;
}
.cat-copy p {
  font: 400 15px/1.6 var(--font-text); color: var(--color-text-ash);
  max-width: 380px; margin: 0 0 32px;
}
.cat-copy.right .huge { text-align: right; }
.cat-copy.right { align-items: flex-end; text-align: right; }
.discover {
  display: inline-flex; align-items: center; gap: 12px;
  font: 500 14px/1 var(--font-text); letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--color-ink);
  border-bottom: 1.5px solid var(--color-ink); padding-bottom: 8px;
  width: fit-content;
}
.discover svg { width: 22px; height: 14px; stroke: currentColor; fill: none; stroke-width: 1.7; transition: transform 160ms ease; }
.discover:hover svg { transform: translateX(6px); }

/* ============================================================
   LOOKBOOK TEASER
   ============================================================ */
.lookband { background: var(--color-ink); color: var(--color-on-primary); padding: 70px var(--gutter) 0; overflow: hidden; }
.lookband-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 40px; max-width: var(--maxw); margin: 0 auto; }
.lookband-top h3 { font: 500 22px/1.2 var(--font-text); text-transform: uppercase; letter-spacing: 0.02em; margin: 0; max-width: 340px; }
.lookband-top .meta { display: flex; align-items: flex-start; gap: 40px; }
.lookband-top .meta p { font: 400 14px/1.5 var(--font-text); color: #b9b9bb; max-width: 320px; margin: 0; }
.lookband .social { display: flex; gap: 10px; }
.lookband .social a {
  width: 38px; height: 38px; border-radius: var(--radius-full);
  border: 1px solid #3a3a3c; display: inline-flex; align-items: center; justify-content: center;
  color: var(--color-on-primary);
}
.lookband .social svg { width: 17px; height: 17px; stroke: currentColor; fill: none; stroke-width: 1.6; }
.lookband-word {
  font-family: var(--font-display); text-transform: uppercase;
  font-size: 22vw; line-height: 0.82; text-align: center; color: var(--color-on-primary);
  margin: 18px 0 -2vw; letter-spacing: -0.01em; position: relative; z-index: 2;
}
.lookband-figs { display: grid; grid-template-columns: repeat(3,1fr); gap: 0; max-width: var(--maxw); margin: 0 auto; position: relative; z-index: 3; }
.lookband-figs img, .lookband-figs .lb-fig { width: 100%; aspect-ratio: 3/4.3; object-fit: cover; background: #1a1a1a; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: var(--color-ink); color: var(--color-on-primary); padding: 56px var(--gutter) 28px; }
.footer-inner { max-width: var(--maxw); margin: 0 auto; }
.footer-badge-row { display: flex; align-items: center; gap: 24px; padding-bottom: 36px; }
.footer-badge-row .line { flex: 1; height: 1px; background: #343436; }
.footer-badge {
  display: inline-flex; align-items: center; justify-content: center;
  border: 1.5px solid var(--color-on-primary); border-radius: var(--radius-lg);
  padding: 9px 30px; font-family: var(--font-display); font-size: 28px;
  letter-spacing: 0.14em; line-height: 1; color: var(--color-on-primary);
}
.footer-logo { display: inline-flex; align-items: center; }
.footer-logo img, .footer-logo .custom-logo { height: 40px; width: auto; display: block; filter: invert(1) brightness(2); }
.footer-logo .custom-logo-link { display: inline-flex; }
.footer-cols { display: flex; justify-content: space-between; gap: 40px; flex-wrap: wrap; padding-bottom: 40px; }
.footer-cols .grp h4 { font: 500 12px/1 var(--font-text); text-transform: uppercase; letter-spacing: 0.12em; margin: 0 0 16px; color: #9e9ea0; }
.footer-cols .grp a { display: block; font: 400 14px/2.2 var(--font-text); color: #d6d6d8; }
.footer-cols .grp a:hover { color: var(--color-on-primary); }
.footer-news { max-width: 320px; }
.footer-news p { font: 400 13px/1.5 var(--font-text); color: #b9b9bb; margin: 0 0 14px; }
.footer-news .field { display: flex; border-bottom: 1px solid #4a4a4c; }
.footer-news input { flex: 1; background: transparent; border: 0; outline: 0; color: #fff; font: 400 14px/1 var(--font-text); padding: 10px 0; }
.footer-news input::placeholder { color: #7a7a7c; }
.footer-news button { background: transparent; border: 0; color: #fff; cursor: pointer; font-family: var(--font-display); font-size: 18px; letter-spacing: 0.06em; }
.footer-legal { display: flex; justify-content: space-between; align-items: center; padding-top: 22px; border-top: 1px solid #2c2c2e; font: 500 11px/1.5 var(--font-text); color: #8a8a8c; flex-wrap: wrap; gap: 12px; }
.footer-legal .lr { display: flex; gap: 22px; }

/* ============================================================
   PLP — PRODUCT LISTING
   ============================================================ */
.plp-head { padding: 40px var(--gutter) 20px; max-width: var(--maxw); margin: 0 auto; }
.crumb { font: 500 12px/1 var(--font-text); letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-text-mute); margin: 0 0 18px; }
.crumb .ink, .crumb a { color: var(--color-ink); }
.plp-title { font-family: var(--font-display); text-transform: uppercase; font-size: clamp(56px,9vw,120px); line-height: 0.82; margin: 0; color: var(--color-ink); }
.plp-sub { font: 400 15px/1.6 var(--font-text); color: var(--color-text-ash); max-width: 520px; margin: 18px 0 0; }

.subbar {
  position: sticky; top: 72px; z-index: 20;
  background: var(--color-canvas);
  box-shadow: var(--hairline-inset);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 var(--gutter); height: 54px;
}
.subbar .count { font: 500 14px/1 var(--font-text); color: var(--color-text-mute); }
.subbar .count p { display: inline; }
.subbar .acts { display: flex; align-items: center; gap: 8px; }
.subbar .ghost {
  display: inline-flex; align-items: center; gap: 8px;
  font: 500 14px/1 var(--font-text); color: var(--color-ink);
  background: transparent; border: 0; cursor: pointer; padding: 8px 6px;
}
.subbar .ghost svg { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 1.7; }
/* WooCommerce ordering select */
.woocommerce-ordering select, .subbar select {
  font: 500 14px/1 var(--font-text); color: var(--color-ink);
  border: 0; background: transparent; cursor: pointer; padding: 8px 4px;
}

.plp-body { display: grid; grid-template-columns: 220px 1fr; gap: 32px; padding: 24px var(--gutter) 0; max-width: var(--maxw); margin: 0 auto; }

/* Filters */
.filters .fg { padding: 20px 0; border-bottom: 1px solid var(--color-hairline); }
.filters .fg:first-child { padding-top: 4px; }
.filters .fg h5 { font: 500 13px/1 var(--font-text); text-transform: uppercase; letter-spacing: 0.1em; margin: 0 0 16px; }
.filters .opt {
  display: flex; align-items: center; gap: 10px; cursor: pointer;
  padding: 5px 0; font: 400 14px/1.4 var(--font-text); color: var(--color-text-charcoal);
  text-decoration: none;
}
.filters .opt:hover { color: var(--color-ink); }
.filters .box { width: 16px; height: 16px; border: 1.5px solid var(--color-hairline); flex: none; display: inline-flex; align-items: center; justify-content: center; }
.filters .opt.on .box { background: var(--color-ink); border-color: var(--color-ink); }
.filters .opt.on .box::after { content:""; width: 8px; height: 4px; border: 2px solid #fff; border-top: 0; border-right: 0; transform: rotate(-45deg) translateY(-1px); }
.filters .clear { background: transparent; border: 0; cursor: pointer; font: 500 13px/1 var(--font-text); text-decoration: underline; color: var(--color-text-mute); padding: 16px 0 4px; display: block; }

/* Product grid */
.pgrid { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px 18px; align-content: start; }

/* ============================================================
   PRODUCT CARD
   ============================================================ */
.card { display: flex; flex-direction: column; cursor: pointer; }
.card .media { position: relative; aspect-ratio: 3/3.6; background: var(--color-soft-cloud); overflow: hidden; }
.card .media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.card .flag { position: absolute; top: 12px; left: 12px; z-index: 3; background: var(--color-canvas); border: 1px solid var(--color-hairline); border-radius: var(--radius-lg); padding: 5px 12px; font: 500 11px/1.3 var(--font-text); letter-spacing: 0.04em; text-transform: uppercase; }
.card .wish { position: absolute; top: 10px; right: 10px; z-index: 3; width: 34px; height: 34px; border-radius: var(--radius-full); background: var(--color-canvas); border: 0; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; }
.card .wish svg { width: 17px; height: 17px; stroke: var(--color-ink); fill: none; stroke-width: 1.6; }
.card .wish.on svg { fill: var(--color-ink); }
.card .quickadd {
  position: absolute; left: 12px; right: 12px; bottom: 12px; z-index: 3;
  background: var(--color-ink); color: var(--color-on-primary);
  border: 0; border-radius: var(--radius-lg); height: 44px; cursor: pointer;
  font: 500 13px/1 var(--font-text); letter-spacing: 0.06em; text-transform: uppercase;
  opacity: 0; transform: translateY(8px); transition: opacity 160ms ease, transform 160ms ease;
  display: flex; align-items: center; justify-content: center; text-decoration: none;
}
.card:hover .quickadd { opacity: 1; transform: translateY(0); }
.card .quickadd:active { transform: scale(0.97); opacity: 0.8; }
/* WooCommerce ajax add to cart button */
.card .add_to_cart_button.loading { opacity: 0.6; }
.card .add_to_cart_button.added { background: var(--color-success); }

.card .meta { padding-top: 14px; display: flex; flex-direction: column; gap: 4px; text-decoration: none; color: inherit; }
.card .dots { display: flex; gap: 5px; margin-bottom: 6px; }
.card .dots .d { width: 11px; height: 11px; border-radius: var(--radius-full); box-shadow: 0 0 0 1px var(--color-hairline); }
.card .nm { font: 500 15px/1.3 var(--font-text); color: var(--color-ink); }
.card .ct { font: 400 13px/1.4 var(--font-text); color: var(--color-text-mute); }
.card .pr { font: 500 15px/1.4 var(--font-text); color: var(--color-ink); margin-top: 2px; }
.card .pr del { color: var(--color-text-stone); font-weight: 400; }
.card .pr ins { text-decoration: none; color: var(--color-sale); }

.empty { grid-column: 1/-1; padding: 80px 0; text-align: center; color: var(--color-text-mute); font: 400 15px/1.5 var(--font-text); }

/* WooCommerce pagination */
.woocommerce-pagination { padding: 40px var(--gutter); text-align: center; }
.woocommerce-pagination .page-numbers { display: inline-flex; gap: 8px; align-items: center; list-style: none; padding: 0; margin: 0; }
.woocommerce-pagination .page-numbers li { display: inline-flex; }
.woocommerce-pagination .page-numbers a, .woocommerce-pagination .page-numbers span {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 40px; height: 40px; padding: 0 8px;
  border: 1px solid var(--color-hairline); border-radius: var(--radius-lg);
  font: 500 14px/1 var(--font-text); color: var(--color-ink);
  transition: background 120ms;
}
.woocommerce-pagination .page-numbers a:hover { background: var(--color-soft-cloud); }
.woocommerce-pagination .page-numbers .current { background: var(--color-ink); color: var(--color-on-primary); border-color: var(--color-ink); }

/* ============================================================
   CART DRAWER
   ============================================================ */
.scrim { position: fixed; inset: 0; background: rgba(17,17,17,0.4); z-index: 60; opacity: 0; pointer-events: none; transition: opacity 200ms ease; }
.scrim.show { opacity: 1; pointer-events: auto; }
.drawer {
  position: fixed; top: 0; right: 0; bottom: 0; width: min(440px,100vw); z-index: 70;
  background: var(--color-canvas); transform: translateX(100%);
  transition: transform 280ms cubic-bezier(0.22,1,0.36,1);
  display: flex; flex-direction: column;
}
.drawer.show { transform: translateX(0); }
.drawer-head { display: flex; align-items: center; justify-content: space-between; padding: 22px 24px; box-shadow: var(--hairline-inset); }
.drawer-head h3 { font-family: var(--font-display); font-size: 26px; letter-spacing: 0.04em; text-transform: uppercase; margin: 0; }
.drawer-items { flex: 1; overflow-y: auto; padding: 8px 24px; }

/* WooCommerce mini-cart styled as HUS cart items */
.woocommerce-mini-cart { list-style: none; margin: 0; padding: 0; }
.woocommerce-mini-cart-item.mini_cart_item {
  display: grid; grid-template-columns: 76px 1fr; gap: 14px;
  padding: 20px 0; border-bottom: 1px solid var(--color-hairline);
  position: relative;
}
.woocommerce-mini-cart-item img { width: 76px; height: 90px; object-fit: cover; background: var(--color-soft-cloud); display: block; }
.woocommerce-mini-cart-item a:not(.remove_from_cart_button) { font: 500 14px/1.3 var(--font-text); color: var(--color-ink); display: block; margin-bottom: 4px; }
.woocommerce-mini-cart-item .quantity { font: 400 13px/1.5 var(--font-text); color: var(--color-text-mute); }
.woocommerce-mini-cart-item .remove_from_cart_button {
  position: absolute; top: 20px; right: 0;
  font: 500 12px/1 var(--font-text); color: var(--color-text-mute);
  text-decoration: underline; background: none; border: none;
  cursor: pointer; padding: 0;
}
.woocommerce-mini-cart-item .remove_from_cart_button:hover { color: var(--color-ink); }
.woocommerce-mini-cart__total { padding: 16px 0 8px; font: 500 16px/1 var(--font-text); display: flex; justify-content: space-between; border-top: 1px solid var(--color-hairline); margin-top: 8px; }
.woocommerce-mini-cart__buttons { display: none; }

.drawer-empty { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 18px; padding: 40px; text-align: center; }
.drawer-empty svg { width: 48px; height: 48px; stroke: var(--color-text-stone); fill: none; stroke-width: 1.4; }
.drawer-empty p { font: 400 15px/1.5 var(--font-text); color: var(--color-text-mute); margin: 0; }
.drawer-foot { padding: 20px 24px 24px; box-shadow: 0 -1px 0 var(--color-hairline-soft); }
.drawer-foot .row { display: flex; justify-content: space-between; font: 500 16px/1 var(--font-text); margin-bottom: 8px; }
.drawer-foot .note { font: 400 12px/1.4 var(--font-text); color: var(--color-text-mute); margin: 0 0 16px; }
.drawer-foot .btn { width: 100%; }

/* ============================================================
   TOAST
   ============================================================ */
.toast { position: fixed; left: 50%; bottom: 30px; transform: translate(-50%,20px); z-index: 90; background: var(--color-ink); color: var(--color-on-primary); padding: 14px 22px; border-radius: var(--radius-lg); font: 500 14px/1 var(--font-text); opacity: 0; pointer-events: none; transition: opacity 200ms ease, transform 200ms ease; display: flex; align-items: center; gap: 10px; }
.toast.show { opacity: 1; transform: translate(-50%,0); }
.toast svg { width: 18px; height: 18px; stroke: var(--color-success-bright); fill: none; stroke-width: 2; }

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.about-hero { padding: 80px var(--gutter) 60px; max-width: var(--maxw); margin: 0 auto; }
.about-hero .eyebrow { margin-bottom: 24px; }
.about-hero h1 { font-family: var(--font-display); text-transform: uppercase; font-size: clamp(60px,11vw,200px); line-height: 0.8; margin: 0; letter-spacing: -0.01em; }
.about-hero .lede { font: 400 clamp(18px,2.2vw,26px)/1.45 var(--font-text); color: var(--color-text-charcoal); max-width: 760px; margin: 32px 0 0; }
.about-media { width: 100%; aspect-ratio: 16/7; background: var(--color-soft-cloud); overflow: hidden; }
.about-media img { width: 100%; height: 100%; object-fit: cover; }
.about-sec { padding: 70px var(--gutter); max-width: var(--maxw); margin: 0 auto; }
.about-2col { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(32px,7vw,100px); align-items: start; }
.about-2col h2 { font-family: var(--font-display); text-transform: uppercase; font-size: clamp(38px,5.5vw,80px); line-height: 0.84; margin: 0; }
.about-2col .body p { font: 400 16px/1.7 var(--font-text); color: var(--color-text-ash); margin: 0 0 20px; max-width: 560px; }
.about-2col .body p strong { color: var(--color-ink); font-weight: 600; }
.pull { background: var(--color-ink); color: var(--color-on-primary); padding: 90px var(--gutter); }
.pull .inner { max-width: 1100px; margin: 0 auto; }
.pull .eyebrow { color: #9e9ea0; margin-bottom: 28px; }
.pull .q { font-family: var(--font-display); text-transform: uppercase; font-size: clamp(40px,6vw,92px); line-height: 0.86; display: block; }
.sustain-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: 36px; }
.sustain-grid .card-s { border: 1px solid var(--color-hairline); padding: 28px 26px; }
.sustain-grid .card-s .ic { width: 40px; height: 40px; stroke: var(--color-ink); fill: none; stroke-width: 1.4; margin-bottom: 20px; }
.sustain-grid .card-s h4 { font: 500 16px/1.3 var(--font-text); margin: 0 0 10px; }
.sustain-grid .card-s p { font: 400 14px/1.6 var(--font-text); color: var(--color-text-ash); margin: 0; }

/* ============================================================
   LOOKBOOK PAGE
   ============================================================ */
.lb-hero { padding: 70px var(--gutter) 30px; max-width: var(--maxw); margin: 0 auto; }
.lb-hero .eyebrow { margin-bottom: 20px; }
.lb-hero h1 { font-family: var(--font-display); text-transform: uppercase; font-size: clamp(64px,16vw,280px); line-height: 0.78; margin: 0; letter-spacing: -0.01em; }
.lb-hero p { font: 400 16px/1.6 var(--font-text); color: var(--color-text-ash); max-width: 520px; margin: 26px 0 0; }
.lb-grid { padding: 30px var(--gutter) 60px; max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: repeat(12,1fr); gap: 14px; }
.lb-cell { position: relative; background: var(--color-soft-cloud); overflow: hidden; }
.lb-cell img { width: 100%; height: 100%; object-fit: cover; display: block; }
.lb-cell .cap { position: absolute; left: 18px; bottom: 16px; z-index: 2; color: #fff; mix-blend-mode: difference; font: 500 12px/1.3 var(--font-text); text-transform: uppercase; letter-spacing: 0.08em; }
.span-7 { grid-column: span 7; } .span-5 { grid-column: span 5; }
.span-6 { grid-column: span 6; } .span-4 { grid-column: span 4; }
.span-8 { grid-column: span 8; } .span-12 { grid-column: span 12; }
.ar-43 { aspect-ratio: 4/3; } .ar-34 { aspect-ratio: 3/4; }
.ar-11 { aspect-ratio: 1/1; } .ar-169 { aspect-ratio: 16/8; }

/* ============================================================
   SINGLE PRODUCT PAGE
   ============================================================ */
.sp-page { padding: 0 0 80px; }
.sp-wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter); }

.sp-crumb { padding: 24px 0 0; }
.sp-crumb .woocommerce-breadcrumb,
.sp-crumb .crumb {
    font: 500 12px/1 var(--font-text);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-text-mute);
}
.sp-crumb a { color: var(--color-ink); }

/* Two-column grid: gallery | info */
.sp-grid {
    display: grid;
    grid-template-columns: 3fr 2fr;
    gap: 60px;
    padding: 32px 0 48px;
    align-items: start;
}
.sp-left-col { display: flex; flex-direction: column; }

/* ---- Gallery (left column) ---- */
.sp-gallery .woocommerce-product-gallery { position: relative; margin: 0; }
.sp-gallery .woocommerce-product-gallery,
.sp-gallery .woocommerce-product-gallery__wrapper { width: 100%; }

/* WooCommerce sets opacity:0 during load, JS sets it to 1 after init */
.sp-gallery .woocommerce-product-gallery--is-loading { opacity: 0; }

/* Zoom + Photoswipe disabled — hide any remnants */
.zoomImg { display: none !important; }
.woocommerce-product-gallery__trigger { display: none !important; }
.pswp { display: none !important; }

/* ============================================================
   CUSTOM LIGHTBOX
   ============================================================ */
#hus-lb {
  display: none;
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,0.92);
  align-items: center; justify-content: center;
  cursor: zoom-out;
}
#hus-lb.open { display: flex; }
#hus-lb-img {
  max-width: 90vw; max-height: 90vh;
  object-fit: contain; display: block;
  cursor: default;
  transition: opacity 200ms ease;
  user-select: none;
}
#hus-lb-close {
  position: absolute; top: 20px; right: 24px;
  background: transparent; border: 0; color: #fff;
  font-size: 28px; line-height: 1; cursor: pointer;
  opacity: 0.7; transition: opacity 120ms;
  padding: 4px 8px; z-index: 2;
}
#hus-lb-close:hover { opacity: 1; }
#hus-lb-prev, #hus-lb-next {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: transparent; border: 0; color: #fff;
  font-size: 56px; line-height: 1; cursor: pointer;
  opacity: 0.55; transition: opacity 120ms;
  padding: 8px 20px; user-select: none; z-index: 2;
}
#hus-lb-prev { left: 12px; }
#hus-lb-next { right: 12px; }
#hus-lb-prev:hover, #hus-lb-next:hover { opacity: 1; }
@media (max-width: 600px) {
  #hus-lb-prev, #hus-lb-next { font-size: 40px; padding: 6px 12px; }
}
#hus-lb-loader {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  width: 32px; height: 32px;
  border: 2px solid rgba(255,255,255,0.2);
  border-top-color: #fff;
  border-radius: 50%;
  display: none;
}
#hus-lb.loading #hus-lb-loader { display: block; animation: husLbSpin 0.7s linear infinite; }
@keyframes husLbSpin { to { transform: translate(-50%,-50%) rotate(360deg); } }
/* Flexslider reset so our CSS controls the layout */
.sp-gallery .flexslider { margin: 0; padding: 0; border: 0; background: transparent; box-shadow: none; }
.sp-gallery .flex-viewport { max-height: none; }
.sp-gallery .flex-direction-nav { display: none; }

.sp-gallery .woocommerce-product-gallery__image { display: block; background: var(--color-soft-cloud); }
.sp-gallery .woocommerce-product-gallery__image img {
    width: 100%;
    display: block;
    object-fit: cover;
    background: var(--color-soft-cloud);
}
/* Thumbnail strip */
.sp-gallery .flex-control-nav {
    display: flex; flex-wrap: wrap; gap: 8px;
    list-style: none; padding: 10px 0 0; margin: 0;
}
.sp-gallery .flex-control-nav li { flex: 0 0 calc(25% - 6px); }
.sp-gallery .flex-control-nav li img {
    width: 100%; aspect-ratio: 1;
    object-fit: cover; cursor: pointer;
    opacity: 0.55; transition: opacity 140ms;
    display: block;
}
.sp-gallery .flex-control-nav li img.flex-active { opacity: 1; }

/* ---- Info panel (right column) ---- */
.sp-info { display: flex; flex-direction: column; gap: 0; }

/* WooCommerce single product summary hooks output */
.sp-info .woocommerce-product-rating { margin: 0 0 12px; }
.sp-info .woocommerce-review-link { font: 400 12px/1 var(--font-text); color: var(--color-text-mute); }

/* Product title */
.sp-info h1.product_title {
    font-family: var(--font-display);
    text-transform: uppercase;
    font-size: clamp(32px, 4.5vw, 60px);
    line-height: 0.88;
    margin: 0 0 16px;
    color: var(--color-ink);
}

/* Price */
.sp-info .price {
    font: 500 22px/1 var(--font-text);
    color: var(--color-ink);
    margin: 0 0 20px;
    display: block;
}
.sp-info .price del { color: var(--color-text-stone); font-weight: 400; font-size: 16px; margin-right: 8px; }
.sp-info .price ins { text-decoration: none; color: var(--color-sale); }

/* Short description */
.sp-info .woocommerce-product-details__short-description {
    font: 400 14px/1.7 var(--font-text);
    color: var(--color-text-ash);
    margin: 0 0 24px;
}
.sp-info .woocommerce-product-details__short-description p { margin: 0 0 10px; }

/* Variations table */
.sp-info .variations_form .variations {
    width: 100%; border: 0; border-collapse: collapse; margin: 0 0 16px;
}
.sp-info .variations_form .variations tr {
    display: flex; flex-direction: column; margin-bottom: 18px;
}
.sp-info .variations_form .variations .label {
    font: 500 11px/1 var(--font-text);
    text-transform: uppercase; letter-spacing: 0.1em;
    color: var(--color-text-mute);
    padding: 0 0 10px; border: 0; text-align: left;
}
.sp-info .variations_form .variations .value { border: 0; padding: 0; }

/* Variation select dropdowns */
.sp-info .variations_form .variations select {
    width: 100%; height: 50px;
    border: 1.5px solid var(--color-hairline);
    border-radius: var(--radius-lg);
    padding: 0 44px 0 18px;
    font: 500 14px/1 var(--font-text);
    color: var(--color-ink);
    background: transparent;
    cursor: pointer;
    appearance: none; -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6 9l6 6 6-6' fill='none' stroke='%23111111' stroke-width='1.7' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 16px center;
    background-size: 18px;
}
.sp-info .variations_form .variations select:focus { border-color: var(--color-ink); outline: none; }

/* Color/image swatches (cfvsw plugin) */
.cfvsw-swatches-container { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 4px; }
.cfvsw-swatch-item {
    height: 40px; min-width: 40px; padding: 0 14px;
    border: 1.5px solid var(--color-hairline);
    border-radius: var(--radius-lg);
    display: inline-flex; align-items: center; justify-content: center;
    font: 500 13px/1 var(--font-text);
    cursor: pointer; transition: border-color 120ms, border-width 120ms;
    text-transform: uppercase; letter-spacing: 0.04em;
}
.cfvsw-swatch-item:hover { border-color: var(--color-ink); }
.cfvsw-swatch-item.cfvsw-selected,
.cfvsw-swatch-item.selected { border-color: var(--color-ink); border-width: 2px; }
.cfvsw-swatch-item.cfvsw-disabled { opacity: 0.35; cursor: not-allowed; text-decoration: line-through; }
/* Color dot swatches */
.cfvsw-swatch-item.cfvsw-color-type {
    width: 36px; height: 36px; min-width: 36px; padding: 0;
    border-radius: var(--radius-full);
}

/* Reset variation link */
.sp-info .reset_variations {
    font: 500 11px/1 var(--font-text);
    color: var(--color-text-mute);
    text-decoration: underline;
    cursor: pointer;
    display: inline-block;
    margin-top: 6px;
}

/* Stock notice */
.sp-info .stock { font: 500 13px/1 var(--font-text); margin: 0 0 16px; }
.sp-info .in-stock { color: var(--color-success); }
.sp-info .out-of-stock { color: var(--color-sale); }

/* Variation price update */
.sp-info .woocommerce-variation-price .price { margin: 0 0 16px; }
.sp-info .woocommerce-variation-availability .stock { margin: 0 0 16px; }

/* Quantity + Add to cart row */
.sp-info form.cart { display: flex; gap: 12px; align-items: center; margin: 20px 0 24px; flex-wrap: wrap; }
.sp-info .quantity { display: flex; }
.sp-info .quantity .qty {
    width: 80px; height: 54px;
    border: 1.5px solid var(--color-hairline);
    border-radius: var(--radius-lg);
    font: 500 16px/1 var(--font-text);
    text-align: center; background: transparent; color: var(--color-ink);
    -moz-appearance: textfield;
}
.sp-info .quantity .qty::-webkit-inner-spin-button { -webkit-appearance: none; }
.sp-info .single_add_to_cart_button {
    flex: 1; height: 54px; min-width: 180px;
    background: var(--color-ink); color: var(--color-on-primary);
    border: 0; border-radius: var(--radius-lg);
    font: 500 14px/1 var(--font-text); letter-spacing: 0.08em;
    text-transform: uppercase; cursor: pointer;
    transition: opacity 120ms ease;
}
.sp-info .single_add_to_cart_button:hover { opacity: 0.82; }
.sp-info .single_add_to_cart_button.loading { opacity: 0.6; pointer-events: none; }

/* Product meta (SKU, categories) */
.sp-info .product_meta {
    margin-top: 20px; padding-top: 20px;
    border-top: 1px solid var(--color-hairline);
    font: 400 12px/1.8 var(--font-text);
    color: var(--color-text-mute);
}
.sp-info .product_meta span { display: block; }
.sp-info .product_meta a { color: var(--color-ink); }

/* ---- Below grid: tabs ---- */
.sp-below { margin-top: 0; }

/* ---- After summary: tabs + related ---- */
.woocommerce-tabs {
    border-top: 1px solid var(--color-hairline);
    margin-top: 0; padding-bottom: 40px;
}
.woocommerce-tabs ul.tabs {
    display: flex; list-style: none; padding: 0; margin: 0;
    border-bottom: 1px solid var(--color-hairline);
    background: transparent;
}
.woocommerce-tabs ul.tabs::before { display: none; }
.woocommerce-tabs ul.tabs li {
    background: transparent; border: 0;
    border-radius: 0; margin: 0; padding: 0;
}
.woocommerce-tabs ul.tabs li::before,
.woocommerce-tabs ul.tabs li::after { display: none; }
.woocommerce-tabs ul.tabs li a {
    display: block; padding: 18px 28px;
    font: 500 12px/1 var(--font-text);
    letter-spacing: 0.1em; text-transform: uppercase;
    color: var(--color-text-mute);
    border-bottom: 2px solid transparent;
    transition: color 120ms, border-color 120ms;
}
.woocommerce-tabs ul.tabs li.active a,
.woocommerce-tabs ul.tabs li a:hover { color: var(--color-ink); border-bottom-color: var(--color-ink); }
.woocommerce-tabs .panel { padding: 32px 0; max-width: 720px; }
.woocommerce-tabs .panel h2 { font-family: var(--font-display); text-transform: uppercase; font-size: 28px; margin: 0 0 20px; }
.woocommerce-tabs .panel p { font: 400 15px/1.7 var(--font-text); color: var(--color-text-ash); margin-bottom: 14px; }
.woocommerce-tabs .panel table { width: 100%; border-collapse: collapse; }
.woocommerce-tabs .panel table th,
.woocommerce-tabs .panel table td { padding: 10px 0; border-bottom: 1px solid var(--color-hairline); font: 400 14px/1.5 var(--font-text); text-align: left; }
.woocommerce-tabs .panel table th { font-weight: 500; color: var(--color-text-mute); width: 180px; }

/* Related + upsell products */
.related.products, .upsells.products {
    margin-top: 60px; padding-top: 40px;
    border-top: 1px solid var(--color-hairline);
}
.related.products > h2, .upsells.products > h2 {
    font-family: var(--font-display); text-transform: uppercase;
    font-size: clamp(28px, 4vw, 48px); line-height: 0.88; margin: 0 0 28px;
}
.related.products ul.products,
.upsells.products ul.products {
    display: grid; grid-template-columns: repeat(4,1fr);
    gap: 8px 18px; list-style: none; padding: 0; margin: 0;
}
/* Use existing .card styles for related product items */
.related.products ul.products li.product,
.upsells.products ul.products li.product { display: flex; flex-direction: column; }
.related.products ul.products li.product a img,
.upsells.products ul.products li.product a img {
    width: 100%; aspect-ratio: 3/3.6; object-fit: cover;
    background: var(--color-soft-cloud); display: block; margin-bottom: 12px;
}
.related.products ul.products li.product .woocommerce-loop-product__title,
.upsells.products ul.products li.product .woocommerce-loop-product__title {
    font: 500 15px/1.3 var(--font-text); color: var(--color-ink); margin: 0 0 4px;
}
.related.products ul.products li.product .price,
.upsells.products ul.products li.product .price { font: 500 14px/1 var(--font-text); color: var(--color-ink); }

/* Responsive */
@media (max-width: 900px) {
    .sp-grid { grid-template-columns: 1fr; gap: 24px; padding-top: 20px; }
    .related.products ul.products, .upsells.products ul.products { grid-template-columns: repeat(2,1fr); }
}

/* ============================================================
   AUTH / WooCommerce Account
   ============================================================ */
.woocommerce-account .woocommerce,
.woocommerce-page .woocommerce { max-width: 600px; margin: 80px auto; padding: 0 var(--gutter); }
.woocommerce form .form-row label { font: 500 11px/1 var(--font-text); text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-text-mute); display: block; margin-bottom: 8px; }
.woocommerce form .form-row input { width: 100%; height: 50px; border: 0; border-bottom: 1.5px solid var(--color-hairline); background: transparent; font: 400 16px/1 var(--font-text); color: var(--color-ink); outline: none; }
.woocommerce form .form-row input:focus { border-bottom-color: var(--color-ink); }
.woocommerce-button, .woocommerce form .button { display: inline-flex; align-items: center; justify-content: center; background: var(--color-ink); color: var(--color-on-primary); border: 0; border-radius: var(--radius-lg); height: 48px; padding: 0 32px; font: 500 16px/1 var(--font-text); cursor: pointer; }

/* ============================================================
   SINGLE PRODUCT
   ============================================================ */
.woocommerce-page div.product { display: block; padding: 0; max-width: none; margin: 0; }
.woocommerce-page div.product .woocommerce-product-gallery { position: relative; }
.woocommerce-page div.product .woocommerce-product-gallery__image img { width: 100%; aspect-ratio: 3/3.6; object-fit: cover; background: var(--color-soft-cloud); }
.woocommerce-page div.product .entry-summary { display: flex; flex-direction: column; gap: 16px; }
.woocommerce-page div.product h1 { font-family: var(--font-display); text-transform: uppercase; font-size: clamp(36px,5vw,72px); line-height: 0.88; }
.woocommerce-page div.product .price { font: 500 22px/1 var(--font-text); }
.woocommerce-page div.product .price del { color: var(--color-text-stone); font-weight: 400; }
.woocommerce-page div.product .price ins { text-decoration: none; color: var(--color-sale); }
.woocommerce-page div.product .woocommerce-product-details__short-description { font: 400 15px/1.6 var(--font-text); color: var(--color-text-ash); }
.woocommerce-page div.product form.cart .single_add_to_cart_button { background: var(--color-ink); color: var(--color-on-primary); border: 0; border-radius: var(--radius-lg); height: 54px; padding: 0 32px; font: 500 16px/1 var(--font-text); cursor: pointer; width: 100%; }
.woocommerce-page div.product form.cart .qty { height: 50px; border: 1.5px solid var(--color-hairline); border-radius: var(--radius-lg); padding: 0 16px; font: 500 16px/1 var(--font-text); width: 80px; text-align: center; background: transparent; }
.woocommerce-page div.product .woocommerce-variation-add-to-cart { display: flex; gap: 12px; align-items: center; }
.woocommerce-page div.product table.variations { width: 100%; border: 0; }
.woocommerce-page div.product table.variations th { font: 500 11px/1 var(--font-text); text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-text-mute); padding: 0 0 12px; text-align: left; }
.woocommerce-page div.product table.variations td select { border: 1.5px solid var(--color-hairline); border-radius: var(--radius-lg); padding: 10px 16px; font: 500 14px/1 var(--font-text); background: transparent; width: 100%; cursor: pointer; }

/* ============================================================
   RESPONSIVE — TABLET (max 1100px)
   ============================================================ */
@media (max-width: 1100px) {
  .sp-grid { grid-template-columns: 3fr 2fr; gap: 40px; }
  .cat-copy .huge { font-size: clamp(52px, 8vw, 120px); }
  .plp-body { grid-template-columns: 190px 1fr; gap: 24px; }
  .pgrid { grid-template-columns: repeat(2, 1fr); gap: 8px 14px; }
  .lookband-top { flex-direction: column; gap: 20px; }
  .lookband-top .meta { flex-direction: column; gap: 16px; }
  .footer-cols { gap: 24px; }
  .sp-info h1.product_title { font-size: clamp(28px, 3.5vw, 52px); }
  .about-2col { gap: clamp(24px, 5vw, 60px); }
  .lb-grid { gap: 10px; }
}

/* ============================================================
   RESPONSIVE — MOBILE (max 900px)
   ============================================================ */
@media (max-width: 900px) {
  :root { --gutter: 20px; }

  /* Nav */
  .nav-inner { grid-template-columns: auto 1fr auto; }
  .nav-links { display: none; }
  .nav-burger { display: inline-flex; }

  /* Hero — show full image width on mobile, JS sets the height */
  .hero { min-height: 50vw; padding: 40px var(--gutter) 28px; }
  .hero-bg { background-size: 100% auto; background-position: top center; }
  .hero-layer { font-size: 38vw; }
  .hero-foot .tag { font-size: clamp(16px, 4vw, 26px); }

  /* Category blocks */
  .cat-grid { grid-template-columns: 1fr; min-height: 0; }
  .cat-block { min-height: 0; }
  .cat-media { aspect-ratio: 3/3.4; }
  .cat-copy { padding: 36px var(--gutter); }
  .cat-copy .huge { font-size: clamp(52px, 14vw, 100px); }
  .cat-copy.right { align-items: flex-start; text-align: left; }

  /* PLP */
  .plp-body { grid-template-columns: 1fr; }
  .plp-title { font-size: clamp(44px, 12vw, 90px); }
  .filters { display: none; }
  .filters.open {
    display: block; position: fixed; inset: 0; z-index: 80;
    background: var(--color-canvas); overflow-y: auto; padding: 80px 24px 24px;
  }
  .pgrid { grid-template-columns: repeat(2, 1fr); gap: 6px 12px; }

  /* Single product */
  .sp-grid { grid-template-columns: 1fr; gap: 24px; padding-top: 20px; }
  .sp-left-col { width: 100%; }
  .sp-info h1.product_title { font-size: clamp(28px, 8vw, 52px); }
  .related.products ul.products, .upsells.products ul.products { grid-template-columns: repeat(2, 1fr); }

  /* About */
  .about-2col { grid-template-columns: 1fr; gap: 28px; }
  .sustain-grid { grid-template-columns: 1fr; }
  .about-hero h1 { font-size: clamp(52px, 14vw, 140px); }

  /* Lookbook page */
  .lb-grid > * { grid-column: span 12 !important; }
  .lb-hero h1 { font-size: clamp(52px, 20vw, 180px); }

  /* Lookband */
  .lookband-top { flex-direction: column; gap: 20px; }
  .lookband-top .meta { flex-direction: column; gap: 16px; }
  .lookband-figs { grid-template-columns: 1fr; }
  .lookband-figs img:nth-child(n+2) { display: none; }
  .lookband-word { font-size: 28vw; }

  /* Footer */
  .footer-cols { flex-direction: column; gap: 28px; }
  .footer-news { max-width: 100%; }
  .footer-legal { flex-direction: column; align-items: flex-start; gap: 10px; }
  .footer-legal .lr { flex-wrap: wrap; gap: 14px; }

  /* Tabs */
  .woocommerce-tabs ul.tabs { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .woocommerce-tabs ul.tabs li a { padding: 14px 18px; white-space: nowrap; }
  .woocommerce-tabs .panel { max-width: 100%; }
}

/* ============================================================
   RESPONSIVE — SMALL PHONE (max 480px)
   ============================================================ */
@media (max-width: 480px) {
  :root { --gutter: 16px; }

  /* Hero */
  .hero { min-height: 50vw; }
  .hero-layer { font-size: 42vw; }

  /* Nav */
  .nav-inner { height: 60px; }
  .brand-badge { font-size: 22px; padding: 7px 18px; }

  /* PLP single column on very small phones */
  .pgrid { grid-template-columns: 1fr; }
  .card .media { aspect-ratio: 3/3.2; }

  /* Subbar */
  .subbar { height: 48px; padding: 0 var(--gutter); }

  /* Single product */
  .sp-info form.cart { flex-direction: column; }
  .sp-info .quantity .qty { width: 100%; }
  .sp-info .single_add_to_cart_button { width: 100%; }

  /* Category editorial */
  .cat-copy { padding: 28px var(--gutter); }
  .cat-copy .huge { font-size: clamp(44px, 16vw, 80px); }

  /* Footer */
  .footer { padding: 40px var(--gutter) 24px; }
  .footer-badge { font-size: 22px; padding: 8px 20px; }

  /* Related products */
  .related.products ul.products, .upsells.products ul.products { grid-template-columns: repeat(2, 1fr); }
}

.mobile-nav { display: none; }
@media (max-width: 900px) {
  .mobile-nav.open {
    display: flex; flex-direction: column; gap: 4px;
    padding: 12px var(--gutter) 18px; box-shadow: var(--hairline-inset);
    background: var(--color-canvas);
  }
  .mobile-nav.open a { padding: 12px 0; font: 500 15px/1 var(--font-text); border-bottom: 1px solid var(--color-hairline); display: block; color: var(--color-ink); }
}

/* ============================================================
   WORDPRESS ADMIN BAR OFFSET
   ============================================================ */
.admin-bar .nav { top: 32px; }
.admin-bar .subbar { top: calc(72px + 32px); }
@media screen and (max-width: 782px) {
  .admin-bar .nav { top: 46px; }
  .admin-bar .subbar { top: calc(72px + 46px); }
}
