/* =============================================================
   Magister Digital: Header / Mega-Menu
   Editorial register. Magister Heritage palette.
   No rounded corners. No gradients. No box-shadow puffiness.
   ============================================================= */

/* ---------- Tokens (scoped, won't collide with theme.json) ----------
   GRAPHITE HEADER (Gold Standard, 2026-05-30): the header + mega-menu + mobile
   drawer now run on graphite #0F1115 so the gold+silver brand logo fits. Slug
   names kept (--mh-navy etc.) to avoid touching 68 consumer refs; the SEMANTICS
   are inverted: the "ivory" surface tokens are now graphite, and the "navy"/ink
   text tokens are now white/silver (legible on graphite). Gold stays gold.
     surface (was ivory)  -> graphite #0F1115 / #16171A
     text   (was navy/ink)-> white #FFFFFF / body #E8E9EA
     muted  (was footnote)-> platinum silver #C0C3C7
     accent (was gold)    -> rich gold #D4AF37 (eyebrows, focus, hover) */
.magister-header,
.magister-mobile-menu {
	--mh-navy: #FFFFFF;          /* primary text/logo on graphite (white ~19:1) */
	--mh-navy-darker: #16171A;   /* deepest graphite (mobile CTA hover bg) */
	--mh-ivory: #0F1115;         /* GRAPHITE shell/mega/drawer background */
	--mh-ivory-tint: #16171A;    /* slightly lifted graphite (scrolled state) */
	--mh-vellum: #16171A;        /* mega feature panel — lifted graphite */
	--mh-oxblood: #D4AF37;       /* nav/link hover -> gold on graphite (~8.5:1) */
	--mh-gold: #D4AF37;          /* rich gold accent (eyebrows, focus, CTA) */
	--mh-action: #D4AF37;        /* gold CTA fill */
	--mh-action-hi: #E3C24E;     /* gold CTA hover */
	--mh-ink: #E8E9EA;           /* body text on graphite (~16:1) */
	--mh-silver: #C0C3C7;        /* platinum silver (muted text on graphite) */
	--mh-footnote: #C0C3C7;      /* muted -> platinum silver (~10:1 on graphite) */
	--mh-rule: rgba(192, 195, 199, 0.18);     /* silver hairline on graphite */
	--mh-rule-strong: rgba(192, 195, 199, 0.32);
	--mh-serif: "Playfair Display", Georgia, "Times New Roman", serif;
	--mh-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--mh-ease: cubic-bezier(0.2, 0.6, 0.2, 1);
	--mh-dur-fast: 180ms;
	--mh-dur: 280ms;
}

/* ---------- Skip link ---------- */
.skip-link {
	position: absolute;
	top: -100px;
	left: 16px;
	z-index: 200;
	padding: 12px 20px;
	background: var(--mh-navy);
	color: var(--mh-ivory);
	font-family: var(--mh-sans);
	font-weight: 500;
	font-size: 14px;
	letter-spacing: 0.02em;
	text-decoration: none;
	transition: top var(--mh-dur-fast) var(--mh-ease);
}
.skip-link:focus { top: 12px; outline: 2px solid var(--mh-gold); outline-offset: 2px; }

/* ---------- Header shell ---------- */
.magister-header {
	position: sticky;
	top: 0;
	z-index: 100;
	width: 100%;
	background-color: var(--mh-ivory);
	border-bottom: 1px solid transparent;
	transition: background-color var(--mh-dur) var(--mh-ease),
				border-color var(--mh-dur) var(--mh-ease);
	font-family: var(--mh-sans);
	color: var(--mh-navy);
}
.magister-header.is-scrolled {
	background-color: var(--mh-ivory-tint);
	border-bottom-color: var(--mh-rule);
}
.magister-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
	max-width: 1320px;
	margin: 0 auto;
	padding: 18px 32px;
}

/* ---------- Logo ---------- */
.magister-logo {
	display: inline-flex;
	align-items: center;
	color: var(--mh-navy);                 /* SVG uses currentColor */
	text-decoration: none;
	flex-shrink: 0;
	transition: transform var(--mh-dur-fast) var(--mh-ease),
				color var(--mh-dur-fast) var(--mh-ease);
}
.magister-logo:hover { transform: scale(1.02); }
.magister-logo:focus-visible { outline: 2px solid var(--mh-gold); outline-offset: 4px; }
.magister-logo__svg { display: block; height: 56px; width: auto; }
/* PNG brand logo (gold wordmark, transparent bg) on graphite header.
   54px tall desktop reads as a confident, dominant brand mark (was 48px floor);
   the >=44px mobile floor below preserves Quality Bar axis 8. Width auto keeps ratio. */
