/* ============================================================
   BOSNIAN BEAST GIN — shared design system
   Dark, atmospheric, premium craft-spirits identity.
   ============================================================ */

/* ---- Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Bodoni+Moda:ital,opsz,wght@0,6..96,400;0,6..96,500;0,6..96,600;0,6..96,700;0,6..96,800;0,6..96,900;1,6..96,400;1,6..96,500&family=Playfair+Display:ital,wght@0,500;0,700;0,900;1,500&family=DM+Serif+Display:ital@0;1&family=Hanken+Grotesk:wght@300;400;500;600;700&family=Jost:wght@300;400;500;600&family=Mulish:wght@300;400;500;600;700&family=Space+Mono:wght@400;700&display=swap');

/* ---- Tokens (overridable by Tweaks) ---- */
:root{
  /* surfaces — Midnight Emerald default */
  --bg:#06120d;
  --bg-1:#0a1c14;
  --bg-2:#0f261c;
  --bg-3:#143024;

  --ink:#f2ece0;
  --muted:#9eb1a6;
  --faint:#6f8579;

  --metal:#c9a45f;        /* brass / gold accent */
  --metal-bright:#e6cd92;
  --accent:#a8322a;       /* contrast: blood red */
  --accent-bright:#c8473a;

  --line:rgba(201,164,95,.20);
  --line-soft:rgba(242,236,224,.08);

  --font-display:'Bodoni Moda', Georgia, serif;
  --font-body:'Hanken Grotesk', system-ui, sans-serif;
  --font-mono:'Space Mono', ui-monospace, monospace;

  --maxw:1280px;
  --gut:clamp(20px,5vw,72px);
  --r:3px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-weight:400;
  line-height:1.65;
  font-size:17px;
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--accent);color:#fff;}

/* page-wide atmospheric vignette + grain */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(201,164,95,.06), transparent 55%),
    radial-gradient(120% 90% at 50% 120%, rgba(10,28,20,.9), transparent 60%);
}
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
main,header,footer{position:relative;z-index:2;}

/* ---- Layout ---- */
.container{max-width:var(--maxw);margin:0 auto;padding-left:var(--gut);padding-right:var(--gut);}
.section{padding:clamp(72px,10vw,150px) 0;position:relative;}
.section--tight{padding:clamp(48px,6vw,90px) 0;}

/* ---- Typography ---- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.02;margin:0;letter-spacing:-.01em;}
.display{
  font-family:var(--font-display);
  font-weight:800;
  font-size:clamp(56px,11vw,150px);
  line-height:.9;
  letter-spacing:-.02em;
}
.h-xl{font-size:clamp(40px,6vw,84px);line-height:.98;}
.h-lg{font-size:clamp(32px,4.4vw,60px);}
.h-md{font-size:clamp(26px,3vw,40px);}
.lead{font-size:clamp(18px,2vw,23px);color:var(--muted);line-height:1.65;font-weight:300;}
p{margin:0 0 1.1em;}
.muted{color:var(--muted);}
em,.italic{font-style:italic;}

.eyebrow{
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--metal);
  display:inline-flex;align-items:center;gap:.8em;
  margin:0 0 1.4em;
}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--metal);opacity:.7;}
.eyebrow--center{justify-content:center;}
.eyebrow--center::after{content:"";width:30px;height:1px;background:var(--metal);opacity:.7;}

.gold{color:var(--metal);}
.accent{color:var(--accent-bright);}

/* gold hairline divider */
.rule{height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent);border:0;margin:0;}

/* ---- Buttons ---- */
.btn{
  --bw:1px;
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--font-mono);
  font-size:12.5px;letter-spacing:.22em;text-transform:uppercase;
  padding:17px 30px;border-radius:var(--r);
  cursor:pointer;border:var(--bw) solid transparent;
  transition:transform .35s cubic-bezier(.2,.7,.2,1), background .35s, color .35s, box-shadow .35s, border-color .35s;
  position:relative;white-space:nowrap;
}
.btn .arr{transition:transform .35s cubic-bezier(.2,.7,.2,1);}
.btn:hover .arr{transform:translateX(5px);}
.btn-primary{
  background:linear-gradient(180deg,var(--metal-bright),var(--metal));
  color:#1a1206;font-weight:700;
  box-shadow:0 10px 30px -12px rgba(201,164,95,.6);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px -14px rgba(201,164,95,.75);}
