/* HIYC v6 — main.css — v20260420 */
/* ─── TOKENS ─────────────────────────────────────────────── */
:root{
  --t:#C8602A;--td:#A84E20;--tl:#FAE8DF;--tg:rgba(200,96,42,.1);
  --g:#3D5C35;--gl:#4E7544;--gp:#EBF2E8;
  --au:#B8965A;--aul:rgba(184,150,90,.15);
  --w:#FBF0E8;--wm:#F5E4D5;--cr:#FEFCF8;
  --dk:#1C1916;--dm:#2E2A25;
  --tx:#2C2520;--tm:#5C5248;--lt:#8C7E74;
  --bd:rgba(200,96,42,.13);--bk:rgba(30,25,20,.09);
  --fd:'Cormorant Garamond',Georgia,serif;
  --fb:'Jost',system-ui,sans-serif;
  --nh:72px;
  --s1:0 1px 4px rgba(0,0,0,.06),0 2px 14px rgba(0,0,0,.05);
  --s2:0 4px 24px rgba(0,0,0,.09),0 1px 4px rgba(0,0,0,.04);
  --s3:0 10px 48px rgba(0,0,0,.13),0 2px 8px rgba(0,0,0,.06);
  --ea:.22s ease;--pill:999px;
  --r1:6px;--r2:12px;--r3:20px;--r4:28px;
}

/* ─── RESET ──────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--fb);color:var(--tx);background:var(--cr);line-height:1.65;font-weight:300;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--t);text-decoration:none;transition:color var(--ea)}
a:hover{color:var(--td)}
ul{list-style:none}
button,input,select,textarea{font-family:var(--fb)}
h1,h2,h3,h4{font-family:var(--fd);font-weight:500;line-height:1.15;color:var(--t)}
h1{font-size:clamp(2rem,5.5vw,4rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.8rem)}
h3{font-size:clamp(1.1rem,2.5vw,1.65rem)}
h4{font-size:1rem}
p{color:var(--tm);font-weight:300;line-height:1.78}
.wrap{max-width:1200px;margin:0 auto;padding:0 20px}
.sec{padding:72px 0}
main{padding-top:var(--nh)}

/* ─── EYEBROW ────────────────────────────────────────────── */
.eb{font-size:.67rem;letter-spacing:.2em;text-transform:uppercase;color:var(--t);font-weight:600;display:flex;align-items:center;gap:10px;margin-bottom:14px}
.eb::before{content:'';width:22px;height:1.5px;background:currentColor;opacity:.55;display:block;flex-shrink:0}
.eb.sym::after{content:'';width:22px;height:1.5px;background:currentColor;opacity:.55;display:block;flex-shrink:0}
.eb.cen{justify-content:center}
.eb.wh{color:rgba(255,255,255,.6)}.eb.wh::before,.eb.wh.sym::after{background:rgba(255,255,255,.4)}

/* ─── BUTTONS ────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 28px;border-radius:var(--pill);font-size:.875rem;font-weight:500;border:1.5px solid transparent;transition:all var(--ea);white-space:nowrap;cursor:pointer;letter-spacing:.02em;line-height:1;text-align:center}
.btn-p{background:var(--t);color:#fff;border-color:var(--t)}.btn-p:hover{background:var(--td);color:#fff;transform:translateY(-1px);box-shadow:0 5px 16px rgba(200,96,42,.35)}
.btn-g{background:var(--g);color:#fff;border-color:var(--g)}.btn-g:hover{background:var(--gl);color:#fff;transform:translateY(-1px)}
.btn-ow{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}.btn-ow:hover{background:rgba(255,255,255,.12);color:#fff}
.btn-ou{background:transparent;color:var(--t);border-color:var(--t)}.btn-ou:hover{background:var(--t);color:#fff}
.btn-sm{padding:9px 20px;font-size:.8rem}
.btn-xs{padding:6px 14px;font-size:.75rem}

/* ─── NAV ────────────────────────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(254,252,248,.97);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--bk);transition:box-shadow var(--ea)}
.nav.on{box-shadow:var(--s1)}
.nav-in{height:var(--nh);display:flex;align-items:center;max-width:1280px;margin:0 auto;padding:0 20px;gap:8px}
.nav-logo{flex-shrink:0;display:flex;align-items:center}
.nav-logo img{height:46px;width:auto;display:block}
.nav-links{display:flex;align-items:center;justify-content:center;gap:2px;flex:1;padding:0 12px}
.nl{font-size:.74rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--tm);padding:7px 11px;position:relative;transition:color var(--ea);white-space:nowrap}
.nl::after{content:'';position:absolute;bottom:0;left:11px;right:11px;height:2px;background:var(--t);transform:scaleX(0);transition:transform var(--ea);transform-origin:center}
.nl:hover,.nl.act{color:var(--t)}.nl:hover::after,.nl.act::after{transform:scaleX(1)}
/* dropdown */
.has-dd{position:relative}
.dd{position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(6px);background:var(--cr);border-radius:var(--r3);box-shadow:var(--s3);border:1px solid var(--bk);min-width:220px;padding:8px 0;opacity:0;visibility:hidden;transition:all .18s ease;z-index:200}
.has-dd:hover .dd,.has-dd:focus-within .dd{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dd li a{display:block;padding:10px 22px;font-size:.82rem;font-weight:400;color:var(--tm);transition:all var(--ea)}
.dd li a:hover{background:var(--tl);color:var(--t);padding-left:28px}
.dd li:not(:last-child) a{border-bottom:1px solid rgba(0,0,0,.04)}
.nav-arr{font-size:.55rem;opacity:.45;margin-left:3px;transition:transform var(--ea);display:inline-block}
.has-dd:hover .nav-arr{transform:rotate(180deg)}
.nav-cta{margin-left:12px;flex-shrink:0}
.nav-mob-book{display:none}
/* hamburger */
.ham{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;background:none;border:1px solid var(--bk);border-radius:var(--r1);padding:8px;width:40px;height:40px;cursor:pointer;margin-left:auto;flex-shrink:0}
.ham span{display:block;width:18px;height:2px;background:var(--tx);border-radius:2px;transition:all .25s;transform-origin:center}
.ham[aria-expanded=true] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ham[aria-expanded=true] span:nth-child(2){opacity:0;transform:scaleX(0)}
.ham[aria-expanded=true] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ─── HERO ───────────────────────────────────────────────── */
.hero{position:relative;min-height:92vh;min-height:96svh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-slides{position:absolute;inset:0}
.hs{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.4s ease}
.hs.on{opacity:1}
.hero-ov{position:absolute;inset:0;background:linear-gradient(165deg,rgba(20,15,10,.65) 0%,rgba(20,15,10,.35) 60%,rgba(20,15,10,.55) 100%)}
.hero-cnt{position:relative;z-index:1;text-align:center;padding:32px 20px;max-width:860px;margin:0 auto;width:100%}
.hero-badge{display:inline-block;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);color:rgba(255,255,255,.88);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;padding:7px 18px;border-radius:var(--pill);margin-bottom:22px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.hero-cnt h1{color:#fff;font-size:clamp(2.2rem,7vw,5rem);margin-bottom:18px;text-shadow:0 2px 30px rgba(0,0,0,.3);line-height:1.08;font-weight:400}
.hero-cnt h1 em{font-style:italic;color:rgba(255,220,180,.92)}
.hero-sub{color:rgba(255,255,255,.8);font-size:clamp(.9rem,2.5vw,1.08rem);margin:0 auto 32px;max-width:540px;line-height:1.72}
.hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:40px}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);max-width:480px;margin:0 auto;background:rgba(255,255,255,.1);border-radius:var(--r3);overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12)}
.hst{padding:18px 12px;text-align:center}.hst:not(:last-child){border-right:1px solid rgba(255,255,255,.12)}
.hst-n{display:block;font-family:var(--fd);font-size:1.8rem;font-weight:500;color:#fff;line-height:1}
.hst-l{display:block;font-size:.62rem;color:rgba(255,255,255,.58);letter-spacing:.1em;margin-top:4px}
.hero-dots{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:2}
.dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.35);border:none;cursor:pointer;transition:all .25s;padding:0}
.dot.on{background:#fff;width:22px;border-radius:4px}

/* ─── TRUST BAR ──────────────────────────────────────────── */
.trust{background:var(--g);padding:14px 0}
.trust-in{display:flex;align-items:center;justify-content:center;gap:22px;flex-wrap:wrap;padding:0 16px}
.ti{display:flex;align-items:center;gap:8px;font-size:.74rem;color:rgba(255,255,255,.8);font-weight:400}
.tck{width:17px;height:17px;border-radius:50%;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:.58rem;color:#fff;flex-shrink:0}
.tdot{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.22)}

/* ─── PAGE HERO ──────────────────────────────────────────── */
.ph-hero{background:var(--t);background-size:cover;background-position:center center;background-repeat:no-repeat;padding:80px 0 60px;text-align:center;position:relative;overflow:hidden}
.ph-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(160deg,rgba(0,0,0,.55) 0%,rgba(0,0,0,.32) 100%)}
.ph-hero::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:40px;background:var(--cr);clip-path:ellipse(55% 100% at 50% 100%)}
.ph-hero .wrap{position:relative;z-index:1}
.ph-hero h1{color:#fff;margin-bottom:12px;text-shadow:0 2px 12px rgba(0,0,0,.35)}
.ph-hero p{color:rgba(255,255,255,.88);max-width:560px;margin:0 auto;font-size:1rem;text-shadow:0 1px 6px rgba(0,0,0,.3)}
.ph-hero .bc a,.ph-hero .bc,.ph-hero .bc span{color:rgba(255,255,255,.75)!important}
.ph-hero .eb{color:rgba(255,255,255,.85)!important;border-color:rgba(255,255,255,.35)!important}
.ph-g{background:var(--g)}.ph-g::after{background:var(--cr)}
.ph-dk{background:var(--dk)}.ph-dk::after{background:var(--cr)}

/* ─── BREADCRUMB ─────────────────────────────────────────── */
.bc{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--lt);padding:16px 0 6px;flex-wrap:wrap}
.bc a{color:var(--lt)}.bc a:hover{color:var(--t)}.bc-sep{opacity:.4}

