/* ============================================================
   TSMHS — Global Stylesheet
   Used by ALL pages
============================================================ */
:root {
  --fs:1;  /* font scale — changed by accessibility widget */
  --o:#FF6B00; --o2:#FF8C35; --o-glow:rgba(255,107,0,0.12); --o-soft:rgba(255,107,0,0.06);
  --bg:#080808; --bg2:#0f0f0f; --bg3:#161616; --bg4:#1e1e1e;
  --line:rgba(255,255,255,0.08); --line-o:rgba(255,107,0,0.2);
  --txt:#FFFFFF; --txt2:rgba(255,255,255,0.65); --txt3:rgba(255,255,255,0.35);
  --display:'Teko',sans-serif; --serif:'Cormorant Garamond',serif; --body:'DM Sans',sans-serif;
  --r:12px; --r2:20px; --ease:cubic-bezier(.4,0,.2,1); --t:.3s;
  --nav-h:68px;
}
[data-theme="light"]{
  --bg:#FAFAFA; --bg2:#F2F2F2; --bg3:#E8E8E8; --bg4:#DCDCDC;
  --line:rgba(0,0,0,0.08); --line-o:rgba(255,107,0,0.25);
  --txt:#0A0A0A; --txt2:rgba(0,0,0,0.6); --txt3:rgba(0,0,0,0.35);
  --o-glow:rgba(255,107,0,0.08); --o-soft:rgba(255,107,0,0.04);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--body);background:var(--bg);color:var(--txt);overflow-x:hidden;transition:background .3s,color .3s;font-size:calc(15px * var(--fs,1));}
::-webkit-scrollbar{width:3px;}::-webkit-scrollbar-thumb{background:var(--o);border-radius:2px;}
a{color:inherit;text-decoration:none;}
button{font-family:var(--body);cursor:pointer;border:none;}
img{display:block;max-width:100%;}

/* ── Typography ── */
.d1{font-family:var(--display);font-size:clamp(36px,6vw,96px);line-height:.95;text-transform:uppercase;letter-spacing:1px;}
.d2{font-family:var(--display);font-size:clamp(28px,4vw,68px);line-height:1;text-transform:uppercase;}
.d3{font-family:var(--display);font-size:clamp(22px,3vw,44px);line-height:1.05;text-transform:uppercase;}
.label{font-size:calc(11px * var(--fs,1));letter-spacing:3px;text-transform:uppercase;color:var(--o);font-weight:600;display:flex;align-items:center;gap:10px;}
.label::before{content:'';width:24px;height:1.5px;background:var(--o);flex-shrink:0;}

/* ── Navbar ── */
#nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 5%;transition:background .3s,border-color .3s;border-bottom:1px solid transparent;}
#nav.scrolled{background:rgba(8,8,8,0.93);backdrop-filter:blur(20px);border-color:var(--line);}
[data-theme="light"] #nav.scrolled{background:rgba(250,250,250,0.95);}
#nav.solid{background:var(--bg2);border-color:var(--line);}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none;}
.nav-logo-inner{display:flex;align-items:center;gap:10px;}
.nav-logo-img{height:52px;width:auto;object-fit:contain;display:block;}
.nav-logo-pill{display:flex;align-items:center;gap:10px;}
.nav-logo-pill-text{display:flex;flex-direction:column;line-height:1;}
.nav-logo-pill-text strong{font-family:var(--display);font-size:calc(20px * var(--fs,1));color:#fff;letter-spacing:1.5px;}
.nav-logo-pill-text span{font-size:calc(8px * var(--fs,1));color:rgba(255,255,255,.55);letter-spacing:2px;text-transform:uppercase;margin-top:2px;}
.nav-logo-mark{width:44px;height:44px;background:var(--o);border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:calc(19px * var(--fs,1));color:#fff;flex-shrink:0;}
.nav-logo-words{display:flex;flex-direction:column;line-height:1;}
.nav-logo-words strong{font-family:var(--display);font-size:calc(21px * var(--fs,1));color:var(--o);letter-spacing:2px;}
.nav-logo-words span{font-size:calc(9px * var(--fs,1));color:var(--txt3);letter-spacing:2px;text-transform:uppercase;margin-top:2px;}
.nav-links{display:flex;gap:22px;list-style:none;}
.nav-links a{font-size:13.5px;font-weight:500;color:var(--txt2);position:relative;transition:color .3s;}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:var(--o);transition:width .3s;}
.nav-links a:hover,.nav-links a.active{color:var(--o);}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.nav-right{display:flex;align-items:center;gap:8px;}
.btn-theme{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);background:var(--bg3);color:var(--txt2);font-size:calc(15px * var(--fs,1));display:flex;align-items:center;justify-content:center;transition:all .3s;cursor:pointer;}
.btn-theme:hover{border-color:var(--o);color:var(--o);}
.btn-cta{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 18px;
  background:var(--o);color:#fff;
  border:1.5px solid var(--o);
  border-radius:8px;
  font-size:13px;font-weight:700;
  transition:all .2s;
  white-space:nowrap;
  height:36px;
}
.btn-cta:hover{background:var(--o2);border-color:var(--o2);transform:translateY(-1px);box-shadow:0 6px 20px rgba(255,107,0,.3);}

