/* =========================================================
   PARTY BOX — home page (v2 layout)
   Self-contained styles for the re-organised storefront home.
   Brand tokens mirror castle.css so the page stays on-brand,
   but the layout is its own so it can't disturb other pages.
   ========================================================= */
:root{
  --gold:#e7c073; --gold-deep:#c79a45; --gold-light:#fff0d2;
  --stone-950:#120c08; --stone-900:#1a120c; --stone-850:#211711;
  --stone-800:#2a1d14; --stone-700:#3a2a1d;
  --parchment:#f3e6cf; --parchment-deep:#e7d3b1; --cream:#fff8ef;
  --ink:#2a1d12; --ink-soft:#6a553c;
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Nunito",system-ui,sans-serif;
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--cream);
  -webkit-font-smoothing:antialiased;line-height:1.55;overflow-x:clip;
}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.05;margin:0}
a{color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.eyebrow{font-size:12.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-deep);font-weight:800;margin-bottom:10px}
.btn{display:inline-flex;align-items:center;gap:8px;border:0;cursor:pointer;
  font-family:var(--sans);font-weight:800;border-radius:999px;padding:14px 26px;
  font-size:15px;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:linear-gradient(180deg,var(--gold),var(--gold-deep));color:#3a2a10;
  box-shadow:0 10px 26px rgba(199,154,69,.4)}
.btn-ghost{background:transparent;color:var(--cream);border:1.5px solid rgba(255,240,210,.5)}
.btn-dark{background:var(--stone-900);color:var(--gold-light)}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:90;background:rgba(20,13,8,.92);
  backdrop-filter:blur(10px);border-bottom:1px solid rgba(231,192,115,.18)}
.nav.scrolled{background:rgba(16,9,5,.97)}
.nav-in{display:flex;align-items:center;gap:24px;height:68px;max-width:var(--maxw);
  margin:0 auto;padding:0 22px}
.brand{display:flex;align-items:center;gap:9px;text-decoration:none;color:var(--cream);
  font-family:var(--serif);font-size:23px;font-weight:700;letter-spacing:.01em}
