:root {
  --ink: #111111;
  --cream: #f7f0df;
  --paper: #fffdf8;
  --yellow: #ffd93d;
  --blue: #71c6ff;
  --pink: #ff8fb1;
  --green: #70d5a3;
  --orange: #ff9a4d;
  --muted: #665f56;
  --line: rgba(17, 17, 17, .16);
  --shadow: 0 20px 50px rgba(17, 17, 17, .16);
  --radius: 26px;
  --hero-accent: var(--yellow);
  --hero-secondary: var(--blue);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--cream);
  font-family: Montserrat, Arial, sans-serif;
  line-height: 1.5;
  overflow-x: hidden;
}
body.modal-open { overflow: hidden; }
img { display: block; max-width: 100%; }
a { color: inherit; }
button, input, select { font: inherit; }
button { color: inherit; }
[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;
}
.skip-link {
  position: fixed;
  z-index: 1000;
  left: 1rem;
  top: 1rem;
  transform: translateY(-180%);
  background: #fff;
  border: 3px solid var(--ink);
  padding: .8rem 1rem;
  font-weight: 800;
}
.skip-link:focus { transform: translateY(0); }

.seasonal-bar {
  min-height: 40px;
  padding: .55rem 4vw;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: .75rem;
  background: var(--hero-accent);
  border-bottom: 3px solid var(--ink);
  font-size: .82rem;
  font-weight: 800;
  text-align: center;
}
.seasonal-bar a { text-underline-offset: 3px; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  min-height: 84px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 2rem;
  padding: .85rem clamp(1rem, 4vw, 4rem);
  background: rgba(255, 253, 248, .94);
  border-bottom: 2px solid var(--ink);
  backdrop-filter: blur(16px);
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: .65rem;
  text-decoration: none;
  font-weight: 900;
  line-height: .82;
  letter-spacing: -.06em;
}
.brand-mark {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  background: var(--yellow);
  border: 3px solid var(--ink);
  border-radius: 12px 12px 3px 12px;
  box-shadow: 4px 4px 0 var(--ink);
  font-size: 1.85rem;
  letter-spacing: -.08em;
  transform: rotate(-3deg);
}
.brand-words { font-size: 1.05rem; }
.site-nav {
  justify-self: center;
  display: flex;
  align-items: center;
  gap: clamp(1rem, 3vw, 2.25rem);
}
.site-nav a {
  position: relative;
  text-decoration: none;
  font-size: .92rem;
  font-weight: 800;
}
.site-nav a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 100%;
  bottom: -.35rem;
  height: 3px;
  background: var(--ink);
  transition: right .2s ease;
}
.site-nav a:hover::after,
.site-nav a:focus-visible::after,
.site-nav a[aria-current="page"]::after { right: 0; }
.nav-toggle { display: none; }