/* Portal button — same shape as others, outlined orange */
.btn-portal{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 16px;
  border:1.5px solid var(--o);
  border-radius:8px;
  color:var(--o);
  font-size:13px;font-weight:700;
  text-decoration:none;
  transition:all .2s;
  white-space:nowrap;
  height:36px;
}
.btn-portal:hover{background:var(--o);color:#fff;}
.burger{display:none;flex-direction:column;gap:5px;background:none;padding:4px;}
.burger span{width:22px;height:1.5px;background:var(--txt);display:block;transition:all .3s;}

/* ── Mobile Drawer ── */
#drawer{display:none;position:fixed;inset:0;top:var(--nav-h);z-index:999;background:var(--bg);padding:28px 5%;flex-direction:column;gap:4px;transform:translateX(100%);transition:transform .3s var(--ease);}
#drawer.open{transform:translateX(0);}
#drawer a{padding:14px 0;font-size:calc(19px * var(--fs,1));font-weight:600;border-bottom:1px solid var(--line);color:var(--txt2);transition:color .3s;}
#drawer a:hover{color:var(--o);}

/* ── Buttons ── */
.btn-primary{padding:14px 28px;background:var(--o);color:#fff;border-radius:var(--r);font-size:calc(14px * var(--fs,1));font-weight:700;display:inline-flex;align-items:center;gap:8px;transition:all .3s;}
.btn-primary:hover{background:var(--o2);transform:translateY(-2px);box-shadow:0 12px 32px rgba(255,107,0,.35);}
.btn-outline{padding:14px 28px;background:transparent;color:var(--txt);border:1px solid var(--line);border-radius:var(--r);font-size:calc(14px * var(--fs,1));font-weight:600;display:inline-flex;align-items:center;gap:8px;transition:all .3s;}
.btn-outline:hover{border-color:var(--o);color:var(--o);background:var(--o-glow);}

/* ── Section base ── */
.sec{padding:88px 5%;}
.sec-alt{background:var(--bg2);}
.sec-head{margin-bottom:48px;}
.sec-head .label{margin-bottom:12px;}
.sec-head p{color:var(--txt2);font-size:15.5px;line-height:1.75;max-width:560px;margin-top:10px;}

/* ── Page Hero (inner pages) ── */
.page-hero{padding:calc(var(--nav-h) + 56px) 5% 64px;background:var(--bg2);border-bottom:1px solid var(--line);position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;top:0;right:0;width:50%;height:100%;background:radial-gradient(ellipse at right,var(--o-glow),transparent 70%);pointer-events:none;}
.page-hero .label{margin-bottom:12px;}
.page-hero h1{margin-bottom:14px;}
.page-hero p{color:var(--txt2);font-size:calc(16px * var(--fs,1));line-height:1.75;max-width:600px;}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:calc(12px * var(--fs,1));color:var(--txt3);margin-bottom:20px;flex-wrap:wrap;}
.breadcrumb a{color:var(--txt3);transition:color .3s;}
.breadcrumb a:hover{color:var(--o);}
.breadcrumb span{color:var(--txt3);}
.breadcrumb strong{color:var(--o);}

/* ── Cards ── */
.card{background:var(--bg3);border:1px solid var(--line);border-radius:var(--r2);transition:all .3s;}
.card:hover{border-color:var(--line-o);transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,.3);}

/* ── Chips/Tags ── */
.chip{font-size:calc(11px * var(--fs,1));padding:4px 10px;border-radius:6px;font-weight:600;letter-spacing:.5px;}
.chip-o{background:var(--o-glow);color:var(--o);border:1px solid var(--line-o);}
.chip-g{background:var(--bg4);color:var(--txt3);}

