/* ============================================================
   VARSITY WISE — sanc_detail.css
   Aesthetic: Editorial magazine · Deep crimson · Refined
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,700;0,800;1,700;1,800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;0,9..40,800&display=swap');

/* ── Tokens ──────────────────────────────────────────────── */
:root {
  --crimson:        #9e0157;
  --crimson-dark:   #7a0041;
  --crimson-deeper: #5c0030;
  --crimson-light:  #fce7f3;
  --crimson-mid:    #f3c6dc;
  --crimson-tint:   rgba(158,1,87,.06);
  --crimson-tint2:  rgba(158,1,87,.12);

  --ink:            #0f1117;
  --ink-80:         #1e2333;
  --ink-60:         #3d4461;
  --ink-40:         #6b7280;
  --ink-20:         #94a3b8;
  --ink-10:         #e2e8f0;
  --ink-05:         #f8fafc;

  --surface:        #ffffff;
  --surface-2:      #fafafa;
  --surface-3:      #f4f6f9;
  --border:         #e5e9f0;
  --border-strong:  #cbd2de;

  --shadow-xs:    0 1px 2px rgba(0,0,0,.05);
  --shadow-sm:    0 1px 4px rgba(0,0,0,.06), 0 2px 8px rgba(0,0,0,.04);
  --shadow-md:    0 4px 16px rgba(0,0,0,.08), 0 1px 4px rgba(0,0,0,.04);

  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'DM Sans', system-ui, sans-serif;

  --transition:   .18s ease;
  --tap-min:      44px;
  --radius-sm:    8px;
  --radius-md:    12px;
  --radius-lg:    18px;
  --radius-xl:    24px;
}

/* ── Reset ───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body { font-family: var(--font-body); color: var(--ink-60); background: var(--surface-3); }
a { color: inherit; }
img { display: block; max-width: 100%; height: auto; }

/* ── Utilities ───────────────────────────────────────────── */
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ── Breadcrumb (inside dark hero) ──────────────────────── */
.breadcrumb-bar {
  background: rgba(255,255,255,.07);
  padding: 10px 20px;
  border-bottom: 1px solid rgba(255,255,255,.09);
}

.breadcrumb {
  max-width: 1160px; margin: 0 auto;
  display: flex; align-items: center; gap: 4px; flex-wrap: wrap;
  list-style: none; font-size: .775rem; color: rgba(255,255,255,.50);
}

.breadcrumb a {
  color: rgba(255,255,255,.65);
  text-decoration: none;
  transition: color var(--transition);
  min-height: var(--tap-min); display: inline-flex; align-items: center; padding: 0 2px;
}
.breadcrumb a:hover { color: #fff; }
.breadcrumb-sep { color: rgba(255,255,255,.24); margin: 0 2px; }
.breadcrumb-current { color: rgba(255,255,255,.84); font-weight: 600; }

/* ── Hero (matches about-hero style) ────────────────────── */
.inst-hero {
  background: var(--crimson-deeper);
  position: relative;
  overflow: hidden;
}

/* Faint geometric circles — mirrors about-hero */
.inst-hero::before,
.inst-hero::after {
  content: '';
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  background: rgba(255,255,255,.055);
}
.inst-hero::before { width: 500px; height: 500px; top: -200px; right: -120px; }
.inst-hero::after  { width: 300px; height: 300px; bottom: -150px; left: -80px; }

.hero-inner {
  max-width: 1160px; margin: 0 auto;
  padding: 36px 20px 40px;
  position: relative;
  z-index: 1;
}

.hero-body {
  display: flex; align-items: flex-start; gap: 20px; flex-wrap: wrap;
}

.hero-icon-wrap { flex-shrink: 0; }

.hero-icon {
  width: 68px; height: 68px; border-radius: 16px;
  background: linear-gradient(135deg, rgba(255,255,255,.15), rgba(255,255,255,.06));
  border: 1px solid rgba(255,255,255,.18);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.80);
  box-shadow: 0 8px 24px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.15);
  backdrop-filter: blur(8px);
}

.hero-text { flex: 1; min-width: 0; }

.hero-eyebrow {
  font-size: .68rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: rgba(255,255,255,.5); margin-bottom: 10px;
  display: block;
}
/* Remove decorative line */
.hero-eyebrow::after { display: none; }

.hero-title {
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 3.5vw, 2.1rem);
  font-weight: 800;
  color: #fff;
  line-height: 1.18;
  letter-spacing: -.025em;
  margin-bottom: 18px;
}

.hero-chips { display: flex; flex-wrap: wrap; gap: 7px; }

.hero-chip {
  display: inline-flex; align-items: center; gap: 5px;
  background: rgba(255,255,255,.09); color: rgba(255,255,255,.80);
  font-size: .72rem; font-weight: 600; padding: 5px 12px; border-radius: 9999px;
  border: 1px solid rgba(255,255,255,.14);
  min-height: 30px;
}

