/* ============================================================
   NWT Business School | nwtbs.com
   Design system: Navy #00338D / Sky Blue #0091D6 (from official logo)
   Display: Archivo · Body: Spline Sans · Utility: Space Grotesk
   ============================================================ */

:root{
  --navy-950:#00133A;
  --navy-900:#001C54;
  --navy-700:#00338D; /* Logo Navy Blue */
  --navy-600:#0A43B2;
  --blue-500:#1E55C8;
  --teal-500:#0091D6; /* Logo Sky Blue */
  --teal-400:#33A2FF; /* Light Sky Blue */
  --teal-200:#BCE2FF; /* Sky Blue Chip */
  --teal-100:#F0F8FF; /* Sky Blue Wash */
  --paper:#F6F8FB;
  --white:#FFFFFF;
  --ink:#001133;
  --grey-600:#5A6478;
  --grey-300:#D8DEE9;
  --gold:#F2B705;

  --ff-display:"Archivo",system-ui,sans-serif;
  --ff-body:"Spline Sans",system-ui,sans-serif;
  --ff-mono:"Space Grotesk","SF Mono",monospace;

  --maxw:1180px;
  --radius:14px;
  --shadow-card:0 6px 24px rgba(10,31,77,.08);
  --shadow-lift:0 18px 48px rgba(10,31,77,.16);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden !important;width:100% !important}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001s!important;transition-duration:.001s!important}
}

body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--white);
  line-height:1.65;
  font-size:1.0rem;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden !important;
  width:100% !important;
}
main{overflow-x:hidden;position:relative;z-index:1;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
:focus-visible{outline:3px solid var(--teal-400);outline-offset:3px;border-radius:4px}

.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- Type ---------- */
h1,h2,h3,h4{font-family:var(--ff-display);line-height:1.08;letter-spacing:-.02em;color:var(--navy-900)}
.display-xl{font-size:clamp(2.6rem,6vw,4.6rem);font-weight:900;text-transform:uppercase;letter-spacing:-.025em}
.display-lg{font-size:clamp(2rem,4.2vw,3.2rem);font-weight:800}
.display-md{font-size:clamp(1.5rem,2.8vw,2.1rem);font-weight:800}
.lede{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--grey-600);max-width:58ch}

.eyebrow{
  font-family:var(--ff-mono);
  font-size:.78rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.22em;
  color:var(--teal-500);
  display:inline-flex;
  align-items:center;
  gap:.6em;
  max-width:100%;
  flex-wrap:wrap;
}
.eyebrow::before{
  content:"";
  width:10px;height:10px;
  background:
    linear-gradient(var(--navy-700),var(--navy-700)) 0 0/5px 5px no-repeat,
    linear-gradient(var(--teal-400),var(--teal-400)) 5px 5px/5px 5px no-repeat;
}
.on-dark .eyebrow,.eyebrow.light{color:var(--teal-200)}

/* ---------- Pixel mosaic (brand signature) ---------- */
.mosaic{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;width:120px}
.mosaic span{aspect-ratio:1;background:var(--teal-400);opacity:0}
.mosaic span:nth-child(3n){background:var(--navy-700)}
.mosaic span:nth-child(7n){background:var(--teal-200)}
.mosaic.play span{animation:px-in .5s ease forwards}
.mosaic.play span:nth-child(1){animation-delay:.05s}.mosaic.play span:nth-child(2){animation-delay:.30s}
.mosaic.play span:nth-child(3){animation-delay:.15s}.mosaic.play span:nth-child(4){animation-delay:.45s}
.mosaic.play span:nth-child(5){animation-delay:.40s}.mosaic.play span:nth-child(6){animation-delay:.10s}
.mosaic.play span:nth-child(7){animation-delay:.55s}.mosaic.play span:nth-child(8){animation-delay:.25s}
.mosaic.play span:nth-child(9){animation-delay:.20s}.mosaic.play span:nth-child(10){animation-delay:.60s}
.mosaic.play span:nth-child(11){animation-delay:.35s}.mosaic.play span:nth-child(12){animation-delay:.08s}
.mosaic.play span:nth-child(13){animation-delay:.50s}.mosaic.play span:nth-child(14){animation-delay:.18s}
.mosaic.play span:nth-child(15){animation-delay:.65s}.mosaic.play span:nth-child(16){animation-delay:.28s}
@keyframes px-in{from{opacity:0;transform:scale(.4)}to{opacity:1;transform:scale(1)}}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--grey-300);
  width:100%;
  left:0;
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{
  display:grid;grid-template-columns:repeat(2,1fr);gap:3px;width:34px;height:34px;flex:none;
}
.brand-mark i{background:var(--navy-700)}
.brand-mark i:nth-child(2){background:var(--teal-400)}
.brand-mark i:nth-child(3){background:var(--teal-400)}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-text strong{font-family:var(--ff-display);font-weight:900;font-size:1.05rem;letter-spacing:.01em;color:var(--navy-900)}
.brand-text small{font-family:var(--ff-mono);font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;color:var(--grey-600)}