/* ── Ticker ── */
.ticker{background:var(--o);padding:10px 0;overflow:hidden;white-space:nowrap;}
.ticker-track{display:inline-flex;align-items:center;animation:tick 40s linear infinite;}
.ticker-track:hover{animation-play-state:paused;}
.ti{font-size:calc(12px * var(--fs,1));color:#fff;padding:0 32px;letter-spacing:1.5px;text-transform:uppercase;font-weight:500;display:flex;align-items:center;gap:32px;}
.ti::after{content:'';display:inline-block;width:4px;height:4px;background:rgba(255,255,255,.45);border-radius:50%;flex-shrink:0;}
.ti:last-child::after{display:none;}
@keyframes tick{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── WhatsApp Float ── */
.wa-float{position:fixed;bottom:28px;right:28px;z-index:900;width:56px;height:56px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 28px rgba(37,211,102,.4);text-decoration:none;transition:all .3s;animation:wafloat 3s ease-in-out infinite;}
.wa-float:hover{transform:scale(1.1)!important;animation-play-state:paused;}
.wa-float svg{width:28px;height:28px;fill:#fff;}
.wa-tip{position:absolute;right:66px;top:50%;transform:translateY(-50%);background:var(--bg2);color:var(--txt);padding:7px 13px;border-radius:8px;font-size:calc(12px * var(--fs,1));font-weight:600;white-space:nowrap;border:1px solid var(--line);pointer-events:none;opacity:0;transition:opacity .3s;}
.wa-float:hover .wa-tip{opacity:1;}
@keyframes wafloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}

/* ── Scroll to top ── */
#scrollTop{position:fixed;bottom:28px;left:28px;z-index:900;width:42px;height:42px;border-radius:50%;background:var(--bg3);border:1px solid var(--line);color:var(--txt2);font-size:calc(18px * var(--fs,1));display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;opacity:0;pointer-events:none;transform:translateY(10px);}
#scrollTop.show{opacity:1;pointer-events:all;transform:translateY(0);}
#scrollTop:hover{background:var(--o);border-color:var(--o);color:#fff;}

/* ── Reveal animations ── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s var(--ease),transform .6s var(--ease);}
.reveal.in{opacity:1;transform:translateY(0);}
.reveal-l{opacity:0;transform:translateX(-24px);transition:opacity .6s var(--ease),transform .6s var(--ease);}
.reveal-l.in{opacity:1;transform:translateX(0);}
.reveal-r{opacity:0;transform:translateX(24px);transition:opacity .6s var(--ease),transform .6s var(--ease);}
.reveal-r.in{opacity:1;transform:translateX(0);}
.d1{transition-delay:.1s}.d2x{transition-delay:.2s}.d3x{transition-delay:.3s}.d4{transition-delay:.4s}.d5{transition-delay:.5s}.d6{transition-delay:.6s}

/* ── Footer ── */
footer{background:var(--bg);border-top:1px solid var(--line);padding:64px 5% 32px;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px;}
.footer-brand p{font-size:calc(13px * var(--fs,1));color:var(--txt2);line-height:1.8;max-width:280px;margin-top:14px;}
.footer-soc{display:flex;gap:8px;margin-top:18px;}
.footer-soc a{width:34px;height:34px;border-radius:8px;background:var(--bg3);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:calc(14px * var(--fs,1));transition:all .3s;}
.footer-soc a:hover{background:var(--o);border-color:var(--o);}
.footer-col h5{font-size:calc(11px * var(--fs,1));color:var(--txt);letter-spacing:2px;text-transform:uppercase;font-weight:700;margin-bottom:18px;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:9px;}
.footer-col ul li a{font-size:calc(13px * var(--fs,1));color:var(--txt2);transition:color .3s;}
.footer-col ul li a:hover{color:var(--o);}
.footer-bottom{padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.footer-bottom p{font-size:calc(12px * var(--fs,1));color:var(--txt3);}
.footer-bottom span{color:var(--o);}

/* ── Accreditation strip ── */
.accred-strip{background:var(--bg);border-bottom:1px solid var(--line);padding:20px 5%;}
.accred-inner{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.accred-divider{width:1px;height:32px;background:var(--line);flex-shrink:0;}
.accred-logos{display:flex;flex-wrap:wrap;gap:8px;flex:1;}
.accred-badge{display:flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--line);border-radius:var(--r);background:var(--bg2);transition:all .25s;}
.accred-badge:hover{border-color:var(--o);background:var(--o-glow);transform:translateY(-2px);}
.accred-icon{font-size:calc(16px * var(--fs,1));}
.accred-info strong{font-size:calc(12px * var(--fs,1));font-weight:700;color:var(--txt);display:block;line-height:1;}
.accred-info span{font-size:calc(10px * var(--fs,1));color:var(--txt3);letter-spacing:1px;text-transform:uppercase;}

/* ── Homepage Campus Cards ── */
.hp-campuses{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);}
.hp-campus-card{position:relative;display:flex;flex-direction:column;text-decoration:none;border-right:1px solid var(--line);transition:background .25s;overflow:hidden;}
.hp-campus-card:last-child{border-right:none;}
.hp-campus-card:hover{background:var(--bg3);}
.hp-campus-photo{height:220px;overflow:hidden;position:relative;background:var(--bg4);flex-shrink:0;}
.hp-campus-photo img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;display:block;}
.hp-campus-card:hover .hp-campus-photo img{transform:scale(1.04);}
.hp-campus-photo-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:56px;background:linear-gradient(135deg,var(--bg3),var(--bg4));}
.hp-campus-main-badge{position:absolute;top:12px;left:12px;background:var(--o);color:#fff;font-size:9px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;padding:3px 10px;border-radius:50px;}
.hp-campus-info{padding:22px 24px 20px;display:flex;flex-direction:column;gap:0;flex:1;}
.hp-campus-city{font-family:'Teko',sans-serif;font-size:calc(32px * var(--fs,1));color:var(--txt);line-height:.95;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;}
.hp-campus-tag{font-size:12px;color:var(--txt2);line-height:1.5;margin-bottom:14px;}
.hp-campus-details{display:flex;flex-direction:column;gap:6px;margin-bottom:18px;flex:1;}
.hp-campus-detail-row{display:flex;align-items:flex-start;gap:7px;font-size:12px;color:var(--txt3);line-height:1.4;}
.hp-campus-footer{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid var(--line);margin-top:auto;}
.hp-campus-explore{font-size:12px;font-weight:700;color:var(--o);transition:gap .2s;}
.hp-campus-card:hover .hp-campus-explore{text-decoration:underline;}
.hp-campus-wa{display:inline-flex;align-items:center;gap:5px;background:#25d366;color:#fff;padding:6px 13px;border-radius:50px;font-size:11px;font-weight:700;text-decoration:none;white-space:nowrap;flex-shrink:0;}
.hp-campus-wa:hover{background:#1ebe5d;}
.hp-campus-accent{position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--o);transform:scaleY(0);transform-origin:bottom;transition:transform .3s ease;}
.hp-campus-card:hover .hp-campus-accent{transform:scaleY(1);}
@media(max-width:900px){.hp-campuses{grid-template-columns:repeat(2,1fr);}.hp-campus-card{border-bottom:1px solid var(--line);}.hp-campus-card:nth-child(2){border-right:none;}.hp-campus-card:nth-child(3){border-right:1px solid var(--line);}.hp-campus-card:last-child{border-right:none;}}
@media(max-width:520px){.hp-campuses{grid-template-columns:1fr;}.hp-campus-card{border-right:none;border-bottom:1px solid var(--line);}.hp-campus-photo{height:180px;}}

/* ── Responsive ── */

/* Large tablet */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr;}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;}
  .gi.large{grid-row:span 1;}
}

