/* ============================================================
   SCNS PROGRAMME PAGES — SHARED STYLESHEET
   Link in each programme page: <link rel="stylesheet" href="programmes.css">
   (or ../programmes.css if pages are in a subfolder)
============================================================ */
:root {
  --navy:      #0A2F44;
  --navy-deep: #071E2E;
  --navy-mid:  #134B73;
  --yellow:    #FFD23F;
  --yellow-bright: #FFE070;
  --yellow-dark: #E6B800;
  --white:     #FFFFFF;
  --off-white: #F4F6F9;
  --text:      #1E2A3E;
  --muted:     #5F6C80;
  --border:    #E2E6ED;
  --radius:    16px;
  --shadow:    0 10px 28px rgba(7,30,46,0.08);
  --shadow-lg: 0 22px 48px rgba(7,30,46,0.14);
  --font-head: 'Playfair Display', Georgia, serif;
  --font-body: 'DM Sans', sans-serif;
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body { font-family:var(--font-body); color:var(--text); background:var(--white); overflow-x:hidden; line-height:1.7; }
img { max-width:100%; display:block; }
a { text-decoration:none; transition:all .3s ease; }

/* UTILITY */
.section-pad { padding:clamp(60px,10vw,100px) 0; }
.bg-off { background:var(--off-white); }
.txt-yellow { color:var(--yellow-dark); }

/* EYEBROW */
.eyebrow { display:inline-flex; align-items:center; gap:8px; font-size:.72rem; font-weight:800; letter-spacing:2.5px; text-transform:uppercase; color:var(--yellow-dark); margin-bottom:14px; }
.eyebrow::before { content:''; width:28px; height:2px; background:var(--yellow); display:block; }
.eyebrow-white { color:var(--yellow); }
.eyebrow-white::before { background:var(--yellow); }

/* HEADINGS */
.section-heading { font-family:var(--font-head); font-size:clamp(1.8rem,4vw,3rem); font-weight:900; color:var(--navy); line-height:1.2; }
.section-heading span { color:var(--yellow-dark); border-bottom:3px solid var(--yellow); display:inline; padding-bottom:3px; }
.section-heading-white { font-family:var(--font-head); font-size:clamp(1.8rem,4vw,3rem); font-weight:900; color:white; line-height:1.2; }
.section-heading-white span { color:var(--yellow); border-bottom:3px solid var(--yellow); display:inline; }

/* BUTTONS */
.btn-yellow { display:inline-flex; align-items:center; gap:8px; background:var(--yellow); color:var(--navy-deep); font-weight:800; font-size:.85rem; padding:13px 26px; border-radius:50px; border:none; cursor:pointer; transition:all .3s; box-shadow:0 4px 14px rgba(255,210,63,.35); white-space:nowrap; }
.btn-yellow:hover { background:var(--yellow-bright); transform:translateY(-2px); color:var(--navy-deep); }
.btn-outline-white { display:inline-flex; align-items:center; gap:8px; border:1.5px solid rgba(255,255,255,.4); background:transparent; color:white; border-radius:50px; padding:12px 26px; font-weight:700; font-size:.85rem; cursor:pointer; transition:all .3s; }
.btn-outline-white:hover { background:var(--yellow); border-color:var(--yellow); color:var(--navy-deep); }
.btn-outline-navy { display:inline-flex; align-items:center; gap:8px; border:1.5px solid var(--navy); background:transparent; color:var(--navy); border-radius:50px; padding:12px 26px; font-weight:700; font-size:.85rem; cursor:pointer; transition:all .3s; }
.btn-outline-navy:hover { background:var(--navy); color:white; }

/* ANNOUNCEMENT BAR */
.announcement-bar { background:var(--yellow); padding:11px 0; }
.announcement-bar p { margin:0; color:var(--navy-deep); font-weight:700; font-size:.87rem; display:flex; align-items:center; justify-content:center; gap:10px; flex-wrap:wrap; }
.ann-btn { background:var(--navy-deep); color:var(--yellow); border:none; border-radius:20px; padding:5px 16px; font-size:.78rem; font-weight:700; transition:all .3s; cursor:pointer; }
.ann-btn:hover { background:var(--navy-mid); }

/* NAVBAR */
.site-nav { background:rgba(255,255,255,.97); backdrop-filter:blur(10px); border-bottom:1px solid var(--border); transition:all .3s; }
.site-nav.scrolled { box-shadow:var(--shadow); }
.site-nav .navbar-brand img { height:52px; }
.site-nav .nav-link { color:var(--navy)!important; font-weight:600; font-size:.84rem; padding:1.4rem .85rem!important; position:relative; }
.site-nav .nav-link::after { content:''; position:absolute; bottom:0; left:50%; transform:translateX(-50%); width:0; height:3px; background:var(--yellow); border-radius:2px; transition:width .3s; }
.site-nav .nav-link:hover::after, .site-nav .nav-link.active::after { width:60%; }
.site-nav .nav-link:hover, .site-nav .nav-link.active { color:var(--yellow-dark)!important; }
@media(min-width:992px){
  .dropdown:hover>.dropdown-menu { display:block; margin-top:0; animation:dFade .22s ease; }
  .dropdown-menu { border:none; box-shadow:var(--shadow-lg); border-radius:14px; padding:8px; min-width:220px; }
  .dropdown-menu .dropdown-item { padding:10px 16px; border-radius:8px; font-size:.84rem; font-weight:500; color:var(--navy); }
  .dropdown-menu .dropdown-item:hover { background:rgba(255,210,63,.12); padding-left:20px; }
}
@keyframes dFade { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }

/* PROGRAMME HERO */
.prog-hero { background:linear-gradient(140deg,var(--navy-deep) 0%,var(--navy) 55%,var(--navy-mid) 100%); padding:clamp(90px,14vw,120px) 0 clamp(60px,8vw,80px); position:relative; overflow:hidden; }
.prog-hero::before { content:''; position:absolute; top:-60px; right:-80px; width:500px; height:500px; background:radial-gradient(circle,rgba(255,210,63,.08) 0%,transparent 68%); border-radius:50%; pointer-events:none; }
.prog-hero::after { content:''; position:absolute; bottom:0; left:0; right:0; height:4px; background:linear-gradient(90deg,var(--yellow) 0%,transparent 55%); }
.breadcrumb-item a { color:var(--yellow); font-size:.82rem; }
.breadcrumb-item.active { color:rgba(255,255,255,.6); font-size:.82rem; }
.breadcrumb-item+.breadcrumb-item::before { color:rgba(255,255,255,.35); }
.prog-badge-pill { display:inline-flex; align-items:center; gap:8px; background:var(--yellow); color:var(--navy-deep); font-weight:800; font-size:.72rem; padding:6px 18px; border-radius:50px; margin-bottom:18px; }
.prog-hero-title { font-family:var(--font-head); font-size:clamp(2rem,5.5vw,3.8rem); font-weight:900; color:white; line-height:1.1; }
.prog-hero-title em { color:var(--yellow); font-style:normal; }
.prog-hero-sub { color:rgba(255,255,255,.65); font-size:clamp(.9rem,2.5vw,1.05rem); max-width:520px; }
.hero-img-card { border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-lg); border:3px solid rgba(255,210,63,.2); position:relative; }
.hero-img-card img { width:100%; height:400px; object-fit:cover; }
.hero-img-card .img-badge { position:absolute; bottom:16px; left:16px; background:var(--yellow); color:var(--navy-deep); padding:8px 18px; border-radius:10px; font-weight:800; font-size:.82rem; }
.prog-meta { display:flex; flex-wrap:wrap; gap:10px; margin-top:28px; }
.meta-chip { display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14); border-radius:10px; padding:10px 16px; font-size:.8rem; color:white; }
.meta-chip i { color:var(--yellow); font-size:.9rem; }
.meta-chip strong { color:white; }

