
:root{
  --or:#e87010;--ob:#ff8822;--od:#c45508;--os:rgba(232,112,16,.1);
  --gold:#d4a843;--gold2:#f2cb5a;--green:#22c55e;
  --bk:#080604;--d1:#0f0c08;--d2:#171209;--d3:#1f180e;--d4:#2a2218;
  --br:rgba(232,112,16,.22);--bs:rgba(255,255,255,.07);
  --tp:#f5f0e8;--ts:#cbb898;--tm:#8a7060;
  --er:#e05050;--ok:#3dba6e;
}
[data-theme="light"]{
  --or:#c45508;--ob:#e87010;--od:#a03d04;--os:rgba(196,85,8,.12);
  --gold:#a07820;--gold2:#c9940a;--green:#16a34a;
  --bk:#f8f4ee;--d1:#f0ebe2;--d2:#e8e0d4;--d3:#ddd5c8;--d4:#ccc3b4;
  --br:rgba(196,85,8,.3);--bs:rgba(0,0,0,.1);
  --tp:#1a1208;--ts:#4a3820;--tm:#7a6040;
  --er:#cc2020;--ok:#15803d;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bk);color:var(--tp);font-family:"Rajdhani",sans-serif;font-size:16px;line-height:1.6;overflow-x:hidden}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--d1)}::-webkit-scrollbar-thumb{background:var(--od);border-radius:3px}
body::before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse 90% 50% at 50% 0%,rgba(232,112,16,.05),transparent 55%);pointer-events:none;z-index:0}

