/* ===== SECTION A — BASE & TOKENS (identical to programme.html) ===== */
*{box-sizing:border-box;margin:0;padding:0}
html,body{width:100%;max-width:100%;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:#4D0D09 #FBF8F4}
html{scroll-behavior:smooth}
img,video{max-width:100%;display:block}
button,a{-webkit-tap-highlight-color:transparent}
:root{
  --primary:#9A2921;--primary-dark:#4D0D09;--primary-deep:#371311;
  --primary-deeper:#2A0908;--primary-bright:#C7372C;
  --accent-warm:#D4A87C;--accent-warm-soft:#E8D2B8;--accent-warm-deep:#8A5E36;
  --text:#1c1c1c;--text-soft:#374151;--text-mute:#6B7280;
  --bg:#FBF8F4;--bg-card:#F8F7F4;--line:#E5E2D9;
  --motion-ease:cubic-bezier(.22, 1, .36, 1);
  --motion-med:700ms;--motion-fast:420ms;
}
body{font-family:'Helvetica Neue',Arial,sans-serif;background:var(--bg);color:var(--text-soft);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.site{font-family:'Helvetica Neue',Arial,sans-serif;background:var(--bg);color:var(--text-soft)}
a{color:inherit;text-decoration:none}


/* ===== SECTION C — ARGUMENT HERO (identical pattern) ===== */
.hero-arg{position:relative;background:var(--primary-deeper);color:#fff;padding:90px 48px 70px;overflow:hidden}
.hero-arg-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;opacity:.32;filter:saturate(.85)}
.hero-arg::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg, rgba(42,9,8,.55) 0%, rgba(42,9,8,.92) 100%);pointer-events:none}
.hero-arg::before{content:"";position:absolute;inset:0;z-index:2;background:radial-gradient(circle at 12% 18%, rgba(212,168,124,.18), transparent 38%),radial-gradient(circle at 88% 78%, rgba(199,55,44,.22), transparent 42%);pointer-events:none}
.hero-arg-inner{position:relative;z-index:3;max-width:1180px;margin:0 auto}
.hero-arg-crumb{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-warm);margin-bottom:28px;flex-wrap:wrap}
.hero-arg-crumb a{color:rgba(255,255,255,.5);transition:color .2s ease}
.hero-arg-crumb a:hover{color:var(--accent-warm)}
.hero-arg-crumb .sep{color:rgba(255,255,255,.3);font-weight:400}
.hero-arg h1{font-family:"Inter Tight",sans-serif;font-size:clamp(2.4rem, 5vw, 4rem);line-height:1.02;letter-spacing:-.04em;font-weight:800;color:#fff;margin-bottom:24px;max-width:920px}
.hero-arg-lead{font-size:17px;color:rgba(255,255,255,.78);max-width:680px;line-height:1.65}
.hero-arg-lead em{color:var(--accent-warm);font-style:normal;font-weight:600}
@media(max-width:768px){.hero-arg{padding:60px 24px 50px}}

/* ===== SECTION D — STATS BAR ===== */
.stats-section{background:var(--bg);position:relative;z-index:5}
.stats-bar{display:grid;grid-template-columns:repeat(4, 1fr);background:#fff;border:1px solid var(--line);border-radius:8px;overflow:hidden;margin-top:-44px;box-shadow:0 18px 50px rgba(55,19,17,.10);position:relative;z-index:6;max-width:1180px;margin-left:auto;margin-right:auto}
@media(max-width:720px){.stats-bar{grid-template-columns:1fr 1fr;margin-top:-30px}}
.stat{padding:28px 22px;text-align:center;border-right:1px solid var(--line)}
.stat:last-child{border-right:none}
@media(max-width:720px){.stat:nth-child(2){border-right:none}.stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line)}}
.stat-n{font-family:"Inter Tight",sans-serif;font-size:clamp(1.8rem, 3vw, 2.4rem);line-height:1;font-weight:800;letter-spacing:-.04em;color:var(--primary);margin-bottom:8px}
.stat-l{font-size:13px;color:var(--text-mute)}