.chip-new    { background: rgba(34,197,94,.15);  border-color: rgba(34,197,94,.3);  color: #86efac; }
.chip-legacy { background: rgba(251,191,36,.15); border-color: rgba(251,191,36,.3); color: #fde68a; }

/* ── Accreditation strip ─────────────────────────────────── */
.accred-strip {
  background: rgba(0,0,0,.18);
  border-top: 1px solid rgba(255,255,255,.07);
  padding: 14px 20px;
  position: relative;
  z-index: 1;
}

.accred-strip-inner {
  max-width: 1160px; margin: 0 auto;
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}

.accred-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #22c55e;
  box-shadow: 0 0 0 3px rgba(34,197,94,.20);
  animation: pulse-green 2.4s ease-in-out infinite;
  flex-shrink: 0;
}

@keyframes pulse-green {
  0%, 100% { box-shadow: 0 0 0 3px rgba(34,197,94,.20); }
  50%       { box-shadow: 0 0 0 6px rgba(34,197,94,.08); }
}

.accred-text { font-size: .75rem; font-weight: 600; color: rgba(255,255,255,.55); }
.accred-text strong { color: rgba(255,255,255,.80); }

/* ── Page body ───────────────────────────────────────────── */
.page-body { padding: 32px 20px 72px; }

.page-inner {
  max-width: 1160px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 28px; align-items: start;
}

/* ── Card base ───────────────────────────────────────────── */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  margin-bottom: 20px;
}
.card:last-child { margin-bottom: 0; }

.card-head {
  padding: 16px 22px 14px;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 10px;
}

.card-head-icon {
  width: 32px; height: 32px;
  border-radius: var(--radius-sm); flex-shrink: 0;
  background: var(--crimson-light);
  color: var(--crimson);
  border: 1px solid var(--crimson-mid);
  display: flex; align-items: center; justify-content: center;
}

.card-head-label {
  font-size: .65rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  color: var(--crimson);
}

.card-head-title {
  font-family: var(--font-display);
  font-size: .92rem; font-weight: 700; color: var(--ink); margin-top: 1px;
  letter-spacing: -.01em;
}

.card-body { padding: 20px 22px; }

/* ── Back link ───────────────────────────────────────────── */
.back-link {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--ink-40); font-size: .8rem; font-weight: 700;
  text-decoration: none; margin-bottom: 22px;
  padding: 0 14px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--surface);
  box-shadow: var(--shadow-xs);
  transition: color var(--transition), border-color var(--transition), box-shadow var(--transition);
  min-height: var(--tap-min);
  -webkit-tap-highlight-color: transparent;
}
.back-link:hover { color: var(--crimson); border-color: var(--crimson-mid); box-shadow: var(--shadow-sm); }

/* ── Programmes table ────────────────────────────────────── */
.prog-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }

.prog-table {
  width: 100%; border-collapse: collapse; font-size: .855rem;
}

.prog-table th {
  text-align: left; padding: 10px 16px;
  font-size: .65rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
  color: var(--ink-40);
  background: var(--surface-3);
  border-bottom: 2px solid var(--border);
  white-space: nowrap;
}

.prog-table td {
  padding: 13px 16px;
  border-bottom: 1px solid var(--border);
  color: var(--ink-60); vertical-align: middle;
}

.prog-table tbody tr:last-child td { border-bottom: none; }
.prog-table tbody tr { transition: background var(--transition); }
.prog-table tbody tr:hover td { background: var(--surface-2); }

.prog-name {
  font-family: var(--font-display);
  font-weight: 700; color: var(--ink); line-height: 1.4; font-size: .9rem;
  letter-spacing: -.01em;
}

.prog-badge {
  display: inline-flex; align-items: center;
  background: var(--crimson-light); color: var(--crimson-dark);
  border: 1px solid var(--crimson-mid);
  font-size: .72rem; font-weight: 700;
  padding: 3px 11px; border-radius: 9999px; white-space: nowrap;
}

.prog-dash { color: var(--ink-20); }

/* ── Programmes: mobile stacked cards ───────────────────── */
.prog-cards { display: none; flex-direction: column; gap: 0; }

.prog-card {
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
  display: flex; flex-direction: column; gap: 6px;
}
.prog-card:first-child { padding-top: 2px; }
.prog-card:last-child  { border-bottom: none; padding-bottom: 2px; }

.prog-card-name {
  font-family: var(--font-display);
  font-size: .875rem; font-weight: 700; color: var(--ink); line-height: 1.38;
  letter-spacing: -.01em;
}

.prog-card-meta { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }

.prog-card-chip {
  display: inline-flex; align-items: center; gap: 4px;
  background: var(--surface-3); border: 1px solid var(--border);
  color: var(--ink-40); font-size: .7rem; font-weight: 600;
  padding: 4px 10px; border-radius: 9999px;
  min-height: 30px;
}

.prog-card-chip strong { color: var(--crimson); }

/* ── Legacy programmes ───────────────────────────────────── */
.legacy-note {
  font-size: .82rem; color: var(--ink-40); line-height: 1.65;
  margin-bottom: 16px; padding-bottom: 16px; border-bottom: 1px solid var(--border);
}

