/* ══════════════════════════════════════════
   ROOT VARIABLES
═════════════════════════════════════════ */
:root {
  --g1: #002147; --g2: #003366; --g3: #0056b3; --g4: #007ea7; --g5: #4da6d4;
  --accent-red: #c8102e; --accent-gold: #f4b400; --accent-green: #2e8b57;
  --white: #ffffff; --offwhite: #f0f8ff; --bg-color: #F4F7FA;
  --text: #002147; --textmid: #333c48; --textsoft: #5e6d7a; --border: #cfe0e8;
  --glight: #e6f3ff; --gpale: #f0f7ff;
  --yellow: var(--accent-gold); --yellow2: #ffd740; --yellowlt: #fff8e1;
}

.mi { font-family:'Material Symbols Rounded';font-style:normal;font-weight:normal;font-size:inherit;display:inline-flex;align-items:center;justify-content:center;vertical-align:middle;line-height:1;font-variation-settings:'FILL' 1,'wght' 400,'GRAD' 0,'opsz' 24; }
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Plus Jakarta Sans',sans-serif;color:var(--text);background:var(--bg-color);overflow-x:hidden;}
.page{display:none;}
.page.active{display:block;}

/* ══════════════ TOPBAR ══════════════ */
.topbar{background:var(--g3);padding:10px 64px;display:flex;justify-content:space-between;align-items:center;font-size:12.5px;color:rgba(255,255,255,0.9);border-bottom:1px solid rgba(255,255,255,0.2);}
.topbar span{display:flex;align-items:center;gap:6px;}
.topbar a{color:rgba(255,255,255,0.9);text-decoration:none;transition:color .2s;}
.topbar a:hover{color:var(--accent-gold);}
.tb-links{display:flex;gap:24px;}

/* ══════════════ NAVIGATION ══════════════ */
nav{background:var(--white);position:sticky;top:0;z-index:1000;box-shadow:0 4px 20px rgba(0,33,71,0.08);border-bottom:4px solid var(--g3);height:auto;}
.nav-top{padding:0 64px;display:flex;align-items:center;justify-content:space-between;height:115px;max-width:100%;box-sizing:border-box;}
.nav-brand{display:flex;align-items:center;gap:18px;text-decoration:none;cursor:pointer;flex-shrink:0;}
.brand-logo-img{width:85px;height:85px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,33,71,0.15));}
.brand-name{font-family:'Playfair Display',serif;font-size:28px;font-weight:700;color:var(--g1);line-height:1.2;}
.brand-sub{font-size:14px;color:var(--textsoft);font-weight:400;letter-spacing:0.3px;white-space:nowrap;}

.nav-menu-wrap{background:var(--g3);padding:0 64px;border-top:1px solid rgba(255,255,255,0.15);height:54px;position:relative;z-index:1002;}
.nav-menu{display:flex;align-items:center;list-style:none;gap:0;margin:0;padding:0;height:100%;}
.nav-menu > li{position:relative;height:100%;display:flex;align-items:center;}
.nav-menu > li > a{display:flex;align-items:center;height:100%;padding:0 20px;color:white;text-decoration:none;font-size:14px;font-weight:600;white-space:nowrap;transition:background .2s;border-bottom:3px solid transparent;cursor:pointer;box-sizing:border-box;}
.nav-menu > li > a:hover, .nav-menu > li > a.nav-active{background:rgba(255,255,255,0.1);border-bottom-color:var(--accent-gold);}

/* MEGA MENU */
.mega-menu{display:none;position:fixed !important;top:169px;left:0 !important;right:0;width:100% !important;transform:none !important;background:linear-gradient(160deg, #ffffff 0%, #e3f2fd 60%, #fff8e1 100%);border-top:4px solid var(--g1);box-shadow:0 25px 60px rgba(0,0,0,0.08);z-index:1001;padding:48px 64px;box-sizing:border-box;opacity:0;visibility:hidden;pointer-events:none;transition:opacity 0.3s ease, visibility 0.3s ease;}
.has-mega:hover .mega-menu{display:block !important;opacity:1;visibility:visible;pointer-events:auto;}
.mega-inner{display:grid !important;grid-template-columns:1fr 320px !important;gap:48px !important;max-width:1200px;margin:0 auto;}
.mega-cols{display:grid !important;grid-template-columns:repeat(3, 1fr) !important;gap:32px !important;}
.mega-col h4{font-size:12px;font-weight:700;text-transform:uppercase;color:var(--g1);letter-spacing:1.5px;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid rgba(0,0,0,0.05);}
.mega-links{list-style:none;padding:0;margin:0;}
.mega-links li{margin-bottom:0;}
.mega-links a{display:flex;align-items:center;width:100%;padding:12px 18px;margin-bottom:8px;background:#002147;color:rgba(255,255,255,0.9);border-radius:8px;font-size:14px;font-weight:500;text-decoration:none;transition:all 0.2s ease;}
.mega-links a:hover{background:var(--accent-gold);color:var(--g1);transform:translateY(-2px);box-shadow:0 5px 15px rgba(244, 180, 0, 0.3);}
.mega-preview{position:relative;height:100%;min-height:240px;border-radius:16px;overflow:hidden;border:1px solid rgba(0,0,0,0.05);box-shadow:0 15px 35px rgba(0,0,0,0.08);}
.mega-preview img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s;}
.has-mega:hover .mega-preview img{transform:scale(1.05);}
.mega-preview-caption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top, rgba(0,33,71,0.9), transparent);padding:24px;color:white;}
.mega-preview-caption h5{font-size:18px;margin-bottom:4px;font-family:'Playfair Display',serif;}
.mega-preview-caption p{font-size:12px;opacity:0.8;}

