/* ============================================================
   BRENNA McNEICE — Hand-Painted Ceramics & Custom Gifts
   Shared stylesheet
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Jost:wght@300;400;500;600&family=La+Belle+Aurore&family=Pinyon+Script&family=Instrument+Serif:ital@0;1&display=swap');

:root{
  /* Palette — Dried Sage · Dusty Rose · Faded Rust · Warm Oak · Bone */
  --cream:        #FBF8F3;     /* soft warm white */
  --cream-deep:   #EDE6DA;     /* bone-warmed neutral */
  --bone:         #E5DFD6;
  --blush:        #EDD8D3;     /* light dusty rose wash */
  --blush-deep:   #D1A9A5;     /* Dusty Rose */
  --dusty-blue:   #AEB89C;     /* repurposed: soft sage (palette has no blue) */
  --dusty-blue-d: #7A816C;
  --sage:         #C3CBB4;     /* light sage */
  --sage-deep:    #7A816C;     /* Dried Sage */
  --butter:       #CBB597;     /* soft warm oak (replaces butter yellow) */
  --coral:        #BC8A82;     /* dusty rose-brown accent (was orange coral) */
  --coral-deep:   #AE6965;     /* Faded Rust */
  --gold:         #A58B71;     /* Warm Oak */
  --ink:          #463F39;     /* warm charcoal for body text */
  --ink-soft:     #8A7F76;
  --line:         #E6DBCC;
  --white:        #FFFFFF;

  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'Jost', 'Helvetica Neue', sans-serif;
  --script:'La Belle Aurore', cursive;
  --script-formal:'Pinyon Script', cursive;

  --maxw: 1240px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--sans);
  font-weight:300;
  color:var(--ink);
  background:var(--cream);
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
  font-size:16px;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

/* ---------- Typography helpers ---------- */
h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; line-height:1.12; letter-spacing:.01em; }
.eyebrow{
  font-family:var(--sans);
  font-size:.7rem; font-weight:400;
  letter-spacing:.32em; text-transform:uppercase;
  color:var(--coral); margin-bottom:1.1rem;
}
.script{ font-family:var(--script); color:var(--coral-deep); }
.script-lg{ font-family:var(--script); font-size:2.4rem; color:var(--coral-deep); line-height:1; }
.lead{ font-size:1.05rem; color:var(--ink-soft); max-width:54ch; }
p{ margin-bottom:1rem; }

/* ---------- Layout ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 2rem; }
.section{ padding:6.5rem 0; }
.section--tight{ padding:4.5rem 0; }
.bg-cream{ background:var(--cream); }
.bg-white{ background:var(--white); }
.bg-blush{ background:var(--blush); }
.bg-sage{ background:var(--sage); }
.bg-blue{ background:var(--dusty-blue); }
.bg-creamdeep{ background:var(--cream-deep); }
.center{ text-align:center; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;
  font-family:var(--sans); font-size:.72rem; font-weight:400;
  letter-spacing:.26em; text-transform:uppercase;
  padding:1rem 2.4rem; cursor:pointer;
  border:1px solid var(--coral); color:var(--coral-deep);
  background:transparent; transition:all .4s var(--ease);
}
.btn:hover{ background:var(--coral); color:var(--white); }
.btn--solid{ background:var(--coral); color:var(--white); }
.btn--solid:hover{ background:var(--coral-deep); border-color:var(--coral-deep); }
.btn--light{ border-color:var(--white); color:var(--white); }
.btn--light:hover{ background:var(--white); color:var(--ink); }

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(251,246,238,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  max-width:var(--maxw); margin:0 auto; padding:1.6rem 3.5rem; gap:1.5rem;
}
.nav .nav-links{ justify-content:flex-end; }
/* ---- b's collection logo lockup ---- */
.brand{ display:inline-flex; flex-direction:column; align-items:flex-start; line-height:.82; flex-shrink:0; }
.brand .logo-b{
  font-family:var(--script-formal); font-size:3rem; color:var(--coral-deep);
  display:inline-block;
}
.brand .logo-b .ap{ font-size:.62em; }
.brand .logo-sub{
  display:block; font-family:var(--serif); font-size:.74rem; font-weight:500;
  letter-spacing:.46em; text-transform:lowercase; color:var(--coral);
  margin-top:.05rem; padding-left:.12em;
}
/* Real logo image (favicon-style mark, top-left) */
.brand-logo{ height:54px; width:auto; display:block; }
.brand-fallback{ display:none; }
.brand-fallback.show{ display:inline-flex; flex-direction:column; align-items:flex-start; line-height:.82; }
.site-footer .brand-logo{ height:66px; }
.nav-links{ display:flex; gap:2.4rem; list-style:none; align-items:center; }
.nav-links a{
  font-size:.7rem; letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink); padding-bottom:3px; position:relative; transition:color .3s;
}
.nav-links a::after{
  content:''; position:absolute; left:0; bottom:0; width:0; height:1px;
  background:var(--coral); transition:width .35s var(--ease);
}
.nav-links a:hover{ color:var(--coral-deep); }
.nav-links a:hover::after, .nav-links a.active::after{ width:100%; }
.nav-links a.active{ color:var(--coral-deep); }
.nav-toggle{ display:none; background:none; border:0; font-size:1.4rem; color:var(--ink); cursor:pointer; }

