/*
Theme Name: UNISTEM College
Theme URI: https://unistem.lk
Author: UNISTEM College
Description: Official WordPress theme for UNISTEM College
Version: 3.0.0
Text Domain: unistem
*/

/* ============================================================
   GT WALSHEIM SELF-HOSTED (uncomment after purchase)
   https://www.grillitype.com/typeface/gt-walsheim
   Upload to /wp-content/themes/unistem-theme/fonts/
   ============================================================ */
/*
@font-face { font-family:'GT Walsheim'; src:url('fonts/GT-Walsheim-Regular.woff2') format('woff2'); font-weight:400; font-display:swap; }
@font-face { font-family:'GT Walsheim'; src:url('fonts/GT-Walsheim-Bold.woff2') format('woff2'); font-weight:700; font-display:swap; }
@font-face { font-family:'GT Walsheim'; src:url('fonts/GT-Walsheim-Ultra-Bold.woff2') format('woff2'); font-weight:800; font-display:swap; }
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  --navy:       #0B2D6E;
  --navy-mid:   #1a3f8f;
  --teal:       #00A3C4;
  --teal-light: #e8f7fb;
  --red:        #E8303A;
  --gold:       #F4A623;
  --ink:        #111827;
  --body-c:     #374151;
  --muted:      #6B7280;
  --border:     #E5E7EB;
  --surface:    #F9FAFB;
  --white:      #FFFFFF;

  --font-head: 'Sora', 'GT Walsheim', system-ui, sans-serif;
  --font-body: 'DM Sans', system-ui, sans-serif;

  --sec:    3rem;
  --sec-sm: 2rem;
  --sec-lg: 4.5rem;

  --container: 1200px;
  --nav-h:     70px;

  --r-sm:   6px;
  --r-md:   10px;
  --r-lg:   16px;
  --r-xl:   24px;
  --r-pill: 9999px;

  --sh-sm: 0 2px 8px rgba(0,0,0,.07);
  --sh-md: 0 6px 24px rgba(0,0,0,.10);
  --sh-lg: 0 16px 48px rgba(0,0,0,.14);

  --ease: cubic-bezier(0.16,1,0.3,1);
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--font-body);font-size:16px;line-height:1.65;color:var(--body-c);background:var(--white);overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1,h2,h3,h4,h5,h6{font-family:var(--font-head);font-weight:800;line-height:1.15;color:var(--ink);letter-spacing:-.02em}
h1{font-size:clamp(2.2rem,5vw,3.5rem)}
h2{font-size:clamp(1.7rem,3.5vw,2.5rem)}
h3{font-size:clamp(1.2rem,2vw,1.5rem);font-weight:700}
h4{font-size:1.1rem;font-weight:700;letter-spacing:-.01em}
h5{font-size:.95rem;font-weight:600}
p{margin-bottom:.9rem;color:var(--body-c)}
p:last-child{margin-bottom:0}
.lead{font-size:1.1rem;line-height:1.7;color:var(--muted)}

/* ============================================================
   LAYOUT
   ============================================================ */
.container{max-width:var(--container);margin:0 auto;padding:0 1.5rem}
.section{padding:var(--sec) 0;background:var(--white)}
.section--tint{background:var(--surface)}
.section--navy{background:var(--navy)}
.section--compact{padding:var(--sec-sm) 0}

.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}

.section-header{text-align:center;margin-bottom:2rem;max-width:680px;margin-left:auto;margin-right:auto}
.section-header h2{margin-bottom:.6rem}
.section-header p{font-size:1rem;color:var(--muted);margin:0}