/* OVERVIEW */
.overview-lead { font-size:clamp(.95rem,2.5vw,1.05rem); color:var(--muted); line-height:1.85; }
.overview-img { border-radius:var(--radius); box-shadow:var(--shadow-lg); width:100%; height:380px; object-fit:cover; }
.stat-badge { display:inline-flex; align-items:center; gap:6px; background:white; border:1px solid var(--border); border-radius:10px; padding:10px 16px; transition:all .3s; }
.stat-badge:hover { border-color:var(--yellow); box-shadow:var(--shadow); }
.stat-badge .val { font-family:var(--font-head); font-size:1.4rem; font-weight:900; color:var(--navy); line-height:1; }
.stat-badge .lbl { font-size:.68rem; color:var(--muted); text-transform:uppercase; letter-spacing:.8px; }

/* VM CARDS */
.vm-card { background:white; border-radius:var(--radius); padding:30px 26px; border:1px solid var(--border); height:100%; transition:all .35s; position:relative; overflow:hidden; }
.vm-card::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; background:var(--yellow); transform:scaleX(0); transition:transform .35s; }
.vm-card:hover::before { transform:scaleX(1); }
.vm-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:transparent; }
.vm-icon { width:52px; height:52px; background:rgba(255,210,63,.12); border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:1.3rem; color:var(--yellow-dark); margin-bottom:18px; transition:all .3s; }
.vm-card:hover .vm-icon { background:var(--yellow); color:var(--navy-deep); }
.vm-card h4 { font-family:var(--font-head); font-weight:800; color:var(--navy); margin-bottom:10px; font-size:1.1rem; }
.vm-card p { color:var(--muted); font-size:.88rem; line-height:1.75; margin:0; }

