@import url('https://fonts.googleapis.com/css2?family=Sarabun:wght@300;400;500;600;700;800;900&display=swap');

:root {
  --ink: #222222;
  --muted: #6b6259;
  --line: #ded3c2;
  --paper: #F4EFE4;
  --soft: #ebe0ce;
  --brand: #4A3426;
  --accent: #B08A45;
  --accent-dark: #4A3426;
  --success: #2F3A2D;
  --outdoor-green: #2F3A2D;
  --wood: #4A3426;
  --brass: #B08A45;
  --canvas: #F4EFE4;
  --charcoal: #222222;
  --radius: 8px;
  --font-main: "Sarabun", "TH Sarabun New", "TH SarabunPSK", "Noto Sans Thai", Tahoma, sans-serif;
}

* { box-sizing: border-box; font-family: var(--font-main); }
*::before,
*::after { font-family: inherit; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--paper);
  font-family: var(--font-main);
  font-size: 20px;
  line-height: 1.48;
}
h1, h2, h3, h4, h5, h6, a, button, input, select, textarea, label, summary, th, td, small, .brand strong, .button, .btn, .product-card__price, .site-nav__scroll, .filters h2 {
  font-family: var(--font-main);
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button, input, select, textarea { font: inherit; }
.site-container { width: min(1200px, calc(100% - 40px)); margin: 0 auto; }
.container { width: min(1200px, calc(100% - 40px)); margin: 0 auto; padding: 34px 0; }

.site-topbar { border-bottom: 1px solid var(--line); background: #f0efed; font-size: 20px; }
.site-topbar__inner { min-height: 34px; display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.site-topbar nav { display: flex; gap: 18px; align-items: center; font-weight: 700; }
body:not(.admin-page) {
  padding-top: 38px;
}
body:not(.admin-page) .site-topbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 120;
  background: #172615;
  color: #fff;
  border-bottom: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 8px 22px rgba(0,0,0,.16);
}
body:not(.admin-page) .site-topbar__inner {
  min-height: 38px;
}
body:not(.admin-page) .site-topbar nav a,
body:not(.admin-page) .site-topbar nav span:not(.language-switch) {
  color: #fff;
}
body:not(.admin-page) .site-nav {
  top: 38px;
}
.language-switch {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #fff;
}
.language-switch button {
  min-height: 28px;
  padding: 4px 10px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--muted);
  font-size: 14px;
  font-weight: 900;
}
.language-switch button.is-active {
  background: #111;
  color: #fff;
}
.phone-icon {
  display: inline-block;
  margin-right: 4px;
  color: var(--accent);
  font-weight: 900;
}
#google_translate_element,
.goog-te-banner-frame,
.goog-te-balloon-frame,
.goog-te-gadget,
.skiptranslate {
  display: none !important;
}
body {
  top: 0 !important;
}
.site-nav { position: sticky; top: 0; z-index: 10; background: var(--paper); box-shadow: 0 1px 0 rgba(0,0,0,.06); }
.site-nav__inner { min-height: 124px; display: flex; gap: 28px; justify-content: space-between; align-items: center; }
.brand { display: flex; align-items: center; gap: 16px; min-width: 500px; }
.brand__logo { width: 230px; height: 120px; object-fit: contain; }
.brand strong { display: block; font-size: 28px; line-height: 1.05; font-weight: 900; }
.brand small { display: block; color: var(--muted); font-size: 20px; font-weight: 650; margin-top: 2px; }
.searchbar { flex: 1; max-width: 460px; }
.searchbar input { width: 100%; border: 1px solid var(--line); border-radius: 999px; padding: 14px 20px; background: #fff; }
.phone { font-weight: 700; white-space: nowrap; }
.site-nav__categories { background: #020202; color: #fff; }
.site-nav__menu-wrap { min-height: 54px; display: flex; align-items: center; }
.mobile-menu-button { display: none; }
.site-nav__scroll { min-height: 54px; display: flex; align-items: center; gap: 30px; overflow-x: auto; white-space: nowrap; font-weight: 850; font-size: 22px; }
.site-nav__scroll {
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.site-nav__scroll::-webkit-scrollbar {
  display: none;
}
.site-nav__scroll a { position: relative; opacity: .78; transition: opacity 160ms ease, color 160ms ease; }
.site-nav__scroll a[href$="#products"] { order: 1; }
.site-nav__scroll a[href*="page=order_status"] { order: 2; }
.site-nav__scroll a[href*="page=payment_notify"] { order: 3; }
.site-nav__scroll a[href$="#camp-media"] { order: 4; }
.site-nav__scroll a[href$="#camp-gallery"] { order: 5; }
.site-nav__scroll a[href$="#compare"] { order: 6; }
.site-nav__scroll a[href$="#how-to-order"] { order: 7; }
.site-nav__scroll a[href$="#shipping"] { order: 8; }
.site-nav__scroll a[href$="#faq"] { order: 9; }
.site-nav__scroll a[href$="admin.php"] { order: 10; }
.site-nav__scroll a:hover,
.site-nav__scroll a.is-active { opacity: 1; color: #fff; }
.site-nav__scroll a.is-active::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -13px;
  height: 3px;
  background: var(--accent);
}

/* Outdoor premium storefront theme */
body:not(.admin-page) {
  background:
    linear-gradient(180deg, rgba(244,239,228,.98), rgba(244,239,228,1)),
    var(--canvas);
  color: var(--charcoal);
}

body:not(.admin-page) .site-topbar,
body:not(.admin-page) .site-nav,
body:not(.admin-page) .site-nav__categories {
  background: var(--outdoor-green);
  color: #fff;
  border-color: rgba(255,255,255,.10);
}

body:not(.admin-page) .site-nav {
  box-shadow: 0 16px 34px rgba(17, 23, 16, .24);
}

body:not(.admin-page) .site-topbar {
  background: #1f291f;
}

body:not(.admin-page) .site-topbar nav a,
body:not(.admin-page) .site-topbar__inner > span,
body:not(.admin-page) .brand small,
body:not(.admin-page) .phone,
body:not(.admin-page) .site-nav__scroll a {
  color: rgba(255,255,255,.86);
}

body:not(.admin-page) .brand strong {
  color: #fff;
}

body:not(.admin-page) .searchbar input {
  border-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.94);
}

body:not(.admin-page) .site-nav__scroll {
  justify-content: center;
}

body:not(.admin-page) .site-nav__scroll a.is-active::after {
  background: var(--brass);
}

body:not(.admin-page) .button,
body:not(.admin-page) .btn,
body:not(.admin-page) button {
  border-color: var(--wood);
  background: var(--wood);
}

body:not(.admin-page) .button--primary,
body:not(.admin-page) .product-card .inline .button {
  border-color: var(--outdoor-green);
  background: var(--outdoor-green);
}

body:not(.admin-page) .button--secondary,
body:not(.admin-page) .btn.light,
body:not(.admin-page) button.secondary {
  background: rgba(255,255,255,.92);
  color: var(--wood);
}

body:not(.admin-page) .hero {
  min-height: 560px;
}

body:not(.admin-page) .hero__image {
  background:
    linear-gradient(90deg, rgba(18, 28, 18, .88), rgba(18, 28, 18, .28) 58%, rgba(18, 28, 18, .50)),
    var(--hero-image) center / cover;
}

body:not(.admin-page) .hero h1 {
  text-transform: uppercase;
  letter-spacing: .01em;
  text-shadow: 0 6px 22px rgba(0,0,0,.32);
}

body:not(.admin-page) .hero p:not(.eyebrow) {
  color: rgba(255,255,255,.88);
}

body:not(.admin-page) .eyebrow {
  color: var(--brass);
}

body:not(.admin-page) .trust-strip {
  background: #fbf7ee;
}

body:not(.admin-page) .trust-strip__grid div {
  display: flex;
  gap: 14px;
  min-height: 92px;
  align-items: center;
}

body:not(.admin-page) .trust-strip strong::before {
  content: "◎";
  margin-right: 8px;
  color: var(--brass);
}

.home-category-showcase {
  padding: 46px 0;
  background: var(--canvas);
}

body:not(.admin-page) .trust-strip strong::before {
  content: none !important;
}

.trust-icon {
  width: 38px;
  height: 38px;
  flex: 0 0 38px;
  display: grid;
  place-items: center;
  color: var(--brass);
}

.trust-icon svg {
  width: 100%;
  height: 100%;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.65;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.trust-strip strong {
  font-size: 16px;
  line-height: 1.25;
}

.trust-strip small {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.35;
}

.home-showcase-grid {
  display: grid;
  grid-template-columns: minmax(220px, .58fr) minmax(0, 1.42fr);
  gap: 28px;
  align-items: center;
}

.home-showcase-copy h2,
.featured-brands-grid h2 {
  margin: 0 0 12px;
  font-size: clamp(24px, 3vw, 34px);
  line-height: 1.1;
  color: var(--charcoal);
}

.home-showcase-copy p:not(.eyebrow) {
  color: var(--muted);
}

.category-card-row {
  display: grid;
  grid-template-columns: repeat(5, minmax(120px, 1fr));
  gap: 12px;
}

.category-mini-card {
  overflow: hidden;
  border: 1px solid rgba(74,52,38,.12);
  border-radius: 6px;
  background: #fbf7ee;
  text-align: center;
  box-shadow: 0 12px 28px rgba(74,52,38,.08);
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.category-mini-card:hover,
.category-mini-card:focus {
  border-color: rgba(176,138,69,.42);
  transform: translateY(-3px);
  box-shadow: 0 18px 38px rgba(74,52,38,.14);
}

.category-mini-card img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.category-mini-card strong,
.category-mini-card span {
  display: block;
}

.category-mini-card strong {
  padding: 12px 8px 0;
  color: var(--charcoal);
  font-size: 16px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .02em;
}

.category-mini-card span {
  padding: 1px 8px 14px;
  color: var(--muted);
  font-size: 14px;
  font-weight: 700;
}

.featured-brands-band {
  padding: 34px 0;
  background:
    linear-gradient(90deg, rgba(47,58,45,.98), rgba(47,58,45,.92)),
    var(--outdoor-green);
  color: #fff;
}

.featured-brands-grid {
  display: grid;
  grid-template-columns: minmax(220px, .55fr) minmax(0, 1.45fr);
  gap: 28px;
  align-items: center;
}

.featured-brands-grid h2 {
  color: #fff;
}

.brand-tile-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(120px, 1fr));
  gap: 10px;
}

.brand-tile-row a {
  min-height: 88px;
  display: grid;
  place-items: center;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.04);
  color: #fff;
  font-weight: 900;
  text-align: center;
  text-transform: uppercase;
}

body:not(.admin-page) .media-section,
body:not(.admin-page) .section--store,
body:not(.admin-page) .footer {
  background: #182218;
}

body:not(.admin-page) .product-card,
body:not(.admin-page) .filters,
body:not(.admin-page) .panel,
body:not(.admin-page) .store-panel,
body:not(.admin-page) .gallery-slider {
  border-color: rgba(74,52,38,.14);
  background: #fffaf2;
  box-shadow: 0 16px 34px rgba(74,52,38,.08);
}

body:not(.admin-page) th {
  background: var(--wood);
}

.flash {
  width: min(1200px, calc(100% - 40px));
  margin: 18px auto 0;
  padding: 16px 18px;
  display: grid;
  grid-template-columns: 38px 1fr 34px;
  gap: 12px;
  align-items: center;
  background: #fff;
  border: 1px solid var(--line);
  border-left: 6px solid var(--accent);
  border-radius: 10px;
  box-shadow: 0 18px 45px rgba(0,0,0,.10);
  font-size: 24px;
  font-weight: 750;
}
.container > .flash { width: auto; margin: 0 0 22px; }
.flash__icon {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: #f1ede5;
  color: var(--ink);
  font-weight: 900;
}
.flash__message { line-height: 1.25; }
.flash__close {
  min-height: 34px;
  width: 34px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: transparent;
  color: #756f66;
  font-size: 28px;
}
.flash--success { border-left-color: #208a50; }
.flash--success .flash__icon { background: #dff7e9; color: #116739; }
.flash--error { border-left-color: #c93636; }
.flash--error .flash__icon { background: #ffe2e2; color: #9b1f1f; }
.flash-alert {
  position: fixed;
  inset: 0;
  z-index: 220;
  display: none;
}
.flash-alert.is-open {
  display: grid;
  place-items: center;
}
.flash-alert__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(17,17,17,.56);
  backdrop-filter: blur(4px);
}
.flash-alert__dialog {
  position: relative;
  width: min(460px, calc(100% - 34px));
  margin: 0;
  padding: 30px 28px;
  display: grid;
  justify-items: center;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fff;
  text-align: center;
  box-shadow: 0 28px 90px rgba(0,0,0,.28);
}
.flash-alert__icon {
  width: 68px;
  height: 68px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: #dff7e9;
  color: #116739;
  font-size: 42px;
  font-weight: 900;
  line-height: 1;
}
.flash-alert--error .flash-alert__icon {
  background: #ffe2e2;
  color: #9b1f1f;
}
.flash-alert--info .flash-alert__icon {
  background: #f1ede5;
  color: var(--ink);
}
.flash-alert__dialog h2 {
  margin: 4px 0 0;
  font-size: 30px;
  line-height: 1.05;
}
.flash-alert__dialog p {
  margin: 0;
  color: var(--muted);
  font-size: 21px;
  line-height: 1.25;
}
.flash-alert__dialog .button {
  min-width: 140px;
  margin-top: 8px;
}
.hero { position: relative; min-height: 540px; display: grid; align-items: end; overflow: hidden; color: #fff; }
.hero__image { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(0,0,0,.74), rgba(0,0,0,.18)), var(--hero-image) center / cover; transform: scale(1.04); }
.hero__content { position: relative; padding: 84px 0; }
.eyebrow { margin: 0 0 10px; color: var(--accent); font-weight: 900; letter-spacing: .08em; text-transform: uppercase; font-size: 20px; }
.hero h1 { width: min(760px, 100%); margin: 0; font-size: clamp(36px, 5.2vw, 64px); line-height: 1.02; font-weight: 900; }
.hero p:not(.eyebrow) { width: min(610px, 100%); margin: 20px 0 0; font-size: 23px; color: rgba(255,255,255,.86); }
.hero__actions, .store-actions, .actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.button, .btn, button {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-height: 46px;
  border: 1px solid var(--ink);
  border-radius: 4px;
  padding: 0 22px;
  cursor: pointer;
  font-weight: 850;
  font-size: 26px;
  line-height: 1.05;
  background: var(--brand);
  color: #fff;
}
.button--primary { background: var(--brand); color: #fff; }
.button--secondary, .btn.light, button.secondary { background: #fff; color: var(--ink); }
.button--small { min-height: 46px; padding: 0 20px; font-size: 26px; }
.trust-strip { border-bottom: 1px solid var(--line); background: #fff; }
.trust-strip__grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.trust-strip__grid div { padding: 22px 20px; border-left: 1px solid var(--line); }
.trust-strip__grid div:last-child { border-right: 1px solid var(--line); }
.trust-strip strong, .trust-strip span { display: block; }
.trust-strip span { color: var(--muted); font-size: 20px; }

.section, .hero, .trust-strip, #products, #camp-media, #camp-gallery, #compare, #how-to-order, #shipping, #faq, #contact {
  scroll-margin-top: 190px;
}
.section { padding: 72px 0; }
.section--tint { background: var(--soft); }
.section__head { margin-bottom: 28px; }
.section__head h2, .collection h2, .product-detail h1, .info-grid h2, .store-card h2 {
  margin: 0;
  font-size: clamp(24px, 3.2vw, 28px);
  line-height: 1.1;
}
.media-section { background: #11100f; color: #fff; }
.media-section__head { display: grid; grid-template-columns: minmax(0,.95fr) minmax(280px,.6fr); gap: 24px; align-items: end; }
.media-section__head p:not(.eyebrow) { color: rgba(255,255,255,.72); margin: 0; }
.media-grid { display: grid; grid-template-columns: minmax(0,1.15fr) minmax(320px,.85fr); gap: 24px; }
.video-section { padding: 82px 0; }
.video-section .site-container { width: min(1320px, calc(100% - 40px)); }
.video-section__head { grid-template-columns: minmax(0, 1fr) minmax(320px, .55fr); }
.video-feature { display: grid; gap: 24px; }
.video-frame--wide {
  aspect-ratio: 16 / 9;
  width: min(100%, 1180px);
  min-height: 0;
  max-height: 68vh;
  margin: 0 auto;
}
.video-frame {
  position: relative;
  overflow: hidden;
}
.video-frame iframe {
  width: 100%;
  height: 100%;
  border: 0;
}
.video-frame video {
  width: 100%;
  height: 100%;
  display: block;
  background: #000;
  object-fit: contain;
}
.video-control {
  position: absolute;
  right: 22px;
  bottom: 22px;
  z-index: 2;
  width: auto;
  min-height: 54px;
  display: inline-flex;
  gap: 10px;
  align-items: center;
  padding: 0 22px;
  border: 1px solid rgba(255,255,255,.28);
  border-radius: 999px;
  background: rgba(10,10,10,.72);
  color: #fff;
  box-shadow: 0 16px 36px rgba(0,0,0,.28);
  backdrop-filter: blur(8px);
}
.video-sound-control {
  right: auto;
  left: 22px;
}
.video-sound-control.is-muted {
  background: rgba(255,255,255,.88);
  color: var(--ink);
}
.video-sound-control.is-muted .video-control__icon {
  background: rgba(0,0,0,.08);
}
.video-control:hover,
.video-control:focus {
  background: #fff;
  color: var(--ink);
}
.video-control__icon {
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(255,255,255,.16);
  font-weight: 900;
}
.video-control:hover .video-control__icon,
.video-control:focus .video-control__icon {
  background: rgba(0,0,0,.08);
}
.video-feature__body {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: center;
  padding: 22px 0 0;
}
.video-feature__body h3 {
  margin: 0;
  font-size: 42px;
}
.video-feature__body p {
  max-width: 720px;
  margin: 0;
  color: rgba(255,255,255,.72);
}
.video-link-list {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}
.video-link-list button {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 46px;
  padding: 0 18px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  color: #fff;
  font-size: 25px;
  font-weight: 800;
}
.video-link-list button:hover,
.video-link-list button:focus,
.video-link-list button.is-active {
  border-color: rgba(255,255,255,.28);
  background: rgba(255,255,255,.14);
}
.video-link-list strong {
  padding: 1px 10px;
  border-radius: 999px;
  background: var(--accent);
  color: #111;
  font-size: 23px;
}
.video-empty {
  padding: 32px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--radius);
  background: rgba(255,255,255,.06);
}
.gallery-section { background: var(--paper); }
.gallery-slider {
  position: relative;
  width: 100%;
  margin: 0 auto;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 18px 45px rgba(0,0,0,.08);
}
.gallery-slider__stage {
  position: relative;
  z-index: 1;
  width: 100%;
  height: clamp(340px, 52vw, 560px);
  min-height: 300px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #111;
}
.gallery-slide {
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity 260ms ease;
}
.gallery-slide.is-active {
  z-index: 1;
  opacity: 1;
  pointer-events: none;
}
.gallery-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.gallery-slide__caption {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 30px 34px;
  color: #fff;
  background: linear-gradient(0deg, rgba(0,0,0,.76), rgba(0,0,0,0));
}
.gallery-slide__caption p {
  margin: 0;
  color: var(--accent);
  font-size: 25px;
  font-weight: 900;
}
.gallery-slide__caption h3 {
  margin: 4px 0 0;
  font-size: 46px;
  line-height: 1.05;
}
.gallery-arrow {
  position: absolute;
  top: 50%;
  z-index: 4;
  width: 56px;
  min-height: 56px;
  padding: 0;
  border-radius: 50%;
  border-color: rgba(255,255,255,.24);
  background: rgba(0,0,0,.55);
  color: #fff;
  font-size: 46px;
  transform: translateY(-50%);
  pointer-events: auto;
}
.gallery-arrow--prev { left: 18px; }
.gallery-arrow--next { right: 18px; }
.gallery-arrow:hover,
.gallery-arrow:focus {
  background: #fff;
  color: var(--ink);
}
.video-card, .gallery-card { overflow: hidden; border: 1px solid rgba(255,255,255,.12); border-radius: var(--radius); background: #1d1a16; }
.video-frame, .gallery-stage { aspect-ratio: 16 / 9; background: #090909; }
.gallery-stage { aspect-ratio: 16 / 10; }
.video-frame img, .gallery-stage img { width: 100%; height: 100%; object-fit: cover; }
.video-card__body, .gallery-caption { padding: 22px; }
.video-card__body h3, .gallery-caption h3 { margin: 0 0 8px; font-size: 32px; line-height: 1.08; }
.video-card__body p, .gallery-caption p { color: rgba(255,255,255,.72); }
.gallery-dots { position: absolute; left: 0; right: 0; bottom: 18px; z-index: 4; display: flex; justify-content: center; gap: 10px; margin-top: 0; pointer-events: none; }
.gallery-dots button { width: 14px; min-height: 14px; height: 14px; padding: 0; border: 0; border-radius: 50%; background: rgba(255,255,255,.65); pointer-events: auto; }
.gallery-dots button.is-active { background: var(--accent); }

.shop-layout { display: grid; grid-template-columns: 260px minmax(0, 1fr); gap: 44px; }
.filters {
  position: sticky;
  top: 126px;
  align-self: start;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 16px 38px rgba(32, 22, 12, .06);
}
.filters h2 { margin: 0; padding: 20px 20px; border-bottom: 1px solid var(--line); font-size: 25px; line-height: 1.05; }
.filters details { padding: 16px 20px; border-bottom: 1px solid var(--line); }
.filters details:last-child { border-bottom: 0; }
.filters summary { cursor: pointer; font-weight: 850; font-size: 22px; }
.filters label, .filter-links a { display: block; margin-top: 12px; color: var(--muted); font-size: 22px; }
.filter-links a {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  transition: background 140ms ease, color 140ms ease;
}
.filter-links a:hover,
.filter-links a:focus,
.filter-links a.is-active {
  background: #171717;
  color: #fff;
}
.tone-dot {
  width: 14px;
  height: 14px;
  flex: 0 0 14px;
  border: 1px solid rgba(0,0,0,.16);
  border-radius: 50%;
  background: #c8b28d;
}
.tone-dot--natural { background: #d8c6a0; }
.tone-dot--suntan { background: #c18a4d; }
.tone-dot--canvas { background: #e9dfc8; }
.tone-dot--steel { background: #9ca3a6; }
.filter-links a.is-active .tone-dot,
.filter-links a:hover .tone-dot,
.filter-links a:focus .tone-dot {
  border-color: rgba(255,255,255,.72);
}
.filter-form {
  margin-top: 14px;
}
.range { display: grid; grid-template-columns: 1fr auto 1fr; gap: 8px; margin: 14px 0; }
.range input { width: 100%; border: 1px solid var(--line); padding: 10px; font-size: 21px; }
.filter-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.breadcrumb { margin: 0 0 14px; color: var(--muted); font-size: 21px; text-transform: uppercase; }
.collection__head { display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; margin-bottom: 28px; }
.collection__intro { width: min(720px,100%); color: var(--muted); }
.collection__count {
  display: inline-flex;
  min-height: 38px;
  align-items: center;
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #fff;
  font-weight: 850;
}
.sort { display: flex; align-items: center; gap: 12px; white-space: nowrap; }
.sort label {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 0;
  font-weight: 900;
}
.sort select { min-width: 190px; border: 1px solid var(--line); border-radius: 4px; padding: 11px 13px; background: #fff; font-size: 22px; }
.sort__submit {
  display: none;
}
.product-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 34px; }
.product-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 16px 34px rgba(32, 22, 12, .07);
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}
.product-card:hover {
  transform: translateY(-3px);
  border-color: rgba(185, 130, 61, .44);
  box-shadow: 0 22px 48px rgba(32, 22, 12, .11);
}
.product-card__image {
  position: relative;
  display: grid;
  place-items: center;
  aspect-ratio: 1;
  overflow: hidden;
  background: #fff;
}
.product-card__image img {
  width: 100%;
  height: 72%;
  object-fit: cover;
  object-position: center;
  background: #fff;
  transition: transform 180ms ease;
}
.product-card:hover img { transform: scale(1.03); }
.wishlist-form {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 3;
  margin: 0 !important;
}
.wishlist, .heart { display: grid; place-items: center; width: 46px; min-height: 46px; height: 46px; padding: 0; border: 1px solid rgba(236,72,153,.18); border-radius: 50%; background: #fff; color: #ec4899; font-size: 27px; box-shadow: 0 10px 24px rgba(236,72,153,.16); }
.heart:hover,
.heart:focus,
.heart.is-active {
  background: #ffe4f1;
  border-color: rgba(236,72,153,.38);
  color: #ec4899;
}
.product-card__body {
  display: grid;
  gap: 10px;
  padding: 18px;
}
.product-card__body > p {
  margin: 0;
  color: var(--accent-dark);
  font-size: 20px;
  font-weight: 850;
}
.product-card h3 { margin: 0; font-size: 24px; line-height: 1.08; font-weight: 850; }
.product-card__rating {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 20px;
  line-height: 1;
  color: var(--muted);
}
.product-card__stars {
  color: #c8a144;
  font-size: 21px;
  letter-spacing: 1px;
  text-shadow: 0 1px 0 rgba(0,0,0,.10);
}
.product-card__meta { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; }
.product-card__price { font-size: 26px; font-weight: 850; }
.product-card__stock { color: var(--success); font-size: 20px; }
.product-card .inline { margin-top: 4px; }
.product-card .inline .button {
  width: 100%;
}
.empty-state {
  grid-column: 1 / -1;
  padding: 34px;
  border: 1px dashed var(--line);
  border-radius: 12px;
  background: #fff;
  text-align: center;
}
.empty-state h3 {
  margin: 0 0 6px;
  font-size: 34px;
}
.empty-state p {
  margin: 0 0 18px;
  color: var(--muted);
}

.table-wrap { overflow-x: auto; border: 1px solid var(--line); background: #fff; }
table { width: 100%; min-width: 760px; border-collapse: collapse; background: #fff; }
th, td { padding: 18px; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; }
th { background: #111; color: #fff; font-weight: 900; }
.admin-page {
  background:
    radial-gradient(circle at top left, rgba(185, 130, 61, .16), transparent 34rem),
    linear-gradient(180deg, #f7f3ec 0%, #fffdf9 42%);
}
.admin-page .site-nav__categories,
.admin-page .footer {
  display: none;
}
.admin-page .site-nav {
  position: static;
  border-bottom: 1px solid rgba(23, 23, 23, .08);
  box-shadow: none;
}
.admin-page .site-nav__inner {
  min-height: 86px;
}
.admin-page .brand__logo {
  width: 150px;
  height: 74px;
}
.admin-page .brand small,
.admin-page .searchbar,
.admin-page .phone {
  display: none;
}
.admin-page .container {
  width: min(1500px, calc(100% - 52px));
  padding: 30px 0 58px;
}
.admin-shell {
  display: grid;
  gap: 24px;
}
.admin-workspace {
  display: grid;
  gap: 24px;
  scroll-margin-top: 18px;
  outline: none;
}
.admin-workspace:focus-visible {
  box-shadow: 0 0 0 4px rgba(185, 130, 61, .24);
  border-radius: 14px;
}
.admin-hero {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 24px;
  padding: 30px 34px;
  border: 1px solid rgba(23, 23, 23, .10);
  border-radius: 14px;
  background:
    linear-gradient(135deg, rgba(17, 17, 17, .96), rgba(54, 43, 31, .94)),
    var(--paper);
  color: #fff;
  box-shadow: 0 22px 70px rgba(32, 22, 12, .14);
}
.admin-hero h1 {
  margin: 0;
  font-size: clamp(32px, 3.2vw, 46px);
  line-height: 1;
}
.admin-hero p {
  max-width: 720px;
  margin: 10px 0 0;
  color: rgba(255, 255, 255, .72);
  font-size: 22px;
}
.admin-hero .button {
  border-color: rgba(255, 255, 255, .26);
  background: #fff;
  color: var(--ink);
  white-space: nowrap;
}
.admin-hero__eyebrow {
  margin: 0 0 8px !important;
  color: var(--accent) !important;
  font-size: 22px !important;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.admin-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(23, 23, 23, .10);
  border-radius: 14px;
  background: rgba(255, 255, 255, .82);
  box-shadow: 0 14px 36px rgba(32, 22, 12, .08);
}
.admin-tabs a {
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 20px;
  border: 1px solid transparent;
  border-radius: 999px;
  color: #4e4840;
  font-size: 27px;
  font-weight: 900;
  line-height: 1;
  transition: background 140ms ease, color 140ms ease, border-color 140ms ease, transform 140ms ease;
}
.admin-tabs a:hover,
.admin-tabs a:focus {
  border-color: rgba(185, 130, 61, .34);
  background: #fff8ed;
  color: var(--ink);
  transform: translateY(-1px);
}
.admin-tabs a.is-active {
  border-color: var(--ink);
  background: var(--ink);
  color: #fff;
}
.admin-stat-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}
.admin-stat-card {
  position: relative;
  overflow: hidden;
  min-height: 180px;
  padding: 24px;
  border: 1px solid rgba(23, 23, 23, .10);
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 16px 42px rgba(32, 22, 12, .08);
}
.admin-stat-card::after {
  content: "";
  position: absolute;
  right: -34px;
  top: -34px;
  width: 110px;
  height: 110px;
  border-radius: 50%;
  background: rgba(185, 130, 61, .14);
}
.admin-stat-card span,
.admin-stat-card small,
.admin-stat-card strong {
  position: relative;
  z-index: 1;
  display: block;
}
.admin-stat-card span {
  color: var(--muted);
  font-size: 26px;
  font-weight: 850;
}
.admin-stat-card strong {
  margin-top: 12px;
  font-size: clamp(30px, 2.8vw, 42px);
  line-height: 1;
  font-weight: 900;
}
.admin-stat-card small {
  margin-top: 14px;
  color: #81776b;
  font-size: 23px;
  line-height: 1.18;
}
.admin-page .panel {
  border-color: rgba(23, 23, 23, .10);
  border-radius: 14px;
  background: rgba(255, 255, 255, .96);
  box-shadow: 0 16px 42px rgba(32, 22, 12, .07);
}
.admin-page .panel h2 {
  margin-top: 0;
  font-size: 28px;
  line-height: 1.08;
}
.admin-panel-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 18px;
  margin-bottom: 18px;
}
.admin-export-bar {
  display: flex;
  justify-content: flex-end;
  margin: 0 0 16px;
}
.admin-export-bar .btn {
  min-width: 160px;
  text-align: center;
}
.admin-report-panel {
  padding: 28px;
}
.admin-page table {
  border-radius: 10px;
  overflow: hidden;
}
.admin-page th {
  background: #111;
  color: #fff;
}
.admin-page tr:hover td {
  background: #fffaf2;
}
.compare-table th,
.compare-table td {
  vertical-align: top;
}
.compare-table td:first-child {
  font-weight: 850;
  min-width: 180px;
}
.compare-table td:first-child small {
  display: block;
  margin-top: 2px;
  color: #8b765f;
  font-weight: 700;
}
.compare-table a {
  color: inherit;
  text-decoration-color: #c58b38;
  text-underline-offset: 4px;
}
.order-chat {
  margin-top: 24px;
}
.order-chat__messages {
  display: grid;
  gap: 12px;
  margin: 14px 0 18px;
}
.order-chat__message {
  max-width: 760px;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
}
.order-chat__message.is-admin {
  margin-left: auto;
  background: #111;
  color: #fff;
}
.order-chat__message p {
  margin: 4px 0 6px;
}
.order-chat__message small {
  color: #8b765f;
  font-weight: 750;
}
.order-chat__message.is-admin small {
  color: rgba(255,255,255,.68);
}
.order-chat__form {
  display: grid;
  gap: 12px;
}
.order-chat__form button {
  justify-self: start;
}
.admin-order-message-row td {
  background: #fffaf2;
}
.order-chat--admin {
  margin-top: 0;
}
.bank-account-list {
  display: grid;
  gap: 12px;
  margin-top: 16px;
}
.bank-account-list--grid {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}
.bank-account-card {
  display: flex;
  gap: 14px;
  align-items: center;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fffaf2;
}
.bank-account-card img,
.bank-logo-thumb {
  width: 58px;
  height: 58px;
  object-fit: contain;
  border-radius: 10px;
  background: #fff;
  border: 1px solid var(--line);
}
.bank-account-card p {
  margin: 2px 0;
}
.payment-slip-form {
  display: grid;
  gap: 12px;
  margin-top: 18px;
}
.payment-slip-form button {
  justify-self: start;
}
.payment-slip-list {
  display: grid;
  gap: 12px;
  margin-top: 18px;
}
.payment-slip-card {
  display: flex;
  gap: 14px;
  align-items: center;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
}
.payment-slip-card img {
  width: 96px;
  height: 96px;
  object-fit: cover;
  border-radius: 10px;
}
.admin-orders-panel {
  overflow-x: auto !important;
}
.admin-orders-panel .admin-panel-head {
  align-items: flex-start;
  gap: 18px;
}
.admin-order-filters {
  display: flex;
  flex-wrap: wrap;
  align-items: end;
  justify-content: flex-end;
  gap: 10px;
  margin: 0;
}
.admin-order-filters label {
  min-width: 160px;
  margin: 0;
  font-size: 22px;
}
.admin-order-filters select,
.admin-order-filters button,
.admin-order-filters .btn {
  min-height: 46px;
  font-size: 23px;
}
.admin-orders-table th,
.admin-orders-table td {
  vertical-align: top;
}
.admin-orders-table {
  width: 100%;
  min-width: 1180px;
  table-layout: fixed !important;
}
.admin-orders-table th,
.admin-orders-table td {
  padding: 10px 12px !important;
  overflow-wrap: anywhere;
}
.admin-orders-table th:nth-child(1),
.admin-orders-table td:nth-child(1) {
  width: 178px;
}
.admin-orders-table th:nth-child(2),
.admin-orders-table td:nth-child(2) {
  width: 260px;
}
.admin-orders-table th:nth-child(3),
.admin-orders-table td:nth-child(3) {
  width: 110px;
}
.admin-orders-table th:nth-child(4),
.admin-orders-table td:nth-child(4) {
  width: 86px;
}
.admin-orders-table th:nth-child(5),
.admin-orders-table td:nth-child(5) {
  width: 128px;
}
.admin-orders-table th:nth-child(6),
.admin-orders-table td:nth-child(6),
.admin-orders-table th:nth-child(7),
.admin-orders-table td:nth-child(7) {
  width: 82px;
}
.admin-orders-table th:nth-child(8),
.admin-orders-table td:nth-child(8) {
  width: 270px;
}
.admin-orders-table .muted {
  font-size: 15px !important;
  line-height: 1.25 !important;
}
.status-pill {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  background: #111;
  color: #fff;
  font-size: 14px !important;
  font-weight: 800;
  line-height: 1.1;
  margin-bottom: 5px;
}
.status-pill--soft {
  background: #f3eadc;
  color: #3f3327;
}
.admin-order-actions,
.admin-order-status-form {
  display: grid;
  gap: 8px;
}
.admin-order-status-form {
  grid-template-columns: minmax(86px, 1fr) minmax(86px, 1fr) auto;
  align-items: center;
}
.admin-order-status-form select,
.admin-order-status-form button,
.btn.compact {
  min-height: 36px !important;
  padding: 6px 10px !important;
  font-size: 14px !important;
}
.admin-orders-table .btn.compact {
  width: 100%;
  white-space: normal;
  line-height: 1.1 !important;
}
.admin-orders-table select {
  min-height: 36px;
  padding: 6px 8px;
  font-size: 14px !important;
}
.order-admin-modal {
  position: fixed;
  inset: 0;
  z-index: 155;
  display: none;
}
.order-admin-modal.is-open {
  display: block;
}
.order-admin-modal__backdrop {
  position: absolute;
  inset: 0;
  width: 100%;
  min-height: 100%;
  border: 0;
  border-radius: 0;
  background: rgba(17,17,17,.62);
}
.order-admin-modal__dialog {
  position: relative;
  width: min(980px, calc(100% - 34px));
  max-height: min(88vh, 900px);
  margin: 5vh auto 0;
  overflow: hidden;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 30px 80px rgba(0,0,0,.26);
}
.order-admin-modal__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 18px 22px;
  background: #111;
  color: #fff;
}
.order-admin-modal__head h2 {
  margin: 0;
  color: #fff;
  font-size: 34px;
}
.order-admin-modal__close {
  width: 46px;
  min-height: 46px;
  border-radius: 999px;
  border-color: rgba(255,255,255,.35);
  background: rgba(255,255,255,.08);
  color: #fff;
  font-size: 34px;
  line-height: 1;
}
.order-admin-modal__body {
  max-height: calc(88vh - 88px);
  overflow: auto;
  padding: 22px;
}
.payment-slip-card--modal {
  align-items: flex-start;
  border-radius: 14px;
}
.payment-slip-card--modal img {
  width: min(360px, 38vw);
  height: auto;
  max-height: 520px;
  object-fit: contain;
  background: #f7f2ea;
}
.order-pick-list {
  display: grid;
  gap: 18px;
}
.order-pick-list__summary {
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fffaf2;
}
.order-pick-list__summary p {
  margin: 4px 0;
}
.order-pick-list__table {
  min-width: 720px;
}
.order-pick-list__table img {
  width: 76px;
  height: 76px;
  object-fit: contain;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}
.order-pick-list__table strong {
  font-weight: 900;
}
.order-pick-list__table small {
  color: var(--muted);
  font-weight: 750;
}
.payment-notify-page {
  max-width: 1180px;
  margin: 0 auto 70px;
}
.payment-notify-hero {
  padding: 34px 0 22px;
}
.payment-notify-hero h1 {
  margin: 4px 0 10px;
  font-size: clamp(32px, 3.8vw, 50px);
  line-height: .98;
}
.payment-notify-hero p {
  max-width: 780px;
  color: var(--muted);
  font-size: 22px;
}
.payment-search-form {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) auto;
  gap: 16px;
  align-items: end;
}
.payment-notify-layout {
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(360px, 1.08fr);
  gap: 24px;
  align-items: start;
}
.payment-order-card h2,
.payment-notify-form h2 {
  margin-top: 0;
}
.payment-notify-form {
  display: grid;
  gap: 14px;
}
.payment-notify-form button {
  justify-self: start;
}
.checkout-form-panel,
.order-summary {
  border-radius: 18px;
  box-shadow: 0 18px 46px rgba(31, 24, 18, .08);
}
.checkout-next-steps,
.checkout-contact-box {
  margin-top: 18px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fffaf2;
}
.checkout-next-steps ol {
  margin: 8px 0 14px 22px;
  padding: 0;
}
.checkout-next-steps li {
  margin: 4px 0;
}
.checkout-contact-box p {
  margin: 4px 0;
}
.checkout-coupon-box {
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fffaf2;
}
.checkout-coupon-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 10px;
  align-items: center;
}
.checkout-coupon-row input {
  text-transform: uppercase;
}
.checkout-coupon-message {
  margin: 8px 0 0;
  color: var(--muted);
  font-weight: 750;
}
.checkout-coupon-message[data-state="success"] {
  color: #157347;
}
.checkout-coupon-message[data-state="error"] {
  color: #b02a37;
}
.checkout-discount-row strong {
  color: #157347;
}
.checkout-payment-methods {
  display: grid;
  gap: 12px;
  margin: 18px 0;
}
.checkout-payment-methods h3 {
  margin: 0;
}
.delivery-option.is-disabled {
  opacity: .55;
  cursor: not-allowed;
}
.checkout-submit-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.checkout-submit-actions button {
  flex: 1 1 240px;
}
.checkout-policy-confirm {
  display: flex;
  grid-template-columns: none;
  align-items: flex-start;
  gap: 10px;
  margin: 18px 0;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fffaf2;
  color: var(--muted);
  font-weight: 750;
}
.checkout-policy-confirm input {
  width: auto;
  margin-top: 5px;
  accent-color: var(--brand);
}
.checkout-policy-confirm a {
  color: var(--accent-dark);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.policy-page {
  max-width: 980px;
  margin: 0 auto;
}
.policy-page h1 {
  margin: 0 0 14px;
  font-size: clamp(30px, 4vw, 48px);
  line-height: 1.08;
}
.policy-page__intro {
  max-width: 780px;
  color: var(--muted);
}
.policy-card-list {
  display: grid;
  gap: 14px;
  margin: 28px 0;
}
.policy-card,
.policy-contact {
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(32, 22, 12, .06);
}
.policy-card h2,
.policy-contact h2 {
  margin: 0 0 8px;
  font-size: 24px;
}
.policy-card p,
.policy-contact p {
  margin: 6px 0;
  color: var(--muted);
}
.policy-contact a {
  color: var(--accent-dark);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.order-status-hero {
  margin: 12px 0 24px;
}
.order-status-hero h1 {
  margin: 4px 0 8px;
  font-size: clamp(32px, 3.6vw, 48px);
  line-height: 1.02;
}
.order-status-hero p {
  max-width: 780px;
  color: var(--muted);
}
.order-status-search form {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(220px, 1fr) auto;
  gap: 14px;
  align-items: end;
}
.order-status-card__head {
  display: flex;
  gap: 18px;
  justify-content: space-between;
  align-items: flex-start;
}
.order-status-card__head h2 {
  margin: 4px 0 0;
  font-size: 30px;
}
.order-status-steps {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  margin: 22px 0;
}
.order-status-steps span {
  padding: 10px 12px;
  border-radius: 999px;
  background: #eee8dd;
  color: #766a5d;
  text-align: center;
  font-weight: 850;
}
.order-status-steps span.is-active {
  background: #111;
  color: #fff;
}
.order-status-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 12px;
}
.order-status-grid p {
  margin: 0;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
}
.order-status-grid span,
.order-status-grid strong {
  display: block;
}
.order-status-grid span {
  color: var(--muted);
}
.admin-page .two-col,
.admin-products-layout {
  align-items: start;
}
.admin-page .two-col > section.panel,
.admin-products-layout > section.panel,
.admin-report-panel {
  max-height: 68vh;
  overflow: auto;
}
.admin-modal-open {
  overflow: hidden;
}
.admin-form-launcher {
  padding: 0 !important;
  overflow: hidden !important;
}
.admin-products-layout > section.panel > .admin-form-launcher,
.two-col > section.panel > .admin-form-launcher {
  margin: 14px 0 24px;
  border: 0;
  border-radius: 12px;
  background: #171717;
  box-shadow: 0 18px 42px rgba(32, 22, 12, .12);
}
.admin-faq-layout {
  grid-template-columns: 1fr;
}
.admin-products-layout > section.panel > .admin-form-launcher .admin-form-open,
.two-col > section.panel > .admin-form-launcher .admin-form-open {
  border-radius: 12px;
}
.admin-form-open {
  width: 100%;
  min-height: 74px;
  justify-content: space-between;
  display: grid;
  grid-template-columns: 1fr auto 44px;
  gap: 18px;
  padding: 16px 22px;
  border: 0;
  border-radius: 0;
  background: #171717;
  color: #fff;
  text-align: left;
}
.admin-form-open::after {
  content: "+";
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  border: 1px solid rgba(255,255,255,.24);
  border-radius: 50%;
  font-size: 32px;
  line-height: 1;
}
.admin-form-open::before {
  content: "เปิดหน้าต่างเพิ่มข้อมูล";
  justify-self: center;
  align-self: center;
  color: rgba(255,255,255,.74);
  font-size: 24px;
  font-weight: 750;
}
.admin-form-open span,
.admin-form-open small {
  display: block;
}
.admin-form-open span {
  font-size: 31px;
  font-weight: 900;
  line-height: 1.02;
}
.admin-form-open small {
  display: none;
  margin-top: 4px;
  color: rgba(255,255,255,.68);
  font-size: 22px;
  font-weight: 750;
}
.admin-form-modal {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: none;
}
.admin-form-modal.is-open {
  display: block;
}
.admin-form-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(17,17,17,.58);
  backdrop-filter: blur(5px);
}
.admin-form-modal__dialog {
  position: relative;
  width: min(860px, calc(100% - 36px));
  max-height: min(86vh, 920px);
  margin: 7vh auto 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 26px 90px rgba(0,0,0,.34);
}
.admin-form-modal__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  padding: 20px 24px;
  background: #171717;
  color: #fff;
}
.admin-form-modal__head h2 {
  margin: 0 !important;
  color: #fff;
  font-size: 36px;
  line-height: 1.05;
}
.admin-form-modal__close {
  width: 44px;
  min-height: 44px;
  height: 44px;
  padding: 0;
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 50%;
  background: rgba(255,255,255,.08);
  color: #fff;
  font-size: 34px;
}
.admin-form-modal__close:hover,
.admin-form-modal__close:focus {
  background: #fff;
  color: var(--ink);
}
.admin-form-modal__body {
  min-height: 0;
  overflow: auto;
  padding: 24px;
}
.admin-form-content {
  display: grid;
  gap: 0;
}
.admin-form-content > h2:first-child {
  display: none;
}
.admin-form-content form,
  form.admin-form-content {
  margin: 0;
}
.panel table {
  min-width: 0;
  table-layout: fixed;
  font-family: var(--font-main);
  font-size: 28px;
  line-height: 1.25;
}
.panel th,
.panel td {
  padding: 14px 20px;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.panel th {
  font-size: 29px;
  font-weight: 900;
}
.panel {
  overflow-x: auto;
}
.row-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.admin-products-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
.admin-subtabs {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 0 0 22px;
}
.admin-subtabs .btn {
  min-height: 56px;
  padding: 0 30px;
  border-color: var(--ink);
  font-family: var(--font-main);
  font-size: 31px;
  font-weight: 900;
}
.admin-subtabs .btn.is-active,
.admin-subtabs .btn:hover,
.admin-subtabs .btn:focus {
  background: var(--ink);
  color: #fff;
}
.admin-products-layout .panel:first-child {
  width: 100%;
}
.product-editor-panel {
  display: grid;
  grid-template-columns: repeat(2, minmax(280px, 1fr));
  gap: 28px;
}
.product-editor-panel h2 {
  margin-top: 0;
}
.product-editor-panel form {
  min-width: 0;
}
.single-editor-panel {
  grid-template-columns: minmax(280px, 720px);
}
.admin-table {
  table-layout: auto !important;
}
.admin-table th,
.admin-table td {
  white-space: normal;
  overflow-wrap: normal;
  word-break: normal;
}
.admin-table th:first-child,
.admin-table td:first-child {
  width: 70px;
}
.admin-table th:nth-child(4),
.admin-table td:nth-child(4),
.admin-table th:nth-child(5),
.admin-table td:nth-child(5),
.admin-table th:nth-child(6),
.admin-table td:nth-child(6),
.admin-table th:last-child,
.admin-table td:last-child {
  width: 130px;
}
.admin-thumb {
  width: 110px;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #eee;
}
.admin-table-toolbar {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 12px;
  margin: 0 0 16px;
}
.admin-table-search {
  width: min(420px, 100%);
  min-height: 48px;
  border-radius: 999px;
  padding: 10px 18px;
  background: #fff;
  box-shadow: 0 8px 22px rgba(32, 22, 12, .06);
}
.admin-product-preview-link {
  min-height: 0;
  display: inline;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--ink);
  font-size: inherit;
  font-weight: inherit;
  text-align: left;
  text-decoration: underline;
  text-decoration-color: rgba(185,130,61,.42);
  text-underline-offset: 5px;
}
.admin-product-preview-link:hover,
.admin-product-preview-link:focus {
  color: var(--accent-dark);
  background: transparent;
}
.admin-product-preview-modal {
  position: fixed;
  inset: 0;
  z-index: 150;
  display: none;
}
.admin-product-preview-modal.is-open {
  display: block;
}
.admin-product-preview-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(17,17,17,.58);
  backdrop-filter: blur(5px);
}
.admin-product-preview-modal__dialog {
  position: relative;
  width: min(860px, calc(100% - 34px));
  margin: 7vh auto 0;
  overflow: hidden;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 26px 90px rgba(0,0,0,.34);
}
.admin-product-preview-modal__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  padding: 18px 22px;
  background: #171717;
  color: #fff;
}
.admin-product-preview-modal__head h2 {
  margin: 0;
  color: #fff;
  font-size: 34px;
  line-height: 1.05;
}
.admin-product-preview-modal__close {
  width: 44px;
  min-height: 44px;
  height: 44px;
  padding: 0;
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 50%;
  background: rgba(255,255,255,.08);
  color: #fff;
  font-size: 34px;
}
.admin-product-preview-modal__body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, .8fr);
  gap: 24px;
  padding: 24px;
}
.admin-product-preview-modal__image {
  display: grid;
  place-items: center;
  min-height: 360px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
}
.admin-product-preview-modal__image img {
  width: 100%;
  height: 100%;
  max-height: 440px;
  object-fit: contain;
}
.admin-product-preview-modal__thumbs {
  display: flex;
  gap: 10px;
  margin-top: 12px;
  overflow-x: auto;
}
.admin-product-preview-modal__thumbs button {
  width: 76px;
  min-width: 76px;
  height: 64px;
  min-height: 64px;
  padding: 0;
  border: 2px solid transparent;
  border-radius: 8px;
  background: #fff;
}
.admin-product-preview-modal__thumbs button.is-active,
.admin-product-preview-modal__thumbs button:hover,
.admin-product-preview-modal__thumbs button:focus {
  border-color: var(--accent);
  background: #fff;
}
.admin-product-preview-modal__thumbs img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 5px;
}
.admin-product-preview-modal__meta {
  display: grid;
  align-content: start;
  gap: 12px;
}
.admin-product-preview-modal__meta p {
  margin: 0;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
  color: var(--muted);
}
.admin-product-preview-modal__meta strong {
  display: block;
  color: var(--ink);
  font-size: 30px;
  line-height: 1.05;
}
.admin-current-image {
  display: grid;
  gap: 8px;
  margin: -2px 0 14px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fffaf3;
}
.admin-current-image span {
  color: var(--muted);
  font-size: 23px;
  font-weight: 850;
}
.admin-current-image img {
  width: min(260px, 100%);
  aspect-ratio: 1;
  object-fit: contain;
  border: 1px solid rgba(23,23,23,.08);
  border-radius: 8px;
  background: #fff;
}
.admin-current-image--wide img {
  width: min(520px, 100%);
  aspect-ratio: 16 / 7;
  object-fit: cover;
}
.admin-settings-group {
  display: grid;
  gap: 14px;
  margin: 12px 0 18px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fffaf3;
}
.admin-settings-group h3 {
  margin: 0;
  font-size: 31px;
  line-height: 1.05;
}
.admin-settings-pair {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 12px;
}
.product-settings-panel {
  max-width: 1120px;
}
.row-actions form {
  margin: 0;
}
.compact {
  min-height: 44px !important;
  padding: 0 16px !important;
  font-size: 26px !important;
}
.icon-btn {
  display: inline-grid;
  place-items: center;
  width: 48px;
  min-height: 48px;
  height: 48px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #fff;
  color: var(--ink);
  font-size: 30px;
  font-weight: 900;
  line-height: 1;
  transition: transform 120ms ease, background 120ms ease, color 120ms ease, border-color 120ms ease;
}
.icon-btn:hover,
.icon-btn:focus {
  background: var(--ink);
  border-color: var(--ink);
  color: #fff;
  transform: translateY(-1px);
}
button.danger,
.danger {
  background: #9f1d1d;
  border-color: #9f1d1d;
  color: #fff;
}
button.danger:hover,
.danger:hover {
  background: #7f1515;
  border-color: #7f1515;
}
.icon-btn.danger {
  border-color: #f1c7c7;
  background: #fff7f7;
  color: #9f1d1d;
}
.icon-btn.danger:hover,
.icon-btn.danger:focus {
  background: #9f1d1d;
  border-color: #9f1d1d;
  color: #fff;
}
.confirm-modal {
  position: fixed;
  inset: 0;
  display: none;
  z-index: 100;
}
.confirm-modal.is-open {
  display: block;
}
.confirm-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(17, 17, 17, .58);
  backdrop-filter: blur(4px);
}
.confirm-modal__dialog {
  position: relative;
  width: min(520px, calc(100% - 32px));
  margin: 16vh auto 0;
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--paper);
  box-shadow: 0 24px 80px rgba(0, 0, 0, .24);
}
.confirm-modal__dialog h2 {
  margin: 0 0 10px;
  font-size: 30px;
}
.confirm-modal__dialog p {
  margin: 0;
  color: var(--muted);
  font-size: 22px;
}
.confirm-modal__actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  margin-top: 24px;
}
.confirm-modal__ok {
  background: #9f1d1d;
  border-color: #9f1d1d;
}
.steps__grid, .info-grid, .footer__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.steps__grid article, .info-grid > div { background: #fff; border: 1px solid var(--line); padding: 24px; }
.steps__grid span { display: grid; place-items: center; width: 38px; height: 38px; border-radius: 50%; background: var(--ink); color: #fff; font-weight: 900; }
.info-grid { grid-template-columns: 1fr 1fr; }
.section--store { background: #171513; color: #fff; }
.store-card { display: grid; grid-template-columns: .9fr 1.1fr; gap: 34px; align-items: center; }
.store-card p:not(.eyebrow) { color: rgba(255,255,255,.78); font-size: 21px; }
.store-card img { width: 100%; border-radius: var(--radius); }
.faq { max-width: 860px; }
.faq details { border: 1px solid var(--line); background: #fff; margin-bottom: 12px; padding: 18px 20px; }
.faq summary { cursor: pointer; font-weight: 900; }
.faq p { color: var(--muted); }
.footer { padding: 54px 0; background: #090909; color: #fff; }
.footer__grid { grid-template-columns: 1.4fr .8fr 1fr 1fr; }
.footer p, .footer a { color: rgba(255,255,255,.74); }
.footer a { display: block; margin: 8px 0; }
.footer .button { width: fit-content; color: var(--ink); }
.floating-cart {
  position: fixed;
  right: 22px;
  top: 44%;
  z-index: 80;
  width: 74px;
  height: 74px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255,255,255,.26);
  border-radius: 50%;
  background: #111;
  color: #fff;
  box-shadow: 0 18px 48px rgba(0,0,0,.24);
  transition: transform 140ms ease, background 140ms ease;
}
.floating-cart:hover,
.floating-cart:focus {
  transform: translateY(-2px);
  background: var(--accent);
  color: #111;
}
.floating-cart__icon {
  font-size: 34px;
  line-height: 1;
}
.floating-cart__count {
  position: absolute;
  top: -7px;
  right: -5px;
  min-width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  padding: 0 8px;
  border: 2px solid #fff;
  border-radius: 999px;
  background: #ec4899;
  color: #fff;
  font-size: 22px;
  font-weight: 900;
  line-height: 1;
}

.panel, .store-panel { background: #fff; border: 1px solid var(--line); padding: 24px; margin-bottom: 24px; }
.two-col, .checkout-layout, .product-detail { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(320px, .95fr); gap: 36px; align-items: start; }
.auth-grid { display: grid; grid-template-columns: minmax(320px, 1fr) minmax(320px, .9fr); gap: 44px; align-items: start; }
.auth-mobile-shell {
  width: min(520px, calc(100% - 28px));
  margin: 24px auto 64px;
}
.auth-mobile-card {
  padding: 30px;
  border-radius: 10px;
  box-shadow: 0 22px 70px rgba(44, 31, 18, .12);
}
.auth-kicker {
  max-width: 320px;
  margin: 0 auto 18px;
  color: #3f3a34;
  font-size: 27px;
  font-weight: 850;
  line-height: 1.22;
  text-align: center;
}
.auth-method {
  display: grid;
  gap: 14px;
}
.auth-phone-field {
  display: grid;
  grid-template-columns: 78px 1fr;
  align-items: center;
  border: 1px solid var(--line);
  background: #fbfaf7;
}
.auth-phone-field input,
.auth-phone-field .auth-country {
  min-height: 56px;
}
.auth-phone-field input {
  border: 0;
  background: transparent;
  font-size: 25px;
}
.auth-country {
  display: grid;
  place-items: center;
  border-right: 1px solid var(--line);
  color: #221f1b;
  font-size: 22px;
  font-weight: 900;
}
.auth-password-mini span:first-child,
.auth-method label {
  font-size: 25px;
  font-weight: 850;
}
.auth-method input {
  min-height: 56px;
  font-size: 25px;
}
.auth-primary,
.auth-method button[type="submit"] {
  width: 100%;
  min-height: 58px;
  justify-content: center;
  font-size: 28px;
}
.auth-remember {
  margin: 0;
}
.auth-divider {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 14px;
  margin: 24px 0;
  color: #7a7168;
  font-size: 23px;
  font-weight: 850;
}
.auth-divider::before,
.auth-divider::after {
  content: "";
  height: 1px;
  background: var(--line);
}
.auth-expand {
  margin: 0 0 14px;
}
.auth-expand summary,
.auth-social {
  min-height: 58px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 0 18px;
  border: 1px solid var(--line);
  background: #fff;
  color: #171717;
  font-size: 25px;
  font-weight: 900;
  cursor: pointer;
}
.auth-expand[open] summary {
  background: #171717;
  color: #fff;
}
.auth-expand form {
  padding: 18px 0 4px;
}
.auth-social {
  margin: 0 0 14px;
  text-decoration: none;
}
.auth-social__icon {
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: #1877f2;
  color: #fff;
  font-size: 24px;
  font-weight: 950;
  font-family: Arial, sans-serif;
}
.auth-register summary {
  border-color: #111;
}
.auth-panel { font-family: var(--font-main); font-size: 28px; }
.auth-panel h1 { font-size: 34px; line-height: 1.05; margin: 0 0 24px; }
.auth-panel label { font-size: 28px; font-weight: 800; }
.auth-panel input { min-height: 58px; font-size: 28px; }
.auth-panel .remember-field { font-size: 27px; font-weight: 800; }
.auth-panel .remember-field input { min-height: auto; transform: scale(1.2); }
.auth-panel button[type="submit"] { min-height: 58px; font-size: 30px; padding: 0 28px; }
.auth-panel .password-toggle,
.auth-mobile-card .password-toggle { min-height: 44px; height: 44px; width: 48px; font-size: 26px; }
.product-gallery, .product-detail__gallery {
  display: grid;
  grid-template-columns: 94px minmax(0, 1fr);
  gap: 14px;
  place-items: stretch;
  overflow: hidden;
  background: #fff;
  border: 1px solid var(--line);
  padding: 12px;
}
.product-gallery--single {
  grid-template-columns: 1fr;
}
.product-gallery__main {
  width: 100%;
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: #fff;
  outline: none;
}
.product-gallery__main:hover,
.product-gallery__main:focus {
  background: #fff;
}
.product-gallery__main:focus-visible {
  box-shadow: 0 0 0 4px rgba(185, 130, 61, .28);
}
.product-gallery__main img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  object-position: center;
  background: #fff;
}
.product-gallery__thumbs {
  width: 100%;
  grid-row: 1;
  display: grid;
  align-content: start;
  gap: 10px;
  max-height: 100%;
  overflow-y: auto;
  padding: 0;
  background: #fff;
  border-top: 0;
}
.product-gallery__thumbs button {
  width: 100%;
  min-width: 0;
  min-height: 104px;
  padding: 0;
  border: 2px solid transparent;
  border-radius: 6px;
  background: #fff;
  overflow: hidden;
}
.product-gallery__thumbs button.is-active,
.product-gallery__thumbs button:hover,
.product-gallery__thumbs button:focus {
  border-color: var(--accent);
  background: #fff;
}
.product-gallery__thumbs img {
  width: 100%;
  height: 78px;
  object-fit: contain;
  background: #fff;
}
.product-gallery__thumbs button.is-color-thumb {
  display: grid;
  gap: 0;
  align-content: start;
  height: auto;
  padding: 0;
}
.product-gallery__thumbs button.is-color-thumb span {
  display: block;
  width: 100%;
  min-height: 24px;
  padding: 4px 4px 5px;
  background: #fff;
  color: var(--ink);
  font-size: 12px !important;
  font-weight: 800;
  line-height: 1.05 !important;
  text-align: center;
  white-space: normal;
  overflow-wrap: anywhere;
}
.product-lightbox {
  position: fixed;
  inset: 0;
  z-index: 160;
  display: none;
}
.product-lightbox.is-open {
  display: block;
}
.product-lightbox__backdrop {
  position: absolute;
  inset: 0;
  width: auto;
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: rgba(0,0,0,.72);
}
.product-lightbox__dialog {
  position: relative;
  width: min(1120px, calc(100vw - 48px));
  height: min(82vh, 760px);
  margin: 6vh auto 0;
  display: grid;
  place-items: center;
  overflow: visible;
  padding: 42px;
  background: #fff;
  box-shadow: 0 24px 90px rgba(0,0,0,.38);
}
.product-lightbox__dialog img {
  display: block;
  width: auto !important;
  height: auto !important;
  max-width: calc(100vw - 140px) !important;
  max-height: calc(82vh - 104px) !important;
  object-fit: contain;
  object-position: center;
}
.product-lightbox__close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 48px;
  min-height: 48px;
  height: 48px;
  padding: 0;
  border-radius: 50%;
  background: rgba(0,0,0,.78);
  color: #fff;
  font-size: 36px;
  line-height: 1;
}
.product-lightbox__arrow {
  position: absolute;
  top: 50%;
  z-index: 2;
  width: 58px;
  min-height: 58px;
  height: 58px;
  padding: 0;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 50%;
  background: rgba(17,17,17,.72);
  color: #fff;
  font-size: 54px;
  line-height: .75;
  transform: translateY(-50%);
  box-shadow: 0 14px 34px rgba(0,0,0,.22);
}
.product-lightbox__arrow:hover,
.product-lightbox__arrow:focus {
  background: #fff;
  color: var(--ink);
}
.product-lightbox__arrow--prev {
  left: 18px;
}
.product-lightbox__arrow--next {
  right: 18px;
}
.product-image-manager {
  display: grid;
  gap: 10px;
  margin: 0 0 14px;
}
.product-image-manager__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 10px;
}
.product-image-manager__grid label {
  gap: 8px;
  margin: 0;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  font-size: 22px;
}
.product-image-manager__grid img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 6px;
  background: #fff;
}
.product-image-manager__grid input {
  width: auto;
}
.admin-product-form-flow {
  display: grid;
  gap: 10px;
  margin: 0 0 16px;
  padding: 14px;
  border: 1px solid rgba(176, 138, 69, .35);
  border-radius: 12px;
  background: #fff8ec;
}
.admin-product-form-flow select[multiple] {
  min-height: 118px;
}
.admin-plus-btn {
  justify-self: start;
  margin: -2px 0 8px;
}
.admin-inline-panel {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid rgba(47,58,45,.22);
  border-radius: 12px;
  background: #fff;
}
.admin-inline-panel[hidden] {
  display: none;
}
.admin-add-variant {
  justify-self: start;
}
.admin-variant-manager {
  display: grid;
  gap: 12px;
  margin: 12px 0 16px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fffaf3;
}
.admin-variant-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(74,52,38,.12);
  border-radius: 10px;
  background: #fff;
}
.admin-variant-row .admin-thumb {
  width: 120px;
  height: 90px;
  object-fit: contain;
}
.product-summary {
  min-width: 0;
}
.product-summary > .muted:first-child {
  display: block;
  margin: 0 0 8px;
  color: var(--muted);
  font-size: 18px !important;
  line-height: 1.2 !important;
}
.product-summary h1 {
  margin: 0 0 10px;
  font-size: clamp(28px, 2.7vw, 38px) !important;
  line-height: 1.16 !important;
  overflow-wrap: anywhere;
}
.product-detail__rating {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 12px;
  color: var(--muted);
  font-size: 18px !important;
  line-height: 1.1 !important;
}
.product-variants {
  display: grid;
  gap: 12px;
  margin: 18px 0;
}
.product-variants > strong {
  font-size: 18px;
}
.product-variant-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.product-variant-list button {
  min-height: 46px;
  gap: 9px;
  padding: 8px 14px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #fffaf2;
  color: var(--charcoal);
}
.product-variant-list button.is-active,
.product-variant-list button:hover,
.product-variant-list button:focus {
  border-color: var(--outdoor-green);
  background: var(--outdoor-green);
  color: #fff;
}
.variant-swatch {
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  border: 1px solid rgba(0,0,0,.18);
  border-radius: 50%;
  background: var(--swatch);
}
.product-variant-list small {
  color: inherit;
  opacity: .72;
}
.product-selected-color {
  width: fit-content;
  margin: 12px 0 18px;
  padding: 8px 12px;
  border: 1px solid rgba(176, 138, 69, .38);
  border-radius: 999px;
  background: rgba(176, 138, 69, .12);
  color: var(--muted);
  font-size: 16px;
  font-weight: 750;
}
.product-selected-color strong {
  color: var(--ink);
}
.product-color-note {
  margin-top: -8px;
}
.product-detail__stars {
  color: #c8a144;
  font-size: 24px;
  letter-spacing: 1px;
  text-shadow: 0 1px 0 rgba(0,0,0,.10);
}
.price { font-size: 30px; font-weight: 850; margin: 12px 0; }
.purchase-row { display: grid; grid-template-columns: 92px 1fr; gap: 12px; margin-top: 22px; }
.purchase-row input { border: 1px solid var(--line); padding: 10px; }
.wishlist-row { margin-top: 12px; }
.cart-product { display: flex; gap: 14px; align-items: center; }
.cart-product img { width: 86px; height: 86px; object-fit: contain; background: #443d33; }
.cart-summary { display: flex; justify-content: space-between; align-items: center; margin-top: 24px; gap: 18px; }
.cart-remove-btn {
  width: 46px;
  height: 46px;
  font-size: 30px;
}
.order-summary p, .order-summary h3 { display: flex; justify-content: space-between; gap: 18px; border-bottom: 1px solid var(--line); padding-bottom: 12px; }
input, select, textarea { width: 100%; padding: 11px 13px; border: 1px solid var(--line); border-radius: 4px; background: #fff; font-family: var(--font-main); font-size: 22px; }
label { display: grid; gap: 6px; margin-bottom: 12px; font-size: 22px; font-weight: 700; }
.delivery-methods {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin: 18px 0 22px;
}
.delivery-option {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fffaf2;
  cursor: pointer;
}
.delivery-option input {
  width: auto;
  margin-top: 8px;
  accent-color: #111;
}
.delivery-option strong {
  display: block;
  font-size: 30px;
}
.delivery-option small,
.shipping-rate-note {
  color: #7a6d5d;
  font-weight: 500;
}
.shipping-rate-note {
  margin: -2px 0 18px;
  padding: 12px 14px;
  border: 1px solid #ead9be;
  border-radius: 10px;
  background: #fff8ec;
  font-size: 25px;
}
.shipping-rate-note.is-error {
  border-color: #efb4b4;
  color: #a51212;
  background: #fff1f1;
}
.remember-field {
  display: flex;
  grid-template-columns: none;
  align-items: center;
  gap: 10px;
  color: var(--muted);
}
.remember-field input {
  width: auto;
}
.password-field { position: relative; display: block; }
.password-field input { padding-right: 54px; }
.password-toggle {
  position: absolute;
  right: 8px;
  top: 50%;
  width: 44px;
  min-height: 40px;
  height: 40px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--muted);
  font-size: 26px;
  transform: translateY(-50%);
}
.password-toggle:hover { color: var(--ink); background: transparent; }
.tabs { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 22px; }
.tabs .btn {
  min-height: 58px;
  padding: 0 28px;
  border-color: var(--ink);
  font-family: var(--font-main);
  font-size: 32px;
  line-height: 1;
  font-weight: 900;
}
.tabs .btn.light {
  background: #fff;
  color: var(--ink);
}
.tabs .btn:hover,
.tabs .btn:focus {
  background: var(--ink);
  color: #fff;
}
.muted { color: var(--muted); font-size: 25px; }

@media (max-width: 920px) {
  .site-nav__inner, .collection__head, .product-detail { display: grid; }
  .brand, .searchbar { min-width: 0; max-width: none; width: 100%; }
  .shop-layout, .product-detail, .two-col, .auth-grid, .checkout-layout, .info-grid, .store-card, .media-section__head, .media-grid, .footer__grid, .payment-search-form, .payment-notify-layout { grid-template-columns: 1fr; }
  .order-status-search form,
  .order-status-steps {
    grid-template-columns: 1fr;
  }
  .order-status-card__head {
    display: grid;
  }
  .checkout-coupon-row {
    grid-template-columns: 1fr;
  }
  .delivery-methods { grid-template-columns: 1fr; }
  .admin-hero { display: grid; align-items: start; }
  .admin-stat-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .admin-tabs { gap: 8px; }
  .admin-tabs a { min-height: 46px; padding: 0 16px; font-size: 25px; }
  .video-feature__body { display: grid; }
  .gallery-grid { grid-template-columns: repeat(2, 1fr); }
  .filters { order: 2; position: static; }
  .product-grid, .trust-strip__grid, .steps__grid { grid-template-columns: repeat(2, 1fr); }
  .product-editor-panel { grid-template-columns: 1fr; }
  .home-showcase-grid,
  .featured-brands-grid {
    grid-template-columns: 1fr;
  }
  .category-card-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .brand-tile-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 620px) {
  body { font-size: 18px; line-height: 1.42; }
  .site-topbar,
  .site-topbar nav { font-size: 18px; }
  .site-container, .container { width: min(100% - 28px, 1200px); }
  .admin-page .container { width: min(100% - 24px, 1500px); padding-top: 18px; }
  .admin-page .site-nav__inner { min-height: 70px; }
  .admin-page .brand { min-width: 0; }
  .admin-page .brand__logo { width: 118px; height: 58px; }
  .admin-page .brand strong { font-size: 23px; }
  .admin-hero { padding: 24px; border-radius: 12px; }
  .admin-hero h1 { font-size: 32px; }
  .admin-hero p { font-size: 20px; }
  .admin-hero .button { width: 100%; }
  .admin-tabs {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding: 10px;
  }
  .admin-tabs a { width: 100%; font-size: 24px; }
  .admin-stat-grid { grid-template-columns: 1fr; }
  .admin-stat-card { min-height: 150px; }
  .admin-subtabs .btn { flex: 1; min-width: 140px; font-size: 27px; }
  .admin-page .two-col > section.panel,
  .admin-products-layout > section.panel,
  .admin-report-panel,
  .admin-form-modal__body {
    max-height: none;
  }
  .admin-form-open {
    min-height: 66px;
    grid-template-columns: 1fr 40px;
    padding: 14px 18px;
  }
  .admin-form-open::before {
    display: none;
  }
  .admin-form-open span {
    font-size: 28px;
  }
  .admin-form-open small {
    font-size: 21px;
  }
  .admin-form-modal__dialog {
    width: min(100% - 22px, 860px);
    max-height: 90vh;
    margin-top: 5vh;
  }
  .admin-form-modal__head {
    padding: 16px 18px;
  }
  .admin-form-modal__head h2 {
    font-size: 31px;
  }
  .admin-form-modal__body {
    padding: 18px;
  }
  .admin-order-filters {
    justify-content: stretch;
  }
  .admin-order-filters label,
  .admin-order-filters button,
  .admin-order-filters .btn {
    width: 100%;
  }
  .admin-order-status-form {
    grid-template-columns: 1fr;
  }
  .payment-slip-card--modal {
    display: grid;
  }
  .payment-slip-card--modal img {
    width: 100%;
    max-height: 52vh;
  }
  .admin-product-preview-modal__dialog {
    margin-top: 4vh;
  }
  .admin-product-preview-modal__body {
    grid-template-columns: 1fr;
    padding: 18px;
  }
  .admin-product-preview-modal__image {
    min-height: 260px;
  }
  .admin-settings-pair {
    grid-template-columns: 1fr;
  }
  .site-topbar__inner { min-height: 28px; padding: 8px 0; }
  .site-topbar__inner > span { display: none; }
  .site-topbar nav { width: 100%; justify-content: flex-end; gap: 8px; }
  .language-switch { margin-right: auto; }
  .language-switch button { min-height: 26px; padding: 4px 8px; font-size: 13px; }
  .site-nav__inner { grid-template-columns: 1fr; gap: 10px 12px; min-height: auto; padding: 10px 0 12px; }
  .brand { width: auto; min-width: 0; gap: 8px; }
  .brand__logo { width: 140px; height: 74px; }
  .brand strong { max-width: 190px; font-size: 22px; line-height: 1.05; }
  .brand small, .phone { display: none; }
  .searchbar input { padding: 11px 16px; font-size: 21px; }
  .site-nav__categories {
    position: sticky;
    top: 0;
    z-index: 12;
    box-shadow: 0 8px 18px rgba(0,0,0,.18);
  }
  .site-nav__categories::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 38px;
    pointer-events: none;
    background: linear-gradient(90deg, rgba(2,2,2,0), #020202 78%);
  }
  .site-nav__scroll {
    width: 100%;
    min-height: 40px;
    gap: 0;
    padding: 0 34px 0 12px;
    overflow-x: auto;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
    font-size: 18px;
    font-weight: 800;
  }
  .site-nav__scroll a {
    flex: 0 0 auto;
    scroll-snap-align: start;
    padding: 10px 10px 9px;
    opacity: .9;
  }
  .site-nav__scroll a.is-active::after {
    bottom: 0;
  }
  .floating-cart {
    right: 14px;
    bottom: 84px;
    top: auto;
    width: 60px;
    height: 60px;
  }
  .floating-cart__icon {
    font-size: 28px;
  }
  .floating-cart__count {
    min-width: 27px;
    height: 27px;
    font-size: 20px;
  }
  .shop-layout { gap: 24px; }
  .collection__head { display: grid; }
  .sort,
  .sort label {
    width: 100%;
  }
  .sort select {
    min-width: 0;
    width: 100%;
  }
  .video-control {
    right: 12px;
    bottom: 12px;
    min-height: 44px;
    width: 44px;
    padding: 0;
    gap: 0;
    justify-content: center;
    font-size: 0;
  }
  .video-sound-control {
    right: auto;
    left: 12px;
  }
  .video-control__icon {
    width: 32px;
    height: 32px;
    font-size: 22px;
  }
  .video-control [data-video-toggle-text],
  .video-control [data-video-sound-text] {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
  }
  .gallery-slider__stage {
    height: clamp(220px, 68vw, 420px);
    min-height: 220px;
  }
  .gallery-slide__caption {
    padding: 22px;
  }
  .gallery-slide__caption h3 { font-size: 30px; }
  .gallery-arrow {
    width: 46px;
    min-height: 46px;
    font-size: 36px;
  }
  .hero { min-height: 620px; }
  .hero h1 { font-size: 32px; }
  .hero p:not(.eyebrow) { font-size: 20px; }
  .eyebrow { font-size: 18px; }
  .trust-strip strong { font-size: 23px; }
  .trust-strip span { font-size: 18px; }
  .section__head h2,
  .collection h1 { font-size: 26px; }
  .section__head p,
  .collection__copy { font-size: 19px; }
  .filters h2 { font-size: 22px; }
  .filters summary,
  .filters label,
  .filter-links a { font-size: 20px; }
  .product-card h3 { font-size: 22px; }
  .product-card__price { font-size: 23px; }
  .product-card__stock,
  .product-card__brand,
  .product-card__tone { font-size: 18px; }
  .video-feature__body h3 { font-size: 28px; }
  .video-feature__body p { font-size: 18px; }
  .product-summary h1 { font-size: 28px !important; }
  .price { font-size: 27px; }
  input, select, textarea,
  label { font-size: 20px; }
  .button,
  .btn,
  button { font-size: 20px; }
  .product-gallery,
  .product-detail__gallery {
    grid-template-columns: 1fr;
  }
  .product-gallery__thumbs {
    grid-row: auto;
    display: flex;
    overflow-x: auto;
    overflow-y: hidden;
  }
  .product-gallery__thumbs button {
    width: 82px;
    min-width: 82px;
    height: auto;
    min-height: 92px;
  }
  .product-gallery__thumbs img {
    height: 64px;
  }
  .product-grid, .trust-strip__grid, .steps__grid { grid-template-columns: 1fr; }
  .gallery-grid { grid-template-columns: 1fr; }
  .section { padding: 52px 0; }
  .cart-summary, .purchase-row { display: block; }
  .home-category-showcase {
    padding: 32px 0;
  }
  .category-card-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .brand-tile-row {
    grid-template-columns: 1fr;
  }
  .brand-tile-row a {
    min-height: 58px;
  }
}

/* Final mobile navigation override: keep this at the end of the file. */
@media (max-width: 768px) {
  .site-nav__categories {
    position: sticky !important;
    top: 0 !important;
    z-index: 12 !important;
    overflow: hidden !important;
    background: #020202 !important;
    box-shadow: 0 8px 18px rgba(0,0,0,.18) !important;
  }

  .site-nav__categories::after {
    display: none !important;
  }

  .site-nav__menu-wrap {
    width: min(100% - 24px, 1200px) !important;
    min-height: 0 !important;
    margin: 0 auto !important;
    padding: 6px 0 !important;
    display: grid !important;
    gap: 6px !important;
  }

  .mobile-menu-button {
    width: 100% !important;
    min-height: 40px !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 8px 12px !important;
    border: 1px solid rgba(255,255,255,.2) !important;
    border-radius: 8px !important;
    background: #111 !important;
    color: #fff !important;
    font-size: 15px !important;
    font-weight: 900 !important;
    line-height: 1.1 !important;
  }

  .site-nav__scroll {
    width: 100% !important;
    min-height: 0 !important;
    display: none !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 6px !important;
    padding: 6px !important;
    overflow: visible !important;
    white-space: normal !important;
    scroll-snap-type: none !important;
    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    border: 1px solid rgba(255,255,255,.12) !important;
    border-radius: 8px !important;
    background: #111 !important;
  }

  .site-nav__categories.is-open .site-nav__scroll {
    display: grid !important;
  }

  .site-nav__scroll::-webkit-scrollbar {
    display: none !important;
  }

  .site-nav__scroll a {
    display: flex !important;
    align-items: center !important;
    min-height: 38px !important;
    padding: 9px 10px !important;
    border-radius: 7px !important;
    background: rgba(255,255,255,.07) !important;
    flex: 0 1 auto !important;
    scroll-snap-align: start !important;
    opacity: .92 !important;
  }

  .site-nav__scroll a:hover,
  .site-nav__scroll a:focus,
  .site-nav__scroll a.is-active {
    background: rgba(255,255,255,.14) !important;
  }

  .site-nav__scroll a.is-active::after {
    display: none !important;
  }
}

/* Comfortable Typography Override: keep this after all layout rules. */
html {
  font-size: 16px;
}

body {
  font-size: 16px !important;
  line-height: 1.65 !important;
}

p,
li,
td,
th,
label,
input,
select,
textarea,
summary,
small,
a {
  font-size: 16px !important;
  line-height: 1.6 !important;
}

h1,
.hero h1,
.admin-hero h1,
.product-detail h1 {
  font-size: clamp(28px, 4vw, 42px) !important;
  line-height: 1.15 !important;
}

h2,
.section__head h2,
.collection h2,
.panel h2,
.store-card h2,
.info-grid h2 {
  font-size: clamp(22px, 3vw, 30px) !important;
  line-height: 1.2 !important;
}

h3,
.product-card h3,
.video-card__body h3,
.gallery-caption h3 {
  font-size: 20px !important;
  line-height: 1.3 !important;
}

.site-topbar,
.site-topbar nav,
.site-nav__scroll,
.brand small,
.phone,
.language-switch button {
  font-size: 15px !important;
}

.brand strong {
  font-size: 22px !important;
}

.brand__logo {
  width: 180px !important;
  height: 90px !important;
}

.site-nav__inner {
  min-height: 96px !important;
}

.button,
.btn,
button,
.button--small,
.compact,
.icon-btn {
  font-size: 15px !important;
  min-height: 40px !important;
  padding: 8px 16px !important;
  line-height: 1.2 !important;
}

input,
select,
textarea {
  font-size: 15px !important;
  padding: 10px 14px !important;
}

.product-card__body > p {
  font-size: 14px !important;
}

.product-card h3 {
  font-size: 17px !important;
}

.product-card__price {
  font-size: 18px !important;
}

.product-card__rating,
.product-card__stock {
  font-size: 14px !important;
}

table,
.panel table {
  font-size: 15px !important;
}

th,
td {
  padding: 12px 14px !important;
}

.panel th {
  font-size: 15px !important;
}

.admin-tabs a,
.admin-subtabs .btn {
  font-size: 16px !important;
  min-height: 42px !important;
}

.admin-stat-card span {
  font-size: 15px !important;
}

.admin-stat-card strong {
  font-size: 28px !important;
}

.admin-stat-card small {
  font-size: 14px !important;
}

.admin-form-open span {
  font-size: 20px !important;
}

.admin-form-open::before {
  font-size: 15px !important;
}

.admin-form-modal__head h2 {
  font-size: 24px !important;
}

.flash {
  font-size: 16px !important;
}

.flash-alert__dialog h2 {
  font-size: 24px !important;
}

.flash-alert__dialog p {
  font-size: 16px !important;
}

@media (max-width: 768px) {
  body {
    font-size: 15px !important;
  }

  .site-container,
  .container {
    width: min(100% - 24px, 1200px) !important;
  }

  .brand {
    min-width: 0 !important;
  }

  .brand__logo {
    width: 140px !important;
    height: 70px !important;
  }

  .brand strong {
    font-size: 18px !important;
  }

  .site-nav__inner {
    min-height: 78px !important;
    gap: 14px !important;
  }

  .site-nav__scroll {
    font-size: 14px !important;
    gap: 6px !important;
  }

  h1,
  .hero h1,
  .admin-hero h1 {
    font-size: 30px !important;
  }

  h2 {
    font-size: 22px !important;
  }

  .button,
  .btn,
  button {
    font-size: 14px !important;
  }

  th,
  td {
    font-size: 14px !important;
    padding: 10px 12px !important;
  }
}

/* Invoice document */
.invoice-page {
  width: min(920px, 100%);
  margin: 0 auto 48px;
}

.invoice-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin: 0 0 16px;
}

.invoice-sheet {
  padding: 26px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  color: #111;
  box-shadow: 0 18px 50px rgba(31, 24, 18, .08);
}

.invoice-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  padding-bottom: 12px;
  border-bottom: 1px solid #d9d9d9;
}

.invoice-kicker {
  margin: 0 0 4px;
  color: #6e6a63;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.invoice-head h1 {
  margin: 0;
  font-size: 28px !important;
  line-height: 1.1 !important;
}

.invoice-logo {
  width: 120px;
  height: 70px;
  object-fit: contain;
}

.invoice-parties {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, .9fr);
  gap: 24px;
  padding: 14px 0;
}

.invoice-parties h2,
.invoice-table-card h2 {
  margin: 0 0 8px;
  font-size: 16px !important;
  line-height: 1.15 !important;
}

.invoice-parties p,
.invoice-meta-grid p,
.invoice-footer-note p {
  margin: 2px 0;
  font-size: 13px !important;
  line-height: 1.35 !important;
}

.invoice-payto {
  text-align: right;
}

.invoice-bank-list {
  display: grid;
  gap: 4px;
  margin-top: 8px;
}

.invoice-meta-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin: 0 0 10px;
}

