@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;700;900&family=Syne:wght@400;600;700;800&family=Inter:wght@300;400;500;600&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --cyan:#00f5ff;--mag:#ff00c8;--gold:#ffd700;--green:#00ff88;
  --void:#020408;--deep:#060c14;--card:#0a1628;--card2:#0d1f3c;
  --bright:#f0f8ff;--mid:#8fa8c8;--dim:#4a6480;
  --border:rgba(0,245,255,0.1);--nav-h:68px;
}
html{scroll-behavior:smooth}
body{background:var(--void);color:var(--bright);font-family:'Inter',sans-serif;line-height:1.6;overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;background-image:linear-gradient(rgba(0,245,255,0.02) 1px,transparent 1px),linear-gradient(90deg,rgba(0,245,255,0.02) 1px,transparent 1px);background-size:60px 60px;pointer-events:none;z-index:0}
img{max-width:100%;display:block}a{text-decoration:none;color:inherit}
.scanline{position:fixed;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,0.02) 2px,rgba(0,0,0,0.02) 4px);pointer-events:none;z-index:9998}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:9999;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 5vw;background:rgba(2,4,8,0.96);backdrop-filter:blur(24px);border-bottom:1px solid var(--border)}
.nav-logo{font-family:'Orbitron',monospace;font-weight:900;font-size:13px;letter-spacing:.1em;color:var(--cyan);text-shadow:0 0 20px rgba(0,245,255,.4)}
.nav-logo span{color:var(--bright)}
.nav-links{display:flex;align-items:center;list-style:none;height:var(--nav-h)}
.nav-links>li{position:relative;height:100%;display:flex;align-items:center}
.nav-links>li>a{font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--mid);padding:0 12px;height:100%;display:flex;align-items:center;transition:color .2s;white-space:nowrap}
.nav-links>li>a:hover,.nav-links>li>a.active{color:var(--cyan)}
.nav-links>li:hover .dropdown{display:flex}
.dropdown{display:none;position:absolute;top:100%;left:0;min-width:240px;flex-direction:column;background:rgba(6,12,20,.98);backdrop-filter:blur(20px);border:1px solid var(--border);border-top:2px solid var(--cyan);z-index:100}
.dropdown a{font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);padding:12px 18px;border-bottom:1px solid var(--border);transition:all .2s}
.dropdown a:hover{color:var(--cyan);background:rgba(0,245,255,.04);padding-left:24px}
.nav-cta{font-family:'Orbitron',monospace;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--void);background:var(--cyan);padding:10px 20px;clip-path:polygon(7px 0%,100% 0%,calc(100% - 7px) 100%,0% 100%);transition:all .2s;white-space:nowrap}
.nav-cta:hover{background:#fff;box-shadow:0 0 28px rgba(0,245,255,.6)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none}
.hamburger span{width:22px;height:2px;background:var(--mid);display:block}
.mobile-menu{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:rgba(2,4,8,.98);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:9997;padding:20px 5vw 28px;flex-direction:column;max-height:calc(100vh - var(--nav-h));overflow-y:auto}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:13px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--mid);padding:13px 0;border-bottom:1px solid var(--border);transition:color .2s}
.mobile-menu a:hover{color:var(--cyan)}
.mobile-menu .sub{font-size:11px;padding:10px 0 10px 16px;color:var(--dim)}
.mobile-cta{color:var(--void)!important;background:var(--cyan);text-align:center;padding:15px!important;font-family:'Orbitron',monospace;font-size:11px;font-weight:700;margin-top:14px;border:none!important;clip-path:polygon(7px 0%,100% 0%,calc(100% - 7px) 100%,0% 100%)}

