/*
 * Handaran — shared store/menu design-system styles.
 * Extracted verbatim from handaran-home.php so the shop page renders with
 * pixel-identical components (glass, buttons, cards, cart drawer, modals).
 */
/* ─── Base ─────────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
html{background:#1A0C05}
body{background:none;color:#FDF4E3;font-family:'Inter','Inter Fallback',sans-serif;overflow-x:hidden}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:#1A0C05}
::-webkit-scrollbar-thumb{background:#E8A23C;border-radius:3px}
.hide-scrollbar{scrollbar-width:none;-ms-overflow-style:none}
.hide-scrollbar::-webkit-scrollbar{display:none}

/* ─── Premium background canvas ──────────────────────── */
#bg-canvas{
  position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none;
  background:
    radial-gradient(ellipse at 8% 20%,  rgba(196,104,42,.22) 0%, transparent 40%),
    radial-gradient(ellipse at 92% 80%, rgba(122,58,20,.26)  0%, transparent 40%),
    radial-gradient(ellipse at 50% 50%, rgba(85,39,12,.14)   0%, transparent 60%),
    radial-gradient(ellipse at 78% 6%,  rgba(196,104,42,.09) 0%, transparent 32%),
    #1A0C05;
}
.bg-orb{position:absolute;border-radius:50%;filter:blur(80px);will-change:transform}
.bg-orb-1{
  width:680px;height:680px;top:-180px;left:-180px;
  background:radial-gradient(circle,rgba(196,104,42,.30) 0%,transparent 70%);
  animation:bgOrb1 58s ease-in-out infinite
}
.bg-orb-2{
  width:820px;height:820px;bottom:-320px;right:-280px;
  background:radial-gradient(circle,rgba(122,58,20,.34) 0%,transparent 70%);
  animation:bgOrb2 72s ease-in-out infinite
}
.bg-orb-3{
  width:480px;height:480px;top:38%;left:28%;
  background:radial-gradient(circle,rgba(232,162,60,.13) 0%,transparent 70%);
  animation:bgOrb3 46s ease-in-out infinite
}
.bg-vignette{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(20,10,3,.35) 0%,transparent 30%,transparent 70%,rgba(20,10,3,.45) 100%),
    radial-gradient(ellipse at 50% 50%,transparent 50%,rgba(10,5,2,.55) 100%)
}
.bg-noise{
  position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='250' height='250'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='250' height='250' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:250px;
  opacity:.042
}
@keyframes bgOrb1{
  0%,100%{transform:translate(0,0) scale(1)}
  25%{transform:translate(45px,-35px) scale(1.07)}
  50%{transform:translate(-25px,55px) scale(.93)}
  75%{transform:translate(65px,25px) scale(1.04)}
}
@keyframes bgOrb2{
  0%,100%{transform:translate(0,0) scale(1)}
  30%{transform:translate(-55px,38px) scale(1.09)}
  65%{transform:translate(42px,-52px) scale(.91)}
}
@keyframes bgOrb3{
  0%,100%{transform:translate(0,0) scale(1)}
  35%{transform:translate(38px,45px) scale(1.11)}
  70%{transform:translate(-45px,-28px) scale(.89)}
}

/* ─── Glass ─────────────────────────────────────────── */
.glass{background:rgba(255,248,235,.08);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(232,162,60,.18)}
.glass-dark{background:rgba(26,15,7,.82);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border:1px solid rgba(232,162,60,.12)}
.glass-card{background:rgba(255,248,235,.06);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(232,162,60,.12);transition:all .3s ease}
.glass-card:hover{background:rgba(255,248,235,.10);border-color:rgba(232,162,60,.32);transform:translateY(-5px);box-shadow:0 24px 48px rgba(0,0,0,.38)}

