html { scroll-behavior: smooth; scroll-padding-top: 96px; }
@media (max-width: 640px) { html { scroll-padding-top: 76px; } }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

.lenis, .lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-smooth [data-lenis-prevent] { overscroll-behavior: contain; }
.lenis.lenis-stopped { overflow: hidden; }
.lenis.lenis-smooth iframe { pointer-events: none; }

#site-header { position: sticky; top: 0; z-index: 1010; }
#site-header .nav {
  position: sticky; top: 0; z-index: 1010;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 40px;
  background: rgba(246, 247, 250, 0.78);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--rule);
}
#site-header .logo {
  display: inline-flex; align-items: center;
  height: 52px;
  transition: opacity .2s;
}
#site-header .logo:hover { opacity: 0.78; }
#site-header .logo img { height: 100%; width: auto; display: block; }

#site-header .nav-links { display: flex; gap: 36px; }
#site-header .nav-links a {
  position: relative;
  font-size: 13px; font-weight: 500;
  color: var(--navy); opacity: 0.78;
  transition: opacity .2s;
}
#site-header .nav-links a:hover { opacity: 1; }
#site-header .nav-links a.active { opacity: 1; }
#site-header .nav-links a.active::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -22px;
  height: 2px; background: var(--navy);
}

#site-header .nav-socials { display: inline-flex; align-items: center; gap: 6px; }
#site-header .nav-social {
  width: 38px; height: 38px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px;
  color: var(--navy);
  background: transparent;
  border: 1px solid var(--rule-strong);
  transition: background .2s ease, color .2s ease, transform .2s ease, border-color .2s ease;
}
#site-header .nav-social svg { width: 16px; height: 16px; display: block; }
#site-header .nav-social:hover {
  background: var(--navy); color: var(--ice);
  border-color: var(--navy); transform: translateY(-1px);
}

#site-header .nav-burger {
  display: none;
  width: 44px; height: 44px;
  align-items: center; justify-content: center;
  background: transparent;
  border: 1px solid var(--rule-strong);
  border-radius: 999px;
  color: var(--navy);
  cursor: pointer; padding: 0;
  transition: background .25s ease, border-color .25s ease, color .25s ease;
  -webkit-tap-highlight-color: transparent;
}
#site-header .nav-burger .burger-bars { position: relative; width: 18px; height: 12px; display: block; }
#site-header .nav-burger .burger-bars span {
  position: absolute; left: 0; right: 0;
  height: 1.5px; background: currentColor; border-radius: 2px;
  transition: transform .35s cubic-bezier(.65,.05,.36,1), top .25s ease .1s;
}
#site-header .nav-burger .burger-bars span:nth-child(1) { top: 2px; }
#site-header .nav-burger .burger-bars span:nth-child(2) { top: 9px; }
#site-header .nav-burger:hover,
#site-header .nav-burger.is-open { background: var(--navy); color: var(--ice); border-color: var(--navy); }
#site-header .nav-burger.is-open .burger-bars span { transition: transform .35s cubic-bezier(.65,.05,.36,1) .05s, top .2s ease; }
#site-header .nav-burger.is-open .burger-bars span:nth-child(1) { top: 5.5px; transform: rotate(45deg); }
#site-header .nav-burger.is-open .burger-bars span:nth-child(2) { top: 5.5px; transform: rotate(-45deg); }

.mobile-menu {
  position: fixed; inset: 0; z-index: 1000;
  background: var(--ice); color: var(--navy);
  display: flex; flex-direction: column;
  pointer-events: none; opacity: 0;
  transition: opacity .35s ease;
  height: 100dvh; overflow: hidden; overscroll-behavior: none;
}
.mobile-menu.is-open { pointer-events: auto; opacity: 1; touch-action: none; }

