/* =============== 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;
  }
}
/* Ensure the absolute menu positions relative to the bar and sits on top */
.site-nav { position: sticky; top: 0; z-index: 2000; }
.site-nav__bar { position: relative; z-index: 2001; }   /* new: anchor for absolute menu */

@media (max-width: 1100px){
  .site-nav__menu{
    position: absolute;
    left: 0; right: 0; top: 100%;
    z-index: 2002;                     /* new: above page content */
    display: none;                     /* as you had */
    pointer-events: auto;              /* ensure clickable */
  }
  .site-nav__menu.show{
    display: flex !important;          /* force show when toggled */
  }

  /* Keep the burger above everything so taps always register */
  .site-nav__burger{ position: relative; z-index: 2003; }
}

/* Extra safety for dropdown-on-hover on desktop */
.site-nav__submenu{ z-index: 2004; }


/* ===== Catering Services — HERO ===== */
.cs-hero {
  position:relative;
  height:70vh;
  min-height:520px;
  background:#000;
  color:#fff;
  overflow:hidden;
  z-index:-1;
}

/* Background */
.cs-hero-bg {
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  z-index:0;
}
.cs-hero-overlay {
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(0,0,0,0.65), rgba(0,0,0,0.25));
  z-index:1;
}

/* Content */
.cs-hero-inner {
  position:relative;
  z-index:2;
  max-width:1000px;
  margin:0 auto;
  padding:0 20px;
  height:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.cs-hero-kicker {
  display:inline-block;
  color:goldenrod;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.95rem;
  padding:.35rem .9rem;
  border:2px solid goldenrod;
  border-radius:999px;
  margin-bottom:12px;
}
.cs-hero-title {
  font-weight:800;
  line-height:1.2;
  margin:0 0 12px;
  font-size:clamp(1.8rem, 4vw, 2.8rem);
}
.cs-hero-sub {
  color:#e8e8e8;
  max-width:800px;
  margin:0 auto 18px;
  font-size:clamp(1rem, 2vw, 1.1rem);
  line-height:1.7;
}

/* CTA buttons */
.cs-hero-cta {
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  justify-content:center;
}
.cs-hero-btn {
  display:inline-block;
  padding:12px 26px;
  border-radius:8px;
  background:goldenrod;
  color:#000;
  font-weight:800;
  text-decoration:none;
  transition:.25s;
}
.cs-hero-btn:hover { background:#fff; color:goldenrod; }
.cs-hero-btn-outline {
  background:transparent;
  color:#fff;
  border:2px solid goldenrod;
}
.cs-hero-btn-outline:hover { background:#fff; color:goldenrod; }

/* Responsive */
@media (max-width:680px){
  .cs-hero { height:64vh; min-height:460px; }
}

/* ===== Catering Services — Services Overview (Scoped) ===== */
.cs-services {
  background:#111;
  color:#fff;
  padding:70px 20px;
}
.cs-services-container {
  max-width:1200px;
  margin:0 auto;
}

.cs-services-h2 {
  text-align:center;
  font-weight:800;
  font-size:clamp(1.6rem,3.8vw,2.2rem);
  margin:0 0 12px;
}
.cs-services-h2::after {
  content:"";
  display:block;
  width:90px;
  height:3px;
  margin:12px auto 0;
  background:linear-gradient(90deg, transparent, goldenrod, transparent);
  border-radius:3px;
}
.cs-services-lead {
  color:#d7d7d7;
  text-align:center;
  max-width:900px;
  margin:0 auto 36px;
  font-size:1.05rem;
  line-height:1.7;
}

/* Grid */
.cs-services-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.cs-services-card {
  background:#1a1a1a;
  border:2px solid rgba(255,255,255,.12);
  border-radius:12px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:.25s;
}
.cs-services-card:hover {
  transform:translateY(-4px);
  border-color:goldenrod;
  box-shadow:0 8px 28px rgba(218,165,32,.25);
}

/* Image */
.cs-services-img {
  height:160px;
  background-size:cover;
  background-position:center;
  border-bottom:2px solid rgba(255,255,255,.08);
}

/* Text */
.cs-services-card h3 {
  margin:14px 14px 6px;
  font-size:1.1rem;
  font-weight:700;
  color:goldenrod;
}
.cs-services-card p {
  margin:0 14px 16px;
  color:#d7d7d7;
  font-size:.95rem;
  line-height:1.6;
}

/* Responsive */
@media (max-width:1000px){
  .cs-services-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:680px){
  .cs-services-grid { grid-template-columns:1fr; }
  .cs-services-img { height:200px; }
}

/* ===== Catering Services — Process Timeline (Scoped) ===== */
.cs-process {
  background:#111;
  padding:70px 20px;
  color:#fff;
}
.cs-process-container {
  max-width:1100px;
  margin:0 auto;
}

.cs-process-h2 {
  text-align:center;
  font-weight:800;
  font-size:clamp(1.6rem,3.8vw,2.2rem);
  margin:0 0 12px;
}
.cs-process-h2::after {
  content:"";
  display:block;
  width:90px;
  height:3px;
  margin:12px auto 0;
  background:linear-gradient(90deg, transparent, goldenrod, transparent);
  border-radius:3px;
}
.cs-process-lead {
  color:#d7d7d7;
  text-align:center;
  max-width:800px;
  margin:0 auto 40px;
  font-size:1.05rem;
  line-height:1.7;
}

/* Timeline */
.cs-process-timeline {
  position:relative;
  margin-left:40px;
}
.cs-process-timeline::before {
  content:"";
  position:absolute;
  left:8px;
  top:0; bottom:0;
  width:2px;
  background:linear-gradient(goldenrod, transparent);
}

.cs-process-step {
  display:flex;
  align-items:flex-start;
  gap:16px;
  position:relative;
  margin-bottom:28px;
}
.cs-process-dot {
  width:14px;
  height:14px;
  border-radius:50%;
  background:goldenrod;
  box-shadow:0 0 0 4px rgba(218,165,32,.25);
  margin-top:.4rem;
  flex-shrink:0;
}
.cs-process-card {
  background:#1a1a1a;
  border-radius:12px;
  padding:18px 20px;
  border:2px solid rgba(255,255,255,.12);
  flex:1;
}
.cs-process-card h4 {
  margin:0 0 8px;
  color:goldenrod;
  font-weight:700;
  font-size:1.1rem;
}
.cs-process-card p {
  margin:0;
  color:#d7d7d7;
  line-height:1.6;
  font-size:.96rem;
}

/* Responsive */
@media (max-width:680px){
  .cs-process-timeline { margin-left:24px; }
  .cs-process-timeline::before { left:4px; }
}

/* ===== Catering Services — FAQ (Scoped) ===== */
.cs-faq {
  background:#111;
  padding:70px 20px;
  color:#fff;
}
.cs-faq-container {
  max-width:1100px;
  margin:0 auto;
}

.cs-faq-h2 {
  text-align:center;
  font-weight:800;
  font-size:clamp(1.6rem,3.8vw,2.2rem);
  margin:0 0 12px;
}
.cs-faq-h2::after {
  content:"";
  display:block;
  width:90px;
  height:3px;
  margin:12px auto 0;
  background:linear-gradient(90deg, transparent, goldenrod, transparent);
  border-radius:3px;
}
.cs-faq-lead {
  color:#d7d7d7;
  text-align:center;
  max-width:800px;
  margin:0 auto 40px;
  font-size:1.05rem;
  line-height:1.7;
}

/* Grid */
.cs-faq-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
}
.cs-faq-card {
  background:#1a1a1a;
  border-radius:12px;
  border:2px solid rgba(255,255,255,.12);
  padding:20px;
  transition:.25s;
}
.cs-faq-card:hover {
  transform:translateY(-4px);
  border-color:goldenrod;
  box-shadow:0 8px 28px rgba(218,165,32,.25);
}
.cs-faq-card h3 {
  margin:0 0 10px;
  color:goldenrod;
  font-size:1.1rem;
  font-weight:700;
}
.cs-faq-card p {
  margin:0;
  color:#d7d7d7;
  line-height:1.6;
  font-size:.95rem;
}

/* Responsive */
@media (max-width:900px){
  .cs-faq-grid { grid-template-columns:1fr; }
}

/* ===== Catering — CTA Banner (match new global banner style) ===== */
.cs-cta-banner{
  background:#000;
  padding: clamp(70px, 12vh, 120px) 24px;
  color:#fff;
}
.cs-cta-banner-container{
  max-width: var(--maxw, 1280px);
  margin: 0 auto;
}
.cs-cta-banner-flex{
  display:flex;
  gap:40px;
  align-items:stretch;
  background:#0f0f0f;
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 18px 48px rgba(0,0,0,.4);
}

/* Image panel */
.cs-cta-banner-img{
  flex:0 0 46%;
  min-height:380px;
  background-size:cover;
  background-position:center;
  position:relative;
}
.cs-cta-banner-img::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.4), transparent 50%);
}

