/* ============================================
   MAGSI — Leave no trace behind
   Responsive: mobile → tablet → desktop w/ side-nav
   ============================================ */

/* Thermal — accent display font (used in banner + footer) */
@font-face {
  font-family: "Thermal";
  src: url("Assets/Thermal-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root {
  --black: #000000;
  --white: #ffffff;
  --gray: #747474;
  --light-gray: #cacaca;
  --off-white: #f2f2f2;
  --off-white-gray: #e6e6e6;
  --border: rgba(255, 255, 255, 0.4);

  --banner-h: 40px;
  --nav-h: 60px;
  --side-pad: 20px;
  --content-max: 1440px;
  --desktop-sidebar: 0px; /* overridden on desktop */

  --font-sans: "Helvetica Neue", "Helvetica Now", Helvetica, Arial, sans-serif;
  --font-thermal: "Thermal", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --ease: cubic-bezier(0.2, 0.8, 0.2, 1);
}

* { box-sizing: border-box; }

html {
  -webkit-text-size-adjust: 100%;
  font-family: var(--font-sans);
  background: var(--white);
  color: var(--black);
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 10px;
  line-height: 1.1;
  letter-spacing: -0.2px;
  color: var(--black);
  background: var(--white);
  text-transform: uppercase;
  padding-left: var(--desktop-sidebar);
  transition: padding-left 300ms var(--ease);
}

img, svg { max-width: 100%; display: block; }

/* Magsi wordmark — the SVG ships with preserveAspectRatio="none",
   which lets the browser stretch it. Lock every instance to the
   correct 353:77 viewBox aspect so it never distorts. */
img[src$="logo-magsi.svg"] {
  aspect-ratio: 353 / 77;
  object-fit: contain;
}

a { color: inherit; text-decoration: none; }

button {
  font: inherit;
  color: inherit;
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 0;
}

/* ============================================
   Page shell (full-width, responsive)
   ============================================ */

.page {
  width: 100%;
  background: var(--white);
  position: relative;
  overflow-x: clip;
}

/* content wrapper — used inside full-bleed sections */
.wrap {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 0 var(--side-pad);
}

/* ============================================
   Promo banner
   ============================================ */

.banner {
  position: sticky;
  top: 0;
  z-index: 40;
  height: var(--banner-h);
  background: var(--black);
  color: var(--white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  letter-spacing: 0;
  overflow: hidden;
  white-space: nowrap;
}

.banner__scroller {
  display: inline-flex;
  gap: 3em;
  padding-left: 1em;
  animation: banner-scroll 40s linear infinite;
  font-family: var(--font-thermal);
  letter-spacing: 0.04em;
}

.banner__scroller > span { flex-shrink: 0; }

@keyframes banner-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ============================================
   Top navigation (mobile + tablet)
   On desktop, hidden in favor of left sidebar
   ============================================ */

.nav {
  position: sticky;
  top: var(--banner-h);
  z-index: 30;
  height: var(--nav-h);
  background: var(--white);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--side-pad);
  border-bottom: 0.5px solid rgba(0, 0, 0, 0.06);
  transition: transform 300ms var(--ease);
  will-change: transform;
}

.nav.is-hidden {
  transform: translateY(-100%);
}

.nav--hero {
  position: absolute;
  top: var(--banner-h);
  left: 0;
  right: 0;
  background: transparent;
  border: 0;
  mix-blend-mode: difference;
  color: var(--white);
}

.nav__dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: currentColor;
  display: inline-block;
  cursor: pointer;
  flex-shrink: 0;
}

.nav__brand {
  display: inline-flex;
  align-items: center;
}

.nav__brand img {
  height: 15px;
  width: auto;
  display: block;
  /* SVG ships as white; invert so it reads black on the white nav */
  filter: invert(1);
}

/* ============================================
   DESKTOP LEFT SIDEBAR (>= 1024px)
   ============================================ */

.sidenav {
  display: none; /* mobile hides */
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: 240px;
  background: var(--black);
  color: var(--white);
  z-index: 50;
  flex-direction: column;
  padding: 40px 32px;
  transform: translateX(-20px);
  opacity: 0;
  animation: sidenav-in 600ms var(--ease) forwards;
}

@keyframes sidenav-in {
  to { transform: translateX(0); opacity: 1; }
}

.sidenav__brand {
  display: flex;
  margin-bottom: 64px;
}

.sidenav__brand img {
  width: 100%;
  max-width: 176px;
  height: auto;
  display: block;
}

.sidenav__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 28px;
  font-size: 12px;
  letter-spacing: 0.02em;
}

.sidenav__list a {
  display: inline-block;
  position: relative;
  padding-left: 0;
  opacity: 0.8;
  transition: opacity 200ms var(--ease), padding-left 260ms var(--ease);
}

.sidenav__list a::before {
  content: "";
  position: absolute;
  left: -18px;
  top: 50%;
  width: 8px;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 260ms var(--ease);
}

.sidenav__list a:hover,
.sidenav__list a.is-active {
  opacity: 1;
  padding-left: 14px;
}

.sidenav__list a:hover::before,
.sidenav__list a.is-active::before {
  transform: scaleX(1);
  transform-origin: left;
}

.sidenav__social {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
  font-size: 10px;
  letter-spacing: 0.08em;
  opacity: 0.7;
}

.sidenav__copy {
  margin-top: 16px;
  font-size: 9px;
  opacity: 0.4;
  letter-spacing: 0.04em;
}

/* ============================================
   Navigation overlay (mobile/tablet)
   ============================================ */

