/* ============================================================
   BELLES BOUTIQUE & BAKERY — Design System
   Inspired by vectorocean.net/artisancakes
   Client Palette: Blush Rose / Dusty Pink / Warm Beige / Ivory / Taupe
   ============================================================ */

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

/* ===== COMING SOON BANNER ===== */
#coming-soon-banner{
  display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;
  background:var(--cranberry);color:rgba(255,255,255,.92);
  padding:9px 48px 9px 20px;
  font-family:var(--font-body);font-size:12px;font-weight:400;
  letter-spacing:.3px;line-height:1.5;
  position:fixed;top:0;left:0;right:0;z-index:201;text-align:center;
}
#coming-soon-banner ~ .csb-icon{font-size:14px;flex-shrink:0}
.csb-text{color:rgba(255,255,255,.88)}
.csb-link{
  color:var(--dusty-pink);font-weight:500;text-decoration:underline;
  text-underline-offset:2px;white-space:nowrap;flex-shrink:0;
  transition:color var(--ease);
}
.csb-link:hover{color:white}
.csb-close{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);
  background:none;border:none;color:rgba(255,255,255,.7);
  font-size:14px;cursor:pointer;padding:4px;line-height:1;
  transition:color var(--ease);
}
.csb-close:hover{color:white}
@media(max-width:600px){
  #coming-soon-banner{gap:6px;padding:9px 40px 9px 14px}
  .csb-link{display:none}
  #coming-soon-banner ~ #site-header{top:38px}
}

/* ===== RESET ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--ivory);
  color:var(--brown-dark);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  display:flex;flex-direction:column;
}
main{flex:1}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit}
ul{list-style:none}
input,select,textarea{font-family:inherit}

/* ===== COLOUR PALETTE ===== */
:root{
  /* ── Exact client palette ── */
  --blush:           #D9A3A0;  /* buttons, accents, highlights */
  --dusty-pink:      #E7B9B4;  /* backgrounds, soft fills */
  --warm-beige:      #E6D2C3;  /* neutral fills, labels */
  --ivory:           #FAF7F4;  /* main background */
  --taupe:           #C7B1A3;  /* borders, secondary text */

  /* ── Extended (from screenshot analysis) ── */
  --sage:            #C8D9B8;  /* features strip bg */
  --sage-dark:       #7A9E6A;  /* icon / text on sage */
  --cranberry:       #A8393A;  /* specialty sections, dark CTAs */
  --cranberry-hover: #8F2E2F;
  --brown-dark:      #3D2B1F;  /* headings, primary text */
  --brown-mid:       #6B4C3B;  /* body copy */
  --brown-light:     #9A7B6C;  /* muted / secondary text */
  --white:           #FFFFFF;

  /* ── Typography ── */
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-script:  'Dancing Script', cursive;
  --font-body:    'Jost', system-ui, sans-serif;

  /* ── Shadows ── */
  --shadow-xs: 0 1px 4px rgba(61,43,31,.06);
  --shadow-sm: 0 2px 12px rgba(61,43,31,.08);
  --shadow-md: 0 4px 24px rgba(61,43,31,.11);
  --shadow-lg: 0 8px 40px rgba(61,43,31,.16);

  /* ── Radius ── */
  --r-sm:   8px;
  --r-md:   16px;
  --r-lg:   24px;
  --r-pill: 100px;

  /* ── Motion ── */
  --ease:        0.3s cubic-bezier(0.4,0,0.2,1);
  --ease-spring: 0.4s cubic-bezier(0.34,1.56,0.64,1);
}

/* ===== UTILITIES ===== */
.container    {max-width:1180px;margin:0 auto;padding:0 40px}
.container-sm {max-width:840px; margin:0 auto;padding:0 40px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* ===== TYPOGRAPHY ===== */
.section-title{
  font-family:var(--font-display);
  font-size:clamp(30px,5vw,54px);
  font-weight:400;letter-spacing:.07em;text-transform:uppercase;
  color:var(--brown-dark);line-height:1.08;
}
.section-title .script{
  font-family:var(--font-script);
  font-weight:500;letter-spacing:0;text-transform:none;font-size:1.06em;
}
.section-eyebrow{
  font-family:var(--font-body);font-size:10px;font-weight:500;
  letter-spacing:3px;text-transform:uppercase;
  color:var(--blush);display:block;margin-bottom:12px;
}
.section-lead{
  font-size:15px;color:var(--brown-light);
  max-width:520px;margin:14px auto 0;line-height:1.8;
}

/* ===== ARCH IMAGE ===== */
.arch-wrap{
  border-radius:50% 50% 0 0 / 42% 42% 0 0;
  overflow:hidden;display:block;
}
.arch-wrap img{width:100%;height:100%;object-fit:cover;display:block}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-body);font-size:13px;font-weight:500;letter-spacing:.3px;
  padding:13px 30px;border-radius:var(--r-pill);border:none;
  text-decoration:none;cursor:pointer;white-space:nowrap;
  transition:background var(--ease),transform var(--ease-spring),box-shadow var(--ease);
}
.btn-blush{
  background:var(--blush);color:var(--white);
  box-shadow:0 4px 16px rgba(217,163,160,.35);
}
.btn-blush:hover{background:var(--cranberry);transform:translateY(-2px);box-shadow:0 8px 24px rgba(168,57,58,.3)}
.btn-outline-white{background:transparent;color:var(--white);border:1.5px solid rgba(255,255,255,.6);position:relative;z-index:2}
.btn-outline-white:hover{background:rgba(255,255,255,.15);border-color:white}
.btn-cranberry{background:var(--cranberry);color:var(--white);box-shadow:0 4px 16px rgba(168,57,58,.25)}
.btn-cranberry:hover{background:var(--cranberry-hover);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--brown-mid);border:1px solid var(--taupe)}
.btn-ghost:hover{border-color:var(--blush);color:var(--cranberry)}

/* ===== HEADER / NAV ===== */
#site-header{
  position:fixed;top:0;left:0;right:0;z-index:200;
  transition:background var(--ease),box-shadow var(--ease);
}
#site-header.scrolled{
  background:rgba(250,247,244,.96);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  box-shadow:0 1px 20px rgba(61,43,31,.08);
}
.header-inner{
  max-width:1180px;margin:0 auto;padding:18px 40px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}

/* Logo */
.logo-link{display:flex;align-items:center;gap:10px;flex-shrink:0}
.logo-icon-img{
  height:62px;width:auto;flex-shrink:0;
  display:flex;align-items:center;
  transition:transform var(--ease-spring);
}
.logo-icon-img img{
  height:62px;width:auto;
  border-radius:50%;
  background:white;
  box-shadow:0 2px 10px rgba(217,163,160,.35);
}
.logo-link:hover .logo-icon-img{transform:scale(1.05)}
.logo-name{
  font-family:var(--font-display);font-size:15px;font-weight:500;
  color:var(--white);letter-spacing:.03em;display:block;line-height:1.2;
  transition:color var(--ease);white-space:nowrap;
}
.logo-sub{
  font-family:var(--font-body);font-size:9px;font-weight:400;
  letter-spacing:2.5px;text-transform:uppercase;
  color:rgba(255,255,255,.65);transition:color var(--ease);
}
#site-header.scrolled .logo-name{color:var(--brown-dark)}
#site-header.scrolled .logo-sub{color:var(--blush)}
#site-header.scrolled .logo-icon-img img{box-shadow:0 2px 12px rgba(168,57,58,.2)}

