/* QUIERO.SURF — design tokens */
:root {
  --sand: #F3EDE4;
  --bone: #FBF7F2;
  --shell: #EFE6D7;
  --coral-wash: #F2D9C8;
  --terracotta: #B24A1F;
  --terracotta-deep: #8F3A15;
  --ink: #1C1C1C;
  --ink-60: #1C1C1C99;
  --ink-40: #1C1C1C66;
  --ink-20: #1C1C1C33;
  --ink-10: #1C1C1C1A;
  --sage: #6B7A55;
  --sage-deep: #4F5B3E;
  --hairline: #1C1C1C22;

  --f-script: "Caveat", "Brush Script MT", cursive;
  --f-display: "Fraunces", "Cormorant Garamond", Georgia, serif;
  --f-sans: "Inter", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
  --f-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bone);
  color: var(--ink);
  font-family: var(--f-sans);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; padding: 0; }
img { display: block; max-width: 100%; }

/* typography utilities */
.script { font-family: var(--f-script); font-weight: 500; }
.display { font-family: var(--f-display); font-weight: 300; letter-spacing: -0.01em; }
.micro {
  font-family: var(--f-sans);
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 500;
}
.mono { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.04em; }

/* striped placeholder */
.placeholder {
  position: relative;
  background:
    repeating-linear-gradient(
      135deg,
      #E8DCC8 0 14px,
      #DFD0B8 14px 28px
    );
  overflow: hidden;
}
.placeholder.warm {
  background:
    repeating-linear-gradient(
      135deg,
      #EFDCCB 0 14px,
      #E6CDB7 14px 28px
    );
}
.placeholder.cool {
  background:
    repeating-linear-gradient(
      135deg,
      #DCE2D5 0 14px,
      #CED6C3 14px 28px
    );
}
.placeholder.ink {
  background:
    repeating-linear-gradient(
      135deg,
      #2A2723 0 14px,
      #1E1B18 14px 28px
    );
  color: var(--bone);
}
.placeholder .tag {
  position: absolute;
  inset: auto 12px 12px 12px;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  color: #1C1C1C99;
  text-transform: uppercase;
  display: flex;
  justify-content: space-between;
  gap: 12px;
}
.placeholder.ink .tag { color: #FBF7F2AA; }

/* layout */
.shell {
  min-height: 100vh;
  background: var(--bone);
}
.container {
  padding: 0 32px;
}

/* header */
.topbar {
  background: var(--ink);
  color: var(--bone);
  font-family: var(--f-sans);
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 8px 32px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.topbar .marquee {
  overflow: hidden;
  flex: 1;
  text-align: center;
}

.header {
  position: sticky;
  top: 0;
  z-index: 40;
  background: var(--bone);
  border-bottom: 1px solid var(--hairline);
}
.header-inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 18px 32px;
  gap: 24px;
}
.nav {
  display: flex;
  gap: 28px;
  align-items: center;
}
.nav a {
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 6px 0;
  position: relative;
  cursor: pointer;
}
.nav a.active::after,
.nav a:hover::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 1px;
  background: var(--ink);
}
.logo {
  font-family: var(--f-display);
  font-weight: 300;
  font-size: 28px;
  letter-spacing: 0.04em;
  cursor: pointer;
  text-align: center;
  line-height: 1;
}
.logo .dot { color: var(--terracotta); }
.header-right {
  display: flex;
  justify-content: flex-end;
  gap: 18px;
  align-items: center;
}
.header-right .icon-btn {
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  display: inline-flex;
  gap: 6px;
  align-items: center;
}
.lang-toggle {
  display: inline-flex;
  border: 1px solid var(--ink-20);
  font-size: 10px;
  letter-spacing: 0.12em;
}
.lang-toggle button {
  padding: 4px 8px;
  text-transform: uppercase;
}
.lang-toggle button.active {
  background: var(--ink);
  color: var(--bone);
}
.bag-count {
  display: inline-flex;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  border-radius: 999px;
  background: var(--terracotta);
  color: var(--bone);
  font-size: 9px;
  align-items: center;
  justify-content: center;
  font-family: var(--f-mono);
  letter-spacing: 0;
}

/* buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 24px;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  border: 1px solid var(--ink);
  background: var(--bone);
  color: var(--ink);
  cursor: pointer;
  transition: all 0.2s ease;
}
.btn:hover { background: var(--ink); color: var(--bone); }
.btn.primary { background: var(--ink); color: var(--bone); }
.btn.primary:hover { background: var(--terracotta); border-color: var(--terracotta); color: var(--bone); }
.btn.ghost { border-color: var(--ink-20); }
.btn.ghost:hover { border-color: var(--ink); background: transparent; color: var(--ink); }
.btn.full { width: 100%; }

/* footer */
.footer {
  margin-top: 120px;
  background: var(--ink);
  color: var(--bone);
  padding: 80px 32px 32px;
}
.footer .row1 {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
  padding-bottom: 64px;
  border-bottom: 1px solid #ffffff22;
}
.footer h4 {
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin: 0 0 20px;
  color: #ffffff88;
  font-weight: 500;
}
.footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; font-size: 13px; }
.footer .signature {
  font-family: var(--f-display);
  font-size: 48px;
  line-height: 1;
  font-weight: 300;
}
.footer .signature .dot { color: var(--terracotta); }
.footer .tag-line {
  font-family: var(--f-script);
  font-size: 28px;
  color: var(--coral-wash);
  margin-top: 8px;
}
.footer .row2 {
  padding-top: 24px;
  display: flex;
  justify-content: space-between;
  font-family: var(--f-mono);
  font-size: 10px;
  color: #ffffff66;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* drawer */
.drawer-overlay {
  position: fixed; inset: 0;
  background: #00000055;
  z-index: 80;
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s ease;
}
.drawer-overlay.open { opacity: 1; pointer-events: auto; }
.drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(460px, 100vw);
  background: var(--bone);
  z-index: 90;
  transform: translateX(100%);
  transition: transform 0.35s cubic-bezier(0.22,1,0.36,1);
  display: flex; flex-direction: column;
}
.drawer.open { transform: translateX(0); }
.drawer-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 20px 24px;
  border-bottom: 1px solid var(--hairline);
}
.drawer-head .title {
  font-family: var(--f-display);
  font-size: 22px;
  font-weight: 300;
}
.drawer-body { flex: 1; overflow-y: auto; padding: 12px 24px 24px; }
.drawer-foot {
  padding: 20px 24px 24px;
  border-top: 1px solid var(--hairline);
  background: var(--sand);
}

/* generic */
.hr { height: 1px; background: var(--hairline); border: 0; margin: 0; }
.row { display: flex; align-items: center; gap: 12px; }
.between { display: flex; justify-content: space-between; align-items: center; }
.stack { display: flex; flex-direction: column; }

/* wishlist heart */
.heart {
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px;
  border: 1px solid var(--ink-20);
  background: var(--bone);
  cursor: pointer;
  transition: all 0.2s ease;
}
.heart:hover { border-color: var(--ink); }
.heart.on { background: var(--terracotta); border-color: var(--terracotta); }
.heart svg { width: 14px; height: 14px; }
.heart.on svg { fill: var(--bone); stroke: var(--bone); }

/* page transitions */
.page-enter { animation: pageIn 0.45s cubic-bezier(0.22,1,0.36,1); }
@keyframes pageIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* swatch */
.swatch-row { display: flex; gap: 10px; flex-wrap: wrap; }
.swatch {
  width: 28px; height: 28px;
  border-radius: 999px;
  border: 1px solid var(--ink-20);
  cursor: pointer;
  position: relative;
  box-shadow: inset 0 0 0 2px var(--bone);
  transition: all 0.15s ease;
}
.swatch.active { outline: 1px solid var(--ink); outline-offset: 2px; }
.size-row { display: flex; gap: 8px; flex-wrap: wrap; }
.size {
  min-width: 44px;
  padding: 10px 12px;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border: 1px solid var(--ink-20);
  background: var(--bone);
  cursor: pointer;
  transition: all 0.15s ease;
}
.size:hover { border-color: var(--ink); }
.size.active { background: var(--ink); color: var(--bone); border-color: var(--ink); }
.size.oos { color: var(--ink-40); text-decoration: line-through; cursor: not-allowed; }

/* Dimensions card + modal */
.dim-card {
  border: 1px solid var(--ink-20);
  padding: 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease;
}
.dim-card:hover { border-color: var(--ink); }
.dim-card.filled { border-color: var(--ink); background: var(--sand); }
.dim-card .left { display: flex; gap: 14px; align-items: center; }
.dim-card .dots { display: flex; flex-direction: column; gap: 3px; }
.dim-card .dot { width: 5px; height: 5px; border-radius: 999px; background: var(--ink-20); }
.dim-card.filled .dot { background: var(--terracotta); }

