/* ═══════════════════════════════════════════════════
   KOTHARI VIDYA MANDIR — SHARED SITE STYLESHEET
   Version 1.0 | 2026
═══════════════════════════════════════════════════ */

/* ── TOKENS ── */
:root{
  --gold:#FFB800;--gold-dark:#E09900;--gold-light:#FFF3CC;
  --navy:#0B1D3A;--navy2:#132848;--navy3:#1a3a6e;
  --red:#CC1C1C;--green:#15803D;--teal:#0D5C69;
  --white:#fff;--text:#3d4a5c;--light:#f4f7fb;--border:#e5eaf2;
  --ease:cubic-bezier(.22,.68,0,1.2);
  --ease-out:cubic-bezier(0,.55,.45,1);
  --shadow-sm:0 2px 12px rgba(0,0,0,.07);
  --shadow:0 8px 32px rgba(0,0,0,.10);
  --shadow-lg:0 20px 60px rgba(0,0,0,.14);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI',system-ui,sans-serif;color:var(--navy);overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{max-width:100%}

/* ── VIEW TRANSITIONS ── */
@keyframes vt-in{from{opacity:0;translate:0 18px}}
@keyframes vt-out{to{opacity:0;translate:0 -18px}}
::view-transition-old(root){animation:.3s ease-in both vt-out}
::view-transition-new(root){animation:.38s var(--ease-out) both vt-in}
@media(prefers-reduced-motion:reduce){
  ::view-transition-old(root),::view-transition-new(root){animation:none}
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

/* ── SCROLL PROGRESS ── */
#scrollProgress{position:fixed;top:0;left:0;height:3px;width:0%;background:linear-gradient(90deg,var(--gold),#ff9f00,var(--gold));z-index:10001;transition:width .1s linear;box-shadow:0 0 12px rgba(255,184,0,.6)}

/* ── REVEAL ENGINE ── */
.reveal{opacity:0;transform:translateY(44px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.reveal.up{transform:translateY(44px)}
.reveal.left{transform:translateX(-54px)}
.reveal.right{transform:translateX(54px)}
.reveal.scale{transform:scale(.86)}
.reveal.fade{transform:none}
.reveal.visible{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}
.d4{transition-delay:.4s}.d5{transition-delay:.5s}.d6{transition-delay:.6s}

/* ── SHIMMER ── */
.shimmer{position:relative;overflow:hidden}
.shimmer::after{content:'';position:absolute;top:-50%;left:-75%;width:50%;height:200%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transform:skewX(-20deg);animation:shim 3.5s ease-in-out infinite}
@keyframes shim{0%{left:-75%}100%{left:130%}}

/* ── RIPPLE ── */
.ripple-host{position:relative;overflow:hidden}
.rpl{position:absolute;border-radius:50%;background:rgba(255,255,255,.38);transform:scale(0);animation:rpl .6s linear;pointer-events:none}
@keyframes rpl{to{transform:scale(4.5);opacity:0}}

/* ══════════════════ TOP BAR ══════════════════ */
.kt-topbar{background:#0B1D3A;padding:12px 0;font-size:15px;color:#fff;position:relative;z-index:1000;border-bottom:1px solid rgba(255,255,255,0.05);box-shadow:inset 0 3px 18px rgba(255,255,255,0.18),inset 0 1px 6px rgba(255,255,255,0.3)}
.kt-topbar .container{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:6px}
.tb-social a{color:rgba(255,255,255,.7);margin-right:14px;transition:color .2s,transform .2s;display:inline-block}
.tb-social a:hover{color:var(--gold);transform:translateY(-2px)}
.tb-info{display:flex;gap:24px;flex-wrap:wrap}
.tb-info span{display:flex;align-items:center;gap:6px;color:rgba(255,255,255,.8)}
.tb-info i{color:var(--gold);font-size:12px}
.tb-info a{color:rgba(255,255,255,.8);transition:color .2s}
.tb-info a:hover{color:var(--gold)}
.tb-phone{font-weight:700;color:var(--gold);display:flex;align-items:center;gap:6px}
@media(max-width:767px){.tb-info{display:none}}

/* ══════════════════ NAVBAR ══════════════════ */
.kt-nav{background:rgba(255,255,255,0.98);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 20px 60px rgba(37, 99, 235, 0.12), 0 0 40px rgba(37, 99, 235, 0.06);position:sticky;top:0;z-index:999;border-bottom:3px solid var(--gold);transition:all .4s var(--ease)}
.kt-nav.nav-scrolled{box-shadow:0 20px 50px rgba(37, 99, 235, 0.2), 0 0 40px rgba(37, 99, 235, 0.1);background:rgba(255,255,255,1);height:72px}
.kt-nav.nav-scrolled .container{height:72px}
.kt-nav .container{display:flex;align-items:center;justify-content:space-between;padding:0 15px;height:80px}
.nav-logo{display:flex;align-items:center;gap:18px;text-decoration:none;flex-shrink:0}
.nav-logo img{height:64px;width:64px;object-fit:contain;border-radius:50%;border:2px solid rgba(255,184,0,.25);padding:2px;transition:transform .35s var(--ease),box-shadow .35s}
.nav-logo:hover img{transform:rotate(-5deg) scale(1.08);box-shadow:0 0 0 7px rgba(255,184,0,.18)}
.nav-logo-text{line-height:1.2}
.nl-main{font-size:20px;font-weight:900;color:var(--navy);letter-spacing:.3px;display:block;white-space:nowrap}
.nl-sub{font-size:14px;font-weight:700;color:var(--gold-dark);letter-spacing:.8px;text-transform:uppercase;display:block;white-space:nowrap}
.nl-tag{font-size:12px;color:var(--text);display:block;white-space:nowrap;margin-top:3px}
.nav-menu{display:flex;align-items:center;gap:2px;list-style:none}
.nav-menu>li>a{display:block;padding:12px 18px;font-size:18px;font-weight:600;color:var(--navy);transition:color .2s;white-space:nowrap;position:relative}
.nav-menu>li>a::after{content:'';position:absolute;bottom:-2px;left:18px;right:18px;height:2px;background:var(--gold);border-radius:2px;transform:scaleX(0);transition:transform .28s var(--ease)}
.nav-menu>li>a:hover,.nav-menu>li>a.active{color:var(--gold)}
.nav-menu>li>a:hover::after,.nav-menu>li>a.active::after{transform:scaleX(1)}
.btn-apply-nav{background:var(--gold)!important;color:var(--navy)!important;padding:15px 30px!important;border-radius:30px!important;font-weight:800!important;font-size:16px!important;box-shadow:0 4px 20px rgba(255,184,0,.4)!important;transition:transform .2s,box-shadow .2s!important}
.btn-apply-nav::after{display:none!important}
.btn-apply-nav:hover{transform:translateY(-2px)!important;box-shadow:0 8px 32px rgba(255,184,0,.55)!important;color:var(--navy)!important}
.nav-toggler{display:none;background:none;border:2px solid var(--gold);padding:9px 12px;border-radius:8px;cursor:pointer;flex-shrink:0}
.nav-toggler span{display:block;width:26px;height:2px;background:var(--gold);margin:6px 0;border-radius:2px;transition:all .3s}
.nav-toggler.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggler.open span:nth-child(2){opacity:0}
.nav-toggler.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
@media(max-width:1100px){.nl-tag{display:none}}
@media(max-width:991px){
  .nav-toggler{display:block}
  .nav-collapse{display:none;width:100%;border-top:1px solid #f0f3f8;background:#fff;box-shadow:0 15px 35px rgba(37, 99, 235, 0.1)}
  .nav-collapse.open{display:block;animation:slideDownNav 0.4s var(--ease) both}
  @keyframes slideDownNav{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
  .nav-menu{flex-direction:column;align-items:stretch;padding:8px 0;gap:0}
  .nav-menu>li>a{padding:14px 22px;font-size:17px}
  .nav-menu>li>a::after{display:none}
  .btn-apply-nav{margin:10px 22px 14px!important;display:block!important;text-align:center}
  .kt-nav .container{height:86px;flex-wrap:wrap;align-items:center}
  .nav-logo img{height:70px;width:70px}
  .nl-main{font-size:17px}.nl-sub{font-size:12px}
}

/* ══════════════════ PAGE HERO (inner pages) ══════════════════ */
.page-hero{position:relative;min-height:44vh;display:flex;align-items:center;overflow:hidden}
.ph-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.07);transition:transform 9s ease}
.page-hero.ph-loaded .ph-bg{transform:scale(1)}
.ph-overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(11,29,58,.93) 0%,rgba(11,29,58,.72) 55%,rgba(11,29,58,.42) 100%)}
.ph-content{position:relative;z-index:2;color:#fff;padding:64px 0 56px}
.ph-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,184,0,.16);border:1px solid rgba(255,184,0,.38);color:var(--gold);font-size:11px;font-weight:800;letter-spacing:2px;text-transform:uppercase;padding:6px 16px;border-radius:30px;margin-bottom:16px}
.ph-title{font-size:clamp(30px,5vw,58px);font-weight:900;line-height:1.14;margin-bottom:14px;text-shadow:0 6px 30px rgba(0,0,0,.3)}
.ph-title span{color:var(--gold)}
.ph-title .red{color:#ff6b6b}
.ph-crumb{display:flex;align-items:center;gap:8px;font-size:14px;color:rgba(255,255,255,.65)}
.ph-crumb a{color:rgba(255,255,255,.65);transition:color .2s}
.ph-crumb a:hover{color:var(--gold)}
.ph-crumb i{font-size:10px}
.ph-particles{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.ph-p{position:absolute;border-radius:50%;animation:phFloat linear infinite;opacity:.14}
@keyframes phFloat{0%{transform:translateY(100%);opacity:0}10%{opacity:.14}90%{opacity:.14}100%{transform:translateY(-20%);opacity:0}}

/* ══════════════════ SECTION UTILITIES ══════════════════ */
.sec-badge{display:inline-flex;align-items:center;gap:8px;color:var(--gold-dark);font-size:11.5px;font-weight:800;text-transform:uppercase;letter-spacing:2px;margin-bottom:14px}
.sec-badge::before{content:'';width:22px;height:2px;background:var(--gold);flex-shrink:0;border-radius:2px}
.sec-badge.c{justify-content:center}
.sec-badge.c::before,.sec-badge.c::after{content:'';width:22px;height:2px;background:var(--gold);flex-shrink:0;border-radius:2px}
.section-hd{text-align:center;margin-bottom:52px}
.section-hd .sec-badge{justify-content:center}
.section-hd .sec-badge::before{display:none}
.section-hd .sec-desc{margin:0 auto}
.sec-title{font-size:clamp(26px,3.8vw,44px);font-weight:900;color:var(--navy);line-height:1.2;margin-bottom:16px}
.sec-title span{color:var(--gold)}
.sec-title .red{color:var(--red)}
.sec-desc{font-size:15px;color:var(--text);line-height:1.8;max-width:620px}

/* ══════════════════ BUTTONS ══════════════════ */
.btn-g{background:var(--gold);color:var(--navy);padding:13px 30px;border-radius:34px;font-weight:800;font-size:15px;display:inline-flex;align-items:center;gap:8px;box-shadow:0 6px 24px rgba(255,184,0,.4);transition:transform .25s,box-shadow .25s}
.btn-g:hover{transform:translateY(-3px);box-shadow:0 12px 36px rgba(255,184,0,.55);color:var(--navy)}
.btn-n{background:var(--navy);color:#fff;padding:13px 30px;border-radius:34px;font-weight:700;font-size:15px;display:inline-flex;align-items:center;gap:8px;transition:background .25s,transform .2s}
.btn-n:hover{background:var(--navy2);color:#fff;transform:translateY(-2px)}
.btn-og{border:2px solid var(--gold);color:var(--gold-dark);padding:11px 26px;border-radius:34px;font-weight:700;font-size:15px;display:inline-flex;align-items:center;gap:8px;transition:all .25s}
.btn-og:hover{background:var(--gold);color:var(--navy)}

/* ══════════════════ CARD BASE ══════════════════ */
.kt-card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:28px 24px;height:100%;transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;position:relative;overflow:hidden}
.kt-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-dark));transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.kt-card:hover{transform:translateY(-7px);box-shadow:var(--shadow-lg);border-color:rgba(255,184,0,.28)}
.kt-card:hover::before{transform:scaleX(1)}

/* ══════════════════ MODAL ══════════════════ */
.modal-ov{position:fixed;inset:0;background:rgba(11,29,58,.88);backdrop-filter:blur(7px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:opacity .35s,visibility .35s}
.modal-ov.open{opacity:1;visibility:visible}
.modal-box{background:#fff;border-radius:24px;width:100%;max-width:560px;overflow:hidden;transform:scale(.88) translateY(22px);transition:transform .38s var(--ease);box-shadow:0 32px 80px rgba(0,0,0,.32)}
.modal-ov.open .modal-box{transform:none}
.mhd{background:linear-gradient(135deg,var(--navy),var(--navy3));padding:28px 32px 22px;position:relative}
.mhd h3{color:#fff;font-size:22px;font-weight:800;margin-bottom:4px}
.mhd p{color:rgba(255,255,255,.72);font-size:14px}
.m-close{position:absolute;top:18px;right:20px;background:rgba(255,255,255,.1);border:none;color:#fff;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .2s}
.m-close:hover{background:rgba(255,255,255,.22)}
.mbody{padding:28px 32px 32px}
.fg{margin-bottom:18px}
.fg label{display:block;font-size:13px;font-weight:700;color:var(--navy);margin-bottom:6px}
.fg input,.fg select,.fg textarea{width:100%;border:1.5px solid #dde2ec;border-radius:10px;padding:12px 14px;font-size:14px;color:var(--navy);outline:none;transition:border-color .2s,box-shadow .2s;font-family:inherit;background:#fff}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(255,184,0,.14)}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:480px){.fr{grid-template-columns:1fr}}
.btn-sub{width:100%;background:var(--gold);color:var(--navy);border:none;padding:14px;border-radius:12px;font-size:16px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:background .25s,transform .2s;position:relative;overflow:hidden}
.btn-sub:hover{background:var(--gold-dark);transform:translateY(-2px)}
.fnote{text-align:center;font-size:12px;color:var(--text);margin-top:12px}

/* ══════════════════ STICKY APPLY ══════════════════ */
.sticky-ap{display:none;position:fixed;bottom:22px;right:22px;z-index:5000;background:var(--gold);color:var(--navy);border:none;border-radius:50px;padding:14px 22px;font-size:15px;font-weight:800;cursor:pointer;box-shadow:0 8px 30px rgba(255,184,0,.55);align-items:center;gap:8px;animation:sapls 2.2s ease-in-out infinite}
@keyframes sapls{0%,100%{box-shadow:0 8px 30px rgba(255,184,0,.55)}50%{box-shadow:0 8px 52px rgba(255,184,0,.85)}}
@media(max-width:767px){.sticky-ap{display:flex}}

/* ══════════════════ FOOTER ══════════════════ */
.kt-footer{background:var(--navy);color:rgba(255,255,255,.72);padding:72px 0 30px}
.ft-logo img{height:50px;margin-bottom:16px}
.ft-desc{font-size:14px;line-height:1.75;margin-bottom:20px}
.ft-social a{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:rgba(255,255,255,.07);border-radius:50%;color:#fff;margin-right:8px;transition:background .2s,transform .2s}
.ft-social a:hover{background:var(--gold);color:var(--navy);transform:translateY(-3px)}
.ft-head{color:#fff;font-size:16px;font-weight:700;margin-bottom:18px;padding-bottom:12px;position:relative}
.ft-head::after{content:'';position:absolute;bottom:0;left:0;width:30px;height:2px;background:var(--gold);border-radius:2px}
.ft-links{list-style:none;padding:0}
.ft-links li{margin-bottom:10px}
.ft-links a{font-size:14px;color:rgba(255,255,255,.6);display:inline-flex;align-items:center;gap:8px;transition:color .2s,gap .2s}
.ft-links a:hover{color:var(--gold);gap:12px}
.ft-links a::before{content:'›';color:var(--gold)}
.ft-ci{display:flex;gap:12px;margin-bottom:14px;align-items:flex-start}
.ft-ci i{color:var(--gold);font-size:14px;margin-top:2px;flex-shrink:0}
.ft-ci span,.ft-ci a{font-size:14px;line-height:1.6;color:rgba(255,255,255,.68);transition:color .2s}
.ft-ci a:hover{color:var(--gold)}
.ft-btm{border-top:1px solid rgba(255,255,255,.1);margin-top:40px;padding-top:22px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;font-size:13px;color:rgba(255,255,255,.45)}
.ft-btm a{color:var(--gold)}

/* ══════════════════ SECTION SPACING ══════════════════ */
.sec-pad{padding:88px 0}
.sec-pad-sm{padding:60px 0}
.bg-light{background:var(--light)}
.bg-navy{background:var(--navy)}
.bg-gold{background:var(--gold)}
.bg-white{background:#fff}