/* REQUIREMENTS */
.req-card { background:white; border-radius:var(--radius); padding:28px; border:1px solid var(--border); height:100%; transition:all .3s; }
.req-card:hover { border-color:var(--yellow); box-shadow:var(--shadow); }
.req-badge { display:inline-block; background:var(--yellow); color:var(--navy-deep); font-weight:800; font-size:.7rem; padding:4px 14px; border-radius:20px; margin-bottom:16px; }
.req-card h4 { font-family:var(--font-head); font-weight:800; color:var(--navy); margin-bottom:18px; }
.req-list { list-style:none; padding:0; margin:0; }
.req-list li { display:flex; align-items:flex-start; gap:10px; margin-bottom:10px; font-size:.88rem; color:var(--text); line-height:1.5; }
.req-list li i { color:var(--yellow-dark); margin-top:2px; flex-shrink:0; }

/* CURRICULUM */
.curr-year { background:white; border-radius:var(--radius); border:1px solid var(--border); overflow:hidden; transition:all .3s; }
.curr-year:hover { border-color:var(--yellow); box-shadow:var(--shadow); }
.curr-year-head { background:var(--navy); color:white; padding:14px 20px; display:flex; align-items:center; gap:12px; }
.curr-year-head .yr-num { width:34px; height:34px; background:var(--yellow); color:var(--navy-deep); border-radius:8px; display:flex; align-items:center; justify-content:center; font-weight:900; font-size:.88rem; flex-shrink:0; }
.curr-year-head h5 { margin:0; color:white; font-weight:700; font-size:.92rem; }
.curr-year-body { padding:16px 20px; }
.curr-subject { display:flex; align-items:center; gap:10px; padding:7px 0; border-bottom:1px solid var(--border); font-size:.84rem; color:var(--text); }
.curr-subject:last-child { border:none; }
.curr-subject i { color:var(--yellow-dark); font-size:.78rem; flex-shrink:0; }