/* SIMPLE DROPDOWN */
.has-drop:not(.has-mega) .dropdown{display:none;position:absolute;top:100%;left:0;background:linear-gradient(160deg, #ffffff 0%, #e3f2fd 60%, #fff8e1 100%);border-top:4px solid var(--g1);min-width:260px;box-shadow:0 20px 50px rgba(0,0,0,0.08);z-index:1001;padding:16px;border-radius:0 0 12px 12px;}
.has-drop:not(.has-mega):hover .dropdown{display:block;}
.dropdown a{display:flex;align-items:center;gap:10px;padding:12px 16px;margin-bottom:8px;background:#002147;color:rgba(255,255,255,0.9);border-radius:8px;font-size:14px;font-weight:500;text-decoration:none;transition:all 0.2s ease;}
.dropdown a:hover{background:var(--accent-gold);color:var(--g1);box-shadow:0 5px 15px rgba(244, 180, 0, 0.3);}
.dropdown a:last-child{margin-bottom:0;}
.nav-toggle{display:none;position:absolute;right:24px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--g1);font-family:'Material Symbols Rounded';font-size:32px;cursor:pointer;z-index:1003;}

/* ══════════════ HERO SECTION ══════════════ */
.hero{position:relative;width:100%;height:85vh;min-height:600px;max-height:900px;background:#000;overflow:hidden;}
.carousel-track{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;transition:transform .9s cubic-bezier(0.77,0,0.18,1);}
.c-slide{position:relative;width:100%;min-width:100%;height:100%;flex-shrink:0;}
.c-slide img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transform:scale(1.02);transition:transform 7s ease;}
.c-slide.active img{transform:scale(1.0);}
.c-overlay{display:none;}
/* ══════════════ HERO REDESIGN: CARD LEFT + RIBBON BOTTOM ══════════════ */

/* 1. Text Card Container (Bottom Left) */
.hero-panel-text {
    position: absolute;
    bottom: 90px; /* Space for the ribbon */
    left: 0;
    right: 0;
    z-index: 10;
    display: flex;
    justify-content: flex-start; /* Align Left */
    padding: 0 64px;
    pointer-events: none;
    box-sizing: border-box;
}

/* The Small Semi-Transparent Card */
.hero-card-small {
    pointer-events: auto;
    max-width: 480px; /* Small width */
    padding: 12px;
    background: rgba(255, 255, 255, 0.5); /* Semi-transparent white */
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.6);
    box-shadow: 0 15px 40px rgba(0, 33, 71, 0.1);
    
    /* Animation */
    animation: fadeSlideUp 0.8s ease forwards;
    opacity: 0;
    transform: translateY(30px);
}
@keyframes fadeSlideUp {
    to { opacity: 1; transform: translateY(0); }
}

.hero-badge-inline {
    display: inline-flex;
    align-items: center;
    background: var(--g1);
    color: var(--accent-gold);
    padding: 4px 12px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 600;
    margin-bottom: 16px;
    letter-spacing: 0.5px;
}

.hero-card-small h1 {
    font-family: 'Playfair Display', serif;
    font-size: clamp(26px, 3vw, 38px);
    font-weight: 900;
    color: var(--g1);
    line-height: 1.2;
    margin-bottom: 12px;
}
.hero-card-small h1 em {
    font-style: italic;
    color: var(--g3);
}
.hero-desc-inline {
    font-size: 14px;
    color: var(--textmid);
    line-height: 1.6;
    margin: 0;
}

/* 2. Button Ribbon (Bottom Edge) */
.hero-ribbon {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 70px;
    background: rgba(0, 33, 71, 0.75); /* Dark Ribbon */
    backdrop-filter: blur(10px);
    z-index: 15;
    display: flex;
    align-items: center;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 -5px 20px rgba(0,0,0,0.1);
}

.hero-ribbon-inner {
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 64px;
    display: flex;
    gap: 16px;
    justify-content: flex-start; /* Align left to match card */
    flex-wrap: nowrap;
}

/* Buttons in Ribbon */
.btn-hero-gold {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--accent-gold);
    color: var(--g1);
    padding: 0 24px;
    height: 44px;
    border-radius: 6px;
    font-weight: 700;
    font-size: 14px;
    text-decoration: none;
    transition: all 0.2s;
    cursor: pointer;
    border: none;
    white-space: nowrap;
}
.btn-hero-gold:hover {
    background: white;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}