/* NAV */
nav{position:sticky;top:0;z-index:200;background:rgba(8,6,4,.96);backdrop-filter:blur(14px);border-bottom:1px solid var(--br);display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:56px}
.nav-brand{display:flex;align-items:center;gap:.6rem;cursor:pointer}
.nav-brand-img{width:34px;height:34px;object-fit:contain}
.nav-title{font-family:"Cinzel",serif;font-size:12px;font-weight:700;color:var(--tp);letter-spacing:.06em;line-height:1.1}
.nav-sub{font-size:9px;font-weight:600;color:var(--or);letter-spacing:.18em;text-transform:uppercase}
.nav-tabs{position:absolute;left:50%;transform:translateX(-50%);display:flex;gap:2px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;max-width:calc(100% - 380px)}.nav-tabs::-webkit-scrollbar{display:none}
.nav-brand{position:relative;z-index:1}
.nav-actions{display:flex;justify-content:flex-end;align-items:center;gap:.4rem;position:relative;z-index:1}
.nav-tab{padding:.32rem .65rem;font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--ts);border-radius:6px;transition:all .2s;border:1px solid transparent;cursor:pointer;display:flex;align-items:center;gap:.4rem;background:none;font-family:"Rajdhani",sans-serif}
.nav-tab:hover{color:var(--or);background:var(--os);border-color:var(--br)}
.nav-tab.on{background:var(--or);color:#fff;border-color:var(--or)}
.nav-tab img{width:20px;height:20px;object-fit:contain}
.nav-admin{padding:.32rem .7rem;background:transparent;border:1px solid var(--br);border-radius:5px;color:var(--tm);font-size:10px;font-family:"Rajdhani",sans-serif;font-weight:700;letter-spacing:.1em;cursor:pointer;transition:all .2s;text-transform:uppercase}
.nav-admin:hover{color:var(--or);border-color:var(--od)}

/* PAGES */
.page{display:none;position:relative;z-index:1}.page.on{display:block}

/* HOME HERO */
.home-wrap{max-width:1100px;margin:0 auto;padding:2.5rem 1.5rem 0}
.home-hero{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start;margin-bottom:2rem}
.hero-text h1{font-family:"Cinzel",serif;font-size:clamp(1.9rem,4vw,3.2rem);font-weight:900;color:var(--tp);line-height:1.05;margin-bottom:.6rem}
.hero-text h1 span{color:var(--or)}
.hero-sub{font-size:1rem;color:var(--ts);line-height:1.75;max-width:480px;margin-bottom:1.25rem}
.hero-sub strong{color:var(--tp);font-weight:600}
.cta-row{display:flex;align-items:center;gap:.85rem;flex-wrap:wrap;margin-bottom:1rem}
.btn{display:inline-flex;align-items:center;gap:.45rem;padding:.65rem 1.4rem;font-family:"Rajdhani",sans-serif;font-size:14px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;border-radius:8px;cursor:pointer;transition:all .2s;border:none;text-decoration:none}
.btn-p{background:var(--or);color:#fff}.btn-p:hover{background:var(--ob);transform:translateY(-1px);box-shadow:0 4px 18px rgba(232,112,16,.4)}
.btn-g{background:transparent;color:var(--ts);border:1px solid var(--br)}.btn-g:hover{color:var(--or);border-color:var(--od);background:var(--os)}
.socials{display:flex;gap:1.1rem;flex-wrap:wrap}
.social{display:flex;align-items:center;gap:.4rem;font-size:12px;font-weight:700;color:var(--tm);text-decoration:none;letter-spacing:.06em;transition:color .2s}
.social:hover{color:var(--or)}.social svg{width:14px;height:14px}

/* NightraTV PROGRESS WIDGET */
.nt-widget{background:linear-gradient(135deg,var(--d2),var(--d3));border:1px solid var(--br);border-radius:16px;padding:1.25rem 1.35rem 1.25rem 0;position:relative;overflow:visible}
.nt-widget::before{content:"";position:absolute;top:-20px;right:-20px;width:80px;height:80px;background:radial-gradient(circle,rgba(232,112,16,.12),transparent 70%);pointer-events:none}
.nt-wgt-title{font-family:"Cinzel",serif;font-size:.82rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--or);margin-bottom:.9rem;padding-bottom:.8rem;border-bottom:1px solid var(--bs)}
.nt-wgt-sub{font-size:11px;color:var(--ts);margin-top:.18rem;font-weight:400}
/* Avatar LEFT, capes RIGHT - avatar is larger and prominent */
.nt-body{display:grid;grid-template-columns:92px 1fr;gap:.9rem;align-items:start}
.nt-avatar-col{display:flex;align-items:flex-start;padding-top:.2rem}
.nt-avatar-img{width:88px;height:88px;object-fit:contain;filter:drop-shadow(0 2px 8px rgba(232,112,16,.3))}
.nt-capes-col{flex:1}
.nt-cape-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.65rem}
.nt-cape-row:last-child{margin-bottom:0}
.nt-cape-img{width:30px;height:30px;object-fit:contain;flex-shrink:0}
.nt-cape-info{flex:1;min-width:0}
.nt-cape-name{font-size:10.5px;font-weight:600;color:var(--ts);margin-bottom:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nt-mini-bar{height:3px;background:var(--d4);border-radius:2px}
.nt-mini-fill{height:100%;border-radius:2px;transition:width .7s ease}
.nt-pct-val{font-family:"Cinzel",serif;font-size:.9rem;font-weight:700;flex-shrink:0;min-width:34px;text-align:right;transition:color .4s}
.nt-overall{margin-top:.85rem;padding-top:.85rem;border-top:1px solid var(--bs)}
.nt-overall-hd{display:flex;justify-content:space-between;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--tm);margin-bottom:.4rem}
.nt-overall-hd span:last-child{color:var(--or)}
.prog-track{height:4px;background:var(--d4);border-radius:3px;overflow:hidden}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--od),var(--ob));border-radius:3px;transition:width .8s ease}

