/* KPTC Alumni Association — style.css — Bold Vibrant Theme */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#08203e;
  --navy2:#0e3460;
  --navy3:#164e8a;
  --gold:#d4920a;
  --gold2:#f0aa20;
  --gold3:#ffd060;
  --teal:#076e72;
  --teal2:#0a9aa0;
  --sky:#00bcd4;
  --sky2:#00d4ec;
  --sky3:#e0f9fc;
  --skyblue:#00bcd4;
  --skyblue2:#00d4ec;

  /* Page background — pure white like kptc.in content area */
  --bg:#ffffff;
  --bg2:#f5f5f5;
  --card:#ffffff;

  --text:#1a1a2e;
  --mid:#2c3e50;
  --muted:#6c7a89;

  --border:rgba(0,0,0,.1);
  --sh1:0 2px 12px rgba(0,0,0,.07);
  --sh2:0 6px 24px rgba(0,0,0,.1);
  --sh3:0 16px 48px rgba(0,0,0,.15);

  --r:10px;--rl:18px;
}

html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;color:var(--text);background:#fff;overflow-x:hidden}
h1,h2,h3,blockquote{font-family:'Cormorant Garamond',serif}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--gold2);border-radius:3px}
a{text-decoration:none;color:inherit}
button{cursor:pointer;font-family:'Jost',sans-serif}

