:root {
  --navy:   #0d1f3c;
  --navy2:  #162c52;
  --blue:   #1a4080;
  --sky:    #2563b0;
  --gold:   #c8922a;
  --gold2:  #e4ae45;
  --cream:  #faf8f3;
  --cream2: #f2ede2;
  --white:  #ffffff;
  --dark:   #0a1525;
  --text:   #1e2d42;
  --muted:  #5a6a82;
  --border: rgba(13,31,60,.11);
  --shad:   0 8px 40px rgba(13,31,60,.13);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;background:var(--cream);color:var(--text);overflow-x:hidden}

/* == TOPBAR == */
.topbar{background:var(--navy);color:rgba(255,255,255,.8);font-size:.76rem;padding:7px 0}
.tb-inner{max-width:1280px;margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:center;gap:8px;flex-wrap:wrap}
.tb-left{display:flex;align-items:center;gap:20px}
.tb-right{display:flex;align-items:center;gap:14px}
.tb-social a{width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.1);display:inline-flex;align-items:center;justify-content:center;color:white;text-decoration:none;font-size:.65rem;transition:background .2s}
.tb-social a:hover{background:var(--gold)}
.tb-social{display:flex;gap:7px}
.tb-link{color:var(--gold2);text-decoration:none;font-weight:500;transition:opacity .2s}
.tb-link:hover{opacity:.75}

/* == HEADER == */
header{background:var(--white);box-shadow:0 2px 18px rgba(13,31,60,.09);position:sticky;top:0;z-index:900}
.hdr{max-width:1280px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none}
.brand-seal{width:52px;height:52px;border-radius:50%;background:linear-gradient(145deg,var(--blue),var(--navy));display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;color:white;font-size:1.3rem;font-weight:800;box-shadow:0 4px 14px rgba(13,31,60,.25);flex-shrink:0}
.brand-text h1{font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:700;color:var(--navy);line-height:1.2}
.brand-text p{font-size:.7rem;color:var(--muted)}