.magister-logo__img { display: block; height: 54px; width: auto; }

/* ---------- Desktop nav ---------- */
.magister-nav { flex: 1 1 auto; display: flex; justify-content: center; }
.magister-nav__list {
	display: flex;
	align-items: center;
	gap: 4px;
	margin: 0;
	padding: 0;
	list-style: none;
}
.magister-nav__item { position: static; }    /* mega menu spans full width; positions absolute against header */

.magister-nav__link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 14px 16px;
	font-family: var(--mh-sans);
	font-size: 15px;
	font-weight: 500;
	letter-spacing: 0.005em;
	color: var(--mh-navy);
	text-decoration: none;
	background: transparent;
	border: none;
	transition: color var(--mh-dur-fast) var(--mh-ease);
}
.magister-nav__link:hover,
.magister-nav__link:focus-visible { color: var(--mh-oxblood); }
.magister-nav__link:focus-visible { outline: 2px solid var(--mh-gold); outline-offset: 2px; }
.magister-nav__caret {
	display: inline-block;
	font-size: 9px;
	line-height: 1;
	transform: translateY(1px);
	transition: transform var(--mh-dur-fast) var(--mh-ease);
}
.magister-nav__item--mega:hover .magister-nav__caret,
.magister-nav__item--mega:focus-within .magister-nav__caret,
.magister-nav__item--mega .magister-nav__link[aria-expanded="true"] .magister-nav__caret {
	transform: translateY(1px) rotate(180deg);
}

/* ---------- Mega menu (full-width structural drop) ---------- */
.magister-mega {
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	background: var(--mh-ivory);
	border-top: 1px solid var(--mh-rule);
	border-bottom: 1px solid var(--mh-rule);
	opacity: 0;
	visibility: hidden;
	transform: translateY(-4px);
	pointer-events: none;
	/* Close delay: 200ms on visibility AND pointer-events so cursor can travel
	   from trigger to dropdown and clicks land before unmount. (2026-05-18 fix) */
	transition: opacity var(--mh-dur) var(--mh-ease),
				transform var(--mh-dur) var(--mh-ease),
				visibility 0s linear 200ms,
				pointer-events 0s linear 200ms;
	z-index: 90;
}
.magister-header.is-scrolled .magister-mega { background: var(--mh-ivory-tint); }

/* Hover-gap bridge: invisible ::before pseudo-element on the dropdown extends
   18px UP from dropdown top edge to cover the physical gap between trigger
   bottom (y≈71.5) and dropdown top (y≈89.5 = header bottom). 18px matches the
   header's bottom padding exactly. Keep .magister-nav__item--mega at position:
   static so the dropdown remains absolutely positioned against .magister-header
   (which is position: sticky and provides the positioning context), giving the
   dropdown full-width spread across the viewport.
   pointer-events: none by default and auto only when dropdown is open via :hover
   chain so the bridge does NOT intercept trigger clicks in default state.
   (Brian-reported click-bug 2026-05-18; verified working via Playwright slow
   cursor traverse — click on first dropdown item succeeded.) */
.magister-mega::before {
	content: "";
	position: absolute;
	top: -18px;
	left: 0;
	right: 0;
	height: 18px;
	pointer-events: none;
}
.magister-nav__item--mega:hover > .magister-mega::before,
.magister-nav__item--mega:focus-within > .magister-mega::before,
.magister-mega:hover::before {
	pointer-events: auto;
}

.magister-nav__item--mega:hover > .magister-mega,
.magister-nav__item--mega:focus-within > .magister-mega,
.magister-nav__item--mega > .magister-nav__link[aria-expanded="true"] + .magister-mega,
.magister-mega:hover {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
	pointer-events: auto;
	transition: opacity var(--mh-dur) var(--mh-ease),
				transform var(--mh-dur) var(--mh-ease),
				visibility 0s linear 0s,
				pointer-events 0s linear 0s;
}

.magister-mega__inner {
	display: grid;
	grid-template-columns: 1fr 1fr 1.1fr;
	gap: 56px;
	max-width: 1320px;
	margin: 0 auto;
	padding: 48px 32px 56px;
}
.magister-mega__inner--two { grid-template-columns: 1fr 1.1fr; }

