@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500&display=swap');
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --rose:#f9e8e8;--rose-mid:#e8c4c4;--rose-dark:#c47b7b;
  --sage:#e8efe6;--sage-mid:#b8cfb4;
  --peach:#fdf0e8;--lav:#ede8f5;--lav-mid:#c4b8e0;
  --cream:#fdfaf6;--white:#fff;
  --ink:#2a2420;--ink-soft:#6b5f5a;--ink-muted:#a09088;
  --red:#c94040;--radius:14px;
}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--ink);font-size:15px;line-height:1.6}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* ── NAV ───────────────────────────────────────────────────────── */
nav{position:sticky;top:0;z-index:200;background:#fff;border-bottom:1px solid rgba(0,0,0,.07);
  height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 32px;gap:16px;overflow:visible}
.nav-logo{font-family:"Cormorant Garamond",serif;font-size:20px;font-weight:400;
  white-space:nowrap;flex-shrink:0;display:flex;align-items:center;gap:4px;color:var(--ink)}
.nav-logo img{height:52px;width:auto;display:block}

.nav-right{display:flex;flex-direction:row;align-items:center;gap:8px;flex-shrink:0}

.nav-links{display:flex;list-style:none;gap:0;margin:0;padding:0;height:64px}
.nav-links > li{position:relative;display:flex;align-items:center;height:64px}
.nav-links > li > a{display:flex;align-items:center;gap:3px;padding:0 14px;height:64px;
  font-size:13px;color:var(--ink-soft);white-space:nowrap;transition:color .2s}
.nav-links > li > a:hover{color:var(--ink)}
.chev{font-size:8px;transition:transform .2s}
.nav-links > li.open > a .chev{transform:rotate(180deg)}
/* Dropdown */
.drop{display:none;position:absolute;top:64px;left:0;background:#fff;
  list-style:none;margin:0;padding:8px 0;min-width:190px;
  border:1px solid rgba(0,0,0,.09);border-top:2px solid var(--ink);
  border-radius:0 0 12px 12px;box-shadow:0 12px 32px rgba(0,0,0,.1);z-index:9999}
.nav-links > li.open .drop{display:block}
.drop li a{display:block;padding:9px 20px;font-size:13px;
  color:var(--ink-soft);white-space:nowrap;transition:background .15s,color .15s}