/* ===== SECTION E — STANDARD SECTION ===== */
.sec{padding:84px 48px}
.sec.alt{background:#fff}
.sec.soft{background:var(--bg-card)}
.sec.warm{background:#F0E8DC}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--primary);margin-bottom:14px;line-height:1}
.eyebrow::before{content:"";width:42px;height:1px;flex-shrink:0;background:linear-gradient(90deg, var(--primary-bright) 0%, var(--primary) 45%, rgba(154,41,33,0) 100%)}
.sec-h2{font-family:"Inter Tight",sans-serif;font-size:34px;font-weight:800;color:var(--primary-deep);margin-bottom:14px;line-height:1.1;letter-spacing:-.03em}
.sec-lead{font-size:16px;color:var(--text-soft);line-height:1.7;max-width:680px;margin-bottom:44px}

/* ===== SECTION F — INTRO GRID + STRUCTURE PILLS (Materials pattern) ===== */
.intro-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:48px;
  align-items:start;
  margin-bottom:48px;
}
@media(max-width:980px){.intro-grid{grid-template-columns:1fr;gap:28px}}
.intro-body p{font-size:15px;color:var(--text-soft);line-height:1.75;margin-bottom:14px}
.intro-body p:last-child{margin-bottom:0}
.intro-image{
  position:relative;
  overflow:hidden;
  border-radius:8px;
  aspect-ratio:5/4;
  background:var(--bg-card);
}
.intro-image img{width:100%;height:100%;object-fit:cover;transition:transform 1200ms var(--motion-ease)}
.intro-image:hover img{transform:scale(1.04)}
.intro-image-tint{position:absolute;inset:0;background:linear-gradient(180deg, rgba(42,9,8,0) 60%, rgba(42,9,8,.28) 100%)}

/* Structure pills — four-year arc visualisation */
.structure-pills{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:12px;
}
@media(max-width:980px){.structure-pills{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.structure-pills{grid-template-columns:1fr}}
.structure-pill{
  background:#fff;
  border:1px solid var(--line);
  border-radius:8px;
  padding:22px 22px;
  position:relative;
  transition:transform var(--motion-fast) var(--motion-ease), box-shadow var(--motion-fast) var(--motion-ease);
}
.structure-pill:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 44px rgba(55,19,17,.10);
}
.structure-pill-year{
  font-family:"Inter Tight",sans-serif;
  font-size:32px;
  font-weight:800;
  color:var(--primary);
  line-height:1;
  letter-spacing:-.04em;
  margin-bottom:8px;
}
.structure-pill-label{
  font-family:"Inter Tight",sans-serif;
  font-size:15px;
  font-weight:700;
  color:var(--primary-deep);
  letter-spacing:-.015em;
  margin-bottom:6px;
}
.structure-pill-ects{
  font-size:11px;
  color:var(--text-mute);
  letter-spacing:.04em;
  margin-bottom:10px;
}
.structure-pill-badge{
  display:inline-block;
  font-size:9.5px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:3px 7px;
  border-radius:3px;
}
.structure-pill-badge.foundation{background:rgba(154,41,33,.08);color:var(--primary)}
.structure-pill-badge.core{background:rgba(154,41,33,.12);color:var(--primary-dark)}
.structure-pill-badge.advanced{background:rgba(154,41,33,.18);color:var(--primary-deep)}
.structure-pill-badge.pathway{background:rgba(212,168,124,.22);color:var(--accent-warm-deep)}

/* ===== SECTION G — COURSE-TYPE LEGEND ===== */
.legend-strip{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:32px;
  padding:18px 22px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:8px;
  align-items:center;
}
.legend-label{
  font-size:10.5px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--text-mute);
  margin-right:6px;
}
.legend-item{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  color:var(--text-soft);
}
.legend-item .course-type{margin-right:0}

