:root {
  --ink: #102f34;
  --ink-soft: #36565a;
  --paper: #f7f4ed;
  --paper-2: #eeeadf;
  --line: rgba(16, 47, 52, .14);
  --social: #dc714d;
  --scientific: #178478;
  --artistic: #7958a6;
  --all: #183e5b;
  --yellow: #f0c866;
  --white: #fffef9;
  --shadow: 0 24px 70px rgba(20, 45, 48, .12);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: "Aptos", "Segoe UI", sans-serif; }
button, input, select { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
a { color: inherit; }
.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; }
.secure-file-mode { overflow: hidden; }
.secure-gate { position: fixed; z-index: 200; inset: 0; padding: 22px; display: grid; place-items: center; background: rgba(8,32,36,.9); backdrop-filter: blur(14px); }
.secure-gate-card { width: min(560px,100%); padding: clamp(30px,6vw,54px); border-radius: 30px; color: var(--ink); background: var(--white); box-shadow: 0 35px 100px rgba(0,0,0,.32); text-align: center; }
.secure-gate-card img { width: 66px; height: 66px; padding: 7px; object-fit: contain; border-radius: 20px; background: var(--paper); }
.secure-gate-label { display: block; margin-top: 20px; color: var(--scientific); font-size: 10px; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; }
.secure-gate-card h2 { margin: 12px 0 0; font-family: Georgia,serif; font-size: clamp(34px,6vw,52px); line-height: .95; letter-spacing: -.05em; font-weight: 500; }
.secure-gate-card p { margin: 20px auto 0; max-width: 460px; color: var(--ink-soft); line-height: 1.55; }
.secure-gate-card a { min-height: 54px; margin-top: 24px; padding: 0 17px 0 22px; display: flex; justify-content: space-between; align-items: center; border-radius: 15px; color: var(--white); background: var(--ink); text-decoration: none; font-weight: 850; }.secure-gate-card a b { width: 31px; height: 31px; display: grid; place-items: center; border-radius: 50%; color: var(--ink); background: var(--yellow); }
.secure-gate-card small { display: block; margin-top: 14px; color: var(--ink-soft); font-size: 10px; line-height: 1.45; }

