/* ============================================================
   Evantaa Institute — brand stylesheet
   Design flourishes + marketing components that core WordPress
   blocks can't express. Also self-sufficient for the static
   preview (defines the raw design tokens on :root).
   ============================================================ */

:root {
  --navy: #0E2340;  --navy-900:#081427; --navy-700:#1B3554; --navy-600:#2C4A6E;
  --navy-100:#D6DEE8; --navy-050:#EDF1F6;
  --emerald:#007B5E; --emerald-900:#00553F; --emerald-800:#006A50; --emerald-100:#CBE7DE; --emerald-050:#E8F4EF;
  --gold:#D6A64A; --gold-600:#C79740; --gold-700:#B6852F; --gold-050:#FBF4E5;
  --ivory:#F7F4EE; --white:#FFFFFF;
  --ink:#1B2430; --grey-700:#444444; --grey-400:#888888; --grey-200:#D9D6CF; --grey-100:#EDEAE3;

  --font-brand:'Plus Jakarta Sans','Nunito Sans',system-ui,sans-serif;
  --font-ui:'Inter','Roboto',system-ui,-apple-system,sans-serif;

  --container-max:1200px;
  --radius-md:12px; --radius-lg:16px; --radius-xl:24px; --radius-pill:999px;
  --shadow-sm:0 2px 8px rgba(14,35,64,0.07);
  --shadow-md:0 8px 24px rgba(14,35,64,0.09);
  --shadow-lg:0 18px 48px rgba(14,35,64,0.12);
  --ease-standard:cubic-bezier(0.4,0,0.2,1);
}

/* ---- Base (static-preview only; WP supplies its own) ---- */
.ev-doc { margin:0; font-family:var(--font-ui); color:var(--grey-700); background:var(--white);
  font-size:16px; line-height:1.7; -webkit-font-smoothing:antialiased; }
.ev-doc h1,.ev-doc h2,.ev-doc h3,.ev-doc h4 { font-family:var(--font-brand); color:var(--navy);
  letter-spacing:-0.02em; line-height:1.2; margin:0; }

/* ---- Layout helpers ---- */
.ev-container { max-width:var(--container-max); margin:0 auto; padding-left:24px; padding-right:24px; }
.ev-section { padding-top:96px; padding-bottom:96px; }
.ev-section--tight { padding-top:88px; padding-bottom:88px; }

/* ---- Eyebrow / overline ---- */
.ev-eyebrow { display:inline-flex; align-items:center; gap:8px; font-family:var(--font-ui);
  font-size:12px; font-weight:600; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--emerald); }
.ev-eyebrow--gold { color:var(--gold); }

/* ---- Gold signature rule ---- */
.ev-rule-gold { width:56px; height:3px; border:0; border-radius:999px; background:var(--gold);
  margin:0 0 20px; }
.ev-rule-gold--center { margin-left:auto; margin-right:auto; }

/* ---- Section heading ---- */
.ev-section-heading { max-width:680px; }
.ev-section-heading--center { margin:0 auto; text-align:center; }
.ev-section-heading h2 { font-size:clamp(28px,3vw,32px); margin:10px 0 0; }
.ev-section-heading .ev-lead { font-size:19px; color:var(--grey-700); margin:14px 0 0; line-height:1.6; }

/* ============================================================
   HEADER
   ============================================================ */
.ev-header { position:sticky; top:0; z-index:50; background:#fff;
  border-bottom:1px solid var(--grey-200); box-shadow:var(--shadow-sm); }
.ev-header__inner { max-width:var(--container-max); margin:0 auto; padding:0 24px; height:76px;
  display:flex; align-items:center; gap:32px; }
.ev-header__logo img, .ev-header .ev-logo img { height:44px !important; width:auto !important; display:block; }
.ev-header .ev-logo, .ev-header .ev-logo.is-resized, .ev-header__logo { width:auto !important; margin:0; flex:0 0 auto !important; }
.ev-header .ev-logo img, .ev-header__logo img { max-width:none !important; }

/* Remove WordPress's default flow gap between header / main / footer
   (each section manages its own padding) — kills the white strip
   between the header and the hero. */
.wp-site-blocks > main, .wp-site-blocks > footer,
.wp-site-blocks > * + *,
.wp-site-blocks > main > * { margin-block-start:0 !important; }
.ev-hero { margin-top:0; }
.ev-nav { display:flex; gap:28px; margin-left:12px; flex:1; align-items:center; }
.ev-nav__item { position:relative; display:flex; align-items:center; }
.ev-nav__link, .ev-nav__item > a { font-family:var(--font-ui); font-size:15px; font-weight:600;
  color:var(--navy); text-decoration:none; display:inline-flex; align-items:center; gap:5px;
  transition:color .2s var(--ease-standard); cursor:pointer; }
