:root {
  --paper:#F3EFE6; --ink:#14110C; --coral:#FF6B4A; --ink-muted:#5A5346; --paper-2:#EAE3D4;
  --prog-musikk:#36638E; --prog-dans:#FF8A65; --prog-drama:#6FA86F; --prog-studie:#F7C31B; --prog-pabygg:#2B4F71;
  --font:'Space Grotesk', system-ui, sans-serif; --maxw:1200px; --radius:14px;
}
* { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:var(--font); background:var(--paper); color:var(--ink); line-height:1.6; -webkit-font-smoothing:antialiased; }
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
h1,h2,h3 { line-height:1; letter-spacing:-0.02em; }
.wrap { width:min(100% - 2.4rem, var(--maxw)); margin-inline:auto; }
.section { padding-block:clamp(3.5rem, 9vw, 7rem); }
.section__label { font-size:0.7rem; font-weight:600; letter-spacing:0.22em; text-transform:uppercase; color:var(--ink-muted); margin-bottom:1.2rem; }

/* buttons */
.btn { display:inline-flex; align-items:center; gap:0.5rem; font-family:inherit; font-weight:600; font-size:0.95rem; padding:0.85rem 1.6rem; border-radius:50px; border:none; cursor:pointer; transition:transform .25s ease, box-shadow .25s ease, background .25s ease; }
.btn:hover { transform:translateY(-2px); }
.btn--ink { background:var(--ink); color:var(--paper); }
.btn--coral { background:var(--coral); color:#fff; }
.btn--ghost { background:transparent; color:var(--ink); border:1.5px solid var(--ink); }

/* grain overlay (reusable) */
.grain::after { content:''; position:absolute; inset:0; pointer-events:none; opacity:0.06; background-image:radial-gradient(var(--ink) 0.5px, transparent 0.5px); background-size:3px 3px; }

/* nav */
.nav { position:sticky; top:0; z-index:50; background:color-mix(in srgb, var(--paper) 88%, transparent); backdrop-filter:blur(8px); border-bottom:1px solid rgba(20,17,12,.08); }
.nav__inner { display:flex; align-items:center; gap:1rem; padding-block:0.9rem; }
.nav__logo { font-weight:700; letter-spacing:0.04em; font-size:1.05rem; display:inline-flex; align-items:center; }
.nav__logo span { color:var(--coral); margin-left:0.22em; }
@keyframes sun-spin { 0% { transform:rotate(0deg) scale(1); } 70% { transform:rotate(385deg) scale(1.16); } 100% { transform:rotate(360deg) scale(1); } }
.nav__logo img { height:30px; width:auto; display:block; margin-right:0.5rem; transform-origin:center; transition:filter .3s ease; will-change:transform; }
.nav__logo:hover img { animation:sun-spin .75s cubic-bezier(.4,0,.2,1); filter:drop-shadow(0 0 7px color-mix(in srgb, var(--coral) 60%, transparent)); }
.nav__logo:active img { animation:none; transform:scale(0.88); transition:transform .1s ease; }
.footer__brand .nav__logo { font-size:1.15rem; }
.footer__brand .nav__logo img { height:34px; }
@media (max-width:640px){ .nav__logo img { height:26px; } }
.nav__links { display:flex; align-items:center; gap:1.6rem; font-weight:500; font-size:0.9rem; margin-left:auto; }
.nav__links a:not(.btn):hover { color:var(--coral); }
.nav__cta { padding:0.55rem 1.1rem; font-size:0.85rem; }
.nav__links a.is-active { color:var(--coral); }
.nav__links a.is-active:not(.btn)::after { content:''; display:block; height:2px; background:var(--coral); margin-top:2px; }
.nav__burger { display:none; flex-direction:column; justify-content:center; gap:5px; width:42px; height:42px; padding:0; border:none; background:none; cursor:pointer; }
.nav__burger span { display:block; width:22px; height:2px; background:var(--ink); margin-inline:auto; transition:transform .25s ease, opacity .2s ease; }
.nav.is-open .nav__burger span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav.is-open .nav__burger span:nth-child(2) { opacity:0; }
.nav.is-open .nav__burger span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* hero */
.hero { position:relative; min-height:88vh; display:flex; align-items:center; overflow:hidden; }
.hero__inner { padding-block:4rem; }
.hero__kicker { font-size:0.72rem; font-weight:600; letter-spacing:0.24em; text-transform:uppercase; color:var(--ink-muted); margin-bottom:1.4rem; }
.hero__title { font-weight:700; text-transform:uppercase; font-size:clamp(3rem, 11vw, 7.5rem); line-height:0.86; letter-spacing:-0.03em; }
.hero__rotator { color:var(--coral); display:inline-block; transition:opacity .22s ease; }
.hero__lead { margin-top:1.6rem; max-width:46ch; font-size:clamp(1rem,1.6vw,1.2rem); color:var(--ink-muted); }
.hero__actions { display:flex; flex-wrap:wrap; gap:0.8rem; margin-top:2rem; }

/* per-page hero band (lighter than the home hero) */
.page-hero { padding-block:clamp(3rem,8vw,6rem) clamp(2rem,5vw,3rem); }
.page-hero h1 { font-size:clamp(2.6rem,9vw,6rem); font-weight:700; text-transform:uppercase; letter-spacing:-0.03em; line-height:0.88; }
.page-hero p { margin-top:1.2rem; max-width:52ch; color:var(--ink-muted); font-size:clamp(1rem,1.6vw,1.2rem); }

/* programs */
.programs__title { font-size:clamp(2rem,5vw,3.2rem); font-weight:700; margin-bottom:2rem; }
.programs { display:grid; grid-template-columns:repeat(auto-fit, minmax(220px,1fr)); gap:1.2rem; }
.program-card { background:#fff; border:1px solid rgba(20,17,12,.07); border-radius:var(--radius); overflow:hidden; transition:transform .25s ease, box-shadow .25s ease; }
.program-card:hover { transform:translateY(-4px) scale(1.01); box-shadow:0 18px 40px -18px rgba(20,17,12,.35); }
.program-card__top { height:170px; position:relative; overflow:hidden; background:var(--c); display:flex; align-items:flex-end; padding:0.7rem 0.9rem; }
.program-card__top img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.program-card__top::after { content:''; position:absolute; inset:0; opacity:0.6; transition:opacity .3s ease;
  background:linear-gradient(to top right,
    var(--c) 0%,
    var(--c) 15%,
    color-mix(in srgb, var(--c) 60%, transparent) 38%,
    color-mix(in srgb, var(--c) 20%, transparent) 58%,
    transparent 78%); }
.program-card:hover .program-card__top::after { opacity:1; }
.program-card__num { position:relative; z-index:1; color:#fff; font-weight:700; font-size:0.9rem; opacity:0.95; text-shadow:0 1px 3px rgba(0,0,0,.45); }
.program-card__body { padding:1rem 1.1rem 1.3rem; }
.program-card__body h3 { font-size:1.25rem; font-weight:700; }
.program-card__body p { margin-top:0.4rem; font-size:0.9rem; color:var(--ink-muted); }
.program-card__more { display:inline-block; margin-top:0.9rem; font-weight:600; font-size:0.85rem; color:var(--c); }

/* alternating program detail rows */
.program-detail { display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:center; padding-block:clamp(2rem,5vw,3.5rem); border-top:1px solid rgba(20,17,12,.1); }
.program-detail:nth-child(even) .program-detail__media { order:-1; }
.program-detail__kicker { font-weight:600; font-size:0.8rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--c); }
.program-detail h2 { font-size:clamp(1.8rem,4vw,2.8rem); font-weight:700; margin:0.4rem 0 0.8rem; }
.program-detail p { color:var(--ink-muted); max-width:46ch; }
.program-detail__list { list-style:none; margin-top:1rem; display:grid; gap:0.5rem; }
.program-detail__list li { padding-left:1.5rem; position:relative; font-weight:500; font-size:0.95rem; }
.program-detail__list li::before { content:'→'; position:absolute; left:0; color:var(--c); font-weight:700; }
.program-detail__media { min-height:320px; border-radius:var(--radius); position:relative; overflow:hidden; background:linear-gradient(150deg, var(--ink), var(--c)); }
.program-detail__media img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.program-detail__media::after { content:''; position:absolute; inset:0; opacity:0.6; transition:opacity .35s ease;
  background:linear-gradient(to top right,
    var(--c) 0%,
    var(--c) 15%,
    color-mix(in srgb, var(--c) 60%, transparent) 38%,
    color-mix(in srgb, var(--c) 20%, transparent) 58%,
    transparent 78%); }
.program-detail:hover .program-detail__media::after { opacity:1; }

/* why */
.why__inner { display:grid; grid-template-columns:1fr 1.4fr; gap:clamp(2rem,5vw,4rem); align-items:start; }
.why__title { font-size:clamp(2rem,5vw,3.4rem); font-weight:700; }
.why__cols { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:1.8rem; }
.why__item h3 { font-size:1.2rem; font-weight:700; }
.why__item h3::before { content:''; display:block; width:32px; height:3px; background:var(--coral); margin-bottom:0.8rem; }
.why__item p { margin-top:0.5rem; color:var(--ink-muted); font-size:0.95rem; }

/* campus + duotone */
.campus__grid { display:grid; grid-template-columns:1.1fr 1fr 1fr; gap:1.2rem; align-items:stretch; }
.campus__title { font-size:clamp(2rem,5vw,3.4rem); font-weight:700; }
.campus__text p { margin:1rem 0 1.6rem; color:var(--ink-muted); max-width:34ch; }
.duotone { border-radius:var(--radius); min-height:300px; position:relative; overflow:hidden; }
.duotone--coral { background:linear-gradient(150deg, var(--ink), var(--coral)); }
.duotone--blue { background:linear-gradient(150deg, var(--ink), var(--prog-musikk)); }
.duotone img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.duotone::after { content:''; position:absolute; inset:0; background:linear-gradient(180deg, transparent 55%, rgba(20,17,12,0.30)); }

/* dorm */
.dorm__inner { display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.dorm__img { min-height:360px; }
.dorm__title { font-size:clamp(2rem,5vw,3.4rem); font-weight:700; }
.dorm__text p { margin:1rem 0; color:var(--ink-muted); max-width:42ch; }
.dorm__list { list-style:none; display:grid; gap:0.6rem; }
.dorm__list li { padding-left:1.6rem; position:relative; font-weight:500; }
.dorm__list li::before { content:'→'; position:absolute; left:0; color:var(--coral); font-weight:700; }

/* numbered apply steps */
.steps { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1.4rem; margin-top:1.5rem; }
.step { background:#fff; border:1px solid rgba(20,17,12,.07); border-radius:var(--radius); padding:1.4rem; }
.step__num { font-weight:700; font-size:1.4rem; color:var(--coral); }
.step h3 { font-size:1.1rem; font-weight:700; margin:0.4rem 0; }
.step p { color:var(--ink-muted); font-size:0.9rem; }

/* FAQ accordion */
.faq { margin-top:1.5rem; display:grid; gap:0.6rem; max-width:760px; }
.faq details { background:#fff; border:1px solid rgba(20,17,12,.08); border-radius:var(--radius); padding:0.4rem 1.1rem; }
.faq summary { cursor:pointer; font-weight:600; padding:0.7rem 0; list-style:none; }
.faq summary::-webkit-details-marker { display:none; }
.faq summary::after { content:'+'; float:right; color:var(--coral); font-weight:700; }
.faq details[open] summary::after { content:'–'; }
.faq details p { color:var(--ink-muted); padding-bottom:0.8rem; }

/* contact */
.contact { display:grid; grid-template-columns:1.25fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:start; }

/* contact form */
.cform { display:grid; gap:1.1rem; }
.cform .section__label { margin-bottom:0; }
.cform__row { display:grid; gap:0.4rem; }
.cform label { font-size:0.72rem; font-weight:600; letter-spacing:0.14em; text-transform:uppercase; color:var(--ink-muted); }
.cform input, .cform textarea { font-family:inherit; font-size:1rem; color:var(--ink); background:#fff; border:1.5px solid rgba(20,17,12,.15); border-radius:12px; padding:0.8rem 1rem; transition:border-color .2s ease, box-shadow .2s ease; }
.cform textarea { resize:vertical; min-height:130px; }
.cform input:focus, .cform textarea:focus { outline:none; border-color:var(--coral); box-shadow:0 0 0 3px color-mix(in srgb, var(--coral) 22%, transparent); }
.cform button { justify-self:start; margin-top:0.2rem; }
.cform__status { font-size:0.92rem; margin:0; min-height:1.2em; }
.cform__status.is-success { color:var(--prog-drama); font-weight:600; }
.cform__status.is-error { color:var(--coral); font-weight:600; }

/* program-colour button (used in quiz result) */
.btn--prog { background:var(--c); color:#fff; }

/* quiz */
section[id], article[id] { scroll-margin-top:90px; }
.quiz { max-width:680px; margin-inline:auto; }
.quiz__progress { display:flex; gap:0.5rem; justify-content:center; margin-bottom:2.2rem; }
.quiz__dot { width:28px; height:4px; border-radius:4px; background:rgba(20,17,12,.15); transition:background .3s ease; }
.quiz__dot.is-done { background:var(--ink); }
.quiz__dot.is-current { background:var(--coral); }
.quiz__step, .quiz__result { animation:quiz-in .4s ease; }
@keyframes quiz-in { from { opacity:0; transform:translateY(12px); } to { opacity:1; transform:none; } }
.quiz__q { font-size:clamp(1.6rem,4.5vw,2.5rem); font-weight:700; line-height:1.05; margin-bottom:1.8rem; text-align:center; }
.quiz__options { display:grid; gap:0.8rem; }
.quiz__opt { font-family:inherit; font-size:1.02rem; font-weight:500; text-align:left; color:var(--ink); background:#fff; border:1.5px solid rgba(20,17,12,.14); border-radius:14px; padding:1rem 1.2rem; cursor:pointer; transition:border-color .2s ease, background .2s ease, transform .15s ease; }
.quiz__opt:hover { border-color:var(--coral); background:color-mix(in srgb, var(--coral) 7%, #fff); transform:translateY(-2px); }
.quiz__count { text-align:center; font-size:0.75rem; letter-spacing:0.14em; text-transform:uppercase; color:var(--ink-muted); margin-top:1.4rem; }
.quiz__result { text-align:center; }
.quiz__badge { display:inline-block; font-size:0.72rem; font-weight:600; letter-spacing:0.2em; text-transform:uppercase; color:var(--ink-muted); margin-bottom:0.6rem; }
.quiz__pick { font-size:clamp(2.2rem,8vw,4.5rem); font-weight:700; text-transform:uppercase; line-height:0.92; letter-spacing:-0.02em; color:var(--c); overflow-wrap:anywhere; }
.quiz__media { margin:1.6rem auto 0; max-width:520px; border-radius:18px; overflow:hidden; position:relative; aspect-ratio:16/10; }
.quiz__media img { width:100%; height:100%; object-fit:cover; }
.quiz__media::after { content:''; position:absolute; inset:0; background:linear-gradient(to top right, var(--c) 0%, var(--c) 12%, color-mix(in srgb, var(--c) 45%, transparent) 40%, transparent 76%); }
.quiz__tag { margin:1.4rem auto 1.8rem; max-width:46ch; font-size:1.1rem; color:var(--ink-muted); }
.quiz__actions { display:flex; flex-wrap:wrap; gap:0.8rem; justify-content:center; }
.quiz__retake { display:block; margin:1.4rem auto 0; background:none; border:none; font-family:inherit; font-size:0.9rem; font-weight:600; color:var(--ink-muted); cursor:pointer; text-decoration:underline; }
.quiz__sharenote { min-height:1.2em; margin-top:0.9rem; font-size:0.9rem; font-weight:600; color:var(--prog-drama); }

/* theme toggle */
.theme-toggle { display:inline-flex; align-items:center; justify-content:center; width:38px; height:38px; border-radius:50%; border:1.5px solid transparent; background:none; color:var(--ink); cursor:pointer; transition:border-color .2s ease, transform .2s ease; }
.theme-toggle:hover { border-color:var(--ink); transform:translateY(-1px); }
.theme-toggle__moon { display:block; }
.theme-toggle__sun { display:none; }
[data-theme="dark"] .theme-toggle__moon { display:none; }
[data-theme="dark"] .theme-toggle__sun { display:block; }

/* smooth theme switch */
body, .nav, .program-card, .step, .faq details, .cform input, .cform textarea, .footer, .quiz__opt, .admissions { transition:background-color .35s ease, color .35s ease, border-color .35s ease; }

/* dark "stage" mode */
[data-theme="dark"] {
  --paper:#14100b;
  --ink:#F3EFE6;
  --ink-muted:#a89e8e;
  --paper-2:#1b1610;
}
[data-theme="dark"] .nav { border-bottom-color:rgba(255,255,255,.10); }
[data-theme="dark"] .hero { background:radial-gradient(120% 80% at 50% -10%, rgba(255,107,74,.12), transparent 60%); }
[data-theme="dark"] .program-card,
[data-theme="dark"] .step,
[data-theme="dark"] .faq details,
[data-theme="dark"] .cform input,
[data-theme="dark"] .cform textarea,
[data-theme="dark"] .quiz__opt { background:#221c15; border-color:rgba(255,255,255,.12); }
[data-theme="dark"] .program-card { border-color:rgba(255,255,255,.10); }
[data-theme="dark"] .quiz__opt:hover { background:color-mix(in srgb, var(--coral) 16%, #221c15); border-color:var(--coral); }
[data-theme="dark"] .quiz__dot { background:rgba(255,255,255,.16); }
[data-theme="dark"] .footer__bottom { border-top-color:rgba(255,255,255,.12); }
[data-theme="dark"] .admissions { background:#1d1810; color:var(--ink); border:1px solid rgba(255,255,255,.10); }
[data-theme="dark"] .admissions__lead { color:var(--ink-muted); }
[data-theme="dark"] .admissions__ghost { color:var(--ink); border-color:var(--ink); }
.contact__details p { margin:0.4rem 0; color:var(--ink-muted); }
.contact__details a:not(.btn) { color:var(--coral); font-weight:600; }
.contact__actions { margin-top:1.4rem; }
.contact__map { margin-top:1.4rem; border-radius:var(--radius); overflow:hidden; border:1px solid rgba(20,17,12,.1); }
.contact__map iframe { display:block; width:100%; height:300px; border:0; }

/* admissions */
.admissions { position:relative; background:var(--ink); color:var(--paper); border-radius:clamp(0px,3vw,28px); margin-inline:auto; overflow:hidden; padding-block:clamp(3rem,7vw,5.5rem); }
.admissions__inner { text-align:center; }
.admissions__label { color:var(--coral); }
.admissions__title { font-size:clamp(2.4rem,7vw,5rem); font-weight:700; text-transform:uppercase; }
.admissions__lead { margin:1.4rem auto 2rem; max-width:48ch; color:color-mix(in srgb, var(--paper) 78%, transparent); }
.admissions__actions { display:flex; flex-wrap:wrap; gap:0.8rem; justify-content:center; }
.admissions__ghost { color:var(--paper); border-color:var(--paper); }

/* footer */
.footer { background:var(--paper-2); padding-block:3rem 1.5rem; margin-top:2rem; }
.footer__inner { display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:2rem; }
.footer__brand p { margin-top:0.8rem; color:var(--ink-muted); max-width:32ch; }
.footer__col h4 { font-size:0.78rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--ink-muted); margin-bottom:0.8rem; }
.footer__col a { display:block; padding:0.2rem 0; }
.footer__col a:hover { color:var(--coral); }
.footer__bottom { margin-top:2.4rem; padding-top:1.2rem; border-top:1px solid rgba(20,17,12,.1); font-size:0.8rem; color:var(--ink-muted); }

/* reveal motion */
.reveal { opacity:0; transform:translateY(24px); transition:opacity .6s ease, transform .6s ease; }
.reveal.is-in { opacity:1; transform:none; }

/* a11y */
:focus-visible { outline:3px solid var(--coral); outline-offset:3px; border-radius:4px; }
.skip { position:absolute; left:-9999px; }
.skip:focus { left:1rem; top:1rem; z-index:100; background:var(--ink); color:var(--paper); padding:0.6rem 1rem; border-radius:8px; }

/* responsive */
@media (max-width:860px){ .campus__grid{ grid-template-columns:1fr 1fr; } .campus__text{ grid-column:1 / -1; } }
@media (max-width:760px){ .why__inner{ grid-template-columns:1fr; } .dorm__inner{ grid-template-columns:1fr; } .program-detail{ grid-template-columns:1fr; } .program-detail:nth-child(even) .program-detail__media{ order:0; } .contact{ grid-template-columns:1fr; } }
@media (max-width:680px){ .footer__inner{ grid-template-columns:1fr 1fr; } .footer__brand{ grid-column:1 / -1; } }
@media (max-width:760px){
  .nav__burger { display:flex; }
  .nav__links { position:absolute; top:100%; left:0; right:0; flex-direction:column; align-items:stretch; gap:0.1rem; background:var(--paper); border-bottom:1px solid color-mix(in srgb, var(--ink) 12%, transparent); box-shadow:0 24px 40px -24px rgba(20,17,12,.45); padding:0.8rem 1.5rem 1.6rem; transform:translateY(-10px); opacity:0; pointer-events:none; transition:opacity .25s ease, transform .25s ease; }
  .nav.is-open .nav__links { transform:none; opacity:1; pointer-events:auto; }
  .nav__links a:not(.btn) { padding:0.9rem 0; font-size:1.1rem; border-bottom:1px solid color-mix(in srgb, var(--ink) 8%, transparent); }
  .nav__links a.is-active:not(.btn)::after { display:none; }
  .nav__cta { align-self:stretch; justify-content:center; margin-top:0.9rem; padding-block:0.8rem; }
  .theme-toggle { margin-left:auto; }
}
@media (max-width:520px){ .campus__grid{ grid-template-columns:1fr; } }

@media (prefers-reduced-motion: reduce){
  html { scroll-behavior:auto; }
  .reveal { opacity:1; transform:none; transition:none; }
  .btn, .program-card, .program-detail__media::after, .program-card__top::after { transition:none; }
  .nav__logo img, .nav__logo:hover img, .nav__logo:active img { animation:none; transition:none; transform:none; filter:none; }
  .quiz__step, .quiz__result { animation:none; }
  .nav__burger span, .nav__links { transition:none; }
}