.mm-inner {
  flex: 1; display: flex; flex-direction: column;
  padding: 72px 28px 20px; max-width: 720px; width: 100%; margin: 0 auto;
  overflow: hidden; overscroll-behavior: none;
}
.mm-links {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 0; flex: 0 0 auto;
}
.mm-links li {
  border-bottom: 1px solid var(--rule); overflow: hidden;
  transform: translateY(20px); opacity: 0;
  transition: transform .55s cubic-bezier(.2,.7,.2,1), opacity .55s cubic-bezier(.2,.7,.2,1);
}
.mobile-menu.is-open .mm-links li { transform: translateY(0); opacity: 1; }
.mobile-menu.is-open .mm-links li:nth-child(1) { transition-delay: .14s; }
.mobile-menu.is-open .mm-links li:nth-child(2) { transition-delay: .19s; }
.mobile-menu.is-open .mm-links li:nth-child(3) { transition-delay: .24s; }
.mobile-menu.is-open .mm-links li:nth-child(4) { transition-delay: .29s; }
.mobile-menu.is-open .mm-links li:nth-child(5) { transition-delay: .34s; }
.mobile-menu.is-open .mm-links li:nth-child(6) { transition-delay: .39s; }
.mm-links a {
  display: flex; align-items: baseline; gap: 12px;
  padding: 10px 4px; color: var(--navy);
  font-family: 'AmsiProCondensed', sans-serif;
  font-weight: 500; font-size: 24px; letter-spacing: -0.01em; line-height: 1;
  transition: color .2s, transform .25s;
}
.mm-links a:hover { color: var(--navy-deep); transform: translateX(4px); }
.mm-links a.active .mm-label { text-decoration: underline; text-underline-offset: 6px; }
.mm-links .mm-num {
  font-family: 'Aptos', sans-serif;
  font-size: 10px; letter-spacing: 0.2em; color: var(--navy);
  opacity: 0.45; font-weight: 500; min-width: 22px;
}
.mm-links .mm-label { font-style: normal; }
.mm-secondary {
  list-style: none; margin: 10px 0 0; padding: 10px 4px 0;
  border-top: 1px solid var(--rule);
  display: flex; flex-wrap: wrap; gap: 8px 24px;
  opacity: 0; transform: translateY(14px);
  transition: opacity .5s ease .5s, transform .5s ease .5s;
}
.mobile-menu.is-open .mm-secondary { opacity: 1; transform: translateY(0); }
.mm-secondary a {
  color: var(--navy); opacity: 0.7;
  font-family: 'Aptos', sans-serif;
  font-size: 12px; letter-spacing: 0.05em;
  transition: opacity .2s;
}
.mm-secondary a:hover { opacity: 1; }
.mm-foot {
  margin-top: 12px; padding-top: 12px;
  border-top: 1px solid var(--rule);
  opacity: 0; transform: translateY(14px);
  transition: opacity .5s ease .55s, transform .5s ease .55s;
}
.mobile-menu.is-open .mm-foot { opacity: 1; transform: translateY(0); }
.mm-foot-label {
  font-family: 'Aptos', sans-serif;
  font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--navy); opacity: 0.5; margin-bottom: 10px;
}
.mm-socials { display: flex; gap: 8px; flex-wrap: wrap; }
.mm-social {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px 8px 10px; border-radius: 999px;
  border: 1px solid var(--rule-strong); color: var(--navy);
  font-family: 'Aptos', sans-serif;
  font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; font-weight: 500;
  transition: background .2s, color .2s, border-color .2s, transform .2s;
}
.mm-social svg { width: 16px; height: 16px; }
.mm-social:hover {
  background: var(--navy); color: var(--ice);
  border-color: var(--navy); transform: translateY(-1px);
}

