@charset "UTF-8";*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}:root{--bg:#0a0a0f;--surface:#12121a;--surface2:#1a1a26;--border:#2a2a3d;--accent:#7c6cfc;--accent2:#fc6c8f;--accent3:#6cfcb8;--gold:#fccc6c;--text:#f0eeff;--muted:#6b6b8a;--font:"Space Grotesk",sans-serif;--display:"Syne",sans-serif}html{height:-webkit-fill-available}body{background:var(--bg);color:var(--text);font-family:var(--font);min-height:100dvh;min-height:-webkit-fill-available;overflow-x:hidden;overscroll-behavior:none}.ambient{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.ambient:before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(124,108,252,.07) 0%,transparent 70%);top:-200px;right:-100px}.ambient:after{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(108,252,184,.05) 0%,transparent 70%);bottom:-100px;left:-50px}.app{position:relative;z-index:1;max-width:480px;margin:0 auto;padding:20px 16px calc(80px + env(safe-area-inset-bottom,10px));overflow-x:hidden;width:100%}.header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;padding-top:env(safe-area-inset-top,8px)}.header h1{font-family:var(--display);font-size:28px;font-weight:800;letter-spacing:-.5px;line-height:1}.header h1 span{color:var(--accent)}.day-label{font-size:11px;color:var(--muted);margin-top:4px;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.countdown-wrap{text-align:right}.countdown-label{font-size:10px;color:var(--muted);margin-bottom:2px}.countdown{font-family:var(--display);font-size:15px;font-weight:800;color:var(--accent);font-variant-numeric:tabular-nums;min-width:5.5em;display:inline-block}.sync-bar{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);margin-bottom:14px;height:16px}.sync-dot{width:6px;height:6px;border-radius:50%;background:var(--muted);flex-shrink:0;transition:background .3s}.sync-dot.live{background:var(--accent3);animation:pulse 2s ease-in-out infinite}.sync-dot.saving{background:var(--gold);animation:pulse .5s ease-in-out infinite}.sync-dot.error{background:var(--accent2)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.char-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:16px;margin-bottom:16px;position:relative;overflow:hidden}.char-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent2),var(--accent3))}.char-top{display:flex;align-items:center;gap:14px;margin-bottom:14px}.avatar{width:50px;height:50px;border-radius:14px;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;position:relative}.level-badge{position:absolute;bottom:-4px;right:-4px;background:var(--gold);color:#1a1000;font-size:9px;font-weight:700;padding:2px 5px;border-radius:6px}.char-info h2{font-size:15px;font-weight:700;margin-bottom:1px}.char-class{font-size:11px;color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:.08em}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.stat{background:var(--surface2);border-radius:10px;padding:8px 10px}.stat-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}.stat-val{font-size:16px;font-weight:700}.stat-val.xp{color:var(--accent)}.stat-val.hp{color:var(--accent2)}.stat-val.gold{color:var(--gold)}.xp-bar-wrap{margin-top:12px}.xp-bar-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-bottom:4px}.xp-bar{height:6px;background:var(--surface2);border-radius:99px;overflow:hidden}.xp-bar-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .6s cubic-bezier(.34,1.56,.64,1)}.streak-banner{background:linear-gradient(135deg,#7c6cfc1f,#fc6c8f14);border:1px solid rgba(124,108,252,.25);border-radius:14px;padding:10px 14px;margin-bottom:16px;display:flex;align-items:center;gap:10px}.streak-fire{font-size:26px;animation:flicker 1.5s ease-in-out infinite}@keyframes flicker{0%,to{transform:scale(1) rotate(-2deg)}50%{transform:scale(1.08) rotate(2deg)}}.streak-count{font-family:var(--display);font-size:22px;font-weight:800;color:var(--gold)}.streak-sub{font-size:11px;color:var(--muted);margin-top:1px}.progress-section{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.ring-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:12px;display:flex;flex-direction:column;align-items:center;gap:6px}.ring-wrap{position:relative;width:68px;height:68px}.ring-svg{transform:rotate(-90deg)}.ring-bg{fill:none;stroke:var(--surface2);stroke-width:6}.ring-fill{fill:none;stroke-width:6;stroke-linecap:round;transition:stroke-dashoffset .7s cubic-bezier(.34,1.56,.64,1)}.ring-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.ring-pct{font-family:var(--display);font-size:15px;font-weight:800;line-height:1}.ring-sub{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.ring-title{font-size:11px;font-weight:600;color:var(--muted)}.section{margin-bottom:20px;overflow-x:hidden}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}.section-count{font-size:11px;color:var(--muted);background:var(--surface);border:1px solid var(--border);padding:2px 8px;border-radius:99px}.section-collapse-btn{background:transparent;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:11px;transition:color .2s}.section-collapse-btn:hover{color:var(--text)}.section-chevron{display:inline-block;transition:transform .2s}.section-chevron.open{transform:rotate(180deg)}.show-all-btn{background:#7c6cfc1a;border:1px solid rgba(124,108,252,.25);border-radius:8px;padding:3px 10px;font-family:var(--font);font-size:10px;font-weight:600;color:var(--accent);cursor:pointer;transition:all .2s;white-space:nowrap}.show-all-btn:hover{background:#7c6cfc33}.show-all-btn.active{background:#7c6cfc33;border-color:#7c6cfc80}.task{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:12px 14px;margin-bottom:7px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:border-color .2s,opacity .2s;position:relative;overflow:hidden;-webkit-user-select:none;user-select:none}.task:active{transform:scale(.98)}.task.done{opacity:.45}.task.done .task-name{text-decoration:line-through;color:var(--muted)}.task-check{width:24px;height:24px;border-radius:7px;border:2px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .25s cubic-bezier(.34,1.56,.64,1)}.task.done .task-check{background:var(--accent3);border-color:var(--accent3)}.check-icon{opacity:0;transform:scale(0);transition:all .2s cubic-bezier(.34,1.56,.64,1);font-size:12px;color:#0a1a10}.task.done .check-icon{opacity:1;transform:scale(1)}.task-body{flex:1;min-width:0}.task-name{font-size:13px;font-weight:500;transition:all .2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-meta{display:flex;align-items:center;gap:5px;margin-top:3px;flex-wrap:wrap}.pill{font-size:10px;font-weight:600;padding:1px 7px;border-radius:99px}.pill-xp{background:#7c6cfc24;color:var(--accent)}.pill-gold{background:#fccc6c24;color:var(--gold)}.pill-streak{background:#fccc6c1a;color:var(--gold)}.pill-p1{background:#fc6c8f26;color:var(--accent2)}.pill-p2{background:#fccc6c1f;color:var(--gold)}.pill-p3{background:#7c6cfc1f;color:var(--accent)}.pill-p4{background:#6b6b8a1f;color:var(--muted)}.task-notes{font-size:11px;color:var(--muted);margin-top:4px;line-height:1.4;white-space:pre-wrap;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.diff-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.diff-easy{background:var(--accent3)}.diff-med{background:var(--gold)}.diff-hard{background:var(--accent2)}@keyframes ripple{0%{transform:scale(0);opacity:.5}to{transform:scale(5);opacity:0}}.ripple{position:absolute;border-radius:50%;background:var(--accent3);width:40px;height:40px;margin-left:-20px;margin-top:-20px;animation:ripple .5s ease-out forwards;pointer-events:none}@keyframes xpPop{0%{transform:translateY(0) scale(1);opacity:1}to{transform:translateY(-55px) scale(.7);opacity:0}}.xp-popup{position:fixed;font-family:var(--display);font-size:17px;font-weight:800;color:var(--accent3);pointer-events:none;z-index:999;animation:xpPop .85s ease-out forwards;text-shadow:0 0 16px rgba(108,252,184,.6)}@keyframes toastIn{0%{transform:translate(-50%) translateY(20px);opacity:0}12%{transform:translate(-50%) translateY(0);opacity:1}88%{transform:translate(-50%) translateY(0);opacity:1}to{transform:translate(-50%) translateY(-10px);opacity:0}}.toast{position:fixed;bottom:82px;left:50%;transform:translate(-50%);background:var(--surface2);border:1px solid var(--border);border-radius:14px;padding:10px 16px;font-size:13px;font-weight:500;z-index:200;white-space:nowrap;animation:toastIn 2.8s ease forwards;pointer-events:none;max-width:90vw;overflow:hidden;text-overflow:ellipsis}.tabbar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;background:#12121af5;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);padding:8px 0 calc(env(safe-area-inset-bottom,10px) + 2px);display:flex;justify-content:space-around;z-index:100;will-change:transform}.tab-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:5px 10px;cursor:pointer;opacity:.38;transition:opacity .2s;flex:1;min-width:0}.tab-btn.active{opacity:1}.tab-icon{font-size:19px;line-height:1}.tab-lbl{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.tab-pane{display:none}.tab-pane.active{display:block}.week-row{display:flex;gap:6px;margin-bottom:16px}.day-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.day-circle{width:34px;height:34px;border-radius:50%;background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;transition:all .3s}.day-circle.done{background:linear-gradient(135deg,var(--accent),var(--accent2));border-color:transparent}.day-circle.today{border-color:var(--accent);box-shadow:0 0 0 2px #7c6cfc4d}.day-name{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.bar-row{margin-bottom:10px}.bar-label-row{display:flex;justify-content:space-between;font-size:12px;margin-bottom:4px}.bar-pct{font-weight:600}.bar-track{height:8px;background:var(--surface2);border-radius:99px;overflow:hidden}.bar-fill{height:100%;border-radius:99px;transition:width .6s cubic-bezier(.34,1.56,.64,1)}.goal-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px;margin-bottom:8px}.goal-title{font-size:14px;font-weight:600;margin-bottom:4px}.goal-desc{font-size:12px;color:var(--muted);margin-bottom:8px}.goal-bar{height:5px;background:var(--surface2);border-radius:99px;overflow:hidden;margin-bottom:6px}.goal-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent3),var(--accent));border-radius:99px;transition:width .6s ease}.reward-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.reward-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px;text-align:center;cursor:pointer;transition:all .2s}.reward-card:active{transform:scale(.95)}.reward-icon{font-size:26px;margin-bottom:5px}.reward-name{font-size:12px;font-weight:600;margin-bottom:2px}.reward-desc{font-size:10px;color:var(--muted);margin-bottom:6px}.reward-cost{font-size:11px;color:var(--gold);font-weight:600}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;transition:opacity .4s}.loading-overlay.hidden{opacity:0;pointer-events:none}.loading-logo{font-family:var(--display);font-size:36px;font-weight:800}.loading-logo span{color:var(--accent)}.loading-dots{display:flex;gap:6px}.loading-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:dotPulse 1.2s ease-in-out infinite}.loading-dot:nth-child(2){animation-delay:.2s;background:var(--accent2)}.loading-dot:nth-child(3){animation-delay:.4s;background:var(--accent3)}@keyframes dotPulse{0%,to{transform:scale(.6);opacity:.4}50%{transform:scale(1);opacity:1}}.loading-msg{font-size:12px;color:var(--muted)}.user-btn{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0;position:relative;transition:transform .15s}.user-btn:hover{transform:scale(1.08)}.user-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface2);border:1px solid var(--border);border-radius:14px;min-width:180px;z-index:200;box-shadow:0 8px 32px #0006;overflow:hidden;display:none}.user-menu.open{display:block}.user-menu-header{padding:12px 14px;border-bottom:1px solid var(--border)}.user-menu-name{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-menu-email{font-size:11px;color:var(--muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-menu-item{display:flex;align-items:center;gap:9px;padding:10px 14px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s;border:none;background:transparent;color:var(--text);width:100%;text-align:left}.user-menu-item:hover{background:var(--surface)}.user-menu-item.danger{color:var(--accent2)}.user-menu-sep{height:1px;background:var(--border);margin:4px 0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:500;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s}.modal-overlay.open{opacity:1;pointer-events:all}.modal{background:var(--surface);border:1px solid var(--border);border-radius:22px 22px 0 0;width:100%;max-width:480px;padding:24px 20px 36px;transform:translateY(40px);transition:transform .3s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}.modal-overlay.open .modal{transform:translateY(0)}.modal:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent2))}.modal-handle{width:36px;height:4px;border-radius:99px;background:var(--border);margin:0 auto 20px}.modal-title{font-family:var(--display);font-size:18px;font-weight:800;margin-bottom:4px}.modal-sub{font-size:13px;color:var(--muted);margin-bottom:20px;line-height:1.5}.modal-input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:11px 14px;font-family:var(--font);font-size:14px;color:var(--text);outline:none;margin-bottom:14px;transition:border-color .2s}.modal-input:focus{border-color:var(--accent)}.modal-btn{width:100%;padding:13px;border-radius:12px;font-family:var(--font);font-size:14px;font-weight:700;cursor:pointer;border:none;transition:opacity .2s,transform .15s;margin-bottom:10px}.modal-btn:hover{opacity:.88;transform:translateY(-1px)}.modal-btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff}.modal-btn.danger{background:#fc6c8f1f;color:var(--accent2);border:1px solid rgba(252,108,143,.25)}.modal-btn.ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}.admin-user-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px;margin-bottom:8px}.admin-user-row{display:flex;align-items:center;gap:10px}.admin-avatar{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.admin-user-name{font-size:14px;font-weight:600}.admin-user-email{font-size:11px;color:var(--muted);margin-top:1px}.admin-user-stats{display:flex;gap:12px;margin-top:8px;flex-wrap:wrap}.admin-stat{font-size:11px;color:var(--muted)}.admin-stat strong{color:var(--text);font-weight:600}.admin-badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:99px;background:#fccc6c24;color:var(--gold);margin-left:6px}.add-btn{width:26px;height:26px;border-radius:8px;background:#7c6cfc26;border:1px solid rgba(124,108,252,.3);color:var(--accent);font-size:18px;font-weight:400;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .15s;flex-shrink:0}.add-btn:hover{background:#7c6cfc47;transform:scale(1.1)}.task-actions{display:flex;gap:4px;flex-shrink:0}.task-action-btn{width:26px;height:26px;border-radius:7px;border:none;background:transparent;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:background .15s;color:var(--muted)}.task-action-btn:hover{background:var(--surface2);color:var(--text)}.task-action-btn.danger:hover{background:#fc6c8f1f;color:var(--accent2)}.task-edit-btn{opacity:1}.task-delete-btn{display:none}@media(min-width:1025px){.task-actions{opacity:0;transition:opacity .15s}.task:hover .task-actions{opacity:1}.task-delete-btn{display:flex}}.task-subtask-wrap{padding-left:34px;margin-top:-3px}.task.subtask{background:var(--surface2);border-color:transparent;border-left:2px solid var(--border);border-radius:0 14px 14px 0;margin-bottom:3px;padding:8px 12px}.task.subtask .task-name{font-size:12px}.subtask-progress{font-size:10px;color:var(--muted);margin-left:4px}.modal-subtask-row{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;margin-bottom:6px}.modal-subtask-name{font-size:13px;font-weight:500;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-del-confirm{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--accent2);font-weight:600}.task-del-confirm button{padding:2px 8px;border-radius:6px;border:none;cursor:pointer;font-size:11px;font-weight:700;font-family:var(--font)}.task-del-yes{background:#fc6c8f26;color:var(--accent2)}.task-del-no{background:var(--surface2);color:var(--muted)}.modal-field-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;display:block;margin-bottom:8px}.modal-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}.modal-input-sm{margin-bottom:0}.diff-picker{display:flex;gap:6px;margin-bottom:14px}.diff-btn{flex:1;padding:8px 4px;border-radius:10px;border:1px solid var(--border);background:var(--surface2);color:var(--muted);font-family:var(--font);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;text-align:center}.diff-btn.active[data-diff=easy]{background:#6cfcb81f;border-color:#6cfcb866;color:var(--accent3)}.diff-btn.active[data-diff=med]{background:#fccc6c1f;border-color:#fccc6c66;color:var(--gold)}.diff-btn.active[data-diff=hard]{background:#fc6c8f1f;border-color:#fc6c8f66;color:var(--accent2)}.day-picker{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:14px}.day-btn{display:flex;align-items:center;justify-content:center}.day-btn input[type=checkbox]{display:none}.day-btn span{display:block;padding:5px 8px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--muted);font-size:11px;font-weight:600;cursor:pointer;transition:all .2s;min-width:36px;text-align:center}.day-btn input:checked+span{background:#7c6cfc2e;border-color:#7c6cfc80;color:var(--accent)}.priority-picker{display:flex;gap:6px;margin-bottom:14px}.priority-btn{flex:1;padding:8px 4px;border-radius:10px;border:1px solid var(--border);background:var(--surface2);color:var(--muted);font-family:var(--font);font-size:12px;font-weight:700;cursor:pointer;transition:all .2s}.priority-btn.active[data-p=P1]{background:#fc6c8f1f;border-color:#fc6c8f66;color:var(--accent2)}.priority-btn.active[data-p=P2]{background:#fccc6c1f;border-color:#fccc6c66;color:var(--gold)}.priority-btn.active[data-p=P3]{background:#7c6cfc1f;border-color:#7c6cfc66;color:var(--accent)}.priority-btn.active[data-p=P4]{background:#12121a80;border-color:var(--border);color:var(--muted)}.archive-toggle{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-top:8px;cursor:pointer;font-size:13px;font-weight:600;color:var(--muted);transition:border-color .2s,color .2s;-webkit-user-select:none;user-select:none}.archive-toggle:hover{border-color:#7c6cfc4d;color:var(--text)}.archive-toggle-icon{font-size:15px}.archive-chevron{margin-left:auto;font-size:11px;transition:transform .2s}.archive-chevron.open{transform:rotate(180deg)}.archive-month-header{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;padding:12px 4px 6px;display:flex;align-items:center;gap:8px}.archive-month-count{background:var(--surface2);border-radius:99px;padding:2px 8px;font-size:11px}.archive-task{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:6px;opacity:.7}.archive-task-check{width:22px;height:22px;border-radius:7px;background:var(--accent3);color:var(--bg);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.archive-task-body{flex:1;min-width:0}.archive-task-name{font-size:13px;font-weight:600;text-decoration:line-through;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.streak-shield{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:700;color:var(--accent);background:#7c6cfc1f;border:1px solid rgba(124,108,252,.3);border-radius:8px;padding:3px 8px;margin-left:8px;cursor:default}.levelup-flash{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;pointer-events:none;display:flex;align-items:center;justify-content:center;animation:levelup-anim 1.2s ease-out forwards}@keyframes levelup-anim{0%{background:#7c6cfc59;opacity:1}to{background:transparent;opacity:0}}.levelup-text{font-family:var(--display);font-size:42px;font-weight:800;color:#fff;text-shadow:0 0 40px rgba(124,108,252,.8);animation:levelup-pop 1.2s ease-out forwards;text-align:center;line-height:1.2}@keyframes levelup-pop{0%{transform:scale(.5);opacity:0}20%{transform:scale(1.15);opacity:1}80%{transform:scale(1);opacity:1}to{transform:scale(.95);opacity:0}}.goals-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.goal-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px;margin-bottom:10px;position:relative;overflow:hidden}.goal-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent2))}.goal-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:8px}.goal-title{font-size:15px;font-weight:700;flex:1;min-width:0}.goal-actions{display:flex;gap:4px;flex-shrink:0}.goal-badges{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.goal-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:99px;text-transform:uppercase;letter-spacing:.05em}.goal-badge.cat{background:#7c6cfc1f;color:var(--accent);border:1px solid rgba(124,108,252,.25)}.goal-badge.diff-easy{background:#6cfcb81f;color:var(--accent3);border:1px solid rgba(108,252,184,.25)}.goal-badge.diff-med{background:#fccc6c1f;color:var(--gold);border:1px solid rgba(252,204,108,.25)}.goal-badge.diff-hard{background:#fc6c8f1f;color:var(--accent2);border:1px solid rgba(252,108,143,.25)}.goal-badge.diff-epic{background:#7c6cfc33;color:var(--accent);border:1px solid rgba(124,108,252,.4)}.goal-badge.horizon{background:var(--surface2);color:var(--muted);border:1px solid var(--border)}.goal-desc{font-size:12px;color:var(--muted);margin-bottom:8px;line-height:1.5}.goal-bar{height:4px;background:var(--border);border-radius:99px;margin:8px 0}.goal-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:99px;transition:width .5s}.goal-footer{display:flex;justify-content:space-between;font-size:11px;color:var(--muted)}.goal-rewards{display:flex;gap:8px;margin-top:8px}.goal-reward-pill{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:3px 8px;border-radius:99px}.goal-reward-pill.xp{background:#7c6cfc1a;color:var(--accent)}.goal-reward-pill.gold{background:#fccc6c1a;color:var(--gold)}.goal-subtasks{margin-top:10px;border-top:1px solid var(--border);padding-top:10px}.goal-subtask-title{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.subtask-row{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:13px;color:var(--muted)}.subtask-row.done{text-decoration:line-through;opacity:.6}.subtask-dot{width:8px;height:8px;border-radius:50%;background:var(--border);flex-shrink:0}.subtask-row.done .subtask-dot{background:var(--accent3)}.modal-select{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:11px 14px;font-family:var(--font);font-size:14px;color:var(--text);outline:none;transition:border-color .2s;margin-bottom:14px;-webkit-appearance:none;-moz-appearance:none;appearance:none}.modal-select:focus{border-color:var(--accent)}.goal-complete-btn{width:100%;background:linear-gradient(135deg,var(--accent3),#4db8a0);border:none;color:var(--bg);padding:11px;border-radius:10px;font-family:var(--font);font-size:13px;font-weight:700;cursor:pointer;margin-top:8px;transition:opacity .2s}.goal-complete-btn:hover{opacity:.88}.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.cal-nav-btn{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:6px 14px;font-family:var(--font);font-size:13px;font-weight:600;color:var(--text);cursor:pointer;transition:border-color .2s}.cal-nav-btn:hover{border-color:var(--accent)}.cal-month-label{font-family:var(--display);font-size:18px;font-weight:800}.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}.cal-weekday{text-align:center;font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;padding:4px 0}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;overflow-x:hidden}.cal-day{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:6px 4px;min-height:56px;cursor:pointer;transition:border-color .2s;position:relative}.cal-day:hover{border-color:#7c6cfc66}.cal-day.today{border-color:var(--accent);background:#7c6cfc12}.cal-day.other-month{opacity:.35}.cal-day.has-events{cursor:pointer}.cal-day-num{font-size:12px;font-weight:600;text-align:center;margin-bottom:4px;line-height:1}.cal-day.today .cal-day-num{color:var(--accent)}.cal-dots{display:flex;gap:2px;flex-wrap:wrap;justify-content:center}.cal-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.cal-dot.daily{background:var(--accent)}.cal-dot.weekly{background:var(--accent3)}.cal-dot.goal{background:var(--gold)}.cal-detail{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px;margin-top:12px;display:none}.cal-detail.open{display:block}.cal-detail-title{font-size:13px;font-weight:700;margin-bottom:10px;color:var(--muted)}.cal-detail-item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:13px;border-bottom:1px solid var(--border)}.cal-detail-item:last-child{border-bottom:none}.cal-detail-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.cal-routine-header{display:flex;align-items:center;justify-content:space-between;padding:8px 0;font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;cursor:pointer;border-bottom:1px solid var(--border);-webkit-user-select:none;user-select:none}.cal-routine-header:hover{color:var(--text)}.cal-detail-subtask{padding-left:22px}.cal-routine-chevron{background:none;border:none;color:var(--muted);font-size:12px;cursor:pointer;padding:0 4px;margin-left:6px;transition:transform .15s ease}.cal-routine-chevron.open{transform:rotate(90deg)}.cal-routine-chevron:hover{color:var(--text)}.leaderboard-toggle-row{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 14px;margin-bottom:14px}.leaderboard-toggle-label{font-size:13px;font-weight:600}.leaderboard-toggle-sub{font-size:11px;color:var(--muted);margin-top:2px}.toggle-switch{position:relative;width:40px;height:22px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border);border-radius:99px;cursor:pointer;transition:background .2s}.toggle-slider:before{content:"";position:absolute;width:16px;height:16px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s}.toggle-switch input:checked+.toggle-slider{background:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(18px)}.leaderboard-table{width:100%;border-collapse:collapse}.leaderboard-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:6px;transition:border-color .2s}.leaderboard-row.me{border-color:var(--accent);background:#7c6cfc0d}.lb-rank{font-family:var(--display);font-size:16px;font-weight:800;width:28px;text-align:center;flex-shrink:0;color:var(--muted)}.lb-rank.top1{color:var(--gold)}.lb-rank.top2{color:silver}.lb-rank.top3{color:#cd7f32}.lb-avatar{font-size:22px;flex-shrink:0}.lb-info{flex:1;min-width:0}.lb-name{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lb-sub{font-size:11px;color:var(--muted);margin-top:1px}.lb-stats{display:flex;gap:12px;flex-shrink:0;text-align:right}.lb-stat{font-size:12px;color:var(--muted)}.lb-stat strong{display:block;font-size:14px;font-weight:700;color:var(--text)}@media(min-width:769px){.app{max-width:680px;padding:24px 20px calc(80px + env(safe-area-inset-bottom,10px))}.tabbar{max-width:680px}.modal{max-width:600px}.header h1{font-size:32px}.progress-section{gap:14px}.reward-grid{grid-template-columns:repeat(3,1fr)}.cal-day{min-height:68px}.stats-row{gap:12px}.char-card{padding:20px}.leaderboard-row{padding:12px 16px}}@media(min-width:1025px){.app{max-width:780px;padding:28px 28px calc(80px + env(safe-area-inset-bottom,10px))}.tabbar{max-width:780px}.modal{max-width:640px}.header h1{font-size:34px}.progress-section{gap:16px}.cal-day{min-height:76px;padding:8px 6px}.cal-day-num{font-size:13px}.ring-wrap{width:80px;height:80px}.ring-pct{font-size:17px}.goal-card{padding:18px}.section-title{font-size:13px}}.archive-task-actions{display:flex;gap:4px;align-items:center}.archive-restore-btn{color:var(--accent3);font-size:14px;font-weight:700}.archive-restore-btn:hover{background:#2ec4b61f}.routine-chevron{font-size:12px;transition:transform .15s ease;color:var(--muted)}.routine-chevron.open{transform:rotate(90deg)}.routine-chevron:hover{color:var(--text)}