.drop li a:hover{background:#fdfaf6;color:var(--ink)}
.drop .sep{height:1px;background:rgba(0,0,0,.07);margin:5px 14px}
/* Mobile menu */
.mobile-menu{display:none;flex-direction:column;
  position:fixed;top:64px;left:0;right:0;bottom:0;
  background:#fff;z-index:199;overflow-y:auto;padding:16px 0}
.mobile-menu.open{display:flex}
.mobile-menu a{display:block;padding:13px 28px;font-size:14px;
  color:var(--ink-soft);border-bottom:1px solid rgba(0,0,0,.05)}
.mobile-menu a.sub{padding-left:44px;font-size:13px;color:var(--ink-muted)}
.mobile-menu a:hover{color:var(--ink)}

.hero{display:grid;grid-template-columns:1fr 1fr;min-height:520px}
.hero-left{background:var(--rose);padding:70px 60px;display:flex;flex-direction:column;justify-content:center}
.hero-right{background:var(--rose-mid);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;min-height:520px}
.hero-carousel{position:absolute;inset:0;width:100%;height:100%;overflow:hidden}
.hero-carousel-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;opacity:0;transition:opacity .8s ease}
.hero-carousel-img.active{opacity:1}
.hero-tag{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--rose-dark);font-weight:500;margin-bottom:20px}
.hero-h1{font-family:'Cormorant Garamond',serif;font-size:58px;line-height:1.08;font-weight:300;color:var(--ink);margin-bottom:18px}
.hero-h1 em{font-style:italic;color:var(--rose-dark)}
.hero-sub{font-size:15px;color:var(--ink-soft);line-height:1.7;margin-bottom:36px;max-width:340px}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-primary{background:var(--ink);color:#fff;padding:13px 28px;border-radius:50px;font-size:13px;font-weight:500;letter-spacing:.04em;transition:background .2s}
.btn-primary:hover{background:#3d342e}
.btn-outline{border:1.5px solid var(--ink);color:var(--ink);padding:12px 26px;border-radius:50px;font-size:13px;transition:all .2s}
.btn-outline:hover{background:var(--ink);color:#fff}

/* Stacked cards in hero */
.card-stack{position:relative;width:260px;height:320px}
.hero-card{position:absolute;width:190px;height:240px;border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;text-align:center;box-shadow:0 10px 40px rgba(0,0,0,.1)}
.hero-card .from{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:8px}
.hero-card .msg{font-family:'Cormorant Garamond',serif;font-size:16px;font-style:italic;font-weight:300;color:var(--ink);line-height:1.35}
.hero-card .hrt{color:var(--red);font-size:20px;margin-top:12px}
.hc1{background:#fff;top:10px;left:10px;transform:rotate(-6deg)}
.hc2{background:var(--lav);top:40px;left:50px;transform:rotate(3.5deg)}
.hc3{background:var(--sage);top:20px;left:30px;transform:rotate(-1deg)}

/* TICKER */
.ticker{background:var(--ink);padding:11px 0;overflow:hidden}
.ticker-inner{display:flex;gap:60px;width:max-content;animation:tick 22s linear infinite}
.ticker-item{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.8);font-size:11px;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap}
.ticker-dot{width:4px;height:4px;border-radius:50%;background:var(--rose-dark);flex-shrink:0}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SECTIONS */
section{padding:70px 40px}
.section-inner{max-width:1120px;margin:0 auto}
.section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:36px}
.section-title{font-family:'Cormorant Garamond',serif;font-size:36px;font-weight:300}
.section-title em{font-style:italic}
.view-all{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted);transition:color .2s}
.view-all:hover{color:var(--ink)}

/* OCCASION TILES */
.occ-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;row-gap:12px}
.occ-card{border-radius:var(--radius);padding:22px 12px;text-align:center;transition:transform .2s;cursor:pointer}
.occ-card:hover{transform:translateY(-3px)}
.occ-icon{font-size:24px;margin-bottom:10px}
.occ-label{font-size:12px;font-weight:500;color:var(--ink)}
.occ-count{display:none}

