@tailwind base;@tailwind components;@tailwind utilities;:root{--l0:#7c3aed;--l0l:#c4b5fd;--l0g:rgba(124,58,237,.13);--l0b:rgba(124,58,237,.22);--l2:#2563eb;--l2l:#3b82f6;--l2g:rgba(37,99,235,.11);--l3:#d97706;--l3l:#fcd34d;--l3g:rgba(217,119,6,.11);--l4:#db2777;--l4l:#f9a8d4;--l4g:rgba(219,39,119,.11);--l5:#0d9488;--l5l:#5eead4;--l5g:rgba(13,148,136,.12);--u:#d97706;--ul:#fcd34d;--ug:rgba(217,119,6,.1);--bg:#07071c;--bg2:#0d0d26;--bg3:#12122e;--bg4:#181840;--line:#1e1e48;--line2:#2a2a60;--ink:#f4f4ff;--ink2:#c8c8f0;--ink3:#8080b8;--ink4:#484878;--shadow:rgba(0,0,0,.5);--ff-d:"Bricolage Grotesque",sans-serif;--ff-h:"Bricolage Grotesque",sans-serif;--ff-b:"DM Sans",sans-serif;--ff-m:"JetBrains Mono",monospace;--radius-card:18px;--radius-btn:14px}[data-theme=light]{--bg:#f8f7ff;--bg2:#fff;--bg3:#f0eef9;--bg4:#e8e5f5;--line:#e0dcf5;--line2:#ccc8ee;--ink:#1a1a3e;--ink2:#3d3d6e;--ink3:#7070a0;--ink4:#a0a0c0;--shadow:rgba(100,80,200,.12)}*{box-sizing:border-box;padding:0;margin:0}body,html{max-width:100vw;overflow-x:hidden;font-family:var(--ff-b);background:var(--bg);color:var(--ink)}a{color:inherit;text-decoration:none}.shell{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--bg)}.top-bar{height:54px;flex-shrink:0;background:var(--bg2);border-bottom:1.5px solid var(--line);display:flex;align-items:center;padding:0 20px;gap:16px;transition:background .3s}@media(max-width:768px){.top-bar{display:none}}.top-logo{font-family:var(--ff-d);font-size:18px;font-weight:800;color:var(--ink);letter-spacing:-.03em;flex-shrink:0}.top-logo span{color:var(--l0l)}.top-nav{gap:2px;flex:1 1}.top-btn,.top-nav{display:flex;align-items:center}.top-btn{gap:6px;padding:6px 12px;border-radius:9px;font-family:var(--ff-b);font-size:13px;font-weight:500;color:var(--ink3);text-decoration:none;transition:all .18s;white-space:nowrap}.top-btn:hover{background:var(--bg3);color:var(--ink2)}.top-btn.on{background:var(--l0g);color:var(--l0l)}.top-btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.nav-dot{width:6px;height:6px;border-radius:50%;background:var(--l3);flex-shrink:0;animation:pulse 2s ease infinite}.top-right{margin-left:auto;gap:8px}.icon-btn,.top-right{display:flex;align-items:center}.icon-btn{width:32px;height:32px;border-radius:9px;border:1.5px solid var(--line);background:var(--bg3);cursor:pointer;justify-content:center;color:var(--ink3);transition:all .18s}.icon-btn:hover{border-color:var(--l0);color:var(--l0l)}.user-chip{display:flex;align-items:center;gap:8px;padding:4px 12px 4px 5px;border-radius:10px;border:1.5px solid var(--line);background:var(--bg3);text-decoration:none;transition:border-color .18s}.user-chip:hover{border-color:var(--line2)}.user-av{width:26px;height:26px;border-radius:7px;background:linear-gradient(135deg,var(--l0),var(--l5));display:flex;align-items:center;justify-content:center;font-family:var(--ff-d);font-size:11px;font-weight:800;color:#fff;flex-shrink:0}.user-name{font-size:12.5px;font-weight:600;color:var(--ink)}.app-scroll{flex:1 1;overflow-y:auto;background:var(--bg);transition:background .3s}.app-scroll::-webkit-scrollbar{width:3px}.app-scroll::-webkit-scrollbar-thumb{background:var(--line2);border-radius:3px}.app-col{max-width:700px;margin:0 auto;padding:28px 20px 96px}@media(min-width:769px){.app-col{padding-bottom:48px}}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg2);border-top:1.5px solid var(--line);z-index:50;padding-bottom:env(safe-area-inset-bottom);transition:background .3s}@media(max-width:768px){.mobile-nav{display:flex}}.mob-tab{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:9px 4px 7px;text-decoration:none;color:var(--ink4);position:relative;transition:color .18s}.mob-tab.on{color:var(--l0l)}.mob-tab svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.mob-tab.on svg{stroke-width:2.2}.mob-lbl{font-family:var(--ff-m);font-size:9px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.mob-dot{position:absolute;top:8px;right:calc(50% - 14px);width:5px;height:5px;border-radius:50%;background:var(--l3)}.page{animation:fadeUp .3s ease both}.greet{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:18px;flex-wrap:wrap}.greet-title{font-family:var(--ff-d);font-size:24px;font-weight:800;color:var(--ink);letter-spacing:-.03em;line-height:1.15;margin-bottom:3px}.greet-title em{font-style:normal;color:var(--ul)}.greet-sub{font-size:13px;color:var(--ink3)}.streak-chip{display:flex;align-items:center;gap:6px;padding:8px 13px;border-radius:11px;background:var(--ug);border:1px solid rgba(217,119,6,.18);flex-shrink:0}.streak-n{font-family:var(--ff-d);font-size:17px;font-weight:800;color:var(--ul);line-height:1}.streak-l{font-size:11.5px;color:var(--ink3)}.sprint-card{padding:13px 16px;border-radius:14px;background:var(--l5g);border:1px solid rgba(13,148,136,.2);margin-bottom:18px}.sprint-top{display:flex;align-items:center;gap:7px;margin-bottom:7px}.sprint-pulse{width:6px;height:6px;border-radius:50%;background:var(--l5);flex-shrink:0;animation:pulse 2s ease infinite}.sprint-name{font-weight:600;flex:1 1}.sprint-name,.sprint-pct{font-family:var(--ff-m);font-size:11px;color:var(--l5l)}.sprint-pct{font-weight:700}.sprint-track{height:4px;border-radius:2px;background:rgba(13,148,136,.16);overflow:hidden}.sprint-track div{height:100%;background:var(--l5);border-radius:2px;transition:width .4s}.stats-3{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:10px;gap:10px;margin-bottom:18px}.stat{padding:14px 15px;background:var(--bg2);border:1.5px solid var(--line);border-radius:15px;transition:background .3s}.stat-ico{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;margin-bottom:9px}.stat-ico svg{width:16px;height:16px;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.stat-v{font-family:var(--ff-d);font-size:23px;font-weight:800;color:var(--ink);line-height:1;margin-bottom:3px}.stat-of{font-size:13px}.stat-l,.stat-of{color:var(--ink3)}.stat-l{font-size:11px}.stats-4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;grid-gap:10px;gap:10px;margin-bottom:18px}.mini{padding:13px 14px;background:var(--bg2);border:1.5px solid var(--line);border-radius:13px}.mini-v{font-family:var(--ff-d);font-size:18px;font-weight:800;color:var(--ink);line-height:1;margin-bottom:3px}.mini-l{font-size:10.5px;color:var(--ink3)}.sec-lbl{font-family:var(--ff-m);font-size:9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink4);margin:18px 0 10px;padding-left:2px}.goal-card{display:block;padding:16px 18px;background:var(--bg2);border:1.5px solid var(--line);border-radius:16px;margin-bottom:10px;text-decoration:none;transition:border-color .18s}.goal-card:hover{border-color:var(--line2)}.goal-top{display:flex;align-items:flex-start;gap:9px;margin-bottom:9px}.goal-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:5px}.goal-name{font-family:var(--ff-d);font-size:13.5px;font-weight:700;color:var(--ink);line-height:1.3;margin-bottom:2px}.goal-meta{font-size:11.5px;color:var(--ink3)}.goal-pct{font-family:var(--ff-d);font-size:22px;font-weight:800;flex-shrink:0;line-height:1}.goal-bar{height:7px;border-radius:4px;background:var(--line);overflow:hidden}.goal-bar div{height:100%;border-radius:4px;transition:width .4s}.task-row{display:flex;align-items:flex-start;gap:10px;padding:11px 14px;background:var(--bg2);border:1.5px solid var(--line);border-radius:12px;margin-bottom:7px;cursor:pointer;transition:border-color .18s}.task-row:hover{border-color:var(--line2)}.chk{width:20px;height:20px;border-radius:6px;border:2px solid var(--line2);flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:1px;transition:all .18s}.chk.done{background:var(--l2);border-color:var(--l2)}.chk svg{width:10px;height:10px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}.task-text{font-size:13.5px;font-weight:500;color:var(--ink);line-height:1.4}.task-done{text-decoration:line-through;opacity:.45}.task-meta{display:flex;gap:6px;align-items:center;margin-top:4px}.task-time{font-family:var(--ff-m);font-size:10px;color:var(--ink4)}.card{padding:15px 17px;background:var(--bg2);border:1.5px solid var(--line);border-radius:14px;margin-bottom:10px;transition:background .3s}.card-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.card-lbl{font-size:13px;font-weight:700;color:var(--ink)}.card-lbl,.card-val{font-family:var(--ff-d)}.card-val{font-size:18px;font-weight:800}.card-sub{font-size:12.5px;color:var(--ink3);margin-top:7px}.card-bar{height:6px;border-radius:3px;background:var(--line);overflow:hidden;margin-bottom:4px}.card-bar div{height:100%;border-radius:3px;transition:width .4s}.card-foot{display:flex;justify-content:space-between;font-family:var(--ff-m);font-size:10px;color:var(--ink3);margin-top:7px}.ring-box{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:13px;background:var(--bg2);border:1.5px solid var(--line);flex-shrink:0}.ring-v{font-family:var(--ff-d);font-size:16px;font-weight:800;color:var(--ink);line-height:1}.ring-v span{font-size:12px;color:var(--ink3)}.ring-l{font-size:11px;color:var(--ink3);margin-top:2px}.score-row{display:flex;align-items:center;gap:16px;padding:16px 18px;background:var(--bg2);border:1.5px solid var(--line);border-radius:16px;margin-bottom:10px}.grade{font-family:var(--ff-d);font-size:20px;font-weight:800;color:var(--l5l);margin-bottom:3px}.grade-sub{font-size:13px;color:var(--ink3)}.grade-next{font-family:var(--ff-m);font-size:10px;color:var(--ink4);margin-top:6px}.badge-done{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:14px;background:rgba(217,119,6,.1);font-family:var(--ff-m);font-size:9.5px;color:var(--ul);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px;font-weight:600}.badge-done,.big-score{border:1.5px solid rgba(217,119,6,.2)}.big-score{padding:14px 22px;background:rgba(217,119,6,.06);border-radius:14px;text-align:center;flex-shrink:0}.big-score-n{font-family:var(--ff-d);font-size:42px;font-weight:800;color:var(--ul);letter-spacing:-.04em;line-height:1}.big-score-g{font-family:var(--ff-m);font-size:10px;color:var(--u);letter-spacing:.12em;text-transform:uppercase;margin-top:3px;font-weight:600}.ms-item{display:flex;align-items:flex-start;gap:11px;padding:12px 14px;background:var(--bg2);border:1.5px solid var(--line);border-radius:13px;margin-bottom:9px}.ms-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ms-icon svg{width:14px;height:14px;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.ms-text{font-size:13.5px;font-weight:500;color:var(--ink);line-height:1.4;margin-bottom:3px}.ms-meta{font-size:11.5px;color:var(--ink3)}.profile-card{gap:12px;padding:15px 17px;background:var(--bg2);border:1.5px solid var(--line);border-radius:15px;margin-bottom:14px}.profile-av,.profile-card{display:flex;align-items:center}.profile-av{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,var(--l0),var(--l5));justify-content:center;font-family:var(--ff-d);font-size:18px;font-weight:800;color:#fff;flex-shrink:0}.profile-name{font-family:var(--ff-d);font-size:15.5px;font-weight:700;color:var(--ink)}.profile-email{font-size:12px;color:var(--ink3);margin-top:2px}.sg-group{margin-bottom:18px}.sg-lbl{font-family:var(--ff-m);font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink4);margin-bottom:8px;padding-left:2px}.sg-items{background:var(--bg2);border:1.5px solid var(--line);border-radius:15px;overflow:hidden}.sg-item{display:flex;align-items:center;gap:11px;padding:13px 15px;border-bottom:1px solid var(--line);transition:background .18s}.sg-item:last-child{border-bottom:none}.sg-icon-wrap,.sg-item:hover{background:var(--bg3)}.sg-icon-wrap{width:32px;height:32px;border-radius:9px;border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sg-icon-wrap svg{width:14px;height:14px;stroke:var(--ink3);fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.sg-name{font-size:13px;font-weight:500;color:var(--ink)}.sg-sub{font-size:11.5px;color:var(--ink3);margin-top:2px}.sg-right{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0}.sg-val{font-family:var(--ff-m);font-size:11px;color:var(--ink3)}.sg-arr{width:18px;height:18px;color:var(--ink4)}.sg-arr svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.sg-badge{font-weight:600;padding:3px 8px;border-radius:6px;background:var(--l2g);color:var(--l2l);border:1px solid rgba(5,150,105,.25)}.sg-badge,.sg-lang-btn{font-family:var(--ff-m);font-size:9px}.sg-lang-btn{padding:4px 10px;border-radius:7px;border:1.5px solid var(--line2);background:var(--bg3);color:var(--ink3);font-weight:700;cursor:pointer;letter-spacing:.06em;transition:all .18s}.sg-lang-btn.on{background:var(--l0);color:#fff;border-color:var(--l0)}.sg-lang-btn:hover:not(.on){border-color:var(--line2);color:var(--ink2)}.ref-q{padding:14px 16px;background:var(--bg2);border:1.5px solid var(--line);border-radius:13px;margin-bottom:9px;cursor:pointer;transition:border-color .18s}.ref-q:hover{border-color:var(--line2)}.ref-qt{font-size:13.5px;font-weight:600;color:var(--ink);margin-bottom:5px}.ref-qh{font-family:var(--ff-m);font-size:10px;color:var(--ink4);letter-spacing:.06em}.e-btn{flex:1 1;flex-direction:column;gap:4px;padding:10px 6px;border-radius:11px;cursor:pointer;transition:all .2s;border:1.5px solid var(--line);background:var(--bg3);color:var(--ink3);font-family:var(--ff-b);font-size:12.5px;font-weight:600}.e-btn,.e-btn-icon{display:flex;align-items:center}.e-btn-icon{width:28px;height:28px;border-radius:8px;background:var(--bg4);justify-content:center;transition:background .2s}.e-btn-icon svg{width:16px;height:16px;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;stroke:var(--ink3);transition:stroke .2s}.e-btn:hover{border-color:var(--line2);color:var(--ink2)}.e-btn.sel-low{border-color:var(--l4);background:var(--l4g);color:var(--l4l)}.e-btn.sel-low .e-btn-icon{background:rgba(219,39,119,.2)}.e-btn.sel-low .e-btn-icon svg{stroke:var(--l4l)}.e-btn.sel-mid{border-color:var(--l3);background:var(--l3g);color:var(--l3l)}.e-btn.sel-mid .e-btn-icon{background:rgba(217,119,6,.2)}.e-btn.sel-mid .e-btn-icon svg{stroke:var(--l3l)}.e-btn.sel-hi{border-color:var(--l5);background:var(--l5g);color:var(--l5l)}.e-btn.sel-hi .e-btn-icon{background:rgba(13,148,136,.2)}.e-btn.sel-hi .e-btn-icon svg{stroke:var(--l5l)}.sh-bars{display:flex;align-items:flex-end;gap:5px;height:64px}.sh-col{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:3px}.sh-bar{width:100%;border-radius:3px 3px 0 0;min-height:4px}.sh-lbl{font-family:var(--ff-m);font-size:8px;color:var(--ink4);font-weight:600}.submit-btn{display:block;width:100%;padding:13px;border-radius:13px;border:none;background:var(--l0);color:#fff;font-family:var(--ff-b);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;text-align:center;margin-top:8px}.submit-btn:hover{background:var(--l0l);transform:translateY(-1px)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg);background-image:radial-gradient(ellipse 50% 50% at 50% 0,rgba(124,58,237,.1) 0,transparent 70%)}.auth-card{width:100%;max-width:400px;background:var(--bg2);border:1.5px solid var(--line);border-radius:22px;padding:36px 32px 32px;animation:fadeUp .35s ease both}.auth-logo{display:inline-block;font-family:var(--ff-d);font-size:20px;font-weight:800;color:var(--ink);text-decoration:none;letter-spacing:-.03em;margin-bottom:28px}.auth-logo span{color:var(--l0l)}.auth-title{font-family:var(--ff-d);font-size:26px;font-weight:800;color:var(--ink);letter-spacing:-.03em;margin-bottom:6px}.auth-sub{font-size:14px;color:var(--ink3);margin-bottom:28px}.auth-err{background:rgba(219,39,119,.1);border:1px solid rgba(219,39,119,.25);border-radius:10px;padding:10px 14px;font-size:13px;color:#f472b6;margin-bottom:16px}.auth-form{gap:14px;margin-bottom:20px}.auth-field,.auth-form{display:flex;flex-direction:column}.auth-field{gap:6px}.auth-label{font-family:var(--ff-m);font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3)}.auth-input{padding:11px 14px;border-radius:11px;border:1.5px solid var(--line2);background:var(--bg3);color:var(--ink);font-family:var(--ff-b);font-size:14px;outline:none;transition:border-color .18s}.auth-input::placeholder{color:var(--ink4)}.auth-input:focus{border-color:var(--l0)}.auth-btn{margin-top:4px;width:100%;padding:16px;border-radius:var(--radius-btn,14px);border:none;background:linear-gradient(135deg,var(--l0),var(--l5));color:#fff;font-family:var(--ff-d);font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;min-height:50px;box-shadow:0 4px 20px rgba(124,58,237,.3);letter-spacing:-.01em;text-decoration:none}.auth-btn:hover:not(:disabled){opacity:.92;transform:translateY(-1.5px);box-shadow:0 6px 24px rgba(124,58,237,.4)}.auth-btn:disabled{opacity:.5;cursor:default;transform:none;box-shadow:none}.auth-footer{text-align:center;font-size:13px;color:var(--ink3)}.auth-link{color:var(--l0l);text-decoration:none;font-weight:500}.auth-link:hover{text-decoration:underline}.spinner{width:18px;height:18px;border:2px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}