/* ============================================================
   WÁSIU — Component Styles
   All layout, component, and page styles.
   ============================================================ */

/* ===== Scroll root — minimal; sticky works via window scroll on WP ===== */
.scroll-root { position: relative; }

/* ===== Force dark theme over Kadence defaults ===== */
html, body {
  background: #0A0A0A !important;
  color: #F7F3EB !important;
}
body.woocommerce, body.woocommerce-page,
body.home, body.page, body.single-product {
  background: #0A0A0A !important;
  color: #F7F3EB !important;
}
.site, #page, .site-main, .content-area,
.kadence-content-wrap, .entry-content-wrap,
.woocommerce-page .site-main,
.kadence-inner-column-inner, .kb-inner-column-inner {
  background: transparent !important;
  overflow: visible !important;
}
.page-wrap {
  background: var(--ink-950);
  min-height: 100vh;
  padding: clamp(80px,10vw,140px) clamp(20px,5vw,80px) clamp(64px,8vw,120px);
}

/* ===== Buttons ===== */
.btn {
  font-family: var(--font-mono); font-weight: 700; font-size: 12px;
  letter-spacing: 0.12em; text-transform: uppercase; border-radius: var(--r-pill);
  padding: 15px 28px; display: inline-flex; align-items: center; gap: 9px;
  transition: transform .14s ease, background .2s ease, box-shadow .2s ease;
  cursor: pointer; border: none;
}
.btn--primary { background: var(--emerald-700); color: var(--cream-50); box-shadow: var(--shadow-glow); }
.btn--primary:hover { background: var(--emerald-500); transform: translateY(-1px); }
.btn--cream { background: var(--cream-50); color: var(--ink-950); }
.btn--cream:hover { background: #fff; transform: translateY(-1px); }
.btn--ghost { border: 1px solid var(--border-strong); color: var(--fg); }
.btn--ghost:hover { border-color: var(--cream-50); background: rgba(247,243,235,.04); }
.btn:active { transform: scale(.97); }
.btn--block { width: 100%; justify-content: center; }
.btn__arrow { transition: transform .2s ease; }
.btn--primary:hover .btn__arrow { transform: translateX(3px); }

/* ===== Nav ===== */
.nav {
  position: sticky; top: 0; z-index: 50;
  transition: background .25s ease, border-color .25s ease, backdrop-filter .25s;
  border-bottom: 1px solid transparent;
}
.nav--scrolled {
  background: var(--overlay); backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px); border-color: var(--border);
}
.nav__inner {
  max-width: 1320px; margin: 0 auto; padding: 16px 28px;
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center;
}
.nav__links { display: flex; align-items: center; gap: 26px; }
.nav__links--right { justify-content: flex-end; gap: 16px; }
.nav__link {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--fg-muted); transition: color .18s;
  background: none; border: none; cursor: pointer; padding: 0;
}
.nav__link:hover, .nav__link.is-active { color: var(--fg); }
.nav__link.is-active { position: relative; }
.nav__link.is-active::after { content: ''; position: absolute; bottom: -18px; left: 0; right: 0; height: 2px; background: var(--emerald-300); border-radius: 999px; }
.nav__icon {
  display: inline-flex; padding: 8px; border-radius: var(--r-pill);
  color: var(--fg); transition: background .18s; position: relative;
  background: none; border: none; cursor: pointer;
}
.nav__icon:hover { background: rgba(247,243,235,.06); }
.nav__count {
  position: absolute; top: -2px; right: -2px; background: var(--emerald-500);
  color: var(--cream-50); font-family: var(--font-mono); font-size: 9px;
  font-weight: 700; min-width: 16px; height: 16px; border-radius: var(--r-pill);
  display: flex; align-items: center; justify-content: center; padding: 0 4px;
}
.wordmark {
  font-family: var(--font-display); font-weight: 800; font-size: 26.4px;
  letter-spacing: 0.01em; color: var(--fg); background: none; border: none;
  cursor: pointer; padding: 0; text-decoration: none; display: inline-block;
}
.wordmark--sm { font-size: 18px; }

/* Mobile nav */
.nav__burger {
  display: none; flex-direction: column; gap: 5px; justify-content: center;
  padding: 8px; background: none; border: none; cursor: pointer;
}
.nav__burger-bar {
  display: block; width: 22px; height: 1.5px; background: var(--fg);
  border-radius: 2px; transition: transform .25s ease, opacity .2s; transform-origin: center;
}
.nav__burger-bar.is-open:first-child  { transform: translateY(3.25px) rotate(45deg); }
.nav__burger-bar.is-open:last-child   { transform: translateY(-3.25px) rotate(-45deg); }

.nav__menu {
  position: fixed; inset: 0; z-index: 45; background: var(--ink-950);
  display: flex; flex-direction: column; justify-content: flex-start;
  padding: clamp(100px,16vh,140px) 28px 40px;
  opacity: 0; pointer-events: none; transition: opacity .3s ease;
}
.nav__menu.is-open { opacity: 1; pointer-events: auto; }
.nav__menu-links { display: flex; flex-direction: column; gap: 4px; }
.nav__menu-link {
  display: flex; align-items: center; gap: 16px; text-align: left;
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(2.4rem, 9vw, 4.8rem); letter-spacing: -0.04em;
  line-height: 1.05; color: var(--fg); padding: 6px 0;
  background: none; border: none; cursor: pointer;
  opacity: 0; transform: translateY(20px); transition: color .18s;
}
.nav__menu.is-open .nav__menu-link {
  opacity: 1; transform: translateY(0);
  transition: opacity .4s ease, transform .4s cubic-bezier(.22,1,.36,1), color .18s;
}
.nav__menu-link:hover, .nav__menu-link.is-active { color: var(--sand-200); }
.nav__menu-no {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.1em; color: var(--fg-subtle); width: 28px; flex: none;
}
.nav__menu-foot {
  display: flex; justify-content: space-between; margin-top: auto;
  padding-top: 32px; border-top: 1px solid var(--border);
}
@media (max-width: 900px) {
  .nav__desktop { display: none !important; }
  .nav__burger { display: flex; }
}

/* ===== Hero ===== */
.hero {
  position: relative; margin: 12px; border-radius: var(--r-2xl); overflow: hidden;
  min-height: min(86vh, 760px); display: flex; align-items: flex-end; isolation: isolate;
  background: radial-gradient(120% 90% at 70% 10%, rgba(44,82,64,.40), transparent 60%), #0c0c0c;
}
.hero__bg {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: center; z-index: 0;
}
.hero__veil {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(10,10,10,.55) 0%, rgba(10,10,10,.15) 35%, rgba(10,10,10,.78) 100%);
}
.hero__copy { position: relative; z-index: 3; padding: clamp(28px,5vw,64px); max-width: 760px; }