.btn-hero-ghost {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(255, 255, 255, 0.1);
    color: white;
    padding: 0 24px;
    height: 44px;
    border-radius: 6px;
    font-weight: 600;
    font-size: 14px;
    text-decoration: none;
    transition: all 0.2s;
    border: 1px solid rgba(255, 255, 255, 0.15);
    cursor: pointer;
    white-space: nowrap;
}
.btn-hero-ghost:hover {
    background: rgba(255, 255, 255, 0.2);
    border-color: rgba(255, 255, 255, 0.3);
}

/* Responsive */
@media(max-width: 968px) {
    .hero-panel-text {
        padding: 0 20px;
        bottom: 100px; /* More space for stacked buttons */
    }
    .hero-card-small {
        padding: 24px;
        max-width: 100%; /* Full width on tablet */
    }
    .hero-ribbon {
        height: auto;
        padding: 16px 20px;
    }
    .hero-ribbon-inner {
        padding: 0;
        flex-wrap: wrap;
        gap: 10px;
    }
    .btn-hero-ghost, .btn-hero-gold {
        flex: 1 1 45%; /* 2 columns */
        justify-content: center;
    }
}

@media(max-width: 480px) {
    .hero-panel-text {
        bottom: 130px; /* Space for 3 rows of buttons */
    }
    .hero-card-small h1 { font-size: 24px; }
    .hero-ribbon-inner {
        flex-direction: column;
    }
    .btn-hero-ghost, .btn-hero-gold {
        width: 100%;
    }
}
/* ══════════════ MARQUEE ══════════════ */
.marquee-bar{background:var(--g3);padding:13px 0;overflow:hidden;border-bottom:2px solid rgba(255,255,255,0.1);}
.marquee-track{display:inline-flex;animation:marquee 30s linear infinite;}
.marquee-item{display:inline-flex;align-items:center;gap:10px;padding:0 32px;color:white;font-size:13px;font-weight:600;}
.mdot{width:6px;height:6px;background:var(--accent-gold);border-radius:50%;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ══════════════ SECTIONS ══════════════ */
section{padding:80px 64px;}
.s-label{font-size:11.5px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--accent-green);margin-bottom:10px;}
h2{font-family:'Playfair Display',serif;font-size:clamp(28px,3.5vw,44px);font-weight:700;color:var(--g1);line-height:1.2;margin-bottom:14px;}

/* ══════════════ COMPONENTS ══════════════ */
.quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.quick-card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:28px 20px;text-align:center;cursor:pointer;transition:transform .2s,border-color .2s;position:relative;overflow:hidden;}
.quick-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg, var(--accent-red), var(--accent-gold), var(--accent-green));transform:scaleX(0);transition:transform .3s;}
.quick-card:hover{transform:translateY(-4px);border-color:var(--g3);}
.quick-card:hover::before{transform:scaleX(1);}
.qc-icon{font-size:38px;color:var(--g3);margin-bottom:14px;font-family:'Material Symbols Rounded';}
.qc-title{font-size:15px;font-weight:700;color:var(--g1);}

.stat-strip{background:var(--g1);padding:48px 64px;}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.stat-item{text-align:center;}
.stat-num{font-family:'Playfair Display',serif;font-size:48px;font-weight:900;color:var(--accent-gold);line-height:1;}
.stat-lbl{font-size:13px;color:rgba(255,255,255,0.6);margin-top:6px;}

.cta-banner{background:linear-gradient(120deg,var(--offwhite),var(--glight));padding:72px 64px;text-align:center;border-top:1px solid var(--border);}
.cta-banner h2{color:var(--g1);margin-bottom:14px;}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}

/* ══════════════ BUTTONS ══════════════ */
.btn-p, .btn-primary{background:linear-gradient(135deg, var(--accent-gold), #d4a300);color:var(--g1);padding:13px 32px;border-radius:6px;font-weight:700;font-size:14px;text-decoration:none;box-shadow:0 4px 15px rgba(244,180,0,0.3);transition:transform .15s, box-shadow .15s;border:none;cursor:pointer;}
.btn-p:hover, .btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(244,180,0,0.45);color:var(--g1);}
.btn-outline{display:inline-block;border:2px solid var(--g3);color:var(--g3);padding:13px 32px;border-radius:6px;text-decoration:none;font-weight:600;font-size:14px;transition:background .2s,color .2s;background:transparent;}
.btn-outline:hover{background:var(--g3);color:white;}
.btn-white{display:inline-block;background:white;color:var(--g3);padding:10px 22px;border-radius:6px;font-weight:700;text-decoration:none;transition:background .2s;}
.btn-white:hover{background:var(--glight);color:var(--g1);}

/* ══════════════ PROGRAMME PAGE ══════════════ */
.prog-grid{display:grid;grid-template-columns:1fr 370px;gap:48px;align-items:start;}
.prog-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:24px;overflow:hidden;}
.prog-head{background:linear-gradient(135deg,var(--g1),var(--g2));padding:24px;border-radius:12px;margin:-24px -24px 24px;color:rgba(255,255,255,0.9);}
.prog-title{font-family:'Playfair Display',serif;font-size:32px;color:white;margin-bottom:4px;}
.prog-full{font-size:14px;color:rgba(255,255,255,0.8);margin-bottom:16px;}
.prog-body p{font-size:14px;color:var(--textmid);line-height:1.7;margin-bottom:16px;}
.subj-list{display:flex;flex-wrap:wrap;gap:7px;margin-top:16px;}
.subj{background:var(--glight);color:var(--g2);font-size:12.5px;padding:4px 12px;border-radius:4px;font-weight:500;}
.prog-sidebar{display:flex;flex-direction:column;gap:16px;}
.sidebar-cta{background:var(--g2);border-radius:14px;padding:26px;text-align:center;color:white;}
.sidebar-cta h4{font-size:18px;margin-bottom:8px;}
.electives-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px;}
.elective-tag{background:var(--gpale);border:1px solid var(--border);color:var(--g2);font-size:13px;padding:10px 16px;border-radius:6px;font-weight:600;text-align:center;transition:all .2s;}
.elective-tag:hover{background:var(--glight);border-color:var(--g3);color:var(--g1);}
.prog-container{display:flex;flex-direction:column;gap:48px;}