/* ─── SECTION HEAD ───────────────────────────────────────── */
.sh{margin-bottom:48px}.sh.c{text-align:center}.sh.c p{margin:0 auto}
.sh h2{margin-bottom:14px}.sh p{max-width:620px;font-size:.95rem}

/* ─── ABOUT SPLIT ────────────────────────────────────────── */
.about-g{display:grid;grid-template-columns:460px 1fr;gap:64px;align-items:start}
.about-img{position:relative}
.about-img img{width:100%;border-radius:var(--r4);box-shadow:var(--s3)}
.about-cap{position:absolute;bottom:-18px;left:24px;right:24px;background:var(--cr);border-radius:var(--r2);padding:14px 18px;box-shadow:var(--s2);border:1px solid var(--bk)}
.about-cap strong{display:block;font-size:.88rem;color:var(--t);font-weight:500}
.about-cap span{font-size:.74rem;color:var(--lt)}
.about-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.atag{font-size:.73rem;padding:4px 14px;border-radius:var(--pill);background:var(--tl);color:var(--t);border:1px solid rgba(200,96,42,.15)}
.about-quote{font-family:var(--fd);font-style:italic;font-size:1.08rem;color:var(--t);border-left:3px solid var(--t);padding-left:18px;margin:20px 0;line-height:1.65}

/* ─── CARDS / GRIDS ──────────────────────────────────────── */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.cc{background:var(--cr);border-radius:var(--r3);overflow:hidden;box-shadow:var(--s1);border:1px solid var(--bk);transition:transform var(--ea),box-shadow var(--ea);display:flex;flex-direction:column}
.cc:hover{transform:translateY(-4px);box-shadow:var(--s2)}
.cc-img{position:relative;height:210px;overflow:hidden}
.cc-img img{width:100%;height:100%;object-fit:cover;object-position:center 20%;transition:transform .5s ease}
.cc:hover .cc-img img{transform:scale(1.05)}
.cc-badge{position:absolute;top:12px;right:12px;font-size:.65rem;font-weight:600;letter-spacing:.07em;padding:4px 11px;border-radius:var(--pill);text-transform:uppercase}
.cb-t{background:var(--t);color:#fff}.cb-g{background:var(--g);color:#fff}.cb-au{background:var(--au);color:#fff}.cb-dk{background:rgba(0,0,0,.7);color:#fff}.cb-wh{background:rgba(255,255,255,.9);color:var(--g)}
.cc-body{padding:20px 22px;flex:1;display:flex;flex-direction:column}
.cc-loc{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--lt);margin-bottom:7px}
.cc-title{font-family:var(--fd);font-size:1.22rem;font-weight:500;color:var(--t);margin-bottom:9px;line-height:1.3}
.cc-title a{color:var(--t)}.cc-title a:hover{color:var(--td)}
.cc-desc{font-size:.83rem;color:var(--tm);line-height:1.68;flex:1;margin-bottom:14px}
.cc-foot{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--bk);flex-wrap:wrap;gap:8px}
.cc-dates{font-size:.78rem;font-weight:500;color:var(--g)}
.cc-price{font-family:var(--fd);font-size:1.1rem;color:var(--t);font-weight:500}

/* ─── COURSE DETAIL PAGE ─────────────────────────────────── */
.course-layout{display:grid;grid-template-columns:1fr 380px;gap:48px;align-items:start;padding:48px 0}
.course-content h2{font-size:1.55rem;margin-bottom:14px;margin-top:34px;font-family:var(--fd);color:var(--t)}
.course-content h2:first-child{margin-top:0}
.course-content h3{font-size:1.15rem;color:var(--g);margin-bottom:10px;margin-top:26px;font-family:var(--fd)}
.course-content p{margin-bottom:13px;font-size:.94rem;line-height:1.82}
.course-content ul{padding-left:0;margin-bottom:16px}
.course-content li{padding:7px 0 7px 22px;position:relative;border-bottom:1px solid var(--bk);font-size:.89rem;color:var(--tm)}
.course-content li:last-child{border-bottom:none}
.course-content li::before{content:'→';position:absolute;left:0;color:var(--t);font-size:.78rem;top:9px}
.course-img-full{width:100%;max-height:480px;object-fit:cover;object-position:center top;border-radius:var(--r3);margin:22px 0;box-shadow:var(--s2)}
.schedule-box{background:var(--w);border-radius:var(--r2);padding:20px 24px;border:1px solid var(--bd);margin-top:22px}
.schedule-box h4{color:var(--t);margin-bottom:12px;font-size:.95rem}
.schedule-row{display:flex;gap:12px;padding:6px 0;border-bottom:1px solid var(--bk);font-size:.84rem}
.schedule-row:last-child{border-bottom:none}
.schedule-time{color:var(--t);font-weight:500;min-width:100px;flex-shrink:0}
.price-box{background:var(--gp);border-radius:var(--r3);padding:24px;border:1px solid rgba(61,92,53,.18);margin:22px 0}
.price-box h4{color:var(--g);margin-bottom:14px}
.price-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid rgba(61,92,53,.12);font-size:.9rem}
.price-row:last-child{border-bottom:none}
.price-lbl{color:var(--tm)}
.price-val{font-family:var(--fd);font-size:1.1rem;color:var(--g);font-weight:500}
.price-note{font-size:.75rem;color:var(--lt);margin-top:3px}

