/* ── ROOT LAYOUT (was inline in index) ── */
:root{--g:#1a7a3c;--gl:#2aab55;--gold:#f0b429;--pw:#f5f5f0;--sky:#0e1a2b;--sky3:#080f1a;--beg:#4ade80;--int:#60a5fa;--adv:#f59e0b;--eli:#ef4444;--page-gutter:2rem;--content-max:1160px;}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;background:var(--sky3);color:var(--pw);overflow-x:hidden;display:flex;flex-direction:column;min-height:100vh;}
.topnav{position:fixed;top:0;left:0;right:0;z-index:200;background:rgba(8,15,26,.95);backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.07);}
.nav-shell{width:100%;max-width:var(--content-max);margin:0 auto;padding:.5rem var(--page-gutter);display:flex;align-items:center;justify-content:space-between;gap:.75rem;min-width:0;}
.nav-left{display:flex;align-items:center;gap:.5rem;}
.logo{display:flex;align-items:center;cursor:pointer;user-select:none;text-decoration:none;flex-shrink:0;min-width:0;color:inherit;}
.logo img,.logo svg{height:68px;width:auto;max-width:100%;display:block;object-fit:contain;}
.fl img{height:48px;width:auto;max-width:100%;display:block;object-fit:contain;}
.ntabs{display:flex;gap:.18rem;list-style:none;align-items:center;}
.ntab{padding:.4rem .85rem;border-radius:6px;cursor:pointer;font-size:.76rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:rgba(245,245,240,.48);transition:all .18s;border:none;background:transparent;text-decoration:none;display:inline-block;}
a.ntab{color:rgba(245,245,240,.48);}
.ntab:hover{color:var(--pw);background:rgba(255,255,255,.07);}
.ntab.active{color:var(--gl);background:rgba(42,171,85,.14);}
.ntab.cta{background:var(--g);color:#fff!important;border-radius:5px;}
.ntab.cta:hover{background:var(--gl);}
.ntab.cta.active{background:var(--gl);color:#fff!important;}
.hbg{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:.2rem;}
.hbg span{display:block;width:23px;height:2px;background:var(--pw);border-radius:2px;}
.drawer{display:none;position:fixed;inset:0;background:var(--sky3);z-index:300;flex-direction:column;align-items:center;justify-content:center;gap:1.3rem;}
.drawer.open{display:flex;}
.drawer button,.drawer a.drw-link{font-family:'Bebas Neue',Impact,'Arial Narrow',system-ui,sans-serif;font-size:2rem;letter-spacing:.1em;color:rgba(245,245,240,.55);cursor:pointer;transition:color .2s;background:none;border:none;text-decoration:none;}
.drawer button:hover,.drawer button.active,.drawer a.drw-link:hover,.drawer a.drw-link.active{color:var(--gl);}
.dcl{position:absolute!important;top:1.2rem;right:1.6rem;font-size:1.65rem!important;}
.wrap{margin-top:106px;flex:1;}
.hero{min-height:calc(100vh - 106px);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem var(--page-gutter);position:relative;overflow:hidden;}
.hbg2{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(255,255,255,.022) 59px,rgba(255,255,255,.022) 60px),repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(255,255,255,.022) 59px,rgba(255,255,255,.022) 60px),radial-gradient(ellipse 80% 60% at 50% 40%,#0f3d20 0%,#080f1a 70%);z-index:0;}
.hglow{position:absolute;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(42,171,85,.13) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-60%);z-index:0;pointer-events:none;}
.hc{position:relative;z-index:1;max-width:860px;}
.hbadge{display:inline-block;background:rgba(42,171,85,.13);border:1px solid rgba(42,171,85,.38);color:var(--gl);padding:.3rem 1rem;border-radius:99px;font-size:.68rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1.2rem;animation:fu .5s ease both;}
.hero h1{font-family:'Bebas Neue',Impact,'Arial Narrow',system-ui,sans-serif;font-size:clamp(4rem,12vw,9rem);line-height:.9;letter-spacing:.03em;animation:fu .55s .1s ease both;}
.hero h1 .ac{color:var(--gl);}
.hsub{margin-top:1.2rem;font-size:clamp(.92rem,2vw,1.12rem);color:rgba(245,245,240,.56);max-width:500px;margin-left:auto;margin-right:auto;line-height:1.65;animation:fu .55s .18s ease both;}
.hbtns{margin-top:1.9rem;display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap;animation:fu .55s .26s ease both;}
.bp{background:var(--g);color:#fff;padding:.75rem 1.85rem;border-radius:6px;font-weight:600;font-size:.88rem;border:none;cursor:pointer;text-decoration:none;display:inline-block;transition:background .2s,transform .14s;}
.bp:hover{background:var(--gl);transform:translateY(-2px);}
.bo{background:transparent;color:var(--pw);padding:.75rem 1.85rem;border-radius:6px;font-weight:600;font-size:.88rem;border:1.5px solid rgba(255,255,255,.2);cursor:pointer;text-decoration:none;display:inline-block;transition:border-color .2s,transform .14s;}
.bo:hover{border-color:var(--gl);transform:translateY(-2px);}
.hstats{margin-top:2.8rem;display:flex;gap:2.3rem;justify-content:center;flex-wrap:wrap;animation:fu .55s .34s ease both;}
.hstat .num{font-family:'Bebas Neue',Impact,'Arial Narrow',system-ui,sans-serif;font-size:2.4rem;color:var(--gl);letter-spacing:.05em;line-height:1;}
.hstat .lbl{font-size:.68rem;color:rgba(245,245,240,.4);text-transform:uppercase;letter-spacing:.1em;margin-top:.18rem;}
@keyframes fu{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:translateY(0);}}
@media(max-width:920px){.ntabs{display:none!important;}.hbg{display:flex!important;}}
@media(max-width:600px){:root{--page-gutter:1.1rem;}.nav-shell{padding:.68rem var(--page-gutter);}}

/* drill list row as link */
a.dr{text-decoration:none;color:inherit;align-items:center;}
.flinks a{color:rgba(245,245,240,.33);font-size:.78rem;cursor:pointer;background:none;border:none;transition:color .2s;text-decoration:none;}
.flinks a:hover{color:var(--pw);}

/* ── COMMON ── */
.sec{padding:4rem var(--page-gutter);}
.cnt{max-width:var(--content-max);margin:0 auto;}
.slbl{font-family:'DM Mono',monospace;font-size:.67rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gl);margin-bottom:.62rem;display:block;}
.stitle{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.1rem,5vw,3.7rem);line-height:1;letter-spacing:.04em;margin-bottom:.85rem;}
.sdesc{color:rgba(245,245,240,.46);font-size:.95rem;max-width:480px;line-height:1.65;}