.modal-overlay {
  position: fixed; inset: 0;
  background: #00000066;
  z-index: 100;
  opacity: 0; pointer-events: none;
  transition: opacity 0.2s ease;
}
.modal-overlay.open { opacity: 1; pointer-events: auto; }
.modal {
  position: fixed;
  left: 50%; top: 50%;
  transform: translate(-50%, -48%) scale(0.98);
  opacity: 0; pointer-events: none;
  width: min(520px, calc(100vw - 32px));
  max-height: calc(100vh - 64px);
  background: var(--bone);
  border: 1px solid var(--ink);
  z-index: 110;
  display: flex; flex-direction: column;
  transition: transform 0.25s cubic-bezier(0.22,1,0.36,1), opacity 0.25s ease;
}
.modal.open { transform: translate(-50%, -50%) scale(1); opacity: 1; pointer-events: auto; }
.modal-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  padding: 20px 24px;
  border-bottom: 1px solid var(--hairline);
}
.modal-head .title { font-family: var(--f-display); font-size: 28px; font-weight: 300; letter-spacing: -0.01em; }
.modal-head .title em { font-style: italic; }
.modal-body { padding: 24px; overflow-y: auto; }
.modal-foot {
  padding: 16px 24px 20px;
  border-top: 1px solid var(--hairline);
  display: flex; gap: 10px; justify-content: space-between; align-items: center;
}

.unit-toggle {
  display: inline-flex;
  border: 1px solid var(--ink-20);
}
.unit-toggle button {
  padding: 6px 14px;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  background: transparent;
  color: var(--ink-60);
  cursor: pointer;
  transition: all 0.15s ease;
}
.unit-toggle button.active {
  background: var(--ink);
  color: var(--bone);
}

.dim-field { margin-top: 18px; }
.dim-field .row {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 6px;
}
.dim-field label {
  font-family: var(--f-sans);
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 500;
}
.dim-field .hint {
  font-size: 11px;
  color: var(--ink-60);
  line-height: 1.5;
  margin-top: 6px;
}
.dim-input {
  display: flex; align-items: center; gap: 0;
  border: 1px solid var(--ink-20);
  padding: 0;
  background: var(--bone);
  transition: border-color 0.15s ease;
}
.dim-input:focus-within { border-color: var(--ink); }
.dim-input input {
  flex: 1;
  border: 0;
  padding: 14px 16px;
  font-family: var(--f-display);
  font-size: 22px;
  font-weight: 300;
  background: transparent;
  color: var(--ink);
  outline: none;
  width: 100%;
  min-width: 0;
}
.dim-input .unit {
  font-family: var(--f-mono);
  font-size: 12px;
  color: var(--ink-40);
  padding: 0 16px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* toast */
.toast {
  position: fixed; left: 50%; bottom: 32px;
  transform: translate(-50%, 20px);
  background: var(--ink);
  color: var(--bone);
  padding: 12px 20px;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  z-index: 100;
  opacity: 0;
  pointer-events: none;
  transition: all 0.3s ease;
}
.toast.show { opacity: 1; transform: translate(-50%, 0); }

/* tweaks panel */
.tweaks {
  position: fixed;
  right: 20px; bottom: 20px;
  width: 300px;
  background: var(--bone);
  border: 1px solid var(--ink);
  z-index: 95;
  font-size: 12px;
  box-shadow: 0 20px 60px #00000020;
  display: none;
}
.tweaks.open { display: block; }
.tweaks-head {
  padding: 14px 16px;
  border-bottom: 1px solid var(--hairline);
  display: flex; justify-content: space-between; align-items: center;
  background: var(--ink); color: var(--bone);
}
.tweaks-body { padding: 16px; display: flex; flex-direction: column; gap: 18px; max-height: 60vh; overflow-y: auto; }
.tweak-group .label {
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-60); margin-bottom: 8px;
}
.tweak-opts { display: flex; gap: 6px; flex-wrap: wrap; }
.tweak-opt {
  padding: 6px 10px;
  border: 1px solid var(--ink-20);
  font-size: 11px;
  cursor: pointer;
}
.tweak-opt.active { background: var(--ink); color: var(--bone); border-color: var(--ink); }

/* ====================================================== */
/* RESPONSIVE LAYOUT HELPERS                              */
/* ====================================================== */