.button {
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .8rem 1.15rem;
  border: 2px solid var(--ink);
  border-radius: 999px;
  text-decoration: none;
  font-size: .82rem;
  font-weight: 900;
  cursor: pointer;
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease;
}
.button:hover,
.button:focus-visible { transform: translateY(-2px); box-shadow: 4px 5px 0 var(--ink); }
.button-dark { color: #fff; background: var(--ink); }
.button-bright { background: var(--yellow); }
.button-ghost { background: rgba(255,255,255,.55); }
.button-light { background: #fff; color: var(--ink); }

.eyebrow {
  margin: 0 0 .55rem;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
}
h1, h2, h3, p { overflow-wrap: anywhere; }
h1, h2, h3 { margin-top: 0; line-height: .98; letter-spacing: -.045em; }
h1 { font-size: clamp(3rem, 7vw, 7.3rem); }
h2 { font-size: clamp(2rem, 4vw, 4.6rem); }
h3 { font-size: 1.1rem; }

.seasonal-hero {
  position: relative;
  min-height: min(760px, calc(100vh - 124px));
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(420px, 1.1fr);
  align-items: center;
  gap: clamp(2rem, 5vw, 6rem);
  padding: clamp(3rem, 8vw, 7rem) clamp(1.2rem, 6vw, 7rem);
  background:
    radial-gradient(circle at 88% 16%, rgba(255,255,255,.45) 0 8%, transparent 8.5%),
    linear-gradient(115deg, var(--hero-accent) 0 54%, var(--hero-secondary) 54% 100%);
  border-bottom: 3px solid var(--ink);
  isolation: isolate;
  overflow: hidden;
}
.seasonal-hero::before,
.products-intro::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: radial-gradient(rgba(17,17,17,.14) .75px, transparent .75px);
  background-size: 8px 8px;
  opacity: .28;
  mix-blend-mode: multiply;
}
.hero-copy { position: relative; z-index: 2; max-width: 760px; }
.hero-copy h1 { margin-bottom: 1.25rem; }
.hero-copy h1 em {
  display: inline-block;
  padding: 0 .12em .08em;
  background: var(--paper);
  border: 4px solid var(--ink);
  box-shadow: .08em .08em 0 var(--ink);
  font-style: normal;
  transform: rotate(-2deg);
}
.hero-intro {
  max-width: 620px;
  margin: 0 0 1.8rem;
  font-size: clamp(1rem, 1.7vw, 1.35rem);
  font-weight: 650;
}
.hero-actions { display: flex; flex-wrap: wrap; gap: .7rem; }
.hero-gallery {
  position: relative;
  z-index: 2;
  min-height: 560px;
}
.hero-card {
  position: absolute;
  width: clamp(190px, 22vw, 315px);
  aspect-ratio: 1772 / 2506;
  border: 4px solid var(--ink);
  border-radius: 7px;
  background: #fff;
  box-shadow: 10px 14px 0 rgba(17,17,17,.95), var(--shadow);
  overflow: hidden;
  cursor: pointer;
  transition: transform .22s ease;
}
.hero-card img { width: 100%; height: 100%; object-fit: contain; background: #fff; }
.hero-card:nth-child(1) { left: 4%; top: 9%; transform: rotate(-9deg); }
.hero-card:nth-child(2) { left: 35%; top: 0; z-index: 2; transform: rotate(4deg) scale(1.08); }
.hero-card:nth-child(3) { right: 1%; top: 18%; transform: rotate(10deg); }
.hero-card:hover,
.hero-card:focus-visible { z-index: 5; transform: rotate(0) scale(1.08); }
.hero-card .hero-badge {
  position: absolute;
  left: .55rem;
  top: .55rem;
  padding: .34rem .55rem;
  background: var(--yellow);
  border: 2px solid var(--ink);
  border-radius: 999px;
  font-size: .62rem;
  font-weight: 900;
  text-transform: uppercase;
}
.hero-scribble {
  position: absolute;
  z-index: 1;
  right: -1.8rem;
  bottom: -1.8rem;
  font-size: clamp(5rem, 13vw, 13rem);
  line-height: 1;
  font-weight: 900;
  letter-spacing: -.09em;
  opacity: .09;
  transform: rotate(-8deg);
  user-select: none;
}

.finder {
  display: grid;
  grid-template-columns: minmax(240px, .65fr) minmax(0, 1.35fr);
  gap: 2rem 4rem;
  padding: clamp(3rem, 7vw, 6rem) clamp(1.2rem, 6vw, 7rem);
  background: var(--paper);
  border-bottom: 3px solid var(--ink);
}
.finder h2 { max-width: 760px; margin-bottom: 0; }
#cardFinder {
  align-self: center;
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  align-items: end;
  gap: .8rem;
}
#cardFinder label { display: grid; gap: .35rem; font-size: .72rem; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; }
select, input[type="search"] {
  width: 100%;
  min-height: 50px;
  color: var(--ink);
  background: #fff;
  border: 2px solid var(--ink);
  border-radius: 13px;
  padding: .7rem .9rem;
  outline: none;
}
select:focus, input[type="search"]:focus { box-shadow: 4px 4px 0 var(--yellow); }
.quick-links {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  padding-top: .4rem;
}
.quick-link,
.filter-button,
.age-button {
  min-height: 38px;
  padding: .55rem .85rem;
  border: 2px solid var(--ink);
  border-radius: 999px;
  background: transparent;
  font-size: .72rem;
  font-weight: 850;
  cursor: pointer;
  text-decoration: none;
}
.quick-link:hover,
.quick-link:focus-visible,
.filter-button:hover,
.filter-button:focus-visible,
.age-button:hover,
.age-button:focus-visible,
.filter-button.is-active,
.age-button.is-active { background: var(--yellow); box-shadow: 3px 3px 0 var(--ink); }

.streaming-shell {
  padding: clamp(3rem, 6vw, 6rem) 0;
  background: #171717;
  color: #fff;
  overflow: hidden;
}
.home-streams { border-bottom: 3px solid var(--ink); }
.card-rail { margin-bottom: clamp(2.2rem, 5vw, 4.4rem); }
.card-rail:last-child { margin-bottom: 0; }
.rail-heading {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
  padding: 0 clamp(1.2rem, 5vw, 5rem) .9rem;
}
.rail-heading h2 { margin: 0; font-size: clamp(1.55rem, 3vw, 3rem); }
.rail-heading p { max-width: 520px; margin: .35rem 0 0; color: rgba(255,255,255,.72); font-size: .85rem; }
.rail-controls { display: flex; gap: .45rem; }
.rail-arrow {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  color: #fff;
  background: rgba(255,255,255,.08);
  border: 2px solid rgba(255,255,255,.55);
  border-radius: 50%;
  cursor: pointer;
  font-size: 1.4rem;
}
.rail-arrow:hover,
.rail-arrow:focus-visible { color: var(--ink); background: var(--yellow); border-color: var(--ink); }
.rail-track {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: clamp(170px, 18vw, 270px);
  gap: clamp(.7rem, 1.4vw, 1.25rem);
  padding: .65rem clamp(1.2rem, 5vw, 5rem) 1.9rem;
  overflow-x: auto;
  overscroll-behavior-inline: contain;
  scroll-snap-type: inline mandatory;
  scrollbar-width: none;
}
.rail-track::-webkit-scrollbar { display: none; }
.poster-card {
  position: relative;
  scroll-snap-align: start;
  min-width: 0;
  aspect-ratio: 1772 / 2506;
  border: 0;
  padding: 0;
  border-radius: 8px;
  background: #2b2b2b;
  box-shadow: 0 10px 24px rgba(0,0,0,.35);
  overflow: hidden;
  cursor: pointer;
  text-align: left;
  isolation: isolate;
  transition: transform .2s ease, box-shadow .2s ease;
}
.poster-card img { width: 100%; height: 100%; object-fit: contain; background: #f2eee5; transition: transform .35s ease; }
.poster-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(to top, rgba(0,0,0,.95) 0, rgba(0,0,0,.62) 30%, transparent 62%);
  opacity: 0;
  transition: opacity .2s ease;
}
.poster-card:hover,
.poster-card:focus-visible { z-index: 4; transform: translateY(-9px) scale(1.045); box-shadow: 0 24px 44px rgba(0,0,0,.6); outline: 3px solid var(--yellow); outline-offset: 3px; }
.poster-card:hover img,
.poster-card:focus-visible img { transform: scale(1.035); }
.poster-card:hover::after,
.poster-card:focus-visible::after { opacity: 1; }
.poster-overlay {
  position: absolute;
  z-index: 2;
  left: .85rem;
  right: .85rem;
  bottom: .85rem;
  color: #fff;
  opacity: 0;
  transform: translateY(.65rem);
  transition: opacity .2s ease, transform .2s ease;
}
.poster-card:hover .poster-overlay,
.poster-card:focus-visible .poster-overlay { opacity: 1; transform: translateY(0); }
.poster-overlay strong { display: block; margin-bottom: .35rem; font-size: .9rem; line-height: 1.05; }
.poster-overlay span { display: block; color: rgba(255,255,255,.78); font-size: .67rem; line-height: 1.35; }
.poster-badge {
  position: absolute;
  z-index: 3;
  top: .55rem;
  left: .55rem;
  padding: .3rem .48rem;
  color: var(--ink);
  background: var(--yellow);
  border: 2px solid var(--ink);
  border-radius: 999px;
  font-size: .58rem;
  font-weight: 900;
  text-transform: uppercase;
}
.poster-lock {
  position: absolute;
  z-index: 3;
  right: .45rem;
  bottom: .45rem;
  width: 25px;
  height: 25px;
  display: grid;
  place-items: center;
  color: #fff;
  background: rgba(0,0,0,.62);
  border-radius: 50%;
  font-size: .7rem;
}
.section-cta { padding: 0 clamp(1.2rem, 5vw, 5rem); text-align: center; }
.streaming-shell .button-dark { border-color: #fff; }

.split-story {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-bottom: 3px solid var(--ink);
}
.story-panel { min-height: 480px; padding: clamp(3rem, 7vw, 7rem); }
.story-panel h2 { max-width: 720px; }
.story-panel p { max-width: 650px; font-weight: 600; }
.story-bright { background: var(--yellow); border-right: 3px solid var(--ink); }
.story-dark { color: #fff; background: var(--ink); }
.contact-section { padding: clamp(4rem, 9vw, 9rem) clamp(1.2rem, 10vw, 12rem); background: var(--pink); border-bottom: 3px solid var(--ink); text-align: center; }
.contact-section h2 { margin-bottom: 1rem; }
.contact-section p { max-width: 700px; margin: 0 auto 1.5rem; font-weight: 650; }

.products-intro {
  position: relative;
  min-height: 360px;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(260px, .8fr);
  align-items: center;
  gap: 2rem;
  padding: clamp(3rem, 7vw, 7rem) clamp(1.2rem, 6vw, 7rem);
  background: linear-gradient(115deg, var(--hero-accent) 0 68%, var(--hero-secondary) 68% 100%);
  border-bottom: 3px solid var(--ink);
  overflow: hidden;
}
.products-intro > * { position: relative; z-index: 1; }
.products-intro h1 { max-width: 900px; margin-bottom: .8rem; font-size: clamp(3rem, 6vw, 6.4rem); }
.products-intro h1 em {
  display: inline-block;
  padding: 0 .12em .08em;
  background: var(--paper);
  border: 4px solid var(--ink);
  box-shadow: .08em .08em 0 var(--ink);
  font-style: normal;
  transform: rotate(-2deg);
}
.products-intro p[data-products-copy] { max-width: 680px; margin: 0; font-size: clamp(1rem, 1.6vw, 1.25rem); font-weight: 650; }
.mini-stack { position: relative; min-height: 260px; }
.mini-stack img {
  position: absolute;
  width: clamp(120px, 14vw, 190px);
  aspect-ratio: 1772 / 2506;
  object-fit: cover;
  border: 3px solid var(--ink);
  background: #fff;
  box-shadow: 8px 10px 0 var(--ink);
}
.mini-stack img:nth-child(1) { left: 2%; top: 24px; transform: rotate(-10deg); }
.mini-stack img:nth-child(2) { left: 34%; top: 0; z-index: 2; transform: rotate(3deg); }
.mini-stack img:nth-child(3) { right: 0; top: 34px; transform: rotate(11deg); }
.browse-tools {
  position: sticky;
  top: 84px;
  z-index: 35;
  padding: 1.5rem clamp(1.2rem, 5vw, 5rem) 1.2rem;
  background: rgba(255,253,248,.97);
  border-bottom: 3px solid var(--ink);
  backdrop-filter: blur(14px);
}
.browse-heading { display: grid; grid-template-columns: 1fr minmax(280px, 460px); align-items: end; gap: 1.5rem; }
.browse-heading h2 { margin: 0; font-size: clamp(1.65rem, 3vw, 3rem); }
.search-box { position: relative; display: block; }
.search-box input { padding-right: 3rem; }
.search-box > span[aria-hidden] { position: absolute; right: 1rem; top: 50%; transform: translateY(-50%); font-size: 1.6rem; font-weight: 900; }
.filter-strip, .age-strip { display: flex; align-items: center; gap: .5rem; margin-top: 1rem; overflow-x: auto; scrollbar-width: none; padding: .2rem .15rem .55rem; }
.filter-strip::-webkit-scrollbar, .age-strip::-webkit-scrollbar { display: none; }
.filter-button, .age-button { flex: 0 0 auto; background: #fff; }
.age-strip > span { flex: 0 0 auto; margin-right: .25rem; font-size: .72rem; font-weight: 900; text-transform: uppercase; }
.result-summary { min-height: 1.2rem; margin-top: .5rem; color: var(--muted); font-size: .76rem; font-weight: 750; }
.product-streams { min-height: 520px; }
.filtered-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: clamp(.75rem, 1.7vw, 1.4rem);
  padding: 0 clamp(1.2rem, 5vw, 5rem);
}
.filtered-grid .poster-card { width: 100%; }
.no-results { max-width: 760px; margin: 2rem auto; padding: 2rem; color: var(--ink); background: var(--yellow); border: 3px solid var(--ink); text-align: center; font-weight: 850; }

.detail-modal { position: fixed; inset: 0; z-index: 200; display: grid; place-items: center; padding: clamp(.6rem, 3vw, 2.2rem); }
.modal-backdrop { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; background: rgba(0,0,0,.78); backdrop-filter: blur(12px); cursor: pointer; }
.modal-card {
  position: relative;
  z-index: 1;
  width: min(1040px, 96vw);
  max-height: min(860px, 92vh);
  display: grid;
  grid-template-columns: minmax(280px, .9fr) minmax(340px, 1.1fr);
  background: var(--paper);
  border: 3px solid var(--ink);
  border-radius: 22px;
  box-shadow: 14px 16px 0 var(--yellow);
  overflow: hidden;
}
.modal-art { min-height: 540px; display: grid; place-items: center; padding: clamp(1rem, 3vw, 2.2rem); background: #292929; }
.modal-art img { max-height: 72vh; width: auto; border: 2px solid rgba(255,255,255,.7); box-shadow: 0 18px 38px rgba(0,0,0,.45); }
.modal-copy { align-self: center; padding: clamp(2rem, 5vw, 5rem); overflow-y: auto; }
.modal-copy h2 { margin-bottom: 1rem; font-size: clamp(2rem, 4vw, 4.3rem); }
.modal-copy > p:not(.eyebrow):not(.sample-note) { font-weight: 600; }
.modal-tags { display: flex; flex-wrap: wrap; gap: .4rem; margin: 1.2rem 0; }
.modal-tags span { padding: .4rem .58rem; background: var(--cream); border: 1.5px solid var(--ink); border-radius: 999px; font-size: .67rem; font-weight: 800; }
.sample-note { color: var(--muted); font-size: .7rem; }
.modal-close {
  position: absolute;
  z-index: 3;
  right: .8rem;
  top: .8rem;
  width: 42px;
  height: 42px;
  border: 2px solid var(--ink);
  border-radius: 50%;
  background: var(--yellow);
  font-size: 1.5rem;
  font-weight: 900;
  cursor: pointer;
}
.modal-step {
  position: absolute;
  z-index: 3;
  top: 50%;
  width: 46px;
  height: 60px;
  border: 2px solid var(--ink);
  background: var(--yellow);
  font-size: 2rem;
  cursor: pointer;
  transform: translateY(-50%);
}
.modal-prev { left: .35rem; border-radius: 0 16px 16px 0; }
.modal-next { right: .35rem; border-radius: 16px 0 0 16px; }

.protected-artwork, .protected-artwork img { user-select: none; -webkit-user-drag: none; }
.site-footer {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 2rem;
  padding: 2.5rem clamp(1.2rem, 5vw, 5rem);
  color: #fff;
  background: var(--ink);
}
.footer-brand { display: flex; flex-direction: column; gap: .35rem; }
.footer-brand-logo { display: block; width: min(230px, 52vw); height: auto; }
.site-footer strong { font-size: 1.35rem; }
.site-footer p { margin: .25rem 0 0; color: rgba(255,255,255,.65); font-size: .78rem; }
.site-footer nav { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: .9rem 1.4rem; }
.site-footer a { color: #fff; font-size: .76rem; font-weight: 750; text-underline-offset: 3px; }

@media (max-width: 980px) {
  .site-header { grid-template-columns: auto auto 1fr; gap: 1rem; }
  .nav-toggle {
    display: grid;
    width: 44px;
    height: 44px;
    place-content: center;
    gap: 5px;
    background: #fff;
    border: 2px solid var(--ink);
    border-radius: 11px;
    cursor: pointer;
  }
  .nav-toggle > span:not(.sr-only) { width: 19px; height: 2px; background: var(--ink); }
  .site-nav {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    display: none;
    padding: 1rem clamp(1rem, 4vw, 4rem);
    background: var(--paper);
    border-bottom: 3px solid var(--ink);
  }
  .site-nav.is-open { display: flex; }
  .header-shop { justify-self: end; }
  .seasonal-hero { grid-template-columns: 1fr; min-height: auto; }
  .hero-copy { max-width: 850px; }
  .hero-gallery { min-height: 500px; }
  .hero-card { width: clamp(175px, 30vw, 270px); }
  .hero-card:nth-child(1) { left: 7%; }
  .hero-card:nth-child(2) { left: 37%; }
  .hero-card:nth-child(3) { right: 7%; }
  .finder { grid-template-columns: 1fr; }
  #cardFinder { grid-template-columns: 1fr 1fr; }
  #cardFinder .button { grid-column: 1 / -1; }
  .quick-links { grid-column: auto; }
  .products-intro { grid-template-columns: 1fr; }
  .mini-stack { display: none; }
  .browse-tools { top: 84px; }
}

@media (max-width: 720px) {
  .seasonal-bar { font-size: .7rem; }
  .site-header { min-height: 68px; padding: .6rem 1rem; }
  .brand-mark { width: 40px; height: 40px; font-size: 1.5rem; box-shadow: 3px 3px 0 var(--ink); }
  .brand-words { display: none; }
  .header-shop { min-height: 40px; padding: .65rem .8rem; font-size: .68rem; }
  .browse-tools { top: 68px; }
  .seasonal-hero { padding: 3rem 1rem 2.5rem; gap: 1rem; }
  .hero-copy h1 { font-size: clamp(3rem, 15vw, 5.4rem); }
  .hero-intro { font-size: .98rem; }
  .hero-actions .button { flex: 1 1 180px; }
  .hero-gallery { min-height: 350px; margin-top: .6rem; }
  .hero-card { width: clamp(128px, 41vw, 185px); border-width: 3px; box-shadow: 6px 8px 0 var(--ink); }
  .hero-card:nth-child(1) { left: 1%; top: 30px; }
  .hero-card:nth-child(2) { left: 30%; top: 0; }
  .hero-card:nth-child(3) { right: 0; top: 46px; }
  .hero-scribble { display: none; }
  .finder { padding: 3rem 1rem; gap: 1.5rem; }
  #cardFinder { grid-template-columns: 1fr; }
  #cardFinder .button { grid-column: auto; }
  .quick-links { flex-wrap: nowrap; overflow-x: auto; padding-bottom: .5rem; scrollbar-width: none; }
  .quick-link { flex: 0 0 auto; }
  .rail-heading { align-items: center; padding-inline: 1rem; }
  .rail-heading p { display: none; }
  .rail-controls { display: none; }
  .rail-track { grid-auto-columns: min(45vw, 190px); padding-inline: 1rem; gap: .75rem; }
  .poster-card:hover,
  .poster-card:focus-visible { transform: none; }
  .poster-card::after { opacity: .2; }
  .poster-overlay { display: none; }
  .poster-badge { font-size: .52rem; }
  .split-story { grid-template-columns: 1fr; }
  .story-panel { min-height: 0; padding: 3.5rem 1rem; }
  .story-bright { border-right: 0; border-bottom: 3px solid var(--ink); }
  .contact-section { padding: 4rem 1rem; }
  .products-intro { min-height: 280px; padding: 3rem 1rem; }
  .products-intro h1 { font-size: clamp(3rem, 14vw, 5rem); }
  .browse-tools { padding: 1.1rem 1rem .8rem; }
  .browse-heading { grid-template-columns: 1fr; gap: .9rem; }
  .filter-strip, .age-strip { margin-top: .65rem; }
  .product-streams { padding-top: 2.5rem; }
  .filtered-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); padding-inline: 1rem; gap: .7rem; }
  .detail-modal { padding: 0; align-items: end; }
  .modal-card {
    width: 100%;
    max-height: 94vh;
    grid-template-columns: 1fr;
    border-radius: 24px 24px 0 0;
    box-shadow: none;
    overflow-y: auto;
  }
  .modal-art { min-height: 0; height: 53vh; padding: 1.1rem; }
  .modal-art img { max-height: 49vh; }
  .modal-copy { align-self: auto; padding: 1.7rem 1.2rem 2rem; overflow: visible; }
  .modal-copy h2 { font-size: clamp(2rem, 10vw, 3.5rem); }
  .modal-step { top: 27vh; width: 40px; height: 52px; }
  .modal-close { position: fixed; right: .7rem; top: .7rem; }
  .site-footer { align-items: flex-start; flex-direction: column; padding: 2rem 1rem; }
  .site-footer nav { justify-content: flex-start; }
  .footer-brand-logo { width: min(220px, 70vw); }
}

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

/* v43 brand, seasonal campaign and compact catalogue controls */
.brand {
  position: relative;
  min-width: 250px;
  padding: .1rem 0;
  letter-spacing: normal;
  line-height: 1;
}
.brand-logo { display: block; height: auto; }
.brand-logo-desktop { width: 250px; max-width: min(38vw, 250px); }
.brand-logo-mobile { display: none; width: 62px; }
.brand-season {
  position: absolute;
  right: -1.15rem;
  bottom: -.42rem;
  max-width: 120px;
  padding: .22rem .48rem;
  border: 2px solid var(--ink);
  border-radius: 999px;
  background: var(--hero-accent);
  box-shadow: 2px 2px 0 var(--ink);
  font-size: .5rem;
  font-weight: 900;
  letter-spacing: .07em;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
  transform: rotate(-2deg);
}
.seasonal-lockup {
  width: fit-content;
  max-width: 100%;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .38rem;
  margin: 0 0 1.15rem;
  padding: .4rem .48rem;
  border: 2px solid var(--ink);
  border-radius: 999px;
  background: rgba(255,253,248,.88);
  box-shadow: 4px 4px 0 var(--ink);
  font-size: .61rem;
  font-weight: 900;
  letter-spacing: .07em;
  text-transform: uppercase;
}
.seasonal-lockup > span { padding: .1rem .35rem; }
.seasonal-lockup-brand {
  color: #fff;
  background: var(--ink);
  border-radius: 999px;
}
.seasonal-lockup-date {
  border-left: 1px solid rgba(17,17,17,.35);
}
.seasonal-doodles {
  position: absolute !important;
  inset: 0;
  z-index: 0 !important;
  pointer-events: none;
  overflow: hidden;
}
.seasonal-doodles span {
  position: absolute;
  display: block;
  color: transparent;
  -webkit-text-stroke: 2px rgba(17,17,17,.16);
  font-size: clamp(4rem, 9vw, 9rem);
  font-weight: 900;
  letter-spacing: -.08em;
  line-height: .8;
  opacity: .55;
  transform: rotate(-8deg);
}
.seasonal-doodles span:nth-child(1) { left: -1.5%; top: 6%; }
.seasonal-doodles span:nth-child(2) { right: -2%; bottom: 4%; transform: rotate(7deg); }
.seasonal-doodles span:nth-child(3) { right: 43%; top: 8%; font-size: clamp(3rem, 6vw, 6rem); transform: rotate(12deg); }
.hero-copy, .hero-gallery, .hero-scribble, .products-intro > div:not(.seasonal-doodles) { position: relative; z-index: 2; }

.browse-tools {
  padding: .55rem clamp(1rem, 4vw, 4rem) .4rem;
}
.browse-toolbar {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto minmax(220px, 320px);
  align-items: center;
  gap: .65rem;
}
.filter-lead {
  display: grid;
  gap: 0;
  padding-right: .25rem;
  white-space: nowrap;
}
.filter-lead .eyebrow { margin: 0; font-size: .55rem; }
.filter-lead strong { font-size: .82rem; line-height: 1; }
.browse-tools .filter-strip,
.browse-tools .age-strip {
  min-width: 0;
  margin: 0;
  padding: .2rem .15rem .32rem;
  gap: .38rem;
}
.browse-tools .filter-button,
.browse-tools .age-button,
.age-filter-toggle {
  min-height: 34px;
  padding: .4rem .68rem;
  border: 2px solid var(--ink);
  border-radius: 999px;
  background: #fff;
  font-size: .65rem;
  font-weight: 850;
  cursor: pointer;
  white-space: nowrap;
}
.age-filter-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  background: var(--cream);
}
.age-filter-toggle:hover,
.age-filter-toggle:focus-visible,
.age-filter-toggle.is-open { background: var(--hero-accent); box-shadow: 3px 3px 0 var(--ink); }
.toggle-symbol { font-size: 1rem; line-height: .7; }
.browse-tools .search-box input { min-height: 39px; padding: .48rem 2.6rem .48rem .75rem; border-radius: 999px; font-size: .75rem; }
.browse-tools .search-box > span[aria-hidden] { right: .85rem; font-size: 1.25rem; }
.age-panel { margin-top: .25rem; border-top: 1px solid var(--line); }
.age-panel .age-strip { padding-top: .4rem; }
.age-panel .age-strip > span { font-size: .58rem; }
.browse-tools .result-summary { min-height: 0; margin: .08rem 0 0; font-size: .62rem; line-height: 1.2; }

@media (max-width: 1080px) {
  .browse-tools { position: static; }
  .browse-toolbar { grid-template-columns: auto minmax(0, 1fr) auto; }
  .browse-toolbar .search-box { grid-column: 1 / -1; }
}

@media (max-width: 720px) {
  .brand { min-width: 62px; padding: 0; }
  .brand-logo-desktop { display: none; }
  .brand-logo-mobile { display: block; width: 60px; }
  .brand-season { display: none; }
  .seasonal-lockup { margin-bottom: .9rem; font-size: .53rem; box-shadow: 3px 3px 0 var(--ink); }
  .seasonal-lockup-date { display: none; }
  .seasonal-doodles span { -webkit-text-stroke-width: 1.5px; opacity: .42; }
  .seasonal-doodles span:nth-child(3) { right: 6%; top: 32%; }
  .browse-tools { position: static; padding: .55rem .75rem .4rem; }
  .browse-toolbar { grid-template-columns: auto minmax(0, 1fr); gap: .45rem; }
  .filter-lead { display: none; }
  .browse-toolbar .filter-strip { grid-column: 1 / -1; grid-row: 1; }
  .age-filter-toggle { grid-column: 1; grid-row: 2; }
  .browse-toolbar .search-box { grid-column: 2; grid-row: 2; }
  .browse-tools .filter-button,
  .browse-tools .age-button,
  .age-filter-toggle { min-height: 32px; padding: .35rem .62rem; font-size: .61rem; }
  .browse-tools .search-box input { min-height: 36px; }
  .browse-tools .result-summary { margin-top: .18rem; }
}

/* v47: the seasonal edit badge was removed so the business logo stays clear. */
.brand-season { display: none !important; }


/* v48: tighter homepage hero, readable footer logo and clearly distinct catalogue page */
.site-nav a[aria-current="page"] {
  text-decoration: underline;
  text-decoration-thickness: 3px;
  text-underline-offset: 7px;
}

@media (min-width: 981px) {
  .seasonal-hero {
    min-height: 590px;
    grid-template-columns: minmax(0, .95fr) minmax(390px, 1.05fr);
    gap: clamp(1.5rem, 4vw, 4.5rem);
    padding-top: clamp(2.4rem, 4.5vw, 4.5rem);
    padding-bottom: clamp(2.4rem, 4.5vw, 4.5rem);
  }
  .hero-gallery { min-height: 440px; }
  .hero-card { width: clamp(180px, 19vw, 270px); }
  .hero-card:nth-child(1) { top: 7%; }
  .hero-card:nth-child(2) { top: 0; }
  .hero-card:nth-child(3) { top: 13%; }
}

.footer-brand-logo {
  width: min(250px, 55vw);
  padding: .6rem .8rem;
  background: #fff;
  border: 2px solid rgba(255,255,255,.75);
  border-radius: 12px;
}

.catalogue-intro {
  min-height: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: clamp(1.5rem, 5vw, 5rem);
  padding: clamp(2rem, 4vw, 3.8rem) clamp(1.2rem, 6vw, 7rem);
  background: var(--paper);
  border-bottom: 3px solid var(--ink);
  overflow: visible;
}
.catalogue-intro::before { display: none; }
.catalogue-intro-copy { max-width: 850px; }
.catalogue-intro h1 {
  max-width: none;
  margin: 0 0 .7rem;
  font-size: clamp(2.7rem, 5.2vw, 5.4rem);
}
.catalogue-intro p:not(.eyebrow) {
  max-width: 720px;
  margin: 0;
  font-size: clamp(.95rem, 1.25vw, 1.12rem);
  font-weight: 650;
  line-height: 1.5;
}
.products-seasonal-link {
  flex: 0 0 min(330px, 30vw);
  display: grid;
  gap: .35rem;
  padding: 1.15rem 1.25rem;
  color: var(--ink);
  background: var(--hero-accent);
  border: 3px solid var(--ink);
  border-radius: 18px;
  box-shadow: 7px 8px 0 var(--ink);
  text-decoration: none;
  transform: rotate(1deg);
  transition: transform .16s ease, box-shadow .16s ease;
}
.products-seasonal-link:hover,
.products-seasonal-link:focus-visible {
  transform: rotate(0) translateY(-2px);
  box-shadow: 8px 10px 0 var(--ink);
}
.products-seasonal-link span {
  font-size: .68rem;
  font-weight: 850;
  letter-spacing: .07em;
  text-transform: uppercase;
}
.products-seasonal-link strong {
  font-size: clamp(1rem, 1.6vw, 1.3rem);
  line-height: 1.05;
}
.product-streams { padding-top: 1.4rem; }

@media (max-width: 980px) {
  .catalogue-intro { align-items: flex-start; flex-direction: column; }
  .products-seasonal-link { flex-basis: auto; width: min(100%, 420px); }
}

@media (max-width: 720px) {
  .seasonal-hero {
    padding-top: 2.25rem;
    padding-bottom: 1.8rem;
  }
  .hero-gallery { min-height: 310px; }
  .catalogue-intro { padding: 2rem 1rem 1.75rem; }
  .catalogue-intro h1 { font-size: clamp(2.55rem, 13vw, 4.2rem); }
  .footer-brand-logo { width: min(235px, 76vw); }
}


/* legacy external-card link styles retained for compatibility */
.site-header { grid-template-columns: auto 1fr; }
.hero-badge-exclusive,
.poster-badge-exclusive {
  color: #111;
  background: #ff8fb1;
  box-shadow: 3px 3px 0 #111;
}
.poster-badge-exclusive {
  max-width: calc(100% - 1.1rem);
  white-space: nowrap;
}
@media (max-width: 980px) {
  .site-header { grid-template-columns: auto auto 1fr; }
}
@media (max-width: 720px) {
  .hero-badge-exclusive, .poster-badge-exclusive { font-size: .48rem; }
}


/* v50: denser desktop homepage and non-repeating homepage rails */
@media (min-width: 981px) {
  body[data-page="home"] .seasonal-hero {
    min-height: 500px;
    grid-template-columns: minmax(0, .92fr) minmax(420px, 1.08fr);
    gap: clamp(1.5rem, 3.2vw, 3.75rem);
    padding-top: clamp(2rem, 3.2vw, 3.25rem);
    padding-bottom: clamp(2rem, 3.2vw, 3.25rem);
  }
  body[data-page="home"] .hero-copy h1 {
    margin-bottom: .85rem;
    font-size: clamp(3.2rem, 5.5vw, 6rem);
  }
  body[data-page="home"] .hero-intro {
    margin-bottom: 1.25rem;
  }
  body[data-page="home"] .hero-gallery {
    min-height: 370px;
  }
  body[data-page="home"] .hero-card {
    width: clamp(170px, 16.5vw, 238px);
  }
  body[data-page="home"] .hero-card:nth-child(1) { top: 8%; }
  body[data-page="home"] .hero-card:nth-child(2) { top: 0; }
  body[data-page="home"] .hero-card:nth-child(3) { top: 13%; }

  body[data-page="home"] .finder {
    grid-template-columns: minmax(340px, .72fr) minmax(0, 1.28fr);
    gap: 1.25rem 3rem;
    padding: 2.25rem clamp(1.2rem, 6vw, 7rem) 2.4rem;
  }
  body[data-page="home"] .finder h2 {
    max-width: 640px;
    font-size: clamp(2.45rem, 3.15vw, 3.75rem);
    line-height: .94;
  }
  body[data-page="home"] #cardFinder {
    gap: .7rem;
  }
  body[data-page="home"] .quick-links {
    gap: .45rem;
    padding-top: 0;
  }
  body[data-page="home"] .quick-link {
    min-height: 35px;
    padding: .45rem .72rem;
    font-size: .67rem;
  }
  body[data-page="home"] .streaming-shell {
    padding-top: 2.5rem;
  }
}


/* v51: compact hero, clean watermarks and non-overlapping monthly status tags */
.hero-scribble { display: none !important; }
.hero-badge, .poster-badge, .poster-lock { display: none !important; }

/* Status labels sit outside the artwork so they never cover card wording. */
.poster-card { overflow: visible; }
.poster-card img,
.poster-card::after { border-radius: 8px; }
.poster-status {
  position: absolute;
  z-index: 6;
  top: calc(100% + .48rem);
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  pointer-events: none;
}
.card-status-tag {
  display: inline-flex;
  align-items: center;
  min-height: 25px;
  padding: .28rem .58rem;
  color: #111;
  background: #fff;
  border: 2px solid #111;
  border-radius: 999px;
  box-shadow: 3px 3px 0 #111;
  font-size: .57rem;
  font-weight: 900;
  letter-spacing: .035em;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
}
.card-status-exclusive { background: #ff8fb1; }
.card-status-new { background: #ffd93d; }
.rail-track { padding-bottom: 3.35rem; }

/* Hero status tag is attached below the card rather than sitting on its artwork. */
.hero-card { overflow: visible; }
.hero-card img { border-radius: 3px; }
.hero-card[data-status-tag]::after {
  content: attr(data-status-tag);
  position: absolute;
  z-index: 8;
  left: 50%;
  bottom: -15px;
  min-height: 27px;
  display: inline-flex;
  align-items: center;
  padding: .3rem .65rem;
  color: #111;
  background: #ff8fb1;
  border: 2px solid #111;
  border-radius: 999px;
  box-shadow: 3px 3px 0 #111;
  font-size: .55rem;
  font-weight: 900;
  letter-spacing: .035em;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
  transform: translateX(-50%);
}

@media (min-width: 981px) {
  body[data-page="home"] .seasonal-hero {
    min-height: 0;
    align-items: center;
    padding-top: 1.8rem;
    padding-bottom: 1.9rem;
  }
  body[data-page="home"] .hero-gallery {
    min-height: 292px;
  }
  body[data-page="home"] .hero-card {
    width: clamp(150px, 14vw, 205px);
  }
  body[data-page="home"] .hero-card:nth-child(1) { top: 7%; }
  body[data-page="home"] .hero-card:nth-child(2) { top: 0; }
  body[data-page="home"] .hero-card:nth-child(3) { top: 11%; }
}

@media (max-width: 720px) {
  .card-status-tag { min-height: 23px; padding: .26rem .5rem; font-size: .5rem; }
  .rail-track { padding-bottom: 3.1rem; }
  .hero-card[data-status-tag]::after { bottom: -13px; font-size: .48rem; }
}


/* v52: white brand header, simplified hero and stronger monthly mission strip */
.site-header {
  background: #fff;
  backdrop-filter: none;
}

.seasonal-bar {
  min-height: 48px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  padding: 0;
  color: var(--ink);
  background: var(--hero-accent);
  border-bottom: 3px solid var(--ink);
  font-size: .78rem;
  font-weight: 850;
  text-align: center;
}
.seasonal-bar.has-monthly {
  grid-template-columns: minmax(330px, .82fr) minmax(480px, 1.18fr);
}
.occasion-message,
.monthly-spotlight {
  min-height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .8rem;
  padding: .58rem clamp(.85rem, 2.2vw, 2rem);
}
.occasion-message {
  background: var(--hero-accent);
}
.occasion-message a {
  color: inherit;
  font-weight: 900;
  text-underline-offset: 3px;
}
.monthly-spotlight {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  color: #fff;
  background: #111;
  text-decoration: none;
}
.monthly-spotlight::before {
  content: '';
  position: absolute;
  z-index: -1;
  inset: 0 0 auto;
  height: 6px;
  background: linear-gradient(90deg,#e40303 0 16.66%,#ff8c00 16.66% 33.32%,#ffed00 33.32% 49.98%,#008026 49.98% 66.64%,#004dff 66.64% 83.3%,#750787 83.3% 100%);
}
.monthly-spotlight[data-monthly="black-history"]::before {
  background: linear-gradient(90deg,#111 0 25%,#d71920 25% 50%,#f6c344 50% 75%,#168447 75% 100%);
}
.monthly-label {
  flex: 0 0 auto;
  padding: .25rem .55rem;
  color: #111;
  background: #fff;
  border-radius: 999px;
  font-size: .62rem;
  font-weight: 950;
  letter-spacing: .07em;
  text-transform: uppercase;
}
.monthly-spotlight strong {
  font-size: .76rem;
  letter-spacing: .005em;
}
.monthly-action {
  flex: 0 0 auto;
  color: #fff;
  font-size: .7rem;
  font-weight: 900;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.monthly-spotlight:hover,
.monthly-spotlight:focus-visible {
  background: #272727;
}

body[data-page="home"] .hero-copy > h1:first-child {
  margin-top: 0;
}
body[data-page="home"] .seasonal-hero {
  padding-top: clamp(2rem, 3vw, 3rem);
}

@media (max-width: 980px) {
  .seasonal-bar.has-monthly {
    grid-template-columns: 1fr;
  }
  .occasion-message,
  .monthly-spotlight {
    min-height: 42px;
  }
}

@media (max-width: 720px) {
  .seasonal-bar {
    font-size: .66rem;
  }
  .occasion-message,
  .monthly-spotlight {
    gap: .45rem;
    padding: .5rem .65rem;
  }
  .monthly-label {
    font-size: .52rem;
  }
  .monthly-spotlight strong {
    font-size: .63rem;
  }
  .monthly-action {
    font-size: .58rem;
  }
}

@media (max-width: 480px) {
  .monthly-spotlight {
    flex-wrap: wrap;
    row-gap: .25rem;
  }
  .monthly-spotlight strong {
    order: 3;
    flex-basis: 100%;
  }
}


/* === v53 direct commerce === */
.shop-announcement{min-height:42px;padding:.55rem clamp(1rem,4vw,4rem);display:flex;justify-content:center;align-items:center;gap:1rem;background:var(--yellow);border-bottom:3px solid var(--ink);font-size:.8rem;text-align:center}.shop-announcement span{font-weight:650}.basket-nav{display:inline-flex!important;gap:.45rem;align-items:center}.basket-count{min-width:1.55rem;height:1.55rem;display:inline-grid;place-items:center;border:2px solid var(--ink);border-radius:999px;background:var(--yellow);font-size:.68rem;line-height:1}.footer-small{max-width:470px;color:#d6d6d6;font-size:.8rem}.modal-actions{display:flex;flex-direction:column;align-items:flex-start;gap:.8rem}.modal-external-link{font-size:.78rem;font-weight:800;text-underline-offset:3px}.commerce-hero{position:relative;display:flex;align-items:center;justify-content:space-between;gap:2rem;padding:clamp(3rem,7vw,6rem) clamp(1.2rem,6vw,7rem);background:linear-gradient(115deg,var(--pink),var(--yellow));border-bottom:3px solid var(--ink);overflow:hidden}.commerce-hero::after{content:'BOLD';position:absolute;right:-.05em;bottom:-.28em;font-size:clamp(7rem,20vw,20rem);font-weight:900;letter-spacing:-.11em;opacity:.08}.commerce-hero>div{position:relative;z-index:1;max-width:850px}.commerce-hero h1{margin-bottom:1rem}.commerce-hero p:not(.eyebrow){max-width:720px;font-size:clamp(1rem,1.7vw,1.25rem);font-weight:650}.commerce-hero.compact{padding-block:clamp(2.8rem,5vw,4.5rem)}.commerce-hero.compact h1{font-size:clamp(2.8rem,6vw,6rem)}.commerce-hero-sticker{position:relative;z-index:2;flex:0 0 auto;min-width:150px;padding:1.2rem;background:#fff;border:4px solid var(--ink);box-shadow:8px 8px 0 var(--ink);transform:rotate(4deg);font-size:2rem;font-weight:900;text-align:center}.commerce-hero-sticker small{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.12em}.commerce-section{padding:clamp(2.5rem,6vw,5.5rem) clamp(1rem,5vw,5rem)}.customiser-layout{max-width:1450px;margin:auto;display:grid;grid-template-columns:minmax(360px,.92fr) minmax(430px,1.08fr);gap:clamp(2rem,5vw,5rem);align-items:start}.preview-panel{position:sticky;top:120px}.preview-tabs{display:flex;gap:.6rem;margin-bottom:1rem}.preview-tab{padding:.7rem 1rem;border:2px solid var(--ink);border-radius:999px;background:#fff;font-weight:900;cursor:pointer}.preview-tab.is-active{background:var(--ink);color:#fff}.front-preview{width:min(520px,100%);aspect-ratio:1772/2506;margin:auto;border:4px solid var(--ink);background:#fff;box-shadow:12px 14px 0 var(--ink),var(--shadow);overflow:hidden}.front-preview img{width:100%;height:100%;object-fit:contain;background:#fff}.inside-preview{width:100%;aspect-ratio:1.42/1;display:grid;grid-template-columns:1fr 1fr;background:#fff;border:4px solid var(--ink);box-shadow:12px 14px 0 var(--ink),var(--shadow)}.inside-page{position:relative;display:grid;place-items:center;padding:clamp(1rem,3vw,2.5rem);overflow:hidden}.inside-left{border-right:2px solid #ddd}.inside-fold-label{font-size:.68rem;color:#999;text-transform:uppercase;letter-spacing:.1em}.inside-message{width:100%;max-width:92%;white-space:pre-wrap;overflow-wrap:anywhere;line-height:1.35}.font-handwritten{font-family:'Caveat','Segoe Print','Comic Sans MS',cursive}.font-classic{font-family:Georgia,serif}.font-clean{font-family:Montserrat,Arial,sans-serif}.align-left{text-align:left}.align-centre{text-align:center}.align-right{text-align:right}.preview-note,.safe-note,.summary-note,.delivery-disclaimer{font-size:.78rem;color:var(--muted);font-weight:600}.preview-note{max-width:560px;margin:1.5rem auto 0}.editor-panel,.checkout-panel{background:#fff;border:3px solid var(--ink);border-radius:var(--radius);padding:clamp(1.2rem,3vw,2.2rem);box-shadow:8px 8px 0 var(--ink)}.editor-panel h2,.checkout-panel h2{font-size:clamp(2rem,4vw,3.5rem);margin-bottom:1rem}.price-badge{display:flex;align-items:baseline;gap:.7rem;margin:1.4rem 0 1.8rem;padding:.9rem 1rem;border:2px solid var(--ink);border-radius:14px;background:var(--yellow)}.price-badge strong{font-size:1.6rem}.price-badge span{font-size:.76rem;font-weight:800}.field{display:grid;gap:.45rem;margin-bottom:1.1rem}.field label{font-size:.78rem;font-weight:900;text-transform:uppercase;letter-spacing:.055em}.optional{font-size:.68rem;color:var(--muted);text-transform:none;letter-spacing:0}.form-control{width:100%;padding:.85rem 1rem;border:2px solid var(--ink);border-radius:12px;background:#fff;color:var(--ink);font:inherit}.form-control:focus{outline:4px solid rgba(113,198,255,.45);outline-offset:1px}.field-help{font-size:.72rem;color:var(--muted);font-weight:600}.two-fields,.address-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.address-grid .wide{grid-column:1/-1}.button-wide{width:100%}.basket-layout,.checkout-layout{max-width:1450px;margin:auto;display:grid;grid-template-columns:minmax(0,1.35fr) minmax(310px,.65fr);gap:clamp(1.5rem,4vw,3rem);align-items:start}.cart-list{display:grid;gap:1.4rem}.basket-item{display:grid;grid-template-columns:150px 1fr auto;gap:1.4rem;padding:1.2rem;background:#fff;border:3px solid var(--ink);border-radius:20px;box-shadow:7px 7px 0 var(--ink)}.basket-item>img{width:150px;aspect-ratio:1772/2506;object-fit:contain;border:2px solid var(--ink);background:#fff}.basket-item h2{font-size:clamp(1.5rem,2.5vw,2.3rem);margin-bottom:.8rem}.message-snippet{white-space:pre-wrap;overflow-wrap:anywhere;padding:1rem;background:var(--cream);border:1px solid var(--line);border-radius:10px;font-family:Georgia,serif}.item-settings{font-size:.73rem;color:var(--muted);text-transform:capitalize}.item-actions{display:flex;gap:1rem}.text-action{border:0;background:transparent;padding:0;color:inherit;font-weight:900;text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px;cursor:pointer}.text-action.danger{color:#a51616}.item-price{font-size:1.15rem}.add-more{margin-top:1.5rem}.empty-basket{padding:3rem;background:#fff;border:3px solid var(--ink);border-radius:22px;box-shadow:8px 8px 0 var(--ink)}.order-summary{position:sticky;top:120px;padding:1.5rem;background:#fff;border:3px solid var(--ink);border-radius:22px;box-shadow:8px 8px 0 var(--ink)}.order-summary h2{font-size:2rem}.summary-line{display:flex;justify-content:space-between;gap:1rem;padding:.7rem 0;border-bottom:1px solid var(--line)}.summary-total{margin:1rem 0;border-top:3px solid var(--ink);border-bottom:0;font-size:1.2rem;font-weight:900}.checkout-panel{margin-bottom:1.5rem;box-shadow:5px 5px 0 var(--ink)}.step-kicker{display:inline-block;margin:0 0 .8rem;padding:.35rem .65rem;background:var(--yellow);border:2px solid var(--ink);border-radius:999px;font-size:.68rem;font-weight:900;text-transform:uppercase}.address-warning{padding:1rem;background:#fff4bf;border:2px solid var(--ink);border-radius:12px}.delivery-choices{display:grid;gap:.8rem}.delivery-choice{display:grid;grid-template-columns:auto 1fr auto;gap:.85rem;align-items:center;padding:1rem;border:2px solid var(--ink);border-radius:14px;cursor:pointer}.delivery-choice:has(input:checked){background:var(--yellow);box-shadow:4px 4px 0 var(--ink)}.delivery-choice input{width:1.2rem;height:1.2rem}.delivery-choice span{display:grid}.delivery-choice small{font-size:.7rem;color:var(--muted);font-weight:600}.check-row{display:flex;gap:.8rem;align-items:flex-start;padding:.9rem 0;font-weight:650}.check-row input{width:1.25rem;height:1.25rem;flex:0 0 auto;margin-top:.15rem}.notice{padding:1rem;border:2px solid var(--ink);border-radius:12px;background:#fff4bf;font-weight:700}.notice.error{background:#ffe2e2;border-color:#a51616}.paypal-box{min-height:100px;margin-top:1rem}.checkout-mini{display:grid;grid-template-columns:46px 1fr auto;gap:.7rem;align-items:center;padding:.75rem 0;border-bottom:1px solid var(--line)}.checkout-mini img{width:46px;aspect-ratio:1772/2506;object-fit:contain;border:1px solid var(--ink)}.checkout-mini div{display:grid}.checkout-mini small{font-size:.65rem;color:var(--muted)}.checkout-mini strong{font-size:.78rem}.band-note{font-size:.68rem;color:var(--muted);font-weight:700}.confirmation-card,.status-card{max-width:940px;margin:0 auto;padding:clamp(1.5rem,5vw,4rem);background:#fff;border:4px solid var(--ink);border-radius:28px;box-shadow:12px 12px 0 var(--ink)}.confirmation-card h1{font-size:clamp(3rem,7vw,6rem)}.confirmation-tick{width:74px;height:74px;display:grid;place-items:center;background:var(--green);border:3px solid var(--ink);border-radius:50%;font-size:2.2rem;font-weight:900}.order-number{font-size:clamp(1.5rem,5vw,3.5rem);font-weight:900;letter-spacing:-.045em;color:#c12668}.status-pill{display:inline-flex;padding:.55rem .9rem;background:var(--yellow);border:2px solid var(--ink);border-radius:999px;font-weight:900}.confirmation-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:1.5rem 0}.confirmation-grid>div,.confirmed-item{padding:1rem;background:var(--cream);border:2px solid var(--ink);border-radius:14px}.confirmed-item{display:grid;gap:.5rem;margin-top:.8rem}.confirmed-item span{font-size:.8rem;color:var(--muted);font-weight:700}.confirmation-actions{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.5rem}.support-line{font-size:.78rem;color:var(--muted)}.track-layout{max-width:1100px;margin:auto;display:grid;grid-template-columns:minmax(300px,.7fr) minmax(0,1.3fr);gap:2rem;align-items:start}.spinner{width:38px;height:38px;margin:3rem auto;border:4px solid #ddd;border-top-color:var(--ink);border-radius:50%;animation:btspin .8s linear infinite}@keyframes btspin{to{transform:rotate(360deg)}}
@media(max-width:1050px){.customiser-layout,.basket-layout,.checkout-layout,.track-layout{grid-template-columns:1fr}.preview-panel,.order-summary{position:static}.site-nav{gap:1rem}.basket-item{grid-template-columns:120px 1fr auto}.basket-item>img{width:120px}}
@media(max-width:760px){.shop-announcement{display:grid;gap:.1rem}.commerce-hero{align-items:flex-start}.commerce-hero-sticker{display:none}.customiser-layout{display:block}.preview-panel{margin-bottom:2.5rem}.inside-preview{aspect-ratio:auto;min-height:390px}.two-fields,.address-grid,.confirmation-grid{grid-template-columns:1fr}.address-grid .wide{grid-column:auto}.basket-item{grid-template-columns:82px 1fr}.basket-item>img{width:82px}.basket-item .item-price{grid-column:1/-1}.delivery-choice{grid-template-columns:auto 1fr}.delivery-choice>b{grid-column:2}.footer-small{display:none}}

.legal-page{padding:clamp(2.5rem,6vw,5rem) 1rem}.legal-document{max-width:920px;margin:auto;padding:clamp(1.3rem,4vw,3.2rem);background:#fff;border:3px solid var(--ink);border-radius:24px;box-shadow:10px 10px 0 var(--ink)}.legal-document h1{font-size:clamp(2.8rem,7vw,6rem)}.legal-document h2{margin-top:2.2rem;font-size:clamp(1.5rem,3vw,2.2rem)}.legal-document p,.legal-document li{line-height:1.75}.legal-updated{font-size:.76rem;color:var(--muted);font-weight:700}.launch-blocker{margin:1.5rem 0;padding:1rem;background:#ffe2e2;border:3px solid #a51616;border-radius:12px}

.admin-shell{margin:0;background:#eee}.admin-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--ink);color:#fff}.admin-header a{color:#fff}.admin-header div{display:flex;gap:1rem;align-items:center}.admin-main{width:min(1480px,calc(100% - 2rem));margin:2rem auto}.admin-login{max-width:480px;margin:6rem auto;padding:2rem;background:#fff;border:3px solid var(--ink);border-radius:22px;box-shadow:9px 9px 0 var(--ink)}.admin-login img{max-width:250px;margin-bottom:1rem}.admin-title{display:flex;justify-content:space-between;gap:1rem;align-items:end;margin-bottom:1.5rem}.admin-title h1,.admin-title h2{margin:0;font-size:clamp(2.5rem,6vw,5rem)}.admin-grid{display:grid;grid-template-columns:270px 1fr;gap:1.5rem}.admin-sidebar,.admin-panel{padding:1.3rem;background:#fff;border:2px solid var(--ink);border-radius:18px}.admin-sidebar{align-self:start;position:sticky;top:1rem}.admin-button{padding:.55rem .8rem;border:2px solid currentColor;border-radius:999px;background:#fff;color:var(--ink);font-weight:900;cursor:pointer}.admin-table-wrap{overflow:auto}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:.85rem .6rem;border-bottom:1px solid #ddd;text-align:left;vertical-align:top}.admin-table th{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em}.production-sheet{padding:1.3rem;background:#fff;border:3px solid var(--ink);border-radius:18px}.admin-address{padding:1.2rem;background:var(--yellow);border:3px solid var(--ink);border-radius:14px}.admin-address h3{font-size:1.8rem;margin:.2rem 0}.admin-meta{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:1rem 0}.admin-meta>div{padding:1rem;background:var(--cream);border-radius:12px}.production-item{display:grid;grid-template-columns:180px 1fr;gap:1.2rem;padding:1.4rem 0;border-top:2px solid var(--ink)}.production-item img{width:180px;aspect-ratio:1772/2506;object-fit:contain;border:2px solid var(--ink)}.copy-box{position:relative;min-height:100px;padding:3rem 1rem 1rem;white-space:pre-wrap;background:var(--cream);border-radius:12px}.copy-btn{position:absolute;right:.6rem;top:.6rem;padding:.4rem .7rem;border:2px solid var(--ink);border-radius:999px;background:#fff;font-weight:900}.admin-update{margin-top:1.5rem}.admin-update h2{font-size:2.2rem}@media(max-width:900px){.admin-grid{grid-template-columns:1fr}.admin-sidebar{position:static}.production-item{grid-template-columns:110px 1fr}.production-item img{width:110px}.admin-meta{grid-template-columns:1fr}}
@media print{.admin-header,.admin-sidebar,.admin-update,#back,.admin-title button,.site-footer{display:none!important}.admin-main{width:100%;margin:0}.admin-panel{border:0;padding:0}.production-sheet{box-shadow:none}}

/* === v55: R2-backed Bold Bundle and automated white-label fulfilment === */
.bold-bundle-banner{display:grid;grid-template-columns:minmax(190px,300px) minmax(0,1fr) auto;align-items:center;gap:clamp(1.2rem,4vw,3.5rem);padding:clamp(1.5rem,4vw,3rem) clamp(1rem,5vw,5rem);background:#fff;border-bottom:3px solid var(--ink);box-shadow:inset 0 -10px 0 var(--yellow)}
.bundle-delivery-van{position:relative;width:100%;max-width:300px;justify-self:center}.bundle-delivery-van img{display:block;width:100%;height:auto;filter:drop-shadow(7px 8px 0 rgba(17,17,17,.18))}.bundle-delivery-van span{position:absolute;right:.35rem;bottom:.25rem;padding:.35rem .55rem;background:#fff;border:2px solid var(--ink);border-radius:999px;font-size:.58rem;font-weight:950;letter-spacing:.08em;transform:rotate(-2deg)}
.bundle-copy h2{max-width:820px;margin:.25rem 0 .65rem;font-size:clamp(2rem,4.7vw,4.7rem);line-height:.92}
.bundle-copy p:last-child{max-width:760px;margin:0;font-weight:650}
.bundle-price{min-width:190px;padding:1rem 1.2rem;display:grid;justify-items:center;background:var(--pink);border:4px solid var(--ink);box-shadow:8px 8px 0 var(--ink);text-align:center;transform:rotate(2deg)}
.bundle-price>span,.bundle-price>small{font-size:.68rem;font-weight:950;letter-spacing:.12em}.bundle-price>strong{font-size:3.4rem;line-height:1}.bundle-price .button{margin-top:.8rem}
.bundle-progress{display:flex;justify-content:space-between;gap:1rem;align-items:center;margin:0 0 1.5rem;padding:1rem 1.2rem;background:var(--yellow);border:3px solid var(--ink);border-radius:16px;box-shadow:5px 5px 0 var(--ink)}
.bundle-progress strong{font-size:1.05rem}.bundle-progress span{font-size:.78rem;font-weight:700;text-align:right}
.saving-line{color:#087438}.item-price small{display:block;font-size:.58rem;font-weight:750;color:var(--muted);white-space:nowrap}.free-delivery-panel{background:linear-gradient(135deg,#fff 0 75%,var(--yellow) 75%)}
.status-tracking{margin-top:1rem;padding:1rem;border:2px solid var(--ink);border-radius:12px;background:#fff}.status-tracking a{font-weight:900}
@media(max-width:900px){.bold-bundle-banner{grid-template-columns:minmax(180px,260px) 1fr}.bundle-price{grid-column:1/-1;width:min(100%,420px);justify-self:center}.bundle-progress{align-items:flex-start;flex-direction:column}.bundle-progress span{text-align:left}}
@media(max-width:600px){.bold-bundle-banner{grid-template-columns:1fr;text-align:center}.bundle-delivery-van{max-width:260px}.bundle-copy h2{font-size:2.35rem}.bundle-price{min-width:0;width:100%}.shop-announcement{flex-direction:column;gap:.15rem}.bundle-progress{margin-inline:-.15rem}}

.product-code{font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#696969;margin:.25rem 0 .5rem}.print-setup-panel{margin:0 0 1.5rem}.print-check-actions{display:flex;gap:.6rem;flex-wrap:wrap}.notice.success{background:#e8f7ed;border-color:#a7d8b5;color:#14532d}

/* touch-friendly inside-message positioning */
.inside-right{display:block;padding:0}.message-safe-area{position:absolute;inset:8%;overflow:hidden}.inside-message{position:absolute;left:calc(50% + var(--message-x,0%));top:calc(50% + var(--message-y,0%));width:92%;max-width:none;transform:translate(-50%,-50%);touch-action:none;cursor:grab;user-select:none;-webkit-user-select:none;transition:font-size .12s ease,transform .08s ease}.inside-message:focus-visible{outline:3px solid var(--blue);outline-offset:5px}.inside-message.is-dragging{cursor:grabbing;transition:none}.message-tools{margin:1.2rem 0;padding:1rem;border:2px solid var(--ink);border-radius:16px;background:var(--cream)}.message-tools legend{padding:0 .45rem;font-size:.78rem;font-weight:900;text-transform:uppercase;letter-spacing:.055em}.message-tool-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;align-items:start}.tool-group{display:grid;gap:.65rem}.tool-label{font-size:.75rem;font-weight:900;text-transform:uppercase;letter-spacing:.055em}.size-controls{display:grid;grid-template-columns:58px minmax(100px,1fr) 58px;gap:.55rem;align-items:center}.touch-control{min-width:52px;min-height:52px;display:grid;place-items:center;border:2px solid var(--ink);border-radius:14px;background:#fff;color:var(--ink);font:900 1.35rem/1 Montserrat,Arial,sans-serif;cursor:pointer;box-shadow:3px 3px 0 var(--ink);touch-action:manipulation}.touch-control:hover,.touch-control:focus-visible{background:var(--yellow);outline:none}.touch-control:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}.touch-control:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none}.tool-status{min-height:44px;display:grid;place-items:center;padding:.45rem .6rem;border:1px solid var(--line);border-radius:10px;background:#fff;font-size:.72rem;font-weight:800;text-align:center}.position-pad{width:174px;display:grid;grid-template-columns:52px 52px 52px;grid-template-rows:52px 52px 52px;gap:6px;grid-template-areas:'. up .' 'left reset right' '. down .'}.move-up{grid-area:up}.move-left{grid-area:left}.move-reset{grid-area:reset;font-size:.85rem}.move-right{grid-area:right}.move-down{grid-area:down}.layout-reset{justify-self:start;margin-top:.35rem}
@media(max-width:760px){.message-tool-grid{grid-template-columns:1fr}.position-pad{margin-inline:auto}.inside-preview .message-safe-area{inset:7%}.touch-control{min-width:56px;min-height:56px}.position-pad{width:186px;grid-template-columns:56px 56px 56px;grid-template-rows:56px 56px 56px}.size-controls{grid-template-columns:64px 1fr 64px}}

/* v57 compact personalisation studio */
body[data-page="personalise"]{background:#f3efe5}
body[data-page="personalise"] .shop-announcement{min-height:34px;padding:.35rem 1rem;font-size:.72rem}
body[data-page="personalise"] .site-header{min-height:64px;padding:.5rem clamp(1rem,3vw,3rem)}
body[data-page="personalise"] .brand-logo-desktop{max-height:46px}
.personalise-main{height:calc(100dvh - 100px);min-height:660px;display:grid;grid-template-rows:auto minmax(0,1fr);overflow:hidden}
.personalise-titlebar{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;padding:.65rem clamp(1rem,2.5vw,2.5rem);background:#fff;border-bottom:2px solid var(--ink)}
.personalise-titlebar>div:first-child{display:grid;grid-template-columns:auto auto;align-items:center;column-gap:1rem;min-width:0}
.personalise-titlebar .text-action{grid-row:1/3;white-space:nowrap}
.personalise-titlebar .eyebrow{margin:0;font-size:.58rem}
.personalise-titlebar h1{grid-column:2;margin:0;font-size:clamp(1.1rem,2vw,1.65rem);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.03em}
.personalise-price{display:grid;grid-template-columns:auto auto;align-items:baseline;column-gap:.7rem;text-align:right;white-space:nowrap}
.personalise-price>span{font-size:.67rem;font-weight:900;color:var(--muted)}
.personalise-price strong{font-size:1.45rem}
.personalise-price small{grid-column:1/-1;font-size:.61rem;font-weight:800;color:var(--muted)}
.personalise-workspace{min-height:0;display:grid;grid-template-columns:minmax(430px,.98fr) minmax(460px,1.02fr);gap:1rem;padding:1rem clamp(.8rem,2vw,1.6rem)}
.compact-preview,.compact-editor{min-height:0;height:100%}
.compact-preview{position:static;display:grid;grid-template-rows:auto minmax(0,1fr) auto;gap:.65rem;padding:0}
.page-switcher{display:flex;gap:.5rem;justify-content:center}
.page-switch{display:inline-flex;align-items:center;gap:.5rem;min-height:40px;padding:.5rem .85rem;border:2px solid var(--ink);border-radius:999px;background:#fff;font-weight:900;cursor:pointer}
.page-switch span{width:1.45rem;height:1.45rem;display:grid;place-items:center;border-radius:50%;background:var(--cream);font-size:.72rem}
.page-switch.is-active{background:var(--ink);color:#fff}.page-switch.is-active span{background:var(--yellow);color:var(--ink)}
.preview-stage{min-height:0;display:grid;place-items:center;padding:.2rem}
.compact-preview .front-preview{height:min(100%,680px);width:auto;max-width:100%;box-shadow:7px 8px 0 var(--ink)}
.compact-preview .inside-preview{width:min(100%,900px);height:auto;max-height:100%;aspect-ratio:3025/2161;box-shadow:7px 8px 0 var(--ink)}
.compact-preview .preview-note{margin:0 auto;text-align:center;font-size:.66rem}
.compact-editor{padding:0;display:grid;grid-template-rows:auto auto minmax(0,1fr) auto;overflow:hidden;box-shadow:6px 6px 0 var(--ink)}
.editor-summary{padding:.7rem 1rem;background:var(--cream);border-bottom:2px solid var(--ink)}
.editor-summary p{margin:0;font-size:.68rem;font-weight:650;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.editor-tabs{display:grid;grid-template-columns:repeat(3,1fr);border-bottom:2px solid var(--ink);background:#fff}
.editor-tab{min-height:48px;padding:.55rem .45rem;border:0;border-right:1px solid var(--line);background:#fff;font-size:.7rem;font-weight:900;cursor:pointer}
.editor-tab:last-child{border-right:0}.editor-tab.is-active{background:var(--yellow);box-shadow:inset 0 -4px 0 var(--ink)}
.editor-panels{min-height:0;overflow:auto;padding:1rem 1.15rem .4rem;overscroll-behavior:contain}
.editor-tab-panel{animation:bt-panel-in .16s ease}@keyframes bt-panel-in{from{opacity:.55;transform:translateY(4px)}}
.compact-editor .field{margin-bottom:.75rem;gap:.3rem}.compact-editor .field label{font-size:.68rem}.compact-editor .form-control{padding:.65rem .8rem;border-radius:10px;font-size:.9rem}.compact-message{min-height:124px;resize:vertical}.compact-editor .field-help{font-size:.63rem}.occasion-field{max-width:280px}
.compact-editor .message-tools{margin:.25rem 0 .6rem;padding:.85rem}.compact-editor .message-tool-grid{gap:.8rem}.compact-editor .touch-control{min-width:46px;min-height:46px}.compact-editor .position-pad{width:156px;grid-template-columns:46px 46px 46px;grid-template-rows:46px 46px 46px}.compact-editor .size-controls{grid-template-columns:52px minmax(94px,1fr) 52px}.compact-editor .tool-status{min-height:38px}
.editor-footer{padding:.75rem 1rem .8rem;border-top:2px solid var(--ink);background:#fff}.editor-footer .notice{margin-bottom:.6rem;padding:.6rem;font-size:.72rem}.editor-footer .button{min-height:44px}.editor-footer .safe-note{margin:.35rem 0 0;text-align:center;font-size:.61rem}
.inside-extras-layer{position:absolute;inset:0;z-index:1;pointer-events:none}.inside-message{z-index:2}.inside-decoration{position:absolute;left:var(--decoration-x);top:var(--decoration-y);transform:translate(-50%,-50%) rotate(var(--decoration-rotation)) scale(var(--decoration-scale));transform-origin:center;display:grid;place-items:center;padding:0;border:0;background:transparent;cursor:grab;pointer-events:auto;touch-action:none;user-select:none;-webkit-user-select:none}.inside-decoration.is-selected{outline:3px dashed #1674c8;outline-offset:5px}.inside-decoration.is-dragging{cursor:grabbing}.decoration-photo{width:34%;max-height:60%}.decoration-photo img{width:100%;max-height:100%;object-fit:contain;background:#fff;border:3px solid var(--ink);box-shadow:5px 6px 0 rgba(17,17,17,.35)}.decoration-sticker span{font-size:clamp(32px,6vw,70px);line-height:1;filter:drop-shadow(2px 3px 0 rgba(17,17,17,.16))}
.extras-intro{display:grid;gap:.2rem;padding:.7rem;background:var(--cream);border:1px solid var(--line);border-radius:10px;font-size:.69rem}.extras-intro span{color:var(--muted);font-weight:600}.upload-row{display:flex;align-items:center;gap:.8rem;margin:.85rem 0}.upload-button{font-size:.72rem;min-height:40px;padding:.55rem .85rem}.sticker-section{display:grid;gap:.5rem}.sticker-grid{display:grid;grid-template-columns:repeat(8,minmax(42px,1fr));gap:.4rem}.sticker-button{min-height:45px;border:2px solid var(--ink);border-radius:11px;background:#fff;font-size:1.5rem;cursor:pointer}.sticker-button:hover,.sticker-button:focus-visible{background:var(--yellow);transform:translateY(-1px)}.decoration-controls{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:center;margin-top:.85rem;padding:.75rem;border:2px solid var(--ink);border-radius:12px;background:#fff}.decoration-controls>div:first-child{display:grid;font-size:.68rem}.decoration-controls span{color:var(--muted);font-weight:600}.decoration-buttons{display:flex;gap:.35rem}.decoration-buttons .touch-control{min-width:40px;min-height:40px;font-size:1.05rem;box-shadow:2px 2px 0 var(--ink)}.decoration-delete{background:#ffe2e2;color:#8f0f0f}

@media(max-width:1050px){.personalise-main{height:auto;overflow:visible}.personalise-workspace{grid-template-columns:1fr;min-height:auto}.compact-preview,.compact-editor{height:auto}.compact-preview{min-height:560px}.compact-editor{max-height:none}.editor-panels{max-height:none;overflow:visible}}
@media(max-width:760px){body[data-page="personalise"] .shop-announcement{display:grid}.personalise-titlebar{align-items:flex-start}.personalise-titlebar>div:first-child{display:block}.personalise-titlebar .text-action{display:inline-block;margin-bottom:.35rem}.personalise-titlebar h1{white-space:normal;font-size:1.15rem}.personalise-price{display:none}.personalise-workspace{padding:.7rem}.compact-preview{min-height:430px}.page-switcher{justify-content:stretch}.page-switch{flex:1;justify-content:center;font-size:.72rem}.compact-preview .inside-preview{min-height:0}.editor-tabs{position:sticky;top:0;z-index:4}.editor-tab{font-size:.62rem}.sticker-grid{grid-template-columns:repeat(4,1fr)}.decoration-controls{grid-template-columns:1fr}.decoration-buttons{justify-content:center;flex-wrap:wrap}.compact-editor .message-tool-grid{grid-template-columns:1fr}.compact-editor .position-pad{margin-inline:auto}.personalise-main{min-height:0}}

/* v57 free-postage ribbon */
.free-postage-ribbon{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.9rem;padding:.28rem clamp(1rem,4vw,4rem);background:#fff;border-bottom:3px solid var(--ink);text-decoration:none;position:relative;z-index:4;min-height:68px}.free-postage-ribbon:hover{background:#fff8cc}.postie-van-image{display:block;width:clamp(92px,9vw,132px);height:auto;flex:0 0 auto}.free-postage-ribbon span{display:grid;line-height:1.05}.free-postage-ribbon strong{font-size:.78rem;letter-spacing:.07em}.free-postage-ribbon small{font-size:.72rem;font-weight:750;color:var(--muted);margin-top:.2rem}.free-postage-ribbon b{font-size:.75rem;text-decoration:underline;text-underline-offset:3px}
@media(max-width:600px){.free-postage-ribbon{grid-template-columns:auto 1fr;padding:.24rem .7rem;gap:.55rem;min-height:58px}.postie-van-image{width:76px}.free-postage-ribbon b{display:none}.free-postage-ribbon strong{font-size:.63rem}.free-postage-ribbon small{font-size:.58rem}}

/* v58 mobile-first card studio */
.mobile-studio-header,.mobile-tool-dock,.mobile-sheet-head,.mobile-canvas-hint,.mobile-sheet-backdrop{display:none}
.print-safe-outline{position:absolute;inset:2.2%;border:2px dashed rgba(0,151,136,.55);pointer-events:none;z-index:6}
.inside-message.is-selected{outline:3px dashed #1688d4;outline-offset:6px;border-radius:6px}
.inside-message.is-selected::after{content:'drag';position:absolute;right:-6px;bottom:-25px;padding:2px 7px;border:2px solid #1688d4;border-radius:999px;background:#fff;color:#126da7;font:800 9px/1 Montserrat,Arial,sans-serif;letter-spacing:.06em;text-transform:uppercase}

@media(max-width:760px){
  html,body[data-page="personalise"]{height:100%;overflow:hidden}
  body[data-page="personalise"]{background:#f3f4f6;padding:0}
  body[data-page="personalise"] .shop-announcement,
  body[data-page="personalise"] .site-header,
  body[data-page="personalise"] .personalise-titlebar{display:none!important}
  .mobile-studio-header{height:64px;display:grid;grid-template-columns:52px 1fr auto;align-items:center;gap:.6rem;padding:.5rem .8rem;background:#fff;border-bottom:2px solid var(--ink);position:fixed;inset:0 0 auto;z-index:70}
  .mobile-studio-back{width:44px;height:44px;display:grid;place-items:center;border:2px solid var(--ink);border-radius:12px;color:var(--ink);font-size:1.4rem;font-weight:900;text-decoration:none;background:#fff}
  .mobile-studio-brand{display:flex;align-items:center;justify-content:center;gap:.5rem;min-width:0;font-size:.86rem}
  .mobile-studio-brand img{width:34px;height:34px;border-radius:50%}
  .mobile-studio-brand strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .mobile-studio-next{min-width:70px;min-height:44px;padding:.55rem .9rem;border:2px solid var(--ink);border-radius:12px;background:var(--yellow);color:var(--ink);font:900 .78rem/1 Montserrat,Arial,sans-serif;box-shadow:3px 3px 0 var(--ink)}
  .mobile-studio-next:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}

  .personalise-main{height:100dvh;min-height:0;display:block;overflow:hidden;padding-top:64px;padding-bottom:82px}
  .personalise-workspace{display:block;height:100%;padding:0;min-height:0}
  .compact-preview{height:100%;min-height:0!important;margin:0!important;padding:.7rem .65rem .5rem;display:flex;flex-direction:column;border:0;border-radius:0;background:#f3f4f6;box-shadow:none;overflow:hidden}
  .preview-stage{order:1;flex:1;min-height:0;display:grid;place-items:center;padding:.45rem .2rem;overflow:hidden}
  .page-switcher{order:2;align-self:center;width:min(290px,84vw);margin:.45rem auto .2rem;padding:3px;display:grid;grid-template-columns:1fr 1.3fr;gap:2px;border:2px solid var(--ink);border-radius:14px;background:#fff;box-shadow:3px 3px 0 rgba(17,17,17,.18)}
  .page-switch{min-height:42px;padding:.45rem .65rem;border:0;border-radius:9px;background:#fff;font-size:.7rem;font-weight:900;box-shadow:none;justify-content:center}
  .page-switch span{display:none}
  .page-switch.is-active{background:var(--yellow);color:var(--ink);box-shadow:inset 0 0 0 2px var(--ink)}
  .preview-note{display:none}
  .mobile-canvas-hint{order:3;display:block;margin:.3rem auto 0;max-width:340px;color:var(--muted);font-size:.62rem;font-weight:700;text-align:center}
  .compact-preview .inside-preview{width:min(92vw,650px);height:auto;max-height:calc(100dvh - 245px);min-height:0;aspect-ratio:3025/2161;border-width:3px;box-shadow:5px 6px 0 var(--ink)}
  .compact-preview .front-preview{width:auto;height:min(calc(100dvh - 245px),68vh);max-width:88vw;border-width:3px;box-shadow:5px 6px 0 var(--ink)}
  .inside-left{border-right:2px dashed #e54a4a}
  .inside-fold-label{font-size:.52rem}
  .print-safe-outline{inset:1.8%;border-width:1.5px}
  .inside-preview .message-safe-area{inset:7%}
  .inside-message{max-width:94%;width:94%;padding:.15rem;line-height:1.12;outline-offset:4px}
  .inside-message.is-selected::after{right:0;bottom:-20px;font-size:7px;padding:2px 5px}
  .decoration-photo{width:42%}
  .decoration-sticker span{font-size:clamp(28px,10vw,56px)}

  .compact-editor{position:fixed;left:0;right:0;bottom:0;z-index:100;height:min(78dvh,700px);max-height:78dvh;min-height:0;padding:0;border:2px solid var(--ink);border-bottom:0;border-radius:22px 22px 0 0;background:#fff;box-shadow:0 -12px 40px rgba(0,0,0,.24);display:grid;grid-template-rows:auto minmax(0,1fr) auto;overflow:hidden;transform:translateY(110%);transition:transform .22s ease}
  .compact-editor.is-mobile-open{transform:translateY(0)}
  .mobile-sheet-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.8rem 1rem;border-bottom:2px solid var(--ink);background:#fff}
  .mobile-sheet-head strong{font-size:1rem}
  .mobile-sheet-head button{width:40px;height:40px;border:2px solid var(--ink);border-radius:50%;background:#fff;font:900 1.35rem/1 Montserrat,Arial,sans-serif}
  .editor-summary,.editor-tabs{display:none!important}
  .editor-panels{min-height:0;max-height:none;overflow:auto;padding:1rem 1rem 1.4rem;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
  .editor-tab-panel{min-height:100%}
  .compact-editor .field{margin-bottom:.85rem}
  .compact-editor .field label{font-size:.68rem}
  .compact-editor .form-control{font-size:16px;padding:.78rem .9rem}
  .compact-message{min-height:120px;resize:none}
  .occasion-field{max-width:none}
  .compact-editor .two-fields{grid-template-columns:1fr 1fr;gap:.7rem}
  .compact-editor .message-tools{margin:.3rem 0 .5rem;padding:.8rem;background:#fffdf3}
  .compact-editor .message-tool-grid{grid-template-columns:1fr;gap:1rem}
  .compact-editor .size-controls{grid-template-columns:62px 1fr 62px}
  .compact-editor .touch-control{min-width:54px;min-height:54px}
  .compact-editor .position-pad{width:180px;grid-template-columns:54px 54px 54px;grid-template-rows:54px 54px 54px;margin-inline:auto}
  .tool-status{font-size:.7rem}
  .editor-footer{padding:.65rem .9rem .75rem;background:#fff;border-top:2px solid var(--ink)}
  .editor-footer .button{min-height:48px}
  .editor-footer .safe-note{display:none}
  .sticker-grid{grid-template-columns:repeat(4,1fr);gap:.55rem}
  .sticker-button{min-height:58px;font-size:1.65rem}
  .upload-row{display:flex;gap:.7rem;align-items:center;flex-wrap:wrap}
  .upload-button{flex:1}
  .decoration-controls{grid-template-columns:1fr;gap:.8rem}
  .decoration-buttons{justify-content:center;flex-wrap:wrap}

  .mobile-tool-dock{height:82px;display:grid;grid-template-columns:repeat(4,1fr);position:fixed;inset:auto 0 0;z-index:75;background:#111;color:#fff;border-top:2px solid #000;padding-bottom:max(0px,env(safe-area-inset-bottom))}
  .mobile-tool-dock button{min-width:0;display:grid;place-items:center;align-content:center;gap:.25rem;border:0;border-right:1px solid #2c2c2c;background:#111;color:#fff;font:800 .62rem/1 Montserrat,Arial,sans-serif}
  .mobile-tool-dock button:last-child{border-right:0}
  .mobile-tool-dock button.is-active{background:#2a2a2a;color:var(--yellow)}
  .mobile-tool-icon{width:28px;height:28px;display:grid;place-items:center;border:2px solid currentColor;border-radius:8px;font-size:1rem;font-weight:900}
  .mobile-tool-icon-aa{font-size:.72rem}
  .mobile-sheet-backdrop{display:block;position:fixed;inset:0;z-index:90;background:rgba(0,0,0,.28)}
  .mobile-sheet-backdrop[hidden]{display:none}
  body.mobile-sheet-open .mobile-tool-dock{visibility:hidden}
  body.mobile-sheet-open .mobile-studio-header{z-index:85}
}

@media(max-width:390px){
  .compact-preview .inside-preview{width:94vw;max-height:calc(100dvh - 232px)}
  .page-switcher{width:min(276px,88vw)}
  .mobile-canvas-hint{font-size:.58rem}
  .compact-editor{height:82dvh;max-height:82dvh}
  .compact-editor .two-fields{grid-template-columns:1fr}
}

/* v59 branded UK-delivery artwork */
.checkout-panel.free-delivery-panel{display:grid;grid-template-columns:minmax(150px,240px) 1fr;gap:1.2rem;align-items:center;background:linear-gradient(135deg,#fff 0 78%,var(--yellow) 78%)}.checkout-delivery-van img{display:block;width:100%;height:auto}.checkout-panel.free-delivery-panel h2{margin-top:0}@media(max-width:700px){.checkout-panel.free-delivery-panel{grid-template-columns:1fr}.checkout-delivery-van{max-width:240px;margin:auto}}
