/* ═══════════════════════════════════════════════════════════
   PGHM College Website — Global Styles
   Pure CSS. No frameworks. Netlify-ready static output.
   ═══════════════════════════════════════════════════════════ */

:root {
  --primary:                  #a43e00;
  --primary-container:        #ff6b1a;
  --primary-fixed:            #ffdbcd;
  --primary-fixed-dim:        #ffb596;
  --on-primary:               #ffffff;
  --on-primary-container:     #591e00;
  --on-primary-fixed:         #360f00;
  --on-primary-fixed-variant: #7d2d00;
  --secondary:                #455d93;
  --secondary-container:      #abc3ff;
  --secondary-fixed:          #d9e2ff;
  --secondary-fixed-dim:      #afc6ff;
  --on-secondary:             #ffffff;
  --on-secondary-container:   #374f84;
  --on-secondary-fixed:       #001944;
  --on-secondary-fixed-variant: #2c4579;
  --tertiary:                 #795900;
  --tertiary-container:       #c39100;
  --tertiary-fixed:           #ffdfa0;
  --tertiary-fixed-dim:       #f6be39;
  --on-tertiary:              #ffffff;
  --on-tertiary-container:    #412e00;
  --on-tertiary-fixed:        #261a00;
  --on-tertiary-fixed-variant: #5c4300;
  --background:               #fff8f1;
  --surface:                  #fff8f1;
  --surface-dim:              #dfd9d1;
  --surface-bright:           #fff8f1;
  --surface-container-lowest: #ffffff;
  --surface-container-low:    #f9f3eb;
  --surface-container:        #f4ede5;
  --surface-container-high:   #eee7df;
  --surface-container-highest:#e8e1da;
  --surface-variant:          #e8e1da;
  --on-surface:               #1e1b17;
  --on-surface-variant:       #5a4137;
  --on-background:            #1e1b17;
  --outline:                  #8e7165;
  --outline-variant:          #e2bfb2;
  --inverse-surface:          #33302b;
  --inverse-on-surface:       #f7f0e8;
  --inverse-primary:          #ffb596;
  --surface-tint:             #a43e00;
  --error:                    #ba1a1a;
  --error-container:          #ffdad6;
  --on-error:                 #ffffff;
  --on-error-container:       #93000a;
  --radius-sm:   4px;
  --radius-md:   8px;
  --radius-lg:   12px;
  --radius-full: 9999px;
  --shadow-card:    0px 12px 32px rgba(90,65,55,0.08);
  --shadow-card-lg: 0px 20px 40px rgba(90,65,55,0.12);
  --shadow-btn:     0px 4px 16px rgba(90,65,55,0.05);
  --glass-bg: rgba(255,248,241,0.80);
  --glass-blur: blur(20px);
  --hero-gradient: linear-gradient(135deg, #a43e00 0%, #455d93 100%);
  --nav-height: 73px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body { font-family: 'Manrope', sans-serif; background: var(--background); color: var(--on-surface); line-height: 1.6; font-size: 16px; overflow-x: hidden; }
img, svg { display: block; max-width: 100%; }
a { text-decoration: none; color: inherit; }
ul, ol { list-style: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
input, select, textarea { font-family: inherit; font-size: inherit; }

.material-symbols-outlined { font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24; vertical-align: middle; }

.skip-nav { position: absolute; top: -100px; left: 1rem; background: var(--primary); color: white; padding: 0.75rem 1.5rem; border-radius: var(--radius-md); font-weight: 700; font-size: 1rem; z-index: 9999; transition: top 0.2s ease; text-decoration: none; }
.skip-nav:focus { top: 1rem; }

.section-label { font-family: 'Inter', sans-serif; font-size: 0.75rem; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: var(--primary); display: block; margin-bottom: 0.5rem; }
.section-container { max-width: 1400px; margin: 0 auto; padding: 0 3rem; }
.card { background: var(--surface-container-lowest); border-radius: 1.5rem; padding: 2rem; box-shadow: var(--shadow-card); transition: box-shadow 0.3s ease, transform 0.3s ease; }
.card:hover { box-shadow: var(--shadow-card-lg); transform: translateY(-4px); }
.btn-primary { background: var(--primary); color: var(--on-primary); padding: 0.75rem 2rem; border-radius: var(--radius-full); font-weight: 700; font-size: 1rem; border: none; cursor: pointer; transition: box-shadow 0.3s ease, transform 0.3s ease, background 0.3s ease; display: inline-flex; align-items: center; gap: 0.5rem; text-decoration: none; }
.btn-primary:hover { box-shadow: 0 0 24px rgba(255,107,26,0.4); transform: scale(1.02); background: var(--primary-container); }
.btn-ghost { background: rgba(255,255,255,0.10); border: 2px solid rgba(255,255,255,0.30); color: white; border-radius: var(--radius-full); padding: 1rem 2rem; font-weight: 700; font-size: 1rem; cursor: pointer; transition: background 0.3s ease; display: inline-flex; align-items: center; gap: 0.5rem; text-decoration: none; }
.btn-ghost:hover { background: rgba(255,255,255,0.20); }
a.btn-primary, a.hero-btn-primary, a.btn-ghost, a.btn-apply-portal, a.btn-contact-admissions, a.btn-footer-cta, a.nav-cta { text-decoration: none; }
.hide-scrollbar { -ms-overflow-style: none; scrollbar-width: none; }
.hide-scrollbar::-webkit-scrollbar { display: none; }

/* NAVBAR */
.navbar { position: fixed; top: 0; width: 100%; z-index: 50; background: var(--glass-bg); backdrop-filter: var(--glass-blur); -webkit-backdrop-filter: var(--glass-blur); transition: box-shadow 0.3s ease; }
.nav-container { max-width: 1400px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; padding: 1rem 3rem; }
.nav-logo { display: flex; align-items: baseline; gap: 0.25rem; }
.logo-primary { font-family: 'Noto Serif', serif; font-size: 1.5rem; font-weight: 900; color: var(--primary); }
.logo-sub { font-family: 'Inter', sans-serif; font-size: 0.85rem; font-weight: 500; color: var(--on-surface-variant); }
.nav-links { display: flex; gap: 2rem; align-items: center; }
.nav-link { font-family: 'Noto Serif', serif; font-weight: 700; font-size: 1.1rem; color: var(--on-surface-variant); transition: color 0.3s ease; text-decoration: none; padding-bottom: 4px; }
.nav-link:hover, .nav-link.active { color: var(--primary); }
.nav-link.active { border-bottom: 2px solid var(--primary); }
.nav-cta { background: var(--primary); color: var(--on-primary); padding: 0.625rem 1.5rem; border-radius: var(--radius-full); font-weight: 700; font-size: 0.95rem; border: none; cursor: pointer; transition: box-shadow 0.3s ease, transform 0.3s ease, background 0.3s ease; white-space: nowrap; }
.nav-cta:hover { box-shadow: var(--shadow-btn); transform: scale(1.02); background: var(--primary-container); }
.hamburger { display: none; padding: 0.5rem; color: var(--on-surface); }
.hamburger .material-symbols-outlined { font-size: 1.75rem; }
.nav-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.40); z-index: 48; }
.nav-overlay.visible { display: block; }

/* HERO */
.hero { min-height: 870px; display: flex; align-items: center; overflow: hidden; position: relative; background: var(--hero-gradient); padding: 6rem 3rem 4rem; }
.hero-grid { max-width: 1400px; margin: 0 auto; width: 100%; position: relative; z-index: 2; display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.hero-left { display: flex; flex-direction: column; }
.hero-right { display: flex; align-items: center; justify-content: center; position: relative; }
.hero-visual-ring { position: absolute; width: 400px; height: 400px; border-radius: 50%; border: 16px solid rgba(255,255,255,0.05); animation: pulse 4s ease-in-out infinite; }
.hero-visual-card { background: rgba(255,255,255,0.10); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); border: 1px solid rgba(255,255,255,0.20); border-radius: 1.5rem; padding: 2.5rem; width: 100%; max-width: 380px; display: flex; flex-direction: column; gap: 1.5rem; transform: rotate(2deg); transition: transform 0.7s ease; }
.hero-visual-card:hover { transform: rotate(0deg); }
.hero-visual-icon { font-size: 3rem; color: var(--tertiary-fixed); }
.hero-visual-title { font-family: 'Noto Serif', serif; font-size: 1.1rem; font-weight: 700; color: white; line-height: 1.3; }
.hero-visual-sub { font-family: 'Inter', sans-serif; font-size: 0.8rem; color: rgba(255,255,255,0.70); }
.hero-visual-badge { display: flex; align-items: center; gap: 0.5rem; background: rgba(255,255,255,0.10); border-radius: var(--radius-full); padding: 0.4rem 0.75rem; width: fit-content; }
.hero-visual-badge .material-symbols-outlined { font-size: 1rem; color: var(--tertiary-fixed); }
.hero-visual-badge span:last-child { font-family: 'Inter', sans-serif; font-size: 0.7rem; font-weight: 700; color: white; text-transform: uppercase; letter-spacing: 0.08em; }
.hero-badge { display: inline-block; background: var(--tertiary-fixed); color: var(--on-tertiary-fixed); font-family: 'Inter', sans-serif; font-size: 0.7rem; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; padding: 0.4rem 1rem; border-radius: var(--radius-full); margin-bottom: 1.5rem; }
.hero h1 { font-family: 'Noto Serif', serif; font-size: 4.5rem; font-weight: 900; color: white; line-height: 1.1; margin-bottom: 1.5rem; max-width: 800px; }
.hero-sub { font-size: 1.25rem; color: rgba(255,255,255,0.90); font-weight: 300; max-width: 650px; margin-bottom: 2.5rem; line-height: 1.7; }
.hero-buttons { display: flex; gap: 1rem; flex-wrap: wrap; }
.hero-btn-primary { background: var(--primary-container); color: var(--on-primary-container); padding: 1rem 2rem; border-radius: var(--radius-full); font-weight: 700; font-size: 1.05rem; border: none; cursor: pointer; transition: box-shadow 0.3s ease, transform 0.3s ease; display: inline-flex; align-items: center; gap: 0.5rem; text-decoration: none; }
.hero-btn-primary:hover { box-shadow: 0 0 24px rgba(255,107,26,0.4); transform: scale(1.02); }
.hero-pulse { position: absolute; top: 10%; right: 10%; width: 300px; height: 300px; border-radius: 50%; background: rgba(255,255,255,0.05); animation: pulse 4s ease-in-out infinite; z-index: 1; }
@keyframes pulse { 0%, 100% { transform: scale(1); opacity: 0.05; } 50% { transform: scale(1.15); opacity: 0.08; } }
.bundela-arch { position: absolute; right: 0; bottom: 0; width: 60%; height: 80%; opacity: 0.10; background: var(--primary); mask-image: url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 100V40C0 17.9086 17.9086 0 40 0H60C82.0914 0 100 17.9086 100 40V100H0Z' fill='black'/%3E%3C/svg%3E"); mask-size: contain; mask-repeat: no-repeat; mask-position: bottom; -webkit-mask-image: url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 100V40C0 17.9086 17.9086 0 40 0H60C82.0914 0 100 17.9086 100 40V100H0Z' fill='black'/%3E%3C/svg%3E"); -webkit-mask-size: contain; -webkit-mask-repeat: no-repeat; -webkit-mask-position: bottom; z-index: 0; }

/* MARQUEE */
.announcement-ticker { background: var(--secondary); padding: 0.75rem 0; overflow: hidden; white-space: nowrap; display: flex; align-items: center; }
.ticker-container { max-width: 1400px; margin: 0 auto; display: flex; align-items: center; gap: 1.5rem; padding: 0 3rem; width: 100%; }
.ticker-badge { background: var(--primary); color: var(--on-primary); font-family: 'Inter', sans-serif; font-size: 0.7rem; font-weight: 700; text-transform: uppercase; padding: 0.35rem 0.85rem; border-radius: var(--radius-full); white-space: nowrap; flex-shrink: 0; }
.marquee-wrapper { overflow: hidden; flex: 1; }
.marquee-track { display: flex; width: 200%; animation: marquee 30s linear infinite; }
.marquee-track:hover { animation-play-state: paused; }
.marquee-content { display: flex; width: 50%; color: white; font-size: 0.9rem; align-items: center; gap: 1rem; }
.marquee-content span { white-space: nowrap; }
@keyframes marquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* ANNOUNCEMENTS */
.announcements { padding: 5rem 0; background: transparent; }
.announcements-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 3rem; flex-wrap: wrap; gap: 1rem; }
.announcements-header h2 { font-family: 'Noto Serif', serif; font-size: 2.5rem; font-weight: 900; color: var(--on-surface); line-height: 1.2; }
.view-all-link { color: var(--primary); font-weight: 700; font-size: 1rem; display: flex; align-items: center; gap: 0.25rem; transition: gap 0.3s ease; }
.view-all-link:hover { gap: 0.5rem; }
.announcements-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2rem; }
.announcement-card { background: var(--surface-container-low); border-radius: 1.5rem; padding: 2rem; box-shadow: var(--shadow-card); display: flex; gap: 1.5rem; transition: box-shadow 0.3s ease, transform 0.3s ease; }
.announcement-card:hover { box-shadow: var(--shadow-card-lg); transform: translateY(-2px); }
.announcement-card.urgent { border-left: 4px solid var(--tertiary); }
.date-block { width: 64px; height: 64px; background: var(--primary-fixed); border-radius: var(--radius-lg); display: flex; flex-direction: column; align-items: center; justify-content: center; flex-shrink: 0; }
.date-block .day { font-size: 1.25rem; font-weight: 900; color: var(--on-primary-container); line-height: 1; }
.date-block .month { font-size: 0.65rem; font-weight: 700; text-transform: uppercase; color: var(--on-primary-fixed-variant); letter-spacing: 0.05em; }
.announcement-body { flex: 1; }
.category-badge { display: inline-block; background: var(--surface-variant); font-family: 'Inter', sans-serif; font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; padding: 0.2rem 0.7rem; border-radius: var(--radius-full); margin-bottom: 0.5rem; color: var(--on-surface-variant); }
.announcement-body h3 { font-family: 'Noto Serif', serif; font-size: 1.15rem; font-weight: 700; color: var(--on-surface); margin-bottom: 0.5rem; line-height: 1.3; transition: color 0.3s ease; }
.announcement-card:hover .announcement-body h3 { color: var(--primary); }
.announcement-body p { font-size: 0.9rem; color: var(--on-surface-variant); line-height: 1.5; margin-bottom: 0.75rem; }
.announcement-tags { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.announcement-tags span { font-size: 0.7rem; font-weight: 600; color: var(--on-surface-variant); background: var(--surface-container); padding: 0.2rem 0.6rem; border-radius: var(--radius-full); }

/* STATS */
.stats-bar { background: var(--surface-container); padding: 4rem 0; }
.stats-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 2rem; text-align: center; }
.stat-item .stat-number { font-family: 'Noto Serif', serif; font-size: 3rem; font-weight: 900; line-height: 1; margin-bottom: 0.5rem; }
.stat-item .stat-number.primary { color: var(--primary); }
.stat-item .stat-number.secondary { color: var(--secondary); }
.stat-item .stat-number.tertiary { color: var(--tertiary); }
.stat-item .stat-label { font-family: 'Inter', sans-serif; font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--on-surface-variant); }

