/* Test University — shared stylesheet
   Palette: pine #16382C · warm white #FBFAF7 · ink #1A1A1A · terracotta accent #BC5A33 */
:root{
  --navy:#16382C;
  --navy-700:#1F4B3A;
  --bg:#FBFAF7;
  --ink:#1A1A1A;
  --accent:#BC5A33;
  --accent-dk:#9C4827;
  --panel:#F4F1EA;
  --panel-2:#EFEBE0;
  --border:#E2DDD0;
  --muted:#5C5A54;
  --white:#ffffff;
  --maxw:1180px;
  --measure:68ch;
  --serif:"Source Serif 4",Georgia,"Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-dk);text-decoration:underline;text-underline-offset:2px}
h1,h2,h3,h4{font-family:var(--serif);color:var(--navy);line-height:1.18;font-weight:600;margin:0 0 .5em}
h1{font-size:2.6rem;letter-spacing:-.01em}
h2{font-size:1.7rem;margin-top:0}
h3{font-size:1.18rem}
h4{font-size:1rem;color:var(--ink)}
p{margin:0 0 1rem}
strong{font-weight:600}
hr{border:0;border-top:1px solid var(--border);margin:2.5rem 0}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.prose{max-width:var(--measure)}
.prose p,.prose li{color:#26251F}
.muted{color:var(--muted)}
.small{font-size:.86rem}
.mono{font-family:"SFMono-Regular",Consolas,"Liberation Mono",Menlo,monospace}

/* ---------- Skip link ---------- */
.skip{position:absolute;left:-9999px;top:0;background:var(--navy);color:#fff;padding:10px 16px;z-index:200}
.skip:focus{left:8px;top:8px}

/* ---------- Top utility bar ---------- */
.topbar{background:var(--navy);color:#cdd6e6;font-size:.8rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:16px;min-height:38px;flex-wrap:wrap}
.topbar a{color:#e7ecf5}
.topbar .topbar-links{display:flex;gap:20px}

/* ---------- Header / nav ---------- */
.site-header{position:sticky;top:0;z-index:100;background:var(--bg);border-bottom:1px solid var(--border)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:78px}
.brand{display:flex;align-items:center;gap:14px}
.brand .crest{width:42px;height:42px;flex:none;background:var(--navy);color:#fff;border-radius:3px;display:grid;place-items:center;font-family:var(--serif);font-weight:700;font-size:20px;letter-spacing:-.02em}
.brand .crest span{display:block}
.brand b{font-family:var(--serif);color:var(--navy);font-weight:600;font-size:1.32rem;line-height:1.05;display:block}
.brand small{display:block;color:var(--muted);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;margin-top:2px}
.brand a{color:inherit;text-decoration:none}

nav.primary>ul{list-style:none;margin:0;padding:0;display:flex;gap:4px}
nav.primary>ul>li{position:relative}
nav.primary>ul>li>a,nav.primary .navbtn{
  display:inline-flex;align-items:center;gap:5px;
  padding:12px 14px;color:var(--ink);font-weight:500;font-size:.95rem;
  border-radius:4px;background:none;border:0;cursor:pointer;font-family:inherit;
}
nav.primary>ul>li>a:hover,nav.primary .navbtn:hover{background:var(--panel);text-decoration:none}
nav.primary .navbtn::after{content:"";width:7px;height:7px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);transform:rotate(45deg) translateY(-2px);margin-left:3px}
.dropdown{
  position:absolute;left:0;top:100%;min-width:264px;background:#fff;
  border:1px solid var(--border);border-radius:6px;box-shadow:0 14px 40px rgba(19,40,75,.14);
  padding:8px;opacity:0;visibility:hidden;transform:translateY(6px);
  transition:opacity .14s ease,transform .14s ease,visibility .14s;z-index:30;
}
nav.primary>ul>li:hover .dropdown,
nav.primary>ul>li:focus-within .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:block;padding:9px 12px;border-radius:4px;color:var(--ink);font-size:.92rem;line-height:1.3}
.dropdown a:hover{background:var(--panel);text-decoration:none}
.dropdown a small{display:block;color:var(--muted);font-size:.78rem}
.dropdown .dd-head{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);padding:8px 12px 4px;font-weight:600}
.nav-cta{background:var(--accent)!important;color:#fff!important}
.nav-cta:hover{background:var(--accent-dk)!important}

/* active state */
body.p-programmes .nav-programmes>a,body.p-programmes .nav-programmes .navbtn,
body.p-admissions .nav-admissions>a,body.p-admissions .nav-admissions .navbtn,
body.p-campus .nav-campus>a,body.p-campus .nav-campus .navbtn,
body.p-about .nav-about>a,body.p-about .nav-about .navbtn{color:var(--navy);box-shadow:inset 0 -2px 0 var(--accent)}

.nav-toggle{display:none}

/* ---------- Hero ---------- */
.hero{background:var(--navy);color:#eaf0fa;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:
  radial-gradient(900px 380px at 88% -10%,rgba(188,90,51,.24),transparent 60%),
  repeating-linear-gradient(135deg,rgba(255,255,255,.03) 0 2px,transparent 2px 26px);
  pointer-events:none}
.hero .wrap{position:relative;z-index:2;padding-top:70px;padding-bottom:70px}
.hero h1{color:#fff;max-width:18ch}
.hero p.lede{font-size:1.22rem;max-width:60ch;color:#cdd9ee;margin-bottom:1.6rem}
.hero .eyebrow{color:var(--accent);text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;font-weight:600;margin-bottom:14px}
.hero-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:48px;align-items:stretch}
.hero-figure{aspect-ratio:4/3;border-radius:8px;border:1px solid rgba(255,255,255,.16);
  background:linear-gradient(160deg,#1c365f,#0f203c);position:relative;overflow:hidden}
.hero-figure::before{content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(45deg,rgba(255,255,255,.05) 0 1px,transparent 1px 16px),
  repeating-linear-gradient(-45deg,rgba(188,90,51,.16) 0 1px,transparent 1px 22px)}

/* ---------- Page header band (interior pages) ---------- */
.pagehead{background:var(--navy);color:#dde6f4}
.pagehead .wrap{padding-top:46px;padding-bottom:46px}
.pagehead h1{color:#fff;margin-bottom:.3em}
.pagehead p{color:#c5d2e8;max-width:62ch;margin:0}
.pagehead .eyebrow{color:var(--accent);text-transform:uppercase;letter-spacing:.16em;font-size:.76rem;font-weight:600;margin-bottom:10px}
.breadcrumb{font-size:.82rem;color:#9fb1cd;margin-bottom:16px}
.breadcrumb a{color:#cdd9ee}
.breadcrumb span{color:#7488a8;padding:0 6px}

/* ---------- Sections ---------- */
main{display:block}
section.band{padding:56px 0}
section.band.alt{background:var(--panel)}
.section-label{text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;color:var(--accent);font-weight:600;margin-bottom:10px}
.lead{font-size:1.12rem;color:#33312B}

/* ---------- Grid utilities ---------- */
.grid{display:grid;gap:24px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.stack-lg>*+*{margin-top:2.2rem}

/* ---------- Cards ---------- */
.card{background:#fff;border:1px solid var(--border);border-radius:8px;padding:24px;display:flex;flex-direction:column}
.card h3{margin-bottom:.35em}
.card .kicker{font-size:.74rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);font-weight:600;margin-bottom:10px}
.card .meta{font-size:.85rem;color:var(--muted);margin-top:auto;padding-top:14px}
.card.linked{transition:border-color .15s,box-shadow .15s,transform .15s}
.card.linked:hover{border-color:#c9c1ac;box-shadow:0 10px 30px rgba(19,40,75,.08);transform:translateY(-2px)}
.card a.more{margin-top:14px;font-weight:600}
.prog-card .tag{align-self:flex-start;font-size:.72rem;font-weight:600;color:var(--navy);background:var(--panel);border:1px solid var(--border);padding:3px 9px;border-radius:20px;margin-bottom:12px}
.prog-card .facts-mini{list-style:none;padding:0;margin:14px 0 0;font-size:.88rem}
.prog-card .facts-mini li{display:flex;justify-content:space-between;gap:10px;padding:5px 0;border-top:1px solid var(--border)}
.prog-card .facts-mini li span:first-child{color:var(--muted)}
.prog-card .facts-mini li span:last-child{font-weight:600;text-align:right}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:8px;background:#fff}
table.data{border-collapse:collapse;width:100%;font-size:.93rem}
table.data caption{text-align:left;font-size:.8rem;color:var(--muted);padding:10px 14px;border-bottom:1px solid var(--border);font-style:italic}
table.data th,table.data td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--border);vertical-align:top}
table.data thead th{background:var(--panel);color:var(--navy);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border)}
table.data tbody tr:last-child td{border-bottom:0}
table.data tbody tr:hover{background:#fcfbf7}
table.data td.num,table.data th.num{font-variant-numeric:tabular-nums}
.note-after{font-size:.82rem;color:var(--muted);margin-top:10px;font-style:italic}

/* ---------- Definition lists ---------- */
dl.facts{margin:0;display:grid;grid-template-columns:max-content 1fr;gap:0}
dl.facts dt{font-weight:600;color:var(--navy);padding:9px 16px 9px 0;border-bottom:1px solid var(--border);font-size:.9rem}
dl.facts dd{margin:0;padding:9px 0;border-bottom:1px solid var(--border);font-size:.93rem}
dl.facts div{display:contents}

/* ---------- Programme layout ---------- */
.prog-layout{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start}
.prog-body{min-width:0}
.prog-body section{scroll-margin-top:100px;padding-top:8px;margin-bottom:40px}
.prog-body section h2{padding-top:18px;border-top:2px solid var(--navy);display:inline-block;margin-bottom:18px}
.sidebar{position:sticky;top:100px}
.sidebar .panel{background:#fff;border:1px solid var(--border);border-radius:8px;padding:20px;margin-bottom:20px}
.sidebar .panel h3{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:14px}
.sidebar .toc{list-style:none;margin:0;padding:0}
.sidebar .toc li{margin:0}
.sidebar .toc a{display:block;padding:6px 0;color:var(--ink);font-size:.9rem;border-bottom:1px solid var(--border)}
.sidebar .toc a:hover{color:var(--accent)}
.qf{list-style:none;margin:0;padding:0;font-size:.9rem}
.qf li{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid var(--border)}
.qf li:last-child{border-bottom:0}
.qf li span:first-child{color:var(--muted)}
.qf li span:last-child{font-weight:600;text-align:right}

/* lists */
ul.ticks{list-style:none;padding:0;margin:0 0 1rem}
ul.ticks li{position:relative;padding:5px 0 5px 26px}
ul.ticks li::before{content:"";position:absolute;left:2px;top:13px;width:9px;height:9px;border-right:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:rotate(45deg)}
ul.cols{columns:2;column-gap:40px;list-style:none;padding:0}
ul.cols li{padding:5px 0 5px 22px;position:relative;break-inside:avoid}
ul.cols li::before{content:"";position:absolute;left:2px;top:12px;width:6px;height:6px;background:var(--accent);border-radius:50%}
ul.warn{list-style:none;padding:0;margin:0}
ul.warn li{position:relative;padding:6px 0 6px 28px;border-bottom:1px solid var(--border)}
ul.warn li:last-child{border-bottom:0}
ul.warn li::before{content:"!";position:absolute;left:0;top:6px;width:18px;height:18px;background:#fbeee6;color:var(--accent-dk);border:1px solid #e7c9a8;border-radius:50%;display:grid;place-items:center;font-size:.7rem;font-weight:700}

/* steps */
ol.steps{list-style:none;counter-reset:s;padding:0;margin:0}
ol.steps li{position:relative;padding:0 0 22px 52px;counter-increment:s}
ol.steps li::before{content:counter(s);position:absolute;left:0;top:0;width:34px;height:34px;background:var(--navy);color:#fff;border-radius:50%;display:grid;place-items:center;font-family:var(--serif);font-weight:600}
ol.steps li::after{content:"";position:absolute;left:16px;top:34px;bottom:2px;width:2px;background:var(--border)}
ol.steps li:last-child::after{display:none}
ol.steps li h4{margin:6px 0 4px}

/* ---------- Avatars / people ---------- */
.people{display:grid;gap:20px}
.person{background:#fff;border:1px solid var(--border);border-radius:8px;padding:20px;display:flex;gap:16px;align-items:flex-start}
.avatar{width:58px;height:58px;flex:none;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-family:var(--serif);font-weight:600;font-size:1.2rem;letter-spacing:.02em}
.avatar.alt{background:var(--accent)}
.person h3{font-size:1.05rem;margin-bottom:3px}
.person .role{font-size:.88rem;color:var(--muted)}
.person .tagline{font-size:.86rem;margin-top:8px}

/* ---------- Callout / disclaimer ---------- */
.callout{background:#fff;border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:6px;padding:18px 22px;margin:1.4rem 0}
.callout.navy{border-left-color:var(--navy);background:var(--panel)}
.synthetic{background:#fbeee6;border:1px solid #e7c9a8;border-radius:6px;padding:14px 18px;font-size:.88rem;color:#6b4a1d;margin:1.2rem 0}
.synthetic strong{color:#5a3c14}

/* ---------- Placeholder media ---------- */
.placeholder{background:var(--panel);border:1px solid var(--border);border-radius:8px;position:relative;display:grid;place-items:center;color:var(--muted);overflow:hidden;min-height:160px}
.placeholder::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,transparent 0 14px,rgba(19,40,75,.04) 14px 15px)}
.placeholder span{position:relative;font-family:"SFMono-Regular",Consolas,monospace;font-size:.78rem;letter-spacing:.04em}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#fff;padding:12px 22px;border-radius:5px;font-weight:600;font-size:.95rem;border:1px solid var(--accent);cursor:pointer}
.btn:hover{background:var(--accent-dk);border-color:var(--accent-dk);color:#fff;text-decoration:none}
.btn.ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn.ghost:hover{background:rgba(255,255,255,.1);color:#fff}
.btn.navy{background:var(--navy);border-color:var(--navy)}
.btn.navy:hover{background:var(--navy-700);border-color:var(--navy-700)}
.btnrow{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* ---------- Stat strip ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;border-top:1px solid rgba(255,255,255,.16);padding-top:28px;margin-top:34px}
.stats .stat b{font-family:var(--serif);font-size:2rem;color:#fff;display:block;line-height:1}
.stats .stat span{font-size:.85rem;color:#aebfd8}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy);color:#bcc9de;margin-top:0;font-size:.9rem}
.site-footer .wrap{padding-top:52px;padding-bottom:40px}
.foot-grid{display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:32px}
.site-footer h4{color:#fff;font-family:var(--sans);font-size:.74rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:14px;font-weight:600}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer li{margin:0 0 8px}
.site-footer a{color:#c3cfe2}
.site-footer a:hover{color:#fff}
.foot-brand b{font-family:var(--serif);color:#fff;font-size:1.2rem;display:block;margin-bottom:8px}
.foot-brand p{font-size:.86rem;color:#9fb1cd;max-width:34ch}
.foot-contact{font-size:.86rem;color:#9fb1cd;margin-top:14px}
.foot-contact a{color:#cdd9ee}
.disclaimer{border-top:1px solid rgba(255,255,255,.14);margin-top:34px;padding-top:22px;font-size:.82rem;color:#9fb1cd;display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap}
.disclaimer strong{color:#dbe4f2;font-weight:600}
.disclaimer .legal{max-width:70ch}

/* ---------- Anchors helper ---------- */
.anchor-list{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 8px}
.anchor-list a{font-size:.82rem;background:var(--panel);border:1px solid var(--border);padding:5px 11px;border-radius:20px;color:var(--ink)}
.anchor-list a:hover{background:#fff;text-decoration:none;border-color:#c9c1ac}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr}
  .hero-figure{display:none}
  .prog-layout{grid-template-columns:1fr}
  .sidebar{position:static;order:-1}
  body.p-programmes .sidebar .panel:has(.toc){display:none}
  .foot-grid{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .cols-4{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  body{font-size:16px}
  h1{font-size:2rem}
  .cols-2,.cols-3,.cols-4{grid-template-columns:1fr}
  ul.cols{columns:1}
  nav.primary{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--border);box-shadow:0 18px 40px rgba(19,40,75,.12)}
  nav.primary.open{display:block}
  nav.primary>ul{flex-direction:column;padding:10px}
  nav.primary>ul>li>a,nav.primary .navbtn{width:100%;justify-content:flex-start}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;border-left:2px solid var(--border);border-radius:0;margin:2px 0 6px 14px;padding:0 0 0 8px}
  nav.primary .navbtn::after{margin-left:auto}
  .nav-toggle{display:inline-flex;align-items:center;gap:8px;background:var(--navy);color:#fff;border:0;border-radius:5px;padding:10px 14px;font-family:inherit;font-weight:600;cursor:pointer}
  .topbar .topbar-links{display:none}
  dl.facts{grid-template-columns:1fr}
  dl.facts dt{border-bottom:0;padding-bottom:0}
  dl.facts dd{padding-top:2px}
  .disclaimer{flex-direction:column}
}