/* ---------- Mega columns ---------- */
.magister-mega__col-head {
	margin: 0 0 18px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--mh-rule);
	font-family: var(--mh-sans);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--mh-footnote);
}
.magister-mega__list { display: flex; flex-direction: column; gap: 4px; }
.magister-mega__link {
	display: block;
	padding: 12px 0;
	text-decoration: none;
	border-top: 1px solid transparent;
	border-bottom: 1px solid transparent;
	transition: color var(--mh-dur-fast) var(--mh-ease),
				transform var(--mh-dur-fast) var(--mh-ease);
}
.magister-mega__link:hover,
.magister-mega__link:focus-visible { transform: translateX(2px); }
.magister-mega__link:focus-visible {
	outline: 2px solid var(--mh-gold);
	outline-offset: 4px;
}
.magister-mega__link-title {
	display: block;
	font-family: var(--mh-serif);
	font-weight: 500;
	font-size: 19px;
	line-height: 1.25;
	color: var(--mh-navy);
	margin-bottom: 4px;
	transition: color var(--mh-dur-fast) var(--mh-ease);
}
.magister-mega__link:hover .magister-mega__link-title,
.magister-mega__link:focus-visible .magister-mega__link-title { color: var(--mh-oxblood); }
.magister-mega__link-desc {
	display: block;
	font-family: var(--mh-sans);
	font-size: 13.5px;
	line-height: 1.5;
	color: var(--mh-ink);
}

/* ---------- Mega feature panel ---------- */
.magister-mega__feature {
	display: flex;
	flex-direction: column;
	gap: 14px;
	padding: 36px 36px 32px;
	background: var(--mh-vellum);
	border-left: 1px solid var(--mh-rule);
}
.magister-mega__feature-eyebrow {
	font-family: var(--mh-sans);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--mh-gold);
}
.magister-mega__feature-num {
	font-family: var(--mh-serif);
	font-weight: 600;
	font-size: 56px;
	line-height: 0.95;
	letter-spacing: -0.01em;
	color: var(--mh-navy);
	font-variant-numeric: oldstyle-nums;
}
.magister-mega__feature-body {
	margin: 0;
	font-family: var(--mh-sans);
	font-size: 14.5px;
	line-height: 1.55;
	color: var(--mh-ink);
}
.magister-mega__feature-link {
	margin-top: auto;
	padding-top: 8px;
	font-family: var(--mh-sans);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.04em;
	color: var(--mh-navy);
	text-decoration: none;
	border-bottom: 1px solid var(--mh-rule-strong);
	align-self: flex-start;
	transition: color var(--mh-dur-fast) var(--mh-ease),
				border-color var(--mh-dur-fast) var(--mh-ease);
}
.magister-mega__feature-link:hover,
.magister-mega__feature-link:focus-visible {
	color: var(--mh-oxblood);
	border-bottom-color: var(--mh-oxblood);
}

/* ---------- Header actions (phone + CTA + mobile toggle) ---------- */
.magister-header__actions {
	display: flex;
	align-items: center;
	gap: 18px;
	flex-shrink: 0;
}
.magister-header__phone {
	font-family: var(--mh-sans);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--mh-navy);
	text-decoration: none;
	font-variant-numeric: tabular-nums;
	transition: color var(--mh-dur-fast) var(--mh-ease);
}
.magister-header__phone:hover,
.magister-header__phone:focus-visible { color: var(--mh-gold); }

