
@import url("https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,650;9..144,800&family=IBM+Plex+Mono:wght@500;700&family=Inter:wght@400;500;650;700;800&family=Space+Grotesk:wght@500;650;700&display=swap");

:root {
  color-scheme: light;
  --ink: #102326;
  --ink-soft: #26393d;
  --muted: #5b686d;
  --line: #d8dfdc;
  --paper: #ffffff;
  --surface: #f6f8f5;
  --surface-warm: #fff9ed;
  --accent: #0f9f95;
  --accent-dark: #075f5a;
  --accent-soft: #e2f7f4;
  --gold: #f0a638;
  --gold-soft: #fff1d6;
  --blue: #2f5fd0;
  --blue-soft: #eaf0ff;
  --plum: #6f3f83;
  --plum-soft: #f4e9f7;
  --danger: #9f2d20;
  --shadow-soft: 0 18px 45px rgba(16, 35, 38, 0.08);
  --shadow-small: 0 8px 24px rgba(16, 35, 38, 0.06);
  --radius-sm: 0.35rem;
  --radius-md: 0.55rem;
  --radius-lg: 0.8rem;
  --font-display: "Space Grotesk", "Manrope", ui-sans-serif, system-ui, sans-serif;
  --font-body: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-accent: "Fraunces", Georgia, serif;
  --font-mono: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  --body-bg: linear-gradient(180deg, #f6f8f5 0%, #eef7f5 100%);
  --header-bg: rgba(255, 255, 255, 0.94);
  --header-border: rgba(16, 35, 38, 0.12);
  --footer-bg: rgba(255, 255, 255, 0.92);
  --nav-bg: #f7fbfb;
  --nav-hover-bg: #ffffff;
  --active-bg: var(--ink);
  --active-fg: #ffffff;
  --link-color: var(--accent-dark);
  --button-bg: var(--accent-dark);
  --button-fg: #ffffff;
  --panel-bg: var(--paper);
  --panel-bg-subtle: #fbfcfd;
  --panel-translucent: rgba(255, 255, 255, 0.72);
  --warm-panel-bg: var(--surface-warm);
  --warm-line: #ecd3a2;
  --blue-panel-bg: #f7fbfb;
  --blue-line: #d6e3e8;
  --table-head-bg: #f7fafb;
  --input-bg: #ffffff;
  --input-border: #b8c3cc;
  --logo-tile-bg: #ffffff;
  --media-bg: #e6ecef;
  --selected-bg: #eefaf8;
  --button-shadow: 0 0.2rem 0 rgba(16, 35, 38, 0.16);
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    color-scheme: dark;
    --ink: #e8f4f2;
    --ink-soft: #c7dcda;
    --muted: #a7bbb9;
    --line: #284347;
    --paper: #112326;
    --surface: #071719;
    --surface-warm: #211b12;
    --accent: #20c9bd;
    --accent-dark: #79e8df;
    --accent-soft: #102f2e;
    --gold: #ffc061;
    --gold-soft: #302514;
    --blue: #99baff;
    --blue-soft: #121f38;
    --plum: #e0a8f3;
    --plum-soft: #2b1a32;
    --danger: #ff9488;
    --shadow-soft: 0 18px 45px rgba(0, 0, 0, 0.35);
    --shadow-small: 0 10px 26px rgba(0, 0, 0, 0.28);
    --body-bg: linear-gradient(180deg, #071719 0%, #0d2427 100%);
    --header-bg: rgba(7, 23, 25, 0.94);
    --header-border: rgba(121, 232, 223, 0.18);
    --footer-bg: rgba(7, 23, 25, 0.94);
    --nav-bg: #0d2427;
    --nav-hover-bg: #153337;
    --active-bg: #e8f4f2;
    --active-fg: #071719;
    --link-color: #79e8df;
    --button-bg: #20c9bd;
    --button-fg: #071719;
    --panel-bg: var(--paper);
    --panel-bg-subtle: #142b2f;
    --panel-translucent: rgba(17, 35, 38, 0.72);
    --warm-panel-bg: #211b12;
    --warm-line: #6b5429;
    --blue-panel-bg: #101e2d;
    --blue-line: #29445d;
    --table-head-bg: #142b2f;
    --input-bg: #0b1d20;
    --input-border: #3a5960;
    --logo-tile-bg: #f7fbfb;
    --media-bg: #172f34;
    --selected-bg: #123a38;
    --button-shadow: 0 0.2rem 0 rgba(0, 0, 0, 0.35);
  }
}

:root[data-theme="dark"] {
  color-scheme: dark;
  --ink: #e8f4f2;
  --ink-soft: #c7dcda;
  --muted: #a7bbb9;
  --line: #284347;
  --paper: #112326;
  --surface: #071719;
  --surface-warm: #211b12;
  --accent: #20c9bd;
  --accent-dark: #79e8df;
  --accent-soft: #102f2e;
  --gold: #ffc061;
  --gold-soft: #302514;
  --blue: #99baff;
  --blue-soft: #121f38;
  --plum: #e0a8f3;
  --plum-soft: #2b1a32;
  --danger: #ff9488;
  --shadow-soft: 0 18px 45px rgba(0, 0, 0, 0.35);
  --shadow-small: 0 10px 26px rgba(0, 0, 0, 0.28);
  --body-bg: linear-gradient(180deg, #071719 0%, #0d2427 100%);
  --header-bg: rgba(7, 23, 25, 0.94);
  --header-border: rgba(121, 232, 223, 0.18);
  --footer-bg: rgba(7, 23, 25, 0.94);
  --nav-bg: #0d2427;
  --nav-hover-bg: #153337;
  --active-bg: #e8f4f2;
  --active-fg: #071719;
  --link-color: #79e8df;
  --button-bg: #20c9bd;
  --button-fg: #071719;
  --panel-bg: var(--paper);
  --panel-bg-subtle: #142b2f;
  --panel-translucent: rgba(17, 35, 38, 0.72);
  --warm-panel-bg: #211b12;
  --warm-line: #6b5429;
  --blue-panel-bg: #101e2d;
  --blue-line: #29445d;
  --table-head-bg: #142b2f;
  --input-bg: #0b1d20;
  --input-border: #3a5960;
  --logo-tile-bg: #f7fbfb;
  --media-bg: #172f34;
  --selected-bg: #123a38;
  --button-shadow: 0 0.2rem 0 rgba(0, 0, 0, 0.35);
}

* { box-sizing: border-box; }
html { font-family: var(--font-body); color: var(--ink); background: var(--surface); }
body { margin: 0; line-height: 1.55; background: var(--body-bg); }
a { color: var(--link-color); text-decoration-thickness: 0.08em; text-underline-offset: 0.18em; }
.skip-link { position: absolute; left: -999px; top: 1rem; background: var(--active-bg); color: var(--active-fg); padding: 0.5rem 0.75rem; z-index: 10; }
.skip-link:focus { left: 1rem; }
.site-header { position: sticky; top: 0; z-index: 5; border-top: 0.22rem solid var(--accent); border-bottom: 1px solid var(--header-border); background: var(--header-bg); backdrop-filter: blur(16px); }
.site-header-inner { max-width: 1180px; margin: 0 auto; padding: 0.55rem 1.25rem; display: grid; grid-template-columns: minmax(14rem, auto) minmax(0, 1fr) auto; align-items: center; gap: 1rem; }
.brand { display: inline-flex; width: fit-content; align-items: center; gap: 0.72rem; font-family: var(--font-display); font-weight: 800; color: var(--ink); text-decoration: none; white-space: nowrap; }
.brand-logo-frame { display: inline-flex; width: 8.6rem; height: 2.85rem; align-items: center; justify-content: flex-start; overflow: hidden; border-radius: var(--radius-sm); background: var(--logo-tile-bg); }
.brand-logo { display: block; width: 100%; height: 100%; object-fit: contain; object-position: left center; }
.brand-lockup { display: grid; gap: 0.1rem; padding-left: 0.68rem; border-left: 1px solid var(--line); line-height: 1; }
.brand-lockup span { font-size: 1.02rem; color: var(--ink); }
.brand-lockup small { font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0; text-transform: uppercase; color: var(--accent-dark); }
.brand-sigil { display: inline-grid; place-items: center; min-width: 2.65rem; min-height: 2.2rem; padding: 0 0.4rem; border-radius: var(--radius-sm); background: var(--active-bg); color: var(--active-fg); box-shadow: inset 0 -0.2rem 0 rgba(15, 159, 149, 0.7); }
.brand-text { color: var(--ink-soft); }
nav[aria-label="Primary navigation"] { display: flex; flex-wrap: nowrap; gap: 0.2rem; justify-content: flex-end; max-width: 100%; padding: 0.22rem; overflow-x: auto; border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--nav-bg); scrollbar-width: none; }
nav[aria-label="Primary navigation"]::-webkit-scrollbar { display: none; }
nav[aria-label="Primary navigation"] a { display: inline-flex; min-height: 2.15rem; align-items: center; border-radius: var(--radius-sm); padding: 0.34rem 0.74rem; color: var(--ink); text-decoration: none; font-size: 0.9rem; font-weight: 800; white-space: nowrap; }
nav[aria-label="Primary navigation"] a:hover { background: var(--nav-hover-bg); color: var(--accent-dark); }
nav[aria-label="Primary navigation"] a[aria-current="page"] { background: var(--active-bg); color: var(--active-fg); box-shadow: inset 0 -0.18rem 0 var(--accent); }
.theme-control { display: flex; justify-content: flex-end; }
.theme-toggle { display: none; min-height: 2.35rem; gap: 0.45rem; padding: 0.4rem 0.62rem; border: 1px solid var(--line); border-radius: var(--radius-sm); background: var(--panel-bg); color: var(--ink); box-shadow: none; font-size: 0.86rem; }
.theme-js .theme-toggle { display: inline-flex; }
.theme-toggle:hover, .theme-toggle:focus-visible { border-color: var(--accent); color: var(--accent-dark); outline: none; }
.theme-toggle:focus-visible { box-shadow: 0 0 0 0.18rem rgba(32, 201, 189, 0.26); }
.theme-toggle-indicator { width: 0.78rem; height: 0.78rem; border-radius: 99px; border: 2px solid currentColor; background: linear-gradient(90deg, currentColor 0 50%, transparent 50% 100%); }
.theme-toggle-text { font-family: var(--font-mono); font-weight: 800; text-transform: uppercase; letter-spacing: 0; }
.page { max-width: 1180px; margin: 0 auto; padding: 2rem 1.25rem 4rem; }
.hero { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 2rem; align-items: end; min-height: 32rem; padding: 4rem 0 2rem; }
.eyebrow { margin: 0 0 0.75rem; font-family: var(--font-mono); font-weight: 700; letter-spacing: 0; text-transform: uppercase; color: var(--accent-dark); font-size: 0.78rem; }
h1, h2, h3 { line-height: 1.12; letter-spacing: 0; font-family: var(--font-display); }
h1 { margin: 0; font-size: 4.2rem; max-width: 930px; }
h2 { margin: 0 0 0.75rem; font-size: 1.55rem; }
h3 { margin: 0 0 0.35rem; font-size: 1.12rem; }
.lead { margin: 1rem 0 0; max-width: 820px; font-size: 1.15rem; color: var(--muted); }
.deadline-panel, .deadline-strip, .notice, .action-card, .draft-card, .form-shell, .calendar-shell, .draft-section, .step, .resource-link, .specimen-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-md); box-shadow: var(--shadow-small); }
.deadline-panel { padding: 1.1rem; display: grid; gap: 0.75rem; }
.deadline-label, .deadline-strip span { display: block; color: var(--muted); font-size: 0.85rem; }
.deadline-panel strong, .deadline-strip strong { display: block; color: var(--ink); font-size: 1rem; }
.deadline-strip { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; padding: 1rem; margin: 1rem 0 2rem; border-left: 0.3rem solid var(--gold); background: var(--warm-panel-bg); }
.section { margin-top: 2.25rem; }
.section-heading { display: flex; justify-content: space-between; gap: 1rem; align-items: end; margin-bottom: 1rem; }
.section-heading p { margin: 0; color: var(--muted); max-width: 680px; }
.action-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1rem; }
.action-card { padding: 1.05rem; min-height: 12rem; display: flex; flex-direction: column; align-items: flex-start; }
.action-card p { color: var(--muted); }
.count { display: inline-grid; place-items: center; width: 2rem; height: 2rem; border-radius: 99px; background: var(--blue-soft); color: var(--blue); font-weight: 800; margin-bottom: 0.8rem; }
.button-link, button { display: inline-flex; align-items: center; justify-content: center; min-height: 2.5rem; padding: 0.55rem 0.85rem; border: 1px solid var(--button-bg); border-radius: var(--radius-sm); background: var(--button-bg); color: var(--button-fg); font: inherit; font-weight: 800; text-decoration: none; cursor: pointer; box-shadow: var(--button-shadow); }
.button-link.secondary { background: var(--paper); color: var(--accent-dark); border-color: var(--accent); }
.button-link.quiet { background: transparent; color: var(--ink); border-color: var(--line); box-shadow: none; }
.action-card .button-link { margin-top: auto; }
.compact-link { min-height: 2.1rem; padding: 0.42rem 0.65rem; white-space: nowrap; font-size: 0.92rem; }
.notice { padding: 1.1rem; margin-top: 2rem; border-left: 0.3rem solid var(--accent); }
.notice.strong { background: var(--accent-soft); }
.notice p:last-child { margin-bottom: 0; }
.page-header { padding: 3rem 0 1rem; }
.page-header.compact { padding-top: 1.5rem; }
.resource-panel { padding: 1.2rem; border: 1px solid var(--line); border-radius: var(--radius-lg); background: var(--panel-translucent); }
.resource-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0.85rem; }
.resource-link { padding: 1rem; min-height: 10rem; }
.resource-link p { margin-bottom: 0; color: var(--muted); }
.resource-link a { color: var(--ink); text-decoration: none; }
.resource-link a:hover { color: var(--accent-dark); text-decoration: underline; }
.section-jump { margin-top: 1rem; }
.section-nav { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.section-nav a { display: inline-flex; align-items: center; min-height: 2.35rem; padding: 0.45rem 0.7rem; border: 1px solid var(--line); border-radius: var(--radius-sm); background: var(--panel-bg); color: var(--ink); font-weight: 750; text-decoration: none; }
.featured-supervisor { display: grid; grid-template-columns: minmax(260px, 360px) minmax(0, 1fr); gap: 1.5rem; align-items: start; padding: 1.25rem; background: var(--warm-panel-bg); border: 1px solid var(--warm-line); border-left: 0.35rem solid var(--gold); border-radius: var(--radius-lg); box-shadow: var(--shadow-soft); }
.featured-supervisor-media { aspect-ratio: 3 / 4; border-radius: var(--radius-md); overflow: hidden; background: var(--media-bg); }
.featured-supervisor-media img { width: 100%; height: 100%; display: block; object-fit: cover; object-position: 50% 18%; }
.featured-supervisor-content { display: grid; align-content: start; gap: 1rem; }
.profile-title-row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.flag-pair { display: inline-flex; align-items: center; gap: 0.25rem; font-size: 1.55rem; line-height: 1; }
.scholar-inline { display: inline-flex; align-items: center; min-height: 2rem; margin-left: 0.5rem; padding: 0.3rem 0.55rem; border: 1px solid var(--accent); border-radius: var(--radius-sm); background: var(--accent-soft); color: var(--accent-dark); font-size: 0.92rem; font-weight: 800; text-decoration: none; vertical-align: middle; }
.feature-lead { max-width: 82ch; font-size: 1.08rem; color: var(--ink-soft); }
.stats-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 0.75rem; }
.stats-grid div { min-height: 5.3rem; padding: 0.85rem; border: 1px solid var(--warm-line); border-radius: var(--radius-md); background: var(--panel-bg); }
.stats-grid strong { display: block; font-size: 1.75rem; line-height: 1; color: var(--accent-dark); }
.stats-grid span { display: block; margin-top: 0.4rem; color: var(--muted); font-weight: 700; }
.snapshot-note, .industry-note { margin: 0; max-width: 86ch; color: var(--muted); font-weight: 650; }
.bio-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.bio-grid > div { padding: 1rem; border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--panel-bg); }
.bio-grid p { color: var(--muted); }
.research-lanes { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.75rem; }
.research-lanes section { padding: 1rem; border: 1px solid var(--blue-line); border-radius: var(--radius-md); background: var(--blue-panel-bg); }
.research-lanes p { margin-bottom: 0; color: var(--muted); }
.supervisor-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem; }
.supervisor-grid.compact { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.supervisor-card { padding: 1.15rem; background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-md); box-shadow: var(--shadow-small); }
.supervisor-card p { color: var(--muted); }
.supervisor-tag { margin-top: -0.35rem; color: var(--accent-dark); font-weight: 800; }
.featured-supervisor, #prof-ling, #dr-shamin, #dr-dangor, #research-area-map { scroll-margin-top: 7rem; }
.fit-detail { margin-top: 0.8rem; border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--panel-bg-subtle); }
.fit-detail summary { cursor: pointer; padding: 0.75rem 0.85rem; font-weight: 800; color: var(--ink); }
.fit-detail > *:not(summary) { margin: 0 0.85rem 0.85rem; }
.vision-header h1 { max-width: 980px; }
.vision-note { margin-top: 1rem; padding: 1.3rem; background: var(--panel-bg-subtle); border: 1px solid var(--line); border-left: 0.35rem solid var(--accent); border-radius: var(--radius-md); }
.vision-note p { max-width: 82ch; }
.wisdom-panel { display: grid; grid-template-columns: minmax(0, 1fr); gap: 0.75rem; padding: 1.3rem; background: var(--warm-panel-bg); border: 1px solid var(--warm-line); border-left: 0.35rem solid var(--gold); border-radius: var(--radius-md); }
.wisdom-panel p { max-width: 86ch; }
.wisdom-panel blockquote { margin: 0; padding: 0.9rem 1rem; border-left: 0.22rem solid var(--accent); background: var(--panel-translucent); font-family: var(--font-accent); font-size: 1.25rem; font-weight: 800; color: var(--accent-dark); }
.wisdom-panel blockquote p { margin: 0; }
.vision-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.vision-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-md); padding: 1.15rem; box-shadow: var(--shadow-small); }
.vision-card p { color: var(--muted); }
.journey-band { background: var(--blue-soft); border: 1px solid var(--blue-line); border-radius: var(--radius-md); padding: 1.35rem; }
.journey-band p { max-width: 86ch; }
.research-header { max-width: 980px; }
.research-principle p { max-width: 88ch; }
.comparison-table td:first-child { color: var(--muted); }
.comparison-table td:last-child { font-weight: 650; }
.bridge-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0.75rem; }
.bridge-step { display: grid; grid-template-columns: 2.4rem 1fr; gap: 0.75rem; padding: 1rem; background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-md); min-height: 9rem; box-shadow: var(--shadow-small); }
.bridge-step > span { display: grid; place-items: center; width: 2rem; height: 2rem; border-radius: 99px; background: var(--blue-soft); color: var(--blue); font-weight: 800; }
.bridge-step p { margin: 0.25rem 0 0; color: var(--muted); }
.example-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem; }
.example-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-md); padding: 1.15rem; box-shadow: var(--shadow-small); }
.example-card p { color: var(--muted); }
.breadcrumb { display: flex; gap: 0.45rem; align-items: center; color: var(--muted); margin-top: 1rem; font-size: 0.95rem; }
.draft-list { display: grid; gap: 0.75rem; }
.draft-card { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1rem; }
.draft-card p { margin: 0.25rem 0 0; color: var(--muted); }
.draft-section { padding: 1.2rem; margin-top: 1rem; }
.draft-section p { max-width: 76ch; }
.feedback-note-page { background: var(--surface); }
.feedback-note-page .page { max-width: 880px; padding-top: 1.25rem; }
.feedback-header h1 { font-size: 3rem; }
.feedback-header .lead { max-width: 760px; }
.feedback-notice { margin-top: 1rem; }
.feedback-section p, .feedback-section li { max-width: 72ch; }
.table-wrap { max-width: 100%; overflow-x: auto; contain: inline-size; border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--paper); box-shadow: var(--shadow-small); }
table { width: 100%; border-collapse: collapse; min-width: 760px; }
th, td { padding: 0.75rem; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; }
th { background: var(--table-head-bg); font-size: 0.9rem; font-family: var(--font-mono); text-transform: uppercase; }
ul, ol { padding-left: 1.35rem; }
.revision-steps { display: grid; gap: 0.8rem; }
.step { display: grid; grid-template-columns: 3rem 1fr; gap: 1rem; padding: 1rem; }
.step > span { display: grid; place-items: center; width: 2.25rem; height: 2.25rem; background: var(--accent-soft); color: var(--accent-dark); border-radius: 99px; font-weight: 800; }
.two-col { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.check-list li { margin-bottom: 0.5rem; }
.form-shell { padding: 1.2rem; max-width: 920px; }
.form-grid { min-width: 0; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.form-grid > * { min-width: 0; }
label { min-width: 0; display: grid; gap: 0.35rem; font-weight: 700; }
label span { font-weight: 700; }
input, select, textarea { min-width: 0; width: 100%; border: 1px solid var(--input-border); border-radius: var(--radius-sm); padding: 0.7rem; font: inherit; background: var(--input-bg); color: var(--ink); }
textarea { resize: vertical; }
.full { grid-column: 1 / -1; }
.checkbox { display: flex; align-items: flex-start; gap: 0.65rem; }
.checkbox input { width: auto; margin-top: 0.35rem; }
.hidden-field, .hidden { display: none !important; }
.calendar-shell { padding: 1rem; }
.schedule-status { margin-top: 1rem; }
.schedule-table { margin-top: 1rem; }
.schedule-table table { min-width: 1280px; }
.schedule-note { margin: 1rem 0 0; color: var(--muted); font-weight: 700; }
.page-turner { display: flex; justify-content: space-between; gap: 1rem; margin-top: 2rem; }
.styleguide-hero h1 { max-width: 780px; }
.brand-principles { display: flex; flex-wrap: wrap; gap: 0.55rem; }
.brand-principles span { display: inline-flex; align-items: center; min-height: 2.2rem; padding: 0.35rem 0.7rem; border-radius: 99px; background: var(--active-bg); color: var(--active-fg); font-weight: 800; }
.logo-showcase { display: grid; grid-template-columns: minmax(0, 2fr) minmax(180px, 0.8fr); gap: 1rem; }
.logo-tile { display: grid; align-content: start; gap: 0.85rem; padding: 1.1rem; border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--paper); box-shadow: var(--shadow-small); }
.logo-tile img { display: block; width: 100%; max-height: 11rem; object-fit: contain; object-position: left center; border-radius: var(--radius-sm); background: var(--logo-tile-bg); }
.logo-tile-icon img { width: min(100%, 10.5rem); margin: 0 auto; object-position: center; }
.swatch-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 0.8rem; }
.swatch { padding: 0.85rem; border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--paper); box-shadow: var(--shadow-small); }
.swatch-chip { display: block; width: 100%; aspect-ratio: 3 / 2; border-radius: var(--radius-sm); border: 1px solid var(--header-border); margin-bottom: 0.75rem; }
code { font-family: var(--font-mono); font-size: 0.9em; }
.specimen-card { padding: 1.15rem; }
.display-sample { margin: 0; font-size: 2.2rem; }
.accent-quote { margin: 0; font-family: var(--font-accent); font-size: 1.7rem; line-height: 1.2; color: var(--plum); }
.mono-sample { font-family: var(--font-mono); font-weight: 700; color: var(--blue); }
.theme-samples { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem; }
.theme-sample { min-height: 11rem; padding: 1.1rem; border: 1px solid var(--line); border-radius: var(--radius-md); box-shadow: var(--shadow-small); }
.theme-sample p:last-child { margin-bottom: 0; color: var(--muted); }
.surface-sample { background: var(--panel-bg); }
.warm-sample { background: var(--warm-panel-bg); border-color: var(--warm-line); }
.logo-sample { background: var(--panel-bg); }
.logo-sample img { display: block; width: 100%; max-height: 5rem; object-fit: contain; object-position: left center; border-radius: var(--radius-sm); background: var(--logo-tile-bg); }
.button-row { display: flex; flex-wrap: wrap; gap: 0.75rem; align-items: center; }
.styleguide-table { margin-top: 1rem; }
.showcase-card { border-left: 0.35rem solid var(--gold); background: var(--surface-warm); }
.site-footer { border-top: 1px solid var(--line); color: var(--muted); padding: 1.3rem 1.25rem; background: var(--footer-bg); }
.footer-inner { max-width: 1180px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 1.15rem; }
.site-footer p { margin: 0; }
.site-footer nav { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 0.55rem; }
.site-footer a { display: inline-flex; min-height: 2.35rem; align-items: center; justify-content: center; padding: 0.45rem 0.7rem; border: 1px solid var(--line); border-radius: var(--radius-sm); background: var(--panel-bg); color: var(--ink); font-size: 0.9rem; font-weight: 800; text-decoration: none; box-shadow: var(--shadow-small); }
.site-footer a:hover, .site-footer a:focus-visible { border-color: var(--accent); color: var(--accent-dark); background: var(--nav-hover-bg); outline: none; }
.site-footer a:focus-visible { box-shadow: 0 0 0 0.18rem rgba(32, 201, 189, 0.26); }
.proposal-review-page { background: var(--surface); }
.proposal-review-page .page { max-width: 1320px; }
.review-workspace { display: grid; gap: 1.25rem; }
.review-brand { margin-bottom: 1.2rem; }
.review-brand .brand-logo-frame { width: 8.8rem; }
.review-hero, .review-instructions, .comments-tracker { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-md); box-shadow: var(--shadow-small); padding: 1.2rem; }
.review-hero h1 { font-size: 3.1rem; max-width: 980px; }
.review-meta { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 0.75rem; margin: 1.2rem 0 0; }
.review-meta div { padding: 0.8rem; border: 1px solid var(--line); border-radius: var(--radius-sm); background: var(--panel-bg-subtle); }
.review-meta dt { font-family: var(--font-mono); font-size: 0.75rem; color: var(--muted); text-transform: uppercase; font-weight: 800; }
.review-meta dd { margin: 0.2rem 0 0; font-weight: 800; }
.review-instructions ol { margin-bottom: 0; }
.review-layout { display: grid; grid-template-columns: minmax(0, 1fr) minmax(280px, 360px); gap: 1rem; align-items: start; }
.review-document { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-md); box-shadow: var(--shadow-small); padding: 1.4rem; }
.review-document h2 { margin-top: 2rem; padding-top: 1rem; border-top: 1px solid var(--line); }
.review-document h2:first-child { margin-top: 0; padding-top: 0; border-top: 0; }
.review-paragraph { position: relative; max-width: 92ch; margin: 0.9rem 0; padding: 0.8rem 0.9rem 0.8rem 4.25rem; border: 1px solid transparent; border-radius: var(--radius-sm); cursor: pointer; scroll-margin-top: 1.5rem; }
.review-paragraph:hover, .review-paragraph:focus { border-color: var(--accent); background: var(--accent-soft); outline: none; }
.review-paragraph.is-selected { border-color: var(--accent-dark); background: var(--selected-bg); box-shadow: inset 0.22rem 0 0 var(--accent); }
.paragraph-marker { position: absolute; top: 0.85rem; left: 0.85rem; font-family: var(--font-mono); font-size: 0.74rem; color: var(--accent-dark); font-weight: 800; }
.review-comment-panel { position: sticky; top: 1rem; }
.comment-form { display: grid; gap: 0.8rem; padding: 1rem; background: var(--warm-panel-bg); border: 1px solid var(--warm-line); border-radius: var(--radius-md); box-shadow: var(--shadow-small); }
.selected-paragraph { margin: 0; padding: 0.65rem; border-radius: var(--radius-sm); background: var(--panel-bg); border: 1px solid var(--line); color: var(--accent-dark); font-weight: 800; }
.form-status { min-height: 1.4rem; margin: 0; color: var(--muted); font-weight: 700; }
.form-status[data-tone="success"] { color: var(--accent-dark); }
.form-status[data-tone="error"] { color: var(--danger); }
button:disabled { opacity: 0.55; cursor: not-allowed; }
.comments-list { display: grid; gap: 0.85rem; }
.tracked-comment { padding: 0.9rem; border: 1px solid var(--line); border-radius: var(--radius-sm); background: var(--panel-bg-subtle); }
.tracked-comment-meta { display: flex; flex-wrap: wrap; gap: 0.55rem; align-items: center; font-size: 0.9rem; }
.tracked-comment-meta a { font-family: var(--font-mono); font-weight: 800; }
.tracked-comment-meta time { color: var(--muted); }
.tracked-comment blockquote { margin: 0.65rem 0; padding: 0.65rem 0.8rem; border-left: 0.22rem solid var(--accent); background: var(--panel-bg); color: var(--muted); }
.tracked-comment p:last-child { margin-bottom: 0; }
.muted { color: var(--muted); }