/* PRODUCT GRID */
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.prod-card{border-radius:0;overflow:visible;border:1px solid rgba(0,0,0,.05);background:#fff;transition:transform .2s,box-shadow .2s;cursor:pointer}
.prod-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.08)}
.prod-img{width:100%;aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:transparent;border-radius:0}
.prod-img img{width:100%;height:100%;object-fit:contain;transition:transform .5s;padding:0}
.prod-card:hover .prod-img img{transform:none}
.prod-img-placeholder{font-family:'Cormorant Garamond',serif;font-size:48px;color:rgba(0,0,0,.1)}
.prod-tag-badge{position:absolute;top:10px;left:10px;background:#fff;padding:4px 10px;border-radius:50px;font-size:10px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--ink)}
.prod-quick-add{position:absolute;bottom:10px;right:10px;background:#fff;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(0,0,0,.12);opacity:0;transition:opacity .2s}
.prod-card:hover .prod-quick-add{opacity:1}
.prod-quick-add:hover{background:var(--ink);color:#fff}
.prod-quick-add svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.5}
.prod-info{padding:14px 16px}
.prod-name{font-size:14px;font-weight:500;color:var(--ink);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.prod-coll{font-size:11px;color:var(--ink-muted);margin-bottom:8px}
.prod-price{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:300;color:var(--ink)}

/* SPLIT BANNER */
.split-banner{display:grid;grid-template-columns:1fr 1fr;border-radius:20px;overflow:hidden;margin:0 40px}
.split-panel{padding:60px 50px;display:flex;flex-direction:column}
.split-tag{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:12px}
.split-h{font-family:'Cormorant Garamond',serif;font-size:38px;font-weight:300;line-height:1.15;margin-bottom:16px}
.split-p{font-size:13px;color:var(--ink-soft);line-height:1.7;margin-bottom:28px;max-width:300px}

/* TRUST BAR */
.trust-bar{border-top:1px solid rgba(0,0,0,.06);border-bottom:1px solid rgba(0,0,0,.06);padding:50px 40px}
.trust-grid{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.trust-num{font-family:'Cormorant Garamond',serif;font-size:38px;font-weight:300;color:var(--ink)}
.trust-label{font-size:12px;color:var(--ink-muted);margin-top:4px;letter-spacing:.04em}

/* REVIEWS */
.reviews-bg{background:var(--peach)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:36px}
.review-card{background:#fff;border-radius:var(--radius);padding:26px}
.review-stars{color:var(--red);letter-spacing:2px;font-size:13px;margin-bottom:12px}
.review-text{font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:300;font-style:italic;color:var(--ink-soft);line-height:1.7;margin-bottom:16px}
.review-author{font-size:12px;font-weight:500;color:var(--ink)}
.review-role{font-size:11px;color:var(--ink-muted)}

/* FOOTER */
footer{background:#3a3130;color:#fff;padding:50px 40px 30px}
.footer-inner{max-width:1120px;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:50px;margin-bottom:40px}
.footer-logo{margin-bottom:16px}
.footer-logo img{height:60px;width:auto;display:block}
.footer-tagline{font-size:13px;color:rgba(255,255,255,.45);line-height:1.7;max-width:240px}
.footer-col h4{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:16px}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:10px}
.footer-col a{font-size:13px;color:rgba(255,255,255,.6);transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:24px;display:flex;justify-content:space-between;align-items:center}
.footer-copy{font-size:12px;color:rgba(255,255,255,.3)}

/* CART DRAWER */
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:9000;display:none;backdrop-filter:blur(2px)}
.cart-overlay.open{display:block}
.cart-drawer{position:fixed;top:0;right:0;height:100dvh;width:100%;max-width:400px;background:#fff;z-index:9001;display:flex;flex-direction:column;overflow:hidden;transform:translateX(100%);transition:transform .3s ease}
.cart-drawer.open{transform:translateX(0)}
.cart-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(0,0,0,.06)}
.cart-header h3{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:300}
.cart-close{background:none;border:none;color:var(--ink-muted);cursor:pointer;padding:4px}
.cart-close svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.5}
.cart-body{flex:1;overflow-y:auto;padding:20px 24px;min-height:0;-webkit-overflow-scrolling:touch}
.cart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px;color:var(--ink-muted)}
.cart-empty svg{width:48px;height:48px;stroke:currentColor;fill:none;stroke-width:1}
.cart-item{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid rgba(0,0,0,.05)}
.cart-item-img{width:72px;height:88px;border-radius:10px;overflow:hidden;background:var(--rose);flex-shrink:0}
.cart-item-img img{width:100%;height:100%;object-fit:contain}
.cart-item-info{flex:1}
.cart-item-name{font-size:13px;font-weight:500;margin-bottom:4px}
.cart-item-price{font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:300}
.cart-qty{display:flex;align-items:center;gap:10px;margin-top:8px}
.qty-btn{width:26px;height:26px;border-radius:50%;border:1px solid rgba(0,0,0,.12);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--ink);cursor:pointer;transition:border-color .2s;background:none}
.qty-btn:hover{border-color:var(--ink)}
.qty-val{font-size:13px;font-weight:500;min-width:16px;text-align:center}
.cart-remove{margin-left:auto;font-size:11px;color:var(--ink-muted);cursor:pointer;background:none;border:none;padding:0}
.cart-remove:hover{color:var(--red)}
.cart-footer{padding:20px 24px;border-top:1px solid rgba(0,0,0,.06);flex-shrink:0;background:#fff}
.cart-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.cart-total span:first-child{font-size:13px;color:var(--ink-soft)}
.cart-total span:last-child{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:300}
.cart-shipping{font-size:11px;color:var(--ink-muted);margin-bottom:16px}
.checkout-btn{width:100%;background:var(--ink);color:#fff;padding:15px;border-radius:50px;font-size:13px;font-weight:500;letter-spacing:.04em;border:none;cursor:pointer;transition:background .2s}
.checkout-btn:hover{background:#3d342e}
.checkout-btn:disabled{opacity:.6;cursor:not-allowed}

/* PRODUCT MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:300;display:none;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(3px)}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:20px;width:100%;max-width:780px;max-height:90vh;overflow:hidden;display:flex}
.modal-img{width:340px;flex-shrink:0;background:var(--rose)}
.modal-img img{width:100%;height:100%;object-fit:contain}
.modal-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:80px;color:rgba(0,0,0,.08)}
.modal-body{flex:1;padding:36px;overflow-y:auto;display:flex;flex-direction:column}
.modal-close{align-self:flex-end;background:none;border:none;cursor:pointer;color:var(--ink-muted);margin-bottom:16px}
.modal-close svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.5}
.modal-coll{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:10px}
.modal-name{font-family:'Cormorant Garamond',serif;font-size:34px;font-weight:300;margin-bottom:8px;line-height:1.15}
.modal-price{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:300;margin-bottom:20px}
.modal-desc{font-size:13px;color:var(--ink-soft);line-height:1.7;margin-bottom:24px}
.modal-qty{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.modal-qty label{font-size:13px;color:var(--ink-soft)}
.qty-control{display:flex;align-items:center;border:1px solid rgba(0,0,0,.1);border-radius:50px;overflow:hidden}
.qty-control button{width:34px;height:34px;display:flex;align-items:center;justify-content:center;font-size:16px;background:none;border:none;cursor:pointer;color:var(--ink)}
.qty-control button:hover{background:rgba(0,0,0,.04)}
.qty-control span{min-width:30px;text-align:center;font-size:14px;font-weight:500}
.add-to-cart-btn{width:100%;background:var(--ink);color:#fff;padding:15px;border-radius:50px;font-size:13px;font-weight:500;letter-spacing:.04em;border:none;cursor:pointer;transition:all .2s;margin-bottom:20px}
.add-to-cart-btn:hover{background:#3d342e}
.add-to-cart-btn.added{background:var(--sage);color:var(--ink)}
.modal-trust{border-top:1px solid rgba(0,0,0,.06);padding-top:16px;display:flex;flex-direction:column;gap:8px}
.modal-trust-item{font-size:12px;color:var(--ink-soft);display:flex;align-items:center;gap:8px}

/* SHOP PAGE */
.shop-page{max-width:1120px;margin:0 auto;padding:40px 40px}
.shop-header{margin-bottom:36px}
.shop-title{font-family:'Cormorant Garamond',serif;font-size:44px;font-weight:300;margin-bottom:6px}
.shop-count{font-size:13px;color:var(--ink-muted)}
.filter-pills{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:28px}
.filter-pills:not(.sub-pills){display:none}
.pill{padding:6px 14px;border-radius:50px;font-size:11px;font-weight:500;cursor:pointer;border:1px solid rgba(0,0,0,.1);color:var(--ink-soft);background:#fff;transition:all .2s;white-space:nowrap}
.pill:hover{border-color:rgba(0,0,0,.3)}
.pill.active{background:var(--ink);color:#fff;border-color:var(--ink)}

/* Loading */
.loading{text-align:center;padding:60px;font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:300;color:var(--ink-muted)}

/* RESPONSIVE */
@media(max-width:900px){
  nav{padding:0 16px}
  .nav-links{display:none}
  .hamburger{display:flex}
  .nav-right{gap:8px}
  .hero{grid-template-columns:1fr}
  .hero-right{display:none}
  .hero-left{padding:50px 24px}
  .hero-h1{font-size:42px}
  .occ-grid{grid-template-columns:repeat(3,1fr)}
  .prod-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  section{padding:50px 20px}
  .split-banner{grid-template-columns:1fr;margin:0 20px;border-radius:16px}
  .split-panel{padding:40px 30px}
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .reviews-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .modal{flex-direction:column;max-height:85vh}
  .modal-img{width:100%;height:200px}
  .modal-body{padding:24px}
  .shop-page{padding:40px 20px}
}
@media(max-width:480px){
  .occ-grid{grid-template-columns:repeat(2,1fr)}
  .prod-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .hero-h1{font-size:36px}
}

/* Sub-pills */
.sub-pills{padding-left:8px;border-left:2px solid rgba(0,0,0,.08)}
.sub-pill{font-size:11px !important;padding:5px 12px !important;background:var(--cream) !important}
.sub-pill.active{background:var(--ink) !important;color:#fff !important}

.account-btn{display:flex;align-items:center}

/* Mobile nav fixes */
@media(max-width:900px){
  .nav-right{gap:8px}
  .hamburger{display:flex !important}
  .cart-btn{display:flex !important}
  .account-btn{display:flex !important}
}


/* ── CART BUTTON FIX ─────────────────────────────────────────────── */
.cart-btn {
  position: relative;
  background: none !important;
  border: none;
  padding: 8px;
  cursor: pointer;
  color: var(--ink);
  display: flex;
  align-items: center;
  justify-content: center;
  -webkit-appearance: none;
  appearance: none;
}
.cart-btn svg {
  width: 22px;
  height: 22px;
  stroke: var(--ink);
  fill: none !important;
  stroke-width: 1.5;
  display: block;
}
.cart-count {
  position: absolute;
  top: -2px;
  right: -2px;
  background: var(--red);
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  width: 17px;
  height: 17px;
  border-radius: 50%;
  display: none;
  align-items: center;
  justify-content: center;
}
.cart-count.show { display: flex; }

/* ── MOBILE CRITICAL FIXES ──────────────────────────────────────── */
@media(max-width:900px) {
  /* Force nav items visible */
  .cart-btn { display:flex !important; align-items:center !important; justify-content:center !important; padding:8px !important; }
  .cart-btn svg { display:block !important; width:24px !important; height:24px !important; }
  .hamburger { display:flex !important; flex-direction:column !important; gap:5px !important; padding:8px !important; background:none !important; border:none !important; cursor:pointer !important; }
  .hamburger span { display:block !important; width:22px !important; height:2px !important; background:var(--ink) !important; border-radius:2px !important; }
  .account-btn { display:flex !important; align-items:center !important; padding:8px !important; }
  .nav-right { display:flex !important; align-items:center !important; gap:4px !important; }
  /* Mobile menu */
  .mobile-menu { display:none; flex-direction:column; position:fixed; top:64px; left:0; right:0; bottom:0; background:#fff; z-index:199; overflow-y:auto; padding:16px 0; }
  .mobile-menu.open { display:flex !important; }
  /* Hide desktop nav on mobile */
  .nav-links { display:none !important; }
}


/* ── CATEGORY LANDING PAGES ───────────────────────────────────── */
.category-hero{background:var(--rose);padding:76px 28px 56px;text-align:center;border-bottom:1px solid rgba(0,0,0,.05)}
.category-eyebrow{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--rose-dark);font-weight:500;margin-bottom:14px}
.category-title{font-family:'Cormorant Garamond',serif;font-size:54px;line-height:1.08;font-weight:300;color:var(--ink);margin-bottom:14px}
.category-title em{font-style:italic;color:var(--rose-dark)}
.category-intro{max-width:560px;margin:0 auto;font-size:15px;color:var(--ink-soft);line-height:1.8}
.category-wrap{max-width:1120px;margin:0 auto;padding:56px 32px 76px}
.subcat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;align-items:stretch}
.subcat-card{display:flex;flex-direction:column;justify-content:space-between;border-radius:18px;padding:24px 20px;min-height:160px;border:1px solid rgba(0,0,0,.05);transition:transform .2s,box-shadow .2s;background:#fff;text-align:center;text-decoration:none;color:var(--ink)}
.subcat-card:hover{transform:translateY(-3px);box-shadow:0 16px 45px rgba(0,0,0,.08)}
.subcat-icon{font-size:28px;margin-bottom:12px;flex-shrink:0}
.subcat-title{font-family:'Cormorant Garamond',serif;font-size:clamp(20px,2.2vw,28px);font-weight:300;color:var(--ink);line-height:1.15;margin-bottom:10px}
.subcat-copy{font-size:13px;color:var(--ink-soft);line-height:1.7;margin-bottom:16px;flex-grow:1}
.subcat-cta{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:3px;flex-shrink:0;align-self:center}
.category-bottom{text-align:center;margin-top:34px}
@media(max-width:900px){.subcat-grid{grid-template-columns:repeat(2,1fr)}.category-title{font-size:44px}}
@media(max-width:640px){.category-hero{padding:54px 20px 42px}.category-wrap{padding:38px 20px 56px}.subcat-grid{grid-template-columns:1fr}.subcat-card{min-height:auto}.category-title{font-size:38px}}


/* ── PHASE 5 REAL CARD IMAGE SYSTEM ───────────────────────────── */
.card-stack.real-card-stack{width:min(420px,80vw);height:430px;position:relative;isolation:isolate}
.real-hero-card{position:absolute;width:210px;aspect-ratio:2/3;border-radius:18px;overflow:hidden;background:#fff;box-shadow:0 22px 70px rgba(42,36,32,.16);border:1px solid rgba(42,36,32,.08);transition:transform .35s ease}
.real-hero-card img{width:100%;height:100%;object-fit:contain;display:block}
.real-hero-card:nth-child(1){left:0;top:78px;transform:rotate(-9deg)}
.real-hero-card:nth-child(2){left:116px;top:18px;z-index:2;transform:rotate(3deg)}
.real-hero-card:nth-child(3){right:0;top:106px;transform:rotate(10deg)}
.real-card-stack:hover .real-hero-card:nth-child(1){transform:rotate(-11deg) translateY(-5px)}
.real-card-stack:hover .real-hero-card:nth-child(2){transform:rotate(2deg) translateY(-9px)}
.real-card-stack:hover .real-hero-card:nth-child(3){transform:rotate(12deg) translateY(-5px)}

.occ-card-img-DISABLED{width:82px;height:112px;margin:0 auto 14px;border-radius:10px;overflow:hidden;background:#fff;box-shadow:0 10px 30px rgba(42,36,32,.10);border:1px solid rgba(42,36,32,.06)}
.occ-card-img img{width:100%;height:100%;object-fit:contain}

.category-hero{position:relative;text-align:left;overflow:hidden;padding:84px 32px;background:linear-gradient(115deg,#f9e8e8 0%,#fff 74%)}
.category-hero-inner{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:minmax(0,1fr) 560px;gap:40px;align-items:center}
.category-eyebrow{margin-bottom:16px}.category-title{font-size:72px;max-width:680px}.category-intro{margin:0;max-width:610px;font-size:17px}
.category-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px}.category-actions .btn-outline{background:rgba(255,255,255,.38)}
.category-visual{min-height:420px;height:420px;display:flex;align-items:stretch;justify-content:center}.category-hero-photo{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.category-hero-photo img{width:100%;height:100%;object-fit:contain;object-position:center;display:block}
.subcat-thumb{display:none}
.category-products{max-width:1120px;margin:0 auto;padding:0 32px 86px}.category-products-head{display:flex;align-items:end;justify-content:space-between;gap:20px;border-top:1px solid rgba(42,36,32,.08);padding-top:42px;margin-bottom:24px}
.category-products-kicker{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--rose-dark);font-weight:500;margin-bottom:10px}.category-products-title{font-family:'Cormorant Garamond',serif;font-size:44px;font-weight:300;line-height:1.1}.category-products .prod-grid{grid-template-columns:repeat(4,1fr)}
.prod-img img{object-fit:cover;padding:0}.prod-card{box-shadow:0 10px 38px rgba(42,36,32,.04)}
@media(max-width:980px){.category-hero-inner{grid-template-columns:1fr}.category-visual{height:300px;min-height:300px;border-radius:16px;overflow:hidden}.category-title{font-size:52px}.category-products .prod-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.card-stack.real-card-stack{height:340px}.real-hero-card{width:158px}.category-hero{padding:58px 22px}.category-title{font-size:44px}.category-intro{font-size:16px}.subcat-grid{grid-template-columns:repeat(2,1fr)}.subcat-card{padding:18px;min-height:140px}.category-products{padding:0 20px 58px}.category-products-head{align-items:flex-start;flex-direction:column}.category-products .prod-grid{grid-template-columns:repeat(2,1fr)}}