/* BUTTONS */
.btn{font-family:'Orbitron',monospace;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:14px 32px;display:inline-block;transition:all .2s;cursor:pointer;border:none}
.btn-cyan{color:var(--void);background:var(--cyan);clip-path:polygon(9px 0%,100% 0%,calc(100% - 9px) 100%,0% 100%)}
.btn-cyan:hover{background:#fff;box-shadow:0 0 36px rgba(0,245,255,.65);transform:translateY(-2px)}
.btn-outline{color:var(--cyan);background:transparent;border:1px solid rgba(0,245,255,.3)}
.btn-outline:hover{border-color:var(--cyan);background:rgba(0,245,255,.05)}
.btn-mag{color:var(--void);background:var(--mag);clip-path:polygon(9px 0%,100% 0%,calc(100% - 9px) 100%,0% 100%)}
.btn-mag:hover{background:#fff;box-shadow:0 0 36px rgba(255,0,200,.65);transform:translateY(-2px)}
.btn-gold{color:var(--void);background:var(--gold);clip-path:polygon(9px 0%,100% 0%,calc(100% - 9px) 100%,0% 100%)}
.btn-gold:hover{background:#fff;box-shadow:0 0 36px rgba(255,215,0,.65);transform:translateY(-2px)}
.btn-sm{font-size:10px;padding:9px 18px}

/* PAGE BANNER */
.page-banner{position:relative;padding:calc(var(--nav-h) + 60px) 5vw 56px;overflow:hidden;z-index:1;border-bottom:1px solid var(--border)}
.page-banner-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.1}
.page-banner-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(2,4,8,.6),rgba(2,4,8,.96))}
.page-banner-content{position:relative;z-index:1}
.page-eyebrow{font-family:'Orbitron',monospace;font-size:10px;letter-spacing:.35em;text-transform:uppercase;color:var(--cyan);margin-bottom:16px;display:flex;align-items:center;gap:10px}
.page-eyebrow::before{content:'';width:32px;height:1px;background:var(--cyan);display:block;box-shadow:0 0 8px var(--cyan)}
.page-title{font-family:'Orbitron',monospace;font-weight:900;font-size:clamp(28px,5vw,62px);line-height:1.05;margin-bottom:14px}
.page-sub{font-size:16px;color:var(--mid);max-width:560px;line-height:1.7}

/* SECTIONS */
.section{position:relative;z-index:1;padding:80px 5vw}
.section.dark{background:var(--deep)}
.sec-eyebrow{font-family:'Orbitron',monospace;font-size:10px;letter-spacing:.35em;text-transform:uppercase;color:var(--cyan);margin-bottom:14px}
.sec-title{font-family:'Orbitron',monospace;font-weight:900;font-size:clamp(24px,3.5vw,46px);line-height:1.1;margin-bottom:16px}
.sec-sub{font-size:16px;color:var(--mid);max-width:540px;line-height:1.7;margin-bottom:48px}

/* TICKER */
.ticker{background:var(--cyan);padding:11px 0;overflow:hidden;position:relative;z-index:1}
.ticker-inner{display:flex;gap:56px;animation:ticker 24s linear infinite;white-space:nowrap}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ti{font-family:'Orbitron',monospace;font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--void);display:flex;align-items:center;gap:18px}
.td{width:4px;height:4px;background:rgba(2,4,8,.3);border-radius:50%;flex-shrink:0}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}

/* COURSE CARDS */
.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2px;background:var(--border);border:1px solid var(--border)}
.course-card{background:var(--card);overflow:hidden;transition:background .25s;position:relative;display:flex;flex-direction:column}
.course-card:hover{background:var(--card2)}
.course-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--cyan);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.course-card.mg::before{background:var(--mag)}.course-card.gd::before{background:var(--gold)}
.course-card:hover::before{transform:scaleX(1)}
.course-card img{width:100%;height:180px;object-fit:cover;filter:brightness(.7) saturate(.6);transition:filter .3s}
.course-card:hover img{filter:brightness(.9) saturate(1)}
.course-body{padding:24px;flex:1;display:flex;flex-direction:column}
.course-track{font-family:'Orbitron',monospace;font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);margin-bottom:8px}
.course-card.mg .course-track{color:var(--mag)}.course-card.gd .course-track{color:var(--gold)}
.course-name{font-family:'Syne',sans-serif;font-weight:700;font-size:18px;color:var(--bright);margin-bottom:8px;line-height:1.2}
.course-desc{font-size:13px;color:var(--mid);line-height:1.6;flex:1;margin-bottom:18px}
.course-foot{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--border)}
.course-price{font-family:'Orbitron',monospace;font-size:18px;font-weight:900;color:var(--bright)}
.course-price small{font-size:10px;font-weight:400;color:var(--dim)}

/* INSTRUCTOR CARDS */
.instructor-card{background:var(--card);overflow:hidden;transition:background .25s;display:block}
.instructor-card:hover{background:var(--card2)}
.instructor-img{width:100%;height:300px;object-fit:cover;object-position:top;filter:brightness(.75) saturate(.7);transition:filter .4s}
.instructor-card:hover .instructor-img{filter:brightness(.95) saturate(1)}
.instructor-body{padding:24px}
.instructor-tag{font-family:'Orbitron',monospace;font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);margin-bottom:8px}
.instructor-name{font-family:'Syne',sans-serif;font-weight:800;font-size:20px;margin-bottom:4px}
.instructor-role{font-size:12px;color:var(--mid);margin-bottom:14px}
.badges{display:flex;flex-wrap:wrap;gap:7px}
.badge{font-family:'Orbitron',monospace;font-size:8px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--dim);border:1px solid var(--border);padding:4px 9px}