.btn-ghost{border-color:var(--line);color:var(--ink);}
.btn-ghost:hover{border-color:var(--metal);color:var(--metal-bright);transform:translateY(-2px);}
.btn-accent{background:var(--accent);color:#fff;font-weight:600;}
.btn-accent:hover{background:var(--accent-bright);transform:translateY(-2px);box-shadow:0 16px 36px -16px var(--accent);}

/* ---- Crest emblem (simple geometry — wolf placeholder stand-in motif) ---- */
.crest{display:inline-block;line-height:0;}
.crest svg{display:block;}
.crest .ring{fill:none;stroke:var(--metal);}
.crest .dia{fill:none;stroke:var(--metal);}
.crest .glyph{fill:var(--metal);}
.crest--accent .ring,.crest--accent .dia{stroke:var(--accent-bright);}
.crest--accent .glyph{fill:var(--accent-bright);}

/* watermark behind sections — wolf-badge silhouette, brass-tinted */
.watermark{
  position:absolute;pointer-events:none;z-index:0;
  opacity:.16;aspect-ratio:343/192;
  background-color:var(--metal);
  -webkit-mask:url('wolf-badge.png') no-repeat center / contain;
  mask:url('wolf-badge.png') no-repeat center / contain;
}
.watermark svg{display:none;}

/* wolf-badge used as the brand logo (nav + footer), brass-tinted */
.wolf-mark{
  display:inline-block;background-color:var(--metal);
  -webkit-mask:url('wolf-badge.png') no-repeat center / contain;
  mask:url('wolf-badge.png') no-repeat center / contain;
}

/* ---- Image placeholders (replace with real photography) ---- */
.ph{
  position:relative;overflow:hidden;border-radius:var(--r);
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.018) 0 2px, transparent 2px 11px),
    linear-gradient(160deg,var(--bg-2),var(--bg-1));
  border:1px solid var(--line-soft);
  display:flex;align-items:center;justify-content:center;
  min-height:240px;
}
.ph::after{
  content:attr(data-label);
  font-family:var(--font-mono);font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--faint);padding:8px 14px;border:1px solid var(--line-soft);border-radius:99px;
  background:rgba(6,18,13,.4);text-align:center;
}
.ph--gold{border-color:var(--line);}
.ph--tall{min-height:520px;}
.ph--bottle{aspect-ratio:3/4.4;min-height:0;}

/* ---- Photo media frame (real photography filling a tall slot) ---- */
.media-photo{
  position:relative;margin:0;overflow:hidden;border-radius:var(--r);
  border:1px solid var(--line-soft);box-shadow:0 30px 60px -30px rgba(0,0,0,.7);
  min-height:clamp(360px,52vh,520px);
}
.media-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.2s cubic-bezier(.2,.7,.2,1);}
.media-photo:hover img{transform:scale(1.05);}

/* ---- Real bottle treatment (transparent PNG on dark) ---- */
.bottle-stage{position:relative;display:flex;justify-content:center;align-items:flex-end;}
.bottle-stage::before{ /* aura */
  content:"";position:absolute;left:50%;top:45%;transform:translate(-50%,-50%);
  width:82%;height:88%;border-radius:50%;z-index:0;filter:blur(14px);
  background:radial-gradient(ellipse at center,
    color-mix(in srgb,var(--metal) 24%,transparent),
    color-mix(in srgb,var(--metal) 7%,transparent) 45%, transparent 70%);
}
.bottle-stage::after{ /* ground shadow */
  content:"";position:absolute;left:50%;bottom:1%;transform:translateX(-50%);
  width:60%;height:30px;border-radius:50%;z-index:0;
  background:radial-gradient(ellipse,rgba(0,0,0,.6),transparent 72%);
}
.bottle-img{
  position:relative;z-index:2;display:block;width:100%;height:auto;
  filter:drop-shadow(0 34px 46px rgba(0,0,0,.55));
}
.bottle-w-hero{width:min(330px,76%);margin:0 auto;}
.bottle-w-mid{width:min(300px,72%);margin:0 auto;}