@media (max-width: 900px) {
  .site-header-inner { grid-template-columns: minmax(0, 1fr) auto; align-items: start; gap: 0.6rem; }
  nav[aria-label="Primary navigation"] { grid-column: 1 / -1; justify-content: flex-start; max-width: 100%; }
  .theme-control { justify-content: flex-end; }
  .section-heading { flex-direction: column; align-items: flex-start; }
  .hero, .deadline-strip, .action-grid, .resource-grid, .two-col, .vision-grid, .bridge-grid, .example-grid, .featured-supervisor, .bio-grid, .research-lanes, .supervisor-grid, .supervisor-grid.compact, .swatch-grid, .logo-showcase, .theme-samples, .review-layout, .review-meta { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .form-grid { grid-template-columns: 1fr; }
  h1 { font-size: 2.55rem; }
  .review-hero h1 { font-size: 2.55rem; }
  .review-comment-panel { position: static; }
  .hero { min-height: auto; padding-top: 2.5rem; }
  .footer-inner { align-items: flex-start; flex-direction: column; }
  .site-footer nav { justify-content: flex-start; }
}

@media (max-width: 560px) {
  .profile-title-row { align-items: flex-start; flex-direction: column; }
  .stats-grid { grid-template-columns: 1fr; }
  .scholar-inline { margin: 0.5rem 0 0; }
  h1 { font-size: 2.15rem; }
  .review-hero h1 { font-size: 2.15rem; }
  .review-paragraph { padding-left: 0.9rem; }
  .paragraph-marker { position: static; display: block; margin-bottom: 0.35rem; }
  .site-header-inner { width: 100%; min-width: 0; padding: 0.6rem 0.85rem; }
  .brand { max-width: 100%; min-width: 0; }
  .brand-logo-frame { width: 7.7rem; height: 2.55rem; }
  .brand-lockup span { font-size: 0.96rem; }
  .brand-lockup small { font-size: 0.58rem; }
  .theme-toggle { min-height: 2.35rem; padding-left: 0.5rem; padding-right: 0.5rem; }
  nav[aria-label="Primary navigation"] { width: 100%; min-width: 0; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); overflow: visible; }
  nav[aria-label="Primary navigation"] a { min-width: 0; justify-content: center; padding-left: 0.45rem; padding-right: 0.45rem; }
  .page { padding-left: 0.9rem; padding-right: 0.9rem; }
}