/* ── PROGRAMS ── */
.fbar{display:flex;gap:.42rem;flex-wrap:wrap;margin-bottom:1.7rem;}
.ftab{padding:.38rem .92rem;border-radius:99px;border:1px solid rgba(255,255,255,.12);background:transparent;color:rgba(245,245,240,.5);font-size:.74rem;font-weight:500;cursor:pointer;transition:all .18s;}
.ftab.active,.ftab:hover{background:var(--g);border-color:var(--g);color:#fff;}
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.15rem;}
.pc{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:12px;overflow:hidden;transition:transform .2s,box-shadow .2s;cursor:pointer;}
.pc:hover{transform:translateY(-4px);box-shadow:0 13px 34px rgba(0,0,0,.44);}
.pimg{height:150px;display:flex;align-items:center;justify-content:center;font-size:3.3rem;}
.knight-ico{color:#ffffff;text-shadow:1px 2px 5px rgba(0,0,0,.7),0 1px 0 rgba(0,0,0,.5);filter:drop-shadow(0 2px 4px rgba(0,0,0,.5));display:inline-block;}
.pbody{padding:1.2rem;}
.plvl{font-size:.64rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.42rem;}
.pc h4{font-family:'Bebas Neue',sans-serif;font-size:1.28rem;letter-spacing:.04em;margin-bottom:.38rem;}
.pc p{color:rgba(245,245,240,.44);font-size:.82rem;line-height:1.6;margin-bottom:.95rem;}
.pfoot{display:flex;justify-content:space-between;align-items:center;}
.pstats{display:flex;gap:.75rem;font-size:.68rem;color:rgba(245,245,240,.3);font-family:'DM Mono',monospace;}
.pbtn{background:rgba(42,171,85,.13);color:var(--gl);border:1px solid rgba(42,171,85,.26);padding:.36rem .9rem;border-radius:6px;font-size:.76rem;font-weight:600;cursor:pointer;transition:all .18s;}
.pbtn:hover{background:var(--g);color:#fff;border-color:var(--g);}
.pcat-wrap{display:flex;flex-direction:column;align-items:stretch;gap:1.35rem;margin-bottom:0;}
.pcat-grid{display:grid;gap:1.25rem;}
.pcat-grid--outfield{grid-template-columns:repeat(3,1fr);}
@media (max-width:920px){.pcat-grid--outfield{grid-template-columns:1fr;}}
.pcat-gk-mid{display:flex;justify-content:center;width:100%;}
.pcat-gk-mid .pcat{max-width:380px;width:100%;text-align:center;border-color:rgba(251,146,60,.22);}
.pcat-gk-mid .pcat:hover{border-color:rgba(251,146,60,.45);background:rgba(251,146,60,.07);}
.pcat-gk-mid .pc-ico{margin-left:auto;margin-right:auto;}
.pcat{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:1.85rem 1.5rem;cursor:pointer;text-align:left;transition:transform .2s,border-color .2s,background .2s;}
button.pcat{font:inherit;color:inherit;}
.pcat:hover{transform:translateY(-4px);border-color:rgba(42,171,85,.38);background:rgba(255,255,255,.08);}
.pcat .pc-ico{font-size:2.75rem;line-height:1;margin-bottom:.85rem;display:block;}
.pcat h3{font-family:'Bebas Neue',sans-serif;font-size:clamp(1.45rem,4vw,1.85rem);letter-spacing:.04em;margin-bottom:.42rem;color:var(--pw);}
.pcat p{font-size:.84rem;color:rgba(245,245,240,.44);line-height:1.58;margin:0;}
.prog-back{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:rgba(245,245,240,.7);padding:.5rem 1.05rem;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;margin-bottom:1.05rem;transition:background .18s,color .18s;}
.prog-back:hover{background:rgba(42,171,85,.12);color:var(--gl);border-color:rgba(42,171,85,.25);}
.prog-list-heading{font-family:'Bebas Neue',sans-serif;font-size:clamp(1.2rem,3vw,1.5rem);color:var(--gl);letter-spacing:.06em;margin-bottom:1.05rem;}

/* ── DRILLS ── */
.dwrap{display:grid;grid-template-columns:205px 1fr;gap:1.6rem;margin-top:2.2rem;}
.dsb{position:sticky;top:67px;height:fit-content;}
.dsh{font-size:.63rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(245,245,240,.27);margin-bottom:.52rem;margin-top:1.25rem;}
.dsh:first-child{margin-top:0;}
.di{display:flex;align-items:center;gap:.52rem;padding:.42rem .62rem;border-radius:6px;color:rgba(245,245,240,.5);font-size:.82rem;cursor:pointer;transition:all .15s;}
.di:hover,.di.active{background:rgba(42,171,85,.12);color:var(--gl);}
.ddot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.dsrch{display:flex;gap:.62rem;margin-bottom:1.45rem;}
.dsrch input{flex:1;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.6rem .98rem;color:var(--pw);font-family:'DM Sans',sans-serif;font-size:.86rem;outline:none;transition:border-color .2s;}
.dsrch input::placeholder{color:rgba(245,245,240,.24);}
.dsrch input:focus{border-color:var(--gl);}
.dsrch button{background:var(--g);color:#fff;border:none;padding:0 1.15rem;border-radius:8px;font-weight:600;font-size:.82rem;cursor:pointer;transition:background .2s;}
.dsrch button:hover{background:var(--gl);}
.dlist{display:flex;flex-direction:column;gap:.82rem;}
.dr{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:.98rem 1.15rem;display:flex;align-items:center;gap:1rem;cursor:pointer;transition:all .18s;}
.dr:hover{background:rgba(255,255,255,.08);border-color:rgba(42,171,85,.35);transform:translateX(3px);}
.dico{font-size:1.6rem;flex-shrink:0;}
.dinf{flex:1;}
.dinf h4{font-weight:600;margin-bottom:.1rem;font-size:.9rem;}
.dinf p{font-size:.76rem;color:rgba(245,245,240,.38);}
.dmeta{display:flex;gap:.42rem;align-items:center;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end;}
.tag{padding:.14rem .55rem;border-radius:99px;font-size:.62rem;font-weight:600;letter-spacing:.05em;}
.tb{background:rgba(74,222,128,.11);color:var(--beg);}
.ti{background:rgba(96,165,250,.11);color:var(--int);}
.ta{background:rgba(245,158,11,.11);color:var(--adv);}
.te{background:rgba(239,68,68,.11);color:var(--eli);}
.ddur{font-size:.68rem;color:rgba(245,245,240,.26);font-family:'DM Mono',monospace;}
.dmore{font-size:.7rem;color:var(--gl);font-family:'DM Mono',monospace;white-space:nowrap;}

/* ── SCHEDULE / STREAK ── */
.stop{display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;margin-bottom:2.3rem;}
.sw{display:flex;align-items:center;gap:1rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:12px;padding:.85rem 1.35rem;flex-wrap:wrap;}
.sfire{font-size:2.1rem;line-height:1;}
.si h3{font-family:'Bebas Neue',sans-serif;font-size:1.95rem;letter-spacing:.05em;color:var(--gold);line-height:1;}
.si p{font-size:.73rem;color:rgba(245,245,240,.4);margin-top:.08rem;}
.sdiv{width:1px;height:36px;background:rgba(255,255,255,.1);}
.sstat{text-align:center;}
.sstat .sv{font-family:'Bebas Neue',sans-serif;font-size:1.4rem;color:var(--gl);letter-spacing:.05em;}
.sstat .sl{font-size:.64rem;color:rgba(245,245,240,.3);text-transform:uppercase;letter-spacing:.1em;}
.logbtn{background:var(--g);color:#fff;border:none;padding:.6rem 1.35rem;border-radius:8px;font-weight:600;font-size:.84rem;cursor:pointer;transition:background .2s;display:inline-flex;align-items:center;gap:.42rem;}
.logbtn:hover{background:var(--gl);}
.logbtn.logged{background:rgba(42,171,85,.17);color:var(--gl);border:1px solid rgba(42,171,85,.3);cursor:default;}
.scal h4{font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:.05em;margin-bottom:.85rem;color:rgba(245,245,240,.6);}
/* Week-aligned calendar */
.cal-wrap{max-width:280px;}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:3px;}
.cal-dow span{text-align:center;font-size:.58rem;font-family:'DM Mono',monospace;color:rgba(245,245,240,.25);text-transform:uppercase;letter-spacing:.05em;padding:.1rem 0;}
.cgrid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;max-width:280px;}
.cd{width:100%;aspect-ratio:1;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-family:'DM Mono',monospace;cursor:pointer;transition:all .15s;border:1px solid transparent;}
.cd.tr{background:rgba(42,171,85,.28);color:var(--gl);border-color:rgba(42,171,85,.35);}
.cd.td{border:2px solid var(--gold);color:var(--gold);font-weight:700;}
.cd.td.tr{background:rgba(42,171,85,.28);border-color:var(--gold);}
.cd.em{background:rgba(255,255,255,.03);color:rgba(245,245,240,.17);}
.cd.blank{background:transparent;border-color:transparent;cursor:default;pointer-events:none;}
.cd:not(.blank):hover{background:rgba(42,171,85,.18);border-color:rgba(42,171,85,.4);}
/* History view */
.hist-tabs{display:flex;gap:.35rem;margin-bottom:1.4rem;flex-wrap:wrap;}
.hist-tab{padding:.35rem .85rem;border-radius:99px;border:1px solid rgba(255,255,255,.1);background:transparent;color:rgba(245,245,240,.44);font-size:.74rem;font-weight:500;cursor:pointer;transition:all .18s;}
.hist-tab.active{background:var(--g);border-color:var(--g);color:#fff;}
/* Year heatmap */
.heatmap-wrap{overflow-x:auto;padding-bottom:.5rem;}
.heatmap{display:flex;gap:3px;align-items:flex-start;}
.hm-col{display:flex;flex-direction:column;gap:3px;}
.hm-cell{width:11px;height:11px;border-radius:2px;flex-shrink:0;}
.hm-cell.empty{background:rgba(255,255,255,.04);}
.hm-cell.t1{background:rgba(42,171,85,.25);}
.hm-cell.t2{background:rgba(42,171,85,.5);}
.hm-cell.t3{background:rgba(42,171,85,.8);}
.hm-month-labels{display:flex;gap:3px;margin-bottom:3px;font-size:.58rem;font-family:'DM Mono',monospace;color:rgba(245,245,240,.25);}
.hm-dow-labels{display:flex;flex-direction:column;gap:3px;margin-right:4px;padding-top:1px;}
.hm-dow-labels span{font-size:.52rem;font-family:'DM Mono',monospace;color:rgba(245,245,240,.2);height:11px;display:flex;align-items:center;}
.hist-stats{display:flex;gap:1.4rem;margin-top:1.1rem;flex-wrap:wrap;}
.hist-stat .hv{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;color:var(--gl);line-height:1;}
.hist-stat .hl{font-size:.65rem;color:rgba(245,245,240,.3);text-transform:uppercase;letter-spacing:.1em;}
/* Day detail popup in streak */
.day-popup{position:absolute;z-index:400;background:#0d1a2a;border:1px solid rgba(255,255,255,.14);border-radius:10px;padding:.85rem 1rem;min-width:200px;max-width:240px;box-shadow:0 10px 30px rgba(0,0,0,.6);animation:fi .18s ease;}
.day-popup h5{font-family:'Bebas Neue',sans-serif;font-size:.9rem;letter-spacing:.05em;color:var(--gl);margin-bottom:.55rem;}
.day-popup .dp-item{font-size:.76rem;color:rgba(245,245,240,.6);padding:.22rem 0;border-bottom:1px solid rgba(255,255,255,.05);display:flex;align-items:center;gap:.45rem;}
.day-popup .dp-item:last-child{border-bottom:none;}
.day-popup .dp-none{font-size:.78rem;color:rgba(245,245,240,.25);font-style:italic;}
.day-popup .dp-close{position:absolute;top:.5rem;right:.6rem;background:none;border:none;color:rgba(245,245,240,.3);cursor:pointer;font-size:.9rem;line-height:1;}
.cal-container{position:relative;}
.smsg{margin-top:.85rem;font-size:.85rem;padding:.6rem .95rem;border-radius:8px;background:rgba(240,180,41,.1);border:1px solid rgba(240,180,41,.24);color:var(--gold);display:none;}
.smsg.show{display:block;}
.sbld{display:grid;grid-template-columns:1fr 1fr;gap:1.7rem;margin-top:1.8rem;}
.fr{margin-bottom:1.15rem;}
.fr label{display:block;font-size:.71rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(245,245,240,.38);margin-bottom:.4rem;}
.fc{width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.65rem .92rem;color:var(--pw);font-family:'DM Sans',sans-serif;font-size:.86rem;outline:none;transition:border-color .2s;appearance:none;}
.fc:focus{border-color:var(--gl);}
.fc option{background:#0e1a2b;}
.fg{display:grid;grid-template-columns:1fr 1fr;gap:.82rem;}
.genbtn{width:100%;background:var(--g);color:#fff;border:none;border-radius:8px;padding:.82rem;font-family:'Bebas Neue',sans-serif;font-size:1.18rem;letter-spacing:.1em;cursor:pointer;transition:background .2s,transform .14s;margin-top:.32rem;}
.genbtn:hover{background:var(--gl);transform:translateY(-2px);}
.sout{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:1.45rem;min-height:250px;}
.sout h4{font-family:'Bebas Neue',sans-serif;font-size:1.05rem;letter-spacing:.05em;margin-bottom:.9rem;color:var(--gl);}
.swk{display:flex;flex-direction:column;gap:.58rem;}
.sd{display:flex;gap:.85rem;align-items:flex-start;padding:.68rem;border-radius:8px;background:rgba(255,255,255,.03);}
.dlbl{font-family:'DM Mono',monospace;font-size:.66rem;color:var(--gl);text-transform:uppercase;letter-spacing:.1em;width:27px;flex-shrink:0;padding-top:2px;}
.dcnt{font-size:.82rem;color:rgba(245,245,240,.6);line-height:1.5;}
.dcnt strong{color:var(--pw);}
.drest{color:rgba(245,245,240,.24)!important;font-style:italic;}
.ph{text-align:center;padding:2.2rem 1rem;color:rgba(245,245,240,.17);font-size:.88rem;}
.ph .bi{font-size:2.5rem;display:block;margin-bottom:.62rem;}

/* ── PROGRESS ── */
.prlyt{display:grid;grid-template-columns:1fr 1fr;gap:1.7rem;margin-top:2.2rem;}
.prc{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:1.45rem;}
.prc h4{font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:.05em;margin-bottom:1.05rem;}
.skb{margin-bottom:.95rem;}
.sbh{display:flex;justify-content:space-between;margin-bottom:.3rem;font-size:.79rem;}
.sbh span:first-child{color:rgba(245,245,240,.6);}
.sbh span:last-child{color:var(--gl);font-family:'DM Mono',monospace;font-size:.74rem;}
.btr{height:5px;background:rgba(255,255,255,.07);border-radius:99px;overflow:hidden;}
.bf{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--g),var(--gl));transition:width 1s cubic-bezier(.4,0,.2,1);}
.achs{display:flex;flex-direction:column;gap:.62rem;}
.ach{display:flex;align-items:center;gap:.82rem;padding:.72rem;border-radius:8px;background:rgba(255,255,255,.04);}
.ai{font-size:1.4rem;}
.ain h5{font-size:.84rem;font-weight:600;margin-bottom:.08rem;}
.ain p{font-size:.72rem;color:rgba(245,245,240,.34);}
.ach.lck{opacity:.3;}
.slr{display:flex;align-items:center;gap:.62rem;font-size:.76rem;margin-bottom:.42rem;}
.slr span:first-child{width:70px;color:rgba(245,245,240,.4);flex-shrink:0;}
.slr input[type=range]{flex:1;}

/* ── COACHES ── */
.cgr{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1.15rem;margin-top:2.2rem;}
.cc{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:1.45rem;text-align:center;transition:transform .2s,border-color .2s;}
.cc:hover{transform:translateY(-4px);border-color:rgba(42,171,85,.3);}
.cav{width:66px;height:66px;border-radius:50%;margin:0 auto .82rem;display:flex;align-items:center;justify-content:center;font-size:1.85rem;border:2px solid rgba(42,171,85,.28);}
.cc h4{font-weight:600;margin-bottom:.12rem;font-size:.91rem;}
.cr{font-size:.76rem;color:var(--gl);font-weight:500;margin-bottom:.52rem;}
.cc p{font-size:.78rem;color:rgba(245,245,240,.38);line-height:1.6;margin-bottom:.82rem;}
.ctags{display:flex;gap:.35rem;flex-wrap:wrap;justify-content:center;}
.ctag{padding:.14rem .58rem;border-radius:99px;font-size:.62rem;background:rgba(255,255,255,.07);color:rgba(245,245,240,.4);}

/* ── JOIN ── */
.jp{min-height:calc(100vh - 106px);display:flex;align-items:center;justify-content:center;padding:4rem var(--page-gutter);position:relative;overflow:hidden;background:linear-gradient(135deg,#0f3d20 0%,#0a2a15 50%,#080f1a 100%);}
.jp::before{content:'⚽';position:absolute;font-size:22rem;opacity:.04;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;}
.jb{position:relative;z-index:1;max-width:460px;width:100%;text-align:center;}
.jb h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.6rem,7vw,4.8rem);letter-spacing:.04em;margin-bottom:.72rem;}
.jb p{color:rgba(245,245,240,.48);font-size:.94rem;max-width:360px;margin:0 auto 1.7rem;line-height:1.65;}
.jf{display:flex;flex-direction:column;gap:.82rem;max-width:330px;margin:0 auto;}
.jf input{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);border-radius:8px;padding:.72rem 1.02rem;color:#fff;font-family:'DM Sans',sans-serif;font-size:.87rem;outline:none;}
.jf input::placeholder{color:rgba(255,255,255,.33);}
.jf button{background:var(--gl);color:#fff;border:none;padding:.75rem;border-radius:8px;font-weight:700;font-size:.87rem;cursor:pointer;transition:background .2s;}
.jf button:hover{background:var(--g);}
.jsuc{color:var(--gl);font-size:1rem;font-weight:600;display:none;margin-top:.85rem;}
.perks{display:flex;flex-direction:column;gap:.62rem;margin-top:1.7rem;text-align:left;}
.perk{display:flex;align-items:center;gap:.62rem;font-size:.84rem;color:rgba(245,245,240,.55);}
.perk span:first-child{color:var(--gl);}

/* ── MASTER MODAL (drills / levels / programs) ── */
.mo{display:none;position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.78);backdrop-filter:blur(7px);align-items:center;justify-content:center;padding:2rem;}
.mo.open{display:flex;}
.md{background:#0d1822;border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:2rem;max-width:500px;width:100%;position:relative;animation:fu .28s ease;max-height:88vh;overflow-y:auto;}
.mc{position:absolute;top:.82rem;right:.98rem;background:none;border:none;color:rgba(245,245,240,.35);font-size:1.22rem;cursor:pointer;}
.mc:hover{color:var(--pw);}
.md h3{font-family:'Bebas Neue',sans-serif;font-size:1.62rem;letter-spacing:.05em;margin-bottom:.5rem;color:var(--gl);}
.md .mlvl{font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.7rem;display:block;}
.md p{color:rgba(245,245,240,.54);font-size:.87rem;line-height:1.65;margin-bottom:1.1rem;}
.msteps{list-style:none;display:flex;flex-direction:column;gap:.68rem;}
.msteps li{display:flex;gap:.82rem;align-items:flex-start;}
.msn{width:24px;height:24px;border-radius:50%;background:var(--g);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;flex-shrink:0;margin-top:1px;}
.mst{font-size:.84rem;color:rgba(245,245,240,.6);line-height:1.5;}
.msbtn{width:100%;background:var(--g);color:#fff;border:none;border-radius:8px;padding:.8rem;font-family:'Bebas Neue',sans-serif;font-size:1.15rem;letter-spacing:.1em;cursor:pointer;margin-top:1.35rem;}
.msbtn:hover{background:var(--gl);}
/* drill detail */
.drill-detail{display:flex;flex-direction:column;gap:.9rem;}
.dd-steps{background:rgba(255,255,255,.04);border-radius:10px;padding:1.1rem;}
.dd-steps h5{font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(245,245,240,.35);margin-bottom:.75rem;}
.dd-step{display:flex;gap:.75rem;margin-bottom:.6rem;font-size:.84rem;color:rgba(245,245,240,.62);line-height:1.5;}
.dd-step:last-child{margin-bottom:0;}
.dd-num{width:22px;height:22px;border-radius:50%;background:rgba(42,171,85,.25);color:var(--gl);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;flex-shrink:0;margin-top:1px;}
.dd-meta{display:flex;gap:.8rem;flex-wrap:wrap;}
.dd-chip{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:6px;padding:.32rem .7rem;font-size:.75rem;font-family:'DM Mono',monospace;color:rgba(245,245,240,.5);}
.dd-yt{background:rgba(255,0,0,.12);border:1px solid rgba(255,0,0,.2);border-radius:8px;padding:.7rem 1rem;display:flex;align-items:center;gap:.7rem;cursor:pointer;transition:background .18s;}
.dd-yt:hover{background:rgba(255,0,0,.22);}
.dd-yt .yt-icon{font-size:1.35rem;}
.dd-yt .yt-text h5{font-size:.84rem;font-weight:600;margin-bottom:.08rem;}
.dd-yt .yt-text p{font-size:.74rem;color:rgba(245,245,240,.42);}

/* ── TOAST ── */
.toast{position:fixed;bottom:1.6rem;right:1.6rem;z-index:999;background:var(--g);color:#fff;padding:.82rem 1.3rem;border-radius:10px;font-size:.84rem;font-weight:500;transform:translateY(80px);opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1);pointer-events:none;}
.toast.show{transform:translateY(0);opacity:1;}

/* ── FOOTER ── */
footer{background:#05090f;padding:1.7rem 0;border-top:1px solid rgba(255,255,255,.05);}
/* Match .nav-shell: max-width + horizontal padding inside the bar so logo lines up with header */
.fi2{width:100%;max-width:var(--content-max);margin:0 auto;padding:0 var(--page-gutter);box-sizing:border-box;display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:.85rem 1rem;}
.fi2 .fl{justify-self:start;min-width:0;}
.fi2 .fl img{display:block;height:auto;width:auto;max-height:52px;max-width:min(240px,100%);object-fit:contain;}
.fi2 .flinks{justify-self:center;justify-content:center;}
.fi2 .fcp{justify-self:end;text-align:end;min-width:0;}
.fl{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;color:var(--gl);letter-spacing:.1em;}
.fl span{color:var(--gold);}
.flinks{display:flex;gap:1.2rem;flex-wrap:wrap;}
.flinks button{color:rgba(245,245,240,.33);font-size:.78rem;cursor:pointer;background:none;border:none;transition:color .2s;}
.flinks button:hover{color:var(--pw);}
.fcp{color:rgba(245,245,240,.18);font-size:.74rem;}
.fcontact{display:flex;flex-direction:column;align-items:center;gap:.45rem;margin-top:1.35rem;padding:1.35rem var(--page-gutter) 0;border-top:1px solid rgba(255,255,255,.06);text-align:center;box-sizing:border-box;}
.fcontact-title{font-family:'DM Mono',monospace;font-size:.67rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gl);}
.fcontact-email{color:rgba(245,245,240,.72);font-size:.9rem;font-weight:500;text-decoration:none;transition:color .2s;}
.fcontact-email:hover{color:var(--gl);}

/* ── DRILL TIMER ── */
.drill-timer{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:12px;padding:1.1rem 1.2rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;}
.timer-display{font-family:'Bebas Neue',sans-serif;font-size:3.2rem;letter-spacing:.08em;line-height:1;color:var(--pw);transition:color .3s;}
.timer-display.running{color:var(--gl);}
.timer-display.warning{color:var(--gold);}
.timer-display.done{color:var(--gl);}
.timer-ring-wrap{position:relative;width:90px;height:90px;flex-shrink:0;}
.timer-ring-wrap svg{transform:rotate(-90deg);}
.timer-ring-bg{fill:none;stroke:rgba(255,255,255,.07);stroke-width:5;}
.timer-ring-fill{fill:none;stroke:var(--gl);stroke-width:5;stroke-linecap:round;transition:stroke-dashoffset .9s linear,stroke .3s;}
.timer-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.timer-center .ttime{font-family:'Bebas Neue',sans-serif;font-size:1.35rem;letter-spacing:.05em;line-height:1;color:var(--pw);}
.timer-center .tlbl{font-size:.52rem;color:rgba(245,245,240,.3);text-transform:uppercase;letter-spacing:.1em;margin-top:1px;}
.timer-btns{display:flex;gap:.55rem;width:100%;}
.timer-btns button{flex:1;padding:.52rem .5rem;border-radius:7px;border:none;font-weight:600;font-size:.8rem;cursor:pointer;transition:all .18s;}
.tbtn-start{background:var(--g);color:#fff;}
.tbtn-start:hover{background:var(--gl);}
.tbtn-pause{background:rgba(240,180,41,.15);color:var(--gold);border:1px solid rgba(240,180,41,.25)!important;}
.tbtn-pause:hover{background:rgba(240,180,41,.25);}
.tbtn-reset{background:rgba(255,255,255,.06);color:rgba(245,245,240,.45);border:1px solid rgba(255,255,255,.1)!important;}
.tbtn-reset:hover{color:var(--pw);background:rgba(255,255,255,.1);}
.timer-presets{display:flex;gap:.35rem;flex-wrap:wrap;justify-content:center;}
.tpreset{padding:.22rem .65rem;border-radius:99px;border:1px solid rgba(255,255,255,.1);background:transparent;color:rgba(245,245,240,.38);font-size:.7rem;font-family:'DM Mono',monospace;cursor:pointer;transition:all .15s;}
.tpreset:hover,.tpreset.active{background:rgba(42,171,85,.15);border-color:rgba(42,171,85,.35);color:var(--gl);}

/* ── RESPONSIVE ── */
@media(max-width:920px){.dwrap{grid-template-columns:1fr;}.dsb{position:static;}.sbld{grid-template-columns:1fr;}.prlyt{grid-template-columns:1fr;}}
@media(max-width:600px){:root{--page-gutter:1.1rem;}.nav-shell{padding:.68rem var(--page-gutter);}.sec{padding:2.7rem var(--page-gutter);}.fg{grid-template-columns:1fr;}.hstats{gap:1.3rem;}.stop{flex-direction:column;align-items:stretch;}.cgrid{max-width:100%;}.fi2{grid-template-columns:1fr;justify-items:center;row-gap:1rem;}.fi2 .fl{justify-self:center;}.fi2 .fcp{justify-self:center;text-align:center;}}

/* ── ACCOUNT ── */
.acct-hero{display:flex;align-items:center;gap:1.2rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:1.6rem;margin-bottom:2rem;}
.acct-avatar{width:62px;height:62px;border-radius:50%;background:linear-gradient(135deg,var(--g),var(--gl));display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:1.6rem;color:#fff;flex-shrink:0;border:2px solid rgba(42,171,85,.4);}
.acct-info h3{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;letter-spacing:.05em;}
.acct-info p{font-size:.8rem;color:rgba(245,245,240,.38);margin-top:.12rem;}
.acct-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem;}
.acct-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:1.4rem;}
.acct-card h4{font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:.06em;margin-bottom:1rem;color:var(--gl);}
.tk-item{display:flex;align-items:center;gap:.75rem;padding:.65rem .75rem;border-radius:8px;background:rgba(255,255,255,.03);margin-bottom:.5rem;font-size:.83rem;}
.tk-item:last-child{margin-bottom:0;}
.tk-ico{font-size:1.15rem;flex-shrink:0;}
.tk-info{flex:1;}
.tk-info strong{display:block;font-size:.83rem;color:var(--pw);}
.tk-info span{font-size:.72rem;color:rgba(245,245,240,.35);}
.tk-done{color:var(--gl);font-size:.75rem;font-family:'DM Mono',monospace;flex-shrink:0;}
.stg-row{display:flex;justify-content:space-between;align-items:center;padding:.7rem 0;border-bottom:1px solid rgba(255,255,255,.05);}
.stg-row:last-child{border-bottom:none;}
.stg-row label{font-size:.84rem;color:rgba(245,245,240,.65);}
.stg-row select,.stg-row input[type=text]{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:.32rem .65rem;color:var(--pw);font-family:'DM Sans',sans-serif;font-size:.82rem;outline:none;max-width:140px;}
.stg-row select:focus,.stg-row input:focus{border-color:var(--gl);}
.stg-row select option{background:#0e1a2b;}
.logout-btn{width:100%;background:rgba(239,68,68,.12);color:#ef4444;border:1px solid rgba(239,68,68,.25);border-radius:8px;padding:.72rem;font-weight:600;font-size:.85rem;cursor:pointer;margin-top:1.3rem;transition:all .2s;}
.logout-btn:hover{background:rgba(239,68,68,.22);}
@media(max-width:720px){.acct-grid{grid-template-columns:1fr;}}