/* ASSESSMENT */
.assess-card { background:white; border-radius:var(--radius); padding:24px; text-align:center; border:1px solid var(--border); transition:all .3s; }
.assess-card:hover { border-color:var(--yellow); transform:translateY(-4px); box-shadow:var(--shadow); }
.assess-card .pct { font-family:var(--font-head); font-size:2.2rem; font-weight:900; color:var(--navy); line-height:1; }
.assess-card .pct span { color:var(--yellow-dark); }
.assess-card .label { font-size:.76rem; color:var(--muted); margin-top:8px; line-height:1.4; }
.assess-card.dark-card { background:var(--navy); border-color:var(--navy); }
.assess-card.dark-card .pct { color:var(--yellow); }
.assess-card.dark-card .label { color:rgba(255,255,255,.7); }
.grade-wrap { background:white; border-radius:var(--radius); overflow:hidden; border:1px solid var(--border); box-shadow:var(--shadow); }
.grade-wrap table { width:100%; border-collapse:collapse; }
.grade-wrap th { background:var(--navy); color:white; padding:12px 18px; font-size:.83rem; font-weight:600; text-align:left; }
.grade-wrap td { padding:12px 18px; font-size:.85rem; border-bottom:1px solid var(--border); }
.grade-wrap tr:last-child td { border:none; }
.grade-wrap tr:hover td { background:var(--off-white); }
.gb { display:inline-block; padding:3px 10px; border-radius:20px; font-size:.72rem; font-weight:700; }
.gb.d { background:#dcfce7; color:#15803d; }
.gb.uc { background:#dbeafe; color:#1d4ed8; }
.gb.lc { background:#fef3c7; color:#d97706; }
.gb.p { background:#e0e7ff; color:#4338ca; }
.gb.f { background:#fee2e2; color:#dc2626; }

/* LICENSING STEPS */
.license-step { display:flex; align-items:flex-start; gap:20px; margin-bottom:26px; position:relative; }
.license-step::before { content:''; position:absolute; left:25px; top:52px; width:2px; height:calc(100% + 2px); background:var(--border); }
.license-step:last-child::before { display:none; }
.lic-num { width:50px; height:50px; background:var(--navy); border-radius:14px; display:flex; align-items:center; justify-content:center; color:var(--yellow); font-weight:900; font-size:1rem; flex-shrink:0; z-index:1; position:relative; transition:all .3s; }
.license-step:hover .lic-num { background:var(--yellow); color:var(--navy-deep); transform:scale(1.08); }
.lic-content h5 { font-weight:700; color:var(--navy); margin-bottom:4px; font-size:.93rem; }
.lic-content p { color:var(--muted); font-size:.84rem; margin:0; line-height:1.6; }

/* CAREER CARDS */
.career-card { background:white; border-radius:var(--radius); padding:24px; border:1px solid var(--border); height:100%; transition:all .35s; }
.career-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-lg); border-color:var(--yellow); }
.career-icon { width:52px; height:52px; background:var(--navy); border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:1.25rem; color:var(--yellow); margin-bottom:14px; transition:all .3s; }
.career-card:hover .career-icon { background:var(--yellow); color:var(--navy-deep); transform:rotate(-5deg) scale(1.08); }
.career-card h5 { font-weight:800; color:var(--navy); margin-bottom:7px; font-size:.96rem; }
.career-card p { color:var(--muted); font-size:.83rem; margin-bottom:10px; line-height:1.6; }
.career-card .roles { font-size:.75rem; color:var(--yellow-dark); font-weight:700; line-height:1.5; }

/* COMPETENCY GRID */
.comp-card { background:white; border-radius:var(--radius); padding:20px; text-align:center; border:1px solid var(--border); transition:all .3s; }
.comp-card:hover { border-color:var(--yellow); transform:translateY(-5px); box-shadow:var(--shadow); }
.comp-card i { font-size:1.6rem; color:var(--yellow-dark); margin-bottom:10px; display:block; }
.comp-card h6 { font-weight:800; color:var(--navy); font-size:.83rem; margin-bottom:4px; }
.comp-card p { color:var(--muted); font-size:.75rem; margin:0; line-height:1.5; }

/* CTA BAND */
.cta-section { background:linear-gradient(135deg,var(--navy-deep) 0%,var(--navy) 100%); padding:clamp(60px,10vw,90px) 0; text-align:center; position:relative; overflow:hidden; }
.cta-section::before { content:''; position:absolute; top:-50%; right:-10%; width:550px; height:550px; background:radial-gradient(circle,rgba(255,210,63,.07) 0%,transparent 70%); border-radius:50%; pointer-events:none; }

/* RELATED PROGRAMME LINKS */
.other-prog-link { display:flex; align-items:center; gap:10px; padding:10px 14px; border-radius:10px; border:1px solid var(--border); margin-bottom:8px; transition:all .3s; background:white; }
.other-prog-link:hover { border-color:var(--yellow); transform:translateX(4px); box-shadow:var(--shadow); }
.other-prog-link .icon { width:36px; height:36px; background:rgba(255,210,63,.12); border-radius:8px; display:flex; align-items:center; justify-content:center; color:var(--yellow-dark); font-size:.9rem; flex-shrink:0; }
.other-prog-link .name { font-weight:700; color:var(--navy); font-size:.82rem; display:block; }
.other-prog-link .dur { font-size:.72rem; color:var(--muted); }

/* FOOTER */
footer { background:var(--navy-deep); color:rgba(255,255,255,.68); }
.footer-logo { height:56px; background:white; border-radius:10px; padding:5px; margin-bottom:18px; }
.social-icon { width:36px; height:36px; background:rgba(255,255,255,.07); border-radius:10px; display:inline-flex; align-items:center; justify-content:center; color:white; transition:.3s; font-size:.85rem; }
.social-icon:hover { background:var(--yellow); color:var(--navy); transform:translateY(-3px); }
.back-top { position:fixed; bottom:24px; right:24px; width:44px; height:44px; background:var(--yellow); color:var(--navy-deep); border-radius:50px; display:flex; align-items:center; justify-content:center; opacity:0; visibility:hidden; transition:.3s; z-index:999; box-shadow:0 4px 14px rgba(0,0,0,.18); }
.back-top.show { opacity:1; visibility:visible; }

/* RESPONSIVE */
@media(max-width:767px){
  .prog-hero { padding:80px 0 50px; }
  .hero-img-card { margin-top:28px; }
  .hero-img-card img { height:240px; }
}
@media(max-width:575px){
  .vm-card, .req-card, .career-card { padding:18px 14px; }
  .curr-year-body { padding:12px 14px; }
  .prog-meta { gap:7px; }
  .meta-chip { font-size:.73rem; padding:8px 11px; }
}