/* Photo hero variant */
.hero--photo { min-height: 58vh; height: 75vh; background: #080808; }
.hero__photo { position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: center 20%; display: block; z-index: 0; }
.hero__veil--photo { display: none; }
.hero__copy--photo { max-width: 100%; width: 100%;
  display: flex; flex-direction: column; align-items: flex-start;
  padding: clamp(28px,5vw,64px); gap: 22px; }
@media (max-width: 640px) {
  .hero--photo { min-height: 100svh; min-height: 100vh; }
  .hero__photo { object-fit: cover; object-position: center center; }
  .hero__copy--photo { padding: 20px 20px 36px; }
}
.hero__eyebrow {
  display: inline-block; padding: 7px 14px;
  border: 1px solid rgba(232,213,176,.35); border-radius: var(--r-pill);
  color: var(--sand-200); margin-bottom: 22px; backdrop-filter: blur(6px);
}
.hero__title {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(2.8rem, 7.5vw, 6.4rem); line-height: 0.92;
  letter-spacing: -0.035em; color: var(--cream-50); text-shadow: 0 2px 40px rgba(0,0,0,.5);
}
.hero__arrow { color: var(--sand-200); }
.hero__lede { color: rgba(247,243,235,.82); font-size: clamp(1rem,1.6vw,1.2rem); max-width: 46ch; margin: 22px 0 30px; }
.hero__cta { display: flex; gap: 14px; flex-wrap: wrap; }

/* Floating tiles */
.hero__scatter { position: absolute; inset: 0; z-index: 2; pointer-events: none; }
.tile {
  position: absolute; width: clamp(120px,14vw,188px); margin: 0;
  background: linear-gradient(180deg,#f5f0e8,#ede6d8);
  border: 1px solid rgba(232,213,176,.3); border-radius: var(--r-lg);
  padding: 10px; box-shadow: var(--shadow-lg); backdrop-filter: blur(4px);
}
.tile img { width: 100%; aspect-ratio: 1/1; object-fit: contain; border-radius: var(--r-md); background: transparent; }
.tile__cap {
  display: flex; justify-content: space-between; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--clay-600); margin-top: 8px;
}
.tile__price { color: var(--emerald-700); }
.tile--a { top: 7%;  right: 5%;  animation: floatA 7s ease-in-out infinite; }
.tile--b { top: 34%; right: 19%; animation: floatB 8s ease-in-out infinite; }
.tile--c { top: 11%; right: 27%; width: clamp(96px,10vw,140px); animation: floatC 9s ease-in-out infinite; }
.tile--d { bottom: 9%; right: 7%; animation: floatD 7.5s ease-in-out infinite; }
@keyframes floatA { 0%,100%{transform:rotate(5deg) translateY(0)} 50%{transform:rotate(5deg) translateY(-13px)} }
@keyframes floatB { 0%,100%{transform:rotate(-7deg) translateY(0)} 50%{transform:rotate(-7deg) translateY(-16px)} }
@keyframes floatC { 0%,100%{transform:rotate(9deg) translateY(0)} 50%{transform:rotate(9deg) translateY(-10px)} }
@keyframes floatD { 0%,100%{transform:rotate(-4deg) translateY(0)} 50%{transform:rotate(-4deg) translateY(-14px)} }
@media (max-width:900px) { .tile--c,.tile--b { display:none; } }
@media (max-width:620px) { .hero__scatter { display:none; } .hero { margin:6px; border-radius:var(--r-xl); } .hero__lede { display:none; } }

/* ===== Marquee ===== */
.marquee { overflow: hidden; white-space: nowrap; padding: 14px 0; border-block: 1px solid var(--border); }
.marquee--green { background: var(--emerald-700); border-color: var(--emerald-900); }
.marquee--dark  { background: var(--ink-900); }
.marquee__track { display: inline-flex; gap: 0; animation: scrollx 26s linear infinite; }
.marquee--green .marquee__track { animation-duration: 22s; }
.marquee__item {
  font-family: var(--font-mono); font-weight: 700; font-size: 13px;
  letter-spacing: 0.18em; text-transform: uppercase;
  display: inline-flex; align-items: center;
}
.marquee--green .marquee__item { color: var(--cream-50); }
.marquee--dark  .marquee__item { color: var(--fg-muted); }
.marquee__dot { margin: 0 26px; color: var(--emerald-300); opacity: .8; }
.marquee--dark .marquee__dot { color: var(--clay-600); }
@keyframes scrollx { to { transform: translateX(-50%); } }

/* Force Kadence wrappers to allow sticky + window scroll */
#page, .site, .site-content, #content, #primary,
.content-area, .site-main, main, article, .entry-content,
.kadence-content-wrap, .entry-content-wrap,
.kb-inner-column-inner, .kadence-inner-column-inner {
  overflow: visible !important;
}

/* ===== Hero photo variant ===== */
.hero--photo { min-height: 58vh; height: 75vh; background: #080808; }
.hero__plate { position: absolute; inset: 0; z-index: 0; }
.hero__photo { position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: center 20%; display: block; }
.hero__veil--photo { display: none; }
.hero__copy--photo { max-width: 100%; width: 100%; position: relative; z-index: 3;
  display: flex; flex-direction: column; align-items: flex-start;
  padding: clamp(28px,5vw,64px); gap: 22px; }
@media (max-width: 640px) {
  .hero--photo { min-height: 58vh; height: 58vh; }
  .hero__photo { object-fit: cover; object-position: center 25%; }
  .hero__copy--photo { padding: 20px 20px 36px; }
}
.shop { max-width: 1320px; margin: 0 auto; padding: 0 28px; }
.shop__head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 24px; margin-bottom: 36px; flex-wrap: wrap;
}
.shop__title { font-size: clamp(2.2rem,4vw,3.4rem); letter-spacing: -0.03em; margin-top: 8px; }
.chips { display: flex; gap: 8px; flex-wrap: wrap; }
.chip {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em;
  text-transform: uppercase; border-radius: var(--r-pill); padding: 9px 17px;
  border: 1px solid var(--border-strong); color: var(--fg-muted);
  transition: all .18s; background: none; cursor: pointer;
}
.chip:hover { color: var(--fg); border-color: var(--cream-50); }
.chip.is-active { background: var(--emerald-700); color: var(--cream-50); border-color: var(--emerald-500); }

.grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.grid--shop { grid-template-columns: repeat(4,1fr); gap: 18px; }
@media (max-width:1100px) { .grid--shop { grid-template-columns: repeat(3,1fr); } }
@media (max-width:940px)  { .grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width:760px)  { .grid--shop { grid-template-columns: repeat(2,1fr); } }
@media (max-width:560px)  { .grid { grid-template-columns: 1fr; } }
@media (max-width:480px)  { .grid--shop { grid-template-columns: 1fr; } }

/* ===== Product card ===== */
.card {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg);
  overflow: hidden; cursor: pointer; transition: transform .25s ease, box-shadow .25s ease, border-color .25s;
  display: block; text-decoration: none; color: inherit;
}
.card:hover { transform: none; box-shadow: none; border-color: var(--border-strong); }
.card__media { position: relative; aspect-ratio: 1/1; background: #e8e4dc; overflow: hidden; padding: 0; }
.card__img {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  padding: 10%; box-sizing: border-box;
  object-fit: contain; object-position: center;
  transition: opacity .4s ease;
}
.card__img--front { opacity: 1; }
.card__img--back  { opacity: 0; }
.card:hover .card__img--front { opacity: 1; }
.card:hover .card__img--back  { opacity: 0; }
.card__badge {
  position: absolute; top: 14px; left: 14px; z-index: 2;
  font-family: var(--font-mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase; background: var(--primary);
  color: var(--cream-50); padding: 6px 11px; border-radius: var(--r-pill);
}
.card__badge--low { background: rgba(232,166,188,.16); color: var(--accent-pink); border: 1px solid rgba(232,166,188,.4); }
.card__add {
  position: absolute; left: 12px; right: 12px; bottom: 12px; z-index: 2; padding: 12px;
  background: var(--overlay); backdrop-filter: blur(12px);
  border: 1px solid var(--border-strong); border-radius: var(--r-pill);
  color: var(--cream-50); font-family: var(--font-mono); font-size: 10px;
  font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
  opacity: 0; transform: translateY(8px); transition: all .25s ease; cursor: pointer;
}
.card__add.is-shown { opacity: 1; transform: translateY(0); }
.card__add:hover { background: var(--primary); border-color: transparent; }
.card__row { display: flex; justify-content: space-between; align-items: flex-start; padding: 16px 18px 20px; }
.card__name { font-family: var(--font-display); font-weight: 600; font-size: 17px; letter-spacing: -0.01em; }
.card__cat  { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-subtle); }
.card__price { font-family: var(--font-mono); font-size: 14px; letter-spacing: 0.04em; color: var(--fg-muted); }
@media (hover:none) {
  .card__add { opacity: 1; transform: translateY(0); }
  .card:hover { transform: none; box-shadow: none; }
  .card:hover .card__img--front { opacity: 1; }
  .card:hover .card__img--back  { opacity: 0; }
}

/* ===== Editorial section ===== */
.ed {
  position: relative; max-width: 1320px; margin: 24px auto;
  padding: clamp(40px,6vw,80px) clamp(24px,4vw,56px); overflow: visible; clip-path: none;
  border-radius: 0; border: 1px solid var(--border);
  background: radial-gradient(110% 90% at 80% 0%,rgba(232,213,176,.10),transparent 60%),
    linear-gradient(180deg,rgba(200,185,154,.05),rgba(200,185,154,.02));
}
.ed__mark {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(5rem,22vw,18rem); line-height: 0.85;
  letter-spacing: -0.05em; color: rgba(232,213,176,.15);
  pointer-events: none; user-select: none;
  white-space: nowrap; display: block;
  overflow: visible; clip-path: none;
  margin-bottom: 0.05em;
}
.ed__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px; margin-top: 12px; }
.ed__cell { padding-top: 28px; }
.ed__cell .eyebrow { display: block; margin-bottom: 10px; }
.ed__cell p { font-size: 1.05rem; color: var(--fg-muted); max-width: 34ch; }
@media (max-width:760px) { .ed__grid { grid-template-columns: 1fr; } }
@media (max-width:640px) { .ed { margin:8px; padding: clamp(28px,5vw,48px) 18px; border-radius:0; } }

