/* ============================================================
   ISTORIA WINE — design system v3 "Pearl & Jewel"
   Light pearl editorial base · pastel washes that match the
   product photography · deep jewel-dark bands for the macro
   shots · gold foil thread throughout · Georgian arch motif
   ============================================================ */
:root{
  /* light base */
  --bg:#faf6ef;
  --bg-2:#ffffff;
  --cream:#f4ecdf;
  --ink:#231630;
  --ink-2:#3d2f4d;
  --muted:#7a6d88;
  --faint:#a99cb5;
  /* pastel washes pulled from the photos */
  --lavender:#ece4f6;
  --blush:#f9e7ec;
  --sky:#e7eef8;
  --mint:#e7f3ee;
  /* gold thread */
  --gold:#b07d30;
  --gold-2:#d8ab5e;
  --gold-3:#f5dfa8;
  /* jewel accents */
  --rose:#d4537f;
  --violet:#7e5bd6;
  --azure:#3f8fd2;
  --emerald:#2f9d6e;
  /* dark band */
  --dark:#150b20;
  --dark-2:#221334;
  --dark-ink:#f6f1e7;
  --dark-muted:#a395b3;
  --line:rgba(35,22,48,.12);
  --line-gold:rgba(176,125,48,.4);
  --dark-line:rgba(246,241,231,.14);
  --maxw:1280px;
  --arch:50% 50% 0 0 / 24% 24% 0 0;
  --display:"Fraunces","Noto Serif Georgian",Georgia,serif;
  --serif:"Fraunces","Noto Serif Georgian",Georgia,serif;
  --sans:"Manrope","Noto Sans Georgian",system-ui,sans-serif;
  --ease:cubic-bezier(.22,.8,.18,1);
}
html[data-lang="ka"]{
  --display:"Noto Serif Georgian","Fraunces",serif;
  --serif:"Noto Serif Georgian","Fraunces",serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--ink);font-family:var(--sans);
  font-weight:400;line-height:1.65;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold-2);color:#211505}
button{font-family:var(--sans)}

/* film grain — kept subtle on light */
.grain{position:fixed;inset:-50%;z-index:96;pointer-events:none;opacity:.4;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0.5 0 0 0 0 0.45 0 0 0 0 0.55 0 0 0 0.04 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 7s steps(8) infinite}
@keyframes grain{0%,100%{transform:translate(0,0)}20%{transform:translate(-3%,2%)}40%{transform:translate(2%,-3%)}60%{transform:translate(-2%,-2%)}80%{transform:translate(3%,2%)}}
/* soft pastel orbs */
.orbs{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.orbs i{position:absolute;border-radius:50%;filter:blur(120px);opacity:.35;animation:orb 26s var(--ease) infinite alternate}
.orbs i:nth-child(1){width:46vw;height:46vw;left:-14vw;top:-12vw;background:var(--lavender)}
.orbs i:nth-child(2){width:38vw;height:38vw;right:-12vw;top:24vh;background:var(--blush);animation-delay:-8s;animation-duration:32s}
.orbs i:nth-child(3){width:30vw;height:30vw;left:30vw;bottom:-16vw;background:var(--gold-3);opacity:.3;animation-delay:-16s}
@keyframes orb{to{transform:translate(7vw,5vh) scale(1.15)}}
main,section,header,footer{position:relative;z-index:1}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,44px)}
.serif{font-family:var(--serif)}
.center{text-align:center}
.pad{padding:clamp(80px,11vw,150px) 0}
.pad-s{padding:clamp(50px,7vw,90px) 0}

/* pastel section washes */
.wash-lav{background:linear-gradient(180deg,var(--bg),var(--lavender) 18%,var(--lavender) 82%,var(--bg))}
.wash-blush{background:linear-gradient(180deg,var(--bg),var(--blush) 18%,var(--blush) 82%,var(--bg))}
.wash-sky{background:linear-gradient(180deg,var(--bg),var(--sky) 18%,var(--sky) 82%,var(--bg))}
.wash-cream{background:linear-gradient(180deg,var(--bg),var(--cream) 18%,var(--cream) 82%,var(--bg))}

