

  /* =============== 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;
  }
}

  /* ===== Corporate Events — HERO (scoped) ===== */
.ce-hero{
  position:relative;
  height:70vh; min-height:520px;
  background:transparent; color:#fff; overflow:hidden;
  z-index: -2;
}

/* Slider */
.ce-hero-slider{ position:absolute; inset:0; }
.ce-slide{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  opacity:0; transform:scale(1.06);
  transition: opacity 1s ease, transform 6s ease;
}
.ce-slide.ce-active{ opacity:1; transform:scale(1); }

/* Overlay for readability (darker bottom, lighter top) */
.ce-hero-shade{
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.65), rgba(0,0,0,.25));
  pointer-events:none;
}

/* Copy */
.ce-hero-inner{
  position:relative; z-index:2;
  max-width:1100px; margin:0 auto; padding:0 20px;
  height:100%; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center;
}
.ce-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;
}
.ce-title{
  font-weight:800; line-height:1.2; margin:0 0 10px;
  font-size:clamp(1.8rem, 4.2vw, 2.8rem);
}
.ce-sub{
  color:#e8e8e8; max-width:840px; margin:6px auto 0;
  font-size:clamp(1rem, 2.2vw, 1.08rem); line-height:1.7;
}

/* CTAs */
.ce-cta{ display:flex; gap:14px; margin-top:18px; flex-wrap:wrap; justify-content:center; background: transparent; }
.ce-btn{
  display:inline-block; padding:12px 26px; border-radius:8px;
  background:goldenrod; color:#000; font-weight:800; text-decoration:none; transition:.25s;
}

/* Nuke any backdrop around the hero CTAs */
.ce-hero .ce-cta {
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
  padding: 0;             /* in case padding was making the box look bigger */
  border-radius: 0;       /* kill rounded container corners */
}

/* In case a pseudo-element is drawing the box */
.ce-hero .ce-cta::before,
.ce-hero .ce-cta::after {
  content: none !important;
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}

/* Keep the buttons themselves as-is */
.ce-hero .ce-cta .ce-btn {
  position: relative;     /* ensures they sit above any leftover layers */
  z-index: 1;
}

.ce-btn:hover{ background:#fff; color:goldenrod; }
.ce-btn--ghost{
  background:transparent; color:#fff; border:2px solid goldenrod;
}
.ce-btn--ghost:hover{ background:#fff; color:goldenrod; }

/* Responsive */
@media (max-width:680px){
  .ce-hero{ height:64vh; min-height:460px; }
  .ce-cta{ gap:10px; }
}

/* ===== Corporate Services (scoped to .ce-services) ===== */
.ce-services {
  background: #000;
  color: #fff;
  padding: clamp(60px, 12vh, 100px) 20px;
}

.ce-container {
  max-width: 1200px;
  margin: 0 auto;
}

.ce-h2 {
  text-align: center;
  font-size: clamp(1rem, 3.2vw, 2.5rem);
  font-weight: 800;
  margin-bottom: 16px;
}

.ce-lead {
  text-align: center;
  max-width: 800px;
  margin: 0 auto 48px;
  color: #cfcfcf;
  font-size: 0.5rem;
  line-height: 1.75;
}

/* Grid */
.ce-services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 28px;
}

/* Card */
.ce-service {
  background: #111;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.35);
  display: flex;
  flex-direction: column;
  transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}

.ce-service:hover {
  transform: translateY(-6px);
  border-color: rgba(218, 165, 32, 0.5);
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.5);
}

/* Image */
.ce-service .ce-thumb img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

/* Content */
.ce-service .ce-body {
  padding: 20px;
}

.ce-service .ce-body h3 {
  margin: 0 0 8px;
  font-size: 1.3rem;
  font-weight: 700;
  color: goldenrod;
}

.ce-service .ce-body p {
  margin: 0;
  color: #d7d7d7;
  font-size: 1rem;
  line-height: 1.6;
}

/* Reveal animation (scoped) */
.ce-services .reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.ce-services.ready .reveal.is-visible {
  opacity: 1;
  transform: none;
  transition-delay: calc(var(--st, 0) * 120ms);
}


    /* ===== Corporate Spotlight (scoped) ===== */
.ce-spotlight {
  background: #000;
  color: #fff;
  padding: clamp(60px, 12vh, 100px) 20px;
}

.ce-spotlight .ce-container {
  max-width: 1200px;
  margin: 0 auto;
}

.ce-flex {
  display: flex;
  align-items: stretch;
  min-height: 60vh;
}