/* ===== Scroll showcase ===== */
.show { position: relative; }
.show__stage {
  position: sticky; top: 0; height: 100vh; overflow: hidden;
  background: radial-gradient(85% 60% at 50% 88%,rgba(232,213,176,.10),transparent 55%), var(--ink-950);
}
.show__piece {
  position: absolute; top: 50%; left: 50%; width: min(54vh,78vw); aspect-ratio: 1/1;
  transform: translate(-50%, calc(-50% + 80px)) scale(.92); opacity: 0; filter: blur(8px);
  pointer-events: none; transition: opacity .65s ease, transform .75s cubic-bezier(.22,1,.36,1), filter .65s ease;
}
.show__piece img { width: 100%; height: 100%; object-fit: contain; }
.show__piece.is-active {
  opacity: 1; filter: blur(0); transform: translate(-50%,-50%) scale(1);
  pointer-events: auto; cursor: pointer;
}
.show__piece.is-prev { transform: translate(-50%,calc(-50% - 70px)) scale(.88); opacity: 0; filter: blur(6px); }
.show__piece.is-next { transform: translate(-50%,calc(-50% + 80px)) scale(.92); opacity: 0; filter: blur(8px); }
.show__piece.is-active:hover { transform: translate(-50%,-50%); }
@keyframes pieceFloat { 0%,100%{margin-top:0} 50%{margin-top:0} }  /* disabled */
.show__ghost {
  position: sticky; top: 0; left: 0; right: 0;
  font-family: var(--font-display); font-weight: 800; font-size: 16vh; line-height: 1;
  color: rgba(232,213,176,.10); pointer-events: none; user-select: none;
  white-space: nowrap; text-align: center;
  z-index: 3; margin-bottom: -16vh;
}
.show__top {
  position: absolute; top: 92px; left: 0; right: 0;
  display: flex; justify-content: space-between; align-items: center;
  padding: 0 clamp(20px,4vw,52px); z-index: 5;
}
.show__count { font-family: var(--font-mono); font-weight: 700; font-size: 14px; letter-spacing: 0.14em; color: var(--sand-200); }
.show__count span { color: var(--fg-subtle); }
.show__index {
  position: absolute; left: clamp(20px,4vw,52px); top: 50%; transform: translateY(-50%);
  display: flex; flex-direction: column; gap: 4px; z-index: 5;
}
.show__chapter { display: flex; align-items: baseline; gap: 12px; padding: 8px 0; text-align: left; opacity: .4; transition: opacity .25s; background: none; border: none; cursor: pointer; }
.show__chapter:hover { opacity: .8; }
.show__chapter.is-active { opacity: 1; }
.show__chapter-no { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--fg-subtle); }
.show__chapter.is-active .show__chapter-no { color: var(--sand-200); }
.show__chapter-nm {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--sand-200); max-width: 0; overflow: hidden; white-space: nowrap;
  transition: max-width .35s ease, opacity .25s; opacity: 0;
}
.show__chapter.is-active .show__chapter-nm, .show__chapter:hover .show__chapter-nm { max-width: 180px; opacity: 1; }
.show__sizes {
  position: absolute; right: clamp(20px,4vw,52px); top: 50%; transform: translateY(-50%);
  display: flex; flex-direction: column; gap: 10px; align-items: center; z-index: 5;
}
.show__sizes-lab { margin-bottom: 2px; }
.show__size {
  width: 46px; height: 46px; border-radius: var(--r-pill); border: 1px solid var(--border-strong);
  font-family: var(--font-mono); font-size: 12px; color: var(--fg-muted);
  transition: all .18s; background: none; cursor: pointer;
}
.show__size:hover { border-color: var(--sand-400); color: var(--sand-200); background: rgba(232,213,176,.08); transform: scale(1.06); }
.show__size.is-active { background: var(--cream-50); color: var(--ink-950); border-color: transparent; }
.show__arrow {
  position: absolute; top: 50%; transform: translateY(-50%); width: 56px; height: 40px;
  border-radius: var(--r-pill); border: 1px solid var(--border-strong); color: var(--fg);
  display: flex; align-items: center; justify-content: center; z-index: 6;
  transition: all .2s; background: none; cursor: pointer;
}
.show__arrow:hover:not(:disabled) { background: var(--cream-50); color: var(--ink-950); border-color: transparent; }
.show__arrow:disabled { opacity: .25; cursor: default; }
.show__arrow--prev { left: calc(clamp(20px,4vw,52px) + 86px); }
.show__arrow--next { right: calc(clamp(20px,4vw,52px) + 64px); }
.show__meta {
  position: absolute; left: clamp(20px,4vw,52px); bottom: clamp(96px,13vh,140px);
  max-width: 30vw; z-index: 5;
}
.show__cat { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-subtle); }
.show__name { font-size: clamp(1.6rem,3vw,2.6rem); letter-spacing: -0.03em; margin: 8px 0 10px; cursor: pointer; width: fit-content; }
.show__name:hover { color: var(--sand-200); }
.show__blurb { font-size: .95rem; color: var(--fg-muted); max-width: 34ch; }
.show__guide { position: absolute; right: clamp(20px,4vw,52px); bottom: clamp(96px,13vh,140px); text-align: right; z-index: 5; }
.show__guide-h { display: block; font-family: var(--font-display); font-weight: 600; font-size: 15px; color: var(--fg); }
.show__guide-h span { color: var(--sand-200); }
.show__guide-s { display: block; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-subtle); margin-top: 5px; }
.show__cart { position: absolute; bottom: clamp(28px,5vh,44px); left: 50%; transform: translateX(-50%); z-index: 6; }
.show__cart-btn {
  display: flex; align-items: center; background: var(--emerald-700); color: var(--cream-50);
  border-radius: var(--r-pill); padding: 6px 6px 6px 24px; gap: 22px;
  box-shadow: var(--shadow-lg), 0 0 0 1px rgba(110,144,121,.3); transition: transform .16s, background .18s; border: none; cursor: pointer;
}
.show__cart-btn:hover { transform: translateY(-2px); background: var(--emerald-500); }
.show__cart-l { display: flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-weight: 700; font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--cream-50); }
.show__cart-r { background: var(--emerald-900); color: var(--cream-50); border-radius: var(--r-pill); padding: 13px 22px; font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.04em; }
.show__cart-unavail { display: flex; align-items: center; justify-content: center;
  background: rgba(14,13,12,.55); backdrop-filter: blur(10px); border: 1px solid rgba(247,243,235,.15);
  border-radius: var(--r-pill); padding: 16px 40px; }
.show__cart-unavail-label { font-family: var(--font-mono); font-size: 12px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase; color: rgba(247,243,235,.45); }
.show__size:hover { border-color: var(--emerald-300); color: var(--cream-50); background: rgba(60,102,80,.25); transform: scale(1.06); }
.show__size.is-active { background: var(--emerald-700); border-color: var(--emerald-500); color: var(--cream-50); }
.show__hint {
  position: absolute; bottom: clamp(28px,5vh,44px); right: clamp(20px,4vw,52px);
  display: flex; flex-direction: column; align-items: center; gap: 8px; z-index: 5; transition: opacity .3s;
}
.show__hint.is-hidden { opacity: 0; }
.show__hint span:first-child { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-subtle); }
.show__hint-line { width: 1px; height: 34px; background: linear-gradient(var(--clay-600),transparent); animation: hintPulse 2s ease-in-out infinite; }
@keyframes hintPulse { 0%,100%{transform:scaleY(.5);opacity:.5} 50%{transform:scaleY(1);opacity:1} }
@media (max-width:1080px) { .show__index { display:none; } .show__arrow--prev { left:clamp(20px,4vw,52px); } .show__meta { max-width:56vw; } }
@media (max-width:720px)  { .show__sizes,.show__guide { display:none; } .show__piece { width:58vw; } .show__meta { max-width:78vw; bottom:120px; } .show__arrow--next { right:clamp(20px,4vw,52px); } }
@media (max-width:520px)  { .show__top { top:72px; } .show__arrow--prev { left:14px; } .show__arrow--next { right:14px; } .show__meta { left:14px; max-width:88vw; bottom:110px; } .show__cart { bottom:20px; } .show__hint { display:none; } .show__piece { width:54vw; } }