#site-footer footer {
  background: var(--navy); color: var(--ice);
  padding: 40px 20px 16px; margin-top: 0;
}
#site-footer .footer-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: start;
  column-gap: clamp(40px, 5vw, 96px); row-gap: 40px;
  max-width: 1600px; margin: 0 auto;
  padding-bottom: 56px;
  border-bottom: 1px solid rgba(238, 242, 247, 0.18);
}
#site-footer .footer-brand { min-width: 0; }
#site-footer .footer-brand .logo { height: 96px; margin-bottom: 22px; }
#site-footer .footer-brand .logo.bear-mark { display: block; height: auto; width: 100%; max-width: 92px; margin-bottom: 20px; }
#site-footer .footer-brand .logo img { height: auto; width: 100%; max-width: 100%; display: block; filter: brightness(0) invert(1); }
#site-footer .footer-socials { display: flex; gap: 10px; flex-wrap: wrap; }
#site-footer .footer-social {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px; color: var(--ice);
  border: 1px solid rgba(238, 242, 247, 0.28);
  transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
}
#site-footer .footer-social svg { width: 16px; height: 16px; display: block; }
#site-footer .footer-social:hover {
  background: var(--ice); color: var(--navy);
  border-color: var(--ice); transform: translateY(-1px);
}
#site-footer .footer-contact { display: flex; flex-direction: column; gap: 8px; }
#site-footer .footer-contact p { margin: 0; font-size: 14px; line-height: 1.5; color: var(--ice); opacity: 0.85; }
#site-footer .footer-contact a { color: var(--ice); font-size: 14px; opacity: 0.85; transition: opacity .2s; }
#site-footer .footer-contact a:hover { opacity: 1; }
#site-footer .footer-brand .tag {
  font-family: 'AmsiProCondensed', sans-serif;
  font-style: normal; font-size: 22px; line-height: 1.3;
  color: var(--ice-3); max-width: 320px;
}
#site-footer .footer-col h3 {
  font-family: 'Aptos', sans-serif;
  font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
  color: rgba(238, 242, 247, 0.55); margin-bottom: 18px; font-weight: 500;
}
#site-footer .footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 10px; margin: 0; padding: 0; }
#site-footer .footer-col a { color: var(--ice); font-size: 14px; opacity: 0.85; transition: opacity .2s; }
#site-footer .footer-col a:hover { opacity: 1; }
#site-footer .footer-bottom {
  padding-top: 28px;
  max-width: 1600px; margin: 0 auto;
  display: flex; justify-content: center; align-items: center;
  gap: 8px 28px; flex-wrap: wrap; text-align: center;
  font-size: 12px; color: rgba(238, 242, 247, 0.55); letter-spacing: 0.05em;
}
#site-footer .footer-bottom .disclaim {
  font-family: inherit; font-style: normal;
  font-size: 12px; letter-spacing: 0.05em; color: rgba(238, 242, 247, 0.55);
}

