/* ——— Base ——— */
:root{
  --text:#f2f2f4;
  --muted:#c4c4c9;
  --accent:#ffffff;
  --dim: 0.50; /* cinematic dark */
  --ring:#2a2a33;
  --panel:#121216;
}

*{ box-sizing:border-box }
html, body{ margin:0; padding:0; }
body{
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--text);
  background: #0b0b0c;
  line-height: 1.45;
  overflow-x:hidden;
  transition: opacity .45s ease; /* global page appear/fade */
}
html.is-loading body{ opacity:0 }

/* ——— HERO (parallax + vignette + fade-in) ——— */
.hero{
  position: relative;
  min-height: 100vh;
  display: grid;
  place-items: center;
  text-align: center;

  background:
    linear-gradient(0deg, rgba(0,0,0,var(--dim)), rgba(0,0,0,var(--dim))),
    url("img/hero.jpg") center center / cover no-repeat;
  background-attachment: fixed;

  opacity: 0;
  animation: heroFade 1.6s ease forwards;
}
@keyframes heroFade{ to{opacity:1} }

/* Stronger vignette + subtle grain */
.hero::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(100% 70% at 0% 50%, rgba(0,0,0,0.6) 0%, rgba(0,0,0,0) 45%),
    radial-gradient(100% 70% at 100% 50%, rgba(0,0,0,0.6) 0%, rgba(0,0,0,0) 45%),
    radial-gradient(90% 60% at 50% 120%, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0) 50%),
    radial-gradient(90% 60% at 50% -20%, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0) 50%);
}
.hero::after{
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.06;
  background-image:
    repeating-linear-gradient(0deg, rgba(255,255,255,.02) 0, rgba(255,255,255,.02) 1px, transparent 1px, transparent 2px),
    repeating-linear-gradient(90deg, rgba(255,255,255,.02) 0, rgba(255,255,255,.02) 1px, transparent 1px, transparent 2px);
  mix-blend-mode: screen;
}

/* wordmark */
.brand{
  position:absolute; top:22px; left:26px; right:26px;
  display:flex; justify-content:center; pointer-events:none;
}
.brand-mark{
  letter-spacing:.5rem; font-weight:300; font-size:.85rem; color:var(--muted);
  opacity:0; animation: fadeUp .9s ease .4s forwards;
}

/* center content */
.center{ position: relative; z-index:1; padding: 0 22px; }
.headline{
  margin:0 0 22px; font-weight:300;
  font-size: clamp(1.1rem, 3.6vw, 2rem);
  letter-spacing:.35rem; text-transform:uppercase; color:var(--muted);
  opacity:0; transform: translateY(8px); animation: fadeUp 1s ease .7s forwards;
}
.cta{
  display:inline-block; color: var(--accent); text-decoration:none;
  font-weight:600; letter-spacing:.15rem; font-size: clamp(1.1rem, 2.8vw, 1.6rem);
  opacity:0; transform: translateY(8px); animation: fadeUp 1s ease 1s forwards;
  position: relative;
}
.cta::after{
  content:""; position:absolute; left:0; right:0; bottom:-6px; height:1px; background: currentColor;
  transform: scaleX(0); transform-origin: left; transition: transform .35s ease; opacity:.7;
}
.cta:hover::after{ transform: scaleX(1) }

@keyframes fadeUp{ to{ opacity:1; transform:translateY(0) } }

/* scroll cue */
.scroll-hint{ margin-top:34px; height:24px; display:flex; justify-content:center; opacity:.75 }
.arrow{ display:inline-block; animation: bounce 2.2s ease-in-out infinite }
@keyframes bounce{ 0%,100%{ transform:translateY(0)} 50%{ transform:translateY(8px)} }

/* ——— SOCIALS ——— */
.section{ background: transparent; color: var(--text) }
.pad{ padding: 64px 22px }
.section-title{
  text-align:center; margin:0 0 22px;
  font-weight:400; color:var(--muted); letter-spacing:.25rem; text-transform:uppercase;
  font-size:clamp(1rem,2.5vw,1.2rem);
}
.social-grid{
  max-width: 1200px; margin: 0 auto;
  display:grid; gap:14px; grid-template-columns: repeat(3, 1fr);
}