.ev-nav__link:hover, .ev-nav__link[aria-current="page"],
.ev-nav__item > a:hover, .ev-nav__item:hover > a { color:var(--emerald); }
.ev-nav__item > a svg { color:var(--grey-400); transition:transform .2s var(--ease-standard), color .2s; }
.ev-nav__item:hover > a svg { transform:rotate(180deg); color:var(--emerald); }
.ev-dropdown { position:absolute; top:100%; left:-12px; min-width:230px; margin-top:14px; padding:8px;
  background:#fff; border:1px solid var(--grey-200); border-radius:var(--radius-md); box-shadow:var(--shadow-lg);
  opacity:0; visibility:hidden; transform:translateY(8px); z-index:60;
  transition:opacity .2s var(--ease-standard), transform .2s var(--ease-standard), visibility .2s; }
.ev-dropdown::before { content:""; position:absolute; top:-16px; left:0; right:0; height:16px; }
.ev-nav__item:hover .ev-dropdown { opacity:1; visibility:visible; transform:translateY(0); }
.ev-dropdown a { display:block; padding:10px 14px; border-radius:var(--radius-sm); white-space:nowrap;
  font-family:var(--font-ui); font-size:14.5px; font-weight:500; color:var(--navy); text-decoration:none;
  transition:background .15s var(--ease-standard), color .15s var(--ease-standard); }
.ev-dropdown a:hover { background:var(--ivory); color:var(--emerald); }

/* Hamburger toggle (hidden on desktop) */
.ev-nav__toggle { display:none; background:none; border:0; cursor:pointer; width:42px; height:42px;
  padding:9px 8px; flex-direction:column; justify-content:center; gap:5px; flex:0 0 auto; }
.ev-nav__toggle span { display:block; width:100%; height:2px; background:var(--navy); border-radius:2px;
  transition:transform .25s var(--ease-standard), opacity .2s var(--ease-standard); }
.ev-header.is-menu-open .ev-nav__toggle span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.ev-header.is-menu-open .ev-nav__toggle span:nth-child(2) { opacity:0; }
.ev-header.is-menu-open .ev-nav__toggle span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
.ev-header__actions { display:flex; align-items:center; gap:14px; }

/* ============================================================
   BUTTONS (mirror the DS Button)
   ============================================================ */
.ev-btn { display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--font-ui); font-weight:600; border:1.5px solid transparent; cursor:pointer;
  border-radius:8px; text-decoration:none; transition:all .2s var(--ease-standard);
  font-size:15px; padding:12px 22px; line-height:1; white-space:nowrap; }
