/* ========== BASE DESIGN SYSTEM ========== */
:root{
  --offwhite:#F7F6F2;
  --slate:#2E4257;
  --slate-dark:#1F2933;
  --gold:#B8A46A;
  --muted:#6B7C8F;
  --border:#E3E0D8;
}

*{margin:0;padding:0;box-sizing:border-box}

html{
  overflow-x:hidden;
  width:100%;
}

body{
  font-family:-apple-system,BlinkMacSystemFont,"Inter",system-ui,sans-serif;
  background:var(--offwhite);
  color:var(--slate);
  line-height:1.7;
  overflow-x:hidden;
  width:100%;
  position:relative;
}

a{ text-decoration:none;color:inherit }
img{ display:block;max-width:100%;height:auto }
.container{ max-width:1200px;margin:auto;padding:96px 24px;width:100% }

/* =========== HEADER ========== */
header{
  position:sticky;
  top:0;
  z-index:100;
  background:var(--slate);
  border-bottom:1px solid rgba(255,255,255,.08);
}

.nav{
  max-width:1200px;
  margin:auto;
  padding:18px 24px;
  display:flex;
  justify-content:space-between;
  align-items:center;
}

.logo-text{
  font-family:"Canela","Playfair Display",Georgia,serif;
  font-size:2rem;
  font-weight:600;
  letter-spacing:.4px;
  color:var(--offwhite);
}

.nav-links{
  display:flex;
  gap:22px;
  align-items:center;
}

.nav-links a{
  font-weight:500;
  font-size:.95rem;
  color:var(--offwhite);
}

.cta{
  background:var(--gold);
  padding:12px 26px;
  border-radius:999px;
  font-weight:600;
  color:#1F2933;
}

/* =========== PROGRAMS PAGE STYLES ========== */
.programs-section{
  background:var(--offwhite);
  padding:96px 0;
}

.programs-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:36px;
}

.program-card{
  background:#fff;
  border-radius:26px;
  padding:36px;
  border:1px solid var(--border);
  box-shadow:0 18px 50px rgba(0,0,0,.12);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}

.program-card h3{
  font-size:1.25rem;
  color:var(--slate-dark);
  margin-bottom:12px;
}

.program-card p{
  font-size:.95rem;
  color:#5F6F82;
  margin-bottom:22px;
}

.program-meta{
  font-size:.9rem;
  color:var(--muted);
  margin-bottom:14px;
}

.program-price{
  font-weight:600;
  color:var(--slate-dark);
  margin-bottom:18px;
}

.program-actions{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-top:auto;
}

.find-more{
  font-size:.9rem;
  font-weight:500;
  color:var(--slate);
  text-decoration:underline;
}

.apply-small{
  background:var(--gold);
  padding:10px 22px;
  border-radius:999px;
  font-weight:600;
  color:#1F2933;
  font-size:.9rem;
  white-space:nowrap;
}

/* =========== OUTCOMES BAND ========== */
.outcomes-band{
  background:var(--slate);
  color:var(--offwhite);
  padding:96px 0;
}

.outcomes-band h2{text-align:center;margin-bottom:48px;font-size:2.2rem;}

.outcomes-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:36px;
}

.outcome-card{
  background:rgba(255,255,255,.06);
  padding:34px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.12);
}

.outcome-card h4{
  font-size:1.1rem;
  margin-bottom:12px;
  color:#fff;
}

.outcome-card h3{
  font-size:1.1rem;
  margin-bottom:12px;
  color:#fff;
}

.outcome-card p{
  font-size:.95rem;
  color:#E2E8F0;
}

/* =========== COURSE PAGE OUTCOMES (for .course-section.alt) ========== */
.course-section .outcomes-grid,
.section .outcomes-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:36px;
}

.course-section .outcome-card,
.section .outcome-card{
  background:#fff;
  border-radius:24px;
  padding:36px;
  border:1px solid var(--border);
  box-shadow:0 18px 45px rgba(0,0,0,.12);
}

.course-section .outcome-card h4,
.section .outcome-card h4,
.course-section .outcome-card h3,
.section .outcome-card h3{
  font-size:1.15rem;
  margin-bottom:14px;
  color:var(--slate-dark);
}

.course-section .outcome-card p,
.section .outcome-card p{
  font-size:.95rem;
  color:#5F6F82;
}

/* =========== AUDIENCE SECTION ========== */
.audience-section{
  background:var(--offwhite);
  padding:96px 0;
}

.audience-section h2{text-align:center;font-size:2.2rem;color:var(--slate-dark);margin-bottom:56px;}