/* dark jewel band */
.dark{background:linear-gradient(170deg,var(--dark),var(--dark-2) 60%,var(--dark));color:var(--dark-ink)}
.dark .eyebrow{color:var(--gold-2)}
.dark .eyebrow::before{background:linear-gradient(90deg,transparent,var(--gold-2))}
.dark p{color:var(--dark-muted)}
.dark .head h2{color:var(--dark-ink)}
.dark .btn-ghost{border-color:var(--dark-line);color:var(--dark-ink);background:rgba(246,241,231,.04)}
.dark .btn-ghost:hover{border-color:var(--gold-2);color:var(--gold-3)}

/* gold foil + iridescent text */
.foil{background:linear-gradient(105deg,#8a6a33 0%,#d8ab5e 22%,#fbeec5 38%,#d8ab5e 52%,#8a6a33 70%,#d8ab5e 88%);
  background-size:220% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:foil 7s linear infinite}
@keyframes foil{to{background-position:220% 0}}
.iri{background:linear-gradient(100deg,var(--rose),var(--violet),var(--azure),var(--gold-2),var(--rose));
  background-size:300% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:iri 9s linear infinite}
@keyframes iri{to{background-position:300% 0}}

.eyebrow{font-size:11px;letter-spacing:.42em;text-transform:uppercase;color:var(--gold);font-weight:600;font-family:var(--sans);display:inline-flex;align-items:center;gap:14px}
.eyebrow::before{content:"";width:34px;height:1px;background:linear-gradient(90deg,transparent,var(--gold))}
.eyebrow.bare::before{display:none}

/* big editorial index numerals */
.idx{font-family:var(--display);font-size:clamp(72px,11vw,150px);line-height:.8;color:transparent;
  -webkit-text-stroke:1px rgba(176,125,48,.35);font-weight:600;font-style:italic;user-select:none}

/* ---------- buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:.7em;font-size:12px;letter-spacing:.22em;
  text-transform:uppercase;font-weight:700;padding:17px 34px;border-radius:100px;cursor:pointer;
  transition:.45s var(--ease);border:1px solid transparent;overflow:hidden;isolation:isolate}
.btn::after{content:"";position:absolute;inset:0;z-index:-1;transform:translateX(-110%) skewX(-18deg);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);transition:.7s var(--ease)}
.btn:hover::after{transform:translateX(110%) skewX(-18deg)}
.btn-gold{background:linear-gradient(115deg,#8a6a33,var(--gold-2) 40%,var(--gold-3));color:#211505;
  box-shadow:0 10px 34px -14px rgba(176,125,48,.55),inset 0 1px 0 rgba(255,255,255,.45)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 20px 48px -16px rgba(176,125,48,.65)}
.btn-ghost{border-color:var(--line);color:var(--ink);background:rgba(255,255,255,.5);backdrop-filter:blur(6px)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-ink{background:var(--ink);color:var(--bg)}
.btn-ink:hover{transform:translateY(-2px);box-shadow:0 18px 40px -18px rgba(35,22,48,.6)}
.btn-block{width:100%;justify-content:center}

/* lang visibility */
[data-en]{display:none}
html[data-lang="en"] [data-en]{display:revert}
html[data-lang="en"] [data-ka]{display:none}
.hide{display:none!important}

/* ---------- header ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:90;transition:.5s var(--ease)}
header::before{content:"";position:absolute;inset:0;opacity:0;transition:.5s;
  background:rgba(250,246,239,.88);backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line)}
header.scrolled::before,header.solid::before{opacity:1}
.nav{position:relative;display:flex;align-items:center;justify-content:space-between;height:88px}
.brand{display:flex;align-items:center;gap:10px}
.brand img{height:50px;width:auto;mix-blend-mode:multiply}
.brand-text{font-family:"Fraunces",var(--serif);font-size:21px;letter-spacing:.26em;font-weight:600;text-transform:uppercase;white-space:nowrap}
.brand-text b{color:var(--gold);font-weight:600}
.menu{display:flex;gap:38px;list-style:none;font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:600}
.menu a{position:relative;padding:6px 0;transition:.3s}
.menu a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:right;transition:.45s var(--ease)}
.menu a:hover{color:var(--ink)}
.menu a:hover::after{transform:scaleX(1);transform-origin:left}
.nav-right{display:flex;align-items:center;gap:24px}
.lang{display:flex;gap:2px;font-size:11.5px;letter-spacing:.12em;font-weight:700}
.lang button{background:none;border:none;color:var(--faint);cursor:pointer;padding:4px 7px;font:inherit;transition:.3s}
.lang button.active{color:var(--gold)}
.cart{position:relative;cursor:pointer;color:var(--ink);transition:.3s}
.cart:hover{color:var(--gold)}
.cart span{position:absolute;top:-8px;right:-10px;background:var(--gold-2);color:#211505;font-size:9.5px;font-weight:700;width:17px;height:17px;border-radius:50%;display:grid;place-items:center}
.burger{display:none;background:none;border:none;color:var(--ink);cursor:pointer}
/* header sitting on a dark hero before scroll */
header.on-dark:not(.scrolled) .menu{color:rgba(246,241,231,.75)}
header.on-dark:not(.scrolled) .menu a:hover{color:#fff}
header.on-dark:not(.scrolled) .cart{color:var(--dark-ink)}
header.on-dark:not(.scrolled) .lang button{color:rgba(246,241,231,.5)}
header.on-dark:not(.scrolled) .lang button.active{color:var(--gold-2)}
header.on-dark:not(.scrolled) .brand{background:rgba(255,255,255,.14);backdrop-filter:blur(10px);border-radius:100px;padding:5px 14px 5px 8px}
header.on-dark:not(.scrolled) .brand img{mix-blend-mode:normal}
header.on-dark:not(.scrolled) .burger{color:var(--dark-ink)}
.logo-chip{display:inline-flex;align-items:center}

/* ---------- marquee ribbon ---------- */
.ribbon{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:20px 0;background:var(--bg-2)}
.ribbon .track{display:flex;gap:0;width:max-content;animation:marq 30s linear infinite}
.ribbon:hover .track{animation-play-state:paused}
.ribbon span{font-family:var(--display);font-size:clamp(17px,2vw,24px);font-style:italic;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;white-space:nowrap;padding:0 28px;color:var(--muted)}
.ribbon span.g{color:var(--gold)}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- page hero (inner pages, photographic) ---------- */
.phero{position:relative;min-height:58vh;display:flex;align-items:flex-end;overflow:hidden}
.phero .bg{position:absolute;inset:0;z-index:0}
.phero .bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);animation:slowzoom 14s var(--ease) forwards}
@keyframes slowzoom{to{transform:scale(1)}}
.phero .bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(0deg,var(--bg) 2%,rgba(250,246,239,.25) 36%,transparent 70%)}
.phero.phero-dark .bg::after{background:linear-gradient(0deg,rgba(21,11,32,.92) 4%,rgba(21,11,32,.35) 50%,rgba(21,11,32,.45))}
.phero.phero-dark{color:var(--dark-ink)}
.phero.phero-dark p{color:var(--dark-muted)}
.phero .inner{position:relative;z-index:2;padding-bottom:64px;padding-top:160px;max-width:820px}
.phero h1{font-family:var(--display);font-weight:500;font-size:clamp(44px,7vw,92px);line-height:1;margin:18px 0 18px;letter-spacing:-.01em}
.phero h1 em{font-style:italic}
.phero p{color:var(--muted);max-width:520px;font-size:16px}
.crumb{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--faint)}
.crumb a{transition:.3s}
.crumb a:hover{color:var(--gold)}