/* ---------- Photo frames / placeholders ---------- */
.photo{
  position:relative; overflow:hidden;
  background:
    linear-gradient(135deg,var(--cream-deep),var(--blush) 120%);
  border:1px solid rgba(255,255,255,.6);
}
.photo .ph{
  position:absolute; inset:0; z-index:1;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:1rem; gap:.5rem;
  color:var(--ink-soft);
}
.photo .ph svg{ width:34px; height:34px; opacity:.5; }
.photo .ph .fn{
  font-size:.6rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--coral); opacity:.85;
}
.photo .ph .cap{ font-family:var(--serif); font-size:1rem; font-style:italic; }
.photo img{
  position:relative; z-index:2; width:100%; height:100%; object-fit:cover; display:block;
}

/* ---------- Pin / location tag (scrapbook detail) ---------- */
.pin{
  position:absolute; top:1rem; left:1rem; z-index:5;
  background:var(--white); color:var(--ink);
  font-size:.58rem; letter-spacing:.18em; text-transform:uppercase;
  padding:.4rem .7rem; display:flex; align-items:center; gap:.35rem;
  box-shadow:0 4px 14px rgba(74,65,59,.08);
}
.pin svg{ width:10px; height:10px; }

/* ---------- Hero ---------- */
.hero{ position:relative; background:var(--cream); overflow:hidden; overflow-x:hidden; }
.hero-grid{
  display:grid; grid-template-columns:1fr 1fr; align-items:stretch;
  min-height:84vh; gap:2.5rem;
  max-width:var(--maxw); margin:0 auto; padding:0 3.5rem;   /* push it all in */
}
.hero-media{ position:relative; }
.hero-media .photo{ position:absolute; inset:0; border:0; }
.hero-copy{
  display:flex; flex-direction:column; justify-content:center;
  padding:4rem 0; background:transparent;
}
.hero-copy h1{ font-size:clamp(3rem,5.4vw,5.2rem); margin:.4rem 0 1.4rem; }
.hero-copy h1 em{ font-style:italic; color:var(--coral-deep); }
.hero-copy .lead{ margin-bottom:2.2rem; }
/* layered floating frame */
.float-frame{
  position:absolute; z-index:6; width:42%; bottom:-3rem; left:-3rem;
  box-shadow:0 24px 50px rgba(74,65,59,.18);
  border:6px solid var(--white); aspect-ratio:3/4; background:var(--sage);
}

/* ---------- Hero: transparent product collage on cream ---------- */
.hero-media--collage{
  background:transparent;
  display:flex;
  align-items:stretch;
  justify-content:center;
  padding:2.5vh 0 2.5vh;
  overflow:visible;
}
.hero-collage-img{
  display:block;
  width:100%;
  height:100%;
  max-height:88vh;
  object-fit:cover;              /* fill the column */
  object-position:center;
  border-radius:8px;             /* rounded corners */
}