/* HOME CARDS */
.home-section{max-width:1100px;margin:0 auto;padding:0 1.5rem 3rem}
.sec-hd{text-align:center;margin-bottom:1.75rem}
.sec-hd h2{font-family:"Cinzel",serif;font-size:clamp(1.2rem,2.5vw,1.6rem);font-weight:700;color:var(--tp);letter-spacing:.06em;margin-bottom:.5rem}
.sec-hd p{font-size:.95rem;color:var(--ts);max-width:560px;margin:0 auto;line-height:1.7}
.home-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.15rem}
.cape-card{background:var(--d2);border:1px solid var(--bs);border-radius:14px;padding:1.4rem 1.4rem 1.1rem;cursor:pointer;transition:all .25s;position:relative;overflow:hidden}
.cape-card::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(232,112,16,.06),transparent 60%);opacity:0;transition:opacity .25s}
.cape-card:hover{border-color:var(--br);transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,0,0,.6)}
.cape-card:hover::before{opacity:1}
.cape-card.complete{border-color:rgba(34,197,94,.4);background:linear-gradient(135deg,rgba(34,197,94,.05),var(--d2) 60%)}
.card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:.8rem}
.card-lhs{display:flex;align-items:center;gap:.7rem}
.card-img{width:48px;height:48px;object-fit:contain;flex-shrink:0}
.card-title{font-family:"Cinzel",serif;font-size:.92rem;font-weight:700;color:var(--tp);margin-bottom:.15rem;line-height:1.2}
.card-tag{font-size:10px;font-weight:600;letter-spacing:.08em;color:var(--or);text-transform:uppercase}
.card-pct{font-family:"Cinzel",serif;font-size:1.45rem;font-weight:700;color:var(--gold2);flex-shrink:0;transition:color .4s}
.card-pct.done{color:var(--green)}
.card-counts{display:flex;justify-content:flex-end;gap:.9rem;margin-bottom:.35rem;font-size:12px;font-weight:600}
.cnt-m{color:var(--ts)}.cnt-n{color:var(--or)}
.cnt-m.done{color:var(--green)}
.card-bar{height:3px;background:var(--d4);border-radius:2px;position:relative;margin-bottom:.8rem}
.bar-n{position:absolute;height:100%;background:var(--or);border-radius:2px;transition:width .7s ease;opacity:.7}
.bar-m{position:absolute;height:100%;border-radius:2px;transition:width .7s ease,background .4s;background:var(--gold)}
.bar-m.done{background:var(--green)}
.card-legend{display:flex;gap:.9rem;margin-bottom:.8rem;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.ldot{width:7px;height:7px;border-radius:50%;display:inline-block;margin-right:3px;vertical-align:middle}
.card-desc{font-size:.88rem;color:var(--ts);line-height:1.65;border-top:1px solid var(--bs);padding-top:.85rem;font-family:"Crimson Pro",serif;font-style:italic}
.card-link{font-size:12px;font-weight:700;color:var(--or);margin-top:.6rem;letter-spacing:.05em}
.card-complete-badge{display:none;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--green);margin-top:.4rem}
.cape-card.complete .card-complete-badge{display:block}

/* MILESTONES */
.milestone-badge{position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:default;transition:transform .2s}
.milestone-badge:hover{transform:translateY(-4px)}
.milestone-badge img{width:72px;height:72px;object-fit:contain;filter:grayscale(1) opacity(.35);transition:filter .3s}
.milestone-badge.earned img{filter:none;filter:drop-shadow(0 2px 8px rgba(232,112,16,.5))}
.milestone-badge .mb-title{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--tm);text-align:center;max-width:80px;line-height:1.2;transition:color .3s}
.milestone-badge.earned .mb-title{color:var(--or)}
.milestone-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--d1);border:1px solid var(--br);border-radius:8px;padding:.5rem .75rem;font-size:11px;color:var(--ts);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s;z-index:50}
.milestone-badge:hover .milestone-tooltip{opacity:1}

/* SPEEDRUN */
.speedrun-bar{background:var(--d2);border:1px solid var(--bs);border-radius:10px;padding:.85rem 1.1rem;margin-bottom:1.25rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.speedrun-timer{font-family:"Cinzel",serif;font-size:1.4rem;font-weight:700;color:var(--or);min-width:90px}
.speedrun-timer.running{color:var(--green)}
.speedrun-btn{padding:.4rem .9rem;font-family:"Rajdhani",sans-serif;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--br);border-radius:6px;background:var(--d3);color:var(--ts);cursor:pointer;transition:all .2s}
.speedrun-btn:hover{color:var(--or);border-color:var(--od)}
.speedrun-btn.active{background:rgba(34,197,94,.12);color:var(--green);border-color:var(--green)}
.speedrun-best{font-size:11px;color:var(--tm)}

/* SHARE BUTTON */
.share-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem 1.1rem;background:rgba(88,101,242,.15);border:1px solid rgba(88,101,242,.4);border-radius:7px;color:#7289da;font-family:"Rajdhani",sans-serif;font-size:13px;font-weight:700;letter-spacing:.05em;cursor:pointer;transition:all .2s;text-transform:uppercase}
.share-btn:hover{background:rgba(88,101,242,.25);border-color:rgba(88,101,242,.7)}