.ev-btn--lg { font-size:16px; padding:15px 28px; }
.ev-btn--sm { font-size:14px; padding:9px 16px; }
.ev-btn--primary { background:var(--gold); color:var(--navy); }
.ev-btn--primary:hover { background:var(--gold-600); transform:translateY(-1px); }
.ev-btn--secondary { background:var(--navy); color:#fff; }
.ev-btn--secondary:hover { background:var(--navy-700); }
.ev-btn--tertiary { background:var(--emerald); color:#fff; }
.ev-btn--tertiary:hover { background:var(--emerald-800); }
.ev-btn--ghost { background:transparent; color:var(--emerald); }
.ev-btn--ghost:hover { background:var(--emerald-050); }
.ev-btn--outline { background:transparent; color:#fff; border-color:rgba(255,255,255,0.4); }
.ev-btn--outline:hover { background:rgba(255,255,255,0.08); }

/* ============================================================
   HERO
   ============================================================ */
.ev-hero { position:relative; background:var(--navy); color:#fff; overflow:hidden; }
.ev-hero__wedges { position:absolute; inset:0 0 0 auto; width:42%; overflow:hidden; pointer-events:none; }
.ev-hero__wedge1 { position:absolute; right:-120px; top:50%; transform:translateY(-50%);
  width:0; height:0; border-style:solid; border-width:240px 0 240px 360px;
  border-color:transparent transparent transparent rgba(0,123,94,0.22); }
.ev-hero__wedge2 { position:absolute; right:60px; bottom:-80px; width:0; height:0; border-style:solid;
  border-width:0 0 200px 200px; border-color:transparent transparent rgba(214,166,74,0.20) transparent; }
.ev-hero__inner { position:relative; max-width:var(--container-max); margin:0 auto; padding:96px 24px;
  display:grid; grid-template-columns:1.1fr 0.9fr; gap:48px; align-items:center; }
.ev-hero h1 { font-family:var(--font-brand); font-weight:700; font-size:clamp(40px,5vw,60px);
  line-height:1.05; letter-spacing:-0.02em; color:#fff; margin:0 0 20px; }
.ev-hero__lead { font-family:var(--font-ui); font-size:19px; line-height:1.6;
  color:rgba(255,255,255,0.82); max-width:480px; margin:0 0 32px; }
.ev-hero__ctas { display:flex; gap:14px; flex-wrap:wrap; }
.ev-hero__cards { display:flex; flex-direction:column; gap:16px; }

/* Glass card over navy hero */
.ev-glass { background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.12);
  backdrop-filter:blur(4px); border-radius:var(--radius-lg); padding:24px; }
.ev-stat-grid { display:grid; grid-template-columns:1fr 1fr; gap:28px; }
.ev-stat__value { font-family:var(--font-brand); font-weight:700; font-size:34px; color:#fff; line-height:1; }
.ev-stat__label { font-family:var(--font-ui); font-size:14px; color:rgba(255,255,255,0.82); margin-top:6px; }
.ev-stat__sub { font-family:var(--font-ui); font-size:12.5px; color:rgba(255,255,255,0.6); }
/* claim-free hero feature list (replaces invented stats) */
.ev-glass-list { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:14px; }
.ev-glass-list li { display:flex; align-items:center; gap:12px; font-family:var(--font-ui);
  font-size:15.5px; font-weight:500; color:#fff; }
.ev-glass-list li svg { color:var(--gold); flex:0 0 auto; }
.ev-card-emerald { background:var(--emerald); border-radius:var(--radius-lg); padding:24px;
  display:flex; align-items:center; gap:14px; }
.ev-card-emerald strong { font-family:var(--font-brand); font-weight:700; font-size:17px; color:#fff; display:block; }
.ev-card-emerald span { font-family:var(--font-ui); font-size:14px; color:rgba(255,255,255,0.85); }

/* ============================================================
   STUDY AREAS
   ============================================================ */
.ev-areas { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:44px; }
.ev-area { display:flex; align-items:center; gap:16px; padding:22px; background:#fff;
  border:1px solid var(--grey-200); border-radius:var(--radius-lg); text-decoration:none;
  transition:all .2s var(--ease-standard); }
.ev-area:hover { box-shadow:var(--shadow-md); transform:translateY(-3px); border-color:var(--emerald-100); }
.ev-area__icon { display:inline-flex; align-items:center; justify-content:center; width:52px; height:52px;
  border-radius:var(--radius-md); background:var(--emerald-050); flex:0 0 auto; color:var(--emerald); }
.ev-area__name { font-family:var(--font-brand); font-weight:700; font-size:17px; color:var(--navy); }
.ev-area__count { font-family:var(--font-ui); font-size:13.5px; color:var(--grey-400); }
.ev-area__arrow { margin-left:auto; color:var(--gold); }

/* ============================================================
   COURSE CARDS
   ============================================================ */
.ev-course-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.ev-course { display:flex; flex-direction:column; background:#fff; border:1px solid var(--grey-200);
  border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm);
  transition:all .2s var(--ease-standard); }
.ev-course:hover { box-shadow:var(--shadow-lg); transform:translateY(-3px); }
/* media zone — holds a real photo when supplied, on-brand graphic until then */
.ev-course__media { position:relative; height:168px; overflow:hidden;
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-700) 100%);
  display:flex; align-items:center; justify-content:center; }
.ev-course__media--emerald { background:linear-gradient(135deg, var(--emerald) 0%, var(--emerald-900) 100%); }
.ev-course__media::after { content:""; position:absolute; right:-26px; bottom:-32px; width:0; height:0;
  border-style:solid; border-width:0 0 84px 84px; border-color:transparent transparent rgba(214,166,74,0.28) transparent; }
.ev-course__media svg { color:rgba(255,255,255,0.16); }
.ev-course__media img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.ev-course__badge { position:absolute; top:14px; left:14px; z-index:2; background:var(--gold); color:var(--navy);
  font-family:var(--font-ui); font-size:11.5px; font-weight:700; letter-spacing:0.06em; text-transform:uppercase;
  padding:5px 11px; border-radius:var(--radius-pill); }
.ev-course__media { text-decoration:none; }
.ev-course__title { font-family:var(--font-brand); font-weight:700; font-size:19px; color:var(--navy);
  margin:0; line-height:1.3; }
.ev-course__title a { color:inherit; text-decoration:none; transition:color .2s var(--ease-standard); }
.ev-course__title a:hover { color:var(--emerald); }

/* Catalogue page */
.ev-page-hero { position:relative; background:var(--navy); color:#fff; overflow:hidden;
  padding:76px 0 66px; }
.ev-page-hero::after { content:""; position:absolute; right:-40px; top:50%; transform:translateY(-50%);
  width:0; height:0; border-style:solid; border-width:170px 0 170px 240px;
  border-color:transparent transparent transparent rgba(0,123,94,0.18); }
.ev-page-hero .ev-container { position:relative; z-index:1; }
.ev-page-hero h1 { color:#fff; font-family:var(--font-brand); font-weight:700;
  font-size:clamp(34px,4.5vw,48px); letter-spacing:-0.02em; line-height:1.1; margin:14px 0 0; }
.ev-page-hero__lead { font-family:var(--font-ui); font-size:19px; color:rgba(255,255,255,0.82);
  max-width:640px; margin:16px 0 0; line-height:1.6; }
.ev-cat-group + .ev-cat-group { margin-top:64px; }

/* Course detail */
.ev-facts { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--grey-200);
  border:1px solid var(--grey-200); border-radius:var(--radius-lg); overflow:hidden; margin:0 0 8px; }
.ev-fact { background:#fff; padding:18px 20px; }
.ev-fact__l { display:block; font-family:var(--font-ui); font-size:11.5px; font-weight:600;
  letter-spacing:0.08em; text-transform:uppercase; color:var(--grey-400); margin-bottom:5px; }
.ev-fact__v { font-family:var(--font-brand); font-weight:700; font-size:16.5px; color:var(--navy); line-height:1.25; }
.ev-pills { display:flex; flex-wrap:wrap; gap:10px; }
.ev-pill { font-family:var(--font-ui); font-size:14px; font-weight:500; color:var(--navy);
  background:var(--emerald-050); border:1px solid var(--emerald-100); border-radius:var(--radius-pill);
  padding:8px 16px; }
.ev-units { display:grid; grid-template-columns:1fr 1fr; gap:16px 36px; }
/* Units as chips */
.ev-unit-group { margin:0 0 26px; }
.ev-unit-group h3 { font-family:var(--font-brand); color:var(--emerald); font-size:18px; margin:0 0 12px; }
.ev-unit-chips { display:flex; flex-wrap:wrap; gap:8px; }
.ev-unit-chip { font-family:var(--font-ui); font-size:13px; font-weight:600; color:var(--navy-700);
  background:var(--navy-050); border:1px solid var(--navy-100); border-radius:8px; padding:7px 12px; line-height:1; }
/* named units list (code + title) */
.ev-units-list { display:grid; grid-template-columns:1fr 1fr; gap:0 32px; }
.ev-unit-row { display:flex; gap:12px; align-items:baseline; padding:11px 0; border-bottom:1px solid var(--grey-100); }
.ev-unit-row__code { flex:0 0 auto; font-family:var(--font-ui); font-size:11px; font-weight:700; letter-spacing:0.02em;
  color:var(--emerald); background:var(--emerald-050); border:1px solid var(--emerald-100); border-radius:5px;
  padding:3px 7px; white-space:nowrap; }
.ev-unit-row__name { font-family:var(--font-ui); font-size:14px; color:var(--grey-700); line-height:1.45; }
@media (max-width:720px){ .ev-units-list{grid-template-columns:1fr} }
/* "What you'll learn" */
.ev-learn { display:grid; grid-template-columns:1fr 1fr; gap:12px 28px; margin:0; padding:0; list-style:none; }
.ev-learn li { display:flex; gap:10px; align-items:flex-start; font-family:var(--font-ui); font-size:15.5px;
  color:var(--grey-700); line-height:1.5; }
.ev-learn li::before { content:""; flex:0 0 auto; width:8px; height:8px; margin-top:8px; border-radius:2px;
  background:var(--gold); transform:rotate(45deg); }
@media (max-width:640px){ .ev-learn{grid-template-columns:1fr} }
.ev-fees-box { background:var(--ivory); border:1px solid var(--grey-200); border-radius:var(--radius-lg);
  padding:24px 28px; display:flex; flex-wrap:wrap; gap:32px; align-items:center; }
.ev-fee__l { display:block; font-family:var(--font-ui); font-size:11.5px; font-weight:600; letter-spacing:0.06em;
  text-transform:uppercase; color:var(--grey-400); margin-bottom:4px; }
.ev-fee__v { font-family:var(--font-brand); font-weight:700; font-size:21px; color:var(--navy); }
.ev-fee__v small { font-family:var(--font-ui); font-size:12px; font-weight:500; color:var(--grey-400); }
@media (max-width:720px){ .ev-facts{grid-template-columns:1fr 1fr} .ev-units{grid-template-columns:1fr} }

/* Mission / vision split */
.ev-mv { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.ev-mv__card { padding:34px; border-radius:var(--radius-lg); }
.ev-mv__card--navy { background:var(--navy); }
.ev-mv__card--emerald { background:var(--emerald); }
.ev-mv__card h3 { color:#fff; font-family:var(--font-ui); font-size:12px; font-weight:700; letter-spacing:0.12em;
  text-transform:uppercase; margin:0 0 12px; opacity:.8; }
.ev-mv__card p { font-family:var(--font-brand); font-weight:600; font-size:20px; line-height:1.45; margin:0; color:#fff; }

/* Value cards */
.ev-values { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.ev-value { display:flex; gap:16px; padding:24px; background:#fff; border:1px solid var(--grey-200); border-radius:var(--radius-lg); }
.ev-value__icon { flex:0 0 auto; width:48px; height:48px; border-radius:var(--radius-md); background:var(--emerald-050);
  display:flex; align-items:center; justify-content:center; color:var(--emerald); }
.ev-value h3 { font-family:var(--font-brand); font-size:18px; color:var(--navy); margin:0 0 6px; }
.ev-value p { font-family:var(--font-ui); font-size:14.5px; color:var(--grey-700); margin:0; line-height:1.6; }

/* Steps */
.ev-steps { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.ev-step__n { display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; border-radius:999px;
  background:var(--gold); color:var(--navy); font-family:var(--font-brand); font-weight:700; font-size:18px; margin-bottom:14px; }
.ev-step h3 { font-family:var(--font-brand); font-size:18px; color:var(--navy); margin:0 0 6px; }
.ev-step p { font-family:var(--font-ui); font-size:14.5px; color:var(--grey-700); margin:0; line-height:1.6; }

/* Contact campus cards */
.ev-campuses-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.ev-campus { background:#fff; border:1px solid var(--grey-200); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); }
.ev-campus__map { height:200px; background:var(--navy-050); }
.ev-campus__map iframe { width:100%; height:100%; border:0; display:block; }
.ev-campus__body { padding:26px 28px; }
.ev-campus h3 { font-family:var(--font-brand); font-size:22px; color:var(--navy); margin:0 0 16px; }
.ev-campus__row { display:flex; gap:12px; align-items:flex-start; margin:0 0 12px; font-family:var(--font-ui);
  font-size:15px; color:var(--grey-700); line-height:1.5; }
.ev-campus__row svg { color:var(--emerald); flex:0 0 auto; margin-top:2px; }
.ev-campus__row a { color:var(--grey-700); text-decoration:none; }
.ev-campus__row a:hover { color:var(--emerald); }

@media (max-width:760px){ .ev-values,.ev-mv,.ev-steps,.ev-campuses-grid{grid-template-columns:1fr} }

/* Enquiry form (also styles Contact Form 7 output) */
.ev-form { background:#fff; border:1px solid var(--grey-200); border-radius:var(--radius-lg);
  padding:32px; box-shadow:var(--shadow-sm); }
.ev-form__row { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.ev-field { display:block; margin-bottom:18px; }
.ev-field > span { display:block; font-family:var(--font-ui); font-size:13.5px; font-weight:600;
  color:var(--navy); margin-bottom:7px; }
.ev-form input[type=text], .ev-form input[type=email], .ev-form input[type=tel],
.ev-form select, .ev-form textarea,
.wpcf7-form input[type=text], .wpcf7-form input[type=email], .wpcf7-form input[type=tel],
.wpcf7-form select, .wpcf7-form textarea {
  width:100%; font-family:var(--font-ui); font-size:15px; color:var(--ink); padding:12px 14px;
  border:1.5px solid var(--grey-200); border-radius:var(--radius-sm); background:#fff; box-sizing:border-box;
  transition:border-color .2s var(--ease-standard), box-shadow .2s var(--ease-standard); }
.ev-form input:focus, .ev-form select:focus, .ev-form textarea:focus,
.wpcf7-form input:focus, .wpcf7-form select:focus, .wpcf7-form textarea:focus {
  outline:none; border-color:var(--emerald); box-shadow:var(--shadow-focus); }
.ev-form textarea { resize:vertical; min-height:120px; }
.ev-form__note { font-family:var(--font-ui); font-size:12.5px; color:var(--grey-400); margin:16px 0 0; line-height:1.5; }
.ev-form button[type=submit], .wpcf7-form .wpcf7-submit { margin-top:4px; }
@media (max-width:600px){ .ev-form__row{grid-template-columns:1fr} .ev-form{padding:24px} }

/* Student Central — forms hub */
.ev-forms-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.ev-form-card { display:flex; gap:14px; align-items:flex-start; padding:22px; background:#fff;
  border:1px solid var(--grey-200); border-radius:var(--radius-lg); text-decoration:none;
  transition:all .2s var(--ease-standard); }
.ev-form-card:hover { box-shadow:var(--shadow-md); transform:translateY(-3px); border-color:var(--emerald-100); }
.ev-form-card__icon { flex:0 0 auto; width:44px; height:44px; border-radius:var(--radius-md);
  background:var(--emerald-050); display:flex; align-items:center; justify-content:center; color:var(--emerald); }
.ev-form-card h3 { font-family:var(--font-brand); font-size:16px; color:var(--navy); margin:0 0 4px; line-height:1.3; }
.ev-form-card p { font-family:var(--font-ui); font-size:13px; color:var(--grey-400); margin:0; line-height:1.5; }
/* horizontal 2-column steps (enrolment journey) */
.ev-steps--2 { grid-template-columns:repeat(2,1fr); gap:22px 40px; }
.ev-steps--2 .ev-step { display:flex; gap:16px; align-items:flex-start; padding:0; }
.ev-steps--2 .ev-step__n { margin-bottom:0; width:38px; height:38px; font-size:16px; }
@media (max-width:860px){ .ev-forms-grid{grid-template-columns:1fr 1fr} }
@media (max-width:560px){ .ev-forms-grid,.ev-steps--2{grid-template-columns:1fr} }

/* Campus detail page */
.ev-campus-detail { display:grid; grid-template-columns:1fr 1fr; gap:36px; align-items:start; }
.ev-campus-detail__map { height:340px; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--grey-200); background:var(--navy-050); }
.ev-campus-detail__map iframe { width:100%; height:100%; border:0; display:block; }
.ev-campus-detail .ev-campus__row { font-size:15.5px; margin-bottom:16px; }
.ev-campus-courses { display:grid; grid-template-columns:1fr 1fr; gap:10px 28px; margin:0; padding:0; list-style:none; }
.ev-campus-courses a { display:flex; align-items:center; gap:10px; font-family:var(--font-ui); font-size:15px;
  font-weight:500; color:var(--navy); text-decoration:none; padding:12px 0; border-bottom:1px solid var(--grey-200);
  transition:color .2s var(--ease-standard); }
.ev-campus-courses a:hover { color:var(--emerald); }
.ev-campus-courses a svg { color:var(--gold); flex:0 0 auto; margin-left:auto; }
@media (max-width:760px){ .ev-campus-detail,.ev-campus-courses{grid-template-columns:1fr} }

/* Education agents directory */
.ev-agents-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.ev-agent-card { background:#fff; border:1px solid var(--grey-200); border-radius:var(--radius-lg);
  padding:24px; transition:all .2s var(--ease-standard); }
.ev-agent-card:hover { box-shadow:var(--shadow-md); transform:translateY(-3px); }
.ev-agent-card__top { display:flex; gap:12px; align-items:center; margin-bottom:14px; }
.ev-agent-card__icon { flex:0 0 auto; width:42px; height:42px; border-radius:var(--radius-md);
  background:var(--navy-050); display:flex; align-items:center; justify-content:center; color:var(--navy); }
.ev-agent-card h3 { font-family:var(--font-brand); font-size:16px; color:var(--navy); margin:0; line-height:1.3; }
.ev-agent-card__row { display:flex; gap:10px; align-items:flex-start; font-family:var(--font-ui);
  font-size:13.5px; color:var(--grey-700); margin-top:9px; line-height:1.5; }
.ev-agent-card__row svg { color:var(--emerald); flex:0 0 auto; margin-top:2px; }
@media (max-width:860px){ .ev-agents-grid{grid-template-columns:1fr 1fr} }
@media (max-width:560px){ .ev-agents-grid{grid-template-columns:1fr} }

/* Guide / reference page prose */
.ev-guide-content { font-size:16.5px; color:var(--grey-700); }
.ev-guide-content h2 { font-family:var(--font-brand); font-size:25px; color:var(--navy);
  margin:46px 0 14px; line-height:1.25; scroll-margin-top:92px; }
.ev-guide-content > h2:first-child, .ev-guide-content > .ev-toc + h2 { margin-top:0; }
.ev-guide-content h3 { font-family:var(--font-brand); font-size:19px; color:var(--emerald); margin:30px 0 10px; }
.ev-guide-content p { line-height:1.75; margin:0 0 16px; }
.ev-guide-content ul, .ev-guide-content ol { padding-left:22px; margin:0 0 16px; }
.ev-guide-content li { margin:8px 0; line-height:1.7; }
.ev-guide-content a { color:var(--emerald); }
.ev-guide-content .wp-block-table { margin:8px 0 24px; }

/* "On this page" auto table of contents */
.ev-toc { background:var(--ivory); border:1px solid var(--grey-200); border-radius:var(--radius-lg);
  padding:20px 24px; margin:0 0 40px; }
.ev-toc__title { display:block; font-family:var(--font-ui); font-size:12px; font-weight:700;
  letter-spacing:0.08em; text-transform:uppercase; color:var(--grey-400); margin-bottom:12px; }
.ev-toc ul { list-style:none; padding:0; margin:0; columns:2; column-gap:32px; }
.ev-toc li { margin:7px 0; break-inside:avoid; }
.ev-toc a { color:var(--navy); text-decoration:none; font-family:var(--font-ui); font-size:14.5px; line-height:1.4;
  display:inline-flex; gap:8px; }
.ev-toc a::before { content:"›"; color:var(--gold); font-weight:700; }
.ev-toc a:hover { color:var(--emerald); }
@media (max-width:560px){ .ev-toc ul{columns:1} }
.ev-course__code { font-family:var(--font-ui); font-size:13px; color:var(--grey-400); margin-top:6px; }
.ev-course__body { padding:20px 22px; display:flex; flex-direction:column; gap:14px; flex:1; }
.ev-course__meta { display:flex; flex-wrap:wrap; gap:8px; }
.ev-tag { display:inline-flex; align-items:center; gap:6px; font-family:var(--font-ui); font-size:12.5px;
  font-weight:500; color:var(--navy-700); background:var(--navy-050); border-radius:var(--radius-pill);
  padding:5px 12px; }
.ev-course__foot { margin-top:auto; display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding-top:8px; border-top:1px solid var(--grey-100); }
.ev-course__cricos { font-family:var(--font-ui); font-size:12px; color:var(--grey-400); }

/* ============================================================
   QUOTE BAND
   ============================================================ */
.ev-quote { background:var(--emerald); color:#fff; }
.ev-quote__inner { max-width:920px; margin:0 auto; padding:88px 24px; text-align:center; }
.ev-quote blockquote { font-family:var(--font-brand); font-weight:600; font-size:clamp(24px,3vw,32px);
  line-height:1.35; color:#fff; margin:20px 0 28px; text-wrap:balance; }
.ev-quote__name { font-family:var(--font-ui); font-weight:600; font-size:16px; }
.ev-quote__meta { font-family:var(--font-ui); font-size:14px; color:rgba(255,255,255,0.8); }

/* ============================================================
   CTA BAND
   ============================================================ */
.ev-cta { position:relative; overflow:hidden; background:var(--navy); border-radius:var(--radius-xl);
  padding:64px 56px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:28px; }
.ev-cta::after { content:""; position:absolute; right:40px; bottom:-60px; width:0; height:0; border-style:solid;
  border-width:0 0 200px 200px; border-color:transparent transparent rgba(214,166,74,0.18) transparent; }
.ev-cta__text { position:relative; }
.ev-cta h2 { font-family:var(--font-brand); font-weight:700; font-size:36px; color:#fff; margin:0 0 10px; }
.ev-cta p { font-family:var(--font-ui); font-size:18px; color:rgba(255,255,255,0.82); margin:0; }
.ev-cta__actions { position:relative; display:flex; gap:14px; flex-wrap:wrap; }

/* ============================================================
   FOOTER
   ============================================================ */
.ev-footer { background:var(--navy); color:rgba(255,255,255,0.72); }
.ev-footer__inner { max-width:var(--container-max); margin:0 auto; padding:64px 24px 32px;
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; }
.ev-footer__brand img, .ev-footer .ev-logo img { height:40px !important; width:auto !important; margin-bottom:18px; }
.ev-footer .ev-logo, .ev-footer .ev-logo.is-resized { width:auto !important; }
.ev-footer__brand p { font-family:var(--font-ui); font-size:14px; line-height:1.7; max-width:280px; margin:0; }
.ev-footer__social { display:flex; gap:14px; margin-top:20px; color:rgba(255,255,255,0.7); }
.ev-footer h4 { font-family:var(--font-brand); font-size:13px; font-weight:700; letter-spacing:0.1em;
  text-transform:uppercase; color:var(--gold); margin:4px 0 16px; }
.ev-footer__campuses { margin:20px 0 4px; display:flex; flex-direction:column; gap:12px; }
.ev-foot-addr { font-family:var(--font-ui); font-size:13.5px; line-height:1.5;
  color:rgba(255,255,255,0.72); margin:0; }
.ev-foot-addr strong { display:block; color:#fff; font-weight:700; font-size:13px; letter-spacing:0.02em; }
.ev-foot-addr a { text-decoration:none; }
.ev-foot-addr a strong { transition:color .2s var(--ease-standard); }
.ev-foot-addr a:hover strong { color:var(--gold); }
.ev-footer ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:11px; }
.ev-footer ul a { font-family:var(--font-ui); font-size:14px; color:rgba(255,255,255,0.72); text-decoration:none; }
.ev-footer ul a:hover { color:#fff; }
.ev-footer__bar { border-top:1px solid rgba(255,255,255,0.1); }
.ev-footer__bar-inner { max-width:var(--container-max); margin:0 auto; padding:20px 24px;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; font-family:var(--font-ui);
  font-size:13px; color:rgba(255,255,255,0.55); }
.ev-footer__bar-inner a { color:inherit; text-decoration:none; }
.ev-footer__legal { display:flex; gap:20px; }

/* ---- Inline note / callout (migrated content) ---- */
.ev-note-inline { background:var(--gold-050); border-left:3px solid var(--gold);
  padding:14px 18px; border-radius:8px; font-size:15px; color:var(--navy); }

/* ---- Migrated page tables ---- */
.wp-block-table table { border-collapse:collapse; width:100%; }
.wp-block-table th { background:var(--navy); color:#fff; font-family:var(--font-ui); font-weight:600;
  text-align:left; padding:12px 14px; font-size:14px; }
.wp-block-table td { padding:11px 14px; border-bottom:1px solid var(--grey-200); font-size:14.5px; }
.wp-block-table tbody tr:nth-child(even) { background:var(--ivory); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:900px) {
  .ev-hero__inner { grid-template-columns:1fr; gap:32px; padding:64px 24px; }
  .ev-areas, .ev-course-grid { grid-template-columns:1fr; }
  .ev-footer__inner { grid-template-columns:1fr 1fr; gap:32px; }
  .ev-section { padding-top:64px; padding-bottom:64px; }
  .ev-cta { padding:40px 28px; }

  /* ---- Mobile menu ---- */
  .ev-nav__toggle { display:flex; }
  .ev-header__inner { gap:12px; }
  .ev-header__logo img, .ev-header .ev-logo img { height:40px !important; }
  .ev-header__actions { margin-left:auto; }
  /* Compact the header CTA on mobile. The .ev-btn class sits on the wp-block-button
     WRAPPER; padding it AND the inner link double-pads into an oversized box — so the
     wrapper becomes a plain container and only the inner link is the button. */
  .ev-header__actions .ev-btn { padding:0 !important; background:transparent !important; border:0 !important; min-height:0 !important; }
  .ev-header__actions .wp-element-button, .ev-header__actions .wp-block-button__link {
    padding:9px 16px !important; font-size:14px !important; line-height:1.2 !important;
    height:auto !important; min-height:0 !important; white-space:nowrap; }
  .ev-header__inner { gap:10px; }
  .ev-header__actions a[aria-label="Search"] { display:none !important; }
  .ev-nav { position:absolute; top:100%; left:0; right:0; display:none; flex-direction:column;
    gap:0; margin:0; padding:6px 0; background:#fff; border-top:1px solid var(--grey-200);
    box-shadow:var(--shadow-lg); align-items:stretch; max-height:calc(100vh - 76px); overflow-y:auto; }
  .ev-header.is-menu-open .ev-nav { display:flex; }
  .ev-nav__item { display:block; position:static; }
  .ev-nav__link, .ev-nav__item > a { display:flex; width:100%; padding:14px 24px; font-size:16px; }
  .ev-nav__item > a svg { display:none; }
  /* dropdowns expand inline in the mobile drawer */
  .ev-dropdown { position:static; opacity:1; visibility:visible; transform:none; box-shadow:none;
    border:0; border-radius:0; margin:0; padding:0 0 6px; min-width:0; background:transparent; }
  .ev-dropdown::before { display:none; }
  .ev-dropdown a { padding:11px 24px 11px 44px; white-space:normal; font-size:15px; }
  .ev-nav__link:hover, .ev-nav__item > a:hover, .ev-dropdown a:hover { background:var(--ivory); color:var(--emerald); }
}
@media (max-width:560px) {
  .ev-footer__inner { grid-template-columns:1fr; }
  .ev-stat-grid { grid-template-columns:1fr 1fr; }
}

/* ---- Mobile polish ---- */
@media (max-width:600px) {
  /* Wide tables (e.g. fee schedule) scroll sideways instead of cramping */
  .wp-block-table { overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .wp-block-table table { min-width:560px; }
  /* Comfortable touch targets for buttons */
  .ev-btn { min-height:44px; }
}

/* Embedded Zoho forms (application / agent application pages) */
.ev-zoho-embed { width:100%; }
.ev-zoho-embed iframe { width:100%; border:0; display:block; }

/* Download icon on brochure / fee-schedule buttons (.ev-brochure-download) */
.ev-brochure-download .wp-element-button, .ev-brochure-download .ev-btn { display:inline-flex; align-items:center; gap:.5em; }
.ev-brochure-download .wp-element-button::before, .ev-brochure-download .ev-btn::before {
  content:""; width:1.05em; height:1.05em; flex:0 0 auto; background-color:currentColor;
  -webkit-mask:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22%23000%22%20stroke-width%3D%222%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%3Cpath%20d%3D%22M21%2015v4a2%202%200%200%201-2%202H5a2%202%200%200%201-2-2v-4%22/%3E%3Cpolyline%20points%3D%227%2010%2012%2015%2017%2010%22/%3E%3Cline%20x1%3D%2212%22%20y1%3D%2215%22%20x2%3D%2212%22%20y2%3D%223%22/%3E%3C/svg%3E") center/contain no-repeat; mask:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22%23000%22%20stroke-width%3D%222%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%3Cpath%20d%3D%22M21%2015v4a2%202%200%200%201-2%202H5a2%202%200%200%201-2-2v-4%22/%3E%3Cpolyline%20points%3D%227%2010%2012%2015%2017%2010%22/%3E%3Cline%20x1%3D%2212%22%20y1%3D%2215%22%20x2%3D%2212%22%20y2%3D%223%22/%3E%3C/svg%3E") center/contain no-repeat;
}

/* ---- Dropdown enhancements: group labels, brochure CTA, wider courses menu ---- */
.ev-dropdown--wide { min-width:288px; }
.ev-dropdown__label { display:block; padding:10px 14px 4px; font-family:var(--font-ui); font-size:11px;
  font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--grey-400); }
.ev-dropdown a.ev-dropdown__cta { display:flex; align-items:center; gap:7px; margin-top:6px;
  border-top:1px solid var(--grey-200); color:var(--emerald); font-weight:600; }
.ev-dropdown a.ev-dropdown__cta svg { color:var(--emerald); }

/* Secondary header CTA (Quick forms) — desktop only; on mobile it's in the menu drawer */
@media (max-width:900px){ .ev-header__actions .ev-quickforms { display:none !important; } }