/* Image side */
.ce-img {
  flex: 1 1 50%;
  min-height: 300px;
  background-size: cover;
  background-position: center;
  border-radius: 12px 0 0 12px;
}

/* Copy side */
.ce-copy {
  flex: 1 1 50%;
  background: #0f0f0f;
  padding: clamp(28px, 6vw, 64px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-radius: 0 12px 12px 0;
}

/* kicker pill */
.ce-kicker-sm {
  display: inline-block;
  color: goldenrod;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: 2px solid goldenrod;
  border-radius: 999px;
  padding: 0.4rem 1rem;
  margin-bottom: 12px;
  font-size: 0.9rem;
}

/* Title + body */
.ce-h3 {
  font-weight: 800;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  margin: 0 0 14px;
}

.ce-body {
  color: #d0d0d0;
  line-height: 1.7;
  margin: 0 0 14px;
  font-size: 1rem;
}

/* Responsive: stack on mobile */
@media (max-width: 820px) {
  .ce-flex {
    flex-direction: column;
  }
  .ce-img {
    border-radius: 12px 12px 0 0;
    height: 40vh;
  }
  .ce-copy {
    border-radius: 0 0 12px 12px;
    padding: 32px 20px;
  }
}



/* ===== Corporate Events — Process Timeline ===== */
.ce-process {
  background:#000;
  padding:70px 20px;
  color:#fff;
}
.ce-container { max-width:1100px; margin:0 auto; }

.ce-h2 {
  text-align:center;
  font-weight:800;
font-size: 42px;
  color: goldenrod;
  margin:0 0 12px;
}
.ce-process .ce-h2{font-size: 3rem;}
.ce-case .ce-h2 {
  font-size: 3rem; /* bigger size for this section only */
}

.ce-h2::after {
  content:"";
  display:block;
  width:90px;
  height:3px;
  margin:12px auto 0;
  background:linear-gradient(90deg, transparent, goldenrod, transparent);
  border-radius:3px;
}
.ce-lead {
  color:#d7d7d7;
  text-align:center;
  max-width:1000px;
  margin:0 auto 40px;
  font-size:2rem;
  line-height:1.7;
  padding-bottom: 150px;
}

.ce-process .ce-lead{font-size: 1.3rem; max-width: 1000px;}
.ce-timeline {
  position:relative;
  margin-left:40px;
}
.ce-timeline::before {
  content:"";
  position:absolute;
  left:8px;
  top:0;
  bottom:0;
  width:2px;
  background:linear-gradient(goldenrod, transparent);
}

.ce-step {
  display:flex;
  align-items:flex-start;
  gap:16px;
  position:relative;
  margin-bottom:28px;
}
.ce-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;
}
.ce-card {
  background:#000;
  border-radius:12px;
  padding:18px 20px;
 
  flex:1;
}
.ce-card h4 {
  margin:0 0 8px;
  color:goldenrod;
  font-weight:700;
  font-size:2rem;
}
.ce-card p {
  margin:0;
  color:#d7d7d7;
  line-height:1.6;
  font-size:1.2rem;
}

/* Responsive */
@media (max-width:680px){
  .ce-timeline { margin-left:24px; }
  .ce-timeline::before { left:4px; }
}


/* ===== Case Studies ===== */

/* Section heading */
.corp-case-head {
  text-align: center;
  margin-bottom: clamp(40px, 8vh, 70px);
}
.corp-h2 {
  font-size: clamp(1.9rem, 3.6vw, 2.6rem);
  font-weight: 800;
  margin: 0 0 12px;
  position: relative;
  display: inline-block;
}
.corp-h2::after {
  content: "";
  display: block;
  width: 80px;
  height: 3px;
  margin: 10px auto 0;
  background: goldenrod;
  border-radius: 2px;
}
.corp-caption {
  max-width: 680px;
  margin: 0 auto;
  color: #cfcfcf;
  font-size: 1rem;
  line-height: 1.6;
}