/* ══════════════ ADMISSIONS PAGE ══════════════ */
.adm-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;}
.adm-box{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:34px;}
.adm-box h3{font-size:20px;font-weight:700;color:var(--g1);margin-bottom:16px;}
.adm-list{list-style:none;}
.adm-list li{padding:10px 0;border-bottom:1px solid var(--gpale);font-size:14px;color:var(--textmid);}
.timeline{display:flex;flex-direction:column;gap:12px;}
.t-step{display:flex;gap:12px;}
.t-num{width:28px;height:28px;background:var(--g3);color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;}
.t-content h4{font-size:14px;font-weight:700;color:var(--g1);}

/* ══════════════ ABOUT PAGE ══════════════ */
.about-layout{display:grid;grid-template-columns:250px 1fr;gap:48px;max-width:1200px;margin:0 auto;}
.about-sidebar{position:sticky;top:180px;height:fit-content;background:var(--gpale);padding:24px;border-radius:12px;border:1px solid var(--border);z-index:10;}
.about-nav{list-style:none;display:flex;flex-direction:column;gap:8px;}
.about-nav a{display:block;padding:10px 16px;text-decoration:none;font-size:13px;font-weight:600;color:var(--textmid);border-radius:6px;transition:all .2s;border-left:3px solid transparent;}
.about-nav a:hover,.about-nav a.active{background:var(--white);color:var(--g1);border-left-color:var(--accent-gold);box-shadow:0 2px 8px rgba(0,0,0,0.05);}
.about-content-section{padding-top:20px;scroll-margin-top:180px;}
.about-content-section h2{margin-bottom:16px;font-size:26px;}
.about-content-section p{font-size:15px;color:var(--textmid);line-height:1.8;margin-bottom:16px;}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;}
.about-visual{background:linear-gradient(145deg,var(--glight),#90caf9);border-radius:20px;height:300px;position:relative;overflow:hidden;}

/* Vision / Mission / Quality Row */
.vmq-row{display:grid;grid-template-columns:200px 1fr;gap:40px;align-items:center;margin-bottom:48px;padding-bottom:48px;border-bottom:1px solid var(--border);}
.vmq-row:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0;}
.vmq-row.reverse{grid-template-columns:1fr 200px;}
.vmq-row.reverse .vmq-img{order:2;}
.vmq-row.reverse .vmq-content{order:1;}
.vmq-img img{width:100%;max-width:180px;height:auto;margin:0 auto;display:block;filter:drop-shadow(0 4px 6px rgba(0,0,0,0.1));}
.vmq-content h2{margin-bottom:12px;}

/* Scope Grid */
.scope-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px;}
.scope-item{background:var(--gpale);padding:12px 16px;border-radius:6px;font-size:13px;color:var(--textmid);display:flex;align-items:center;gap:8px;}
.scope-item::before{content:'';width:6px;height:6px;background:var(--g3);border-radius:50%;flex-shrink:0;}

/* Leadership Grid */
.leadership-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:32px;}
.leader-profile-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:24px 16px;text-align:center;transition:transform 0.2s, box-shadow 0.2s;}
.leader-profile-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px rgba(0,0,0,0.08);border-color:var(--accent-gold);}
.leader-photo-wrap{width:90px;height:90px;margin:0 auto 16px;border-radius:50%;overflow:hidden;border:3px solid var(--gpale);background:var(--gpale);}
.leader-photo-wrap img{width:100%;height:100%;object-fit:cover;transition:transform 0.3s;}
.leader-profile-card:hover .leader-photo-wrap img{transform:scale(1.05);}
.leader-name{font-size:15px;font-weight:700;color:var(--g1);margin-bottom:4px;line-height:1.2;}
.leader-designation{font-size:12px;color:var(--textsoft);font-weight:500;text-transform:uppercase;letter-spacing:0.5px;}

/* Accreditation Badges */
.about-content-section .accred-badge{background:var(--g1);border:1px solid var(--g2);}
.about-content-section .accred-badge-icon{color:var(--accent-gold);}
.about-content-section .accred-badge-title{color:white;}
.about-content-section .accred-badge-sub{color:rgba(255,255,255,0.6);}