/* Helper classes used by JSX to opt into mobile collapsing */
.q-section          { padding: 120px 32px 0; }
.q-section.tight    { padding: 56px 32px 32px; }
.q-section.bleed    { padding: 0 0 0; }
.q-grid-2           { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.q-grid-2.tight     { gap: 8px; align-items: stretch; }
.q-grid-2.split     { grid-template-columns: 1fr 1.4fr; gap: 64px; }
.q-grid-3           { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.q-grid-3.lookbook  { gap: 48px; row-gap: 80px; }
.q-grid-3.values    { gap: 64px; }
.q-grid-3.atelier   { gap: 40px; }
.q-grid-3.thumbs    { gap: 16px; }
.q-grid-hero-a      { display: grid; grid-template-columns: 1.2fr 0.8fr; gap: 8px; margin-bottom: 8px; }
.q-grid-hero-b      { display: grid; grid-template-columns: 1fr 1fr 1.2fr; gap: 8px; }
.q-grid-hero-rows   { display: grid; grid-template-rows: 1fr 1fr; gap: 8px; }
.q-pdp-grid         { display: grid; grid-template-columns: 1.4fr 1fr; gap: 0; align-items: flex-start; }
.q-pdp-gallery      { padding: 32px; border-right: 1px solid var(--hairline); }
.q-pdp-info         { padding: 48px; position: sticky; top: 110px; }
.q-visit-grid       { background: var(--sand); padding: 80px 48px; display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.q-shop-mast        { display: grid; grid-template-columns: 1fr auto; align-items: end; gap: 24px; }

/* ----- TABLET (< 1024px) ----- */
@media (max-width: 1023px) {
  .q-section { padding: 90px 24px 0; }
  .q-section.tight { padding: 40px 24px 24px; }
  .q-grid-3 { grid-template-columns: repeat(2, 1fr); gap: 32px; row-gap: 56px; }
  .q-grid-3.lookbook { gap: 32px; row-gap: 64px; }
  .q-grid-3.atelier { gap: 32px; }
  .q-pdp-grid { grid-template-columns: 1fr; }
  .q-pdp-gallery { border-right: 0; border-bottom: 1px solid var(--hairline); padding: 24px; }
  .q-pdp-info { padding: 32px 24px; position: static; }
  .footer .row1 { grid-template-columns: 2fr 1fr 1fr; }
}

/* ----- MOBILE (< 768px) ----- */
@media (max-width: 767px) {
  /* tap targets & base */
  body { font-size: 15px; }
  .container { padding: 0 18px; }

  /* ---------- TOPBAR / HEADER ---------- */
  .topbar {
    padding: 7px 16px;
    font-size: 9.5px;
    letter-spacing: 0.16em;
    gap: 10px;
  }
  .topbar > span:first-child { white-space: nowrap; }
  .topbar .marquee { display: none; }

  .header-inner {
    grid-template-columns: auto 1fr auto;
    padding: 14px 18px;
    gap: 12px;
  }
  .header-inner .nav { display: none; }
  .logo { font-size: 22px; }
  .logo img { height: 32px !important; }
  .logo span { font-size: 22px !important; }
  .header-right { gap: 10px; }
  .header-right .icon-btn span { display: none; }
  .header-right .lang-toggle { display: none; }
  .header-right .icon-btn { padding: 8px; min-width: 36px; min-height: 36px; justify-content: center; }
  .mobile-burger { display: inline-flex !important; align-items: center; justify-content: center; min-width: 36px; min-height: 36px; }

  /* ---------- MOBILE NAV DRAWER ---------- */
  .mobile-nav-overlay {
    position: fixed; inset: 0;
    background: #00000055;
    z-index: 80;
    opacity: 0; pointer-events: none;
    transition: opacity 0.3s ease;
  }
  .mobile-nav-overlay.open { opacity: 1; pointer-events: auto; }
  .mobile-nav {
    position: fixed; top: 0; left: 0; bottom: 0;
    width: min(320px, 88vw);
    background: var(--bone);
    z-index: 90;
    transform: translateX(-100%);
    transition: transform 0.35s cubic-bezier(0.22,1,0.36,1);
    display: flex; flex-direction: column;
  }
  .mobile-nav.open { transform: translateX(0); }
  .mobile-nav-head {
    display: flex; justify-content: space-between; align-items: center;
    padding: 18px 20px;
    border-bottom: 1px solid var(--hairline);
  }
  .mobile-nav-body {
    padding: 12px 0;
    display: flex; flex-direction: column;
  }
  .mobile-nav-body a {
    padding: 16px 24px;
    font-family: var(--f-display);
    font-size: 22px;
    font-weight: 300;
    border-bottom: 1px solid var(--hairline);
    cursor: pointer;
  }
  .mobile-nav-body a.active { color: var(--terracotta); }
  .mobile-nav-foot {
    margin-top: auto;
    padding: 20px 24px;
    border-top: 1px solid var(--hairline);
    display: flex; justify-content: space-between; align-items: center;
  }

  /* ---------- SECTIONS / GRIDS ---------- */
  .q-section { padding: 64px 18px 0; }
  .q-section.tight { padding: 24px 18px 18px; }
  .q-section.bleed { padding: 0; }

  .q-grid-2 { grid-template-columns: 1fr; gap: 32px; }
  .q-grid-2.tight { gap: 6px; }
  .q-grid-2.split { grid-template-columns: 1fr; gap: 32px; }
  .q-grid-3 { grid-template-columns: 1fr; gap: 36px; row-gap: 48px; }
  .q-grid-3.lookbook { grid-template-columns: 1fr 1fr; gap: 12px; row-gap: 32px; }
  .q-grid-3.thumbs { grid-template-columns: 1fr; gap: 8px; }
  .q-grid-hero-a { grid-template-columns: 1fr; gap: 6px; }
  .q-grid-hero-b { grid-template-columns: 1fr 1fr; gap: 6px; }
  .q-grid-hero-rows { grid-template-rows: auto auto; gap: 6px; }

  /* ---------- PDP ---------- */
  .q-pdp-gallery { padding: 18px; }
  .q-pdp-info { padding: 24px 18px 32px; }
  .q-pdp-info h1 { font-size: 36px !important; }

  /* ---------- VISIT / FERNANDA ---------- */
  .q-visit-grid {
    grid-template-columns: 1fr;
    padding: 40px 22px;
    gap: 32px;
  }
  .q-visit-grid iframe { height: 280px !important; }

  /* ---------- SHOP MASTHEAD ---------- */
  .q-shop-mast { grid-template-columns: 1fr; gap: 8px; }

  /* ---------- TYPOGRAPHY SCALING ---------- */
  .display { letter-spacing: -0.005em; }

  /* ---------- BUTTONS ---------- */
  .btn {
    padding: 14px 18px;
    font-size: 11px;
    letter-spacing: 0.18em;
    min-height: 44px;
  }

  /* ---------- FOOTER ---------- */
  .footer { padding: 48px 18px 24px; margin-top: 80px; }
  .footer .row1 {
    grid-template-columns: 1fr;
    gap: 32px;
    padding-bottom: 32px;
  }
  .footer .signature { font-size: 36px; }
  .footer .tag-line { font-size: 22px; }
  .footer .row2 {
    flex-direction: column;
    gap: 8px;
    text-align: center;
    align-items: center;
  }

  /* ---------- DRAWER ---------- */
  .drawer { width: 100vw; max-width: 100vw; }
  .drawer-head { padding: 16px 18px; }
  .drawer-body { padding: 12px 18px 18px; }
  .drawer-foot { padding: 16px 18px 22px; }

  /* ---------- MODAL ---------- */
  .modal {
    width: calc(100vw - 16px);
    max-height: calc(100vh - 32px);
  }
  .modal-head { padding: 16px 18px; }
  .modal-head .title { font-size: 22px; }
  .modal-body { padding: 18px; }
  .modal-foot { padding: 14px 18px 18px; }
  .dim-input input { font-size: 18px; padding: 12px 14px; }
  .dim-card { padding: 14px; }

  /* ---------- TWEAKS ---------- */
  .tweaks { right: 10px; bottom: 10px; left: 10px; width: auto; }

  /* ---------- IMAGE BLOCKS ---------- */
  /* prevent stuck-on hover-zoom on touch */
  .imgblock-zoom { transform: none !important; }
}

/* ----- SMALL PHONES ----- */
@media (max-width: 380px) {
  .q-grid-hero-b { grid-template-columns: 1fr; }
  .q-grid-3.lookbook { grid-template-columns: 1fr; }
  .topbar { font-size: 9px; letter-spacing: 0.12em; padding: 6px 12px; }
}

/* hide burger on desktop */
.mobile-burger { display: none; }

/* ----- MOBILE POLISH ----- */
html, body { overflow-x: hidden; }
button, a { -webkit-tap-highlight-color: transparent; }

@media (max-width: 767px) {
  /* 2-col product grid on mobile */
  .q-grid-3.lookbook { grid-template-columns: 1fr 1fr; gap: 12px; row-gap: 40px; }
  /* sticky filter needs to clear the header */
  .q-pdp-info { position: static !important; padding-bottom: 120px !important; }
  /* sticky add-to-cart spacer handled in PDP */
  .sticky-atc {
    position: fixed; left: 0; right: 0; bottom: 0;
    background: var(--bone);
    border-top: 1px solid var(--hairline);
    padding: 12px 16px calc(12px + env(safe-area-inset-bottom, 0px));
    display: flex; gap: 8px; align-items: center;
    z-index: 40;
  }
  .sticky-atc .price { font-family: var(--f-display); font-size: 18px; font-weight: 300; margin-right: auto; }
  .sticky-atc .btn { flex: 1; min-width: 0; }
}
.sticky-atc { display: none; }
@media (max-width: 767px) { .sticky-atc { display: flex; } }