.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-weight:500;font-size:.95rem;color:var(--ink);position:relative;padding:6px 0}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:0;height:3px;width:0;
  background:linear-gradient(90deg,var(--navy-700) 50%,var(--teal-400) 50%);
  transition:width .25s ease;
}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{width:100%}
.nav-links a[aria-current="page"]{color:var(--navy-700);font-weight:500}

.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--ff-display);font-weight:700;font-size:.95rem;
  padding:.72em 1.45em;border-radius:8px;border:2px solid transparent;
  cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease;
}
.btn-primary{
  background: var(--navy-700);
  color: #fff;
  box-shadow: 0 4px 12px rgba(18, 51, 128, 0.12);
}
.btn-primary:hover{
  background: var(--navy-600);
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(18, 51, 128, 0.28);
}
.btn-teal{
  background: var(--teal-500);
  color: var(--white);
  box-shadow: 0 4px 12px rgba(0, 145, 214, 0.15);
}
.btn-teal:hover{
  background: var(--teal-400);
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(0, 145, 214, 0.35);
}
.nav-links .btn {
  padding: 0.55em 1.25em;
  font-size: 0.88rem;
  border-radius: 6px;
}
.nav-links .btn-primary {
  background: var(--teal-500);
  color: #fff;
  box-shadow: 0 4px 10px rgba(0, 145, 214, 0.15);
}
.nav-links .btn-primary:hover {
  background: var(--teal-400);
  box-shadow: 0 6px 15px rgba(0, 145, 214, 0.3);
}
.btn-ghost{border-color:var(--navy-700);color:var(--navy-700);background:transparent}
.btn-ghost:hover{background:var(--navy-700);color:#fff}
.on-dark .btn-ghost{border-color:rgba(255,255,255,.5);color:#fff}
.on-dark .btn-ghost:hover{background:#fff;color:var(--navy-900)}

.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:24px;height:2.5px;background:var(--navy-900);margin:5px 0;transition:.25s}

@media (max-width:880px){
  .site-header {
    overflow: hidden; /* Prevent horizontal scroll from closed mobile nav links */
  }
  .nav-toggle{
    display:block;
    position:relative;
    z-index:100;
  }
  .nav-links{
    position:fixed;
    inset:0 0 0 auto;
    width:280px;
    height:100vh;
    background:#fff;
    flex-direction:column;
    align-items:flex-start;
    padding:96px 24px 32px;
    gap:24px;
    border-left:1px solid var(--grey-300);
    transform:translateX(100%);
    transition:transform 0.3s cubic-bezier(0.16, 1, 0.3, 1), visibility 0.3s;
    box-shadow:var(--shadow-lift);
    z-index:90;
    visibility: hidden;
  }
  .nav-links.open{
    transform:translateX(0);
    visibility: visible;
  }
  .nav-links a:not(.btn) {
    color: var(--navy-900) !important;
  }
  .nav-links a:not(.btn):hover {
    color: var(--teal-500) !important;
  }
  .nav-open .nav-toggle span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
  .nav-open .nav-toggle span:nth-child(2){opacity:0}
  .nav-open .nav-toggle span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
  .nav-open .nav-toggle span {
    background: var(--navy-900) !important;
  }
  .nav-open .site-header {
    position: fixed !important;
    top: 0 !important;
    overflow: visible !important;
  }
}

/* ---------- Top strip ---------- */
.topstrip{background:var(--navy-950);color:var(--teal-200);font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.08em}
.topstrip .wrap{display:flex;justify-content:space-between;align-items:center;height:34px;gap:16px}
.topstrip a{color:#fff}
.topstrip a:hover{color:var(--teal-400)}
@media (max-width:680px){.topstrip .hide-sm{display:none}}

/* ---------- Hero ---------- */
.hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(1100px 600px at 85% -10%,rgba(0,145,214,.18),transparent 60%),
    linear-gradient(180deg,var(--navy-950) 0%,var(--navy-900) 60%,var(--navy-700) 130%);
  color:#fff;
}
.hero .wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;padding-top:92px;padding-bottom:108px}
.hero h1{color:#fff}
.hero h1 .tint{color:var(--teal-400)}
.hero .lede{color:#C6D2EE}
.hero-cta{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.hero-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:30px}
.chip{
  font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;
  border:1px solid rgba(255,255,255,.25);color:#DCE6FB;border-radius:999px;padding:.45em 1em;
  background:rgba(255,255,255,.05);
}

.hero-panel{position:relative}
.ticket{
  background:#fff;color:var(--ink);border-radius:var(--radius);
  box-shadow:var(--shadow-lift);overflow:hidden;
}
.ticket-head{
  background:var(--navy-700);color:#fff;padding:16px 22px;
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--ff-mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
}
.ticket-head b{color:var(--teal-200)}
.ticket-body{padding:22px}
.ticket-row{display:flex;justify-content:space-between;gap:14px;padding:11px 0;border-bottom:1px dashed var(--grey-300);font-size:.94rem}
.ticket-row:last-child{border-bottom:0}
.ticket-row .k{color:var(--grey-600)}
.ticket-row .v{font-weight:600;text-align:right;color:var(--navy-900)}
.hero-mosaic{position:absolute;top:-44px;right:-26px;z-index:1}
@media (max-width:980px){
  .hero .wrap{grid-template-columns:1fr;padding-top:64px;padding-bottom:72px}
  .hero-mosaic{display:none}
}

/* ---------- Sections ---------- */
.section{padding:96px 0;scroll-margin-top:80px;overflow:hidden;width:100%;max-width:100%}
.section.tight{padding:72px 0}
.section.paper{background:var(--paper)}
.section.navy{background:linear-gradient(180deg,var(--navy-900),var(--navy-950));color:#fff}
.section.navy h2,.section.navy h3{color:#fff}
.section.teal-wash{background:var(--teal-100)}
.sec-head{margin-bottom:48px;max-width:760px}
.sec-head h2{margin:.45em 0 .4em}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.center .lede{margin:0 auto}

/* ---------- Cards ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media (max-width:980px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.card{
  background:#fff;border:1px solid var(--grey-300);border-radius:var(--radius);
  padding:30px 28px;box-shadow:var(--shadow-card);position:relative;overflow:hidden;
  transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lift);border-color:var(--teal-400)}
.card::before{
  content:"";position:absolute;top:0;left:0;height:5px;width:100%;
  background:linear-gradient(90deg,var(--navy-700) 0 60%,var(--teal-400) 60% 100%);
  transform:scaleX(0);transform-origin:left;transition:transform .3s ease;
}
.card:hover::before{transform:scaleX(1)}
.card h3{font-size:1.15rem;margin-bottom:.5em}
.card p{color:var(--grey-600);font-size:.95rem}
.card .icon{
  width:46px;height:46px;border-radius:10px;display:grid;place-items:center;margin-bottom:18px;
  background:var(--teal-100);color:var(--navy-700);font-size:1.3rem;
}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);overflow:hidden}
.stat{padding:34px 26px;border-right:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.03)}
.stat:last-child{border-right:0}
.stat b{font-family:var(--ff-display);font-size:clamp(1.9rem,3.4vw,2.7rem);font-weight:900;color:var(--teal-400);display:block;line-height:1}
.stat span{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#AFC2E8;display:block;margin-top:10px}
@media (max-width:880px){.stats{grid-template-columns:repeat(2,1fr)}.stat:nth-child(2){border-right:0}.stat:nth-child(-n+2){border-bottom:1px solid rgba(255,255,255,.14)}}

/* ---------- Curriculum ledger ---------- */
.ledger{background:#fff;border:1px solid var(--grey-300);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);color:var(--navy-900)}
.ledger-head{
  background:var(--navy-700);color:#fff;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;
}
.ledger-head h3{color:#fff;font-size:1.05rem;margin:0}
.ledger-head .tag{font-family:var(--ff-mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--navy-950);background:var(--teal-400);padding:.35em .9em;border-radius:4px;font-weight:700}
.ledger table{width:100%;border-collapse:collapse;font-size:.94rem}
.ledger td{padding:13px 24px;border-bottom:1px solid var(--grey-300)}
.ledger tr:last-child td{border-bottom:0}
.ledger tr:hover td{background:var(--teal-100);color:var(--navy-900)}
.ledger tr:hover .code{color:var(--teal-500)}
.ledger .code{font-family:var(--ff-mono);font-size:.74rem;color:var(--teal-500);font-weight:600;width:96px;white-space:nowrap}
.ledger .sap{font-family:var(--ff-mono);font-size:.7rem;color:var(--navy-700);background:var(--teal-100);border-radius:4px;padding:.25em .7em;white-space:nowrap;font-weight:600}
.ledger .ojt-row td{background:linear-gradient(90deg,var(--navy-700),var(--navy-600));color:#fff;font-weight:700;font-family:var(--ff-display);letter-spacing:.02em}

/* ---------- Mentors ---------- */
.mentor{
  background:#fff;border:1px solid var(--grey-300);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-card);transition:transform .22s ease,box-shadow .22s ease;
}
.mentor:hover{transform:translateY(-6px);box-shadow:var(--shadow-lift)}
.mentor-avatar{
  aspect-ratio: 4 / 5;
  height: auto;
  position: relative;
  background:linear-gradient(135deg,var(--navy-700),var(--navy-900));
  overflow:hidden;
}
.mentor-avatar::after{
  content:"";position:absolute;right:14px;top:14px;width:30px;height:30px;
  background:
    linear-gradient(var(--teal-400),var(--teal-400)) 0 0/14px 14px no-repeat,
    linear-gradient(rgba(255,255,255,.35),rgba(255,255,255,.35)) 16px 16px/14px 14px no-repeat;
  z-index:2;
}
.mentor-initials{
  position:absolute;left:24px;bottom:-30px;width:64px;height:64px;border-radius:14px;
  background:var(--teal-400);color:var(--navy-950);display:grid;place-items:center;
  font-family:var(--ff-display);font-weight:900;font-size:1.3rem;border:4px solid #fff;
}
.mentor-photo{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center top;
  transition:transform .3s ease;
}
.mentor:hover .mentor-photo{
  transform:scale(1.05);
}
.mentor-body{padding:24px}
.mentor-body h3{font-size:1.08rem}
.mentor-role{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--teal-500);margin:.4em 0 .7em;font-weight:600}
.mentor-body p{font-size:.9rem;color:var(--grey-600)}

/* ---------- Recruiter marquee ---------- */
.marquee{overflow:hidden;position:relative;padding:8px 0;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);z-index:1;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}
.marquee-track{display:flex;flex-wrap:nowrap;gap:20px;width:max-content;animation:scroll 42s linear infinite;will-change:transform}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes scroll{to{transform:translateX(-50%)}}
.logo-pill{
  font-family:var(--ff-display);font-weight:700;font-size:.95rem;white-space:nowrap;
  border:1px solid var(--grey-300);border-radius:10px;padding:.9em 1.6em;background:#fff;color:var(--navy-900);
  display:flex;align-items:center;gap:.6em;
}
.logo-pill::before{content:"";width:8px;height:8px;background:var(--teal-400)}
.logo-pill:nth-child(odd)::before{background:var(--navy-700)}

.logo-card {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border: 1px solid var(--grey-300);
  border-radius: 10px;
  width: 180px;
  height: 80px;
  padding: 12px 24px;
  flex: none;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}
.logo-card img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  transition: transform 0.25s ease;
}
.logo-card:hover img {
  transform: scale(1.08);
}

.marquee-track.reverse {
  animation: scroll-reverse 42s linear infinite;
}
@keyframes scroll-reverse {
  0% { transform: translateX(-50%); }
  100% { transform: translateX(0); }
}

/* ---------- Fee table ---------- */
.fee-card{
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lift);overflow:hidden;
  border:1px solid var(--grey-300);
}
.fee-top{background:var(--navy-700);color:#fff;padding:30px 32px;position:relative;overflow:hidden}
.fee-top::after{
  content:"";position:absolute;right:-10px;bottom:-10px;width:90px;height:90px;opacity:.35;
  background:
    linear-gradient(var(--teal-400),var(--teal-400)) 0 0/40px 40px no-repeat,
    linear-gradient(var(--teal-200),var(--teal-200)) 46px 46px/40px 40px no-repeat,
    linear-gradient(rgba(255,255,255,.4),rgba(255,255,255,.4)) 46px 0/40px 40px no-repeat;
}
.fee-top .amount{font-family:var(--ff-display);font-weight:900;font-size:clamp(2.2rem,4vw,3rem);line-height:1}
.fee-top .label{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--teal-200);margin-bottom:10px;display:block}
.fee-list{padding:14px 32px 28px}
.fee-list li{display:flex;gap:14px;padding:13px 0;border-bottom:1px dashed var(--grey-300);font-size:.96rem;align-items:flex-start}
.fee-list li:last-child{border:0}
.fee-list .tick{
  flex:none;width:22px;height:22px;border-radius:6px;background:var(--teal-100);color:var(--teal-500);
  display:grid;place-items:center;font-size:.8rem;font-weight:800;margin-top:2px;
}

/* ---------- Steps ---------- */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media (max-width:980px){.steps{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.steps{grid-template-columns:1fr}}
.step{counter-increment:step;background:#fff;border:1px solid var(--grey-300);border-radius:var(--radius);padding:26px;position:relative}
.step::before{
  content:"S" counter(step);
  font-family:var(--ff-mono);font-weight:700;font-size:.74rem;letter-spacing:.12em;
  background:var(--navy-700);color:var(--teal-200);padding:.4em .9em;border-radius:6px;display:inline-block;margin-bottom:16px;
}
.step h3{font-size:1.02rem;margin-bottom:.4em}
.step p{font-size:.9rem;color:var(--grey-600)}

/* ---------- CTA band ---------- */
.cta-band{
  background:linear-gradient(120deg,var(--navy-700),var(--navy-900) 70%);
  border-radius:20px;color:#fff;padding:clamp(36px,6vw,72px);
  display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap;
  position:relative;overflow:hidden;
}
.cta-band::before{
  content:"";position:absolute;right:-30px;top:-30px;width:180px;height:180px;opacity:.25;
  background:
    linear-gradient(var(--teal-400),var(--teal-400)) 0 0/56px 56px no-repeat,
    linear-gradient(var(--teal-200),var(--teal-200)) 62px 62px/56px 56px no-repeat,
    linear-gradient(rgba(255,255,255,.5),rgba(255,255,255,.5)) 124px 0/56px 56px no-repeat;
}
.cta-band h2{color:#fff;margin-bottom:.3em}
.cta-band p{color:#C6D2EE;max-width:46ch}

/* ---------- FAQ ---------- */
details.faq{background:#fff;border:1px solid var(--grey-300);border-radius:12px;margin-bottom:14px;overflow:hidden}
details.faq summary{
  cursor:pointer;list-style:none;padding:20px 24px;font-family:var(--ff-display);font-weight:700;
  display:flex;justify-content:space-between;align-items:center;gap:16px;color:var(--navy-900);
}
details.faq summary::-webkit-details-marker{display:none}
details.faq summary::after{content:"+";font-size:1.4rem;color:var(--teal-500);transition:transform .25s}
details.faq[open] summary::after{transform:rotate(45deg)}
details.faq .faq-body{padding:0 24px 22px;color:var(--grey-600);font-size:.95rem}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr}}
.info-block{display:flex;gap:16px;padding:18px 0;border-bottom:1px dashed var(--grey-300)}
.info-block:last-child{border:0}
.info-block .icon{flex:none;width:44px;height:44px;border-radius:10px;background:var(--teal-100);display:grid;place-items:center;color:var(--navy-700);font-size:1.15rem}
.info-block b{display:block;font-family:var(--ff-display);color:var(--navy-900)}
.info-block a:hover{color:var(--teal-500)}

form.enquiry{background:#fff;border:1px solid var(--grey-300);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow-card)}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-600);margin-bottom:7px;font-weight:600}
.field input,.field select,.field textarea{
  width:100%;padding:.85em 1em;border:1.5px solid var(--grey-300);border-radius:9px;
  font-family:var(--ff-body);font-size:.96rem;background:var(--paper);transition:border-color .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--teal-400);outline:none;background:#fff}
.form-note{font-size:.82rem;color:var(--grey-600);margin-top:12px}
.form-success{
  display:none;background:var(--teal-100);border:1px solid var(--teal-400);color:var(--navy-900);
  padding:16px 20px;border-radius:10px;margin-top:16px;font-weight:600;
}
.form-success.show{display:block}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy-950);color:#9FB1D8;padding:72px 0 0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:56px}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr}}
.site-footer h4{color:#fff;font-size:.95rem;margin-bottom:18px;letter-spacing:.04em}
.site-footer li{margin-bottom:11px;font-size:.92rem}
.site-footer a:hover{color:var(--teal-400)}
.footer-brand p{font-size:.9rem;margin-top:16px;max-width:34ch}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);padding:22px 0;
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.08em;
}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{
  background:
    radial-gradient(900px 420px at 90% -20%,rgba(0,145,214,.2),transparent 60%),
    linear-gradient(180deg,var(--navy-950),var(--navy-800,#0F2A66) 120%);
  color:#fff;padding:84px 0 72px;
}
.page-hero h1{color:#fff;margin:.35em 0 .35em}
.page-hero .lede{color:#C6D2EE}
.crumbs{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#8FA4D4}
.crumbs a:hover{color:var(--teal-400)}
.crumbs b{color:var(--teal-400)}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}

/* ---------- Misc ---------- */
.accred-strip{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.accred{
  display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--grey-300);
  border-radius:10px;padding:14px 22px;font-weight:600;font-size:.92rem;color:var(--navy-900);
}
.accred i{width:10px;height:10px;background:linear-gradient(135deg,var(--navy-700) 50%,var(--teal-400) 50%);flex:none}

.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
@media (max-width:880px){.split{grid-template-columns:1fr}}

.highlight-num{
  font-family:var(--ff-display);font-weight:900;color:var(--teal-400);
  font-size:clamp(2.4rem,5vw,3.6rem);line-height:1;
}
.checklist li{display:flex;gap:12px;margin-bottom:14px;align-items:flex-start}
.checklist .tick{flex:none;width:22px;height:22px;border-radius:6px;background:var(--teal-100);color:var(--teal-500);display:grid;place-items:center;font-size:.8rem;font-weight:800;margin-top:3px}
.on-dark .checklist .tick{background:rgba(0,145,214,.2);color:var(--teal-400)}

.notice{
  font-size:.84rem;color:var(--grey-600);border-left:3px solid var(--teal-400);
  padding:10px 16px;background:var(--teal-100);border-radius:0 8px 8px 0;margin-top:20px;
}

/* ---------- Business English Section Split ---------- */
.english-split {
  display: grid;
  grid-template-columns: 1fr 1.25fr;
  gap: 48px;
  align-items: flex-start;
}

.english-images {
  display: flex;
  gap: 20px;
  justify-content: flex-end;
}

.english-images .mentor {
  width: 250px;
  flex: 0 0 250px;
}

/* Dark mode styling override for mentor cards in navy/on-dark sections */
.navy .mentor {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.15);
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.3);
  color: #fff;
  transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}

.navy .mentor:hover {
  transform: translateY(-6px);
  border-color: var(--teal-400);
  box-shadow: 0 16px 40px rgba(0, 145, 214, 0.2);
}

.navy .mentor h3 {
  color: #fff;
  font-size: 1.08rem;
}

.navy .mentor-role {
  color: var(--teal-400);
}

.navy .mentor-body p {
  color: #c7d5f0;
}

@media (max-width: 960px) {
  .english-split {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .english-images {
    justify-content: center;
    margin-top: 16px;
  }
}

@media (max-width: 580px) {
  .english-images {
    flex-direction: column;
    align-items: center;
    gap: 20px;
  }
  .english-images .mentor {
    width: 100%;
    max-width: 280px;
    flex: 0 1 auto;
  }
}

/* ---------- WhatsApp Float ---------- */
.whatsapp-float {
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: 60px;
  height: 60px;
  background-color: #25D366;
  color: #fff;
  border-radius: 50%;
  display: grid;
  place-items: center;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.25);
  z-index: 999;
  transition: transform 0.25s cubic-bezier(0.175, 0.885, 0.32, 1.275), background-color 0.25s ease;
}

.whatsapp-float:hover {
  transform: scale(1.1);
  background-color: #20ba5a;
}

.whatsapp-float svg {
  width: 32px;
  height: 32px;
}

@media (max-width: 580px) {
  .whatsapp-float {
    bottom: 16px;
    right: 16px;
    width: 50px;
    height: 50px;
  }
  .whatsapp-float svg {
    width: 26px;
    height: 26px;
  }
}

/* ---------- Modal Popup Form ---------- */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(8, 23, 53, 0.75);
  backdrop-filter: blur(8px);
  z-index: 1000;
  display: grid;
  place-items: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  padding: 24px;
}

.modal-overlay.active {
  opacity: 1;
  visibility: visible;
}

.modal-content {
  background: var(--white);
  border-radius: var(--radius);
  border: 1px solid var(--grey-300);
  box-shadow: var(--shadow-lift);
  width: 100%;
  max-width: 440px;
  position: relative;
  padding: 36px 32px;
  transform: translateY(20px);
  transition: transform 0.3s ease;
}

.modal-overlay.active .modal-content {
  transform: translateY(0);
}

.modal-close {
  position: absolute;
  top: 14px;
  right: 16px;
  background: none;
  border: 0;
  font-size: 2rem;
  color: var(--grey-600);
  cursor: pointer;
  line-height: 1;
  transition: color 0.15s ease;
}

.modal-close:hover {
  color: var(--navy-900);
}

.modal-header {
  margin-bottom: 20px;
}

.modal-form .field {
  margin-bottom: 14px;
}

.modal-form .field label {
  font-size: 0.7rem;
  margin-bottom: 4px;
}

.modal-form .field input, .modal-form .field select {
  padding: 0.7em 0.85em;
  font-size: 0.88rem;
}

@media (max-width: 480px) {
  .modal-overlay {
    padding: 16px;
  }
  .modal-content {
    padding: 24px 20px 20px;
    border-radius: 12px;
    max-width: 100%;
  }
  .modal-header h2 {
    font-size: 1.35rem;
    margin: 4px 0 6px 0;
  }
  .modal-header p {
    font-size: 0.82rem;
  }
  .modal-form .field {
    margin-bottom: 12px;
  }
  .modal-form .field label {
    font-size: 0.65rem;
    margin-bottom: 3px;
  }
  .modal-form .field input, .modal-form .field select {
    padding: 0.6em 0.75em;
    font-size: 0.84rem;
    border-radius: 6px;
  }
  .modal-form button[type="submit"] {
    padding: 0.72em 1.4em;
    font-size: 0.9rem;
    border-radius: 8px;
  }
}

/* Horizontal Swipable Option Columns/Cards on Mobile */
@media (max-width: 640px) {
  .wrap {
    padding: 0 16px !important;
  }
  .section {
    padding: 48px 0 !important;
  }
  .section.tight {
    padding: 32px 0 !important;
  }
  .sec-head {
    margin-bottom: 24px !important;
  }
  .display-xl {
    font-size: 2.0rem !important;
  }
  .display-lg {
    font-size: 1.55rem !important;
  }
  .display-md {
    font-size: 1.35rem !important;
  }
  .lede {
    font-size: 0.9rem !important;
    line-height: 1.5 !important;
  }
  
  /* Card text scaling on mobile to optimize text density */
  .card h3 {
    font-size: 1.05rem !important;
  }
  .card p {
    font-size: 0.85rem !important;
    line-height: 1.5 !important;
  }
  
  /* Checklist scaling */
  .checklist li {
    font-size: 0.85rem !important;
    margin-bottom: 10px !important;
  }
  
  /* Hero section mobile alignment & centering */
  .hero {
    height: auto !important;
    min-height: calc(100vh - 34px) !important;
    display: flex !important;
    align-items: center !important;
    padding: 120px 0 60px 0 !important;
  }
  .hero .wrap {
    transform: none !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  
  /* Brand logo size on mobile */
  .brand img {
    height: 38px !important;
  }
  
  /* Inner page hero compact padding */
  .page-hero {
    padding: 60px 0 40px !important;
  }
  
  /* Accreditation strip mobile styling */
  .accred-strip {
    gap: 12px !important;
  }
  .accred-box {
    width: calc(50% - 6px) !important;
    height: 70px !important;
    padding: 10px 16px !important;
    border-radius: 8px !important;
  }
  
  /* Preview table styling and size compatibility on mobile */
  .ledger td {
    padding: 10px 12px !important;
  }
  .ledger table {
    font-size: 0.82rem !important;
  }
  .ledger .sap {
    font-size: 0.65rem !important;
    padding: 0.25em 0.5em !important;
  }
  .ledger .code {
    font-size: 0.68rem !important;
    width: 70px !important;
  }
  
  /* Swipable grid alignment adjustments for 16px page padding */
  .grid-2:not(.no-swipe), .grid-3:not(.no-swipe), .grid-4:not(.no-swipe), .steps {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory;
    gap: 16px;
    padding-bottom: 20px;
    margin-bottom: 12px;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    margin-left: -16px !important;
    margin-right: -16px !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
    scrollbar-width: none; /* Firefox */
  }
  
  .grid-2:not(.no-swipe)::-webkit-scrollbar, 
  .grid-3:not(.no-swipe)::-webkit-scrollbar, 
  .grid-4:not(.no-swipe)::-webkit-scrollbar, 
  .steps::-webkit-scrollbar {
    display: none; /* Safari and Chrome */
  }
  
  .grid-2:not(.no-swipe) .card, .grid-3:not(.no-swipe) .card, .grid-4:not(.no-swipe) .card, .step, 
  .grid-2:not(.no-swipe) .mentor, .grid-3:not(.no-swipe) .mentor, .grid-4:not(.no-swipe) .mentor, 
  .grid-2:not(.no-swipe) > div, .grid-2:not(.no-swipe) .fee-card {
    flex: 0 0 285px !important;
    width: 285px !important;
    scroll-snap-align: start;
    height: auto;
    margin: 0;
  }

  /* Make the recruiter marquee more compact on mobile */
  .logo-card {
    width: 130px;
    height: 60px;
    padding: 8px 16px;
    border-radius: 8px;
  }
  .marquee-track {
    gap: 12px;
  }

  /* CTA Band mobile alignment */
  .cta-band {
    text-align: center !important;
    justify-content: center !important;
    padding: 30px 20px !important;
  }
  .cta-band div {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .cta-band p {
    margin: 0 auto !important;
  }
  .cta-band div[style*="display:flex"] {
    justify-content: center !important;
    width: 100% !important;
  }
  
  /* Stats mobile 1-column layout */
  .stats {
    grid-template-columns: 1fr !important;
  }
  .stat {
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255,255,255,.14) !important;
  }
  .stat:last-child {
    border-bottom: 0 !important;
  }

  /* Footer mobile optimization (compact & horizontal column-wise layout) */
  .site-footer {
    padding: 24px 0 0 !important;
    overflow: hidden;
    position: relative;
    z-index: 1;
    -webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0);
  }
  .footer-grid {
    grid-template-columns: 0.85fr 0.85fr 1.3fr !important;
    gap: 16px 12px !important;
    padding-bottom: 20px !important;
    text-align: left !important;
  }
  .footer-brand {
    grid-column: 1 / -1 !important;
    margin-bottom: 4px !important;
    display: block !important;
  }
  .footer-brand p {
    display: none !important;
  }
  .footer-brand .brand {
    justify-content: flex-start !important;
  }
  .footer-brand img {
    height: 32px !important;
    width: auto !important;
  }
  .site-footer h4 {
    margin-bottom: 6px !important;
    font-size: 0.78rem !important;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #fff;
  }
  .site-footer li {
    margin-bottom: 4px !important;
    font-size: 0.72rem !important;
    line-height: 1.35 !important;
  }
  .footer-bottom {
    flex-direction: column !important;
    align-items: flex-start !important;
    text-align: left !important;
    gap: 4px !important;
    padding: 12px 0 !important;
    font-size: 0.62rem !important;
  }

  /* Refine Why NWT section text layout on mobile to prevent overlapping */
  .why-nwt-section {
    background-image: linear-gradient(rgba(255, 255, 255, 0.9), rgba(255, 255, 255, 0.9)), url('../Bg%20Image/javier-trueba-iQPr1XkF5F0-unsplash.jpg') !important;
  }
  .why-nwt-section .sec-head {
    margin-bottom: 16px !important;
  }
  .why-nwt-section h2 {
    font-size: 1.35rem !important;
    line-height: 1.25 !important;
  }
  .why-nwt-section .lede {
    font-size: 0.82rem !important;
    line-height: 1.45 !important;
  }

  /* Apply dark overlay to Our Vision section background on mobile only */
  .vision-section {
    background-image: linear-gradient(rgba(8, 23, 53, 0.72), rgba(8, 23, 53, 0.72)), url('../assets/girl_vision.jpg') !important;
  }
}

/* ---------- Flashy Good News Section ---------- */
.good-news-card {
  margin-top: 20px;
  background: linear-gradient(135deg, var(--teal-100) 0%, var(--white) 100%);
  border: 2px solid var(--teal-400);
  border-radius: var(--radius);
  padding: 24px;
  box-shadow: var(--shadow-card);
  position: relative;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  text-align: center;
}

.good-news-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lift);
}

.good-news-card::before {
  content: "";
  position: absolute;
  top: -30px;
  right: -30px;
  width: 80px;
  height: 80px;
  background: radial-gradient(circle, rgba(91, 184, 196, 0.3) 0%, rgba(91, 184, 196, 0) 70%);
  filter: blur(5px);
  border-radius: 50%;
  pointer-events: none;
}

.good-news-badge {
  display: inline-block;
  background: var(--teal-500);
  color: var(--white);
  font-family: var(--ff-mono);
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 20px;
  letter-spacing: 0.12em;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(63, 164, 178, 0.25);
  animation: badge-blink 1.5s infinite ease-in-out;
}

.good-news-title {
  font-family: var(--ff-display);
  color: var(--navy-900);
  font-size: 1.18rem;
  font-weight: 800;
  margin-bottom: 6px;
  line-height: 1.35;
}

.good-news-text {
  font-size: 0.92rem;
  color: var(--navy-950);
  line-height: 1.55;
  margin: 0;
  font-weight: 500;
}

.good-news-text strong {
  color: var(--navy-900);
  font-weight: 700;
}

@keyframes badge-blink {
  0%, 100% {
    opacity: 1;
    transform: scale(1);
    box-shadow: 0 0 12px rgba(63, 164, 178, 0.6);
  }
  50% {
    opacity: 0.35;
    transform: scale(0.96);
    box-shadow: 0 0 2px rgba(63, 164, 178, 0.1);
  }
}

@media (max-width: 480px) {
  .good-news-card {
    padding: 16px;
  }
  .good-news-title {
    font-size: 1.05rem;
  }
}
.good-news-heading {
  animation: text-blink 1.5s infinite ease-in-out;
  color: var(--teal-600) !important;
}

@keyframes text-blink {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.35;
  }
}