.site-age-gate {
  position: fixed; inset: 0; z-index: 3000;
  background: rgba(11, 26, 51, 0.97);
  display: flex; align-items: center; justify-content: center;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  animation: sag-fadein 400ms cubic-bezier(.4, 0, .2, 1) both;
}
@keyframes sag-fadein { from { opacity: 0; } to { opacity: 1; } }
.site-age-gate.sag-hide {
  opacity: 0; pointer-events: none;
  transition: opacity 350ms cubic-bezier(.4, 0, .2, 1);
}
.sag-inner {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 40px; max-width: 600px; width: 100%;
  color: #EEF2F7;
}
.sag-logo { height: 188px; margin-bottom: 34px; }
.sag-logo img { height: 100%; width: auto; display: block; filter: brightness(0) invert(1); }
.sag-heading {
  font-family: 'AmsiProCondensed', sans-serif;
  font-style: normal; font-weight: 700;
  font-size: clamp(22px, 3.4vw, 42px);
  line-height: 1.1; letter-spacing: -0.01em;
  color: #EEF2F7; max-width: 580px; margin-bottom: 20px;
}
.sag-body {
  font-family: 'Aptos', system-ui, sans-serif;
  color: rgba(238, 242, 247, 0.72); font-size: 15px;
  margin-bottom: 36px; max-width: 460px;
}
.sag-body + .sag-body { margin-top: -20px; }
.sag-buttons { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }
.sag-buttons button {
  padding: 16px 32px; border-radius: 999px;
  font-size: 14px; font-weight: 500; cursor: pointer;
  font-family: 'Aptos', system-ui, sans-serif;
  transition: background .2s, color .2s; border: none;
}
.sag-yes { background: #EEF2F7; color: #13294B; border: 1px solid #EEF2F7 !important; }
.sag-yes:hover { background: #fff; }
.sag-no {
  background: transparent; color: #EEF2F7;
  border: 1px solid rgba(238, 242, 247, 0.45) !important;
}
.sag-no:hover { background: rgba(238, 242, 247, 0.08); }
.sag-small {
  margin-top: 32px; font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: rgba(238, 242, 247, 0.5);
  font-family: 'Aptos', system-ui, sans-serif;
}
@media (max-width: 520px) {
  .sag-logo { height: 130px; margin-bottom: 24px; }
  .sag-heading { font-size: clamp(18px, 5.5vw, 28px); }
  .sag-buttons { flex-direction: column; width: 100%; max-width: 320px; }
  .sag-buttons button { width: 100%; padding: 14px 22px; }
}
@media (prefers-reduced-motion: reduce) {
  .site-age-gate { animation: none; }
  .site-age-gate.sag-hide { transition: none; }
}

@media (max-width: 1100px) {
  #site-header .nav { padding: 16px 22px; }
  #site-header .nav-links,
  #site-header .nav-socials { display: none; }
  #site-header .nav-burger { display: inline-flex; }
  #site-footer footer { padding: 40px 40px 16px 40px; }
  #site-footer .footer-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); justify-content: stretch; column-gap: 40px; row-gap: 36px; }
  #site-footer .footer-brand { grid-column: 1 / -1; display: flex; flex-direction: column; align-items: flex-start; text-align: left; gap: 16px; }
  #site-footer .footer-brand .logo.bear-mark { margin-bottom: 0; max-width: 84px; }
  #site-footer .footer-socials { justify-content: flex-start; }
}
@media (max-width: 640px) {
  #site-header .nav { padding: 14px 18px; }
  #site-header .logo { height: 40px; }
#site-footer footer { padding: 28px 14px 14px; }
  #site-footer .footer-grid { grid-template-columns: minmax(0, 260px); justify-content: center; gap: 34px; padding-bottom: 42px; }
  #site-footer .footer-brand { flex-direction: column; align-items: center; text-align: center; gap: 18px; }
  #site-footer .footer-brand .logo.bear-mark { max-width: 96px; }
  #site-footer .footer-brand .tag { font-size: 18px; }
  #site-footer .footer-bottom { flex-direction: column; gap: 14px; text-align: center; }
}

.pk-curtain {
  position: fixed; inset: 0; z-index: 2000;
  background: var(--navy, #13294B);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity 500ms cubic-bezier(.4, 0, .2, 1);
}
.pk-curtain.on { opacity: 1; pointer-events: auto; }
.pk-curtain.pk-no-anim { transition: none; }
.pk-curtain-stack { display: flex; flex-direction: column; align-items: center; opacity: 0; transform: scale(.96); transition: opacity .5s cubic-bezier(.4,0,.2,1), transform .5s cubic-bezier(.4,0,.2,1); }
.pk-curtain.on .pk-curtain-stack { opacity: 1; transform: scale(1); }
.pk-curtain.pk-no-anim .pk-curtain-stack { transition: none; }
.pk-curtain-logo { height: 168px; width: auto; opacity: .97; }
.pk-curtain-line { margin-top: 26px; width: 118px; height: 1px; background: rgba(238,242,247,.22); position: relative; overflow: hidden; }
.pk-curtain-line::before { content: ""; position: absolute; inset: 0; transform: translateX(-100%); background: linear-gradient(90deg, transparent, #EEF2F7, transparent); animation: pk-curtain-sweep 1100ms cubic-bezier(.45,0,.55,1) infinite; }
@keyframes pk-curtain-sweep { to { transform: translateX(100%); } }
@media (max-width: 760px) { .pk-curtain-logo { height: 132px; } .pk-curtain-line { width: 92px; } }
@media (prefers-reduced-motion: reduce) { .pk-curtain-line::before { animation: none; } }