.corp-case{background:#000;color:#fff;padding:clamp(60px,12vh,100px) 20px}
.corp-case-container{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:80px}
.corp-case-block{display:flex;gap:40px;align-items:stretch}
.corp-case-block.reverse{flex-direction:row-reverse}

/* Media (single image) */
.corp-case-media{flex:1 1 50%}
.corp-case-media img{width:100%;height:100%;object-fit:cover;border-radius:12px;box-shadow:0 8px 28px rgba(0,0,0,.35)}

/* Details */
.corp-case-details{flex:1 1 50%;background:#0f0f0f;padding:clamp(24px,5vw,48px);border-radius:12px;box-shadow:0 8px 28px rgba(0,0,0,.25);display:flex;flex-direction:column;justify-content:center}
.corp-case-title{font-size:clamp(1.8rem,3vw,2.4rem);font-weight:800;margin:0 0 12px;color:goldenrod}
.corp-case-summary{color:#d7d7d7;font-size:1.05rem;margin:0 0 16px;line-height:1.7}
.corp-case-stats{list-style:none;margin:0 0 20px;padding:0}
.corp-case-stats li{margin-bottom:8px;color:#e8e8e8}
.corp-case-stats strong{color:goldenrod}

/* Attachments (Gmail-style chip) */
.corp-attach-wrap h3{margin:4px 0 10px;font-size:1.05rem;font-weight:700;color:goldenrod}
.corp-attach{display:inline-flex;align-items:center;gap:12px;background:#151515;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:10px 12px;text-decoration:none;color:#fff;box-shadow:0 6px 18px rgba(0,0,0,.25);transition:.25s}
.corp-attach:hover{border-color:goldenrod;box-shadow:0 10px 26px rgba(218,165,32,.25);transform:translateY(-2px)}
.corp-attach-thumb{position:relative;width:72px;height:52px;border-radius:6px;overflow:hidden;background:#0e0e0e;display:grid;place-items:center}
.corp-attach-thumb svg{position:absolute;inset:0;width:100%;height:100%}
.corp-attach-thumb img{width:100%;height:100%;object-fit:cover}
.corp-attach-meta{display:flex;flex-direction:column}
.corp-attach-meta strong{line-height:1.1;font-size:.95rem}
.corp-attach-meta small{color:#cfcfcf;font-size:.85rem}

/* Modal PDF viewer */
.pdf-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.9);justify-content:center;align-items:center;z-index:9999}
.pdf-modal-content{position:relative;width:92%;max-width:1100px;height:90vh;background:#111;border-radius:12px;overflow:hidden;box-shadow:0 10px 30px rgba(0,0,0,.6)}
.pdf-close{position:absolute;top:10px;right:14px;font-size:32px;line-height:1;padding:2px 8px;background:transparent;border:0;color:#fff;cursor:pointer}
.pdf-close:hover{color:goldenrod}
.pdf-modal iframe{border:0;width:100%;height:100%}

@media (max-width:900px){
  .corp-case-block,.corp-case-block.reverse{flex-direction:column}
  .corp-case-media img{height:42vh}
}




/* ===== Corporate CTA (corporate.html only) ===== */
.ce-cta { background:#000; padding: clamp(70px, 12vh, 120px) 24px; color:#fff; } /* ↑ overall height */
.ce-cta__card {
  max-width: var(--maxw, 1280px);  /* matches your site container */
  width: 100%;                     /* ensure it stretches */
  margin: 0 auto;
  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);
}
.ce-cta__img{
  flex:0 0 46%;
  min-height:380px; /* ↑ image height */
  background-size:cover; background-position:center;
  position:relative;
}
.ce-cta__img::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.4), transparent 50%); /* slightly stronger */
}
.ce-cta__copy{
  flex:1; 
  padding: clamp(32px, 6vw, 56px); /* ↑ inner padding */
  display:flex; flex-direction:column; justify-content:center;
}
.ce-cta__h3{
  font-weight:800;
  font-size:clamp(1.6rem, 3.4vw, 2.4rem); /* ↑ heading size */
  margin:0 0 14px;
}
.ce-cta__p{
  color:#d7d7d7;
  font-size:clamp(1rem, 1.4vw, 1.125rem); /* ↑ body size slightly on larger screens */
  line-height:1.75; margin:0 0 20px;
}
.ce-cta__btn{
  align-self:flex-start;
  display:inline-block;
  padding:14px 32px;              /* ↑ button size */
  border-radius:12px;
  background:goldenrod; color:#000; font-weight:800; text-decoration:none;
  border:2px solid transparent; transition:.25s;
}
.ce-cta__btn:hover{ background:#fff; color:goldenrod; border-color:goldenrod; }

/* stack on mobile */
@media (max-width: 900px){
  .ce-cta__card{ flex-direction:column; gap:24px; }
  .ce-cta__img{ flex:0 0 auto; min-height:260px; } /* ↑ mobile image height */
  .ce-cta__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; }


/* ===== Global Reveal ===== */
[data-reveal] .reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .6s ease, transform .6s ease;
}
[data-reveal].ready .reveal.is-visible {
  opacity: 1;
  transform: none;
  transition-delay: calc(var(--st, 0) * 120ms);
}
@media (prefers-reduced-motion: reduce) {
  [data-reveal] .reveal { opacity:1; transform:none; transition:none; }
}