/* Copy panel */
.cs-cta-banner-copy{
  flex:1;
  padding: clamp(32px, 6vw, 56px);
  display:flex; flex-direction:column; justify-content:center;
}
.cs-cta-banner-h3{
  font-weight:800;
  font-size: clamp(1.6rem, 3.4vw, 2.4rem);
  margin:0 0 14px;
}
.cs-cta-banner-text{
  color:#d7d7d7;
  font-size: clamp(1rem, 1.4vw, 1.125rem);
  line-height:1.75;
  margin:0 0 20px;
}

/* Button */
.cs-cta-banner-btn{
  align-self:flex-start;
  display:inline-block;
  padding:14px 32px;
  border-radius:12px;
  background:goldenrod; color:#000;
  font-weight:800; text-decoration:none;
  border:2px solid transparent; transition:.25s;
}
.cs-cta-banner-btn:hover{
  background:#fff; color:goldenrod; border-color:goldenrod;
}

/* Responsive stack */
@media (max-width: 900px){
  .cs-cta-banner-flex{ flex-direction:column; gap:24px; text-align:left; }
  .cs-cta-banner-img{ flex:0 0 auto; min-height:260px; }
  .cs-cta-banner-btn{ align-self:stretch; text-align:center; }
}


   /* =============== 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;
  }
}