/* Nav links */
#main-nav{display:flex;align-items:center;gap:2px}
#main-nav a{
  font-family:var(--font-body);font-size:13px;font-weight:400;letter-spacing:.3px;
  color:rgba(255,255,255,.85);padding:8px 14px;border-radius:var(--r-pill);
  transition:color var(--ease),background var(--ease);white-space:nowrap;
}
#main-nav a:hover,#main-nav a.active{color:white;background:rgba(255,255,255,.12)}
#site-header.scrolled #main-nav a{color:var(--brown-mid)}
#site-header.scrolled #main-nav a:hover,
#site-header.scrolled #main-nav a.active{color:var(--cranberry);background:rgba(168,57,58,.06)}

/* Nav CTA */
.btn-nav-contact{
  font-family:var(--font-body);font-size:12px;font-weight:500;
  background:var(--sage);color:var(--brown-dark);
  padding:9px 20px;border-radius:var(--r-pill);border:none;
  transition:background var(--ease),transform var(--ease-spring);
  text-decoration:none;white-space:nowrap;display:inline-block;
}
.btn-nav-contact:hover{background:var(--sage-dark);color:white;transform:translateY(-1px)}

/* Cart button */
.cart-btn{
  position:relative;
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.35);
  color:white;width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:background var(--ease),transform var(--ease-spring);
}
#site-header.scrolled .cart-btn{background:var(--warm-beige);border-color:var(--taupe);color:var(--brown-dark)}
.cart-btn:hover{transform:scale(1.1)}
.cart-btn svg{width:18px;height:18px}
.cart-badge{
  position:absolute;top:-4px;right:-4px;
  background:var(--blush);color:white;font-size:10px;font-weight:700;
  width:18px;height:18px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transform:scale(0);transition:transform var(--ease-spring);
}
.cart-badge.show{transform:scale(1)}

/* Mobile toggle */
.mobile-toggle{display:none;background:none;border:none;padding:8px;color:white;position:relative;z-index:201;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
#site-header.scrolled .mobile-toggle{color:var(--brown-dark)}
.mobile-toggle svg{width:22px;height:22px}
.nav-close-btn{display:none}
.header-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}

/* Mobile nav panel — dedicated element, always in DOM */
#mobile-nav-panel{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:6px;
  position:fixed;
  top:0;left:0;right:0;bottom:0;
  background:#FAF7F4;
  z-index:99999;
  opacity:0;
  pointer-events:none;
  visibility:hidden;
}
#mobile-nav-panel.open{
  opacity:1;
  pointer-events:auto;
  visibility:visible;
}
#mobile-nav-panel a{
  display:block;
  width:80%;
  padding:16px 32px;
  text-align:center;
  font-family:var(--font-body);
  font-size:22px;
  font-weight:500;
  color:#1a1a1a;
  text-decoration:none;
  cursor:pointer;
  -webkit-tap-highlight-color:rgba(168,57,58,.1);
  border-radius:8px;
}
#mobile-nav-panel a:active,
#mobile-nav-panel a.active{
  color:var(--cranberry);
  background:rgba(168,57,58,.06);
}
.mobile-nav-close{
  position:absolute;
  top:24px;right:24px;
  background:none;border:none;
  font-size:28px;color:#1a1a1a;
  cursor:pointer;line-height:1;
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
}

@media(max-width:900px){
  .mobile-toggle{display:block}
  #main-nav{display:none}
  #nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:9997;}
  #nav-overlay.open{display:block;}
  .nav-close-btn{display:none}
}

/* ===== HERO ===== */
.hero{
  position:relative;min-height:100vh;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;
  background-position:center 30%;
  background-color:#7a3830;
}
.hero-bg::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(90,40,30,.72) 0%,rgba(60,25,18,.60) 50%,rgba(40,15,10,.75) 100%);
}
.hero-content{
  position:relative;z-index:2;
  padding:140px 40px 60px;max-width:900px;
}
.hero-eyebrow{
  font-family:var(--font-body);font-size:10px;font-weight:500;
  letter-spacing:3.5px;text-transform:uppercase;
  color:rgba(255,255,255,.7);margin-bottom:20px;display:block;
}
.hero-title{
  font-family:var(--font-display);
  font-size:clamp(44px,8vw,88px);
  font-weight:400;letter-spacing:.05em;text-transform:uppercase;
  color:var(--white);line-height:1.02;margin-bottom:28px;
}
.hero-title .script{
  font-family:var(--font-script);
  text-transform:none;letter-spacing:0;
  color:var(--dusty-pink);font-size:.95em;font-weight:500;display:inline;
}
.hero-sub{
  font-size:16px;color:rgba(255,255,255,.65);
  max-width:480px;margin:0 auto 36px;line-height:1.8;
}
.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ===== FEATURES STRIP ===== */
.features-strip{background:var(--sage);padding:40px}
.features-inner{
  max-width:1000px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:40px;
}
.feature-item{display:flex;align-items:center;gap:18px}
.feature-icon{width:54px;height:54px;flex-shrink:0;color:var(--cranberry);opacity:.85}
.feature-icon svg{width:100%;height:100%}
.f-serif{
  font-family:var(--font-display);font-size:15px;font-weight:400;
  letter-spacing:.1em;text-transform:uppercase;color:var(--brown-dark);display:block;
}
.f-script{font-family:var(--font-script);font-size:19px;font-weight:500;color:var(--brown-mid)}
@media(max-width:680px){
  .features-inner{grid-template-columns:1fr;gap:22px}
  .features-strip{padding:32px 24px}
}

/* ===== MEET THE BAKER ===== */
.meet-section{background:var(--ivory);padding:100px 40px 80px}
.meet-inner{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1.15fr;gap:80px;align-items:center;
}
.meet-arch-wrap{
  width:100%;max-width:420px;
  aspect-ratio:3/4;
  border-radius:50% 50% 0 0 / 42% 42% 0 0;
  overflow:hidden;
  background:linear-gradient(135deg,var(--dusty-pink),var(--warm-beige));
  display:flex;align-items:center;justify-content:center;
}
.meet-arch-wrap img{width:100%;height:100%;object-fit:cover}
.meet-arch-placeholder{
  font-family:var(--font-script);font-size:80px;color:var(--blush);opacity:.4;
  text-align:center;padding:40px;
}
.meet-text .section-eyebrow{text-align:left}
.meet-heading{
  font-family:var(--font-display);
  font-size:clamp(36px,5.5vw,58px);
  font-weight:400;letter-spacing:.05em;text-transform:uppercase;
  color:var(--brown-dark);line-height:1.05;margin-bottom:20px;
}
.meet-heading .script{
  font-family:var(--font-script);text-transform:none;
  letter-spacing:0;font-size:1.05em;font-weight:500;
}
.meet-body{font-size:15px;line-height:1.85;color:var(--brown-mid);margin-bottom:16px}
.meet-body strong{font-weight:600;color:var(--brown-dark)}
@media(max-width:760px){
  .meet-inner{grid-template-columns:1fr;gap:40px}
  .meet-arch-wrap{max-width:280px;margin:0 auto}
  .meet-section{padding:60px 24px 52px}
}