/* ══════════════ COMMITTEE & COUNCIL ══════════════ */
.committee-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:24px;}
.committee-card{background:var(--gpale);border:1px solid var(--border);border-radius:12px;padding:24px;border-left:4px solid var(--g3);}
.committee-card h3{font-family:'Playfair Display',serif;font-size:20px;color:var(--g1);margin-bottom:12px;}
.committee-card ul{list-style:none;}
.committee-card li{position:relative;padding-left:20px;margin-bottom:8px;font-size:14px;color:var(--textmid);}
.committee-card li::before{content:'';position:absolute;left:0;top:8px;width:6px;height:6px;background:var(--g3);border-radius:50%;}

.council-grid{display:grid;grid-template-columns:repeat(5, 1fr);gap:20px;margin-top:32px;}
.council-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:24px 16px;text-align:center;transition:transform 0.2s;}
.council-card:hover{transform:translateY(-3px);box-shadow:0 8px 20px rgba(0,0,0,0.06);border-color:var(--accent-gold);}
.council-icon{width:60px;height:60px;background:var(--glight);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;color:var(--g3);font-family:'Material Symbols Rounded';font-size:28px;}
.council-title{font-size:14px;font-weight:700;color:var(--g1);margin-bottom:4px;}
.council-desc{font-size:12px;color:var(--textsoft);}

/* ══════════════ CONTACT PAGE ══════════════ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.contact-info-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:32px;box-shadow:0 4px 15px rgba(0,0,0,0.05);}
.contact-info-card h3{font-size:20px;font-weight:700;color:var(--g1);margin-bottom:24px;}
.ci{display:flex;flex-direction:row;align-items:center;gap:16px;padding:16px;background:var(--gpale);border-radius:10px;margin-bottom:12px;}
.ci-icon{font-size:22px;color:var(--g3);flex-shrink:0;width:44px;height:44px;background:var(--white);border-radius:8px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 5px rgba(0,0,0,0.05);}
.ci-details{flex:1;min-width:0;}
.ci-val{font-size:15px;font-weight:600;color:var(--g1);line-height:1.3;}
.ci-sub{font-size:13px;color:var(--textsoft);margin-top:2px;}
.contact-map-wrap{background:var(--white);border:1px solid var(--border);border-radius:12px;overflow:hidden;height:100%;min-height:400px;}
.contact-map-wrap iframe{width:100%;height:100%;border:0;}
.social-btns{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap;}
.social-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:8px;text-decoration:none;font-size:14px;font-weight:600;transition:transform 0.2s, box-shadow 0.2s;box-shadow:0 2px 8px rgba(0,0,0,0.05);}
.social-btn.yt{background:#FF0000;color:white;}
.social-btn.ig{background:linear-gradient(45deg, #f09433 0%,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%);color:white;}
.social-btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px rgba(0,0,0,0.15);}

/* ══════════════ TEACHING PAGE ══════════════ */
.teaching-features{display:grid;grid-template-columns:repeat(4, 1fr);gap:20px;margin-top:32px;margin-bottom:48px;}
.feature-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:24px;text-align:center;transition:all 0.2s;border-bottom:4px solid transparent;}
.feature-card:hover{transform:translateY(-4px);box-shadow:0 10px 30px rgba(0,0,0,0.06);border-bottom-color:var(--g3);}
.feature-icon{width:56px;height:56px;background:var(--gpale);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--g3);font-size:28px;font-family:'Material Symbols Rounded';}
.feature-title{font-size:15px;font-weight:700;color:var(--g1);line-height:1.3;}
.teaching-layout{display:grid !important;grid-template-columns:1fr 1.2fr;gap:48px;align-items:start;}
.teaching-layout .t-carousel{order:2;}
.teaching-layout > div:first-child{order:1;}
.t-carousel{position:relative;width:100%;height:380px;border-radius:12px;overflow:hidden;box-shadow:0 8px 20px rgba(0,0,0,0.1);background:#eee;}
.t-track{display:flex;height:100%;transition:transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);}
.t-slide{min-width:100%;height:100%;}
.t-slide img{width:100%;height:100%;object-fit:cover;display:block;}
.t-dots{position:absolute;bottom:15px;left:0;width:100%;display:flex;justify-content:center;gap:8px;z-index:10;}
.t-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.5);cursor:pointer;transition:all 0.3s;}
.t-dot.active{background:var(--accent-gold);width:24px;border-radius:4px;}

/* ══════════════ GALLERY PAGES ══════════════ */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.gallery-card{background:var(--white);border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .2s, box-shadow .2s;}
.gallery-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(14,61,110,0.12);}
.gall-img-wrap{height:180px;overflow:hidden;position:relative;}
.gall-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.gallery-card:hover .gall-img-wrap img{transform:scale(1.05);}
.gall-badge{position:absolute;top:10px;left:10px;background:rgba(10,37,64,0.85);color:white;font-size:10px;font-weight:700;padding:4px 10px;border-radius:4px;text-transform:uppercase;}
.gall-body{padding:16px;}
.gall-title{font-size:15px;font-weight:700;color:var(--g1);margin-bottom:6px;}
.gall-desc{font-size:13px;color:var(--textsoft);line-height:1.5;}
.gall-count{font-size:11px;color:var(--g3);font-weight:600;margin-top:8px;display:flex;align-items:center;gap:4px;}

