:root{
  --gold:#D4A017; --gold-light:#E0B84C; --gold-bright:#F7CB5E; --gold-dim:#8A6A1E;
  --black:#070707; --ink:#111111; --surface:#161616; --surface-2:#1D1D1D;
  --white:#F6F5F1; --text-soft:#ADACA5; --text-dim:#77766F;
  --line:rgba(255,255,255,.09); --line-strong:rgba(255,255,255,.16);
  --serif:'Cormorant Garamond', serif; --sans:'Montserrat', sans-serif;
  --ease:cubic-bezier(.16,.84,.44,1);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0; background:var(--black); color:var(--white); font-family:var(--sans); line-height:1.6; overflow-x:hidden;}
h1,h2,h3,h4{font-family:var(--serif); font-weight:600; margin:0 0 .4em; color:#fff; letter-spacing:-.01em;}
a{color:inherit;}
img{max-width:100%; display:block;}
.wrap{max-width:1220px; margin:0 auto; padding:0 32px;}
section{padding:130px 0; position:relative;}
@media (max-width:768px){ section{padding:80px 0;} .wrap{padding:0 22px;} }

::selection{background:var(--gold); color:#0A0A0A;}
::-webkit-scrollbar{width:10px;}
::-webkit-scrollbar-track{background:var(--black);}
::-webkit-scrollbar-thumb{background:var(--surface-2); border-radius:6px;}

/* ---------- reveal on scroll ---------- */
.reveal{opacity:0; transform:translateY(28px); transition:opacity .9s var(--ease), transform .9s var(--ease);}
.reveal.in{opacity:1; transform:translateY(0);}
.reveal-stagger > *{opacity:0; transform:translateY(24px); transition:opacity .7s var(--ease), transform .7s var(--ease);}
.reveal-stagger.in > *{opacity:1; transform:translateY(0);}
.reveal-stagger.in > *:nth-child(1){transition-delay:.05s;}
.reveal-stagger.in > *:nth-child(2){transition-delay:.15s;}
.reveal-stagger.in > *:nth-child(3){transition-delay:.25s;}
.reveal-stagger.in > *:nth-child(4){transition-delay:.35s;}
.reveal-stagger.in > *:nth-child(5){transition-delay:.45s;}
.reveal-stagger.in > *:nth-child(6){transition-delay:.55s;}
@media (prefers-reduced-motion: reduce){ .reveal, .reveal-stagger > *{opacity:1 !important; transform:none !important; transition:none !important;} * { animation:none !important; } }

/* ---------- scroll progress bar ---------- */
.scroll-progress{position:fixed; top:0; left:0; height:2px; background:linear-gradient(90deg,var(--gold-dim),var(--gold),var(--gold-bright)); z-index:1000; width:0%; transition:width .1s linear;}

/* ---------- eyebrow ---------- */
.eyebrow{font-family:var(--sans); font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); font-weight:600; margin-bottom:1.1rem; display:flex; align-items:center; gap:.6rem;}
.eyebrow::before{content:''; width:26px; height:1px; background:var(--gold);}

/* ---------- nav ---------- */
header.site{position:fixed; top:0; left:0; right:0; z-index:100; background:rgba(7,7,7,.72); backdrop-filter:blur(14px); border-bottom:1px solid var(--line); transition:background .3s;}
.nav{display:flex; align-items:center; justify-content:space-between; padding:16px 32px; max-width:1220px; margin:0 auto;}
.brand-logo{height:76px; width:auto; transition:transform .3s var(--ease);}
.brand-logo:hover{transform:scale(1.04);}
nav.links{display:flex; gap:36px; font-size:.86rem; font-weight:500;}
nav.links a{text-decoration:none; opacity:.75; position:relative; padding:4px 0; transition:opacity .2s;}
nav.links a::after{content:''; position:absolute; left:0; bottom:0; width:0; height:1px; background:var(--gold); transition:width .3s var(--ease);}
nav.links a:hover{opacity:1;}
nav.links a:hover::after{width:100%;}
.menu-toggle{display:none; background:none; border:none; color:#fff; font-size:1.5rem; cursor:pointer;}
@media (max-width:900px){ nav.links{display:none;} .menu-toggle{display:block;} }

/* ---------- buttons ---------- */
.btn{font-family:var(--sans); font-weight:600; font-size:.86rem; border:none; cursor:pointer; padding:15px 30px; border-radius:2px; text-decoration:none; display:inline-flex; align-items:center; gap:10px; position:relative; overflow:hidden; transition:transform .25s var(--ease), box-shadow .25s var(--ease);}
.btn span{position:relative; z-index:2;}
.btn:hover{transform:translateY(-2px);}
.btn-gold{background:linear-gradient(120deg,var(--gold-light),var(--gold) 60%,var(--gold-dim)); color:#0A0A0A; box-shadow:0 8px 24px -8px rgba(212,160,23,.5);}
.btn-gold:hover{box-shadow:0 14px 32px -8px rgba(212,160,23,.7);}
.btn-gold::before{content:''; position:absolute; top:0; left:-120%; width:60%; height:100%; background:linear-gradient(120deg, transparent, rgba(255,255,255,.55), transparent); transform:skewX(-20deg); transition:left .6s ease;}
.btn-gold:hover::before{left:130%;}
.btn-outline{background:transparent; color:#fff; border:1px solid var(--line-strong);}
.btn-outline:hover{border-color:var(--gold); color:var(--gold);}
.btn:focus-visible{outline:2px solid var(--gold); outline-offset:3px;}

/* ---------- hero ---------- */
.hero{min-height:100vh; display:flex; align-items:center; padding-top:150px; position:relative; overflow:hidden;}
.hero-bg{position:absolute; inset:0; z-index:0; background:
  radial-gradient(ellipse 60% 50% at 15% 20%, rgba(212,160,23,.16), transparent 60%),
  radial-gradient(ellipse 50% 40% at 85% 75%, rgba(212,160,23,.10), transparent 60%),
  var(--black);
}
.orb{position:absolute; border-radius:50%; filter:blur(60px); opacity:.5; pointer-events:none;}
.orb1{width:420px; height:420px; background:radial-gradient(circle, rgba(212,160,23,.35), transparent 70%); top:-100px; right:-80px; animation:float1 16s ease-in-out infinite;}
.orb2{width:300px; height:300px; background:radial-gradient(circle, rgba(224,184,76,.25), transparent 70%); bottom:-60px; left:-60px; animation:float2 20s ease-in-out infinite;}
@keyframes float1{0%,100%{transform:translate(0,0);} 50%{transform:translate(-40px,50px);}}
@keyframes float2{0%,100%{transform:translate(0,0);} 50%{transform:translate(40px,-40px);}}
.hero-content{position:relative; z-index:2; max-width:820px;}
.hero h1{font-size:clamp(2.6rem,5.6vw,4.6rem); line-height:1.04; letter-spacing:-.02em;}
.hero h1 .gold-text{background:linear-gradient(100deg,var(--gold-light),var(--gold-bright) 40%,var(--gold)); -webkit-background-clip:text; background-clip:text; color:transparent;}
.hero p.lead{font-size:1.2rem; color:var(--text-soft); max-width:56ch; margin:24px 0 38px;}
.hero-ctas{display:flex; gap:16px; flex-wrap:wrap; margin-bottom:60px;}
.hero-stats{display:flex; gap:52px; flex-wrap:wrap;}
.hero-stats .stat b{font-family:var(--serif); font-size:2.2rem; display:block; color:#fff;}
.hero-stats .stat span{font-size:.78rem; color:var(--text-dim); text-transform:uppercase; letter-spacing:.08em;}
.scroll-cue{position:absolute; bottom:38px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:8px; opacity:.55; z-index:2;}
.scroll-cue .line{width:1px; height:34px; background:linear-gradient(var(--gold), transparent); animation:scrollcue 2s ease-in-out infinite;}
@keyframes scrollcue{0%{transform:scaleY(0); transform-origin:top;} 50%{transform:scaleY(1); transform-origin:top;} 51%{transform-origin:bottom;} 100%{transform:scaleY(0); transform-origin:bottom;}}
.scroll-cue span{font-family:var(--sans); font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; color:var(--text-dim);}

/* ---------- marquee ---------- */
.marquee-wrap{border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--ink); padding:26px 0; overflow:hidden;}
.marquee{display:flex; width:max-content; animation:marquee 32s linear infinite;}
.marquee:hover{animation-play-state:paused;}
.marquee .m-item{display:flex; align-items:center; gap:14px; padding:0 42px; white-space:nowrap; font-family:var(--sans); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text-soft);}
.marquee .m-item .dot{width:5px; height:5px; border-radius:50%; background:var(--gold);}
@keyframes marquee{from{transform:translateX(0);} to{transform:translateX(-50%);}}

/* ---------- section headers ---------- */
.section-head{max-width:680px; margin-bottom:60px;}
.section-head h2{font-size:clamp(2rem,3.6vw,2.8rem);}
.section-head p{color:var(--text-soft); font-size:1.06rem;}

/* ---------- about / big number ---------- */
.about-grid{display:grid; grid-template-columns:.9fr 1.1fr; gap:70px; align-items:center;}
@media (max-width:900px){ .about-grid{grid-template-columns:1fr;} }
.big-number{font-family:var(--serif); font-size:clamp(5rem,12vw,9rem); line-height:.85; background:linear-gradient(160deg,var(--gold-light),var(--gold-dim)); -webkit-background-clip:text; background-clip:text; color:transparent; margin-bottom:6px;}
.about-grid p{color:var(--text-soft); font-size:1.05rem; margin-bottom:18px;}

/* ---------- bento services ---------- */
.bento{display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:18px;}
@media (max-width:960px){ .bento{grid-template-columns:repeat(2,1fr);} }
@media (max-width:600px){ .bento{grid-template-columns:1fr; grid-auto-rows:auto;} }
.bento-card{
  background:linear-gradient(160deg,var(--surface),var(--ink)); border:1px solid var(--line); border-radius:6px;
  padding:28px; display:flex; flex-direction:column; justify-content:space-between; position:relative; overflow:hidden;
  transition:transform .35s var(--ease), border-color .35s var(--ease), box-shadow .35s var(--ease);
}
.bento-card::before{content:''; position:absolute; inset:0; background:radial-gradient(circle at 30% 20%, rgba(212,160,23,.14), transparent 60%); opacity:0; transition:opacity .4s;}
.bento-card:hover{transform:translateY(-6px); border-color:var(--gold-dim); box-shadow:0 24px 48px -20px rgba(0,0,0,.6);}
.bento-card:hover::before{opacity:1;}
.bento-card.wide{grid-column:span 2;}
.bento-card .num{font-family:var(--sans); font-size:.72rem; color:var(--gold); letter-spacing:.1em;}
.bento-card h3{font-size:1.2rem; margin:10px 0 8px; position:relative; z-index:1;}
.bento-card p{color:var(--text-soft); font-size:.9rem; margin:0; position:relative; z-index:1;}
.bento-card .arrow{position:absolute; bottom:22px; right:24px; width:34px; height:34px; border:1px solid var(--line-strong); border-radius:50%; display:flex; align-items:center; justify-content:center; transition:all .3s var(--ease);}
.bento-card:hover .arrow{background:var(--gold); border-color:var(--gold); transform:rotate(45deg);}
.bento-card .arrow svg{width:14px; height:14px; stroke:#fff; transition:stroke .3s;}
.bento-card:hover .arrow svg{stroke:#0A0A0A;}

/* ---------- process timeline ---------- */
.process{display:grid; grid-template-columns:repeat(4,1fr); gap:28px; position:relative;}
@media (max-width:860px){ .process{grid-template-columns:1fr;} }
.process-line{position:absolute; top:26px; left:0; right:0; height:1px; background:var(--line); z-index:0;}
@media (max-width:860px){ .process-line{display:none;} }
.process-step{position:relative; z-index:1;}
.process-step .step-num{width:52px; height:52px; border-radius:50%; background:var(--ink); border:1px solid var(--line-strong); display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:1.3rem; color:var(--gold); margin-bottom:22px; transition:all .4s var(--ease);}
.process-step:hover .step-num{background:var(--gold); color:#0A0A0A; transform:scale(1.08);}
.process-step h4{font-size:1.05rem; margin-bottom:8px;}
.process-step p{color:var(--text-soft); font-size:.88rem;}

/* ---------- booking ---------- */
.booking{background:linear-gradient(180deg,var(--ink),var(--black));}
.booking-panel{background:var(--surface); border:1px solid var(--line); border-radius:8px; display:grid; grid-template-columns:1fr 1fr; overflow:hidden;}
@media (max-width:860px){ .booking-panel{grid-template-columns:1fr;} }
.bk-col{padding:40px;}
.bk-col.left{border-right:1px solid var(--line);}
@media (max-width:860px){ .bk-col.left{border-right:none; border-bottom:1px solid var(--line);} }
.field-label{font-family:var(--sans); font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:var(--text-dim); margin-bottom:9px; display:block; font-weight:600;}
select, input{width:100%; font-family:var(--sans); font-size:.95rem; padding:13px 14px; margin-bottom:22px; border:1px solid var(--line-strong); border-radius:3px; background:var(--ink); color:#fff;}
select:focus, input:focus{outline:none; border-color:var(--gold);}
input::placeholder{color:var(--text-dim);}
.day-picker{display:flex; gap:8px; overflow-x:auto; margin-bottom:22px; padding-bottom:4px;}
.day-chip{flex-shrink:0; border:1px solid var(--line-strong); background:var(--ink); border-radius:3px; padding:11px 15px; text-align:center; cursor:pointer; font-family:var(--sans); font-size:.78rem; font-weight:500; min-width:66px; color:#fff; transition:all .25s;}
.day-chip .dow{display:block; opacity:.55; margin-bottom:3px;}
.day-chip.active{background:var(--gold); color:#0A0A0A; border-color:var(--gold);}
.slot-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:9px; margin-bottom:26px;}
.slot{border:1px solid var(--line-strong); background:var(--ink); border-radius:3px; padding:10px 4px; text-align:center; font-family:var(--sans); font-size:.82rem; font-weight:500; cursor:pointer; color:#fff; transition:all .25s;}
.slot:hover{border-color:var(--gold-dim);}
.slot.active{background:var(--gold); color:#0A0A0A; border-color:var(--gold);}
.teams-badge{display:flex; align-items:center; gap:12px; background:var(--ink); border:1px solid var(--line); border-radius:4px; padding:14px 16px; margin-top:8px; font-size:.85rem; color:var(--text-soft);}
.teams-badge svg{width:22px;height:22px; flex-shrink:0; stroke:var(--gold);}
.confirm-box{display:none; border:1px solid var(--gold-dim); background:rgba(212,160,23,.06); border-radius:4px; padding:20px; margin-top:20px; font-size:.9rem;}
.confirm-box.show{display:block; animation:popin .4s var(--ease);}
@keyframes popin{from{opacity:0; transform:scale(.97);} to{opacity:1; transform:scale(1);}}
.confirm-box b{display:block; margin-bottom:6px; font-family:var(--serif); font-size:1.1rem; color:var(--gold);}

/* ---------- shop ---------- */
.shop-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px;}
@media (max-width:900px){ .shop-grid{grid-template-columns:repeat(2,1fr);} }
@media (max-width:640px){ .shop-grid{grid-template-columns:1fr;} }
.product{background:var(--surface); border:1px solid var(--line); border-radius:6px; display:flex; flex-direction:column; overflow:hidden; transition:transform .35s var(--ease), border-color .35s var(--ease);}
.product:hover{transform:translateY(-6px); border-color:var(--gold-dim);}
.product-media{height:150px; background:linear-gradient(135deg,var(--surface-2),var(--ink)); display:flex; align-items:center; justify-content:center; position:relative;}
.product-media .fmt{position:absolute; top:12px; left:12px; font-family:var(--sans); font-size:.66rem; text-transform:uppercase; color:var(--gold); opacity:.9; letter-spacing:.08em; font-weight:600;}
.product-media svg{width:36px; height:36px; stroke:var(--gold-light); fill:none;}
.product-body{padding:24px; display:flex; flex-direction:column; gap:10px; flex-grow:1;}
.product-body h3{font-size:1.02rem;}
.product-body p{color:var(--text-soft); font-size:.87rem; flex-grow:1;}
.price-row{display:flex; align-items:center; justify-content:space-between; margin-top:6px;}
.price{font-family:var(--serif); font-size:1.4rem; font-weight:600; color:var(--gold-light);}
.add-btn{font-family:var(--sans); font-weight:600; font-size:.8rem; background:#fff; color:#0A0A0A; border:none; border-radius:3px; padding:10px 16px; cursor:pointer; transition:background .25s;}
.add-btn:hover{background:var(--gold);}
.buy-link{font-family:var(--sans); font-size:.76rem; font-weight:600; color:var(--gold); text-decoration:none; margin-top:2px;}
.buy-link:hover{text-decoration:underline;}

/* ---------- testimonial ---------- */
.testimonial{text-align:center;}
.quote-mark{font-family:var(--serif); font-size:5rem; color:var(--gold-dim); line-height:1; margin-bottom:10px;}
blockquote{font-family:var(--serif); font-size:clamp(1.5rem,3vw,2.1rem); font-style:italic; max-width:820px; margin:0 auto 26px; line-height:1.4; color:#fff;}
.cite{font-family:var(--sans); font-size:.82rem; color:var(--text-dim); text-transform:uppercase; letter-spacing:.08em;}

/* ---------- final CTA banner ---------- */
.cta-banner{background:linear-gradient(120deg,var(--gold-dim),var(--gold) 45%,var(--gold-light)); color:#0A0A0A; border-radius:10px; padding:70px 50px; text-align:center; position:relative; overflow:hidden;}
.cta-banner h2{color:#0A0A0A; font-size:clamp(1.9rem,4vw,2.8rem);}
.cta-banner p{color:rgba(10,10,10,.75); font-size:1.05rem; max-width:520px; margin:0 auto 32px;}
.cta-banner .btn-outline{border:1.5px solid #0A0A0A; color:#0A0A0A;}
.cta-banner .btn-outline:hover{background:#0A0A0A; color:var(--gold);}
.cta-shine{position:absolute; top:-50%; left:-20%; width:60%; height:200%; background:rgba(255,255,255,.25); transform:rotate(20deg); animation:shine 5s ease-in-out infinite;}
@keyframes shine{0%,100%{left:-20%;} 50%{left:110%;}}

/* ---------- footer ---------- */
footer{background:var(--black); border-top:1px solid var(--line); padding:70px 0 30px;}
.foot-top{display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:24px; margin-bottom:50px; padding-bottom:44px; border-bottom:1px solid var(--line);}
.foot-top .brand-logo{height:130px;}
.foot-grid{display:grid; grid-template-columns:1fr 1fr 1fr; gap:40px; margin-bottom:50px;}
@media (max-width:800px){ .foot-grid{grid-template-columns:1fr 1fr;} }
footer h4{color:#fff; font-size:.85rem; text-transform:uppercase; letter-spacing:.08em; margin-bottom:18px;}
footer ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:11px; font-size:.9rem;}
footer a{text-decoration:none; color:var(--text-soft); transition:color .2s;}
footer a:hover{color:var(--gold);}
.foot-bottom{border-top:1px solid var(--line); padding-top:26px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; font-size:.78rem; color:var(--text-dim);}

/* ---------- cart drawer ---------- */
.cart-overlay{position:fixed; inset:0; background:rgba(0,0,0,.65); z-index:200; display:none;}
.cart-overlay.show{display:block;}
.cart-drawer{position:fixed; top:0; right:0; height:100%; width:min(420px,92vw); background:var(--surface); z-index:201; transform:translateX(100%); transition:transform .35s var(--ease); display:flex; flex-direction:column; border-left:1px solid var(--line);}
.cart-drawer.show{transform:translateX(0);}
.cart-head{padding:26px; border-bottom:1px solid var(--line); display:flex; justify-content:space-between; align-items:center;}
.cart-items{flex-grow:1; overflow-y:auto; padding:16px 26px;}
.cart-line{display:flex; justify-content:space-between; gap:12px; padding:16px 0; border-bottom:1px solid var(--line); font-size:.9rem;}
.cart-line .rm{background:none; border:none; color:var(--text-dim); cursor:pointer; font-size:.78rem; text-decoration:underline; padding:0;}
.cart-empty{color:var(--text-soft); font-size:.9rem; padding:40px 0; text-align:center;}
.cart-foot{padding:26px; border-top:1px solid var(--line);}
.cart-total{display:flex; justify-content:space-between; font-family:var(--serif); font-size:1.3rem; margin-bottom:18px; color:#fff;}
.close-x{background:none; border:none; font-size:1.4rem; cursor:pointer; line-height:1; color:#fff;}
.cart-fab{position:fixed; bottom:28px; right:28px; z-index:150; background:var(--gold); color:#0A0A0A; border:none; border-radius:50px; padding:14px 22px; font-family:var(--sans); font-weight:700; font-size:.85rem; cursor:pointer; box-shadow:0 10px 30px -8px rgba(212,160,23,.6); transition:transform .25s;}
.cart-fab:hover{transform:scale(1.06);}
.toast{position:fixed; bottom:28px; left:50%; transform:translateX(-50%) translateY(20px); background:var(--surface); color:#fff; padding:13px 22px; border-radius:4px; font-size:.88rem; opacity:0; transition:all .3s var(--ease); z-index:300; pointer-events:none; border:1px solid var(--gold-dim);}
.toast.show{opacity:1; transform:translateX(-50%) translateY(0);}
/* ---------- sub-page additions ---------- */
.breadcrumb{font-family:var(--sans); font-size:.78rem; color:var(--text-dim); margin-bottom:26px; display:flex; align-items:center; gap:8px;}
.breadcrumb a{color:var(--text-soft); text-decoration:none;}
.breadcrumb a:hover{color:var(--gold);}
.subpage-hero{padding:170px 0 70px; background:radial-gradient(ellipse 70% 50% at 20% 0%, rgba(212,160,23,.14), transparent 60%), var(--black);}
.subpage-hero h1{font-size:clamp(2rem,4.4vw,3.2rem); max-width:780px;}
.subpage-hero .lead{color:var(--text-soft); font-size:1.08rem; max-width:60ch; margin-top:18px;}
.detail-grid{display:grid; grid-template-columns:1.3fr .7fr; gap:60px;}
@media (max-width:900px){ .detail-grid{grid-template-columns:1fr;} }
.detail-list{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:16px;}
.detail-list li{display:flex; gap:14px; align-items:flex-start; color:var(--text-soft); font-size:.98rem;}
.detail-list li .check{width:20px; height:20px; border-radius:50%; border:1px solid var(--gold-dim); flex-shrink:0; display:flex; align-items:center; justify-content:center; margin-top:2px;}
.detail-list li .check svg{width:11px; height:11px; stroke:var(--gold);}
.sidebar-card{background:var(--surface); border:1px solid var(--line); border-radius:8px; padding:30px; position:sticky; top:120px;}
.sidebar-card .price{font-size:2rem; margin-bottom:6px; display:block;}
.sidebar-card .meta-row{display:flex; justify-content:space-between; padding:10px 0; border-bottom:1px solid var(--line); font-size:.86rem; color:var(--text-soft);}
.sidebar-card .meta-row span:last-child{color:#fff; font-weight:500;}
.related-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px;}
@media (max-width:900px){ .related-grid{grid-template-columns:repeat(2,1fr);} }
@media (max-width:600px){ .related-grid{grid-template-columns:1fr;} }
.related-card{background:var(--surface); border:1px solid var(--line); border-radius:6px; padding:22px; transition:transform .3s var(--ease), border-color .3s var(--ease); text-decoration:none; display:block;}
.related-card:hover{transform:translateY(-4px); border-color:var(--gold-dim);}
.related-card .num{font-family:var(--sans); font-size:.68rem; color:var(--gold); letter-spacing:.1em; text-transform:uppercase;}
.related-card h4{font-size:1rem; margin:8px 0 6px; color:#fff;}
.related-card p{font-size:.85rem; color:var(--text-soft); margin:0;}

/* bento cards now render as <a> tags on the homepage */
a.bento-card{text-decoration:none; color:inherit; cursor:pointer;}

/* ---------- branded product cover placeholders ---------- */
.product-media{ overflow:hidden; }
.brand-emblem{
  position:absolute; opacity:.13;
  background-image:url(favicon.webp);
  background-repeat:no-repeat; background-size:contain;
  pointer-events:none;
}
.product-media .brand-emblem{
  width:150px; height:150px; bottom:-34px; right:-26px; transform:rotate(-10deg);
}
.product-media .stamp{
  position:absolute; bottom:11px; left:0; right:0; text-align:center;
  font-family:var(--sans); font-size:.58rem; letter-spacing:.16em; text-transform:uppercase;
  color:rgba(224,184,76,.5); pointer-events:none;
}
.product-media .frame{position:absolute; inset:8px; border:1px solid rgba(224,184,76,.18); pointer-events:none;}
.cover-hero{
  height:230px; border-radius:6px; border:1px solid var(--line); margin-bottom:34px; position:relative; overflow:hidden;
  background:linear-gradient(150deg,var(--surface-2),var(--ink));
}
.cover-hero .brand-emblem{width:260px; height:260px; bottom:-70px; right:-50px; opacity:.16; transform:rotate(-10deg);}
.cover-hero .fmt{position:absolute; top:18px; left:20px; font-family:var(--sans); font-size:.72rem; text-transform:uppercase; color:var(--gold); letter-spacing:.1em; font-weight:600;}
.cover-hero .cover-icon{position:absolute; top:50%; left:38px; transform:translateY(-50%); width:56px; height:56px; stroke:var(--gold-light); fill:none;}
.cover-hero .stamp{position:absolute; bottom:16px; left:0; right:0; text-align:center; font-family:var(--sans); font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(224,184,76,.5);}
.cover-hero .frame{position:absolute; inset:8px; border:1px solid rgba(224,184,76,.18); pointer-events:none;}