/* ===== SECTION H — ACCORDION (Materials pattern, ported) ===== */
.accordion-wrap{
  border:1px solid var(--line);
  border-radius:8px;
  overflow:hidden;
  background:#fff;
}
.acc-item{border-bottom:1px solid var(--line)}
.acc-item:last-child{border-bottom:none}
.acc-trigger{
  width:100%;
  background:none;
  border:none;
  padding:22px 26px;
  display:flex;
  align-items:center;
  gap:18px;
  cursor:pointer;
  font-family:inherit;
  text-align:left;
  transition:background var(--motion-fast) var(--motion-ease);
}
.acc-trigger:hover{background:var(--bg-card)}
.acc-year-dot{
  width:38px;
  height:38px;
  border-radius:50%;
  background:var(--primary);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.acc-year-dot span{
  font-family:"Inter Tight",sans-serif;
  font-size:14px;
  color:#fff;
  font-weight:800;
  letter-spacing:-.02em;
}
.acc-trigger-info{flex:1}
.acc-trigger-title{
  font-family:"Inter Tight",sans-serif;
  font-size:19px;
  font-weight:700;
  color:var(--primary-deep);
  letter-spacing:-.02em;
  margin-bottom:4px;
  line-height:1.2;
}
.acc-trigger-meta{
  font-size:12.5px;
  color:var(--text-mute);
  line-height:1.4;
}
.acc-trigger-badges{
  display:flex;
  gap:6px;
  margin-top:8px;
}
.acc-badge{
  font-size:10px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:3px 8px;
  border-radius:3px;
}
.acc-badge-foundation{background:rgba(154,41,33,.08);color:var(--primary)}
.acc-badge-core{background:rgba(154,41,33,.12);color:var(--primary-dark)}
.acc-badge-advanced{background:rgba(154,41,33,.18);color:var(--primary-deep)}
.acc-chevron{
  font-size:18px;
  color:var(--text-mute);
  transition:transform var(--motion-fast) var(--motion-ease);
  flex-shrink:0;
  line-height:1;
}
.acc-chevron.open{transform:rotate(180deg)}
.acc-body{
  display:none;
  padding:0 26px 26px;
  border-top:1px solid var(--line);
  background:var(--bg-card);
}
.acc-body.open{display:block}

/* Course table inside accordion */
.course-table{
  width:100%;
  border-collapse:collapse;
  font-size:13px;
  margin-bottom:14px;
  margin-top:18px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:6px;
  overflow:hidden;
}
.course-table th{
  padding:10px 14px;
  text-align:left;
  font-size:10px;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--text-mute);
  border-bottom:1px solid var(--line);
  background:var(--bg-card);
}
.course-table th.th-code{width:90px}
.course-table th.th-ects{width:60px;text-align:right}
.course-table th.th-sem{width:120px}
.course-table td{
  padding:12px 14px;
  border-bottom:0.5px solid var(--line);
  vertical-align:middle;
  line-height:1.45;
}
.course-table tr:last-child td{border-bottom:none}
.course-table tr:hover td{background:#FDFCF8}
.course-table .course-code-cell{
  padding-right:10px;
}
.course-code-chip{
  display:inline-block;
  padding:3px 8px;
  background:rgba(154,41,33,.08);
  color:var(--primary);
  border-radius:3px;
  font-family:"Inter Tight",sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:.04em;
  white-space:nowrap;
}
.course-name{
  color:var(--primary-deep);
  font-weight:600;
  font-size:13.5px;
  line-height:1.35;
}
.course-type{
  display:inline-block;
  font-size:10px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:3px 8px;
  border-radius:3px;
  white-space:nowrap;
}
.course-type-mandatory-core{background:rgba(154,41,33,.10);color:var(--primary)}
.course-type-elective-core{background:rgba(212,168,124,.20);color:var(--accent-warm-deep)}
.course-type-mand-spec{background:rgba(154,41,33,.18);color:var(--primary-dark)}
.course-type-elec-spec{background:rgba(212,168,124,.30);color:var(--accent-warm-deep)}
.course-type-project{background:var(--primary);color:#fff}
.course-ects{
  font-size:13px;
  color:var(--primary-deep);
  font-weight:700;
  text-align:right;
  white-space:nowrap;
  font-family:"Inter Tight",sans-serif;
}
.course-elective-sem{
  font-size:11.5px;
  color:var(--text-mute);
  letter-spacing:.02em;
}

.sem-divider{
  background:var(--primary-deeper);
  padding:8px 14px;
  font-size:10.5px;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#fff;
}
.acc-year-note{
  background:rgba(212,168,124,.10);
  border:1px solid rgba(212,168,124,.28);
  border-radius:6px;
  padding:14px 18px;
  font-size:13px;
  color:var(--text-soft);
  line-height:1.6;
  margin-top:6px;
}
.acc-year-note strong{color:var(--primary-dark);font-weight:700}

/* ===== SECTION I — YEAR 4 PARALLEL PATHWAY DISPLAY ===== */
.pathway-shell{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  align-items:start;
}
@media(max-width:980px){.pathway-shell{grid-template-columns:1fr;gap:32px}}
.pathway-col{
  background:#fff;
  border:1px solid var(--line);
  border-radius:8px;
  padding:0;
  overflow:hidden;
}
.pathway-head{
  padding:30px 30px 26px;
  border-bottom:1px solid var(--line);
  background:var(--bg-card);
}
.pathway-pill{
  display:inline-block;
  font-size:10px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:5px 11px;
  border-radius:3px;
  margin-bottom:12px;
}
.pathway-pill-a{background:rgba(154,41,33,.10);color:var(--primary)}
.pathway-pill-b{background:rgba(212,168,124,.25);color:var(--accent-warm-deep)}
.pathway-title{
  font-family:"Inter Tight",sans-serif;
  font-size:20px;
  font-weight:800;
  color:var(--primary-deep);
  letter-spacing:-.025em;
  line-height:1.2;
  margin-bottom:8px;
}
.pathway-meta{
  font-size:12px;
  color:var(--text-mute);
  letter-spacing:.02em;
  margin-bottom:14px;
}
.pathway-desc{
  font-size:13.5px;
  color:var(--text-soft);
  line-height:1.7;
}
.pathway-semester{
  padding:20px 30px 26px;
}
.pathway-semester + .pathway-semester{
  border-top:1px solid var(--line);
}
.pathway-sem-name{
  font-family:"Inter Tight",sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--accent-warm-deep);
  margin-bottom:10px;
}
.course-table-pathway{
  margin:0;
  border:1px solid var(--line);
}
.course-table-pathway td{padding:11px 14px}

/* ===== SECTION J — ELECTIVES ===== */
.elective-block{
  background:#fff;
  border:1px solid var(--line);
  border-radius:8px;
  overflow:hidden;
  margin-bottom:18px;
}
.elective-block:last-child{margin-bottom:0}
.elective-block-head{
  padding:18px 24px;
  background:var(--bg-card);
  border-bottom:1px solid var(--line);
}
.elective-block-tag{
  display:inline-block;
  font-family:"Inter Tight",sans-serif;
  font-size:13px;
  font-weight:700;
  color:var(--primary-deep);
  letter-spacing:-.01em;
}
.course-table-elective{
  margin:0;
  border:none;
  border-radius:0;
}

/* ===== SECTION K — THE PROJECT (image-led card) ===== */
.project-shell{
  display:grid;
  grid-template-columns:5fr 7fr;
  gap:0;
  background:#fff;
  border:1px solid var(--line);
  border-radius:8px;
  overflow:hidden;
}
@media(max-width:980px){.project-shell{grid-template-columns:1fr}}
.project-image{
  position:relative;
  min-height:340px;
  background:var(--bg-card);
  overflow:hidden;
}
.project-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform 1200ms var(--motion-ease);
}
.project-image:hover img{transform:scale(1.04)}
.project-image-tint{position:absolute;inset:0;background:linear-gradient(180deg, rgba(42,9,8,.10) 0%, rgba(42,9,8,.40) 100%)}
.project-image-label{
  position:absolute;
  bottom:18px;
  left:22px;
  z-index:2;
  color:#fff;
  font-family:"Inter Tight",sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.project-body{
  padding:36px 40px 38px;
}
.project-eyebrow{
  display:inline-block;
  font-size:11px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--primary);
  padding:5px 10px;
  background:rgba(154,41,33,.08);
  border-radius:3px;
  margin-bottom:18px;
}
.project-h{
  font-family:"Inter Tight",sans-serif;
  font-size:26px;
  font-weight:800;
  color:var(--primary-deep);
  letter-spacing:-.03em;
  line-height:1.15;
  margin-bottom:14px;
}
.project-desc{
  font-size:14.5px;
  color:var(--text-soft);
  line-height:1.7;
  margin-bottom:22px;
}
.project-parts{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  padding-top:22px;
  border-top:1px solid var(--line);
}
@media(max-width:540px){.project-parts{grid-template-columns:1fr}}
.project-part{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:6px;
  padding:18px 20px;
}
.project-part-h{
  font-family:"Inter Tight",sans-serif;
  font-size:13px;
  font-weight:700;
  color:var(--primary-deep);
  letter-spacing:-.01em;
  margin-bottom:5px;
}
.project-part-meta{
  font-size:11px;
  color:var(--text-mute);
  letter-spacing:.04em;
  text-transform:uppercase;
  font-weight:600;
  margin-bottom:8px;
}
.project-part-desc{
  font-size:12.5px;
  color:var(--text-soft);
  line-height:1.55;
}