/* ===== Footer ===== */
.footer {
  background: var(--ink-900); border-top: 1px solid var(--border); margin-top: 24px;
  border-top-left-radius: var(--r-2xl); border-top-right-radius: var(--r-2xl);
}
.footer__top {
  max-width: 1320px; margin: 0 auto; padding: clamp(40px,6vw,80px) 28px;
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 48px;
}
@media (max-width:820px) { .footer__top { grid-template-columns:1fr; gap:36px; } }
.footer__title { font-size: clamp(1.8rem,3.5vw,2.8rem); letter-spacing: -0.03em; }
.footer__title::after { content:""; display:block; width:56px; height:3px; border-radius:var(--r-pill); background:var(--emerald-500); margin-top:18px; }
.footer__form { display: flex; gap: 10px; margin-top: 22px; max-width: 440px; flex-wrap: wrap; }
.footer__input {
  flex: 1; min-width: 200px; font-family: var(--font-body); font-size: 15px;
  color: #F7F3EB !important;
  -webkit-text-fill-color: #F7F3EB !important;
  background: #0d0d0c !important;
  -webkit-box-shadow: 0 0 0 1000px #0d0d0c inset !important;
  border: 1.5px solid rgba(247,243,235,.22) !important;
  border-radius: 999px !important;
  padding: 14px 22px; outline: none;
  -webkit-appearance: none; appearance: none;
  transition: border-color .18s, box-shadow .18s;
}
.footer__input::placeholder {
  color: rgba(247,243,235,.32) !important;
  -webkit-text-fill-color: rgba(247,243,235,.32) !important;
}
.footer__input:focus {
  border-color: #3C6650 !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(60,102,80,.18) !important;
  -webkit-box-shadow: 0 0 0 1000px #0d0d0c inset, 0 0 0 3px rgba(60,102,80,.18) !important;
}
.footer__cols { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.footer__col { display: flex; flex-direction: column; gap: 12px; }
.footer__col .eyebrow { margin-bottom: 4px; }
.footer__col a, .footer__col button {
  text-align: left; font-size: 14px; color: var(--fg-muted); transition: color .18s;
  width: fit-content; background: none; border: none; cursor: pointer; padding: 0; font-family: inherit;
}
.footer__col a:hover, .footer__col button:hover { color: var(--fg); }
.footer__bar {
  border-top: 1px solid var(--border); max-width: 1320px; margin: 0 auto;
  padding: 22px 28px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px;
}
.footer__meta { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-subtle); }
.footer__socials { display: flex; gap: 14px; }
.footer__social { display: flex; align-items: center; justify-content: center; color: var(--fg-subtle); transition: color .18s; }
.footer__social:hover { color: var(--sand-400); }
@media (max-width:640px) { .footer__cols { grid-template-columns: repeat(2,1fr); } .footer__form { flex-direction: column; } .footer__input { min-width: 0; } }

/* ===== Cart drawer ===== */
.cart { position: fixed; inset: 0; z-index: 95; visibility: hidden; }
.cart.is-open { visibility: visible; }
.cart__scrim { position: absolute; inset: 0; background: var(--overlay); backdrop-filter: blur(6px); opacity: 0; transition: opacity .3s; }
.cart.is-open .cart__scrim { opacity: 1; }
.cart__panel {
  position: absolute; top: 0; right: 0; height: 100%; width: min(440px,92vw);
  background: var(--bg-elevated); border-left: 1px solid var(--border);
  display: flex; flex-direction: column; transform: translateX(100%);
  transition: transform .35s cubic-bezier(.22,1,.36,1);
  border-top-left-radius: var(--r-xl); border-bottom-left-radius: var(--r-xl);
}
.cart.is-open .cart__panel { transform: translateX(0); }
.cart__head { display: flex; justify-content: space-between; align-items: center; padding: 24px 26px; border-bottom: 1px solid var(--border); }
.cart__title { font-family: var(--font-display); font-size: 22px; }
.cart__title span { color: var(--fg-subtle); }
.cart__close { padding: 8px; border-radius: var(--r-pill); color: var(--fg); transition: background .18s; background: none; border: none; cursor: pointer; }
.cart__close:hover { background: var(--surface-2); }
.cart__empty { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; color: var(--fg-subtle); }
.cart__ship { padding: 16px 26px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-muted); border-bottom: 1px solid var(--border); }
.cart__ship b { color: var(--emerald-300); }
.cart__bar { height: 4px; background: var(--surface-2); border-radius: var(--r-pill); margin-top: 10px; overflow: hidden; }
.cart__bar span { display: block; height: 100%; background: var(--primary); border-radius: var(--r-pill); transition: width .4s ease; }
.cart__items { flex: 1; overflow-y: auto; padding: 8px 26px; }
.citem { display: flex; gap: 14px; align-items: center; padding: 16px 0; border-bottom: 1px solid var(--border); }
.citem__media { width: 64px; height: 64px; border-radius: var(--r-md); background: var(--cream-50); flex: none; overflow: hidden; }
.citem__media img { width: 100%; height: 100%; object-fit: contain; }
.citem__info { flex: 1; display: flex; flex-direction: column; gap: 3px; }
.citem__name { font-family: var(--font-display); font-weight: 600; font-size: 15px; }
.citem__meta { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-subtle); }
.citem__remove {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--fg-subtle); text-decoration: underline;
  text-underline-offset: 2px; width: fit-content; margin-top: 2px; transition: color .18s;
  background: none; border: none; cursor: pointer; padding: 0;
}
.citem__remove:hover { color: var(--accent-pink); }
.citem__price { font-family: var(--font-mono); font-size: 13px; color: var(--fg); }
.cart__foot { padding: 20px 26px; border-top: 1px solid var(--border); }
.cart__total { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 14px; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 14px; }
.cart__note { display: block; text-align: center; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-subtle); margin-top: 10px; }

/* ===== Toast ===== */
.toast {
  position: fixed; bottom: 22px; left: 50%; transform: translateX(-50%); z-index: 99;
  background: var(--cream-50); color: var(--ink-950); border-radius: var(--r-pill);
  padding: 13px 16px 13px 20px; display: flex; align-items: center; gap: 14px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase;
  box-shadow: var(--shadow-lg); animation: toastIn .3s cubic-bezier(.22,1,.36,1); pointer-events: auto;
}
.toast__dot { color: var(--emerald-500); }
.toast__cta {
  background: var(--ink-950); color: var(--cream-50); border-radius: var(--r-pill);
  padding: 7px 14px; font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.08em; border: none; cursor: pointer;
}
@keyframes toastIn { from { transform: translate(-50%,20px); opacity:0; } }
@media (max-width:500px) { .toast { width:calc(100% - 24px); left:12px; transform:none; right:12px; flex-wrap:wrap; justify-content:center; } }

/* ===== Single product (PDP full page) ===== */
.pdp-page { max-width: 1200px; margin: 0 auto; padding: clamp(32px,5vw,64px) 28px clamp(64px,8vw,120px); }
.pdp-page__grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(32px,5vw,72px); align-items: start; }
@media (max-width:860px) { .pdp-page__grid { grid-template-columns: 1fr; } }
.pdp-page__media { position: relative; background: var(--cream-50); border-radius: var(--r-2xl); overflow: hidden; aspect-ratio: 1/1; display: flex; align-items: center; justify-content: center; padding: 32px; }
.pdp-page__media img { width: 80%; max-height: 60vh; object-fit: contain; object-position: center; }
.pdp-page__thumbs { display: flex; gap: 10px; margin-top: 14px; }
.pdp-page__thumb {
  width: 72px; height: 72px; border-radius: var(--r-md); overflow: hidden;
  border: 1px solid var(--border); background: var(--cream-50); opacity: .7;
  transition: opacity .18s, border-color .18s; cursor: pointer; padding: 0;
}
.pdp-page__thumb.is-active { opacity: 1; border-color: var(--emerald-300); }
.pdp-page__thumb img { width: 100%; height: 100%; object-fit: contain; }
.pdp-page__info { display: flex; flex-direction: column; gap: 0; padding-top: 8px; }
.pdp-page__eyebrow { margin-bottom: 8px; }
.pdp-page__name { font-size: clamp(2rem,4vw,3rem); letter-spacing: -0.03em; margin: 0 0 10px; }
.pdp-page__price { font-family: var(--font-mono); font-size: 20px; color: var(--fg); margin-bottom: 20px; }
.pdp-page__blurb { color: var(--fg-muted); font-size: 1.05rem; margin-bottom: 28px; line-height: 1.7; }
.pdp-page__sizes { margin-bottom: 24px; }
.pdp-page__sizes-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.pdp-page__guide { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-subtle); text-decoration: underline; text-underline-offset: 3px; cursor: pointer; background: none; border: none; }
.pdp-page__size-row { display: flex; gap: 8px; flex-wrap: wrap; }
.size {
  min-width: 52px; padding: 12px 0; flex: 1; border: 1px solid var(--border-strong);
  border-radius: var(--r-pill); font-family: var(--font-mono); font-size: 13px;
  color: var(--fg-muted); transition: all .16s; background: none; cursor: pointer;
}
.size:hover { border-color: var(--cream-50); color: var(--fg); }
.size.is-active { background: var(--emerald-700); color: var(--cream-50); border-color: var(--emerald-500); }
.pdp__unavail { width: 100%; padding: 18px; text-align: center; border-radius: var(--r-pill);
  border: 1px solid rgba(247,243,235,.15); font-family: var(--font-mono); font-size: 12px;
  font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(247,243,235,.4); }