/* ---------- section heading ---------- */
.head{max-width:640px;margin-bottom:64px}
.head.center{margin-left:auto;margin-right:auto}
.head h2{font-family:var(--display);font-size:clamp(34px,4.8vw,62px);font-weight:500;line-height:1.04;margin:16px 0 18px;letter-spacing:-.01em}
.head h2 em{font-style:italic;color:var(--gold)}
.head p{color:var(--muted)}

/* ---------- product card ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,30px)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{position:relative;background:var(--bg-2);
  border:1px solid var(--line);border-radius:20px 20px 18px 18px;overflow:hidden;
  transition:.55s var(--ease);box-shadow:0 10px 36px -26px rgba(35,22,48,.3)}
.card::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;z-index:3;pointer-events:none;
  background:linear-gradient(160deg,rgba(216,171,94,.7),transparent 38%,transparent 70%,rgba(126,91,214,.4));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:.55s}
.card:hover{transform:translateY(-9px);box-shadow:0 44px 80px -42px rgba(35,22,48,.45),0 0 60px -30px rgba(216,171,94,.4)}
.card:hover::before{opacity:1}
.card .ph{position:relative;aspect-ratio:3/4;overflow:hidden;background:#f3eee6;display:block}
.card .ph::after{content:"";position:absolute;inset:0;z-index:2;transform:translateX(-130%) skewX(-14deg);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);transition:.9s var(--ease)}
.card:hover .ph::after{transform:translateX(130%) skewX(-14deg)}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:1.4s var(--ease)}
.card:hover .ph img{transform:scale(1.07)}
.card .tag{position:absolute;top:16px;left:16px;z-index:4;font-size:9.5px;letter-spacing:.24em;text-transform:uppercase;
  background:rgba(255,255,255,.82);backdrop-filter:blur(8px);border:1px solid var(--line-gold);padding:7px 13px;border-radius:100px;color:var(--gold);font-weight:700}
.card .body{padding:24px 24px 26px}
.card h3{font-family:var(--display);font-size:24px;font-weight:500}
.card .type{color:var(--faint);font-size:11px;letter-spacing:.2em;text-transform:uppercase;margin:6px 0 18px}
.card .foot{display:flex;align-items:center;justify-content:space-between}
.card .price{font-family:var(--display);font-size:22px;color:var(--gold);font-style:italic}
.card .add{font-size:11px;letter-spacing:.18em;text-transform:uppercase;border:1px solid var(--line);padding:10px 18px;
  border-radius:100px;cursor:pointer;transition:.4s;background:none;color:var(--ink);font-weight:700}
.card .add:hover{background:var(--gold-2);color:#211505;border-color:var(--gold-2);box-shadow:0 8px 24px -10px var(--gold-2)}
/* color swatch dot on product cards */
.card .dot{width:14px;height:14px;border-radius:50%;display:inline-block;box-shadow:inset 0 1px 3px rgba(0,0,0,.2),0 0 0 3px rgba(255,255,255,.7)}