/* ─── BOOKING PANEL ──────────────────────────────────────── */
.book-panel{background:var(--cr);border-radius:var(--r4);border:1px solid var(--bk);box-shadow:var(--s2);overflow:hidden;position:sticky;top:calc(var(--nh) + 18px)}
.bp-head{background:var(--t);padding:24px 26px}
.bp-head h3{color:#fff;font-family:var(--fd);font-size:1.45rem;margin-bottom:6px}
.bp-head p{color:rgba(255,255,255,.75);font-size:.83rem}
.bp-body{padding:22px 24px}
.fg{margin-bottom:14px}
.fl{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.09em;color:var(--tm);margin-bottom:5px}
.fc{width:100%;padding:10px 13px;border:1.5px solid var(--bk);border-radius:var(--r2);font-size:.87rem;color:var(--tx);background:var(--cr);transition:border var(--ea),box-shadow var(--ea);outline:none;font-family:var(--fb);-webkit-appearance:none;appearance:none}
.fc:focus{border-color:var(--t);box-shadow:0 0 0 3px rgba(200,96,42,.1)}
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
textarea.fc{min-height:76px;resize:vertical}
select.fc{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238C7E74' fill='none' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;cursor:pointer}

/* Price toggle (Indian / Foreign) */
.price-toggle{display:flex;background:var(--w);border-radius:var(--pill);padding:3px;margin-bottom:14px;border:1px solid var(--bk);width:100%}
.pt-btn{flex:1;padding:8px 6px;border:none;border-radius:var(--pill);font-size:.78rem;font-weight:500;cursor:pointer;background:transparent;color:var(--tm);transition:all var(--ea);font-family:var(--fb);white-space:nowrap}
.pt-btn.on{background:var(--t);color:#fff;box-shadow:0 2px 8px rgba(200,96,42,.3)}

/* Batch options */
.bo{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border:1.5px solid var(--bk);border-radius:var(--r2);cursor:pointer;transition:all var(--ea);background:var(--cr);margin-bottom:7px;gap:8px}
.bo:hover,.bo.on{border-color:var(--t);background:var(--tl)}
.bo-dates{font-size:.84rem;font-weight:500;color:var(--tx)}
.bo-teacher{font-size:.73rem;color:var(--lt);margin-top:2px}
.bo-spots{font-size:.68rem;padding:2px 8px;border-radius:var(--pill);background:var(--gp);color:var(--g);font-weight:500;white-space:nowrap;flex-shrink:0}
.bo-spots.low{background:var(--tl);color:var(--t)}
.bo-spots.full{background:rgba(192,57,43,.1);color:#b03030}

/* Payment type */
.pay-type{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:14px}
.ptype{padding:11px 8px;border:1.5px solid var(--bk);border-radius:var(--r2);text-align:center;cursor:pointer;transition:all var(--ea);background:var(--cr)}
.ptype:hover,.ptype.on{border-color:var(--t);background:var(--tl)}
.ptype-name{font-size:.8rem;font-weight:500;color:var(--tx)}
.ptype-amt{font-size:.73rem;color:var(--au);margin-top:2px}

/* Booking summary */
.bp-sum{background:var(--w);border-radius:var(--r2);padding:14px 16px;margin-bottom:14px;width:100%}
.bsr{display:flex;justify-content:space-between;font-size:.83rem;padding:4px 0;color:var(--tm)}
.bsr.tot{font-family:var(--fd);font-size:1.02rem;font-weight:500;color:var(--t);border-top:1px solid var(--bd);margin-top:7px;padding-top:9px}
.pay-note{font-size:.69rem;color:var(--lt);text-align:center;margin-top:9px}

/* ─── ROOMS ──────────────────────────────────────────────── */
.rl{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding:56px 0;border-bottom:1.5px solid var(--bk);align-items:start}
.rl:first-of-type{padding-top:0}
.rl:last-of-type{border-bottom:none}
.rl-gal .main-img{border-radius:var(--r4);overflow:hidden;height:360px;cursor:pointer}
.rl-gal .main-img img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .4s}
.rl-gal .main-img:hover img{transform:scale(1.03)}
.rl-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;margin-top:8px}
.rl-thumbs img{aspect-ratio:1;object-fit:cover;border-radius:var(--r1);cursor:pointer;opacity:.68;transition:all .2s;border:2px solid transparent}
.rl-thumbs img:hover{opacity:1}.rl-thumbs img.act{opacity:1;border-color:var(--t)}
.rl-info h2{font-family:var(--fd);font-size:2rem;color:var(--t);margin-bottom:9px}
.rl-cat{display:inline-flex;align-items:center;background:var(--gp);color:var(--g);font-size:.7rem;font-weight:600;padding:4px 14px;border-radius:var(--pill);letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px}
.rl-desc{font-size:.92rem;line-height:1.78;color:var(--tm);margin-bottom:20px}
.rl-det{border-top:1px solid var(--bk);margin-bottom:16px}
.rl-row{display:grid;grid-template-columns:1fr 1fr;gap:0 24px}
.rl-row div{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--bk);font-size:.86rem}
.dl{font-weight:500;color:var(--lt);font-size:.74rem;text-transform:uppercase;letter-spacing:.06em}
.rl-ams{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}
.am{font-size:.72rem;background:var(--gp);color:var(--g);padding:4px 12px;border-radius:var(--pill);font-weight:500}
.rl-pr{display:flex;align-items:center;justify-content:space-between;padding-top:18px;border-top:1.5px solid var(--bk);flex-wrap:wrap;gap:12px}
.price-from{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--lt);margin-bottom:3px}
.price-num{font-family:var(--fd);font-size:1.9rem;color:var(--t);font-weight:500;line-height:1}
.price-sub{font-size:.76rem;color:var(--lt)}