/* CELL GRID */
.cell-grid{display:grid;gap:1px;background:var(--border);border:1px solid var(--border)}
.cell{background:var(--card);padding:32px 28px;transition:background .25s}
.cell:hover{background:var(--card2)}

/* STEPS */
.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1px;background:var(--border);border:1px solid var(--border)}
.step{background:var(--card);padding:32px 26px}
.step-num{font-family:'Orbitron',monospace;font-size:10px;color:var(--dim);letter-spacing:.2em;margin-bottom:14px}
.step-title{font-family:'Syne',sans-serif;font-weight:700;font-size:17px;margin-bottom:8px}
.step-desc{font-size:13px;color:var(--mid);line-height:1.6}

/* TESTIMONIALS */
.testi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2px;background:var(--border);border:1px solid var(--border)}
.testi-card{background:var(--card);padding:32px 28px}
.testi-quote{font-size:14px;color:var(--mid);line-height:1.7;margin-bottom:22px}
.testi-quote::before{content:'"';font-family:'Orbitron',monospace;font-size:48px;color:var(--cyan);opacity:.22;display:block;line-height:1;margin-bottom:6px}
.author-av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--cyan),var(--mag));display:flex;align-items:center;justify-content:center;font-family:'Orbitron',monospace;font-size:12px;font-weight:700;color:var(--void);flex-shrink:0}
.author-name{font-family:'Syne',sans-serif;font-weight:700;font-size:14px}
.author-role{font-size:11px;color:var(--dim)}

/* CTA BAND */
.cta-band{text-align:center;padding:100px 5vw;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;width:700px;height:700px;background:radial-gradient(circle,rgba(0,245,255,.07) 0%,transparent 65%);top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;pointer-events:none}
.cta-label{font-family:'Orbitron',monospace;font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--mag);margin-bottom:18px}
.cta-h{font-family:'Orbitron',monospace;font-weight:900;font-size:clamp(28px,5vw,58px);line-height:1.05;margin-bottom:14px}
.cta-sub{font-size:16px;color:var(--mid);margin-bottom:40px}
.cta-contact{font-family:'Orbitron',monospace;font-size:10px;color:var(--dim);margin-top:24px;letter-spacing:.08em}
.cta-contact a{color:var(--cyan)}

/* PHOTO STRIP */
.photo-strip{display:grid;grid-template-columns:repeat(3,1fr);height:280px;gap:2px;background:var(--border);position:relative;z-index:1}
.ps-item{overflow:hidden;position:relative}
.ps-item img{width:100%;height:100%;object-fit:cover;filter:brightness(.72) saturate(.75);transition:all .45s}
.ps-item:hover img{transform:scale(1.04);filter:brightness(.92) saturate(1.05)}