/* ---- Wolf treatment (transparent PNG, moonlit aura) ---- */
.wolf-stage{position:relative;display:flex;justify-content:center;align-items:flex-end;min-height:460px;}
.wolf-stage::before{ /* cool moonlit aura */
  content:"";position:absolute;left:50%;top:40%;transform:translate(-50%,-50%);
  width:96%;height:92%;border-radius:50%;z-index:0;filter:blur(22px);
  background:radial-gradient(ellipse at center,
    color-mix(in srgb,var(--metal) 15%,transparent),
    color-mix(in srgb,var(--bg-3) 55%,transparent) 48%, transparent 68%);
}
.wolf-stage::after{ /* ground shadow */
  content:"";position:absolute;left:50%;bottom:2%;transform:translateX(-50%);
  width:66%;height:30px;border-radius:50%;z-index:0;
  background:radial-gradient(ellipse,rgba(0,0,0,.5),transparent 72%);
}
.wolf-img{
  position:relative;z-index:2;display:block;width:auto;max-width:100%;max-height:600px;
  filter:drop-shadow(0 28px 40px rgba(0,0,0,.5));
}

/* ---- Cards ---- */
.card{
  background:linear-gradient(180deg,var(--bg-2),var(--bg-1));
  border:1px solid var(--line-soft);
  border-radius:var(--r);
  padding:34px;
  transition:transform .5s cubic-bezier(.2,.7,.2,1), border-color .5s, box-shadow .5s;
  position:relative;overflow:hidden;
}
.card:hover{transform:translateY(-6px);border-color:var(--line);box-shadow:0 30px 60px -30px rgba(0,0,0,.7);}
.card .idx{font-family:var(--font-mono);font-size:12px;color:var(--metal);letter-spacing:.2em;}

/* ---- Reveal on scroll ---- */
[data-reveal]{opacity:0;transform:translateY(30px);transition:opacity 1s cubic-bezier(.2,.7,.2,1), transform 1.05s cubic-bezier(.2,.7,.2,1);will-change:transform,opacity;}
/* directional slide variants */
[data-reveal="left"]{transform:translateX(-70px);}
[data-reveal="right"]{transform:translateX(70px);}
[data-reveal="up"]{transform:translateY(64px);}
[data-reveal="zoom"]{transform:scale(.9);}
[data-reveal].in{opacity:1;transform:none;}
[data-reveal][data-delay="1"]{transition-delay:.09s;}
[data-reveal][data-delay="2"]{transition-delay:.18s;}
[data-reveal][data-delay="3"]{transition-delay:.27s;}
[data-reveal][data-delay="4"]{transition-delay:.36s;}

/* ---- Idle bob on bottles (independent of scroll parallax on the stage) ---- */
@keyframes bb-bob{0%,100%{transform:translateY(0);}50%{transform:translateY(-9px);}}
.bottle-img{animation:bb-bob 5.5s ease-in-out infinite;}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none;transition:none;}
  .bottle-img{animation:none;}
  .preloader .drop,.preloader .pool{animation:none;}
  html{scroll-behavior:auto;}
}
/* When the document is hidden/inactive, transitions freeze at their start value.
   In that case skip the animation entirely so revealed content shows instantly. */
html.bb-static [data-reveal]{transition:none !important;}
html.bb-static [data-reveal].in{opacity:1;transform:none;}

/* ============================================================
   PRELOADER — dripping gin drops
   ============================================================ */