/* SHARE MODAL */
.share-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:800;align-items:center;justify-content:center;padding:1rem}
.share-modal.open{display:flex}
.share-box{background:var(--d2);border:1px solid var(--br);border-radius:16px;padding:2rem;max-width:460px;width:100%;text-align:center}
.share-card{background:linear-gradient(135deg,var(--d1),var(--d3));border:2px solid var(--or);border-radius:12px;padding:1.5rem;margin:1rem auto;position:relative;overflow:hidden}
.share-card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 50%,rgba(232,112,16,.1),transparent 60%);pointer-events:none}

/* MODAL CLOSE */
/* FEEDBACK */
.feedback-section{max-width:1100px;margin:0 auto;padding:0 1.5rem 4rem}
.fb-inner{background:var(--d2);border:1px solid var(--bs);border-radius:14px;padding:2rem}
.fb-title{font-family:"Cinzel",serif;font-size:1.2rem;font-weight:700;color:var(--tp);margin-bottom:.4rem}
.fb-sub{font-size:.92rem;color:var(--ts);margin-bottom:1.5rem;font-family:"Crimson Pro",serif;font-style:italic;line-height:1.65}
.fb-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.fb-inp,.fb-sel,.fb-ta{width:100%;background:var(--d3);border:1px solid var(--br);border-radius:7px;padding:.55rem .9rem;font-family:"Rajdhani",sans-serif;font-size:14px;font-weight:500;color:var(--tp);transition:border-color .2s}
.fb-inp:focus,.fb-sel:focus,.fb-ta:focus{outline:none;border-color:var(--or)}
.fb-ta{min-height:90px;resize:vertical;margin-bottom:1rem}
.albl{display:block;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ts);margin-bottom:.38rem}
.fb-ok{color:var(--ok);font-size:13px;margin-top:.5rem;display:none}