.gallery-modal{display:none;position:fixed;z-index:9999;left:0;top:0;width:100%;height:100%;background-color:rgba(0,0,0,0.95);justify-content:center;align-items:center;flex-direction:column;}
.gallery-modal.active{display:flex;}
.gm-container{position:relative;max-width:90%;width:1200px;background:#111;border-radius:8px;overflow:hidden;display:flex;flex-direction:column;}
.gm-header{padding:16px 24px;background:#222;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #333;}
.gm-title{color:white;font-size:18px;font-weight:600;}
.gm-close{color:#aaa;font-size:32px;font-weight:bold;cursor:pointer;background:none;border:none;transition:color .2s;}
.gm-close:hover{color:white;}
.gm-main{position:relative;height:60vh;min-height:400px;background:#000;display:flex;align-items:center;justify-content:center;}
.gm-main img{max-width:100%;max-height:100%;object-fit:contain;}
.gm-nav{position:absolute;top:50%;transform:translateY(-50%);width:100%;display:flex;justify-content:space-between;padding:0 10px;pointer-events:none;}
.gm-nav button{pointer-events:all;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);color:white;width:44px;height:44px;border-radius:50%;cursor:pointer;font-size:20px;transition:background .2s;}
.gm-nav button:hover{background:var(--accent-gold);color:var(--g1);}
.gm-thumbs{background:#181818;padding:16px;overflow-x:auto;white-space:nowrap;}
.gm-thumb{height:60px;border-radius:4px;cursor:pointer;margin-right:8px;opacity:0.5;border:2px solid transparent;display:inline-block;}
.gm-thumb.active{opacity:1;border-color:var(--accent-gold);}

.flat-gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.flat-gallery-item{position:relative;border-radius:8px;overflow:hidden;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,0.05);}
.flat-gallery-item img{width:100%;height:200px;object-fit:cover;transition:transform .3s;}
.flat-gallery-item:hover img{transform:scale(1.05);}
.flat-gallery-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top, rgba(0,0,0,0.7), transparent);padding:16px;opacity:0;transition:opacity .3s;}
.flat-gallery-item:hover .flat-gallery-overlay{opacity:1;}
.flat-gallery-overlay span{color:white;font-size:12px;font-weight:600;}

/* ══════════════ FOOTER ══════════════ */
.main-footer{background:var(--g1);padding:60px 64px 30px;color:rgba(255,255,255,0.7);font-size:14px;border-top:4px solid var(--g3);}
.footer-grid-new{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:48px;margin-bottom:40px;}
.footer-brand img{width:48px;height:48px;margin-bottom:12px;}
.footer-brand h3{font-family:'Playfair Display',serif;font-size:18px;color:white;margin-bottom:4px;}
.footer-brand p{font-size:12px;color:rgba(255,255,255,0.5);margin-bottom:16px;}
.footer-desc{font-size:13px;line-height:1.7;color:rgba(255,255,255,0.6);}
.footer-section h4{color:var(--accent-gold);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:20px;}
.footer-links{list-style:none;padding:0;}
.footer-links li{margin-bottom:10px;word-break:break-word;overflow-wrap:break-word;}
.footer-links a{color:rgba(255,255,255,0.65);text-decoration:none;transition:color 0.2s;}
.footer-links a:hover{color:white;}
.footer-social{display:flex;gap:12px;margin-top:8px;}
.footer-social a{width:36px;height:36px;background:rgba(255,255,255,0.05);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--yellow2);font-size:18px;transition:background 0.2s;}
.footer-social a:hover{background:var(--accent-gold);color:var(--g1);}
.footer-bottom-new{border-top:1px solid rgba(255,255,255,0.1);padding-top:20px;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:rgba(255,255,255,0.4);}

/* ══════════════ PAGE HERO (Internal Pages) ══════════════ */
.page-hero{position:relative;min-height:380px;height:auto;display:flex;align-items:center;padding:80px 64px;background-color:var(--g1);background-size:cover;background-position:center;overflow:hidden;}
.page-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(105deg, rgba(0,33,71,0.95) 0%, rgba(0,86,179,0.85) 50%, rgba(0,33,71,0.4) 100%);z-index:1;}
.page-hero::after{content:'';position:absolute;right:-100px;bottom:-100px;width:400px;height:400px;border-radius:50%;background:rgba(244,180,0,0.1);z-index:1;pointer-events:none;}
.page-hero-inner{position:relative;z-index:2;width:100%;max-width:1200px;margin:0 auto;}
.page-hero h1{font-family:'Playfair Display',serif;font-size:clamp(32px, 4vw, 52px);font-weight:900;color:white;line-height:1.2;margin-bottom:16px;text-shadow:0 2px 10px rgba(0,0,0,0.3);}
.page-hero p{font-size:16px;color:rgba(255,255,255,0.85);max-width:600px;line-height:1.7;font-weight:300;}
.page-breadcrumb{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,0.1);padding:8px 16px;border-radius:50px;margin-bottom:24px;backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,0.1);}
.page-breadcrumb a{color:rgba(255,255,255,0.7);text-decoration:none;font-size:12px;font-weight:500;transition:color 0.2s;}
.page-breadcrumb a:hover{color:var(--accent-gold);}
.page-breadcrumb span{color:var(--accent-gold);font-size:12px;font-weight:600;}