.preloader{
  position:fixed;inset:0;z-index:99999;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:34px;
  background:radial-gradient(120% 90% at 50% 38%, var(--bg-1), var(--bg) 70%);
  transition:opacity .6s ease, visibility .6s ease;
}
.preloader.hide{opacity:0;visibility:hidden;}
.preloader .drip{position:relative;width:60px;height:172px;}
.preloader .spout{
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:38px;height:9px;border-radius:0 0 7px 7px;
  background:linear-gradient(180deg,var(--metal-bright),var(--metal));
  box-shadow:0 0 16px rgba(201,164,95,.45);
}
.preloader .drop{
  position:absolute;top:9px;left:50%;width:14px;height:14px;margin-left:-7px;
  animation:bb-drip 1.8s cubic-bezier(.5,.05,.85,.4) infinite;
}
.preloader .drop::before{
  content:"";display:block;width:100%;height:100%;
  background:linear-gradient(160deg,#eafaf5,#c6e9e0 42%,var(--metal-bright));
  border-radius:0 50% 50% 50%;transform:rotate(45deg);
  box-shadow:0 2px 6px rgba(0,0,0,.45), inset 1px -1px 3px rgba(255,255,255,.6);
}
.preloader .drop:nth-of-type(2){animation-delay:.6s;}
.preloader .drop:nth-of-type(3){animation-delay:1.2s;}
.preloader .pool{
  position:absolute;bottom:2px;left:50%;width:30px;height:7px;transform:translateX(-50%);
  border-radius:50%;background:radial-gradient(ellipse,var(--metal-bright),transparent 72%);
  animation:bb-pool 1.8s ease-out infinite;
}
.preloader-brand{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(22px,4.4vw,34px);letter-spacing:.06em;color:var(--ink);
  opacity:0;animation:bb-fadein .9s ease .2s forwards;
}
@keyframes bb-drip{
  0%{transform:translateY(0) scale(.5);opacity:0;}
  14%{transform:translateY(0) scale(1);opacity:1;}
  72%{transform:translateY(120px) scale(1);opacity:1;}
  90%{transform:translateY(150px) scale(.7);opacity:1;}
  100%{transform:translateY(152px) scale(.25);opacity:0;}
}
@keyframes bb-pool{
  0%,58%{transform:translateX(-50%) scale(.5);opacity:.15;}
  78%{transform:translateX(-50%) scale(1.35);opacity:.55;}
  100%{transform:translateX(-50%) scale(1.9);opacity:0;}
}
@keyframes bb-fadein{to{opacity:.9;}}

/* ============================================================
   NAV
   ============================================================ */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px var(--gut);
  transition:background .4s, padding .4s, border-color .4s, backdrop-filter .4s;
  border-bottom:1px solid transparent;
}
.site-nav.scrolled{
  background:rgba(6,18,13,.82);
  backdrop-filter:blur(14px) saturate(1.1);
  border-bottom-color:var(--line-soft);
  padding-top:15px;padding-bottom:15px;
}
.brand{display:flex;align-items:center;gap:13px;}
.brand .mark{width:64px;height:40px;}
.brand .name{
  font-family:var(--font-display);font-weight:700;font-size:24px;letter-spacing:.02em;
  line-height:1;white-space:nowrap;
}
.brand .name small{display:block;font-family:var(--font-mono);font-size:8.5px;letter-spacing:.42em;color:var(--metal);margin-top:4px;font-weight:400;}
.nav-links{display:flex;align-items:center;gap:26px;}
.nav-links a{
  font-family:var(--font-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);
  position:relative;padding:6px 0;transition:color .3s;white-space:nowrap;
}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--metal);transition:width .35s cubic-bezier(.2,.7,.2,1);}
.nav-links a:hover{color:var(--ink);}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.nav-links a.active{color:var(--metal);}
.nav-cta{margin-left:8px;padding:17px 56px;min-width:170px;justify-content:center;}

.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:40px;height:40px;flex-direction:column;justify-content:center;gap:6px;padding:0;}
.nav-toggle span{display:block;height:1.5px;width:26px;background:var(--ink);transition:transform .35s, opacity .3s;}
.nav-toggle.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0;}
.nav-toggle.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}

/* dedicated close button inside the mobile menu (hidden on desktop) */
.nav-close{display:none;}