/* CAPE DETAIL PAGES */
.dp-wrap{max-width:1100px;margin:0 auto;padding:2rem 1.5rem 4rem}
.back-btn{display:inline-flex;align-items:center;gap:.4rem;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ts);background:var(--d2);border:1px solid var(--bs);border-radius:6px;padding:.4rem .9rem;cursor:pointer;transition:all .2s;margin-bottom:1.5rem}
.back-btn:hover{color:var(--or);border-color:var(--br)}
.dp-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:1.75rem;padding-bottom:1.5rem;border-bottom:1px solid var(--bs)}
.dp-cape-img{width:80px;height:80px;object-fit:contain;flex-shrink:0}
.dp-title{font-family:"Cinzel",serif;font-size:clamp(1.3rem,3vw,1.9rem);font-weight:900;color:var(--tp);margin-bottom:.2rem}
.dp-tag{font-size:12px;font-weight:600;letter-spacing:.1em;color:var(--or);text-transform:uppercase;margin-bottom:.6rem}
.dp-desc{font-size:.92rem;color:var(--ts);line-height:1.75;font-family:"Crimson Pro",serif;max-width:580px}
.dp-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.25rem}
.stat-box{background:var(--d2);border:1px solid var(--bs);border-radius:10px;padding:.9rem 1rem;transition:border-color .4s,background .4s}
.stat-box.done{border-color:rgba(34,197,94,.35);background:rgba(34,197,94,.04)}
.stat-lbl{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--tm);margin-bottom:.25rem}
.stat-val{font-family:"Cinzel",serif;font-size:1.35rem;font-weight:700;color:var(--gold2);transition:color .4s}
.stat-val.done{color:var(--green)}
.stat-sub{font-size:12px;color:var(--ts)}
.dp-bar{height:6px;background:var(--d4);border-radius:4px;position:relative;margin-bottom:1.5rem}
.dp-bar-n{position:absolute;height:100%;background:var(--or);border-radius:4px;opacity:.7;transition:width .8s ease}
.dp-bar-m{position:absolute;height:100%;border-radius:4px;transition:width .8s ease,background .4s;background:var(--gold)}
.dp-bar-m.done{background:var(--green)}
.bar-legend{display:flex;gap:1rem;margin-bottom:1.4rem;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.progress-tools{background:var(--d2);border:1px solid var(--bs);border-radius:10px;padding:.9rem 1.25rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}
.progress-tools-title{font-family:"Cinzel",serif;font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ts);margin-right:.25rem}
.pt-btn{padding:.38rem .85rem;font-family:"Rajdhani",sans-serif;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--br);border-radius:6px;background:var(--d3);color:var(--ts);cursor:pointer;transition:all .2s}
.pt-btn:hover{color:var(--or);border-color:var(--od)}
.pt-inp{display:none;background:var(--d3);border:1px solid var(--br);border-radius:6px;padding:.38rem .7rem;font-family:"Rajdhani",sans-serif;font-size:12px;color:var(--tp);width:220px}
.task-toolbar{display:flex;gap:.65rem;align-items:center;margin-bottom:.75rem;flex-wrap:wrap}
.task-search{flex:1;min-width:150px;background:var(--d3);border:1px solid var(--br);border-radius:8px;padding:.55rem .85rem;font-family:"Rajdhani",sans-serif;font-size:14px;color:var(--tp);transition:border-color .2s}
.task-search:focus{outline:none;border-color:var(--or)}
.filter-btn{padding:.48rem .95rem;font-family:"Rajdhani",sans-serif;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--br);border-radius:7px;background:var(--d3);color:var(--ts);cursor:pointer;transition:all .2s}
.filter-btn.on{background:var(--os);color:var(--or);border-color:var(--or)}
.task-mini-bar{height:3px;background:var(--d4);border-radius:2px;margin-bottom:.85rem}
.task-mini-fill{height:100%;border-radius:2px;transition:width .4s,background .4s}
.task-list{display:flex;flex-direction:column;gap:.3rem}
.task-item{display:flex;align-items:stretch;background:var(--d2);border:1px solid var(--bs);border-radius:8px;transition:all .15s;overflow:hidden}
.task-item:hover{background:var(--d3);border-color:rgba(232,112,16,.2)}
.task-item.done{opacity:.38}
.task-item.done .task-name{text-decoration:line-through;color:var(--tm)}
.task-item.hidden{display:none}
.task-check-area{display:flex;align-items:center;padding:.55rem .65rem .55rem .75rem;flex-shrink:0;cursor:pointer}
.task-check{width:17px;height:17px;border:1.5px solid var(--tm);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:10px;color:transparent;transition:all .15s;flex-shrink:0}
.task-item.done .task-check{background:var(--or);border-color:var(--or);color:#fff}
.task-body{flex:1;padding:.5rem 0;cursor:pointer}
.task-name{font-size:13px;font-weight:600;color:var(--tp);line-height:1.3;margin-bottom:.1rem}
.task-desc{font-size:11.5px;color:var(--ts);line-height:1.4;font-family:"Crimson Pro",serif}
.task-tip-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:0 1.1rem;font-size:12px;font-weight:700;color:var(--or);background:var(--os);border:none;border-left:1px solid var(--bs);cursor:pointer;transition:background .15s;font-family:"Rajdhani",sans-serif;letter-spacing:.06em;min-width:58px;align-self:stretch}
.task-tip-btn:hover{background:rgba(232,112,16,.18)}
.tip-panel{background:var(--d1);border-left:3px solid var(--or);border-radius:0 0 8px 0;padding:.75rem .95rem;font-size:13px;color:var(--ts);line-height:1.7;display:none}
.tip-panel.open{display:block;animation:sIn .18s ease}
@keyframes sIn{from{opacity:0;transform:translateY(-3px)}to{opacity:1;transform:translateY(0)}}
.tip-ttl{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--or);margin-bottom:.3rem}
.tip-link{display:inline-flex;align-items:center;gap:.35rem;margin-top:.5rem;font-size:12px;font-weight:700;color:var(--or);text-decoration:none;letter-spacing:.05em;text-transform:uppercase}
.tip-link:hover{color:var(--ob)}

/* CAPE CUSTOMISER */











.cust-swatch input[type="color"]{position:absolute;inset:-4px;width:calc(100%+8px);height:calc(100%+8px);border:none;cursor:pointer;opacity:0}

.cust-hex:focus{outline:none;border-color:var(--or)}