.nav-overlay {
  position: fixed;
  inset: 0;
  background: var(--black);
  color: var(--white);
  z-index: 90; /* below .nav so the logo + dots stay visible on top */
  display: flex;
  flex-direction: column;
  padding: calc(var(--banner-h) + var(--nav-h) + 40px) var(--side-pad) 40px;
  transform: translateY(-100%);
  transition: transform 480ms var(--ease);
  pointer-events: none;
  will-change: transform;
}

.nav-overlay.is-open {
  transform: translateY(0);
  pointer-events: auto;
}

/* When the overlay is open, the top nav stays on top but its styling flips
   from white-on-black to black-on-black, with the logo and dots turning white. */
body.nav-open .nav {
  background: transparent;
  border-bottom: 0;
  z-index: 110;
}

body.nav-open .nav__brand img {
  filter: none; /* SVG ships white — remove the invert so it renders white */
}

body.nav-open .nav__dot {
  background: var(--white);
}

.nav-overlay__top {
  display: none; /* nav's logo takes over as the top bar */
}

.nav-overlay__brand img { height: 15px; width: auto; }

.nav-overlay__close {
  font-size: 10px;
  letter-spacing: 0.05em;
  color: var(--white);
  cursor: pointer;
}

.nav-overlay__list {
  list-style: none;
  margin: 0;
  padding: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 28px;
  text-align: center;
}