.magister-header__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 12px 26px;
	background: var(--mh-gold);
	color: #0F1115;                 /* graphite label on gold (~8.5:1) */
	font-family: var(--mh-sans);
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.02em;
	text-decoration: none;
	border: 1px solid var(--mh-gold);
	border-radius: 0;
	transition: background-color var(--mh-dur-fast) var(--mh-ease),
				border-color var(--mh-dur-fast) var(--mh-ease),
				color var(--mh-dur-fast) var(--mh-ease);
}
.magister-header__cta:hover,
.magister-header__cta:focus-visible {
	background: var(--md-accent-hi, #E3C24E);
	border-color: var(--md-accent-hi, #E3C24E);
}
.magister-header__cta:focus-visible { outline: 2px solid var(--mh-gold); outline-offset: 2px; }

/* ---------- Mobile toggle ---------- */
.magister-nav-toggle {
	display: none;
	width: 44px;
	height: 44px;
	padding: 0;
	background: transparent;
	border: 1px solid var(--mh-rule-strong);
	border-radius: 0;
	cursor: pointer;
	position: relative;
}
.magister-nav-toggle__bar,
.magister-nav-toggle__bar::before,
.magister-nav-toggle__bar::after {
	content: "";
	position: absolute;
	left: 11px;
	right: 11px;
	height: 1.5px;
	background: var(--mh-navy);
	transition: transform var(--mh-dur-fast) var(--mh-ease),
				opacity var(--mh-dur-fast) var(--mh-ease);
}
.magister-nav-toggle__bar { top: 50%; transform: translateY(-50%); }
.magister-nav-toggle__bar::before { top: -7px; left: 0; right: 0; }
.magister-nav-toggle__bar::after { top: 7px; left: 0; right: 0; }
.magister-nav-toggle[aria-expanded="true"] .magister-nav-toggle__bar { background: transparent; }
.magister-nav-toggle[aria-expanded="true"] .magister-nav-toggle__bar::before { top: 0; transform: rotate(45deg); }
.magister-nav-toggle[aria-expanded="true"] .magister-nav-toggle__bar::after  { top: 0; transform: rotate(-45deg); }

/* ---------- Mobile drawer ---------- */
.magister-mobile-menu {
	position: fixed;
	inset: 0;
	z-index: 95;
	background: var(--mh-ivory);
	overflow-y: auto;
	overscroll-behavior: contain;
	padding-top: 81px;     /* approx header height; matched in JS via scroll measurement if needed */
	display: none;
}
.magister-mobile-menu[data-open="true"] { display: block; }
.magister-mobile-menu__inner {
	max-width: 720px;
	margin: 0 auto;
	padding: 24px 32px 64px;
}
.magister-mobile-menu nav { display: flex; flex-direction: column; gap: 4px; }

.magister-mobile-menu__group {
	border-bottom: 1px solid var(--mh-rule);
	padding: 4px 0;
}
.magister-mobile-menu__group > summary {
	list-style: none;
	cursor: pointer;
	padding: 18px 4px;
	font-family: var(--mh-serif);
	font-weight: 500;
	font-size: 22px;
	color: var(--mh-navy);
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.magister-mobile-menu__group > summary::-webkit-details-marker { display: none; }
.magister-mobile-menu__group > summary::after {
	content: "+";
	font-family: var(--mh-sans);
	font-weight: 300;
	font-size: 24px;
	color: var(--mh-footnote);
	transition: transform var(--mh-dur-fast) var(--mh-ease);
}
.magister-mobile-menu__group[open] > summary::after {
	content: "−";
	color: var(--mh-oxblood);
}
.magister-mobile-menu__group a {
	display: block;
	padding: 12px 4px;
	font-family: var(--mh-sans);
	font-size: 16px;
	color: var(--mh-ink);
	text-decoration: none;
	border-top: 1px solid var(--mh-rule);
}
.magister-mobile-menu__group a:hover,
.magister-mobile-menu__group a:focus-visible { color: var(--mh-oxblood); }

.magister-mobile-menu__link {
	display: block;
	padding: 20px 4px;
	border-bottom: 1px solid var(--mh-rule);
	font-family: var(--mh-serif);
	font-weight: 500;
	font-size: 22px;
	color: var(--mh-navy);
	text-decoration: none;
}
.magister-mobile-menu__phone {
	display: block;
	margin-top: 32px;
	padding: 16px 0;
	font-family: var(--mh-sans);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--mh-navy);
	text-decoration: none;
	font-variant-numeric: tabular-nums;
}
.magister-mobile-menu__cta {
	display: block;
	margin-top: 16px;
	padding: 18px 24px;
	background: var(--mh-action);    /* gold action fill */
	color: #0F1115;                  /* graphite label (~8.5:1) */
	font-family: var(--mh-sans);
	font-size: 15px;
	font-weight: 700;
	letter-spacing: 0.02em;
	text-align: center;
	text-decoration: none;
	border-radius: 0;
}
.magister-mobile-menu__cta:hover { background: var(--mh-action-hi); }

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
	.magister-header__inner { padding: 14px 24px; gap: 16px; }
	.magister-nav,
	.magister-header__phone,
	.magister-header__cta { display: none; }
	.magister-nav-toggle { display: inline-flex; align-items: center; justify-content: center; }
	.magister-logo__svg { height: 38px; }
	.magister-logo__img { height: 44px; } /* keep >=44px on mobile (Quality Bar axis 8) */
}
@media (max-width: 520px) {
	.magister-header__inner { padding: 12px 20px; }
	.magister-mobile-menu__inner { padding: 16px 20px 48px; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
	.magister-header,
	.magister-mega,
	.magister-mega__link,
	.magister-mega__feature-link,
	.magister-nav__link,
	.magister-nav__caret,
	.magister-header__cta,
	.magister-header__phone,
	.magister-logo,
	.skip-link,
	.magister-nav-toggle__bar,
	.magister-nav-toggle__bar::before,
	.magister-nav-toggle__bar::after,
	.magister-mobile-menu__group > summary::after {
		transition: none !important;
	}
	.magister-logo:hover { transform: none; }
	.magister-mega__link:hover,
	.magister-mega__link:focus-visible { transform: none; }
}

/* ---------- Print ---------- */
@media print {
	.magister-header,
	.magister-mobile-menu,
	.skip-link { display: none !important; }
}

/* ---------- Touch-device hover guard (ported from _nav.css 2026-05-18) ---------- */
/* On devices without true hover (touch screens), the :hover open path is wrong.
   Tap-then-tap-elsewhere leaves dropdowns stuck open. Suppress :hover-open here;
   :focus-within remains so keyboard navigation still works. JS toggle via
   aria-expanded on click handles the tap interaction. */
@media (hover: none) {
	.magister-nav__item--mega:hover > .magister-mega {
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
	}
	.magister-nav__item--mega:focus-within > .magister-mega,
	.magister-nav__item--mega[aria-expanded="true"] > .magister-mega {
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
	}
}

/* =============================================================
   Magister Digital: GLOBAL FOOTER + mobile call-bar + scroll-progress
   ------------------------------------------------------------
   Added 2026-05-30 (homepage redesign Slice 1 follow-up). The footer
   markup in parts/footer.html shipped with ZERO matching CSS, so the
   gold CTA strip rendered deep-teal text on the deep-teal body bg
   (ratio 1.0, invisible) on all 16 pages. This block styles the whole
   footer on-brand: gold-warm action strip with deep-teal text (Von
   Restorff isolation), deep-teal main footer with bone text, plus the
   mobile Call|Book bar and the scroll-progress fill that the homepage
   motion script drives.
   ============================================================= */

.magister-footer { background: #0F1115; color: rgba(247, 247, 245, 0.82); }

/* Final-CTA action strip across the top of the footer: charcoal band so the
   coral booking button is the one warm element that pops. Text = bone / muted
   bone / blue-on-dark eyebrow (all pass AA on charcoal). */
.magister-footer-cta-strip { background: #0F1115; color: #F7F7F5; }
.magister-footer-cta-inner {
	width: 100%; max-width: 1280px; margin-inline: auto;
	padding: 36px 24px; display: flex; flex-wrap: wrap; align-items: center;
	justify-content: space-between; gap: 24px;
}
.magister-footer-cta-copy { display: flex; flex-direction: column; gap: 6px; max-width: 640px; }
.magister-footer-cta-eyebrow {
	font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 700;
	letter-spacing: 0.16em; text-transform: uppercase; color: #D4AF37;
}
.magister-footer-cta-headline {
	font-family: 'Playfair Display', Georgia, serif; font-size: clamp(24px, 3vw, 32px);
	font-weight: 700; line-height: 1.15; color: #F7F7F5;
}
.magister-footer-cta-sub { font-size: 16px; line-height: 1.5; color: rgba(247, 247, 245, 0.82); }
.magister-footer-cta-action { display: flex; flex-direction: column; align-items: flex-start; gap: 10px; }
/* Primary booking CTA = gold fill + graphite #0F1115 bold label (~8.5:1). */
.magister-footer-cta-btn {
	display: inline-flex; align-items: center; justify-content: center;
	min-height: 48px; padding: 0 28px; background: #D4AF37; color: #0F1115 !important;
	font-family: Inter, sans-serif; font-size: 19px; font-weight: 700;
	border-radius: 8px; transition: background 200ms ease;
}
.magister-footer-cta-btn:hover { background: #E3C24E; }
.magister-footer-cta-phone { font-family: 'JetBrains Mono', monospace; font-size: 14px; font-weight: 600; color: #D4AF37 !important; }
.magister-footer-cta-phone:hover { color: #F7F7F5 !important; }

/* Main footer grid (deep teal, bone text). */
.magister-footer-main { width: 100%; max-width: 1280px; margin-inline: auto; padding: 64px 24px 40px; }
.magister-footer-grid { display: grid; grid-template-columns: 1fr; gap: 40px; }
@media (min-width: 720px) { .magister-footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr 1.3fr; gap: 32px; } }
/* Footer accents sit on charcoal #0F1115 → blue-on-dark #D4AF37 (~6:1).
   Bright cobalt #E3C24E only hits ~3.4:1 on charcoal. */
.magister-footer-col h4 {
	font-family: Inter, sans-serif; font-size: 13px; font-weight: 700; letter-spacing: 0.08em;
	text-transform: uppercase; color: #D4AF37; margin: 0 0 16px;
}
.magister-footer-h4-spaced { margin-top: 28px !important; }
.magister-footer-col ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 10px; }
.magister-footer-col a { color: rgba(247, 247, 245, 0.86); font-size: 15px; line-height: 1.4; transition: color 160ms ease; }
.magister-footer-col a:hover { color: #D4AF37; }
.magister-footer-logo { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
/* Footer brand logo = same gold+silver-on-dark transparent logo as the header
   (footer band is graphite #0F1115, so the dark-bg logo sits correctly). */
.magister-footer-logo-img { display: block; height: 46px; width: auto; }
.magister-footer-blurb { font-size: 15px; line-height: 1.6; color: rgba(247, 247, 245, 0.78); max-width: 40ch; margin: 0 0 16px; }
.magister-footer-social { display: flex; gap: 18px; }
.magister-footer-social a { font-size: 14px; color: rgba(247, 247, 245, 0.86); }
.magister-footer-contact-block { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.magister-footer-phone { font-family: 'JetBrains Mono', monospace; font-size: 18px; font-weight: 700; color: #D4AF37 !important; }
.magister-footer-email { font-size: 15px; color: rgba(247, 247, 245, 0.86) !important; }
.magister-footer-hours { font-size: 13px; color: rgba(247, 247, 245, 0.7); line-height: 1.6; margin-bottom: 14px; }
.magister-footer-mini-cta { font-size: 15px; font-weight: 600; color: #D4AF37 !important; }

/* Bottom legal strip. */
.magister-footer-bottom { border-top: 1px solid rgba(247, 247, 245, 0.12); }
.magister-footer-bottom-inner {
	width: 100%; max-width: 1280px; margin-inline: auto; padding: 22px 24px;
	display: flex; flex-wrap: wrap; gap: 14px; align-items: center; justify-content: space-between;
}
.magister-footer-copy { font-size: 13px; color: rgba(247, 247, 245, 0.66); }
.magister-footer-legal { display: flex; flex-wrap: wrap; gap: 20px; }
.magister-footer-legal a { font-size: 13px; color: rgba(247, 247, 245, 0.78); }
.magister-footer-legal a:hover { color: #E3C24E; }

/* ---------- Scroll-progress fill (footer-shipped bar) ---------- */
.md-scroll-progress {
	position: fixed; top: 0; left: 0; height: 3px; z-index: 130;
	width: 100%; transform: scaleX(var(--md-journey-scroll, 0)); transform-origin: 0 50%;
	background: linear-gradient(90deg, #D4AF37, #E3C24E); pointer-events: none;
}
@media (prefers-reduced-motion: reduce) { .md-scroll-progress { display: none; } }

/* ---------- Mobile sticky Call | Book bar ---------- */
.magister-mobile-cta {
	position: fixed; left: 0; right: 0; bottom: 0; z-index: 140;
	display: none; grid-template-columns: 1fr 1fr; gap: 1px;
	background: rgba(15, 17, 21, 0.96); box-shadow: 0 -6px 24px rgba(15, 17, 21, 0.32);
	transform: translateY(110%); transition: transform 260ms cubic-bezier(0.16, 1, 0.3, 1);
}
.magister-mobile-cta__call,
.magister-mobile-cta__book {
	display: flex; align-items: center; justify-content: center; gap: 8px;
	min-height: 56px; font-family: Inter, sans-serif; font-size: 19px; font-weight: 700;
}
.magister-mobile-cta__call { background: #0F1115; color: #F7F7F5 !important; }
/* Sticky mobile primary CTA = gold fill + graphite #0F1115 bold label (~8.5:1). */
.magister-mobile-cta__book { background: #D4AF37; color: #0F1115 !important; }
@media (max-width: 767px) {
	.magister-mobile-cta { display: grid; }
	body.is-cta-visible .magister-mobile-cta { transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
	.magister-mobile-cta { transition: none; }
}