/* ---------- Editorial hero collage (legacy tiles) ---------- */
.hero-collage{
  display:grid; grid-template-columns:1fr 1fr; gap:1.1rem;
  align-content:center; padding:3.2rem 5vw 3.2rem 1rem;
}
.hero-collage .photo{
  border:6px solid var(--white);
  box-shadow:0 18px 44px rgba(74,65,59,.16);
  aspect-ratio:3/4; background:var(--cream-deep);
}
.hero-collage .c1{ margin-top:2.6rem; transform:rotate(-1.6deg); }
.hero-collage .c2{ transform:rotate(1.4deg); }
.hero-collage .c3{ transform:rotate(1.2deg); margin-top:-1.4rem; }
.hero-collage .c4{ transform:rotate(-1.2deg); }
.hero-collage .photo .ph .cap{ font-size:.82rem; }
.hero-collage .photo .ph .fn{ font-size:.5rem; }

/* ---------- Marquee / announcement bar ---------- */
.ann{
  background:var(--coral); color:var(--cream);
  text-align:center; font-size:.62rem; letter-spacing:.26em;
  text-transform:uppercase; padding:.9rem 1rem;
}

/* ---------- Section heading block ---------- */
.shead{ text-align:center; max-width:60ch; margin:0 auto 3.4rem; }
.shead h2{ font-size:clamp(2rem,3.4vw,2.9rem); margin-bottom:.6rem; }
.shead .script-lg{ margin-bottom:.4rem; }
.divider{ width:46px; height:1px; background:var(--coral); margin:1.3rem auto 0; opacity:.6; }

/* ---------- Collections grid ---------- */
.col-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; }
.col-card{ text-align:center; }
.col-card .photo{ aspect-ratio:4/5; margin-bottom:1.2rem; }
.col-card h3{ font-size:1.45rem; margin-bottom:.2rem; }
.col-card .meta{ font-size:.68rem; letter-spacing:.22em; text-transform:uppercase; color:var(--coral); }
.col-card .price{ color:var(--ink-soft); font-style:italic; font-family:var(--serif); font-size:1.05rem; margin-top:.3rem; }

/* ---------- Meet Brenna split ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:0; align-items:center; }
.split--cream{ background:var(--cream); }
.split .media{ position:relative; min-height:560px; }
.split .media .photo{ position:absolute; inset:0; border:0; }
.split .copy{ padding:5rem clamp(2rem,6vw,6rem); }
.split .copy h2{ font-size:clamp(2rem,3.4vw,3rem); margin:.3rem 0 1.4rem; }
.split .stamp{
  position:absolute; z-index:6; bottom:2rem; right:-2.5rem; width:34%;
  border:6px solid var(--white); box-shadow:0 18px 40px rgba(74,65,59,.16);
  aspect-ratio:1; background:var(--butter);
}
.signature{ font-family:var(--script); font-size:2.2rem; color:var(--coral-deep); margin-top:1.5rem; }

/* ---------- Custom band ---------- */
.band{ position:relative; text-align:center; padding:6rem 2rem; }
.band .inner{ max-width:64ch; margin:0 auto; }
.band h2{ font-size:clamp(2.2rem,4vw,3.4rem); color:var(--ink); margin-bottom:1.2rem; }

/* ---------- Testimonials ---------- */
.quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:2.4rem; }
.quote{ text-align:center; padding:2rem 1.2rem; }
.quote .stars{ color:var(--gold); letter-spacing:.25em; font-size:.8rem; margin-bottom:1rem; }
.quote p{ font-family:var(--serif); font-style:italic; font-size:1.25rem; color:var(--ink); line-height:1.5; }
.quote .who{ font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; color:var(--coral); margin-top:1rem; }

/* ---------- Instagram / follow grid ---------- */
.ig-grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:.6rem; }
.ig-grid .photo{ aspect-ratio:1; }
.ig-grid .photo::after{
  content:''; position:absolute; inset:0; z-index:4; background:rgba(201,133,107,0);
  transition:background .35s; pointer-events:none;
}
.ig-grid .photo:hover::after{ background:rgba(201,133,107,.18); }

