:root{
  --gold:#e3b437;
  --gold-dark:#b98811;
  --cream:#f7f0e6;
  --ink:#17120d;
  --muted:#5e5548;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--cream);color:var(--ink)}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{width:min(1180px,calc(100% - 32px));margin:0 auto}

.topbar{background:#120d09;color:#fff}
.topbar-inner,.nav-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  padding:14px 0;
}
.top-links,.top-actions,.nav-links{
  display:flex;
  align-items:center;
  gap:22px;
  flex-wrap:nowrap;
}
.top-links a,.nav-links a{
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:rgba(255,255,255,.76);
  white-space:nowrap;
}
.nav-links a{
  color:#342a1e;
  font-weight:700;
}

.pill{
  padding:10px 18px;
  border-radius:999px;
  font-size:13px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  white-space:nowrap;
}
.pill.gold{background:var(--gold);color:#000}
.pill.dark{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18)}

.navbar{
  background:#f7f0e6;
  border-bottom:1px solid #e8ddcf;
  position:sticky;
  top:0;
  z-index:30;
}
.brand{display:flex;align-items:center;gap:14px}
.brand-logo{
  width:58px;
  height:58px;
  border-radius:50%;
  object-fit:cover;
  box-shadow:0 10px 25px rgba(0,0,0,.12);
}
.brand small{
  display:block;
  color:#8b6d2c;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:11px;
}
.brand strong{font-size:18px}

.hero{position:relative;min-height:92vh;overflow:hidden;color:#fff}
.hero-bg{
  position:absolute;
  inset:0;
  background:url('hero-bg.jpg') center center/cover no-repeat;
  filter:blur(2px);
  transform:scale(1.04);
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(9,8,6,.84) 0%,rgba(10,9,7,.68) 35%,rgba(18,14,10,.52) 62%,rgba(28,20,12,.46) 100%);
}
.hero-glow{
  position:absolute;
  border-radius:50%;
  filter:blur(56px);
  opacity:.5;
}
.hero-glow-1{width:340px;height:340px;background:rgba(227,180,55,.35);left:-90px;top:-60px}
.hero-glow-2{width:300px;height:300px;background:rgba(255,255,255,.12);right:-60px;top:60px}

.hero-inner{
  position:relative;
  display:grid;
  grid-template-columns:1.06fr .94fr;
  gap:28px;
  align-items:center;
  min-height:92vh;
  padding:72px 0;
}
.glass-panel{
  background:rgba(9,10,14,.28);
  border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  box-shadow:0 20px 50px rgba(0,0,0,.22);
}
.hero-copy{border-radius:34px;padding:38px}
.hero-aside{border-radius:34px;padding:20px}

.eyebrow,.section-kicker{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.26em;
  font-weight:700;
  color:var(--gold);
}
.hero h1{font-size:70px;line-height:.95;margin:18px 0 18px}
.hero h1 span{
  background:linear-gradient(90deg,#fff,#f4d37b,var(--gold));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.hero p{max-width:680px;font-size:20px;color:rgba(255,255,255,.92)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:15px 26px;
  border-radius:999px;
  font-weight:700;
}
.btn-gold{background:var(--gold);color:#000}
.btn-dark{background:#17120d;color:#fff}

.hero-badge-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  margin-bottom:18px;
}
.hero-badge-circle{
  width:88px;
  height:88px;
  object-fit:cover;
  border-radius:50%;
}
.hero-dcl-logo{
  width:88px;
  height:88px;
  object-fit:contain;
  border-radius:24px;
  background:rgba(255,255,255,.08);
  padding:10px;
}
.hero-feature-image{overflow:hidden;border-radius:26px}
.hero-feature-image img{height:320px;width:100%;object-fit:cover}
.hero-feature-copy{padding:18px 6px 6px}
.hero-feature-copy .label{
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:rgba(255,255,255,.66);
}
.hero-feature-copy h3{font-size:30px;margin:10px 0}
.hero-feature-copy p{font-size:16px;color:rgba(255,255,255,.78);margin:0}

.section{padding:76px 0}
.section.light{background:#fff}
.section.dark{background:#17120d;color:#fff}
.gold-text{color:var(--gold)}
.light-text{color:rgba(255,255,255,.78)}
.section h2{font-size:52px;line-height:1.02;margin:14px 0 0}
.lead{font-size:19px;color:#4b4338}
.section-head{
  display:flex;
  justify-content:space-between;
  gap:20px;
  align-items:end;
}

.gallery-section{padding-bottom:42px}
.slider-controls{display:flex;gap:10px}
.slider-controls button{
  width:46px;
  height:46px;
  border-radius:50%;
  border:none;
  background:#15110d;
  color:#fff;
  font-size:28px;
  cursor:pointer;
}
.slider-controls button:last-child{background:var(--gold);color:#000}

.full-slider{
  position:relative;
  overflow:hidden;
  border-top:1px solid #2b241b;
  border-bottom:1px solid #2b241b;
  background:#0f0b08;
  margin-top:24px;
}
.slide{display:none;position:relative}
.slide.active{display:block}
.slide img{width:100%;height:720px;object-fit:cover}
.slide::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.16) 35%,rgba(0,0,0,.82) 100%);
}
.slide-caption{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:42px;
  width:min(1180px,calc(100% - 32px));
  z-index:2;
}
.slide-caption span{
  font-size:12px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--gold);
}
.slide-caption h3{font-size:56px;margin:10px 0}
.slide-caption p{max-width:760px;font-size:18px;color:rgba(255,255,255,.86)}

.dots-wrap{padding-top:22px}
.dots{display:flex;justify-content:center;gap:10px}
.dot{
  width:11px;
  height:11px;
  border-radius:999px;
  background:#9a9a9a;
  opacity:.5;
  cursor:pointer;
  border:0;
  padding:0;
}
.dot.active{width:38px;background:var(--gold);opacity:1}

.featured-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:18px;
  margin-top:30px;
}
.featured-card{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  min-height:260px;
  background:#111;
  box-shadow:0 12px 30px rgba(0,0,0,.08);
}
.featured-card.wide{grid-column:span 2;min-height:360px}
.featured-card.tall{grid-row:span 2;min-height:548px}
.featured-card img{width:100%;height:100%;object-fit:cover}
.featured-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.04),rgba(0,0,0,.25) 46%,rgba(0,0,0,.82) 100%);
}
.featured-copy{
  position:absolute;
  left:20px;
  right:20px;
  bottom:18px;
  z-index:2;
  color:#fff;
}
.featured-copy span{
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
}
.featured-copy h3{font-size:28px;margin:10px 0 0;line-height:1.08}