.card__unavail { position: absolute; bottom: 14px; left: 50%; transform: translateX(-50%);
  white-space: nowrap; background: rgba(14,13,12,.7); backdrop-filter: blur(8px);
  border: 1px solid rgba(247,243,235,.15); border-radius: var(--r-pill);
  padding: 10px 20px; font-family: var(--font-mono); font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase; color: rgba(247,243,235,.4);
  opacity: 0; transition: opacity .2s; pointer-events: none; }
.card__unavail.is-shown { opacity: 1; }
.size:disabled { opacity: .3; cursor: not-allowed; }
.pdp-page__care { display: flex; align-items: center; gap: 9px; color: var(--fg-subtle); font-size: 13px; margin-top: 14px; }
.pdp-page__meta { margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--border); display: flex; flex-direction: column; gap: 10px; }

/* WooCommerce variation form overrides */
.variations_form .variations { display: none; } /* hidden — we use custom size UI */
.woocommerce-variation-add-to-cart { display: none !important; }

/* ===== Inner pages ===== */
.page-wrap { max-width: 1120px; margin: 0 auto; padding: 0 28px clamp(64px,8vw,120px); }
.page-hero { padding: clamp(100px,14vh,160px) 0 clamp(32px,5vw,64px); border-bottom: 1px solid rgba(232,213,176,.14); margin-bottom: clamp(40px,6vw,80px); }
.page-title { font-size: clamp(3rem,7vw,6rem); letter-spacing: -0.04em; line-height: 0.92; margin: 14px 0 18px; }
.page-sub { font-size: clamp(1rem,1.8vw,1.2rem); color: var(--fg-muted); max-width: 52ch; }

/* --- About --- */
.about__hero { padding: clamp(100px,14vh,160px) 28px clamp(40px,6vw,72px); max-width: 1120px; margin: 0 auto; }
.about__title { font-size: clamp(3.5rem,10vw,8.5rem); letter-spacing: -0.045em; line-height: 0.88; margin: 0 0 22px; }
.about__title em { font-style: italic; color: var(--sand-200); font-weight: 700; }
.about__tagline { font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-muted); }
.about__stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: rgba(232,213,176,.12); border-radius: var(--r-xl); overflow: hidden; max-width: 1120px; margin: 0 auto 64px; }
.about__stat { padding: clamp(24px,4vw,48px); background: var(--ink-900); text-align: center; }
.about__stat-val { display: block; font-family: var(--font-display); font-weight: 800; font-size: clamp(2.5rem,6vw,5rem); letter-spacing: -0.04em; color: var(--sand-200); line-height: 1; }
.about__stat-lab { display: block; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-subtle); margin-top: 10px; }
.about__intro { max-width: 1120px; margin: 0 auto 72px; padding: 0 28px; }
.about__intro-h { font-size: clamp(2rem,4vw,3.5rem); letter-spacing: -0.03em; margin: 14px 0 22px; }
.about__intro-h em { font-style: italic; color: var(--sand-200); }
.about__intro-p { font-size: 1.1rem; color: var(--fg-muted); max-width: 64ch; line-height: 1.7; }
.about__chapters { max-width: 1120px; margin: 0 auto 80px; padding: 0 28px; display: flex; flex-direction: column; }
.about__chapter { display: grid; grid-template-columns: 72px 1fr; gap: 32px; padding: 40px 0; border-top: 1px solid rgba(232,213,176,.12); }
.about__chapter-no { font-family: var(--font-display); font-weight: 800; font-size: clamp(2.5rem,5vw,4.5rem); letter-spacing: -0.05em; color: rgba(232,213,176,.15); line-height: 1; padding-top: 4px; }
.about__chapter-tag { display: block; margin-bottom: 10px; }
.about__chapter-h { font-size: clamp(1.4rem,2.5vw,2rem); letter-spacing: -0.02em; margin: 0 0 16px; }
.about__chapter-p { color: var(--fg-muted); font-size: 1rem; line-height: 1.75; max-width: 58ch; }
.about__quote { max-width: 1120px; margin: 0 auto 80px; padding: clamp(40px,6vw,72px) 28px; text-align: center; border-block: 1px solid rgba(232,213,176,.14); }
.about__quote-mark { display: block; font-family: var(--font-display); font-size: clamp(5rem,14vw,12rem); line-height: .6; color: rgba(232,213,176,.10); }
.about__quote p { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.3rem,3vw,2.2rem); letter-spacing: -0.02em; line-height: 1.35; max-width: 70ch; margin: 0 auto; }
.about__founder { max-width: 1120px; margin: 0 auto; padding: 0 28px; display: grid; grid-template-columns: 340px 1fr; gap: clamp(32px,5vw,72px); align-items: start; }
.about__founder-placeholder { width: 100%; min-height: 400px; background: var(--surface); border-radius: var(--r-xl); border: 1px solid rgba(232,213,176,.14); display: flex; align-items: center; justify-content: center; }
.about__founder-init { font-family: var(--font-display); font-weight: 800; font-size: clamp(4rem,10vw,8rem); letter-spacing: -0.05em; color: rgba(232,213,176,.12); }
.about__founder-name { font-size: clamp(2.2rem,4vw,3.8rem); letter-spacing: -0.04em; line-height: 0.92; margin: 14px 0 6px; }
.about__founder-name em { font-style: italic; color: var(--sand-200); }
.about__founder-role { display: block; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-subtle); margin-bottom: 22px; }
.about__founder-info p { color: var(--fg-muted); line-height: 1.72; margin-bottom: 14px; max-width: 52ch; }
@media (max-width:860px) { .about__founder { grid-template-columns: 1fr; } }
@media (max-width:640px) { .about__chapter { grid-template-columns: 1fr; } .about__stats { grid-template-columns: repeat(3,1fr); } }

/* --- Contact --- */
.contact__cards { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-bottom: 64px; }
.contact__card { background: var(--surface); border: 1px solid rgba(232,213,176,.1); border-radius: var(--r-xl); padding: clamp(22px,3vw,36px); display: flex; flex-direction: column; gap: 8px; }
.contact__icon { width: 46px; height: 46px; border-radius: var(--r-pill); background: rgba(44,82,64,.25); border: 1px solid rgba(60,102,80,.35); display: flex; align-items: center; justify-content: center; color: var(--emerald-300); margin-bottom: 6px; }
.contact__val { font-family: var(--font-display); font-weight: 600; font-size: 1.2rem; letter-spacing: -0.01em; }
.contact__sub { font-size: .9rem; color: var(--fg-subtle); }
.contact__form-wrap { background: var(--surface); border: 1px solid rgba(232,213,176,.1); border-radius: var(--r-xl); padding: clamp(28px,4vw,56px); }
.contact__form-h { font-size: clamp(1.8rem,3vw,2.8rem); letter-spacing: -0.03em; margin: 0 0 10px; }
.contact__form-p { color: var(--fg-muted); margin-bottom: 32px; }
.contact__form { display: flex; flex-direction: column; gap: 18px; }
.contact__row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.contact__field { display: flex; flex-direction: column; gap: 7px; }
.contact__field label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-muted); }
.contact__field input, .contact__field textarea {
  font-family: var(--font-body); font-size: 15px; color: var(--fg);
  background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--r-md);
  padding: 14px 18px; outline: none; resize: vertical;
}
.contact__field input::placeholder, .contact__field textarea::placeholder { color: var(--fg-subtle); }
.contact__field input:focus, .contact__field textarea:focus { border-color: var(--emerald-300); box-shadow: 0 0 0 3px rgba(110,144,121,.22); }
.contact__thanks { display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 48px 0; color: var(--sand-200); }
.contact__thanks h3 { font-size: 1.8rem; letter-spacing: -0.02em; color: var(--fg); }
.contact__thanks p { color: var(--fg-muted); }
@media (max-width:720px) { .contact__cards { grid-template-columns: 1fr; } .contact__row { grid-template-columns: 1fr; } }