.brand img{height:42px;width:auto;display:block}
.brand--foot img{height:50px}
.brand .dot{width:26px;height:26px;border-radius:50%;
  background:radial-gradient(circle at 32% 30%,#fff,var(--gold) 60%,var(--gold-deep));
  box-shadow:0 0 0 2px rgba(231,192,115,.4)}
.brand b{color:var(--gold)}
.navlinks{display:flex;gap:22px;list-style:none;margin:0 0 0 8px;padding:0;
  font-weight:700;font-size:14.5px}
.navlinks a{color:#efe2cf;text-decoration:none;opacity:.92;transition:color .15s}
.navlinks a:hover{color:var(--gold)}
.navtools{margin-left:auto;display:flex;align-items:center;gap:12px}
.icon-btn{background:transparent;border:0;color:#efe2cf;font-size:17px;cursor:pointer;
  text-decoration:none;width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:50%;transition:background .15s;position:relative}
.icon-btn:hover{background:rgba(231,192,115,.16);color:var(--gold)}
.cart-count{position:absolute;top:-2px;right:-4px;background:var(--gold);color:#3a2a10;
  font-size:10px;font-weight:800;min-width:16px;height:16px;border-radius:999px;
  display:grid;place-items:center;padding:0 3px}
.vendor-link{color:#bba883 !important;font-size:13px;font-weight:700;text-decoration:none}
.vendor-link:hover{color:var(--gold) !important}
.menu-btn{display:none;background:transparent;border:0;color:var(--cream);font-size:22px;cursor:pointer}

/* mobile drawer */
.scrim{position:fixed;inset:0;background:rgba(10,6,3,.5);opacity:0;pointer-events:none;
  transition:opacity .25s;z-index:95}
.scrim.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(82vw,320px);z-index:96;
  background:linear-gradient(180deg,#1c130b,#120c08);transform:translateX(100%);
  transition:transform .28s ease;padding:74px 26px 26px;display:flex;flex-direction:column;gap:4px;
  box-shadow:-20px 0 50px rgba(0,0,0,.4)}
.drawer.open{transform:none}
.drawer a{color:#efe2cf;text-decoration:none;font-weight:700;font-size:16px;padding:12px 0;
  border-bottom:1px solid rgba(231,192,115,.12)}
.drawer a:hover{color:var(--gold)}
.drawer .btn{margin-top:18px;justify-content:center}
.drawer-close{position:absolute;top:18px;right:20px;background:transparent;border:0;
  color:var(--cream);font-size:28px;cursor:pointer;line-height:1}

/* ---------- hero ---------- */
.hero{position:relative;min-height:84vh;display:flex;align-items:center;color:var(--cream);
  overflow:hidden;text-align:center;background:#150e09}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  transition:opacity 1s ease}
.hero-vid.under{opacity:0}
.hero-scroll{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:3;
  color:#f4e7cd;text-decoration:none;font-size:12.5px;font-weight:800;letter-spacing:.14em;
  text-transform:uppercase;opacity:.85;animation:bob 2.4s ease-in-out infinite}
.hero-scroll:hover{opacity:1;color:var(--gold)}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,6px)}}
.hero-grade{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(120% 90% at 50% 0%,rgba(231,192,115,.40),transparent 60%),
    linear-gradient(180deg,rgba(18,12,8,.50),rgba(18,12,8,.20) 42%,rgba(12,8,5,.66))}
.hero-bubbles{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:1}
.hero-bubbles span{position:absolute;bottom:-60px;border-radius:50%;opacity:.5;
  background:radial-gradient(circle at 32% 28%,rgba(255,255,255,.9),var(--c,#f6a9c6));
  animation:rise var(--d,18s) linear infinite;animation-delay:var(--dl,0s)}
@keyframes rise{to{transform:translateY(-95vh);opacity:0}}
.hero-in{position:relative;z-index:2;max-width:760px;margin:0 auto;padding:60px 22px}
.hero h1{font-size:clamp(40px,7vw,76px);letter-spacing:.005em}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero-tag{font-family:var(--serif);font-style:italic;font-size:clamp(20px,3.2vw,30px);
  color:var(--gold);margin-top:14px;letter-spacing:.01em}
.hero p{font-size:clamp(16px,2.1vw,20px);color:#e9dcc6;margin:14px auto 30px;max-width:560px}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero-sub{margin-top:26px;font-size:13px;color:#e3d4b6;letter-spacing:.04em}

/* ---------- trust strip ---------- */
.trust{background:linear-gradient(180deg,var(--gold-light),#fff6e6);color:var(--ink);
  border-top:1px solid rgba(231,192,115,.4);border-bottom:1px solid rgba(231,192,115,.3)}
.trust-in{display:flex;flex-wrap:wrap;gap:10px 40px;justify-content:center;align-items:center;
  padding:16px 22px;max-width:var(--maxw);margin:0 auto;font-size:14px;font-weight:700}
.trust-in span{display:inline-flex;align-items:center;gap:8px;opacity:.92}
.trust .star{color:var(--gold-deep)}

/* ---------- section shell ---------- */
.sec{padding:84px 0}
.sec.tint{background:linear-gradient(180deg,var(--parchment),var(--cream))}
.sec.dark{background:linear-gradient(180deg,#1a120c,#241a10);color:var(--cream)}
.sec-head{text-align:center;max-width:640px;margin:0 auto 46px}
.sec-head h2{font-size:clamp(30px,4.5vw,46px)}
.sec-head p{margin-top:12px;color:var(--ink-soft);font-size:16.5px}
.sec.dark .sec-head p{color:#d8c8ad}

/* ---------- feature ---------- */
.feature{display:grid;grid-template-columns:1.05fr 1fr;gap:54px;align-items:center}
.feature h2{font-size:clamp(28px,4vw,42px)}
.feature p{color:var(--ink-soft);margin:16px 0 22px;font-size:16.5px}
.feature ul{list-style:none;padding:0;margin:0 0 26px;display:grid;gap:11px}
.feature li{display:flex;gap:11px;align-items:flex-start;color:var(--ink);font-weight:600}
.feature li .ck{color:var(--gold-deep)}
.fvis{aspect-ratio:4/3;border-radius:24px;position:relative;overflow:hidden;margin:0;
  background:var(--cream);padding:9px;border:1px solid var(--parchment-deep);
  box-shadow:0 30px 64px rgba(58,42,16,.22),0 4px 14px rgba(58,42,16,.1)}
.fvis img{width:100%;height:100%;object-fit:cover;border-radius:16px;display:block}
/* floating credibility caption (bottom-left) */
.fvis-cap{position:absolute;left:20px;bottom:20px;display:flex;align-items:center;gap:8px;
  font-family:var(--sans);font-size:13px;font-weight:700;color:var(--ink);
  background:rgba(255,248,239,.9);backdrop-filter:blur(6px);
  padding:8px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.7);
  box-shadow:0 8px 22px rgba(58,42,16,.18)}
.fvis-cap strong{font-weight:800}
.fvis-dot{width:8px;height:8px;border-radius:50%;flex:none;
  background:radial-gradient(circle at 35% 30%,#fff,var(--gold) 55%,var(--gold-deep));
  box-shadow:0 0 0 3px rgba(231,192,115,.3)}
/* proof chip (top-right) */
.fvis-chip{position:absolute;right:20px;top:20px;font-family:var(--sans);
  font-size:12.5px;font-weight:800;letter-spacing:.01em;color:#3a2a10;
  background:linear-gradient(180deg,var(--gold),var(--gold-deep));
  padding:7px 14px;border-radius:999px;box-shadow:0 8px 22px rgba(199,154,69,.4)}
@media(max-width:760px){
  .fvis-cap{left:14px;bottom:14px;font-size:12px;padding:7px 12px}
  .fvis-chip{right:14px;top:14px}
}

/* ---------- 3 ways (decision hub) ---------- */
.ways{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.way{background:var(--cream);border:1px solid var(--parchment-deep);border-radius:20px;
  overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:inherit;
  box-shadow:0 12px 30px rgba(58,42,20,.08);transition:transform .18s ease,box-shadow .18s ease}
.way:hover{transform:translateY(-5px);box-shadow:0 22px 44px rgba(58,42,20,.16)}
.way-photo{position:relative;aspect-ratio:16/10;overflow:hidden;background:#1c130c}
.way-photo img{width:100%;height:100%;object-fit:cover}
.way-photo .pill{position:absolute;top:12px;left:12px;background:var(--gold);color:#3a2a10;
  font-size:11px;font-weight:800;padding:4px 11px;border-radius:999px;letter-spacing:.06em}
.way-body{padding:24px 26px 28px;display:flex;flex-direction:column;flex:1}
.way .tag{font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  color:var(--gold-deep);margin-bottom:6px}
.way h3{font-size:25px}
.way p{color:var(--ink-soft);font-size:15px;margin:10px 0 18px;flex:1}
.way .go{font-weight:800;color:var(--gold-deep)}
.way:hover .go{text-decoration:underline}
.way.lead{border-color:var(--gold)}

/* ---------- collection grid ---------- */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.pcard{background:var(--cream);border-radius:18px;overflow:hidden;text-decoration:none;color:inherit;
  border:1px solid var(--parchment-deep);box-shadow:0 10px 26px rgba(58,42,20,.08);
  transition:transform .18s ease,box-shadow .18s ease}
.pcard:hover{transform:translateY(-5px);box-shadow:0 22px 44px rgba(58,42,20,.16)}
.pcard .thumb{position:relative;aspect-ratio:4/5;display:grid;place-items:center;
  background:radial-gradient(80% 70% at 50% 40%,var(--a,#f6a9c6),#1c130c);overflow:hidden}
.pcard .thumb .pphoto{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;
  transition:opacity .3s}
.pcard .thumb.has-photo .pphoto{opacity:1}
.pcard .arch{font-size:54px;filter:drop-shadow(0 6px 14px rgba(0,0,0,.3))}
.pcard .badge{position:absolute;top:12px;left:12px;background:rgba(20,13,8,.78);color:var(--gold-light);
  font-size:12px;font-weight:800;padding:5px 11px;border-radius:999px;z-index:2}
.pcard .meta{padding:16px 18px 20px}
.pcard .cat{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep);font-weight:800}
.pcard h3{font-size:21px;margin:3px 0 7px}
.pcard .desc{font-size:13.5px;color:var(--ink-soft);min-height:38px}
.pcard .row{display:flex;justify-content:space-between;align-items:center;margin-top:12px}
.pcard .price b{font-size:19px}
.pcard .go{font-weight:800;color:var(--gold-deep)}

/* ---------- pre-made box collection (the lead offer) ----------
   A dense, abundant grid of small themed boxes — auto-fills as many
   per row as fit so the whole catalogue reads "a lot to choose from". */
.boxgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(205px,1fr));gap:16px}
.boxcard{position:relative;display:flex;flex-direction:column;text-decoration:none;color:inherit;
  border-radius:16px;overflow:hidden;background:var(--cream);border:1px solid var(--parchment-deep);
  box-shadow:0 8px 22px rgba(58,42,20,.09);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.boxcard:hover{transform:translateY(-5px);box-shadow:0 20px 40px rgba(58,42,20,.18);border-color:var(--gold)}
.boxcard-art{position:relative;aspect-ratio:1/1;display:grid;place-items:center;padding:10px 10px 0;
  background:
    radial-gradient(120% 100% at 50% 8%,color-mix(in srgb,var(--a,#f6a9c6) 38%,transparent),transparent 62%),
    linear-gradient(180deg,#1a120c,#241a10)}
.boxcard-art .pbx-art{width:100%;height:100%;filter:drop-shadow(0 12px 20px rgba(0,0,0,.4))}
.boxcard-body{padding:13px 15px 16px;display:flex;flex-direction:column;flex:1}
.boxcard .cat{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-deep);font-weight:800}
.boxcard h3{font-size:18px;margin:3px 0 5px}
.boxcard p{font-size:12.5px;line-height:1.4;color:var(--ink-soft);margin:0 0 12px;flex:1;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.boxcard-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}
.boxcard-row .sw{display:inline-flex;gap:4px}
.boxcard-row .sw i{width:14px;height:14px;border-radius:50%;display:block;
  box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.55),0 1px 3px rgba(0,0,0,.18)}
.boxcard-row .price{font-size:12.5px;color:var(--ink-soft)}
.boxcard-row .price b{font-size:17px;color:var(--ink)}
.boxcard .go{font-weight:800;color:var(--gold-deep);font-size:12.5px}
.boxcard:hover .go{text-decoration:underline}
/* collapsed collection: only the featured (most-trafficked) boxes show until expanded */
.boxgrid--collapsed .boxcard--more{display:none}
.boxmore{display:inline-flex;align-items:center;gap:8px;margin:28px auto 0;padding:13px 30px;
  font:inherit;font-weight:800;font-size:14.5px;letter-spacing:.01em;cursor:pointer;
  color:var(--ink);background:var(--cream);border:1.5px solid var(--gold);border-radius:999px;
  box-shadow:0 6px 18px rgba(58,42,20,.10);transition:transform .15s ease,box-shadow .15s ease,background .15s ease}
.boxgrid + .boxmore{display:flex}
.boxmore:hover{transform:translateY(-2px);background:var(--gold);box-shadow:0 12px 26px rgba(58,42,20,.18)}
.boxmore-ic{font-size:16px;line-height:1}
.collection-note{text-align:center;margin-top:32px;color:var(--ink-soft);font-size:14.5px;font-weight:600}

/* ---------- two more ways (demoted custom + white-glove) ---------- */
.ways2{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:880px;margin:0 auto}
.way2{display:flex;gap:18px;align-items:flex-start;background:var(--cream);border:1px solid var(--parchment-deep);
  border-radius:18px;padding:24px 26px;text-decoration:none;color:inherit;
  box-shadow:0 10px 26px rgba(58,42,20,.08);transition:transform .18s ease,box-shadow .18s ease}
.way2:hover{transform:translateY(-4px);box-shadow:0 20px 40px rgba(58,42,20,.16)}
.way2-ic{flex:none;width:50px;height:50px;border-radius:14px;display:grid;place-items:center;font-size:24px;
  color:#3a2a10;background:linear-gradient(180deg,var(--gold-light),var(--gold))}
.way2 h3{font-size:21px;margin-bottom:6px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.way2 p{font-size:14px;color:var(--ink-soft);margin:0 0 10px}
.way2 .go{font-weight:800;color:var(--gold-deep);font-size:14px}
.way2 .chip{font-size:10.5px;font-weight:800;letter-spacing:.06em;color:var(--gold-deep);
  background:var(--gold-light);border:1px solid rgba(231,192,115,.5);padding:2px 8px;border-radius:999px}

/* ---------- how it works ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.step{text-align:center;padding:0 8px}
.step .n{width:50px;height:50px;border-radius:50%;margin:0 auto 14px;display:grid;place-items:center;
  font-family:var(--serif);font-size:24px;font-weight:700;color:#3a2a10;
  background:linear-gradient(180deg,var(--gold-light),var(--gold))}
.step h3{font-size:20px;margin-bottom:6px}
.step p{font-size:14px;color:var(--ink-soft)}

/* ---------- gallery — polaroid row ---------- */
:root{--hand:"Caveat","Segoe Script",cursive}
.prow-sec{overflow:hidden;padding-bottom:34px}
.prow-sec .sec-head{margin-bottom:18px}
/* a draggable, auto-drifting row of scrapbook polaroids; the soft fade
   on each edge hints there's more to scroll either way */
.prow{position:relative;max-width:100%;padding:20px 0 26px;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.prow-track{display:flex;align-items:center;gap:8px;overflow-x:auto;
  padding:18px max(22px,calc((100vw - var(--maxw))/2));cursor:grab;
  scrollbar-width:none;-ms-overflow-style:none}
.prow-track::-webkit-scrollbar{display:none}
.prow-track.grabbing{cursor:grabbing}

.polaroid{flex:0 0 auto;width:188px;background:#fffdf6;border-radius:3px;padding:12px 12px 0;
  box-shadow:0 16px 30px rgba(40,24,8,.22),0 2px 6px rgba(40,24,8,.16);
  border:1px solid rgba(70,45,15,.06);position:relative;cursor:pointer;user-select:none;
  transform:rotate(var(--r,0deg));transition:transform .22s cubic-bezier(.2,.7,.3,1),box-shadow .22s}
.polaroid:hover{transform:rotate(0deg) translateY(-6px) scale(1.04);z-index:5;
  box-shadow:0 28px 52px rgba(40,24,8,.3)}
.polaroid:focus-visible{outline:3px solid var(--gold-deep);outline-offset:3px}
.polaroid-img{width:164px;height:164px;object-fit:cover;display:block;border-radius:2px;
  background:#ece0c8 url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20"><circle cx="10" cy="10" r="2" fill="%23d8c5a3"/></svg>');
  pointer-events:none}
.polaroid-cap{font-family:var(--hand);font-size:22px;line-height:1.04;color:#5a4326;
  text-align:center;padding:9px 4px 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  pointer-events:none}
.polaroid-sub{font-family:var(--hand);font-size:15px;color:#9a7d52;text-align:center;
  padding:0 6px 13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none}
/* washi-tape strip — patterned & rotated, varies per card */
.polaroid .tape{position:absolute;top:-10px;left:50%;width:80px;height:24px;
  transform:translateX(-50%) rotate(-4deg);opacity:.82;pointer-events:none;
  border-radius:2px;box-shadow:0 2px 5px rgba(40,24,8,.16);mix-blend-mode:multiply}
.polaroid:nth-child(even) .tape{transform:translateX(-50%) rotate(5deg)}
.tape-0{background:#f7b8cf;background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.55) 0 5px,transparent 5px 11px)}
.tape-1{background:#a9d6f2;background-image:radial-gradient(rgba(255,255,255,.65) 2px,transparent 2.6px);background-size:11px 11px}
.tape-2{background:#ffd98f;background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.5) 0 4px,transparent 4px 9px),repeating-linear-gradient(90deg,rgba(180,120,20,.18) 0 4px,transparent 4px 9px)}
.tape-3{background:#bfe3c8;background-image:radial-gradient(rgba(60,120,80,.28) 1.4px,transparent 2px),radial-gradient(rgba(60,120,80,.2) 1.4px,transparent 2px);background-size:13px 13px,13px 13px;background-position:0 0,6px 6px}
.tape-4{background:#d9c3f3;background-image:repeating-linear-gradient(-45deg,rgba(255,255,255,.5) 0 5px,transparent 5px 11px)}

.prow-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:60;width:46px;height:46px;
  border-radius:50%;border:1px solid rgba(231,192,115,.5);background:rgba(20,13,8,.82);
  color:var(--gold-light);font-size:24px;line-height:1;cursor:pointer;backdrop-filter:blur(4px);
  box-shadow:0 10px 24px rgba(0,0,0,.3);transition:transform .15s,background .15s}
.prow-btn:hover{transform:translateY(-50%) scale(1.08);background:rgba(20,13,8,.95)}
.prow-btn.prev{left:14px}.prow-btn.next{right:14px}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(10,6,3,.92);display:none;
  align-items:center;justify-content:center;padding:30px}
.lightbox.on{display:flex}
.lightbox img{max-width:88vw;max-height:78vh;border-radius:12px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb-fig{margin:0;text-align:center}
.lb-fig figcaption{color:var(--cream);margin-top:14px;font-size:14px}
.lb-close,.lb-nav{position:absolute;background:rgba(255,255,255,.1);border:0;color:var(--cream);
  width:46px;height:46px;border-radius:50%;font-size:22px;cursor:pointer}
.lb-close{top:22px;right:22px}
.lb-prev{left:22px;top:50%;transform:translateY(-50%)}
.lb-next{right:22px;top:50%;transform:translateY(-50%)}

/* ---------- reviews ---------- */
.revs{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rev{background:var(--cream);border:1px solid var(--parchment-deep);border-radius:18px;padding:24px;
  box-shadow:0 10px 26px rgba(58,42,20,.08)}
.rev .stars{color:var(--gold);letter-spacing:2px;margin-bottom:10px}
.rev p{font-size:15px;color:var(--ink);font-style:italic}
.rev .who{margin-top:14px;display:flex;align-items:center;gap:10px;font-size:14px}
.rev .who .av{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;
  font-weight:800;color:#3a2a10;flex:none}
.rev .who b{font-weight:800;display:block}
.rev .who .sub{color:var(--ink-soft);font-weight:600;font-size:12.5px}
.rev .who .verified{margin-left:auto;color:var(--gold-deep);font-weight:800;font-size:12px}

/* ---------- newsletter + footer ---------- */
/* ---------- newsletter — dreamy twilight dreamscape ---------- */
.news{
  position:relative;isolation:isolate;overflow:hidden;
  text-align:center;color:var(--cream);padding:104px 22px 112px;
  /* dusk indigo → lavender → mauve → warm rose horizon, with a moon-glow + horizon-glow */
  background:
    radial-gradient(150% 96% at 50% 138%, #ffcaa6 0%, rgba(255,202,166,0) 50%),
    radial-gradient(56% 52% at 79% 24%, rgba(255,244,214,.5), rgba(255,244,214,0) 62%),
    linear-gradient(180deg,#2b2a5e 0%,#473c84 24%,#6f54a2 46%,#a06fab 64%,#d093ad 82%,#f4c6bf 100%);
}
/* — atmospheric sky layers (behind the copy) — */
.news-sky{position:absolute;inset:0;z-index:-1;pointer-events:none}
.news-moon{
  position:absolute;top:15%;right:13%;width:clamp(72px,9vw,116px);aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle at 38% 34%,#fffdf6 0%,#fff0c9 56%,#ffdf9c 100%);
  box-shadow:0 0 0 12px rgba(255,255,255,.06),
             0 0 50px 16px rgba(255,246,214,.5),
             0 0 120px 46px rgba(255,226,160,.32);
  animation:newsMoon 9s ease-in-out infinite;
}
.news-moon::after{content:"";position:absolute;inset:0;border-radius:50%;
  background:
    radial-gradient(circle at 64% 42%,rgba(208,170,108,.38) 0 7px,transparent 8px),
    radial-gradient(circle at 41% 64%,rgba(208,170,108,.3) 0 10px,transparent 11px),
    radial-gradient(circle at 30% 38%,rgba(208,170,108,.24) 0 5px,transparent 6px);}
@keyframes newsMoon{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

.news-stars{position:absolute;top:0;left:0;right:0;height:70%;background-repeat:no-repeat;
  background-image:
    radial-gradient(1.7px 1.7px at 12% 30%,#fff 50%,transparent 51%),
    radial-gradient(1.4px 1.4px at 26% 12%,rgba(255,255,255,.85) 50%,transparent 51%),
    radial-gradient(1.9px 1.9px at 44% 40%,#fff 50%,transparent 51%),
    radial-gradient(1.3px 1.3px at 63% 18%,rgba(255,255,255,.8) 50%,transparent 51%),
    radial-gradient(1.7px 1.7px at 88% 34%,#fff 50%,transparent 51%),
    radial-gradient(1.4px 1.4px at 73% 8%,rgba(255,255,255,.85) 50%,transparent 51%),
    radial-gradient(1.5px 1.5px at 33% 52%,#fff 50%,transparent 51%),
    radial-gradient(1.2px 1.2px at 52% 9%,rgba(255,255,255,.8) 50%,transparent 51%),
    radial-gradient(2px 2px at 7% 44%,#fff 50%,transparent 51%),
    radial-gradient(1.4px 1.4px at 95% 14%,rgba(255,255,255,.85) 50%,transparent 51%),
    radial-gradient(1.3px 1.3px at 68% 46%,#fff 50%,transparent 51%);
  animation:newsTwinkle 4s ease-in-out infinite;}
.news-stars::before{content:"";position:absolute;inset:0;background-repeat:no-repeat;
  background-image:
    radial-gradient(1.4px 1.4px at 18% 22%,#fff 50%,transparent 51%),
    radial-gradient(1.6px 1.6px at 38% 8%,rgba(255,255,255,.8) 50%,transparent 51%),
    radial-gradient(1.3px 1.3px at 55% 30%,#fff 50%,transparent 51%),
    radial-gradient(1.7px 1.7px at 82% 16%,rgba(255,255,255,.85) 50%,transparent 51%),
    radial-gradient(1.3px 1.3px at 6% 14%,#fff 50%,transparent 51%),
    radial-gradient(1.5px 1.5px at 48% 50%,#fff 50%,transparent 51%),
    radial-gradient(1.2px 1.2px at 30% 38%,rgba(255,255,255,.8) 50%,transparent 51%),
    radial-gradient(1.6px 1.6px at 91% 42%,#fff 50%,transparent 51%),
    radial-gradient(1.3px 1.3px at 16% 54%,rgba(255,255,255,.8) 50%,transparent 51%),
    radial-gradient(1.4px 1.4px at 78% 30%,#fff 50%,transparent 51%);
  animation:newsTwinkle 5.5s ease-in-out .9s infinite;}
@keyframes newsTwinkle{0%,100%{opacity:.45}50%{opacity:1}}

/* — 4-point sparkle glints that pop in and out — */
.news-sparkles b{position:absolute;width:18px;height:18px;opacity:0;
  animation:newsSpark 3.4s ease-in-out infinite}
.news-sparkles b::before,.news-sparkles b::after{content:"";position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);
  background:radial-gradient(closest-side,#fff,rgba(255,236,200,.6),rgba(255,255,255,0))}
.news-sparkles b::before{width:100%;height:2px;box-shadow:0 0 6px 1px rgba(255,247,220,.8)}
.news-sparkles b::after{width:2px;height:100%;box-shadow:0 0 6px 1px rgba(255,247,220,.8)}
.news-sparkles b:nth-child(1){top:20%;left:20%;animation-delay:0s}
.news-sparkles b:nth-child(2){top:14%;left:58%;animation-delay:.7s;transform:scale(1.3)}
.news-sparkles b:nth-child(3){top:34%;left:40%;animation-delay:1.4s;transform:scale(.8)}
.news-sparkles b:nth-child(4){top:26%;left:84%;animation-delay:2.1s;transform:scale(1.1)}
.news-sparkles b:nth-child(5){top:44%;left:10%;animation-delay:2.8s}
.news-sparkles b:nth-child(6){top:10%;left:33%;animation-delay:1.1s;transform:scale(.9)}
@keyframes newsSpark{0%,100%{opacity:0;transform:scale(.3) rotate(0deg)}
  45%,55%{opacity:1;transform:scale(1) rotate(45deg)}}

/* — shooting stars: a bright head with a fading tail, streaking diagonally — */
.news-shoot{position:absolute;top:8%;left:6%;width:4px;height:4px;border-radius:50%;
  background:#fff;opacity:0;transform:rotate(26deg);
  box-shadow:0 0 8px 2px rgba(255,255,255,.95),0 0 20px 7px rgba(255,236,200,.55);
  animation:newsShoot 8s ease-in infinite}
.news-shoot::before{content:"";position:absolute;right:3px;top:50%;transform:translateY(-50%);
  width:150px;height:2px;border-radius:2px;
  background:linear-gradient(270deg,rgba(255,255,255,.95),rgba(255,236,200,.35) 40%,rgba(255,255,255,0))}
.news-shoot2{top:5%;left:48%;transform:rotate(20deg);animation-duration:11s;animation-delay:4.5s}
.news-shoot2::before{width:110px}
@keyframes newsShoot{
  0%{opacity:0;transform:translate(0,0) rotate(26deg)}
  3%{opacity:1}
  14%{opacity:1}
  20%{opacity:0;transform:translate(440px,230px) rotate(26deg)}
  100%{opacity:0;transform:translate(440px,230px) rotate(26deg)}}

.news-clouds i{position:absolute;display:block;border-radius:50%;
  background:radial-gradient(closest-side,rgba(255,255,255,.5),rgba(255,255,255,0) 72%);
  filter:blur(7px);animation:newsDrift linear infinite}
.news-clouds i:nth-child(1){width:280px;height:90px;top:30%;left:-18%;opacity:.5;animation-duration:48s}
.news-clouds i:nth-child(2){width:200px;height:68px;top:55%;left:-22%;opacity:.38;animation-duration:64s;animation-delay:-22s}
.news-clouds i:nth-child(3){width:340px;height:112px;top:70%;left:-28%;opacity:.5;animation-duration:80s;animation-delay:-44s}
@keyframes newsDrift{from{transform:translateX(0)}to{transform:translateX(140vw)}}

/* — copy — */
.news-in{position:relative;z-index:1;max-width:640px;margin:0 auto}
.news .eyebrow{color:var(--gold-light);letter-spacing:.32em;
  text-shadow:0 0 18px rgba(255,240,200,.55)}
.news h2{font-size:clamp(28px,4.4vw,44px);
  text-shadow:0 2px 30px rgba(40,20,60,.45),0 0 60px rgba(255,200,170,.22)}
.news .news-em{font-style:italic;color:var(--gold-light)}
.news p{color:rgba(255,248,239,.92);margin:14px 0 26px;font-size:clamp(15px,2vw,17px)}
.news form{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.news input{padding:15px 20px;border-radius:999px;border:1px solid rgba(255,255,255,.4);
  background:rgba(255,255,255,.14);color:var(--cream);min-width:280px;font-family:var(--sans);
  font-weight:600;backdrop-filter:blur(6px);box-shadow:0 8px 24px rgba(40,20,60,.2)}
.news input::placeholder{color:rgba(255,248,239,.7)}
.news input:focus{outline:none;border-color:var(--gold-light);background:rgba(255,255,255,.2);
  box-shadow:0 0 0 3px rgba(255,240,200,.35)}
@media(prefers-reduced-motion:reduce){
  .news-moon,.news-stars,.news-stars::before,.news-clouds i,
  .news-sparkles b,.news-shoot{animation:none}
  .news-sparkles b{opacity:.9}
}
footer{background:#0e0907;color:#c9b896;padding:50px 22px 34px}
.foot-in{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px}
.foot-in h4{font-family:var(--sans);font-size:13px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--gold);margin:0 0 14px}
.foot-in a{display:block;color:#c9b896;text-decoration:none;font-size:14px;padding:4px 0}
.foot-in a:hover{color:var(--gold)}
.foot-motto{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--gold);margin-top:12px}
.foot-bot{max-width:var(--maxw);margin:30px auto 0;padding-top:20px;border-top:1px solid rgba(231,192,115,.16);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:#9a8a6e}

/* ---------- toast ---------- */
.toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%,20px);z-index:130;
  background:var(--stone-900);color:var(--gold-light);padding:12px 22px;border-radius:999px;
  border:1px solid rgba(231,192,115,.4);font-weight:700;font-size:14px;opacity:0;pointer-events:none;
  transition:opacity .25s,transform .25s;box-shadow:0 16px 40px rgba(0,0,0,.4)}
.toast.show{opacity:1;transform:translate(-50%,0)}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .navlinks,.vendor-link,.navtools .icon-btn,.navtools .btn-primary{display:none}
  .menu-btn{display:inline-flex}
  .feature,.ways,.grid,.steps,.revs,.ways2{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr 1fr}
  .foot-in{grid-template-columns:1fr 1fr}
  .sec{padding:60px 0}
}
@media(max-width:560px){
  .grid{grid-template-columns:1fr}
  .boxgrid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
  .polaroid{width:158px}
  .polaroid-img{width:134px;height:134px}
  .prow-btn{display:none}
  .foot-in{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  .hero-bubbles span{animation:none;display:none}
  .btn:hover,.way:hover,.pcard:hover{transform:none}
}

/* ---------- from the journal (storefront press strip) ---------- */
.journal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.jcard{display:flex;flex-direction:column;text-decoration:none;color:var(--ink);background:var(--cream);
  border:1px solid rgba(106,85,60,.16);border-radius:18px;padding:24px;
  transition:transform .15s ease,box-shadow .15s ease}
.jcard:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(106,85,60,.14)}
.jcard .j-emoji{font-size:26px;margin-bottom:10px}
.jcard .j-cat{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);font-weight:800}
.jcard h3{font-family:var(--serif);font-size:21px;font-weight:600;line-height:1.18;margin:7px 0 9px}
.jcard p{margin:0;font-size:14.5px;color:var(--ink-soft);flex:1}
.jcard .j-read{margin-top:14px;font-size:13px;font-weight:800;color:var(--gold-deep)}
