/* Celebration Kraft · shared site styles (header, footer, marquee, etc.) */
:root{
  --wine:#5A0E18; --wine-deep:#3A0710; --brass:#B88936; --brass-light:#E1B964;
  --cream:#FBF5E2; --paper:#FAF4E6; --ivory:#F2E7CD; --ink:#221912;
  --velvet:#1A0F0B; --muted:#7C6A52; --rule:rgba(217,184,106,.28); --rose:#C77B6D;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:'Inter',system-ui,sans-serif;font-weight:300;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:400;line-height:1.05;color:var(--velvet);letter-spacing:-.01em}
.container{max-width:1280px;margin:0 auto;padding:0 32px}
.small{font-family:'Inter',sans-serif;font-size:11px;letter-spacing:.36em;text-transform:uppercase;color:var(--brass);font-weight:500}
.script{font-family:'Allura',cursive;font-style:normal;color:var(--wine);font-weight:400;line-height:.85;display:inline-block}

/* === Top marquee === */
.topbar{background:var(--velvet);color:var(--brass-light);overflow:hidden;border-bottom:1px solid var(--brass);text-align:center;padding:10px 0;font-family:'Inter',sans-serif;font-size:11px;letter-spacing:.36em;text-transform:uppercase;font-weight:500}
.topbar b{color:#F1D58A;font-weight:600;margin:0 6px}
.topbar .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--rose);margin-right:8px;animation:ckPulse 1.6s ease-in-out infinite;vertical-align:middle}
.topbar a{color:#F1D58A;text-decoration:underline;text-underline-offset:3px}
@keyframes ckPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}

/* === Header (with mega-menu nav) === */
header.site{background:rgba(250,244,230,.94);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--rule);position:sticky;top:0;z-index:30}
.nav{display:flex;align-items:center;justify-content:space-between;padding:16px 0;gap:30px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:42px;height:42px;object-fit:contain}
.brand .mark{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;letter-spacing:.14em;color:var(--velvet);line-height:1}
.brand .mark em{font-family:'Allura',cursive;font-style:normal;color:var(--wine);font-size:1.2em;font-weight:400;line-height:.85;display:inline-block;margin:0 .04em}

.main-nav{display:flex;gap:30px;align-items:center}
.main-nav > a, .main-nav > div > a{font-family:'Inter',sans-serif;font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--velvet);font-weight:500;position:relative;padding:8px 0;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:.25s}
.main-nav > a:hover, .main-nav > div > a:hover{color:var(--wine)}
.main-nav > a.active, .main-nav > div > a.active{color:var(--wine)}
.main-nav > a::after, .main-nav > div > a::after{content:"";position:absolute;left:0;right:0;bottom:2px;height:1px;background:var(--wine);transform:scaleX(0);transition:.3s}
.main-nav > a:hover::after, .main-nav > div > a:hover::after, .main-nav > a.active::after, .main-nav > div > a.active::after{transform:scaleX(1)}

/* Shop mega-dropdown */
.shop-menu{position:relative}
.shop-menu > a .caret{display:inline-block;width:6px;height:6px;border-right:1px solid currentColor;border-bottom:1px solid currentColor;transform:rotate(45deg) translateY(-2px);margin-left:4px;transition:.25s}
.shop-menu:hover > a .caret{transform:rotate(225deg) translateY(2px)}
.mega{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);background:var(--cream);border:1px solid var(--brass);min-width:520px;padding:14px;display:grid;grid-template-columns:1fr 1fr;gap:6px;opacity:0;visibility:hidden;transition:.22s;pointer-events:none;z-index:40;box-shadow:0 30px 60px -30px rgba(31,17,8,.4);border-radius:6px}
.shop-menu:hover .mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);pointer-events:auto}
.mega a{display:flex;flex-direction:column;gap:2px;padding:14px 18px;border:1px solid transparent;border-radius:4px;text-decoration:none;transition:.2s}
.mega a:hover{background:var(--paper);border-color:var(--rule)}
.mega a b{font-family:'Cormorant Garamond',serif;font-style:normal;font-size:18px;color:var(--velvet);font-weight:500;line-height:1.1;letter-spacing:0;text-transform:none}
.mega a b em{font-family:'Allura',cursive;font-style:normal;color:var(--wine);font-size:1.3em;font-weight:400;line-height:.85;display:inline-block;margin:0 .04em}
.mega a span{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:13px;color:var(--muted);line-height:1.35}

.nav-cta{padding:11px 22px;background:var(--velvet);color:var(--brass-light);font-family:'Inter',sans-serif;font-size:11px;letter-spacing:.32em;text-transform:uppercase;font-weight:600;border-radius:4px;transition:.25s;text-decoration:none;display:inline-flex;align-items:center;gap:8px}
.nav-cta:hover{background:var(--wine)}
.utility{display:flex;gap:10px;align-items:center}
.icon{width:36px;height:36px;display:grid;place-items:center;border:1px solid var(--brass);border-radius:50%;color:var(--velvet);font-size:14px;cursor:pointer;background:var(--cream);text-decoration:none;transition:.25s}
.icon:hover{background:var(--velvet);color:var(--brass-light);border-color:var(--velvet)}

.hamburger{display:none;width:40px;height:40px;background:var(--cream);border:1px solid var(--brass);border-radius:50%;color:var(--velvet);cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:0}
.hamburger span{display:block;width:16px;height:1.5px;background:var(--velvet)}