/* Tablet / small laptop */
@media(max-width:900px){
  .hp-campuses{grid-template-columns:repeat(2,1fr);}
  .hp-campus-card{border-bottom:1px solid var(--line);}
  .hp-campus-card:nth-child(2){border-right:none;}
  .hp-campus-card:nth-child(3){border-right:1px solid var(--line);}
  .hp-campus-card:last-child{border-right:none;}
}

/* Mobile — primary breakpoint */
@media(max-width:768px){
  /* Nav */
  .nav-links{display:none;}
  .nav-right .btn-cta{display:none;}
  .nav-right .btn-portal{display:none;}
  .nav-right .btn-user-login{display:none;}
  .nav-right .btn-user-acct .user-name{display:none;}
  .nav-right .btn-user-acct{padding:4px;}
  .burger{display:flex;}
  #drawer{display:flex;}

  /* Layout */
  .footer-grid{grid-template-columns:1fr;}
  .sec{padding:56px 5%;}
  .page-hero{padding:100px 5% 48px;}

  /* Logo — hide text on small screens, show just image */
  .nav-logo-pill-text{display:none;}
  .nav-logo-pill{padding:4px;}
  .nav-logo-img{height:44px;}

  /* Homepage */
  .about-grid{grid-template-columns:1fr!important;}
  .about-img-col{order:1!important;}
  .about-grid .reveal-r{order:2!important;}
  .campus-grid,.courses-grid{grid-template-columns:1fr;}
  .gallery-grid{grid-template-columns:1fr 1fr;}
  .hero-btns{flex-direction:column;align-items:flex-start;}
  .hstat{padding:0 14px 0 0;margin-right:14px;}

  /* Course & campus detail */
  .content-grid{grid-template-columns:1fr!important;}
  .campus-body-grid{grid-template-columns:1fr!important;}
  .sidebar,.sidebar-info{position:static!important;}

  /* Apply form */
  .apply-grid{grid-template-columns:1fr!important;}
  .form-grid{grid-template-columns:1fr!important;}

  /* About page */
  .about-split{grid-template-columns:1fr!important;}
  .stats-grid{grid-template-columns:1fr 1fr!important;}

  /* Account page */
  .acct-grid{grid-template-columns:1fr!important;}
  .acct-sidebar{position:static;flex-direction:row;flex-wrap:wrap;}
  .acct-nav-btn{flex:1;min-width:120px;justify-content:center;}
  .field-row{grid-template-columns:1fr!important;}

  /* Auth pages */
  .auth-head,.auth-body{padding:24px 22px!important;}
  .field-group{grid-template-columns:1fr!important;}

  /* Campus section */
  .hp-campuses{grid-template-columns:1fr;}
  .hp-campus-card{border-right:none!important;border-bottom:1px solid var(--line);}
  .hp-campus-photo{height:200px;}

  /* Contact */
  .contact-grid{grid-template-columns:1fr!important;}

  /* Clubs */
  .clubs-grid{grid-template-columns:1fr!important;}

  /* Alumni tabs */
  .tab-btn{font-size:11px;padding:8px 10px;}
}