/* ---------- Newsletter strip ---------- */
.news{ background:var(--blush); text-align:center; padding:4.5rem 2rem; }
.news h3{ font-size:1.9rem; margin-bottom:.5rem; }
.news .lead{ margin:0 auto 1.8rem; }
.news form{ display:flex; gap:.6rem; justify-content:center; flex-wrap:wrap; max-width:560px; margin:0 auto; }
.field{
  font-family:var(--sans); font-size:.8rem; letter-spacing:.06em;
  padding:1rem 1.2rem; border:1px solid var(--line); background:var(--white); color:var(--ink);
  flex:1; min-width:200px;
}
.field:focus{ outline:none; border-color:var(--coral); }

/* ---------- Forms (enquiry / contact) ---------- */
.form-card{ background:var(--white); padding:clamp(2rem,4vw,3.5rem); border:1px solid var(--line); }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-group{ margin-bottom:1.2rem; }
label{ display:block; font-size:.64rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:.5rem; }
input.field, select.field, textarea.field{ width:100%; }
textarea.field{ min-height:140px; resize:vertical; font-family:var(--sans); }

/* ---------- File upload ---------- */
.file-drop{
  display:flex; align-items:center; gap:1rem; cursor:pointer;
  border:1px dashed var(--blush-deep); background:var(--cream);
  padding:1.1rem 1.3rem; transition:all .3s var(--ease);
}
.file-drop:hover{ border-color:var(--coral-deep); background:var(--blush); }
.file-drop.has-file{ border-style:solid; border-color:var(--sage-deep); background:var(--white); }
.file-icon{ flex:0 0 auto; width:40px; height:40px; border-radius:50%; background:var(--blush);
  display:flex; align-items:center; justify-content:center; color:var(--coral-deep); }
.file-icon svg{ width:20px; height:20px; }
.file-text{ display:flex; flex-direction:column; line-height:1.3; }
.file-text strong{ font-family:var(--sans); font-weight:500; font-size:.8rem; letter-spacing:.08em;
  text-transform:uppercase; color:var(--ink); }
.file-name{ font-size:.82rem; color:var(--ink-soft); font-style:italic; font-family:var(--serif); }

/* ---------- Page hero (interior) ---------- */
.page-hero{ text-align:center; padding:5rem 2rem 3.5rem; background:var(--cream); }
.page-hero h1{ font-size:clamp(2.6rem,5vw,4rem); }
.page-hero .lead{ margin:1rem auto 0; }

/* ---------- Shop filters ---------- */
.filters{ display:flex; gap:1.6rem; justify-content:center; flex-wrap:wrap; margin-bottom:3rem; }
.filters button{
  background:none; border:0; cursor:pointer;
  font-family:var(--sans); font-size:.7rem; letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink-soft); padding-bottom:4px; border-bottom:1px solid transparent; transition:.3s;
}
.filters button.active, .filters button:hover{ color:var(--coral-deep); border-color:var(--coral); }
.shop-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:2.4rem 2rem; }

/* ---------- Gallery masonry ---------- */
.masonry{ column-count:3; column-gap:1rem; }
.masonry .photo{ break-inside:avoid; margin-bottom:1rem; }
.masonry .photo.tall{ aspect-ratio:3/4; }
.masonry .photo.sq{ aspect-ratio:1; }
.masonry .photo.wide{ aspect-ratio:4/3; }

/* ---------- Steps (custom process) ---------- */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.6rem; }
.step{ text-align:center; }
.step .num{ font-family:var(--script); font-size:2.6rem; color:var(--coral); line-height:1; }
.step h4{ font-size:1.25rem; margin:.4rem 0 .5rem; }
.step p{ font-size:.92rem; color:var(--ink-soft); }

/* ---------- Footer ---------- */
.site-footer{ background:var(--ink); color:var(--cream); padding:4.5rem 0 2rem; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:2.5rem; }
.site-footer .name{ font-family:var(--serif); font-size:1.5rem; letter-spacing:.18em; text-transform:uppercase; }
.site-footer .tag{ font-family:var(--script); color:var(--butter); font-size:1.1rem; }
.site-footer h5{ font-size:.66rem; letter-spacing:.24em; text-transform:uppercase; color:var(--butter); margin-bottom:1rem; }
.site-footer ul{ list-style:none; }
.site-footer li{ margin-bottom:.6rem; font-size:.85rem; opacity:.85; }
.site-footer a:hover{ color:var(--butter); }
.foot-social{ display:flex; gap:1rem; margin-top:1rem; }
.foot-social a{ width:36px; height:36px; border:1px solid rgba(251,246,238,.3); border-radius:50%; display:flex; align-items:center; justify-content:center; transition:.3s; }
.foot-social a:hover{ background:var(--butter); border-color:var(--butter); color:var(--ink); }
.foot-social svg{ width:16px; height:16px; }
.foot-bottom{ text-align:center; border-top:1px solid rgba(251,246,238,.15); margin-top:3rem; padding-top:1.6rem; font-size:.7rem; letter-spacing:.12em; opacity:.6; }