/* ADMIN */
.adm-ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:500;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(8px)}
.adm-ov.open{display:flex}
.adm-panel{background:var(--d2);border:1px solid var(--br);border-radius:16px;width:100%;max-width:600px;max-height:92vh;overflow-y:auto;animation:mIn .25s ease}
@keyframes mIn{from{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}
.adm-hd{padding:1.15rem 1.4rem;border-bottom:1px solid var(--bs);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--d2);z-index:5}
.adm-hd h2{font-family:"Cinzel",serif;font-size:.95rem;font-weight:700;color:var(--or)}
.xbtn{width:29px;height:29px;border-radius:7px;background:var(--d3);border:1px solid var(--bs);color:var(--ts);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}
.xbtn:hover{color:var(--tp)}
.adm-bd{padding:1.2rem 1.4rem}
.adm-login{display:block}.adm-ctrl{display:none}.adm-ctrl.on{display:block}
.ainp,.apw,.asel,.ata{width:100%;background:var(--d3);border:1px solid var(--br);border-radius:7px;padding:.52rem .82rem;font-family:"Rajdhani",sans-serif;font-size:14px;font-weight:500;color:var(--tp);transition:border-color .2s}
.ainp:focus,.apw:focus,.asel:focus,.ata:focus{outline:none;border-color:var(--or)}
.ata{min-height:80px;resize:vertical}
.a-sec{background:var(--d3);border:1px solid var(--bs);border-radius:9px;padding:.88rem .95rem;margin-bottom:.75rem}
.a-sec-hd{font-family:"Cinzel",serif;font-size:.82rem;font-weight:700;color:var(--tp);margin-bottom:.6rem;display:flex;align-items:center;gap:.45rem}
.aci{width:20px;height:20px;object-fit:contain}
.a-row{display:grid;grid-template-columns:1fr 1fr;gap:.55rem}
.a-fld{margin-bottom:.82rem}
.abtn{width:100%;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.58rem 1.1rem;background:var(--or);color:#fff;font-family:"Rajdhani",sans-serif;font-size:13px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;border:none;border-radius:7px;cursor:pointer;transition:all .2s;margin-top:.38rem}
.abtn:hover{background:var(--ob)}.abtn.sec{background:var(--d3);color:var(--ts);border:1px solid var(--br);margin-top:.45rem}.abtn.sec:hover{color:var(--or);border-color:var(--od)}.abtn.danger{background:var(--er)}
.aerr{color:var(--er);font-size:11px;margin-top:.38rem;display:none}
.aok{color:var(--ok);font-size:11px;margin-top:.38rem;display:none}
.adm-tabs{display:flex;gap:.4rem;margin-bottom:1.1rem;border-bottom:1px solid var(--bs);flex-wrap:wrap}
.adm-tab{padding:.45rem .85rem;font-family:"Rajdhani",sans-serif;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--tm);cursor:pointer;border:none;background:transparent;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s}
.adm-tab:hover{color:var(--ts)}.adm-tab.on{color:var(--or);border-bottom-color:var(--or)}
.adm-pane{display:none}.adm-pane.on{display:block}