/* ===== TRUST STATS ===== */
.stats-section{background:var(--ivory);padding:0 40px 80px;text-align:center}
.stats-heading{
  font-family:var(--font-display);font-size:clamp(28px,5vw,48px);
  font-weight:400;letter-spacing:.07em;text-transform:uppercase;
  color:var(--brown-dark);margin-bottom:50px;
}
.stats-grid{
  max-width:800px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.stat-num{
  font-family:var(--font-display);font-size:clamp(48px,8vw,80px);
  font-weight:300;color:var(--taupe);line-height:1;margin-bottom:8px;
}
.stat-label{
  font-family:var(--font-body);font-size:12px;font-weight:500;
  letter-spacing:2px;text-transform:uppercase;color:var(--brown-light);
}
@media(max-width:540px){.stats-grid{grid-template-columns:1fr;gap:32px}}

/* ===== STORY / VALUES CARDS ===== */
.story-cards{background:var(--ivory);padding:0 40px 80px}
.story-cards-grid{
  max-width:1000px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:stretch;
}
.story-card{
  background:var(--sage);border-radius:var(--r-lg);
  padding:44px 36px;text-align:left;
  display:flex;flex-direction:column;
}
.story-card-title{
  font-family:var(--font-script);font-size:28px;font-weight:500;
  color:var(--brown-dark);margin-bottom:16px;
}
.story-card-body{font-size:14px;line-height:1.85;color:var(--brown-mid)}
.story-card-photo{flex:1;display:flex;flex-direction:column}
.story-card-photo img{flex:1}
/* Photo-only card — no padding, image fills fully */
.story-card.photo-only{padding:0;overflow:hidden;}
.story-card.photo-only img{width:100%;height:100%;min-height:420px;object-fit:cover;object-position:center 15%;border-radius:var(--r-lg);}
@media(max-width:640px){
  .story-cards-grid{grid-template-columns:1fr}
  .story-cards{padding:0 24px 60px}
}

/* ===== SPECIALTY / FEATURED (cranberry bg) ===== */
.specialty-section{
  background:var(--cranberry);
  padding:80px 40px 100px;text-align:center;
  position:relative;overflow:hidden;
}
.specialty-section::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 20% 50%,rgba(255,255,255,.04) 0%,transparent 60%);
}
.specialty-section .section-title{color:var(--white);position:relative}
.specialty-section .section-title .script{color:var(--dusty-pink)}
.specialty-title-block{margin-bottom:52px}
.specialty-arch-grid{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
  position:relative;
}
.specialty-arch-grid.two-col{
  grid-template-columns:repeat(2,1fr);
  max-width:640px;
}
.specialty-arch-item{}
.specialty-arch-frame{
  border-radius:50% 50% 0 0 / 42% 42% 0 0;
  overflow:hidden;background:var(--dusty-pink);aspect-ratio:3/4;
}
.specialty-arch-frame img{width:100%;height:100%;object-fit:cover;display:block}
.specialty-arch-placeholder{
  width:100%;height:100%;
  background:linear-gradient(160deg,var(--dusty-pink),var(--warm-beige));
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-size:48px;color:var(--blush);opacity:.6;
}
.specialty-label{
  text-align:center;margin-top:18px;
  font-family:var(--font-display);font-size:18px;font-weight:400;
  letter-spacing:.04em;color:var(--white);
}
.specialty-label .script{
  font-family:var(--font-script);font-size:16px;
  color:rgba(255,255,255,.7);display:block;margin-top:2px;
}
@media(max-width:680px){
  .specialty-arch-grid{grid-template-columns:1fr;max-width:300px}
  .specialty-section{padding:60px 24px 72px}
}

/* ===== FOOTER CTA SECTION ===== */
.cta-section{
  background:var(--warm-beige);padding:80px 40px;
  display:grid;grid-template-columns:1.1fr 1fr;gap:60px;
  align-items:center;max-width:1100px;margin:0 auto;
}
.cta-text .section-eyebrow{text-align:left}
.cta-heading{
  font-family:var(--font-display);font-size:clamp(36px,5vw,56px);
  font-weight:400;letter-spacing:.05em;text-transform:uppercase;
  color:var(--brown-dark);line-height:1.05;margin-bottom:24px;
}
.cta-heading .script{
  font-family:var(--font-script);text-transform:none;
  letter-spacing:0;font-size:1.06em;font-weight:500;
}
.cta-arch-wrap{
  max-width:360px;aspect-ratio:3/4;
  border-radius:50% 50% 0 0 / 42% 42% 0 0;
  overflow:hidden;
  background:linear-gradient(135deg,var(--dusty-pink),var(--blush));
  display:flex;align-items:center;justify-content:center;
}
.cta-arch-wrap img{width:100%;height:100%;object-fit:cover}
.cta-arch-placeholder{
  font-family:var(--font-script);font-size:72px;color:white;opacity:.5;
}
@media(max-width:680px){
  .cta-section{grid-template-columns:1fr;gap:40px;padding:60px 24px}
  .cta-arch-wrap{max-width:240px;margin:0 auto}
}

/* ===== CONTACT SECTION IN FOOTER ===== */
.footer-cta-section{
  background:var(--warm-beige);padding:80px 40px;text-align:center;
}
.footer-cta-grid{
  max-width:1000px;margin:0 auto;
  display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center;
}
.footer-contact-info{text-align:left}
.footer-contact-info .section-eyebrow{text-align:left}
.footer-contact-heading{
  font-family:var(--font-display);font-size:clamp(32px,5vw,52px);
  font-weight:400;letter-spacing:.05em;text-transform:uppercase;
  color:var(--brown-dark);line-height:1.05;margin-bottom:24px;
}
.footer-contact-heading .script{
  font-family:var(--font-script);text-transform:none;
  letter-spacing:0;font-size:1.05em;font-weight:500;
}
.contact-detail{margin-bottom:16px}
.contact-detail-label{
  font-size:10px;font-weight:500;letter-spacing:2px;
  text-transform:uppercase;color:var(--blush);margin-bottom:4px;display:block;
}
.contact-detail-value{
  font-family:var(--font-display);font-size:18px;font-weight:400;
  color:var(--brown-dark);letter-spacing:.02em;
}
.footer-social-row{display:flex;gap:10px;margin-top:20px}
.footer-social-row a{
  width:38px;height:38px;border-radius:50%;
  background:var(--blush);color:white;
  display:flex;align-items:center;justify-content:center;font-size:15px;
  transition:background var(--ease),transform var(--ease-spring);
}
.footer-social-row a:hover{background:var(--cranberry);transform:scale(1.1)}
@media(max-width:680px){
  .footer-cta-grid{grid-template-columns:1fr;gap:40px}
  .footer-cta-section{padding:60px 24px}
}