/* Small phones */
@media(max-width:480px){
  .d1{font-size:clamp(32px,9vw,52px);}
  .d2{font-size:clamp(26px,7vw,42px);}
  .hero-stats{gap:12px;}
  .hstat{padding:0 12px 0 0;margin-right:12px;}
  .hstat-num{font-size:clamp(24px,6vw,36px);}
  .accred-strip .accred-badge{padding:6px 10px;}
  .hp-campus-photo{height:180px;}
  .gallery-grid{grid-template-columns:1fr;}
  .stats-grid{grid-template-columns:1fr 1fr!important;}
  .sec{padding:44px 4%;}
  .page-hero{padding:88px 4% 40px;}
  .btn-primary,.btn-outline{padding:10px 18px;font-size:13px;}
  .acct-nav-btn{font-size:12px;padding:9px 10px;}
  .intake-chips{gap:6px;}
  .intake-chip{padding:6px 12px;font-size:12px;}
}


/* ── SVG Social icons ──────────────────────────────────────── */
.soc-icon {
  width: 36px;
  height: 36px;
  border-radius: 9px;
  background: var(--bg3);
  border: 1px solid var(--line);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all .25s;
  color: var(--txt2);
}
.soc-icon svg {
  width: 16px;
  height: 16px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.soc-icon:hover { background: var(--o); border-color: var(--o); color: #fff; transform: translateY(-2px); }
.soc-wa svg { fill: currentColor; stroke: none; }
.soc-wa:hover { background: #25D366; border-color: #25D366; }
.footer-soc { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }


/* ── SVG Social icons ──────────────────────────────────────── */
.soc-icon {
  width: 36px;
  height: 36px;
  border-radius: 9px;
  background: var(--bg3);
  border: 1px solid var(--line);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all .25s;
  color: var(--txt2);
}
.soc-icon svg {
  width: 16px;
  height: 16px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.soc-icon:hover { background: var(--o); border-color: var(--o); color: #fff; transform: translateY(-2px); }
.soc-wa svg { fill: currentColor; stroke: none; }
.soc-wa:hover { background: #25D366; border-color: #25D366; }
.footer-soc { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }

/* ── Accessibility Bar ─────────────────────────────────────── */
#a11y-bar {
  background: #1a1a1a;
  border-bottom: 1px solid rgba(255,255,255,.06);
  padding: 5px 5%;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  font-size: 12px;
}
.a11y-lbl { color: rgba(255,255,255,.35); font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; margin-right: 6px; }
.a11y-btn {
  width: 30px; height: 30px; border-radius: 7px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  color: rgba(255,255,255,.7);
  cursor: pointer; font-size: 13px; font-weight: 700;
  display: inline-flex; align-items: center; justify-content: center;
  transition: all .2s;
}
.a11y-btn:hover { background: var(--o); border-color: var(--o); color: #fff; }
.a11y-btn.active { background: var(--o); border-color: var(--o); color: #fff; }
.a11y-sep { width: 1px; height: 18px; background: rgba(255,255,255,.1); margin: 0 4px; }

/* Font size levels */
body.fs-sm  { font-size: 13px; }
body.fs-md  { font-size: 15px; }
body.fs-lg  { font-size: 17px; }
body.fs-xl  { font-size: 19px; }
body.fs-xxl { font-size: 22px; }

/* High contrast mode */
body.hi-contrast {
  --bg: #000 !important;
  --bg2: #111 !important;
  --bg3: #1a1a1a !important;
  --bg4: #222 !important;
  --txt: #fff !important;
  --txt2: #eee !important;
  --txt3: #ccc !important;
  --line: rgba(255,255,255,.25) !important;
}

/* Dyslexia-friendly font */
body.dyslexic-font {
  font-family: 'OpenDyslexic', 'Comic Sans MS', 'Trebuchet MS', sans-serif !important;
}
body.dyslexic-font * { letter-spacing: 0.08em !important; word-spacing: 0.2em !important; line-height: 1.9 !important; }

/* ── Font scale levels (accessibility) ─────────────────────── */
/* We use --fs multiplier so ALL text scales together */
body.fs-sm  { --fs: 0.88; }
body.fs-md  { --fs: 1;    }
body.fs-lg  { --fs: 1.15; }
body.fs-xl  { --fs: 1.30; }
body.fs-xxl { --fs: 1.50; }

/* ── PATCH 24 MOBILE FIXES ──────────────────────────────────── */

/* Feedback page */
@media(max-width:768px){
  .feedback-grid{grid-template-columns:1fr!important;}
}

/* Accreditations page */
@media(max-width:768px){
  .why-matters-grid{grid-template-columns:1fr!important;}
  .why-grid{grid-template-columns:1fr!important;}
  .accred-hero-strip{gap:6px;}
  .ach{padding:7px 12px;}
  .ach-name{display:none;}
}

/* Campus listing cards — already handled in .clc styles */

/* Hero stat strip — smaller on very small phones */
@media(max-width:400px){
  .hero-stats{gap:0;flex-wrap:wrap;}
  .hstat{flex:0 0 50%;padding:8px 0;margin:0;border:none;border-bottom:1px solid rgba(255,255,255,.08);}
}

/* Campuses detail page mobile */
@media(max-width:768px){
  .campus-hero-inner{flex-direction:column!important;gap:16px!important;}
}

/* Blog/post page */
@media(max-width:768px){
  .post-grid{grid-template-columns:1fr!important;}
  .blog-grid{grid-template-columns:1fr!important;}
}

/* Courses page */
@media(max-width:480px){
  .courses-grid{grid-template-columns:1fr!important;}
}

/* About page mobile */
@media(max-width:768px){
  .about-split{grid-template-columns:1fr!important;}
  .about-stats-grid{grid-template-columns:1fr 1fr!important;}
  .milestones-grid{grid-template-columns:1fr!important;}
}

/* Alumni page mobile */
@media(max-width:768px){
  .alumni-featured-grid{grid-template-columns:1fr!important;}
  #panel-map .world-map-wrap{height:300px!important;}
}

/* Apply page mobile */
@media(max-width:480px){
  .apply-grid{grid-template-columns:1fr!important;}
}

/* Auth pages mobile */
@media(max-width:480px){
  .auth-card{border-radius:0!important;border-left:none!important;border-right:none!important;}
}

/* Account page mobile */
@media(max-width:480px){
  .acct-grid{gap:14px!important;}
}

/* Mobile nav — original behaviour restored + scroll-shrink */
@media(max-width:768px){
  /* Nav */
  .nav-links{display:none;}
  .nav-right .btn-cta{display:none;}
  .nav-right .btn-portal{display:none;}
  .nav-right .btn-user-login{display:none;}
  .nav-right .btn-user-acct .user-name{display:none;}
  .nav-right .btn-user-acct{padding:4px;}
  .burger{display:flex;}
  #drawer{display:flex;}
  /* Logo — show image only */
  .nav-logo-pill-text{display:none;}
  .nav-logo-pill{padding:4px;}
  .nav-logo-img{height:44px;}
  /* Hide mob-apply-btn (was added for apple style) */
  .mob-apply-btn{display:none!important;}
  /* Search btn always visible */
  .nav-search-btn{display:flex;}

  /* Scroll-shrink: nav goes from 68px → 52px when scrolled */
  #nav{transition:height .3s ease,background .3s,padding .3s;}
  #nav.scrolled{height:52px!important;padding:0 16px;}
  #nav.scrolled .nav-logo-img{height:34px;}
  #nav.scrolled .nav-logo-mark{width:34px;height:34px;font-size:14px;}

  /* On home page (hero visible) hide logo until scrolled — logo appears on scroll */
  body.page-home #nav:not(.scrolled) .nav-logo{opacity:0;pointer-events:none;transition:opacity .3s;}
  body.page-home #nav.scrolled .nav-logo{opacity:1;pointer-events:all;transition:opacity .3s;}
}

/* Nav — prevent overflow on very small screens */
@media(max-width:360px){
  #nav{padding:0 12px;}
  .nav-logo-img{height:38px;}
}

/* Accreditations strip on mobile — hide "View all" text, use icon */
@media(max-width:480px){
  .accred-strip .accred-badge:nth-child(n+4){display:none;}
}

/* ── "More" nav dropdown ────────────────────────────────────── */
.nav-more{position:relative;list-style:none;}
.nav-more-btn{background:none;border:none;cursor:pointer;font-family:var(--body);font-size:calc(13px * var(--fs,1));font-weight:500;color:var(--nl,rgba(255,255,255,.75));display:flex;align-items:center;gap:4px;padding:0;transition:color .2s;}
.nav-more-btn:hover,.nav-more-btn.active{color:var(--nl-act,#FF6B00);}
.nav-more-btn.active{color:var(--nl-act,#FF6B00);}
.nav-more-drop{display:none;position:absolute;top:calc(100% + 14px);right:0;background:var(--bg2);border:1px solid var(--line);border-radius:var(--r2);min-width:180px;overflow:hidden;box-shadow:0 20px 48px rgba(0,0,0,.35);z-index:1000;}
.nav-more-drop.open{display:block;}
.nav-more-drop a{display:block;padding:11px 18px;font-size:13px;color:var(--txt2);transition:background .15s,color .15s;text-decoration:none;border-bottom:1px solid var(--line);}
.nav-more-drop a:last-child{border-bottom:none;}
.nav-more-drop a:hover,.nav-more-drop a.active{background:rgba(255,107,0,.08);color:var(--o);}
@media(max-width:768px){.nav-more{display:none;}}




/* ── Logo: full name on desktop, short on narrow ─────────── */
.logo-full { display: inline; font-family: var(--display); font-size: 13px; color: #fff; letter-spacing: 0.5px; font-weight: 700; white-space: nowrap; }
.logo-short { display: none; font-family: var(--display); font-size: 18px; color: #fff; letter-spacing: 1.5px; font-weight: 700; }
@media (max-width: 1200px) {
  .logo-full { font-size: 11px; }
}
@media (max-width: 1100px) {
  .logo-full { display: none; }
  .logo-short { display: inline; }
}

/* ============================================================
   TSMHS — Mobile Patch v3
   Fixes: nav wrapping at medium widths, drawer scroll,
   hero section stability, breadcrumb overflow
   ============================================================ */

/* ── Global: prevent horizontal scroll ───────────────────── */
html, body { overflow-x: hidden; }
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }
*, *::before, *::after { box-sizing: border-box; min-width: 0; }
img { max-width: 100%; height: auto; }
a, button { -webkit-tap-highlight-color: transparent; touch-action: manipulation; }

/* ── NAV: tablet-friendly at 1024px ─────────────────────── */

/* Reduce nav gaps at medium widths */
@media (max-width: 1100px) {
  .nav-links { gap: 20px !important; }
}

@media (max-width: 1020px) {
  /* Hide subtitle, keep brand name */
  .nav-logo-pill-text span,
  .nav-logo-words span { display: none; }
  .nav-links { gap: 16px !important; }
  /* Compact Apply button */
  .btn-cta { padding: 8px 14px !important; font-size: 12px !important; }
  .btn-portal { padding: 6px 12px !important; font-size: 12px !important; }
}

@media (max-width: 960px) {
  /* Collapse to burger (tablet) */
  .nav-links { display: none !important; }
  .nav-right .btn-cta { display: none; }
  .nav-right .btn-portal { display: none; }
  .nav-right .btn-user-login { display: none; }
  .burger { display: flex !important; }
  #drawer { display: flex !important; }
}

@media (max-width: 768px) {
  /* Full mobile — hide burger entirely, bottom bar takes over */
  .burger { display: none !important; }
  #drawer { display: none !important; }
  /* Hide logo text */
  .nav-logo-pill-text { display: none; }
  .nav-logo-words { display: none; }
  .nav-logo-pill { padding: 4px; }
  .nav-logo-img { height: 44px; }
  /* Hide user/portal buttons — accessible via More sheet */
  .nav-right .btn-user-acct { display: none; }
}

/* ── DRAWER: full width + scrollable (tablet 769-960px only) ── */
#drawer {
  overflow-y: auto !important;
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch;
  padding-bottom: max(40px, env(safe-area-inset-bottom, 40px)) !important;
}

@media (max-width: 960px) {
  #drawer {
    width: 100vw !important;
    max-width: 100vw !important;
    left: 0 !important;
    right: 0 !important;
    padding: 20px 6% max(60px, env(safe-area-inset-bottom, 60px)) !important;
    box-sizing: border-box;
    max-height: calc(100dvh - var(--nav-h));
    height: calc(100dvh - var(--nav-h));
  }
}

/* ── HERO: stable at all widths ──────────────────────────── */
.page-hero {
  overflow: hidden;
  word-break: break-word;
  overflow-wrap: break-word;
}

/* Hero heading — fluid, never wraps into too many lines */
.page-hero h1,
.page-hero .d1,
.page-hero .d2 {
  font-size: clamp(20px, 4.5vw, 64px);
  line-height: 1.15;
  word-break: break-word;
  overflow-wrap: break-word;
  max-width: 100%;
}

@media (max-width: 960px) {
  .page-hero h1, .page-hero .d1, .page-hero .d2 {
    font-size: clamp(22px, 5.5vw, 42px);
  }
}

@media (max-width: 640px) {
  .page-hero h1, .page-hero .d1, .page-hero .d2 {
    font-size: clamp(20px, 6.5vw, 34px);
  }
  .page-hero { padding: 96px 5% 44px; }
}

@media (max-width: 420px) {
  .page-hero h1, .page-hero .d1, .page-hero .d2 {
    font-size: clamp(18px, 7vw, 28px);
  }
  .page-hero { padding: 88px 4% 36px; }
}

/* ── BREADCRUMB: truncate long titles ────────────────────── */
.breadcrumb { flex-wrap: wrap; overflow: hidden; gap: 6px; }
.breadcrumb strong {
  display: inline-block;
  max-width: min(260px, 55vw);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: bottom;
}

/* ── BLOG: 1 column on mobile ────────────────────────────── */
.posts-grid {
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 300px), 1fr)) !important;
}
@media (max-width: 640px) {
  .posts-grid { grid-template-columns: 1fr !important; gap: 14px !important; }
}

/* ── BLOG SINGLE POST: stack on mobile ───────────────────── */
.blog-single-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 36px;
  align-items: start;
  max-width: 1200px;
  margin: 0 auto;
}
.blog-sidebar { position: sticky; top: 90px; }

@media (max-width: 768px) {
  .blog-single-grid { grid-template-columns: 1fr !important; gap: 24px; }
  .blog-sidebar { position: static !important; }
}

/* ── TABLES: horizontal scroll ───────────────────────────── */
@media (max-width: 768px) {
  .panel table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
}

/* ── Touch targets ───────────────────────────────────────── */
@media (pointer: coarse) {
  .filter-btn { min-height: 44px; }
  .intake-chip { min-height: 40px; }
}

/* ── iOS safe area ───────────────────────────────────────── */
@supports (padding: env(safe-area-inset-bottom)) {
  footer { padding-bottom: calc(24px + env(safe-area-inset-bottom)); }
}


/* ── Site Search ───────────────────────────────────────────── */
/* ── Search button in nav ── */
.nav-search-btn{background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;padding:6px 8px;border-radius:8px;display:flex;align-items:center;transition:color .2s,background .2s;-webkit-tap-highlight-color:transparent}
.nav-search-btn:hover,.nav-search-btn:active{color:#fff;background:rgba(255,255,255,.1)}

/* ── Search overlay ── */
#search-overlay{position:fixed;inset:0;z-index:9990;display:none;align-items:flex-start;justify-content:center;padding-top:80px}
#search-overlay.open{display:flex}
#search-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
#search-panel{position:relative;width:100%;max-width:620px;margin:0 16px;border-radius:16px;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.1);background:var(--bg2,#111)}
#search-input-wrap{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.08)}
#search-icon-svg{flex-shrink:0;color:var(--txt3,#666)}
#search-input{flex:1;background:none;border:none;outline:none;font-size:17px;color:var(--txt,#fff);font-family:inherit;caret-color:var(--o)}
#search-input::placeholder{color:var(--txt3,#555)}
#search-clear{display:none;background:rgba(255,255,255,.1);border:none;color:var(--txt2);width:24px;height:24px;border-radius:50%;font-size:12px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center}
kbd#search-esc{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:5px;padding:3px 8px;font-size:11px;color:var(--txt3);cursor:pointer;font-family:inherit;flex-shrink:0}

/* Results */
#search-results{max-height:420px;overflow-y:auto}
.sr-empty{padding:40px 20px;text-align:center;color:var(--txt3,#555);font-size:14px}
.sr-empty svg{display:block;margin:0 auto 12px;opacity:.3}
.sr-group-label{padding:10px 18px 4px;font-size:10px;color:var(--txt3);letter-spacing:1.5px;text-transform:uppercase;font-weight:600}
.sr-item{display:flex;align-items:center;gap:14px;padding:11px 18px;cursor:pointer;text-decoration:none;transition:background .15s;border-left:3px solid transparent}
.sr-item:hover,.sr-item.active{background:rgba(255,107,0,.08);border-left-color:var(--o,#FF6B00)}
.sr-item-icon{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.sr-item.active .sr-item-icon{background:rgba(255,107,0,.15)}
.sr-item-body{flex:1;min-width:0}
.sr-item-title{font-size:14px;font-weight:600;color:var(--txt,#fff);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sr-item-sub{font-size:12px;color:var(--txt3,#666);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sr-badge{font-size:10px;padding:2px 8px;border-radius:10px;font-weight:600;flex-shrink:0}
.sr-badge-course{background:rgba(255,107,0,.15);color:var(--o,#FF6B00)}
.sr-badge-campus{background:rgba(99,102,241,.15);color:#818cf8}
.sr-badge-news{background:rgba(34,197,94,.12);color:#22c55e}
.sr-badge-page{background:rgba(255,255,255,.08);color:var(--txt3)}

/* Footer hints */
#search-footer{padding:8px 18px;border-top:1px solid rgba(255,255,255,.06);display:flex;gap:16px;font-size:11px;color:var(--txt3,#555)}
#search-footer span{display:flex;align-items:center;gap:4px}

/* Mobile adjustments */
@media(max-width:768px){
  #search-overlay{padding-top:56px}
  #search-panel{margin:0 12px;border-radius:14px}
  #search-input{font-size:16px}
  #search-footer{display:none}
  kbd#search-esc{display:none}
  /* Show search btn in mobile nav */
  .nav-search-btn{color:rgba(255,255,255,.7)}
}
