:root {
  --navy-950: #061827;
  --navy-900: #09263d;
  --navy-800: #0c3554;
  --navy-700: #134867;
  --navy-600: #25698d;
  --wine-900: #4b0f25;
  --wine-800: #65132f;
  --wine-700: #7a1838;
  --wine-600: #96284b;
  --silver-100: #f8fafc;
  --silver-200: #edf1f4;
  --silver-300: #dce2e7;
  --silver-400: #bac4cd;
  --ink: #17222d;
  --muted: #667483;
  --cream: #f8f7f5;
  --white: #ffffff;
  --line: rgba(17, 39, 58, .12);
  --line-light: rgba(255, 255, 255, .14);
  --shadow: 0 22px 60px rgba(5, 24, 39, .12);
  --radius: 24px;
  --container: 1260px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 118px; }
body { margin: 0; min-width: 320px; overflow-x: hidden; color: var(--ink); background: var(--cream); font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; font-size: 16px; line-height: 1.58; -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button { font: inherit; }
svg { width: 1.15em; height: 1.15em; flex: 0 0 auto; }
.svg-sprite { position: absolute; width: 0; height: 0; overflow: hidden; }
.container { width: min(calc(100% - 48px), var(--container)); margin: 0 auto; }
.section { padding: 112px 0; }
.skip-link { position: absolute; z-index: 200; top: -100px; left: 24px; padding: 10px 14px; border-radius: 8px; color: #fff; background: var(--wine-700); }
.skip-link:focus { top: 16px; }

.notice-bar { position: relative; z-index: 50; color: #fff; background: linear-gradient(90deg, var(--wine-900), var(--wine-700)); }
.notice-inner { min-height: 38px; display: flex; align-items: center; justify-content: space-between; gap: 18px; font-size: .73rem; font-weight: 700; letter-spacing: .01em; }
.notice-inner span, .notice-inner a { display: inline-flex; align-items: center; gap: 7px; }
.notice-inner span svg { color: #f3c7d2; }
.notice-inner a { color: #fff; opacity: .95; transition: opacity .2s ease; }
.notice-inner a:hover { opacity: .72; }
.notice-inner a svg { width: 1em; height: 1em; }

.site-header { position: sticky; top: 0; z-index: 45; background: rgba(251, 252, 253, .985); border-bottom: 1px solid rgba(9, 38, 61, .11); box-shadow: 0 7px 24px rgba(8, 37, 57, .055); }
.nav-wrap { min-height: 88px; display: flex; align-items: center; gap: 28px; }
.brand { flex: 0 0 auto; display: block; }
.brand img { width: 232px; height: 66px; object-fit: contain; object-position: left center; }
.main-nav { display: flex; align-items: center; gap: 27px; margin-left: auto; }
.main-nav a { position: relative; padding: 10px 0; color: #334353; font-size: .87rem; font-weight: 750; transition: color .2s ease; }
.main-nav a::after { content: ""; position: absolute; left: 0; bottom: 4px; width: 0; height: 2px; border-radius: 50px; background: var(--wine-700); transition: width .25s ease; }
.main-nav a:hover, .main-nav a.active { color: var(--navy-800); }
.main-nav a:hover::after, .main-nav a.active::after { width: 100%; }
.nav-cta { display: inline-flex; align-items: center; justify-content: center; gap: 8px; min-height: 42px; padding: 10px 14px; border: 1px solid var(--wine-700); border-radius: 999px; color: var(--wine-700); background: #fff; font-size: .78rem; font-weight: 800; white-space: nowrap; transition: .25s ease; }
.nav-cta:hover { color: #fff; background: var(--wine-700); box-shadow: 0 8px 20px rgba(122, 24, 56, .2); transform: translateY(-1px); }
.nav-toggle { display: none; width: 43px; height: 43px; margin-left: auto; padding: 10px; border: 1px solid rgba(9, 38, 61, .18); border-radius: 11px; color: var(--navy-800); background: #fff; cursor: pointer; }
.nav-toggle span { display: block; width: 100%; height: 2px; margin: 4px 0; border-radius: 999px; background: currentColor; transition: transform .25s ease, opacity .2s ease; }
.nav-toggle.is-open span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.nav-toggle.is-open span:nth-child(2) { opacity: 0; }
.nav-toggle.is-open span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

.hero { position: relative; overflow: hidden; padding: 110px 0 104px; color: #fff; background: radial-gradient(circle at 86% 22%, rgba(150, 40, 75, .58), transparent 28%), radial-gradient(circle at 11% 97%, rgba(47, 121, 156, .45), transparent 36%), linear-gradient(120deg, var(--navy-950) 5%, var(--navy-900) 50%, #0c243a 100%); }
.hero::before { content: ""; position: absolute; inset: 0; opacity: .24; background-image: linear-gradient(rgba(255,255,255,.12) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.12) 1px, transparent 1px); background-size: 56px 56px; mask-image: linear-gradient(135deg, black 0%, rgba(0,0,0,.65) 45%, transparent 90%); }
.hero::after { content: ""; position: absolute; inset: auto -100px -195px auto; width: 580px; height: 580px; border: 1px solid rgba(255,255,255,.12); border-radius: 50%; box-shadow: 0 0 0 50px rgba(255,255,255,.026), 0 0 0 100px rgba(255,255,255,.018); }
.hero-pulse { position: absolute; border: 1px solid rgba(255,255,255,.14); border-radius: 50%; pointer-events: none; }
.hero-pulse-one { width: 650px; height: 650px; top: -455px; left: 24%; }
.hero-pulse-two { width: 420px; height: 420px; bottom: -245px; left: -240px; }
.hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, .93fr) minmax(410px, .85fr); gap: 70px; align-items: center; }
.eyebrow { display: flex; align-items: center; gap: 9px; margin: 0 0 16px; color: var(--wine-700); font-size: .72rem; font-weight: 850; letter-spacing: .14em; text-transform: uppercase; }
.eyebrow span { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: currentColor; box-shadow: 0 0 0 4px rgba(122,24,56,.12); }
.eyebrow-light { color: #f5c4d1; }
.eyebrow-light span { box-shadow: 0 0 0 4px rgba(245,196,209,.13); }
.hero h1, h2 { margin: 0; font-family: Georgia, "Times New Roman", serif; font-weight: 500; letter-spacing: -.045em; }
.hero h1 { max-width: 670px; font-size: clamp(3rem, 5.35vw, 5.3rem); line-height: .99; }
.hero-lead { max-width: 612px; margin: 26px 0 31px; color: #d5e0e8; font-size: 1.07rem; line-height: 1.75; }
.hero-lead strong { color: #fff; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; }
.button { display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-height: 50px; padding: 13px 19px; border-radius: 999px; font-size: .86rem; font-weight: 820; transition: transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease; }
.button:hover { transform: translateY(-2px); }
.button svg { width: 1.05em; height: 1.05em; }
.button-wine { color: #fff; background: linear-gradient(135deg, var(--wine-600), var(--wine-800)); box-shadow: 0 13px 28px rgba(100,19,47,.3); }
.button-wine:hover { box-shadow: 0 18px 34px rgba(100,19,47,.44); }
.button-ghost { border: 1px solid rgba(255,255,255,.29); color: #fff; background: rgba(255,255,255,.04); }
.button-ghost:hover { background: rgba(255,255,255,.12); }
.button-navy { color: #fff; background: linear-gradient(135deg, var(--navy-800), var(--navy-950)); box-shadow: 0 12px 25px rgba(7,34,54,.22); }
.button-light { color: var(--navy-900); background: #fff; box-shadow: 0 12px 25px rgba(0,0,0,.14); }
.button-light:hover { color: var(--wine-800); }
.hero-badges { display: flex; flex-wrap: wrap; gap: 14px 25px; margin-top: 34px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,.18); color: #d0dbe4; font-size: .82rem; }
.hero-badges span { display: inline-flex; align-items: center; gap: 7px; }
.hero-badges svg { color: #f4b8c9; }
.hero-visual { position: relative; min-height: 510px; }
.hero-photo { position: absolute; inset: 0 20px 0 56px; overflow: hidden; border: 1px solid rgba(255,255,255,.25); border-radius: 30px; background: linear-gradient(135deg, rgba(13,57,87,.75), rgba(77,15,39,.65)), url("https://images.unsplash.com/photo-1523240795612-9a054b0db644?auto=format&fit=crop&w=1400&q=85") center/cover; box-shadow: 0 31px 65px rgba(0,0,0,.24); }
.hero-photo::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 35%, rgba(5,19,31,.58)); }
.hero-photo-overlay { position: absolute; inset: 13px 34px 14px 70px; border: 1px solid rgba(255,255,255,.12); border-radius: 24px; pointer-events: none; }
.hero-stat { position: absolute; z-index: 2; display: flex; align-items: center; gap: 11px; min-width: 170px; padding: 13px 15px; border: 1px solid rgba(255,255,255,.28); border-radius: 15px; background: rgba(6,24,39,.72); box-shadow: 0 16px 30px rgba(0,0,0,.17); backdrop-filter: blur(10px); }
.hero-stat-top { top: 33px; left: 0; }
.hero-stat-bottom { right: 0; bottom: 32px; }
.stat-icon { display: grid; place-items: center; width: 35px; height: 35px; border-radius: 10px; color: #fff; background: rgba(150,40,75,.78); }
.hero-stat strong, .hero-stat small { display: block; }
.hero-stat strong { color: #fff; font-size: .8rem; line-height: 1.25; }
.hero-stat small { margin-top: 2px; color: #d7e0e7; font-size: .66rem; line-height: 1.25; }
.hero-glass-card { position: absolute; z-index: 2; left: 89px; bottom: 33px; display: flex; align-items: flex-start; gap: 9px; padding: 13px 16px; border: 1px solid rgba(255,255,255,.2); border-radius: 14px; background: rgba(255,255,255,.1); color: #fff; backdrop-filter: blur(10px); }
.hero-glass-card p { margin: 0; font-size: .78rem; line-height: 1.38; }
.glass-dot { width: 9px; height: 9px; margin-top: 3px; border-radius: 50%; background: #d97091; box-shadow: 0 0 0 4px rgba(217,112,145,.15); }

.trust-strip { color: #fff; background: linear-gradient(100deg, var(--wine-900), #5b122b 48%, var(--navy-950)); }
.trust-grid { display: grid; grid-template-columns: repeat(3, 1fr); }
.trust-grid article { display: flex; align-items: center; gap: 15px; min-height: 112px; padding: 23px 30px; border-right: 1px solid rgba(255,255,255,.17); }
.trust-grid article:first-child { border-left: 1px solid rgba(255,255,255,.17); }
.trust-icon { display: grid; place-items: center; width: 42px; height: 42px; flex: 0 0 42px; border-radius: 12px; color: #fff; background: rgba(255,255,255,.13); }
.trust-grid strong { display: block; font-size: .88rem; }
.trust-grid p { margin: 3px 0 0; color: rgba(255,255,255,.74); font-size: .76rem; line-height: 1.45; }

.intro-section { background: #fff; }
.intro-grid { display: grid; grid-template-columns: minmax(370px, .92fr) minmax(0, .9fr); gap: 104px; align-items: center; }
.intro-image { position: relative; min-height: 518px; }
.intro-image::before { content: ""; position: absolute; top: 30px; left: -18px; width: 87%; height: 92%; border: 1px solid rgba(12,53,84,.14); border-radius: 28px; }
.intro-photo { position: absolute; inset: 0 0 18px 32px; overflow: hidden; border-radius: 28px; background: linear-gradient(30deg, rgba(6,24,39,.55), transparent 58%), url("https://images.unsplash.com/photo-1522202176988-66273c2fd55f?auto=format&fit=crop&w=1400&q=85") center/cover; box-shadow: var(--shadow); }
.photo-caption { position: absolute; right: -17px; bottom: 0; max-width: 243px; padding: 18px 20px; border-left: 4px solid #b34f6f; border-radius: 13px; color: #fff; background: var(--navy-900); box-shadow: 0 13px 30px rgba(5,27,43,.24); }
.photo-caption span, .photo-caption strong { display: block; }
.photo-caption span { margin-bottom: 4px; color: #f5b4c9; font-size: .65rem; font-weight: 850; letter-spacing: .16em; }
.photo-caption strong { font-size: .86rem; line-height: 1.38; }
.intro-content h2, .section-heading h2, .learn-copy h2, .contact-copy h2 { max-width: 650px; color: var(--navy-900); font-size: clamp(2.35rem, 4vw, 4rem); line-height: 1.04; }
.intro-content > p:not(.eyebrow), .learn-copy > p:not(.eyebrow), .contact-copy > p:not(.eyebrow) { max-width: 608px; margin: 22px 0 28px; color: var(--muted); font-size: .99rem; line-height: 1.78; }
.feature-list { display: grid; gap: 13px; margin: 0 0 29px; }
.feature-list div { display: flex; align-items: flex-start; gap: 11px; }
.feature-list span { display: grid; place-items: center; width: 23px; height: 23px; flex: 0 0 23px; margin-top: 1px; border-radius: 50%; color: #fff; background: var(--wine-700); }
.feature-list span svg { width: .78em; height: .78em; }
.feature-list p { margin: 0; color: #405465; font-size: .88rem; }
.text-link { display: inline-flex; align-items: center; gap: 8px; color: var(--wine-700); font-size: .86rem; font-weight: 850; }
.text-link svg { transition: transform .2s ease; }
.text-link:hover svg { transform: translateX(4px); }

.courses-section { background: linear-gradient(180deg, #f3f5f6, #e8edf0); }
.section-heading { display: grid; grid-template-columns: minmax(0, .98fr) minmax(280px, .6fr); align-items: end; gap: 70px; margin-bottom: 31px; }
.section-heading > p { max-width: 445px; margin: 0 0 7px; color: #5c6c7a; font-size: .96rem; line-height: 1.7; }
.section-heading > p strong { color: var(--navy-800); }
.course-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin-bottom: 24px; }
.filters { display: flex; flex-wrap: wrap; gap: 8px; }
.filter-button { display: inline-flex; align-items: center; gap: 6px; padding: 8px 12px; border: 1px solid rgba(9,38,61,.14); border-radius: 999px; color: #566574; background: rgba(255,255,255,.52); font-size: .74rem; font-weight: 760; cursor: pointer; transition: all .2s ease; }
.filter-button span { display: grid; place-items: center; min-width: 17px; height: 17px; padding: 0 4px; border-radius: 99px; color: #fff; background: var(--wine-700); font-size: .61rem; }
.filter-button:hover, .filter-button.is-active { border-color: var(--navy-800); color: #fff; background: var(--navy-800); }
.filter-button.is-active span { color: var(--navy-800); background: #fff; }
.course-toolbar > p { display: inline-flex; align-items: center; gap: 7px; margin: 0; color: #596877; font-size: .78rem; font-weight: 700; }
.course-toolbar > p svg { color: var(--wine-700); }
.courses-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; }
.course-card { display: flex; flex-direction: column; min-height: 363px; padding: 21px; border: 1px solid rgba(12,53,84,.13); border-radius: 19px; background: rgba(255,255,255,.94); box-shadow: 0 12px 26px rgba(7,34,54,.055); transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease, opacity .2s ease; }
.course-card:hover { border-color: rgba(122,24,56,.42); box-shadow: 0 20px 38px rgba(6,32,50,.13); transform: translateY(-7px); }
.course-card.is-hidden { display: none; }
.course-card-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.course-area, .course-hours { display: inline-flex; align-items: center; min-height: 23px; border-radius: 999px; padding: 4px 8px; font-size: .61rem; font-weight: 830; }
.course-area { color: var(--wine-700); background: #fbedf1; letter-spacing: .06em; text-transform: uppercase; }
.course-hours { color: #597084; background: #edf3f6; }
.course-icon { display: grid; place-items: center; width: 47px; height: 47px; margin: 25px 0 18px; border-radius: 14px; }
.course-icon svg { width: 25px; height: 25px; }
.icon-navy { color: var(--navy-800); background: #e9f1f6; }
.icon-wine { color: var(--wine-700); background: #fbedf1; }
.course-card h3 { margin: 0; color: var(--navy-900); font-size: 1.06rem; line-height: 1.27; letter-spacing: -.025em; }
.course-card p { margin: 11px 0 20px; color: #687788; font-size: .79rem; line-height: 1.66; }
.course-card > a { display: inline-flex; align-items: center; gap: 7px; margin-top: auto; color: var(--wine-700); font-size: .77rem; font-weight: 840; }
.course-card > a svg { width: 1em; height: 1em; transition: transform .2s ease; }
.course-card > a:hover svg { transform: translateX(4px); }
.courses-cta { display: flex; align-items: center; justify-content: space-between; gap: 25px; margin-top: 31px; padding: 20px 22px; border: 1px solid rgba(12,53,84,.12); border-radius: 18px; background: rgba(255,255,255,.72); }
.courses-cta > div { display: flex; align-items: center; gap: 13px; }
.mini-seal { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 13px; color: var(--wine-700); background: #fbecef; }
.courses-cta p { margin: 0; color: #687787; font-size: .82rem; line-height: 1.45; }
.courses-cta strong { color: var(--navy-900); }

.accreditation-section { padding-top: 0; background: #e8edf0; }
.accreditation-card { position: relative; overflow: hidden; display: grid; grid-template-columns: auto minmax(0, 1fr) auto; gap: 28px; align-items: center; padding: 36px 42px; border-radius: 26px; color: #fff; background: linear-gradient(118deg, var(--wine-900), var(--wine-700) 55%, #8c2444); box-shadow: 0 24px 50px rgba(82,12,38,.2); }
.accreditation-card::before { content: ""; position: absolute; width: 480px; height: 480px; top: -330px; right: -100px; border: 1px solid rgba(255,255,255,.18); border-radius: 50%; box-shadow: 0 0 0 50px rgba(255,255,255,.025), 0 0 0 100px rgba(255,255,255,.025); }
.seal-visual { position: relative; z-index: 1; display: grid; place-items: center; width: 88px; height: 88px; border: 1px solid rgba(255,255,255,.38); border-radius: 50%; color: #fff; background: rgba(255,255,255,.1); }
.seal-visual span { font-family: Georgia, "Times New Roman", serif; font-size: 1.05rem; font-weight: 700; letter-spacing: .08em; }
.seal-visual svg { position: absolute; width: 103px; height: 103px; opacity: .12; }
.accreditation-copy { position: relative; z-index: 1; }
.accreditation-copy h2 { max-width: 670px; font-size: clamp(2rem, 3.1vw, 3.25rem); line-height: 1.05; }
.accreditation-copy > p:not(.eyebrow) { max-width: 690px; margin: 12px 0 0; color: rgba(255,255,255,.79); font-size: .9rem; }
.accreditation-copy strong { color: #fff; }
.accreditation-card > .button { position: relative; z-index: 1; white-space: nowrap; }

.learn-section { background: #fff; }
.learn-grid { display: grid; grid-template-columns: minmax(0, .83fr) minmax(390px, .88fr); gap: 95px; align-items: center; }
.learn-stats { display: flex; gap: 0; margin: 32px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.learn-stats div { padding: 20px 33px 20px 0; }
.learn-stats div + div { padding-left: 33px; border-left: 1px solid var(--line); }
.learn-stats strong, .learn-stats span { display: block; }
.learn-stats strong { color: var(--wine-700); font-family: Georgia, "Times New Roman", serif; font-size: 2rem; line-height: 1; }
.learn-stats span { max-width: 140px; margin-top: 6px; color: var(--muted); font-size: .73rem; line-height: 1.35; }
.learn-visual { position: relative; min-height: 410px; }
.learn-visual::before { content: ""; position: absolute; top: -18px; right: -15px; width: 72%; height: 76%; border: 1px solid rgba(122,24,56,.22); border-radius: 26px; }
.learn-photo { position: absolute; inset: 0 26px 0 0; overflow: hidden; border-radius: 27px; background: linear-gradient(45deg, rgba(5,28,46,.5), rgba(122,24,56,.16)), url("https://images.unsplash.com/photo-1516321318423-f06f85e504b3?auto=format&fit=crop&w=1400&q=85") center/cover; box-shadow: var(--shadow); }
.learn-overlay-card { position: absolute; right: 0; bottom: 24px; display: flex; align-items: center; gap: 12px; min-width: 224px; padding: 15px 17px; border-radius: 15px; color: #fff; background: var(--navy-900); box-shadow: 0 18px 35px rgba(5,31,50,.24); }
.learn-overlay-card svg { color: #f5b3c7; }
.learn-overlay-card p { margin: 0; font-size: .77rem; line-height: 1.45; }
.learn-overlay-card strong { font-size: .84rem; }

.campus-section { position: relative; overflow: hidden; padding: 103px 0; color: #fff; background: radial-gradient(circle at 79% 15%, rgba(153,37,76,.5), transparent 25%), linear-gradient(125deg, var(--navy-950), var(--navy-900) 57%, #113b59); }
.campus-section::before { content: ""; position: absolute; inset: 0; opacity: .12; background-image: linear-gradient(rgba(255,255,255,.12) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.12) 1px, transparent 1px); background-size: 46px 46px; mask-image: linear-gradient(135deg, transparent 2%, black 38%, black 88%, transparent); }
.campus-grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0,.8fr) minmax(430px, 1fr); gap: 90px; align-items: center; }
.campus-content h2 { max-width: 580px; font-size: clamp(2.5rem, 4vw, 4.2rem); line-height: 1.02; }
.campus-content > p:not(.eyebrow) { max-width: 515px; margin: 21px 0 28px; color: #cfdae3; font-size: .98rem; line-height: 1.75; }
.campus-mockup { position: relative; min-height: 360px; }
.mockup-window { position: absolute; inset: 0 0 0 31px; overflow: hidden; border: 1px solid rgba(255,255,255,.24); border-radius: 19px; background: #f8fafc; box-shadow: 0 30px 64px rgba(0,0,0,.32), inset 0 1px 0 rgba(255,255,255,.2); transform: perspective(1000px) rotateY(-8deg) rotateX(2deg); }
.mockup-bar { display: flex; align-items: center; gap: 5px; height: 39px; padding: 0 13px; border-bottom: 1px solid #dce4ea; background: #fff; }
.mockup-bar span { width: 7px; height: 7px; border-radius: 50%; background: #c9d2d9; }
.mockup-bar b { margin-left: 9px; color: #637383; font-size: .61rem; }
.mockup-body { display: grid; grid-template-columns: 74px 1fr; height: calc(100% - 39px); }
.mockup-sidebar { display: grid; align-content: start; gap: 14px; padding: 22px 14px; background: #eaf0f4; }
.mockup-sidebar i { display: block; height: 8px; border-radius: 4px; background: #c3d2dc; }
.mockup-main { padding: 30px 25px; background: linear-gradient(135deg, #f7fafb, #ecf2f5); }
.mockup-title { width: 48%; height: 16px; border-radius: 7px; background: #153f5d; }
.mockup-subtitle { width: 31%; height: 8px; margin-top: 10px; border-radius: 7px; background: #aabcc7; }
.mockup-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 26px; }
.mockup-cards i { display: block; height: 91px; border-radius: 10px; background: linear-gradient(145deg, #dfeaf1, #edf2f5); }
.mockup-cards i:nth-child(2) { background: linear-gradient(145deg, #e9cdd6, #f3e5ea); }
.mockup-progress { display: flex; align-items: center; gap: 12px; margin-top: 26px; padding: 12px; border-radius: 9px; background: #fff; box-shadow: 0 7px 15px rgba(14,45,67,.05); }
.mockup-progress span { display: block; width: 50%; height: 8px; border-radius: 9px; background: linear-gradient(90deg, var(--wine-700) 0 68%, #e8edf0 68%); }
.mockup-progress b { color: #516574; font-size: .68rem; }
.mockup-chip { position: absolute; z-index: 2; display: flex; align-items: center; gap: 7px; padding: 10px 12px; border: 1px solid rgba(255,255,255,.21); border-radius: 11px; color: #fff; background: rgba(8,34,54,.85); box-shadow: 0 13px 25px rgba(0,0,0,.2); backdrop-filter: blur(8px); font-size: .68rem; font-weight: 750; }
.mockup-chip svg { width: 1em; height: 1em; color: #f5b4c9; }
.chip-one { top: 31px; left: 0; }
.chip-two { right: 3px; bottom: 22px; }

.contact-section { background: #f1f4f5; }
.contact-grid { display: grid; grid-template-columns: minmax(0,.8fr) minmax(440px, .94fr); gap: 100px; align-items: center; }
.contact-cards { display: grid; gap: 12px; }
.contact-card { display: grid; grid-template-columns: 45px minmax(0,1fr) auto; align-items: center; gap: 13px; padding: 17px; border: 1px solid rgba(9,38,61,.12); border-radius: 16px; background: #fff; box-shadow: 0 8px 18px rgba(5,31,50,.035); transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease; }
.contact-card:hover { border-color: rgba(122,24,56,.38); box-shadow: 0 15px 28px rgba(6,32,50,.1); transform: translateX(5px); }
.contact-icon { display: grid; place-items: center; width: 45px; height: 45px; border-radius: 13px; }
.contact-icon svg { width: 22px; height: 22px; }
.contact-card small, .contact-card strong { display: block; }
.contact-card small { margin-bottom: 3px; color: #8a98a5; font-size: .64rem; font-weight: 820; letter-spacing: .08em; text-transform: uppercase; }
.contact-card strong { color: var(--navy-900); font-size: .82rem; line-height: 1.42; }
.contact-arrow { color: var(--wine-700); transition: transform .2s ease; }
.contact-card:hover .contact-arrow { transform: translateX(3px); }

.site-footer { color: #c4d0d8; background: #061827; }
.footer-main { display: grid; grid-template-columns: 1.35fr .55fr .75fr; gap: 68px; padding: 56px 0 42px; }
.footer-brand img { width: 245px; height: 70px; margin-bottom: 15px; object-fit: contain; object-position: left center; }
.footer-brand p { max-width: 345px; margin: 0; color: #aebdc8; font-size: .82rem; line-height: 1.65; }
.footer-links { display: grid; align-content: start; gap: 10px; }
.footer-links strong { margin-bottom: 5px; color: #fff; font-size: .82rem; }
.footer-links a { color: #b9c8d3; font-size: .77rem; transition: color .2s ease; }
.footer-links a:hover { color: #f2b1c5; }
.footer-bottom { display: flex; justify-content: space-between; gap: 20px; padding: 17px 0; border-top: 1px solid rgba(255,255,255,.12); color: #8395a4; font-size: .68rem; }

.back-to-top { position: fixed; z-index: 42; right: 20px; bottom: 19px; display: grid; place-items: center; width: 42px; height: 42px; border: 0; border-radius: 50%; color: #fff; background: var(--wine-700); box-shadow: 0 10px 22px rgba(91,16,42,.25); cursor: pointer; opacity: 0; pointer-events: none; transform: translateY(12px); transition: .25s ease; }
.back-to-top svg { transform: rotate(-90deg); }
.back-to-top.is-visible { opacity: 1; pointer-events: auto; transform: translateY(0); }
.back-to-top:hover { background: var(--wine-600); transform: translateY(-2px); }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity .65s ease, transform .65s ease; }
.reveal.is-visible { opacity: 1; transform: translateY(0); }
.reveal-delay { transition-delay: .12s; }
.reveal-delay-2 { transition-delay: .22s; }
.reveal-delay-3 { transition-delay: .32s; }

@media (max-width: 1130px) {
  .nav-wrap { gap: 20px; }
  .brand img { width: 207px; }
  .main-nav { gap: 18px; }
  .nav-cta { display: none; }
  .hero-grid, .intro-grid, .learn-grid, .campus-grid, .contact-grid { gap: 55px; }
  .courses-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .course-card { min-height: 320px; }
}

@media (max-width: 810px) {
  .container { width: min(calc(100% - 36px), var(--container)); }
  .section { padding: 82px 0; }
  .notice-inner { min-height: 41px; font-size: .66rem; }
  .notice-inner a { display: none; }
  .nav-wrap { min-height: 76px; position: relative; }
  .brand img { width: 186px; height: 55px; }
  .nav-toggle { display: block; }
  .main-nav { position: absolute; top: 68px; left: 0; right: 0; display: grid; gap: 0; margin: 0; padding: 10px; border: 1px solid rgba(9,38,61,.13); border-radius: 15px; background: #fff; box-shadow: 0 17px 35px rgba(5,31,50,.15); opacity: 0; visibility: hidden; transform: translateY(-8px); transition: opacity .2s ease, visibility .2s ease, transform .2s ease; }
  .main-nav.is-open { opacity: 1; visibility: visible; transform: translateY(0); }
  .main-nav a { padding: 12px 11px; border-radius: 8px; }
  .main-nav a:hover, .main-nav a.active { background: #f5f8fa; }
  .main-nav a::after { display: none; }
  .hero { padding: 85px 0 81px; }
  .hero-grid, .intro-grid, .learn-grid, .campus-grid, .contact-grid { grid-template-columns: 1fr; }
  .hero-grid { gap: 48px; }
  .hero h1 { max-width: 620px; font-size: clamp(3rem, 10.5vw, 4.6rem); }
  .hero-visual { max-width: 570px; width: 100%; margin: 0 auto; }
  .trust-grid { grid-template-columns: 1fr; }
  .trust-grid article, .trust-grid article:first-child { min-height: 92px; border-right: 0; border-left: 0; border-bottom: 1px solid rgba(255,255,255,.16); }
  .trust-grid article:last-child { border-bottom: 0; }
  .intro-grid, .learn-grid, .campus-grid, .contact-grid { gap: 45px; }
  .intro-image { max-width: 590px; width: 100%; margin: 0 auto; }
  .section-heading { grid-template-columns: 1fr; gap: 16px; }
  .section-heading > p { margin: 0; }
  .accreditation-card { grid-template-columns: auto minmax(0, 1fr); }
  .accreditation-card > .button { grid-column: 1 / -1; justify-self: start; }
  .campus-mockup { max-width: 610px; width: 100%; margin: 0 auto; }
  .footer-main { grid-template-columns: 1.2fr .7fr .8fr; gap: 30px; }
}

@media (max-width: 560px) {
  html { scroll-padding-top: 96px; }
  .section { padding: 68px 0; }
  .notice-inner { justify-content: center; text-align: center; }
  .notice-inner span { justify-content: center; }
  .brand img { width: 171px; height: 50px; }
  .hero { padding: 68px 0 66px; }
  .hero h1 { font-size: clamp(2.75rem, 13.5vw, 3.85rem); }
  .hero-lead { font-size: .96rem; }
  .button { width: 100%; }
  .hero-actions { display: grid; }
  .hero-badges { display: grid; gap: 11px; }
  .hero-visual { min-height: 410px; }
  .hero-photo { inset: 0 3px 0 27px; border-radius: 24px; }
  .hero-photo-overlay { inset: 10px 12px 10px 39px; border-radius: 19px; }
  .hero-stat { min-width: 153px; padding: 10px 11px; }
  .hero-stat-top { top: 22px; left: 0; }
  .hero-stat-bottom { right: -8px; bottom: 20px; }
  .hero-glass-card { left: 47px; bottom: 21px; }
  .trust-grid article { padding: 20px 3px; }
  .intro-image { min-height: 400px; }
  .intro-photo { inset: 0 0 15px 15px; }
  .photo-caption { right: 0; max-width: 215px; padding: 14px 15px; }
  .intro-content h2, .section-heading h2, .learn-copy h2, .contact-copy h2 { font-size: clamp(2.15rem, 10vw, 3.1rem); }
  .course-toolbar { display: grid; }
  .course-toolbar > p { display: none; }
  .filters { flex-wrap: nowrap; overflow-x: auto; padding-bottom: 3px; }
  .filter-button { white-space: nowrap; }
  .courses-grid { grid-template-columns: 1fr; }
  .course-card { min-height: 0; }
  .courses-cta { display: grid; padding: 18px; }
  .courses-cta > div { align-items: flex-start; }
  .accreditation-card { grid-template-columns: 1fr; padding: 31px 23px; gap: 18px; }
  .accreditation-card > .button { width: 100%; }
  .learn-stats div { padding: 17px 17px 17px 0; }
  .learn-stats div + div { padding-left: 17px; }
  .learn-visual { min-height: 345px; }
  .learn-photo { inset: 0 9px 0 0; }
  .learn-overlay-card { right: 0; bottom: 13px; }
  .campus-section { padding: 72px 0; }
  .campus-mockup { min-height: 268px; }
  .mockup-window { inset: 0 0 0 10px; }
  .mockup-main { padding: 21px 16px; }
  .mockup-sidebar { grid-template-columns: 1fr; padding: 16px 10px; }
  .mockup-cards i { height: 62px; }
  .mockup-progress { margin-top: 16px; }
  .mockup-chip { font-size: .58rem; }
  .chip-one { top: 18px; left: -4px; }
  .chip-two { right: -4px; bottom: 15px; }
  .contact-card { grid-template-columns: 42px minmax(0, 1fr); }
  .contact-arrow { display: none; }
  .footer-main { grid-template-columns: 1fr; gap: 27px; padding: 44px 0 34px; }
  .footer-bottom { display: grid; gap: 5px; }
  .footer-brand img { width: 220px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