.youtube-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:30px;
}
.glass-card{
  background:rgba(255,255,255,.72);
  border:1px solid rgba(227,180,55,.25);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-radius:28px;
  padding:18px;
  box-shadow:0 18px 40px rgba(0,0,0,.06);
}
.video-frame{
  position:relative;
  padding-top:56.25%;
  overflow:hidden;
  border-radius:20px;
  background:#000;
}
.video-frame iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
}
.youtube-card h4{font-size:26px;margin:16px 0 8px}
.youtube-card p{margin:0;color:#5e5548}

.social-icon,.social-glass{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:18px;
  color:#fff;
  font-weight:700;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 10px 30px rgba(0,0,0,.18);
  transition:.2s;
}
.social-icon:hover,.social-glass:hover{transform:translateY(-3px)}

.social-icon{
  width:62px;
  height:62px;
  background:rgba(18,13,9,.58);
}
.social-icon svg{width:30px;height:30px}
.social-icon.instagram{background:linear-gradient(135deg,rgba(131,58,180,.78),rgba(225,48,108,.68),rgba(252,175,69,.62))}
.social-icon.tiktok{background:linear-gradient(135deg,rgba(0,0,0,.86),rgba(37,244,238,.26),rgba(254,44,85,.34))}
.social-icon.facebook{background:linear-gradient(135deg,rgba(24,119,242,.78),rgba(13,71,161,.72))}

.social-glass-row{
  display:flex;
  justify-content:center;
  gap:16px;
  flex-wrap:wrap;
  margin-top:30px;
}
.social-glass{
  gap:10px;
  padding:14px 18px;
  min-width:170px;
}
.social-glass svg{width:22px;height:22px;fill:currentColor}
.social-glass.instagram{background:linear-gradient(135deg,rgba(131,58,180,.88),rgba(225,48,108,.78),rgba(252,175,69,.72))}
.social-glass.tiktok{background:linear-gradient(135deg,rgba(0,0,0,.86),rgba(37,244,238,.26),rgba(254,44,85,.34))}
.social-glass.facebook{background:linear-gradient(135deg,rgba(24,119,242,.88),rgba(13,71,161,.72))}

.top-actions .social-icon{
  background:rgba(255,255,255,.12);
  width:42px;
  height:42px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.16);
}
.top-actions .social-icon svg{width:20px;height:20px;fill:currentColor}
.top-actions .social-icon.facebook{background:linear-gradient(135deg,rgba(24,119,242,.88),rgba(13,71,161,.72))}
.top-actions .social-icon.instagram{background:linear-gradient(135deg,rgba(131,58,180,.88),rgba(225,48,108,.78),rgba(252,175,69,.72))}
.top-actions .social-icon.tiktok{background:linear-gradient(135deg,rgba(0,0,0,.86),rgba(37,244,238,.26),rgba(254,44,85,.34))}