/* arch image frame — brand signature */
.arch{border-radius:var(--arch);overflow:hidden}

/* ---------- footer ---------- */
footer{background:var(--cream);border-top:1px solid var(--line);padding:84px 0 36px;overflow:hidden}
footer .fmark{display:flex;justify-content:center;margin-bottom:64px}
footer .fmark img{height:78px;width:auto}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:44px;margin-bottom:56px}
footer h5{font-size:10.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;font-weight:700}
footer ul{list-style:none;display:flex;flex-direction:column;gap:12px;color:var(--muted);font-size:14px}
footer ul a{transition:.3s}
footer ul a:hover{color:var(--gold);padding-left:4px}
.fbrand img{height:40px;width:auto;margin-bottom:18px}
.fbrand p{color:var(--muted);font-size:14px;max-width:280px}
.fbottom{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding-top:28px;color:var(--faint);font-size:12px;letter-spacing:.06em;flex-wrap:wrap;gap:12px}
.drink{font-size:11px;color:var(--faint);max-width:560px;line-height:1.5}

/* ---------- age gate (dark jewel + glitter photo) ---------- */
#agegate{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;
  background:var(--dark);text-align:center;padding:28px;overflow:hidden}
#agegate .gbg{position:absolute;inset:0;pointer-events:none}
#agegate .gbg img{width:100%;height:100%;object-fit:cover;opacity:.55}
#agegate .gbg::after{content:"";position:absolute;inset:0;background:radial-gradient(80% 70% at 50% 45%,transparent 30%,rgba(21,11,32,.78))}
#agegate .box{position:relative;max-width:540px;padding:clamp(36px,5vw,60px) clamp(26px,4vw,52px);
  border:1px solid rgba(216,171,94,.5);border-radius:26px 26px 22px 22px;background:rgba(18,9,28,.66);backdrop-filter:blur(16px);color:var(--dark-ink)}
