:root {
  --red: #ff0028;
  --red-dark: #d90d21;
  --navy: #042962;
  --ink: #111;
  --muted: #475569;
  --soft: #f5f7fb;
  --line: #dbe6f3;
  --shadow: 0 14px 34px rgba(15, 23, 42, .08);
  --radius: 12px;
}

@font-face {
  font-family: "Font Awesome 5 Free";
  font-style: normal;
  font-weight: 900;
  font-display: block;
  src: url("../vendor/wp-content/plugins/elementor/assets/lib/font-awesome/webfonts/fa-solid-900.woff2") format("woff2"),
       url("../vendor/wp-content/plugins/elementor/assets/lib/font-awesome/webfonts/fa-solid-900.woff") format("woff");
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: Figtree, Arial, sans-serif; color: var(--ink); line-height: 1.6; background: #fff; }
p { font-size: 18px; }
.text-red { color: var(--red); }
.text-navy { color: var(--navy); }
img { max-width: 100%; display: block; }
a { color: inherit; }
.container { width: min(1300px, calc(100% - 32px)); margin-inline: auto; }
.narrow { width: min(980px, calc(100% - 32px)); }
.center { text-align: center; }
.section-title { font-size: clamp(28px, 3vw, 38px); line-height: 1.15; margin: 0 0 14px; font-weight: 800; }
.section-lead { max-width: 760px; margin: 0 auto 30px; color: var(--muted); font-size: 18px; }
.section-kicker { color: var(--red); font-size: 20px; margin: 0 0 8px; font-weight: 500; }
.btn { display: inline-flex; align-items: center; justify-content: center; border-radius: 14px; padding: 13px 26px; font-weight: 600; text-decoration: none; border: 1px solid transparent; cursor: pointer; }
.btn-primary { background: var(--red); color: #fff; }
.btn-dark { background: #111; color: #fff; }
.center-button { margin: 28px auto 0; display: flex; width: max-content; }

.site-header { position: sticky; top: 0; z-index: 50; background: #fff; border-bottom: 1px solid #e5e7eb; }
.header-inner { min-height: 96px; display: flex; align-items: center; gap: 22px; }
.brand img { width: 270px; }
.site-nav { display: flex; gap: 6px; margin-left: auto; }
.site-nav a { padding: 14px 12px; text-decoration: none; font-weight: 500; }
.header-contact { display: flex; align-items: center; gap: 20px; }
.header-phone { display: inline-flex; align-items: center; gap: 12px; color: var(--red); font-size: 25px; font-weight: 800; line-height: 1; text-decoration: none; white-space: nowrap; }
.header-phone-icon { display: inline-grid; place-items: center; width: 25px; height: 25px; }
.header-phone-icon img { width: 25px; height: 25px; object-fit: contain; }
.header-contact .btn-primary { background: var(--navy); border-color: var(--navy); border-radius: 14px; padding: 13px 22px; font-size: 16px; line-height: 1; min-height: 44px; }
.nav-toggle { display: none; background: none; border: 0; width: 42px; height: 42px; margin-left: auto; }
.nav-toggle span { display: block; height: 2px; background: #111; margin: 7px; transition: transform .2s ease, opacity .2s ease; transform-origin: center; }
.nav-toggle.is-open span:nth-child(1) { transform: translateY(9px) rotate(45deg); }
.nav-toggle.is-open span:nth-child(2) { opacity: 0; }
.nav-toggle.is-open span:nth-child(3) { transform: translateY(-9px) rotate(-45deg); }

.hero { background: #f4f3f2; padding: 44px 0; }
.hero-grid { display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 34px; }
.hero h1 { font-size: clamp(34px, 4.5vw, 58px); line-height: 1.08; margin: 12px 0 18px; letter-spacing: 0; }
.hero p { font-size: 18px; }
.eyebrow { display: inline-block; background: #fff1f2; border: 1px solid #ffd5dc; color: var(--red); border-radius: 999px; padding: 10px 16px; margin: 0 !important; font-size: 18px !important; font-weight: 700; line-height: 1.3; text-align: center; }
.hero-card { text-align: center; }
.hero-card p { color: var(--red); font-size: 28px; font-weight: 800; margin: 0; }
.hero-card h2 { font-size: clamp(25px, 2.7vw, 36px); line-height: 1.16; margin: 0 0 16px; }
.hero-card img { margin: auto; border-radius: 16px; }
.hero-copy .btn-dark { background: var(--red); border-color: var(--red); }
.mobile-apply-content, .mobile-apply-details { display: none; }
.mobile-hero-actions { display: none; }

.why-choose-section { padding: 42px 0; background: #fff; }
.why-choose-panel { position: relative; overflow: hidden; border-radius: 20px; padding: 38px; background: linear-gradient(135deg, #fff 0%, #f8fbff 54%, #fff2f5 100%); border: 1px solid #dbe6f3; box-shadow: 0 18px 46px rgba(15, 23, 42, .08); }
.why-choose-panel:before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at top right, rgba(255, 0, 40, .12), transparent 34%); pointer-events: none; }
.why-choose-head { position: relative; max-width: 820px; margin: 0 auto 26px; }
.why-choose-title { color: var(--navy); }
.why-choose-grid { position: relative; display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 14px; }
.why-choose-item { display: flex; align-items: center; gap: 10px; min-height: 76px; padding: 16px; border-radius: 14px; background: rgba(255, 255, 255, .86); border: 1px solid #e2eaf5; color: #082b5f; font-weight: 700; line-height: 1.28; box-shadow: 0 10px 24px rgba(15, 23, 42, .05); }
.why-choose-item span { flex: 0 0 auto; display: grid; place-items: center; width: 24px; height: 24px; border-radius: 50%; background: var(--red); color: #fff; font-size: 13px; font-weight: 800; }

.split-section { padding: 60px 0; }
.split-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 34px; align-items: center; }
.split-grid-reverse > img { order: -1; }
.rounded-media { width: 100%; border-radius: 20px; object-fit: cover; box-shadow: var(--shadow); }
.split-section h2, .contact-section h2, .section-head h2 { font-size: clamp(28px, 3vw, 38px); line-height: 1.15; margin: 0 0 16px; }
.split-section h3 { font-size: 20px; margin: 24px 0 10px; }
.check-list { list-style: none; padding: 0; margin: 18px 0 0; }
.check-list li { position: relative; padding-left: 34px; margin: 11px 0; color: #1f2937; font-size: 18px; }
.check-list li:before { content: "✓"; position: absolute; left: 0; top: 4px; width: 16px; height: 16px; border: 1.5px solid var(--red); border-radius: 50%; color: var(--red); font-size: 10px; font-weight: 800; line-height: 15px; text-align: center; }
.university-section, .courses-section, .career-section { background: #f5f5f5; }
.university-section .rounded-media { height: 520px; border-radius: 16px; object-fit: cover; object-position: center center; box-shadow: none; }

#about-us { padding: 70px 0; }
#about-us .split-grid { grid-template-columns: minmax(0, .98fr) minmax(0, 1fr); gap: 40px; align-items: center; }
#about-us .rounded-media { height: 749px; border-radius: 16px; object-fit: cover; object-position: 48% center; box-shadow: none; }
#about-us h2 { font-size: clamp(30px, 3vw, 38px); line-height: 1.12; margin-bottom: 14px; }
#about-us p:not(.section-kicker) { line-height: 1.58; margin-top: 0; }
#about-us h3 { margin-top: 16px; margin-bottom: 8px; }
#about-us .check-list { margin-top: 10px; }
#about-us .check-list li { padding-left: 28px; margin: 8px 0; }
#about-us .check-list li:before { content: ""; width: 15px; height: 15px; top: 5px; border: 2px solid var(--red); border-radius: 50%; background: radial-gradient(circle, var(--red) 0 2px, transparent 3px); }

.course-banner-section { padding: 10px 0 42px; background: #fff; }
.course-banner-section img { width: 100%; border-radius: 16px; box-shadow: none; }
.course-banner-section h2 { margin: 20px 0 0; text-align: center; font-size: clamp(24px, 2.4vw, 34px); line-height: 1.18; font-weight: 800; color: #111; }

.courses-section, .form-section, .eligibility-section, .spot-admission-section, .career-section, .contact-section, .testimonials-section { padding: 58px 0; }
.courses-section .section-kicker { font-size: 24px; font-weight: 700; }
.course-accordion { max-width: 1120px; margin: 0 auto; overflow-anchor: none; }
.course-accordion details { margin-bottom: 10px; }
.course-accordion summary { list-style: none; cursor: pointer; background: var(--red); color: #fff; border-radius: 10px; padding: 20px 30px; font-size: 20px; font-weight: 700; display: flex; justify-content: space-between; }
.course-accordion summary::-webkit-details-marker { display: none; }
.course-accordion summary span:before { content: "+"; }
.course-accordion details[open] summary span:before { content: "-"; }
.accordion-panel { background: #fff; border-radius: 0 0 12px 12px; overflow: hidden; max-height: 0; opacity: 0; transform: translateY(-6px); transition: max-height .42s ease, opacity .28s ease, transform .28s ease; }
.course-accordion details[open] .accordion-panel { max-height: var(--accordion-height, 2200px); opacity: 1; transform: translateY(0); padding: 18px; }
.course-card { background: #fff; border: 1px solid #edf2f7; border-radius: 14px; padding: 20px; margin-bottom: 16px; box-shadow: 0 10px 24px rgba(15, 23, 42, .06); }
.course-card:last-child { margin-bottom: 0; }
.course-card-head { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin-bottom: 13px; padding-bottom: 12px; border-bottom: 2px solid rgba(255, 0, 40, .9); }
.course-degree, .course-duration { display: flex; align-items: center; gap: 10px; color: #130047; }
.course-degree-icon, .course-duration-icon { position: relative; flex: 0 0 auto; width: 20px; height: 20px; border: 2px solid var(--red); border-radius: 50%; }
.course-degree-icon:before { content: ""; position: absolute; inset: 5px; border-radius: 50%; background: var(--red); }
.course-duration-icon:before { content: ""; position: absolute; left: 8px; top: 4px; width: 2px; height: 6px; background: var(--red); border-radius: 2px; }
.course-duration-icon:after { content: ""; position: absolute; left: 8px; top: 9px; width: 6px; height: 2px; background: var(--red); border-radius: 2px; transform: rotate(25deg); transform-origin: left center; }
.course-degree h3 { margin: 0; color: #130047; font-size: 33px; line-height: 1; font-weight: 800; letter-spacing: 0; }
.course-duration strong { color: #130047; font-size: 25px; line-height: 1; font-weight: 400; white-space: nowrap; }
.course-tags { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px 12px; list-style: none; padding: 0; margin: 0; }
.course-tags li { background: #f3f4f6; border-radius: 999px; padding: 9px 14px; color: #062f68; font-weight: 500; line-height: 1.3; }

.form-section { background: #fff; }
.enquiry-form { background: #fff; border: 1px solid #e5edf5; border-radius: 16px; padding: 28px; box-shadow: var(--shadow); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.enquiry-form label { display: block; font-weight: 600; margin-bottom: 18px; }
.enquiry-form input, .enquiry-form select, .enquiry-form textarea { width: 100%; margin-top: 8px; border: 1px solid #d7dde8; border-radius: 8px; padding: 14px 13px; font: inherit; background: #fff; }
.enquiry-form .consent-field { display: flex; align-items: flex-start; gap: 10px; font-size: 16px; line-height: 1.45; font-weight: 500; color: #334155; }
.enquiry-form .consent-field input { width: 18px; height: 18px; flex: 0 0 auto; margin-top: 3px; }
.enquiry-form .btn,
.enquiry-form button[type="submit"] { font-family: Figtree, Arial, sans-serif !important; font-size: 14px; font-weight: 700; }
.static-form-message { margin-top: 12px; font-size: 14px; color: #155724; }
.static-form-message--error { color: #b42318; }

.eligibility-section { background: #f7f9fc; }
.eligibility-layout { display: grid; grid-template-columns: minmax(320px, .45fr) minmax(0, .55fr); gap: 28px; align-items: start; }
.eligibility-left { display: grid; gap: 18px; }
.eligibility-image { width: 100%; height: 360px; object-fit: cover; border-radius: 14px; box-shadow: var(--shadow); }
.eligibility-right { background: #fff; border: 1px solid #dbe6f3; border-radius: 14px; padding: 30px; box-shadow: var(--shadow); }
.eligibility-right h2 { font-size: clamp(28px, 3vw, 38px); line-height: 1.18; margin: 0 0 14px; color: #082b5f; }
.eligibility-card, .info-card, .notice-card, .soft-card, .spot-final-note { background: #fff; border: 1px solid #dbe6f3; border-radius: 10px; padding: 22px; box-shadow: var(--shadow); }
.eligibility-card { box-shadow: none; background: #f8fbff; margin-top: 16px; }
.eligibility-card h3, .info-card h3, .notice-card h3, .soft-card h3 { margin: 0 0 10px; color: #082b5f; }
.eligibility-card ul, .notice-card ul, .soft-card ul, .soft-card ol { margin: 0; padding-left: 20px; }
.eligibility-view-more { margin-top: 18px; padding: 11px 24px; border-radius: 12px; font-size: 14px; font-weight: 700; }
.eligibility-page-layout { display: block; }
.eligibility-page-section .eligibility-right { max-width: 100%; }
.eligibility-page-section .eligibility-right h1 { font-size: clamp(28px, 3vw, 38px); line-height: 1.18; margin: 0 0 14px; color: #082b5f; }
.eligibility-card-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; margin-top: 20px; }
.eligibility-card-grid .eligibility-card { margin-top: 0; }
.mobile-between-image { display: none; }
.phone-row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 12px; }
.phone-row a { background: #eef5ff; color: #082b5f; padding: 9px 12px; border-radius: 8px; text-decoration: none; font-weight: 700; }
.notice-card { border-color: #ffd6d6; background: #fffafa; }
.notice-card h3, .warning h3 { color: #d21f2b; }
.eligibility-more { font-weight: 700; color: #082b5f; }

.spot-admission-section { background: #fff; padding-top: 56px; }
.section-head { text-align: center; max-width: 820px; margin: 0 auto 28px; }
.section-head h1 { font-size: clamp(28px, 3vw, 38px); line-height: 1.15; margin: 0 0 16px; font-weight: 800; }
.admission-disclaimer { display: inline-block; margin-top: 14px; padding: 10px 14px; border: 1px solid #ffd6d6; border-radius: 12px; background: #fff7f7; color: #334155; font-size: 16px; line-height: 1.55; }
.admission-disclaimer strong { color: #d21f2b; }
.spot-admission-view-more { margin-top: 16px; padding: 11px 24px; border-radius: 12px; font-size: 14px; font-weight: 700; }
.two-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.mt { margin-top: 20px; }
.soft-card p { margin: 0; color: #334155; }
.spot-final-note { margin-top: 24px; background: #f8fafc; }
.spot-final-note p { margin: 0; color: #334155; }
.spot-final-note p + p { margin-top: 10px; }

.privacy-section { background: #f7f9fc; padding: 64px 0; }
.privacy-card { background: #fff; border: 1px solid #dbe6f3; border-radius: 14px; padding: 34px; box-shadow: var(--shadow); }
.privacy-card h2 { margin: 30px 0 10px; color: #082b5f; font-size: 24px; line-height: 1.25; }
.privacy-card p, .privacy-card li { color: #263241; font-size: 18px; line-height: 1.75; }
.privacy-card p { margin: 0 0 16px; }
.privacy-card ul { margin: 0 0 16px; padding-left: 22px; }
.privacy-card a { color: #082b5f; font-weight: 700; }

.career-section { padding-top: 42px; background: #fff; }
.career-section .section-lead { max-width: 720px; margin-bottom: 42px; }
.career-copy { max-width: 980px; margin: 0 auto; text-align: center; color: var(--muted); font-size: 17px; line-height: 1.75; }
.career-copy p { margin: 0; }
.career-copy p + p { margin-top: 14px; }
.logo-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 46px 58px; align-items: center; }
.logo-grid img { width: 100%; max-width: 150px; max-height: 82px; object-fit: contain; margin: auto; }
.sector-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; max-width: 960px; margin: 0 auto; }
.sector-grid span { display: grid; place-items: center; min-height: 74px; padding: 16px; border: 1px solid #dbe6f3; border-radius: 12px; background: #fff; color: #082b5f; font-weight: 700; text-align: center; box-shadow: 0 10px 24px rgba(15, 23, 42, .05); }
.alumnus-section { background: #fff; }
.alumnus-section .rounded-media { height: 560px; border-radius: 14px; object-fit: cover; object-position: center; box-shadow: none; }
.alumnus-section .section-kicker { font-size: 20px; margin-bottom: 8px; }
.alumnus-section .large-list { margin-top: 24px; }
.alumnus-section .large-list li { padding-left: 40px; margin: 16px 0; color: #111; font-size: 18px; line-height: 1.55; }
.alumnus-section .large-list li:before { content: "✓"; top: 4px; width: 20px; height: 20px; border: 1.6px solid var(--red); border-radius: 50%; color: var(--red); font-size: 12px; line-height: 19px; text-align: center; background: #fff; }
.alumnus-section .large-list li:after { display: none; }
.contact-section { background: #f5f5f5; }
.contact-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 28px; align-items: stretch; }
.contact-list { display: grid; gap: 18px; }
.contact-list div { background: #fff; border-radius: 12px; padding: 20px; box-shadow: var(--shadow); }
.contact-list strong { display: block; color: #082b5f; margin-bottom: 6px; }
.contact-list p { margin: 0; }
.map-frame { width: 100%; min-height: 520px; border: 0; border-radius: 20px; box-shadow: var(--shadow); }
.thank-you-section { background: #f7f9fc; padding: 72px 0; }
.thank-you-card { max-width: 760px; margin: 0 auto; text-align: center; background: #fff; border: 1px solid #dbe6f3; border-radius: 18px; padding: 42px 28px; box-shadow: var(--shadow); }
.thank-you-icon { display: grid; place-items: center; width: 70px; height: 70px; margin: 0 auto 20px; border-radius: 50%; background: var(--red); color: #fff; font-size: 34px; font-weight: 800; }
.thank-you-card h1 { margin: 0 0 14px; color: var(--navy); font-size: clamp(30px, 4vw, 44px); line-height: 1.12; }
.thank-you-card p { margin: 0 auto 24px; max-width: 620px; color: #334155; }
.thank-you-actions { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; }

.testimonials-section { background: #fff; }
.testimonial-shell { position: relative; padding: 0 54px; }
.testimonial-slider { overflow: hidden; padding: 0 10px 28px; }
.testimonial-track { display: flex; gap: 18px; transition: transform 1000ms ease; }
.testimonial-card { flex: 0 0 calc((100% - 56px) / 3); background: #fff; border: 1px solid #dbe3ee; border-radius: 14px; padding: 24px; box-shadow: none; }
.testimonial-arrow { position: absolute; top: 50%; transform: translateY(-50%); width: 42px; height: 42px; border: 1px solid #cbd5e1; border-radius: 50%; background: #fff; color: #111; font-size: 30px; line-height: 1; display: grid; place-items: center; cursor: pointer; box-shadow: none; z-index: 2; transition: border-color .2s ease, color .2s ease, transform .2s ease; }
.testimonial-arrow:hover { border-color: #94a3b8; color: var(--red); transform: translateY(-50%) scale(1.04); }
.testimonial-arrow-prev { left: 0; }
.testimonial-arrow-next { right: 0; }
.stars { color: #ffb400; letter-spacing: 2px; }
.testimonial-author { display: flex; align-items: center; gap: 12px; margin-top: 18px; }
.testimonial-author img { width: 62px; height: 62px; border-radius: 50%; object-fit: cover; }
.testimonial-author span { display: block; color: #64748b; font-size: 14px; }

.admissions-cta-section { background: #fff; padding: 34px 0 58px; }
.admissions-cta-card { display: block; text-align: left; text-decoration: none; color: var(--navy); border: 1px solid #dbe6f3; border-radius: 18px; padding: 28px 32px; background: linear-gradient(135deg, #fff 0%, #f8fbff 60%, #fff2f5 100%); box-shadow: var(--shadow); transition: transform .2s ease, border-color .2s ease; }
.admissions-cta-card:hover { border-color: #ffc5cf; transform: translateY(-2px); }
.admissions-cta-kicker { display: inline-block; margin-bottom: 10px; color: var(--red); font-size: 22px; line-height: 1.2; font-weight: 800; }
.admissions-cta-card p { margin: 0 0 14px; color: var(--navy); font-size: 20px; line-height: 1.4; font-weight: 500; }
.admissions-course-links { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px 22px; margin: 0; padding: 0; list-style: none; }
.admissions-course-links a { display: block; color: var(--navy); text-decoration: none; font-size: 18px; line-height: 1.38; font-weight: 500; }
.admissions-course-links a:hover { color: var(--red); }
.admissions-cta-action { display: inline-flex; align-items: center; justify-content: center; margin-top: 18px; min-height: 45px; padding: 12px 24px; border-radius: 12px; background: var(--red); color: #fff; font-size: 16px; line-height: 1; font-weight: 800; }

.site-footer { background: #191919; color: #fff; padding: 56px 0 0; }
.footer-grid { display: grid; grid-template-columns: 1.35fr .7fr .7fr 1.7fr; gap: 48px; align-items: start; }
.footer-logo { width: 330px; max-width: 100%; margin-bottom: 28px; }
.site-footer h3 { margin: 0 0 18px; color: #fff; font-size: 20px; line-height: 1.2; }
.site-footer a { color: #fff; text-decoration: none; }
.footer-links a { display: block; width: max-content; margin: 0 0 11px; font-size: 18px; line-height: 1.25; }
.footer-about p { max-width: 345px; margin: 0; color: #fff; font-size: 20px; line-height: 1.42; }
.footer-about .footer-highlight { margin-top: 40px; color: var(--red); font-size: 17px; line-height: 1.3; }
.footer-qr img { width: 92px; height: 92px; object-fit: cover; background: #fff; padding: 4px; }
.footer-contact p { display: grid; grid-template-columns: 30px minmax(0, 1fr); gap: 15px; align-items: start; margin: 0 0 17px; color: #fff; font-size: 18px; line-height: 1.55; }
.footer-contact-icon { display: grid; place-items: start center; width: 28px; height: 28px; margin-top: 2px; }
.footer-contact-icon img { width: 24px; height: 24px; object-fit: contain; }
.footer-support { display: flex; flex-wrap: nowrap; gap: 0; margin-top: 22px; font-size: 15px; color: #fff; white-space: nowrap; }
.footer-support span { padding-right: 14px; }
.footer-support span + span { position: relative; padding-left: 14px; }
.footer-support span + span:before { content: ""; position: absolute; left: 0; top: 50%; width: 1px; height: 14px; background: rgba(255, 255, 255, .7); transform: translateY(-50%); }
.footer-policy { display: inline-block; margin-top: 24px; font-size: 16px; }
.footer-policy-links { display: flex; flex-wrap: wrap; gap: 10px 18px; margin-top: 24px; font-size: 16px; }
.footer-bottom { text-align: center; border-top: 1px solid rgba(255, 255, 255, .12); padding: 16px; margin-top: 34px; color: #d1d5db; font-size: 14px; }

.side-actions { position: fixed; right: 22px; bottom: 34px; z-index: 60; width: 130px; background: var(--red); border-radius: 8px; overflow: hidden; box-shadow: none; }
.side-actions a { display: flex; align-items: center; gap: 6px; color: #fff; text-decoration: none; padding: 7px 12px; border-bottom: 1px solid rgba(255, 255, 255, .65); font-size: 14px; line-height: 1.15; font-weight: 600; }
.side-icon { flex: 0 0 15px; width: 15px; height: 15px; display: inline-grid; place-items: center; color: #fff; font-family: "Font Awesome 5 Free"; font-weight: 900; font-size: 13px; line-height: 1; }
.side-icon-courses:before { content: "\f03a"; }
.side-icon-call:before { content: "\f095"; }
.side-icon-enquiry:before { content: "\f0e0"; }
.side-icon-admissions:before { content: "\f19d"; }
.side-actions a:last-child { border-bottom: 0; }
.quick-contact { position: fixed; left: 30px; bottom: 30px; z-index: 70; display: grid; gap: 10px; }
.quick-row { display: flex; align-items: center; gap: 12px; }
.quick-icon { width: 50px; height: 50px; border-radius: 9px; display: grid; place-items: center; color: #fff; text-decoration: none; font-size: 25px; box-shadow: none; }
.quick-icon img { width: 27px; height: 27px; object-fit: contain; }
.quick-icon.whatsapp { background: #25d366; }
.quick-icon.whatsapp img { filter: brightness(0) invert(1); }
.quick-icon.phone { background: #258be6; border-radius: 50%; }
.fa-phone-icon {
    display: inline-block;
    color: #fff !important;
    background: transparent !important;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 24px;
    line-height: 1;
    padding: 11px 15px !important;
    box-shadow: none !important;
}
.fa-phone-icon:before { content: "\f095"; }
.quick-row span { background: #fff; border-radius: 8px; padding: 11px 22px; box-shadow: var(--shadow); font-size: 16px; color: #333; }
.back-to-top { position: fixed; right: 62px; bottom: 174px; width: 50px; height: 50px; border-radius: 50%; border: 0; background: #07336f; color: #fff; font-size: 32px; line-height: 1; opacity: 0; pointer-events: none; transition: .2s; z-index: 70; }
.back-to-top.is-visible { opacity: 1; pointer-events: auto; }

@media (max-width: 1024px) {
  .header-contact { display: none; }
  .nav-toggle { display: block; }
  .site-nav { display: none; position: absolute; left: 16px; right: 16px; top: 96px; background: #fff; border: 1px solid #e5e7eb; border-radius: 14px; padding: 12px; box-shadow: var(--shadow); flex-direction: column; }
  .site-nav.is-open { display: flex; }
  .hero-grid, .split-grid, .contact-grid { grid-template-columns: 1fr; }
  #about-us .split-grid { grid-template-columns: 1fr; }
  #about-us .rounded-media { height: 430px; }
  .university-section .rounded-media { height: 460px; }
  .alumnus-section .rounded-media { height: 460px; }
  .split-grid-reverse > img { order: 0; }
  .why-choose-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .testimonial-card { flex-basis: calc((100% - 38px) / 2); }
  .footer-grid { grid-template-columns: 1.2fr .8fr; gap: 34px; }
  .logo-grid { grid-template-columns: repeat(3, 1fr); gap: 34px; }
  .sector-grid { grid-template-columns: repeat(2, 1fr); }
  .eligibility-card-grid { grid-template-columns: 1fr; }
}

@media (max-width: 760px) {
  .container, .narrow { width: min(100% - 24px, 1300px); }
  .header-inner { min-height: 76px; }
  .brand img { width: 205px; }
  .site-nav { top: 76px; }
  .hero { padding: 16px 0 34px; }
  .hero-grid { gap: 20px; }
  .hero-card { order: -1; display: flex; flex-direction: column; gap: 14px; padding: 14px 12px 18px; border: 1px solid #dbe6f3; border-radius: 20px; background: #fff; box-shadow: 0 14px 34px rgba(4, 41, 98, .08); }
  .hero-card > p,
  .hero-card > h2 { display: none; }
  .mobile-apply-content { order: -2; display: block; text-align: center; margin-bottom: 2px; }
  .mobile-apply-content .mobile-apply-kicker { display: block; color: var(--red); font-size: 24px; line-height: 1.1; font-weight: 800; margin: 0 0 10px; }
  .mobile-apply-content h2 { color: #111; font-size: 26px; line-height: 1.12; margin: 0 0 12px; font-weight: 800; }
  .mobile-apply-content p { color: #1f2937; font-size: 18px; line-height: 1.45; margin: 0 0 6px; font-weight: 500; }
  .hero-card img { order: -1; width: 100%; margin: 0 auto 8px; border-radius: 18px; box-shadow: 0 10px 24px rgba(4, 41, 98, .12); }
  .mobile-apply-details { order: 0; display: block; text-align: center; margin-top: 0; }
  .mobile-apply-details p { color: #1f2937; font-size: 18px; line-height: 1.45; margin: 0 0 14px; font-weight: 500; }
  .mobile-apply-details .mobile-course-list { margin: 4px 0 18px; padding: 14px 12px; border: 1px solid #ffd5dc; border-radius: 16px; background: #fff7f8; color: var(--navy); font-size: 18px; line-height: 1.38; font-weight: 800; box-shadow: inset 4px 0 0 var(--red); }
  .mobile-hero-actions { order: 1; display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 2px; }
  .mobile-hero-actions .btn { min-height: 48px; padding: 12px 14px; border-radius: 12px; font-size: 16px; }
  .mobile-hero-actions .btn-dark { background: var(--navy); border-color: var(--navy); }
  .hero-copy .btn-dark { background: var(--red); border-color: var(--red); }
  .hero-card h2 { margin-bottom: 0; }
  .hero .eyebrow { font-size: 26px !important; line-height: 1.25; padding: 12px 16px; font-weight: 800; }
  .hero-copy { text-align: center; }
  .hero h1 { font-size: 31px; text-align: center; }
  .section-title { font-size: 26px; line-height: 1.18; }
  .section-kicker { font-size: 17px; line-height: 1.35; }
  .courses-section .section-kicker { font-size: 24px; font-weight: 700; }
  .courses-section .section-title { font-size: 32px; line-height: 1.12; }
  .courses-section .section-lead { font-size: 20px; line-height: 1.55; }
  .split-section h2, .contact-section h2, .section-head h2 { font-size: 27px; line-height: 1.18; }
  .form-grid, .two-grid, .eligibility-layout, .footer-grid, .why-choose-grid { grid-template-columns: 1fr; }
  .why-choose-section { padding: 28px 0; }
  .why-choose-panel { padding: 26px 18px; border-radius: 16px; }
  .why-choose-item { min-height: 58px; padding: 13px; font-size: 15px; }
  .mobile-between-image { display: block; padding: 0 0 20px; background: #f7f9fc; }
  .mobile-between-image img { width: 100%; border-radius: 16px; object-fit: cover; box-shadow: var(--shadow); }
  .mobile-why-image { padding: 20px 0 28px; background: linear-gradient(180deg, #f4f3f2 0%, #f7f9fc 100%); }
  .mobile-campus-card { position: relative; margin: 0; padding: 10px; border: 1px solid #dbe6f3; border-radius: 20px; background: #fff; box-shadow: 0 14px 28px rgba(4, 41, 98, .12); }
  .mobile-campus-card img { height: 178px; border-radius: 14px; object-fit: cover; object-position: center; box-shadow: none; }
  .mobile-campus-card figcaption { position: absolute; left: 22px; bottom: 20px; max-width: calc(100% - 44px); padding: 7px 12px; border-radius: 999px; background: rgba(4, 41, 98, .92); color: #fff; font-size: 13px; line-height: 1.2; font-weight: 700; box-shadow: 0 8px 18px rgba(4, 41, 98, .22); }
  .split-section, .courses-section, .form-section, .eligibility-section, .spot-admission-section, .career-section, .contact-section, .testimonials-section { padding: 38px 0; }
  #about-us { padding: 38px 0; }
  #about-us .rounded-media { height: 330px; }
  #about-us h2 { font-size: 28px; line-height: 1.14; }
  #about-us p:not(.section-kicker) { font-size: 18px; line-height: 1.62; }
  #about-us .check-list li { display: grid; grid-template-columns: 16px minmax(0, 1fr); gap: 10px; padding-left: 0; align-items: start; }
  #about-us .check-list li:before { position: static; margin-top: 5px; }
  .university-section .split-grid-reverse > img { order: -1; }
  .university-section .rounded-media { height: 360px; }
  .alumnus-section .rounded-media { height: 360px; }
  .alumnus-section .large-list li { font-size: 18px; padding-left: 40px; margin: 13px 0; }
  .course-banner-section { padding: 4px 0 30px; }
  .course-banner-section img { border-radius: 12px; }
  .course-banner-section h2 { font-size: 22px; }
  .course-card { padding: 16px; }
  .course-card-head { align-items: flex-start; flex-direction: column; gap: 10px; }
  .course-degree h3 { font-size: 27px; }
  .course-duration strong { font-size: 24px; font-weight: 400; }
  .course-tags { grid-template-columns: 1fr; gap: 9px; }
  .eligibility-image { height: 300px; }
  .eligibility-right, .enquiry-form { padding: 20px 16px; }
  .eligibility-right h2 { font-size: 26px; line-height: 1.18; }
  .privacy-section { padding: 38px 0; }
  .privacy-card { padding: 22px 16px; }
  .privacy-card h2 { font-size: 21px; }
  .privacy-card p, .privacy-card li { font-size: 18px; }
  .logo-grid { grid-template-columns: repeat(2, 1fr); gap: 26px 22px; }
  .logo-grid img { max-width: 128px; max-height: 70px; }
  .sector-grid { grid-template-columns: 1fr; gap: 12px; }
  .map-frame { min-height: 360px; }
  .testimonial-card { flex-basis: calc(100% - 20px); }
  .admissions-cta-section { padding: 28px 0 42px; }
  .admissions-cta-card { padding: 22px 16px; border-radius: 16px; }
  .admissions-cta-kicker { font-size: 19px; margin-bottom: 8px; }
  .admissions-cta-card p { font-size: 18px; margin-bottom: 12px; }
  .admissions-course-links { grid-template-columns: 1fr; gap: 9px; }
  .admissions-course-links a { font-size: 18px; line-height: 1.35; }
  .admissions-cta-action { min-height: 44px; padding: 12px 22px; font-size: 15px; }
  .site-footer { padding-top: 38px; }
  .site-footer { padding-bottom: 190px; }
  .footer-grid { gap: 30px; }
  .footer-logo { width: 280px; margin-bottom: 20px; }
  .footer-about p { font-size: 18px; }
  .footer-about .footer-highlight { margin-top: 24px; }
  .footer-links a { font-size: 17px; }
  .footer-support { display: grid; gap: 8px; }
  .footer-support span + span { padding-left: 0; }
  .footer-support span + span:before { display: none; }
  .testimonial-shell { padding: 0 42px; }
  .testimonial-arrow { width: 34px; height: 34px; font-size: 25px; }
  .side-actions { right: 16px; bottom: 22px; width: 130px; }
  .side-actions a { font-size: 13px; padding: 7px 11px; }
  .quick-contact { left: 18px; bottom: 20px; gap: 10px; }
  .quick-icon { width: 50px; height: 50px; font-size: 25px; }
  .quick-icon img { width: 27px; height: 27px; }
  .quick-row span { font-size: 16px; padding: 11px 22px; }
  .back-to-top { width: 50px; height: 50px; font-size: 31px; right: 56px; bottom: 160px; }
  .course-accordion summary { padding: 18px; font-size: 18px; }
  .spot-admission-section { padding-top: 34px; }
  .career-section { padding-top: 20px; }
}