/* ─── SHANTI ASHRAM ──────────────────────────────────────── */
.shanti{background:linear-gradient(145deg,#1e3019 0%,#2d4a26 50%,#3D5C35 100%);border-radius:var(--r4);overflow:hidden;margin-top:64px;border:1px solid rgba(255,255,255,.06)}
.shanti-hd{padding:40px 40px 28px;border-bottom:1px solid rgba(255,255,255,.1)}
.shanti-badge{display:inline-block;background:var(--au);color:#fff;font-size:.66rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:4px 14px;border-radius:var(--pill);margin-bottom:12px}
.shanti-hd h2{color:#fff;font-size:clamp(1.6rem,3vw,2.3rem);margin-bottom:9px}
.shanti-hd p{color:rgba(255,255,255,.68);max-width:560px;font-size:.92rem}
.shanti-bd{padding:32px 40px 40px}
.shanti-cat{font-family:var(--fd);font-size:1.1rem;color:rgba(255,255,255,.85);margin-bottom:16px;display:flex;align-items:center;gap:14px}
.shanti-cat::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.12);display:block}
.shanti-g3{display:grid;grid-template-columns:repeat(3,1fr);gap:13px;margin-bottom:26px}
.shanti-g2{display:grid;grid-template-columns:repeat(2,1fr);gap:11px}
.sr{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:var(--r2);padding:18px 20px;cursor:pointer;transition:all var(--ea);display:flex;flex-direction:column}
.sr:hover{background:rgba(255,255,255,.12);transform:translateY(-2px)}
.sr-name{font-family:var(--fd);font-size:1.08rem;color:#fff;margin-bottom:4px}
.sr-sub{font-size:.75rem;color:rgba(255,255,255,.52);margin-bottom:10px;line-height:1.5}
.sr-price{font-family:var(--fd);font-size:1.45rem;color:var(--au);font-weight:500;line-height:1;margin-bottom:10px}
.sr-price small{font-size:.68rem;color:rgba(255,255,255,.38);font-family:var(--fb);font-weight:300}
.sr-feats{display:flex;flex-wrap:wrap;gap:5px;flex:1;margin-bottom:12px}
.sf{font-size:.67rem;background:rgba(255,255,255,.1);color:rgba(255,255,255,.7);padding:3px 9px;border-radius:var(--pill)}
.sr-btn{width:100%;padding:9px;border-radius:var(--r1);font-size:.78rem;font-weight:500;cursor:pointer;font-family:var(--fb);border:1px solid rgba(255,255,255,.22);background:transparent;color:#fff;transition:all var(--ea)}
.sr-btn:hover{background:var(--t);border-color:var(--t)}
.shanti-note{margin-top:24px;padding:16px 20px;background:rgba(255,255,255,.06);border-radius:var(--r2);display:flex;align-items:flex-start;gap:13px}
.shanti-note p{color:rgba(255,255,255,.55);font-size:.82rem;line-height:1.65}

/* ─── SCHEDULE TABLE ─────────────────────────────────────── */
.sched-wrap{overflow-x:auto;border-radius:var(--r3);box-shadow:var(--s1);border:1px solid var(--bk);-webkit-overflow-scrolling:touch}
.sched{width:100%;border-collapse:collapse;font-size:.85rem;background:var(--cr)}
.sched thead th{background:var(--t);color:#fff;text-align:left;padding:12px 18px;font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600;white-space:nowrap}
.sched tbody td{padding:12px 18px;border-bottom:1px solid var(--bk);vertical-align:middle}
.sched tbody tr:last-child td{border-bottom:none}
.sched tbody tr:hover td{background:var(--w)}
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--pill);font-size:.68rem;font-weight:600}
.b-op{background:var(--gp);color:var(--g)}.b-fi{background:var(--tl);color:var(--t)}.b-fu{background:rgba(192,57,43,.1);color:#b03030}.b-en{background:var(--aul);color:#8a6520}

/* ─── TESTIMONIALS ───────────────────────────────────────── */
.testi-g{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tc{background:rgba(255,255,255,.08);border-radius:var(--r3);padding:26px;border:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column}
.tc-stars{color:#f5a623;font-size:.88rem;letter-spacing:3px;margin-bottom:11px}
.tc-text{font-size:.85rem;color:rgba(255,255,255,.78);line-height:1.75;flex:1;margin-bottom:14px;font-weight:300}
.tc-auth{font-size:.75rem;color:rgba(255,255,255,.42)}
.tc-name{color:rgba(255,255,255,.7);font-weight:500}

/* ─── FAQ ────────────────────────────────────────────────── */
.faq-item{border-bottom:1.5px solid var(--bk)}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:17px 0;cursor:pointer;font-size:.93rem;font-weight:500;color:var(--tx);gap:14px}
.faq-q:hover{color:var(--t)}
.faq-ico{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--bd);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.75rem;color:var(--t);transition:all var(--ea)}
.faq-item.open .faq-ico{background:var(--t);border-color:var(--t);color:#fff;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease}
.faq-item.open .faq-a{max-height:600px;padding-bottom:16px}
.faq-a p{font-size:.89rem;color:var(--tm);line-height:1.82}
.faq-section-title{font-family:var(--fd);font-size:1.3rem;color:var(--g);margin:40px 0 18px;padding-bottom:10px;border-bottom:2px solid var(--gp)}

/* ─── INFO BOXES ─────────────────────────────────────────── */
.iboxes{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:52px}
.ib{background:var(--w);border-radius:var(--r2);padding:24px;border:1px solid var(--bd)}
.ib h4{font-size:.93rem;color:var(--t);margin-bottom:8px}
.ib p{font-size:.85rem}

/* ─── CTA BANNER ─────────────────────────────────────────── */
.cta-ban{background:var(--g);padding:64px 0;text-align:center}
.cta-ban h2{color:#fff;margin-bottom:12px}
.cta-ban p{color:rgba(255,255,255,.76);max-width:500px;margin:0 auto 28px}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ─── FILTER BAR ─────────────────────────────────────────── */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:40px}
.fp{padding:8px 18px;border-radius:var(--pill);font-size:.77rem;font-weight:500;cursor:pointer;border:1.5px solid var(--bk);background:var(--cr);color:var(--tm);transition:all var(--ea);font-family:var(--fb)}
.fp:hover,.fp.on{background:var(--t);color:#fff;border-color:var(--t)}

/* ─── TEACHER CARDS ──────────────────────────────────────── */
.teacher-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.teacher-card{background:var(--cr);border-radius:var(--r3);overflow:hidden;border:1px solid var(--bk);box-shadow:var(--s1);display:flex;flex-direction:column}
.tc-img{height:250px;overflow:hidden}
.tc-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.teacher-card:hover .tc-img img{transform:scale(1.04)}
.tc-body{padding:22px;flex:1}
.tc-name{font-family:var(--fd);font-size:1.35rem;color:var(--t);margin-bottom:5px}
.tc-years{font-size:.75rem;color:var(--lt);margin-bottom:10px;text-transform:uppercase;letter-spacing:.08em}
.tc-desc{font-size:.86rem;color:var(--tm);line-height:1.75}

/* ─── CONFIRMATION ───────────────────────────────────────── */
.conf{max-width:540px;margin:0 auto;padding:52px 20px}
.conf-card{background:var(--cr);border-radius:var(--r4);border:1px solid var(--bk);overflow:hidden;box-shadow:var(--s2)}
.conf-hd{background:var(--g);padding:32px;text-align:center}
.conf-ico{width:52px;height:52px;background:rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:1.4rem}
.conf-hd h2{color:#fff;margin-bottom:5px}
.conf-hd p{color:rgba(255,255,255,.72);font-size:.87rem}
.conf-body{padding:28px}
.conf-ref{background:var(--w);border-radius:var(--r2);padding:14px;text-align:center;margin-bottom:22px}
.conf-ref small{font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--lt);display:block;margin-bottom:5px}
.conf-ref strong{font-family:var(--fd);font-size:1.5rem;color:var(--t);letter-spacing:.06em}
.dr{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--bk);font-size:.86rem}
.dr:last-child{border-bottom:none}
.dr .lbl{color:var(--lt)}.dr .val{font-weight:500}

/* ─── SCROLL ANIMATIONS ──────────────────────────────────── */
.anim{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}
.anim.vis{opacity:1;transform:none}

/* ─── WHATSAPP FLOAT ─────────────────────────────────────── */
.wa{position:fixed;bottom:24px;left:24px;z-index:900;width:50px;height:50px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px rgba(37,211,102,.4);transition:transform var(--ea);flex-shrink:0}
.wa:hover{transform:scale(1.1);color:#fff}
.wa svg{width:24px;height:24px;fill:currentColor}

/* ─── FOOTER ─────────────────────────────────────────────── */
.footer{background:var(--dm);padding:64px 0 0}
.footer-g{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px}
.footer-logo img{height:44px;width:auto;margin-bottom:16px;opacity:.9;filter:brightness(1.1)}
.footer-tag{font-size:.82rem;color:rgba(255,255,255,.42);line-height:1.72;margin-bottom:16px}
.footer-addr{font-size:.82rem;color:rgba(255,255,255,.48);line-height:1.9;font-style:normal}
.footer-addr a{color:rgba(255,255,255,.48)}.footer-addr a:hover{color:rgba(255,255,255,.82)}
.footer-col h4{font-size:.66rem;text-transform:uppercase;letter-spacing:.14em;color:rgba(255,255,255,.28);font-weight:600;margin-bottom:16px}
.footer-col a{display:block;font-size:.82rem;color:rgba(255,255,255,.45);margin-bottom:9px;transition:color var(--ea)}.footer-col a:hover{color:rgba(255,255,255,.88)}
.footer-bot{border-top:1px solid rgba(255,255,255,.07);padding:18px 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.footer-copy{font-size:.76rem;color:rgba(255,255,255,.22)}
.footer-leg a{font-size:.76rem;color:rgba(255,255,255,.22);margin-left:16px}.footer-leg a:hover{color:rgba(255,255,255,.58)}
.socials{display:flex;gap:9px;margin-top:18px}
.soc{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.1);color:rgba(255,255,255,.6);display:flex;align-items:center;justify-content:center;transition:all var(--ea);border:1px solid rgba(255,255,255,.1);flex-shrink:0}
.soc:hover{background:var(--t);color:#fff;border-color:var(--t)}
.soc svg{width:15px;height:15px;fill:currentColor}

/* ─── ADMIN ──────────────────────────────────────────────── */
.adm{display:flex;min-height:100vh;background:#F0EDE7;font-family:var(--fb);font-size:14px}
.sb{width:230px;flex-shrink:0;background:linear-gradient(180deg,#161c12 0%,#1e2719 100%);display:flex;flex-direction:column;height:100vh;position:sticky;top:0;overflow-y:auto}
.sb::-webkit-scrollbar{width:0}
.sb-logo{padding:18px 18px 14px;border-bottom:1px solid rgba(255,255,255,.06)}
.sb-logo-n{font-family:var(--fd);font-size:1rem;color:rgba(255,255,255,.85);font-weight:600;line-height:1.2}
.sb-logo-t{font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.28);margin-top:3px}
.sb-nav{padding:8px 0;flex:1}
.sb-sec{font-size:.6rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.22);padding:14px 18px 5px}
.sbl{display:flex;align-items:center;gap:9px;padding:9px 18px;font-size:.79rem;color:rgba(255,255,255,.48);border-left:2px solid transparent;transition:all .15s;cursor:pointer;text-decoration:none}
.sbl:hover,.sbl.on{color:#fff;background:rgba(255,255,255,.07);border-left-color:var(--g)}
.sbl-ico{width:16px;font-size:13px;text-align:center;flex-shrink:0}
.sb-foot{padding:12px 18px;border-top:1px solid rgba(255,255,255,.06)}
.sb-av{width:28px;height:28px;border-radius:50%;background:var(--g);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0}
.sb-un{font-size:.77rem;font-weight:500;color:rgba(255,255,255,.65);white-space:nowrap}
.sb-ur{font-size:.64rem;color:rgba(255,255,255,.28);text-transform:uppercase;letter-spacing:.08em}
.sb-acts{display:flex;gap:6px;margin-top:7px}
.sb-acts a{font-size:.7rem;color:rgba(255,255,255,.32);padding:3px 9px;border-radius:4px;border:1px solid rgba(255,255,255,.1)}
.sb-acts a:hover{color:rgba(255,255,255,.6)}
.adm-main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{height:52px;background:#fff;border-bottom:1px solid rgba(30,28,24,.09);display:flex;align-items:center;justify-content:space-between;padding:0 22px;position:sticky;top:0;z-index:50}
.tb-title{font-size:.88rem;font-weight:600;color:#1C1916}
.adm-con{padding:22px;overflow-y:auto}
.stats-g{display:grid;grid-template-columns:repeat(4,1fr);gap:11px;margin-bottom:20px}
.sc{background:#fff;border-radius:11px;padding:16px 18px;border:1px solid rgba(30,28,24,.09);box-shadow:0 1px 3px rgba(0,0,0,.06)}
.sc-ico{width:34px;height:34px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:15px;margin-bottom:10px}
.sc-lbl{font-size:.64rem;font-weight:600;text-transform:uppercase;letter-spacing:.09em;color:#A09890;margin-bottom:3px}
.sc-val{font-size:1.6rem;font-weight:600;color:#1C1916;line-height:1}
.sc-sub{font-size:.7rem;color:var(--g);margin-top:4px;font-weight:500}
.panel{background:#fff;border-radius:11px;border:1px solid rgba(30,28,24,.09);margin-bottom:14px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.ph2{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-bottom:1px solid rgba(30,28,24,.09);flex-wrap:wrap;gap:8px}
.pt2{font-size:.81rem;font-weight:600;color:#1C1916}
.dt{width:100%;border-collapse:collapse;font-size:.78rem}
.dt thead th{text-align:left;padding:9px 15px;font-size:.63rem;text-transform:uppercase;letter-spacing:.08em;color:#A09890;border-bottom:1px solid rgba(30,28,24,.09);background:#F8F5F0;font-weight:600;white-space:nowrap}
.dt tbody td{padding:10px 15px;border-bottom:1px solid rgba(30,28,24,.06);color:#1C1916;vertical-align:middle}
.dt tbody tr:last-child td{border-bottom:none}
.dt tbody tr:hover td{background:#F8F5F0}
.bg2{display:inline-flex;align-items:center;padding:2px 9px;border-radius:20px;font-size:.66rem;font-weight:600}
.bgg{background:rgba(61,92,53,.1);color:#2d5c28}.bgau{background:rgba(184,150,90,.12);color:#7a5f20}.bgr{background:rgba(192,57,43,.1);color:#c0392b}.bggr{background:rgba(0,0,0,.06);color:#6B6456}.bgb{background:rgba(37,99,235,.1);color:#2563eb}
.ab{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:6px;font-size:.74rem;font-weight:500;border:1px solid transparent;cursor:pointer;transition:all .15s;white-space:nowrap;text-decoration:none;font-family:var(--fb)}
.ab-p{background:var(--g);color:#fff;border-color:var(--g)}.ab-p:hover{background:var(--gl);color:#fff}
.ab-t{background:var(--t);color:#fff;border-color:var(--t)}.ab-t:hover{background:var(--td);color:#fff}
.ab-o{background:transparent;color:var(--g);border-color:rgba(30,28,24,.18)}.ab-o:hover{border-color:var(--g)}
.ab-d{background:transparent;color:#c0392b;border-color:rgba(192,57,43,.2)}.ab-d:hover{background:rgba(192,57,43,.06)}
.fsec{background:#fff;border-radius:11px;border:1px solid rgba(30,28,24,.09);padding:20px;margin-bottom:14px;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.fs-t{font-size:.71rem;font-weight:600;text-transform:uppercase;letter-spacing:.09em;color:#A09890;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid rgba(30,28,24,.09)}
.afc{width:100%;padding:8px 11px;border:1px solid rgba(30,28,24,.18);border-radius:6px;font-size:.79rem;color:#1C1916;background:#fff;transition:border .15s;outline:none;-webkit-appearance:none;appearance:none;font-family:var(--fb)}
.afc:focus{border-color:var(--g);box-shadow:0 0 0 3px rgba(61,92,53,.1)}
.afl{display:block;font-size:.67rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#6B6456;margin-bottom:5px}
.afg{margin-bottom:13px}
.afr2{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.afr3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:11px}
textarea.afc{min-height:80px;resize:vertical}
select.afc{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23999' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px;cursor:pointer}
.two-ca{display:grid;grid-template-columns:1fr 380px;gap:18px;align-items:start}
.tab-bar{display:flex;gap:2px;background:#F0EDE7;padding:3px;border-radius:7px;margin-bottom:18px;width:fit-content;flex-wrap:wrap}
.tab{padding:6px 14px;font-size:.74rem;font-weight:500;border-radius:5px;cursor:pointer;border:none;background:transparent;color:#6B6456;transition:all .15s;font-family:var(--fb)}
.tab.on{background:#fff;color:#1C1916;box-shadow:0 1px 3px rgba(0,0,0,.08);font-weight:600}
.fbw{display:flex;align-items:center;gap:7px}
.fb{background:#E5E0D8;border-radius:4px;height:6px;width:60px;overflow:hidden;flex-shrink:0}
.fbi{height:100%;border-radius:4px;background:var(--g)}
.fbi.warn{background:var(--t)}
.adm-ph{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:14px;flex-wrap:wrap}
.adm-ph h1{font-size:1.2rem;font-weight:600;color:#1C1916;font-family:var(--fd);margin-bottom:2px}
.adm-ph p{font-size:.74rem;color:#A09890}
.avail-ok{color:var(--g);font-weight:500;font-size:.79rem}
.avail-no{color:#c0392b;font-weight:500;font-size:.79rem}
.notice-bar{background:linear-gradient(135deg,var(--g),#2d5c28);color:#fff;padding:10px 18px;font-size:.82rem;border-radius:8px;margin-bottom:16px}
.badge-pill{display:inline-flex;padding:3px 10px;border-radius:20px;font-size:.67rem;font-weight:600}

/* ═══════════════════════════════════════════════════════════ */
/* ─── RESPONSIVE — 1100px ─────────────────────────────────── */

/* ════════════════════════════════════════════════════════════
   RESPONSIVE — Complete mobile-first breakpoints
   ════════════════════════════════════════════════════════════ */

/* ── 1100px — tablet landscape ───────────────────────────── */
@media(max-width:1100px){
  .grid3{grid-template-columns:1fr 1fr}
  .about-g{grid-template-columns:320px 1fr;gap:40px}
  .footer-g{grid-template-columns:1fr 1fr;gap:28px}
  .shanti-g3{grid-template-columns:1fr 1fr}
  .course-layout{grid-template-columns:1fr;gap:36px}
  .book-panel{position:static}
  .testi-g{grid-template-columns:1fr 1fr}
}

/* ── 960px — tablet portrait ─────────────────────────────── */
@media(max-width:960px){
  .rl{grid-template-columns:1fr;gap:28px;padding:44px 0}
  .rl-gal .main-img{height:300px}
  .rl-row{grid-template-columns:1fr}
  .teacher-cards{grid-template-columns:1fr}
  .two-ca{grid-template-columns:1fr}
  .about-g{grid-template-columns:1fr;gap:24px}
  .about-cap{position:static;margin-top:12px;box-shadow:none}
  .stats-g{grid-template-columns:1fr 1fr}
}

/* ── 768px — MOBILE ───────────────────────────────────────── */
@media(max-width:768px){
  :root{--nh:60px}

  /* ── NAV ── */
  .ham{display:flex}
  .nav-cta{display:inline-flex;margin-left:auto;margin-right:12px;padding:9px 18px;font-size:.8rem}
  .nav-mob-book{display:flex;justify-content:center;margin:16px 18px 6px;padding:14px;border-radius:var(--pill);font-size:.95rem}
  .nav-in{padding:0 16px}

  /* Nav links slide-down panel */
  .nav-links{
    /* Keep in DOM but hidden — transition in/out */
    display:flex;
    flex-direction:column;
    align-items:stretch;
    position:fixed;
    top:var(--nh);
    left:0;right:0;
    background:var(--cr);
    border-top:1px solid var(--bk);
    padding:4px 0 28px;
    max-height:calc(100vh - var(--nh));
    overflow-y:auto;
    overflow-x:visible;
    -webkit-overflow-scrolling:touch;
    /* Hidden state */
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transform:translateY(-6px);
    transition:opacity .22s ease, visibility .22s ease, transform .22s ease;
    z-index:999;
    box-shadow:0 12px 40px rgba(0,0,0,.14)
  }
  .nav-links.open{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:translateY(0)
  }

  /* Each nav link */
  .nl{
    padding:14px 22px;
    font-size:.9rem;
    letter-spacing:.03em;
    border-bottom:1px solid rgba(0,0,0,.05);
    color:var(--tx);
    display:block
  }
  .nl::after{display:none}
  .nl:hover,.nl.act{color:var(--t)}

  /* Courses dropdown trigger row */
  .has-dd > .nl{
    display:flex;
    align-items:center;
    justify-content:space-between;
    cursor:pointer
  }
  .has-dd > .nl .nav-arr{
    display:inline-block;
    font-size:.7rem;
    opacity:.55;
    transition:transform .25s ease;
    margin-left:auto
  }
  .has-dd.open > .nl .nav-arr{transform:rotate(180deg)}

  /* Dropdown panel */
  .has-dd .dd{
    position:static;
    opacity:1;
    visibility:visible;
    transform:none;
    box-shadow:none;
    border:none;
    border-radius:0;
    background:var(--w);
    min-width:unset;
    padding:0;
    max-height:0;
    overflow:hidden;
    transition:max-height .3s ease
  }
  .has-dd.open .dd{max-height:340px}
  .dd li{border-bottom:none}
  .dd li a{
    padding:11px 22px 11px 38px;
    font-size:.86rem;
    color:var(--tm);
    display:block
  }
  .dd li a:hover{padding-left:44px;background:var(--tl);color:var(--t)}

  /* ── LAYOUT GRIDS ── */
  .grid3{grid-template-columns:1fr}
  .grid2{grid-template-columns:1fr}
  .testi-g{grid-template-columns:1fr}
  .iboxes{grid-template-columns:1fr}
  .shanti-g3,.shanti-g2{grid-template-columns:1fr}
  .teacher-cards{grid-template-columns:1fr}
  .course-layout{grid-template-columns:1fr;gap:24px;padding:24px 0}
  .book-panel{position:static}

  /* ── SECTIONS ── */
  .sec{padding:44px 0}
  .sh{margin-bottom:28px}
  .wrap{padding:0 16px}

  /* ── HERO ── */
  .hero{min-height:96svh;min-height:96vh}/* svh fallback */
  .hero-cnt{padding:20px 16px}
  .hero-cnt h1{font-size:clamp(2rem,8vw,3.2rem)}
  .hero-sub{font-size:.92rem}
  .hero-stats{max-width:100%;grid-template-columns:repeat(3,1fr)}
  .hst-n{font-size:1.4rem}
  .hero-btns{flex-direction:column;align-items:center;gap:10px;margin-bottom:32px}
  .hero-btns .btn{width:100%;max-width:300px;justify-content:center}
  .hero-badge{font-size:.64rem;padding:6px 16px}

  /* ── PAGE HERO ── */
  .ph-hero{padding:52px 0 40px}
  .ph-hero h1{font-size:clamp(1.8rem,7vw,2.8rem)}
  .ph-hero p{font-size:.9rem}

  /* ── ABOUT ── */
  .about-g{grid-template-columns:1fr;gap:24px}
  .about-img img{border-radius:var(--r3);max-height:280px;width:100%;object-fit:cover}
  .about-cap{position:static;margin-top:10px;box-shadow:none;border-radius:var(--r2)}
  .about-quote{font-size:.98rem;padding-left:16px}

  /* ── COURSE CARDS ── */
  .cc-img{height:200px}
  .cc-body{padding:18px 18px}
  .cc-title{font-size:1.1rem}
  .cc-foot{flex-wrap:wrap;gap:10px}

  /* ── BOOKING PANEL ── */
  .bp-head{padding:20px 18px}
  .bp-body{padding:18px 16px}
  .price-toggle{font-size:.82rem}
  .pt-btn{font-size:.78rem;padding:9px}
  .pay-type{grid-template-columns:1fr 1fr;gap:8px}
  .ptype{padding:11px 8px}
  .ptype-name{font-size:.78rem}
  .ptype-amt{font-size:.72rem}
  .bo{padding:10px 12px}
  .bo-dates{font-size:.84rem}
  .bo-teacher{font-size:.72rem}
  .fr2{grid-template-columns:1fr 1fr;gap:10px}

  /* ── ROOMS ── */
  .rl{grid-template-columns:1fr;gap:20px;padding:32px 0}
  .rl-gal .main-img{height:220px}
  .rl-row{grid-template-columns:1fr 1fr}
  .rl-ams{gap:5px}
  .am{font-size:.7rem}
  .rl-pr{flex-direction:column;gap:14px;align-items:flex-start}
  .rl-pr .btn{width:100%;justify-content:center}

  /* ── SHANTI ASHRAM ── */
  .shanti{border-radius:var(--r3)}
  .shanti-hd{padding:22px 20px}
  .shanti-bd{padding:20px 20px 28px}
  .shanti-g3,.shanti-g2{grid-template-columns:1fr}

  /* ── TESTIMONIALS ── */
  .testi-g{grid-template-columns:1fr}
  .tc{padding:22px 20px}

  /* ── TRUST BAR ── */
  .trust-in{gap:16px;padding:0 8px}
  .ti{font-size:.72rem}
  .tdot{display:none}

  /* ── FOOTER ── */
  .footer-g{grid-template-columns:1fr;gap:24px}
  .footer{padding-top:40px}
  .footer-bot{flex-direction:column;gap:8px;align-items:center;text-align:center}
  .footer-leg a{margin-left:10px}

  /* ── WA FLOAT ── */
  .wa{bottom:20px;left:16px;width:48px;height:48px}

  /* ── CTA BANNER ── */
  .cta-ban{padding:52px 0}
  .cta-ban h2{font-size:1.8rem}
  .cta-btns{flex-direction:column;align-items:center}
  .cta-btns .btn{width:100%;max-width:300px;justify-content:center}

  /* ── BLOG ── */
  .blog-hero{height:240px!important}
  .rel-grid{grid-template-columns:1fr!important}

  /* ── FAQ ── */
  .faq-q{font-size:.9rem}

  /* ── FILTER BAR ── */
  .filter-bar{gap:6px}
  .fp{padding:7px 14px;font-size:.74rem}

  /* ── PRICE BOX ── */
  .price-box{padding:18px 16px}
  .price-row{flex-wrap:wrap;gap:6px}

  /* ── SCHEDULE BOX ── */
  .schedule-box{padding:16px 14px}
  .schedule-row{flex-wrap:wrap;gap:4px}
  .schedule-time{min-width:unset}

  /* ── ADMIN ── */
  .stats-g{grid-template-columns:1fr 1fr}
  .sb{display:none}
  .sb.mob-open{display:flex;position:fixed;left:0;top:0;height:100vh;z-index:200;box-shadow:4px 0 24px rgba(0,0,0,.3)}
  .mob-ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:199}
  .smb{display:flex!important}
  .two-ca{grid-template-columns:1fr}
  .afr3{grid-template-columns:1fr 1fr}
  .adm-ph{flex-direction:column;gap:10px}
  .adm-ph h1{font-size:1rem}

  /* ── HERO — mobile ── */
  .hero{min-height:88vh}
  .hero-cnt h1{font-size:2.2rem;line-height:1.12}
  .hero-sub{font-size:.92rem}
  .hero-btns{gap:10px}
  .hero-btns .btn{padding:12px 22px;font-size:.84rem}
  .hero-badge{font-size:.62rem;padding:5px 14px}

  /* ── PAGE HERO — mobile ── */
  .ph-hero{padding:60px 0 44px}
  .ph-hero h1{font-size:1.8rem}
  .ph-hero::after{height:30px}

  /* ── SECTION PADDING ── */
  .sec{padding:52px 0}
  .wrap{padding:0 18px}

  /* ── ABOUT SPLIT — stack on mobile ── */
  .about-g{grid-template-columns:1fr;gap:32px}
  .about-img .about-cap{left:12px;right:12px;bottom:-14px}
  .about-quote{font-size:.98rem;padding:14px 16px}

  /* ── COURSE LAYOUT — stack booking panel below content ── */
  .course-layout{display:flex;flex-direction:column;gap:32px;padding:36px 0}
  .book-panel{position:static;width:100%;box-sizing:border-box}

  /* ── SHANTI ASHRAM BLOCK ── */
  .shanti-hd h2{font-size:1.5rem}
  .shanti-g3,.shanti-g2{grid-template-columns:1fr}

  /* ── HERO STATS ── */
  .hero-stats{max-width:320px;grid-template-columns:repeat(3,1fr)}
  .hst-n{font-size:1.5rem}

  /* ── TRUST BAR ── */
  .trust{padding:12px 0}
  .trust-in{flex-wrap:wrap;gap:10px}
  .ti{font-size:.7rem}
  .tdot{display:none}

  /* ── CARDS ── */
  .cc-title{font-size:1.05rem}
  .cc-desc{font-size:.82rem}
  .cc-foot{gap:8px;flex-wrap:wrap}

  /* ── PRICE BOX ── */
  .price-box{padding:16px 14px}
  .price-val{font-size:1rem}
  .price-row{flex-wrap:wrap;gap:4px;align-items:flex-start}

  /* ── BOOKING PANEL ── */
  .bp-head{padding:20px 18px}
  .bp-head h3{font-size:1.3rem}
  .bp-body{padding:16px 14px}
  .pay-type{gap:8px}
  .ptype{padding:10px 8px}
  .ptype-name{font-size:.78rem}
  .ptype-amt{font-size:.72rem}
  .bo{padding:10px 12px}
  .bo-dates{font-size:.82rem}
  .bo-teacher{font-size:.7rem}
  .bp-sum{padding:13px 14px}
  .bsr{font-size:.82rem}

  /* ── ROOM LISTING ── */
  .rl{grid-template-columns:1fr;gap:24px;padding:28px 0}
  .rl-gal .main-img{height:220px}
  .rl-info h2{font-size:1.6rem}
  .rl-pr{flex-direction:column;gap:12px;align-items:flex-start}
  .rl-pr .btn{width:100%;justify-content:center}

  /* ── TESTIMONIALS ── */
  .testi-g{grid-template-columns:1fr}
  .tc{padding:20px 18px}
  .tc-text{font-size:.84rem}

  /* ── CTA BANNER ── */
  .cta-ban{padding:48px 0}
  .cta-ban h2{font-size:1.7rem}
  .cta-btns{flex-direction:column;align-items:center;gap:10px}
  .cta-btns .btn{width:100%;max-width:280px;justify-content:center}

  /* ── FOOTER ── */
  .footer-g{grid-template-columns:1fr;gap:20px}
  .footer{padding:36px 0 0}
  .footer-bot{flex-direction:column;gap:8px;text-align:center}
  .footer-leg{display:flex;flex-wrap:wrap;justify-content:center;gap:6px}
  .footer-leg a{margin-left:0}

  /* ── BLOG ── */
  .blog-hero{height:220px!important}
  .rel-grid{grid-template-columns:1fr!important}

  /* ── BOOKINGS PAGE ── */
  #cardsView .grid3{grid-template-columns:1fr}

  /* ── CONFIRM PAGE ── */
  .conf{padding:36px 0}
  .conf-card{border-radius:var(--r3)}
  .conf-hd{padding:28px 22px}
  .conf-body{padding:22px 18px}

  /* ── ABOUT PAGE ── */
  .teacher-cards{grid-template-columns:1fr}
  .tc-img{height:220px}

  /* ── FAQ ── */
  .faq-q{font-size:.88rem;gap:10px}
  .faq-section-title{font-size:1.15rem}

  /* ── FILTER BAR ── */
  .filter-bar{gap:6px;flex-wrap:wrap}
  .fp{padding:7px 12px;font-size:.73rem}

  /* ── WA FLOAT ── */
  .wa{bottom:18px;left:14px;width:46px;height:46px}

}

/* ── 480px — small phones ─────────────────────────────────── */
@media(max-width:480px){
  :root{--nh:56px}
  .hero-stats{display:none}
  .hero-cnt h1{font-size:1.85rem}
  .fr2,.afr2,.afr3{grid-template-columns:1fr}
  .cc-img{height:175px}
  .bp-body{padding:12px 12px}
  .pay-type{grid-template-columns:1fr 1fr}
  .ptype{padding:9px 6px}
  .ptype-name{font-size:.72rem}
  .ptype-amt{font-size:.66rem}
  .price-toggle{gap:4px}
  .pt-btn{font-size:.76rem;padding:8px 6px}
  .shanti-hd,.shanti-bd{padding:16px 14px}
  .shanti-badge{font-size:.62rem}
  .stats-g{grid-template-columns:1fr 1fr}
  .adm-con{padding:12px}
  .ph2{padding:9px 12px;flex-wrap:wrap;gap:8px}
  .dt thead th,.dt tbody td{padding:7px 8px;font-size:.7rem}
  .tab-bar{gap:2px}
  .tab{padding:5px 10px;font-size:.68rem}
  .rl-thumbs{grid-template-columns:repeat(4,1fr)}
  .bc{font-size:.7rem}
  .conf{padding:28px 0}
  .nl{padding:12px 16px;font-size:.84rem}
  .dd li a{padding:10px 14px 10px 28px}
  .hero-btns{flex-direction:column;align-items:center}
  .hero-btns .btn{width:100%;max-width:260px;justify-content:center}
  .section-head h2{font-size:1.5rem}
}
  .hero-stats{display:none}
  .fr2,.afr2,.afr3{grid-template-columns:1fr}
  .hero-btns .btn{font-size:.82rem;padding:11px 20px}
  .cc-img{height:175px}
  .bp-body{padding:14px 13px}
  .pay-type{grid-template-columns:1fr 1fr}
  .ptype-name{font-size:.74rem}
  .ptype-amt{font-size:.68rem}
  .shanti-hd,.shanti-bd{padding:16px 14px}
  .shanti-badge{font-size:.62rem}
  .stats-g{grid-template-columns:1fr 1fr}
  .adm-con{padding:12px}
  .ph2{padding:9px 12px;flex-wrap:wrap;gap:8px}
  .dt thead th,.dt tbody td{padding:7px 8px;font-size:.72rem}
  .tab-bar{gap:2px}
  .tab{padding:5px 10px;font-size:.7rem}
  .rl-thumbs{grid-template-columns:repeat(4,1fr)}
  .iboxes{grid-template-columns:1fr}
  .bc{font-size:.72rem}
  .price-val{font-size:1rem}
  .conf{padding:40px 12px}
  .conf-body{padding:22px 18px}
  .nl{padding:12px 16px;font-size:.86rem}
  .dd li a{padding:10px 16px 10px 30px}
}


/* ═══════════════════════════════════════════════════════════
   MOBILE RESPONSIVE — v20260424
   Covers all pages from screenshots:
   room-booking, course pages, bookings, contact, accommodations
   ═══════════════════════════════════════════════════════════ */

/* ── Shared: ensure nothing overflows horizontally ── */
*, *::before, *::after { box-sizing: border-box; }
img { max-width: 100%; }

@media (max-width: 768px) {

  /* ── Base ── */
  html, body { overflow-x: hidden; }
  .wrap { padding: 0 16px; width: 100%; }

  /* ── Room booking page layout ── */
  .rb-layout {
    display: flex !important;
    flex-direction: column !important;
    gap: 24px !important;
  }
  .rb-layout > div:first-child { width: 100%; }

  /* ── All 2-col grids that need to stack ── */
  [style*="grid-template-columns:1fr 420px"],
  [style*="grid-template-columns:1fr 380px"],
  [style*="grid-template-columns:1fr 360px"],
  [style*="grid-template-columns:1.8fr 1fr 1fr 1fr"],
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns:2fr 1fr"] {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }

  /* ── book-panel: full width, no sticky ── */
  .book-panel {
    position: static !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    top: auto !important;
  }
  .bp-head {
    padding: 18px 16px !important;
  }
  .bp-head h3 { font-size: 1.15rem !important; }
  .bp-body { padding: 16px 14px !important; }

  /* ── Check-in / Check-out: stack vertically on small screens ── */
  .fr2 { grid-template-columns: 1fr !important; gap: 0 !important; }

  /* ── Booking summary: ensure text doesn't overflow ── */
  .bp-sum {
    width: 100% !important;
    padding: 12px 12px !important;
    overflow: hidden !important;
  }
  .bsr {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    width: 100% !important;
    font-size: .82rem !important;
    gap: 8px !important;
    padding: 5px 0 !important;
    flex-wrap: nowrap !important;
  }
  .bsr span:last-child {
    text-align: right !important;
    flex-shrink: 0 !important;
  }

  /* ── Price toggle ── */
  .price-toggle {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    width: 100% !important;
  }
  .pt-btn {
    width: 100% !important;
    text-align: center !important;
    font-size: .8rem !important;
    padding: 10px 6px !important;
  }

  /* ── Payment type (deposit/full) ── */
  .pay-type {
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    width: 100% !important;
  }
  .ptype {
    padding: 10px 8px !important;
    width: 100% !important;
  }
  .ptype-name { font-size: .76rem !important; }
  .ptype-amt  { font-size: .7rem  !important; }

  /* ── Form fields: full width ── */
  .fc {
    width: 100% !important;
    box-sizing: border-box !important;
    font-size: .9rem !important;
  }
  .fg { margin-bottom: 14px !important; }

  /* ── Batch option selector ── */
  .bo {
    padding: 10px 12px !important;
    gap: 8px !important;
  }
  .bo-dates { font-size: .82rem !important; }
  .bo-teacher { font-size: .72rem !important; }
  .bo-spots { font-size: .7rem !important; white-space: nowrap !important; }

  /* ── Course cards ── */
  .cc-body { padding: 16px 14px !important; }
  .cc-foot {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    align-items: center !important;
  }
  .cc-foot .btn {
    margin-left: auto !important;
    padding: 9px 16px !important;
    font-size: .8rem !important;
  }

  /* ── Room listing ── */
  .rl { padding: 20px 0 !important; }
  .rl-gal .main-img { height: 200px !important; }
  .rl-pr {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 12px !important;
  }
  .rl-pr .btn { width: 100% !important; justify-content: center !important; }

  /* ── What's included amenity tags ── */
  .am { font-size: .72rem !important; padding: 4px 10px !important; }

  /* ── Bookings page ── */
  .sched-card { padding: 14px 14px !important; }
  .sched-card-prices {
    grid-template-columns: 1fr 1fr !important;
    gap: 6px !important;
    padding: 8px 10px !important;
  }
  .sched-card-prices strong { font-size: .92rem !important; }

  /* ── Contact page: 2-col → 1-col ── */
  .sec > .wrap > div[style*="grid-template-columns:1fr 380px"],
  .sec > .wrap > div[style*="grid-template-columns:1fr 420px"] {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  /* ── Info boxes / bottom grid ── */
  div[style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }

  /* ── Page hero ── */
  .ph-hero { padding: 48px 0 36px !important; }
  .ph-hero h1 { font-size: clamp(1.5rem, 6vw, 2rem) !important; line-height: 1.2 !important; }

  /* ── Section heading ── */
  .sh h2,
  .section-head h2 { font-size: 1.5rem !important; }

  /* ── Trust bar ── */
  .trust-in { flex-wrap: wrap !important; gap: 8px !important; justify-content: center !important; }
  .tdot { display: none !important; }

  /* ── CTA banner ── */
  .cta-ban h2 { font-size: 1.6rem !important; }
  .cta-btns {
    flex-direction: column !important;
    align-items: center !important;
    gap: 10px !important;
  }
  .cta-btns .btn { width: 100% !important; max-width: 280px !important; justify-content: center !important; }

  /* ── Testimonials ── */
  .tc { padding: 20px 16px !important; }
  .tc-text { font-size: .88rem !important; line-height: 1.7 !important; }

  /* ── Footer ── */
  .footer-g { grid-template-columns: 1fr !important; gap: 20px !important; }
  .footer-bot {
    flex-direction: column !important;
    gap: 8px !important;
    text-align: center !important;
    align-items: center !important;
  }

  /* ── Blog articles ── */
  .blog-hero { height: 220px !important; }
  .rel-grid { grid-template-columns: 1fr !important; }

  /* ── Schedule table view ── */
  .desk-sched { display: none !important; }
  .mob-sched  { display: block !important; }

  /* ── Room booking info cards (left col) ── */
  div[style*="background:var(--w)"][style*="border-radius:var(--r3)"],
  div[style*="background:var(--gp)"][style*="border-radius:var(--r3)"],
  div[style*="background:var(--tl)"][style*="border-radius:var(--r3)"] {
    padding: 18px 16px !important;
  }

  /* ── Price box on course pages ── */
  .price-box { padding: 16px 14px !important; }
  .price-row {
    flex-direction: column !important;
    gap: 4px !important;
    padding: 12px 0 !important;
  }
  .price-lbl { font-size: .82rem !important; }
  .price-val { font-size: 1.1rem !important; }

  /* ── Shanti Ashram block ── */
  .shanti-hd { padding: 18px 16px !important; }
  .shanti-bd  { padding: 16px 16px 24px !important; }
  .shanti-badge { font-size: .62rem !important; }

  /* ── About page teacher section ── */
  .about-g { grid-template-columns: 1fr !important; gap: 24px !important; }
  .about-img img {
    max-height: 260px !important;
    width: 100% !important;
    object-fit: cover !important;
    border-radius: var(--r3) !important;
  }

  /* ── FAQ ── */
  .faq-q { font-size: .88rem !important; padding: 14px 16px !important; }
  .faq-a { padding: 0 16px !important; }
  .faq-item.open .faq-a { padding-bottom: 14px !important; }

  /* ── Confirmation page ── */
  .conf { padding: 28px 0 !important; }
  .conf-card { border-radius: 16px !important; margin: 0 4px !important; }
  .conf-hd { padding: 24px 18px !important; }
  .conf-body { padding: 20px 16px !important; }
  .dr { flex-wrap: wrap !important; gap: 4px !important; }

  /* ── Admin ── */
  .adm-con { padding: 12px !important; }
  .stats-g { grid-template-columns: 1fr 1fr !important; }
  .dt thead th, .dt tbody td { padding: 8px !important; font-size: .74rem !important; }
}

/* ── Extra small: 400px and below ── */
@media (max-width: 400px) {
  .wrap { padding: 0 12px !important; }
  .hero-cnt h1 { font-size: 1.75rem !important; }
  .ph-hero h1  { font-size: 1.4rem !important; }
  .fr2 { grid-template-columns: 1fr !important; }
  .pay-type { grid-template-columns: 1fr 1fr !important; }
  .bp-body { padding: 12px 10px !important; }
  .cc-img  { height: 170px !important; }
  .pt-btn  { font-size: .74rem !important; padding: 9px 4px !important; }
  .hero-btns .btn { max-width: 100% !important; }
  .nav-cta { display:inline-flex !important; margin-right:10px; padding:8px 14px; font-size:.76rem; }
  .bc { font-size: .7rem !important; }
  .bsr { font-size: .78rem !important; }
  .btn { padding: 10px 16px !important; font-size: .82rem !important; }
  .sched-card-prices strong { font-size: .86rem !important; }
}

/* ── Missing responsive grid overrides ── */
@media(max-width:768px){
  .about-g{grid-template-columns:1fr;gap:32px}
  .course-layout{grid-template-columns:1fr;gap:32px}
  .shanti-g3{grid-template-columns:repeat(2,1fr);gap:10px}
  .testi-g{grid-template-columns:1fr;gap:14px}
  .iboxes{grid-template-columns:1fr;gap:14px}
  .teacher-cards{grid-template-columns:1fr;gap:18px}
}
@media(max-width:480px){
  .shanti-g3{grid-template-columns:1fr}
  .shanti-g2{grid-template-columns:1fr}
  .fr2{grid-template-columns:1fr}
  .pay-type{grid-template-columns:1fr}
  .rl-thumbs{grid-template-columns:repeat(4,1fr)}
  .hero-stats{grid-template-columns:1fr;max-width:200px}
  .about-g{gap:24px}
  .grid2{grid-template-columns:1fr}
}