/* ---------- Font-style chooser (custom orders) ---------- */
.fontpick{ display:flex; gap:1rem; }
.fontpick label{
  flex:1; margin:0; cursor:pointer;
  border:1px solid var(--line); background:var(--white);
  padding:1rem 1rem 1.1rem; text-align:center; transition:all .3s var(--ease);
  display:flex; flex-direction:column; align-items:center; gap:.35rem;
}
.fontpick input{ position:absolute; opacity:0; pointer-events:none; }
.fontpick .sample{ color:var(--ink); line-height:1; }
.fontpick .opt-cursive .sample{ font-family:var(--script-formal); font-size:2.2rem; color:var(--coral-deep); }
.fontpick .opt-bold .sample{ font-family:var(--serif); font-weight:600; font-size:1.5rem; letter-spacing:.04em; text-transform:uppercase; }
.fontpick .opt-name{ font-size:.58rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-soft); }
.fontpick label:hover{ border-color:var(--blush-deep); }
.fontpick input:checked + .sample,
.fontpick label:has(input:checked){ border-color:var(--coral); background:var(--blush); box-shadow:0 6px 18px rgba(174,105,101,.12); }

/* ---------- Footer logo + subtle studio credit ---------- */
.site-footer .brand{ margin-bottom:.2rem; }
.site-footer .brand .logo-b{ color:var(--blush-deep); }
.site-footer .brand .logo-sub{ color:var(--butter); }
.ohsay-credit{
  display:block; margin-top:.7rem; font-size:.64rem; letter-spacing:.08em; opacity:.5;
}
.ohsay-credit a{ transition:opacity .3s; }
.ohsay-credit a:hover{ opacity:1; }
.ohsay-credit .om{ font-family:'Instrument Serif', Georgia, serif; font-size:.92rem; letter-spacing:.01em; color:var(--cream); }
.ohsay-credit .om-italic{ font-style:italic; color:#C8606E; }
.ohsay-credit .om-dot{ color:#C8606E; }

/* ---------- Reveal on scroll ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero-grid{ grid-template-columns:1fr; min-height:auto; }   /* image stacks BELOW text */
  .hero-media{ min-height:auto; }
  .hero-media--collage{ justify-content:center; padding:1.5rem 1rem 2.5rem; }
  .hero-collage-img{ width:auto; height:auto; max-width:94%; max-height:62vh; margin-right:0; }
  .hero-collage{ padding:2rem; }
  .float-frame{ display:none; }
  .split{ grid-template-columns:1fr; }
  .split .media{ min-height:420px; }
  .split .stamp{ display:none; }
  .col-grid, .shop-grid, .quotes, .steps{ grid-template-columns:1fr 1fr; }
  .ig-grid{ grid-template-columns:repeat(3,1fr); }
  .masonry{ column-count:2; }
}
@media(max-width:640px){
  .nav{ flex-wrap:wrap; gap:.8rem; justify-content:space-between; padding:1.6rem 1.5rem; }
  .nav-links{ position:fixed; inset:0 0 0 auto; width:74%; max-width:320px;
    flex-direction:column; background:var(--cream); padding:5rem 2rem; gap:1.6rem;
    transform:translateX(100%); transition:transform .4s var(--ease); box-shadow:-10px 0 40px rgba(0,0,0,.1); z-index:60; }
  .nav-links.open{ transform:none; }
  .nav-toggle{ display:block; order:2; }
  .brand{ order:1; }
  .brand .logo-b{ font-size:2.5rem; }
  .col-grid, .shop-grid, .quotes, .steps, .form-row{ grid-template-columns:1fr; }
  .fontpick{ flex-direction:column; }
  .hero-collage-img{ max-width:96%; max-height:54vh; }
  .ig-grid{ grid-template-columns:repeat(2,1fr); }
  .masonry{ column-count:1; }
  .section{ padding:4rem 0; }
  .foot-grid{ grid-template-columns:1fr; }
}

/* ---------- Shipping & packaging section ---------- */
.ship-grid{ display:grid; grid-template-columns:1fr 1fr; gap:3.4rem; align-items:center; }
.ship-photo{ aspect-ratio:4/5; }
.ship-copy h2{ font-size:clamp(1.8rem,3vw,2.6rem); margin:.3rem 0 1.2rem; }
.ship-copy p{ font-size:.95rem; color:var(--ink-soft); margin-bottom:.9rem; }
.ship-copy strong{ color:var(--ink); font-weight:500; }
@media(max-width:780px){ .ship-grid{ grid-template-columns:1fr; gap:1.6rem; } }

/* ============================================================
   CART · PERSONALIZATION · CHECKOUT
   ============================================================ */
/* Nav cart link + badge */
.bsc-navcart{ position:relative; display:inline-flex; align-items:center; color:var(--ink); }
.bsc-navcart svg{ width:20px; height:20px; }
.bsc-navcart:hover{ color:var(--coral-deep); }
.bsc-count{
  position:absolute; top:-8px; right:-11px; min-width:17px; height:17px; padding:0 4px;
  background:var(--coral); color:#fff; border-radius:9px; font-family:var(--sans);
  font-size:.6rem; line-height:17px; text-align:center; letter-spacing:0; opacity:0; transition:opacity .25s;
}
.bsc-count.has{ opacity:1; }

/* Add-to-cart button on shop cards */
.col-card .add-to-cart{ margin-top:.7rem; width:100%; font-size:.66rem; padding:.85rem 1rem; }

/* Overlay + drawer */
.bsc-overlay{
  position:fixed; inset:0; background:rgba(70,63,57,.42); opacity:0; visibility:hidden;
  transition:opacity .35s var(--ease); z-index:90;
}
.bsc-overlay.open{ opacity:1; visibility:visible; }
.bsc-drawer{
  position:fixed; top:0; right:0; height:100%; width:420px; max-width:92vw;
  background:var(--cream); z-index:95; display:flex; flex-direction:column;
  transform:translateX(102%); transition:transform .4s var(--ease);
  box-shadow:-18px 0 50px rgba(70,63,57,.18);
}
.bsc-drawer.open{ transform:none; }
.bsc-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:1.5rem 1.6rem; border-bottom:1px solid var(--line); flex-shrink:0;
}
.bsc-title{ font-family:var(--serif); font-size:1.5rem; color:var(--ink); }
.bsc-close{ background:none; border:0; font-size:1.7rem; line-height:1; color:var(--ink-soft); cursor:pointer; }
.bsc-close:hover{ color:var(--coral-deep); }
.bsc-body{ flex:1; overflow-y:auto; padding:1.2rem 1.6rem 2rem; }

