

  /* =============== Base ================= */
:root{
  --bg:#000; --bg2:#111; --ink:#fff; --muted:#d7d7d7; --gold:goldenrod;
  --radius:12px; --shadow:0 10px 28px rgba(0,0,0,.35);
  --maxw:1200px;
  --h1:clamp(1.9rem,2.8vw,2.7rem);
  --h2:clamp(1.6rem,2.2vw,2.1rem);
  --h3:clamp(1.2rem,1.6vw,1.4rem);
  --lead:clamp(1rem,1.2vw,1.1rem);
}

/* --- Responsive gutters that never disappear --- */
:root{
  /* you can tweak these numbers later */
  --maxw: 1200px;                       /* content max width */
  --gutter: clamp(16px, 4vw, 32px);     /* min 16px → grows to 32px on big screens */
}

/* container always leaves left/right space, even on tiny screens */
.container{
  width: min(var(--maxw), calc(100% - (var(--gutter) * 2.9)));
  margin-inline: auto;
  /* fallback if the min()/calc() isn’t supported somewhere ancient */
  padding-inline: max(16px, 4vw);
}


*{box-sizing:border-box}
html{font-family:Inter,system-ui,Arial,sans-serif;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);line-height:1.6;overflow-x:hidden}
img,video,iframe{max-width:100%;height:auto;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.section{padding:64px 0}
.center{text-align:center}
h1{font-size:var(--h1);line-height:1.2;margin:.2rem 0 .6rem}
h2{font-size:var(--h2);line-height:1.25;margin:0 0 .5rem}
h3{font-size:var(--h3);line-height:1.3;margin:0 0 .4rem}
.lead{font-size:var(--lead);color:var(--muted)}
a{text-decoration:none;color:inherit}

/* =============== NAV ================== */
/* =============== NAV (updated) ================== */
.site-nav{
  position:sticky; top:0; z-index:1000;
  background:rgba(10,10,10,.9);
  backdrop-filter:saturate(120%) blur(8px);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.site-nav__bar{
  min-height:68px;
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; flex-wrap:nowrap;
}
.site-nav__brand{ display:flex; align-items:center; gap:10px; color:#fff; text-decoration:none; white-space:nowrap; }
.site-nav__brand img{ height:48px; width:auto; }
.site-nav__brand span{ font-weight:700; letter-spacing:.3px; }

.site-nav__menu{
  display:flex; align-items:center; gap:10px;
  list-style:none; margin:0; padding:0; flex-wrap:nowrap;
}
.site-nav__menu a, .site-nav__menu .sub-toggle{
  appearance:none; background:none; border:0; color:#fff;
  text-decoration:none; cursor:pointer;
  padding:10px 12px; border-radius:8px; font-weight:600; font-size:1rem;
}
.site-nav__menu a:hover, .site-nav__menu .sub-toggle:hover{ background:#1a1a1a; }

/* dropdown */
.has-sub{ position:relative; }
.site-nav__submenu{
  position:absolute; left:0; top:100%;
  min-width:240px; padding:8px;
  background:#111; border:1px solid rgba(255,255,255,.08);
  border-radius:12px; box-shadow:0 12px 32px rgba(0,0,0,.45);
  opacity:0; transform:translateY(8px); pointer-events:none; transition:.16s;
}
.has-sub::after{ content:""; position:absolute; left:0; right:0; top:100%; height:12px; } /* hover bridge */
.has-sub:hover .site-nav__submenu, .has-sub.open .site-nav__submenu{
  opacity:1; transform:translateY(0); pointer-events:auto;
}
.site-nav__submenu, .site-nav__submenu li{ list-style:none; margin:0; padding:0; }
.site-nav__submenu a{ display:block; padding:10px 12px; border-radius:8px; color:#cfd6e4; }
.site-nav__submenu a:hover{ background:#1c1c1c; color:#fff; }

/* WhatsApp pill */
.site-nav__wa{
  background:var(--gold); color:#000; font-weight:800;
  padding:10px 14px; border-radius:999px; text-decoration:none;
  white-space:nowrap;
}
.site-nav__wa:hover{ background:#fff; color:var(--gold); }

/* burger (hidden by default) */
.site-nav__burger{
  display:none; width:44px; height:44px;
  border:1px solid rgba(255,255,255,.12);
  background:none; color:var(--gold);
  border-radius:8px; align-items:center; justify-content:center;
}

/* ===== tighten spacing slightly on mid widths (pre-hamburger) */
@media (max-width: 1240px){
  .site-nav__menu{ gap:8px; }
  .site-nav__menu a, .site-nav__menu .sub-toggle{ padding:8px 10px; font-size:.96rem; }
  .site-nav__wa{ padding:9px 12px; }
}

/* ===== switch to hamburger earlier to avoid wrap (≤1100px) */
@media (max-width: 1100px){
  .site-nav__burger{ display:flex; }
  .site-nav__wa{ display:none; }                /* hide WA on mobile */
  .site-nav__menu{
    position:absolute; left:0; right:0; top:100%;
    background:#0f0f0f; border-bottom:1px solid rgba(255,255,255,.08);
    flex-direction:column; align-items:flex-start; gap:8px;
    padding:16px 20px; display:none;
  }
  .site-nav__menu.show{ display:flex; }

  /* mobile submenu renders inline (no hover) */
  .site-nav__submenu{
    position:static; opacity:1; transform:none; pointer-events:auto;
    background:transparent; border:0; box-shadow:none; padding:0; margin-left:8px;
  }
}

 
  /* ===== Gallery — Section shell ===== */
.gallery-section { background:#111; color:#fff; padding:70px 20px; }
.gallery-container { max-width:1200px; margin:0 auto; }

/* Headings */
.gallery-h2 {
  text-align:center; font-weight:800;
  font-size:clamp(1.6rem,3.8vw,2.2rem); margin:0 0 12px;
}
.gallery-h2::after{
  content:""; display:block; width:90px; height:3px; margin:12px auto 0;
  background:linear-gradient(90deg,transparent,goldenrod,transparent); border-radius:3px;
}
.gallery-sub{ margin-top:48px; }
.gallery-lead{
  color:#d7d7d7; text-align:center; max-width:800px; margin:0 auto 24px;
  font-size:1.05rem; line-height:1.7;
}

/* Masonry blocks */
.gallery-grid{ column-count:3; column-gap:20px; }
.gallery-item{
  break-inside:avoid; margin-bottom:20px; overflow:hidden; border-radius:12px;
  border:2px solid rgba(255,255,255,.08); box-shadow:0 6px 18px rgba(0,0,0,.3); transition:.3s;
}
.gallery-item:hover{ transform:translateY(-4px); border-color:goldenrod; box-shadow:0 10px 28px rgba(218,165,32,.25); }
.gallery-item img, .gallery-item video{ width:100%; height:auto; display:block; border-radius:12px; object-fit:cover; }

/* Reels: make vertical media look great */
.gallery-reels .gallery-item video{
  aspect-ratio:9/16; width:100%; height:auto; object-fit:cover;
  background:#000; /* avoids white flash before poster */
}

/* Responsive columns */
@media (max-width:1000px){ .gallery-grid{ column-count:2; } }
@media (max-width:680px){ .gallery-grid{ column-count:1; } }

/* ===== Lightbox ===== */
.gallery-lightbox{
  display:none; position:fixed; inset:0; background:rgba(0,0,0,.9);
  z-index:9999; align-items:center; justify-content:center; padding:20px;
}
.gallery-lightbox-content{ max-width:90%; max-height:90%; }
.gallery-lightbox-content img, .gallery-lightbox-content video{
  max-width:100%; max-height:100%; border-radius:12px; box-shadow:0 6px 28px rgba(0,0,0,.6);
}
.gallery-lightbox-close{
  position:absolute; top:20px; right:30px; color:#fff; font-size:2.2rem; font-weight:700;
  cursor:pointer; z-index:10000; transition:.25s;
}
.gallery-lightbox-close:hover{ color:goldenrod; }


    /* =============== FOOTER =============== */
.site-footer{background:var(--bg2);color:var(--muted);padding:60px 0;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:40px}
.site-footer h3{color:#fff;margin-bottom:12px}
.site-footer a{color:var(--muted)}
.site-footer a:hover{color:#fff}
.footer-socials { display:grid;  gap:12px; margin-top:12px; }
.footer-socials .soc svg {
  width: 32px;   /* adjust to your liking */
  height: 32px;
}

.footer-socials .soc { color: var(--gold); display:inline-flex; }
.footer-socials .soc:hover { color:#fff; }



/* --- TEMP HOTFIX: normalize unexpected global scaling --- */
html, body {
  font-size: 16px !important;        /* reset REM base */
  line-height: 1.6 !important;
  zoom: 1 !important;                 /* neutralize accidental zoom */
  transform: none !important;         /* neutralize parent scaling */
  -webkit-text-size-adjust: 100% !important; /* iOS auto-enlarge guard */
}

/* ===== Global Reveal (shared) ===== */
.rv {
  opacity: 0;
  transform: translateY(16px);
  transition:
    opacity .6s ease,
    transform .6s ease;
  transition-delay: var(--rv-delay, 0s);
  will-change: opacity, transform;
}
.rv--in { opacity: 1; transform: none; }

/* Optional directional variants */
.rv-up    { transform: translateY(16px); }
.rv-right { transform: translateX(-14px); }
.rv-left  { transform: translateX(14px); }

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  .rv, .rv--in, .rv-up, .rv-right, .rv-left {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}