/* CELEBRATION - confetti full screen, box on top */
.cel-ov{display:none;position:fixed;inset:0;z-index:900;align-items:center;justify-content:center;padding:1.5rem;pointer-events:none;background:rgba(0,0,0,0)}
.cel-ov.open{display:flex;pointer-events:all;background:rgba(0,0,0,.5);transition:background .3s}
.cel-canvas{position:fixed;inset:0;width:100%;height:100%;pointer-events:none;z-index:900}
.cel-box{background:rgba(10,8,4,.97);border:2px solid var(--br);border-radius:20px;padding:2.5rem 2rem;text-align:center;max-width:460px;width:100%;position:relative;z-index:902;animation:mIn .4s ease;cursor:pointer;box-shadow:0 0 60px rgba(0,0,0,.9)}
.cel-cape{width:100px;height:100px;object-fit:contain;margin:0 auto .75rem;display:block;filter:drop-shadow(0 0 20px rgba(232,112,16,.6));animation:float 3s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.cel-title{font-family:"Cinzel",serif;font-size:1.5rem;font-weight:900;color:var(--or);margin-bottom:.3rem}
.cel-msg{font-size:.93rem;color:var(--tp);line-height:1.7;margin-bottom:1.5rem;font-family:"Crimson Pro",serif}

@media(max-width:680px){
  /* Layout */
  .home-hero{grid-template-columns:1fr}.nt-widget{display:none}.home-grid{grid-template-columns:1fr}
  .dp-header{flex-direction:column;gap:1rem}.dp-stats{grid-template-columns:1fr}
  .a-row{grid-template-columns:1fr}.cust-grid{grid-template-columns:1fr}.fb-grid{grid-template-columns:1fr}
  /* Nav — wrap to 2 rows: [brand | theme] then [scrollable tabs] */
  nav{display:flex;height:auto;flex-wrap:wrap;padding:.45rem .75rem;gap:.2rem}
  .nav-brand{flex:1;min-width:0;position:static}
  .nav-tabs{position:static;transform:none;max-width:100%;order:10;width:100%;padding:.2rem 0 .3rem;gap:2px}
  .nav-actions{order:1;position:static}
  .nav-tab{font-size:10px;padding:.22rem .45rem;white-space:nowrap}
  .nav-tab img{width:15px;height:15px}
  /* Backup section */
  .backup-inner{flex-direction:column;gap:.75rem;text-align:center}
  .backup-btns{flex-direction:row;justify-content:center}
}


/* ═══ ADMIN CUSTOM MILESTONES ═══ */
.cms-form{display:flex;flex-direction:column;gap:.1rem}
.cms-row{display:flex;gap:.75rem;align-items:flex-start}
.cms-emoji-inp{width:56px;text-align:center;font-size:1.2rem;padding:.35rem .4rem}
.cms-color-row{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.cms-color-picker{width:36px;height:28px;padding:0;border:1px solid var(--br);border-radius:5px;cursor:pointer;background:none;flex-shrink:0}
.cms-color-presets{display:flex;gap:.35rem;flex-wrap:wrap}
.cms-preset{display:inline-block;width:22px;height:22px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .15s,border-color .15s;flex-shrink:0}
.cms-preset:hover{transform:scale(1.25);border-color:var(--tp)}
.cust-ms-item{display:flex;align-items:center;gap:.75rem;padding:.55rem 0;border-bottom:1px solid var(--bs)}
.cust-ms-item:last-child{border-bottom:none}
.cust-ms-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;font-size:1.1rem;flex-shrink:0}
.cust-ms-info{flex:1;min-width:0}
.cust-ms-name{font-family:"Rajdhani",sans-serif;font-weight:700;font-size:.9rem;color:var(--tp)}
.cust-ms-desc{font-size:.78rem;color:var(--tm);margin-top:.1rem}

/* ═══ PROGRESS BACKUP ═══ */
.backup-section{max-width:1100px;margin:0 auto;padding:0 1.5rem 3rem}
.backup-inner{display:flex;align-items:center;gap:1.25rem;background:var(--d2);border:1px solid var(--bs);border-radius:14px;padding:1.1rem 1.4rem;flex-wrap:wrap}
.backup-icon{font-size:1.6rem;flex-shrink:0}
.backup-text{flex:1;min-width:180px}
.backup-title{font-family:"Rajdhani",sans-serif;font-size:.92rem;font-weight:700;color:var(--tp);letter-spacing:.04em}
.backup-sub{font-size:.8rem;color:var(--tm);margin-top:.18rem;line-height:1.5}
.backup-btns{display:flex;gap:.5rem;flex-shrink:0}
.backup-btn{font-size:12px;padding:.38rem .85rem}

/* ═══ MILESTONE ANIMATIONS ═══ */
@keyframes badgeUnlock {
  0%   { transform: scale(0) rotate(-180deg); opacity: 0; }
  60%  { transform: scale(1.25) rotate(8deg); opacity: 1; }
  80%  { transform: scale(0.92) rotate(-4deg); }
  100% { transform: scale(1) rotate(0deg); opacity: 1; }
}
@keyframes toastPop {
  0%   { transform: translateX(-50%) translateY(20px) scale(0.85); opacity: 0; }
  60%  { transform: translateX(-50%) translateY(-4px) scale(1.05); opacity: 1; }
  100% { transform: translateX(-50%) translateY(0) scale(1); opacity: 1; }
}
@keyframes toastFadeOut {
  0%   { transform: translateX(-50%) scale(1); opacity: 1; }
  100% { transform: translateX(-50%) scale(0.9); opacity: 0; }
}
@keyframes weeklyFlash {
  0%,100% { box-shadow: none; }
  30%      { box-shadow: 0 0 0 3px var(--green), 0 0 24px rgba(34,197,94,.5); }
}
@keyframes progressPulse {
  0%   { transform: scaleX(1); }
  50%  { transform: scaleX(1.02); filter: brightness(1.3); }
  100% { transform: scaleX(1); }
}
.milestone-badge.anim-in {
  animation: badgeUnlock 0.65s cubic-bezier(0.34,1.56,0.64,1) both;
}
.weekly-flash { animation: weeklyFlash 0.9s ease; }
.prog-fill-anim { animation: progressPulse 0.5s ease; }


/* ═══ MILESTONE BIG UNLOCK OVERLAY ═══ */
#ms-unlock-ov{
  display:none;position:fixed;inset:0;z-index:1000;
  background:rgba(0,0,0,.82);backdrop-filter:blur(10px);
  align-items:center;justify-content:center;
  cursor:pointer;
}
#ms-unlock-ov.open{display:flex;animation:msOvIn .35s ease both}
#ms-unlock-ov.closing{animation:msOvOut .45s ease both}
@keyframes msOvIn{from{opacity:0}to{opacity:1}}
@keyframes msOvOut{from{opacity:1}to{opacity:0}}