/* === Buttons === */
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 28px;background:var(--velvet);color:var(--brass-light);font-family:'Inter',sans-serif;font-size:12px;letter-spacing:.32em;text-transform:uppercase;font-weight:600;border:1px solid var(--velvet);cursor:pointer;border-radius:4px;text-decoration:none;transition:.3s}
.btn:hover{background:var(--wine);border-color:var(--wine);transform:translateY(-2px)}
.btn.ghost{background:transparent;color:var(--velvet)}
.btn.ghost:hover{background:var(--velvet);color:var(--brass-light)}

/* === Section heading === */
.section-h{text-align:center;margin-bottom:50px}
.section-h h2{font-size:54px;line-height:1.05;letter-spacing:-.005em}
.section-h h2 em{font-family:'Allura',cursive;font-style:normal;color:var(--wine);font-size:1.3em;font-weight:400;line-height:.85;display:inline-block;margin:0 .06em}
.section-h p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:18px;color:var(--muted);margin-top:14px;max-width:60ch;margin-left:auto;margin-right:auto}

/* === Product card (shared) === */
.pcard{background:var(--cream);overflow:hidden;display:flex;flex-direction:column;transition:.3s;border-radius:6px;border:1px solid var(--rule);text-decoration:none}
.pcard:hover{border-color:var(--brass);transform:translateY(-3px);box-shadow:0 30px 50px -30px rgba(90,14,24,.2)}
.pcard .pimg{aspect-ratio:4/5;overflow:hidden;background:var(--velvet);position:relative}
.pcard .pimg img{width:100%;height:100%;object-fit:cover;transition:1s cubic-bezier(.2,.7,.2,1)}
.pcard:hover .pimg img{transform:scale(1.04)}
.pcard .pribbon{position:absolute;top:14px;left:14px;background:var(--wine);color:var(--brass-light);padding:5px 12px;font-family:'Inter',sans-serif;font-size:10px;letter-spacing:.32em;text-transform:uppercase;font-weight:500;z-index:2;border-radius:999px}
.pcard .pbody{padding:22px;text-align:center}
.pcard .pbody h3{font-family:'Cormorant Garamond',serif;font-size:20px;line-height:1.2;font-weight:500;min-height:50px}
.pcard .pbody h3 em{font-family:'Allura',cursive;font-style:normal;color:var(--wine);font-size:1.4em;font-weight:400;line-height:.85;display:inline-block;margin:0 .04em}
.pcard .pbody .pmeta{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--muted);font-size:14px;margin-top:6px}
.pcard .pbody .price{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--wine);font-weight:500;margin-top:10px}
.pcard .pbody .price small{font-family:'Inter',sans-serif;font-size:10px;letter-spacing:.32em;color:var(--muted);text-transform:uppercase;font-weight:500;display:block;margin-bottom:2px}

/* === Footer === */
footer.site{background:var(--velvet);color:#cdb389;padding:70px 0 24px;border-top:1px solid var(--brass)}
footer.site .ftgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px}
footer.site h4{font-family:'Inter',sans-serif;font-size:11px;letter-spacing:.32em;color:var(--brass-light);text-transform:uppercase;margin-bottom:16px;font-weight:600}
footer.site ul{list-style:none}
footer.site li{margin:7px 0;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:16px}
footer.site li a:hover{color:var(--brass-light)}
footer.site .brand-block{font-family:'Cormorant Garamond',serif;color:var(--brass-light);font-size:28px;letter-spacing:.08em;font-weight:500;margin-bottom:4px}
footer.site .brand-block em{font-family:'Allura',cursive;font-style:normal;color:#F1D58A;font-size:1.2em;line-height:.85}
footer.site .tag{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:17px;color:#cdb389;margin-bottom:18px;max-width:34ch}
footer.site .ic-row{display:flex;gap:10px;margin-top:18px}
footer.site .ic-row a{width:36px;height:36px;display:grid;place-items:center;border:1px solid rgba(217,184,106,.4);border-radius:50%;color:var(--brass-light);font-size:13px;transition:.25s}
footer.site .ic-row a:hover{background:var(--brass);color:var(--velvet);border-color:var(--brass)}
.legal-bar{margin-top:50px;padding-top:24px;border-top:1px solid rgba(217,184,106,.2);display:flex;justify-content:space-between;color:#8a6f4f;font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-family:'Inter',sans-serif;flex-wrap:wrap;gap:14px}

/* Mobile menu (slide-down) */
.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--paper);z-index:50;overflow-y:auto;padding:80px 32px 40px}
.mobile-menu.open{display:block}
.mobile-menu .close{position:absolute;top:18px;right:24px;background:transparent;border:0;font-size:28px;color:var(--velvet);cursor:pointer}
.mobile-menu nav a{display:block;padding:14px 0;border-bottom:1px solid var(--rule);font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--velvet)}
.mobile-menu nav a em{font-family:'Allura',cursive;font-style:normal;color:var(--wine);font-size:1.3em;line-height:.85;display:inline-block;margin:0 .04em}
.mobile-menu nav a.sub{font-size:18px;padding-left:18px;font-family:'Inter',sans-serif;color:var(--muted);letter-spacing:.04em;border-bottom-style:dashed}

@media (max-width:900px){
  .main-nav{display:none}
  .hamburger{display:flex}
  footer.site .ftgrid{grid-template-columns:1fr 1fr;gap:30px}
}
@media (max-width:600px){
  footer.site .ftgrid{grid-template-columns:1fr}
}