/* ─── Typography ─────────────────────────────────────── */
.serif{font-family:'Playfair Display',Georgia,serif}
.gradient-text{background:linear-gradient(135deg,#E8A23C,#FDF4E3 50%,#C4682A);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.section-label{letter-spacing:3px;text-transform:uppercase;font-size:11px;font-weight:700;color:#E8A23C}

/* ─── Buttons ─────────────────────────────────────────── */
.btn-primary{background:linear-gradient(135deg,#E8A23C,#C4682A);color:#2C1A0E;font-weight:700;transition:all .3s ease;position:relative;overflow:hidden;display:inline-flex;align-items:center}
.btn-primary::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent);transition:left .5s}
.btn-primary:hover::after{left:100%}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(232,162,60,.42)}
.btn-outline{background:transparent;border:2px solid rgba(253,244,227,.25);color:#FDF4E3;font-weight:600;transition:all .3s;display:inline-flex;align-items:center}
.btn-outline:hover{border-color:rgba(232,162,60,.6);color:#E8A23C;transform:translateY(-2px)}

/* ─── Navbar ─────────────────────────────────────────── */
#navbar{transition:background .35s,backdrop-filter .35s,box-shadow .35s}
#navbar.scrolled{background:rgba(26,15,7,.96)!important;backdrop-filter:blur(28px);box-shadow:0 1px 0 rgba(232,162,60,.15)}

/* ─── Hero ──────────────────────────────────────────── */
#hero-video{will-change:transform;transition:transform .08s linear}

/* ─── Live dot ──────────────────────────────────────── */
.live-dot{width:9px;height:9px;border-radius:50%}
@keyframes pulse-ring{0%,100%{box-shadow:0 0 0 0 currentColor}50%{box-shadow:0 0 0 7px transparent}}
.dot-open{background:#4ade80;color:rgba(74,222,128,.45);animation:pulse-ring 1.8s infinite}
.dot-closed{background:#f87171}

/* ─── Animations ─────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.anim-float{animation:float 3.2s ease-in-out infinite}

/* ─── Reveal ─────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}

/* ─── Menu tabs ─────────────────────────────────────── */
.tab-btn{transition:transform .22s cubic-bezier(.34,1.56,.64,1),background .25s ease,color .25s ease,box-shadow .25s ease,border-color .25s ease;white-space:nowrap;cursor:pointer;will-change:transform}
.tab-btn:hover{transform:translateY(-2px)}
.tab-btn:active{transform:scale(.95)}
.tab-btn.active{background:linear-gradient(135deg,#E8A23C,#C4682A);color:#2C1A0E;border-color:transparent;box-shadow:0 6px 18px rgba(232,162,60,.34)}

/* ─── Tag pills ─────────────────────────────────────── */
.tag-pill{transition:transform .22s cubic-bezier(.34,1.56,.64,1),background .25s ease,color .25s ease,border-color .25s ease,box-shadow .25s ease;white-space:nowrap;cursor:pointer;border:1px solid rgba(232,162,60,.18)}
.tag-pill:hover{transform:translateY(-2px);border-color:rgba(232,162,60,.42)}
.tag-pill:active{transform:scale(.94)}
.tag-pill.active-tag{background:linear-gradient(135deg,#E8A23C,#C4682A);color:#2C1A0E;border-color:transparent;font-weight:700;box-shadow:0 5px 16px rgba(232,162,60,.3)}

/* ─── Product cards ─────────────────────────────────── */
.product-card{background:rgba(255,248,235,.06);backdrop-filter:blur(14px);border:1px solid rgba(232,162,60,.12);border-radius:1rem;overflow:hidden;transition:transform .35s cubic-bezier(.22,1,.36,1),border-color .3s ease,box-shadow .35s ease}
.product-card:hover{border-color:rgba(232,162,60,.35);transform:translateY(-6px);box-shadow:0 20px 44px rgba(0,0,0,.4)}
.product-card:hover .card-img{transform:scale(1.07)}
.card-img{transition:transform .6s cubic-bezier(.22,1,.36,1)}
.prod-add-btn{transition:transform .2s cubic-bezier(.34,1.56,.64,1),background-color .2s ease,color .2s ease}
.prod-add-btn:hover{transform:scale(1.12)}
.prod-add-btn:active{transform:scale(.9)}
.prod-add-btn i{transition:transform .25s cubic-bezier(.34,1.56,.64,1)}
.prod-add-btn:hover i{transform:rotate(90deg)}

/* ─── Menu card entrance (staggered, GPU-only) ───────── */
@keyframes menuPop{from{opacity:0;transform:translateY(16px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}
.menu-pop{animation:menuPop .45s cubic-bezier(.22,1,.36,1) both}

/* ─── Category cards ─────────────────────────────────── */
.cat-card{position:relative;overflow:hidden;border-radius:1rem;cursor:pointer;transition:all .3s;border:1px solid rgba(232,162,60,.22);box-shadow:0 4px 20px rgba(0,0,0,.32);background:rgba(44,26,14,.6);aspect-ratio:1}
.cat-card::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(44,26,14,.9) 0%,rgba(44,26,14,.15) 100%);transition:all .3s}
.cat-card:hover{transform:scale(1.03);border-color:rgba(232,162,60,.5);box-shadow:0 8px 32px rgba(0,0,0,.45)}
.cat-card:hover::after{background:linear-gradient(to top,rgba(232,162,60,.65) 0%,rgba(44,26,14,.1) 100%)}
.cat-card .cat-info{position:absolute;bottom:0;left:0;right:0;padding:1rem;z-index:10}

/* ─── Testimonials v2 ───────────────────────────────── */
@keyframes rvLeft {from{transform:translateX(0)} to{transform:translateX(-50%)}}
@keyframes rvRight{from{transform:translateX(-50%)} to{transform:translateX(0)}}
.rv-row{overflow:hidden;
  -webkit-mask:linear-gradient(90deg,transparent 0%,#000 10%,#000 90%,transparent 100%);
  mask:linear-gradient(90deg,transparent 0%,#000 10%,#000 90%,transparent 100%)}
.rv-track{display:flex;gap:1.25rem;width:max-content}
.rv-left{animation:rvLeft  46s linear infinite}
.rv-right{animation:rvRight 54s linear infinite}
.rv-track:hover{animation-play-state:paused}
.rv-card{
  flex:0 0 340px;padding:1.75rem 1.875rem;border-radius:1.375rem;
  background:rgba(255,248,235,.055);backdrop-filter:blur(14px);
  border:1px solid rgba(232,162,60,.11);
  position:relative;
  transition:background .35s,border-color .35s}
.rv-card:hover{background:rgba(255,248,235,.09);border-color:rgba(232,162,60,.26)}
.rv-glyph{
  font-family:'Playfair Display',Georgia,serif;font-size:5rem;line-height:1;
  color:rgba(232,162,60,.14);position:absolute;top:.5rem;left:1.5rem;
  pointer-events:none;user-select:none;font-style:normal}

/* ─── Instagram grid ─────────────────────────────────── */
.ig-item{position:relative;overflow:hidden;border-radius:.75rem;aspect-ratio:1;cursor:pointer}
.ig-item img{transition:transform .4s ease}
.ig-item:hover img{transform:scale(1.08)}
.ig-overlay{position:absolute;inset:0;background:rgba(44,26,14,.72);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.ig-item:hover .ig-overlay{opacity:1}

/* ─── Form inputs ─────────────────────────────────────── */
.form-field{background:rgba(255,248,235,.06);border:1px solid rgba(232,162,60,.18);color:#FDF4E3;border-radius:.75rem;width:100%;padding:.75rem 1rem;font-size:.875rem;font-family:'Inter','Inter Fallback',sans-serif;transition:all .3s;outline:none}
.form-field:focus{border-color:rgba(232,162,60,.55);background:rgba(255,248,235,.1);box-shadow:0 0 0 3px rgba(232,162,60,.1)}
.form-field::placeholder{color:rgba(253,244,227,.35)}
select.form-field option{background:#2C1A0E;color:#FDF4E3}

/* ─── Cart sidebar ────────────────────────────────────── */
#cart-sidebar{transition:transform .4s cubic-bezier(.4,0,.2,1)}
.cart-qty-btn{width:1.75rem;height:1.75rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;transition:all .2s;cursor:pointer;flex-shrink:0}
.cart-qty-btn:disabled{opacity:.35;cursor:not-allowed}
.cart-suggest-card{flex:0 0 120px;border-radius:.875rem;overflow:hidden;cursor:pointer;border:1px solid rgba(232,162,60,.12);background:rgba(255,248,235,.04);transition:all .25s}
.cart-suggest-card:hover{border-color:rgba(232,162,60,.35);background:rgba(255,248,235,.08)}

/* ─── Search ─────────────────────────────────────────── */
.search-wrap input{background:rgba(255,248,235,.07);border:1px solid rgba(232,162,60,.18);color:#FDF4E3;border-radius:.875rem;padding:.7rem 1rem .7rem 2.75rem;font-size:.875rem;transition:all .3s;outline:none;width:100%}
.search-wrap input:focus{border-color:rgba(232,162,60,.5);background:rgba(255,248,235,.11)}
.search-wrap input::placeholder{color:rgba(253,244,227,.35)}

/* ─── Sheffield's Selection bento ───────────────────── */
.sel-card{
  position:relative;overflow:hidden;border-radius:1.5rem;
  background:rgba(255,248,235,.05);
  border:1px solid rgba(232,162,60,.1);
  cursor:pointer;
  transition:border-color .4s,box-shadow .4s}
.sel-card::before{
  content:'';position:absolute;inset:0 0 auto;height:2px;
  background:linear-gradient(90deg,transparent,rgba(232,162,60,.6),transparent);
  transform:scaleX(0);transition:transform .5s ease;z-index:2}
.sel-card:hover::before{transform:scaleX(1)}
.sel-card:hover{border-color:rgba(232,162,60,.3);box-shadow:0 28px 56px rgba(0,0,0,.45)}
.sel-ghost{
  position:absolute;top:.5rem;right:1.25rem;
  font-family:'Playfair Display',Georgia,serif;font-weight:700;line-height:1;
  color:rgba(255,255,255,.035);pointer-events:none;user-select:none;z-index:1}
.sel-img{width:100%;height:100%;object-fit:cover;
  transition:transform .75s cubic-bezier(.4,0,.2,1)}
.sel-card:hover .sel-img{transform:scale(1.06)}

/* ─── Divider ────────────────────────────────────────── */
.divider{height:1px;background:linear-gradient(90deg,transparent,rgba(232,162,60,.25),transparent)}

/* ─── Line-clamp ─────────────────────────────────────── */
.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ─── Badge ──────────────────────────────────────────── */
.badge{font-size:10px;font-weight:700;letter-spacing:.5px;padding:2px 9px;border-radius:20px;text-transform:uppercase;display:inline-block}
.badge-gold{background:#E8A23C;color:#2C1A0E}
.badge-red{background:#C4682A;color:#FDF4E3}
.badge-green{background:#4a7c59;color:#FDF4E3}
.badge-blue{background:#3b6ea8;color:#FDF4E3}

/* ─── Toast ──────────────────────────────────────────── */
#toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);z-index:9999;transition:opacity .4s}

/* ─── Map ────────────────────────────────────────────── */
.map-frame{filter:invert(92%) hue-rotate(180deg) saturate(.55) brightness(.85)}

/* ─── Allergy banner ─────────────────────────────────── */
#allergy-bar{position:fixed;top:0;left:0;right:0;z-index:45;background:linear-gradient(90deg,#55270C,#7A3A14 50%,#55270C);border-bottom:1px solid rgba(232,162,60,.2);transition:transform .3s ease}
#allergy-bar.bar-hidden{transform:translateY(-100%)}

/* ─── Stars ──────────────────────────────────────────── */
.stars{color:#E8A23C}

/* ─── Variant sheet ──────────────────────────────────── */
#variant-sheet{
  position:fixed;bottom:0;left:0;right:0;z-index:62;
  display:flex;flex-direction:column;max-height:92vh;
  background:rgba(14,8,3,.98);
  border-top:1px solid rgba(232,162,60,.2);
  border-radius:1.5rem 1.5rem 0 0;
  transform:translateY(100%);
  transition:transform .4s cubic-bezier(.4,0,.2,1);
  overflow:hidden;
}
#variant-sheet.vs-open{transform:translateY(0)}
#variant-overlay{position:fixed;inset:0;z-index:61;background:rgba(26,15,7,.72);backdrop-filter:blur(6px);display:none}
#variant-overlay.vs-open{display:block}
@media(min-width:640px){
  #variant-sheet{left:50%;right:auto;width:min(500px,100vw);margin-left:min(-250px,-50vw);border-radius:1.5rem 1.5rem 0 0}
}
.vopt-btn{display:flex;align-items:center;gap:.875rem;width:100%;border-radius:.875rem;padding:.875rem 1rem;text-align:left;transition:all .25s;border:1.5px solid rgba(232,162,60,.12);background:rgba(255,248,235,.04);cursor:pointer}
.vopt-btn:hover{border-color:rgba(232,162,60,.38);background:rgba(255,248,235,.08)}
.vopt-btn.vopt-selected{border-color:#E8A23C;background:rgba(232,162,60,.1)}
.vopt-radio{width:1.125rem;height:1.125rem;border-radius:50%;border:2px solid rgba(253,244,227,.25);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .2s}
.vopt-btn.vopt-selected .vopt-radio{border-color:#E8A23C;background:#E8A23C}
.vopt-radio-dot{width:.5rem;height:.5rem;border-radius:50%;background:#2C1A0E;opacity:0;transform:scale(0);transition:all .2s}
.vopt-btn.vopt-selected .vopt-radio-dot{opacity:1;transform:scale(1)}

/* ─── Order mode toggle ──────────────────────────────────── */
.order-mode-btn{flex:1;padding:.575rem .5rem;border-radius:.5rem;font-size:.75rem;font-weight:700;transition:all .25s;cursor:pointer;border:none;outline:none;font-family:'Inter','Inter Fallback',sans-serif}
.omode-active{background:linear-gradient(135deg,#E8A23C,#C4682A);color:#2C1A0E;box-shadow:0 2px 8px rgba(232,162,60,.28)}
.omode-inactive{background:transparent;color:rgba(253,244,227,.4)}
.omode-inactive:hover{color:rgba(253,244,227,.72)}

/* ─── Postcode input ─────────────────────────────────────── */
.pc-input{background:rgba(255,248,235,.07);border:1px solid rgba(232,162,60,.22);color:#FDF4E3;border-radius:.5rem;padding:.525rem .75rem;font-size:.8rem;font-family:'Inter','Inter Fallback',sans-serif;outline:none;transition:border-color .25s,background .25s;flex:1;letter-spacing:.04em}
.pc-input:focus{border-color:rgba(232,162,60,.55);background:rgba(255,248,235,.11)}
.pc-input::placeholder{color:rgba(253,244,227,.28);letter-spacing:0}

/* ─── Postcode gate modal ────────────────────────────────── */
#postcode-modal{
  position:fixed;inset:0;z-index:80;
  display:flex;align-items:flex-end;justify-content:center;
  background:rgba(14,8,3,.8);backdrop-filter:blur(9px);-webkit-backdrop-filter:blur(9px);
  opacity:0;pointer-events:none;transition:opacity .3s;
}
@media(min-width:520px){#postcode-modal{align-items:center}}
#postcode-modal.pm-open{opacity:1;pointer-events:all}
#pm-box{
  background:rgba(14,8,3,.99);
  border:1px solid rgba(232,162,60,.22);
  border-radius:1.5rem 1.5rem 0 0;
  padding:1.875rem 1.75rem 2.25rem;
  width:100%;max-width:440px;
  transform:translateY(24px);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
}
@media(min-width:520px){#pm-box{border-radius:1.5rem;transform:scale(.93) translateY(8px)}}
#postcode-modal.pm-open #pm-box{transform:translateY(0)}
@media(min-width:520px){#postcode-modal.pm-open #pm-box{transform:scale(1) translateY(0)}}
#pm-result{font-size:.8rem;margin-top:.6rem;line-height:1.5;min-height:1.1rem;transition:all .2s}
.pm-success{color:#4ade80}
.pm-error{color:#f87171}

/* ─── Saved postcode chips ───────────────────────────────── */
.pc-chip{display:inline-flex;align-items:center;border:1px solid rgba(232,162,60,.25);background:rgba(255,248,235,.05);border-radius:9999px;overflow:hidden;transition:border-color .2s,background .2s}
.pc-chip:hover{border-color:rgba(232,162,60,.5);background:rgba(255,248,235,.09)}
.pc-chip-label{padding:.35rem .7rem;font-size:.72rem;font-weight:600;color:#FDF4E3;cursor:pointer;border:none;background:none;font-family:'Inter','Inter Fallback',sans-serif;letter-spacing:.02em}
.pc-chip-x{padding:.35rem .55rem .35rem .15rem;font-size:.9rem;line-height:1;color:rgba(253,244,227,.32);cursor:pointer;border:none;background:none;transition:color .2s}
.pc-chip-x:hover{color:#f87171}

/* ─── Focus visibility (keyboard a11y) ───────────────── */
:focus-visible{outline:2px solid #E8A23C;outline-offset:2px;border-radius:4px}
.btn-primary:focus-visible,.btn-outline:focus-visible,.cat-card:focus-visible,.sel-card:focus-visible,.product-card:focus-visible{outline-offset:3px}
input:focus-visible,textarea:focus-visible,select:focus-visible{outline:none}

/* ─── Skip link ──────────────────────────────────────── */
.skip-link{position:fixed;top:-120px;left:1rem;z-index:100;background:#E8A23C;color:#2C1A0E;font-weight:700;font-size:.875rem;padding:.65rem 1.1rem;border-radius:.5rem;transition:top .25s ease}
.skip-link:focus{top:1rem}

/* ─── Reduced motion (accessibility) ─────────────────── */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  html{scroll-behavior:auto!important}
  .menu-pop{animation:none!important;opacity:1!important;transform:none!important}
  .reveal{opacity:1!important;transform:none!important}
}

/* ─── Hero text readability ─────────────────────────────── */
#home h1 .text-cream{text-shadow:0 1px 12px rgba(0,0,0,.65),0 3px 40px rgba(0,0,0,.45)}
#home .live-status-pill{filter:drop-shadow(0 2px 10px rgba(0,0,0,.55))}
#home .hero-feature-pills{filter:drop-shadow(0 2px 8px rgba(0,0,0,.5))}
#home .hero-cta-row{filter:drop-shadow(0 4px 16px rgba(0,0,0,.4))}

/* ─── Value Prop Cards ──────────────────────────────────── */
.vp-card{
  position:relative;border-radius:1.5rem;overflow:hidden;
  background:rgba(255,248,235,.045);
  border:1px solid rgba(232,162,60,.1);
  transition:transform .45s cubic-bezier(.22,1,.36,1),border-color .4s ease,box-shadow .45s ease;
  cursor:default}
.vp-card:hover{
  transform:translateY(-10px);
  border-color:rgba(232,162,60,.32);
  box-shadow:0 40px 80px rgba(0,0,0,.48),inset 0 1px 0 rgba(232,162,60,.14)}
.vp-card::before{
  content:'';position:absolute;inset:0 0 auto;height:2px;
  background:linear-gradient(90deg,transparent,rgba(232,162,60,.85),transparent);
  transform:scaleX(0);transition:transform .55s ease;z-index:3}
.vp-card:hover::before{transform:scaleX(1)}
.vp-card::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(110deg,transparent 35%,rgba(255,255,255,.035) 50%,transparent 65%);
  background-size:200% 100%;background-position:100% 0;
  opacity:0;transition:opacity .25s ease;z-index:1;pointer-events:none}
.vp-card:hover::after{opacity:1;animation:vpSweep 1.4s ease forwards}
@keyframes vpSweep{from{background-position:100% 0}to{background-position:-100% 0}}
.vp-glow{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at 25% 0%,rgba(232,162,60,.14) 0%,transparent 60%);
  opacity:0;transition:opacity .5s ease;pointer-events:none;z-index:0}
.vp-card:hover .vp-glow{opacity:1}
.vp-ghost-num{
  position:absolute;right:1.1rem;top:.2rem;
  font-family:'Playfair Display',serif;font-size:5.5rem;font-weight:700;line-height:1;
  color:rgba(232,162,60,.06);user-select:none;pointer-events:none;z-index:1;
  transition:color .4s ease,transform .45s cubic-bezier(.22,1,.36,1)}
.vp-card:hover .vp-ghost-num{color:rgba(232,162,60,.14);transform:scale(1.08) translateY(-6px)}
.vp-icon{
  width:3.5rem;height:3.5rem;border-radius:1.125rem;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.25rem;font-size:1.375rem;color:#E8A23C;
  background:linear-gradient(135deg,rgba(232,162,60,.16),rgba(196,104,42,.1));
  border:1px solid rgba(232,162,60,.2);
  transition:all .4s cubic-bezier(.34,1.56,.64,1);position:relative;z-index:2}
.vp-card:hover .vp-icon{
  transform:scale(1.18) rotate(-8deg);
  background:linear-gradient(135deg,rgba(232,162,60,.28),rgba(196,104,42,.2));
  border-color:rgba(232,162,60,.52);
  box-shadow:0 10px 28px rgba(232,162,60,.28)}
@keyframes vpDot{0%,100%{transform:translateY(0) scale(1);opacity:.45}50%{transform:translateY(-9px) scale(1.3);opacity:.9}}
.vp-dot{position:absolute;border-radius:50%;background:rgba(232,162,60,.22);pointer-events:none;z-index:1}
.vp-dot-1{width:5px;height:5px;bottom:3.5rem;left:1.5rem;animation:vpDot 3s ease-in-out infinite}
.vp-dot-2{width:3px;height:3px;bottom:2.25rem;left:2.75rem;animation:vpDot 4s .5s ease-in-out infinite}
.vp-dot-3{width:4px;height:4px;bottom:4.5rem;left:3.25rem;animation:vpDot 3.5s 1.1s ease-in-out infinite}
.vp-content{position:relative;z-index:2;padding:2rem 1.75rem}
.vp-label{font-size:.6875rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(232,162,60,.5);margin-bottom:.5rem}
.vp-title{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:#FDF4E3;line-height:1.35;margin-bottom:.875rem}
.vp-desc{font-size:.875rem;color:rgba(253,244,227,.52);line-height:1.75}
.vp-footer{
  margin-top:1.5rem;padding-top:.875rem;
  border-top:1px solid rgba(232,162,60,.1);
  display:flex;align-items:center;justify-content:space-between}
.vp-stat{font-size:.6875rem;color:rgba(232,162,60,.52);font-weight:600}
.vp-pulse{
  width:7px;height:7px;border-radius:50%;
  background:rgba(74,222,128,.75);
  box-shadow:0 0 0 3px rgba(74,222,128,.18);
  animation:pulse-ring 2s infinite;color:rgba(74,222,128,.4);flex-shrink:0}
.vp-cta{
  font-size:.6875rem;font-weight:700;color:rgba(232,162,60,.62);
  transition:color .2s ease;display:inline-flex;align-items:center;gap:.35rem;
  border:none;background:none;cursor:pointer;font-family:'Inter','Inter Fallback',sans-serif}
.vp-cta:hover{color:#E8A23C}

/* ─── Sheffield's Selection — premium additions ─────────── */
.sel-card.sel-hero::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:3;
  background:linear-gradient(110deg,transparent 35%,rgba(255,255,255,.04) 50%,transparent 65%);
  background-size:200% 100%;background-position:100% 0;opacity:0}
.sel-card.sel-hero:hover::after{opacity:1;animation:vpSweep 2.2s ease-in-out infinite}
.sel-pop-badge{
  position:absolute;top:1.25rem;right:1.25rem;z-index:10;
  display:flex;align-items:center;gap:.4rem;
  background:rgba(14,8,3,.78);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(232,162,60,.28);border-radius:9999px;
  padding:.35rem .8rem .35rem .6rem;font-size:.6875rem;font-weight:700;
  color:#E8A23C;letter-spacing:.02em;
  animation:fadeUp .7s .5s ease both}
.sel-pop-dot{
  width:6px;height:6px;border-radius:50%;background:#E8A23C;
  box-shadow:0 0 0 3px rgba(232,162,60,.22);
  animation:pulse-ring 2s infinite;color:rgba(232,162,60,.35);flex-shrink:0}
@keyframes selSparkle{
  0%,100%{opacity:0;transform:scale(0) translateY(0)}
  30%,70%{opacity:.9}
  50%{transform:scale(1) translateY(-15px)}}
.sel-sparkle{
  position:absolute;pointer-events:none;z-index:5;
  font-size:11px;color:rgba(232,162,60,.8);user-select:none}
.sel-sparkle-1{bottom:7.5rem;right:2.75rem;animation:selSparkle 3.5s ease-in-out infinite}
.sel-sparkle-2{bottom:9.5rem;right:4.75rem;animation:selSparkle 4.2s .9s ease-in-out infinite}
.sel-sparkle-3{bottom:6.5rem;right:5.75rem;animation:selSparkle 5s 1.8s ease-in-out infinite}
.sel-freshness{
  position:absolute;bottom:6.5rem;left:1.75rem;z-index:20;
  display:flex;align-items:center;gap:.4rem;
  background:rgba(14,8,3,.65);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(74,222,128,.22);border-radius:.625rem;
  padding:.4rem .8rem;font-size:.7rem;font-weight:600;color:rgba(74,222,128,.9);
  opacity:0;transform:translateY(6px);transition:all .35s ease;pointer-events:none}
.sel-card.sel-hero:hover .sel-freshness{opacity:1;transform:translateY(0)}
.sel-stats{
  display:flex;margin-top:1rem;
  background:rgba(255,248,235,.04);
  border:1px solid rgba(232,162,60,.1);
  border-radius:1rem;overflow:hidden}
.sel-stat-item{
  flex:1;display:flex;align-items:center;gap:.75rem;
  padding:.875rem 1.25rem;
  border-right:1px solid rgba(232,162,60,.07);
  transition:background .3s ease}
.sel-stat-item:last-child{border-right:none}
.sel-stat-item:hover{background:rgba(255,248,235,.06)}
.sel-stat-icon{
  width:2rem;height:2rem;border-radius:.625rem;
  background:rgba(232,162,60,.1);
  display:flex;align-items:center;justify-content:center;
  color:#E8A23C;font-size:.8rem;flex-shrink:0}

/* ─── Team Section ───────────────────────────────────────── */
.team-card{
  position:relative;border-radius:1.5rem;overflow:hidden;cursor:default;
  border:1px solid rgba(232,162,60,.14);
  transition:transform .55s cubic-bezier(.22,1,.36,1),border-color .4s ease,box-shadow .55s ease}
.team-card:hover{
  transform:translateY(-10px);
  border-color:rgba(232,162,60,.42);
  box-shadow:0 44px 88px rgba(0,0,0,.55),0 0 0 1px rgba(232,162,60,.2)}
.team-card::before{
  content:'';position:absolute;inset:0 0 auto;height:2px;
  background:linear-gradient(90deg,transparent,rgba(232,162,60,.9),transparent);
  transform:scaleX(0);transition:transform .6s ease;z-index:5}
.team-card:hover::before{transform:scaleX(1)}
.team-img{
  width:100%;height:100%;object-fit:cover;object-position:top center;
  transition:transform .8s cubic-bezier(.4,0,.2,1);display:block}
.team-card:hover .team-img{transform:scale(1.08)}
.team-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(14,8,3,.97) 0%,rgba(14,8,3,.4) 42%,rgba(14,8,3,.04) 75%);
  transition:background .5s ease}
.team-card:hover .team-overlay{
  background:linear-gradient(to top,rgba(14,8,3,.99) 0%,rgba(14,8,3,.74) 50%,rgba(14,8,3,.2) 85%)}
.team-ghost-num{
  position:absolute;top:.875rem;right:1.25rem;z-index:2;
  font-family:'Playfair Display',serif;font-size:5rem;font-weight:700;line-height:1;
  color:rgba(253,244,227,.05);user-select:none;pointer-events:none;
  transition:color .4s ease,transform .5s cubic-bezier(.22,1,.36,1)}
.team-card:hover .team-ghost-num{color:rgba(232,162,60,.14);transform:scale(1.06) translateY(-5px)}
.team-info{position:absolute;bottom:0;left:0;right:0;z-index:10;padding:1.5rem 1.5rem 1.75rem}
.team-accent{
  height:2px;
  background:linear-gradient(90deg,#E8A23C,#C4682A);
  width:1.875rem;border-radius:2px;margin-bottom:.875rem;
  transition:width .55s cubic-bezier(.22,1,.36,1)}
.team-card:hover .team-accent{width:4.5rem}
.team-role{
  font-size:.625rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:rgba(232,162,60,.72);margin-bottom:.35rem}
.team-name{
  font-family:'Playfair Display',serif;font-size:1.25rem;font-weight:700;
  color:#FDF4E3;line-height:1.25}
.team-bio{
  font-size:.78rem;color:rgba(253,244,227,.5);line-height:1.65;
  max-height:0;overflow:hidden;opacity:0;
  transition:max-height .45s ease,opacity .4s .05s ease,margin .4s ease}
.team-card:hover .team-bio{max-height:5.5rem;opacity:1;margin-top:.625rem}
.team-socials{
  display:flex;gap:.45rem;margin-top:0;
  opacity:0;transform:translateY(8px);
  transition:opacity .35s .15s ease,transform .35s .15s ease,margin .4s ease}
.team-card:hover .team-socials{opacity:1;transform:translateY(0);margin-top:.75rem}
.team-social-btn{
  width:2rem;height:2rem;border-radius:.5rem;cursor:pointer;
  background:rgba(255,248,235,.08);border:1px solid rgba(232,162,60,.2);
  display:flex;align-items:center;justify-content:center;
  color:rgba(253,244,227,.5);font-size:.7rem;
  transition:all .2s ease;text-decoration:none}
.team-social-btn:hover{
  background:rgba(232,162,60,.22);border-color:rgba(232,162,60,.55);color:#E8A23C}

/* ─── Social Platform Cards ─────────────────────────────── */
.social-platform-card{
  position:relative;border-radius:1.25rem;overflow:hidden;
  background:rgba(255,248,235,.04);border:1px solid rgba(232,162,60,.1);
  padding:1.625rem 1rem;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  text-decoration:none;
  transition:transform .38s cubic-bezier(.22,1,.36,1),border-color .35s,box-shadow .38s}
.social-platform-card:hover{
  transform:translateY(-7px);
  border-color:rgba(232,162,60,.35);
  box-shadow:0 28px 60px rgba(0,0,0,.46)}
.social-platform-card::before{
  content:'';position:absolute;inset:0 0 auto;height:2px;
  background:linear-gradient(90deg,transparent,rgba(232,162,60,.8),transparent);
  transform:scaleX(0);transition:transform .5s ease;z-index:2}
.social-platform-card:hover::before{transform:scaleX(1)}
.spc-icon{
  width:3rem;height:3rem;border-radius:.875rem;
  display:flex;align-items:center;justify-content:center;font-size:1.375rem;
  transition:transform .38s cubic-bezier(.34,1.56,.64,1),box-shadow .38s ease}
.social-platform-card:hover .spc-icon{transform:scale(1.18) rotate(-7deg)}
.spc-name{
  font-family:'Playfair Display',serif;font-size:.95rem;font-weight:700;
  color:#FDF4E3;line-height:1.2;margin-top:.125rem}
.spc-handle{font-size:.68rem;color:rgba(253,244,227,.35);font-weight:500;letter-spacing:.02em}
.spc-cta{
  font-size:.625rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(232,162,60,.6);margin-top:.125rem;
  transition:color .2s ease}
.social-platform-card:hover .spc-cta{color:#E8A23C}

/* ─── Award Section ──────────────────────────────────────── */
@keyframes shimmerSweep{
  0%{background-position:200% center}
  100%{background-position:-200% center}}
.award-shimmer-text{
  background:linear-gradient(90deg,#E8A23C 0%,#FDF4E3 25%,#E8A23C 50%,#FDF4E3 75%,#C4682A 100%);
  background-size:200% auto;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:shimmerSweep 4s linear infinite}
@keyframes starTwinkle{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.45;transform:scale(.8)}}
.award-star{display:inline-block}
.award-star:nth-child(1){animation:starTwinkle 2.4s .0s  ease-in-out infinite}
.award-star:nth-child(2){animation:starTwinkle 2.4s .25s ease-in-out infinite}
.award-star:nth-child(3){animation:starTwinkle 2.4s .5s  ease-in-out infinite}
.award-star:nth-child(4){animation:starTwinkle 2.4s .75s ease-in-out infinite}
.award-star:nth-child(5){animation:starTwinkle 2.4s 1.0s ease-in-out infinite}

/* ── Main card ── */
.aw2-card{
  position:relative;overflow:hidden;border-radius:2rem;
  border:1px solid rgba(232,162,60,.2);
  box-shadow:0 48px 96px rgba(0,0,0,.6),0 0 0 1px rgba(232,162,60,.05)}
.aw2-card::before{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse at 95% 8%,rgba(232,162,60,.13) 0%,transparent 42%),
    radial-gradient(ellipse at 5%  92%,rgba(122,58,20,.17)  0%,transparent 42%),
    linear-gradient(145deg,rgba(26,14,5,.99) 0%,rgba(44,26,14,.99) 40%,rgba(68,32,10,.97) 100%)}
/* Subtle certificate hatching watermark */
.aw2-card::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  opacity:.018;
  background-image:repeating-linear-gradient(
    50deg,rgba(232,162,60,1) 0px,rgba(232,162,60,1) 1px,
    transparent 1px,transparent 32px)}

/* ── Text column ── */
.aw2-text-col{
  position:relative;z-index:1;
  display:flex;flex-direction:column;justify-content:center;
  padding:3.25rem 3.25rem 3rem;
  border-right:1px solid rgba(232,162,60,.08)}
@media(max-width:1023px){.aw2-text-col{padding:2.5rem 2rem;border-right:none;border-bottom:1px solid rgba(232,162,60,.08)}}

/* ── Image column ── */
.aw2-img-col{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:3.25rem 3rem;
  background:radial-gradient(ellipse at 50% 50%,rgba(85,39,12,.28) 0%,transparent 68%)}

/* ── Concentric glow rings behind image ── */
.aw2-ring{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  border-radius:50%;pointer-events:none;border-style:solid}
.aw2-ring-1{width:440px;height:440px;border:1px solid rgba(232,162,60,.07);animation:aw2RingPulse 5s ease-in-out infinite}
.aw2-ring-2{width:340px;height:340px;border:1px solid rgba(232,162,60,.11);animation:aw2RingPulse 5s .8s ease-in-out infinite}
.aw2-ring-3{width:240px;height:240px;border:1px solid rgba(232,162,60,.06);animation:aw2RingPulse 5s 1.6s ease-in-out infinite}
@keyframes aw2RingPulse{
  0%,100%{opacity:.6;transform:translate(-50%,-50%) scale(1)}
  50%{opacity:1;transform:translate(-50%,-50%) scale(1.03)}}

/* ── Image frame (golden triple-border) ── */
.aw2-frame-wrap{position:relative;flex-shrink:0}
.aw2-frame{
  border-radius:1.625rem;
  padding:3px;
  background:linear-gradient(145deg,#E8A23C 0%,rgba(196,104,42,.55) 50%,#E8A23C 100%);
  box-shadow:
    0 0 0 9px rgba(22,11,4,.95),
    0 0 0 11px rgba(232,162,60,.15),
    0 0 0 12px rgba(22,11,4,.6),
    0 40px 88px rgba(0,0,0,.6),
    0 0 100px rgba(232,162,60,.1)}
.aw2-photo{
  width:100%;aspect-ratio:1;object-fit:cover;display:block;
  border-radius:calc(1.625rem - 3px);
  max-width:340px}
.aw2-photo-hover-wrap{overflow:hidden;border-radius:calc(1.625rem - 3px)}
.aw2-photo-hover-wrap:hover .aw2-photo{transform:scale(1.04);transition:transform 12s ease-in-out}
.aw2-photo{transition:transform 12s ease-in-out}

/* ── Award seal ── */
@keyframes aw2SealPulse{
  0%,100%{box-shadow:0 4px 20px rgba(232,162,60,.45),0 0 0 3.5px rgba(20,10,3,.92),0 0 0 5px rgba(232,162,60,.35),0 0 0 0 rgba(232,162,60,0)}
  50%{box-shadow:0 4px 32px rgba(232,162,60,.65),0 0 0 3.5px rgba(20,10,3,.92),0 0 0 5px rgba(232,162,60,.55),0 0 48px rgba(232,162,60,.18)}}
.aw2-seal{
  position:absolute;top:-16px;right:-16px;
  width:68px;height:68px;border-radius:50%;
  background:linear-gradient(135deg,#E8A23C 30%,#C4682A 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;
  color:#1A0C05;font-weight:800;
  animation:aw2SealPulse 3s ease-in-out infinite;
  z-index:10}
.aw2-seal-icon{font-size:.95rem;line-height:1}
.aw2-seal-yr{font-size:.52rem;font-weight:800;letter-spacing:.05em;line-height:1}

/* ── Corner ornaments ── */
.aw2-corner{position:absolute;width:22px;height:22px;pointer-events:none}
.aw2-corner-tl{top:-16px;left:-16px;border-top:2px solid rgba(232,162,60,.5);border-left:2px solid rgba(232,162,60,.5);border-radius:3px 0 0 0}
.aw2-corner-tr{top:-16px;right:-16px;border-top:2px solid rgba(232,162,60,.5);border-right:2px solid rgba(232,162,60,.5);border-radius:0 3px 0 0}
.aw2-corner-bl{bottom:-16px;left:-16px;border-bottom:2px solid rgba(232,162,60,.5);border-left:2px solid rgba(232,162,60,.5);border-radius:0 0 0 3px}
.aw2-corner-br{bottom:-16px;right:-16px;border-bottom:2px solid rgba(232,162,60,.5);border-right:2px solid rgba(232,162,60,.5);border-radius:0 0 3px 0}

/* ── Text details ── */
.aw2-ribbon{
  display:inline-flex;align-items:center;gap:.45rem;
  background:linear-gradient(135deg,rgba(232,162,60,.18),rgba(196,104,42,.1));
  border:1px solid rgba(232,162,60,.32);border-radius:9999px;
  padding:.38rem 1rem;font-size:.65rem;font-weight:800;
  color:#E8A23C;letter-spacing:.08em;text-transform:uppercase;
  box-shadow:0 4px 16px rgba(232,162,60,.12)}
.aw2-divider{
  height:1px;margin:1.5rem 0;
  background:linear-gradient(90deg,rgba(232,162,60,.3),rgba(232,162,60,.08) 65%,transparent)}
.aw2-quote{
  position:relative;padding:.875rem 1.25rem .875rem 1.375rem;
  border-left:2.5px solid rgba(232,162,60,.5);
  background:rgba(232,162,60,.04);border-radius:0 .875rem .875rem 0}
.aw2-qmark{
  font-family:'Playfair Display',Georgia,serif;font-size:5rem;line-height:.75;
  color:rgba(232,162,60,.1);position:absolute;top:.5rem;left:.625rem;
  pointer-events:none;user-select:none}
.aw2-founder{
  display:flex;align-items:center;gap:.875rem;
  background:rgba(255,248,235,.04);border:1px solid rgba(232,162,60,.12);
  border-radius:1rem;padding:.875rem 1.125rem;margin-top:1.25rem;
  transition:border-color .3s,background .3s}
.aw2-founder:hover{border-color:rgba(232,162,60,.28);background:rgba(255,248,235,.06)}
.aw2-founder-av{
  width:2.75rem;height:2.75rem;border-radius:.75rem;flex-shrink:0;
  background:linear-gradient(135deg,rgba(232,162,60,.3),rgba(122,58,20,.2));
  border:1.5px solid rgba(232,162,60,.35);
  display:flex;align-items:center;justify-content:center;
  font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;color:#E8A23C;
  transition:all .3s ease}
.aw2-founder:hover .aw2-founder-av{
  background:linear-gradient(135deg,rgba(232,162,60,.44),rgba(122,58,20,.32));
  box-shadow:0 6px 20px rgba(232,162,60,.22)}

/* ── Bottom stats strip ── */
.aw2-stats{
  display:flex;position:relative;z-index:1;
  border-top:1px solid rgba(232,162,60,.09)}
.aw2-stat{
  flex:1;display:flex;align-items:center;gap:.75rem;
  padding:.875rem 1.375rem;
  border-right:1px solid rgba(232,162,60,.07);
  transition:background .3s}
.aw2-stat:last-child{border-right:none}
.aw2-stat:hover{background:rgba(255,248,235,.04)}
.aw2-stat-icon{
  width:2rem;height:2rem;border-radius:.5rem;flex-shrink:0;
  background:rgba(232,162,60,.1);
  display:flex;align-items:center;justify-content:center;
  color:#E8A23C;font-size:.75rem}

/* ─── Custom Cakes Section ───────────────────────────── */
/* Feature cards */
.cc-feat-card{
  position:relative;padding:1.25rem 1.375rem 1.125rem;border-radius:1rem;
  background:rgba(14,6,1,.68);border:1px solid rgba(232,162,60,.07);
  overflow:hidden;cursor:default;isolation:isolate;
  transition:transform .5s cubic-bezier(.22,1,.36,1),border-color .45s,box-shadow .45s}
/* Ember underlight — blooms upward from the base on hover */
.cc-feat-card::before{
  content:'';position:absolute;bottom:-40px;left:50%;
  transform:translateX(-50%);
  width:130%;height:110px;
  background:radial-gradient(ellipse at 50% 100%,rgba(232,162,60,.26) 0%,rgba(196,104,42,.1) 40%,transparent 72%);
  opacity:0;pointer-events:none;
  transition:opacity .55s cubic-bezier(.22,1,.36,1),bottom .55s cubic-bezier(.22,1,.36,1)}
/* Inner surface sheen — soft warm reflection sweeping in */
.cc-feat-card::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(135deg,rgba(232,162,60,.055) 0%,transparent 55%);
  opacity:0;transition:opacity .45s}
.cc-feat-card:hover{
  transform:scale(1.028);
  border-color:rgba(232,162,60,.22);
  box-shadow:0 0 0 1px rgba(232,162,60,.07) inset,0 22px 52px rgba(0,0,0,.52),0 2px 14px rgba(232,162,60,.07)}
.cc-feat-card:hover::before{opacity:1;bottom:-16px}
.cc-feat-card:hover::after{opacity:1}
.cc-feat-icon{
  position:relative;z-index:1;width:2.875rem;height:2.875rem;border-radius:.875rem;
  background:linear-gradient(135deg,rgba(232,162,60,.15),rgba(196,104,42,.08));
  border:1px solid rgba(232,162,60,.18);
  display:flex;align-items:center;justify-content:center;
  font-size:1.15rem;color:#E8A23C;margin-bottom:1rem;
  transition:transform .55s cubic-bezier(.22,1,.36,1),filter .45s,border-color .45s,background .45s}
.cc-feat-card:hover .cc-feat-icon{
  transform:translateY(-5px);
  filter:drop-shadow(0 6px 14px rgba(232,162,60,.38));
  background:linear-gradient(135deg,rgba(232,162,60,.26),rgba(196,104,42,.16));
  border-color:rgba(232,162,60,.45)}
.cc-feat-title{
  font-family:'Playfair Display',serif;font-size:.975rem;font-weight:700;
  color:#FDF4E3;line-height:1.3;margin-bottom:.3rem;position:relative;z-index:1}
.cc-feat-sub{
  font-size:.74rem;color:rgba(253,244,227,.38);line-height:1.55;position:relative;z-index:1}
.cc-feat-bar{
  height:1px;margin-top:1rem;
  background:linear-gradient(90deg,rgba(232,162,60,.2),transparent);
  transition:background .45s;position:relative;z-index:1}
.cc-feat-card:hover .cc-feat-bar{background:linear-gradient(90deg,rgba(232,162,60,.55),transparent)}

/* Portfolio gallery strip */
.cc-gallery{
  display:flex;gap:.875rem;
  overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  padding-bottom:.5rem;cursor:grab;
  scrollbar-width:none;-ms-overflow-style:none;
  -webkit-mask:linear-gradient(90deg,transparent 0%,#000 4%,#000 96%,transparent 100%);
  mask:linear-gradient(90deg,transparent 0%,#000 4%,#000 96%,transparent 100%)}
.cc-gallery::-webkit-scrollbar{display:none}
.cc-gallery:active{cursor:grabbing}
.cc-gal-item{
  flex:0 0 calc(25% - .66rem);scroll-snap-align:start;
  border-radius:1.125rem;overflow:hidden;position:relative;
  border:1px solid rgba(232,162,60,.1);flex-shrink:0;
  transition:border-color .35s,box-shadow .35s}
.cc-gal-item:hover{border-color:rgba(232,162,60,.42);box-shadow:0 20px 44px rgba(0,0,0,.5)}
@media(max-width:1024px){.cc-gal-item{flex:0 0 calc(33.333% - .58rem)}}
@media(max-width:640px){.cc-gal-item{flex:0 0 calc(62% - .35rem)}}
.cc-gal-img{
  width:100%;aspect-ratio:1;object-fit:cover;display:block;
  transition:transform .65s cubic-bezier(.22,1,.36,1)}
.cc-gal-item:hover .cc-gal-img{transform:scale(1.09)}
.cc-gal-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(14,8,3,.88) 0%,rgba(14,8,3,.18) 55%,transparent 100%);
  transition:background .35s}
.cc-gal-item:hover .cc-gal-overlay{
  background:linear-gradient(to top,rgba(14,8,3,.94) 0%,rgba(44,22,10,.55) 55%,rgba(232,162,60,.06) 100%)}
.cc-gal-item::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(110deg,transparent 35%,rgba(255,255,255,.055) 50%,transparent 65%);
  background-size:200% 100%;background-position:100% 0;
  opacity:0;transition:opacity .2s;pointer-events:none}
.cc-gal-item:hover::after{opacity:1;animation:ccGalSweep 1.1s ease forwards}
@keyframes ccGalSweep{from{background-position:100% 0}to{background-position:-100% 0}}
.cc-gal-label{
  position:absolute;bottom:.75rem;left:.875rem;right:.875rem;
  color:#FDF4E3;font-family:'Playfair Display',Georgia,serif;
  font-size:.8rem;font-weight:700;line-height:1.3;
  transition:transform .3s ease}
.cc-gal-item:hover .cc-gal-label{transform:translateY(-3px)}
.cc-gal-tag{
  position:absolute;top:.75rem;left:.75rem;
  background:rgba(14,8,3,.72);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(232,162,60,.25);border-radius:9999px;
  padding:.22rem .65rem;font-size:.6rem;font-weight:700;
  color:#E8A23C;letter-spacing:.06em;text-transform:uppercase;
  opacity:0;transform:translateY(-4px);transition:opacity .3s ease,transform .3s ease}
.cc-gal-item:hover .cc-gal-tag{opacity:1;transform:translateY(0)}

/* ════════════════════════════════════════════════════════
   SHOP PAGE — bespoke additions (hero, toolbar, trust strip)
   Builds on the shared tokens above (honey/cream/dark, glass).
════════════════════════════════════════════════════════ */

/* ── Shop hero banner ─────────────────────────────────── */
.shop-hero{position:relative;overflow:hidden;padding:9.5rem 0 3.5rem}
.shop-hero-img{position:absolute;inset:0;z-index:0}
.shop-hero-img img{width:100%;height:100%;object-fit:cover;transform:scale(1.06)}
.shop-hero-veil{position:absolute;inset:0;z-index:1;background:
  linear-gradient(180deg,rgba(26,12,5,.62) 0%,rgba(26,12,5,.55) 40%,rgba(26,12,5,.86) 100%),
  radial-gradient(ellipse at 18% 22%,rgba(232,162,60,.16) 0%,transparent 55%)}
.shop-hero-inner{position:relative;z-index:2}

/* breadcrumb */
.shop-crumb{display:inline-flex;align-items:center;gap:.5rem;font-size:.75rem;color:rgba(253,244,227,.5);font-weight:600}
.shop-crumb a{color:rgba(253,244,227,.5);transition:color .2s}
.shop-crumb a:hover{color:#E8A23C}
.shop-crumb i{font-size:.55rem;color:rgba(232,162,60,.45)}

/* hero search */
.shop-search{position:relative;max-width:34rem}
.shop-search input{width:100%;background:rgba(253,244,227,.07);border:1px solid rgba(232,162,60,.22);
  border-radius:9999px;color:#FDF4E3;font-size:.95rem;padding:1rem 1.25rem 1rem 3.25rem;
  transition:border-color .25s,box-shadow .25s,background .25s;outline:none}
.shop-search input::placeholder{color:rgba(253,244,227,.4)}
.shop-search input:focus{border-color:rgba(232,162,60,.6);background:rgba(253,244,227,.1);
  box-shadow:0 0 0 4px rgba(232,162,60,.12)}
.shop-search i{position:absolute;left:1.25rem;top:50%;transform:translateY(-50%);color:rgba(232,162,60,.7);pointer-events:none}

/* hero stat chips */
.shop-stat{display:flex;flex-direction:column}
.shop-stat .n{font-family:'Playfair Display',serif;font-weight:700;font-size:1.6rem;color:#E8A23C;line-height:1}
.shop-stat .l{font-size:.7rem;color:rgba(253,244,227,.55);margin-top:.25rem;letter-spacing:.02em}

/* ── Sticky filter/sort toolbar ───────────────────────── */
.shop-toolbar{position:sticky;top:72px;z-index:30;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  background:rgba(26,12,5,.82);border:1px solid rgba(232,162,60,.14);border-radius:1rem;
  box-shadow:0 12px 40px -18px rgba(0,0,0,.7);transition:opacity .3s,transform .3s}
.shop-toolbar.toolbar-hidden{opacity:0;transform:translateY(-6px);pointer-events:none;height:0;padding:0!important;margin:0!important;border-width:0;overflow:hidden}

#shop-sort,.shop-sort{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:rgba(26,12,5,.96);
  border:1px solid rgba(232,162,60,.22);border-radius:9999px;color:#FDF4E3;font-size:.8rem;font-weight:600;
  font-family:'Inter','Inter Fallback',sans-serif;padding:.6rem 2.4rem .6rem 1rem;cursor:pointer;outline:none;transition:border-color .2s}
#shop-sort:focus,#shop-sort:hover,.shop-sort:focus,.shop-sort:hover{border-color:rgba(232,162,60,.55)}
#shop-sort option,.shop-sort option{background:#2C1A0E;color:#FDF4E3;font-weight:500}
.shop-sort-wrap{position:relative}
.shop-sort-wrap::after{content:"\f078";font-family:"Font Awesome 6 Free";font-weight:900;font-size:.65rem;
  color:rgba(232,162,60,.7);position:absolute;right:1rem;top:50%;transform:translateY(-50%);pointer-events:none}

/* ── Trust strip ──────────────────────────────────────── */
.trust-strip{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}
@media(min-width:768px){.trust-strip{grid-template-columns:repeat(4,1fr)}}
.trust-item{display:flex;align-items:center;gap:.85rem;padding:1.1rem 1.25rem;border-radius:1rem;
  background:rgba(253,244,227,.04);border:1px solid rgba(232,162,60,.12);transition:border-color .25s,background .25s,transform .25s}
.trust-item:hover{border-color:rgba(232,162,60,.3);background:rgba(253,244,227,.06);transform:translateY(-2px)}
.trust-item .ico{width:2.6rem;height:2.6rem;border-radius:.75rem;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  background:rgba(232,162,60,.12);color:#E8A23C;font-size:1.05rem}
.trust-item .tt{font-weight:700;color:#FDF4E3;font-size:.82rem;line-height:1.2}
.trust-item .ts{font-size:.7rem;color:rgba(253,244,227,.5);margin-top:.15rem}