nav{display:flex;align-items:center;gap:2px}
.ni{position:relative}
.nl{display:flex;align-items:center;gap:3px;padding:8px 12px;font-size:.83rem;font-weight:500;color:var(--text);text-decoration:none;border-radius:8px;transition:all .2s;white-space:nowrap}
.nl svg{width:9px;height:9px;transition:transform .2s}
.ni:hover .nl{background:var(--cream);color:var(--blue)}
.ni:hover .nl svg{transform:rotate(180deg)}
.drop{position:absolute;top:calc(100% + 6px);left:0;background:white;border:1px solid var(--border);border-radius:12px;box-shadow:var(--shad);min-width:196px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .22s;z-index:999;overflow:hidden}
.ni:hover .drop{opacity:1;visibility:visible;transform:translateY(0)}
.drop a{display:block;padding:10px 16px;font-size:.82rem;color:var(--text);text-decoration:none;border-bottom:1px solid var(--border);transition:background .15s}
.drop a:last-child{border-bottom:none}
.drop a:hover{background:var(--cream);color:var(--blue)}
.btn-admit{background:var(--gold);color:white;padding:9px 20px;border-radius:30px;font-size:.82rem;font-weight:600;text-decoration:none;margin-left:6px;transition:all .2s;box-shadow:0 4px 14px rgba(200,146,42,.28)}
.btn-admit:hover{background:var(--gold2);transform:translateY(-1px)}
.ham{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.ham span{width:22px;height:2px;background:var(--navy);border-radius:2px;transition:all .3s}

/* == HERO / SLIDER == */
.hero{position:relative;height:600px;overflow:hidden;background:var(--dark)}
.slides{display:flex;height:100%;transition:transform .85s cubic-bezier(.77,0,.18,1);will-change:transform}
.slide{min-width:100%;height:100%;position:relative;display:flex;align-items:center}

/* Slide backgrounds - rich illustrated gradients */
.s1 .sbg{background:linear-gradient(120deg,#0d1f3c 0%,#1a4080 55%,#2563b0 100%)}
.s2 .sbg{background:linear-gradient(120deg,#13240a 0%,#1e4810 50%,#2c6b18 100%)}
.s3 .sbg{background:linear-gradient(120deg,#2a1200 0%,#7a3d0a 45%,#c8922a 100%)}
.s4 .sbg{background:linear-gradient(120deg,#1a0d2e 0%,#3d1a6e 50%,#5c2ca0 100%)}

.sbg{position:absolute;inset:0;background-size:cover;background-position:center}
.sbg::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.72) 0%,rgba(0,0,0,.35) 60%,transparent 100%)}

/* decorative geometric layer */
.s-deco{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.s-deco::before{content:'';position:absolute;right:-60px;top:-60px;width:500px;height:500px;border-radius:50%;background:rgba(255,255,255,.03);border:60px solid rgba(255,255,255,.04)}
.s-deco::after{content:'';position:absolute;right:100px;bottom:-80px;width:300px;height:300px;border-radius:50%;background:rgba(255,255,255,.025);border:40px solid rgba(255,255,255,.03)}

/* pattern dots */
.s-dots{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:32px 32px;pointer-events:none}

.s-content{position:relative;z-index:2;max-width:1280px;margin:0 auto;padding:0 28px;width:100%}
.s-badge{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.1);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.9);padding:5px 14px;border-radius:30px;font-size:.74rem;font-weight:500;margin-bottom:18px;animation:fadeUp .7s ease both}
.s-badge i{width:5px;height:5px;border-radius:50%;background:var(--gold2);flex-shrink:0}
.slide h2{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,4.5vw,3.4rem);color:white;font-weight:800;line-height:1.15;max-width:580px;margin-bottom:14px;animation:fadeUp .7s .1s ease both}
.slide h2 em{color:var(--gold2);font-style:normal}
.slide p{color:rgba(255,255,255,.78);font-size:.98rem;max-width:460px;line-height:1.75;margin-bottom:28px;animation:fadeUp .7s .2s ease both}
.s-btns{display:flex;gap:12px;flex-wrap:wrap;animation:fadeUp .7s .3s ease both}
.btn-p{background:var(--gold);color:white;padding:12px 28px;border-radius:36px;font-size:.86rem;font-weight:600;text-decoration:none;transition:all .2s;box-shadow:0 5px 18px rgba(200,146,42,.32)}
.btn-p:hover{background:var(--gold2);transform:translateY(-2px)}
.btn-o{background:rgba(255,255,255,.1);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.28);color:white;padding:12px 28px;border-radius:36px;font-size:.86rem;font-weight:500;text-decoration:none;transition:all .2s}
.btn-o:hover{background:rgba(255,255,255,.2)}

/* hero stats panel */
.h-stats{position:absolute;bottom:0;right:0;z-index:3;display:flex}
.hstat{background:rgba(255,255,255,.08);backdrop-filter:blur(14px);border-left:1px solid rgba(255,255,255,.12);border-top:1px solid rgba(255,255,255,.12);padding:20px 28px;text-align:center;color:white}
.hstat .n{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:800;color:var(--gold2);display:block;line-height:1}
.hstat .l{font-size:.72rem;opacity:.75;margin-top:4px}

/* slider controls */
.s-arrows{position:absolute;top:50%;transform:translateY(-50%);width:100%;display:flex;justify-content:space-between;padding:0 16px;z-index:10;pointer-events:none}
.s-arr{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.22);color:white;font-size:1.2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;pointer-events:all;transition:all .2s}
.s-arr:hover{background:var(--gold)}
.s-dots-nav{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:10;display:flex;gap:8px}
.sdot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.35);border:none;cursor:pointer;transition:all .3s;padding:0}
.sdot.on{background:var(--gold2);width:26px;border-radius:4px}

@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}

/* == TICKER == */
.ticker{background:var(--blue);padding:11px 0;overflow:hidden}
.t-wrap{display:flex;align-items:center}
.t-tag{background:var(--gold);color:white;font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 18px;white-space:nowrap;flex-shrink:0;margin-right:16px}
.t-track{display:flex;gap:60px;animation:tick 38s linear infinite;white-space:nowrap}
.t-track a{color:rgba(255,255,255,.85);font-size:.82rem;text-decoration:none;white-space:nowrap;transition:color .2s}
.t-track a:hover{color:var(--gold2)}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* == QUICKLINKS == */
.ql{background:white;padding:36px 0;border-bottom:1px solid var(--border)}
.ql-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.ql-card{display:flex;flex-direction:column;align-items:center;gap:9px;padding:18px 12px;border-radius:14px;border:1px solid var(--border);text-decoration:none;color:var(--text);background:var(--cream);transition:all .25s;text-align:center}
.ql-card:hover{background:var(--navy);color:white;border-color:var(--navy);transform:translateY(-3px);box-shadow:var(--shad)}
.ql-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--blue),var(--sky));display:flex;align-items:center;justify-content:center;font-size:1.3rem;transition:all .25s}
.ql-card:hover .ql-icon{background:rgba(255,255,255,.15)}
.ql-card span{font-size:.78rem;font-weight:500}