.eyebrow{display:inline-block;font-family:var(--font-body);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);margin-bottom:.6rem}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.65rem 1.5rem;border-radius:var(--r-pill);font-family:var(--font-head);font-weight:700;font-size:.875rem;transition:all .2s var(--ease);white-space:nowrap;border:2px solid transparent;cursor:pointer}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--navy);color:var(--white)}
.btn-primary:hover{background:var(--navy-mid);transform:translateY(-2px);box-shadow:var(--sh-md)}
.btn-teal{background:var(--teal);color:var(--white)}
.btn-teal:hover{filter:brightness(1.08);transform:translateY(-2px)}
.btn-accent{background:var(--red);color:var(--white)}
.btn-accent:hover{filter:brightness(1.08);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--white);border-color:rgba(255,255,255,.55)}
.btn-outline:hover{background:rgba(255,255,255,.12);border-color:var(--white)}
.btn-outline-dark{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-outline-dark:hover{background:var(--navy);color:var(--white)}
.btn-lg{padding:.85rem 1.9rem;font-size:.95rem}
.btn-sm{padding:.45rem 1.1rem;font-size:.8rem}

/* ============================================================
   NAVIGATION
   ============================================================ */
#site-header{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);background:rgba(255,255,255,.97);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:box-shadow .2s}
#site-header.scrolled{box-shadow:var(--sh-sm)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:100%;gap:1.5rem}

.site-logo{display:flex;align-items:center;gap:.65rem;flex-shrink:0;text-decoration:none}
.site-logo-mark{width:38px;height:38px;border-radius:var(--r-sm);background:var(--navy);color:var(--white);font-family:var(--font-head);font-weight:800;font-size:.85rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.site-logo img{height:38px;width:auto}
.site-logo-text strong{display:block;font-family:var(--font-head);font-size:.95rem;font-weight:800;color:var(--ink);letter-spacing:-.02em;line-height:1.1}
.site-logo-text span{font-size:.62rem;color:var(--muted);font-weight:500;letter-spacing:.03em}

.main-nav{display:flex;align-items:center}
.main-nav a{padding:.4rem .8rem;border-radius:var(--r-sm);font-family:var(--font-body);font-size:.85rem;font-weight:600;color:var(--body-c);transition:color .15s,background .15s}
.main-nav a:hover,.main-nav a.active{color:var(--navy);background:var(--surface)}
.nav-cta{display:flex;align-items:center;gap:.6rem;flex-shrink:0}

.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;padding:6px;cursor:pointer;background:none;border:none}
.hamburger span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:all .22s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}

.mobile-nav{position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;background:var(--white);z-index:999;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.2rem;transform:translateX(-100%);transition:transform .32s var(--ease);overflow-y:auto;border-top:1px solid var(--border)}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav a{display:block;padding:.8rem 1rem;font-family:var(--font-body);font-weight:600;font-size:.95rem;color:var(--ink);border-radius:var(--r-md);border-bottom:1px solid var(--border)}
.mobile-nav a:hover{background:var(--surface)}
.mobile-nav .btn{display:flex;justify-content:center;margin-top:.75rem}

/* ============================================================
   HERO — background image support
   ============================================================ */
.hero{
  min-height:100vh;
  background-color:var(--navy);
  background-image:url('images/hero-bg.jpg');
  background-size:cover;background-position:center top;
  background-blend-mode:multiply;
  display:flex;align-items:center;
  padding-top:var(--nav-h);
  position:relative;overflow:hidden;
}
.hero::before{content:'';position:absolute;inset:0;z-index:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:55px 55px}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:160px;z-index:0;background:linear-gradient(transparent,rgba(11,45,110,.4))}

.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;padding:4rem 0;width:100%}

