@font-face {
  font-family: "Clash Display";
  src: url("/assets/fonts/ClashDisplay-Extralight.otf") format("opentype");
  font-weight: 200;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Clash Display";
  src: url("/assets/fonts/ClashDisplay-Light.otf") format("opentype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Clash Display";
  src: url("/assets/fonts/ClashDisplay-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Clash Display";
  src: url("/assets/fonts/ClashDisplay-Medium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Clash Display";
  src: url("/assets/fonts/ClashDisplay-Semibold.otf") format("opentype");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Clash Display";
  src: url("/assets/fonts/ClashDisplay-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Clash Display";
  src: url("/assets/fonts/ClashDisplay-Bold.otf") format("opentype");
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}

:root {
  --ink: #11110f;
  --paper: #f4f1e9;
  --white: #fffef9;
  --orange: #e9562a;
  --acid: #d9ef49;
  --gray: #78766f;
  --line: rgba(17, 17, 15, 0.18);
  --display: Arial, "Helvetica Neue", sans-serif;
  --body: Arial, "Helvetica Neue", sans-serif;
  --mono: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
}

/* Foundation */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 84px; overflow-x: clip; }
body { min-width: 280px; margin: 0; overflow-x: clip; color: var(--ink); background: var(--paper); font-family: var(--body); }
main { overflow-x: clip; }
body.menu-open { overflow: hidden; }
img { display: block; width: 100%; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input { font: inherit; }
button { color: inherit; touch-action: manipulation; }
[hidden] { display: none !important; }
.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; }

/* Global navigation */
.announcement {
  min-height: 34px;
  padding: 7px 2.2vw;
  display: flex;
  justify-content: center;
  gap: 32px;
  align-items: center;
  background: var(--ink);
  color: var(--white);
  font: 500 10px/1.4 var(--mono);
  letter-spacing: .08em;
  text-transform: uppercase;
}
.announcement p { margin: 0; }
.announcement a { color: var(--acid); }

.site-header {
  position: sticky;
  top: 0;
  z-index: 40;
  height: 78px;
  padding: 0 clamp(18px, 3vw, 52px);
  display: flex;
  align-items: center;
  background: rgba(244, 241, 233, .92);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(16px);
  transition: height .3s ease, box-shadow .3s ease;
}
.site-header.scrolled { height: 64px; box-shadow: 0 8px 30px rgba(20, 20, 15, .06); }
.brand-cluster {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: clamp(12px, 1.7vw, 22px);
  position: relative;
  z-index: 1;
}
.logo {
  width: max-content;
  display: inline-flex;
  align-items: center;
  font: 800 clamp(20px, 2vw, 27px)/1 var(--display);
  letter-spacing: -.08em;
  flex-shrink: 0;
  line-height: 0;
}
.site-header .logo,
.auth-header .logo,
.account-header .logo,
.admin-header .logo {
  max-width: 180px;
}
.site-header .logo-mark,
.auth-header .logo-mark,
.account-header .logo-mark,
.admin-header .logo-mark {
  display: block;
  width: 100%;
  max-width: 180px;
  height: auto;
  max-height: 42px;
  object-fit: contain;
  flex: 0 0 auto;
}
.logo sup { margin-left: 4px; color: var(--orange); font: 500 9px/1 var(--mono); letter-spacing: 0; vertical-align: top; }
.account-button { min-height: 34px; padding: 0 11px; display: inline-flex; align-items: center; border: 1px solid var(--ink); font: 500 9px var(--mono); letter-spacing: .03em; text-transform: uppercase; white-space: nowrap; transition: background .2s, color .2s; }
.account-button:hover { background: var(--ink); color: white; }
.desktop-nav {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: clamp(24px, 2vw, 34px);
  font-size: 13px;
  font-weight: 600;
}
.desktop-nav a { position: relative; }
.desktop-nav a::after { content: ""; position: absolute; right: 0; bottom: -7px; left: 0; height: 1px; background: currentColor; transform: scaleX(0); transform-origin: right; transition: transform .25s ease; }
.desktop-nav a:hover::after { transform: scaleX(1); transform-origin: left; }
.header-actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 7px;
  position: relative;
  z-index: 1;
}
.icon-button, .menu-toggle { width: 44px; height: 44px; padding: 11px; border: 0; background: transparent; cursor: pointer; }
.icon-button svg { fill: none; stroke: currentColor; stroke-width: 1.5; }
.cart-button { min-height: 38px; padding: 0 14px; border: 1px solid var(--ink); background: transparent; font: 500 11px var(--mono); text-transform: uppercase; cursor: pointer; transition: background .2s, color .2s; }
.cart-button:hover { background: var(--ink); color: white; }
.cart-count { display: inline-grid; place-items: center; min-width: 18px; height: 18px; margin-left: 5px; border-radius: 50%; background: var(--orange); color: white; }
.menu-toggle { display: none; position: relative; }
.menu-toggle span:not(.sr-only) { position: absolute; left: 11px; width: 22px; height: 1.5px; background: var(--ink); transition: .25s; }
.menu-toggle span:first-child { top: 17px; }
.menu-toggle span:nth-child(2) { top: 25px; }
.menu-toggle[aria-expanded="true"] span:first-child { top: 21px; transform: rotate(45deg); }
.menu-toggle[aria-expanded="true"] span:nth-child(2) { top: 21px; transform: rotate(-45deg); }

.search-panel {
  position: fixed;
  z-index: 35;
  top: 112px;
  left: 0;
  width: 100%;
  padding: 28px clamp(18px, 4vw, 64px);
  background: var(--paper);
  border-bottom: 1px solid var(--line);
  transform: translateY(-130%);
  opacity: 0;
  transition: .35s ease;
}
.search-panel.open { transform: translateY(0); opacity: 1; }
.search-panel label { display: block; margin-bottom: 12px; font: 500 10px var(--mono); text-transform: uppercase; letter-spacing: .08em; }
.search-field { display: flex; gap: 20px; }
.search-field input { flex: 1; padding: 8px 0 14px; border: 0; border-bottom: 2px solid var(--ink); outline: 0; background: transparent; font: 600 clamp(20px, 3vw, 36px) var(--display); }
.search-close { border: 0; background: none; cursor: pointer; text-decoration: underline; }
.mobile-menu { display: none; }

/* Hero and campaign motion */
.hero {
  position: relative;
  min-height: calc(100vh - 112px);
  display: grid;
  grid-template-columns: minmax(620px, 48%) 1fr;
  border-bottom: 1px solid var(--line);
}
.hero-copy { position: relative; z-index: 2; padding: clamp(64px, 7vw, 110px) clamp(28px, 4vw, 72px); display: flex; flex-direction: column; justify-content: center; align-items: flex-start; }
.eyebrow { margin: 0 0 18px; font: 500 10px/1.4 var(--mono); letter-spacing: .11em; text-transform: uppercase; }
.hero h1, .custom-content h2, .showcase-copy h2, .newsletter h2 { margin: 0; max-width: 100%; font-family: var(--display); font-weight: 800; letter-spacing: -.065em; line-height: .89; }
.hero h1 {
  width: 100%;
  max-width: 760px;
  font-family: var(--body);
  font-size: clamp(54px, 4.25vw, 88px);
  font-weight: 800;
  letter-spacing: -.045em;
  line-height: .92;
}
.hero-intro { max-width: 500px; margin: 34px 0 0; color: #55534d; font-size: clamp(15px, 1.3vw, 19px); line-height: 1.65; }
.hero-actions { margin-top: 36px; display: flex; align-items: center; gap: 26px; flex-wrap: wrap; }
.button { min-height: 50px; padding: 0 22px; display: inline-flex; align-items: center; justify-content: center; gap: 30px; border: 1px solid; font: 600 11px var(--mono); letter-spacing: .03em; text-transform: uppercase; transition: transform .2s, background .2s, color .2s; }
.button:hover { transform: translateY(-3px); }
.button-dark { background: var(--ink); border-color: var(--ink); color: var(--white); }
.button-dark:hover { background: var(--orange); border-color: var(--orange); }
.button-light { background: var(--white); border-color: var(--white); color: var(--ink); }
.text-link { display: inline-flex; gap: 10px; align-items: center; padding-bottom: 4px; border-bottom: 1px solid; font-size: 12px; font-weight: 700; }
.text-link span { transition: transform .2s; }
.text-link:hover span { transform: translateX(5px); }
.hero-media { position: relative; overflow: hidden; min-height: 650px; background: #d6c5a4; }
.hero-media > img { height: 100%; object-fit: cover; object-position: 59% center; transition: transform 1s cubic-bezier(.2,.7,.2,1); }
.hero-media:hover > img { transform: scale(1.025); }
.hero-caption { position: absolute; top: 24px; left: 24px; color: var(--white); text-shadow: 0 1px 20px rgba(0,0,0,.3); }
.hero-caption span { font: 400 9px var(--mono); letter-spacing: .1em; }
.hero-caption p { font-size: 12px; line-height: 1.4; }
.floating-product { position: absolute; right: 20px; bottom: 20px; width: 170px; padding: 14px; display: flex; justify-content: space-between; background: rgba(255,254,249,.92); backdrop-filter: blur(8px); font-size: 10px; transition: transform .2s; }
.floating-product:hover { transform: translateY(-4px); }
.floating-product strong { font-weight: 700; }
.rotating-seal { position: absolute; z-index: 3; left: calc(48% - 54px); bottom: 8%; width: 108px; height: 108px; display: grid; place-items: center; border-radius: 50%; background: var(--acid); }
.rotating-seal svg { position: absolute; inset: 5px; width: calc(100% - 10px); animation: spin 14s linear infinite; }
.rotating-seal text { font: 500 10px var(--mono); letter-spacing: 1.4px; }
.rotating-seal > span { font-size: 24px; }
@keyframes spin { to { transform: rotate(360deg); } }

.glitch.is-glitching::before, .glitch.is-glitching::after { content: attr(data-text); position: absolute; inset: 0; pointer-events: none; }
.glitch { position: relative; }
.glitch.is-glitching::before { color: var(--orange); animation: glitch-one .35s steps(2) both; clip-path: inset(20% 0 55%); }
.glitch.is-glitching::after { color: #5f74ff; animation: glitch-two .35s steps(2) both; clip-path: inset(65% 0 12%); }
@keyframes glitch-one { 0% { transform: translate(0) } 30% { transform: translate(-6px, 2px) } 70% { transform: translate(5px, -2px) } 100% { transform: translate(0) } }
@keyframes glitch-two { 0% { transform: translate(0) } 30% { transform: translate(6px, -2px) } 70% { transform: translate(-4px, 2px) } 100% { transform: translate(0) } }

.marquee { overflow: hidden; padding: 19px 0; background: var(--orange); color: var(--white); }
.marquee-track { width: max-content; display: flex; align-items: center; gap: 34px; animation: ticker 22s linear infinite; font: 700 13px var(--display); letter-spacing: .05em; }
.marquee-track i { font-style: normal; color: var(--acid); }
@keyframes ticker { to { transform: translateX(-50%); } }

/* Commerce sections */
.section-shell { max-width: 1500px; margin: 0 auto; padding: clamp(80px, 10vw, 150px) clamp(18px, 3.3vw, 52px); }
.section-heading { margin-bottom: 45px; display: flex; justify-content: space-between; align-items: flex-end; gap: 30px; }
.section-heading h2 { margin: 0; font: 700 clamp(38px, 5vw, 72px)/.95 var(--display); letter-spacing: -.055em; }
.product-tabs { display: flex; gap: 24px; }
.tab { min-height: 44px; padding: 5px 0; border: 0; border-bottom: 1px solid transparent; background: transparent; color: var(--gray); font: 500 11px var(--mono); text-transform: uppercase; cursor: pointer; }
.tab.active { color: var(--ink); border-color: currentColor; }
.product-grid { display: none; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: clamp(12px, 2vw, 26px); }
.product-grid.active { display: grid; }
.product-grid#new { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.product-card { min-width: 0; }
.product-image { position: relative; aspect-ratio: .78; overflow: hidden; display: block; background: #dedbd2; }
.product-image img { width: 280%; height: 100%; max-width: none; object-fit: cover; transition: transform .6s ease; }
.product-card:hover .product-image img { transform: scale(1.035); }
.crop-black img { object-position: 0 center; }
.crop-vase img { margin-left: -61%; object-position: center; }
.crop-figure img { margin-left: -121%; object-position: center; }
.crop-tray img { margin-left: -181%; object-position: right center; }
.badge { position: absolute; z-index: 2; top: 12px; left: 12px; padding: 7px 9px; background: var(--ink); color: white; font: 500 8px var(--mono); letter-spacing: .08em; text-transform: uppercase; }
.badge-light { background: var(--acid); color: var(--ink); }
.product-info { min-height: 75px; padding: 15px 2px 9px; display: flex; justify-content: space-between; gap: 10px; border-bottom: 1px solid var(--line); }
.product-info h3 { margin: 0 0 5px; font-size: 14px; }
.product-info p { margin: 0; color: var(--gray); font-size: 10px; }
.product-info .price { color: var(--ink); font: 500 11px var(--mono); white-space: nowrap; }
.quick-add { width: 100%; min-height: 44px; padding: 11px 2px; display: flex; justify-content: space-between; align-items: center; border: 0; border-bottom: 1px solid var(--ink); background: transparent; font: 500 10px var(--mono); text-transform: uppercase; cursor: pointer; transition: padding .2s, background .2s; }
.quick-add:hover { padding-inline: 10px; background: var(--acid); }
.wide-product .product-image { aspect-ratio: 1.45; }
.wide-product .product-image img { width: 180%; }

.categories { padding-top: 30px; }
.category-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--ink); border: 1px solid var(--ink); }
.category-card { position: relative; min-height: 380px; padding: 24px; display: flex; flex-direction: column; justify-content: space-between; overflow: hidden; background: var(--paper); transition: color .3s; }
.category-card::before { content: ""; position: absolute; inset: 0; transform: translateY(101%); transition: transform .45s cubic-bezier(.2,.7,.2,1); }
.category-home::before { background: var(--orange); }
.category-desk::before { background: var(--acid); }
.category-play::before { background: #6866d9; }
.category-card:hover::before { transform: translateY(0); }
.category-card > * { position: relative; z-index: 1; }
.category-number { font: 500 10px var(--mono); }
.category-card h3 { max-width: 250px; margin: 0 0 14px; font: 700 clamp(30px, 3vw, 47px)/.95 var(--display); letter-spacing: -.05em; }
.category-card p { max-width: 270px; margin: 0; font-size: 12px; line-height: 1.6; }
.arrow-circle { position: absolute; top: 20px; right: 20px; width: 44px; height: 44px; display: grid; place-items: center; border: 1px solid; border-radius: 50%; transition: transform .3s; }
.category-card:hover .arrow-circle { transform: rotate(45deg); }

/* Editorial campaign and process */
.custom-feature { position: relative; min-height: min(82vw, 850px); margin-top: 70px; display: flex; align-items: center; overflow: hidden; background: #222; color: white; }
.custom-feature > img { position: absolute; inset: 0; height: 100%; object-fit: cover; }
.custom-overlay { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(5,5,5,.82) 0%, rgba(5,5,5,.55) 40%, rgba(5,5,5,.05) 75%); }
.custom-content { position: relative; z-index: 2; max-width: 780px; padding: clamp(70px, 8vw, 130px) clamp(24px, 8vw, 120px); }
.custom-content h2 { font-size: clamp(53px, 8vw, 120px); }
.custom-content > p:not(.eyebrow) { max-width: 520px; margin: 32px 0; color: rgba(255,255,255,.75); font-size: 16px; line-height: 1.65; }
.custom-email { position: absolute; z-index: 2; right: 24px; bottom: 25px; margin: 0; font: 400 10px var(--mono); writing-mode: vertical-rl; }

.showcase {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  padding-inline: clamp(18px, 3.3vw, 52px);
  gap: 0;
  overflow: hidden;
}
.showcase-media {
  position: relative;
  grid-column: 1 / -1;
  min-height: 760px;
  min-width: 0;
  overflow: hidden;
  background: #ddd6c7;
}
.showcase-media > img {
  height: 100%;
  object-fit: cover;
  object-position: 48% center;
  transition: transform .45s ease, object-position .45s ease;
}
.showcase-copy {
  position: absolute;
  z-index: 3;
  top: 50%;
  right: clamp(28px, 4vw, 54px);
  width: min(48%, 720px);
  min-width: 0;
  padding: clamp(42px, 4.8vw, 76px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: var(--acid);
  box-shadow: 0 24px 60px rgba(0,0,0,.16);
  transform: translate3d(0, -50%, 0);
  transition: transform .4s cubic-bezier(.22,.61,.36,1), box-shadow .3s ease;
}
.showcase-copy h2 { font-size: clamp(44px, 6vw, 88px); }
.showcase-copy > p:not(.eyebrow) { margin: 30px 0; font-size: 15px; line-height: 1.65; }
.showcase-copy .button { align-self: flex-start; }
.showcase:hover .showcase-copy,
.showcase:focus-within .showcase-copy {
  transform: translate3d(clamp(120px, 10vw, 180px), -50%, 0);
  box-shadow: 0 30px 70px rgba(0,0,0,.2);
}
.showcase:hover .showcase-media > img,
.showcase:focus-within .showcase-media > img {
  transform: scale(1.03);
  object-position: 44% center;
}
.material-note { margin-top: 65px; padding-top: 20px; border-top: 1px solid rgba(0,0,0,.35); }
.material-note span { font: 500 9px var(--mono); text-transform: uppercase; }
.material-note p { max-width: 430px; margin: 10px 0 0; font-size: 11px; line-height: 1.6; }
.hotspot {
  position: absolute;
  z-index: 2;
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border: 0;
  border-radius: 50%;
  background: rgba(255,255,255,.96);
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(0,0,0,.18);
  font: 600 21px/1 var(--display);
  transition: transform .22s ease, background .22s ease, color .22s ease;
  animation: pulse 2s infinite;
}
.hotspot:hover,
.hotspot:focus-visible,
.hotspot.is-active {
  transform: scale(1.06);
  background: var(--ink);
  color: var(--white);
}
.hotspot-one { top: 34%; left: 42%; }
.hotspot-two { top: 60%; left: 18%; }
@keyframes pulse { 50% { box-shadow: 0 0 0 10px rgba(255,255,255,.25); } }
.hotspot-card {
  position: absolute;
  left: clamp(18px, 3vw, 32px);
  right: auto;
  bottom: clamp(18px, 3vw, 32px);
  width: min(240px, calc(100% - 36px));
  padding: 16px 16px 14px;
  display: none;
  flex-direction: column;
  gap: 6px;
  background: rgba(255,254,249,.96);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 40px rgba(0,0,0,.16);
  font-style: normal;
  font-size: 10px;
}
.hotspot-card.open { display: flex; }
.hotspot-label { font: 500 9px var(--mono); text-transform: uppercase; letter-spacing: .08em; color: var(--gray); }
.hotspot-card strong { font: 700 clamp(20px, 2vw, 24px)/1 var(--display); letter-spacing: -.03em; }
.hotspot-card em { font-style: normal; font: 500 11px var(--mono); }
.hotspot-card p { margin: 0 0 4px; color: #55534d; font-size: 11px; line-height: 1.55; }
.hotspot-link { width: fit-content; margin-top: 2px; }

.process { background: var(--ink); color: var(--white); }
.process .section-shell { max-width: 1500px; }
.process-intro { max-width: 400px; color: #aaa89f; font-size: 14px; line-height: 1.6; }
.process-grid { margin: 0; padding: 0; display: grid; grid-template-columns: repeat(4, 1fr); list-style: none; border-top: 1px solid rgba(255,255,255,.25); }
.process-grid li { min-height: 270px; padding: 22px 26px 20px 0; border-right: 1px solid rgba(255,255,255,.25); }
.process-grid li:not(:first-child) { padding-left: 26px; }
.process-grid span { color: var(--orange); font: 500 10px var(--mono); }
.process-grid h3 { margin: 82px 0 18px; font: 600 29px var(--display); }
.process-grid p { max-width: 240px; margin: 0; color: #aaa89f; font-size: 12px; line-height: 1.6; }

.journal-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 24px; align-items: start; }
.journal-image { display: block; aspect-ratio: 1.1; overflow: hidden; background: #ddd; }
.journal-card:not(.journal-feature) .journal-image { aspect-ratio: .9; }
.journal-image img { height: 100%; object-fit: cover; transition: transform .65s ease; }
.journal-image:hover img { transform: scale(1.035); }
.journal-card:nth-child(2) img { object-position: 70% center; }
.crop-journal img { object-position: center; }
.journal-meta { margin: 15px 0 10px; color: var(--gray); font: 400 9px var(--mono); text-transform: uppercase; }
.journal-card h3 { margin: 0; font: 600 clamp(18px, 2vw, 28px)/1.15 var(--display); letter-spacing: -.03em; }

.newsletter { padding: clamp(70px, 8vw, 120px) clamp(20px, 8vw, 120px); display: grid; grid-template-columns: 1fr .8fr; align-items: end; gap: 60px; background: var(--orange); color: var(--white); }
.newsletter h2 { font-size: clamp(48px, 7.4vw, 112px); }
.newsletter-form { position: relative; align-self: end; display: flex; border-bottom: 2px solid white; }
.newsletter-form input { flex: 1; min-width: 0; padding: 18px 0; border: 0; outline: 0; background: transparent; color: white; font: 500 clamp(16px, 2vw, 24px) var(--body); }
.newsletter-form input::placeholder { color: rgba(255,255,255,.65); }
.newsletter-form button { width: 60px; border: 0; background: transparent; color: white; font-size: 28px; cursor: pointer; transition: transform .2s; }
.newsletter-form button:hover { transform: translateX(5px); }
.form-message { position: absolute; top: 100%; left: 0; font: 400 10px var(--mono); }

/* Footer and interface feedback */
.site-footer { padding: 75px clamp(20px, 4vw, 60px) 25px; display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; background: var(--ink); color: var(--white); }
.footer-logo {
  display: block;
  width: 220px;
  max-width: 100%;
  line-height: 0;
}
.footer-logo-mark {
  display: block;
  width: 220px;
  max-width: 100%;
  height: auto;
  max-height: none;
  object-fit: contain;
}
.footer-brand > p { margin: 24px 0; color: #aaa89f; font-size: 13px; line-height: 1.6; }
.footer-brand > a:last-child { font: 400 11px var(--mono); text-decoration: underline; }
.footer-links { display: grid; grid-template-columns: repeat(3, 1fr); gap: 35px; }
.footer-links div { display: flex; flex-direction: column; align-items: flex-start; gap: 12px; }
.footer-links p { margin: 0 0 12px; color: #77766f; font: 400 9px var(--mono); text-transform: uppercase; }
.footer-links a { font-size: 12px; }
.footer-links a:hover { color: var(--acid); }
.footer-bottom { grid-column: 1 / -1; padding-top: 22px; display: flex; justify-content: space-between; border-top: 1px solid rgba(255,255,255,.2); color: #77766f; font: 400 9px var(--mono); text-transform: uppercase; }
.footer-bottom div { display: flex; gap: 25px; }

.toast { position: fixed; z-index: 60; right: 22px; bottom: 22px; padding: 14px 20px; background: var(--acid); font: 500 10px var(--mono); text-transform: uppercase; transform: translateY(120px); transition: transform .35s ease; }
.toast.show { transform: translateY(0); }
.reveal { opacity: 0; transform: translateY(32px); transition: opacity .75s ease, transform .75s ease; }
.reveal.visible { opacity: 1; transform: none; }

/* Interior storefront pages */
.page-main { min-height: 70vh; }
.page-hero { padding: clamp(78px, 9vw, 138px) clamp(18px, 5vw, 80px) clamp(55px, 7vw, 100px); border-bottom: 1px solid var(--line); }
.page-hero-grid { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(280px, .55fr); gap: clamp(40px, 8vw, 140px); align-items: end; }
.page-hero h1 { max-width: 1050px; margin: 0; font: 800 clamp(64px, 10vw, 158px)/.82 var(--display); letter-spacing: -.075em; }
.page-hero-copy { max-width: 510px; margin: 0 0 8px; color: #55534d; font-size: clamp(15px, 1.25vw, 19px); line-height: 1.65; }
.page-kicker { margin-bottom: 24px; font: 500 10px var(--mono); letter-spacing: .11em; text-transform: uppercase; }
.shop-hero {
  position: relative;
  overflow: hidden;
  background: #1f1c18;
  color: var(--white);
}
.shop-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(115deg, rgba(14, 12, 10, .72) 0%, rgba(14, 12, 10, .42) 48%, rgba(14, 12, 10, .68) 100%),
    url("/assets/product-collection.jpg") center 42% / cover no-repeat;
  transform: scale(1.03);
}
.shop-hero::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 120px;
  background: linear-gradient(180deg, rgba(20, 17, 14, 0) 0%, rgba(20, 17, 14, .34) 100%);
}
.shop-hero-shell {
  position: relative;
  z-index: 1;
  padding: clamp(26px, 3vw, 36px);
  border: 1px solid rgba(255,255,255,.18);
  background: linear-gradient(135deg, rgba(20, 17, 14, .54), rgba(20, 17, 14, .26));
  backdrop-filter: blur(10px);
  box-shadow: 0 30px 80px rgba(0,0,0,.2);
}
.shop-hero .page-kicker { color: rgba(255,255,255,.78); }
.shop-hero .page-hero-copy { color: rgba(255,255,255,.86); }
.page-band { padding: 18px clamp(18px, 5vw, 80px); display: flex; justify-content: space-between; gap: 24px; background: var(--orange); color: white; font: 500 10px var(--mono); letter-spacing: .06em; text-transform: uppercase; }
.page-band span:last-child { color: var(--acid); }

.shop-layout { max-width: 1600px; margin: 0 auto; padding: clamp(50px, 7vw, 105px) clamp(18px, 3.3vw, 52px) 130px; display: grid; grid-template-columns: 245px minmax(0, 1fr); gap: clamp(40px, 5vw, 80px); }
.filters { position: sticky; top: 92px; align-self: start; }
.filter-heading { padding-bottom: 16px; display: flex; align-items: baseline; justify-content: space-between; gap: 16px; border-bottom: 1px solid var(--ink); }
.filter-heading h2 { margin: 0; font: 600 18px var(--display); }
.filter-reset { padding: 0; border: 0; background: none; font: 500 9px var(--mono); text-decoration: underline; cursor: pointer; }
.filter-group { min-width: 0; margin: 0; padding: 18px 0; border: 0; }
fieldset.filter-group { min-inline-size: 0; padding: 18px 0; display: grid; row-gap: 14px; }
.filter-group legend, .filter-label { width: 100%; margin: 0; padding: 0; font: 500 9px/1.2 var(--mono); letter-spacing: .08em; text-transform: uppercase; }
.filters .filter-group legend,
.filters .filter-label {
  width: 100%;
  display: block;
  box-sizing: border-box;
  padding: 6px 10px;
  background: var(--orange);
  color: var(--white);
}
.filter-label { margin-bottom: 14px; }
.filter-options { display: grid; gap: 2px; }
.filter-option { display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: center; gap: 14px; padding: 9px 0; color: #4f4d47; font-size: 12px; line-height: 1.45; cursor: pointer; }
.filter-option:first-of-type { padding-top: 0; }
.filter-option:last-of-type { padding-bottom: 0; }
.filter-option-name { min-width: 0; }
.filter-option-meta { display: inline-flex; align-items: center; gap: 8px; color: var(--gray); }
.filter-group input[type="checkbox"] { width: 15px; height: 15px; margin: 0; accent-color: var(--orange); }
.filter-count { min-width: 10px; text-align: right; font: 500 11px var(--mono); }
.filter-range { position: relative; height: 26px; margin-top: 2px; }
.filter-range-track,
.filter-range-fill {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  height: 6px;
  border-radius: 999px;
}
.filter-range-track { right: 0; left: 0; background: rgba(17,17,15,.14); }
.filter-range-fill { background: var(--orange); }
.filter-range input[type="range"] {
  position: absolute;
  inset: 0;
  width: 100%;
  margin: 0;
  background: transparent;
  pointer-events: none;
  -webkit-appearance: none;
  appearance: none;
}
.filter-range input[type="range"]::-webkit-slider-runnable-track {
  height: 6px;
  background: transparent;
}
.filter-range input[type="range"]::-moz-range-track {
  height: 6px;
  background: transparent;
}
.filter-range input[type="range"]::-webkit-slider-thumb {
  width: 18px;
  height: 18px;
  margin-top: -6px;
  border: 1px solid rgba(17,17,15,.16);
  border-radius: 50%;
  background: var(--white);
  box-shadow: 0 4px 12px rgba(0,0,0,.12);
  pointer-events: auto;
  -webkit-appearance: none;
}
.filter-range input[type="range"]::-moz-range-thumb {
  width: 18px;
  height: 18px;
  border: 1px solid rgba(17,17,15,.16);
  border-radius: 50%;
  background: var(--white);
  box-shadow: 0 4px 12px rgba(0,0,0,.12);
  pointer-events: auto;
}
.filter-price { margin-top: 16px; display: flex; justify-content: space-between; align-items: center; font: 500 10px var(--mono); }
.shop-tools { min-height: 48px; margin-bottom: 28px; display: flex; justify-content: space-between; align-items: center; gap: 20px; border-bottom: 1px solid var(--ink); }
.result-count { font: 500 10px var(--mono); text-transform: uppercase; }
.sort-select { padding: 9px 28px 9px 0; border: 0; background: transparent; font: 500 10px var(--mono); text-transform: uppercase; }
.catalog-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 42px clamp(14px, 2vw, 28px); }
.catalog-grid .product-image { aspect-ratio: .82; }
.product-image-single img { width: 100%; height: 100%; object-fit: cover; object-position: 62% center; }
.catalog-empty { grid-column: 1 / -1; padding: 80px 20px; text-align: center; border: 1px solid var(--line); }
.catalog-empty h2 { margin: 0 0 10px; font: 700 32px var(--display); }

.cart-layout { max-width: 1450px; margin: 0 auto; padding: clamp(55px, 7vw, 100px) clamp(18px, 4vw, 64px) 130px; display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(310px, .65fr); gap: clamp(50px, 8vw, 120px); }
.cart-list { border-top: 1px solid var(--ink); }
.cart-item { padding: 22px 0; display: grid; grid-template-columns: 135px minmax(0, 1fr) auto; gap: 24px; align-items: center; border-bottom: 1px solid var(--line); }
.cart-item .product-image { aspect-ratio: 1; }
.cart-item-copy h2 { margin: 0 0 8px; font: 600 22px var(--display); }
.cart-item-copy p { margin: 0 0 18px; color: var(--gray); font-size: 11px; }
.quantity-control { width: max-content; display: grid; grid-template-columns: 35px 38px 35px; border: 1px solid var(--ink); }
.quantity-control button { height: 34px; border: 0; background: transparent; cursor: pointer; }
.quantity-control span { display: grid; place-items: center; font: 500 10px var(--mono); }
.cart-item-price { height: 100%; display: flex; flex-direction: column; align-items: flex-end; justify-content: space-between; font: 500 11px var(--mono); }
.remove-item { padding: 0; border: 0; background: transparent; color: var(--gray); font: 400 9px var(--mono); text-decoration: underline; cursor: pointer; }
.cart-summary { position: sticky; top: 92px; align-self: start; padding: 30px; background: var(--acid); }
.cart-summary h2 { margin: 0 0 28px; font: 700 34px var(--display); }
.summary-row { padding: 13px 0; display: flex; justify-content: space-between; border-bottom: 1px solid rgba(0,0,0,.2); font-size: 12px; }
.summary-row.total { padding-top: 22px; border: 0; font-weight: 700; }
.checkout-button { width: 100%; margin-top: 20px; }
.summary-note { margin: 16px 0 0; font-size: 10px; line-height: 1.55; }
.cart-empty { padding: 80px 0; text-align: center; }
.cart-empty h2 { margin: 0 0 15px; font: 700 clamp(34px, 5vw, 64px) var(--display); }
.cart-empty p { margin: 0 0 30px; color: var(--gray); }

.story-grid { max-width: 1500px; margin: 0 auto; padding: clamp(70px, 9vw, 140px) clamp(18px, 4vw, 64px); display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 7vw, 110px); align-items: center; }
.story-grid.reverse .story-media { order: 2; }
.story-media { min-height: min(60vw, 720px); overflow: hidden; }
.story-media img { height: 100%; object-fit: cover; }
.story-copy h2 { margin: 0 0 30px; font: 700 clamp(45px, 6vw, 88px)/.92 var(--display); letter-spacing: -.055em; }
.story-copy > p { max-width: 580px; color: #55534d; font-size: 15px; line-height: 1.8; }
.principles { background: var(--ink); color: white; }
.principle-grid { max-width: 1500px; margin: 0 auto; padding: clamp(75px, 9vw, 135px) clamp(18px, 4vw, 64px); display: grid; grid-template-columns: repeat(3, 1fr); }
.principle { min-height: 320px; padding: 24px 30px 30px 0; border-top: 1px solid rgba(255,255,255,.25); border-right: 1px solid rgba(255,255,255,.25); }
.principle:not(:first-child) { padding-left: 30px; }
.principle span { color: var(--orange); font: 500 10px var(--mono); }
.principle h3 { margin: 105px 0 18px; font: 600 28px var(--display); }
.principle p { max-width: 310px; margin: 0; color: #aaa89f; font-size: 12px; line-height: 1.7; }

.contact-layout { max-width: 1450px; margin: 0 auto; padding: clamp(65px, 8vw, 120px) clamp(18px, 4vw, 64px) 130px; display: grid; grid-template-columns: .7fr 1.3fr; gap: clamp(55px, 10vw, 150px); }
.contact-details h2, .contact-form h2 { margin: 0 0 30px; font: 700 clamp(36px, 5vw, 62px)/.95 var(--display); letter-spacing: -.045em; }
.contact-method { padding: 20px 0; border-top: 1px solid var(--line); }
.contact-method span { display: block; margin-bottom: 8px; color: var(--gray); font: 500 9px var(--mono); text-transform: uppercase; }
.contact-method a, .contact-method p, .contact-method address { margin: 0; font-size: 14px; line-height: 1.6; }
.contact-method address { color: var(--ink); font-style: normal; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.field { display: flex; flex-direction: column; gap: 9px; }
.field-full { grid-column: 1 / -1; }
.field label { font: 500 9px var(--mono); letter-spacing: .06em; text-transform: uppercase; }
.field input, .field select, .field textarea { width: 100%; padding: 14px 0; border: 0; border-bottom: 1px solid var(--ink); border-radius: 0; outline: 0; background: transparent; }
.field textarea { min-height: 120px; resize: vertical; }
.contact-form .button { margin-top: 28px; cursor: pointer; }
.form-success { margin: 18px 0 0; color: #31510b; font: 500 10px var(--mono); }
.checkout-hero { padding-block: clamp(58px, 7vw, 100px); }
.checkout-layout { align-items: start; }
.checkout-form { padding-top: 4px; }
.payment-note { margin-top: 38px; padding: 24px; border: 1px solid var(--ink); }
.payment-note span { display: block; margin-bottom: 16px; color: var(--gray); font: 500 9px var(--mono); text-transform: uppercase; }
.payment-note strong { font: 600 18px var(--display); }
.payment-note p { margin: 10px 0 0; color: var(--gray); font-size: 11px; line-height: 1.6; }
.checkout-items { margin-bottom: 15px; border-top: 1px solid rgba(0,0,0,.2); }
.checkout-line { padding: 13px 0; display: flex; justify-content: space-between; gap: 20px; border-bottom: 1px solid rgba(0,0,0,.2); font-size: 11px; }
.faq { max-width: 1100px; margin: 0 auto; padding: 0 clamp(18px, 4vw, 64px) 130px; }
.faq h2 { margin: 0 0 35px; font: 700 clamp(38px, 5vw, 68px) var(--display); }
.faq details { border-top: 1px solid var(--ink); }
.faq details:last-child { border-bottom: 1px solid var(--ink); }
.faq summary { padding: 23px 0; display: flex; justify-content: space-between; gap: 20px; cursor: pointer; font-weight: 600; list-style: none; }
.faq summary::after { content: "+"; font: 500 18px var(--mono); }
.faq details[open] summary::after { content: "−"; }
.faq details p { max-width: 760px; margin: 0; padding: 0 0 26px; color: var(--gray); font-size: 13px; line-height: 1.75; }
.info-layout { max-width: 1200px; margin: 0 auto; padding: clamp(65px, 8vw, 120px) clamp(18px, 4vw, 64px) 130px; }
.info-nav { margin-bottom: 70px; display: flex; flex-wrap: wrap; gap: 12px; }
.info-nav a { padding: 10px 14px; border: 1px solid var(--ink); font: 500 9px var(--mono); text-transform: uppercase; }
.info-section { max-width: 800px; padding: 50px 0; border-top: 1px solid var(--line); scroll-margin-top: 90px; }
.info-section h2 { margin: 0 0 22px; font: 700 clamp(32px, 4vw, 54px) var(--display); }
.info-section h3 { margin: 30px 0 10px; font: 600 18px var(--display); }
.info-section p, .info-section li { color: #55534d; font-size: 13px; line-height: 1.8; }
.info-section ul { margin: 12px 0 22px; padding-left: 20px; }
.info-section li + li { margin-top: 7px; }
.info-section a { color: var(--ink); text-decoration: underline; text-underline-offset: 3px; }
.info-section .policy-updated { margin: -12px 0 24px; color: var(--gray); font: 500 9px var(--mono); letter-spacing: .05em; text-transform: uppercase; }

/* Authentication, accounts and admin */
.auth-page, .admin-page { background: var(--paper); }
.auth-header, .account-header, .admin-header { min-height: 78px; padding: 0 clamp(18px, 3vw, 52px); display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--line); }
.auth-shell { min-height: calc(100vh - 78px); display: grid; grid-template-columns: 1.08fr .92fr; }
.auth-art { position: relative; min-height: 740px; overflow: hidden; color: white; }
.auth-art > img { position: absolute; inset: 0; height: 100%; object-fit: cover; object-position: 62% center; }
.auth-art::after { content: ""; position: absolute; inset: 0; background: linear-gradient(0deg, rgba(8,8,7,.78), rgba(8,8,7,.05) 68%); }
.auth-art-copy { position: absolute; z-index: 1; right: clamp(28px, 5vw, 80px); bottom: clamp(45px, 7vw, 100px); left: clamp(28px, 5vw, 80px); }
.auth-art-copy h1 { margin: 0; font: 800 clamp(54px, 7vw, 104px)/.86 var(--display); letter-spacing: -.065em; }
.auth-art-copy > p:last-child { max-width: 520px; margin: 25px 0 0; color: rgba(255,255,255,.76); line-height: 1.7; }
.auth-panel { padding: clamp(45px, 8vw, 120px); display: flex; flex-direction: column; justify-content: center; }
.auth-tabs { margin-bottom: 55px; display: grid; grid-template-columns: 1fr 1fr; border-bottom: 1px solid var(--line); }
.auth-tab { padding: 15px 0; border: 0; border-bottom: 2px solid transparent; background: transparent; color: var(--gray); font: 500 10px var(--mono); text-transform: uppercase; cursor: pointer; }
.auth-tab.active { border-color: var(--ink); color: var(--ink); }
.auth-form { display: none; gap: 25px; }
.auth-form.active { display: grid; }
.auth-form h2 { margin: 0; font: 700 clamp(42px, 5vw, 68px)/.95 var(--display); letter-spacing: -.05em; }
.auth-form small { color: var(--gray); font-size: 10px; }
.auth-form .button { width: 100%; margin-top: 10px; cursor: pointer; }
.auth-social-button {
  width: 100%;
  min-height: 56px;
  padding: 0 18px;
  display: grid;
  grid-template-columns: 22px 1fr auto;
  align-items: center;
  gap: 14px;
  border: 1px solid rgba(16,16,15,.18);
  background: rgba(255,255,255,.72);
  color: var(--ink);
  text-align: left;
  text-decoration: none;
  transition: border-color .2s, transform .2s, background .2s;
}
.auth-social-button:hover { border-color: var(--ink); background: rgba(255,255,255,.94); transform: translateY(-1px); }
.auth-social-button svg { width: 20px; height: 20px; }
.auth-social-button span { font: 600 12px var(--body); }
.auth-social-button small { font: 500 9px var(--mono); color: var(--gray); text-transform: uppercase; letter-spacing: .05em; }
.auth-divider {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gray);
  font: 500 9px var(--mono);
  letter-spacing: .08em;
  text-transform: uppercase;
}
.auth-divider::before,
.auth-divider::after {
  content: "";
  flex: 1;
  border-top: 1px solid var(--line);
}
.auth-divider::before { margin-right: 12px; }
.auth-divider::after { margin-left: 12px; }
.auth-message, .admin-message { min-height: 18px; margin: 0; color: #31510b; font: 500 10px var(--mono); }
.auth-message.error, .admin-message.error { color: #a52c16; }
.auth-inline-action { justify-self: start; color: var(--ink); font: 500 10px var(--mono); letter-spacing: .03em; text-transform: uppercase; }
.text-button { padding: 0; border: 0; background: transparent; font: inherit; text-decoration: underline; cursor: pointer; }

.account-header nav, .admin-header > div { display: flex; align-items: center; gap: 25px; font-size: 12px; }
.dashboard-shell { min-height: calc(100vh - 78px); display: grid; grid-template-columns: minmax(320px, .72fr) minmax(0, 1.28fr); }
.dashboard-sidebar { position: sticky; top: 0; height: calc(100vh - 78px); padding: clamp(55px, 7vw, 105px) clamp(25px, 5vw, 75px); background: var(--acid); }
.dashboard-sidebar h1 {
  margin: 0;
  font: 800 clamp(58px, 7vw, 108px)/.83 var(--display);
  letter-spacing: -.07em;
  overflow-wrap: normal;
}
.dashboard-sidebar h1 span {
  display: block;
  margin-top: .12em;
  font-family: var(--body);
  font-size: clamp(42px, 4.8vw, 72px);
  font-weight: 700;
  line-height: .95;
  letter-spacing: -.05em;
  text-wrap: balance;
}
.account-meta { position: absolute; right: clamp(25px, 5vw, 75px); bottom: 45px; left: clamp(25px, 5vw, 75px); display: grid; grid-template-columns: auto 1fr; gap: 10px 20px; padding-top: 20px; border-top: 1px solid rgba(0,0,0,.3); font-size: 11px; }
.account-meta span { color: rgba(0,0,0,.6); font: 500 9px var(--mono); text-transform: uppercase; }
.dashboard-content { padding: clamp(55px, 7vw, 105px) clamp(25px, 5vw, 75px); }
.dashboard-heading, .admin-section-heading { margin-bottom: 45px; display: flex; align-items: flex-end; justify-content: space-between; gap: 30px; }
.dashboard-heading h2, .admin-section-heading h2 { margin: 0; font: 700 clamp(40px, 5vw, 70px)/.95 var(--display); letter-spacing: -.05em; }
.settings-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.settings-card { padding: 28px; display: flex; flex-direction: column; gap: 22px; border: 1px solid var(--ink); }
.settings-card > span { font: 500 9px var(--mono); color: var(--gray); text-transform: uppercase; }
.settings-card h3 { margin: 18px 0 10px; font: 600 25px var(--display); }
.settings-card .button { margin-top: auto; cursor: pointer; }
.addresses-panel { margin-top: 80px; }
.address-book { gap: 28px; }
.address-book-heading { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; }
.address-book-heading > div > span, .address-dialog-heading span { color: var(--gray); font: 500 9px var(--mono); text-transform: uppercase; }
.address-book-heading h3 { margin: 10px 0 0; }
.address-book-heading .button { flex: 0 0 auto; margin: 0; }
.addresses-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; }
.address-empty { grid-column: 1 / -1; }
.saved-address-card { gap: 14px; }
.saved-address-card h3 { margin: 0; }
.saved-address-card address { color: #55534d; font-style: normal; font-size: 12px; line-height: 1.7; }
.saved-address-card p { margin: 0; font-size: 12px; }
.saved-address-heading { display: flex; align-items: center; justify-content: space-between; gap: 15px; }
.saved-address-heading > span, .saved-address-heading small { font: 500 9px var(--mono); text-transform: uppercase; }
.saved-address-heading small { padding: 5px 8px; background: var(--acid); }
.address-delete { align-self: flex-start; margin-top: 8px; color: #a52c16; }
.address-checkbox { display: flex; align-items: center; gap: 10px; font-size: 11px; cursor: pointer; }
.address-checkbox input { width: 16px; height: 16px; accent-color: var(--ink); }
.address-dialog { width: min(720px, calc(100vw - 32px)); max-height: calc(100vh - 32px); padding: 0; border: 0; background: transparent; color: var(--ink); overflow: auto; }
.address-dialog::backdrop { background: rgba(16,16,15,.7); backdrop-filter: blur(8px); }
.address-dialog .address-form { border: 0; background: var(--paper); }
.address-dialog-heading { display: flex; align-items: flex-start; justify-content: space-between; gap: 24px; }
.address-dialog-heading h3 { margin: 10px 0 0; font-size: clamp(30px, 5vw, 48px); }
.address-dialog-close { width: 42px; height: 42px; flex: 0 0 auto; border: 1px solid var(--ink); background: transparent; color: var(--ink); font: 300 28px/1 var(--body); cursor: pointer; }
.address-dialog-actions { display: flex; justify-content: flex-end; gap: 12px; }
.address-dialog-actions .button { margin: 0; }
.saved-address-picker { margin: 24px 0; }
.checkout-save-address { margin: 25px 0; display: grid; gap: 18px; }
.address-label-field { max-width: 280px; }
.orders-panel { margin-top: 80px; }
.orders-list { display: grid; gap: 22px; }
.order-card { gap: 18px; }
.order-card h3 { margin: 0; }
.order-meta-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.order-meta-grid small { display: block; margin-bottom: 6px; color: var(--gray); font: 500 9px var(--mono); text-transform: uppercase; }
.order-lines { display: grid; gap: 12px; }

.admin-header { position: sticky; z-index: 20; top: 0; background: var(--paper); }
.admin-shell { display: grid; grid-template-columns: 285px minmax(0, 1fr); min-height: calc(100vh - 78px); }
.admin-sidebar { position: sticky; top: 78px; height: calc(100vh - 78px); padding: 50px 28px; background: var(--ink); color: white; }
.admin-sidebar h1 { margin: 0 0 70px; font: 800 34px/.86 var(--display); letter-spacing: -.06em; }
.admin-sidebar nav { display: flex; flex-direction: column; }
.admin-sidebar nav a { padding: 17px 0; display: flex; justify-content: space-between; border-bottom: 1px solid rgba(255,255,255,.2); color: #aaa89f; font-size: 12px; }
.admin-sidebar nav a.active, .admin-sidebar nav a:hover { color: var(--acid); }
.admin-sidebar nav span { font: 500 9px var(--mono); }
.admin-content { padding: clamp(50px, 6vw, 90px); min-width: 0; }
.admin-status { padding: 9px 12px; background: var(--acid); font: 500 9px var(--mono); text-transform: uppercase; }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); border: 1px solid var(--ink); }
.stats-grid-wide { grid-template-columns: repeat(4, 1fr); }
.stats-grid article { min-height: 170px; padding: 22px; display: flex; flex-direction: column; justify-content: space-between; border-right: 1px solid var(--ink); }
.stats-grid article:last-child { border-right: 0; }
.stats-grid-wide article:nth-child(-n+4) { border-bottom: 1px solid var(--ink); }
.stats-grid span { font: 500 9px var(--mono); text-transform: uppercase; }
.stats-grid strong { font: 700 clamp(40px, 5vw, 70px) var(--display); }
.admin-section + .admin-section { padding-top: 110px; }
.admin-summary-grid, .admin-card-grid { margin-top: 28px; display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.admin-card { padding: 28px; display: flex; flex-direction: column; gap: 18px; border: 1px solid var(--ink); background: var(--white); }
.admin-card > span { color: var(--gray); font: 500 9px var(--mono); text-transform: uppercase; }
.admin-card h3 { margin: 0; font: 700 clamp(28px, 3vw, 42px)/.95 var(--display); letter-spacing: -.04em; }
.admin-card p { margin: 0; color: #55534d; font-size: 12px; line-height: 1.7; }
.admin-search input { width: min(320px, 40vw); padding: 12px 0; border: 0; border-bottom: 1px solid var(--ink); background: transparent; outline: 0; }
.admin-table-wrap { overflow-x: auto; border-top: 1px solid var(--ink); }
.admin-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.admin-table th { padding: 14px 12px; color: var(--gray); font: 500 9px var(--mono); text-align: left; text-transform: uppercase; }
.admin-table td { padding: 17px 12px; border-top: 1px solid var(--line); vertical-align: middle; }
.admin-table td:first-child strong, .admin-table td:first-child span { display: block; }
.admin-table td:first-child span { margin-top: 5px; color: var(--gray); font-size: 10px; }
.admin-table select, .admin-table input { width: 100%; min-width: 88px; padding: 8px; border: 1px solid var(--line); background: var(--white); }
.admin-save { padding: 9px 13px; border: 1px solid var(--ink); background: var(--ink); color: white; font: 500 9px var(--mono); text-transform: uppercase; cursor: pointer; }
.admin-save:disabled { opacity: .35; cursor: not-allowed; }
.admin-form { display: grid; gap: 28px; }
.admin-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.admin-form-actions { display: flex; justify-content: flex-start; }
.admin-form .button { cursor: pointer; }
.admin-checkbox { min-height: 54px; display: flex; align-items: center; gap: 10px; padding-top: 25px; font-size: 12px; }
.admin-checkbox input { width: 16px; height: 16px; accent-color: var(--orange); }
.admin-heading-actions, .admin-row-actions { display: flex; align-items: center; gap: 14px; }
.admin-heading-actions .button { min-height: 42px; }
.admin-product-cell { min-width: 250px; display: flex; align-items: center; gap: 12px; }
.admin-product-thumb { width: 52px; height: 52px; flex: 0 0 auto; object-fit: cover; background: #dedbd2; }
.admin-edit-link { white-space: nowrap; font: 500 9px var(--mono); text-decoration: underline; text-transform: uppercase; }

/* Admin analytics */
.analytics-content { padding-top: clamp(42px, 5vw, 72px); }
.analytics-heading { display: flex; align-items: flex-end; justify-content: space-between; gap: 36px; }
.analytics-heading h2 { margin: 0; font: 700 clamp(54px, 7vw, 96px)/.85 var(--display); letter-spacing: -.07em; }
.analytics-range-label { margin: 17px 0 0; color: var(--gray); font: 500 9px var(--mono); text-transform: uppercase; }
.analytics-actions { min-width: min(100%, 560px); display: flex; align-items: flex-end; flex-direction: column; gap: 12px; }
.analytics-presets { display: flex; border: 1px solid var(--ink); }
.analytics-presets button, .analytics-export, .analytics-custom-range button { min-height: 38px; padding: 0 14px; border: 0; border-right: 1px solid var(--ink); background: transparent; font: 500 9px var(--mono); text-transform: uppercase; cursor: pointer; }
.analytics-presets button:last-child { border-right: 0; }
.analytics-presets button.active { background: var(--ink); color: var(--acid); }
.analytics-selects { display: flex; align-items: flex-end; gap: 12px; }
.analytics-selects label, .analytics-custom-range label { display: grid; gap: 6px; color: var(--gray); font: 500 8px var(--mono); text-transform: uppercase; }
.analytics-selects select, .analytics-custom-range input { min-width: 130px; height: 38px; padding: 0 11px; border: 1px solid var(--ink); border-radius: 0; background: var(--white); color: var(--ink); font: 500 10px var(--mono); }
.analytics-export { border: 1px solid var(--ink); background: var(--acid); white-space: nowrap; }
.analytics-export span { margin-left: 10px; }
.analytics-custom-range { display: flex; align-items: flex-end; gap: 10px; }
.analytics-custom-range[hidden] { display: none; }
.analytics-custom-range button { border: 1px solid var(--ink); background: var(--ink); color: white; }
.analytics-tabs { position: sticky; z-index: 10; top: 78px; margin: 44px 0 38px; display: flex; overflow-x: auto; border-bottom: 1px solid var(--ink); background: var(--paper); scrollbar-width: none; }
.analytics-tabs::-webkit-scrollbar { display: none; }
.analytics-tabs button { flex: 0 0 auto; padding: 16px 20px 14px; border: 0; border-bottom: 4px solid transparent; background: transparent; color: var(--gray); font: 500 10px var(--mono); text-transform: uppercase; cursor: pointer; }
.analytics-tabs button:first-child { padding-left: 0; }
.analytics-tabs button.active { border-bottom-color: var(--acid); color: var(--ink); }
.analytics-loading { padding: 18px; border: 1px solid var(--ink); background: var(--acid); font: 500 10px var(--mono); text-transform: uppercase; }
.analytics-loading[hidden] { display: none; }
.analytics-message { margin-bottom: 14px; }
.analytics-panel { display: none; animation: analytics-in .25s ease; }
.analytics-panel.active { display: block; }
@keyframes analytics-in { from { opacity: 0; transform: translateY(5px); } }
.analytics-kpis { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); border: 1px solid var(--ink); }
.analytics-kpis.compact { grid-template-columns: repeat(4, minmax(0, 1fr)); margin-bottom: 26px; }
.analytics-kpis article { min-height: 154px; padding: 20px; display: flex; flex-direction: column; border-right: 1px solid var(--ink); }
.analytics-kpis article:last-child { border-right: 0; }
.analytics-kpis span, .analytics-block-heading span, .analytics-section-intro span { color: var(--gray); font: 500 8px var(--mono); text-transform: uppercase; }
.analytics-kpis strong { margin: auto 0 12px; font: 700 clamp(26px, 3vw, 48px)/.9 var(--display); letter-spacing: -.05em; overflow-wrap: anywhere; }
.analytics-kpis small { color: #66635c; font: 500 9px var(--mono); }
.analytics-primary-grid { margin-top: 26px; display: grid; grid-template-columns: minmax(0, 1.8fr) minmax(280px, .8fr); gap: 22px; }
.analytics-secondary-grid { margin-top: 22px; display: grid; grid-template-columns: minmax(0, 1.5fr) minmax(280px, .8fr); gap: 22px; }
.analytics-block { min-width: 0; padding: 25px; border: 1px solid var(--ink); background: var(--white); }
.analytics-block-heading { min-height: 48px; margin-bottom: 24px; display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; }
.analytics-block-heading h3 { margin: 7px 0 0; font: 700 clamp(23px, 2.3vw, 34px)/.95 var(--display); letter-spacing: -.045em; }
.analytics-block-heading button { border: 0; background: transparent; font: 500 9px var(--mono); text-transform: uppercase; cursor: pointer; }
.chart-legend { display: flex; gap: 13px; color: var(--gray); font: 500 8px var(--mono); text-transform: uppercase; }
.chart-legend span { display: flex; align-items: center; gap: 6px; }
.chart-legend i { width: 17px; height: 3px; background: var(--orange); }
.chart-legend .legend-orders { background: var(--ink); }
.analytics-line-chart { width: 100%; min-height: 270px; display: block; overflow: visible; }
.chart-grid line { stroke: #dedbd2; stroke-width: 1; }
.chart-area { fill: rgba(203,255,0,.17); stroke: none; }
.chart-primary, .chart-secondary { fill: none; stroke: var(--orange); stroke-width: 4; vector-effect: non-scaling-stroke; }
.chart-secondary { stroke: var(--ink); stroke-width: 2; stroke-dasharray: 7 5; }
.chart-labels text { fill: #77736b; font: 8px var(--mono); text-transform: uppercase; }
.analytics-bars { display: grid; gap: 19px; }
.analytics-bar-row > div { margin-bottom: 8px; display: flex; justify-content: space-between; gap: 15px; font-size: 11px; text-transform: capitalize; }
.analytics-bar-row strong { font: 500 10px var(--mono); }
.analytics-bar-row i { height: 7px; display: block; background: #e4e1d9; }
.analytics-bar-row b { height: 100%; display: block; background: var(--ink); }
.analytics-bar-row:first-child b { background: var(--acid); outline: 1px solid var(--ink); }
.analytics-rank-list { margin: 0; padding: 0; list-style: none; }
.analytics-rank-list li { min-height: 64px; display: grid; grid-template-columns: 34px minmax(0, 1fr) auto; align-items: center; gap: 12px; border-top: 1px solid var(--line); }
.analytics-rank-list li > span { font: 500 9px var(--mono); }
.analytics-rank-list strong, .analytics-rank-list small { display: block; }
.analytics-rank-list strong { font-size: 12px; }
.analytics-rank-list small { margin-top: 5px; color: var(--gray); font-size: 9px; }
.analytics-rank-list b { font: 600 12px var(--mono); }
.analytics-insights { background: var(--ink); color: white; }
.analytics-insights .analytics-block-heading span { color: var(--acid); }
.analytics-insights ol { margin: 0; padding: 0; counter-reset: insights; list-style: none; }
.analytics-insights li { position: relative; padding: 18px 0 18px 39px; border-top: 1px solid rgba(255,255,255,.2); font-size: 11px; line-height: 1.6; }
.analytics-insights li::before { position: absolute; left: 0; counter-increment: insights; content: "0" counter(insights); color: var(--acid); font: 500 9px var(--mono); }
.analytics-section-intro { margin-bottom: 32px; display: flex; align-items: flex-end; justify-content: space-between; gap: 30px; }
.analytics-section-intro h3 { margin: 8px 0 0; font: 700 clamp(38px, 5vw, 70px)/.88 var(--display); letter-spacing: -.06em; }
.analytics-section-intro p { width: min(390px, 100%); margin: 0; color: #5e5b55; font-size: 12px; line-height: 1.7; }
.funnel-layout { display: grid; grid-template-columns: minmax(0, 1.6fr) minmax(280px, .7fr); gap: 22px; align-items: start; }
.analytics-funnel { padding: 34px; border: 1px solid var(--ink); background: var(--ink); }
.analytics-funnel article { width: var(--funnel-width); min-width: 220px; margin: 0 auto 10px; padding: 20px 24px; border: 1px solid rgba(255,255,255,.35); background: var(--acid); color: var(--ink); }
.analytics-funnel article:nth-child(even) { background: white; }
.analytics-funnel article:last-child { margin-bottom: 0; background: var(--orange); color: white; }
.analytics-funnel span, .analytics-funnel strong, .analytics-funnel small { display: block; }
.analytics-funnel span, .analytics-funnel small { font: 500 8px var(--mono); text-transform: uppercase; }
.analytics-funnel strong { margin: 9px 0; font: 700 35px var(--display); }
.funnel-insight { padding: 17px 0; display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 5px 15px; border-top: 1px solid var(--line); }
.funnel-insight span { color: var(--ink); font: 500 10px var(--mono); text-transform: none; }
.funnel-insight strong { font: 700 20px var(--display); }
.funnel-insight small { color: var(--gray); font-size: 9px; }
.analytics-table-scroll { overflow-x: auto; }
.analytics-table { width: 100%; border-collapse: collapse; font-size: 11px; }
.analytics-table th { padding: 12px 10px; border-bottom: 1px solid var(--ink); color: var(--gray); font: 500 8px var(--mono); text-align: left; text-transform: uppercase; white-space: nowrap; }
.analytics-table td { padding: 17px 10px; border-bottom: 1px solid var(--line); white-space: nowrap; }
.analytics-table td:first-child strong, .analytics-table td:first-child span { display: block; }
.analytics-table td:first-child span { margin-top: 5px; color: var(--gray); font-size: 9px; }
.stock-mark { min-width: 30px; padding: 5px 7px; display: inline-block; border: 1px solid var(--ink); text-align: center; }
.stock-mark.warning { background: var(--orange); color: white; }
.production-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); border-top: 1px solid var(--ink); border-left: 1px solid var(--ink); }
.production-list > div { min-height: 112px; padding: 16px; display: flex; flex-direction: column; border-right: 1px solid var(--ink); border-bottom: 1px solid var(--ink); }
.production-list span { font-size: 11px; }
.production-list strong { margin: auto 0 6px; font: 700 24px var(--display); }
.production-list small { color: var(--gray); font: 500 8px var(--mono); text-transform: uppercase; }
.status-text { font: 500 9px var(--mono); text-transform: uppercase; }
.status-text.paid { color: #477300; }
.status-text.failed { color: #b6341d; }
.registration-grid { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--ink); border-left: 1px solid var(--ink); }
.registration-grid > div { min-height: 118px; padding: 16px; display: flex; flex-direction: column; border-right: 1px solid var(--ink); border-bottom: 1px solid var(--ink); }
.registration-grid span { color: var(--gray); font: 500 8px var(--mono); text-transform: uppercase; }
.registration-grid strong { margin: auto 0 4px; font: 700 31px var(--display); }
.registration-grid small { font-size: 10px; }
.analytics-empty { min-height: 130px; display: grid; place-items: center; padding: 20px; border: 1px dashed #aaa69d; color: var(--gray); font: 500 9px var(--mono); text-align: center; text-transform: uppercase; }

@media (max-width: 1400px) {
  .analytics-heading { align-items: flex-start; flex-direction: column; }
  .analytics-actions { width: 100%; align-items: flex-start; }
  .analytics-kpis { grid-template-columns: repeat(3, 1fr); }
  .analytics-kpis article { border-bottom: 1px solid var(--ink); }
  .analytics-kpis article:nth-child(3n) { border-right: 0; }
  .analytics-kpis article:nth-last-child(-n+2) { border-bottom: 0; }
  .analytics-primary-grid, .analytics-secondary-grid { grid-template-columns: 1fr; }
}

@media (max-width: 760px) {
  .analytics-sidebar nav { display: grid; grid-template-columns: 1fr 1fr; column-gap: 16px; }
  .analytics-heading h2 { font-size: 58px; }
  .analytics-actions, .analytics-selects, .analytics-custom-range { width: 100%; }
  .analytics-selects { display: grid; grid-template-columns: 1fr 1fr; }
  .analytics-selects label, .analytics-selects select { width: 100%; min-width: 0; }
  .analytics-export { width: 100%; grid-column: 1 / -1; }
  .analytics-custom-range { display: grid; grid-template-columns: 1fr 1fr; }
  .analytics-custom-range label, .analytics-custom-range input { width: 100%; min-width: 0; }
  .analytics-custom-range button { grid-column: 1 / -1; }
  .analytics-tabs { top: 64px; margin-top: 32px; }
  .analytics-kpis, .analytics-kpis.compact { grid-template-columns: 1fr 1fr; }
  .analytics-kpis article, .analytics-kpis article:nth-child(3n) { min-height: 130px; border-right: 1px solid var(--ink); border-bottom: 1px solid var(--ink); }
  .analytics-kpis article:nth-child(even) { border-right: 0; }
  .analytics-kpis article:last-child { grid-column: 1 / -1; border-bottom: 0; }
  .analytics-kpis.compact article:nth-last-child(-n+2) { border-bottom: 0; }
  .analytics-kpis.compact article:last-child { grid-column: auto; }
  .analytics-section-intro { align-items: flex-start; flex-direction: column; }
  .funnel-layout { grid-template-columns: 1fr; }
  .analytics-funnel { padding: 18px; overflow: hidden; }
  .analytics-funnel article { min-width: 170px; padding: 16px; }
  .analytics-line-chart { min-width: 650px; }
  .analytics-chart-block > div:last-child { overflow-x: auto; }
  .production-list { grid-template-columns: 1fr; }
}

/* Visual product editor */
.product-editor-page { background: var(--white); }
.product-editor-header { background: rgba(255,254,249,.94); backdrop-filter: blur(16px); }
.product-editor-toolbar { display: flex; align-items: center; gap: 14px; }
.product-editor-toolbar .button { min-height: 40px; padding-inline: 16px; cursor: pointer; }
.editor-save-draft { background: transparent; border-color: var(--ink); }
.editor-save-state { color: var(--gray); font: 500 9px var(--mono); text-transform: uppercase; }
.product-editor-form { display: block; }
.editor-intro { min-height: 390px; padding: clamp(60px, 8vw, 125px) clamp(22px, 5vw, 78px); display: grid; grid-template-columns: 1fr minmax(280px, 390px); align-items: end; gap: 50px; background: var(--acid); border-bottom: 1px solid var(--ink); }
.editor-intro h1 { margin: 0; font: 800 clamp(62px, 9vw, 140px)/.82 var(--display); letter-spacing: -.075em; }
.editor-intro-note { padding-top: 18px; border-top: 1px solid var(--ink); }
.editor-intro-note span, .editor-section-label, .editor-detail-grid article > span { font: 500 9px var(--mono); letter-spacing: .08em; text-transform: uppercase; }
.editor-intro-note p { margin: 18px 0 0; font-size: 13px; line-height: 1.75; }
.editor-product-stage { display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(390px, .75fr); border-bottom: 1px solid var(--ink); }
.editor-gallery-panel { min-width: 0; padding: clamp(25px, 4vw, 60px); background: var(--paper); border-right: 1px solid var(--ink); }
.editor-section-label { margin-bottom: 20px; display: flex; justify-content: space-between; gap: 20px; color: var(--gray); }
.editor-section-label button { padding: 0; border: 0; background: transparent; font: inherit; text-transform: uppercase; text-decoration: underline; cursor: pointer; }
.editor-media-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.editor-media-empty { grid-column: 1 / -1; min-height: 520px; padding: 45px; display: flex; flex-direction: column; justify-content: flex-end; background: #dedbd2; }
.editor-media-empty span { font: 500 9px var(--mono); text-transform: uppercase; }
.editor-media-empty strong { max-width: 470px; margin-top: 14px; font: 700 clamp(36px, 5vw, 68px)/.92 var(--display); letter-spacing: -.05em; }
.editor-media-empty p { max-width: 440px; margin: 20px 0 0; color: #55534d; line-height: 1.7; }
.editor-media-card { min-width: 0; background: var(--white); border: 1px solid var(--line); }
.editor-media-preview { position: relative; aspect-ratio: .84; overflow: hidden; background: #dedbd2; }
.editor-media-preview img, .editor-media-preview video { width: 100%; height: 100%; object-fit: cover; }
.media-cover-label { position: absolute; top: 10px; left: 10px; padding: 7px 9px; background: var(--acid); font: 500 8px var(--mono); text-transform: uppercase; }
.editor-media-controls { padding: 12px; display: grid; gap: 10px; }
.editor-media-controls > span { color: var(--gray); font: 500 8px var(--mono); text-transform: uppercase; }
.editor-media-controls input { width: 100%; padding: 9px; border: 1px solid var(--line); background: transparent; font-size: 11px; }
.editor-media-controls > div { display: flex; justify-content: space-between; gap: 12px; }
.editor-media-controls button { padding: 0; border: 0; background: none; font: 500 8px var(--mono); text-decoration: underline; text-transform: uppercase; cursor: pointer; }
.media-dropzone { min-height: 120px; margin-top: 14px; padding: 28px; display: flex; flex-direction: column; justify-content: center; border: 1px dashed var(--ink); background: rgba(255,255,255,.4); cursor: pointer; transition: background .2s; }
.media-dropzone:hover { background: var(--acid); }
.media-dropzone input { position: absolute; opacity: 0; pointer-events: none; }
.media-dropzone strong { font: 700 22px var(--display); }
.media-dropzone span { margin-top: 8px; color: var(--gray); font-size: 11px; }
.editor-buy-panel { position: sticky; top: 78px; align-self: start; min-width: 0; padding: clamp(38px, 5vw, 74px); }
.editor-kicker { margin: 0 0 26px; font: 500 9px var(--mono); text-transform: uppercase; }
.editor-live-field, .editor-buy-panel .field { display: grid; gap: 8px; }
.editor-live-field > span, .editor-buy-panel .field > span, .editor-seo-section .field > span { color: var(--gray); font: 500 8px var(--mono); letter-spacing: .08em; text-transform: uppercase; }
.editor-live-field input, .editor-live-field textarea, .editor-buy-panel .field input, .editor-buy-panel .field select { width: 100%; padding: 10px 0; border: 0; border-bottom: 1px solid var(--line); outline: 0; background: transparent; resize: vertical; }
.editor-live-field:focus-within input, .editor-live-field:focus-within textarea { border-color: var(--orange); }
.editor-title-field textarea { overflow: hidden; font: 700 clamp(42px, 5vw, 76px)/.9 var(--display); letter-spacing: -.055em; resize: none; }
.editor-price-row, .editor-option-grid { margin-top: 25px; display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.editor-price-row input { font: 600 20px var(--mono); }
.editor-description-field { margin-top: 28px; }
.editor-description-field textarea { color: #55534d; font-size: 14px; line-height: 1.75; }
.editor-commerce-preview { margin-top: 34px; display: grid; grid-template-columns: 112px 1fr; gap: 10px; }
.quantity-preview { min-height: 52px; display: flex; justify-content: space-around; align-items: center; border: 1px solid var(--ink); }
.quantity-preview button { border: 0; background: transparent; }
.editor-add-preview { justify-content: space-between; pointer-events: none; }
.editor-reassurance { margin: 15px 0 0; color: var(--gray); font: 500 9px var(--mono); text-transform: uppercase; }
.editor-settings-block { margin-top: 48px; padding-top: 24px; border-top: 1px solid var(--ink); }
.editor-settings-block .editor-section-label { margin-bottom: 5px; }
.editor-story-section { padding: clamp(70px, 9vw, 140px) clamp(22px, 6vw, 95px); display: grid; grid-template-columns: .8fr 1.2fr; gap: clamp(50px, 9vw, 150px); background: var(--ink); color: var(--white); }
.editor-story-heading h2, .editor-seo-section h2 { margin: 0; font: 700 clamp(48px, 7vw, 105px)/.86 var(--display); letter-spacing: -.065em; }
.editor-story-fields { display: grid; gap: 48px; }
.editor-story-fields .editor-live-field > span { color: #aaa89f; }
.editor-story-fields textarea { color: white; border-color: rgba(255,255,255,.3); font-size: 16px; line-height: 1.8; }
.feature-editor .editor-section-label { color: #aaa89f; }
.feature-row { display: grid; grid-template-columns: 1fr auto; border-top: 1px solid rgba(255,255,255,.25); }
.feature-row:last-child { border-bottom: 1px solid rgba(255,255,255,.25); }
.feature-row input { min-width: 0; padding: 18px 0; border: 0; outline: 0; background: transparent; color: white; }
.feature-row button { padding: 0 0 0 20px; border: 0; background: transparent; color: #aaa89f; font: 500 8px var(--mono); text-transform: uppercase; cursor: pointer; }
.editor-detail-grid { display: grid; grid-template-columns: repeat(3, 1fr); }
.editor-detail-grid article { min-height: 330px; padding: clamp(28px, 4vw, 58px); border-right: 1px solid var(--ink); }
.editor-detail-grid article:last-child { border-right: 0; }
.editor-detail-grid textarea { width: 100%; margin-top: 45px; padding: 0; border: 0; outline: 0; background: transparent; font-size: 14px; line-height: 1.8; resize: vertical; }
.editor-seo-section { padding: clamp(70px, 9vw, 130px) clamp(22px, 6vw, 95px); display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(45px, 8vw, 130px); background: var(--paper); border-top: 1px solid var(--ink); }
.editor-seo-section h2 { max-width: 600px; font-size: clamp(48px, 6vw, 88px); }
.editor-seo-section input, .editor-seo-section textarea { width: 100%; padding: 13px 0; border: 0; border-bottom: 1px solid var(--ink); background: transparent; resize: vertical; }
.related-products { margin: 0; padding: 25px 0 0; border: 0; border-top: 1px solid var(--ink); }
.related-products legend { padding: 0 0 18px; font: 500 9px var(--mono); text-transform: uppercase; }
.related-products > div { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.related-products label { padding: 13px; display: grid; grid-template-columns: auto 1fr; gap: 2px 10px; border: 1px solid var(--line); background: var(--white); }
.related-products input { grid-row: 1 / 3; width: 15px; align-self: center; }
.related-products small { color: var(--gray); }
.editor-bottom-bar { position: sticky; z-index: 10; bottom: 0; min-height: 78px; padding: 12px clamp(18px, 3vw, 52px); display: flex; align-items: center; justify-content: space-between; gap: 25px; background: rgba(255,254,249,.95); border-top: 1px solid var(--ink); backdrop-filter: blur(16px); }
.editor-bottom-bar > div { display: flex; align-items: center; gap: 12px; }
.editor-bottom-bar .button { min-height: 46px; cursor: pointer; }

/* Product detail page */
.product-loading { min-height: 70vh; display: grid; place-items: center; font: 500 10px var(--mono); text-transform: uppercase; }
.pdp-breadcrumb { padding: 18px clamp(18px, 4vw, 64px); display: flex; gap: 10px; border-bottom: 1px solid var(--line); color: var(--gray); font: 500 9px var(--mono); text-transform: uppercase; }
.pdp-stage { display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(390px, .75fr); border-bottom: 1px solid var(--ink); }
.pdp-gallery { padding: clamp(16px, 2vw, 30px); display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; background: var(--paper); border-right: 1px solid var(--ink); }
.pdp-media-item { position: relative; min-width: 0; margin: 0; overflow: hidden; background: #dedbd2; }
.pdp-media-item:first-child:last-child { grid-column: 1 / -1; }
.pdp-media-item img, .pdp-media-item video { width: 100%; height: 100%; aspect-ratio: .82; object-fit: cover; }
.pdp-media-primary { grid-column: 1 / -1; }
.pdp-media-primary img, .pdp-media-primary video { aspect-ratio: 1.18; }
.pdp-media-item figcaption { position: absolute; right: 10px; bottom: 10px; left: 10px; padding: 8px; background: rgba(255,254,249,.88); font: 500 8px var(--mono); }
.pdp-buy-panel { position: sticky; top: 78px; align-self: start; padding: clamp(45px, 5vw, 82px); }
.pdp-kicker, .pdp-badge { font: 500 9px var(--mono); letter-spacing: .08em; text-transform: uppercase; }
.pdp-badge { display: inline-block; margin-bottom: 18px; padding: 8px 10px; background: var(--acid); }
.pdp-buy-panel h1 { margin: 0; font: 700 clamp(50px, 6vw, 92px)/.86 var(--display); letter-spacing: -.065em; }
.pdp-price { margin: 28px 0 0; font: 500 18px var(--mono); }
.pdp-description { margin: 28px 0 0; color: #55534d; font-size: 14px; line-height: 1.75; }
.pdp-options { margin-top: 34px; display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.pdp-options > div { padding: 18px 0; display: grid; gap: 8px; }
.pdp-options span { color: var(--gray); font: 500 8px var(--mono); text-transform: uppercase; }
.pdp-options strong { font-size: 12px; }
.pdp-buy-row { margin-top: 25px; display: grid; grid-template-columns: 90px 1fr; gap: 10px; }
.pdp-buy-row select { width: 100%; height: 100%; padding: 0 15px; border: 1px solid var(--ink); background: transparent; }
.pdp-buy-row .button { width: 100%; justify-content: space-between; cursor: pointer; }
.pdp-buy-row .button:disabled { background: var(--gray); border-color: var(--gray); cursor: not-allowed; }
.pdp-stock { margin: 15px 0 0; color: var(--gray); font: 500 9px var(--mono); text-transform: uppercase; }
.pdp-promises { margin-top: 35px; display: grid; }
.pdp-promises span { padding: 14px 0; border-top: 1px solid var(--line); font-size: 11px; }
.pdp-promises span:last-child { border-bottom: 1px solid var(--line); }
.pdp-story { padding: clamp(85px, 12vw, 190px) clamp(22px, 7vw, 110px); background: var(--acid); }
.pdp-story h2 { max-width: 1200px; margin: 0; font: 700 clamp(46px, 7vw, 108px)/.92 var(--display); letter-spacing: -.055em; }
.pdp-features { padding: clamp(75px, 9vw, 135px) clamp(22px, 7vw, 110px); background: var(--ink); color: white; }
.pdp-features ol { margin: 50px 0 0; padding: 0; list-style: none; }
.pdp-features li { min-height: 110px; padding: 24px 0; display: grid; grid-template-columns: 90px 1fr; align-items: center; border-top: 1px solid rgba(255,255,255,.25); }
.pdp-features li:last-child { border-bottom: 1px solid rgba(255,255,255,.25); }
.pdp-features li span { color: var(--acid); font: 500 9px var(--mono); }
.pdp-features li p { margin: 0; font: 600 clamp(24px, 3vw, 42px) var(--display); }
.pdp-detail-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.pdp-detail-grid article { min-height: 280px; padding: clamp(28px, 4vw, 58px); border-right: 1px solid var(--ink); }
.pdp-detail-grid article:last-child { border-right: 0; }
.pdp-detail-grid span { font: 500 9px var(--mono); text-transform: uppercase; }
.pdp-detail-grid p { margin: 60px 0 0; color: #55534d; font-size: 13px; line-height: 1.75; }
.pdp-related { border-top: 1px solid var(--ink); }
.product-not-found { min-height: 75vh; padding: clamp(70px, 10vw, 150px) clamp(22px, 6vw, 95px); }
.product-not-found h1 { margin: 0 0 30px; font: 800 clamp(70px, 12vw, 170px)/.8 var(--display); letter-spacing: -.075em; }

/* Compact desktop and landscape tablets */
@media (max-width: 1200px) {
  .site-header { padding-inline: 24px; }
  .desktop-nav { gap: 20px; }
  .hero { grid-template-columns: minmax(500px, 47%) 1fr; }
  .hero h1 { font-size: clamp(48px, 4.2vw, 58px); }
  .hero-copy { padding-inline: clamp(28px, 4vw, 48px); }
  .category-card { min-height: 330px; }
  .showcase-copy { padding: clamp(48px, 5vw, 72px); }
  .catalog-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* Tablet */
@media (max-width: 1024px) {
  .section-shell { padding-block: clamp(72px, 9vw, 105px); }
  .product-grid { grid-template-columns: repeat(2, 1fr); row-gap: 45px; }
  .category-grid { grid-template-columns: repeat(2, 1fr); }
  .category-card { min-height: 300px; }
  .category-card:last-child { grid-column: 1 / -1; min-height: 250px; }
  .showcase {
    grid-template-columns: 1fr;
    overflow: visible;
  }
  .showcase-media { min-height: min(68vw, 650px); }
  .showcase-media > img {
    transform: none;
    object-position: 48% center;
  }
  .showcase-copy {
    position: relative;
    top: auto;
    right: auto;
    width: auto;
    padding: clamp(48px, 5vw, 72px);
    box-shadow: none;
    transform: none;
  }
  .showcase:hover .showcase-copy,
  .showcase:focus-within .showcase-copy,
  .showcase:hover .showcase-media > img,
  .showcase:focus-within .showcase-media > img { transform: none; }
  .hotspot-card {
    left: 20px;
    bottom: 20px;
    width: min(250px, calc(100% - 40px));
  }
  .process-grid { grid-template-columns: repeat(2, 1fr); }
  .process-grid li:nth-child(2) { border-right: 0; }
  .process-grid li:nth-child(n+3) { border-top: 1px solid rgba(255,255,255,.25); }
  .journal-grid { grid-template-columns: 1.35fr 1fr; }
  .journal-card:last-child { grid-column: 1 / -1; }
  .journal-card:last-child .journal-image { aspect-ratio: 2.1; }
  .newsletter { grid-template-columns: 1fr; }
  .shop-layout { grid-template-columns: 210px minmax(0, 1fr); gap: 35px; }
  .cart-layout { grid-template-columns: 1fr 330px; gap: 45px; }
}

/* Portrait tablets and mobile navigation */
@media (max-width: 900px) {
  html { scroll-padding-top: 72px; }
  .announcement {
    min-height: 0;
    padding: 8px max(14px, env(safe-area-inset-left)) 8px max(14px, env(safe-area-inset-right));
    justify-content: space-between;
    gap: 16px;
    font-size: 9px;
    letter-spacing: .06em;
  }
  .announcement p {
    flex: 1;
    min-width: 0;
  }
  .announcement a {
    flex-shrink: 0;
    white-space: nowrap;
  }
  .site-header {
    height: 72px;
    padding-left: max(18px, env(safe-area-inset-left));
    padding-right: max(18px, env(safe-area-inset-right));
  }
  .site-header.scrolled { height: 64px; }
  .desktop-nav { display: none; }
  .menu-toggle { display: block; }
  .cart-button { min-height: 40px; padding-inline: 12px; }
  .search-panel {
    top: 72px;
    padding-left: max(20px, env(safe-area-inset-left));
    padding-right: max(20px, env(safe-area-inset-right));
  }
  .site-header.scrolled + .search-panel { top: 64px; }
  .mobile-menu {
    position: fixed;
    z-index: 39;
    inset: 72px 0 0;
    padding-top: clamp(38px, 7vw, 64px);
    padding-bottom: max(28px, env(safe-area-inset-bottom));
    padding-left: max(24px, env(safe-area-inset-left));
    padding-right: max(24px, env(safe-area-inset-right));
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    background: var(--acid);
    transform: translateX(100%);
    transition: transform .4s cubic-bezier(.7,0,.2,1);
  }
  .site-header.scrolled ~ .mobile-menu { top: 64px; }
  .mobile-menu.open { transform: translateX(0); }
  .mobile-menu a:not(.mobile-email) { padding: clamp(15px, 3vh, 24px) 0; display: flex; justify-content: space-between; border-bottom: 1px solid rgba(0,0,0,.3); font: 700 clamp(36px, 7vw, 60px)/1 var(--display); letter-spacing: -.04em; }
  .mobile-menu a span { font: 400 9px var(--mono); }
  .mobile-email { margin-top: auto; font: 400 11px var(--mono); }
  .mobile-account { margin-top: 20px; }

  .hero { min-height: auto; display: flex; flex-direction: column; }
  .hero-copy { min-height: auto; padding: clamp(72px, 12vw, 110px) clamp(22px, 6vw, 54px) clamp(58px, 9vw, 82px); }
  .hero h1 { max-width: 760px; font-size: clamp(54px, 9vw, 76px); }
  .hero-intro { max-width: 620px; }
  .hero-media { min-height: clamp(520px, 82vw, 760px); }
  .hero-media > img { object-position: 60% center; }
  .rotating-seal { left: auto; right: clamp(18px, 5vw, 44px); bottom: calc(clamp(520px, 82vw, 760px) - 44px); width: 96px; height: 96px; }
  .custom-feature { min-height: clamp(660px, 90vw, 820px); }
  .custom-content { padding-inline: clamp(24px, 7vw, 70px); }
  .custom-content h2 { font-size: clamp(62px, 11vw, 100px); }
  .site-footer { grid-template-columns: 1fr; gap: 55px; }
  .page-hero-grid, .story-grid, .contact-layout { grid-template-columns: 1fr; }
  .page-hero h1 { font-size: clamp(64px, 14vw, 120px); }
  .shop-layout { grid-template-columns: 1fr; }
  .filters { position: static; display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
  .filter-heading { grid-column: 1 / -1; }
  .filter-group { padding: 15px 0; }
  .cart-layout { grid-template-columns: 1fr; }
  .cart-summary { position: static; }
  .story-grid.reverse .story-media { order: 0; }
  .story-media { min-height: min(85vw, 650px); }
  .principle-grid { grid-template-columns: 1fr; }
  .principle { min-height: 220px; padding: 24px 0; border-right: 0; }
  .principle:not(:first-child) { padding-left: 0; }
  .principle h3 { margin-top: 55px; }
  .auth-shell { grid-template-columns: 1fr; }
  .auth-art { min-height: 560px; }
  .dashboard-shell { grid-template-columns: 1fr; }
  .dashboard-sidebar { position: relative; height: auto; min-height: 450px; }
  .settings-grid { grid-template-columns: 1fr; }
  .admin-shell { grid-template-columns: 1fr; }
  .admin-sidebar { position: relative; top: 0; height: auto; }
  .admin-sidebar h1 { margin-bottom: 35px; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .stats-grid article:nth-child(2) { border-right: 0; }
  .stats-grid article:nth-child(n+3) { border-top: 1px solid var(--ink); }
  .stats-grid-wide article:nth-child(-n+4) { border-bottom: 0; }
  .admin-summary-grid, .admin-card-grid, .admin-form-grid { grid-template-columns: 1fr; }
  .product-editor-header { position: relative; }
  .product-editor-toolbar .text-link, .product-editor-toolbar .editor-save-state { display: none; }
  .editor-product-stage, .editor-story-section, .editor-seo-section { grid-template-columns: 1fr; }
  .editor-gallery-panel { border-right: 0; border-bottom: 1px solid var(--ink); }
  .editor-buy-panel { position: relative; top: 0; }
  .editor-detail-grid { grid-template-columns: 1fr; }
  .editor-detail-grid article { min-height: 240px; border-right: 0; border-bottom: 1px solid var(--ink); }
  .editor-detail-grid article:last-child { border-bottom: 0; }
  .pdp-stage { grid-template-columns: 1fr; }
  .pdp-gallery { border-right: 0; border-bottom: 1px solid var(--ink); }
  .pdp-buy-panel { position: relative; top: 0; }
  .pdp-detail-grid { grid-template-columns: repeat(2, 1fr); }
  .pdp-detail-grid article:nth-child(2) { border-right: 0; }
  .pdp-detail-grid article:nth-child(-n+2) { border-bottom: 1px solid var(--ink); }
}

/* Phones */
@media (max-width: 600px) {
  .editor-intro { min-height: 440px; grid-template-columns: 1fr; align-items: start; }
  .editor-intro h1 { font-size: clamp(54px, 17vw, 78px); }
  .editor-media-grid, .editor-option-grid, .editor-price-row, .related-products > div { grid-template-columns: 1fr; }
  .editor-media-empty { min-height: 390px; padding: 25px; }
  .editor-buy-panel { padding: 42px 18px; }
  .editor-title-field textarea { font-size: 44px; }
  .editor-commerce-preview { grid-template-columns: 1fr; }
  .quantity-preview { display: none; }
  .editor-story-section, .editor-seo-section { padding-inline: 18px; }
  .editor-bottom-bar { align-items: stretch; flex-direction: column; }
  .editor-bottom-bar > div { width: 100%; }
  .editor-bottom-bar .text-link { display: none; }
  .editor-bottom-bar .button { flex: 1; padding-inline: 10px; }
  .product-editor-toolbar [data-save-draft] { display: none; }
  .pdp-gallery { grid-template-columns: 1fr; padding: 10px; }
  .pdp-media-primary { grid-column: auto; }
  .pdp-media-primary img, .pdp-media-primary video, .pdp-media-item img, .pdp-media-item video { aspect-ratio: .82; }
  .pdp-buy-panel { padding: 45px 18px; }
  .pdp-buy-panel h1 { font-size: 52px; }
  .pdp-buy-row { grid-template-columns: 1fr; }
  .pdp-buy-row label { display: none; }
  .pdp-detail-grid { grid-template-columns: 1fr; }
  .pdp-detail-grid article { min-height: 220px; border-right: 0; border-bottom: 1px solid var(--ink); }
  .pdp-features li { grid-template-columns: 50px 1fr; }
  .announcement {
    padding-inline: max(12px, env(safe-area-inset-left)) max(12px, env(safe-area-inset-right));
    justify-content: center;
    text-align: center;
  }
  .announcement a { display: none; }
  .site-header {
    height: 64px;
    padding-left: max(12px, env(safe-area-inset-left));
    padding-right: max(12px, env(safe-area-inset-right));
  }
  .logo { font-size: 21px; }
  .site-header .logo,
  .auth-header .logo,
  .account-header .logo,
  .admin-header .logo { max-width: 148px; }
  .site-header .logo-mark,
  .auth-header .logo-mark,
  .account-header .logo-mark,
  .admin-header .logo-mark {
    max-width: 148px;
    max-height: 30px;
  }
  .footer-logo,
  .footer-logo {
    width: 170px;
  }
  .footer-logo-mark {
    width: 170px;
    max-width: 100%;
  }
  .search-panel { top: 64px; padding-block: 22px; }
  .search-field { gap: 10px; }
  .search-field input { font-size: 19px; }
  .mobile-menu {
    inset-block-start: 64px;
    padding-left: max(18px, env(safe-area-inset-left));
    padding-right: max(18px, env(safe-area-inset-right));
  }
  .mobile-menu a:not(.mobile-email) { font-size: clamp(32px, 11vw, 48px); }
  .header-actions { gap: 0; }
  .brand-cluster { gap: 0; }
  .account-button { display: none; }
  .search-toggle { display: none; }
  .cart-button { min-height: 38px; padding-inline: 8px; font-size: 9px; }
  .hero-copy { padding: 66px 18px 52px; }
  .hero h1 { font-size: clamp(35px, 9.1vw, 48px); overflow-wrap: normal; }
  .hero-intro { margin-top: 26px; font-size: 15px; }
  .hero-actions { align-items: flex-start; flex-direction: column; gap: 20px; }
  .hero-actions .button { width: 100%; justify-content: space-between; }
  .hero-media {
    min-height: auto;
    aspect-ratio: 4 / 5;
  }
  .hero-media > img { object-position: 68% 32%; }
  .rotating-seal { display: none; }
  .floating-product { right: 12px; bottom: 12px; width: min(148px, calc(100vw - 40px)); padding: 12px; }
  .section-shell { padding-inline: 16px; }
  .section-heading { align-items: flex-start; flex-direction: column; margin-bottom: 30px; }
  .section-heading h2 { font-size: clamp(38px, 12vw, 50px); }
  .product-tabs { width: 100%; gap: 24px; }
  .product-grid, .product-grid#new {
    display: none;
    width: 100%;
    max-width: 100%;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px 12px;
    overflow: visible;
    padding: 0;
    scroll-snap-type: none;
    scrollbar-width: auto;
  }
  .product-grid::-webkit-scrollbar { display: initial; }
  .product-grid#new { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .product-grid.active { display: grid; }
  .product-card { scroll-snap-align: none; }
  .category-grid { grid-template-columns: 1fr; }
  .category-card:last-child { grid-column: auto; }
  .category-card { min-height: 270px; }
  .custom-feature { min-height: 730px; align-items: flex-end; }
  .custom-feature > img { object-position: 62% center; }
  .custom-overlay { background: linear-gradient(0deg, rgba(5,5,5,.92) 0%, rgba(5,5,5,.2) 80%); }
  .custom-content {
    width: 100%;
    min-width: 0;
    padding: 50px 20px;
  }
  .custom-content h2 {
    max-width: 100%;
    font-size: clamp(38px, 10.5vw, 52px);
    line-height: .92;
    letter-spacing: -.045em;
    overflow-wrap: anywhere;
  }
  .custom-content > p:not(.eyebrow) {
    max-width: 100%;
    margin-block: 24px;
    font-size: 14px;
    overflow-wrap: anywhere;
  }
  .custom-email { display: none; }
  .showcase {
    grid-template-columns: 1fr;
    padding-inline: 0;
  }
  .showcase-media { min-height: min(112vw, 520px); }
  .showcase-copy {
    width: 100%;
    min-width: 0;
    padding: 52px 20px;
  }
  .showcase-copy h2 {
    max-width: 100%;
    font-size: clamp(36px, 10.5vw, 50px);
    line-height: .92;
    letter-spacing: -.045em;
    overflow-wrap: anywhere;
  }
  .showcase-copy > p:not(.eyebrow) {
    max-width: 100%;
    overflow-wrap: anywhere;
  }
  .showcase-copy .button {
    width: 100%;
    justify-content: space-between;
  }
  .material-note { margin-top: 45px; }
  .material-note p { max-width: 100%; }
  .hotspot-one { top: 31%; left: 58%; }
  .hotspot-two { top: 57%; left: 22%; }
  .hotspot-card {
    left: 12px;
    right: 12px;
    bottom: 12px;
    width: auto;
    padding: 14px 14px 13px;
  }
  .process .section-heading { margin-bottom: 40px; }
  .process-grid { grid-template-columns: 1fr; }
  .process-grid li, .process-grid li:not(:first-child) { min-height: 210px; padding: 22px 0; border-right: 0; border-top: 1px solid rgba(255,255,255,.25); }
  .process-grid h3 { margin-top: 55px; }
  .journal-grid { grid-template-columns: 1fr; gap: 50px; }
  .journal-card:last-child { grid-column: auto; }
  .journal-card:last-child .journal-image,
  .journal-card:not(.journal-feature) .journal-image { aspect-ratio: 1.15; }
  .newsletter {
    width: 100%;
    max-width: 100%;
    overflow-x: clip;
    padding: 70px 20px 85px;
    gap: 40px;
  }
  .newsletter h2 {
    max-width: 100%;
    font-size: clamp(36px, 10.5vw, 50px);
    line-height: .92;
    letter-spacing: -.045em;
    overflow-wrap: anywhere;
  }
  .newsletter-form button { min-width: 48px; }
  .footer-links { grid-template-columns: repeat(2, 1fr); row-gap: 40px; }
  .footer-bottom {
    align-items: flex-start;
    flex-direction: column;
    gap: 12px;
    overflow-x: clip;
  }
  .footer-bottom div {
    width: 100%;
    flex-wrap: wrap;
    gap: 10px 18px;
  }
  .toast {
    right: max(12px, env(safe-area-inset-right));
    bottom: max(12px, env(safe-area-inset-bottom));
    left: max(12px, env(safe-area-inset-left));
    text-align: center;
  }
  .page-hero { padding-top: 65px; }
  .page-hero h1 { font-size: clamp(35px, 9.5vw, 54px); }
  .page-band span:last-child { display: none; }
  .filters { display: block; }
  .catalog-grid { grid-template-columns: 1fr; row-gap: 45px; }
  .shop-tools { align-items: flex-start; flex-direction: column; padding-bottom: 15px; }
  .cart-item { grid-template-columns: 90px 1fr; align-items: start; }
  .cart-item-price { grid-column: 2; height: auto; align-items: flex-start; gap: 12px; }
  .form-grid { grid-template-columns: 1fr; }
  .field-full { grid-column: auto; }
  .auth-header, .account-header, .admin-header { min-height: 64px; }
  .auth-art { min-height: 470px; }
  .auth-art-copy h1 { font-size: clamp(34px, 9vw, 44px); }
  .auth-panel { padding: 55px 20px 75px; }
  .account-header nav { gap: 13px; }
  .account-header nav > a:not(.admin-only) { display: none; }
  .dashboard-sidebar h1 { font-size: clamp(52px, 17vw, 75px); }
  .dashboard-sidebar h1 span { font-size: clamp(34px, 11vw, 54px); }
  .account-meta { position: relative; right: auto; bottom: auto; left: auto; margin-top: 80px; }
  .dashboard-heading, .admin-section-heading { align-items: flex-start; flex-direction: column; }
  .settings-card { padding: 22px 18px; }
  .address-book-heading { align-items: stretch; flex-direction: column; }
  .address-book-heading .button { width: 100%; text-align: center; }
  .addresses-list { grid-template-columns: 1fr; }
  .address-dialog { width: calc(100vw - 20px); max-height: calc(100vh - 20px); }
  .address-dialog-actions { flex-direction: column-reverse; }
  .address-dialog-actions .button { width: 100%; text-align: center; }
  .order-meta-grid { grid-template-columns: 1fr; }
  .admin-header > div { gap: 12px; }
  .admin-header > div > span { display: none; }
  .admin-content { padding: 55px 16px; }
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .stats-grid article { min-height: 135px; }
  .admin-search input { width: 100%; }
}

/* Very small phones */
@media (max-width: 380px) {
  .showcase-media { min-height: 430px; }
  .hotspot { width: 40px; height: 40px; font-size: 19px; }
  .hotspot-card strong { font-size: 18px; }
  .product-grid,
  .product-grid#new { grid-template-columns: 1fr; }
  .search-toggle { display: none; }
  .hero h1 { font-size: clamp(34px, 9.5vw, 40px); }
  .hero-media { aspect-ratio: 10 / 13; }
  .floating-product { right: 12px; bottom: 12px; }
  .button { min-height: 48px; padding-inline: 16px; }
  .footer-links { grid-template-columns: 1fr; }
}

/* Short landscape phones */
@media (max-height: 520px) and (orientation: landscape) and (max-width: 900px) {
  .mobile-menu { padding-top: 18px; }
  .mobile-menu a:not(.mobile-email) { padding: 9px 0; font-size: 30px; }
  .mobile-email { margin-top: 20px; }
  .hero { display: grid; grid-template-columns: 1fr 1fr; }
  .hero-copy { min-height: calc(100vh - 64px); padding: 38px 24px; }
  .hero h1 { font-size: clamp(43px, 7vw, 66px); }
  .hero-intro { margin-top: 18px; font-size: 13px; }
  .hero-actions { margin-top: 22px; }
  .hero-media { min-height: calc(100vh - 64px); }
  .rotating-seal { display: none; }
}

/* Apply hover-only effects only where hover input exists. */
@media (hover: none) {
  .hero-media:hover > img,
  .product-card:hover .product-image img,
  .journal-image:hover img { transform: none; }
  .category-card::before { display: none; }
  .quick-add:hover { padding-inline: 2px; background: transparent; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