/* == SECTION BASE == */
section{padding:76px 0}
.container{max-width:1280px;margin:0 auto;padding:0 24px}
.sec-head{text-align:center;margin-bottom:52px}
.sec-tag{display:inline-block;color:var(--blue);font-size:.74rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px}
.sec-title{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,3vw,2.6rem);font-weight:800;color:var(--dark);line-height:1.2}
.sec-title em{color:var(--blue);font-style:normal}
.sec-bar{width:54px;height:3px;background:linear-gradient(to right,var(--blue),var(--gold));margin:14px auto 0;border-radius:2px}

/* == NOTICE + SIDEBAR == */
.ns{background:var(--cream)}
.ns-grid{display:grid;grid-template-columns:1fr 330px;gap:28px;align-items:start}

.nbox{background:white;border-radius:18px;box-shadow:0 4px 22px rgba(13,31,60,.07);overflow:hidden}
.nbox-hdr{background:linear-gradient(135deg,var(--navy),var(--blue));padding:18px 24px;display:flex;justify-content:space-between;align-items:center}
.nbox-hdr h3{color:white;font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:700}
.nbox-hdr a{color:var(--gold2);font-size:.78rem;text-decoration:none}
.nlist{padding:6px 0;max-height:400px;overflow-y:auto}
.nitem{display:flex;gap:14px;align-items:flex-start;padding:14px 20px;border-bottom:1px solid var(--border);transition:background .15s}
.nitem:last-child{border-bottom:none}
.nitem:hover{background:var(--cream)}
.ndate{flex-shrink:0;text-align:center;background:var(--cream2);border-radius:9px;padding:7px 10px;min-width:48px}
.ndate .dy{font-size:1.2rem;font-weight:700;color:var(--blue);line-height:1}
.ndate .mn{font-size:.62rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.ninfo a{font-size:.86rem;color:var(--text);text-decoration:none;font-weight:500;display:block;margin-bottom:5px;line-height:1.4;transition:color .15s}
.ninfo a:hover{color:var(--blue)}
.ndl{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;color:var(--gold);font-weight:500;text-decoration:none}

/* Sidebar */
.sidebar{display:flex;flex-direction:column;gap:18px}
.scard{background:white;border-radius:18px;box-shadow:0 4px 22px rgba(13,31,60,.07);overflow:hidden}
.scard-hdr{padding:14px 18px;font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:700;color:white}
.hdr-navy{background:linear-gradient(135deg,var(--navy),var(--blue))}
.hdr-gold{background:linear-gradient(135deg,var(--gold),var(--gold2))}
.principal-body{padding:18px;display:flex;flex-direction:column;align-items:center;text-align:center}
.p-avatar{width:90px;height:110px;border-radius:12px;background:linear-gradient(135deg,var(--blue),var(--sky));display:flex;align-items:center;justify-content:center;font-size:2.6rem;border:3px solid var(--blue);margin-bottom:12px;box-shadow:0 6px 18px rgba(13,31,60,.18)}
.p-name{font-family:'Cormorant Garamond',serif;font-size:.96rem;font-weight:700;color:var(--navy)}
.p-role{font-size:.73rem;color:var(--muted);margin-bottom:12px}
.btn-rm{background:var(--navy);color:white;padding:7px 18px;border-radius:20px;font-size:.76rem;font-weight:500;text-decoration:none;transition:background .2s}
.btn-rm:hover{background:var(--blue)}
.ulinks{padding:10px 0}
.ulinks a{display:flex;align-items:center;gap:9px;padding:9px 18px;font-size:.83rem;color:var(--text);text-decoration:none;border-bottom:1px solid var(--border);transition:all .15s}
.ulinks a:last-child{border-bottom:none}
.ulinks a:hover{background:var(--cream);color:var(--blue);padding-left:24px}
.ulinks a::before{content:'\203A';color:var(--blue);font-size:1rem}

/* == ABOUT == */
.about-sec{background:white}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.about-visual{position:relative}
.a-main{width:100%;height:400px;border-radius:22px;background:linear-gradient(135deg,var(--navy) 0%,var(--blue) 60%,var(--sky) 100%);display:flex;align-items:center;justify-content:center;font-size:5rem;box-shadow:var(--shad);position:relative;overflow:hidden}
.a-main::before{content:'';position:absolute;top:-30px;right:-30px;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.05);border:30px solid rgba(255,255,255,.06)}
.a-float{position:absolute;bottom:-20px;right:-20px;width:160px;background:white;border-radius:14px;padding:18px;box-shadow:var(--shad);text-align:center}
.a-float .big{font-family:'Cormorant Garamond',serif;font-size:2rem;color:var(--blue);font-weight:900}
.a-float .sm{font-size:.72rem;color:var(--muted)}
.about-content .sec-tag{display:block;text-align:left}
.about-content .sec-title{text-align:left;margin-bottom:18px}
.about-content p{color:var(--muted);line-height:1.85;margin-bottom:14px;font-size:.93rem}
.afeats{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin:22px 0}
.afeat{display:flex;align-items:center;gap:9px;font-size:.83rem;font-weight:500}
.adot{width:7px;height:7px;background:var(--blue);border-radius:50%;flex-shrink:0}
.btn-more{display:inline-block;background:var(--navy);color:white;padding:12px 28px;border-radius:36px;font-size:.86rem;font-weight:600;text-decoration:none;transition:all .2s}
.btn-more:hover{background:var(--blue);transform:translateY(-1px)}