/* ── PRELOADER ── */
.preloader{position:fixed;inset:0;z-index:9999;background:var(--navy);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;transition:opacity .5s,visibility .5s}
.preloader.gone{opacity:0;visibility:hidden}
.pl-ring{width:52px;height:52px;border-radius:50%;border:2px solid rgba(212,146,10,.25);border-top-color:var(--gold2);animation:spin 1s linear infinite}
.pl-txt{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:700;color:var(--gold2);letter-spacing:4px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── RIBBON ── */
.ribbon{background:#e0f7fa;color:#006064;font-size:11.5px;padding:7px 0;border-bottom:1px solid #b2ebf2}
.ribbon-inner{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;gap:1.25rem;justify-content:flex-end;align-items:center;flex-wrap:wrap}
.ribbon a{color:#00838f;transition:color .15s}.ribbon a:hover{color:#006064}
.rdiv{color:#b2ebf2}

/* ── HEADER ── */
.header{position:sticky;top:0;z-index:300;background:#00bcd4;border-bottom:4px solid #fff;transition:box-shadow .3s;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.header.on{box-shadow:0 4px 24px rgba(0,0,0,.4)}
.header-inner{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:11px;background:none;border:none;padding:0}
.brand-seal{width:52px;height:52px;color:#08203e;flex-shrink:0}
.brand-seal svg{width:100%;height:100%;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}
.brand-name{font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:700;color:#08203e;line-height:1.1;text-align:left}
.brand-sub{font-size:10px;text-transform:uppercase;letter-spacing:2px;color:#08203e;text-align:left;font-weight:600}
.nav{display:flex;align-items:center;gap:2px}
.nl{padding:7px 14px;border-radius:var(--r);font-size:13px;color:#08203e;background:none;border:none;transition:all .2s;font-weight:500}
.nl:hover{color:#08203e;background:rgba(0,0,0,.08)}
.nl.active{color:#08203e;font-weight:700;background:rgba(0,0,0,.1);border-radius:var(--r)}
.nl-join{background:#08203e!important;color:#fff!important;border-radius:30px;padding:8px 20px;margin-left:6px;font-weight:700}
.nl-join:hover{background:#00838f!important;color:#fff!important;transform:translateY(-1px)}
.nl-admin{font-size:11px;opacity:.7;text-decoration:none;color:#08203e!important}
.nl-admin:hover{opacity:.9}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px}
.burger span{display:block;width:22px;height:2px;background:#08203e;border-radius:2px;transition:all .3s}

/* ── PAGES ── */
.pg{display:none}.pg.active{display:block}

/* ── HERO ── */
.hero{min-height:260px;background:linear-gradient(135deg,#e0f7fa 0%,#f5f5f5 50%,#e8f5e9 100%);position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:2.5rem 2rem 2rem;border-bottom:2px solid #b2ebf2}
.hero-bg{position:absolute;inset:0}
.hero-bg::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 15% 65%,rgba(212,146,10,.22),transparent 50%),radial-gradient(ellipse at 85% 20%,rgba(7,110,114,.28),transparent 48%),radial-gradient(ellipse at 55% 90%,rgba(92,26,120,.18),transparent 45%)}
.hring{position:absolute;border-radius:50%;border:1px solid rgba(212,146,10,.12)}
.r1{width:720px;height:720px;top:-200px;right:-200px}
.r2{width:420px;height:420px;bottom:-120px;left:-120px}
.r3{width:200px;height:200px;top:28%;right:14%}
#particles{position:absolute;inset:0;pointer-events:none}
.hero-body{position:relative;z-index:10;max-width:1100px;width:100%;padding:1.5rem 2rem;text-align:left}
.hero-ey{display:inline-flex;align-items:center;gap:9px;background:#00bcd4;border:none;color:#fff;font-size:11px;letter-spacing:2px;text-transform:uppercase;padding:6px 16px;border-radius:30px;margin-bottom:.8rem}
.edot{width:6px;height:6px;border-radius:50%;background:#fff;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.hero-h1{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700;color:#006064;line-height:1.1;margin-bottom:.6rem;letter-spacing:-.2px}
.hero-h1 em{color:#08203e;font-style:normal;font-weight:700}
.hero-sub{font-family:'Jost',sans-serif;font-size:14px;color:#37474f;line-height:1.7;max-width:600px;margin:0 0 1.2rem}
.hero-btns{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:1.2rem}
.btn-gold{background:#00bcd4;color:#fff;border:none;padding:12px 28px;border-radius:30px;font-size:14px;font-weight:600;transition:all .25s;box-shadow:0 4px 14px rgba(0,188,212,.3)}
.btn-gold:hover{background:#0097a7;color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,188,212,.4)}
.btn-ghost{background:#fff;color:#08203e;border:1.5px solid #ddd;padding:12px 28px;border-radius:30px;font-size:14px;transition:all .2s}
.btn-ghost:hover{background:#f5f5f5;border-color:#bbb}
.hero-stats{display:flex;align-items:center;gap:1.5rem;background:#e0f7fa;border:2px solid #00bcd4;border-radius:var(--r);padding:1rem 1.75rem;flex-wrap:wrap;box-shadow:0 2px 12px rgba(0,188,212,.15)}
.hs{text-align:center}
.hsn{display:block;font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:700;color:#01579b;line-height:1}
.hs span{display:block;font-size:10px;color:#006064;text-transform:uppercase;letter-spacing:1px;margin-top:2px;font-weight:600}
.hsdiv{width:1.5px;height:40px;background:#00bcd4}
.scroll-hint{display:none}
.sh-bar{display:block;width:1px;height:38px;background:linear-gradient(to bottom,rgba(255,255,255,.3),transparent)}

.ai{opacity:0;transform:translateY(18px);animation:aIn .6s ease forwards;animation-delay:var(--d,0s);animation-play-state:paused}
@keyframes aIn{to{opacity:1;transform:translateY(0)}}

/* ── TICKER ── */
.ticker{background:#01579b;padding:9px 0;overflow:hidden;position:relative;z-index:299}
.ticker-track{display:flex;gap:2rem;white-space:nowrap;animation:tick 30s linear infinite;font-size:13px;font-weight:700;color:#fff;letter-spacing:.3px;padding:0 1rem}
.ticker-track span{flex-shrink:0}
.tdot{color:rgba(8,32,62,.35)}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── SECTION BACKGROUNDS — each page gets distinct strong colour ── */
.sec{padding:5rem 1.5rem;background:var(--bg)}

/* Home sections */
.sec-pillars{background:#fff;padding:3rem 1.5rem}
.sec-dark{background:#ffffff;padding:3rem 1.5rem 4rem;border-top:1px solid #e8e8e8}
.sec-depts{background:#fff;padding:3rem 1.5rem}

/* About section */
.sec-about{background:linear-gradient(160deg,#c8e4f8 0%,#d4ecfb 50%,#c4e0f6 100%)}

/* Directory section */
.sec-directory{background:#fff;padding:3rem 1.5rem 4rem}

/* Events section */
.sec-events{background:#fff;padding:3rem 1.5rem 4rem}

/* Register section */
.sec-register{background:#fff;padding:3rem 1.5rem 4rem}

.wrap{max-width:1100px;margin:0 auto}
.wrap-n{max-width:860px;margin:0 auto}
.sec-lbl{font-size:11px;text-transform:uppercase;letter-spacing:3px;color:var(--gold);font-weight:700;margin-bottom:10px}
.sec-lbl.light{color:#00bcd4}
.sec-h2{font-size:clamp(1.5rem,3.5vw,2.2rem);font-weight:700;color:var(--navy);line-height:1.15;margin-bottom:2rem}
.sec-h2.light{color:#08203e}
.divider{border:none;border-top:2px solid rgba(100,70,10,.15);margin:3rem 0}

/* ── PILLARS ── */
.pillars{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}
.pillar{background:linear-gradient(145deg,rgba(255,255,255,.75),rgba(255,255,255,.5));backdrop-filter:blur(8px);border-radius:var(--rl);padding:2.5rem 2rem;position:relative;overflow:hidden;box-shadow:var(--sh2);transition:all .3s;border:1px solid rgba(255,255,255,.6);border-top:5px solid var(--pa,var(--gold))}
.pillar:hover{transform:translateY(-6px);box-shadow:var(--sh3);background:linear-gradient(145deg,rgba(255,255,255,.9),rgba(255,255,255,.7))}
.pillar-ico{width:44px;height:44px;color:var(--pa,var(--gold));margin-bottom:1.1rem}
.pillar-ico svg{width:100%;height:100%}
.pillar h3{font-size:1.5rem;font-weight:700;margin-bottom:.65rem;color:var(--navy)}
.pillar p{font-size:13.5px;color:var(--mid);line-height:1.75}
.pillar-n{position:absolute;bottom:1.2rem;right:1.5rem;font-size:4rem;font-weight:700;color:rgba(0,0,0,.05);line-height:1}

/* ── VOICES ── */
.voices{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;margin-top:2.5rem}
.voice{background:#f5fbfc;border:1px solid #b2ebf2;border-radius:var(--rl);padding:2rem;transition:all .3s}
.voice:hover{background:#e0f7fa;transform:translateY(-3px)}
.v-av{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff;margin-bottom:1.1rem}
.voice blockquote{font-size:1.05rem;font-style:italic;color:#333;line-height:1.75;border-left:3px solid #00bcd4;padding-left:12px;margin-bottom:1rem}
.v-name{font-size:14px;font-weight:600;color:#08203e}
.v-role{font-size:12px;color:#555;margin-top:2px}

/* ── DEPT GRID ── */
.dept-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px;margin-top:2rem}
.dg-card{background:linear-gradient(135deg,rgba(255,255,255,.7),rgba(255,255,255,.5));border:1px solid rgba(255,255,255,.65);border-radius:var(--rl);padding:1.25rem 1rem;display:flex;align-items:center;gap:10px;box-shadow:var(--sh1);transition:all .25s;border-left:5px solid var(--dc,var(--gold))}
.dg-card:hover{transform:translateY(-4px);box-shadow:var(--sh2);background:rgba(255,255,255,.9)}
.dg-card span{font-size:13px;font-weight:600;color:var(--navy)}
.dg-n{font-size:1.6rem;font-weight:700;color:var(--dc,var(--gold));line-height:1;flex-shrink:0;min-width:32px}
.dg-join{cursor:pointer;border-left-color:var(--gold)}
.dg-join span{color:var(--gold)}

/* ── PAGE HERO ── */
.pg-hero{height:auto;min-height:100px;background:#ffffff;border-bottom:2px solid #b2ebf2;position:relative;display:flex;align-items:flex-end;padding:2rem 2rem}
.pg-hero::after{display:none}
.pgh-inner{position:relative;z-index:1;max-width:1100px;width:100%;margin:0 auto}
.pgh-crumb{font-size:11px;color:#00838f;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:6px;font-weight:600}
.pgh-h1{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700;color:#006064;line-height:1.1;margin-bottom:6px}
.pgh-sub{font-size:14px;color:#555;line-height:1.7;max-width:600px}

/* ── ABOUT ── */
.ab{margin-bottom:0}
.ab-lbl{font-size:11px;text-transform:uppercase;letter-spacing:3px;color:var(--amber);font-weight:700;margin-bottom:8px}
.ab-h2{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:700;color:var(--navy);line-height:1.15;margin-bottom:1.5rem}
.ab-text p{font-size:14.5px;color:var(--mid);line-height:1.85;margin-bottom:.85rem}
.ab-text strong{color:var(--navy);font-weight:600}
.ab-facts{display:flex;gap:2.5rem;margin-top:1.75rem;flex-wrap:wrap;padding-top:1.5rem;border-top:2px solid rgba(100,70,10,.15)}
.abf strong{display:block;font-size:2rem;font-weight:700;color:var(--navy);line-height:1}
.abf span{font-size:12px;color:var(--muted);margin-top:3px;display:block}

/* VMG cards — strong distinct colours */
.vmg-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem}
.vmg{background:linear-gradient(145deg,#0e6e72,#09505470);border:none;border-radius:var(--rl);padding:1.75rem 1.5rem;box-shadow:var(--sh2)}
.vmg:nth-child(1){background:linear-gradient(145deg,#076e72,#0a9a9e)}
.vmg:nth-child(2){background:linear-gradient(145deg,#7a4200,#b06000)}
.vmg:nth-child(3){background:linear-gradient(145deg,#5c1a78,#8a2ab0)}
.vmg-h{font-size:1.2rem;font-weight:700;color:#fff;margin-bottom:.75rem}
.vmg p{font-size:13.5px;color:rgba(255,255,255,.85);line-height:1.75}

/* Principal box */
.principal{display:flex;gap:2rem;align-items:flex-start;background:linear-gradient(135deg,#c46a00,#e08010);border-radius:var(--rl);padding:2rem;box-shadow:var(--sh2)}
.prin-av{width:110px;height:140px;border-radius:var(--r);overflow:hidden;background:rgba(0,0,0,.3);flex-shrink:0;border:2px solid rgba(255,255,255,.3)}
.prin-av img{width:100%;height:100%;object-fit:cover;display:block}
.prin-body blockquote{font-size:1.1rem;font-style:italic;color:rgba(255,255,255,.92);line-height:1.8;border-left:4px solid rgba(255,255,255,.5);padding-left:1.1rem;margin-bottom:.85rem}
.prin-sig{font-size:14px;font-weight:600;color:#fff}
.prin-meta{font-size:12px;color:rgba(255,255,255,.65);margin-top:4px}

/* Dept list items — each coloured by dept */
.dept-list{display:flex;flex-direction:column;gap:.7rem;margin-top:1rem}
.dl-item{display:flex;gap:1.25rem;align-items:flex-start;background:linear-gradient(135deg,rgba(255,255,255,.65),rgba(255,255,255,.45));border:1px solid rgba(255,255,255,.6);border-left:6px solid var(--dc,var(--gold));border-radius:var(--rl);padding:1.25rem 1.5rem;box-shadow:var(--sh1);transition:all .2s}
.dl-item:hover{transform:translateX(5px);box-shadow:var(--sh2);background:rgba(255,255,255,.85)}
.dl-n{font-size:2rem;font-weight:700;color:var(--dc,var(--gold));line-height:1;flex-shrink:0;width:36px}
.dl-item strong{display:block;font-size:14px;font-weight:700;color:var(--navy);margin-bottom:3px}
.dl-item p{font-size:13px;color:var(--muted);line-height:1.65}

/* Contact cards */
.contact-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.1rem;margin-top:1.25rem}
.cr-item{display:flex;gap:10px;align-items:flex-start;background:linear-gradient(135deg,#08203e,#0e3060);border:1px solid rgba(255,255,255,.12);border-radius:var(--rl);padding:1.1rem 1.25rem;box-shadow:var(--sh2)}
.cr-ico{font-size:1.3rem;flex-shrink:0;margin-top:2px}
.cr-item strong{display:block;font-size:13px;font-weight:600;color:var(--gold2);margin-bottom:3px}
.cr-item div{font-size:13px;color:rgba(255,255,255,.7);line-height:1.65}
.cr-item a{color:var(--gold3);font-weight:500}

/* ── DIRECTORY ── */
.dir-bar{margin-bottom:1.75rem;background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:var(--rl);padding:1.4rem 1.5rem;box-shadow:var(--sh1)}
.dir-si{position:relative;margin-bottom:1.1rem}
.dir-sico{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:15px;pointer-events:none}
.dir-inp{width:100%;padding:13px 16px 13px 46px;border:2px solid rgba(100,70,10,.15);border-radius:50px;font-size:14px;font-family:'Jost',sans-serif;color:var(--text);background:#fff;outline:none;transition:all .2s}
.dir-inp:focus{border-color:var(--sky);background:#fff;box-shadow:0 0 0 3px rgba(26,111,175,.12);box-shadow:0 0 0 3px rgba(212,146,10,.15)}
.dir-filter-label{font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--amber);font-weight:700;margin-bottom:.55rem}
.dir-filters{display:flex;gap:7px;flex-wrap:wrap}
.df{padding:7px 16px;border-radius:30px;font-size:13px;border:1.5px solid rgba(8,32,62,.2);background:rgba(255,255,255,.6);color:var(--navy);transition:all .2s;font-weight:500}
.df:hover{background:rgba(255,255,255,.9);border-color:var(--navy)}
.df.active{background:var(--sky);color:#fff;border-color:var(--sky)}
.dir-batch-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}
.dir-batch-sel{display:flex;align-items:center;gap:.4rem}
.dir-blbl{font-size:12px;font-weight:600;color:var(--mid)}
.dir-bsel{padding:8px 12px;border:1.5px solid rgba(8,32,62,.2);border-radius:var(--r);font-size:13px;font-family:'Jost',sans-serif;background:rgba(255,255,255,.7);color:var(--navy);outline:none;transition:all .2s;min-width:100px}
.dir-bsel:focus{border-color:var(--gold);background:#fff}
.dir-batch-dash{font-size:16px;color:var(--muted);font-weight:300}
.dir-batch-clear{padding:7px 14px;border-radius:30px;border:1.5px solid rgba(180,50,30,.3);background:#fce8e8;color:#c53030;font-size:12px;font-weight:600;font-family:'Jost',sans-serif;cursor:pointer;transition:all .2s}
.dir-batch-clear:hover{background:#fca5a5}
.dir-results{font-size:13px;color:var(--muted);margin-bottom:1rem;font-weight:500}
.dir-results strong{color:var(--navy)}
.dir-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(215px,1fr));gap:1.1rem}
.dir-card{background:#ffffff;border-radius:var(--rl);overflow:hidden;box-shadow:var(--sh1);transition:all .3s;border:1px solid rgba(255,255,255,.65);cursor:pointer}
.dir-card:hover{transform:translateY(-6px);box-shadow:var(--sh3);background:#ffffff}
.dc-top{height:96px;display:flex;align-items:center;justify-content:center;position:relative}
.dc-av{width:60px;height:60px;border-radius:50%;background:rgba(255,255,255,.2);border:3px solid rgba(255,255,255,.45);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff}
.dc-av-img{width:60px;height:60px;border-radius:50%;object-fit:cover;border:3px solid rgba(255,255,255,.45)}
.dc-badge{position:absolute;top:8px;right:8px;background:var(--gold2);border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:10px}
.dc-body{padding:1.1rem}
.dc-name{font-size:14px;font-weight:700;margin-bottom:2px;color:var(--navy)}
.dc-co{font-size:12.5px;color:var(--teal);font-weight:600}
.dc-role{font-size:12px;color:var(--muted);margin-bottom:8px}
.dc-tags{display:flex;gap:4px;flex-wrap:wrap}
.dc-tag{font-size:10px;background:rgba(8,32,62,.1);color:var(--navy);padding:2px 8px;border-radius:20px;font-weight:600}
.dir-empty{text-align:center;padding:4rem;color:var(--muted);font-size:14px}

/* ── EVENTS ── */
.etabs{display:flex;gap:4px;margin-bottom:2.5rem;background:rgba(255,255,255,.5);border:2px solid rgba(8,32,62,.2);border-radius:50px;padding:4px;width:fit-content}
.etab{padding:9px 24px;border-radius:50px;border:none;font-size:13px;color:var(--navy);background:none;transition:all .2s;font-weight:500}
.etab.active{background:var(--navy);color:#fff}
.evg{display:none}.evg.active{display:block}
.evtl{display:flex;flex-direction:column}
.evtr{display:grid;grid-template-columns:88px 28px 1fr;align-items:start}
.evd{border-radius:var(--r);padding:10px 6px;text-align:center;display:flex;flex-direction:column;align-items:center;min-width:80px}
.ed-d{font-size:1.9rem;font-weight:700;color:#fff;line-height:1}
.ed-m{font-size:10px;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:1px}
.ed-y{font-size:9px;color:rgba(255,255,255,.45);margin-top:1px}
.evc{display:flex;flex-direction:column;align-items:center;padding-top:18px}
.evc-dot{width:9px;height:9px;border-radius:50%;background:var(--navy);flex-shrink:0}
.evc-line{width:1px;flex:1;min-height:50px;background:linear-gradient(to bottom,rgba(8,32,62,.3),transparent);margin-top:5px}
.evcard{background:#ffffff;border:1px solid rgba(255,255,255,.65);border-radius:var(--rl);padding:1.4rem 1.6rem;margin:0 0 1.4rem 1.1rem;box-shadow:var(--sh1);transition:all .2s}
.evcard:hover{box-shadow:var(--sh2);background:#ffffff}
.evcard.past{opacity:.6}
.evtag{display:inline-block;font-size:11px;padding:3px 10px;border-radius:20px;background:rgba(8,32,62,.12);color:var(--navy);font-weight:700;margin-bottom:7px}
.evcard h3{font-size:1.35rem;font-weight:700;margin-bottom:6px;color:var(--navy)}
.evmeta{font-size:12px;color:var(--muted);margin-bottom:8px}
.evcard p{font-size:13.5px;color:var(--mid);line-height:1.75;margin-bottom:1rem}
.evbtn{background:var(--sky);color:#fff;border:none;padding:9px 22px;border-radius:30px;font-size:13px;transition:all .2s;font-weight:600}
.evbtn:hover{transform:translateY(-1px);background:var(--sky2);color:#fff}

/* ── REGISTER ── */
.reg-layout{display:grid;grid-template-columns:1fr 280px;gap:2rem;align-items:start}
.reg-form{background:#ffffff;border:1px solid rgba(255,255,255,.7);border-radius:var(--rl);padding:2.25rem;box-shadow:var(--sh2)}
.rfs{font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--amber);font-weight:700;margin-bottom:1.1rem;padding-bottom:7px;border-bottom:2px solid rgba(196,106,0,.3)}
.rfr2{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;margin-bottom:.9rem}
.rff{display:flex;flex-direction:column;gap:4px}
.rff label{font-size:12px;font-weight:600;color:var(--mid)}
.rff input,.rff select,.rff textarea{padding:10px 13px;border:1.5px solid rgba(100,70,10,.2);border-radius:var(--r);font-size:13.5px;font-family:'Jost',sans-serif;color:var(--text);background:#fff;outline:none;transition:all .2s}
.rff input:focus,.rff select:focus,.rff textarea:focus{border-color:var(--sky);background:rgba(255,255,255,.95);box-shadow:0 0 0 3px rgba(212,146,10,.15)}
.rff textarea{height:88px;resize:vertical}
.rfcheck{display:flex;gap:10px;align-items:flex-start;margin-top:1.5rem}
.rfcheck input{flex-shrink:0;margin-top:3px;accent-color:var(--navy)}
.rfcheck label{font-size:13px;color:var(--mid);line-height:1.65}
.rfsub{width:100%;margin-top:1.6rem;padding:14px;background:var(--sky);color:#fff;border:none;border-radius:50px;font-size:14px;font-weight:700;letter-spacing:.3px;transition:all .25s;box-shadow:0 4px 18px rgba(26,111,175,.3)}
.rfsub:hover{background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--navy);transform:translateY(-2px);box-shadow:0 8px 24px rgba(212,146,10,.45)}

/* Aside cards */
.reg-aside{display:flex;flex-direction:column;gap:1rem}
.ra-card{background:linear-gradient(145deg,#076e72,#0a9a9e);border-radius:var(--rl);padding:1.6rem;box-shadow:var(--sh2)}
.ra-ico{font-size:1.75rem;margin-bottom:.6rem}
.ra-card h3{font-size:1.2rem;font-weight:700;margin-bottom:.85rem;color:#fff}
.ra-card ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.ra-card li{font-size:13px;color:rgba(255,255,255,.88);display:flex;gap:7px;align-items:center}
.ra-card li::before{content:'✓';color:var(--gold3);font-weight:700;flex-shrink:0}
.ra-card p{font-size:13px;color:rgba(255,255,255,.8);line-height:1.65}
.ra-card a{color:var(--gold3);font-weight:600;font-size:13px;word-break:break-word}
.ra-card:last-child{background:linear-gradient(145deg,#7a4200,#b06010)}

/* ── PROFILE MODAL ── */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:700;display:none;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(8px)}
.modal-bg.open{display:flex}
.modal-box{background:var(--bg);border-radius:var(--rl);width:100%;max-width:580px;overflow:hidden;box-shadow:0 32px 80px rgba(0,0,0,.4);animation:mIn .28s ease}
@keyframes mIn{from{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}
.pm-head{padding:1.75rem;display:flex;gap:1.25rem;align-items:center;position:relative}
.pm-cls{position:absolute;top:.9rem;right:.9rem;background:rgba(255,255,255,.2);border:none;color:#fff;width:30px;height:30px;border-radius:50%;font-size:13px;display:flex;align-items:center;justify-content:center;transition:background .2s}
.pm-cls:hover{background:rgba(255,255,255,.35)}
.pm-avimg{width:72px;height:72px;border-radius:50%;object-fit:cover;border:3px solid rgba(255,255,255,.45)}
.pm-av{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:#fff;border:3px solid rgba(255,255,255,.35)}
.pm-name{font-size:1.45rem;font-weight:700;color:#fff;margin-bottom:2px}
.pm-desig{font-size:13px;color:rgba(255,255,255,.88);margin-bottom:2px}
.pm-dept{font-size:11px;color:rgba(255,255,255,.55)}
.pm-body{padding:1.4rem 1.75rem 1.75rem;background:var(--bg)}
.pm-quote{background:linear-gradient(135deg,#c46a00,#e08010);border-radius:var(--r);padding:.9rem 1.1rem;font-style:italic;font-size:1.05rem;color:#fff;line-height:1.75;margin-bottom:1.1rem}
.pm-qq{font-size:1.8rem;color:rgba(255,255,255,.5);line-height:.4;vertical-align:-9px;margin-right:3px}
.pm-cols{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.pm-lbl{font-size:10px;text-transform:uppercase;letter-spacing:2px;color:var(--amber);font-weight:700;margin-bottom:.6rem}
.pm-row{display:flex;flex-direction:column;margin-bottom:.4rem}
.pm-row span{font-size:11px;color:var(--muted)}
.pm-row strong{font-size:13px;color:var(--text)}
.pm-row a{font-size:13px;color:var(--teal)}
.pm-ach{background:linear-gradient(135deg,#0a6e3a,#0c9050);border-radius:var(--r);padding:.9rem 1.1rem}
.pm-ach .pm-lbl{color:rgba(255,255,255,.7);margin-bottom:.4rem}
.pm-ach p{font-size:13px;color:rgba(255,255,255,.9)}

/* ── FOOTER ── */
.footer{background:#00bcd4;border-top:4px solid rgba(255,255,255,.3)}
.ft-top{max-width:1200px;margin:0 auto;padding:2.5rem 2rem 2rem;display:grid;grid-template-columns:280px 1fr 200px;gap:2rem;align-items:start}
.ft-brand{display:flex;align-items:center;gap:14px}
.ft-seal{width:52px;height:52px;color:#08203e;flex-shrink:0;min-width:52px}
.ft-seal svg{width:100%;height:100%;display:block}
.ft-name{font-size:15px;font-weight:700;color:#08203e}
.ft-tamil{font-size:11px;color:#08203e;margin-top:2px}
.ft-tag{font-size:10px;text-transform:uppercase;letter-spacing:2px;color:#006064;margin-top:4px;font-weight:600}
.ft-motto{font-size:12.5px;color:#08203e;line-height:1.88;max-width:380px}
.ft-nav{display:flex;flex-direction:column;gap:7px;align-items:flex-end}
.ft-nav button,.ft-nav a{font-size:13px;color:#08203e;background:none;border:none;transition:color .15s;text-decoration:none;text-align:right}
.ft-nav button:hover,.ft-nav a:hover{color:#006064}
.ft-bottom{border-top:1px solid rgba(0,0,0,.1);padding:1.1rem 2rem;max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem;font-size:11.5px;color:#08203e}

/* ── TOAST ── */
.toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%) translateY(16px);background:var(--navy);color:#fff;border:2px solid rgba(212,146,10,.4);padding:12px 28px;border-radius:50px;font-size:13.5px;box-shadow:var(--sh3);opacity:0;pointer-events:none;transition:all .3s;z-index:9000;white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── ALUMNI MEET ── */
.nl-meet{background:#08203e!important;color:#fff!important;border-radius:30px;padding:8px 16px;margin-left:4px;font-weight:700;animation:pulse-meet 2s infinite}
@keyframes pulse-meet{0%,100%{box-shadow:0 0 0 0 rgba(212,146,10,.4)}50%{box-shadow:0 0 0 8px rgba(212,146,10,0)}}
.countdown-banner{background:#01579b;border-bottom:none;border-top:none;padding:1.1rem 1.5rem}
.cd-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
.cd-label{font-size:13px;font-weight:600;color:#fff;letter-spacing:.5px}
.cd-units{display:flex;align-items:center;gap:.6rem}
.cd-unit{text-align:center}
.cd-num{font-family:'Cormorant Garamond',serif;font-size:1.9rem;font-weight:700;color:#006064;line-height:1;min-width:44px;background:#fff;border-radius:6px;padding:3px 8px;display:inline-block}
.cd-name{font-size:9px;color:rgba(255,255,255,.8);text-transform:uppercase;letter-spacing:1px;margin-top:2px}
.cd-sep{font-size:1.5rem;color:#fff;font-weight:700;margin-top:-6px;padding:0 2px}
.cd-btn{background:#fff;color:#006064;border:none;padding:9px 20px;border-radius:30px;font-size:13px;font-weight:700;font-family:'Jost',sans-serif;cursor:pointer;white-space:nowrap;transition:all .2s}
.cd-btn:hover{background:#e0f7fa;transform:translateY(-1px)}
.meet-hero{min-height:260px;background:linear-gradient(135deg,#e0f7fa 0%,#f5f5f5 50%,#e8f5e9 100%);border-bottom:2px solid #b2ebf2;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;text-align:center;padding:4rem 2rem}
.meet-hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 30% 60%,rgba(212,146,10,.2),transparent 55%),radial-gradient(ellipse at 75% 25%,rgba(14,110,114,.2),transparent 50%)}
.meet-hero-body{position:relative;z-index:1;max-width:780px}
.meet-badge{display:inline-block;background:#006064;color:#fff;border:none;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:6px 18px;border-radius:30px;margin-bottom:1rem}
.meet-h1{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700;color:#006064;line-height:1.1;margin-bottom:.5rem}
.meet-sub{font-size:14px;color:#37474f;margin-bottom:.75rem}
.meet-date-strip{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;font-size:14px;color:#37474f;margin-bottom:1.25rem;font-weight:500}
.mds{color:#bbb}
.meet-countdown{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:2.5rem;flex-wrap:wrap}
.mc-unit{text-align:center;background:#fff;border:2px solid #b2ebf2;border-radius:12px;padding:.75rem 1.25rem;min-width:72px;box-shadow:0 2px 8px rgba(0,188,212,.12)}
.mc-num{font-family:'Cormorant Garamond',serif;font-size:2.6rem;font-weight:700;color:#006064;line-height:1}
.mc-lbl{font-size:10px;color:#006064;text-transform:uppercase;letter-spacing:1px;margin-top:3px;font-weight:600}
.mc-sep{font-size:2rem;color:#006064;font-weight:700;margin-top:-4px}
.meet-btns{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-top:1.25rem}
.checkin-form{background:#ffffff;border:1px solid rgba(0,188,212,.25);border-radius:var(--rl);padding:1.5rem;box-shadow:var(--sh2);margin-bottom:2rem}
.ci-row{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}
.ci-input{padding:11px 14px;border:1.5px solid rgba(8,32,62,.2);border-radius:var(--r);font-size:13.5px;font-family:'Jost',sans-serif;background:rgba(255,255,255,.8);outline:none;transition:all .2s;flex:1;min-width:140px}
.ci-input:focus{border-color:var(--gold);background:#fff;box-shadow:0 0 0 3px rgba(212,146,10,.15)}
.ci-btn{background:linear-gradient(135deg,var(--navy),var(--navy3));color:#fff;border:none;padding:11px 24px;border-radius:30px;font-size:14px;font-weight:700;font-family:'Jost',sans-serif;cursor:pointer;white-space:nowrap;transition:all .2s}
.ci-btn:hover{background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--navy);transform:translateY(-1px)}
.checkin-wall{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin-top:1rem}
.ci-card{background:linear-gradient(135deg,rgba(255,255,255,.9),rgba(255,255,255,.7));border:1px solid rgba(255,255,255,.8);border-radius:14px;padding:1rem 1.1rem;box-shadow:var(--sh1);animation:popIn .4s ease}
@keyframes popIn{from{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}
.ci-card-av{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:700;color:#fff;margin-bottom:.6rem}
.ci-card-name{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:2px}
.ci-card-meta{font-size:12px;color:var(--muted)}
.ci-card-msg{font-size:12px;color:var(--mid);font-style:italic;margin-top:.4rem;border-top:1px solid var(--border);padding-top:.4rem}
.shoutout-form{display:flex;gap:.75rem;flex-wrap:wrap;background:#fff;border:1px solid rgba(0,188,212,.2);border-radius:var(--rl);padding:1.25rem;margin-bottom:1.5rem;box-shadow:var(--sh1)}
.shoutout-wall{display:flex;flex-direction:column;gap:.6rem}
.so-card{background:linear-gradient(135deg,rgba(7,110,114,.12),rgba(7,110,114,.06));border:1px solid rgba(7,110,114,.2);border-radius:12px;padding:.85rem 1rem;display:flex;gap:.75rem;align-items:flex-start;animation:popIn .35s ease}
.so-av{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--teal2));display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}
.so-name{font-size:13px;font-weight:700;color:var(--teal);margin-bottom:2px}
.so-msg{font-size:13.5px;color:var(--mid);line-height:1.5}
.bb-card{background:#fff;border:1px solid rgba(0,188,212,.2);border-radius:12px;padding:1rem;text-align:center;box-shadow:var(--sh1)}
.bb-year{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:700;color:var(--navy)}
.bb-count{font-size:2rem;font-weight:700;color:var(--gold);line-height:1}
.bb-lbl{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.qr-box{display:inline-block;background:#fff;border:3px solid var(--sky);border-radius:16px;padding:1.5rem;box-shadow:var(--sh3)}
@media print{body *{display:none!important}#qrSection,#qrSection *{display:block!important}.qr-box{border:2px solid #000;margin:2rem auto}}

/* ── ALUMNI COMMITTEE ── */
.committee{display:grid;grid-template-columns:280px 1fr;gap:2.5rem;align-items:start;margin-top:1rem}
.cmte-secretary{background:#e0f7fa;border:1px solid #b2ebf2;border-radius:var(--rl);padding:2rem;text-align:center;box-shadow:var(--sh1)}
.cmte-badge{display:inline-block;background:#00bcd4;color:#fff;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:5px 14px;border-radius:30px;margin-bottom:1.25rem}
.sec-av{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:700;color:var(--navy);margin:0 auto 1rem;box-shadow:0 4px 20px rgba(212,146,10,.4)}
.cmte-av{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:700;color:#fff;margin:0 auto 1rem}
.cmte-name{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:700;color:#08203e;margin-bottom:4px}
.cmte-role{font-size:13px;color:#555;line-height:1.6;margin-bottom:.85rem}
.cmte-contact a{font-size:13px;color:#00838f;font-weight:500;text-decoration:underline}
.cmte-members{padding:.5rem 0}
.cmte-mlabel{font-size:11px;text-transform:uppercase;letter-spacing:3px;color:#00bcd4;font-weight:700;margin-bottom:1.1rem}
.cmte-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}
.cmte-member{display:flex;align-items:center;gap:.85rem;background:#f5fbfc;border:1px solid #b2ebf2;border-radius:var(--rl);padding:1rem 1.1rem;transition:all .2s}
.cmte-member:hover{background:#e0f7fa;transform:translateY(-2px)}
.cmte-av-sm{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:700;color:#fff;flex-shrink:0}
.cmte-mname{font-size:14px;font-weight:600;color:#08203e;margin-bottom:2px}
.cmte-mrole{font-size:11px;color:#555}

/* ── JOBS ── */
.sec-jobs{padding:4rem 1.5rem 5rem;background:#ffffff}
.portal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.1rem;margin-bottom:1rem}
.portal-card{display:flex;flex-direction:column;background:#ffffff;border:1px solid rgba(255,255,255,.7);border-radius:var(--rl);padding:1.5rem;box-shadow:var(--sh1);transition:all .25s;text-decoration:none;position:relative;overflow:hidden;border-top:4px solid var(--pc,var(--navy))}
.portal-card:hover{transform:translateY(-5px);box-shadow:var(--sh3);background:rgba(255,255,255,.96)}
.portal-logo{font-size:2rem;margin-bottom:.65rem}
.portal-name{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:700;color:var(--navy);margin-bottom:.45rem}
.portal-desc{font-size:13px;color:var(--mid);line-height:1.7;flex:1;margin-bottom:.85rem}
.portal-tag{display:inline-block;font-size:11px;font-weight:600;background:rgba(8,32,62,.08);color:var(--navy);padding:3px 10px;border-radius:20px}
.portal-arrow{position:absolute;top:1rem;right:1rem;font-size:1.1rem;color:var(--pc,var(--navy));opacity:.5}
.portal-card:hover .portal-arrow{opacity:1;transform:translate(2px,-2px)}
.job-filters{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:.5rem}
.job-card{background:rgba(255,255,255,.85);border:1px solid rgba(255,255,255,.7);border-radius:var(--rl);padding:1.5rem;box-shadow:var(--sh1);margin-bottom:1rem;transition:all .2s;border-left:5px solid var(--navy)}
.job-card:hover{box-shadow:var(--sh2);background:rgba(255,255,255,.97)}
.job-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.6rem;flex-wrap:wrap}
.job-title{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:700;color:var(--navy)}
.job-badges{display:flex;gap:.4rem;flex-wrap:wrap}
.job-badge{font-size:10px;padding:3px 9px;border-radius:20px;font-weight:600;background:#dbeafe;color:#1e40af}
.job-badge.green{background:#d1fae5;color:#065f46}
.job-badge.purple{background:#ede9fe;color:#5b21b6}
.job-badge.amber{background:#fef3c7;color:#92400e}
.job-meta{display:flex;gap:1rem;flex-wrap:wrap;font-size:13px;color:var(--muted);margin-bottom:.75rem}
.job-meta span{display:flex;align-items:center;gap:4px}
.job-desc{font-size:13.5px;color:var(--mid);line-height:1.75;margin-bottom:1rem}
.job-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;padding-top:.85rem;border-top:1px solid var(--border)}
.job-poster{font-size:12px;color:var(--muted)}
.job-poster strong{color:var(--navy)}
.job-apply{background:linear-gradient(135deg,var(--navy),var(--navy3));color:#fff;border:none;padding:8px 20px;border-radius:30px;font-size:13px;font-weight:600;font-family:'Jost',sans-serif;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block}
.job-apply:hover{background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--navy);transform:translateY(-1px)}
.job-deadline{font-size:11px;color:#c53030;font-weight:600}

/* ── GALLERY ── */
.sec-gallery{padding:3rem 1.5rem 5rem;background:#ffffff}
.gal-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:2rem}
.gtab{padding:8px 20px;border-radius:30px;border:2px solid rgba(8,32,62,.2);background:rgba(255,255,255,.6);color:var(--navy);font-size:13px;font-weight:500;font-family:'Jost',sans-serif;cursor:pointer;transition:all .2s}
.gtab:hover{background:rgba(255,255,255,.9);border-color:var(--navy)}
.gtab.active{background:var(--sky);color:#fff;border-color:var(--sky)}
.gal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}
.gal-item{position:relative;border-radius:var(--rl);overflow:hidden;box-shadow:var(--sh2);cursor:pointer;aspect-ratio:4/3;background:#ddd}
.gal-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s}
.gal-item:hover img{transform:scale(1.06)}
.gal-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,transparent 55%);opacity:0;transition:opacity .3s;display:flex;flex-direction:column;justify-content:flex-end;padding:1rem}
.gal-item:hover .gal-overlay{opacity:1}
.gal-caption{font-size:13px;font-weight:600;color:#fff;line-height:1.3}
.gal-cat{font-size:11px;color:rgba(255,255,255,.65);margin-top:3px}

/* LIGHTBOX */
.lb-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:800;align-items:center;justify-content:center}
.lb-bg.open{display:flex}
.lb-wrap{max-width:90vw;max-height:90vh;position:relative;text-align:center}
.lb-img{max-width:100%;max-height:82vh;border-radius:var(--r);box-shadow:0 8px 48px rgba(0,0,0,.6);display:block}
.lb-caption{color:rgba(255,255,255,.8);font-size:14px;margin-top:.75rem;padding:0 1rem}
.lb-close{position:fixed;top:1.5rem;right:1.5rem;background:rgba(255,255,255,.15);border:none;color:#fff;width:40px;height:40px;border-radius:50%;font-size:18px;cursor:pointer;transition:background .2s;z-index:2}
.lb-close:hover{background:rgba(255,255,255,.3)}
.lb-prev,.lb-next{position:fixed;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:none;color:#fff;width:48px;height:48px;border-radius:50%;font-size:28px;cursor:pointer;transition:background .2s;z-index:2;display:flex;align-items:center;justify-content:center}
.lb-prev{left:1.5rem}.lb-next{right:1.5rem}
.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.28)}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .nav{display:none;flex-direction:column;position:absolute;top:68px;left:0;right:0;background:#00bcd4;border-bottom:2px solid rgba(0,0,0,.08);padding:.75rem 1.5rem;gap:2px;z-index:200}
  .nav.open{display:flex}
  .burger{display:flex}
  .hero-stats{gap:1rem;padding:1.25rem}
  .hsdiv{display:none}
  .voices{grid-template-columns:1fr}
  .reg-layout{grid-template-columns:1fr}
  .evtr{grid-template-columns:76px 22px 1fr}
  .ft-top{grid-template-columns:1fr;gap:1.5rem}
  .ft-nav{align-items:flex-start}
  .principal{flex-direction:column}
  .committee{grid-template-columns:1fr}
  .cmte-grid{grid-template-columns:1fr 1fr}
  .contact-row{grid-template-columns:1fr 1fr}
  .pm-cols{grid-template-columns:1fr}
}
@media(max-width:600px){
  .rfr2{grid-template-columns:1fr}
  .dept-grid{grid-template-columns:1fr 1fr}
  .hero-btns{flex-direction:column;align-items:center}
  .contact-row{grid-template-columns:1fr}
  .pillars{grid-template-columns:1fr}
  .ribbon-inner{justify-content:center;gap:.75rem;font-size:11px}
}