.invoice-meta-grid p {
  padding: 7px 9px;
  border: 1px solid #e5e1da;
  border-radius: 8px;
  background: #fffaf2;
}

.invoice-meta-grid span,
.invoice-meta-grid strong {
  display: block;
}

.invoice-meta-grid span {
  color: #6e6a63;
}

.invoice-table-card {
  margin-top: 10px;
  border: 1px solid #d9d9d9;
  border-radius: 8px;
  overflow: hidden;
}

.invoice-table-card h2 {
  padding: 8px 10px;
  border-bottom: 1px solid #d9d9d9;
  background: #f4f4f4;
}

.invoice-table {
  min-width: 0 !important;
  width: 100%;
  border-collapse: collapse;
  table-layout: auto;
}

.invoice-table th,
.invoice-table td {
  padding: 7px 10px !important;
  border-bottom: 1px solid #e5e5e5;
  font-size: 13px !important;
  line-height: 1.25 !important;
}

.invoice-table th {
  background: #fff !important;
  color: #111 !important;
  font-weight: 900;
}

.invoice-table th:not(:first-child),
.invoice-table td:not(:first-child) {
  text-align: right;
}

.invoice-total-row td:first-child,
.invoice-grand-row td:first-child {
  text-align: right;
  font-weight: 900;
}