/* == RESULTS == */
.res-sec{background:linear-gradient(135deg,var(--navy) 0%,var(--blue) 100%);padding:76px 0;position:relative;overflow:hidden}
.res-sec::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Ccircle cx='30' cy='30' r='4'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.res-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px}
.rcard{background:rgba(255,255,255,.08);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:26px 20px;text-align:center;text-decoration:none;color:white;transition:all .25s}
.rcard:hover{background:rgba(255,255,255,.16);transform:translateY(-4px)}
.rcard .yr{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:800;color:var(--gold2);display:block}
.rcard .lb{font-size:.76rem;opacity:.75;margin-top:3px}
.rcard .go{font-size:.78rem;color:var(--gold2);margin-top:12px}
.res-stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.rstats{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:20px;text-align:center;color:white}
.rstats .rn{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:800;color:var(--gold2)}
.rstats .rl{font-size:.76rem;opacity:.7;margin-top:4px}

/* == ACADEMICS == */
.ac-sec{background:var(--cream)}
.ac-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.ac-card{background:white;border-radius:18px;padding:28px;border:1px solid var(--border);transition:all .3s;position:relative;overflow:hidden}
.ac-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(to right,var(--navy),var(--gold));transform:scaleX(0);transition:transform .3s;transform-origin:left}
.ac-card:hover::after{transform:scaleX(1)}
.ac-card:hover{transform:translateY(-4px);box-shadow:var(--shad)}
.ac-ico{font-size:2.2rem;margin-bottom:14px;display:block}
.ac-card h3{font-family:'Cormorant Garamond',serif;font-size:1.18rem;color:var(--navy);margin-bottom:9px}
.ac-card p{font-size:.83rem;color:var(--muted);line-height:1.7;margin-bottom:14px}
.ac-lks a{display:flex;align-items:center;gap:6px;font-size:.79rem;color:var(--text);text-decoration:none;transition:color .15s;margin-bottom:5px}
.ac-lks a:hover{color:var(--blue)}
.ac-lks a::before{content:'\2197';font-size:.75rem}