/* ===== SECTION L — DOWNLOAD BAND ===== */
.download-band{
  background:var(--bg-card);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:32px 48px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:32px;
  align-items:center;
}
@media(max-width:768px){.download-band{grid-template-columns:1fr;padding:24px}}
.download-title{
  font-family:"Inter Tight",sans-serif;
  font-size:20px;
  font-weight:800;
  color:var(--primary-deep);
  letter-spacing:-.025em;
  margin-bottom:5px;
}
.download-sub{
  font-size:13.5px;
  color:var(--text-mute);
  line-height:1.6;
}

/* ===== SECTION M — CTA ===== */
.cta-sec{background:var(--bg-card);border-top:1px solid var(--line);padding:80px 48px;text-align:center;position:relative;overflow:hidden}
.cta-sec::before{content:"";position:absolute;top:-120px;left:50%;width:520px;height:520px;transform:translateX(-50%);background:radial-gradient(circle, rgba(154,41,33,.13), rgba(154,41,33,0) 68%);pointer-events:none}
.cta-inner{position:relative;z-index:1;max-width:740px;margin:0 auto}
.cta-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--primary);margin-bottom:16px}
.cta-eyebrow::before,.cta-eyebrow::after{content:"";width:34px;height:1px;background:linear-gradient(90deg, rgba(154,41,33,0), rgba(154,41,33,.75), rgba(154,41,33,0))}
.cta-h2{font-family:"Inter Tight",sans-serif;font-size:38px;font-weight:800;color:var(--primary-deep);margin-bottom:14px;line-height:1.15;letter-spacing:-.035em;text-wrap:balance}
.cta-sub{font-size:15px;color:var(--text-mute);margin:0 auto 32px;max-width:520px;line-height:1.65}
.cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ===== SECTION N — BUTTONS ===== */
.btn-burgundy{background:var(--primary);color:#fff;padding:15px 32px;font-size:14.5px;font-weight:600;border:1px solid var(--primary);border-radius:3px;cursor:pointer;font-family:inherit;letter-spacing:.01em;text-decoration:none;display:inline-block;transition:transform var(--motion-fast) var(--motion-ease), box-shadow var(--motion-fast) var(--motion-ease), background var(--motion-fast) var(--motion-ease)}
.btn-burgundy:hover{transform:translateY(-3px);background:var(--primary-dark);box-shadow:0 16px 34px rgba(154,41,33,.22)}
.btn-burgundy-lead{background:var(--primary);color:#fff;padding:15px 36px;font-size:14.5px;font-weight:600;border:1px solid var(--primary);border-radius:3px 18px 18px 3px;cursor:pointer;font-family:inherit;letter-spacing:.01em;text-decoration:none;display:inline-block;transition:transform var(--motion-fast) var(--motion-ease), box-shadow var(--motion-fast) var(--motion-ease), background var(--motion-fast) var(--motion-ease)}
.btn-burgundy-lead:hover{transform:translateY(-3px);background:var(--primary-dark);box-shadow:0 16px 34px rgba(154,41,33,.22)}
.btn-outline{background:transparent;color:var(--primary);border:1.5px solid var(--primary);padding:14px 34px;font-size:14.5px;font-weight:600;border-radius:3px;cursor:pointer;font-family:inherit;text-decoration:none;display:inline-block;transition:transform var(--motion-fast) var(--motion-ease), background var(--motion-fast) var(--motion-ease), color var(--motion-fast) var(--motion-ease)}
.btn-outline:hover{transform:translateY(-3px);background:var(--primary);color:#fff}

/* ===== SECTION O — FOOTER ===== */
footer{background:var(--primary-deeper)}
.footer{padding:40px 48px 24px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:42px}
.footer-top{background:var(--primary-deeper);border-bottom:1px solid rgba(255,255,255,.06)}
.footer-bottom-grid{background:var(--primary-deeper)}
.footer-brand{font-family:"Inter Tight",sans-serif;font-size:16px;font-weight:700;color:#fff;margin-bottom:8px;letter-spacing:-.015em}
.footer-brand span{color:var(--accent-warm)}
.footer-desc{font-size:12px;color:rgba(255,255,255,.42);line-height:1.65;max-width:280px}
.footer-head{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.42);margin-bottom:14px}
.footer-subhead{margin-top:14px}
.footer-link{display:block;font-size:12px;color:rgba(255,255,255,.62);margin-bottom:8px;text-decoration:none;line-height:1.55;transition:.18s ease}
.footer-link:hover{color:var(--accent-warm);transform:translateX(2px)}
.footer-bottom{background:var(--primary-dark);border-top:1px solid rgba(255,255,255,.06);padding:16px 48px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer-copy{font-size:11px;color:rgba(255,255,255,.34)}

/* ===== MOTION ===== */
.motion-ready [data-reveal]{opacity:0;transform:translateY(24px);transition:opacity var(--motion-med) var(--motion-ease), transform var(--motion-med) var(--motion-ease);will-change:opacity,transform}
.motion-ready [data-reveal].is-visible{opacity:1;transform:translateY(0)}
.motion-ready [data-reveal="left"]{transform:translateX(-28px)}
.motion-ready [data-reveal="right"]{transform:translateX(28px)}
.motion-ready [data-reveal="left"].is-visible,
.motion-ready [data-reveal="right"].is-visible{transform:translateX(0)}
.motion-ready [data-delay="1"]{transition-delay:80ms}
.motion-ready [data-delay="2"]{transition-delay:160ms}
.motion-ready [data-delay="3"]{transition-delay:240ms}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
  .motion-ready [data-reveal],.motion-ready [data-reveal].is-visible{opacity:1;transform:none}
}

/* ===== RESPONSIVE ===== */
@media(max-width:1200px){
  .nav,.sub-nav,.sec,.cta-sec,.footer,.footer-bottom,.download-band{padding-left:32px;padding-right:32px}
  .hero-arg{padding-left:32px;padding-right:32px}
}
@media(max-width:992px){
  .nav{padding:0 24px;overflow-x:auto;scrollbar-width:none}
  .nav::-webkit-scrollbar{display:none}
  .nav-link{padding:20px 12px}
  .nav-apply{margin-left:12px}
  .sub-nav{padding:0 24px}
  .footer{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .nav{padding:0 18px}
  .nav-link{font-size:12px;padding:18px 10px}
  .nav-apply{font-size:12px;padding:9px 14px}
  .nav-logo-main{font-size:13.5px}
  .nav-logo-main small{font-size:10px}
  .sub-nav{padding:0 18px;top:54px}
  .sub-nav-label{padding:11px 14px 11px 0;font-size:10px}
  .sub-nav-link{padding:11px 12px;font-size:12px}
  .sec,.cta-sec{padding:60px 22px}
  .hero-arg{padding:50px 22px 40px}
  .sec-h2{font-size:28px}
  .sec-lead{font-size:14.5px;margin-bottom:32px}
  .cta-h2{font-size:30px}
  .cta-row{flex-direction:column;align-items:stretch}
  .btn-burgundy,.btn-burgundy-lead,.btn-outline{width:100%;text-align:center}
  .acc-trigger{padding:18px 18px;gap:14px}
  .acc-trigger-title{font-size:16px}
  .acc-body{padding:0 18px 18px}
  .course-table{font-size:12px}
  .course-table th,.course-table td{padding:8px 10px}
  .course-code-chip{font-size:10px;padding:2px 6px}
  .course-name{font-size:12.5px}
  .pathway-head,.pathway-semester{padding-left:22px;padding-right:22px}
  .project-body{padding:26px 24px}
  .project-h{font-size:22px}
  .footer{grid-template-columns:1fr;padding:32px 24px 20px;gap:28px}
  .footer-bottom{padding:14px 24px;flex-direction:column;align-items:flex-start}
}

.course-code-link,
.course-name-link {
  text-decoration: none;
  color: inherit;
  display: block;
  transition: background-color 150ms ease;
}

.course-code-link:hover .course-code-chip {
  /* darker burgundy on hover */
  background: var(--primary-dark);
}

.course-name-link:hover .course-name {
  /* burgundy text on hover */
  color: var(--primary);
}