/* ══════════════ INFRASTRUCTURE SECTIONS ══════════════ */
.infra-section{padding:80px 64px;}
.infra-section.alt-bg{background:var(--glight);}
.infra-header{max-width:800px;margin-bottom:40px;}
.infra-header h2{margin-bottom:12px;}

/* ══════════════ ACADEMIC EVENTS GRID ══════════════ */
.academic-grid{display:grid;grid-template-columns:repeat(4, 1fr);gap:24px;margin-top:32px;}
.academic-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:32px 20px;text-align:center;transition:all 0.3s ease;border-bottom:4px solid transparent;}
.academic-card:hover{transform:translateY(-5px);box-shadow:0 15px 35px rgba(0,0,0,0.08);border-bottom-color:var(--accent-gold);}
.ac-icon{width:64px;height:64px;background:var(--gpale);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:var(--g3);font-size:32px;font-family:'Material Symbols Rounded';transition:all 0.3s;}
.academic-card:hover .ac-icon{background:var(--g3);color:white;}
.ac-title{font-size:15px;font-weight:700;color:var(--g1);line-height:1.4;}

/* ══════════════ NEWSLETTER SECTION ══════════════ */
.newsletter-section{background:var(--glight);padding:80px 64px;border-top:1px solid var(--border);}
.newsletter-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(240px, 1fr));gap:24px;margin-top:32px;}
.newsletter-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:32px 24px;text-decoration:none;text-align:center;transition:all 0.3s ease;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.newsletter-card:hover{transform:translateY(-5px);box-shadow:0 15px 35px rgba(0,0,0,0.08);border-color:var(--accent-red);}
.newsletter-icon{font-size:48px;color:#D32F2F;margin-bottom:16px;transition:transform 0.3s;}
.newsletter-card:hover .newsletter-icon{transform:scale(1.1);}
.newsletter-title{font-size:16px;font-weight:700;color:var(--g1);margin-bottom:8px;line-height:1.3;}
.newsletter-date{font-size:12px;color:var(--textsoft);margin-bottom:16px;}
.newsletter-btn{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--g3);background:var(--gpale);padding:8px 16px;border-radius:20px;transition:all 0.2s;}
.newsletter-card:hover .newsletter-btn{background:var(--accent-red);color:white;}

/* ══════════════════════════════════════════
   CONSOLIDATED RESPONSIVE FIX (ALL PAGES)
════════════════════════════════════════ */
@media(max-width: 1100px){
  /* Desktop Tablet Adjustments */
  .nav-top, .nav-menu-wrap, .topbar, section, .cta-banner, .stat-strip, .page-hero, .newsletter-section, .infra-section{padding-left:28px;padding-right:28px;}
  
  /* Grid Stacking for Internal Pages */
  .about-layout, .contact-grid, .prog-grid, .adm-grid, .teaching-layout{grid-template-columns:1fr;}
  
  /* Other Grids */
  .quick-grid{grid-template-columns:repeat(2,1fr);}
  .gallery-grid{grid-template-columns:repeat(2,1fr);}
  .flat-gallery-grid{grid-template-columns:repeat(3,1fr);}
  .footer-grid-new{grid-template-columns:repeat(2,1fr);gap:32px;}
  
  /* About Page Specific */
  .about-sidebar{position:relative;top:0;margin-bottom:24px;}
  .leadership-grid{grid-template-columns:repeat(3,1fr);}
  .teaching-features{grid-template-columns:repeat(2,1fr);}
  .academic-grid{grid-template-columns:repeat(3,1fr);}
}