#ms-unlock-box{
  position:relative;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:1rem;
  padding:2.5rem 3rem;
  background:linear-gradient(145deg,var(--d2),var(--d3));
  border:1px solid var(--or);border-radius:24px;
  box-shadow:0 0 80px rgba(232,112,16,.35),0 0 200px rgba(232,112,16,.15),inset 0 1px 0 rgba(255,255,255,.06);
  max-width:380px;width:90vw;
}
#ms-unlock-ov.closing #ms-unlock-box{
  animation:msBoxOut .45s cubic-bezier(.55,.06,.68,.19) both;
}
@keyframes msBoxOut{to{transform:scale(.85);opacity:0}}

#ms-unlock-label{
  font-family:Cinzel,serif;font-size:.75rem;font-weight:700;letter-spacing:.25em;
  text-transform:uppercase;color:var(--or);
  animation:msTitleIn .5s .15s ease both;
}
#ms-unlock-ring{position:relative;width:160px;height:160px;flex-shrink:0}
#ms-unlock-badge-wrap{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
}
#ms-unlock-badge{
  width:130px;height:130px;
  animation:msBadgeDrop .8s .1s cubic-bezier(.34,1.56,.64,1) both;
  filter:drop-shadow(0 0 24px rgba(232,112,16,.9)) drop-shadow(0 0 60px rgba(232,112,16,.4));
}
#ms-unlock-glow{
  position:absolute;inset:-20px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,112,16,.25),transparent 70%);
  animation:msGlow 1.8s .3s ease-in-out infinite alternate;
}
#ms-unlock-title{
  font-family:Cinzel,serif;font-size:1.35rem;font-weight:900;color:var(--tp);letter-spacing:.04em;
  animation:msTitleIn .5s .35s ease both;
}
#ms-unlock-desc{
  font-family:"Crimson Pro",serif;font-style:italic;font-size:.95rem;color:var(--ts);
  animation:msTitleIn .5s .5s ease both;
}
#ms-unlock-hint{
  font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--tm);margin-top:.5rem;
  animation:msHintPulse 1.6s .8s ease-in-out infinite alternate;
}
@keyframes msBadgeDrop{
  0%  {transform:scale(0) rotate(-180deg);opacity:0}
  60% {transform:scale(1.25) rotate(12deg);opacity:1}
  80% {transform:scale(.92) rotate(-6deg)}
  90% {transform:scale(1.06) rotate(3deg)}
  100%{transform:scale(1) rotate(0deg);opacity:1}
}
@keyframes msGlow{
  from{transform:scale(.9);opacity:.6}
  to  {transform:scale(1.15);opacity:1}
}
@keyframes msTitleIn{
  from{transform:translateY(16px);opacity:0}
  to  {transform:translateY(0);opacity:1}
}
@keyframes msHintPulse{from{opacity:.35}to{opacity:.7}}
@keyframes msPart{
  0%  {transform:translate(0,0) scale(1);opacity:1}
  100%{transform:translate(calc(cos(var(--ang))*var(--dist)),calc(sin(var(--ang))*var(--dist))) scale(0);opacity:0}
}