/* == GALLERY == */
.gal-sec{background:white}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,170px);gap:12px}
.git{border-radius:14px;overflow:hidden;position:relative;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:2.8rem;transition:transform .3s}
.git:hover{transform:scale(1.02)}
.git:nth-child(1){grid-column:span 2;background:linear-gradient(135deg,#0d1f3c,#2563b0);color:white}
.git:nth-child(4){grid-row:span 2;background:linear-gradient(135deg,#162c52,#1a4080);color:white}
.git:nth-child(2){background:linear-gradient(135deg,#c8922a,#e4ae45);color:white}
.git:nth-child(3){background:linear-gradient(135deg,#0a3320,#1a6640);color:white}
.git:nth-child(5){background:linear-gradient(135deg,#1a0d2e,#5c2ca0);color:white}
.git:nth-child(6){background:linear-gradient(135deg,#2a0a0a,#801a1a);color:white}
.git-lbl{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.65),transparent);color:white;padding:18px 14px 12px;font-size:.78rem;font-weight:500}

/* == CONTACT == */
.ct-sec{background:var(--cream)}
.ct-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.ct-info h3{font-family:'Cormorant Garamond',serif;font-size:1.55rem;color:var(--navy);margin-bottom:22px}
.ct-items{display:flex;flex-direction:column;gap:18px}
.ct-item{display:flex;gap:14px;align-items:flex-start}
.ct-ico{width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,var(--navy),var(--blue));display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;color:white}
.ct-txt strong{font-size:.82rem;color:var(--blue);display:block;margin-bottom:2px}
.ct-txt span{font-size:.86rem;color:var(--muted)}
.ct-form{background:white;border-radius:20px;padding:32px;box-shadow:0 4px 22px rgba(13,31,60,.07)}
.ct-form h3{font-family:'Cormorant Garamond',serif;font-size:1.35rem;color:var(--navy);margin-bottom:22px}
.fg{margin-bottom:16px}
.fg label{display:block;font-size:.79rem;font-weight:500;color:var(--text);margin-bottom:6px}
.fg input,.fg textarea,.fg select{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:9px;font-family:inherit;font-size:.88rem;color:var(--text);background:var(--cream);outline:none;transition:border-color .2s}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--blue);background:white}
.fg textarea{height:110px;resize:vertical}
.btn-send{width:100%;background:var(--navy);color:white;padding:13px;border:none;border-radius:9px;font-size:.92rem;font-weight:600;cursor:pointer;transition:background .2s;font-family:inherit}
.btn-send:hover{background:var(--blue)}

/* == FOOTER == */
footer{background:var(--dark);color:rgba(255,255,255,.7);padding:60px 0 0}
.ft-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:44px;margin-bottom:44px}
.ft-brand p{font-size:.83rem;line-height:1.8;margin:14px 0 18px;max-width:270px}
.ft-soc{display:flex;gap:9px}
.ft-soc a{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;text-decoration:none;color:rgba(255,255,255,.65);font-size:.8rem;transition:all .2s}
.ft-soc a:hover{background:var(--gold);color:white}
.ft-col h4{color:white;font-size:.86rem;font-weight:600;margin-bottom:16px;padding-bottom:9px;border-bottom:1px solid rgba(255,255,255,.07)}
.ft-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.ft-col ul li a{color:rgba(255,255,255,.58);font-size:.82rem;text-decoration:none;transition:color .2s;display:flex;align-items:center;gap:5px}
.ft-col ul li a:hover{color:var(--gold2)}
.ft-col ul li a::before{content:'\203A';font-size:.95rem}
.ft-bot{border-top:1px solid rgba(255,255,255,.07);padding:18px 0;display:flex;justify-content:space-between;align-items:center;font-size:.76rem;flex-wrap:wrap;gap:8px}
.ft-bot a{color:var(--gold2);text-decoration:none}

/* == BACK TOP == */
.btt{position:fixed;bottom:28px;right:28px;z-index:999;width:42px;height:42px;border-radius:50%;background:var(--blue);color:white;display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:1rem;box-shadow:0 4px 16px rgba(13,31,60,.28);opacity:0;transform:translateY(10px);transition:all .3s;pointer-events:none}
.btt.on{opacity:1;transform:translateY(0);pointer-events:all}
.btt:hover{background:var(--navy)}

/* == REVEAL == */
.rv{opacity:0;transform:translateY(28px);transition:all .6s ease}
.rv.vis{opacity:1;transform:translateY(0)}

/* == MOBILE == */
.mob-menu{display:none;position:fixed;inset:0;background:rgba(10,21,37,.96);backdrop-filter:blur(8px);z-index:9999;flex-direction:column;padding:26px 24px;overflow-y:auto}
.mob-menu.open{display:flex}
.mob-close{align-self:flex-end;background:none;border:none;color:white;font-size:1.7rem;cursor:pointer;margin-bottom:18px}
.mob-lnk{display:block;color:rgba(255,255,255,.82);font-size:1.05rem;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.07);text-decoration:none;transition:color .2s}
.mob-lnk:hover{color:var(--gold2)}

/* == RESPONSIVE == */
@media(max-width:1024px){
  nav{display:none}.ham{display:flex}
  .ns-grid{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr;gap:36px}
  .ft-grid{grid-template-columns:1fr 1fr}
  .ac-grid{grid-template-columns:1fr 1fr}
  .ql-grid{grid-template-columns:repeat(3,1fr)}
  .h-stats{display:none}
  .res-grid{grid-template-columns:repeat(2,1fr)}
  .ct-grid{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:auto}
  .git:nth-child(1){grid-column:span 1}
  .git:nth-child(4){grid-row:span 1}
}
@media(max-width:640px){
  .hero{height:520px}
  .ql-grid{grid-template-columns:repeat(2,1fr)}
  .ac-grid{grid-template-columns:1fr}
  .res-grid{grid-template-columns:repeat(2,1fr)}
  .res-stat-row{grid-template-columns:1fr 1fr}
  .ft-grid{grid-template-columns:1fr;gap:28px}
  .a-float{display:none}
}