/* --- FAQ --- */
.faq__tabs { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 36px; }
.faq__tab {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  border-radius: var(--r-pill); padding: 11px 20px; border: 1px solid var(--border-strong);
  color: var(--fg-muted); transition: all .18s; background: none; cursor: pointer;
}
.faq__tab:hover { color: var(--fg); border-color: var(--sand-400); }
.faq__tab.is-active { background: var(--emerald-700); color: var(--cream-50); border-color: var(--emerald-500); }
.faq__section { display: none; }
.faq__section.is-active { display: block; }
.faq__list { display: flex; flex-direction: column; margin-bottom: 56px; }
.faq__item { border-bottom: 1px solid rgba(232,213,176,.1); }
.faq__q {
  width: 100%; display: flex; justify-content: space-between; align-items: center;
  gap: 16px; padding: 22px 0; text-align: left; font-family: var(--font-display);
  font-weight: 600; font-size: clamp(1rem,1.8vw,1.2rem); letter-spacing: -0.01em;
  color: var(--fg); transition: color .18s; background: none; border: none; cursor: pointer;
}
.faq__q:hover { color: var(--sand-200); }
.faq__icon { flex: none; color: var(--sand-400); transition: transform .25s; font-size: 20px; line-height: 1; }
.faq__item.is-open .faq__icon { transform: rotate(45deg); }
.faq__a { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .3s cubic-bezier(.22,1,.36,1); }
.faq__item.is-open .faq__a { grid-template-rows: 1fr; }
.faq__a-inner { overflow: hidden; min-height: 0; }
.faq__a p { color: var(--fg-muted); line-height: 1.72; padding-bottom: 22px; margin: 0; max-width: 70ch; }
.faq__cta { background: var(--surface); border-radius: var(--r-xl); border: 1px solid rgba(232,213,176,.1); padding: clamp(28px,4vw,52px); display: flex; flex-direction: column; align-items: flex-start; gap: 10px; }
.faq__cta h3 { font-size: clamp(1.6rem,3vw,2.4rem); letter-spacing: -0.03em; margin: 0; }

/* ===== WooCommerce global resets ===== */
.woocommerce-notices-wrapper { max-width: 1320px; margin: 0 auto; padding: 0 28px; }
.woocommerce-message, .woocommerce-info {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg);
  color: var(--fg); padding: 14px 20px; font-family: var(--font-mono); font-size: 12px;
  letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 16px;
}
.woocommerce-error li { color: var(--accent-pink); }