/* cards */
.card{
  border:1px solid var(--ring); background:var(--panel); border-radius:14px;
  padding:12px; min-height: 640px; display:flex; flex-direction:column;
  box-shadow: 0 8px 28px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.04);
}
.card-head{
  display:flex; align-items:center; gap:10px; padding:4px 2px 10px;
  border-bottom:1px solid #262632; color:#cfd1d7; letter-spacing:.1rem;
  text-transform:uppercase; font-size:.9rem; z-index:2;
}
.card-body{ padding:10px 2px; flex:1; display:flex; align-items:center; justify-content:center; }
.card-foot{ padding-top:10px; border-top:1px solid #262632; display:flex; justify-content:center }

/* small header icon */
.icon{ width:20px; height:20px; opacity:.85; border-radius:4px; }

/* IG header glow (subtle) */
.glow{
  filter: drop-shadow(0 0 6px rgba(255,255,255,0.25));
}

/* Full-card logo variant (X & TikTok) */
.logo-card .card-body{ padding: 18px 10px; }
.card-logo{
  width: 82%;
  max-height: 82%;
  object-fit: contain;
  filter:
    drop-shadow(0 0 10px rgba(255,255,255,0.22))
    drop-shadow(0 0 24px rgba(255,255,255,0.10));
}

/* medium pulse glow */
.pulse{
  animation: pulseGlow 2.8s ease-in-out infinite;
}
@keyframes pulseGlow{
  0%,100%{
    filter:
      drop-shadow(0 0 10px rgba(255,255,255,0.20))
      drop-shadow(0 0 22px rgba(255,255,255,0.10));
    transform: translateZ(0) scale(1);
  }
  50%{
    filter:
      drop-shadow(0 0 14px rgba(255,255,255,0.34))
      drop-shadow(0 0 30px rgba(255,255,255,0.18));
    transform: translateZ(0) scale(1.01);
  }
}

/* Buttons */
.btn{
  display:inline-block; padding:10px 16px; border-radius:10px; border:1px solid var(--ring);
  background:#1a1a23; color:#f2f2f4; text-decoration:none; transition:transform .2s ease, opacity .2s ease;
}
.btn:hover{ transform:translateY(-1px); opacity:.9 }

/* Footer */
.foot{
  text-align:center;
  padding: 28px 16px 40px;
  color:#a9a9af; letter-spacing:.12rem; font-size:.78rem;
}

/* Responsive */
@media (max-width:1024px){
  .social-grid{ grid-template-columns:1fr 1fr }
}
@media (max-width:640px){
  .brand-mark{ letter-spacing:.35rem }
  .headline{ letter-spacing:.2rem }
  .social-grid{ grid-template-columns:1fr }
}

/* —— NAV (top-right hamburger + animated dropdown) —— */
.fv-nav{
  position: fixed; top: 16px; right: 16px; z-index: 999;
  pointer-events: none;
}
.fv-burger{
  pointer-events: auto;
  width: 44px; height: 44px;
  display: grid; place-items: center;
  background: rgba(18,18,22,.74);
  border: 1px solid var(--ring);
  border-radius: 10px;
  cursor: pointer;
  transition: transform .2s ease, opacity .2s ease;
}
.fv-burger:hover{ transform: translateY(-1px); opacity:.95; }
.fv-burger .bar{
  display:block; width: 20px; height: 2px; background: #fff;
  margin: 3px 0; border-radius: 2px;
  transition: transform .3s ease, opacity .2s ease;
}
.fv-burger[aria-expanded="true"] .bar:nth-child(1){ transform: translateY(5px) rotate(45deg); }
.fv-burger[aria-expanded="true"] .bar:nth-child(2){ opacity: 0; }
.fv-burger[aria-expanded="true"] .bar:nth-child(3){ transform: translateY(-5px) rotate(-45deg); }

.fv-menu{
  pointer-events: auto;
  list-style: none; margin: 10px 0 0; padding: 10px;
  position: absolute; right: 0; top: 44px;
  width: 180px;
  background: var(--panel);
  border: 1px solid var(--ring);
  border-radius: 12px;
  box-shadow: 0 10px 28px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.04);
  opacity: 0; transform: translateY(-8px) scale(.98);
  pointer-events: none;
  transition: opacity .24s ease, transform .24s ease;
}
.fv-menu.open{
  opacity: 1; transform: translateY(0) scale(1);
  pointer-events: auto;
}
.fv-link{
  display:block; padding:10px 12px; border-radius: 8px;
  text-decoration:none; color: var(--text);
  letter-spacing:.06rem;
  transition: background .18s ease, opacity .18s ease, transform .18s ease;
}
.fv-link:hover{ background: #1a1a23; transform: translateX(2px); }

/* —— Page layout helpers for static pages —— */
.page-wrap{
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 64px 22px;
}
.page-inner{
  max-width: 900px;
  text-align: center;
  opacity: 0; transform: translateY(8px);
  animation: fadeUp .9s ease .2s forwards;
}
.page-title{
  margin: 0 0 14px;
  font-weight: 400;
  color: var(--muted);
  letter-spacing: .25rem;
  text-transform: uppercase;
  font-size: clamp(1rem, 2.5vw, 1.2rem);
}
.page-text{
  font-weight: 300;
  font-size: clamp(1rem, 2.2vw, 1.2rem);
  color: var(--text);
  line-height: 1.6;
}
