@import url('https://fonts.googleapis.com/css2?family=Source+Serif+4:wght@500;600;700&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@500&family=Noto+Sans+Malayalam:wght@400;500;600&display=swap');

:root{
	--navy:#0f2a43; --navy-dark:#081a2c; --maroon:#8b2635; --gold:#b9912e;
	--paper:#f7f5f1; --ink:#222a33; --slate:#566073; --line:#e2ddd2;
	--radius:8px; --gap:28px;
	--font-display:'Source Serif 4', Georgia, serif;
	--font-body:'Inter', Arial, sans-serif;
	--font-mono:'JetBrains Mono', monospace;
	--font-malayalam:'Noto Sans Malayalam', 'Inter', sans-serif;
}
*{box-sizing:border-box;}
body{margin:0;font-family:var(--font-body);color:var(--ink);background:#fff;line-height:1.7;font-size:16px;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.25;margin:0 0 .5em;color:var(--navy);}
img{max-width:100%;height:auto;display:block;}
a{color:var(--navy);text-decoration:none;transition:color .2s;}
.container{max-width:1180px;margin:0 auto;padding:0 24px;}
.section{padding:72px 0;}
.section + .section{border-top:1px solid var(--line);}
.section-heading{margin-bottom:32px;}
.section-heading.center{text-align:center;}
.section-heading .kicker{display:block;font-family:var(--font-mono);color:var(--gold);font-weight:600;font-size:.86rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px;}
.section-heading h2{font-size:1.85rem;margin:0;}
.prose p{color:var(--slate);}
.about-prose p{max-width:none;}
.lede{font-size:1.08rem;color:var(--slate);max-width:620px;}

/* ===== Top bar ===== */
.top-bar{background:var(--navy-dark);color:#a9c0d4;font-family:var(--font-mono);font-size:.76rem;letter-spacing:.02em;}
.top-bar-inner{display:flex;justify-content:space-between;align-items:center;padding:7px 24px;gap:16px;}
.top-bar-contact{flex:0 0 auto;}
.top-bar-contact span{margin-right:18px;}
.top-bar-credential{flex:1 1 auto;text-align:right;color:#e7c984;white-space:nowrap;}
.top-bar-social{flex:0 0 auto;display:flex;justify-content:flex-end;gap:14px;}
.top-bar-social a{color:#a9c0d4;display:inline-flex;}
.top-bar-social a:hover{color:var(--gold);}

/* ===== Logo bar ===== */
.logo-bar{background:var(--paper);border-bottom:1px solid var(--line);}
.logo-bar-inner{display:flex;align-items:center;justify-content:space-between;padding:22px 24px;gap:24px;}
.site-branding{display:flex;align-items:center;gap:18px;}
.site-branding img{max-height:72px;width:auto;}
.site-title-fallback{display:none;}
.brand-text{display:flex;flex-direction:column;}
.brand-text .site-title{font-family:var(--font-display);font-weight:700;font-size:1.55rem;color:var(--navy);letter-spacing:.01em;}
.brand-text .site-tagline{font-family:var(--font-malayalam);font-size:1.02rem;font-weight:500;letter-spacing:0;text-transform:none;color:var(--maroon);margin-top:4px;line-height:1.4;}
.header-cta{background:var(--maroon);color:#fff;padding:12px 24px;border-radius:4px;font-weight:600;font-size:.9rem;white-space:nowrap;}
.header-cta:hover{background:var(--navy);}

/* ===== Nav ===== */
.site-header{background:var(--navy);position:sticky;top:0;z-index:200;}
.header-inner{padding:0 24px;}
.nav-menu{display:flex;gap:4px;list-style:none;margin:0;padding:0;}
.nav-menu > li{position:relative;}
.nav-menu > li > a{color:#dce6ef;font-weight:500;font-size:.86rem;letter-spacing:.03em;text-transform:uppercase;padding:18px 16px;display:block;border-bottom:2px solid transparent;transition:color .22s ease, background .22s ease, border-color .22s ease;}
.nav-menu > li.menu-item-has-children > a::after{content:"";display:inline-block;border:3px solid transparent;border-top-color:currentColor;opacity:.6;margin-left:6px;vertical-align:middle;transition:transform .22s ease, opacity .22s ease;}
.nav-menu > li:hover > a::after, .nav-menu > li.gptc-open > a::after{transform:rotate(180deg);opacity:1;}
.nav-menu > li:hover > a, .nav-menu > li.gptc-open > a{color:#fff;border-bottom-color:var(--gold);background:rgba(185,145,46,.12);}
.nav-menu .current-menu-item > a, .nav-menu .current-menu-ancestor > a{color:#fff;font-weight:700;}
/* Submenu panel */
.nav-menu ul.sub-menu{display:none;position:absolute;left:0;top:100%;background:var(--navy-dark);min-width:240px;box-shadow:0 16px 36px rgba(8,26,44,.5);padding:6px 0;list-style:none;margin:0;z-index:50;border-radius:0 0 4px 4px;animation:gptc-submenu-in .18s ease;}
@keyframes gptc-submenu-in{from{opacity:0;transform:translateY(-6px);}to{opacity:1;transform:translateY(0);}}
.nav-menu li.gptc-open > ul.sub-menu, .nav-menu li:hover > ul.sub-menu{display:block;}
.nav-menu ul.sub-menu li{position:relative;}
.nav-menu ul.sub-menu a{color:#b8cfe0;padding:11px 20px;font-size:.87rem;text-transform:none;letter-spacing:.01em;font-weight:500;display:block;transition:color .15s ease, background .15s ease;}
.nav-menu ul.sub-menu a:hover{background:rgba(255,255,255,.08);color:#fff;}
.nav-menu ul.sub-menu li + li{border-top:1px solid rgba(255,255,255,.05);}
.nav-menu ul.sub-menu ul.sub-menu{top:0;left:100%;border-radius:0 0 4px 4px;}
.mobile-menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:16px 0;width:30px;}
.mobile-menu-toggle span{display:block;height:2px;background:#fff;margin:6px 0;}

/* ===== Homepage announcement ticker (slim bar, not a full section) ===== */
.ticker-bar{background:var(--navy-dark);color:#fff;}
.ticker-inner{display:flex;align-items:center;gap:18px;padding:11px 24px;}
.ticker-label{font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--gold);white-space:nowrap;flex-shrink:0;}
.ticker-track-wrap{flex:1;overflow:hidden;}
.ticker-track{display:inline-flex;gap:0;white-space:nowrap;animation:gptc-ticker-scroll 32s linear infinite;}
.ticker-track:hover{animation-play-state:paused;}
.ticker-track a{color:#fff;font-size:.86rem;}
.ticker-track a:hover{color:var(--gold);}
.ticker-track .sep{opacity:.4;margin:0 22px;}
.ticker-viewall{font-size:.78rem;white-space:nowrap;color:var(--gold);font-weight:600;flex-shrink:0;}
@keyframes gptc-ticker-scroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ===== Hero slider ===== */
.hero-slider{position:relative;overflow:hidden;height:380px;background:var(--navy-dark);}
.hero-slides{position:relative;height:100%;}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease;}
.hero-slide.active{opacity:1;}
.hero-slide img{width:100%;height:100%;object-fit:cover;}
.hero-slide.hero-fit-contain{background:var(--navy-dark);}
.hero-slide.hero-fit-contain img{object-fit:contain;position:relative;z-index:1;}
.hero-slide-bgblur{position:absolute;inset:0;background-position:center;background-repeat:no-repeat;background-size:cover;filter:blur(14px) brightness(.88);transform:scale(1.15);z-index:0;-webkit-mask-image:linear-gradient(to right,rgba(0,0,0,.55) 0%,#000 18%,#000 82%,rgba(0,0,0,.55) 100%);mask-image:linear-gradient(to right,rgba(0,0,0,.55) 0%,#000 18%,#000 82%,rgba(0,0,0,.55) 100%);}
.hero-caption{position:absolute;left:0;bottom:0;max-width:520px;background:rgba(15,42,67,.88);color:#fff;padding:22px 28px;margin:0 0 0 0;}
.hero-caption h2{color:#fff;font-size:1.35rem;margin-bottom:6px;}
.hero-caption p{margin:0;opacity:.88;font-size:.92rem;}
.hero-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.9);border:none;width:38px;height:38px;border-radius:50%;cursor:pointer;font-size:.9rem;color:var(--navy);}
.hero-nav.prev{left:18px;} .hero-nav.next{right:18px;}
.hero-dots{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:flex;gap:8px;}
.hero-dot{width:8px;height:8px;border-radius:50%;border:none;background:rgba(255,255,255,.5);cursor:pointer;padding:0;}
.hero-dot.active{background:var(--gold);}
.hero-fallback{background:linear-gradient(160deg,var(--navy),var(--navy-dark));color:#fff;padding:84px 0;text-align:center;}
.hero-fallback h1{color:#fff;font-size:2.1rem;}
.hero-fallback p{color:#cfe0ee;}
.hero-slider.dept-page-slider{height:250px;}
.hero-slider.dept-page-slider .hero-caption{max-width:600px;}
.hero-slider.dept-page-slider .hero-caption h2{color:#fff;font-size:1.7rem;margin-bottom:6px;}

/* ===== Layout helpers ===== */
.two-col{display:grid;grid-template-columns:1.2fr .8fr;gap:var(--gap);align-items:start;}
.doc-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:var(--gap);margin-top:8px;align-items:start;}
.doc-row.doc-pair{grid-template-columns:repeat(2,1fr);align-items:stretch;}
.doc-card{background:var(--paper);border-top:3px solid var(--gold);padding:26px 24px;}
.doc-card.doc-full{max-width:none;}
.doc-card h3{font-size:1.05rem;margin-bottom:.6em;}
.doc-card p{color:var(--slate);margin:0;}
.doc-card ul.gptc-line-list{margin:0;padding-left:18px;color:var(--slate);}
.doc-card ul.gptc-line-list li{margin-bottom:6px;}
.about-prose{margin-bottom:8px;}
.about-layout.has-image .about-prose{margin-bottom:0;}
.about-section{
    background:linear-gradient(to bottom,#fff,var(--paper));
}

.about-layout.has-image{
    display:grid;
    grid-template-columns:1.4fr 380px;
    gap:60px;
    align-items:center;
    background:#fff;
    border:1px solid var(--line);
    border-radius:16px;
    padding:40px;
    box-shadow:0 10px 30px rgba(15,42,67,.06);
}

.about-prose{
    font-size:1.02rem;
}

.about-prose p:first-child{
    color:var(--ink);
    font-weight:500;
}

.about-image{
    position:relative;
}

.about-image::before{
    content:"";
    position:absolute;
    width:100%;
    height:100%;
    top:16px;
    left:16px;
    background:var(--gold);
    opacity:.12;
    border-radius:16px;
}

.about-image img{
    position:relative;
    z-index:2;
    width:100%;
    border-radius:16px;
    aspect-ratio:4/5;
    object-fit:cover;
    max-height:280px;
    box-shadow:0 24px 50px rgba(15,42,67,.18);
}


/* ===== Scroll reveal (subtle fade + rise, added only after JS confirms support) ===== */
.gptc-reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease, transform .6s ease;}
.gptc-reveal-visible{opacity:1;transform:translateY(0);}

/* ===== Vision / Mission / Program Outcomes (homepage) ===== */
.vmp-section{background:var(--paper);position:relative;overflow:hidden;}
.vmp-section::before{content:"";position:absolute;top:-120px;right:-120px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle, rgba(185,145,46,.10), transparent 70%);pointer-events:none;}
.vmp-section::after{content:"";position:absolute;bottom:-160px;left:-100px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle, rgba(15,42,67,.06), transparent 70%);pointer-events:none;}
.vmp-section .container{position:relative;z-index:1;}
.vmp-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap);margin-top:0;}
.vmp-row + .vmp-row{margin-top:28px;}
.vmp-row-full{grid-template-columns:1fr;}
.vmp-card{background:#fff;border:1px solid var(--line);border-top:3px solid var(--gold);border-radius:var(--radius);padding:32px 34px;box-shadow:0 4px 14px rgba(15,42,67,.05);transition:transform .25s ease, box-shadow .25s ease;position:relative;}
.vmp-card:hover{transform:translateY(-4px);box-shadow:0 16px 32px rgba(15,42,67,.12);}
.vmp-card-header{display:flex;align-items:center;gap:14px;margin-bottom:18px;}
.vmp-icon{display:inline-flex;align-items:center;justify-content:center;flex:none;width:42px;height:42px;border-radius:10px;background:linear-gradient(150deg,rgba(15,42,67,.08),rgba(185,145,46,.12));font-size:1.3rem;}
.vmp-card h3{font-size:1.2rem;margin:0;color:var(--navy);}
.vmp-card p{color:var(--slate);margin:0;text-align:left;}
.vmp-card-full{text-align:left;}
.vmp-card-full .vmp-card-header{justify-content:flex-start;}
.vmp-card-full .gptc-line-list{text-align:left;max-width:none;width:100%;margin:0;padding-left:0;list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:14px 20px;}
.vmp-card-full .gptc-line-list li{position:relative;padding:14px 16px 14px 42px;margin:0;color:var(--ink);font-size:.92rem;line-height:1.5;background:#fdf8ea;border-left:3px solid var(--gold);border-radius:var(--radius);transition:background .2s ease;}
.vmp-card-full .gptc-line-list li:hover{background:#f6ecd2;}
.vmp-card-full .gptc-line-list li::before{content:"\2713";position:absolute;left:16px;top:14px;color:var(--gold);font-weight:700;}

/* ===== Labs ===== */
.lab-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;}
.lab-card{background:#fff;border:1px solid var(--line);overflow:hidden;text-align:center;}
.lab-card img{aspect-ratio:4/3;object-fit:cover;width:100%;}
.lab-card h4{font-size:.95rem;margin:14px 16px;}
.lab-photo img{border:1px solid var(--line);}
.lab-dept{margin:2px 0 18px;font-weight:600;}

/* ===== Announcements (archive page rows) ===== */
.btn-link{display:inline-block;background:var(--navy);color:#fff;padding:11px 24px;border-radius:4px;font-weight:600;border:none;cursor:pointer;font-size:.88rem;letter-spacing:.02em;}
.btn-link:hover{background:var(--maroon);color:#fff;}
.announcement-row{display:flex;gap:18px;border-bottom:1px solid var(--line);padding:20px 0;}
.date-box{background:var(--navy);color:#fff;padding:8px 14px;text-align:center;min-width:58px;height:fit-content;font-family:var(--font-mono);}
.date-box span{display:block;font-size:.68rem;opacity:.8;}

/* ===== Principal / faculty profile shared grid ===== */
.principal-grid{display:grid;grid-template-columns:220px 1fr;gap:40px;align-items:center;}
.principal-photo img, .faculty-photo img, .photo-placeholder{width:220px;aspect-ratio:4/5;object-fit:cover;border:1px solid var(--line);}
.photo-placeholder{display:flex;align-items:center;justify-content:center;background:var(--paper);color:var(--slate);font-family:var(--font-mono);font-size:.8rem;}
.principal-name{font-family:var(--font-display);font-weight:600;margin:14px 0 0;color:var(--navy);}
.principal-role{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.05em;text-transform:uppercase;color:var(--slate);margin:2px 0 0;}
.principal-quote{margin:0;padding:0 0 0 36px;border-left:3px solid var(--gold);position:relative;width:100%;max-width:none;}
.principal-quote::before{content:'\201C';position:absolute;left:14px;top:-6px;font-family:var(--font-display);font-size:3rem;color:var(--gold);opacity:.55;line-height:1;}
.principal-quote p{font-style:italic;font-size:1rem;color:var(--ink);line-height:1.7;margin:0 0 .8em;max-width:none;position:relative;z-index:1;}
.principal-quote p:last-child{margin-bottom:0;}
.principal-section .principal-grid{grid-template-columns:300px 1fr;}
.principal-section .principal-photo img, .principal-section .photo-placeholder{width:300px;}
.faculty-detail-blocks{margin-top:40px;}
.faculty-info .designation{color:var(--maroon);font-weight:600;margin-bottom:14px;}

/* ===== Departments (homepage) ===== */
.dept-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:26px;}
.dept-card{display:block;background:#fff;border:1px solid var(--line);overflow:hidden;transition:transform .3s ease, box-shadow .3s ease;}
.dept-card:hover{transform:translateY(-4px);box-shadow:0 14px 28px rgba(15,42,67,.12);}
.dept-card-media{aspect-ratio:4/3;overflow:hidden;}
.dept-card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.dept-card:hover .dept-card-media img{transform:scale(1.06);}
.dept-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(150deg,var(--navy),var(--navy-dark));}
.dept-placeholder .dept-code{font-family:var(--font-mono);color:var(--gold);font-size:2.2rem;font-weight:600;}
.dept-card-body{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;}
.dept-card-body .dept-name{font-weight:600;color:var(--navy);font-size:1.02rem;}
.dept-card-body .dept-arrow{color:var(--gold);font-size:1.2rem;display:inline-block;transition:transform .25s ease;}
.dept-card:hover .dept-card-body .dept-arrow{transform:translateX(4px);}
.dept-banner{background-size:cover;background-position:center;}

/* ===== Faculty grid + HOD ===== */
.faculty-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;}
.faculty-subheading{font-size:1.05rem;font-weight:700;color:var(--navy);margin:36px 0 16px;padding-bottom:8px;border-bottom:2px solid var(--line);font-family:var(--font-display);}
.faculty-subheading--nt{margin-top:64px;color:var(--slate);}
.staff-dept-heading{font-size:1.05rem;font-weight:700;color:var(--navy);margin:36px 0 16px;padding-bottom:8px;border-bottom:2px solid var(--line);font-family:var(--font-display);}
.staff-dept-heading:first-child{margin-top:8px;}
.faculty-card{background:#fff;border:1px solid var(--line);padding:0 0 12px;text-align:center;overflow:hidden;border-radius:var(--radius);transition:transform .2s, box-shadow .2s;width:100%;}
.faculty-card:hover{transform:translateY(-3px);box-shadow:0 14px 28px rgba(15,42,67,.1);}
.faculty-card img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:0;margin:0 0 10px;display:block;}
.faculty-card .faculty-card-photo-placeholder{width:100%;aspect-ratio:4/5;border-radius:0;margin:0 0 10px;}
.faculty-card h4{font-size:.82rem;margin:0 10px 2px;}
.faculty-card p{color:var(--slate);font-size:.75rem;margin:0 10px;}
.hod-card{display:flex;gap:24px;align-items:center;background:var(--paper);border-left:3px solid var(--maroon);padding:24px;margin:28px 0;}
.hod-card img{width:140px;aspect-ratio:4/5;border-radius:4px;object-fit:cover;}
.hod-label{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--maroon);margin:0;}
.hod-designation{color:var(--slate);margin:2px 0 8px;}
.dept-about{margin-bottom:8px;}

/* ===== Cell events (NSS, IEDC, etc.) ===== */
/* ── Cell event card grid (3 per row) ───────────────────── */
.cell-event-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.cell-event-card{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;text-decoration:none;transition:box-shadow .2s,transform .18s;}
.cell-event-card:hover{box-shadow:0 8px 28px rgba(8,26,44,.14);transform:translateY(-2px);}
.cell-event-thumbs{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--line);}
.cell-event-thumb{position:relative;overflow:hidden;aspect-ratio:1/1;}
.cell-event-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .22s;}
.cell-event-card:hover .cell-event-thumb img{transform:scale(1.05);}
.cell-event-thumb.has-more img{filter:brightness(.4);}
.cell-event-more{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--font-display);font-size:1.4rem;font-weight:700;}
.cell-event-no-photo{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;font-size:2.8rem;background:var(--line);}
.cell-event-info{padding:14px 16px 16px;flex:1;display:flex;flex-direction:column;gap:4px;}
.cell-event-date{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);}
.cell-event-title{margin:0;font-size:1rem;line-height:1.35;color:var(--navy);font-family:var(--font-display);}
.cell-event-count{font-family:var(--font-mono);font-size:.72rem;color:var(--slate);margin-top:auto;padding-top:6px;}

/* ===== Gallery ===== */
/* ── Gallery Archive ─────────────────────────────────────── */
.gallery-archive-section{padding-top:36px;}
.gallery-group{margin-bottom:52px;}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;}
.gallery-card{display:block;position:relative;overflow:hidden;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper);transition:box-shadow .2s,transform .2s;text-decoration:none;}
.gallery-card:hover,.gallery-card:focus-visible{box-shadow:0 8px 28px rgba(8,26,44,.18);transform:translateY(-2px);}
.gallery-card img{aspect-ratio:4/3;object-fit:cover;width:100%;display:block;}
.gallery-card-no-cover{aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;font-size:3rem;background:var(--line);}
.gallery-card-info{padding:10px 13px 12px;}
.gallery-card-type-badge{display:inline-block;background:var(--maroon);color:#fff;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;padding:2px 7px;border-radius:3px;margin-bottom:5px;}
.gallery-card-title{display:block;font-family:var(--font-display);font-weight:600;color:var(--navy);font-size:.95rem;line-height:1.3;margin-bottom:4px;}
.gallery-card-meta{display:block;font-family:var(--font-mono);font-size:.73rem;color:var(--slate);letter-spacing:.02em;}

/* ── Album breadcrumb / meta ─────────────────────────────── */
.album-breadcrumb{margin:0 0 10px;font-family:var(--font-mono);font-size:.8rem;}
.album-breadcrumb a{color:rgba(255,255,255,.72);text-decoration:none;}
.album-breadcrumb a:hover{color:#fff;}
.album-meta-banner{margin:8px 0 0;font-size:.88rem;color:rgba(255,255,255,.8);display:flex;flex-wrap:wrap;gap:8px;align-items:center;}
.album-cell-tag{background:var(--gold);color:#fff;border-radius:3px;padding:2px 8px;font-size:.76rem;font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;}
.album-photo-count{color:var(--slate);font-size:.85rem;font-family:var(--font-mono);margin:0 0 16px;}
.album-desc{margin-bottom:24px;color:var(--slate);}

/* ── Album grid ─────────────────────────────────────────── */
.album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;}
.gptc-album-thumb{all:unset;cursor:pointer;display:block;overflow:hidden;border-radius:4px;border:1px solid var(--line);transition:transform .18s,box-shadow .18s;}
.gptc-album-thumb:hover,.gptc-album-thumb:focus-visible{transform:scale(1.03);box-shadow:0 4px 16px rgba(8,26,44,.2);}
.gptc-album-thumb img{display:block;width:100%;aspect-ratio:1/1;object-fit:cover;}

/* ── Lightbox ───────────────────────────────────────────── */
#gptc-lightbox{position:fixed;inset:0;z-index:900;display:flex;align-items:center;justify-content:center;}
#gptc-lightbox[hidden]{display:none;}
.gptc-lb-backdrop{position:absolute;inset:0;background:rgba(5,14,26,.94);cursor:pointer;}
.gptc-lb-stage{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;max-width:92vw;max-height:90vh;}
.gptc-lb-img{display:block;max-width:100%;max-height:82vh;border-radius:4px;box-shadow:0 24px 80px rgba(0,0,0,.6);object-fit:contain;transition:opacity .18s;}
.gptc-lb-caption{color:rgba(255,255,255,.78);font-size:.85rem;margin:10px 0 0;text-align:center;max-width:60ch;}
.gptc-lb-counter{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);z-index:2;font-family:var(--font-mono);font-size:.78rem;color:rgba(255,255,255,.55);letter-spacing:.06em;}
.gptc-lb-close,.gptc-lb-prev,.gptc-lb-next{all:unset;position:absolute;z-index:2;cursor:pointer;color:#fff;display:flex;align-items:center;justify-content:center;border-radius:50%;width:44px;height:44px;font-size:1.4rem;background:rgba(255,255,255,.12);transition:background .18s;}
.gptc-lb-close:hover,.gptc-lb-prev:hover,.gptc-lb-next:hover{background:rgba(255,255,255,.26);}
.gptc-lb-close{top:16px;right:16px;font-size:1.7rem;}
.gptc-lb-prev{left:12px;top:50%;transform:translateY(-50%);}
.gptc-lb-next{right:12px;top:50%;transform:translateY(-50%);}
.gptc-lb-prev:disabled,.gptc-lb-next:disabled{opacity:.25;pointer-events:none;}
@media(max-width:600px){
  .album-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:7px;}
  .gptc-lb-prev{left:4px;}.gptc-lb-next{right:4px;}
}

/* ===== Downloads ===== */
.downloads-table{width:100%;border-collapse:collapse;}
.downloads-table th,.downloads-table td{padding:14px;border-bottom:1px solid var(--line);text-align:left;}
.downloads-table th{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;color:var(--slate);}

/* ===== Page banner ===== */
.page-banner{background:linear-gradient(150deg,var(--navy),var(--navy-dark));color:#fff;padding:48px 0;}
.page-banner.page-banner-image{background-size:cover;background-position:center;}
.page-banner h1{color:#fff;margin:0;font-size:1.7rem;}

/* ===== Footer ===== */
.site-footer{background:var(--navy-dark);color:#9fb3c5;}
.footer-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding:56px 24px 32px;}
.site-footer h4{color:#fff;margin-top:0;font-family:var(--font-display);font-size:1.05rem;}
.site-footer a{color:#9fb3c5;}
.site-footer a:hover{color:var(--gold);}
.footer-menu{list-style:none;padding:0;margin:0;}
.footer-menu li{margin-bottom:9px;}
.footer-bottom{text-align:center;padding:16px 0;font-family:var(--font-mono);font-size:.76rem;border-top:1px solid rgba(255,255,255,.1);}

/* ===== Contact form ===== */
.contact-form{display:flex;flex-direction:column;gap:14px;}
.contact-form input,.contact-form textarea{padding:12px 14px;border:1px solid var(--line);font-family:inherit;}
.form-success{color:#187a3c;font-weight:600;}
.form-error{color:#b32d2e;font-weight:600;}

/* ===== Placement statistics ===== */
.placement-year-switcher{display:flex;align-items:center;gap:12px;margin-bottom:36px;}
.placement-year-switcher select{padding:9px 14px;border:1px solid var(--line);font-family:inherit;font-size:.92rem;background:#fff;}
.placement-summary-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:48px;}
.placement-summary-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:26px 18px;text-align:center;}
.placement-summary-card.placement-summary-highlight{background:var(--navy);border-color:var(--navy);}
.placement-summary-card.placement-summary-highlight .placement-summary-figure,
.placement-summary-card.placement-summary-highlight .placement-summary-label{color:#fff;}
.placement-summary-figure{display:block;font-family:var(--font-display);font-size:2.1rem;font-weight:700;color:var(--navy);}
.placement-summary-label{display:block;font-size:.82rem;color:var(--slate);margin-top:4px;}
.placement-table{margin:24px 0 48px;}
/* Table polish */
.placement-table thead tr{background:var(--navy);}
.placement-table thead th{color:#fff;font-family:var(--font-mono);font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;padding:13px 14px;border-bottom:none;}
.placement-table tbody tr:nth-child(even){background:rgba(15,42,67,.03);}
.placement-table tbody tr:hover{background:rgba(185,145,46,.07);}
.placement-table td{padding:12px 14px;vertical-align:middle;}
.placement-branch-cell{font-weight:600;color:var(--navy);}
/* Progress bar in % column */
.pct-bar-wrap{display:flex;align-items:center;gap:8px;min-width:120px;}
.pct-bar-track{flex:1;background:var(--line);border-radius:4px;height:14px;overflow:hidden;}
.pct-bar-fill{height:100%;background:linear-gradient(90deg,var(--navy),var(--gold));border-radius:4px;transition:width .6s ease;}
.pct-bar-label{font-size:.8rem;font-weight:600;color:var(--navy);white-space:nowrap;min-width:38px;}
/* Charts */
.placement-charts-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:32px 0 40px;}
.placement-chart-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px 20px;}
.placement-chart-title{font-size:.92rem;font-weight:600;color:var(--navy);margin:0 0 18px;font-family:var(--font-display);}
.placement-chart-wrap{position:relative;height:280px;width:100%;}
.company-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin:24px 0 48px;}
.company-card{background:#fff;border:1px solid var(--line);border-left:3px solid var(--gold);padding:18px 20px;display:flex;flex-direction:column;gap:4px;}
.company-name{font-weight:600;color:var(--navy);}
.company-package{font-size:.86rem;color:var(--slate);}

/* ===== About page ===== */
.page-banner-kicker{display:block;font-family:var(--font-mono);font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:8px;}

/* Intro grid */
.about-intro-section{background:#fff;}
.about-intro-grid{display:grid;grid-template-columns:1fr 280px;gap:56px;align-items:start;}
.about-intro-text p{font-size:1.05rem;line-height:1.85;color:var(--slate);}
.about-intro-grid--full{grid-template-columns:1fr;}
.about-intro-image{border-radius:var(--radius);overflow:hidden;}
.about-intro-image img{display:block;width:100%;height:100%;min-height:280px;object-fit:cover;}

/* Mission list inside vmp-card */
.about-mission-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;}
.about-mission-list li{padding:10px 14px;background:#fdf8ea;border-left:3px solid var(--gold);border-radius:0 var(--radius) var(--radius) 0;font-size:.93rem;color:var(--slate);line-height:1.6;}
.about-mission-list li strong{color:var(--navy);}

/* Programmes */
.about-programmes-section{background:var(--paper);}
.about-programmes-intro{text-align:center;color:var(--slate);margin:-16px 0 32px;font-size:.97rem;}
.about-programmes-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.about-prog-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px 22px;text-align:center;transition:box-shadow .2s,transform .18s;}
.about-prog-card:hover{box-shadow:0 8px 28px rgba(8,26,44,.1);transform:translateY(-3px);}
.about-prog-icon{font-size:2.2rem;margin-bottom:14px;line-height:1;}
.about-prog-card h3{font-size:.97rem;color:var(--navy);margin:0 0 10px;line-height:1.35;}
.about-prog-card p{font-size:.88rem;color:var(--slate);margin:0;line-height:1.6;}

/* Campus life */
.about-campus-section{background:#fff;}
.about-campus-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.about-campus-card{padding:28px 22px;border-top:3px solid var(--gold);background:var(--paper);border-radius:0 0 var(--radius) var(--radius);text-align:center;}
.about-campus-icon{display:block;font-size:2rem;margin-bottom:12px;}
.about-campus-card h4{font-size:.97rem;color:var(--navy);margin:0 0 8px;font-family:var(--font-display);}
.about-campus-card p{font-size:.87rem;color:var(--slate);margin:0;line-height:1.6;}

/* Contact strip */

/* Responsive */
@media(max-width:900px){
	.about-intro-grid{grid-template-columns:1fr;}
	.about-intro-image img{min-height:220px;}
	.about-programmes-grid{grid-template-columns:repeat(2,1fr);}
	.about-campus-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:540px){
	.about-programmes-grid{grid-template-columns:1fr;}
	.about-campus-grid{grid-template-columns:1fr;}
}

/* ===== Alumni registration ===== */
.alumni-form{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:780px;}
.alumni-form .field-full{grid-column:1 / -1;}
.alumni-form label{display:block;font-size:.86rem;font-weight:600;color:var(--navy);margin-bottom:6px;}
.alumni-form input,.alumni-form textarea,.alumni-form select{width:100%;padding:12px 14px;border:1px solid var(--line);font-family:inherit;font-size:.95rem;}
.alumni-form button{justify-self:start;}

@media (max-width:980px){
	.two-col,.principal-grid,.footer-inner,.doc-row.doc-pair,.vmp-row{grid-template-columns:1fr;}
	.principal-section .principal-grid{grid-template-columns:1fr;}
	.principal-photo, .faculty-photo{display:flex;justify-content:center;flex-direction:column;align-items:center;}
	.principal-section .principal-photo img,.principal-section .photo-placeholder{width:100%;max-width:220px;}
	.principal-quote{padding-left:20px;}
	.principal-quote::before{left:0;font-size:2rem;}
	.top-bar-inner{font-size:.68rem;flex-wrap:wrap;}
	.top-bar-credential{flex:1 0 100%;order:3;text-align:left;white-space:normal;margin-top:2px;}
	.placement-summary-row{grid-template-columns:repeat(2,1fr);}
	.placement-charts-row{grid-template-columns:1fr;}
	.alumni-form{grid-template-columns:1fr;}
	.vmp-card-full .gptc-line-list{grid-template-columns:1fr;}
	.about-layout.has-image{grid-template-columns:1fr;}
	.about-image{order:-1;max-width:240px;margin:0 auto 8px;}
	.faculty-grid{grid-template-columns:repeat(3,1fr);}
	.cell-event-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:540px){
	.cell-event-grid{grid-template-columns:1fr;}
}
@media (max-width:860px){
	.mobile-menu-toggle{display:block;}
	.primary-nav{display:none;width:100%;}
	.primary-nav.open{display:block;padding-bottom:10px;}
	.nav-menu{flex-direction:column;}
	.nav-menu > li > a::after{display:none;}
	.nav-menu ul.sub-menu{position:static;box-shadow:none;border-radius:0;animation:none;padding-left:14px;}
	.nav-menu ul.sub-menu li + li{border-top:none;}
	.nav-menu ul.sub-menu a:hover{padding-left:20px;}
	.logo-bar-inner{flex-wrap:wrap;}
	.hero-caption{max-width:none;right:0;}
	.faculty-grid{grid-template-columns:repeat(2,1fr);}
}

/* =====================================================================
   Faculty Profile Page  (single-faculty.php)
   ===================================================================== */

/* ── Hero section ── */
.fp-hero {
	display: grid;
	grid-template-columns: 200px 1fr;
	gap: 48px;
	align-items: flex-start;
	padding-top: 48px;
	padding-bottom: 40px;
}

.fp-photo img {
	width: 200px;
	aspect-ratio: 4/5;
	object-fit: cover;
	border-radius: 6px;
	border: 1px solid var(--line);
	display: block;
}

.fp-photo-placeholder {
	width: 200px;
	aspect-ratio: 4/5;
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: 6px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--line);
	font-size: 4rem;
}

.fp-identity {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding-top: 6px;
}

.fp-name {
	font-size: clamp(1.6rem, 4vw, 2.4rem);
	margin: 0;
	line-height: 1.15;
}

.fp-designation {
	color: var(--maroon);
	font-weight: 600;
	font-size: 1.05rem;
	margin: 6px 0 16px;
}

.fp-contact {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 24px;
	margin-top: 8px;
}

.fp-contact-item {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: .9rem;
	color: var(--slate);
	text-decoration: none;
	transition: color .2s;
}

.fp-contact-item:hover { color: var(--gold); }

.fp-contact-item .dashicons {
	color: var(--gold);
	font-size: 1rem;
	width: 1rem;
	height: 1rem;
}

/* ── Detail cards container ── */
.fp-details {
	padding-bottom: 56px;
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.fp-row {
	display: grid;
	gap: 20px;
}

.fp-row-half {
	grid-template-columns: repeat(2, 1fr);
}

.fp-row-full {
	grid-template-columns: 1fr;
}

/* ── Individual card ── */
.fp-card {
	background: var(--paper);
	border-top: 3px solid var(--gold);
	border-radius: 0 0 var(--radius) var(--radius);
	padding: 28px 32px;
	position: relative;
}

.fp-card-highlight {
	border-top-color: var(--maroon);
	background: #fff;
	box-shadow: 0 2px 16px rgba(15,42,67,.07);
}

.fp-card-icon {
	position: absolute;
	top: 22px;
	right: 24px;
	color: var(--gold);
	opacity: .35;
	font-size: 1.5rem;
	line-height: 1;
}

.fp-card-highlight .fp-card-icon { color: var(--maroon); }

.fp-card h3 {
	font-size: 1rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--navy);
	margin: 0 0 16px;
}

.fp-card-body {
	color: var(--slate);
	font-size: .97rem;
	line-height: 1.75;
}

.fp-card-body p { margin: 0 0 .6em; }
.fp-card-body p:last-child { margin-bottom: 0; }

.fp-card-body ul,
.fp-card-body ol {
	padding-left: 20px;
	margin: 0;
}

.fp-card-body li { margin-bottom: 6px; }

/* ── Mobile ── */
@media (max-width: 680px) {
	.fp-hero {
		grid-template-columns: 1fr;
		gap: 24px;
		padding-top: 28px;
		padding-bottom: 24px;
	}

	.fp-photo {
		display: flex;
		justify-content: center;
	}

	.fp-photo img,
	.fp-photo-placeholder {
		width: 150px;
	}

	.fp-identity {
		text-align: center;
		align-items: center;
	}

	.fp-contact {
		justify-content: center;
	}

	.fp-row-half {
		grid-template-columns: 1fr;
	}

	.fp-card {
		padding: 22px 20px;
	}
}