#agegate .box::before{content:"✦";position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--dark);padding:0 16px;color:var(--gold-2);font-size:16px}
#agegate .gate-logo{background:#fff;border-radius:14px;padding:10px 22px;display:inline-flex;margin-bottom:26px;box-shadow:0 14px 44px -14px rgba(0,0,0,.6)}
#agegate .gate-logo img{height:46px;width:auto}
#agegate h2{font-family:var(--display);font-size:clamp(28px,4vw,40px);font-weight:500;margin-bottom:14px}
#agegate p{color:var(--dark-muted);margin-bottom:30px;font-size:14.5px}
#agegate .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- cookie ---------- */
#cookie{position:fixed;left:18px;right:18px;bottom:18px;z-index:120;max-width:580px;margin:0 auto;
  background:rgba(255,255,255,.95);backdrop-filter:blur(18px);border:1px solid var(--line-gold);border-radius:18px;
  padding:20px 24px;display:flex;gap:18px;align-items:center;flex-wrap:wrap;box-shadow:0 34px 70px -24px rgba(35,22,48,.35)}
#cookie p{font-size:13px;color:var(--muted);flex:1;min-width:220px}
#cookie .btn{padding:12px 24px}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(42px);transition:1.1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.18s}.reveal.d3{transition-delay:.28s}.reveal.d4{transition-delay:.38s}

/* ---------- shop toolbar ---------- */
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:46px;padding-bottom:26px;border-bottom:1px solid var(--line)}
.filters{display:flex;gap:10px;flex-wrap:wrap}
.chip{font-size:11px;letter-spacing:.18em;text-transform:uppercase;border:1px solid var(--line);padding:10px 20px;border-radius:100px;cursor:pointer;color:var(--muted);background:rgba(255,255,255,.6);transition:.35s;font-weight:700}
.chip:hover,.chip.active{border-color:var(--gold);color:var(--gold);background:rgba(216,171,94,.1)}
.select{background:var(--bg-2);border:1px solid var(--line);color:var(--ink);padding:12px 20px;border-radius:100px;font:inherit;font-size:13px}