/* BOOKING TABS */
.tabs{display:flex;gap:2px;background:var(--border);margin-bottom:2px}
.tab-btn{font-family:'Orbitron',monospace;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:13px 18px;background:var(--card);color:var(--dim);border:none;cursor:pointer;transition:all .2s;flex:1}
.tab-btn.on{background:var(--card2);color:var(--cyan);border-top:2px solid var(--cyan)}
.tab-btn.mg.on{color:var(--mag);border-top-color:var(--mag)}
.tab-btn.gd.on{color:var(--gold);border-top-color:var(--gold)}
.tab-panel{display:none;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2px;background:var(--border);border:1px solid var(--border)}
.tab-panel.on{display:grid}
.book-card{background:var(--card);display:flex;flex-direction:column;overflow:hidden;transition:background .25s;position:relative}
.book-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--cyan);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.book-card.mg::before{background:var(--mag)}.book-card.gd::before{background:var(--gold)}
.book-card:hover{background:var(--card2)}.book-card:hover::before{transform:scaleX(1)}
.book-card img{width:100%;height:160px;object-fit:cover;filter:brightness(.7) saturate(.6);transition:filter .3s}
.book-card:hover img{filter:brightness(.9) saturate(1)}
.book-body{padding:20px 22px;flex:1;display:flex;flex-direction:column}
.book-month{font-family:'Orbitron',monospace;font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);margin-bottom:7px}
.book-card.mg .book-month{color:var(--mag)}.book-card.gd .book-month{color:var(--gold)}
.book-name{font-family:'Syne',sans-serif;font-weight:700;font-size:16px;color:var(--bright);margin-bottom:7px;line-height:1.2}
.book-tag{font-size:12px;color:var(--mid);line-height:1.5;flex:1;margin-bottom:14px}
.book-foot{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--border)}
.book-price{font-family:'Orbitron',monospace;font-size:16px;font-weight:900;color:var(--bright)}
.book-price small{font-size:9px;font-weight:400;color:var(--dim)}
.enroll-a{font-family:'Orbitron',monospace;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--void);background:var(--cyan);padding:8px 14px;clip-path:polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%);transition:all .2s}
.book-card.mg .enroll-a{background:var(--mag)}.book-card.gd .enroll-a{background:var(--gold)}
.enroll-a:hover{background:#fff;box-shadow:0 0 14px rgba(0,245,255,.5)}

/* COURSE DETAIL */
.detail-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:2px;background:var(--border);border:1px solid var(--border)}
.detail-img img{width:100%;height:100%;min-height:460px;object-fit:cover;filter:brightness(.8) saturate(.75)}
.detail-side{background:var(--card);padding:44px 40px;display:flex;flex-direction:column;gap:24px}
.price-box{background:var(--card2);border:1px solid var(--border);padding:26px}
.price-num{font-family:'Orbitron',monospace;font-size:38px;font-weight:900;line-height:1;margin-bottom:6px}
.price-sub{font-size:12px;color:var(--mid)}
.meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.meta-item{background:var(--void);border:1px solid var(--border);padding:12px 14px}
.meta-label{font-family:'Orbitron',monospace;font-size:8px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);margin-bottom:5px}
.meta-val{font-size:13px;color:var(--bright);font-weight:500}
.includes{display:flex;flex-direction:column;gap:9px}
.inc-item{display:flex;gap:10px;font-size:13px;color:var(--mid)}
.curr-item{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--border)}
.curr-num{font-family:'Orbitron',monospace;font-size:11px;font-weight:700;flex-shrink:0;width:28px;line-height:1.6}
.curr-title{font-family:'Syne',sans-serif;font-weight:700;font-size:15px;margin-bottom:4px}
.curr-desc{font-size:13px;color:var(--mid);line-height:1.6}

/* TEACHER PAGE */
.teacher-split{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--border);border:1px solid var(--border)}
.teacher-img{overflow:hidden}
.teacher-img img{width:100%;height:100%;min-height:420px;object-fit:cover;object-position:top;filter:brightness(.75) saturate(.75);transition:filter .4s}
.teacher-img:hover img{filter:brightness(.95) saturate(1)}
.teacher-info{background:var(--card);padding:44px 40px}
.t-tag{font-family:'Orbitron',monospace;font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);margin-bottom:10px}
.t-name{font-family:'Syne',sans-serif;font-weight:800;font-size:26px;margin-bottom:4px}
.t-role{font-size:12px;color:var(--mid);letter-spacing:.08em;margin-bottom:14px}
.t-bio{font-size:14px;color:var(--mid);line-height:1.75;margin-bottom:18px}
.t-stats{display:flex;gap:28px;flex-wrap:wrap;padding-top:18px;border-top:1px solid var(--border)}
.t-stat .n{font-family:'Orbitron',monospace;font-size:26px;font-weight:900;color:var(--cyan);line-height:1}
.t-stat .l{font-size:10px;color:var(--dim);letter-spacing:.1em;margin-top:4px}