/* COURSES OVERVIEW */
.courses-overview { background: var(--surface-container-lowest); padding: 6rem 0; position: relative; overflow: hidden; }
.courses-overview .bundela-arch { transform: rotate(180deg); opacity: 0.05; }
.courses-header { text-align: center; margin-bottom: 4rem; position: relative; z-index: 2; }
.courses-header h2 { font-family: 'Noto Serif', serif; font-size: 3.5rem; font-weight: 900; color: var(--on-surface); line-height: 1.1; margin-bottom: 1rem; }
.courses-header p { font-size: 1.1rem; color: var(--on-surface-variant); max-width: 600px; margin: 0 auto; line-height: 1.6; }
.courses-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 2rem; position: relative; z-index: 2; }
.course-card { background: var(--background); border: 1px solid var(--outline-variant); border-radius: 1.5rem; padding: 2rem; transition: background 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease; cursor: default; }
.course-card:hover { background: var(--primary); transform: translateY(-8px); box-shadow: var(--shadow-card-lg); border-color: transparent; }
.course-icon { width: 56px; height: 56px; background: var(--primary-fixed); border-radius: var(--radius-lg); display: flex; align-items: center; justify-content: center; margin-bottom: 1.5rem; transition: background 0.3s ease; }
.course-icon .material-symbols-outlined { font-size: 1.75rem; color: var(--primary); transition: color 0.3s ease; }
.course-card:hover .course-icon { background: rgba(255,255,255,0.20); }
.course-card:hover .course-icon .material-symbols-outlined { color: white; }
.course-card h3 { font-family: 'Noto Serif', serif; font-size: 1.35rem; font-weight: 900; color: var(--on-surface); margin-bottom: 1rem; transition: color 0.3s ease; }
.course-card:hover h3 { color: white; }
.course-meta { display: flex; justify-content: space-between; padding-bottom: 0.5rem; margin-bottom: 0.5rem; border-bottom: 1px solid var(--outline-variant); transition: border-color 0.3s ease; }
.course-card:hover .course-meta { border-color: rgba(255,255,255,0.20); }
.course-meta-label { font-size: 0.75rem; font-weight: 600; text-transform: uppercase; color: var(--on-surface-variant); transition: color 0.3s ease; }
.course-meta-value { font-size: 0.85rem; font-weight: 700; color: var(--on-surface); transition: color 0.3s ease; }
.course-card:hover .course-meta-label, .course-card:hover .course-meta-value { color: white; }
.course-card .course-desc { font-size: 0.85rem; color: var(--on-surface-variant); line-height: 1.5; margin-top: 0.75rem; transition: color 0.3s ease; }
.course-card:hover .course-desc { color: rgba(255,255,255,0.70); }