.partners-grid-clean{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:28px;
  margin-top:30px;
}
.partner-card-clean{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 18px 40px rgba(0,0,0,.08);
}
.partner-image-box{
  height:280px;
  background:#eef1f6;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:30px;
}
.partner-image-box.dark{
  background:#0f2e5d;
}
.partner-image-box img{
  max-width:78%;
  max-height:170px;
  object-fit:contain;
}
.partner-body{
  padding:24px 28px 30px;
}
.partner-body span{
  display:block;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.22em;
  color:#c89f2f;
  margin-bottom:10px;
  font-weight:700;
}
.partner-body h3{
  margin:0 0 12px;
  font-size:1.95rem;
  line-height:1.08;
}
.partner-body p{
  margin:0;
  color:#4d4d4d;
  line-height:1.6;
}

.support{
  background:#e7bf60;
}
.support-inner{
  display:grid;
  grid-template-columns:1fr auto;
  gap:24px;
  align-items:center;
}
.support h2{font-size:48px;margin:10px 0}
.support p{font-size:18px;color:rgba(0,0,0,.72)}

.footer{
  background:#15110d;
  color:#fff;
  padding:56px 0;
}
.footer-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
}
.footer h4{
  color:var(--gold);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:13px;
  margin:0 0 14px;
}
.footer p,.footer a{
  color:rgba(255,255,255,.78);
  margin:8px 0;
  display:block;
}

@media (max-width: 1180px){
  .topbar-inner,.nav-inner{
    flex-wrap:wrap;
  }
  .top-actions,.nav-links,.top-links{
    gap:14px;
  }
}

@media (max-width: 1100px){
  .hero-inner,.support-inner,.footer-grid,.youtube-grid{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .hero h1{font-size:56px}
  .slide img{height:560px}
  .slide-caption h3{font-size:44px}
  .featured-grid{grid-template-columns:1fr 1fr}
  .featured-card.wide{grid-column:span 2}
  .featured-card.tall{grid-row:auto;min-height:320px}
}

@media (max-width: 900px){
  .partners-grid-clean{
    grid-template-columns:1fr;
  }
}

@media (max-width: 760px){
  .topbar-inner,.nav-inner,.hero-inner,.support-inner,.footer-grid,.youtube-grid{
    grid-template-columns:1fr;
    display:grid;
  }
  .top-links,.top-actions{
    justify-content:center;
    flex-wrap:wrap;
  }
  .brand strong{font-size:16px}
  .hero{min-height:auto}
  .hero-inner{padding:48px 0}
  .hero h1{font-size:42px}
  .hero p{font-size:17px}
  .section{padding:56px 0}
  .section h2{font-size:34px}
  .slide img{height:360px}
  .slide-caption h3{font-size:30px}
  .slide-caption p{font-size:15px}
  .featured-grid{grid-template-columns:1fr}
  .featured-card.wide{grid-column:auto;min-height:280px}
  .featured-card.tall{min-height:280px}
  .partner-image-box{
    height:220px;
  }
  .partner-image-box img{
    max-width:82%;
    max-height:120px;
  }
}