.audience-section .section-header{
  max-width:720px;
  margin-bottom:56px;
  text-align:left;
}

.audience-section .section-header h2{
  text-align:left;
  font-size:2.2rem;
  color:var(--slate-dark);
  margin-bottom:0;
}

.course-section .section-header h2,
.section .section-header h2{
  text-align:left;
  margin-bottom:0;
}

.audience-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
}

.audience-card{
  background:#fff;
  border-radius:24px;
  padding:36px;
  border:1px solid var(--border);
  box-shadow:0 18px 45px rgba(0,0,0,.12);
}

.audience-card h3{
  font-size:1.25rem;
  margin-bottom:18px;
  color:var(--slate-dark);
}

.audience-card ul{
  list-style:none;
  padding:0;
}

.audience-card li{
  font-size:.95rem;
  color:#5F6F82;
  margin-bottom:12px;
  padding-left:20px;
  position:relative;
}

.audience-card li::before{
  content:"•";
  position:absolute;
  left:0;
  color:var(--gold);
  font-size:1.4rem;
  line-height:1;
}

/* =========== PHILOSOPHY SECTION ========== */
.philosophy-section{
  background:#EFEDE6;
  padding:96px 0;
}

.philosophy-section h2{text-align:center;font-size:2.2rem;color:var(--slate-dark);margin-bottom:56px;}

.philosophy-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:36px;
  margin-bottom:48px;
}

.philosophy-card{
  background:#fff;
  border-radius:24px;
  padding:36px;
  border:1px solid var(--border);
}

.philosophy-card h4{
  font-size:1.15rem;
  margin-bottom:14px;
  color:var(--slate-dark);
}

.philosophy-card p{
  font-size:.95rem;
  color:#5F6F82;
}

/* =========== PROGRAMS APPLY ========== */
.programs-apply{
  background:#EFEDE6;
  color:var(--slate-dark);
  padding:96px 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}

.programs-apply-box{
  max-width:720px;
  margin:0 auto;
  text-align:center;
}

.programs-apply-box h2{
  font-size:2.3rem;
  margin-bottom:18px;
  color:var(--slate-dark);
}

.programs-apply-box p{
  font-size:1.05rem;
  color:#5F6F82;
  margin-bottom:36px;
}

.programs-apply-actions{
  display:flex;
  justify-content:center;
  gap:18px;
  flex-wrap:wrap;
}

.programs-apply-actions .primary{
  background:var(--gold);
  padding:14px 36px;
  border-radius:999px;
  font-weight:600;
  color:#1F2933;
}

.programs-apply-actions .secondary{
  padding:14px 36px;
  border-radius:999px;
  border:2px solid var(--slate);
  color:var(--slate);
  font-weight:600;
  background:transparent;
}

/* =========== COURSE PAGES ========== */
.course-hero{
  background:linear-gradient(to bottom,rgba(46,66,87,.08),transparent);
}

.course-hero h1{
  font-size:3rem;
  line-height:1.1;
  color:var(--slate-dark);
  max-width:780px;
}

.course-subtitle{
  margin-top:22px;
  font-size:1.15rem;
  color:#5F6F82;
  max-width:720px;
}

.course-meta{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:18px;
  margin-top:36px;
  font-size:.95rem;
}

.course-actions{
  margin-top:42px;
  display:flex;
  gap:18px;
  flex-wrap:wrap;
}

.course-actions .primary,
.actions .primary{
  background:var(--gold);
  padding:14px 36px;
  border-radius:999px;
  font-weight:600;
  color:#1F2933;
}

.course-actions .secondary,
.actions .secondary{
  padding:14px 36px;
  border-radius:999px;
  border:1px solid var(--border);
  font-weight:600;
  color:var(--slate);
}

.course-section,
.section{
  background:var(--offwhite);
  padding:96px 0;
}

.course-section.alt{
  background:#EFEDE6;
}

.section-header{
  max-width:720px;
  margin-bottom:56px;
}

.section-header h2{
  font-size:2.2rem;
  color:var(--slate-dark);
  margin-bottom:16px;
}

.section-header p{
  font-size:1.05rem;
  color:#5F6F82;
}

.learn-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:36px;
}

.learn-card{
  background:#fff;
  border-radius:24px;
  padding:36px;
  border:1px solid var(--border);
  box-shadow:0 18px 45px rgba(0,0,0,.12);
}

.learn-card h3{
  font-size:1.15rem;
  margin-bottom:12px;
  color:var(--slate-dark);
}

