/* ═══════════════════════════════════════════
   BASE — variables, reset, shared, buttons
   ═══════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --gold: #D4AF37; --gold-light: #F4D03F; --gold-dark: #C5A028; --gold-deep: #8B6914;
  --bg: #080808; --bg2: #050505; --bg3: #0D0D0D;
  --w60: rgba(255,255,255,.6); --w40: rgba(255,255,255,.4);
  --w20: rgba(255,255,255,.2); --w10: rgba(255,255,255,.1); --w05: rgba(255,255,255,.05);
  --g10: rgba(212,175,55,.1); --g20: rgba(212,175,55,.2);
  --g30: rgba(212,175,55,.3); --g50: rgba(212,175,55,.5);
  --serif: "Helvetica", Arial, sans-serif;
  --sans: "Helvetica", Arial, sans-serif;
  --r: 16px;
}

html { scroll-behavior: smooth; }
body { background: var(--bg); color: #fff; font-family: var(--sans); font-weight: 300; overflow-x: hidden; }
body, h1, h2, h3, h4, h5, h6, p, span, a, li, label, button, input, textarea, select, option {
  font-family: "Helvetica", Arial, sans-serif;
}
a { text-decoration: none; color: inherit; }
img { display: block; width: 100%; height: 100%; object-fit: cover; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }

/* Gold gradient text */
.gold-text {
  background: linear-gradient(135deg, var(--gold-deep), var(--gold), var(--gold-light), var(--gold));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}

/* Dot pattern */
.dot-pattern {
  position: absolute; inset: 0; opacity: .025; pointer-events: none;
  background-image: radial-gradient(circle at 1px 1px, var(--gold) 1px, transparent 0);
  background-size: 44px 44px;
}

/* Section top line */
.section-top-line {
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--g30), transparent);
}

/* Reveal animation */
.reveal-up {
  opacity: 0; transform: translateY(36px);
  transition: opacity .8s ease calc(var(--delay,0s)), transform .8s ease calc(var(--delay,0s));
}
.reveal-up.visible { opacity: 1; transform: translateY(0); }

/* Section headers */
.section-header { text-align: center; margin-bottom: 80px; }
.header-row { display: flex; align-items: center; justify-content: center; gap: 12px; margin-bottom: 16px; }
.h-line { height: 1px; width: 48px; background: linear-gradient(90deg, transparent, var(--g50)); }
.h-line:last-child { background: linear-gradient(90deg, var(--g50), transparent); }
.h-line.long { width: 80px; }
.section-label { font-size: 11px; letter-spacing: .4em; text-transform: uppercase; color: var(--gold); }
.section-header h2 { font-family: var(--serif); font-size: clamp(2.2rem,5vw,3.5rem); font-weight: 400; color: #fff; margin-bottom: 20px; }
.header-ornament { display: flex; align-items: center; justify-content: center; gap: 10px; }
.orn-star { color: var(--g50); font-size: 18px; }
.orn-star.small { font-size: 11px; }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 14px 32px; border-radius: 999px; font-size: 11px; font-weight: 500;
  letter-spacing: .2em; text-transform: uppercase; cursor: pointer;
  gap: 10px;
  transition: all .4s; position: relative; overflow: hidden; font-family: var(--sans);
}
.btn-icon {
  width: 15px;
  height: 15px;
  flex: 0 0 auto;
}
.btn-outline { border: 1px solid var(--g30); color: rgba(255,255,255,.8); background: transparent; }
.btn-outline::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, var(--g10), transparent);
  transform: translateX(-100%); transition: transform .6s;
}
.btn-outline:hover { border-color: var(--gold); color: #fff; box-shadow: 0 0 20px var(--g20); }
.btn-outline:hover::before { transform: translateX(100%); }
.btn-gold {
  background: linear-gradient(135deg, var(--gold-dark), var(--gold), var(--gold-light), var(--gold), var(--gold-dark));
  background-size: 200% 100%; color: #0D0D0D; font-weight: 600; border: none;
  animation: goldShift 4s linear infinite;
}
.btn-gold:hover { box-shadow: 0 0 40px var(--g50); transform: scale(1.02); }
.btn-gold-shine {
  position: absolute; inset: 0;
  background: linear-gradient(105deg, transparent 30%, rgba(255,255,255,.3) 50%, transparent 70%);
  animation: shimmerBtn 3s ease-in-out infinite;
}

@keyframes goldShift { 0%{background-position:0% 0%} 100%{background-position:200% 0%} }
@keyframes shimmerBtn { 0%{transform:translateX(-150%)} 60%,100%{transform:translateX(150%)} }
@keyframes fadeIn { to { opacity: 1; } }
@keyframes bounce { 0%,100%{transform:translateY(0)} 50%{transform:translateY(8px)} }
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
@keyframes goldShimmer { 0%{transform:translateX(-150%)} 55%,100%{transform:translateX(150%)} }
@keyframes packShimmer { 0%{transform:translateX(-100%)} 60%,100%{transform:translateX(100%)} }

/* Mobile bottom navigation */
.mobile-bottom-nav {
  display: none;
}

@media (max-width: 768px) {
  body {
    padding-bottom: 64px;
  }

  .mobile-bottom-nav {
    position: fixed;
    left: 12px;
    right: 12px;
    bottom: 12px;
    z-index: 1200;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 8px;
    padding: 6px 8px calc(6px + env(safe-area-inset-bottom));
    border: 1px solid var(--g20);
    border-radius: 18px;
    background: rgba(8, 8, 8, .9);
    backdrop-filter: blur(10px);
    box-shadow: 0 10px 35px rgba(0, 0, 0, .45);
  }

  .mobile-nav-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    color: rgba(255,255,255,.78);
    font-size: 10px;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: 4px 4px;
    border-radius: 12px;
    transition: color .25s ease, background-color .25s ease, transform .25s ease;
  }

  .mobile-nav-item svg {
    width: 18px;
    height: 18px;
    color: var(--gold);
  }

  .mobile-nav-item:active {
    transform: translateY(1px);
  }

  .mobile-nav-item:hover,
  .mobile-nav-item:focus-visible {
    color: #fff;
    background: rgba(212,175,55,.14);
    outline: none;
  }
}