.invoice-grand-row td {
  background: #faf7f1;
  font-weight: 900;
}

.invoice-footer-note {
  margin-top: 10px;
  padding-top: 9px;
  border-top: 1px solid #d9d9d9;
  color: #5f5a53;
}

.order-status-actions {
  display: grid;
  justify-items: end;
  gap: 8px;
}

@media (max-width: 768px) {
  .invoice-actions,
  .invoice-head,
  .invoice-parties {
    display: grid;
  }

  .invoice-actions {
    justify-content: stretch;
  }

  .invoice-actions .button {
    width: 100%;
  }

  .invoice-sheet {
    padding: 18px;
  }

  .invoice-payto {
    text-align: left;
  }

  .invoice-meta-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media print {
  @page {
    size: A4;
    margin: 12mm;
  }

  body {
    background: #fff !important;
  }

  .site-topbar,
  .site-nav,
  .footer,
  .floating-cart,
  .no-print,
  .confirm-modal {
    display: none !important;
  }

  .container,
  .invoice-page {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .invoice-sheet {
    padding: 0;
    border: 0;
    box-shadow: none;
  }

  .invoice-head h1 {
    font-size: 22px !important;
  }

  .invoice-logo {
    width: 92px;
    height: 52px;
  }

  .invoice-parties {
    gap: 14px;
    padding: 10px 0;
  }

  .invoice-parties h2,
  .invoice-table-card h2 {
    font-size: 13px !important;
    margin-bottom: 5px;
  }

  .invoice-parties p,
  .invoice-meta-grid p,
  .invoice-footer-note p {
    font-size: 11px !important;
    line-height: 1.25 !important;
  }

  .invoice-meta-grid {
    gap: 6px;
    margin-bottom: 8px;
  }

  .invoice-meta-grid p {
    padding: 5px 7px;
  }

  .invoice-table-card {
    margin-top: 8px;
  }

  .invoice-table-card h2 {
    padding: 6px 8px;
  }

  .invoice-table th,
  .invoice-table td {
    padding: 5px 7px !important;
    font-size: 11px !important;
    line-height: 1.18 !important;
  }

  .invoice-payment-card {
    margin-top: 6px;
  }

  .invoice-footer-note {
    margin-top: 8px;
    padding-top: 7px;
  }

  .invoice-footer-note p:first-child {
    display: none;
  }

  .invoice-payment-table th:nth-child(3),
  .invoice-payment-table td:nth-child(3) {
    display: none;
  }

  .invoice-table-card,
  .invoice-meta-grid p {
    break-inside: avoid;
  }
}

/* Keep customer account shortcuts visible while scrolling */
body:not(.admin-page) {
  padding-top: 38px !important;
}
body:not(.admin-page) .site-topbar {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 300 !important;
  background: #172615 !important;
  color: #fff !important;
  box-shadow: 0 8px 22px rgba(0,0,0,.16);
}
body:not(.admin-page) .site-topbar__inner {
  min-height: 38px !important;
}
body:not(.admin-page) .site-topbar nav a,
body:not(.admin-page) .site-topbar nav span:not(.language-switch),
body:not(.admin-page) .site-topbar__inner > span {
  color: #fff !important;
}
body:not(.admin-page) .site-nav {
  top: 38px !important;
}
body:not(.admin-page) .site-nav__categories {
  top: 38px !important;
}
@media (max-width: 620px) {
  body:not(.admin-page) {
    padding-top: 42px !important;
  }
  body:not(.admin-page) .site-topbar__inner {
    min-height: 42px !important;
    padding: 6px 0 !important;
  }
  body:not(.admin-page) .site-topbar nav {
    justify-content: flex-end !important;
    gap: 7px !important;
    font-size: 13px !important;
  }
  body:not(.admin-page) .site-nav {
    top: 42px !important;
  }
  body:not(.admin-page) .site-nav__categories {
    top: 42px !important;
  }
}