.hero-eyebrow{display:inline-flex;align-items:center;gap:.45rem;background:rgba(0,163,196,.18);border:1px solid rgba(0,163,196,.35);color:#7de8f7;font-family:var(--font-body);font-size:.74rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;padding:.32rem .85rem;border-radius:var(--r-pill);margin-bottom:1.1rem}
.hero-content h1{color:var(--white);margin-bottom:1rem}
.hero-content h1 em{font-style:normal;color:#7de8f7}
.hero-content .lead{color:rgba(255,255,255,.75);margin-bottom:1.75rem;max-width:480px}
.hero-actions{display:flex;flex-wrap:wrap;gap:.7rem;margin-bottom:2.5rem}
.hero-stats{display:flex;gap:2rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.12)}
.hero-stat strong{display:block;font-family:var(--font-head);font-size:1.8rem;font-weight:800;color:var(--white);letter-spacing:-.03em;line-height:1}
.hero-stat span{font-size:.74rem;color:rgba(255,255,255,.5);font-weight:500;display:block;margin-top:.2rem}

/* PATHWAY CARD — right of hero, with bg image placeholder */
.hero-visual{position:relative}
.hero-card{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  border-radius:var(--r-xl);padding:1.75rem;
  backdrop-filter:blur(10px);
  /* Upload campus/students photo here */
  background-image:url('images/pathway-card-bg.jpg');
  background-size:cover;background-position:center;
  background-blend-mode:overlay;
}
.hero-card-label{font-family:var(--font-body);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.65);margin-bottom:1rem}
.pathway-steps{display:flex;flex-direction:column}
.pathway-step{display:flex;align-items:center;gap:.8rem;padding:.8rem 0;border-bottom:1px solid rgba(255,255,255,.08)}
.pathway-step:last-child{border-bottom:none}
.step-num{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:800;font-size:.7rem;flex-shrink:0}
.s1{background:rgba(0,163,196,.25);color:#7de8f7}
.s2{background:rgba(244,166,35,.22);color:#fcd34d}
.s3{background:rgba(232,48,58,.18);color:#fca5a5}
.s5{background:rgba(255,255,255,.18);color:var(--white)}
.step-info strong{display:block;font-family:var(--font-head);font-size:.82rem;font-weight:700;color:var(--white);line-height:1.3}
.step-info span{font-size:.7rem;color:rgba(255,255,255,.45)}
.step-badge{margin-left:auto;font-family:var(--font-body);font-size:.63rem;font-weight:700;padding:.18rem .55rem;border-radius:var(--r-pill);background:rgba(72,200,120,.2);color:#6ee7b7;border:1px solid rgba(72,200,120,.3);flex-shrink:0}
.hero-card-footer{margin-top:1.1rem;padding-top:1.1rem;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between}
.hero-card-footer span{font-size:.75rem;color:rgba(255,255,255,.45)}
.hero-card-footer strong{font-family:var(--font-head);font-size:1rem;font-weight:800;color:#fcd34d}

.floating-badge{position:absolute;background:var(--white);border-radius:var(--r-lg);padding:.8rem 1rem;box-shadow:var(--sh-lg);display:flex;align-items:center;gap:.65rem;animation:float 4s ease-in-out infinite}
.floating-badge.b1{top:-14px;right:-14px}
.floating-badge.b2{bottom:20px;left:-22px;animation-delay:-2s}
.badge-icon{width:30px;height:30px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:.95rem}
.badge-icon.teal{background:var(--teal-light)}
.badge-icon.gold{background:#fef3c7}
.badge-text strong{display:block;font-family:var(--font-head);font-size:.75rem;font-weight:700;color:var(--ink);line-height:1.2}
.badge-text span{font-size:.64rem;color:var(--muted)}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}

/* ============================================================
   PAGE HERO — inner pages, per-page background image
   ============================================================ */
.page-hero{
  background-color:var(--navy);
  background-image:url('images/page-hero-bg.jpg');
  background-size:cover;background-position:center;
  background-blend-mode:multiply;
  padding:calc(var(--nav-h) + 3rem) 0 3rem;
  position:relative;overflow:hidden;
}
.page-hero.about-hero    {background-image:url('images/about-hero.jpg')}
.page-hero.prog-hero     {background-image:url('images/programmes-hero.jpg')}
.page-hero.degrees-hero  {background-image:url('images/degrees-hero.jpg')}
.page-hero.admissions-hero{background-image:url('images/admissions-hero.jpg')}
.page-hero.life-hero     {background-image:url('images/student-life-hero.jpg')}
.page-hero.testi-hero    {background-image:url('images/testimonials-hero.jpg')}
.page-hero.contact-hero  {background-image:url('images/contact-hero.jpg')}
.page-hero::before{content:'';position:absolute;inset:0;z-index:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:50px 50px}
.page-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:100px;background:linear-gradient(transparent,rgba(11,45,110,.4))}
.page-hero-inner{position:relative;z-index:2;text-align:center}
.page-hero h1{color:var(--white);margin-bottom:.75rem;text-shadow:0 2px 12px rgba(0,0,0,.25)}
.page-hero p{color:rgba(255,255,255,.75);max-width:560px;margin:0 auto;font-size:1rem}
.breadcrumb{display:flex;align-items:center;gap:.4rem;justify-content:center;margin-bottom:.75rem;font-size:.76rem;color:rgba(255,255,255,.45)}
.breadcrumb a{color:rgba(255,255,255,.65)}
.breadcrumb a:hover{color:var(--white)}
.breadcrumb-sep{opacity:.4}

/* ============================================================
   LOGO STRIP
   ============================================================ */
.logo-strip{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:1.25rem 0}
.logo-strip-inner{display:flex;align-items:center;gap:2rem;flex-wrap:wrap;justify-content:center}
.logo-strip-label{font-family:var(--font-body);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);white-space:nowrap}
.partner-logo{display:flex;align-items:center;gap:.45rem;opacity:.5;transition:opacity .15s;filter:grayscale(1)}
.partner-logo:hover{opacity:.95;filter:grayscale(0)}
.partner-mark{width:34px;height:34px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:800;color:var(--white);flex-shrink:0}
.partner-mark.pearson{background:#005A8E}
.partner-mark.uon{background:#003A70}
.partner-mark.tvec{background:#007B5E}
.partner-mark.mqa{background:#1a3a6e}
.partner-mark.murdoch{background:#8C1515}
.partner-name-wrap strong{display:block;font-family:var(--font-head);font-size:.78rem;font-weight:700;color:var(--ink);line-height:1.2}
.partner-name-wrap span{font-size:.65rem;color:var(--muted)}

/* ============================================================
   STATS ROW
   ============================================================ */
.stats-row{padding:2.5rem 0;background:var(--navy)}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-cell{text-align:center;padding:1rem;border-right:1px solid rgba(255,255,255,.1)}
.stat-cell:last-child{border-right:none}
.stat-num{display:block;font-family:var(--font-head);font-size:2.2rem;font-weight:800;color:var(--white);letter-spacing:-.03em;line-height:1;margin-bottom:.3rem}
.stat-label{font-size:.78rem;color:rgba(255,255,255,.55);font-weight:500}

/* ============================================================
   PATHWAY TABS
   ============================================================ */
.tab-row{display:flex;gap:.3rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-pill);padding:.28rem;max-width:fit-content;margin:0 auto 2rem}
.tab-btn{padding:.5rem 1.35rem;border-radius:var(--r-pill);font-family:var(--font-head);font-weight:700;font-size:.84rem;color:var(--muted);cursor:pointer;transition:all .2s;background:none;border:none}
.tab-btn.active{background:var(--navy);color:var(--white)}
.tab-panel{display:none}
.tab-panel.active{display:block}

.timeline{display:flex;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.tl-step{flex:1;padding:1.25rem 1rem;border-right:1px solid var(--border);background:var(--white);transition:background .15s}
.tl-step:hover{background:var(--surface)}
.tl-step:last-child{border-right:none}
.tl-year{font-family:var(--font-body);font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--teal);margin-bottom:.4rem}
.tl-title{font-family:var(--font-head);font-weight:700;font-size:.84rem;color:var(--ink);margin-bottom:.28rem;line-height:1.3}
.tl-eq{display:inline-block;background:var(--teal-light);color:var(--teal);font-size:.66rem;font-weight:700;padding:.12rem .5rem;border-radius:var(--r-pill);margin-bottom:.28rem}
.tl-dur{font-size:.7rem;color:var(--muted)}
.tl-step.final{background:var(--navy)}
.tl-step.final:hover{background:var(--navy-mid)}
.tl-step.final .tl-year{color:rgba(255,255,255,.5)}
.tl-step.final .tl-title{color:var(--white)}
.tl-step.final .tl-dur{color:rgba(255,255,255,.45)}
.tl-step.final .tl-eq{background:rgba(252,211,77,.15);color:#fcd34d}
.tl-badge{display:block;background:var(--red);color:var(--white);font-size:.7rem;font-weight:700;text-align:center;padding:.28rem 0;margin-top:.65rem;border-radius:var(--r-sm)}

/* ============================================================
   PROGRAMME CARDS — with image placeholder at top
   ============================================================ */
.prog-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:1.1rem}
.prog-card{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:all .25s var(--ease);background:var(--white);display:flex;flex-direction:column}
.prog-card:hover{border-color:var(--navy);box-shadow:var(--sh-md);transform:translateY(-3px)}

.prog-card-img{
  height:200px;
  background-color:#1a3a6e;
  background-image:url('images/fulltime-programme.jpg');
  background-size:cover;background-position:center;
  position:relative;
}
.prog-card-img.pt{background-color:#1b3a5c;background-image:url('images/parttime-programme.jpg')}
.prog-card-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(transparent 40%,rgba(11,45,110,.65));
}
.prog-card-img-label{
  position:absolute;bottom:0;left:0;right:0;z-index:1;
  padding:.9rem 1.25rem;
  color:var(--white);
  font-family:var(--font-body);font-size:.72rem;font-weight:600;letter-spacing:.06em;
}

.prog-card-head{padding:1.25rem 1.5rem 0;display:flex;gap:.9rem;align-items:flex-start}
.prog-icon{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.prog-icon.ft{background:#e8f4fd}
.prog-icon.pt{background:#fef3c7}
.prog-schedule{display:flex;align-items:center;gap:.3rem;font-family:var(--font-body);font-size:.74rem;font-weight:600;color:var(--teal);margin-top:.25rem}
.prog-card-body{padding:1rem 1.5rem 1.5rem;flex:1;display:flex;flex-direction:column}
.prog-features{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1.25rem;flex:1}
.prog-feature{display:flex;gap:.55rem;font-size:.85rem;color:var(--body-c);align-items:flex-start;line-height:1.5}
.prog-feature::before{content:'✓';width:17px;height:17px;border-radius:50%;background:var(--teal-light);color:var(--teal);font-size:.68rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.12rem}

/* ============================================================
   WHY CARDS
   ============================================================ */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem}
.why-card{padding:1.35rem;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--white);transition:all .22s var(--ease)}
.why-card:hover{border-color:var(--navy);box-shadow:var(--sh-sm);transform:translateY(-2px)}
.why-icon{font-size:1.5rem;margin-bottom:.6rem;display:block}
.why-card h4{font-size:.9rem;margin-bottom:.35rem;color:var(--ink)}
.why-card p{font-size:.82rem;line-height:1.6;margin:0}

/* ============================================================
   DEGREE CARDS — image placeholder per subject
   ============================================================ */
.degrees-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.85rem}
.degree-card{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:all .2s var(--ease);background:var(--white);display:flex;flex-direction:column}
.degree-card:hover{border-color:var(--teal);box-shadow:var(--sh-sm);transform:translateY(-2px)}

.degree-card-img{
  height:100px;
  background-size:cover;background-position:center top;
  position:relative;display:flex;align-items:flex-end;padding:.6rem;
}
/* Distinct colour per subject (replaced by photo when uploaded) */
.deg-bms{background-color:#1e3a5f;background-image:url('images/deg-business-strategy.jpg')}
.deg-bai{background-color:#0f4c75;background-image:url('images/deg-ai-analytics.jpg')}
.deg-hrm{background-color:#2d6a4f;background-image:url('images/deg-hrm.jpg')}
.deg-tou{background-color:#1a6b8a;background-image:url('images/deg-tourism.jpg')}
.deg-mkt{background-color:#7b2d8b;background-image:url('images/deg-marketing.jpg')}
.deg-log{background-color:#8a3a00;background-image:url('images/deg-logistics.jpg')}
.deg-acc{background-color:#1b4332;background-image:url('images/deg-accounting.jpg')}
.deg-bnk{background-color:#1a3a6e;background-image:url('images/deg-banking.jpg')}
.deg-pm {background-color:#3d2c8d;background-image:url('images/deg-project-mgmt.jpg')}
.deg-psy{background-color:#6d2b2b;background-image:url('images/deg-psychology.jpg')}
.degree-card-img::after{content:'';position:absolute;inset:0;background:linear-gradient(transparent 30%,rgba(0,0,0,.45))}
.degree-img-label{position:relative;z-index:1;font-family:var(--font-body);font-size:.6rem;font-weight:700;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.06em}

.degree-card-body{padding:.9rem}
.degree-type{font-family:var(--font-body);font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--teal);margin-bottom:.32rem}
.degree-name{font-family:var(--font-head);font-size:.84rem;font-weight:700;color:var(--ink);line-height:1.35}
.degree-uni{font-size:.7rem;color:var(--muted);margin-top:.38rem}

/* ============================================================
   LEADERSHIP CARDS
   ============================================================ */
.leaders-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.leader-card{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:all .25s var(--ease);background:var(--white)}
.leader-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.leader-photo{aspect-ratio:4/3;background-color:#c8d8f0;background-image:url('images/leader-placeholder.jpg');background-size:cover;background-position:top center;overflow:hidden;position:relative;min-height:160px}
.leader-photo img{width:100%;height:100%;object-fit:cover;object-position:top}
.leader-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--navy),var(--teal));color:rgba(255,255,255,.4);font-size:3rem;min-height:160px}
.leader-body{padding:1.1rem}
.leader-name{font-size:.95rem;margin-bottom:.18rem;color:var(--ink)}
.leader-role{font-family:var(--font-body);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--teal);margin-bottom:.6rem}
.leader-bio{font-size:.8rem;line-height:1.65;color:var(--body-c)}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonials-section{background:var(--navy)}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.testi-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);padding:1.5rem;transition:all .22s var(--ease)}
.testi-card:hover{background:rgba(255,255,255,.11);transform:translateY(-3px)}
.testi-quote{font-size:1.8rem;line-height:1;color:var(--teal);margin-bottom:.5rem}
.testi-text{font-size:.84rem;line-height:1.7;color:rgba(255,255,255,.78);font-style:italic;margin-bottom:1.1rem}
.testi-author{display:flex;align-items:center;gap:.7rem}
.testi-avatar{width:38px;height:38px;border-radius:50%;overflow:hidden;background:rgba(255,255,255,.14);color:var(--white);font-family:var(--font-head);font-weight:700;font-size:.78rem;display:flex;align-items:center;justify-content:center;border:1.5px solid rgba(255,255,255,.22);flex-shrink:0}
.testi-avatar img{width:100%;height:100%;object-fit:cover}
.testi-name{display:block;font-family:var(--font-head);font-size:.82rem;font-weight:700;color:var(--white)}
.testi-role{font-size:.7rem;color:rgba(255,255,255,.5)}

/* ============================================================
   ENTRY CARDS (Admissions) — with image
   ============================================================ */
.entry-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.entry-card{border:2px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:all .25s var(--ease);background:var(--white);display:flex;flex-direction:column}
.entry-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:var(--navy)}

.entry-card-img{height:140px;background-size:cover;background-position:center;position:relative}
.entry-card-img::after{content:'';position:absolute;inset:0;background:linear-gradient(transparent 40%,rgba(0,0,0,.45))}
.entry-card-img.grade8{background-color:#0f4c75;background-image:url('images/entry-grade8.jpg')}
.entry-card-img.ol    {background-color:#1b4332;background-image:url('images/entry-ol.jpg')}
.entry-card-img.al    {background-color:#3d2c8d;background-image:url('images/entry-al.jpg')}

.entry-card-body{padding:1.4rem;text-align:center;flex:1;display:flex;flex-direction:column;align-items:center}
.entry-icon{font-size:1.8rem;margin-bottom:.5rem}
.entry-dur{display:inline-block;background:var(--surface);color:var(--navy);font-family:var(--font-head);font-weight:800;font-size:1.2rem;padding:.25rem .9rem;border-radius:var(--r-pill);margin:.6rem 0;letter-spacing:-.02em}
.entry-badge{display:inline-block;font-family:var(--font-body);font-size:.68rem;font-weight:700;padding:.18rem .65rem;border-radius:var(--r-pill);border:1.5px solid;margin-bottom:.6rem}
.entry-badge.teal{color:var(--teal);border-color:rgba(0,163,196,.3);background:var(--teal-light)}
.entry-badge.navy{color:var(--navy);border-color:rgba(11,45,110,.2);background:#eef2fb}
.entry-badge.red {color:var(--red); border-color:rgba(232,48,58,.22);background:#fef2f2}

/* ============================================================
   COMPARISON TABLE
   ============================================================ */
.comparison{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.comparison-head{display:grid;grid-template-columns:1.6fr 1fr 1fr;background:var(--navy)}
.comparison-head>div{padding:.9rem 1.1rem;font-family:var(--font-head);font-weight:700;font-size:.84rem;color:var(--white)}
.comparison-head .hs{background:var(--teal)}
.comparison-row{display:grid;grid-template-columns:1.6fr 1fr 1fr;border-bottom:1px solid var(--border)}
.comparison-row:last-child{border-bottom:none}
.comparison-row:nth-child(even){background:var(--surface)}
.comparison-row>div{padding:.8rem 1.1rem;font-size:.82rem;display:flex;align-items:center;gap:.38rem}
.comparison-row>div:nth-child(3){font-weight:700;color:var(--navy);background:rgba(0,163,196,.04)}
.ok{color:#16a34a;font-size:.95rem}
.nok{color:#dc2626;font-size:.95rem}

/* ============================================================
   ACCREDITATIONS
   ============================================================ */
.accred-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.9rem}
.accred-card{border:1px solid var(--border);border-radius:var(--r-lg);padding:1.35rem 1.1rem;text-align:center;background:var(--white);transition:all .2s var(--ease)}
.accred-card:hover{transform:translateY(-3px);box-shadow:var(--sh-sm);border-color:var(--teal)}
.accred-mark{width:48px;height:48px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:800;color:var(--white);margin:0 auto .8rem}
.accred-card h4{font-size:.82rem;margin-bottom:.28rem;color:var(--ink)}
.accred-card p{font-size:.72rem;color:var(--muted);margin:0}

/* ============================================================
   GALLERY — Student Life (image grid)
   ============================================================ */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.65rem}
.gallery-item{border-radius:var(--r-md);overflow:hidden;aspect-ratio:1;position:relative;background:#c8d8f0}
.gallery-item.wide{grid-column:span 2;aspect-ratio:2/1}
.gallery-fill{width:100%;height:100%;background:linear-gradient(135deg,var(--navy),var(--teal));display:flex;align-items:center;justify-content:center;font-size:1.8rem;transition:transform .38s var(--ease)}
.gallery-item img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .38s var(--ease)}
.gallery-item:hover .gallery-fill,
.gallery-item:hover img{transform:scale(1.04)}
.gallery-overlay{position:absolute;inset:0;background:linear-gradient(transparent 45%,rgba(0,0,0,.62));display:flex;align-items:flex-end;padding:.75rem;opacity:0;transition:opacity .2s}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-overlay span{font-family:var(--font-body);font-size:.78rem;font-weight:600;color:var(--white)}

/* ============================================================
   CONTACT & FORM
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:3rem;align-items:start}
.contact-detail{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.9rem}
.contact-icon{width:38px;height:38px;border-radius:var(--r-md);background:var(--navy);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0}
.contact-detail strong{display:block;font-family:var(--font-body);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:.18rem}
.contact-detail a,.contact-detail span{font-size:.9rem;color:var(--ink);font-weight:500}
.contact-detail a:hover{color:var(--teal)}

.form-wrap{background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);padding:2rem;box-shadow:var(--sh-sm)}
.form-wrap h3{font-size:1.25rem;margin-bottom:.35rem}
.form-wrap>p{font-family:var(--font-body);font-size:.85rem;color:var(--muted);margin-bottom:1.35rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.form-group{margin-bottom:.8rem}
.form-group label{display:block;font-family:var(--font-body);font-size:.76rem;font-weight:600;color:var(--body-c);margin-bottom:.3rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.65rem .85rem;border:1.5px solid var(--border);border-radius:var(--r-md);font-family:var(--font-body);font-size:.86rem;color:var(--ink);background:var(--white);transition:border-color .15s,box-shadow .15s;outline:none;-webkit-appearance:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(11,45,110,.08)}
.form-group textarea{resize:vertical;min-height:95px}
.form-success{display:none;text-align:center;padding:2rem 1rem}
.form-success-icon{font-size:2.5rem;margin-bottom:.7rem}

.hours-box{background:var(--navy);border-radius:var(--r-md);padding:1.1rem 1.35rem;margin-bottom:1.1rem}
.hours-box h4{color:var(--white);margin-bottom:.55rem;font-size:.9rem}
.hours-row{display:flex;justify-content:space-between;font-size:.82rem;color:rgba(255,255,255,.7);margin-bottom:.28rem}
.hours-row span:last-child{font-weight:600;color:var(--white)}
.hours-row.closed span:last-child{color:rgba(255,255,255,.35);font-weight:400}

/* ============================================================
   CTA BANNER — background image support
   ============================================================ */
.cta-banner{background-color:var(--navy);background-image:url('images/cta-bg.jpg');background-size:cover;background-position:center;background-blend-mode:multiply;padding:4rem 0;text-align:center;position:relative;overflow:hidden}
.cta-banner::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:48px 48px}
.cta-banner-inner{position:relative;z-index:1}
.cta-banner h2{color:var(--white);margin-bottom:.8rem}
.cta-banner p{color:rgba(255,255,255,.75);font-size:1rem;margin-bottom:1.75rem;max-width:560px;margin-left:auto;margin-right:auto}
.cta-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}

/* ============================================================
   FOOTER
   ============================================================ */
#site-footer{background:var(--ink);color:rgba(255,255,255,.6);padding:3.5rem 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2.25rem;margin-bottom:2.5rem}
.footer-brand p{font-size:.82rem;line-height:1.7;color:rgba(255,255,255,.42);margin:1rem 0 1.1rem;max-width:270px}
.footer-social{display:flex;gap:.45rem}
.social-link{width:32px;height:32px;border-radius:var(--r-sm);background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:.82rem;color:rgba(255,255,255,.5);transition:all .15s}
.social-link:hover{background:var(--teal);border-color:var(--teal);color:var(--white)}
.footer-col h5{font-family:var(--font-body);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.32);margin-bottom:.9rem}
.footer-links{display:flex;flex-direction:column;gap:.45rem}
.footer-links a{font-size:.82rem;color:rgba(255,255,255,.52);transition:color .15s}
.footer-links a:hover{color:var(--white)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding:1.1rem 0;display:flex;align-items:center;justify-content:space-between}
.footer-bottom p{font-size:.78rem;color:rgba(255,255,255,.28);margin:0}

.scroll-top{position:fixed;bottom:75px;right:1.1rem;width:38px;height:38px;background:var(--navy);color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.95rem;box-shadow:var(--sh-md);cursor:pointer;opacity:0;transform:translateY(8px);transition:all .2s;z-index:998;border:none}
.scroll-top.visible{opacity:1;transform:translateY(0)}
.scroll-top:hover{background:var(--teal)}

/* ============================================================
   RESPONSIVE — TABLET ≤ 1024px
   ============================================================ */
@media(max-width:1024px){
  .hero-inner{gap:2rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .accred-grid{grid-template-columns:repeat(3,1fr)}
  .degrees-grid{grid-template-columns:repeat(2,1fr)}
}

/* ============================================================
   RESPONSIVE — SMALL TABLET ≤ 900px
   ============================================================ */
@media(max-width:900px){
  :root{--sec:2.25rem;--sec-sm:1.5rem}
  .main-nav,.nav-cta{display:none}
  .hamburger{display:flex}

  /* Hero stacks */
  .hero-inner{grid-template-columns:1fr;text-align:center;padding:3rem 0}
  .hero-visual{display:none}
  .hero-actions,.hero-stats{justify-content:center}
  .hero-content .lead{max-width:100%}

  .why-grid{grid-template-columns:repeat(2,1fr)}
  .degrees-grid{grid-template-columns:repeat(2,1fr)}
  .leaders-grid{grid-template-columns:repeat(2,1fr)}
  .entry-cards{grid-template-columns:repeat(2,1fr)}
  .testimonials-grid{grid-template-columns:repeat(2,1fr)}
  .prog-cards{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:2rem}
  .accred-grid{grid-template-columns:repeat(2,1fr)}

  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .stat-cell{border-right:none;border-bottom:1px solid rgba(255,255,255,.08)}
  .stat-cell:nth-child(odd){border-right:1px solid rgba(255,255,255,.08)}
  .stat-cell:nth-last-child(-n+2){border-bottom:none}

  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-item.wide{grid-column:span 1;aspect-ratio:1}

  /* Timeline scrollable on tablet */
  .timeline{flex-direction:column}
  .tl-step{border-right:none;border-bottom:1px solid var(--border)}
  .tl-step:last-child{border-bottom:none}

  .comparison{overflow-x:auto}
  .comparison-head,.comparison-row{min-width:500px}
}

/* ============================================================
   RESPONSIVE — MOBILE ≤ 640px
   ============================================================ */
@media(max-width:640px){
  :root{--sec:1.75rem;--nav-h:62px}

  h1{font-size:2rem}
  h2{font-size:1.55rem}

  .why-grid,.degrees-grid,.leaders-grid,
  .entry-cards,.testimonials-grid,.accred-grid{grid-template-columns:1fr}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}

  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .stat-num{font-size:1.8rem}
  .stat-cell:nth-child(odd){border-right:1px solid rgba(255,255,255,.08)}

  .hero-stats{flex-wrap:wrap;gap:1rem;justify-content:center}
  .hero-stat{min-width:120px;text-align:center}

  .footer-grid{grid-template-columns:1fr;gap:1.5rem}
  .footer-bottom{flex-direction:column;gap:.5rem;text-align:center}

  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-item.wide{grid-column:span 1;aspect-ratio:1}

  .cta-actions{flex-direction:column;align-items:center}
  .cta-actions .btn{width:100%;max-width:300px;justify-content:center}

  .logo-strip-inner{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;padding:0 .5rem}
  .partner-name-wrap{display:none}
  .site-logo-text span{display:none}

  .section-header{margin-bottom:1.5rem}
  .degree-card-img{height:80px}

  .comparison-head,.comparison-row{min-width:440px}
  .comparison-head>div,.comparison-row>div{padding:.6rem .75rem;font-size:.78rem}

  .tab-row{max-width:100%;border-radius:var(--r-lg)}
  .tab-btn{font-size:.8rem;padding:.45rem 1rem}

  .prog-card-img{height:160px}
}

/* ============================================================
   UTILITY
   ============================================================ */
.text-center{text-align:center}
.text-white{color:var(--white)!important}
.mt-1{margin-top:.75rem}.mt-2{margin-top:1.5rem}.mt-3{margin-top:2rem}
.mb-1{margin-bottom:.75rem}.mb-2{margin-bottom:1.5rem}