/* ===== PRODUCT CARDS ===== */
.products-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:28px;padding-bottom:80px;
}
.product-card{
  background:var(--white);border-radius:var(--r-md);overflow:hidden;
  box-shadow:var(--shadow-xs);border:1px solid var(--warm-beige);
  transition:transform var(--ease),box-shadow var(--ease);cursor:pointer;
  display:flex;flex-direction:column;
}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}

/* ===== CARD GALLERY ===== */
.card-gallery-slide{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;opacity:0;transition:opacity .4s ease;
  pointer-events:none;
}
.card-gallery-slide.active{opacity:1;pointer-events:auto;}
.card-gallery-dots{
  display:flex;justify-content:center;gap:6px;
  padding:8px 0 2px;
}
.card-gallery-dot{
  width:7px;height:7px;border-radius:50%;border:none;
  background:var(--warm-beige);cursor:pointer;padding:0;
  transition:background .2s ease,transform .2s ease;
}
.card-gallery-dot.active{background:var(--blush);transform:scale(1.3);}
.card-gallery-dot:hover:not(.active){background:var(--dusty-pink);}
.product-img-wrap{
  position:relative;padding-top:100%;
  background:var(--dusty-pink);overflow:hidden;
}
.product-img-wrap img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;transition:transform .6s ease;
}
.product-card:hover .product-img-wrap img{transform:scale(1.06)}
.product-badge{
  position:absolute;top:12px;left:12px;
  background:var(--cranberry);color:white;
  font-family:var(--font-body);font-size:9px;font-weight:500;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:5px 12px;border-radius:var(--r-pill);
}
.product-badge.badge-sage{background:var(--sage-dark)}
.product-badge.badge-blush{background:var(--blush)}
.product-info{padding:18px 20px 22px;display:flex;flex-direction:column;flex:1}
.product-name{
  font-family:var(--font-display);font-size:19px;font-weight:400;
  color:var(--brown-dark);line-height:1.3;margin-bottom:6px;
}
.product-desc{
  font-size:12px;color:var(--brown-light);line-height:1.65;margin-bottom:10px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.product-price{
  font-family:var(--font-display);font-size:21px;font-weight:400;
  color:var(--cranberry);margin-bottom:4px;
}
.product-shipping-note{
  font-size:10px;font-weight:500;letter-spacing:.5px;text-transform:uppercase;
  color:var(--sage-dark);margin-bottom:8px;
}
.product-low-stock{font-size:11px;font-weight:600;color:#b03030;margin-bottom:6px}
.variant-select{
  width:100%;padding:8px 12px;margin-bottom:10px;
  font-family:var(--font-body);font-size:12px;
  border:1px solid var(--warm-beige);border-radius:var(--r-sm);
  background:var(--ivory);color:var(--brown-dark);outline:none;
  transition:border-color var(--ease);
}
.variant-select:focus{border-color:var(--blush)}
.btn-add-to-cart{
  width:100%;padding:11px;
  background:var(--blush);color:white;
  font-family:var(--font-body);font-size:11px;font-weight:500;
  letter-spacing:1px;text-transform:uppercase;
  border:none;border-radius:var(--r-pill);transition:background var(--ease);
  margin-top:auto;
}
.btn-add-to-cart:hover{background:var(--cranberry)}
.btn-add-to-cart.added{background:var(--sage-dark);pointer-events:none}

/* ===== VIEW DETAILS BUTTON ===== */
.btn-view-details{
  width:100%;padding:9px;margin-bottom:8px;
  background:transparent;color:var(--brown-mid);
  font-family:var(--font-body);font-size:11px;font-weight:500;
  letter-spacing:.8px;text-transform:uppercase;
  border:1px solid var(--taupe);border-radius:var(--r-pill);
  transition:border-color var(--ease),color var(--ease),background var(--ease);
  cursor:pointer;
}
.btn-view-details:hover{border-color:var(--blush);color:var(--cranberry);background:var(--dusty-pink)}
.placeholder-img{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--dusty-pink) 0%,var(--warm-beige) 100%);
  color:var(--blush);
}
.placeholder-img .p-icon{font-size:38px;opacity:.5;margin-bottom:8px}
.placeholder-img .p-label{font-size:9px;letter-spacing:1.5px;text-transform:uppercase;opacity:.65}

/* ===== FILTER BAR ===== */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;padding:0 0 44px}
.filter-btn{
  font-family:var(--font-body);font-size:11px;font-weight:500;
  letter-spacing:.8px;text-transform:uppercase;
  padding:9px 22px;border-radius:var(--r-pill);
  border:1px solid var(--taupe);background:var(--white);color:var(--brown-light);
  transition:all var(--ease);
}
.filter-btn:hover,.filter-btn.active{background:var(--cranberry);border-color:var(--cranberry);color:white}

/* ===== PAGE HERO BANNER (inner pages) ===== */
.page-hero{
  background:var(--cranberry);padding:120px 40px 72px;
  text-align:center;position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 30% 60%,rgba(231,185,180,.14) 0%,transparent 55%);
}
.page-hero .section-eyebrow{color:rgba(250,247,244,.6);position:relative}
.page-hero h1{
  font-family:var(--font-display);
  font-size:clamp(40px,7vw,72px);
  font-weight:400;letter-spacing:.06em;text-transform:uppercase;
  color:var(--white);line-height:1.04;position:relative;
}
.page-hero h1 .script{
  font-family:var(--font-script);text-transform:none;
  letter-spacing:0;color:var(--dusty-pink);font-size:1.04em;font-weight:500;
}
.page-hero p{
  font-size:16px;color:rgba(250,247,244,.65);
  max-width:500px;margin:16px auto 0;line-height:1.8;position:relative;
}

