/*
Theme Name: Agastya Ayurveda
Theme URI: https://agastyayukoppal.org/
Author: Agastya Ayurveda Medical College and Hospital
Description: A fast, accessible custom theme for Agastya Ayurveda Medical College and Hospital.
Version: 1.7.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: agastya-ayurveda
*/

:root {
	--forest: #123f32;
	--forest-2: #1d5b47;
	--leaf: #8eb65b;
	--saffron: #d69a36;
	--cream: #f7f3e9;
	--ink: #17231e;
	--muted: #607068;
	--line: #dfe7e2;
	--white: #fff;
	--shadow: 0 18px 50px rgba(18, 63, 50, .12);
	--radius: 18px;
	--wrap: min(1180px, calc(100% - 32px));
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: #fff; font: 16px/1.7 Arial, Helvetica, sans-serif; }
body.admin-bar .site-header { top: 32px; }
img { max-width: 100%; height: auto; }
a { color: var(--forest-2); text-decoration-thickness: 1px; text-underline-offset: 3px; }
h1, h2, h3, h4 { margin: 0 0 .65em; color: var(--forest); font-family: Georgia, "Times New Roman", serif; line-height: 1.15; }
h1 { font-size: clamp(2.35rem, 6vw, 4.75rem); }
h2 { font-size: clamp(2rem, 4vw, 3.2rem); }
h3 { font-size: 1.4rem; }
p { margin: 0 0 1.25em; }
.wrap { width: var(--wrap); margin-inline: auto; }
.screen-reader-text { position: absolute; width: 1px; height: 1px; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); }
.skip-link:focus { z-index: 99999; top: 10px; left: 10px; width: auto; height: auto; padding: 10px 16px; clip: auto; color: #fff; background: var(--forest); }

.topbar { padding: 8px 0; color: #e7f0eb; background: #0d3026; font-size: .83rem; }
.topbar .wrap, .brand-row, .nav-row, .footer-bottom .wrap { display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.topbar-links { display: flex; flex-wrap: wrap; gap: 18px; }
.topbar a { color: #fff; text-decoration: none; }
.site-header { position: sticky; z-index: 1000; top: 0; background: rgba(255,255,255,.98); box-shadow: 0 8px 30px rgba(13,48,38,.08); backdrop-filter: blur(15px); }
.brand-row { min-height: 100px; }
.brand { display: flex; align-items: center; gap: 13px; color: var(--forest); text-decoration: none; }
.brand img { width: 76px; height: 76px; object-fit: contain; }
.brand-name { display: block; max-width: 560px; font: 700 clamp(1.1rem, 2vw, 1.45rem)/1.2 Georgia, serif; }
.brand-tag { display: block; margin-top: 4px; color: var(--muted); font-size: .78rem; letter-spacing: .12em; text-transform: uppercase; }
.brand-actions { display: flex; align-items: center; gap: 24px; }
.accreditation { display: grid; gap: 2px; color: var(--muted); font-size: .76rem; text-align: right; }
.accreditation strong { color: var(--forest); font-size: .87rem; }
.nav-shell { background: var(--forest); }
.nav-row { min-height: 52px; }
.nav-toggle { display: none; padding: 10px 14px; color: #fff; background: transparent; border: 1px solid rgba(255,255,255,.35); border-radius: 8px; font-weight: 700; }
.site-nav { flex: 1; min-width: 0; }
.site-nav ul { display: flex; align-items: center; gap: 3px; margin: 0; padding: 0; list-style: none; }
.site-nav li { position: relative; }
.site-nav a { display: block; padding: 14px 10px; color: #fff; text-decoration: none; font-size: .81rem; font-weight: 700; white-space: nowrap; }
.site-nav a:hover, .site-nav .current-menu-item > a, .site-nav .current-menu-ancestor > a { color: #fff; background: rgba(255,255,255,.12); }
.site-nav .sub-menu { position: absolute; top: 100%; left: 0; display: none; min-width: 250px; padding: 8px; background: #fff; border: 1px solid var(--line); border-radius: 0 0 12px 12px; box-shadow: var(--shadow); }
.site-nav .sub-menu .sub-menu { top: -8px; left: 100%; }
.site-nav li:hover > .sub-menu, .site-nav li:focus-within > .sub-menu { display: block; }
.site-nav .sub-menu a { padding: 9px 11px; color: var(--ink); font-size: .84rem; white-space: normal; }
.site-nav .sub-menu a:hover { color: var(--forest); background: var(--cream); }

.button, .wp-element-button, input[type="submit"], button[type="submit"] { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 13px 21px; color: #fff; background: var(--forest-2); border: 0; border-radius: 999px; font-weight: 700; text-decoration: none; cursor: pointer; transition: .2s ease; }
.button:hover, .wp-element-button:hover, input[type="submit"]:hover { color: #fff; background: var(--forest); transform: translateY(-2px); }
.button-light { color: var(--forest); background: #fff; }
.button-outline { color: #fff; background: transparent; border: 1px solid rgba(255,255,255,.55); }
.button-sm { padding: 9px 15px; font-size: .84rem; }

.hero { position: relative; isolation: isolate; min-height: 650px; overflow: hidden; color: #fff; background: linear-gradient(115deg, #0c3025 0%, #18513f 54%, #32765c 100%); }
.hero::before { position: absolute; z-index: -1; inset: 0; content: ""; opacity: .12; background-image: radial-gradient(circle at 15% 15%, #fff 1px, transparent 1px); background-size: 22px 22px; }
.hero .wrap { display: grid; grid-template-columns: 1.05fr .95fr; align-items: center; min-height: 650px; padding-block: 70px; }
.eyebrow { display: inline-flex; align-items: center; gap: 8px; margin-bottom: 18px; color: var(--saffron); font-size: .78rem; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; }
.eyebrow::before { width: 32px; height: 2px; content: ""; background: currentColor; }
.hero h1 { max-width: 760px; color: #fff; }
.hero p { max-width: 650px; color: #dcebe4; font-size: 1.08rem; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.hero-visual { align-self: end; filter: drop-shadow(0 25px 40px rgba(0,0,0,.3)); }
.hero-visual img { display: block; width: 115%; max-width: none; transform: translateX(-7%); }
.trust-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 36px; }
.trust-item { padding: 15px; border: 1px solid rgba(255,255,255,.18); border-radius: 13px; background: rgba(255,255,255,.07); }
.trust-item strong { display: block; color: #fff; font-size: 1.15rem; }
.trust-item span { color: #c6d9d0; font-size: .78rem; }

.notice-bar { position: relative; z-index: 3; margin-top: -28px; }
.notice-inner { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 18px; padding: 19px 24px; background: #fff; border-left: 5px solid var(--saffron); border-radius: 14px; box-shadow: var(--shadow); }
.notice-label { color: var(--forest); font-weight: 800; }
.notice-text { color: var(--muted); }
.notice-text a { font-weight: 700; }

.section { padding: 92px 0; }
.section-soft { background: var(--cream); }
.section-green { color: #dce9e3; background: var(--forest); }
.section-green h2, .section-green h3 { color: #fff; }
.section-head { display: flex; align-items: end; justify-content: space-between; gap: 30px; margin-bottom: 38px; }
.section-head p { max-width: 590px; margin: 0; color: var(--muted); }
.section-green .section-head p { color: #c4d6ce; }
.intro-grid { display: grid; grid-template-columns: .95fr 1.05fr; align-items: center; gap: clamp(40px, 7vw, 90px); }
.intro-image { position: relative; min-height: 440px; border-radius: 28px; background: #dce8e2 url("../../uploads/2024/09/Slider-1-1.png") center bottom / contain no-repeat; box-shadow: var(--shadow); }
.intro-image::after { position: absolute; right: -20px; bottom: -20px; width: 150px; height: 150px; content: ""; border: 2px solid var(--saffron); border-radius: 50%; z-index: -1; }
.check-list { display: grid; gap: 10px; padding: 0; list-style: none; }
.check-list li { position: relative; padding-left: 28px; }
.check-list li::before { position: absolute; left: 0; color: var(--leaf); content: "\2713"; font-weight: 900; }

.card-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.card { padding: 28px; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); box-shadow: 0 8px 30px rgba(18,63,50,.06); transition: .22s ease; }
.card:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.card-icon { display: grid; place-items: center; width: 48px; height: 48px; margin-bottom: 20px; color: #fff; background: var(--forest-2); border-radius: 14px; font-family: Georgia, serif; font-size: 1.25rem; font-weight: 700; }
.card p { color: var(--muted); font-size: .94rem; }
.card-link { font-weight: 800; text-decoration: none; }
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; overflow: hidden; background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.15); border-radius: 20px; }
.stat { padding: 34px 22px; background: var(--forest); text-align: center; }
.stat strong { display: block; margin-bottom: 4px; color: #fff; font: 700 2.5rem/1 Georgia, serif; }
.stat span { color: #c5d7cf; font-size: .85rem; }

.cta { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 30px; padding: clamp(30px, 5vw, 55px); color: #fff; background: linear-gradient(120deg, var(--forest), var(--forest-2)); border-radius: 24px; box-shadow: var(--shadow); }
.cta h2 { color: #fff; }
.cta p { max-width: 680px; margin: 0; color: #d6e5de; }
.cta-actions { display: flex; flex-wrap: wrap; gap: 10px; }

.page-hero { padding: 72px 0; color: #fff; background: linear-gradient(115deg, #0d3026, #24634e); }
.page-hero-compact { padding: 58px 0 62px; }
.page-hero h1 { color: #fff; font-size: clamp(2.2rem, 5vw, 4rem); }
.page-hero p { max-width: 680px; margin: 0; color: #d4e4dc; }
.breadcrumbs { margin-bottom: 12px; color: #cbdcd4; font-size: .84rem; }
.breadcrumbs a { color: #fff; }
.content-layout { display: grid; grid-template-columns: minmax(0, 1fr) 270px; gap: 50px; }
.entry-content { min-width: 0; }
.entry-content > *:first-child { margin-top: 0; }
.entry-content h2, .entry-content h3 { margin-top: 1.4em; }
.entry-content table { width: 100%; border-collapse: collapse; font-size: .9rem; }
.entry-content th, .entry-content td { padding: 10px; border: 1px solid var(--line); text-align: left; }
.entry-content th { color: #fff; background: var(--forest); }
.entry-content tr:nth-child(even) { background: #f5f8f6; }
.entry-content iframe, .entry-content object { max-width: 100%; border: 1px solid var(--line); border-radius: 12px; }
.entry-content input, .entry-content textarea, .entry-content select { max-width: 100%; padding: 12px; border: 1px solid #cbd6d0; border-radius: 8px; }
.side-card { position: sticky; top: 125px; padding: 24px; background: var(--cream); border-radius: 16px; }
.side-card a { display: block; padding: 8px 0; border-bottom: 1px solid #dce3dc; font-weight: 700; text-decoration: none; }

.contact-section { background: linear-gradient(#fff 0 38%, var(--cream) 38% 100%); }
.contact-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 65px; }
.contact-card { display: flex; flex-direction: column; align-items: flex-start; padding: 28px; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); }
.contact-card p { color: var(--muted); }
.contact-card a { display: block; overflow-wrap: anywhere; font-weight: 700; text-decoration: none; }
.contact-card .card-link { margin-top: auto; padding-top: 16px; color: var(--forest-2); }
.contact-icon { display: grid; place-items: center; width: 48px; height: 48px; margin-bottom: 18px; color: #fff; background: var(--forest-2); border-radius: 14px; font: 700 1.1rem Georgia, serif; }
.contact-main { display: grid; grid-template-columns: .75fr 1.25fr; gap: clamp(35px, 7vw, 85px); align-items: start; }
.contact-copy { padding-top: 28px; }
.contact-hours { display: grid; grid-template-columns: auto 1fr; gap: 10px 18px; margin-top: 30px; padding-top: 24px; border-top: 1px solid #d7dfda; }
.contact-hours strong { color: var(--forest); }
.contact-hours span { color: var(--muted); text-align: right; }
.contact-form-card { padding: clamp(24px, 4vw, 42px); background: #fff; border: 1px solid var(--line); border-radius: 20px; box-shadow: var(--shadow); }
.contact-form-card .wpforms-container { margin: 0; }
.contact-form-card .wpforms-field { padding: 0 0 18px !important; }
.contact-form-card .wpforms-field-label { margin-bottom: 7px !important; color: var(--forest) !important; font-weight: 700 !important; }
.contact-form-card input:not([type="submit"]), .contact-form-card textarea, .contact-form-card select { width: 100% !important; max-width: none !important; padding: 13px 14px !important; background: #fbfcfb !important; border: 1px solid #cbd7d0 !important; border-radius: 9px !important; font: inherit !important; }
.contact-form-card textarea { min-height: 130px; }
.contact-form-card button[type="submit"] { min-width: 150px; }

.leadership-section { background: linear-gradient(90deg, #fff 0 68%, var(--cream) 68% 100%); }
.leadership-layout { display: grid; grid-template-columns: minmax(0, 1.45fr) minmax(280px, .55fr); gap: clamp(35px, 7vw, 90px); align-items: start; }
.message-card { position: relative; padding: clamp(30px, 5vw, 58px); background: #fff; border: 1px solid var(--line); border-radius: 24px; box-shadow: var(--shadow); }
.message-card p { color: #35453d; font-size: 1.05rem; line-height: 1.9; }
.message-card .message-lead { color: var(--forest); font: 700 clamp(1.25rem, 2.4vw, 1.65rem)/1.55 Georgia, serif; }
.quote-mark { position: absolute; top: -25px; left: 35px; color: var(--saffron); font: 700 6rem/1 Georgia, serif; }
.leader-signature { display: flex; align-items: center; gap: 16px; margin-top: 36px; padding-top: 28px; border-top: 1px solid var(--line); }
.signature-mark { display: grid; flex: 0 0 58px; place-items: center; width: 58px; height: 58px; color: #fff; background: var(--forest); border-radius: 50%; font: 700 1rem Georgia, serif; }
.leader-signature strong, .leader-signature span, .leader-signature small { display: block; }
.leader-signature strong { color: var(--forest); font: 700 1.25rem Georgia, serif; }
.leader-signature span { color: var(--saffron); font-weight: 800; }
.leader-signature small { max-width: 430px; color: var(--muted); }
.leadership-aside { position: sticky; top: 190px; padding-top: 22px; }
.leadership-aside h2 { font-size: clamp(2rem, 4vw, 2.7rem); }
.leadership-aside .button { margin-top: 20px; }

.principal-section { background: #fff; }
.principal-intro { display: grid; grid-template-columns: minmax(360px, .82fr) minmax(0, 1.18fr); gap: clamp(35px, 7vw, 85px); align-items: start; }
.principal-portrait { position: sticky; top: 190px; overflow: hidden; margin: 0; background: var(--forest); border-radius: 22px; box-shadow: var(--shadow); }
.principal-portrait img { display: block; width: 100%; aspect-ratio: 16 / 10; object-fit: cover; }
.principal-portrait figcaption { display: grid; gap: 3px; padding: 22px 24px; color: #d8e6df; }
.principal-portrait strong { color: #fff; font: 700 1.35rem Georgia, serif; }
.principal-portrait span { color: var(--saffron); font-weight: 800; }
.principal-portrait small { color: #c5d8cf; }
.principal-message { position: relative; padding-top: 25px; }
.principal-message p { color: #35453d; font-size: 1.03rem; line-height: 1.85; }
.principal-message .message-lead { color: var(--forest); font: 700 clamp(1.3rem, 2.5vw, 1.75rem)/1.55 Georgia, serif; }
.principal-message .quote-mark { top: -28px; left: -24px; opacity: .8; }
.principal-signoff { display: grid; gap: 2px; margin-top: 32px; padding: 22px 24px; background: var(--cream); border-left: 4px solid var(--saffron); border-radius: 0 12px 12px 0; }
.principal-signoff strong { color: var(--forest); font: 700 1.2rem Georgia, serif; }
.principal-signoff span { color: var(--forest-2); font-weight: 800; }
.principal-signoff small { color: var(--muted); }
.principal-pillars { padding: 38px 0; color: #fff; background: var(--forest); }
.principal-pillars .wrap { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: rgba(255,255,255,.15); }
.pillar { display: grid; gap: 5px; padding: 24px 28px; background: var(--forest); }
.pillar strong { color: #fff; font: 700 1.15rem Georgia, serif; }
.pillar span { color: #c7d9d0; font-size: .88rem; }

.staff-section { background: #f8faf8; }
.staff-lead { display: grid; grid-template-columns: 120px 1fr auto; align-items: center; gap: 28px; margin-bottom: 34px; padding: 28px; color: #d7e5de; background: linear-gradient(120deg, var(--forest), var(--forest-2)); border-radius: 22px; box-shadow: var(--shadow); }
.staff-lead img { width: 120px; height: 140px; object-fit: cover; object-position: top; border: 4px solid rgba(255,255,255,.75); border-radius: 15px; }
.staff-lead h2 { margin-bottom: 6px; color: #fff; font-size: 2rem; }
.staff-lead strong { color: var(--saffron); }
.staff-lead p { margin: 7px 0 0; color: #d3e2da; }
.department-nav { display: flex; gap: 8px; margin-bottom: 65px; padding-bottom: 12px; overflow-x: auto; scrollbar-width: thin; }
.department-nav a { flex: 0 0 auto; padding: 8px 13px; color: var(--forest); background: #fff; border: 1px solid var(--line); border-radius: 999px; font-size: .8rem; font-weight: 700; text-decoration: none; }
.department-nav a:hover { color: #fff; background: var(--forest-2); }
.staff-department { margin-bottom: 70px; scroll-margin-top: 190px; }
.staff-department-head { display: flex; align-items: end; justify-content: space-between; gap: 20px; margin-bottom: 24px; padding-bottom: 15px; border-bottom: 1px solid var(--line); }
.staff-department-head span { color: var(--saffron); font-size: .72rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.staff-department-head h2 { margin: 4px 0 0; font-size: clamp(1.8rem, 3vw, 2.5rem); }
.staff-department-head > strong { color: var(--muted); font-size: .8rem; }
.faculty-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.faculty-card { overflow: hidden; background: #fff; border: 1px solid var(--line); border-radius: 17px; box-shadow: 0 8px 24px rgba(18,63,50,.07); transition: .2s ease; }
.faculty-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.faculty-photo { height: 235px; overflow: hidden; background: linear-gradient(145deg, #edf3ef, #dbe7e0); }
.faculty-photo img { display: block; width: 100%; height: 100%; object-fit: contain; object-position: center bottom; }
.faculty-info { padding: 20px; }
.faculty-info > span { color: var(--saffron); font-size: .74rem; font-weight: 800; letter-spacing: .07em; text-transform: uppercase; }
.faculty-info h3 { margin: 5px 0 8px; font-size: 1.35rem; }
.faculty-info p { min-height: 3.4em; margin-bottom: 14px; color: var(--muted); font-size: .88rem; }
.faculty-info small { display: block; padding-top: 12px; color: var(--muted); border-top: 1px solid var(--line); }
.faculty-info small strong { color: var(--forest-2); }
.staff-disclosure { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 30px; padding: clamp(28px, 5vw, 48px); background: var(--cream); border-radius: 20px; }
.staff-disclosure h2 { margin-bottom: 8px; }
.staff-disclosure p { margin: 0; color: var(--muted); }

.overview-hero { position: relative; isolation: isolate; overflow: hidden; }
.overview-hero::after { position: absolute; z-index: -1; top: -180px; right: 8%; width: 470px; height: 470px; content: ""; border: 1px solid rgba(255,255,255,.13); border-radius: 50%; box-shadow: 0 0 0 60px rgba(255,255,255,.025), 0 0 0 120px rgba(255,255,255,.02); }
.overview-hero h1 { max-width: 880px; }
.overview-intro-section { background: #fff; }
.overview-intro { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(310px, .6fr); gap: clamp(45px, 8vw, 105px); align-items: center; }
.overview-copy h2 { max-width: 760px; }
.overview-lead { color: var(--forest); font: 700 clamp(1.15rem, 2vw, 1.4rem)/1.6 Georgia, serif; }
.overview-copy > p:not(.overview-lead) { max-width: 770px; color: var(--muted); }
.overview-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 16px; margin-top: 30px; }
.button-plain { padding-inline: 4px; color: var(--forest-2); background: transparent; }
.button-plain:hover { color: var(--forest); background: transparent; transform: translateX(3px); }
.recognition-panel { position: relative; overflow: hidden; padding: 30px; color: #d8e7df; background: var(--forest); border-radius: 22px; box-shadow: var(--shadow); }
.recognition-panel::after { position: absolute; right: -55px; bottom: -65px; width: 180px; height: 180px; content: ""; border: 28px solid rgba(255,255,255,.045); border-radius: 50%; }
.recognition-kicker { display: block; margin-bottom: 18px; color: var(--saffron); font-size: .72rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.recognition-item { position: relative; z-index: 1; display: grid; gap: 3px; padding: 17px 0; border-top: 1px solid rgba(255,255,255,.14); }
.recognition-item strong { color: #fff; font: 700 1.1rem Georgia, serif; }
.recognition-item span { color: #c5d8cf; font-size: .84rem; line-height: 1.55; }
.vision-mission-grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: 22px; }
.purpose-card { position: relative; overflow: hidden; padding: clamp(30px, 5vw, 52px); background: #fff; border: 1px solid var(--line); border-radius: 24px; box-shadow: 0 10px 35px rgba(18,63,50,.07); }
.purpose-card-vision { color: #deebe5; background: linear-gradient(145deg, var(--forest), var(--forest-2)); border: 0; }
.purpose-card-vision h3 { color: #fff; font-size: clamp(1.8rem, 3.2vw, 2.65rem); }
.purpose-card-vision p { color: #d0e0d8; }
.purpose-number { position: absolute; right: 25px; bottom: -20px; color: rgba(18,63,50,.055); font: 700 9rem/1 Georgia, serif; }
.purpose-card-vision .purpose-number { color: rgba(255,255,255,.055); }
.purpose-label { display: inline-block; margin-bottom: 22px; color: var(--saffron); font-size: .74rem; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; }
.purpose-card-mission h3 { max-width: 650px; font-size: clamp(1.65rem, 3vw, 2.3rem); }
.purpose-card-mission .check-list { position: relative; z-index: 1; margin-bottom: 0; color: var(--muted); }
.commitments-section { padding-top: 80px; }
.commitment-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.commitment-card { padding: 26px 24px; border-top: 3px solid var(--saffron); border-radius: 0 0 16px 16px; box-shadow: 0 8px 30px rgba(18,63,50,.07); }
.commitment-card > span { display: block; margin-bottom: 35px; color: var(--leaf); font: 700 .9rem Georgia, serif; }
.commitment-card h3 { font-size: 1.25rem; }
.commitment-card p { margin: 0; color: var(--muted); font-size: .9rem; line-height: 1.65; }
.overview-cta-section { padding-top: 0; }

.site-footer { color: #cbd9d2; background: #0c2b22; }
.footer-main { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 50px; padding: 65px 0; }
.site-footer h3 { color: #fff; font-size: 1.1rem; }
.site-footer a { color: #dce8e2; text-decoration: none; }
.site-footer ul { margin: 0; padding: 0; list-style: none; }
.site-footer li { margin-bottom: 8px; }
.footer-bottom { padding: 18px 0; background: #071d17; font-size: .82rem; }

@media (max-width: 1180px) {
	.nav-toggle { display: block; }
	.nav-row { min-height: 58px; }
	.site-nav { position: absolute; top: 100%; right: 16px; left: 16px; display: none; max-height: calc(100vh - 150px); overflow: auto; padding: 12px; background: #fff; border: 1px solid var(--line); border-radius: 0 0 14px 14px; box-shadow: var(--shadow); }
	.site-nav.is-open { display: block; }
	.site-nav ul { display: block; }
	.site-nav a { padding: 10px; color: var(--ink); white-space: normal; }
	.site-nav a:hover, .site-nav .current-menu-item > a, .site-nav .current-menu-ancestor > a { color: var(--forest); background: var(--cream); }
	.site-nav .sub-menu, .site-nav .sub-menu .sub-menu { position: static; display: block; padding: 0 0 0 14px; border: 0; box-shadow: none; }
	.card-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 800px) {
	body.admin-bar .site-header { top: 46px; }
	.topbar .wrap { justify-content: center; }
	.topbar-links { justify-content: center; gap: 8px 14px; }
	.topbar-note { display: none; }
	.brand-name { max-width: 230px; font-size: .95rem; }
	.brand-tag { display: none; }
	.brand img { width: 53px; height: 53px; }
	.brand-row { min-height: 75px; }
	.accreditation { display: none; }
	.brand-actions { gap: 8px; }
	.header-cta { display: none; }
	.hero, .hero .wrap { min-height: auto; }
	.hero .wrap, .intro-grid, .content-layout, .footer-main { grid-template-columns: 1fr; }
	.hero .wrap { padding: 65px 0 0; }
	.hero-visual { margin-top: 30px; }
	.hero-visual img { width: 100%; transform: none; }
	.trust-row, .stats { grid-template-columns: repeat(2, 1fr); }
	.notice-inner, .cta { grid-template-columns: 1fr; }
	.section { padding: 65px 0; }
	.section-head { display: block; }
	.card-grid { grid-template-columns: 1fr; }
	.intro-image { min-height: 330px; }
	.side-card { position: static; }
	.contact-cards, .contact-main { grid-template-columns: 1fr; }
	.contact-cards { margin-bottom: 45px; }
	.leadership-section { background: var(--cream); }
	.leadership-layout { grid-template-columns: 1fr; }
	.leadership-aside { position: static; }
	.principal-intro, .principal-pillars .wrap { grid-template-columns: 1fr; }
	.principal-portrait { position: static; }
	.staff-lead, .staff-disclosure { grid-template-columns: 1fr; }
	.faculty-grid { grid-template-columns: repeat(2, 1fr); }
	.overview-intro, .vision-mission-grid { grid-template-columns: 1fr; }
	.commitment-grid { grid-template-columns: repeat(2, 1fr); }
	.footer-main { gap: 30px; }
	.footer-bottom .wrap { display: block; text-align: center; }
}

@media (max-width: 480px) {
	.brand-name { max-width: 190px; font-size: .82rem; }
	.hero h1 { font-size: 2.35rem; }
	.trust-row { grid-template-columns: 1fr; }
	.stats { grid-template-columns: 1fr 1fr; }
	.stat { padding: 24px 10px; }
	.faculty-grid { grid-template-columns: 1fr; }
	.commitment-grid { grid-template-columns: 1fr; }
}