/* ---------- single product ---------- */
.pdp{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(36px,5vw,80px);align-items:start}
.gallery .main{border-radius:var(--arch);overflow:hidden;aspect-ratio:3/4.1;background:#f3eee6;margin-bottom:16px;border:1px solid var(--line)}
.gallery .main img{width:100%;height:100%;object-fit:cover}
.thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.thumbs img{border-radius:12px;aspect-ratio:1;object-fit:cover;cursor:pointer;opacity:.5;transition:.4s;border:1px solid var(--line)}
.thumbs img:hover,.thumbs img.active{opacity:1;border-color:var(--gold)}
.pdp .info h1{font-family:var(--display);font-size:clamp(38px,5vw,64px);font-weight:500;line-height:1;margin:10px 0 12px}
.pdp .price{font-family:var(--display);font-size:36px;color:var(--gold);margin:20px 0;font-style:italic}
.pdp .desc{color:var(--muted);margin-bottom:26px}
.pdp .opts{display:flex;gap:10px;margin:20px 0 28px;flex-wrap:wrap}
.qty{display:flex;align-items:center;border:1px solid var(--line);border-radius:100px;overflow:hidden;background:var(--bg-2)}
.qty button{background:none;border:none;color:var(--ink);width:46px;height:50px;font-size:18px;cursor:pointer;transition:.3s}
.qty button:hover{color:var(--gold)}
.qty input{width:44px;text-align:center;background:none;border:none;color:var(--ink);font:inherit}
.buyrow{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:32px}
.meta{border-top:1px solid var(--line);padding-top:24px;display:flex;flex-direction:column;gap:15px}
.meta .r{display:flex;justify-content:space-between;font-size:14px}
.meta .r span:first-child{color:var(--faint);letter-spacing:.18em;text-transform:uppercase;font-size:11px}

/* ---------- cart / checkout ---------- */
.cartgrid{display:grid;grid-template-columns:1.6fr 1fr;gap:48px;align-items:start}
.line{display:grid;grid-template-columns:90px 1fr auto;gap:20px;align-items:center;padding:24px 0;border-bottom:1px solid var(--line)}
.line img{width:90px;height:120px;object-fit:cover;border-radius:12px 12px 10px 10px;border:1px solid var(--line)}
.line h4{font-family:var(--display);font-size:22px;font-weight:500}
.line .t{color:var(--faint);font-size:11px;text-transform:uppercase;letter-spacing:.18em}
.line .lp{color:var(--gold);font-family:var(--display);font-size:22px;font-style:italic}
.summary{background:var(--bg-2);border:1px solid var(--line-gold);border-radius:22px;padding:32px;position:sticky;top:110px;box-shadow:0 24px 60px -40px rgba(35,22,48,.35)}
.summary h3{font-family:var(--display);font-size:26px;margin-bottom:24px;font-weight:500}
.summary .r{display:flex;justify-content:space-between;margin-bottom:14px;color:var(--muted);font-size:15px}
.summary .total{display:flex;justify-content:space-between;border-top:1px solid var(--line);padding-top:20px;margin-top:10px;font-family:var(--display);font-size:24px}
.summary .total b{color:var(--gold);font-weight:600;font-style:italic}
.field{margin-bottom:16px}
.field label{display:block;font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--faint);margin-bottom:8px;font-weight:700}
.field input,.field select,.field textarea{width:100%;background:var(--bg-2);border:1px solid var(--line);border-radius:13px;padding:15px 17px;color:var(--ink);font:inherit;font-size:14px;transition:.3s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);background:#fffdf8}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.payopt{display:flex;align-items:center;gap:14px;border:1px solid var(--line);border-radius:14px;padding:18px;margin-bottom:12px;cursor:pointer;transition:.35s;background:var(--bg-2)}
.payopt:hover{border-color:var(--line-gold)}
.payopt.active{border-color:var(--gold);background:rgba(216,171,94,.08)}

/* ---------- contact ---------- */
.contactgrid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,80px);align-items:start}
.cinfo .r{display:flex;gap:16px;align-items:flex-start;margin-bottom:28px}
.cinfo .ic{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--line-gold);color:var(--gold);flex:none;background:var(--bg-2)}
.cinfo h4{font-family:var(--display);font-size:20px;margin-bottom:3px;font-weight:500}
.cinfo p{color:var(--muted);font-size:14px}
.map{border-radius:var(--arch);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/11;background:var(--cream);display:grid;place-items:center;color:var(--faint);font-size:11px;letter-spacing:.3em;text-transform:uppercase}

/* ---------- mystery (the one dark page) ---------- */
.myst-wrap{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;padding:130px 0 80px;background:var(--dark);color:var(--dark-ink)}
.myst-wrap .bg{position:absolute;inset:0;z-index:0}
.myst-wrap .bg img{width:100%;height:100%;object-fit:cover;opacity:.45}
.myst-wrap .bg::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 40%,transparent,var(--dark) 80%)}
.myst-card{position:relative;z-index:2;max-width:660px;margin:0 auto;text-align:center;
  background:rgba(18,9,28,.66);backdrop-filter:blur(20px);border:1px solid rgba(216,171,94,.5);
  border-radius:30px 30px 24px 24px;padding:clamp(36px,5vw,64px)}
.myst-card::before{content:"✦";position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--dark);padding:0 16px;color:var(--gold-2);font-size:16px}
.myst-card p{color:var(--dark-muted)}
.qr{width:92px;height:92px;border-radius:18px;background:conic-gradient(from 0deg,var(--rose),var(--violet),var(--azure),var(--gold-3),var(--rose));
  display:grid;place-items:center;margin:0 auto 28px;animation:qrspin 12s linear infinite}
