/* style.css — Conscious Wellbeing SA (shared) */
/* Palette: deep charcoal, soft gold, sage, off-white */
:root{
  --charcoal:#0B1D39;
  --gold:#D4AF37;
  --sage:#A8BBA1;
  --ivory:#F8F8F8;
  --muted:#EAE7E2;
  --card-bg: rgba(255,255,255,0.03);
}

*{box-sizing:border-box}
html,body{height:100%;margin:0;font-family:"Lato",system-ui,Arial,sans-serif;color:var(--ivory);background:var(--charcoal);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}

/* ---------- LAYOUT ---------- */
.container{width:90%;max-width:1200px;margin:0 auto}

/* ---------- HEADER ---------- */
header{
  position:sticky;top:0;z-index:1200;
  background:linear-gradient(180deg, rgba(11,17,29,0.92), rgba(11,17,29,0.85));
  backdrop-filter: blur(6px);
  padding:14px 0;
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:12px}
.logo{display:flex;align-items:center;gap:12px}
.logo .mark{width:46px;height:46px;border-radius:10px;background:linear-gradient(135deg,var(--sage),#7d8f6b);display:flex;align-items:center;justify-content:center;color:var(--charcoal);font-family:'Playfair Display',serif;font-weight:700}
.brand-title{font-family:'Playfair Display',serif;font-size:18px;color:var(--ivory)}
.nav{display:flex;gap:22px;align-items:center}
.nav a{color:var(--ivory);padding:8px 12px;border-radius:8px;transition:all .18s ease}
.nav a:hover,.nav a.active{background:var(--card-bg)}
.cta{display:flex;gap:10px;align-items:center}
.btn{padding:10px 16px;border-radius:999px;font-weight:600;cursor:pointer}
.btn-ghost{background:transparent;border:1px solid rgba(255,255,255,0.06);color:var(--ivory)}
.btn-gold{background:linear-gradient(90deg,var(--gold),#b88922);color:var(--charcoal);transition:all .24s}
.btn-gold:hover{filter:brightness(.95);transform:translateY(-2px)}

/* mobile nav */
.menu-toggle{display:none;background:transparent;border:0;color:var(--ivory);font-size:22px;cursor:pointer}
.mobile-menu{display:none}

/* ---------- HERO (cinematic sunrise/ocean) ---------- */
.hero{
  min-height:62vh;display:flex;align-items:center;
  background-image:linear-gradient(180deg, rgba(11,17,29,0.28), rgba(11,17,29,0.6)), 
  background-size:cover;background-position:center;padding:84px 0;
}
.hero .hero-grid{display:grid;grid-template-columns:1fr 420px;gap:40px;align-items:center}
.hero h1{font-family:'Playfair Display',serif;font-size:36px;margin:0 0 12px;color:var(--ivory);line-height:1.02}
.lead{color:rgba(250,250,250,0.9);max-width:56ch;margin-bottom:18px}
.visual-card{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));padding:18px;border-radius:12px;box-shadow:0 8px 30px rgba(2,6,8,0.6)}

/* ---------- BOXED SECTIONS / TWO-COLUMN CARDS ---------- */
.section{padding:56px 0}
.section .grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;align-items:start}
.card{background:var(--card-bg);padding:22px;border-radius:12px;box-shadow:0 8px 26px rgba(2,6,8,0.5)}
.card h3{font-family:'Playfair Display',serif;color:var(--ivory);margin-top:0}
.card p{color:rgba(250,250,250,0.88);line-height:1.55}

/* small cards grid (programs) */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px}
.program{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));padding:18px;border-radius:12px}

/* pillars row */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:18px}
.pillar{background:linear-gradient(180deg,rgba(255,255,255,0.01),rgba(255,255,255,0.005));padding:16px;border-radius:10px;text-align:left;color:var(--ivory)}

/* testimonials */
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.testimonial{background:var(--card-bg);padding:18px;border-radius:12px;font-style:italic;color:rgba(250,250,250,0.95)}

/* resources gallery */
.gallery{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:16px;
  margin-top:18px;
}
.thumb{
  border-radius:12px;
  overflow:hidden;
  background:#000;
  cursor:pointer;
  box-shadow:0 10px 30px rgba(0,0,0,0.6);
  position: relative;
  width: 100%;
  padding-bottom: 133.33%; /* This creates 3:4 ratio (4/3 = 1.333 = 133.33%) */
  height: 0;
}
.thumb img, .thumb video{
  position: absolute;
  top: 0;
  left: 0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* contact */
.contact-card{display:grid;grid-template-columns:1fr 360px;gap:22px}
form input, form textarea{width:100%;padding:12px;border-radius:8px;border:1px solid rgba(255,255,255,0.04);background:transparent;color:var(--ivory)}
form button{margin-top:8px}

/* ------------ LIGHTBOX ------------ */
.lightbox{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(2,6,8,0.9);z-index:2000;padding:18px}
.lightbox.open{display:flex}
.lb-content{max-width:1100px;max-height:90vh}
.lb-content img, .lb-content video{max-width:100%;max-height:90vh;border-radius:8px}
.lb-close{position:absolute;top:18px;right:18px;background:transparent;border:0;color:var(--ivory);font-size:24px;cursor:pointer}

/* ---------- FOOTER ---------- */
footer{padding:24px 0;border-top:1px solid rgba(255,255,255,0.03);text-align:center;color:rgba(250,250,250,0.75)}
.footer-links a{color:var(--ivory);margin:0 8px}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .hero .hero-grid{grid-template-columns:1fr}
  .section .grid{grid-template-columns:1fr}
  .cards-grid{grid-template-columns:1fr}
  .pillars{grid-template-columns:repeat(2,1fr)}
  .testimonials{grid-template-columns:1fr}
  .contact-card{grid-template-columns:1fr}
}
@media(max-width:720px){
  .menu-toggle{display:inline-flex}
  .nav{display:none}
  .mobile-menu{display:block}
  header .container{padding:0 12px}
  .hero{padding:56px 0}
}

.video-background {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  object-fit: cover !important;
  z-index: -1 !important;
}

@media (max-width: 768px) {
  .video-background {
    object-fit: contain !important;
    background-color: #000 !important;
  }
}



