.learn-card p{
  font-size:.95rem;
  color:#5F6F82;
}

.delivery-section{
  background:#EFEDE6;
  padding:96px 0;
}

.delivery-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:36px;
}

.delivery-card{
  background:#fff;
  border-radius:24px;
  padding:36px;
  border:1px solid var(--border);
  box-shadow:0 18px 45px rgba(0,0,0,.12);
}

.delivery-card h3{
  font-size:1.2rem;
  margin-bottom:14px;
  color:var(--slate-dark);
}

.delivery-card p{
  font-size:.95rem;
  color:#5F6F82;
}

.course-apply,
.final-apply{
  background:#EFEDE6;
  color:var(--slate-dark);
  padding:96px 0;
  text-align:center;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}

.course-apply h2,
.final-apply h2{
  font-size:2.3rem;
  margin-bottom:18px;
  color:var(--slate-dark);
}

.course-apply p,
.final-apply p{
  font-size:1.05rem;
  color:#5F6F82;
  max-width:680px;
  margin:0 auto 36px;
}

.course-apply-actions,
.final-apply .actions{
  display:flex;
  justify-content:center;
  gap:18px;
  flex-wrap:wrap;
}

.course-apply-actions a,
.final-apply .actions a{
  padding:14px 36px;
  border-radius:999px;
  font-weight:600;
  font-size:1rem;
}

.course-apply-actions .primary,
.final-apply .actions .primary{
  background:var(--gold);
  color:#1F2933;
}

.course-apply-actions .secondary,
.final-apply .actions .secondary{
  border:2px solid var(--slate);
  color:var(--slate);
  background:transparent;
}

/* =========== FOOTER ========== */
footer{
  background:var(--slate);
  color:var(--offwhite);
  padding:72px 0 36px;
}

.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:48px;
  margin-bottom:36px;
}

.footer-brand h3{
  font-family:"Canela","Playfair Display",Georgia,serif;
  font-size:1.6rem;
  margin-bottom:14px;
}

.footer-brand p{
  font-size:.95rem;
  color:#D8E0EA;
  max-width:360px;
}

.footer-col h4{
  font-size:1rem;
  margin-bottom:12px;
  color:#fff;
}

.footer-col a{
  display:block;
  font-size:.95rem;
  color:#D8E0EA;
  margin-bottom:8px;
}

.footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);
  padding-top:22px;
  text-align:center;
  font-size:.85rem;
  color:#D8E0EA;
}

.socials{
  display:flex;
  gap:14px;
  margin-top:16px;
}

.socials a{
  width:36px;
  height:36px;
  border-radius:50%;
  background:rgba(255,255,255,.12);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#F7F6F2;
}

/* =========== RESPONSIVE ========== */
@media(max-width:900px){
  html,body{
    overflow-x:hidden;
    max-width:100vw;
    position:relative;
  }
  
  .container{
    padding:48px 20px;
    max-width:100%;
  }
  
  .nav{
    flex-direction:column;
    align-items:center;
    padding:16px 20px;
  }
  
  .logo-text{
    font-size:1.8rem;
    text-align:center;
    margin-bottom:12px;
  }
  
  .nav-links{
    display:flex;
    gap:16px;
    flex-wrap:wrap;
    justify-content:center;
    width:100%;
  }
  
  .nav-links a{
    font-size:.9rem;
  }
  
  .audience-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .course-hero h1{font-size:2rem;line-height:1.2}
  .hero-grid{grid-template-columns:1fr}
  .hero h1{font-size:2.2rem;line-height:1.2}
  .hero-actions{flex-wrap:wrap;justify-content:center}
  
  /* Homepage specific fixes */
  .companies-section{
    overflow:hidden;
    max-width:100vw;
    padding:48px 0 40px;
  }
  
  .marquee{
    max-width:100vw;
    overflow:hidden;
  }
  
  .marquee-row{
    max-width:100vw;
  }
  
  .hero{
    overflow:hidden;
  }
  
  .hero-img{
    max-width:100%;
  }
  
  .programs-header{
    padding:0 20px;
  }
  
  .why-section .container{
    max-width:100%;
  }
  
  /* Fix all grids on mobile */
  .programs-grid,
  .learn-grid,
  .delivery-grid,
  .outcomes-grid,
  .philosophy-grid,
  .why-grid{
    grid-template-columns:1fr;
    gap:24px;
  }
  
  /* Fix office section */
  .office-grid{
    grid-template-columns:1fr;
  }
  
  .map-wrapper iframe{
    height:280px;
  }
}