/* ===== CART DRAWER ===== */
.cart-overlay{
  position:fixed;inset:0;
  background:rgba(61,43,31,.35);backdrop-filter:blur(4px);
  z-index:300;opacity:0;pointer-events:none;transition:opacity var(--ease);
}
.cart-overlay.open{opacity:1;pointer-events:auto}
.cart-drawer{
  position:fixed;top:0;right:0;bottom:0;
  width:400px;max-width:95vw;
  background:var(--ivory);z-index:301;
  display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform var(--ease);box-shadow:var(--shadow-lg);
}
.cart-drawer.open{transform:translateX(0)}
.cart-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;border-bottom:1px solid var(--warm-beige);
}
.cart-head h3{
  font-family:var(--font-display);font-size:22px;font-weight:400;
  letter-spacing:.05em;color:var(--brown-dark);
}
.cart-close-btn{
  background:var(--warm-beige);border:none;width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:var(--brown-mid);
  transition:background var(--ease);
}
.cart-close-btn:hover{background:var(--dusty-pink)}
.cart-close-btn svg{width:16px;height:16px}
.cart-items-list{flex:1;overflow-y:auto;padding:20px 24px}
.cart-empty-state{text-align:center;padding:60px 24px}
.cart-empty-state .empty-icon{font-size:48px;opacity:.3;margin-bottom:12px}
.cart-empty-state p{font-size:14px;color:var(--brown-light)}
.cart-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--warm-beige)}
.cart-item:last-child{border-bottom:none}
.cart-item-thumb{
  width:68px;height:68px;border-radius:var(--r-sm);
  background:var(--dusty-pink);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:22px;overflow:hidden;
}
.cart-item-thumb img{width:100%;height:100%;object-fit:cover}
.cart-item-info{flex:1;min-width:0}
.cart-item-name{
  font-family:var(--font-display);font-size:15px;font-weight:500;
  color:var(--brown-dark);margin-bottom:4px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.cart-item-price{font-size:13px;font-weight:600;color:var(--cranberry);margin-bottom:8px}
.cart-qty-row{display:flex;align-items:center;gap:10px}
.qty-btn{
  width:26px;height:26px;border-radius:50%;
  border:1px solid var(--taupe);background:white;font-size:14px;color:var(--brown-dark);
  display:flex;align-items:center;justify-content:center;
  transition:border-color var(--ease),color var(--ease);
}
.qty-btn:hover{border-color:var(--blush);color:var(--cranberry)}
.qty-val{font-size:13px;font-weight:600;min-width:18px;text-align:center}
.cart-remove-btn{
  background:none;border:none;font-size:11px;color:var(--brown-light);
  text-decoration:underline;padding:0;margin-top:2px;transition:color var(--ease);
}
.cart-remove-btn:hover{color:var(--cranberry)}
.cart-foot{padding:20px 24px;border-top:1px solid var(--warm-beige);background:var(--white)}
.cart-subtotal-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.cart-subtotal-label{
  font-size:11px;font-weight:500;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--brown-light);
}
.cart-subtotal-value{font-size:22px;font-weight:600;color:var(--brown-dark)}
.cart-shipping-note{font-size:11px;color:var(--brown-light);margin-bottom:14px;line-height:1.5}
.btn-checkout-go{
  display:block;width:100%;padding:14px;
  background:var(--blush);color:white;
  font-family:var(--font-body);font-size:13px;font-weight:500;
  letter-spacing:.5px;text-transform:uppercase;
  border:none;border-radius:var(--r-pill);
  transition:background var(--ease),transform var(--ease-spring);
  text-align:center;text-decoration:none;
}
.btn-checkout-go:hover{background:var(--cranberry);transform:translateY(-1px)}
.btn-keep-shopping{
  display:block;width:100%;padding:11px;margin-top:8px;
  background:none;border:1px solid var(--taupe);
  color:var(--brown-light);font-family:var(--font-body);font-size:12px;
  letter-spacing:.5px;text-transform:uppercase;
  border-radius:var(--r-pill);text-align:center;
  transition:border-color var(--ease),color var(--ease);text-decoration:none;
}
.btn-keep-shopping:hover{border-color:var(--blush);color:var(--cranberry)}

/* ===== PRODUCT MODAL ===== */
.product-modal{
  position:fixed;inset:0;z-index:400;
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .3s ease;
}
.product-modal.open{opacity:1;pointer-events:auto}
.modal-bg{position:absolute;inset:0;background:rgba(61,43,31,.5);backdrop-filter:blur(8px)}
.modal-box{
  position:relative;z-index:1;background:white;
  border-radius:var(--r-lg);max-width:860px;width:92vw;
  max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-lg);
}
.modal-close{
  position:absolute;top:16px;right:16px;z-index:2;
  width:36px;height:36px;background:var(--warm-beige);border:none;
  border-radius:50%;font-size:20px;color:var(--brown-dark);
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-sm);transition:background var(--ease);
}
.modal-close:hover{background:var(--dusty-pink)}
.modal-grid{display:grid;grid-template-columns:1fr 1fr}
.modal-imgs{
  padding:28px;
  background:linear-gradient(135deg,var(--dusty-pink) 0%,var(--warm-beige) 100%);
  border-radius:var(--r-lg) 0 0 var(--r-lg);
}
.modal-main-img{width:100%;border-radius:var(--r-sm);aspect-ratio:1;object-fit:cover}
.modal-product-img{width:100%;border-radius:var(--r-sm);aspect-ratio:1;object-fit:cover;display:block}

/* ===== MODAL GALLERY ===== */
.modal-gallery{
  position:relative;width:100%;aspect-ratio:1;
  border-radius:var(--r-sm);overflow:hidden;
}
.modal-gallery-slide{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;display:block;
  opacity:0;transition:opacity .35s ease;
  pointer-events:none;
}
/* ===== ZOOM LIGHTBOX ===== */
.zoom-overlay{
  position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,.92);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .25s ease;
}
.zoom-overlay.open{opacity:1;pointer-events:auto;}
.zoom-overlay img{
  max-width:92vw;max-height:92vh;
  object-fit:contain;border-radius:var(--r-sm);
  transform:scale(.92);transition:transform .3s ease;
  box-shadow:0 24px 80px rgba(0,0,0,.6);
}
.zoom-overlay.open img{transform:scale(1);}
.zoom-close{
  position:absolute;top:20px;right:24px;
  background:rgba(255,255,255,.12);border:none;
  width:44px;height:44px;border-radius:50%;
  font-size:22px;color:white;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s ease;
}
.zoom-close:hover{background:rgba(255,255,255,.25);}
.zoom-hint{
  position:absolute;bottom:10px;right:10px;
  background:rgba(0,0,0,.45);color:white;
  font-size:10px;letter-spacing:.5px;
  padding:4px 8px;border-radius:var(--r-pill);
  pointer-events:none;opacity:0;
  transition:opacity .2s ease;
}
.modal-gallery:hover .zoom-hint,
.product-img-wrap:hover .zoom-hint{opacity:1;}
.modal-gallery-slide.active{
  opacity:1;pointer-events:auto;cursor:zoom-in;
}
.card-zoom-hint{
  position:absolute;bottom:10px;right:10px;
  background:rgba(0,0,0,.45);color:white;
  font-size:13px;padding:5px 9px;border-radius:var(--r-pill);
  pointer-events:auto;opacity:0;cursor:pointer;
  transition:opacity .2s ease;z-index:3;
}
.product-img-wrap:hover .card-zoom-hint{opacity:1;}
.card-zoom-hint--always{opacity:1 !important;}