/* ABOUT / CONTACT */
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--border);border:1px solid var(--border)}
.about-img{overflow:hidden}
.about-img img{width:100%;height:100%;min-height:380px;object-fit:cover;filter:brightness(.75) saturate(.75);transition:filter .4s}
.about-img:hover img{filter:brightness(.95) saturate(1)}
.about-text{background:var(--card);padding:44px 40px}
.about-text h2{font-family:'Orbitron',monospace;font-weight:900;font-size:clamp(20px,2.5vw,32px);margin-bottom:18px;line-height:1.1}
.about-text p{font-size:14px;color:var(--mid);line-height:1.75;margin-bottom:14px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--border);border:1px solid var(--border)}
.contact-info{background:var(--card);padding:44px 40px}
.contact-form{background:var(--card2);padding:44px 40px}
.c-item{margin-bottom:28px}
.c-label{font-family:'Orbitron',monospace;font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);margin-bottom:7px}
.c-val{font-size:15px;color:var(--bright);line-height:1.6}
.c-val a{color:var(--cyan)}
.form-group{margin-bottom:18px}
.form-group label{font-family:'Orbitron',monospace;font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);display:block;margin-bottom:7px}
.form-group input,.form-group select,.form-group textarea{width:100%;background:var(--void);border:1px solid var(--border);color:var(--bright);font-family:'Inter',sans-serif;font-size:14px;padding:11px 14px;outline:none;transition:border-color .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--cyan)}
.form-group select option{background:var(--deep)}
.form-group textarea{height:110px;resize:vertical}
.map-wrap{border:1px solid var(--border);overflow:hidden;margin-top:36px}
.map-wrap iframe{width:100%;height:340px;border:none;filter:invert(90%) hue-rotate(180deg) saturate(.7)}
.loc-grid{background:var(--card);padding:22px 28px;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:20px}
.loc-label{font-family:'Orbitron',monospace;font-size:8px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);margin-bottom:5px}
.loc-val{font-size:13px;color:var(--bright)}

/* FOOTER */
footer{background:var(--deep);border-top:1px solid var(--border);padding:56px 5vw 34px;position:relative;z-index:1}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px;margin-bottom:44px}
.foot-logo{font-family:'Orbitron',monospace;font-weight:900;font-size:13px;letter-spacing:.08em;color:var(--cyan);text-shadow:0 0 18px rgba(0,245,255,.35);margin-bottom:12px}
.foot-brand p{font-size:13px;color:var(--dim);line-height:1.7;max-width:240px}
.foot-brand p+p{margin-top:9px}
.foot-col h4{font-family:'Orbitron',monospace;font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--mid);margin-bottom:16px}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:8px}
.foot-col a{font-size:12px;color:var(--dim);transition:color .2s}
.foot-col a:hover{color:var(--cyan)}
.foot-bottom{border-top:1px solid var(--border);padding-top:22px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.foot-copy{font-size:11px;color:var(--dim)}
.foot-copy span{color:var(--cyan)}
.socials{display:flex;gap:10px}
.socials a{width:34px;height:34px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--dim);font-size:10px;font-family:'Orbitron',monospace;font-weight:700;transition:all .2s}
.socials a:hover{border-color:var(--cyan);color:var(--cyan);box-shadow:0 0 12px rgba(0,245,255,.3)}

/* GALLERY */
.gallery-4{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:var(--border);border:1px solid var(--border);height:220px}
.gallery-4 div{overflow:hidden}
.gallery-4 img{width:100%;height:100%;object-fit:cover;filter:brightness(.7) saturate(.7);transition:all .4s}
.gallery-4 div:hover img{filter:brightness(.92) saturate(1);transform:scale(1.04)}

/* UTILITY */
.flex{display:flex}.gap-16{gap:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mt-48{margin-top:48px}
.text-cyan{color:var(--cyan)}.text-mag{color:var(--mag)}.text-gold{color:var(--gold)}.text-mid{color:var(--mid)}
.orb{font-family:'Orbitron',monospace}.syne{font-family:'Syne',sans-serif}
[data-reveal]{transition:opacity .6s ease,transform .6s ease}

/* RESPONSIVE */
@media(max-width:1024px){.foot-grid{grid-template-columns:1fr 1fr}.foot-grid>*:first-child{grid-column:1/-1}}
@media(max-width:768px){
  .nav-links{display:none}.hamburger{display:flex}
  .section{padding:56px 4vw}.page-banner{padding:calc(var(--nav-h) + 36px) 4vw 44px}
  .teacher-split,.about-split,.contact-grid,.detail-grid{grid-template-columns:1fr}
  .detail-img img{min-height:260px}.teacher-img img{min-height:260px}
  .photo-strip{grid-template-columns:1fr 1fr;height:220px}.photo-strip .ps-item:last-child{display:none}
  .gallery-4{grid-template-columns:1fr 1fr;height:auto}.gallery-4 div{height:160px}
}
@media(max-width:540px){
  nav{padding:0 4vw}
  .photo-strip{grid-template-columns:1fr;height:200px}.photo-strip .ps-item:last-child{display:block}.photo-strip .ps-item:nth-child(2){display:none}
  .foot-grid{grid-template-columns:1fr}
  .meta-grid{grid-template-columns:1fr}
}
