@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg:#212226;--bg-card:#303136;--bg-card-hover:#3a3b41;--border:#3f3f46;--border-subtle:#3a3b41;--text:#fafafa;--text-secondary:#a1a1aa;--text-muted:#71717a;--accent:#2dd4bf;--accent-dim:#2dd4bf1f;--easy:#5abe92;--easy-dim:#5abe921f;--medium:#dfa231;--medium-dim:#dfa2311f;--hard:#e47778;--hard-dim:#e477781f;--font:"Outfit", sans-serif;--font-mono:"JetBrains Mono", monospace;--radius:10px;--radius-sm:6px;--shadow:0 1px 3px #0000004d, 0 1px 2px #0003;--shadow-md:0 4px 16px #0006, 0 2px 4px #0003}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.5}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:var(--font);cursor:pointer;background:0 0;border:none}input,textarea,select{font-family:var(--font);background:var(--bg-card);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;padding:8px 12px;font-size:14px;transition:border-color .15s,box-shadow .15s}input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.app-shell{flex-direction:column;min-height:100vh;display:flex}.nav{border-bottom:1px solid var(--border);z-index:100;height:58px;box-shadow:var(--shadow);background:#303136;align-items:center;gap:32px;padding:0 28px;display:flex;position:sticky;top:0}.nav-brand{color:var(--text);letter-spacing:-.02em;align-items:center;gap:8px;font-size:15px;font-weight:700;display:flex}.nav-brand-dot{background:var(--accent);border-radius:50%;width:8px;height:8px}.nav-links{gap:4px;display:flex}.nav-link{border-radius:var(--radius-sm);color:var(--text-secondary);padding:6px 14px;font-size:14px;font-weight:500;transition:color .15s,background .15s}.nav-link:hover{color:var(--text);background:var(--bg-card-hover)}.nav-link.active{color:var(--accent);background:var(--accent-dim)}.page{width:100%;max-width:1340px;margin:0 auto;padding:32px 28px}.page-title{letter-spacing:-.02em;color:var(--text);margin-bottom:24px;font-size:22px;font-weight:700}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.stats-row{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 22px}.stat-label{color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px;font-size:11px;font-weight:600}.stat-value{font-family:var(--font-mono);color:var(--text);letter-spacing:-.02em;font-size:28px;font-weight:500}.stat-value.accent{color:var(--accent)}.stat-value.easy{color:var(--easy)}.stat-value.medium{color:var(--medium)}.badge{font-size:11px;font-weight:600;font-family:var(--font-mono);white-space:nowrap;border-radius:100px;align-items:center;padding:2px 9px;display:inline-flex}.badge-easy{background:var(--easy-dim);color:var(--easy)}.badge-medium{background:var(--medium-dim);color:var(--medium)}.badge-hard{background:var(--hard-dim);color:var(--hard)}.table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}table{border-collapse:collapse;width:100%;font-size:14px}thead tr{border-bottom:1px solid var(--border);background:var(--bg)}th{text-align:left;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;padding:10px 14px;font-size:11px;font-weight:700}td{border-bottom:1px solid var(--border-subtle);vertical-align:middle;padding:11px 14px}tr:last-child td{border-bottom:none}tbody tr{cursor:pointer;transition:background .1s}tbody tr:hover{background:var(--bg-card-hover)}.problem-link{color:var(--text);font-weight:500;transition:color .15s}.problem-link:hover{color:var(--accent)}.mono{font-family:var(--font-mono);font-size:13px}.btn{border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font);border:none;align-items:center;gap:6px;padding:7px 14px;transition:all .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#0b7a70}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--bg-card-hover);color:var(--text);border-color:var(--text-muted)}.btn-sm{padding:4px 10px;font-size:12px}.srs-toggle-wrap{align-items:center;gap:8px;display:flex}.srs-toggle{flex-shrink:0;width:36px;height:20px;position:relative}.srs-toggle input{opacity:0;border:none;width:0;height:0;margin:0;padding:0;position:absolute}.srs-toggle-track{background:var(--border);cursor:pointer;border:none;border-radius:100px;transition:background .2s;position:absolute;inset:0}.srs-toggle input:checked+.srs-toggle-track{background:var(--accent)}.srs-toggle-track:after{content:"";background:#fff;border-radius:50%;width:14px;height:14px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}.srs-toggle input:checked+.srs-toggle-track:after{transform:translate(16px)}.srs-next-date{font-family:var(--font-mono);color:var(--accent);font-size:11px}.srs-mastered{color:var(--easy);font-size:11px;font-weight:500}.srs-toggle-disabled{opacity:.3;cursor:not-allowed}.srs-toggle-disabled .srs-toggle-track{cursor:not-allowed}.filter-row{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;display:flex}.search-input{flex:1;min-width:200px;max-width:320px}.filter-pills{flex-wrap:wrap;gap:6px;display:flex}.pill{cursor:pointer;border:1px solid var(--border);color:var(--text-secondary);background:var(--bg-card);font-size:12px;font-weight:500;font-family:var(--font);border-radius:100px;padding:5px 13px;transition:all .15s}.pill:hover{border-color:var(--text-muted);color:var(--text)}.pill.active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.pill.easy.active{border-color:var(--easy);color:var(--easy);background:var(--easy-dim)}.pill.medium.active{border-color:var(--medium);color:var(--medium);background:var(--medium-dim)}.pill.hard.active{border-color:var(--hard);color:var(--hard);background:var(--hard-dim)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0f172a66;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:440px;box-shadow:var(--shadow-md);flex-direction:column;gap:16px;padding:24px;display:flex}.modal-title{font-size:16px;font-weight:600}.modal-problem-name{color:var(--text-secondary);font-size:13px}.form-field{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-secondary);letter-spacing:.03em;font-size:12px;font-weight:600}.form-field input,.form-field textarea{width:100%}.modal-actions{justify-content:flex-end;gap:8px;padding-top:4px;display:flex}.review-section{margin-bottom:28px}.section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section-title{color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;font-size:12px;font-weight:700}.review-list{flex-direction:column;gap:8px;display:flex}.review-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;transition:box-shadow .15s;display:flex}.review-item:hover{box-shadow:var(--shadow-md)}.review-item-info{align-items:center;gap:12px;min-width:0;display:flex}.review-item-number{font-family:var(--font-mono);color:var(--text-muted);flex-shrink:0;font-size:12px}.review-item-title{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.review-item-interval{font-size:11px;font-family:var(--font-mono);color:var(--text-secondary);flex-shrink:0}.empty-state{text-align:center;color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:36px;font-size:14px}.category-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px;margin-bottom:28px;display:grid}.category-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px 16px}.category-name{white-space:nowrap;text-overflow:ellipsis;color:var(--text);margin-bottom:8px;font-size:13px;font-weight:600;overflow:hidden}.category-progress{align-items:center;gap:10px;display:flex}.progress-bar{background:var(--border);border-radius:100px;flex:1;height:5px;overflow:hidden}.progress-fill{background:var(--accent);border-radius:100px;height:100%;transition:width .4s}.progress-label{font-family:var(--font-mono);color:var(--text-secondary);white-space:nowrap;font-size:11px}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.status-dot.solved{background:var(--easy)}.status-dot.unsolved{background:var(--border)}.recent-list{flex-direction:column;display:flex}.recent-item{border-bottom:1px solid var(--border-subtle);align-items:center;gap:12px;padding:10px 0;display:flex}.recent-item:last-child{border-bottom:none}.recent-date{font-family:var(--font-mono);color:var(--text-muted);flex-shrink:0;width:88px;font-size:11px}.recent-title{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:13px;overflow:hidden}.recent-time{font-family:var(--font-mono);color:var(--text-secondary);flex-shrink:0;font-size:11px}@keyframes sidebar-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes overlay-fade-in{0%{opacity:0}to{opacity:1}}.sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:150;background:#0f172a40;animation:.2s overlay-fade-in;position:fixed;inset:0}.sidebar{background:var(--bg-card);border-left:1px solid var(--border);width:620px;height:100vh;box-shadow:var(--shadow-md);z-index:151;flex-direction:column;animation:.28s cubic-bezier(.25,.46,.45,.94) sidebar-slide-in;display:flex;position:fixed;top:0;right:0;overflow:hidden}.sidebar-header{border-bottom:1px solid var(--border);flex-shrink:0;padding:20px 24px 16px}.sidebar-header-top{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;display:flex}.sidebar-number{font-family:var(--font-mono);color:var(--text-muted);margin-bottom:4px;font-size:12px}.sidebar-title{letter-spacing:-.01em;color:var(--text);font-size:17px;font-weight:700;line-height:1.3}.sidebar-close{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.sidebar-close:hover{background:var(--bg-card-hover);color:var(--text)}.sidebar-meta{align-items:center;gap:8px;display:flex}.sidebar-body{flex:1;padding:20px 24px;overflow-y:auto}.sidebar-section{margin-bottom:24px}.sidebar-section-title{color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:12px;font-size:11px;font-weight:700}.solve-timeline{flex-direction:column;gap:10px;display:flex}.solve-entry{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px}.solve-entry-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.solve-date{font-family:var(--font-mono);color:var(--text);font-size:12px;font-weight:500}.solve-time{font-family:var(--font-mono);color:var(--accent);font-size:12px;font-weight:500}.solve-delete-btn{border-radius:var(--radius-sm);width:20px;height:20px;color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:none;justify-content:center;align-items:center;transition:opacity .15s,background .15s,color .15s;display:flex}.solve-entry:hover .solve-delete-btn{opacity:1}.solve-delete-btn:hover{background:var(--hard-dim);color:var(--hard)}.solve-notes{color:var(--text-secondary);margin-top:6px;font-size:13px;line-height:1.5}.srs-info-row{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:10px 14px;font-size:13px;display:flex}.srs-info-label{color:var(--text-secondary)}.srs-info-value{font-family:var(--font-mono);color:var(--text);font-size:12px;font-weight:500}@keyframes sidebar-slide-out{0%{transform:translate(0)}to{transform:translate(100%)}}@keyframes overlay-fade-out{0%{opacity:1}to{opacity:0}}.sidebar.closing{animation:.25s cubic-bezier(.55,0,1,.45) forwards sidebar-slide-out}.sidebar-overlay.closing{pointer-events:none;animation:.22s forwards overlay-fade-out}.note-editor{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);transition:border-color .15s;overflow:hidden}.note-editor:focus-within{border-color:var(--accent)}.note-toolbar{border-bottom:1px solid var(--border);background:var(--bg-card);align-items:center;gap:2px;padding:4px 6px;display:flex}.note-editor-content{min-height:100px;color:var(--text);outline:none;padding:10px 12px;font-size:13px;line-height:1.65}.note-editor-content p{margin:0 0 6px}.note-editor-content p:last-child{margin-bottom:0}.note-editor-content ul,.note-editor-content ol{margin:4px 0;padding-left:20px}.note-editor-content li{margin:2px 0}.note-editor-content strong{color:var(--text)}.note-editor-content em{color:var(--text-secondary)}.note-editor-content p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--text-muted);pointer-events:none;height:0}@keyframes detail-slide-in{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}.detail-slide-in{animation:.22s cubic-bezier(.25,.46,.45,.94) detail-slide-in}.note-textarea{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);font-family:var(--font);resize:vertical;min-height:90px;padding:10px 12px;font-size:13px;line-height:1.6;transition:border-color .15s}.note-textarea::placeholder{color:var(--text-muted)}.note-textarea:focus{border-color:var(--accent);outline:none}.url-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-mono);flex:1;min-width:0;padding:7px 10px;font-size:11px;transition:border-color .15s}.url-input::placeholder{color:var(--text-muted)}.url-input:focus{border-color:var(--accent);outline:none}.time-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);width:72px;color:var(--text);font-family:var(--font-mono);text-align:center;padding:6px 10px;font-size:13px;transition:border-color .15s}.time-input::placeholder{color:var(--text-muted)}.time-input:focus{border-color:var(--accent);outline:none}.time-input::-webkit-inner-spin-button{-webkit-appearance:none}.sidebar-problem-row{border-bottom:1px solid var(--border-subtle);cursor:pointer;align-items:center;gap:10px;padding:12px 20px;transition:background .1s;display:flex}.sidebar-problem-row:hover{background:var(--bg-card-hover)}.sidebar-problem-row:last-child{border-bottom:none}.sidebar-problem-num{font-family:var(--font-mono);color:var(--text-muted);flex-shrink:0;width:34px;font-size:11px}.sidebar-problem-title{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:13px;font-weight:500;overflow:hidden}.category-card-clickable{cursor:pointer;transition:background .15s,border-color .15s,transform .1s}.category-card-clickable:hover{background:var(--bg-card-hover);border-color:var(--accent)}.category-card-clickable:active{transform:scale(.98)}.charts-row{grid-template-columns:280px 1fr;gap:14px;margin-bottom:28px;display:grid}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.chart-title{color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:16px;font-size:12px;font-weight:700}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (width<=768px){.nav{gap:16px;padding:0 16px}.nav-brand{font-size:14px}.page{padding:20px 16px}.page-title{margin-bottom:18px;font-size:18px}.stats-row{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px}.stat-value{font-size:22px}.charts-row{grid-template-columns:1fr;gap:10px}.category-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}table{min-width:680px}.filter-row{gap:8px}.search-input{width:100%;max-width:100%}.sidebar{border-left:none;border-top:1px solid var(--border);width:100%!important}.modal{max-width:calc(100vw - 32px);padding:20px}.review-item{flex-direction:column;align-items:flex-start;gap:10px}}