.modal-gallery-dots{
  display:flex;justify-content:center;gap:7px;
  margin-top:12px;
}
.modal-gallery-dot{
  width:8px;height:8px;border-radius:50%;border:none;
  background:rgba(255,255,255,.35);cursor:pointer;
  padding:0;transition:background .2s ease,transform .2s ease;
}
.modal-gallery-dot.active{
  background:var(--blush);transform:scale(1.25);
}
.modal-gallery-dot:hover:not(.active){
  background:rgba(255,255,255,.65);
}
.modal-main-placeholder{
  width:100%;aspect-ratio:1;border-radius:var(--r-sm);
  background:rgba(255,255,255,.3);
  display:flex;align-items:center;justify-content:center;
  font-size:64px;color:var(--blush);opacity:.6;
}
.modal-details{padding:32px 28px 28px;display:flex;flex-direction:column}
.modal-cat{
  font-size:10px;font-weight:500;letter-spacing:2px;
  text-transform:uppercase;color:var(--blush);margin-bottom:8px;
}
.modal-title{
  font-family:var(--font-display);font-size:28px;font-weight:400;
  color:var(--brown-dark);line-height:1.25;margin-bottom:10px;
}
.modal-price{
  font-family:var(--font-display);font-size:24px;font-weight:400;
  color:var(--cranberry);margin-bottom:14px;
}
.modal-desc{font-size:14px;line-height:1.85;color:var(--brown-mid);flex:1;margin-bottom:16px}
.modal-ship{font-size:12px;color:var(--sage-dark);margin-bottom:16px;line-height:1.6}
.modal-variant{margin-bottom:16px}
.modal-variant label{
  display:block;font-size:10px;font-weight:500;letter-spacing:1.2px;
  text-transform:uppercase;color:var(--brown-light);margin-bottom:6px;
}
.modal-variant select{
  width:100%;padding:10px 14px;font-family:var(--font-body);font-size:13px;
  border:1px solid var(--warm-beige);border-radius:var(--r-sm);
  background:var(--ivory);color:var(--brown-dark);outline:none;
}
.modal-variant select:focus{border-color:var(--blush)}
@media(max-width:640px){
  .modal-grid{grid-template-columns:1fr}
  .modal-imgs{border-radius:var(--r-lg) var(--r-lg) 0 0}
  .modal-details{padding:20px}
}

/* ===== CHECKOUT PAGE ===== */
.checkout-page-header{
  background:var(--ivory);border-bottom:1px solid var(--warm-beige);
  padding:16px 40px;display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:50;
}
.checkout-back-link{
  font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase;
  color:var(--brown-light);display:flex;align-items:center;gap:6px;transition:color var(--ease);
}
.checkout-back-link:hover{color:var(--cranberry)}
.checkout-progress{display:flex;align-items:center;gap:8px;font-size:11px}
.checkout-step{
  padding:6px 14px;border-radius:var(--r-pill);
  font-family:var(--font-body);letter-spacing:.5px;text-transform:uppercase;
  color:var(--brown-light);
}
.checkout-step.active{background:var(--cranberry);color:white}
.checkout-step-sep{color:var(--taupe)}
.checkout-wrapper{
  max-width:1040px;margin:0 auto;padding:52px 40px 80px;
  display:grid;grid-template-columns:1.2fr .9fr;gap:52px;
}
.checkout-form-side h3{
  font-family:var(--font-display);font-size:20px;font-weight:400;
  letter-spacing:.04em;color:var(--brown-dark);
  margin:28px 0 16px;padding-bottom:10px;border-bottom:1px solid var(--warm-beige);
}
.checkout-form-side h3:first-child{margin-top:0}
.form-label{
  display:block;font-size:10px;font-weight:500;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--brown-light);margin:14px 0 6px;
}
.form-input{
  width:100%;padding:12px 16px;font-family:var(--font-body);font-size:14px;
  border:1px solid var(--warm-beige);border-radius:var(--r-sm);
  background:white;color:var(--brown-dark);outline:none;
  transition:border-color var(--ease),box-shadow var(--ease);
}
.form-input:focus{border-color:var(--blush);box-shadow:0 0 0 3px rgba(217,163,160,.15)}
.form-row{display:flex;gap:16px}
.form-row>div{flex:1}
.order-summary-box{
  background:white;border-radius:var(--r-md);padding:28px;
  box-shadow:var(--shadow-sm);border:1px solid var(--warm-beige);
  position:sticky;top:100px;
}
.order-summary-box h3{
  font-family:var(--font-display);font-size:20px;font-weight:400;
  letter-spacing:.04em;color:var(--brown-dark);
  margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--warm-beige);
}
.order-line{display:flex;justify-content:space-between;padding:7px 0;font-size:13px;color:var(--brown-light)}
.order-line.total{
  border-top:1px solid var(--warm-beige);margin-top:10px;padding-top:14px;
  font-weight:700;font-size:16px;color:var(--brown-dark);
}
#place-order-btn{
  width:100%;margin-top:20px;padding:15px;
  background:var(--blush);color:white;
  font-family:var(--font-body);font-size:12px;font-weight:500;
  letter-spacing:1px;text-transform:uppercase;
  border:none;border-radius:var(--r-pill);transition:background var(--ease);
}
#place-order-btn:hover{background:var(--cranberry)}
.secure-badge{
  font-size:11px;color:var(--brown-light);text-align:center;
  margin-top:14px;line-height:1.5;padding:10px 12px;
  background:var(--ivory);border-radius:var(--r-sm);
}
#payment-error{
  color:#b03030;font-size:13px;margin-top:12px;
  display:none;padding:10px 14px;background:#fff5f5;
  border-radius:var(--r-sm);border-left:3px solid #b03030;
}
#shipping-options{margin-top:12px}
.shipping-option{
  display:flex;align-items:center;gap:10px;padding:10px 14px;
  border:1px solid var(--warm-beige);border-radius:var(--r-sm);
  margin-bottom:8px;cursor:pointer;transition:border-color var(--ease);
}
.shipping-option:hover{border-color:var(--blush)}
.shipping-option input[type=radio]{accent-color:var(--blush)}
.shipping-option-info{flex:1}
.shipping-option-name{font-size:13px;font-weight:500;color:var(--brown-dark)}
.shipping-option-time{font-size:11px;color:var(--brown-light)}
.shipping-option-price{font-size:14px;font-weight:600;color:var(--cranberry)}
#calculate-shipping-btn{
  margin-top:10px;padding:10px 20px;
  background:var(--warm-beige);color:var(--brown-dark);
  font-family:var(--font-body);font-size:12px;font-weight:500;
  letter-spacing:.5px;text-transform:uppercase;
  border:none;border-radius:var(--r-pill);transition:background var(--ease);
}
#calculate-shipping-btn:hover{background:var(--taupe);color:white}
#card-container{margin:12px 0}
#square-payment-form{margin-top:8px}
.empty-cart-notice{
  text-align:center;padding:80px 32px;
  background:var(--ivory);min-height:60vh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
}
.empty-cart-notice .empty-icon{font-size:60px;opacity:.25;margin-bottom:16px}
.empty-cart-notice h2{
  font-family:var(--font-display);font-size:32px;font-weight:400;
  color:var(--brown-dark);margin-bottom:10px;
}
.empty-cart-notice p{font-size:15px;color:var(--brown-light);margin-bottom:24px}
@media(max-width:768px){
  .checkout-wrapper{grid-template-columns:1fr}
  .form-row{flex-direction:column;gap:0}
  .order-summary-box{position:static}
  .checkout-page-header{padding:14px 20px}
  .checkout-wrapper{padding:36px 20px 60px}
}