/* Empty */
.bsc-empty{ text-align:center; padding:3rem 1rem; color:var(--ink-soft); }
.bsc-empty p{ font-family:var(--serif); font-style:italic; font-size:1.2rem; margin-bottom:1.4rem; }

/* Items */
.bsc-item{ display:flex; gap:.9rem; padding:1.1rem 0; border-bottom:1px solid var(--line); }
.bsc-thumb{ width:74px; height:90px; flex-shrink:0; background:var(--cream-deep); overflow:hidden; border:1px solid var(--line); }
.bsc-thumb img{ width:100%; height:100%; object-fit:cover; }
.bsc-info{ flex:1; min-width:0; }
.bsc-name{ font-family:var(--serif); font-size:1.05rem; color:var(--ink); line-height:1.2; }
.bsc-unit{ font-size:.72rem; color:var(--ink-soft); margin:.15rem 0 .5rem; }
.bsc-perstoggle{ display:flex; align-items:center; gap:.45rem; font-size:.72rem; letter-spacing:.06em;
  text-transform:none; color:var(--coral-deep); cursor:pointer; margin-bottom:.4rem; }
.bsc-perstoggle input{ accent-color:var(--coral); }
.bsc-persfields{ margin:.2rem 0 .6rem; }
.bsc-pname{ width:100%; padding:.55rem .7rem; font-size:.8rem; margin-bottom:.5rem; }
.bsc-fontpick{ display:flex; gap:.5rem; }
.bsc-fontpick label{
  flex:1; text-align:center; padding:.4rem; border:1px solid var(--line); background:var(--white);
  cursor:pointer; transition:.25s; margin:0;
}
.bsc-fontpick label.sel{ border-color:var(--coral); background:var(--blush); }
.bsc-fontpick input{ position:absolute; opacity:0; pointer-events:none; }
.bsc-fontpick .bsc-fopt{ font-family:var(--sans); font-size:.82rem; letter-spacing:.04em; color:var(--ink); }
.bsc-foplabel{ display:block; font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); margin:.2rem 0 .4rem; }
.bsc-row{ display:flex; align-items:center; gap:.8rem; margin-top:.3rem; }
.bsc-qty{ display:flex; align-items:center; border:1px solid var(--line); }
.bsc-qty button{ width:28px; height:28px; background:none; border:0; cursor:pointer; color:var(--ink); font-size:1rem; }
.bsc-qty button:hover{ color:var(--coral-deep); }
.bsc-qty span{ min-width:26px; text-align:center; font-size:.85rem; }
.bsc-line{ font-family:var(--serif); font-size:1.05rem; color:var(--ink); margin-left:auto; }
.bsc-remove{ background:none; border:0; cursor:pointer; font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); }
.bsc-remove:hover{ color:var(--coral-deep); }