@media(max-width: 768px){
  /* General Padding */
  .nav-top, .nav-menu-wrap, .topbar, section, .cta-banner, footer, .stat-strip, .accred-strip, .page-hero, .newsletter-section, .infra-section{padding-left:15px;padding-right:15px;}
  section{padding:40px 20px;}
  
  /* Topbar Mobile */
  .topbar{padding:6px 15px;justify-content:center;text-align:center;font-size:11px;}
  .topbar .tb-links{display:none;}

  /* Navigation Mobile */
  .nav-top{padding:0 20px;height:auto;min-height:90px;padding-top:15px;padding-bottom:15px;flex-wrap:wrap;}
  .nav-menu-wrap{display:none;position:fixed;top:0;left:0;width:100%;height:100vh;background:var(--g3);padding:100px 0 40px 0;overflow-y:auto;z-index:999;}
  .nav-menu-wrap.active{display:block;}
  .nav-menu{flex-direction:column;width:100%;gap:0;padding:0 24px;}
  .nav-menu > li{width:100%;height:auto;}
  .nav-menu > li > a{width:100%;justify-content:space-between;padding:18px 0;border-bottom:1px solid rgba(255,255,255,0.1);font-size:16px;color:white;}
  .has-drop:not(.has-mega) .dropdown{position:relative;background:rgba(0,0,0,0.2);border:none;box-shadow:none;padding:0 0 15px 0;margin:0;border-radius:0 0 12px 12px;}
  .dropdown a{color:rgba(255,255,255,0.7);padding:10px 20px;margin:4px 0;border-bottom:none;background:rgba(255,255,255,0.05);border-radius:8px;}
  .dropdown a:hover{background:var(--accent-gold);color:var(--g1);}
  .mega-menu{position:relative !important;top:auto !important;left:auto !important;width:100% !important;border:none;box-shadow:none;padding:0 24px;background:rgba(0,0,0,0.2);opacity:1;visibility:visible;pointer-events:auto;}
  .mega-inner{grid-template-columns:1fr !important;gap:0 !important;}
  .mega-cols{grid-template-columns:1fr !important;gap:16px !important;padding:16px 0;}
  .mega-col{margin-bottom:10px;}
  .mega-col h4{color:var(--accent-gold);border-color:rgba(255,255,255,0.1);font-size:11px;margin-bottom:10px;}
  .mega-links a{color:rgba(255,255,255,0.8);background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,0.05);border-radius:0;margin-bottom:0;padding:12px 0;}
  .mega-links a:hover{background:transparent;color:var(--accent-gold);transform:none;box-shadow:none;}
  .mega-preview{display:none !important;}
  .nav-toggle{display:block;}
  .brand-logo-img{width:70px;height:70px;}
  .brand-name{font-size:18px;}
  .brand-sub{font-size:11px;}

  /* Hero Mobile */
  .hero{height:auto;min-height:100vh;}
  .carousel-track{position:relative;height:50vh;}
  .hero-panel{position:relative;background:var(--g1);padding:40px 20px;height:auto;}
  .hero-content{max-width:100%;text-align:center;margin:0 auto;}
  .hero h1{font-size:28px;text-shadow:none;}
  .hero-sub{font-size:14px;text-shadow:none;color:rgba(255,255,255,0.8);}
  .hero-tag{margin-bottom:16px;}
  .hero-btns{flex-direction:column;align-items:center;}
  .hero-btns a{width:100%;text-align:center;justify-content:center;}
  .c-arrow{display:none;}

  /* Components Mobile */
  .quick-grid{grid-template-columns:1fr;gap:12px;}
  .stat-strip{padding:32px 20px;}
  .stat-grid{grid-template-columns:repeat(2,1fr);gap:24px;}
  .stat-num{font-size:32px;}
  
  /* ═══════ ABOUT PAGE MOBILE FIX ═══════ */
  .about-layout{grid-template-columns:1fr;} /* Force stack */
  .about-sidebar{
    position:relative;
    top:0;
    display:flex;
    overflow-x:auto;
    white-space:nowrap;
    padding:10px 15px;
    border-radius:8px;
    margin-bottom:24px;
    -webkit-overflow-scrolling:touch;
  }
  .about-nav{
    flex-direction:row;
    gap:6px;
    width:max-content; /* Forces items to stay in one line */
  }
  .about-nav a{
    border-left:none;
    border-bottom:3px solid transparent;
    padding:8px 12px;
    font-size:12px;
  }
  .about-nav a.active{border-bottom-color:var(--accent-gold);}
  
  .scope-grid{grid-template-columns:1fr;}
  .leadership-grid{grid-template-columns:repeat(2,1fr);}
  .vmq-row,.vmq-row.reverse{grid-template-columns:1fr;text-align:center;}
  .vmq-img,.vmq-row.reverse .vmq-img{order:1;margin-bottom:20px;}
  .vmq-content,.vmq-row.reverse .vmq-content{order:2;}
  
  /* ═══════ CONTACT PAGE MOBILE FIX ═══════ */
  .contact-grid{grid-template-columns:1fr;} /* Force stack */
  .contact-map-wrap{min-height:300px;} /* Adjust map height */
  
  /* Other Pages Mobile */
  .footer-bottom-new{flex-direction:column;gap:8px;text-align:center;}
  .footer-grid-new{grid-template-columns:1fr;} /* Footer stack */
  .accred-inner{flex-direction:column;text-align:center;}
  .gallery-grid{grid-template-columns:1fr;}
  .gm-main{height:40vh;}
  .committee-grid{grid-template-columns:1fr;}
  .council-grid{grid-template-columns:repeat(2,1fr);}
  .flat-gallery-grid{grid-template-columns:repeat(2,1fr);}
  .teaching-features{grid-template-columns:1fr;}
  .teaching-layout{grid-template-columns:1fr !important;gap:32px;}
  .teaching-layout .t-carousel,.teaching-layout > div:first-child{order:unset;}
  .t-carousel{height:250px;width:100%;}
  .academic-grid{grid-template-columns:repeat(2,1fr);}
  .record-list{grid-template-columns:1fr;}
}