.legacy-tags { display: flex; flex-wrap: wrap; gap: 8px; list-style: none; }

.legacy-tag {
  background: #fffbeb; color: #92400e;
  font-size: .75rem; font-weight: 700;
  padding: 6px 13px; border-radius: var(--radius-sm);
  border: 1px solid #fde68a;
  line-height: 1.35;
  min-height: 32px; display: inline-flex; align-items: center;
}

/* ── Contact ─────────────────────────────────────────────── */
.contact-list { display: flex; flex-direction: column; gap: 14px; }

.contact-row { display: flex; align-items: flex-start; gap: 14px; }

.contact-icon {
  width: 38px; height: 38px; border-radius: 10px; flex-shrink: 0;
  background: var(--crimson-light);
  color: var(--crimson);
  border: 1px solid var(--crimson-mid);
  display: flex; align-items: center; justify-content: center;
}

.contact-meta { min-width: 0; }

.contact-label {
  font-size: .63rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
  color: var(--ink-20); margin-bottom: 3px;
}

.contact-value { font-size: .88rem; font-weight: 600; color: var(--ink); word-break: break-word; }

.contact-value a {
  color: var(--crimson); text-decoration: none;
  transition: color var(--transition);
  min-height: var(--tap-min); display: inline-flex; align-items: center;
  font-weight: 500;
}
.contact-value a:hover { color: var(--crimson-dark); text-decoration: underline; }

/* ── Sidebar ─────────────────────────────────────────────── */
.sidebar { position: sticky; top: 20px; }

.qi-list { display: flex; flex-direction: column; }

.qi-row {
  display: flex; flex-direction: column; gap: 3px;
  padding: 13px 0; border-bottom: 1px solid var(--border);
}
.qi-row:first-child { padding-top: 0; }
.qi-row:last-child  { border-bottom: none; padding-bottom: 0; }

.qi-label {
  font-size: .63rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
  color: var(--ink-20);
}

.qi-value {
  font-size: .875rem; font-weight: 700; color: var(--ink); line-height: 1.35;
}

.qi-badge {
  display: inline-flex; align-items: center;
  padding: 3px 10px; border-radius: 9999px;
  font-size: .65rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
}

.qi-badge-new    { background: #dcfce7; color: #166534; }
.qi-badge-legacy { background: #fef3c7; color: #92400e; }

/* ── Related links ───────────────────────────────────────── */
.related-list { display: flex; flex-direction: column; gap: 0; }

.related-link {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  padding: 0; border-bottom: 1px solid var(--border);
  font-size: .84rem; font-weight: 700; color: var(--crimson);
  text-decoration: none; transition: color var(--transition);
  min-height: var(--tap-min);
  -webkit-tap-highlight-color: transparent;
}
.related-link:last-child { border-bottom: none; }
.related-link:hover { color: var(--crimson-dark); }

.related-link-arrow { flex-shrink: 0; font-size: .8rem; }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 860px) {
  .page-inner { grid-template-columns: 1fr; gap: 0; }
  .sidebar { position: static; margin-top: 20px; }

  .qi-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
  }
  .qi-row {
    padding: 12px;
    border-bottom: 1px solid var(--border);
    border-right: 1px solid var(--border);
  }
  .qi-row:nth-child(even) { border-right: none; }
  .qi-row:last-child,
  .qi-row:nth-last-child(2):nth-child(odd) { border-bottom: none; }
}

@media (max-width: 600px) {
  .hero-inner  { padding: 24px 16px 28px; }
  .hero-icon   { width: 52px; height: 52px; border-radius: 12px; }
  .hero-title  { font-size: 1.25rem; margin-bottom: 14px; }
  .hero-body   { gap: 14px; }
  .accred-strip { padding: 11px 16px; }
  .accred-text  { font-size: .72rem; }
  .page-body   { padding: 18px 16px 60px; }
  .card-body   { padding: 14px 16px; }
  .card-head   { padding: 12px 16px 10px; }
  .card        { margin-bottom: 16px; }
  .prog-table-wrap { display: none; }
  .prog-cards  { display: flex; }
  .qi-list     { grid-template-columns: 1fr; }
  .qi-row      { border-right: none; padding: 10px 0; }
  .qi-row:last-child { border-bottom: none; }
  .contact-row  { gap: 10px; }
  .contact-icon { width: 34px; height: 34px; }
  .breadcrumb  { font-size: .7rem; gap: 2px; }
  .back-link   { font-size: .78rem; }
}

@media (hover: none) {
  .prog-table tbody tr:hover td { background: transparent; }
  .back-link:hover { color: var(--ink-40); border-color: var(--border); box-shadow: var(--shadow-xs); }
  .related-link:hover { color: var(--crimson); }
  .related-link:active { color: var(--crimson-dark); }
  .contact-value a:hover { color: var(--crimson); }
  .contact-value a:active { color: var(--crimson-dark); }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { transition: none !important; animation: none !important; }
  .accred-dot { animation: none; }
}