/* Footer / subtotal */
.bsc-foot{ padding-top:1.2rem; }
.bsc-sub{ display:flex; justify-content:space-between; align-items:baseline; font-family:var(--serif); margin-bottom:.6rem; }
.bsc-sub span{ font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-soft); font-family:var(--sans); }
.bsc-sub strong{ font-size:1.5rem; font-weight:500; }
.bsc-note{ font-size:.72rem; color:var(--ink-soft); line-height:1.5; margin-bottom:1rem; }
.bsc-checkout, .bsc-place{ width:100%; }

/* Checkout form */
.bsc-checkout-form h4{ font-family:var(--serif); font-size:1.15rem; margin:1rem 0 .6rem; }
.bsc-checkout-form .field{ width:100%; margin-bottom:.6rem; padding:.7rem .8rem; font-size:.82rem; }
.bsc-checkout-form textarea.field{ min-height:80px; }
.bsc-2col{ display:grid; grid-template-columns:1fr 1fr; gap:.6rem; }
.bsc-uplabel{ display:block; font-size:.7rem; letter-spacing:.06em; color:var(--ink); margin:.2rem 0 .4rem; }
.bsc-uplabel span{ color:var(--ink-soft); }
.bsc-file{ width:100%; font-size:.78rem; padding:.5rem; margin-bottom:.6rem; }
.bsc-back{ background:none; border:0; cursor:pointer; font-size:.72rem; letter-spacing:.1em; color:var(--coral-deep); padding:0; margin-bottom:.4rem; }

/* Success */
.bsc-success{ text-align:center; padding:2.4rem 1rem; }
.bsc-tick{ width:54px; height:54px; border-radius:50%; background:var(--sage); color:#fff; font-size:1.6rem;
  display:flex; align-items:center; justify-content:center; margin:0 auto 1.2rem; }
.bsc-success h4{ font-family:var(--serif); font-size:1.6rem; margin-bottom:.6rem; }
.bsc-pay{ background:var(--blush); border:1px solid var(--blush-deep); padding:1.4rem 1.2rem; margin:1.2rem 0; }
.bsc-pay-head{ font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--coral-deep); margin-bottom:.4rem; }
.bsc-pay-amt{ font-family:var(--serif); font-size:2.2rem; color:var(--ink); margin-bottom:.9rem; }
.bsc-venmo{ width:100%; background:#3D95CE; border-color:#3D95CE; }
.bsc-venmo:hover{ background:#2f7bab; border-color:#2f7bab; }

@media(max-width:640px){
  .bsc-drawer{ width:100%; max-width:100%; }
}