.nav-overlay__list a {
  display: block;
  font-family: var(--font-thermal);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.nav-overlay__social {
  margin-top: auto;
  display: flex;
  justify-content: center;
  gap: 20px;
  font-size: 10px;
}

/* ============================================
   Hero (home)
   ============================================ */

.hero {
  position: relative;
  height: calc(100vh - var(--banner-h));
  min-height: 640px;
  background: #050608;
  color: var(--white);
  overflow: hidden;
  isolation: isolate;
}

.hero__bg {
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(1200px 600px at 50% 35%, rgba(130, 140, 160, 0.35), transparent 70%),
    radial-gradient(900px 500px at 15% 85%, rgba(70, 80, 95, 0.3), transparent 72%),
    radial-gradient(700px 450px at 85% 55%, rgba(55, 60, 75, 0.28), transparent 70%),
    linear-gradient(180deg, #0b0d10 0%, #030405 100%);
}

.hero__noise {
  position: absolute;
  inset: 0;
  opacity: 0.32;
  mix-blend-mode: overlay;
  pointer-events: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

.hero__wordmark {
  position: absolute;
  top: 20%;
  left: 50%;
  transform: translateX(-50%);
  width: min(88%, 1120px);
  aspect-ratio: 353 / 77;
  display: flex;
  align-items: center;
  justify-content: center;
  mix-blend-mode: normal;
}

.hero__wordmark img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.hero__tag {
  position: absolute;
  bottom: 180px;
  left: var(--side-pad);
  right: var(--side-pad);
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  line-height: 1.2;
  color: var(--white);
  letter-spacing: 0.04em;
}

.hero__tag p { margin: 0; }
.hero__tag--right { text-align: right; }

.hero__cta {
  position: absolute;
  left: var(--side-pad);
  right: var(--side-pad);
  bottom: 30px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  max-width: 800px;
  margin-inline: auto;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 48px;
  padding: 0 24px;
  font-size: 10px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  background: var(--black);
  color: var(--white);
  border: 0;
  transition: opacity 200ms var(--ease), transform 200ms var(--ease), background 200ms var(--ease);
  cursor: pointer;
  white-space: nowrap;
}

.btn:hover { opacity: 0.85; }
.btn:active { transform: translateY(1px); }

.btn--outline {
  background: transparent;
  border: 0.5px solid rgba(255, 255, 255, 0.5);
  color: var(--white);
}

.btn--outline:hover {
  background: rgba(255, 255, 255, 0.08);
  opacity: 1;
}

.btn--full { width: 100%; }

/* ============================================
   Sections (generic)
   ============================================ */

.section {
  padding: 80px var(--side-pad);
}

.section__label {
  font-size: 10px;
  margin: 0 0 20px;
  display: block;
  letter-spacing: 0.05em;
}

/* Intro block */
.intro {
  padding: 60px var(--side-pad);
}

.intro__inner {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.intro__copy p { margin: 0; }
.intro__copy p + p {
  margin-top: 8px;
  color: var(--gray);
  font-size: 12px;
  line-height: 1.5;
  text-transform: none;
  letter-spacing: 0;
}

/* ============================================
   Product grid
   ============================================ */

.products {
  padding: 40px var(--side-pad) 80px;
  max-width: var(--content-max);
  margin: 0 auto;
  border-top: 0.5px solid rgba(0, 0, 0, 0.12);
}

.products__head {
  margin-bottom: 24px;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}

.products__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.card {
  display: flex;
  flex-direction: column;
  gap: 16px;
  color: var(--black);
  transition: opacity 200ms var(--ease);
  position: relative;
}

.card:hover { opacity: 0.96; }

.card__media {
  aspect-ratio: 1 / 1;
  width: 100%;
  overflow: hidden;
  background: var(--off-white);
}

.card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 600ms var(--ease);
}

.card:hover .card__media img { transform: scale(1.04); }

.card__body {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.card__title { font-size: 11px; margin: 0; }
.card__meta  { font-size: 11px; color: var(--gray); margin: 0; }

/* ============================================
   Feature (big image + copy)
   ============================================ */

.feature {
  padding: 40px 0 80px;
  max-width: var(--content-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}

.feature__media {
  padding: 0 var(--side-pad);
}

.feature__media img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

.feature__body {
  padding: 20px var(--side-pad);
  display: flex;
  flex-direction: column;
  gap: 20px;
  max-width: 640px;
}

.feature__body h3 {
  margin: 0;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.05em;
}

.feature__body p {
  margin: 0;
  color: var(--gray);
  line-height: 1.5;
  font-size: 13px;
  text-transform: none;
  letter-spacing: 0;
}

/* ============================================
   Rails (article strip, insta strip)
   ============================================ */

.rail {
  padding: 40px 0 60px;
  max-width: var(--content-max);
  margin: 0 auto;
}

.rail__head {
  padding: 0 var(--side-pad) 20px;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
}

.rail__head-copy p { margin: 0; }
.rail__head-copy p:last-child { color: var(--gray); margin-top: 4px; }

.rail__scroll {
  display: flex;
  gap: 14px;
  padding: 0 var(--side-pad);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.rail__scroll::-webkit-scrollbar { display: none; }

.rail__item {
  flex: 0 0 260px;
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.rail__media {
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: var(--off-white);
}

.rail__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 600ms var(--ease);
}

.rail__item:hover .rail__media img { transform: scale(1.03); }

.rail__meta { font-size: 11px; }
.rail__meta p { margin: 0; }
.rail__meta p:last-child { color: var(--gray); margin-top: 8px; }

/* ============================================
   Email signup
   ============================================ */

.signup {
  background: var(--off-white);
  padding: 60px var(--side-pad);
}

.signup__inner {
  max-width: 560px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.signup__copy p { margin: 0; }
.signup__copy p:last-child {
  color: var(--gray);
  margin-top: 10px;
  text-transform: none;
  line-height: 1.5;
  font-size: 12px;
  letter-spacing: 0;
}

.signup__form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.signup__input {
  width: 100%;
  height: 52px;
  padding: 0 18px;
  background: var(--white);
  border: 0;
  font: inherit;
  font-size: 11px;
  text-transform: uppercase;
  color: var(--black);
  outline: 0;
  transition: box-shadow 200ms var(--ease);
}

.signup__input::placeholder { color: rgba(0, 0, 0, 0.3); }
.signup__input:focus { box-shadow: 0 0 0 1px var(--black); }

/* ============================================
   Footer
   ============================================ */

.footer {
  background: var(--off-white);
  padding: 40px var(--side-pad) 60px;
  position: relative;
  color: var(--black);
}

.footer__inner {
  max-width: var(--content-max);
  margin: 0 auto;
}

.footer__links {
  display: flex;
  flex-direction: column;
}

.footer__link {
  display: block;
  padding: 14px 0;
  font-size: 11px;
  position: relative;
  color: var(--black);
  transition: padding-left 200ms var(--ease);
  border-bottom: 0.5px dotted rgba(0, 0, 0, 0.35);
  letter-spacing: 0.02em;
}

.footer__link:hover { padding-left: 4px; }

.footer__meta {
  display: flex;
  justify-content: space-between;
  margin-top: 80px;
  font-family: var(--font-thermal);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: rgba(0, 0, 0, 0.9);
}

.footer__wordmark {
  margin-top: 48px;
  width: 100%;
  display: flex;
  justify-content: center;
}

.footer__wordmark img {
  width: 100%;
  max-width: 560px;
  height: auto;
  /* SVG ships white; invert for the off-white footer */
  filter: invert(1);
}

/* ============================================
   Product detail (PDP) — expanded
   ============================================ */

.pdp {
  width: 100%;
}

.pdp__hero {
  background: var(--white);
  padding: 16px 0 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  max-width: none;
  margin: 0 auto;
  width: 100%;
}

/* Slider — horizontal scroll-snap, one slide per page */
.pdp__slider {
  display: flex;
  gap: 6px;
  width: 100%;
  padding: 0 var(--side-pad);
  scroll-padding-left: var(--side-pad);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  scroll-behavior: smooth;
}

.pdp__slider::-webkit-scrollbar { display: none; }

.pdp__slide {
  flex: 0 0 calc(100% + 4px);
  scroll-snap-align: start;
  position: relative;
  aspect-ratio: 353 / 560;
  /* Cap slide height so the title + selectors always peek below the hero,
     no matter how tall the viewport is. Leaves room for banner+nav,
     hero padding, dots, and a reveal of the title/color/pack block. */
  max-height: calc(100vh - 340px);
  max-height: calc(100svh - 340px);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Slide background variants — match Figma colors */
.pdp__slide--soft {
  background: linear-gradient(180deg, #f2f7ff 0%, #d3d7ff 100%);
}

.pdp__slide--blue { background: #264bcf; }
.pdp__slide--place { background: #ffffff; }
.pdp__slide--deep { background: #002094; }

.pdp__slide img {
  width: 62%;
  height: 62%;
  object-fit: contain;
  display: block;
}

/* Slide-specific image treatments */
.pdp__slide--blue img {
  width: 64%;
  height: auto;
  mix-blend-mode: screen;
}

.pdp__slide--place img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pdp__slide--deep img {
  width: 90%;
  height: 90%;
  object-fit: contain;
  mix-blend-mode: multiply;
}

.pdp__slide__captions {
  position: absolute;
  bottom: 22px;
  left: 22px;
  right: 22px;
  display: flex;
  justify-content: space-between;
  font-family: var(--font-thermal);
  font-size: 10px;
  letter-spacing: 0.06em;
  color: var(--white);
  text-transform: uppercase;
}

/* Dot indicators */
.pdp__hero__dots {
  display: flex;
  gap: 4px;
  padding: 16px var(--side-pad) 0;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
}

.pdp__hero__dots button {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.18);
  border: 0;
  padding: 0;
  cursor: pointer;
  transition: background 200ms var(--ease), transform 200ms var(--ease);
}

.pdp__hero__dots button:hover { background: rgba(0, 0, 0, 0.4); }

.pdp__hero__dots button.is-active {
  background: var(--black);
  transform: scale(1.15);
}

.pdp__title {
  padding: 16px var(--side-pad) 8px;
  max-width: 600px;
}

.pdp__title h1 {
  margin: 0;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--black);
}

.pdp__title p {
  margin: 8px 0 0;
  font-size: 10px;
  color: var(--gray);
  letter-spacing: 0.02em;
}

.pdp__selectors {
  padding: 24px var(--side-pad) 32px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.pdp__selector__label {
  font-size: 9px;
  letter-spacing: 0.06em;
  margin-bottom: 10px;
  display: block;
}

.pdp__color {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}

.pdp__color__opt {
  height: 38px;
  border: 0.5px solid var(--light-gray);
  background: var(--white);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: all 200ms var(--ease);
  color: var(--gray);
  text-transform: uppercase;
}

.pdp__color__opt.is-active {
  background: var(--white);
  color: var(--black);
  border: 1px solid var(--black);
}

.pdp__color__opt:hover:not(.is-active) {
  color: var(--black);
  border-color: var(--black);
}

.pdp__pack {
  display: grid;
  /* Match the 4-col color grid so each pack button is the same width as a color button */
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}

.pdp__pack__col {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 10px;
}

.pdp__pack__opt {
  width: 100%;
  height: 38px;
  background: var(--white);
  color: var(--gray);
  border: 0.5px solid var(--light-gray);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: color 200ms var(--ease), border-color 200ms var(--ease), border-width 200ms var(--ease);
  font-size: 9px;
  letter-spacing: 0.04em;
  font-family: inherit;
  text-transform: uppercase;
}

.pdp__pack__opt:hover:not(.is-active) {
  color: var(--black);
  border-color: var(--black);
}

.pdp__pack__opt.is-active {
  color: var(--black);
  border: 1px solid var(--black);
}

.pdp__pack__save {
  font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--gray);
  text-align: center;
  text-transform: uppercase;
  transition: color 200ms var(--ease);
}

.pdp__pack__opt.is-active + .pdp__pack__save {
  color: var(--black);
}

.pdp__badge {
  display: inline-flex;
  align-items: center;
  align-self: center;
  padding: 8px 14px;
  background: var(--off-white);
  border-radius: 999px;
  font-size: 9px;
  letter-spacing: 0.06em;
  text-transform: lowercase;
  margin: 12px auto;
  color: var(--gray);
}

.pdp__add {
  padding: 16px var(--side-pad) 28px;
  background: var(--white);
}

.pdp__add__inner { max-width: 600px; margin: 0 auto; }

/* Pinned CTA — appears at viewport bottom when natural CTA scrolls off the top */
.pdp__pinned {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 14px var(--side-pad) calc(14px + env(safe-area-inset-bottom, 0px));
  background: var(--white);
  z-index: 60;
  box-shadow: 0 -10px 30px rgba(0, 0, 0, 0.08);
  transform: translateY(110%);
  transition: transform 320ms var(--ease);
  pointer-events: none;
  border-top: 0.5px solid rgba(0, 0, 0, 0.08);
}

.pdp__pinned.is-visible {
  transform: translateY(0);
  pointer-events: auto;
}

/* Parked — once the user reaches the testimonials, the CTA locks into a
   document position and scrolls with the page instead of staying fixed. */
.pdp__pinned.is-parked {
  position: absolute;
  bottom: auto;
  transform: none;
  transition: none;
  pointer-events: auto;
  box-shadow: none;
}

.pdp__pinned__inner { max-width: 600px; margin: 0 auto; }

.pdp__pinned .pdp__add__cta {
  height: 52px;
}

/* Inline desktop CTA — lives in the right column on desktop, hidden on mobile */
.pdp__cta-inline {
  display: none;
}

.pdp__cta-inline__note {
  margin: 10px 0 0;
  font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--gray);
  text-align: center;
  text-transform: uppercase;
}

/* Cart indicator — lives inside the nav, right side. Appears after first Add to cart click.
   Because it's inside the nav, it slides with the nav whenever the nav hides/reveals. */
.cart-nav {
  position: absolute;
  right: var(--side-pad);
  top: 50%;
  transform: translateY(calc(-50% - 4px));
  display: inline-flex;
  align-items: center;
  z-index: 2; /* above the nav dot so it sits alone visually */
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--black);
  text-transform: uppercase;
  font-weight: 500;
  pointer-events: none;
  opacity: 0;
  transition: opacity 260ms var(--ease), transform 260ms var(--ease);
}

.cart-nav.is-visible {
  opacity: 1;
  transform: translateY(-50%);
}

/* When the cart has items, hide the right nav dot so the cart text sits alone */
body.cart-has-items .nav > .nav__dot:last-of-type {
  visibility: hidden;
}

/* When the menu overlay is open, the cart indicator turns white too */
body.nav-open .cart-nav {
  color: var(--white);
}

/* Make the cart indicator interactive once it's visible */
.cart-nav.is-visible {
  pointer-events: auto;
  cursor: pointer;
}

/* ============================================
   Cart drawer — Shopify-style slide-down from the top
   ============================================ */

.cart-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  z-index: 115;
  opacity: 0;
  pointer-events: none;
  transition: opacity 360ms var(--ease);
}
.cart-backdrop.is-open {
  opacity: 1;
  pointer-events: auto;
}

.cart-drawer {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  height: 100vh;
  height: 100dvh; /* use dynamic viewport height on mobile so it fills past the URL bar */
  background: var(--white);
  color: var(--black);
  z-index: 120; /* above the nav and the nav-overlay */
  display: flex;
  flex-direction: column;
  transform: translateY(-100%);
  transition: transform 480ms var(--ease);
  will-change: transform;
}
.cart-drawer.is-open {
  transform: translateY(0);
}

.cart-drawer__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 22px var(--side-pad) 18px;
  border-bottom: 0.5px solid rgba(0, 0, 0, 0.1);
}

.cart-drawer__title {
  margin: 0;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 500;
}
.cart-drawer__count {
  margin-left: 4px;
  color: var(--gray);
  font-weight: 400;
}

.cart-drawer__close {
  background: none;
  border: 0;
  padding: 0;
  font: inherit;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--black);
  cursor: pointer;
}

.cart-drawer__body {
  flex: 1;
  overflow-y: auto;
  padding: 20px var(--side-pad);
  -webkit-overflow-scrolling: touch;
}

.cart-drawer__empty {
  margin: 48px 0;
  text-align: center;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--gray);
}

.cart-drawer__items {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.cart-item {
  display: grid;
  grid-template-columns: 96px 1fr auto;
  gap: 16px;
  align-items: stretch; /* let info + right columns match the 96px image height */
}

.cart-item__media {
  background: var(--off-white);
  aspect-ratio: 1;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cart-item__media img {
  width: 50%;
  height: 50%;
  object-fit: contain; /* show the whole image — never crop */
  display: block;
}

.cart-item__info {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.cart-item__title {
  margin: 0;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.cart-item__variant {
  margin: 0;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 400;
  color: var(--gray);
}

.cart-item__qty {
  display: inline-flex;
  align-items: center;
  border: 0.5px solid rgba(0, 0, 0, 0.2);
  height: 28px;
  width: fit-content;
  margin-top: auto; /* push the stepper to the bottom of the info column */
}
.cart-item__qty button {
  background: none;
  border: 0;
  width: 28px;
  height: 100%;
  cursor: pointer;
  font-size: 11px;
  letter-spacing: 0.06em;
  line-height: 1;
  color: var(--black);
  padding: 0;
}
.cart-item__qty span {
  min-width: 22px;
  text-align: center;
  font-size: 11px;
  letter-spacing: 0.06em;
}

.cart-item__right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
}

.cart-item__price {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.cart-item__remove {
  background: none;
  border: 0;
  padding: 0;
  font: inherit;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--gray);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
  margin-top: auto; /* push Remove to the bottom of the right column */
}
.cart-item__remove:hover {
  color: var(--black);
}

.cart-drawer__footer {
  padding: 18px var(--side-pad) 22px;
  border-top: 0.5px solid rgba(0, 0, 0, 0.1);
  background: var(--white);
}

.cart-drawer__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 14px;
}

.cart-drawer__note {
  margin: 12px 0 0;
  font-size: 11px;
  color: var(--gray);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-align: center;
}

.cart-drawer__checkout {
  width: 100%;
}

/* Lock page scroll while the drawer is open */
body.cart-open {
  overflow: hidden;
}


.pdp__pinned__note {
  margin: 10px 0 0;
  font-size: 10px;
  color: var(--gray);
  letter-spacing: 0.04em;
  text-align: center;
}

@media (min-width: 1024px) {
  .pdp__pinned { left: var(--desktop-sidebar); }
}

.pdp__add__cta {
  height: 56px;
  width: 100%;
  background: var(--black);
  color: var(--white);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  cursor: pointer;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: opacity 200ms var(--ease);
}

.pdp__add__was {
  text-decoration: line-through;
  text-decoration-thickness: 1px;
  opacity: 0.55;
}

.pdp__add__was[hidden] { display: none; }

.pdp__add__cta:hover { opacity: 0.88; }

.pdp__add__note {
  margin: 14px 0 0;
  font-size: 10px;
  text-align: center;
  color: var(--gray);
  letter-spacing: 0.04em;
}

/* Accordion */
.acc {
  border-top: 0.5px solid rgba(0, 0, 0, 0.15);
}

.acc__item {
  border-bottom: 0.5px solid rgba(0, 0, 0, 0.15);
}

.acc__btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 22px var(--side-pad);
  font-size: 11px;
  letter-spacing: 0.04em;
  text-align: left;
  cursor: pointer;
  background: transparent;
  text-transform: uppercase;
}

.acc__btn::after {
  content: "";
  width: 11px;
  height: 13px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 11 13' fill='none'><path d='M5.5 1v11M1 7.5l4.5 4.5L10 7.5' stroke='%23000' stroke-width='1' stroke-linecap='square' stroke-linejoin='miter' fill='none'/></svg>");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  transition: transform 200ms var(--ease);
}

.acc__item.is-open .acc__btn::after { transform: rotate(180deg); }

.acc__panel {
  max-height: 0;
  overflow: hidden;
  transition: max-height 420ms var(--ease);
  font-size: 11px;
  line-height: 1.6;
  color: var(--gray);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.acc__panel > * {
  margin: 0;
  padding: 0 var(--side-pad) 22px;
}

.acc__item.is-open .acc__panel {
  max-height: 1600px;
}

.need {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.need__card {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin: 0;
  opacity: 0;
  transform: translateY(14px);
}

.acc__item.is-open .need__card {
  animation: need-in 640ms cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
}

.acc__item.is-open .need__card:nth-child(1) { animation-delay: 60ms; }
.acc__item.is-open .need__card:nth-child(2) { animation-delay: 200ms; }

.acc__item.is-open .need__media img {
  animation: need-img-in 760ms cubic-bezier(0.22, 0.61, 0.36, 1) both;
  animation-delay: 260ms;
}

.acc__item.is-open .need__card:nth-child(2) .need__media img {
  animation-delay: 400ms;
}

@keyframes need-in {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes need-img-in {
  from { opacity: 0; transform: scale(0.92); }
  to   { opacity: 1; transform: scale(1); }
}

@media (prefers-reduced-motion: reduce) {
  .need__card {
    opacity: 1;
    transform: none;
  }
  .acc__item.is-open .need__card,
  .acc__item.is-open .need__media img {
    animation: none;
  }
}

.need__media {
  position: relative;
  aspect-ratio: 360 / 575;
  background: linear-gradient(180deg, #8a8a8a 0%, #e6e6e6 100%);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 28px 30px;
}

.need__media img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.need__media--tall {
  padding: 40px 30px;
}

.need__media--tall img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  transform: none;
}

.need__label {
  font-size: 10px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--black, #000);
  line-height: 1.1;
}

.acc__panel--spec p {
  font-size: 11px;
  letter-spacing: 0.04em;
  line-height: 1.9;
  color: #000;
}

.acc__panel--spec p strong {
  font-weight: 500;
}

/* Benefits */
.benefits {
  padding: 8px 0 32px;
}

.benefits__head {
  padding: 32px var(--side-pad) 24px;
  font-size: 11px;
  letter-spacing: 0.06em;
}

.benefit {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 20px;
  padding: 20px var(--side-pad);
  align-items: center;
}

.benefit__icon {
  width: 96px;
  height: 96px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--white);
}

.benefit__title {
  font-size: 11px;
  margin: 0 0 8px;
  letter-spacing: 0.04em;
  color: var(--black);
  text-transform: uppercase;
}

.benefit__copy {
  font-size: 11px;
  color: var(--gray);
  line-height: 1.6;
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* How it works — horizontal scroll of step cards */
.howto {
  padding: 8px 0 32px;
}

.howto__head {
  padding: 32px var(--side-pad) 24px;
  font-size: 11px;
  letter-spacing: 0.06em;
}

.howto__scroll {
  display: flex;
  gap: 10px;
  padding-left: var(--side-pad);
  padding-right: var(--side-pad);
  scroll-padding-left: var(--side-pad);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.howto__scroll::-webkit-scrollbar { display: none; }

.howto__step {
  flex: 0 0 232px;
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.howto__step:first-child { margin-left: 0; }
.howto__step:last-child { padding-right: var(--side-pad); }

.howto__step__media {
  width: 232px;
  height: 232px;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: #000;
}

.howto__step__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.howto__step__copy {
  font-size: 10px;
  line-height: 1.1;
  color: var(--black);
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

/* Editorial / full bleed */
/* How-it-works video — full-bleed under the steps */
.howto-video {
  margin: 8px 0 0;
  padding: 0;
  width: 100%;
  background: var(--black);
  overflow: hidden;
}

.howto-video video {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}

.editorial {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--white);
  margin: 32px 0 32px var(--side-pad);
}

.editorial img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Testimonials */
.testimonials {
  padding: 32px 0;
}

.testimonials__head {
  padding: 0 var(--side-pad) 20px;
  font-size: 11px;
  letter-spacing: 0.06em;
}

.testimonials__scroll {
  display: flex;
  gap: 12px;
  padding-left: var(--side-pad);
  padding-right: var(--side-pad);
  scroll-padding-left: var(--side-pad);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.testimonials__scroll::-webkit-scrollbar { display: none; }

.testimonial {
  flex: 0 0 280px;
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.testimonial:last-child { padding-right: var(--side-pad); }

.testimonial__media {
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--off-white);
}

.testimonial__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.testimonial__handle {
  font-size: 10px;
  color: var(--gray);
  letter-spacing: 0.04em;
}

/* Tagline — compact, uppercase, left-aligned to match accordion section */
.tagline {
  padding: 24px var(--side-pad) 28px;
  background: var(--white);
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.tagline h2 {
  margin: 0;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--black);
  line-height: 1.4;
}

.tagline p {
  margin: 0;
  color: var(--gray);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  line-height: 1.4;
}

/* ============================================
   Category switch (Shop filter)
   ============================================ */

.switch {
  position: sticky;
  top: calc(var(--banner-h) + var(--nav-h));
  z-index: 20;
  background: var(--white);
  padding: 14px var(--side-pad);
  display: flex;
  gap: 9px;
  overflow-x: auto;
  scrollbar-width: none;
  border-bottom: 0.5px solid rgba(0, 0, 0, 0.08);
}

.switch::-webkit-scrollbar { display: none; }

.chip {
  flex: 0 0 auto;
  height: 40px;
  padding: 0 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  color: var(--gray);
  border: 0.5px solid var(--light-gray);
  background: var(--white);
  cursor: pointer;
  transition: border-color 200ms var(--ease), color 200ms var(--ease), background 200ms var(--ease);
  letter-spacing: 0.04em;
}

.chip.is-active {
  color: var(--white);
  background: var(--black);
  border-color: var(--black);
}

.chip:hover:not(.is-active) {
  color: var(--black);
  border-color: var(--black);
}

/* Shop grid */
.shop-grid {
  padding: 24px var(--side-pad) 60px;
  max-width: var(--content-max);
  margin: 0 auto;
  display: grid;
  gap: 20px;
  grid-template-columns: 1fr;
}

.shop-row {
  display: grid;
  gap: 16px;
}

.shop-row--1 { grid-template-columns: 1fr; }
.shop-row--2 { grid-template-columns: 1fr 1fr; }

.shop-row--wide .card__media { aspect-ratio: 4 / 3; }

/* ============================================
   Article template
   ============================================ */

.article { background: var(--white); }

.article__hero {
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #111;
  max-height: 80vh;
}

.article__hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.article__body {
  padding: 40px var(--side-pad);
  display: flex;
  flex-direction: column;
  gap: 24px;
  text-transform: none;
  font-size: 15px;
  line-height: 1.6;
  color: var(--gray);
  max-width: 680px;
  margin: 0 auto;
  letter-spacing: 0;
}

.article__body h1,
.article__body h2 {
  color: var(--black);
  font-weight: 500;
  letter-spacing: -0.01em;
}

.article__body h1 {
  font-size: 36px;
  margin: 12px 0 0;
  line-height: 1.1;
}

.article__body h2 {
  font-size: 22px;
  margin: 16px 0 0;
  line-height: 1.25;
}

.article__kicker {
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--gray);
  font-size: 11px;
}

.article__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin: 16px 0;
}

.article__grid img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.article__full {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  margin: 16px 0;
}

/* ============================================
   Utility
   ============================================ */

.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;
}

/* ============================================
   Responsive
   ============================================ */

/* Tablet */
@media (min-width: 640px) {
  :root { --side-pad: 32px; }
  body { font-size: 12px; }
  .products__grid { grid-template-columns: repeat(3, 1fr); gap: 20px; }
  .hero__tag { bottom: 220px; font-size: 13px; }
  .hero__wordmark { width: min(84%, 1120px); }
  .rail__item { flex-basis: 300px; }
  .article__body { font-size: 16px; }
  .article__body h1 { font-size: 44px; }
  .article__body h2 { font-size: 26px; }
}

/* Desktop — show left sidebar, hide top nav */
@media (min-width: 1024px) {
  :root {
    --side-pad: 48px;
    --desktop-sidebar: 240px;
  }

  .sidenav { display: flex; }

  /* Keep the top nav (dots + centered MAGSi wordmark) visible on desktop too.
     Only hide the hero-overlay nav, since the home hero has its own wordmark. */
  .nav--hero { display: none; }

  .nav {
    height: 72px;
    padding: 0 40px;
  }

  .nav__brand img { height: 18px; }
  .nav__dot { width: 14px; height: 14px; }

  .hero {
    height: calc(100vh - var(--banner-h));
    min-height: 720px;
  }

  .hero__wordmark {
    top: 25%;
    width: min(75%, 1200px);
  }

  .hero__tag {
    bottom: 240px;
    font-size: 14px;
  }

  .hero__cta {
    max-width: 480px;
    bottom: 48px;
  }

  .btn { height: 52px; padding: 0 36px; font-size: 11px; }

  .intro {
    padding: 120px var(--side-pad);
  }

  .intro__inner {
    max-width: 860px;
    flex-direction: row;
    gap: 80px;
    align-items: flex-start;
  }

  .intro__copy {
    flex: 1;
  }

  .intro__copy p:first-child {
    font-size: 18px;
    letter-spacing: 0;
  }

  .intro__copy p + p {
    margin-top: 16px;
    font-size: 14px;
    line-height: 1.55;
  }

  .intro .btn {
    min-width: 240px;
    align-self: center;
  }

  .products { padding: 60px var(--side-pad) 100px; }
  .products__grid { grid-template-columns: repeat(4, 1fr); gap: 24px; }

  .feature {
    padding: 80px var(--side-pad);
    grid-template-columns: 1.2fr 1fr;
    gap: 80px;
    align-items: center;
  }

  .feature__media {
    padding: 0;
  }

  .feature__media img {
    aspect-ratio: 4 / 5;
  }

  .feature__body {
    padding: 0;
    gap: 24px;
  }

  .feature__body h3 { font-size: 14px; }
  .feature__body p { font-size: 15px; }

  .rail__item { flex-basis: 340px; }
  .rail__scroll { padding: 0 var(--side-pad); gap: 20px; }

  .signup {
    padding: 100px var(--side-pad);
  }

  .signup__inner {
    max-width: 680px;
  }

  .signup__copy p:first-child {
    font-size: 18px;
  }

  .signup__copy p:last-child {
    font-size: 14px;
  }

  .signup__form {
    flex-direction: row;
    gap: 12px;
  }

  .signup__form .signup__input { flex: 1; height: 56px; }
  .signup__form .btn { flex: 0 0 auto; min-width: 160px; height: 56px; }

  .footer {
    padding: 80px var(--side-pad) 60px;
  }

  .footer__links {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 0 40px;
    border-bottom: 0.5px solid rgba(0, 0, 0, 0.15);
    padding-bottom: 8px;
  }

  .footer__link {
    border-bottom: 0;
    padding: 8px 0;
  }

  .footer__meta { margin-top: 40px; }

  .footer__wordmark {
    margin-top: 60px;
  }

  .footer__wordmark img { max-width: 960px; }

  /* PDP */
  .pdp {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 0;
    align-items: flex-start;
  }

  .pdp__media-feed {
    position: sticky;
    top: var(--banner-h);
    max-height: calc(100vh - var(--banner-h));
    overflow-y: auto;
    scrollbar-width: thin;
  }

  .pdp__media-feed img {
    aspect-ratio: 1 / 1;
    max-height: calc(100vh - var(--banner-h));
  }

  .pdp__info {
    padding: 80px var(--side-pad);
    max-width: none;
  }

  .pdp__info h1 { font-size: 48px; }

  .pdp__add {
    padding: 24px var(--side-pad) 40px;
  }

  /* Shop grid */
  .switch {
    top: var(--banner-h);
    padding: 16px var(--side-pad);
  }

  .shop-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
  }

  .shop-row {
    grid-column: span 4;
  }

  .shop-row--1 {
    grid-template-columns: 1fr 1fr;
  }

  .shop-row--2 {
    grid-template-columns: repeat(4, 1fr);
  }

  /* Article */
  .article__body {
    font-size: 17px;
    max-width: 760px;
    padding: 80px var(--side-pad);
  }

  .article__body h1 { font-size: 56px; }
  .article__body h2 { font-size: 30px; margin-top: 24px; }

  .article__hero { aspect-ratio: 21 / 9; max-height: 70vh; }

  /* ============================================
     PDP — desktop split-view (Tatcha-style)
     Image stays anchored on the left while details scroll on the right
     ============================================ */

  /* Hide the top nav (dots + wordmark) on desktop — sidebar takes over */
  .nav { display: none; }

  /* Turn .page into a 2-col grid for the PDP layout */
  .page {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    column-gap: 0;
    align-items: start;
  }

  /* Full-width rows — everything that isn't part of the PDP column pair */
  .page > .banner,
  .page > .editorial,
  .page > .howto-video,
  .page > .testimonials,
  .page > .products,
  .page > .signup,
  .page > .footer,
  /* FAQ is an unclassed <section> wrapping a .acc */
  .page > section:not(.tagline):not(.benefits):not(.howto) {
    grid-column: 1 / -1;
  }

  /* Left column: hero image pinned while the right column scrolls */
  .pdp__hero {
    grid-column: 1;
    grid-row: span 7;
    position: sticky;
    top: var(--banner-h);
    align-self: start;
    height: calc(100vh - var(--banner-h));
    padding: 0;
    background: var(--off-white);
    overflow: hidden;
  }

  .pdp__hero .pdp__slider {
    height: 100%;
    padding: 0;
    scroll-padding-left: 0;
  }

  .pdp__hero .pdp__slide {
    flex: 0 0 100%;
    max-height: none;
    height: 100%;
    aspect-ratio: auto;
  }

  .pdp__hero .pdp__slide img {
    width: 72%;
    height: 72%;
  }

  .pdp__hero .pdp__slide--place img {
    width: 100%;
    height: 100%;
  }

  .pdp__hero__dots {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 32px;
    padding: 0 40px;
    justify-content: center;
    z-index: 2;
  }

  /* Right column: product title, selectors, accordions, benefits, howto */
  .pdp__title,
  .pdp__selectors,
  .pdp__cta-inline,
  .tagline,
  .tagline ~ .acc,
  .page > .benefits,
  .page > .howto {
    grid-column: 2;
    width: 100%;
    max-width: 560px;
    margin: 0;
    box-sizing: border-box;
  }

  /* Breathing room at the top of the right column */
  .pdp__title {
    padding: 80px 48px 8px;
  }

  .pdp__title h1 { font-size: 12px; }
  .pdp__title p { font-size: 12px; }

  .pdp__selectors {
    padding: 24px 48px 16px;
  }

  /* Show the inline CTA on desktop */
  .pdp__cta-inline {
    display: block;
    padding: 16px 48px 32px;
  }

  .tagline {
    padding: 24px 48px 28px;
  }

  /* First .acc (What you need + Spec) — align to right column padding */
  .tagline ~ .acc .acc__btn {
    padding: 22px 48px;
  }

  .tagline ~ .acc .acc__panel > * {
    padding-left: 48px;
    padding-right: 48px;
  }

  .page > .benefits {
    padding: 32px 48px 24px;
  }

  .page > .howto {
    padding: 32px 0 24px;
  }

  .page > .howto .howto__head {
    padding: 0 48px;
  }

  .page > .howto .howto__scroll {
    padding-left: 48px;
    padding-right: 48px;
    scroll-padding-left: 48px;
  }

  /* Hide the pinned mobile CTA on desktop — the inline one takes over */
  .pdp__pinned { display: none; }

  /* Editorial images shouldn't have the mobile left-inset on desktop — go edge to edge */
  .page > .editorial {
    margin: 0;
    width: 100%;
  }

  .page > .editorial img {
    width: 100%;
    max-height: 80vh;
    object-fit: cover;
  }
}

/* Large desktop */
@media (min-width: 1440px) {
  .hero__wordmark {
    width: min(68%, 1360px);
    top: 28%;
  }

  .hero__cta { max-width: 520px; }

  .products__grid { gap: 32px; }

  .feature { gap: 120px; }
}

/* Extra large */
@media (min-width: 1800px) {
  :root { --desktop-sidebar: 280px; }
  .sidenav { width: 280px; }
  .hero__wordmark { width: min(62%, 1500px); }
}

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
}