.site-header { position: fixed; z-index: 60; inset: 0 0 auto; height: 74px; padding: 0 clamp(22px, 4vw, 68px); display: flex; align-items: center; justify-content: space-between; color: var(--white); transition: background .3s, color .3s, box-shadow .3s; }
.site-header.scrolled { color: var(--ink); background: rgba(247,244,237,.91); backdrop-filter: blur(18px); box-shadow: 0 1px 0 var(--line); }
.brand { display: inline-flex; align-items: center; gap: 9px; font-weight: 900; font-size: 23px; text-decoration: none; letter-spacing: -.045em; }
.brand-mark { display: block; width: 42px; height: 42px; padding: 4px; border-radius: 15px; object-fit: contain; background: rgba(255,254,249,.95); box-shadow: 0 8px 24px rgba(0,0,0,.12); }
.brand-word { display: inline-flex; align-items: baseline; gap: 1px; }
.brand-word b { font: inherit; }
.brand-word b:last-child { color: #11afa2; }
.site-header nav { display: flex; align-items: center; gap: 28px; }
.site-header nav a { font-size: 14px; font-weight: 650; text-decoration: none; }
.nav-compare { border: 1px solid currentColor; color: inherit; background: transparent; border-radius: 999px; padding: 9px 13px 9px 16px; cursor: pointer; }
.nav-compare span { display: inline-grid; place-items: center; min-width: 23px; height: 23px; margin-left: 6px; border-radius: 50%; color: var(--ink); background: var(--yellow); font-weight: 800; }
.view-toggle { position: fixed; z-index: 54; top: 86px; right: clamp(16px,4vw,68px); display: inline-flex; align-items: center; gap: 4px; padding: 4px; border: 1px solid var(--line); border-radius: 999px; color: var(--ink); background: rgba(255,254,249,.91); backdrop-filter: blur(12px); box-shadow: 0 16px 45px rgba(20,45,48,.12); }
.view-toggle button { min-height: 32px; padding: 0 12px; border: 0; border-radius: 999px; color: currentColor; background: transparent; cursor: pointer; font-size: 11px; font-weight: 900; letter-spacing: .02em; }
.view-toggle button[aria-pressed="true"] { color: var(--ink); background: var(--yellow); box-shadow: 0 8px 18px rgba(0,0,0,.12); }
.site-header.scrolled .view-toggle { border-color: var(--line); background: rgba(255,254,249,.62); }

.hero { position: relative; min-height: 100svh; overflow: hidden; display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(420px, .95fr); align-items: center; padding: 110px clamp(24px, 7vw, 120px) 80px; color: var(--white); background: var(--ink); }
.hero::before { content: ""; position: absolute; width: 620px; height: 620px; left: -290px; bottom: -300px; border-radius: 50%; background: var(--social); filter: blur(0); opacity: .84; }
.hero::after { content: ""; position: absolute; width: 420px; height: 420px; right: -170px; top: -170px; border-radius: 50%; border: 1px solid rgba(255,255,255,.22); box-shadow: 0 0 0 70px rgba(255,255,255,.035), 0 0 0 140px rgba(255,255,255,.025); }
.hero-noise { position: absolute; inset: 0; opacity: .09; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E"); }
.hero-wallpaper { position: absolute; inset: -9% -7%; z-index: 1; display: flex; flex-wrap: wrap; align-content: center; gap: 16px 18px; transform: rotate(-8deg); opacity: .14; pointer-events: none; }
.hero-wallpaper span { padding: 10px 16px; border: 1px solid rgba(255,255,255,.22); border-radius: 999px; color: rgba(255,255,255,.88); background: rgba(255,255,255,.035); font-size: clamp(15px, 2.1vw, 31px); font-weight: 850; white-space: nowrap; }
.hero-copy { position: relative; z-index: 2; max-width: 760px; }
.eyebrow { margin: 0 0 18px; font-size: 12px; line-height: 1; letter-spacing: .14em; text-transform: uppercase; font-weight: 800; }
.hero h1 { margin: 0; max-width: 780px; font-family: Georgia, "Times New Roman", serif; font-size: clamp(64px, 7.5vw, 124px); line-height: .84; letter-spacing: -.075em; font-weight: 500; }
.hero h1 em { color: var(--yellow); font-weight: 500; }
.hero-lead { max-width: 640px; margin: 34px 0 30px; color: rgba(255,255,255,.72); font-size: clamp(17px, 1.5vw, 22px); line-height: 1.5; }
.hero-cta { display: inline-flex; gap: 40px; align-items: center; padding: 15px 18px 15px 24px; border-radius: 999px; color: var(--ink); background: var(--white); text-decoration: none; font-weight: 800; box-shadow: 0 12px 35px rgba(0,0,0,.18); }
.hero-cta span { display: grid; place-items: center; width: 36px; height: 36px; border-radius: 50%; background: var(--yellow); }

.hero-visual { position: relative; z-index: 2; height: min(66vw, 660px); max-height: 660px; min-height: 480px; }
.orbit { position: absolute; border-radius: 50%; border: 1px solid rgba(255,255,255,.2); }
.orbit-one { width: 470px; height: 470px; left: 50%; top: 50%; transform: translate(-50%,-50%); }
.orbit-two { width: 650px; height: 650px; left: 50%; top: 50%; transform: translate(-50%,-50%); border-style: dashed; opacity: .55; animation: spin 34s linear infinite; }
.visual-card { position: absolute; display: flex; flex-direction: column; padding: 22px; border-radius: 22px; color: var(--ink); background: rgba(255,254,249,.96); box-shadow: var(--shadow); }
.visual-card-main { width: 350px; min-height: 330px; left: 50%; top: 50%; transform: translate(-50%,-50%) rotate(-2deg); animation: float 5s ease-in-out infinite; }
.visual-kicker { display: inline-flex; align-self: flex-start; padding: 7px 10px; border-radius: 999px; color: var(--white); background: var(--scientific); font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }
.hero-degree-list { display: grid; gap: 0; margin-top: 17px; }
.hero-degree-row { display: grid; grid-template-columns: 31px 1fr; gap: 11px; align-items: center; padding: 10px 0; border-top: 1px solid var(--line); }
.hero-degree-row:first-child { border-top: 0; }
.hero-degree-row > i { width: 28px; height: 28px; display: grid; place-items: center; border-radius: 9px; color: var(--white); background: var(--row-color); font-size: 9px; font-style: normal; font-weight: 900; }
.hero-degree-row > span { min-width: 0; }
.hero-degree-row b { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-family: Georgia,serif; font-size: 16px; font-weight: 600; line-height: 1.05; }
.hero-degree-row small { display: block; margin-top: 4px; color: var(--ink-soft); font-size: 10px; }
.hero-degree-row.social { --row-color: var(--social); }.hero-degree-row.scientific { --row-color: var(--scientific); }.hero-degree-row.artistic { --row-color: var(--artistic); }.hero-degree-row.all { --row-color: var(--all); }
.visual-card-left { left: 2%; top: 21%; background: var(--yellow); transform: rotate(-8deg); animation: float-small 6s ease-in-out infinite; }
.visual-card-science { right: 9%; top: 10%; color: var(--white); background: var(--scientific); transform: rotate(5deg); animation: float-small 5.8s .35s ease-in-out infinite; }
.visual-card-right { right: 0; bottom: 18%; color: var(--white); background: var(--artistic); transform: rotate(7deg); animation: float-small 5.5s .7s ease-in-out infinite; }
.visual-card-left b, .visual-card-right b, .visual-card-science b { font-size: 19px; }.visual-card-left span, .visual-card-right span, .visual-card-science span { margin-top: 4px; font-size: 12px; }
.hero-example-cloud { position: absolute; left: 4%; right: 2%; bottom: 4%; display: flex; flex-wrap: wrap; justify-content: center; gap: 7px; }
.hero-example-cloud span { padding: 8px 10px; border-radius: 999px; color: var(--white); background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.16); font-size: 11px; font-weight: 800; backdrop-filter: blur(10px); }
.visual-dot { position: absolute; border-radius: 50%; }.dot-b { width: 14px; height: 14px; left: 13%; bottom: 13%; background: var(--yellow); }
.scroll-cue { position: absolute; z-index: 4; left: clamp(24px,7vw,120px); bottom: 28px; display: flex; gap: 13px; align-items: center; color: rgba(255,255,255,.58); text-decoration: none; font-size: 11px; text-transform: uppercase; letter-spacing: .13em; }
.scroll-cue i { position: relative; display: block; width: 38px; height: 1px; background: currentColor; }.scroll-cue i::after { content: ""; position: absolute; right: 0; top: -3px; width: 7px; height: 7px; border-right: 1px solid; border-bottom: 1px solid; transform: rotate(45deg); }

.branch-section { padding: clamp(90px, 11vw, 170px) clamp(22px, 6vw, 92px); }
.section-heading { max-width: 800px; margin-bottom: 54px; }
.section-heading h2, .catalog-top h2, .comparison-head h2 { margin: 0; font-family: Georgia, serif; font-size: clamp(44px, 5vw, 76px); line-height: .98; letter-spacing: -.055em; font-weight: 500; }
.section-heading > p:last-child { max-width: 600px; color: var(--ink-soft); font-size: 18px; line-height: 1.55; }
.branch-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.branch-card { position: relative; overflow: hidden; min-height: 370px; padding: 24px; display: flex; flex-direction: column; align-items: flex-start; border: 0; border-radius: 28px; color: var(--white); text-align: left; cursor: pointer; transition: transform .25s, box-shadow .25s; }
.branch-card::after { content: ""; position: absolute; width: 220px; height: 220px; border-radius: 50%; right: -110px; bottom: -110px; border: 1px solid rgba(255,255,255,.3); box-shadow: 0 0 0 34px rgba(255,255,255,.05), 0 0 0 68px rgba(255,255,255,.035); }
.branch-card:hover, .branch-card.active { transform: translateY(-8px); box-shadow: var(--shadow); }
.branch-card.active { outline: 4px solid var(--yellow); outline-offset: 4px; }
.branch-card.social { background: var(--social); }.branch-card.scientific { background: var(--scientific); }.branch-card.artistic { background: var(--artistic); }.branch-card.all { background: var(--all); }
.branch-number { font-size: 12px; font-weight: 800; letter-spacing: .12em; opacity: .76; }
.branch-icon { position: absolute; right: 24px; top: 20px; font-size: 30px; }
.branch-card strong { margin-top: auto; font-family: Georgia, serif; font-size: 42px; letter-spacing: -.04em; font-weight: 500; }
.branch-card small { max-width: 250px; margin: 10px 0 22px; font-size: 14px; line-height: 1.45; opacity: .78; }
.branch-count { padding: 8px 11px; border: 1px solid rgba(255,255,255,.35); border-radius: 999px; font-size: 12px; font-weight: 800; }

.catalog-section { padding: 100px clamp(22px, 6vw, 92px) 150px; background: var(--white); border-radius: 56px 56px 0 0; }
.catalog-top { display: flex; justify-content: space-between; gap: 40px; align-items: flex-end; }
.catalog-intro { max-width: 470px; margin: 0; color: var(--ink-soft); line-height: 1.6; font-size: 17px; }
.filters { position: sticky; z-index: 20; top: 82px; display: grid; grid-template-columns: minmax(280px, 2fr) repeat(3,minmax(145px,1fr)); gap: 10px; margin-top: 42px; padding: 12px; border: 1px solid var(--line); border-radius: 20px; background: rgba(255,254,249,.94); backdrop-filter: blur(16px); box-shadow: 0 8px 30px rgba(20,45,48,.06); }
.filters label { display: flex; flex-direction: column; gap: 4px; padding: 2px 12px; border-left: 1px solid var(--line); font-size: 11px; color: var(--ink-soft); }
.filters label:first-child { border-left: 0; }
.filters select, .filters input { width: 100%; min-width: 0; border: 0; outline: 0; color: var(--ink); background: transparent; font-size: 14px; font-weight: 650; }
.search-field { flex-direction: row !important; align-items: center; gap: 10px !important; }
.search-field svg { width: 20px; fill: none; stroke: currentColor; stroke-width: 1.8; }
.search-field input { height: 44px; font-size: 16px; font-weight: 500; }
.results-meta { display: flex; justify-content: space-between; align-items: center; margin: 28px 0 20px; color: var(--ink-soft); }
.results-meta p { margin: 0; }.results-meta strong { color: var(--ink); font-size: 20px; }
.results-meta button { border: 0; background: none; color: var(--ink); text-decoration: underline; cursor: pointer; }
.degree-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.degree-card { position: relative; display: flex; min-height: 420px; flex-direction: column; padding: 24px; border: 1px solid var(--line); border-radius: 24px; background: var(--paper); transition: transform .2s, box-shadow .2s, border-color .2s; }
.degree-card:hover { transform: translateY(-4px); box-shadow: 0 20px 45px rgba(20,45,48,.1); border-color: transparent; }
.degree-card.selected { border: 2px solid var(--card-color); box-shadow: inset 0 0 0 3px color-mix(in srgb, var(--card-color) 12%, transparent); }
.degree-top { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.branch-pill, .data-pill { display: inline-flex; align-items: center; padding: 7px 10px; border-radius: 999px; font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .07em; }
.branch-pill { color: var(--white); background: var(--card-color); }.data-pill { color: var(--ink-soft); background: rgba(16,47,52,.07); }
.degree-card h3 { margin: 22px 0 8px; font-family: Georgia, serif; font-size: 28px; line-height: 1.04; letter-spacing: -.035em; font-weight: 500; }
.degree-location { margin: 0; color: var(--ink-soft); font-size: 13px; }
.mini-themes { display: grid; gap: 8px; margin-top: 24px; }
.mini-theme { display: grid; grid-template-columns: minmax(0,1fr) 68px 32px; gap: 8px; align-items: center; font-size: 11px; }
.mini-theme > span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }.mini-theme b { text-align: right; }
.mini-bar { height: 7px; border-radius: 99px; overflow: hidden; background: rgba(16,47,52,.09); }.mini-bar i { display: block; height: 100%; border-radius: inherit; background: var(--theme-color); }
.degree-facts { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin: auto 0 18px; padding-top: 22px; }
.degree-facts div { min-width: 0; }.degree-facts span { display: block; color: var(--ink-soft); font-size: 9px; text-transform: uppercase; letter-spacing: .08em; }.degree-facts strong { display: block; margin-top: 4px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 13px; }
.degree-actions { display: grid; grid-template-columns: 1fr 1.4fr; gap: 8px; }
.degree-actions button { min-height: 42px; border-radius: 12px; cursor: pointer; font-weight: 750; }
.detail-button { border: 1px solid var(--line); color: var(--ink); background: transparent; }.select-button { border: 0; color: var(--white); background: var(--ink); }.selected .select-button { color: var(--ink); background: var(--yellow); }
.no-results { grid-column: 1/-1; padding: 80px 20px; text-align: center; border: 1px dashed var(--line); border-radius: 24px; color: var(--ink-soft); }
.catalog-loading,.dialog-loading,.compare-loading { display: grid; place-content: center; gap: 8px; min-height: 260px; padding: 40px; text-align: center; border: 1px dashed var(--line); border-radius: 24px; color: var(--ink-soft); background: var(--paper); }.catalog-loading { grid-column: 1/-1; }.catalog-loading strong,.dialog-loading strong,.compare-loading strong { color: var(--ink); font-family: Georgia,serif; font-size: 28px; font-weight: 500; }.dialog-loading { min-height: 520px; margin: 18px; }.compare-loading { min-height: 55vh; margin-top: 30px; }.dialog-loading.error,.compare-loading.error { color: #8b4939; background: #fff0e8; }
.load-more { display: block; margin: 34px auto 0; padding: 15px 28px; border: 1px solid var(--ink); border-radius: 999px; color: var(--ink); background: transparent; cursor: pointer; font-weight: 800; }.load-more[hidden] { display: none; }

.compare-tray { position: fixed; z-index: 55; left: 50%; bottom: 18px; width: min(960px, calc(100% - 30px)); min-height: 76px; padding: 10px 10px 10px 22px; display: grid; grid-template-columns: auto 1fr auto; gap: 16px; align-items: center; border-radius: 22px; color: var(--white); background: rgba(16,47,52,.96); backdrop-filter: blur(18px); box-shadow: 0 24px 60px rgba(0,0,0,.23); transform: translate(-50%, 140%); transition: transform .35s cubic-bezier(.2,.8,.2,1); }
.compare-tray.visible { transform: translate(-50%,0); }
.compare-tray-copy span { display: block; color: rgba(255,255,255,.58); font-size: 10px; text-transform: uppercase; letter-spacing: .1em; }.compare-tray-copy strong { font-size: 13px; }
.compare-picks { display: flex; min-width: 0; gap: 8px; }
.pick-chip { display: flex; min-width: 0; align-items: center; gap: 8px; padding: 8px 10px; border-radius: 11px; color: var(--ink); background: var(--white); font-size: 11px; }.pick-chip span { max-width: 150px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }.pick-chip button { border: 0; background: none; cursor: pointer; font-size: 16px; }
.compare-now { min-height: 54px; padding: 0 18px; border: 0; border-radius: 14px; color: var(--ink); background: var(--yellow); cursor: pointer; font-weight: 850; }.compare-now:disabled { opacity: .4; cursor: not-allowed; }.compare-now span { margin-left: 16px; }

.comparison-section { position: fixed; z-index: 70; inset: 0; overflow-y: auto; padding: 54px clamp(20px,5vw,80px) 100px; background: var(--paper); }
.comparison-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 30px; padding-bottom: 34px; border-bottom: 1px solid var(--line); }
.comparison-head button { border: 1px solid var(--line); border-radius: 999px; padding: 11px 16px; background: transparent; cursor: pointer; }
.compare-hero-grid { display: grid; grid-template-columns: repeat(var(--compare-count), minmax(0,1fr)); gap: 14px; margin: 32px 0; }
.compare-hero-card { position: relative; min-height: 260px; padding: 24px; border-radius: 24px; color: var(--white); background: var(--card-color); overflow: hidden; }
.compare-hero-card::after { content: ""; position: absolute; width: 190px; height: 190px; right: -80px; bottom: -90px; border: 1px solid rgba(255,255,255,.25); border-radius: 50%; box-shadow: 0 0 0 30px rgba(255,255,255,.05); }
.compare-hero-card h3 { position: relative; z-index: 1; margin: 16px 0 7px; font-family: Georgia,serif; font-size: clamp(25px,3vw,40px); line-height: .98; font-weight: 500; letter-spacing: -.04em; }.compare-hero-card p { position: relative; z-index: 1; margin: 0; opacity: .75; }.compare-hero-card .branch-pill { color: var(--ink); background: var(--white); }
.hero-facts { position: relative; z-index: 1; display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin-top: 34px; }.hero-facts span { display: block; font-size: 9px; text-transform: uppercase; letter-spacing: .08em; opacity: .65; }.hero-facts strong { display: block; margin-top: 5px; font-size: 14px; }
.insight-strip { display: grid; grid-template-columns: repeat(var(--compare-count),1fr); gap: 12px; margin: 24px 0 44px; }.insight-card { padding: 18px; border: 1px solid var(--line); border-radius: 18px; background: var(--white); }.insight-card span { color: var(--ink-soft); font-size: 10px; text-transform: uppercase; letter-spacing: .08em; }.insight-card strong { display: block; margin-top: 7px; font-family: Georgia,serif; font-size: 22px; font-weight: 500; }
.compare-block { margin-top: 30px; padding: clamp(22px,4vw,44px); border-radius: 28px; background: var(--white); box-shadow: 0 12px 35px rgba(20,45,48,.05); }.compare-block h3 { margin: 0 0 6px; font-family: Georgia,serif; font-size: 34px; font-weight: 500; letter-spacing: -.04em; }.compare-block > p { margin: 0 0 28px; color: var(--ink-soft); }
.theme-comparison { display: grid; gap: 18px; }.theme-row { display: grid; grid-template-columns: 190px 1fr; gap: 18px; align-items: center; }.theme-label { font-size: 13px; font-weight: 750; }.theme-bars { display: grid; gap: 6px; }.theme-bar-line { display: grid; grid-template-columns: 130px 1fr 42px; gap: 9px; align-items: center; font-size: 11px; }.theme-bar-track { height: 11px; overflow: hidden; border-radius: 99px; background: var(--paper-2); }.theme-bar-track i { display: block; height: 100%; min-width: 2px; border-radius: inherit; background: var(--degree-color); }
.compare-tabs { display: flex; gap: 8px; margin-top: 34px; overflow-x: auto; }.compare-tabs button { flex: 0 0 auto; padding: 11px 15px; border: 1px solid var(--line); border-radius: 999px; color: var(--ink); background: transparent; cursor: pointer; font-weight: 750; }.compare-tabs button.active { color: var(--white); background: var(--ink); }
.tab-panel { margin-top: 16px; }.comparison-columns { display: grid; grid-template-columns: repeat(var(--compare-count), minmax(0,1fr)); gap: 12px; }.compare-column { padding: 20px; border: 1px solid var(--line); border-radius: 18px; background: var(--paper); }.compare-column h4 { margin: 0 0 14px; font-size: 16px; }.compare-column p { color: var(--ink-soft); font-size: 13px; line-height: 1.55; }.compare-column dl { margin: 0; }.compare-column dt { margin-top: 16px; color: var(--ink-soft); font-size: 10px; text-transform: uppercase; letter-spacing: .09em; }.compare-column dd { margin: 5px 0 0; font-size: 13px; line-height: 1.5; }
.subject-list { display: flex; flex-wrap: wrap; gap: 7px; }.subject-chip { padding: 7px 9px; border-radius: 9px; background: var(--white); font-size: 11px; border: 1px solid var(--line); }.subject-year { margin-top: 20px; font-size: 11px; text-transform: uppercase; letter-spacing: .08em; color: var(--ink-soft); }
.source-note { margin-top: 28px; padding: 14px 16px; border-radius: 13px; color: #725331; background: #fff1dd; font-size: 12px; line-height: 1.5; }

.degree-dialog { width: min(960px, calc(100% - 28px)); max-height: calc(100dvh - 32px); padding: 0; border: 0; border-radius: 28px; color: var(--ink); background: var(--paper); box-shadow: 0 30px 90px rgba(0,0,0,.28); }.degree-dialog::backdrop { background: rgba(5,25,28,.7); backdrop-filter: blur(5px); }.dialog-close { position: sticky; z-index: 4; float: right; top: 16px; margin: 16px 16px 0 0; width: 42px; height: 42px; border: 0; border-radius: 50%; background: var(--white); cursor: pointer; font-size: 24px; box-shadow: 0 5px 20px rgba(0,0,0,.12); }.dialog-hero { padding: 58px clamp(24px,6vw,65px) 45px; color: var(--white); background: var(--card-color); }.dialog-hero h2 { max-width: 730px; margin: 18px 0 10px; font-family: Georgia,serif; font-size: clamp(42px,6vw,72px); line-height: .92; letter-spacing: -.055em; font-weight: 500; }.dialog-hero p { margin: 0; opacity: .75; }.dialog-body { padding: 34px clamp(24px,6vw,65px) 64px; }.dialog-quick { display: grid; grid-template-columns: 190px 1fr; gap: 34px; align-items: center; }.donut { position: relative; width: 170px; height: 170px; border-radius: 50%; background: var(--donut); }.donut::after { content: ""; position: absolute; inset: 33px; border-radius: 50%; background: var(--paper); }.donut strong { position: absolute; z-index: 1; inset: 0; display: grid; place-items: center; text-align: center; font-family: Georgia,serif; font-size: 21px; }.detail-theme-list { display: grid; gap: 8px; }.detail-theme { width: 100%; display: grid; grid-template-columns: 1fr 100px 44px; gap: 10px; align-items: center; padding: 8px 10px; border: 1px solid transparent; border-radius: 13px; color: var(--ink); background: transparent; text-align: left; cursor: pointer; font-size: 12px; }.detail-theme:hover,.detail-theme.active { border-color: var(--line); background: var(--white); }.detail-theme b { text-align: right; }.detail-sections { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 32px; }.detail-panel { padding: 21px; border: 1px solid var(--line); border-radius: 18px; background: var(--white); }.detail-panel h3 { margin: 0 0 11px; font-family: Georgia,serif; font-size: 23px; font-weight: 500; }.detail-panel p { margin: 0; color: var(--ink-soft); font-size: 13px; line-height: 1.6; }.dialog-links { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 24px; }.dialog-links a { padding: 11px 14px; border-radius: 999px; color: var(--white); background: var(--ink); text-decoration: none; font-size: 13px; font-weight: 750; }

.nav-test { border: 0; color: inherit; background: transparent; cursor: pointer; font-size: 14px; font-weight: 750; }
.quiz-promo { position: relative; overflow: hidden; margin: 0 clamp(22px,6vw,92px) 110px; min-height: 470px; padding: clamp(34px,5vw,68px); display: grid; grid-template-columns: minmax(0,1.15fr) minmax(330px,.72fr); gap: clamp(36px,6vw,90px); align-items: center; border-radius: 36px; color: var(--white); background: radial-gradient(circle at 6% 100%,rgba(23,132,120,.35),transparent 34%),linear-gradient(135deg,#102f34 0%,#183e5b 100%); }
.quiz-promo::before { content: ""; position: absolute; inset: 22px; border: 1px solid rgba(255,255,255,.1); border-radius: 24px; pointer-events: none; }
.quiz-promo-copy { position: relative; z-index: 2; max-width: 760px; }
.quiz-label { display: inline-flex; padding: 8px 11px; border: 1px solid rgba(255,255,255,.22); border-radius: 999px; color: rgba(255,255,255,.75); font-size: 10px; font-weight: 850; letter-spacing: .1em; text-transform: uppercase; }
.quiz-promo h2 { margin: 22px 0 0; font-family: Georgia,serif; font-size: clamp(42px,5.4vw,72px); line-height: .92; letter-spacing: -.055em; font-weight: 500; }.quiz-promo h2 em { color: var(--yellow); font-weight: 500; }
.quiz-promo-copy > p { max-width: 620px; margin: 22px 0 0; color: rgba(255,255,255,.7); font-size: 16px; line-height: 1.55; }
.quiz-steps { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 28px; }.quiz-steps span { display: inline-flex; gap: 8px; align-items: center; padding: 9px 11px; border-radius: 11px; color: rgba(255,255,255,.74); background: rgba(255,255,255,.08); font-size: 11px; }.quiz-steps b { color: var(--yellow); font-size: 9px; letter-spacing: .08em; }
.quiz-preview { position: relative; z-index: 2; padding: 24px; border-radius: 25px; color: var(--ink); background: var(--white); box-shadow: 0 25px 70px rgba(0,0,0,.22); transform: rotate(1.5deg); }
.quiz-preview-top { display: flex; justify-content: space-between; gap: 16px; color: var(--ink-soft); font-size: 9px; font-weight: 850; letter-spacing: .09em; text-transform: uppercase; }.quiz-preview-top small { font: inherit; }
.quiz-preview > strong { display: block; margin: 25px 0 21px; font-family: Georgia,serif; font-size: clamp(25px,2.6vw,36px); line-height: 1.02; font-weight: 500; letter-spacing: -.035em; }
.quiz-preview-options { display: grid; gap: 7px; }.quiz-preview-options span { padding: 10px 12px; border: 1px solid var(--line); border-radius: 10px; color: var(--ink-soft); background: var(--paper); font-size: 11px; }.quiz-preview-options span:nth-child(2) { color: var(--ink); border-color: color-mix(in srgb,var(--scientific) 42%,transparent); background: color-mix(in srgb,var(--scientific) 10%,var(--white)); font-weight: 800; }
.quiz-start { width: 100%; min-height: 52px; margin-top: 18px; padding: 0 16px 0 19px; display: flex; justify-content: space-between; align-items: center; border: 0; border-radius: 14px; color: var(--white); background: var(--ink); cursor: pointer; font-weight: 850; box-shadow: 0 12px 25px rgba(16,47,52,.16); transition: transform .2s,background .2s; }.quiz-start:hover { transform: translateY(-2px); background: var(--scientific); }.quiz-start i { width: 30px; height: 30px; display: grid; place-items: center; border-radius: 50%; color: var(--ink); background: var(--yellow); font-style: normal; font-size: 16px; }
.reading-key { margin: 14px 0 0; padding: 12px 16px; display: flex; justify-content: space-between; gap: 20px; align-items: center; border-radius: 14px; color: var(--ink-soft); background: #edf5f2; font-size: 12px; }.reading-key span { display: flex; align-items: center; gap: 8px; font-weight: 800; }.reading-key i { width: 10px; height: 10px; border-radius: 50%; background: var(--scientific); }.reading-key b { font-weight: 500; }
.profile-explainer { margin-top: 22px; }.profile-title { display: flex; justify-content: space-between; gap: 12px; align-items: center; margin-bottom: 11px; color: var(--ink-soft); font-size: 10px; text-transform: uppercase; letter-spacing: .09em; }.profile-title b { color: var(--ink); }.profile-title span { text-transform: none; letter-spacing: 0; font-weight: 600; }.human-profile { display: grid; gap: 7px; }.human-theme { display: grid; grid-template-columns: 10px minmax(0,1fr) auto; gap: 8px; align-items: center; padding: 7px 9px; border-radius: 10px; background: rgba(255,255,255,.58); font-size: 11px; }.human-theme i { width: 9px; height: 9px; border-radius: 50%; background: var(--theme-color); }.human-theme b { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }.human-theme span { color: var(--ink-soft); }
.aqu-mini { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px; }.aqu-chip { display: inline-flex; gap: 5px; align-items: center; padding: 6px 8px; border: 1px solid rgba(16,47,52,.1); border-radius: 999px; color: var(--ink-soft); background: var(--white); font-size: 10px; }.aqu-chip strong { color: var(--ink); }.aqu-chip.source { color: #356966; background: #dff0ec; border-color: transparent; font-weight: 800; }
.winner-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 10px; margin: 24px 0 34px; }.winner-card { padding: 16px; border: 1px solid var(--line); border-radius: 17px; background: var(--white); }.winner-card span { color: var(--ink-soft); font-size: 9px; text-transform: uppercase; letter-spacing: .08em; }.winner-card strong { display: block; margin: 8px 0 4px; font-size: 14px; }.winner-card b { color: var(--scientific); font-size: 18px; }
.aqu-compare-grid { display: grid; gap: 14px; }.aqu-compare-row { display: grid; grid-template-columns: 170px 1fr; gap: 16px; align-items: center; }.aqu-compare-row > strong { font-size: 12px; }.aqu-bar-list { display: grid; gap: 6px; }.aqu-bar-line { display: grid; grid-template-columns: 125px minmax(80px,1fr) 70px; gap: 8px; align-items: center; font-size: 11px; }.aqu-bar-line span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }.aqu-bar-track { height: 10px; border-radius: 99px; overflow: hidden; background: var(--paper-2); }.aqu-bar-track i { display: block; height: 100%; border-radius: inherit; background: var(--degree-color); }
.dialog-one-line { margin: 0 0 24px; padding: 16px 19px; border-radius: 18px; color: var(--ink); background: var(--white); font-family: Georgia,serif; font-size: clamp(18px,1.8vw,25px); line-height: 1.15; }.theme-wording { color: var(--ink-soft); font-size: 11px; }.theme-wording strong { display: block; color: var(--ink); font-size: 12px; }
.theme-examples { margin-top: 12px; padding: 15px; border-radius: 17px; background: var(--white); border: 1px solid var(--line); }.theme-examples > div:first-child { display: flex; justify-content: space-between; gap: 12px; align-items: baseline; }.theme-examples strong { font-family: Georgia,serif; font-size: 22px; font-weight: 500; }.theme-examples > div:first-child span { color: var(--ink-soft); font-size: 11px; }.theme-examples p { margin: 8px 0 12px; color: var(--ink-soft); font-size: 12px; line-height: 1.35; }.theme-examples > div:last-child { display: flex; flex-wrap: wrap; gap: 6px; }.theme-examples > div:last-child span { padding: 7px 8px; border-radius: 9px; background: var(--paper); border: 1px solid rgba(16,47,52,.08); font-size: 10px; }
.aqu-dashboard { margin-top: 32px; }.section-minihead { display: flex; justify-content: space-between; align-items: end; gap: 20px; margin-bottom: 14px; }.section-minihead h3 { margin: 0; font-family: Georgia,serif; font-size: 30px; font-weight: 500; }.section-minihead span { color: var(--ink-soft); font-size: 11px; }.aqu-metrics { display: grid; grid-template-columns: repeat(5,1fr); gap: 9px; }.aqu-metric { min-height: 118px; padding: 15px; display: flex; flex-direction: column; border: 1px solid var(--line); border-radius: 16px; background: var(--white); }.aqu-metric span { color: var(--ink-soft); font-size: 9px; text-transform: uppercase; letter-spacing: .08em; }.aqu-metric strong { margin-top: auto; font-family: Georgia,serif; font-size: 25px; font-weight: 500; }.aqu-metric small { margin-top: 3px; color: var(--ink-soft); font-size: 9px; }
.outcome-cloud { display: flex; flex-wrap: wrap; gap: 8px; }.outcome-pill { padding: 8px 10px; border-radius: 10px; color: var(--ink); background: #edf3f1; font-size: 11px; }.visual-details { margin-top: 28px; border-top: 1px solid var(--line); }.visual-details details { border-bottom: 1px solid var(--line); }.visual-details summary { padding: 16px 0; cursor: pointer; font-weight: 800; }.visual-details p { margin: 0 0 18px; color: var(--ink-soft); line-height: 1.6; font-size: 13px; }
.quiz-dialog { width: min(900px,calc(100% - 28px)); max-height: calc(100dvh - 28px); padding: 0; border: 0; border-radius: 30px; color: var(--ink); background: var(--paper); box-shadow: 0 30px 100px rgba(0,0,0,.32); }.quiz-dialog::backdrop { background: rgba(5,25,28,.78); backdrop-filter: blur(7px); }.quiz-shell { min-height: 640px; padding: clamp(28px,6vw,62px); display: flex; flex-direction: column; }.quiz-progress { padding-right: 55px; display: grid; grid-template-columns: auto 1fr; gap: 15px; align-items: center; color: var(--ink-soft); font-size: 11px; text-transform: uppercase; letter-spacing: .08em; }.quiz-progress > div { height: 5px; overflow: hidden; border-radius: 99px; background: #dcdad2; }.quiz-progress i { display: block; width: 10%; height: 100%; border-radius: inherit; background: var(--social); transition: width .3s; }
.quiz-question { flex: 1; display: flex; flex-direction: column; justify-content: center; padding-top: 28px; }.quiz-question .eyebrow { color: var(--social); }.quiz-question h2 { max-width: 720px; margin: 0; font-family: Georgia,serif; font-size: clamp(38px,5vw,62px); line-height: 1; letter-spacing: -.05em; font-weight: 500; }.quiz-question > p { max-width: 620px; color: var(--ink-soft); font-size: 16px; line-height: 1.55; }.quiz-options { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin-top: 30px; }.quiz-options.branch-options { grid-template-columns: repeat(4,1fr); }.quiz-option { min-height: 120px; padding: 18px; display: flex; flex-direction: column; justify-content: space-between; align-items: flex-start; border: 1px solid var(--line); border-radius: 18px; color: var(--ink); background: var(--white); text-align: left; cursor: pointer; transition: transform .2s,border-color .2s,background .2s; }.quiz-option:hover { transform: translateY(-3px); border-color: var(--social); }.quiz-option.selected { color: var(--white); background: var(--ink); border-color: var(--ink); }.quiz-option b { font-size: 16px; }.quiz-option span { color: inherit; opacity: .65; font-size: 11px; line-height: 1.4; }
.quiz-textarea { width: 100%; min-height: 170px; margin-top: 24px; padding: 20px; resize: vertical; border: 1px solid var(--line); border-radius: 18px; outline: 0; color: var(--ink); background: var(--white); font-size: 17px; line-height: 1.5; }.quiz-textarea:focus { border-color: var(--social); box-shadow: 0 0 0 4px rgba(220,113,77,.12); }.quiz-actions { display: flex; justify-content: space-between; gap: 12px; margin-top: 28px; }.quiz-actions button { min-height: 48px; padding: 0 18px; border-radius: 999px; cursor: pointer; font-weight: 800; }.quiz-back { border: 1px solid var(--line); background: transparent; }.quiz-next { margin-left: auto; border: 0; color: var(--white); background: var(--ink); }.quiz-next:disabled { opacity: .35; cursor: not-allowed; }
.quiz-results-head { max-width: 680px; margin: 30px 0; }.quiz-results-head h2 { margin: 0; font-family: Georgia,serif; font-size: clamp(38px,5vw,60px); line-height: .98; font-weight: 500; letter-spacing: -.05em; }.quiz-results-head p { color: var(--ink-soft); line-height: 1.55; }.recommendation-list { display: grid; gap: 10px; }.recommendation { display: grid; grid-template-columns: 50px 1fr auto; gap: 16px; align-items: center; padding: 17px; border: 1px solid var(--line); border-radius: 18px; background: var(--white); }.recommendation-rank { width: 48px; height: 48px; display: grid; place-items: center; border-radius: 50%; color: var(--white); background: var(--card-color); font-family: Georgia,serif; font-size: 20px; }.recommendation h3 { margin: 0; font-size: 16px; }.recommendation p { margin: 5px 0 0; color: var(--ink-soft); font-size: 11px; line-height: 1.45; }.recommendation button { border: 0; border-radius: 999px; padding: 10px 13px; color: var(--white); background: var(--ink); cursor: pointer; font-size: 11px; font-weight: 800; }
.ask-section { margin: 0 clamp(22px,6vw,92px) 110px; padding: clamp(34px,5vw,64px); border: 1px solid var(--line); border-radius: 34px; background: var(--white); box-shadow: 0 22px 70px rgba(20,45,48,.08); }.ask-heading h2 { max-width: 980px; margin: 0; font-family: Georgia,serif; font-size: clamp(34px,4.5vw,64px); line-height: 1; letter-spacing: -.05em; font-weight: 500; }.ask-heading > p:last-child { max-width: 700px; color: var(--ink-soft); line-height: 1.55; }.ask-box { margin-top: 28px; padding: 10px; border: 1px solid var(--line); border-radius: 20px; background: var(--paper); }.ask-box textarea { width: 100%; min-height: 120px; padding: 18px; resize: vertical; border: 0; outline: 0; color: var(--ink); background: transparent; font-size: 17px; line-height: 1.5; }.ask-actions { display: flex; justify-content: space-between; gap: 15px; align-items: center; padding: 8px; }.ask-actions span { margin-left: 10px; color: var(--ink-soft); font-size: 11px; text-transform: uppercase; letter-spacing: .1em; }.ask-actions button { min-height: 48px; padding: 0 18px; border: 0; border-radius: 14px; color: var(--white); background: var(--ink); cursor: pointer; font-weight: 800; }.ask-actions button b { margin-left: 20px; }.ask-answer { margin-top: 16px; padding: 22px; border-radius: 20px; color: var(--white); background: var(--ink); }.ask-answer h3 { margin: 0 0 8px; font-family: Georgia,serif; font-size: 29px; font-weight: 500; }.ask-answer > p { margin: 0; color: rgba(255,255,255,.7); line-height: 1.55; }.ask-recommendations { display: grid; grid-template-columns: repeat(3,1fr); gap: 9px; margin-top: 18px; }.ask-rec { padding: 15px; border-radius: 14px; color: var(--ink); background: var(--white); }.ask-rec b { display: block; }.ask-rec span { display: block; margin-top: 5px; color: var(--ink-soft); font-size: 11px; line-height: 1.4; }.ask-evidence { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 17px; }.ask-evidence span { padding: 6px 8px; border: 1px solid rgba(255,255,255,.2); border-radius: 999px; font-size: 10px; }
.degree-advisor { margin-top: 30px; padding: 20px; border-radius: 18px; color: var(--white); background: var(--ink); }.degree-advisor h3 { margin: 0 0 5px; font-family: Georgia,serif; font-size: 24px; font-weight: 500; }.degree-advisor p { margin: 0 0 14px; color: rgba(255,255,255,.68); font-size: 12px; }.degree-advisor-row { display: grid; grid-template-columns: 1fr auto; gap: 8px; }.degree-advisor input { min-width: 0; height: 46px; padding: 0 14px; border: 0; border-radius: 12px; outline: 0; }.degree-advisor button { border: 0; border-radius: 12px; padding: 0 15px; color: var(--ink); background: var(--yellow); cursor: pointer; font-weight: 850; }.degree-advisor-answer { margin-top: 12px; padding: 13px; border-radius: 12px; color: var(--ink); background: var(--white); font-size: 12px; line-height: 1.55; }.degree-advisor-answer strong { display: block; margin-bottom: 5px; font-size: 15px; }
.aqu-quick { display: grid; grid-template-columns: auto 1fr 1fr; gap: 7px; align-items: stretch; margin-top: 14px; }.aqu-source { display: grid; place-items: center; padding: 0 8px; border-radius: 10px; color: #fff; background: var(--scientific); font-size: 9px; font-weight: 900; letter-spacing: .08em; writing-mode: vertical-rl; transform: rotate(180deg); }.aqu-quick > div { padding: 9px 10px; border-radius: 11px; background: var(--white); border: 1px solid var(--line); }.aqu-quick small { display: block; color: var(--ink-soft); font-size: 9px; }.aqu-quick strong { display: block; margin-top: 3px; font-size: 14px; }
.aqu-showcase { display: grid; grid-template-columns: 1.05fr 1.5fr; gap: 12px; }.aqu-income { min-height: 190px; padding: 22px; display: flex; flex-direction: column; border-radius: 22px; color: var(--white); background: var(--ink); }.aqu-income span { font-size: 10px; text-transform: uppercase; letter-spacing: .09em; opacity: .62; }.aqu-income strong { margin-top: auto; font-family: Georgia,serif; font-size: clamp(38px,5vw,58px); line-height: .9; font-weight: 500; }.aqu-income small { margin-top: 9px; opacity: .55; }
.aqu-ring-grid { padding: 18px; display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; border-radius: 22px; background: var(--white); border: 1px solid var(--line); }.metric-ring { position: relative; aspect-ratio: 1; padding: 8px; border-radius: 50%; background: conic-gradient(var(--ring-color) var(--ring-value), #e5e8e4 0); }.metric-ring::after { content: ""; position: absolute; inset: 10px; border-radius: 50%; background: var(--white); }.metric-ring > div { position: absolute; z-index: 1; inset: 16px; display: grid; place-content: center; text-align: center; }.metric-ring strong { font-family: Georgia,serif; font-size: clamp(18px,2.2vw,31px); font-weight: 500; }.metric-ring span { margin-top: 2px; color: var(--ink-soft); font-size: 9px; text-transform: uppercase; letter-spacing: .07em; }
.aqu-detail-grid { grid-column: 1/-1; display: grid; grid-template-columns: 1.5fr 1fr; gap: 12px; }.job-speed,.stable-contract { padding: 17px; border: 1px solid var(--line); border-radius: 18px; background: var(--white); }.job-speed > span,.stable-contract > span { display: block; margin-bottom: 12px; color: var(--ink-soft); font-size: 10px; text-transform: uppercase; letter-spacing: .08em; }.job-speed-bar { height: 16px; display: flex; overflow: hidden; border-radius: 99px; background: #e5e8e4; }.job-speed-bar i:nth-child(1) { background: var(--scientific); }.job-speed-bar i:nth-child(2) { background: var(--yellow); }.job-speed-bar i:nth-child(3) { background: var(--social); }.job-speed-legend { display: flex; flex-wrap: wrap; gap: 11px; margin-top: 10px; }.job-speed-legend b { display: flex; align-items: center; gap: 5px; font-size: 9px; font-weight: 650; }.job-speed-legend i { width: 7px; height: 7px; border-radius: 50%; background: var(--scientific); }.job-speed-legend b:nth-child(2) i { background: var(--yellow); }.job-speed-legend b:nth-child(3) i { background: var(--social); }.job-speed em { color: var(--ink-soft); font-size: 11px; }.stable-contract strong { display: block; font-family: Georgia,serif; font-size: 34px; font-weight: 500; }.stable-contract > i { display: block; height: 8px; margin-top: 12px; overflow: hidden; border-radius: 99px; background: #e5e8e4; }.stable-contract > i b { display: block; height: 100%; border-radius: inherit; background: var(--artistic); }
.learning-visual { padding: 20px; border: 1px solid var(--line); border-radius: 22px; background: var(--white); }.signal-cloud,.friction-cloud { display: flex; flex-wrap: wrap; gap: 7px; }.signal-cloud span { padding: 9px 11px; border-radius: 999px; color: var(--white); background: var(--ink); font-size: 11px; font-weight: 750; }.learning-axes { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 18px; margin: 22px 0; }.learning-axes > div { display: grid; grid-template-columns: 60px 1fr; gap: 8px; align-items: center; font-size: 10px; }.learning-axes i { height: 9px; overflow: hidden; border-radius: 99px; background: #e5e8e4; }.learning-axes b { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg,var(--scientific),#55aa9f); }.friction-cloud small { flex-basis: 100%; color: var(--ink-soft); text-transform: uppercase; letter-spacing: .08em; }.friction-cloud span { padding: 7px 9px; border-radius: 9px; color: #704f30; background: #fff0de; font-size: 10px; }.compare-column .aqu-showcase { grid-template-columns: 1fr; }.compare-column .aqu-ring-grid { grid-template-columns: repeat(3,1fr); }.compare-column .aqu-detail-grid { grid-template-columns: 1fr; }.compare-column .aqu-income { min-height: 140px; }
.ct-visual-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 9px; margin-top: 14px; }.ct-visual-card { min-height: 130px; padding: 16px; border-radius: 16px; background: var(--white); border: 1px solid var(--line); }.ct-visual-card span { color: var(--ink-soft); font-size: 9px; text-transform: uppercase; letter-spacing: .09em; }.ct-visual-card strong { display: block; margin-top: 10px; font-size: 13px; line-height: 1.45; }
.subject-dashboard { padding: 18px; border: 1px solid var(--line); border-radius: 24px; background: var(--white); }.subject-dashboard.empty { color: var(--ink-soft); }.subject-overview { display: grid; grid-template-columns: 210px 1fr; gap: 18px; align-items: stretch; margin-bottom: 18px; }.subject-big-number { min-height: 160px; padding: 20px; display: flex; flex-direction: column; justify-content: flex-end; border-radius: 20px; color: var(--white); background: radial-gradient(circle at 20% 0%, rgba(240,200,102,.38), transparent 38%), var(--ink); }.subject-big-number strong { font-family: Georgia,serif; font-size: 64px; line-height: .85; font-weight: 500; }.subject-big-number span { margin-top: 10px; color: rgba(255,255,255,.68); font-size: 11px; text-transform: uppercase; letter-spacing: .08em; }.subject-category-bars { display: grid; align-content: center; gap: 9px; padding: 18px; border-radius: 20px; background: var(--paper); }.subject-category-bars > div { display: grid; grid-template-columns: 140px 1fr 28px; gap: 10px; align-items: center; font-size: 11px; }.subject-category-bars span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 750; }.subject-category-bars i { height: 10px; overflow: hidden; border-radius: 99px; background: rgba(16,47,52,.09); }.subject-category-bars b { display: block; height: 100%; border-radius: inherit; background: var(--theme-color); }.subject-category-bars em { color: var(--ink-soft); font-style: normal; text-align: right; }.subject-year-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 10px; }.subject-year-grid article { min-width: 0; padding: 15px; border-radius: 18px; background: var(--paper); border: 1px solid rgba(16,47,52,.08); }.subject-year-grid h4 { margin: 0 0 10px; font-size: 12px; text-transform: uppercase; letter-spacing: .09em; color: var(--ink-soft); }.subject-year-grid article > div { display: flex; flex-wrap: wrap; gap: 6px; }.subject-year-grid span,.subject-year-grid b { padding: 7px 8px; border-radius: 10px; background: var(--white); border: 1px solid var(--line); font-size: 10px; line-height: 1.25; }.subject-year-grid b { color: var(--white); background: var(--ink); border-color: var(--ink); }
.learning-summary { margin: 0 0 16px; padding: 17px 18px; border-radius: 18px; background: var(--paper); color: var(--ink); font-family: Georgia,serif; font-size: 19px; line-height: 1.35; }.study-badges { display: grid; grid-template-columns: repeat(5,1fr); gap: 8px; margin-bottom: 18px; }.study-badge { min-height: 96px; padding: 12px; display: flex; flex-direction: column; border-radius: 16px; border: 1px solid var(--line); background: var(--paper); }.study-badge b { font-size: 12px; }.study-badge small { width: max-content; margin-top: 8px; padding: 5px 8px; border-radius: 999px; color: var(--white); background: var(--ink); font-size: 10px; font-weight: 850; }.study-badge.mid small { background: var(--scientific); }.study-badge.high small { background: var(--social); }.study-badge em { margin-top: auto; color: var(--ink-soft); font-size: 10px; font-style: normal; }.learning-axes > div { grid-template-columns: 62px 1fr 38px; }.learning-axes em { color: var(--ink-soft); font-size: 10px; font-style: normal; text-align: right; }.fit-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin: 18px 0; }.fit-grid > div { padding: 16px; border-radius: 18px; background: var(--paper); border: 1px solid rgba(16,47,52,.08); }.fit-grid h4 { margin: 0 0 10px; font-size: 11px; text-transform: uppercase; letter-spacing: .09em; color: var(--ink-soft); }.fit-grid span { display: block; position: relative; padding-left: 17px; margin-top: 8px; font-size: 12px; line-height: 1.35; }.fit-grid span::before { content: ""; position: absolute; left: 0; top: .5em; width: 7px; height: 7px; border-radius: 50%; background: var(--scientific); }.fit-grid > div:nth-child(2) span::before { background: var(--social); }
.outcome-visual { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 10px; }.outcome-visual article { min-height: 124px; padding: 15px; display: flex; flex-direction: column; border-radius: 18px; background: var(--white); border: 1px solid var(--line); box-shadow: 0 10px 24px rgba(20,45,48,.04); }.outcome-visual i { width: 34px; height: 34px; display: grid; place-items: center; border-radius: 50%; color: var(--white); background: var(--ink); font-style: normal; font-weight: 900; }.outcome-visual strong { margin-top: 12px; font-family: Georgia,serif; font-size: 20px; line-height: 1; font-weight: 500; }.outcome-visual span { margin-top: auto; color: var(--ink-soft); font-size: 10px; line-height: 1.25; }
.flag-section { margin-top: 28px; padding: 18px; border: 1px solid var(--line); border-radius: 24px; background: var(--white); box-shadow: 0 12px 28px rgba(20,45,48,.04); }.person-profile { display: grid; grid-template-columns: minmax(0,1.5fr) minmax(180px,.7fr); gap: 12px; margin-bottom: 12px; padding: 16px; border-radius: 18px; color: var(--white); background: radial-gradient(circle at 100% 0%, rgba(240,200,102,.24), transparent 34%), var(--ink); }.person-profile span { color: rgba(255,255,255,.55); font-size: 9px; text-transform: uppercase; letter-spacing: .09em; }.person-profile strong { display: block; margin-top: 6px; font-family: Georgia,serif; font-size: 22px; line-height: 1.05; font-weight: 500; }.person-profile p { margin: 8px 0 0; color: rgba(255,255,255,.7); font-size: 12px; line-height: 1.45; }.person-profile small { display: block; margin-top: 8px; color: rgba(255,255,255,.45); font-size: 10px; }.person-profile > div:last-child { display: flex; flex-wrap: wrap; align-content: center; gap: 6px; }.person-profile b { padding: 7px 8px; border-radius: 999px; color: var(--ink); background: var(--yellow); font-size: 10px; }.flag-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }.flag-column { min-width: 0; padding: 16px; border-radius: 18px; border: 1px solid var(--line); }.flag-column.green { background: #eaf4ef; border-color: rgba(23,132,120,.18); }.flag-column.red { background: #fff0e8; border-color: rgba(220,113,77,.2); }.flag-column h4 { margin: 0 0 12px; font-size: 12px; text-transform: uppercase; letter-spacing: .09em; }.flag-column article { display: grid; grid-template-columns: 28px 1fr; gap: 3px 10px; align-items: start; margin-top: 9px; padding: 10px; border-radius: 13px; background: rgba(255,255,255,.68); }.flag-column i { grid-row: 1/3; display: grid; place-items: center; width: 26px; height: 26px; border-radius: 50%; color: var(--white); background: var(--scientific); font-style: normal; font-weight: 900; }.flag-column.red i { background: var(--social); }.flag-column strong { font-size: 13px; }.flag-column span { color: var(--ink-soft); font-size: 11px; line-height: 1.35; }.diff-card { margin-top: 16px; padding: 14px; border: 1px solid rgba(16,47,52,.1); border-radius: 16px; background: var(--white); }.diff-card > span { color: var(--ink-soft); font-size: 9px; text-transform: uppercase; letter-spacing: .09em; }.diff-card > strong { display: block; margin: 7px 0 12px; font-family: Georgia,serif; font-size: 20px; line-height: 1.08; font-weight: 500; }.diff-row { display: grid; grid-template-columns: 88px minmax(70px,1fr) 44px; gap: 7px; align-items: center; margin-top: 8px; font-size: 10px; }.diff-row > span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 800; }.diff-row i { height: 8px; overflow: hidden; border-radius: 99px; background: var(--paper-2); }.diff-row b { display: block; height: 100%; border-radius: inherit; background: var(--theme-color); }.diff-row em { color: var(--ink-soft); font-style: normal; text-align: right; }.diff-row small { grid-column: 1/-1; color: var(--ink-soft); line-height: 1.25; }
.person-profile.person-profile-visual { grid-template-columns: 1.1fr 1fr; gap: 12px; align-items: stretch; padding: 18px; overflow: hidden; background: radial-gradient(circle at 82% 0%, rgba(17,175,162,.25), transparent 34%), radial-gradient(circle at 0% 100%, rgba(240,200,102,.22), transparent 38%), var(--ink); }
.person-profile-visual .person-profile-head { display: flex; min-height: 190px; flex-direction: column; justify-content: flex-end; }
.person-profile-visual .person-profile-head strong { max-width: 520px; font-size: clamp(27px,3vw,43px); }
.person-profile-visual .person-profile-head p { max-width: 360px; font-size: 15px; }
.person-profile-visual .person-trait-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 8px; }
.person-profile-visual .person-trait-card { min-width: 0; padding: 13px; border-radius: 16px; color: var(--ink); background: var(--yellow); }
.person-profile-visual .person-trait-card i { display: grid; place-items: center; width: 34px; height: 34px; margin-bottom: 15px; border-radius: 50%; color: var(--white); background: var(--ink); font-style: normal; font-weight: 950; }
.person-profile-visual .person-trait-card b { display: block; padding: 0; border-radius: 0; color: var(--ink); background: none; font-size: 14px; }
.person-profile-visual .person-trait-card span { display: block; margin-top: 6px; color: rgba(16,47,52,.7); font-size: 11px; text-transform: none; letter-spacing: 0; line-height: 1.25; }
.person-profile-visual .person-signal-grid { grid-column: 1/-1; display: grid !important; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 9px; }
.person-profile-visual .person-signal-card { min-width: 0; padding: 13px; border: 1px solid rgba(255,255,255,.13); border-radius: 15px; background: rgba(255,255,255,.08); }
.person-profile-visual .person-signal-card span { display: block; color: var(--white); font-size: 12px; text-transform: none; letter-spacing: 0; font-weight: 850; }
.person-profile-visual .person-signal-card i { display: block; height: 9px; margin: 10px 0 8px; overflow: hidden; border-radius: 99px; background: rgba(255,255,255,.16); }
.person-profile-visual .person-signal-card i b { display: block; height: 100%; padding: 0; border-radius: inherit; background: #11afa2; }
.person-profile-visual .person-signal-card small { margin: 0; color: rgba(255,255,255,.62); line-height: 1.25; }
footer { padding: 75px clamp(24px,6vw,92px) 120px; color: var(--white); background: var(--ink); }.footer-brand { margin-bottom: 28px; }.footer-brand + p { max-width: 600px; font-family: Georgia,serif; font-size: 33px; line-height: 1.15; }.footer-sources { max-width: 900px; display: grid; gap: 10px; margin-top: 26px; color: rgba(255,255,255,.62); font-size: 13px; line-height: 1.5; }.footer-sources p { margin: 0; }.footer-sources a { color: var(--yellow); font-weight: 800; }
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s ease; }.reveal.visible { opacity: 1; transform: none; }
@keyframes spin { to { transform: translate(-50%,-50%) rotate(360deg); } } @keyframes float { 50% { transform: translate(-50%,-53%) rotate(1deg); } } @keyframes float-small { 50% { translate: 0 -10px; } }

@media (max-width: 1050px) {
  .hero { grid-template-columns: 1fr; padding-top: 140px; }.hero-visual { position: absolute; right: -110px; bottom: -80px; width: 56%; opacity: .56; }.hero-copy { max-width: 700px; }.hero-wallpaper { opacity: .09; }.branch-grid { grid-template-columns: 1fr 1fr; }.branch-card { min-height: 310px; }.degree-grid { grid-template-columns: 1fr 1fr; }.filters { grid-template-columns: 1fr 1fr; }.filters label:nth-child(3) { border-left: 0; }.comparison-columns, .compare-hero-grid, .insight-strip { grid-template-columns: 1fr; }.theme-row { grid-template-columns: 1fr; }.compare-tray { grid-template-columns: 1fr auto; }.compare-tray-copy { display: none; }.compare-picks { overflow-x: auto; }
}
@media (max-width: 680px) {
  .site-header { height: 64px; padding: 0 18px; }.site-header nav a { display: none; }.brand-mark { width: 37px; height: 37px; }.brand-word { font-size: 20px; }.hero { min-height: 850px; padding: 120px 21px 100px; align-items: start; }.hero-wallpaper { inset: 2% -130%; opacity: .08; }.hero h1 { font-size: clamp(58px,18vw,86px); }.hero-lead { font-size: 16px; }.hero-visual { width: 100%; height: 410px; min-height: 0; right: -70px; bottom: -40px; }.orbit-one { width: 360px; height: 360px; }.orbit-two { width: 480px; height: 480px; }.visual-card-main { width: 265px; min-height: 285px; padding: 17px; }.hero-degree-row { padding: 7px 0; }.visual-card-left { left: 5%; }.visual-card-science { right: 8%; top: 6%; }.visual-card-right { right: 2%; }.hero-example-cloud { display: none; }.scroll-cue { display: none; }.branch-section { padding: 90px 18px; }.branch-grid { grid-template-columns: 1fr; }.branch-card { min-height: 260px; }.catalog-section { padding: 74px 16px 130px; border-radius: 34px 34px 0 0; }.catalog-top { display: block; }.catalog-intro { margin-top: 20px; }.filters { position: static; grid-template-columns: 1fr; padding: 8px; }.filters label, .filters label:nth-child(3) { border-left: 0; border-top: 1px solid var(--line); padding: 10px; }.filters label:first-child { border-top: 0; }.degree-grid { grid-template-columns: 1fr; }.degree-card { min-height: 330px; }.compare-tray { bottom: 8px; width: calc(100% - 16px); grid-template-columns: 1fr auto; padding: 8px; }.pick-chip span { max-width: 75px; }.compare-now { min-width: 116px; font-size: 12px; }.compare-now span { display: none; }.comparison-section { padding: 28px 16px 100px; }.comparison-head h2 { font-size: 43px; }.compare-block { padding: 20px 16px; }.theme-bar-line { grid-template-columns: 80px 1fr 34px; }.dialog-quick, .detail-sections { grid-template-columns: 1fr; }.donut { margin: auto; }.degree-dialog { border-radius: 20px; }.dialog-hero { padding-top: 70px; }
}
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; } }
@media (max-width: 900px) { .aqu-metrics { grid-template-columns: repeat(3,1fr); }.winner-grid { grid-template-columns: 1fr 1fr; }.ask-recommendations { grid-template-columns: 1fr; }.quiz-options.branch-options { grid-template-columns: 1fr 1fr; } }
@media (max-width: 680px) { .nav-test { display: none; }.quiz-promo { margin: 0 16px 70px; min-height: 0; padding: 40px 22px 22px; grid-template-columns: 1fr; gap: 30px; }.quiz-promo::before { inset: 10px; }.quiz-promo h2 { font-size: 42px; }.quiz-steps { display: grid; grid-template-columns: 1fr; }.quiz-preview { padding: 19px; transform: none; }.quiz-start { width: 100%; min-height: 52px; }.ask-section { margin: 0 16px 70px; padding: 30px 18px; }.ask-heading h2 br { display: none; }.ask-actions { align-items: stretch; flex-direction: column; }.ask-actions span { display: none; }.ask-actions button { width: 100%; }.reading-key { align-items: flex-start; flex-direction: column; }.aqu-metrics { grid-template-columns: 1fr 1fr; }.winner-grid { grid-template-columns: 1fr; }.aqu-compare-row { grid-template-columns: 1fr; }.aqu-bar-line { grid-template-columns: 78px 1fr 62px; }.quiz-shell { min-height: 670px; padding: 26px 18px; }.quiz-progress { padding-right: 46px; grid-template-columns: 1fr; }.quiz-options, .quiz-options.branch-options { grid-template-columns: 1fr; }.quiz-option { min-height: 86px; }.recommendation { grid-template-columns: 42px 1fr; }.recommendation button { grid-column: 1/-1; }.degree-advisor-row { grid-template-columns: 1fr; }.degree-advisor button { min-height: 44px; }.ct-visual-grid { grid-template-columns: 1fr; } }
@media (max-width: 680px) { .aqu-showcase { grid-template-columns: 1fr; }.aqu-income { min-height: 150px; }.aqu-ring-grid { padding: 11px; gap: 7px; }.metric-ring::after { inset: 7px; }.metric-ring > div { inset: 12px; }.metric-ring strong { font-size: 18px; }.metric-ring span { font-size: 7px; }.aqu-detail-grid { grid-template-columns: 1fr; }.job-speed-legend { display: grid; grid-template-columns: 1fr 1fr; }.learning-axes { grid-template-columns: 1fr; }.aqu-quick { grid-template-columns: auto 1fr 1fr; }.aqu-quick strong { font-size: 12px; } }
@media (max-width: 900px) { .subject-overview { grid-template-columns: 1fr; }.subject-year-grid { grid-template-columns: 1fr; }.study-badges { grid-template-columns: 1fr 1fr; }.outcome-visual { grid-template-columns: 1fr 1fr; }.fit-grid { grid-template-columns: 1fr; } }
@media (max-width: 680px) { .subject-dashboard { padding: 12px; }.subject-big-number { min-height: 125px; }.subject-category-bars > div { grid-template-columns: 105px 1fr 24px; }.study-badges { grid-template-columns: 1fr; }.outcome-visual { grid-template-columns: 1fr; }.flag-grid,.person-profile { grid-template-columns: 1fr; }.person-profile-visual .person-trait-grid,.person-profile-visual .person-signal-grid { grid-template-columns: 1fr; }.person-profile-visual .person-profile-head { min-height: 145px; }.learning-summary { font-size: 17px; } }

/* Mobile polish + explicit mobile/PC switch */
@media (max-width: 680px) {
  body { background: #fbf8f0; }
  .site-header {
    inset: 10px 10px auto;
    width: auto;
    height: 58px;
    padding: 0 12px;
    border: 1px solid rgba(255,255,255,.13);
    border-radius: 20px;
    color: var(--white);
    background: rgba(16,47,52,.78);
    backdrop-filter: blur(18px);
    box-shadow: 0 12px 36px rgba(0,0,0,.18);
  }
  .site-header.scrolled { color: var(--ink); background: rgba(255,254,249,.92); }
  .site-header nav { gap: 8px; margin-left: auto; }
  .nav-compare { padding: 7px 9px; font-size: 12px; }
  .nav-compare span { min-width: 20px; height: 20px; margin-left: 4px; font-size: 11px; }
  .view-toggle {
    position: fixed;
    z-index: 54;
    top: auto;
    left: auto;
    right: 12px;
    bottom: calc(92px + env(safe-area-inset-bottom));
    color: var(--ink);
    border-color: var(--line);
    background: rgba(255,254,249,.96);
    box-shadow: 0 16px 45px rgba(20,45,48,.16);
  }
  .view-toggle button { min-height: 34px; padding: 0 13px; font-size: 11px; }

  .hero {
    min-height: auto;
    display: flex;
    flex-direction: column;
    gap: 28px;
    padding: 104px 18px 42px;
  }
  .hero::before { width: 310px; height: 310px; left: -170px; bottom: 115px; opacity: .42; }
  .hero::after { width: 260px; height: 260px; right: -130px; top: -120px; opacity: .8; }
  .hero-wallpaper { inset: -2% -170%; opacity: .075; }
  .hero-copy { max-width: none; }
  .hero h1 { font-size: clamp(47px, 16vw, 72px); line-height: .92; letter-spacing: -.062em; }
  .hero-lead { max-width: 340px; margin: 22px 0 20px; font-size: 15px; line-height: 1.48; }
  .hero-cta { width: 100%; max-width: 330px; justify-content: space-between; gap: 18px; padding: 12px 13px 12px 18px; }
  .hero-visual {
    position: relative;
    right: auto;
    bottom: auto;
    width: 100%;
    height: auto;
    min-height: 0;
    display: grid;
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap: 9px;
    opacity: 1;
  }
  .orbit, .visual-dot { display: none; }
  .visual-card { position: relative; inset: auto; transform: none !important; animation: none; box-shadow: 0 12px 30px rgba(0,0,0,.14); }
  .visual-card-main { grid-column: 1/-1; width: 100%; min-height: 0; padding: 18px; }
  .visual-card-left, .visual-card-science, .visual-card-right { min-height: 78px; padding: 13px; border-radius: 18px; }
  .visual-card-left b, .visual-card-right b, .visual-card-science b { font-size: 15px; line-height: 1; }
  .visual-card-left span, .visual-card-right span, .visual-card-science span { font-size: 10px; }
  .hero-degree-row b { white-space: normal; font-size: 15px; }
  .hero-example-cloud { grid-column: 1/-1; position: static; display: flex; justify-content: flex-start; margin-top: 2px; }
  .hero-example-cloud span { font-size: 10px; padding: 7px 9px; }

  .branch-section { padding: 72px 16px; }
  .section-heading { margin-bottom: 28px; }
  .section-heading h2, .catalog-top h2, .comparison-head h2 { font-size: clamp(39px, 12vw, 54px); }
  .section-heading > p:last-child { font-size: 15px; }
  .branch-grid { gap: 12px; }
  .branch-card { min-height: 185px; padding: 20px; border-radius: 24px; }
  .branch-card strong { font-size: 36px; }
  .branch-card small { margin-bottom: 16px; font-size: 13px; }

  .quiz-promo { border-radius: 28px; }
  .quiz-promo h2 { font-size: clamp(36px, 11vw, 48px); }
  .quiz-preview { border-radius: 22px; }
  .ask-heading h2 { font-size: clamp(34px, 9.8vw, 45px); line-height: 1.02; }

  .catalog-section { padding: 60px 14px 130px; border-radius: 30px 30px 0 0; }
  .filters { margin-top: 26px; border-radius: 18px; box-shadow: none; }
  .results-meta { align-items: flex-start; gap: 12px; }
  .degree-grid { gap: 12px; }
  .degree-card { min-height: 0; padding: 20px; border-radius: 22px; }
  .degree-card h3 { margin-top: 17px; font-size: 24px; }
  .degree-actions { grid-template-columns: 1fr; }
  .degree-actions button { min-height: 47px; }
  .mini-themes { margin-top: 17px; }
  .aqu-quick { grid-template-columns: 1fr 1fr; }
  .aqu-source { grid-column: 1/-1; min-height: 24px; writing-mode: horizontal-tb; transform: none; }

  .compare-tray { bottom: calc(10px + env(safe-area-inset-bottom)); border-radius: 18px; }
  .comparison-section { padding-top: 24px; }
  .comparison-head { gap: 16px; align-items: center; }
  .comparison-head button { flex: 0 0 auto; }
  .compare-hero-card { min-height: 210px; }

  .degree-dialog { width: calc(100% - 14px); max-height: calc(100dvh - 14px); border-radius: 24px; }
  .dialog-close { top: 10px; margin: 10px 10px 0 0; width: 38px; height: 38px; }
  .dialog-hero { padding: 68px 18px 30px; }
  .dialog-hero h2 { font-size: clamp(34px, 11vw, 50px); }
  .dialog-body { padding: 24px 16px 72px; }
  .detail-theme { grid-template-columns: 1fr 78px 36px; }
  .subject-category-bars { padding: 14px; }
  .subject-year-grid article { padding: 13px; }

  footer { padding: 54px 18px 110px; }
  .footer-brand + p { font-size: 27px; }
}

body.view-mode-desktop {
  min-width: 1180px;
}
body.view-mode-desktop .site-header {
  inset: 0 0 auto;
  width: auto;
  height: 74px;
  padding: 0 clamp(22px, 4vw, 68px);
  border: 0;
  border-radius: 0;
  color: var(--white);
  background: transparent;
  box-shadow: none;
}
body.view-mode-desktop .site-header.scrolled {
  color: var(--ink);
  background: rgba(247,244,237,.91);
  box-shadow: 0 1px 0 var(--line);
}
body.view-mode-desktop .site-header nav {
  gap: 28px;
  margin-left: 0;
}
body.view-mode-desktop .site-header nav a,
body.view-mode-desktop .nav-test {
  display: inline-flex;
}
body.view-mode-desktop .nav-compare {
  padding: 9px 13px 9px 16px;
  font-size: 14px;
}
body.view-mode-desktop .view-toggle {
  top: 86px;
  right: clamp(16px,4vw,68px);
  bottom: auto;
  left: auto;
}
body.view-mode-desktop .hero {
  min-height: 100svh;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(420px, .95fr);
  align-items: center;
  gap: 0;
  padding: 110px clamp(24px, 7vw, 120px) 80px;
}
body.view-mode-desktop .hero h1 {
  font-size: clamp(64px, 7.5vw, 124px);
  line-height: .84;
  letter-spacing: -.075em;
}
body.view-mode-desktop .hero-lead {
  max-width: 640px;
  margin: 34px 0 30px;
  font-size: clamp(17px, 1.5vw, 22px);
}
body.view-mode-desktop .hero-cta {
  width: auto;
  max-width: none;
  gap: 40px;
  padding: 15px 18px 15px 24px;
}
body.view-mode-desktop .hero-visual {
  position: relative;
  right: auto;
  bottom: auto;
  width: auto;
  height: min(66vw, 660px);
  max-height: 660px;
  min-height: 480px;
  display: block;
  opacity: 1;
}
body.view-mode-desktop .orbit,
body.view-mode-desktop .visual-dot {
  display: block;
}
body.view-mode-desktop .visual-card {
  position: absolute;
}
body.view-mode-desktop .visual-card-main {
  width: 350px;
  min-height: 330px;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%) rotate(-2deg) !important;
}
body.view-mode-desktop .visual-card-left {
  left: 2%;
  top: 21%;
  transform: rotate(-8deg) !important;
}
body.view-mode-desktop .visual-card-science {
  right: 9%;
  top: 10%;
  transform: rotate(5deg) !important;
}
body.view-mode-desktop .visual-card-right {
  right: 0;
  bottom: 18%;
  transform: rotate(7deg) !important;
}
body.view-mode-desktop .hero-example-cloud {
  position: absolute;
  left: 4%;
  right: 2%;
  bottom: 4%;
  display: flex;
  justify-content: center;
  margin-top: 0;
}
body.view-mode-desktop .branch-section {
  padding: clamp(90px, 11vw, 170px) clamp(22px, 6vw, 92px);
}
body.view-mode-desktop .branch-grid {
  grid-template-columns: repeat(4, 1fr);
}
body.view-mode-desktop .branch-card {
  min-height: 370px;
  padding: 24px;
}
body.view-mode-desktop .catalog-section {
  padding: 100px clamp(22px, 6vw, 92px) 150px;
}
body.view-mode-desktop .filters {
  position: sticky;
  grid-template-columns: minmax(280px, 2fr) repeat(3,minmax(145px,1fr));
  margin-top: 42px;
}
body.view-mode-desktop .degree-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
body.view-mode-desktop .degree-card {
  min-height: 420px;
}