@media (max-width:900px){
  .nav-toggle{display:flex;}
  .nav-links{
    position:fixed;inset:0;flex-direction:column;justify-content:center;gap:30px;
    background:rgba(6,18,13,.97);backdrop-filter:blur(8px);
    transform:translateY(-100%);visibility:hidden;
    transition:transform .5s cubic-bezier(.2,.7,.2,1), visibility .5s;
    z-index:49;
  }
  .nav-links.open{transform:none;visibility:visible;}
  .nav-links a{font-size:15px;letter-spacing:.2em;}
  .nav-cta{margin-left:0;}
  /* close (✕) pinned top-right of the open overlay */
  .nav-close{
    display:block;position:absolute;top:16px;right:var(--gut);z-index:2;
    background:none;border:0;cursor:pointer;color:var(--ink);
    font-family:var(--font-body);font-size:30px;line-height:1;padding:8px;
    transition:color .3s, transform .3s;
  }
  .nav-close:hover{color:var(--metal);transform:rotate(90deg);}
  /* hide the hamburger while the menu is open so the two marks don't overlap */
  .nav-links.open ~ .nav-toggle{opacity:0;pointer-events:none;}
}

/* ============================================================
   PAGE HERO BAND (interior pages)
   ============================================================ */
.pagehero{
  padding:clamp(140px,18vh,210px) 0 clamp(48px,7vw,90px);
  position:relative;overflow:hidden;
  border-bottom:1px solid var(--line-soft);
}
.pagehero .crumb{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--faint);margin-bottom:24px;}
.pagehero .crumb a:hover{color:var(--metal);}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  background:linear-gradient(180deg,var(--bg),#040c08);
  border-top:1px solid var(--line);
  padding:clamp(60px,8vw,100px) 0 40px;
  position:relative;overflow:hidden;
}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:48px;}
.footer-col h5{font-family:var(--font-mono);font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--metal);margin:0 0 18px;font-weight:400;}
.footer-col a{display:block;color:var(--muted);padding:5px 0;transition:color .3s,transform .3s;font-size:15px;}
.footer-col a:hover{color:var(--ink);transform:translateX(4px);}
.footer-brand .name{font-family:var(--font-display);font-size:30px;font-weight:700;line-height:1;margin:18px 0 14px;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;margin-top:60px;padding-top:28px;border-top:1px solid var(--line-soft);}
.footer-bottom p{margin:0;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;color:var(--faint);}
.age-note{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-bright);border:1px solid color-mix(in srgb,var(--accent) 50%,transparent);padding:8px 16px;border-radius:99px;}
@media (max-width:780px){.footer-grid{grid-template-columns:1fr 1fr;gap:34px;}}
@media (max-width:480px){.footer-grid{grid-template-columns:1fr;}}

/* ---- Utility grids ---- */
.grid{display:grid;gap:clamp(20px,2.5vw,34px);}
.g-2{grid-template-columns:repeat(2,1fr);}
.g-3{grid-template-columns:repeat(3,1fr);}
.g-4{grid-template-columns:repeat(4,1fr);}
@media (max-width:900px){.g-3,.g-4{grid-template-columns:repeat(2,1fr);}}
@media (max-width:620px){.g-2,.g-3,.g-4{grid-template-columns:1fr;}}

.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center;}
.split--wide-left{grid-template-columns:1.15fr .85fr;}
.split--wide-right{grid-template-columns:.85fr 1.15fr;}
@media (max-width:860px){.split,.split--wide-left,.split--wide-right{grid-template-columns:1fr;gap:40px;}}

.stat{font-family:var(--font-display);font-weight:700;font-size:clamp(40px,5vw,68px);line-height:1;color:var(--metal-bright);}
.stat-label{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:10px;}

/* small helpers */
.center{text-align:center;}
.mt-s{margin-top:14px;}.mt-m{margin-top:26px;}.mt-l{margin-top:44px;}
.maxch{max-width:62ch;}
.flex{display:flex;}.wrap{flex-wrap:wrap;}.gap-s{gap:12px;}.gap-m{gap:20px;}
.btn-row{display:flex;flex-wrap:wrap;gap:16px;}