/* ===== REVIEWS ===== */
.reviews-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  max-width:700px;margin:0 auto 60px;text-align:center;
}
.review-stat-num{
  font-family:var(--font-display);font-size:48px;font-weight:300;
  color:var(--taupe);line-height:1;margin-bottom:6px;
}
.review-stat-label{
  font-size:11px;font-weight:500;letter-spacing:2px;
  text-transform:uppercase;color:var(--brown-light);
}
.reviews-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:24px;padding-bottom:80px;
}
.review-card{
  background:white;border-radius:var(--r-md);padding:28px;
  box-shadow:var(--shadow-xs);border:1px solid var(--warm-beige);
  transition:box-shadow var(--ease);
}
.review-card:hover{box-shadow:var(--shadow-md)}
.review-stars{color:var(--blush);font-size:16px;letter-spacing:2px;margin-bottom:10px}
.review-text{font-size:14px;line-height:1.8;color:var(--brown-mid);font-style:italic;margin-bottom:16px}
.review-author{font-family:var(--font-display);font-size:16px;font-weight:500;color:var(--brown-dark)}
.review-date{font-size:11px;color:var(--taupe)}
.review-product-tag{
  display:inline-block;margin-top:8px;
  font-size:10px;font-weight:500;letter-spacing:1px;text-transform:uppercase;
  color:var(--blush);background:rgba(217,163,160,.1);
  padding:4px 12px;border-radius:var(--r-pill);
}
@media(max-width:540px){.reviews-stats{grid-template-columns:1fr;gap:28px}}

/* ===== CONTACT PAGE ===== */
.contact-grid{
  max-width:1000px;margin:0 auto;
  display:grid;grid-template-columns:1.1fr .9fr;gap:60px;
  padding:60px 40px 80px;
}
.contact-form-title{
  font-family:var(--font-display);font-size:28px;font-weight:400;
  letter-spacing:.04em;color:var(--brown-dark);margin-bottom:20px;
}
.contact-detail-label{
  font-size:10px;font-weight:500;letter-spacing:2px;
  text-transform:uppercase;color:var(--blush);margin-bottom:4px;display:block;
}
.contact-detail-value{
  font-family:var(--font-display);font-size:19px;font-weight:400;
  color:var(--brown-dark);letter-spacing:.02em;
}
.contact-detail-note{font-size:13px;color:var(--brown-light);margin-top:4px;line-height:1.6}
.contact-detail-block{margin-bottom:28px}
.faq-item{border-bottom:1px solid var(--warm-beige);margin-bottom:4px}
.faq-trigger{
  width:100%;background:none;border:none;padding:16px 0;
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--font-display);font-size:17px;font-weight:400;
  color:var(--brown-dark);text-align:left;cursor:pointer;transition:color var(--ease);
}
.faq-trigger:hover{color:var(--cranberry)}
.faq-arrow{font-size:18px;color:var(--blush);transition:transform var(--ease);flex-shrink:0;margin-left:12px}
.faq-item.open .faq-arrow{transform:rotate(45deg)}
.faq-body{
  max-height:0;overflow:hidden;
  transition:max-height .35s ease,padding .35s ease;
  font-size:14px;line-height:1.8;color:var(--brown-mid);
}
.faq-item.open .faq-body{max-height:400px;padding-bottom:16px}
@media(max-width:700px){.contact-grid{grid-template-columns:1fr;gap:40px;padding:40px 20px 60px}}

/* ===== ABOUT PAGE ===== */
.about-story{background:var(--ivory);padding:80px 40px}
.about-story-inner{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:center;
}
.about-arch-wrap{
  width:100%;max-width:420px;aspect-ratio:3/4;
  border-radius:50% 50% 0 0 / 42% 42% 0 0;
  overflow:hidden;
  background:linear-gradient(135deg,var(--dusty-pink),var(--warm-beige));
  display:flex;align-items:center;justify-content:center;
}
.about-arch-wrap img{width:100%;height:100%;object-fit:cover}
.about-arch-placeholder{
  font-family:var(--font-script);font-size:72px;color:var(--blush);opacity:.4;
  text-align:center;padding:40px;
}
.about-text .section-eyebrow{text-align:left}
.about-heading{
  font-family:var(--font-display);font-size:clamp(34px,5vw,54px);
  font-weight:400;letter-spacing:.05em;text-transform:uppercase;
  color:var(--brown-dark);line-height:1.08;margin-bottom:22px;
}
.about-heading .script{
  font-family:var(--font-script);text-transform:none;
  letter-spacing:0;font-size:1.05em;font-weight:500;
}
.about-body{font-size:15px;line-height:1.9;color:var(--brown-mid);margin-bottom:14px}
.about-body strong{font-weight:600;color:var(--brown-dark)}
/* ===== ABOUT — ANNABELLE SECTION ===== */
.annabelle-section{background:var(--ivory);padding:60px 40px 80px}
.annabelle-grid{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
.annabelle-card{
  background:#e8edd8;border-radius:20px;padding:36px;
  display:flex;flex-direction:column;gap:20px;
}
.annabelle-title{
  font-family:var(--font-script);font-size:clamp(26px,4vw,38px);
  color:var(--brown-dark);margin:0;
}
.annabelle-puppy-wrap{border-radius:12px;overflow:hidden;width:100%;max-width:320px;}
.annabelle-puppy-img{width:100%;height:240px;object-fit:cover;object-position:center 30%;display:block;}
.annabelle-body{font-size:15px;line-height:1.85;color:var(--brown-mid);margin:0}
.annabelle-cowboy-wrap{border-radius:20px;overflow:hidden;width:100%;aspect-ratio:3/4;max-height:560px;}
.annabelle-cowboy-img{width:100%;height:100%;object-fit:cover;object-position:center 15%;display:block;}
@media(max-width:900px){
  .annabelle-grid{grid-template-columns:1fr;gap:32px}
  .annabelle-cowboy-wrap{aspect-ratio:16/9;max-height:320px;max-width:560px;margin:0 auto}
  .annabelle-section{padding:52px 28px 72px}
}
@media(max-width:600px){
  .annabelle-grid{gap:24px}
  .annabelle-card{padding:24px}
  .annabelle-puppy-wrap{max-width:100%}
  .annabelle-puppy-img{height:200px}
  .annabelle-cowboy-wrap{aspect-ratio:4/3;max-height:260px}
  .annabelle-section{padding:40px 16px 60px}
}
@media(max-width:480px){
  .annabelle-cowboy-wrap{aspect-ratio:4/3;max-height:220px}
  .annabelle-puppy-img{height:180px}
}

@media(max-width:760px){
  .about-story-inner{grid-template-columns:1fr;gap:40px}
  .about-arch-wrap{max-width:260px;margin:0 auto}
  .about-story{padding:60px 24px}
}


/* ===== MAINTENANCE OVERLAY ===== */
#maintenance-overlay{
  position:fixed;inset:0;z-index:9999;
  background:var(--ivory);
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  font-family:var(--font-ui);
}
.maint-box{
  max-width:520px;width:100%;text-align:center;
  background:white;border-radius:var(--r-lg);
  padding:56px 48px;
  box-shadow:0 8px 48px rgba(100,30,30,.10);
  border:1px solid var(--warm-beige);
}
.maint-icon{font-size:48px;margin-bottom:16px;line-height:1}
.maint-logo{
  font-family:var(--font-display);font-size:15px;font-weight:400;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--brown-light);margin-bottom:28px;
}
.maint-title{
  font-family:var(--font-display);font-size:clamp(28px,6vw,40px);
  font-weight:400;letter-spacing:.04em;text-transform:uppercase;
  color:var(--brown-dark);line-height:1.1;margin-bottom:20px;
}
.maint-msg{
  font-size:15px;line-height:1.85;color:var(--brown-mid);
  margin-bottom:28px;max-width:380px;margin-left:auto;margin-right:auto;
}
.maint-sub{
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--brown-light);
}
@media(max-width:480px){
  .maint-box{padding:40px 24px}
  .maint-title{font-size:28px}
}
/* ===== TOAST ===== */
.toast{
  position:fixed;bottom:28px;right:28px;
  background:var(--brown-dark);color:var(--ivory);
  font-size:13px;padding:14px 22px;border-radius:var(--r-pill);
  box-shadow:var(--shadow-lg);
  transform:translateY(70px);opacity:0;
  transition:transform var(--ease),opacity var(--ease);
  z-index:500;pointer-events:none;display:flex;align-items:center;gap:8px;
}
.toast.show{transform:translateY(0);opacity:1}