/* ===== Accessibility ===== */
:focus-visible { outline: 2px solid var(--focus-ring); outline-offset: 3px; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ===== Reduced motion ===== */
@media (prefers-reduced-motion: reduce) {
  .tile, .marquee__track, .show__piece, .show__hint-line { animation: none !important; }
}

/* ===== WooCommerce native add-to-cart form — styled to match WÁSIU ===== */
.pdp-wc-form { margin-top: 24px; }

/* Hide WC's default quantity input — we don't need it */
.pdp-wc-form .quantity { display: none !important; }

/* Size/variation selector */
.pdp-wc-form .variations { width: 100%; border-collapse: collapse; margin-bottom: 20px; }
.pdp-wc-form .variations td,
.pdp-wc-form .variations th { padding: 0; border: none; }
.pdp-wc-form .variations label {
  font-family: var(--font-mono); font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-subtle);
  display: block; margin-bottom: 10px;
}
.pdp-wc-form .variations select {
  width: 100%; background: var(--surface); color: var(--fg);
  border: 1px solid var(--border-strong); border-radius: var(--r-md);
  padding: 14px 16px; font-family: var(--font-mono); font-size: 14px;
  cursor: pointer; appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a89c8a' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 14px center;
}
.pdp-wc-form .variations select:focus { outline: none; border-color: var(--emerald-300); }
.pdp-wc-form .variations select option { background: #1a1918; }

/* Reset variation link */
.pdp-wc-form .reset_variations {
  font-family: var(--font-mono); font-size: 10px; color: var(--fg-subtle);
  text-decoration: none; letter-spacing: 0.08em; text-transform: uppercase;
  display: inline-block; margin-top: 6px;
}

/* The actual add-to-cart button */
.pdp-wc-form .single_add_to_cart_button {
  width: 100%; padding: 18px 24px;
  background: var(--emerald-700) !important; color: var(--cream-50) !important;
  border: none !important; border-radius: var(--r-pill) !important;
  font-family: var(--font-mono) !important; font-size: 13px !important;
  font-weight: 700 !important; letter-spacing: 0.1em !important;
  text-transform: uppercase !important; cursor: pointer !important;
  transition: background .18s, transform .15s !important;
  margin-top: 16px; display: block;
}
.pdp-wc-form .single_add_to_cart_button:hover {
  background: var(--emerald-500) !important; transform: translateY(-2px) !important;
}
.pdp-wc-form .single_add_to_cart_button.loading { opacity: 0.7; }
.pdp-wc-form .single_add_to_cart_button.added { background: var(--emerald-500) !important; }

/* WC notices on product page */
.woocommerce-message, .woocommerce-error, .woocommerce-info {
  background: var(--surface) !important; color: var(--fg) !important;
  border-top: 3px solid var(--emerald-500) !important;
  border-radius: var(--r-md) !important; padding: 16px 20px !important;
  font-family: var(--font-mono) !important; font-size: 12px !important;
  letter-spacing: 0.06em !important; margin: 16px 0 !important;
  list-style: none !important;
}
.woocommerce-message a.button {
  background: var(--emerald-700) !important; color: var(--cream-50) !important;
  border-radius: var(--r-pill) !important; padding: 10px 20px !important;
  text-decoration: none !important; font-size: 11px !important;
  float: right !important; margin-top: -4px !important;
}

/* WC cart + checkout page styling */
.woocommerce, .woocommerce-page { background: #0A0A0A; color: #F7F3EB; }
.woocommerce table.shop_table {
  background: var(--surface); border-color: var(--border) !important;
  color: var(--fg); border-radius: var(--r-md); overflow: hidden;
}
.woocommerce table.shop_table th { color: var(--fg-subtle); font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; padding: 14px 16px; }
.woocommerce table.shop_table td { padding: 16px; border-color: var(--border) !important; }
.woocommerce .cart_totals h2, .woocommerce .checkout h3 { color: var(--fg); font-family: var(--font-display); }
.woocommerce .button, .woocommerce button[type="submit"] {
  background: var(--emerald-700) !important; color: var(--cream-50) !important;
  border-radius: var(--r-pill) !important; font-family: var(--font-mono) !important;
  font-size: 12px !important; font-weight: 700 !important; letter-spacing: 0.1em !important;
  text-transform: uppercase !important; padding: 14px 28px !important;
  border: none !important;
}
.woocommerce .button:hover, .woocommerce button[type="submit"]:hover {
  background: var(--emerald-500) !important;
}
.woocommerce form .form-row input, .woocommerce form .form-row textarea, .woocommerce form .form-row select {
  background: var(--surface) !important; color: var(--fg) !important;
  border-color: var(--border-strong) !important; border-radius: var(--r-md) !important;
  padding: 12px 14px !important;
}
.woocommerce-input-wrapper input:focus, .woocommerce form .form-row input:focus {
  border-color: var(--emerald-300) !important; outline: none !important;
}
.woocommerce form .form-row label { color: var(--fg-subtle); font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; }


/* =====================================================================
   WooCommerce global overrides — cart, checkout, product pages
   ===================================================================== */

/* Force dark background on all WC pages */
.woocommerce, .woocommerce-page,
body.woocommerce, body.woocommerce-page,
body.woocommerce-cart, body.woocommerce-checkout {
  background: #0A0A0A !important; color: #F7F3EB !important;
}

/* WC notices */
.woocommerce-message, .woocommerce-error, .woocommerce-info {
  background: #141311 !important; color: #F7F3EB !important;
  border-top: 3px solid var(--emerald-700) !important;
  border-radius: 12px !important; padding: 16px 20px !important;
  font-size: 14px !important; margin: 0 0 24px !important; list-style: none !important;
}
.woocommerce-message a.button, .woocommerce-info a.button {
  background: var(--emerald-700) !important; color: var(--cream-50) !important;
  border-radius: 999px !important; padding: 10px 20px !important;
  text-decoration: none !important; font-size: 11px !important;
  font-family: var(--font-mono) !important; float: right !important;
  border: none !important;
}

/* Cart page */
.woocommerce-cart-form table.shop_table { width: 100%; border-collapse: collapse; }
.woocommerce-cart-form table.shop_table th {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .2em;
  text-transform: uppercase; color: rgba(247,243,235,.4);
  padding: 12px 16px; border-bottom: 1px solid rgba(247,243,235,.1); background: none; font-weight: 400;
}
.woocommerce-cart-form table.shop_table td {
  padding: 20px 16px; border-bottom: 1px solid rgba(247,243,235,.08); vertical-align: middle; background: none;
}
.woocommerce-cart-form .product-thumbnail img {
  width: 80px !important; height: 80px !important; object-fit: contain !important;
  background: #F7F3EB; border-radius: 8px; padding: 4px;
}
.woocommerce-cart-form .product-name a { color: #F7F3EB; text-decoration: none; font-size: 16px; font-weight: 500; }
.woocommerce-cart-form .product-name a:hover { color: var(--sand-200); }
.woocommerce-cart-form .product-name .variation dt,
.woocommerce-cart-form .product-name .variation dd {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .12em;
  color: rgba(247,243,235,.4); display: inline; margin: 0;
}
.woocommerce-cart-form .product-name .variation dt::after { content: ': '; }
.woocommerce-cart-form .product-price,
.woocommerce-cart-form .product-subtotal { font-family: var(--font-mono); font-size: 15px; color: var(--sand-200); }
.woocommerce-cart-form .quantity { display: inline-flex; align-items: center; border: 1px solid rgba(247,243,235,.2); border-radius: 8px; }
.woocommerce-cart-form input.qty {
  background: transparent !important; border: none !important; color: #F7F3EB !important;
  padding: 8px !important; font-family: var(--font-mono) !important; font-size: 13px !important;
  width: 48px !important; text-align: center !important; -moz-appearance: textfield !important;
}
.woocommerce-cart-form input.qty::-webkit-inner-spin-button,
.woocommerce-cart-form input.qty::-webkit-outer-spin-button { -webkit-appearance: none !important; }
.woocommerce-cart-form .product-remove a { color: rgba(247,243,235,.3) !important; font-size: 20px; text-decoration: none; transition: color .2s; }
.woocommerce-cart-form .product-remove a:hover { color: #e87c6a !important; }
.woocommerce-cart-form .actions {
  padding: 20px 16px 0; display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap;
}
.woocommerce-cart-form .coupon { display: flex; }
.woocommerce-cart-form .coupon input#coupon_code {
  background: transparent !important; border: 1px solid rgba(247,243,235,.2) !important;
  border-right: none !important; color: #F7F3EB !important; padding: 11px 16px !important;
  font-family: var(--font-mono) !important; font-size: 11px !important;
  border-radius: 8px 0 0 8px !important; outline: none !important; min-width: 140px;
}
.woocommerce-cart-form .coupon .button,
.woocommerce-cart-form .button[name=update_cart] {
  font-family: var(--font-mono) !important; font-size: 10px !important; letter-spacing: .16em !important;
  text-transform: uppercase !important; padding: 11px 16px !important;
  background: rgba(44,82,64,.5) !important; border: 1px solid rgba(60,102,80,.4) !important;
  color: #F7F3EB !important; cursor: pointer !important;
}
.woocommerce-cart-form .coupon .button { border-radius: 0 8px 8px 0 !important; }
.woocommerce-cart-form .button[name=update_cart] { border-radius: 8px !important; }
body.woocommerce-cart .cart-collaterals { display: none !important; }

/* Cart totals */
.cart_totals > h2 { font-size: 16px; font-weight: 600; letter-spacing: -.02em; margin: 0 0 20px; }
.cart_totals table { width: 100%; border-collapse: collapse; }
.cart_totals table th {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .16em;
  text-transform: uppercase; color: rgba(247,243,235,.4); font-weight: 400;
  padding: 13px 0; border-bottom: 1px solid rgba(247,243,235,.08); vertical-align: top;
}
.cart_totals table td { padding: 13px 0; border-bottom: 1px solid rgba(247,243,235,.08); font-size: 14px; }
.cart_totals .order-total td, .cart_totals .order-total th { border-bottom: none; padding-top: 18px; }
.cart_totals .order-total .woocommerce-Price-amount { font-size: 24px; color: var(--sand-200); font-weight: 700; }
.cart_totals .wc-proceed-to-checkout { margin-top: 20px; }
.cart_totals .wc-proceed-to-checkout a.checkout-button {
  display: block !important; text-align: center !important; width: 100% !important;
  padding: 18px !important; font-family: var(--font-mono) !important; font-size: 12px !important;
  letter-spacing: .16em !important; text-transform: uppercase !important;
  background: var(--emerald-700) !important; color: var(--cream-50) !important;
  border: none !important; border-radius: 999px !important; transition: background .18s !important;
  text-decoration: none !important;
}
.cart_totals .wc-proceed-to-checkout a.checkout-button:hover { background: var(--emerald-500) !important; }

/* Checkout form fields */
.woocommerce-checkout h3 { font-size: 18px; font-weight: 700; letter-spacing: -.02em; margin: 0 0 20px; padding-bottom: 12px; border-bottom: 1px solid rgba(247,243,235,.08); }
.woocommerce form .form-row label {
  font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: rgba(247,243,235,.45); display: block; margin-bottom: 6px;
}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea {
  width: 100%; background: #141311 !important; color: #F7F3EB !important;
  border: 1px solid rgba(247,243,235,.2) !important; border-radius: 10px !important;
  padding: 13px 16px !important; font-size: 15px !important; font-family: inherit !important;
  transition: border-color .18s !important; box-sizing: border-box !important;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus { border-color: var(--emerald-300) !important; outline: none !important; }
.woocommerce form .form-row select {
  appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a89c8a' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important; background-position: right 14px center !important;
  background-color: #141311 !important; padding-right: 40px !important;
}
#payment { background: #141311 !important; border: 1px solid rgba(247,243,235,.08) !important; border-radius: 16px !important; }
#payment .wc_payment_methods { list-style: none; padding: 16px; margin: 0; }
#payment .wc_payment_methods li { padding: 14px; border: 1px solid rgba(247,243,235,.1); border-radius: 10px; margin-bottom: 8px; }
#payment .payment_box { background: rgba(247,243,235,.04); border-radius: 8px; padding: 14px; margin-top: 10px; font-size: 13px; color: rgba(247,243,235,.6); }
#place_order {
  width: 100% !important; padding: 18px !important;
  background: var(--emerald-700) !important; color: var(--cream-50) !important;
  border: none !important; border-radius: 999px !important;
  font-family: var(--font-mono) !important; font-size: 13px !important;
  font-weight: 700 !important; letter-spacing: .1em !important; text-transform: uppercase !important;
  cursor: pointer !important; transition: background .18s !important; margin-top: 20px !important;
}
#place_order:hover { background: var(--emerald-500) !important; }

/* Order received page */
.woocommerce-order-received h2, .woocommerce-thankyou-order-details { color: #F7F3EB; }
.woocommerce-thankyou-order-details li { border-bottom: 1px solid rgba(247,243,235,.08) !important; }

/* ═══════════════════════════════════════════════════
   GLOBAL FORM FIELD OVERRIDES
   Dark background, clearly readable cream text,
   fully rounded borders matching button style
═══════════════════════════════════════════════════ */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="number"],
input[type="url"],
input[type="search"],
select,
textarea,
.woocommerce input.input-text,
.woocommerce-page input.input-text,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea,
.wc-coupon input,
.checkout_coupon input[type="text"],
#coupon_code,
.cart-discount input {
  background: #0d0d0c !important;
  color: #F7F3EB !important;
  border: 1.5px solid rgba(247, 243, 235, 0.2) !important;
  border-radius: 12px !important;
  padding: 14px 18px !important;
  font-size: 15px !important;
  font-family: inherit !important;
  line-height: 1.5 !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  box-sizing: border-box !important;
  transition: border-color 0.18s, box-shadow 0.18s !important;
  /* Force override any browser autofill yellow */
  -webkit-box-shadow: 0 0 0 1000px #0d0d0c inset !important;
  -webkit-text-fill-color: #F7F3EB !important;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
input[type="url"]:focus,
select:focus,
textarea:focus,
.woocommerce input.input-text:focus,
.woocommerce-page input.input-text:focus,
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus,
.woocommerce form .form-row textarea:focus {
  border-color: #3C6650 !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(60, 102, 80, 0.18) !important;
  -webkit-box-shadow: 0 0 0 1000px #0d0d0c inset, 0 0 0 3px rgba(60, 102, 80, 0.18) !important;
}

input::placeholder,
textarea::placeholder,
.woocommerce input.input-text::placeholder {
  color: rgba(247, 243, 235, 0.3) !important;
  -webkit-text-fill-color: rgba(247, 243, 235, 0.3) !important;
}

/* Select dropdown arrow */
select,
.woocommerce form .form-row select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a89c8a' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 16px center !important;
  background-color: #0d0d0c !important;
  padding-right: 44px !important;
}


/* ── Additional input targets: WPForms, CF7, Kadence forms, search ── */
.wpforms-field input[type="text"],
.wpforms-field input[type="email"],
.wpforms-field input[type="tel"],
.wpforms-field input[type="number"],
.wpforms-field input[type="url"],
.wpforms-field select,
.wpforms-field textarea,
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 select,
.wpcf7 textarea,
.kb-form input[type="text"],
.kb-form input[type="email"],
.kb-form select,
.kb-form textarea,
.kadence-form input,
.kadence-form select,
.kadence-form textarea,
input.search-field,
.search-form input[type="search"],
.widget input[type="text"],
.widget input[type="email"],
.widget select,
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
  background: #0d0d0c !important;
  color: #F7F3EB !important;
  -webkit-text-fill-color: #F7F3EB !important;
  -webkit-box-shadow: 0 0 0 1000px #0d0d0c inset !important;
  border: 1.5px solid rgba(247,243,235,.22) !important;
  border-radius: 12px !important;
  padding: 13px 18px !important;
  font-size: 15px !important;
  font-family: inherit !important;
  line-height: 1.5 !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  box-sizing: border-box !important;
  transition: border-color .18s, box-shadow .18s !important;
}
.wpforms-field input:focus,
.wpforms-field select:focus,
.wpforms-field textarea:focus,
.wpcf7 input:focus,
.wpcf7 select:focus,
.wpcf7 textarea:focus,
.kb-form input:focus,
.kb-form select:focus,
.kb-form textarea:focus,
input.search-field:focus,
.comment-form input:focus,
.comment-form textarea:focus {
  border-color: #3C6650 !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(60,102,80,.18) !important;
  -webkit-box-shadow: 0 0 0 1000px #0d0d0c inset, 0 0 0 3px rgba(60,102,80,.18) !important;
}
/* Quantity inputs — still rounded but compact */
input[type="number"].qty,
.qty-wrap input.qty,
.woocommerce-cart-form input.qty {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 8px 6px !important;
  font-size: 13px !important;
  color: #F7F3EB !important;
  -webkit-text-fill-color: #F7F3EB !important;
  -webkit-box-shadow: none !important;
  width: 44px !important;
  text-align: center !important;
  -moz-appearance: textfield !important;
}
input[type="number"].qty::-webkit-inner-spin-button,
input[type="number"].qty::-webkit-outer-spin-button,
.qty-wrap input.qty::-webkit-inner-spin-button,
.qty-wrap input.qty::-webkit-outer-spin-button {
  -webkit-appearance: none !important;
}

/* Coupon code field — shorter height fits inline */
input#coupon_code,
.wc-coupon input[type="text"],
.checkout_coupon input[type="text"] {
  padding: 11px 14px !important;
  font-size: 13px !important;
  border-radius: 12px !important;
}

/* Newsletter / email inputs in footer */
.wasiu-subscribe input[type="email"],
.footer-signup input[type="email"],
input.wasiu-email {
  border-radius: 12px !important;
  background: rgba(247,243,235,.07) !important;
  color: #F7F3EB !important;
  -webkit-text-fill-color: #F7F3EB !important;
  -webkit-box-shadow: 0 0 0 1000px rgba(20,19,17,0.95) inset !important;
}


/* ═══════════════════════════════════════════════════
   SELECT2 / WC ENHANCED DROPDOWNS
   (WooCommerce country & state selectors)
═══════════════════════════════════════════════════ */
.select2-container .select2-selection--single,
.select2-container--default .select2-selection--single {
  background: #0d0d0c !important;
  border: 1.5px solid rgba(247,243,235,.22) !important;
  border-radius: 12px !important;
  height: auto !important;
  padding: 12px 44px 12px 18px !important;
  outline: none !important;
}
.select2-container .select2-selection--single .select2-selection__rendered,
.select2-container--default .select2-selection--single .select2-selection__rendered {
  color: #F7F3EB !important;
  font-size: 15px !important;
  font-family: inherit !important;
  line-height: 1.5 !important;
  padding: 0 !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 100% !important;
  right: 14px !important;
  top: 0 !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow b {
  border-color: rgba(247,243,235,.5) transparent transparent transparent !important;
  border-width: 5px 4px 0 4px !important;
}
.select2-container--default.select2-container--open .select2-selection--single .select2-selection__arrow b {
  border-color: transparent transparent rgba(247,243,235,.5) transparent !important;
  border-width: 0 4px 5px 4px !important;
}
.select2-container--default.select2-container--open .select2-selection--single,
.select2-container--default.select2-container--focus .select2-selection--single {
  border-color: #3C6650 !important;
  box-shadow: 0 0 0 3px rgba(60,102,80,.18) !important;
}
/* Dropdown panel */
.select2-dropdown,
.select2-container--default .select2-dropdown {
  background: #141311 !important;
  border: 1.5px solid rgba(247,243,235,.18) !important;
  border-radius: 12px !important;
  box-shadow: 0 8px 32px rgba(0,0,0,.5) !important;
  overflow: hidden !important;
  margin-top: 4px !important;
}
/* Search box inside dropdown */
.select2-container--default .select2-search--dropdown .select2-search__field {
  background: #0d0d0c !important;
  color: #F7F3EB !important;
  -webkit-text-fill-color: #F7F3EB !important;
  -webkit-box-shadow: 0 0 0 1000px #0d0d0c inset !important;
  border: 1.5px solid rgba(247,243,235,.18) !important;
  border-radius: 8px !important;
  padding: 10px 14px !important;
  font-size: 14px !important;
  margin: 8px !important;
  width: calc(100% - 16px) !important;
  box-sizing: border-box !important;
  outline: none !important;
}
.select2-container--default .select2-search--dropdown .select2-search__field::placeholder {
  color: rgba(247,243,235,.3) !important;
}
.select2-container--default .select2-search--dropdown .select2-search__field:focus {
  border-color: #3C6650 !important;
}
/* Option items */
.select2-container--default .select2-results__option {
  background: transparent !important;
  color: rgba(247,243,235,.75) !important;
  font-size: 14px !important;
  padding: 11px 18px !important;
  transition: background .12s !important;
}
.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-results__option--highlighted[data-selected] {
  background: #2C5240 !important;
  color: #F7F3EB !important;
}
.select2-container--default .select2-results__option[aria-selected=true],
.select2-container--default .select2-results__option[data-selected=true] {
  background: rgba(60,102,80,.35) !important;
  color: #F7F3EB !important;
}
/* Scrollbar in dropdown */
.select2-results__options::-webkit-scrollbar { width: 4px; }
.select2-results__options::-webkit-scrollbar-track { background: #141311; }
.select2-results__options::-webkit-scrollbar-thumb { background: rgba(247,243,235,.15); border-radius: 2px; }

/* ═══════════════════════════════════════════════════
   TEXTAREA — global dark override
═══════════════════════════════════════════════════ */
textarea {
  background: #0d0d0c !important;
  color: #F7F3EB !important;
  -webkit-text-fill-color: #F7F3EB !important;
  -webkit-box-shadow: 0 0 0 1000px #0d0d0c inset !important;
  border: 1.5px solid rgba(247,243,235,.22) !important;
  border-radius: 12px !important;
  padding: 14px 18px !important;
  font-size: 15px !important;
  font-family: inherit !important;
  line-height: 1.6 !important;
  resize: vertical !important;
  outline: none !important;
  width: 100% !important;
  box-sizing: border-box !important;
  transition: border-color .18s, box-shadow .18s !important;
}
textarea::placeholder {
  color: rgba(247,243,235,.32) !important;
  -webkit-text-fill-color: rgba(247,243,235,.32) !important;
}
textarea:focus {
  border-color: #3C6650 !important;
  box-shadow: 0 0 0 3px rgba(60,102,80,.18) !important;
  -webkit-box-shadow: 0 0 0 1000px #0d0d0c inset, 0 0 0 3px rgba(60,102,80,.18) !important;
}

/* ── Footer email input — pill shape override (must come after global block) ── */
.footer__input,
input.footer__input[type="email"] {
  border-radius: 999px !important;
  background: #0d0d0c !important;
  color: #F7F3EB !important;
  -webkit-text-fill-color: #F7F3EB !important;
  -webkit-box-shadow: 0 0 0 1000px #0d0d0c inset !important;
  border: 1.5px solid rgba(247,243,235,.22) !important;
  padding: 14px 22px !important;
}
.footer__input::placeholder,
input.footer__input[type="email"]::placeholder {
  color: rgba(247,243,235,.32) !important;
  -webkit-text-fill-color: rgba(247,243,235,.32) !important;
}
.footer__input:focus,
input.footer__input[type="email"]:focus {
  border-color: #3C6650 !important;
  box-shadow: 0 0 0 3px rgba(60,102,80,.18) !important;
  -webkit-box-shadow: 0 0 0 1000px #0d0d0c inset, 0 0 0 3px rgba(60,102,80,.18) !important;
}