/* CAMPUS HIGHLIGHTS */
.campus-highlights { background: var(--surface-container-low); padding: 6rem 0; }
.campus-top { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; margin-bottom: 4rem; }
.campus-top-text h2 { font-family: 'Noto Serif', serif; font-size: 2.5rem; font-weight: 900; color: var(--on-surface); line-height: 1.15; margin-bottom: 1rem; }
.campus-top-text p { font-size: 1.05rem; color: var(--on-surface-variant); line-height: 1.7; }
.campus-image-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.campus-img-placeholder { border-radius: 1.5rem; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 0.5rem; min-height: 180px; position: relative; overflow: hidden; }
.campus-img-placeholder:nth-child(1) { background: linear-gradient(135deg, #ffdbcd, #ff6b1a); min-height: 220px; }
.campus-img-placeholder:nth-child(2) { background: linear-gradient(135deg, #d9e2ff, #455d93); min-height: 160px; }
.campus-img-placeholder:nth-child(3) { background: linear-gradient(135deg, #d9e2ff, #455d93); min-height: 160px; }
.campus-img-placeholder:nth-child(4) { background: linear-gradient(135deg, #ffdfa0, #795900); min-height: 220px; }
.campus-img-placeholder .material-symbols-outlined { font-size: 2.5rem; color: white; }
.campus-img-placeholder span:last-child { font-family: 'Inter', sans-serif; font-size: 0.8rem; font-weight: 700; color: white; text-transform: uppercase; letter-spacing: 0.05em; }
.features-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.feature-item { display: flex; gap: 1rem; align-items: flex-start; }
.feature-icon { width: 48px; height: 48px; background: var(--primary-fixed); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.feature-icon .material-symbols-outlined { font-size: 1.5rem; color: var(--primary); }
.feature-item h4 { font-family: 'Noto Serif', serif; font-size: 1.05rem; font-weight: 700; color: var(--on-surface); margin-bottom: 0.25rem; }
.feature-item p { font-size: 0.85rem; color: var(--on-surface-variant); line-height: 1.5; }

/* PAGE HEADER */
.page-header { background: var(--surface-container-low); padding: 8rem 0 5rem; position: relative; overflow: hidden; }
.page-header .section-container { position: relative; z-index: 2; }
.breadcrumb { font-family: 'Inter', sans-serif; font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--primary); margin-bottom: 1rem; }
.breadcrumb a { color: var(--on-surface-variant); transition: color 0.3s ease; }
.breadcrumb a:hover { color: var(--primary); }
.page-header h1 { font-family: 'Noto Serif', serif; font-size: 4rem; font-weight: 900; color: var(--primary); line-height: 1.05; margin-bottom: 1rem; }
.page-header p { font-size: 1.15rem; color: var(--on-surface-variant); max-width: 650px; line-height: 1.7; }

/* ABOUT HISTORY */
.history-section { background: var(--surface-container-low); padding: 6rem 0; }
.history-grid { display: grid; grid-template-columns: 7fr 5fr; gap: 4rem; align-items: start; }
.history-text .section-label { display: flex; align-items: center; gap: 1rem; }
.history-text .section-label::after { content: ''; flex: 1; height: 2px; background: var(--secondary); }
.history-text h2 { font-family: 'Noto Serif', serif; font-size: 2.5rem; font-weight: 900; color: var(--on-surface); line-height: 1.15; margin-bottom: 1.5rem; }
.history-text p { font-size: 1rem; color: var(--on-surface-variant); line-height: 1.7; margin-bottom: 1.25rem; }
.history-image-placeholder { background: linear-gradient(135deg, #ff6b1a, #455d93); border-radius: var(--radius-lg); aspect-ratio: 4/3; display: flex; flex-direction: column; align-items: center; justify-content: center; margin-top: 2rem; }
.history-image-placeholder .material-symbols-outlined { font-size: 4rem; color: rgba(255,255,255,0.4); }
.history-img-label { font-family: 'Inter', sans-serif; font-size: 0.8rem; font-weight: 700; color: rgba(255,255,255,0.7); text-transform: uppercase; letter-spacing: 0.1em; margin-top: 0.5rem; }
.history-sidebar { position: sticky; top: calc(var(--nav-height) + 2rem); display: flex; flex-direction: column; gap: 1.5rem; }
.quote-card { background: var(--secondary); color: white; border-radius: 2rem; padding: 2.5rem; box-shadow: 0 25px 50px rgba(0,0,0,0.15); position: relative; overflow: hidden; }
.quote-card .quote-icon { position: absolute; top: -10px; right: 10px; font-size: 8rem; color: rgba(255,255,255,0.10); line-height: 1; }
.quote-card blockquote { font-family: 'Noto Serif', serif; font-size: 1.15rem; font-style: italic; line-height: 1.6; margin-bottom: 1.5rem; position: relative; z-index: 1; }
.quote-card .attribution { font-family: 'Inter', sans-serif; font-size: 0.8rem; font-weight: 600; opacity: 0.8; }
.verification-badge { background: var(--tertiary-fixed); border-radius: 1.5rem; padding: 1.5rem; display: flex; align-items: center; gap: 1rem; }
.verification-badge .material-symbols-outlined { font-size: 2rem; color: var(--tertiary); }
.verification-badge p { font-size: 0.9rem; font-weight: 600; color: var(--on-tertiary-fixed); line-height: 1.4; }

/* MISSION VISION */
.mission-vision { padding: 6rem 0; }
.mv-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.mv-card { border-radius: 2rem; padding: 3rem; transition: transform 0.3s ease, box-shadow 0.3s ease; }
.mv-card:hover { transform: scale(1.02); box-shadow: var(--shadow-card-lg); }
.mv-card.mission { background: var(--surface-container-lowest); border-left: 4px solid var(--primary); }
.mv-card.vision { background: var(--secondary); color: white; }
.mv-icon { width: 64px; height: 64px; border-radius: 1.5rem; display: flex; align-items: center; justify-content: center; margin-bottom: 1.5rem; }
.mv-card.mission .mv-icon { background: var(--primary-container); }
.mv-card.mission .mv-icon .material-symbols-outlined { color: var(--primary); }
.mv-card.vision .mv-icon { background: var(--secondary-container); }
.mv-card.vision .mv-icon .material-symbols-outlined { color: var(--secondary); }
.mv-card h3 { font-family: 'Noto Serif', serif; font-size: 1.75rem; font-weight: 900; margin-bottom: 1rem; }
.mv-card.mission h3 { color: var(--primary); }
.mv-card.vision h3 { color: white; }
.mv-card p { font-size: 1rem; line-height: 1.7; }
.mv-card.mission p { color: var(--on-surface-variant); }
.mv-card.vision p { color: rgba(255,255,255,0.90); }

/* CORE VALUES */
.core-values { background: var(--surface-container); padding: 6rem 0; }
.core-values h2 { font-family: 'Noto Serif', serif; font-size: 2.5rem; font-weight: 900; text-align: center; margin-bottom: 3rem; color: var(--on-surface); }
.values-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 1.5rem; }
.value-card { background: var(--surface-container-lowest); border-radius: 1.5rem; padding: 2rem; text-align: center; box-shadow: 0 1px 3px rgba(0,0,0,0.05); transition: transform 0.3s ease, box-shadow 0.3s ease; display: flex; flex-direction: column; align-items: center; }
.value-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card); }
.value-card .material-symbols-outlined { font-size: 2.5rem; color: var(--primary); margin-bottom: 1rem; }
.value-card h4 { font-family: 'Noto Serif', serif; font-size: 1.1rem; font-weight: 700; color: var(--on-surface); margin-bottom: 0.5rem; }
.value-card p { font-size: 0.85rem; color: var(--on-surface-variant); line-height: 1.5; }

/* AFFILIATION */
.affiliation { background: rgba(232,225,218,0.30); padding: 6rem 0; }
.affiliation-container { background: var(--surface-container-highest); border-radius: 3rem; padding: 4rem; }
.affiliation-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.affiliation-text h2 { font-family: 'Noto Serif', serif; font-size: 2.25rem; font-weight: 900; color: var(--on-surface); margin-bottom: 1rem; line-height: 1.15; }
.affiliation-text p { font-size: 1rem; color: var(--on-surface-variant); line-height: 1.7; margin-bottom: 1.5rem; }
.affiliation-chips { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.affiliation-chips span { background: var(--primary-fixed); color: var(--on-primary-fixed); font-family: 'Inter', sans-serif; font-size: 0.75rem; font-weight: 700; padding: 0.35rem 0.85rem; border-radius: var(--radius-full); }
.affiliation-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.aff-card { background: var(--surface-container-lowest); border-radius: 2rem; padding: 2rem; text-align: center; box-shadow: 0 12px 32px rgba(0,0,0,0.08); transition: transform 0.3s ease; }
.aff-card:hover { transform: translateY(-4px); }
.aff-card.ncte { border-top: 4px solid var(--primary); }
.aff-card .material-symbols-outlined { font-size: 3rem; margin-bottom: 1rem; }
.aff-card .material-symbols-outlined.secondary { color: var(--secondary); }
.aff-card .material-symbols-outlined.primary { color: var(--primary); }
.aff-card h4 { font-family: 'Noto Serif', serif; font-size: 1rem; font-weight: 700; color: var(--on-surface); margin-bottom: 0.5rem; }
.aff-card p { font-size: 0.8rem; color: var(--on-surface-variant); line-height: 1.5; }

/* FILTER TABS */
.filter-tabs { position: sticky; top: var(--nav-height); z-index: 40; background: rgba(255,248,241,0.90); backdrop-filter: var(--glass-blur); -webkit-backdrop-filter: var(--glass-blur); padding: 1rem 0; border-bottom: 1px solid var(--outline-variant); }
.filter-tabs .section-container { display: flex; gap: 1rem; flex-wrap: wrap; }
.filter-btn { background: var(--surface-container); color: var(--on-surface-variant); padding: 0.5rem 1.25rem; border-radius: var(--radius-full); font-family: 'Inter', sans-serif; font-size: 0.85rem; font-weight: 600; border: none; cursor: pointer; transition: background 0.3s ease, color 0.3s ease; }
.filter-btn:hover { background: var(--surface-container-high); }
.filter-btn.active { background: var(--primary); color: var(--on-primary); }

/* ACCORDION */
.courses-accordion { padding: 4rem 0; }
.accordion-item { background: var(--surface-container-lowest); border-radius: var(--radius-md); border: 1px solid rgba(226,191,178,0.15); margin-bottom: 1rem; overflow: hidden; transition: box-shadow 0.3s ease; }
.accordion-item:hover { box-shadow: var(--shadow-card); }
.accordion-header { display: flex; justify-content: space-between; align-items: center; padding: 1.5rem 2rem; cursor: pointer; gap: 1rem; flex-wrap: wrap; }
.accordion-header-left { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.course-badge { font-family: 'Inter', sans-serif; font-size: 0.6rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; padding: 0.25rem 0.65rem; border-radius: var(--radius-full); }
.course-badge.ug { background: var(--secondary-fixed); color: var(--on-secondary-container); }
.course-badge.pg { background: var(--primary-fixed); color: var(--on-primary-container); }
.course-badge.professional { background: var(--tertiary-fixed); color: var(--on-tertiary-fixed); }
.accordion-header-left .faculty-label { display: flex; align-items: center; gap: 0.25rem; font-size: 0.8rem; color: var(--on-surface-variant); }
.accordion-header-left .faculty-label .material-symbols-outlined { font-size: 1.1rem; color: var(--primary); }
.accordion-header h3 { font-family: 'Noto Serif', serif; font-size: 1.5rem; font-weight: 700; color: var(--on-surface); }
.accordion-header-right { display: flex; align-items: center; gap: 0.75rem; }
.meta-chip { background: var(--surface-container); font-size: 0.75rem; font-weight: 600; color: var(--on-surface-variant); padding: 0.3rem 0.7rem; border-radius: var(--radius-full); }
.accordion-chevron { transition: transform 0.3s ease; color: var(--on-surface-variant); }
.accordion-body { max-height: 0; overflow: hidden; transition: max-height 0.4s ease; }
.accordion-body.open { max-height: 600px; }
.accordion-content { background: rgba(249,243,235,0.30); border-top: 1px solid rgba(226,191,178,0.10); padding: 2.5rem; }
.accordion-content-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.accordion-content-left h4, .accordion-content-right h4 { font-family: 'Inter', sans-serif; font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--primary); margin-bottom: 0.5rem; }
.accordion-content-left p, .accordion-content-right p { font-size: 0.9rem; color: var(--on-surface-variant); line-height: 1.6; margin-bottom: 0.75rem; }

/* CTA BANNER */
.cta-banner { background: var(--primary); border-radius: 3rem; padding: 4rem; text-align: center; position: relative; overflow: hidden; margin: 4rem 0; }
.cta-banner .cta-blur { position: absolute; width: 300px; height: 300px; border-radius: 50%; background: rgba(255,255,255,0.10); filter: blur(80px); }
.cta-banner .cta-blur.one { top: -100px; left: -100px; }
.cta-banner .cta-blur.two { bottom: -100px; right: -100px; }
.cta-banner h2 { font-family: 'Noto Serif', serif; font-size: 2.5rem; font-weight: 900; color: white; margin-bottom: 1rem; position: relative; z-index: 1; }
.cta-banner p { font-size: 1.1rem; color: rgba(255,255,255,0.90); margin-bottom: 2rem; max-width: 600px; margin-left: auto; margin-right: auto; position: relative; z-index: 1; }
.cta-banner .btn-cta-white { background: white; color: var(--primary); padding: 1.25rem 3rem; border-radius: var(--radius-full); font-weight: 900; font-size: 1.25rem; border: none; cursor: pointer; transition: transform 0.3s ease, box-shadow 0.3s ease; box-shadow: 0 12px 32px rgba(0,0,0,0.15); position: relative; z-index: 1; display: inline-flex; align-items: center; gap: 0.5rem; }
.cta-banner .btn-cta-white:hover { transform: scale(1.05); box-shadow: 0 16px 40px rgba(0,0,0,0.20); }

/* ROADMAP */
.roadmap-section { padding: 6rem 0; }
.roadmap-header { margin-bottom: 4rem; }
.roadmap-header h2 { font-family: 'Noto Serif', serif; font-size: 2.5rem; font-weight: 900; color: var(--on-surface); margin-bottom: 1rem; }
.roadmap-underline { width: 6rem; height: 4px; background: var(--primary); border-radius: 2px; margin-bottom: 1rem; }
.roadmap-header p { font-size: 1.05rem; color: var(--on-surface-variant); }
.roadmap-steps { display: grid; grid-template-columns: repeat(6, 1fr); gap: 1.5rem; position: relative; }
.roadmap-connector { position: absolute; top: 24px; left: 5%; right: 5%; height: 2px; background: var(--outline-variant); z-index: 0; }
.roadmap-step { display: flex; flex-direction: column; align-items: center; text-align: center; position: relative; z-index: 10; }
.step-number { width: 48px; height: 48px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 1rem; color: white; box-shadow: 0 8px 16px rgba(0,0,0,0.10); margin-bottom: 1.5rem; position: relative; }
.step-number.primary { background: var(--primary); }
.step-number.secondary { background: var(--secondary); }
.step-number::after { content: ''; position: absolute; inset: -8px; border-radius: 50%; border: 8px solid var(--background); }
.roadmap-step h3 { font-family: 'Noto Serif', serif; font-size: 1rem; font-weight: 700; color: var(--on-surface); margin-bottom: 0.5rem; }
.roadmap-step p { font-size: 0.8rem; color: var(--on-surface-variant); line-height: 1.5; }

/* ELIGIBILITY TABLE */
.eligibility-section { padding: 4rem 0 6rem; }
.eligibility-section h2 { font-family: 'Noto Serif', serif; font-size: 2.25rem; font-weight: 900; color: var(--on-surface); margin-bottom: 2rem; }
.table-wrapper { overflow-x: auto; }
.eligibility-table { width: 100%; background: var(--surface-container-lowest); border-radius: var(--radius-md); box-shadow: 0 1px 3px rgba(0,0,0,0.05); border-collapse: collapse; min-width: 700px; }
.eligibility-table thead { background: var(--secondary); color: white; }
.eligibility-table th { font-family: 'Inter', sans-serif; font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; padding: 1rem 1.5rem; text-align: left; }
.eligibility-table td { padding: 1rem 1.5rem; font-size: 0.9rem; color: var(--on-surface-variant); border-bottom: 1px solid var(--surface-container); }
.eligibility-table tbody tr { transition: background 0.2s ease; }
.eligibility-table tbody tr:hover { background: var(--surface-container-lowest); }
.eligibility-table tbody tr:nth-child(even) { background: rgba(249,243,235,0.30); }

/* DOCUMENTS */
.documents-section { padding: 4rem 0 6rem; }
.documents-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.documents-image { background: linear-gradient(135deg, #ff6b1a, #455d93); aspect-ratio: 4/5; border-radius: 1.5rem; display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; width: 100%; min-height: 280px; }
.documents-image::after { content: 'Excellence in every detail.'; position: absolute; bottom: 2rem; left: 2rem; right: 2rem; font-family: 'Noto Serif', serif; font-size: 1.5rem; font-weight: 700; color: white; text-align: center; }
.documents-list h2 { font-family: 'Noto Serif', serif; font-size: 2.25rem; font-weight: 900; color: var(--on-surface); margin-bottom: 1rem; }
.documents-list > p { font-size: 1rem; color: var(--on-surface-variant); margin-bottom: 2rem; line-height: 1.7; }
.doc-item { display: flex; gap: 1rem; align-items: flex-start; margin-bottom: 1.5rem; }
.doc-icon { width: 48px; height: 48px; background: var(--primary-fixed); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.doc-icon .material-symbols-outlined { font-size: 1.5rem; color: var(--primary); }
.doc-item h4 { font-family: 'Noto Serif', serif; font-size: 1rem; font-weight: 700; color: var(--on-surface); margin-bottom: 0.25rem; }
.doc-item p { font-size: 0.85rem; color: var(--on-surface-variant); line-height: 1.5; }

/* APPLY CTA */
.apply-cta { background: var(--primary); border-radius: 2.5rem; padding: 4rem; position: relative; overflow: hidden; box-shadow: 0 25px 50px rgba(164,62,0,0.20); margin-bottom: 6rem; }
.apply-cta .cta-gold-blur { position: absolute; top: -80px; right: -80px; width: 300px; height: 300px; border-radius: 50%; background: rgba(195,145,0,0.20); filter: blur(80px); }
.apply-cta h2 { font-family: 'Noto Serif', serif; font-size: 3rem; font-weight: 900; color: white; margin-bottom: 1rem; position: relative; z-index: 1; }
.apply-cta p { font-size: 1.1rem; color: rgba(255,255,255,0.90); margin-bottom: 2rem; max-width: 600px; position: relative; z-index: 1; line-height: 1.7; }
.apply-cta-buttons { display: flex; gap: 1rem; flex-wrap: wrap; position: relative; z-index: 1; }
.btn-apply-portal { background: white; color: var(--primary); padding: 1rem 2.5rem; border-radius: var(--radius-full); font-weight: 700; font-size: 1.1rem; border: none; cursor: pointer; transition: transform 0.3s ease, box-shadow 0.3s ease; box-shadow: 0 8px 16px rgba(0,0,0,0.10); display: inline-flex; align-items: center; gap: 0.5rem; }
.btn-apply-portal:hover { transform: scale(1.05); }
.btn-contact-admissions { background: rgba(255,255,255,0.15); border: 1px solid rgba(255,255,255,0.40); color: white; padding: 1rem 2rem; border-radius: var(--radius-full); font-weight: 700; font-size: 1.05rem; cursor: pointer; transition: background 0.3s ease; display: inline-flex; align-items: center; gap: 0.5rem; }
.btn-contact-admissions:hover { background: rgba(255,255,255,0.25); }

/* FACILITIES */
.facility-section { padding: 6rem 0; }
.facility-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.facility-grid.reverse { direction: rtl; }
.facility-grid.reverse > * { direction: ltr; }
.facility-image { border-radius: 1.5rem; position: relative; overflow: hidden; }
.facility-image.library { background: linear-gradient(135deg, #ffdfa0, #795900); height: 500px; }
.facility-image.labs { background: linear-gradient(135deg, #d9e2ff, #455d93); height: 500px; }
.facility-image.sports { background: linear-gradient(135deg, #a43e00, #6b1a00); height: 600px; border-radius: 2rem; }
.facility-image.campus { background: linear-gradient(135deg, #ffdbcd, #a43e00); aspect-ratio: 4/5; border-radius: 3rem; box-shadow: 0 25px 50px rgba(0,0,0,0.15); }
.facility-image .overlay-badge { position: absolute; top: 1.5rem; right: 1.5rem; background: rgba(255,255,255,0.90); backdrop-filter: var(--glass-blur); -webkit-backdrop-filter: var(--glass-blur); border-radius: var(--radius-md); padding: 1rem; display: flex; align-items: center; gap: 0.5rem; }
.facility-image .overlay-badge .material-symbols-outlined { font-size: 2rem; color: var(--tertiary); }
.facility-image .overlay-badge span:last-child { font-family: 'Inter', sans-serif; font-size: 0.8rem; font-weight: 700; color: var(--on-surface); }
.facility-image .floating-badge { position: absolute; bottom: 1.5rem; left: 1.5rem; background: var(--secondary); color: white; border-radius: 1.5rem; padding: 1rem 1.5rem; font-family: 'Inter', sans-serif; font-size: 0.85rem; font-weight: 700; }
.facility-image .sports-overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 2rem; background: linear-gradient(to top, rgba(164,62,0,0.80), transparent); }
.facility-image .sports-overlay h3 { font-family: 'Noto Serif', serif; font-size: 1.5rem; font-weight: 700; color: white; margin-bottom: 0.25rem; }
.facility-image .sports-overlay p { font-size: 0.9rem; color: rgba(255,255,255,0.80); }
.facility-text h2 { font-family: 'Noto Serif', serif; font-size: 2.25rem; font-weight: 900; color: var(--on-surface); margin-bottom: 1rem; line-height: 1.15; }
.facility-text p { font-size: 1rem; color: var(--on-surface-variant); line-height: 1.7; margin-bottom: 1.5rem; }
.facility-checklist { display: flex; flex-direction: column; gap: 1rem; }
.facility-checklist .check-item { display: flex; align-items: flex-start; gap: 0.75rem; }
.check-icon { width: 24px; height: 24px; background: var(--primary-fixed); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
.check-icon .material-symbols-outlined { font-size: 1rem; color: var(--primary); }
.check-item p { font-size: 0.9rem; color: var(--on-surface-variant); line-height: 1.5; margin-bottom: 0; }
.facility-labs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1.5rem; }
.lab-card { background: var(--surface-container-lowest); border-radius: var(--radius-md); padding: 1.25rem; display: flex; gap: 0.75rem; align-items: flex-start; }
.lab-card .material-symbols-outlined { font-size: 1.5rem; color: var(--primary); flex-shrink: 0; }
.lab-card h4 { font-family: 'Noto Serif', serif; font-size: 0.95rem; font-weight: 700; color: var(--on-surface); margin-bottom: 0.25rem; }
.lab-card p { font-size: 0.8rem; color: var(--on-surface-variant); line-height: 1.4; margin-bottom: 0; }
.facility-features { display: flex; flex-direction: column; gap: 1rem; margin-bottom: 1.5rem; }
.facility-feature-row { display: flex; gap: 1rem; align-items: flex-start; }
.facility-feature-row .material-symbols-outlined { font-size: 1.5rem; color: var(--primary); flex-shrink: 0; margin-top: 2px; }
.facility-feature-row h4 { font-family: 'Noto Serif', serif; font-size: 0.95rem; font-weight: 700; color: var(--on-surface); margin-bottom: 0.15rem; }
.facility-feature-row p { font-size: 0.85rem; color: var(--on-surface-variant); line-height: 1.4; margin-bottom: 0; }
.faculty-section { padding: 6rem 0; }
.faculty-header { text-align: center; max-width: 700px; margin: 0 auto 4rem; }
.faculty-header h2 { font-family: 'Noto Serif', serif; font-size: 2.5rem; font-weight: 900; color: var(--on-secondary-fixed); margin-bottom: 1rem; }
.faculty-header p { font-size: 1.1rem; color: var(--on-secondary-fixed-variant); line-height: 1.7; }
.faculty-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.faculty-card { background: rgba(255,255,255,0.40); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,0.50); border-radius: 1.5rem; padding: 2rem; }
.faculty-card .material-symbols-outlined { font-size: 2.5rem; color: var(--secondary); margin-bottom: 1rem; display: block; }
.faculty-card h3 { font-family: 'Noto Serif', serif; font-size: 1.25rem; font-weight: 700; margin-bottom: 0.75rem; color: var(--on-surface); }
.faculty-card p { font-size: 0.95rem; color: var(--on-surface-variant); line-height: 1.65; }
.campus-feature-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; margin-bottom: 1.5rem; }
.campus-feature-card { background: var(--surface-container-lowest); border-radius: 1.5rem; padding: 1.5rem; transition: background 0.3s ease, transform 0.3s ease; }
.campus-feature-card:hover { background: var(--primary); transform: translateY(-4px); }
.campus-feature-card .material-symbols-outlined { font-size: 1.75rem; color: var(--primary); margin-bottom: 0.75rem; transition: color 0.3s ease; }
.campus-feature-card:hover .material-symbols-outlined { color: white; }
.campus-feature-card h4 { font-family: 'Noto Serif', serif; font-size: 1rem; font-weight: 700; color: var(--on-surface); margin-bottom: 0.35rem; transition: color 0.3s ease; }
.campus-feature-card:hover h4 { color: white; }
.campus-feature-card p { font-size: 0.8rem; color: var(--on-surface-variant); line-height: 1.5; transition: color 0.3s ease; }
.campus-feature-card:hover p { color: rgba(255,255,255,0.70); }

/* CONTACT */
.contact-hero { padding: 8rem 0 5rem; background: var(--surface-container-low); }
.contact-hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.contact-hero-text h1 { font-family: 'Noto Serif', serif; font-size: 3.5rem; font-weight: 900; color: var(--on-surface); line-height: 1.1; margin-bottom: 1rem; }
.contact-hero-text h1 em { color: var(--primary); font-style: italic; }
.contact-hero-text p { font-size: 1.05rem; color: var(--on-surface-variant); line-height: 1.7; margin-bottom: 1.5rem; }
.contact-hero-image { background: linear-gradient(135deg, #ffdbcd, #a43e00); aspect-ratio: 4/3; border-radius: 2rem; box-shadow: 0 25px 50px rgba(0,0,0,0.15); position: relative; overflow: hidden; }
.contact-hero-image::before { content: ''; position: absolute; top: -20px; right: -20px; width: 120px; height: 120px; border: 3px dashed var(--tertiary-fixed); border-radius: 50%; opacity: 0.5; }
.contact-hero-image::after { content: ''; position: absolute; bottom: -30px; left: -30px; width: 100px; height: 100px; background: var(--tertiary-fixed); opacity: 0.3; border-radius: var(--radius-md); transform: rotate(15deg); }
.contact-content { padding: 6rem 0; }
.contact-grid { display: grid; grid-template-columns: 2fr 3fr; gap: 4rem; }
.contact-cards-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; margin-bottom: 2rem; }
.contact-card { background: var(--surface-container-lowest); border-radius: 1.5rem; padding: 1.5rem; box-shadow: var(--shadow-card); }
.contact-card-icon { width: 48px; height: 48px; border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; margin-bottom: 1rem; }
.contact-card-icon.primary { background: rgba(164,62,0,0.10); }
.contact-card-icon.secondary { background: rgba(69,93,147,0.10); }
.contact-card-icon.tertiary { background: rgba(121,89,0,0.10); }
.contact-card-icon .material-symbols-outlined { font-size: 1.5rem; }
.contact-card-icon.primary .material-symbols-outlined { color: var(--primary); }
.contact-card-icon.secondary .material-symbols-outlined { color: var(--secondary); }
.contact-card-icon.tertiary .material-symbols-outlined { color: var(--tertiary); }
.contact-card h3 { font-family: 'Noto Serif', serif; font-size: 1rem; font-weight: 700; color: var(--on-surface); margin-bottom: 0.5rem; }
.contact-card p { font-size: 0.85rem; color: var(--on-surface-variant); line-height: 1.5; }
.contact-card a { color: var(--primary); font-weight: 600; font-size: 0.85rem; transition: color 0.3s ease; }
.contact-card a:hover { color: var(--primary-container); }
.map-wrapper { border-radius: 2rem; overflow: hidden; height: 400px; background: var(--surface-container-highest); position: relative; }
.map-wrapper iframe { width: 100%; height: 100%; border: 0; }
.map-pin-badge { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); background: rgba(255,255,255,0.90); backdrop-filter: var(--glass-blur); -webkit-backdrop-filter: var(--glass-blur); border-radius: var(--radius-full); padding: 0.5rem 1rem; display: flex; align-items: center; gap: 0.35rem; box-shadow: var(--shadow-card); pointer-events: none; z-index: 5; }
.map-pin-badge .material-symbols-outlined { font-size: 1.25rem; color: var(--primary); }
.map-pin-badge span { font-family: 'Inter', sans-serif; font-size: 0.75rem; font-weight: 600; color: var(--on-surface); }
.contact-form-card { background: var(--surface-container-lowest); border-radius: 2rem; padding: 3rem; box-shadow: 0 25px 50px rgba(0,0,0,0.08); border: 1px solid rgba(226,191,178,0.15); }
.contact-form-card h2 { font-family: 'Noto Serif', serif; font-size: 2rem; font-weight: 900; color: var(--on-surface); margin-bottom: 0.5rem; }
.contact-form-card > p { font-size: 0.95rem; color: var(--on-surface-variant); margin-bottom: 2rem; line-height: 1.6; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1rem; }
.form-group { margin-bottom: 1rem; }
.form-group label { display: block; font-family: 'Inter', sans-serif; font-size: 0.8rem; font-weight: 600; color: var(--on-surface-variant); margin-bottom: 0.4rem; }
.form-group input, .form-group select, .form-group textarea { width: 100%; background: var(--surface-container-high); border: none; border-radius: var(--radius-md); padding: 1rem; font-size: 0.95rem; color: var(--on-surface); transition: box-shadow 0.3s ease; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { outline: none; box-shadow: 0 0 0 2px var(--primary); }
.form-group textarea { resize: vertical; min-height: 120px; }
.form-group select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%235a4137' d='M6 8L1 3h10z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 1rem center; padding-right: 2.5rem; }
.btn-submit { width: 100%; background: var(--primary); color: white; padding: 1rem; border-radius: var(--radius-md); font-weight: 700; font-size: 1.1rem; border: none; cursor: pointer; transition: transform 0.3s ease, box-shadow 0.3s ease; box-shadow: 0 8px 16px rgba(164,62,0,0.20); display: flex; align-items: center; justify-content: center; gap: 0.5rem; }
.btn-submit:hover { transform: translateY(-4px); box-shadow: 0 12px 24px rgba(164,62,0,0.30); }
.privacy-note { display: flex; align-items: center; gap: 0.5rem; margin-top: 1rem; }
.privacy-note .material-symbols-outlined { font-size: 1.25rem; color: var(--tertiary-container); }
.privacy-note p { font-size: 0.75rem; color: var(--on-surface-variant); line-height: 1.4; }

/* SOCIAL BAND */
.social-band { background: var(--secondary); border-radius: 3rem; padding: 4rem; display: flex; justify-content: space-between; align-items: center; gap: 3rem; margin: 4rem 0 6rem; flex-wrap: wrap; }
.social-band-text h2 { font-family: 'Noto Serif', serif; font-size: 2rem; font-weight: 900; color: white; margin-bottom: 0.5rem; }
.social-band-text p { font-size: 1rem; color: rgba(255,255,255,0.80); line-height: 1.6; max-width: 400px; }
.social-band-icons { display: flex; gap: 1rem; align-items: center; flex-wrap: wrap; }
.social-icon-btn { width: 56px; height: 56px; background: rgba(255,255,255,0.10); border-radius: 1.5rem; display: flex; align-items: center; justify-content: center; transition: background 0.3s ease; }
.social-icon-btn:hover { background: rgba(255,255,255,0.20); }
.social-icon-btn .material-symbols-outlined { font-size: 1.5rem; color: white; }
.btn-portal { background: var(--tertiary-fixed); color: var(--on-tertiary-fixed); padding: 0.75rem 1.5rem; border-radius: var(--radius-full); font-weight: 700; font-size: 0.9rem; display: flex; align-items: center; gap: 0.5rem; transition: transform 0.3s ease; }
.btn-portal:hover { transform: scale(1.05); }
.btn-portal .material-symbols-outlined { font-size: 1.25rem; }

/* FOOTER */
.site-footer { background: var(--inverse-surface); color: var(--inverse-on-surface); }
.footer-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 3rem; max-width: 1400px; margin: 0 auto; padding: 4rem 3rem 3rem; }
.footer-col h5 { font-family: 'Inter', sans-serif; font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: rgba(255,255,255,0.60); margin-bottom: 1.25rem; }
.footer-col ul li { margin-bottom: 0.6rem; }
.footer-col ul li a { font-size: 0.9rem; color: var(--inverse-on-surface); opacity: 0.80; transition: opacity 0.3s ease, color 0.3s ease; }
.footer-col ul li a:hover { opacity: 1; color: var(--primary-fixed-dim); }
.footer-col p { font-size: 0.9rem; line-height: 1.6; opacity: 0.80; margin-bottom: 1rem; }
.footer-logo { font-family: 'Noto Serif', serif; font-size: 1.5rem; font-weight: 900; color: white; margin-bottom: 1rem; }
.footer-social { display: flex; gap: 0.75rem; }
.footer-social a { width: 40px; height: 40px; background: rgba(255,255,255,0.10); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; transition: background 0.3s ease; }
.footer-social a:hover { background: rgba(255,255,255,0.20); }
.footer-social a .material-symbols-outlined { font-size: 1.25rem; color: white; }
.btn-footer-cta { display: inline-block; background: var(--primary); color: white; padding: 0.6rem 1.25rem; border-radius: var(--radius-full); font-weight: 700; font-size: 0.85rem; margin-bottom: 1rem; transition: background 0.3s ease; }
.btn-footer-cta:hover { background: var(--primary-container); }
.footer-affiliation { font-size: 0.75rem !important; opacity: 0.50 !important; margin-bottom: 0 !important; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,0.10); padding: 1.5rem 3rem; max-width: 1400px; margin: 0 auto; }
.footer-bottom p { font-size: 0.8rem; opacity: 0.50; text-align: center; }

/* BACK TO TOP */
.back-to-top { position: fixed; bottom: 2rem; right: 2rem; width: 48px; height: 48px; border-radius: 50%; background: var(--primary); color: white; border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 20px rgba(164,62,0,0.3); opacity: 0; transform: translateY(20px); transition: opacity 0.3s ease, transform 0.3s ease; z-index: 40; }
.back-to-top.visible { opacity: 1; transform: translateY(0); }
.back-to-top:hover { background: var(--primary-container); transform: translateY(-2px); }

/* RESPONSIVE */
@media (max-width: 1024px) {
  .section-container { padding: 0 2rem; }
  .nav-container { padding: 1rem 2rem; }
  .hero h1 { font-size: 3.5rem; }
  .hero-grid { grid-template-columns: 1fr; }
  .hero-right { display: none; }
  .hero-visual-ring { animation: none; }
  .courses-header h2 { font-size: 2.75rem; }
  .features-grid { grid-template-columns: repeat(2, 1fr); }
  .values-grid { grid-template-columns: repeat(3, 1fr); }
  .roadmap-steps { grid-template-columns: repeat(3, 1fr); gap: 2rem; }
  .roadmap-connector { display: none; }
  .footer-grid { grid-template-columns: repeat(2, 1fr); }
  .faculty-cards { grid-template-columns: repeat(2, 1fr); }
  .campus-feature-cards { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .section-container { padding: 0 1.5rem; }
  .nav-container { padding: 1rem 1.5rem; }
  .hamburger { display: block; }
  .nav-links { display: none; position: fixed; top: 64px; left: 0; width: 100%; background: var(--background); flex-direction: column; padding: 1.5rem; gap: 1rem; box-shadow: 0 8px 24px rgba(0,0,0,0.10); z-index: 49; align-items: flex-start; }
  .nav-links.open { display: flex; }
  .nav-link { font-size: 1.25rem; width: 100%; padding: 0.5rem 0; }
  .nav-cta { width: 100%; text-align: center; justify-content: center; margin-top: 0.5rem; }
  .hero { min-height: auto; padding: 7rem 1.5rem 3rem; }
  .hero h1 { font-size: 2.5rem; }
  .hero-sub { font-size: 1.05rem; }
  .hero-buttons { flex-direction: column; }
  .hero-btn-primary, .btn-ghost { width: 100%; justify-content: center; }
  .announcements-grid { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .courses-grid { grid-template-columns: 1fr; }
  .courses-header h2 { font-size: 2.25rem; }
  .campus-top { grid-template-columns: 1fr; gap: 2rem; }
  .features-grid { grid-template-columns: 1fr; }
  .page-header h1 { font-size: 2.5rem; }
  .history-grid { grid-template-columns: 1fr; }
  .history-sidebar { position: static; }
  .mv-grid { grid-template-columns: 1fr; }
  .values-grid { grid-template-columns: repeat(2, 1fr); }
  .affiliation-grid { grid-template-columns: 1fr; }
  .affiliation-cards { grid-template-columns: 1fr; }
  .affiliation-container { padding: 2rem; border-radius: 2rem; }
  .accordion-header { flex-direction: column; align-items: flex-start; }
  .accordion-header-right { width: 100%; justify-content: flex-start; }
  .accordion-content-grid { grid-template-columns: 1fr; }
  .roadmap-steps { grid-template-columns: repeat(2, 1fr); }
  .documents-grid { grid-template-columns: 1fr; }
  .facility-grid { grid-template-columns: 1fr; }
  .facility-grid.reverse { direction: ltr; }
  .faculty-cards { grid-template-columns: 1fr; }
  .campus-feature-cards { grid-template-columns: 1fr; }
  .contact-hero-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .contact-cards-grid { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .social-band { flex-direction: column; text-align: center; padding: 3rem 2rem; border-radius: 2rem; }
  .social-band-text p { max-width: 100%; }
  .footer-grid { grid-template-columns: 1fr; gap: 2rem; padding: 3rem 1.5rem 2rem; }
  .marquee-content { font-size: 0.85rem; }
  .cta-banner { padding: 3rem 2rem; border-radius: 2rem; }
  .cta-banner h2 { font-size: 2rem; }
  .apply-cta { padding: 3rem 2rem; border-radius: 2rem; }
  .apply-cta h2 { font-size: 2rem; }
  .apply-cta-buttons { flex-direction: column; }
  .btn-apply-portal, .btn-contact-admissions { width: 100%; justify-content: center; }
}

@media (max-width: 480px) {
  .section-container { padding: 0 1rem; }
  .hero { padding: 6rem 1rem 2rem; }
  .hero h1 { font-size: 2rem; }
  .page-header h1 { font-size: 2rem; }
  .page-header { padding: 7rem 0 3rem; }
  .announcements, .stats-bar, .courses-overview, .campus-highlights, .history-section, .mission-vision, .core-values, .affiliation, .courses-accordion, .roadmap-section, .eligibility-section, .documents-section, .facility-section, .faculty-section, .contact-content { padding: 3rem 0; }
  .values-grid { grid-template-columns: 1fr; }
  .roadmap-steps { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
  .stat-item .stat-number { font-size: 2.25rem; }
  .contact-hero-text h1 { font-size: 2.25rem; }
  .contact-form-card { padding: 2rem 1.5rem; }
  .footer-bottom { padding: 1.5rem 1rem; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; }
  .marquee-track { animation: none !important; }
  .hero-pulse { animation: none !important; }
  .hero-visual-ring { animation: none !important; }
}