/* ===== FOOTER ===== */
#site-footer{background:var(--warm-beige);padding:72px 40px 36px;text-align:center}
.footer-logo-circle{
  width:72px;height:72px;margin:0 auto 14px;border-radius:50%;
  background:linear-gradient(135deg,var(--dusty-pink) 0%,var(--blush) 100%);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-script);font-size:34px;color:white;
  box-shadow:0 4px 18px rgba(217,163,160,.45);
}
.footer-brand-name{
  font-family:var(--font-display);font-size:22px;font-weight:400;
  letter-spacing:.04em;color:var(--brown-dark);display:block;
}
.footer-brand-script{font-family:var(--font-script);font-size:18px;color:var(--brown-light);display:block;margin-top:2px}
.footer-nav{display:flex;justify-content:center;gap:28px;flex-wrap:wrap;margin:28px 0 22px}
.footer-nav a{font-size:13px;color:var(--brown-mid);transition:color var(--ease)}
.footer-nav a:hover{color:var(--cranberry)}
.footer-social{display:flex;justify-content:center;gap:10px;margin-bottom:28px}
.footer-social a{
  width:38px;height:38px;border-radius:50%;
  background:var(--blush);color:white;
  display:flex;align-items:center;justify-content:center;font-size:15px;
  transition:background var(--ease),transform var(--ease-spring);
}
.footer-social a:hover{background:var(--cranberry);transform:scale(1.1)}
.footer-bottom{
  border-top:1px solid var(--taupe);padding-top:24px;margin-top:8px;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:12px;font-size:12px;color:var(--brown-light);
}
.pay-badges{display:flex;gap:8px}
.pay-badge{
  padding:3px 9px;border:1px solid var(--taupe);border-radius:4px;
  font-size:10px;letter-spacing:.5px;color:var(--brown-light);
}
@media(max-width:540px){.footer-bottom{flex-direction:column;text-align:center}}

/* ===== SCROLL FADE ===== */
.fade-up{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* ===== RESPONSIVE ===== */
@media(max-width:600px){
  .products-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
  .container,.container-sm{padding:0 20px}
  .header-inner{padding:14px 20px}
  .page-hero{padding:100px 20px 56px}
}

/* ===== MOBILE — phones ≤480px ===== */
@media(max-width:480px){

  /* ── Layout ── */
  .container,.container-sm{padding:0 16px}

  /* ── Hero ── */
  .hero-content{padding:120px 20px 60px}
  .hero-actions{flex-direction:column;gap:12px;align-items:stretch}
  .hero-actions .btn{text-align:center;justify-content:center}

  /* ── Products grid — single column on small phones ── */
  .products-grid{grid-template-columns:1fr;gap:16px;padding-bottom:40px}

  /* ── Product cards — larger tap targets ── */
  .btn-add-to-cart{padding:13px;font-size:12px}
  .btn-view-details{padding:10px;font-size:11px}
  .variant-select{padding:10px 12px;font-size:13px}
  .product-name{font-size:17px}
  .product-price{font-size:20px}

  /* ── Modal — full screen on mobile ── */
  .modal-box{width:100vw;max-width:100vw;max-height:100vh;border-radius:0;margin:0}
  .modal-details{padding:16px}
  .modal-title{font-size:20px}
  .modal-price{font-size:22px}
  .modal-close{top:12px;right:12px}

  /* ── Cart drawer ── */
  .cart-drawer{width:100vw;max-width:100vw}

  /* ── Filter bar — scrollable on mobile ── */
  .filter-bar{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;padding-bottom:16px;
    -webkit-overflow-scrolling:touch;scrollbar-width:none}
  .filter-bar::-webkit-scrollbar{display:none}
  .filter-btn{white-space:nowrap;flex-shrink:0}

  /* ── Coming soon banner ── */
  #coming-soon-banner{font-size:11px;padding:8px 36px 8px 12px}

  /* ── Sections ── */
  .meet-section{padding:48px 16px 40px}
  .stats-section{padding:0 16px 60px}
  .story-cards{padding:0 16px 60px}
  .specialty-section{padding:52px 16px 64px}

  /* ── Specialty arch grid — single column ── */
  .specialty-arch-grid{grid-template-columns:1fr;max-width:280px}

  /* ── Footer CTA ── */
  .footer-cta-grid{grid-template-columns:1fr;gap:32px;padding:52px 16px}
  .footer-contact-heading{font-size:clamp(28px,8vw,40px)}

  /* ── Footer nav — wrap tighter ── */
  .footer-nav{gap:16px}
  .footer-nav a{font-size:12px}

  /* ── Page hero ── */
  .page-hero{padding:90px 16px 48px}
  .page-hero h1{font-size:clamp(32px,10vw,56px)}

  /* ── Checkout ── */
  .checkout-page-header{padding:12px 16px;gap:8px}
  .checkout-progress{display:none}
  .checkout-wrapper{padding:24px 16px 60px;gap:32px}
  .form-row{flex-direction:column;gap:0}

  /* ── Lifestyle strip ── */
  #lifestyle-strip{height:300px}

  /* ── About page ── */
  .about-arch-wrap{max-width:240px;margin:0 auto}

  /* ── Bakery steps grid ── */
  #steps-grid{grid-template-columns:1fr !important}
}