@keyframes qrspin{to{filter:hue-rotate(360deg)}}
.qr div{width:76px;height:76px;border-radius:12px;background:var(--dark);display:grid;place-items:center;font-size:32px}
.toast-out{margin-top:32px;border-top:1px solid var(--dark-line);padding-top:32px;text-align:left;display:none}
.toast-out.show{display:block;animation:fade 1s var(--ease)}
@keyframes fade{from{opacity:0;transform:translateY(14px)}to{opacity:1}}
.toast-out h3{font-family:var(--display);font-size:26px;color:var(--gold-3);margin-bottom:12px;font-weight:500}
.toast-out p{color:var(--dark-ink);font-family:var(--display);font-size:22px;font-style:italic;line-height:1.5;margin-bottom:20px}
.pair{display:flex;flex-direction:column;gap:10px;color:var(--dark-muted);font-size:15px}
.pair .p{display:flex;gap:10px;align-items:center}
.pair .p::before{content:"✦";color:var(--gold-2);font-size:10px}
.spinner{width:28px;height:28px;border:2px solid var(--dark-line);border-top-color:var(--gold-2);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .pdp,.cartgrid,.contactgrid{grid-template-columns:1fr}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .summary{position:static}
}
@media(max-width:900px){
  .menu{display:none}.burger{display:block}
  .grid{grid-template-columns:repeat(2,1fr)}
  .fgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .grid,.grid-4{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr}
  .row2{grid-template-columns:1fr}
  .brand img{height:36px}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

/* ---------- mobile menu open state ---------- */
/* Triggered by JS: document.getElementById('hdr').classList.toggle('menu-open') */
@media(max-width:900px){
  header.menu-open::before{opacity:1}
  header.menu-open .menu{
    display:flex;flex-direction:column;gap:0;
    position:absolute;top:88px;left:0;right:0;z-index:98;
    background:rgba(250,246,239,.97);backdrop-filter:blur(22px);
    border-bottom:1px solid var(--line);
    padding:8px 0 24px;
    box-shadow:0 30px 60px -20px rgba(35,22,48,.18)
  }
  header.menu-open .menu a{
    padding:15px clamp(20px,4vw,44px);
    font-size:13px;color:var(--ink);letter-spacing:.18em
  }
  header.menu-open .menu a:hover{color:var(--gold);padding-left:calc(clamp(20px,4vw,44px) + 6px)}
  header.menu-open .menu a::after{display:none}
  /* on-dark pages: keep contrast even when menu is open */
  header.on-dark.menu-open .menu{background:rgba(21,11,32,.97)}
  header.on-dark.menu-open .menu a{color:var(--dark-ink)}
  header.on-dark.menu-open .menu a:hover{color:var(--gold-2)}
  /* Animate burger → X */
  header.menu-open .burger svg path:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
  header.menu-open .burger svg path:nth-child(2){opacity:0}
  header.menu-open .burger svg path:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
  header .burger svg path{transform-origin:center;transition:.3s var(--ease)}
}

/* ---------- legal / generic page ---------- */
.page-content{max-width:780px;margin:0 auto;padding:150px clamp(20px,4vw,44px) 100px}
.page-content h1{font-family:var(--display);font-size:clamp(36px,5vw,62px);font-weight:500;margin-bottom:32px;line-height:1.04}
.page-content h2{font-family:var(--display);font-size:clamp(22px,3vw,32px);font-weight:500;margin:40px 0 14px}
.page-content h3{font-family:var(--display);font-size:20px;font-weight:500;margin:28px 0 10px}
.page-content p{color:var(--muted);margin-bottom:16px;max-width:68ch}
.page-content ul,.page-content ol{color:var(--muted);padding-left:22px;margin-bottom:16px}
.page-content li{margin-bottom:8px}
.page-content a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
.page-content hr{border:none;border-top:1px solid var(--line);margin:40px 0}
.page-content .updated{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--faint);margin-bottom:40px}
