.app-shell{flex-direction:column;gap:18px;width:100%;max-width:760px;margin:0 auto;padding:22px 16px 64px;display:flex}.card{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:var(--radius);box-shadow:var(--shadow);background:#ffffffdb;border:1.5px solid #ffffffe6;padding:22px}.section-title{align-items:center;gap:8px;margin-bottom:14px;font-size:1.15rem;display:flex}.app-header{flex-direction:column;gap:14px;display:flex}.header-top{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.header-brand{align-items:center;gap:14px;display:flex}.crown-name{font-family:var(--font-display);background:linear-gradient(120deg, var(--accent), var(--accent-2));color:#0000;-webkit-background-clip:text;background-clip:text;font-size:1.9rem;font-weight:800;line-height:1.1}.header-date{color:var(--ink-soft);font-size:.9rem;font-weight:500}.header-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.chip{background:var(--white);border:1.5px solid var(--line);color:var(--ink);box-shadow:var(--shadow);border-radius:999px;align-items:center;gap:6px;padding:7px 14px;font-size:.82rem;font-weight:700;display:inline-flex}.chip.role-admin{background:var(--purple-soft);border-color:#0000}.chip.role-student{background:var(--pink-soft);border-color:#0000}.navlink,.signout-btn{box-shadow:var(--shadow);border:none;border-radius:999px;align-items:center;gap:6px;padding:8px 16px;font-size:.82rem;font-weight:800;text-decoration:none;transition:transform .12s,box-shadow .12s;display:inline-flex}.navlink{background:var(--accent-2);color:#fff}.signout-btn{background:var(--white);color:var(--ink);border:1.5px solid var(--line)}.navlink:hover,.signout-btn:hover{transform:translateY(-2px)}.navlink:active,.signout-btn:active{transform:scale(.96)}.mascot{filter:drop-shadow(0 8px 12px #965aa040);-webkit-user-select:none;user-select:none}.brand-logo{object-fit:contain;filter:drop-shadow(0 8px 14px #965aa04d);border-radius:20px;flex-shrink:0;width:96px;height:96px}@media (width<=540px){.brand-logo{width:76px;height:76px}}.stats-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.stat-card{border-radius:var(--radius-md);text-align:center;box-shadow:inset 0 1px 0 #fff9, var(--shadow);border:1.5px solid #ffffffb3;padding:16px 10px;position:relative;overflow:hidden}.stat-emoji{font-size:1.7rem;line-height:1}.stat-value{font-family:var(--font-display);margin-top:4px;font-size:1.7rem;font-weight:800}.stat-label{color:var(--ink-soft);margin-top:2px;font-size:.78rem;font-weight:700}.tone-star{background:linear-gradient(160deg,#fff4cf,#ffe49a)}.tone-purple{background:linear-gradient(160deg,#f1e9ff,#ddcaff)}.tone-pink{background:linear-gradient(160deg,#ffe3ee,#ffc6db)}.tone-mint{background:linear-gradient(160deg,#ddf6ec,#bdeed8)}.progress{margin-top:16px}.progress-track{background:var(--purple-soft);border-radius:999px;height:16px;overflow:hidden;box-shadow:inset 0 2px 4px #965aa02e}.progress-fill{background:linear-gradient(90deg, var(--accent), var(--accent-2), var(--pink));background-size:200% 100%;border-radius:999px;height:100%;animation:2.5s linear infinite shimmer}.progress-label{text-align:center;color:var(--ink-soft);margin-top:8px;font-size:.85rem;font-weight:700;display:block}.timer-main{flex-direction:column;align-items:center;gap:8px;padding:8px 0 4px;display:flex}.timer-clock{font-family:var(--font-display);letter-spacing:1px;font-variant-numeric:tabular-nums;color:var(--ink);font-size:2.8rem;font-weight:800}.timer-status{color:var(--ink-soft);align-items:center;gap:8px;font-weight:700;display:inline-flex}.live-dot{background:var(--accent);border-radius:50%;width:11px;height:11px;animation:1.6s ease-out infinite pulse-ring}.timer-today{color:var(--ink-soft);margin-top:2px;font-size:.9rem;font-weight:700}.timer-today b{color:var(--accent-2);font-size:1.05rem}.btn-timer{border-radius:var(--radius-md);width:100%;font-family:var(--font-display);color:#fff;box-shadow:var(--shadow);border:none;margin-top:12px;padding:18px;font-size:1.2rem;font-weight:800;transition:transform .12s,filter .12s}.btn-timer.start{background:linear-gradient(140deg,#34d399,#10b981)}.btn-timer.stop{background:linear-gradient(140deg, var(--accent), #e11d6b)}.btn-timer:hover{filter:brightness(1.03);transform:translateY(-2px)}.btn-timer:active{transform:scale(.97)}.btn-timer:disabled{filter:grayscale(.4)opacity(.7);transform:none}.sessions{flex-direction:column;gap:8px;margin-top:16px;display:flex}.sessions-title{color:var(--ink-soft);font-size:.82rem;font-weight:800}.session-row{background:var(--cream);border:1.5px solid var(--line);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:9px 14px;font-size:.86rem;font-weight:600;display:flex}.session-row .dur{color:var(--accent-2);font-variant-numeric:tabular-nums;font-weight:800}.session-row.live{border-color:var(--accent);background:#fff0f5}.today-status{border-radius:var(--radius-md);justify-content:center;align-items:center;gap:10px;margin-bottom:14px;padding:12px;font-size:1rem;font-weight:800;display:flex}.actions{grid-template-columns:1fr 1fr 1fr;gap:12px;display:grid}.action-btn{border-radius:var(--radius-md);font-family:var(--font-display);color:#fff;border:none;flex-direction:column;align-items:center;gap:6px;padding:18px 8px 16px;font-size:.95rem;font-weight:800;transition:transform .1s,box-shadow .1s,filter .1s;display:flex}.action-btn .big{font-size:1.8rem;line-height:1}.action-btn .count{opacity:.92;font-size:.74rem;font-weight:700}.action-btn:hover{transform:translateY(-3px)}.action-btn:active{transform:translateY(1px)scale(.97)}.action-btn:disabled{filter:grayscale(.5);opacity:.6;transform:none}.action-btn.is-complete{background:linear-gradient(150deg,#34d399,#10b981);box-shadow:0 6px #0c9b6e}.action-btn.is-joker{background:linear-gradient(150deg,#a78bfa,#7c3aed);box-shadow:0 6px #6428c4}.action-btn.is-miss{background:linear-gradient(150deg, #fb7aa0, var(--accent));box-shadow:0 6px #d8366d}.action-btn.is-complete:active,.action-btn.is-joker:active,.action-btn.is-miss:active{box-shadow:0 2px #00000026}.action-btn.active-pick{outline-offset:-3px;outline:3px solid #fff}.action-note{text-align:center;color:var(--ink-soft);margin-top:12px;font-size:.85rem;font-weight:700}.wheel-wrap{flex-direction:column;align-items:center;gap:14px;display:flex}.wheel-title{font-family:var(--font-display);text-align:center;font-size:1.35rem;font-weight:800}.wheel-sub{color:var(--ink-soft);text-align:center;font-size:.9rem;font-weight:600}.tier-filter{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.tier-chip{border:1.5px solid var(--line);background:var(--white);color:var(--ink);border-radius:999px;padding:6px 13px;font-size:.8rem;font-weight:800;transition:transform .1s}.tier-chip[data-on=true]{color:#fff;border-color:#0000}.tier-chip:active{transform:scale(.95)}.wheel-stage{width:280px;height:280px;position:relative}.wheel-pointer{z-index:3;border-left:16px solid #0000;border-right:16px solid #0000;border-top:26px solid var(--accent);filter:drop-shadow(0 4px 4px #0003);width:0;height:0;position:absolute;top:-12px;left:50%;transform:translate(-50%)}.wheel-svg{width:280px;height:280px;box-shadow:var(--shadow-lg), inset 0 0 0 8px #ffffffd9;background:#fff;border-radius:50%}.wheel-hub{width:54px;height:54px;box-shadow:var(--shadow);z-index:2;background:#fff;border-radius:50%;place-items:center;font-size:1.6rem;display:grid;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.spin-btn{font-family:var(--font-display);color:#fff;background:linear-gradient(140deg, var(--accent), var(--accent-2));box-shadow:var(--shadow);border:none;border-radius:999px;padding:14px 30px;font-size:1.05rem;font-weight:800;transition:transform .12s}.spin-btn:hover{transform:translateY(-2px)}.spin-btn:active{transform:scale(.96)}.spin-btn:disabled{opacity:.6}.reveal{text-align:center;flex-direction:column;align-items:center;gap:12px;display:flex}.reveal-emoji{font-size:3rem}.reveal-title{font-family:var(--font-display);font-size:1.5rem;font-weight:800}.reveal-desc{color:var(--ink);font-weight:600;line-height:1.7}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#5b4b6b73;justify-content:center;align-items:center;padding:18px;display:flex;position:fixed;inset:0}.modal-card{background:var(--cream);border-radius:var(--radius);box-shadow:var(--shadow-lg);border:2px solid #fff;width:100%;max-width:420px;max-height:90svh;padding:26px;overflow-y:auto}.modal-card.wide{max-width:480px}.joker-modal{text-align:center;flex-direction:column;align-items:center;gap:10px;display:flex}.joker-modal .big-joker{font-size:4rem}.joker-modal h2{font-size:1.6rem}.joker-modal p{color:var(--ink-soft);font-weight:600}.btn{border-radius:var(--radius-sm);font-family:var(--font-display);box-shadow:var(--shadow);border:none;padding:13px 22px;font-size:1rem;font-weight:800;transition:transform .12s,filter .12s}.btn:hover{transform:translateY(-2px)}.btn:active{transform:scale(.96)}.btn-primary{background:linear-gradient(140deg, var(--accent), var(--accent-2));color:#fff}.btn-ghost{background:var(--white);color:var(--ink);border:1.5px solid var(--line);box-shadow:none}.btn-danger{background:linear-gradient(140deg, var(--accent), #e11d6b);color:#fff}.btn-block{width:100%}.confirm{text-align:center;flex-direction:column;gap:8px;display:flex}.confirm h2{font-size:1.4rem}.confirm p{color:var(--ink-soft);font-weight:600}.confirm-actions{gap:10px;margin-top:12px;display:flex}.confirm-actions .btn{flex:1}.tier-badge{border-radius:999px;align-items:center;gap:5px;padding:4px 11px;font-size:.78rem;font-weight:800;display:inline-flex}.cal-head{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.cal-title{font-family:var(--font-display);font-size:1.2rem;font-weight:800}.cal-nav-btn{border:1.5px solid var(--line);background:var(--white);width:38px;height:38px;color:var(--ink);border-radius:50%;place-items:center;font-size:1.1rem;font-weight:800;transition:transform .1s;display:grid}.cal-nav-btn:hover:not(:disabled){background:var(--pink-soft);transform:scale(1.08)}.cal-nav-btn:disabled{opacity:.35}.cal-weekdays,.cal-grid{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.cal-weekdays{margin-bottom:6px}.cal-weekday{text-align:center;color:var(--ink-soft);padding-bottom:2px;font-size:.72rem;font-weight:800}.cal-cell{aspect-ratio:1;border:1.5px solid var(--line);background:var(--white);border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:1px;padding:2px;font-weight:700;transition:transform .1s;display:flex;position:relative}.cal-cell.has-log{cursor:pointer}.cal-cell.has-log:hover{transform:translateY(-2px)scale(1.04)}.cal-cell.is-outside{opacity:.32}.cal-cell.is-today{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}.cal-daynum{font-variant-numeric:tabular-nums;font-size:.82rem}.cal-icon{font-size:.95rem;line-height:1}.cal-hours{color:var(--accent-2);background:var(--purple-soft);border-radius:999px;padding:0 5px;font-size:.6rem;font-weight:800;line-height:1.4}.cal-legend{flex-wrap:wrap;justify-content:center;gap:14px;margin-top:14px;display:flex}.cal-legend span{color:var(--ink-soft);align-items:center;gap:4px;font-size:.76rem;font-weight:700;display:inline-flex}.day-detail{text-align:center;flex-direction:column;gap:12px;display:flex}.day-detail .dd-date{color:var(--ink-soft);font-weight:700}.day-detail .dd-status{font-family:var(--font-display);font-size:1.5rem;font-weight:800}.day-detail .dd-conseq{background:var(--white);border:1.5px solid var(--line);border-radius:var(--radius-sm);text-align:start;flex-direction:column;gap:8px;padding:14px;display:flex}.rules{padding:6px 22px}.rules summary{cursor:pointer;font-family:var(--font-display);align-items:center;gap:8px;padding:14px 0;font-size:1.1rem;font-weight:800;list-style:none;display:flex}.rules summary::-webkit-details-marker{display:none}.rules summary:after{content:"▾";color:var(--ink-soft);margin-inline-start:auto;transition:transform .2s}.rules[open] summary:after{transform:rotate(180deg)}.rules-body{flex-direction:column;gap:10px;padding-bottom:16px;display:flex}.rules-body li{line-height:1.8}.rules-body ul{margin:0;padding-inline-start:20px}.app-footer{justify-content:center;padding-top:4px;display:flex}.login-screen{place-items:center;min-height:100svh;padding:20px;display:grid}.login-card{text-align:center;flex-direction:column;gap:14px;width:100%;max-width:380px;display:flex}.login-logo{font-family:var(--font-display);background:linear-gradient(120deg, var(--accent), var(--accent-2));color:#0000;-webkit-background-clip:text;background-clip:text;font-size:2.2rem;font-weight:800}.login-logo-img{object-fit:contain;filter:drop-shadow(0 14px 22px #965aa052);align-self:center;width:132px;height:132px;animation:4s ease-in-out infinite float}.login-tag{color:var(--ink-soft);margin-top:-2px;font-weight:600}.field{text-align:start;flex-direction:column;gap:6px;display:flex}.field label{font-size:.85rem;font-weight:800}.input{border:1.5px solid var(--line);border-radius:var(--radius-sm);font-family:var(--font-body);background:var(--white);color:var(--ink);width:100%;padding:13px 16px;font-size:1rem;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--accent-2);box-shadow:0 0 0 4px var(--purple-soft);outline:none}.login-error{background:var(--pink-soft);color:var(--accent);border-radius:var(--radius-sm);padding:10px;font-size:.88rem;font-weight:700}.admin-list{flex-direction:column;gap:10px;display:flex}.conseq-row{background:var(--white);border:1.5px solid var(--line);border-radius:var(--radius-sm);align-items:center;gap:12px;padding:12px 14px;display:flex}.conseq-row[data-off=true]{opacity:.5}.conseq-main{flex:1;min-width:0}.conseq-title{flex-wrap:wrap;align-items:center;gap:8px;font-weight:800;display:flex}.conseq-desc{color:var(--ink-soft);margin-top:3px;font-size:.84rem}.conseq-actions{align-items:center;gap:6px;display:flex}.icon-btn{border:1.5px solid var(--line);background:var(--white);border-radius:12px;place-items:center;width:36px;height:36px;font-size:1rem;transition:transform .1s,background .1s;display:grid}.icon-btn:hover{background:var(--pink-soft);transform:scale(1.08)}.icon-btn:active{transform:scale(.94)}.icon-btn:disabled{opacity:.35}.toggle{background:var(--line);border:none;border-radius:999px;flex:none;width:46px;height:27px;transition:background .18s;position:relative}.toggle[data-on=true]{background:#34d399}.toggle:after{content:"";top:3px;background:#fff;border-radius:50%;width:21px;height:21px;transition:transform .18s;position:absolute;inset-inline-start:3px;box-shadow:0 1px 3px #00000040}.toggle[data-on=true]:after{transform:translate(-19px)}.form-grid{flex-direction:column;gap:14px;display:flex}.form-actions{gap:10px;margin-top:4px;display:flex}.form-actions .btn{flex:1}.admin-toolbar{justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px;display:flex}.seg{gap:8px;display:flex}.seg-btn{border:1.5px solid var(--line);background:var(--white);border-radius:var(--radius-sm);color:var(--ink);flex:1;padding:11px;font-weight:800;transition:transform .1s}.seg-btn[data-on=true]{color:#fff;border-color:#0000}.seg-btn:active{transform:scale(.96)}.center-screen{text-align:center;place-items:center;min-height:100svh;padding:24px;display:grid}.spinner{border:5px solid var(--purple-soft);border-top-color:var(--accent-2);border-radius:50%;width:46px;height:46px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.setup-card{text-align:start;max-width:540px;line-height:1.8}.setup-card code{background:var(--purple-soft);border-radius:6px;padding:2px 7px;font-size:.85em}.setup-card pre{color:#f3eafc;border-radius:var(--radius-sm);text-align:left;direction:ltr;background:#2c2438;padding:14px;font-size:.82rem;overflow-x:auto}.empty-hint{color:var(--ink-soft);text-align:center;padding:12px;font-weight:600}@media (width<=540px){.stats-grid{grid-template-columns:repeat(2,1fr)}.crown-name{font-size:1.6rem}.timer-clock{font-size:2.3rem}.action-btn{padding:14px 4px 12px;font-size:.82rem}.action-btn .big{font-size:1.5rem}.card{padding:18px}}:root{--peach:#fff5f0;--cream:#fffaf6;--pink:#ff8fb1;--pink-soft:#ffd9e6;--purple:#b388eb;--purple-soft:#ece4ff;--mint:#9de0c8;--mint-soft:#d6f5e6;--accent:#ff5d8f;--accent-2:#8b5cf6;--star:#ffce4a;--ink:#5b4b6b;--ink-soft:#9a8fa8;--line:#f0e6f2;--white:#fff;--radius:30px;--radius-md:22px;--radius-sm:15px;--shadow:0 12px 30px -14px #965aa052, 0 4px 12px -8px #965aa040;--shadow-lg:0 28px 64px -20px #965aa073;--shadow-press:0 4px 0 0 #965aa02e;--font-display:"Baloo Bhaijaan 2", system-ui, "Segoe UI", sans-serif;--font-body:"Tajawal", system-ui, "Segoe UI", sans-serif;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-family:var(--font-body);color:var(--ink)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{background:radial-gradient(1100px 600px at 100% -10%, var(--purple-soft), transparent 60%), radial-gradient(900px 520px at -5% 0%, var(--mint-soft), transparent 55%), radial-gradient(800px 600px at 50% 120%, var(--pink-soft), transparent 60%), linear-gradient(170deg, #fff5f0db, #ffeef6d1 55%, #f4efffe0), url(/background.webp) center / cover no-repeat;-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;background-attachment:fixed;min-height:100svh;margin:0;overflow-x:hidden}h1,h2,h3{font-family:var(--font-display);color:var(--ink);margin:0;line-height:1.2}p{margin:0}button{font-family:var(--font-body);cursor:pointer}button:disabled{cursor:not-allowed}a{color:var(--accent-2)}::selection{background:var(--pink-soft)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-9px)}}@keyframes pulse-ring{0%{box-shadow:0 0 #ff5d8f73}70%{box-shadow:0 0 0 14px #ff5d8f00}to{box-shadow:0 0 #ff5d8f00}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes blob{0%,to{transform:translate(0)scale(1)}50%{transform:translate(10px,-12px)scale(1.05)}}@media (prefers-reduced-motion:reduce){*{transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}
