:root{--bg: #f5f7fa;--surface: #ffffff;--surface-soft: #fafbfc;--text: #1f2937;--text-soft: #6b7280;--text-muted: #c8d0db;--border: #e5e9f0;--shadow: 0 1px 3px rgba(15, 23, 42, .04), 0 4px 16px rgba(15, 23, 42, .04);--shadow-md: 0 4px 12px rgba(15, 23, 42, .05), 0 12px 28px rgba(15, 23, 42, .06);--accent: #e74c3c;--accent-soft: rgba(231, 76, 60, .08);--blue: #3b82f6;--blue-soft: rgba(59, 130, 246, .08);--amber: #f59e0b;--amber-soft: rgba(245, 158, 11, .08);--green: #10b981;--green-soft: rgba(16, 185, 129, .08);--radius: 14px;--radius-lg: 20px;--radius-xl: 24px}@media (prefers-color-scheme: dark){:root{--bg: #0d1117;--surface: #161b22;--surface-soft: #1a2029;--text: #e6edf3;--text-soft: #8b949e;--text-muted: #484f58;--border: #21262d;--shadow: 0 1px 3px rgba(0, 0, 0, .3), 0 8px 24px rgba(0, 0, 0, .25);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4), 0 16px 36px rgba(0, 0, 0, .35);--accent-soft: rgba(231, 76, 60, .16);--blue-soft: rgba(59, 130, 246, .16);--amber-soft: rgba(245, 158, 11, .16);--green-soft: rgba(16, 185, 129, .16)}}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"tnum" 1;line-height:1.5}button{font-family:inherit}.app{min-height:100vh;max-width:1500px;margin:0 auto;padding:28px 32px 36px;display:flex;flex-direction:column;gap:22px}.app-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.brand{display:flex;align-items:center;gap:14px}.brand .logo{font-size:32px;width:52px;height:52px;background:var(--surface);border-radius:14px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);border:1px solid var(--border)}.brand-text h1{margin:0;font-size:22px;font-weight:600;letter-spacing:.3px}.brand-sub{margin:2px 0 0;font-size:13px;color:var(--text-soft)}.header-meta{display:inline-flex;align-items:center;gap:20px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:10px 18px;box-shadow:var(--shadow)}.meta-item{display:flex;flex-direction:column;align-items:flex-start;line-height:1.2}.meta-label{font-size:11px;color:var(--text-soft);letter-spacing:.5px;text-transform:uppercase}.meta-value{font-size:16px;font-weight:600;margin-top:2px}.meta-divider{width:1px;align-self:stretch;background:var(--border);margin:4px 0}.dashboard{display:grid;gap:20px;grid-template-columns:1fr}@media (min-width: 880px){.dashboard{grid-template-columns:minmax(0,1.25fr) minmax(0,1fr);grid-template-areas:"stats  stats" "timer  todos" "chart  chart"}.dashboard>.stats-row{grid-area:stats}.dashboard>.card.timer{grid-area:timer}.dashboard>.card.todos{grid-area:todos}.dashboard>.chart-card{grid-area:chart}}@media (min-width: 1280px){.dashboard{grid-template-columns:minmax(0,1.2fr) minmax(0,1fr) minmax(0,1.05fr);grid-template-areas:"stats stats stats" "timer todos chart"}}.card{background:var(--surface);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow);border:1px solid var(--border)}.card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:18px}.card-header h2{margin:0;font-size:16px;font-weight:600}.card-sub{margin:4px 0 0;font-size:12px;color:var(--text-soft)}.link-btn{border:none;background:none;color:var(--text-soft);cursor:pointer;font-size:13px;padding:6px 10px;border-radius:8px;transition:color .15s ease,background .15s ease}.link-btn:hover{color:var(--accent);background:var(--accent-soft)}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;display:flex;gap:14px;align-items:center;box-shadow:var(--shadow);position:relative;overflow:hidden;transition:transform .18s ease,box-shadow .18s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card:after{content:"";position:absolute;inset:0 auto 0 0;width:3px;background:var(--accent);opacity:0;transition:opacity .2s ease}.stat-card:hover:after{opacity:1}.stat-card.tone-red:after{background:var(--accent)}.stat-card.tone-blue:after{background:var(--blue)}.stat-card.tone-amber:after{background:var(--amber)}.stat-card.tone-green:after{background:var(--green)}.stat-card-icon{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.tone-red .stat-card-icon{background:var(--accent-soft)}.tone-blue .stat-card-icon{background:var(--blue-soft)}.tone-amber .stat-card-icon{background:var(--amber-soft)}.tone-green .stat-card-icon{background:var(--green-soft)}.stat-card-body{min-width:0}.stat-card-label{font-size:12px;color:var(--text-soft);letter-spacing:.2px}.stat-card-value{font-size:22px;font-weight:600;line-height:1.2;margin-top:2px;display:flex;align-items:baseline;gap:2px}.stat-card-unit{font-size:13px;color:var(--text-soft);font-weight:500}.stat-card-hint{font-size:11px;color:var(--text-muted);margin-top:3px}.card.timer{display:flex;flex-direction:column;align-items:center;gap:18px}.mode-tabs{display:inline-flex;background:var(--surface-soft);border:1px solid var(--border);border-radius:12px;padding:4px;gap:2px}.mode-tab{border:none;background:transparent;color:var(--text-soft);font-size:13px;padding:8px 14px;border-radius:10px;cursor:pointer;transition:color .18s ease;font-weight:500}.mode-tab:hover{color:var(--text)}.mode-tab.active{color:#fff}.ring-wrap{position:relative;width:280px;height:280px;display:flex;align-items:center;justify-content:center}.ring-track{stroke:var(--border)}.ring-progress{transition:stroke-dashoffset .3s ease}.ring-content{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}.time-display{font-size:60px;font-weight:300;letter-spacing:1.5px;font-variant-numeric:tabular-nums;line-height:1}.round-info{color:var(--text-soft);font-size:13px;letter-spacing:.3px}.active-todo{font-size:13px;color:var(--text-soft);text-align:center;min-height:20px}.active-todo span{color:var(--text);font-weight:500}.muted{color:var(--text-muted)}.controls{display:flex;gap:10px}.btn{border:none;cursor:pointer;font-size:14px;font-weight:500;padding:11px 22px;border-radius:11px;transition:all .18s ease;background:transparent;color:var(--text)}.btn.small{padding:8px 14px;font-size:13px}.btn:disabled{opacity:.45;cursor:not-allowed}.btn.primary{background:var(--accent);color:#fff;min-width:110px}.btn.primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #e74c3c52}.btn.primary.outline{background:var(--surface);color:var(--accent);border:1px solid var(--accent)}.btn.primary.outline:hover:not(:disabled){background:var(--accent-soft);box-shadow:none}.btn.ghost{background:var(--surface-soft);color:var(--text-soft);border:1px solid var(--border)}.btn.ghost:hover{background:var(--border);color:var(--text)}.add-form{display:flex;gap:8px;margin-bottom:14px}.add-input{flex:1;border:1px solid var(--border);background:var(--surface-soft);color:var(--text);padding:10px 14px;border-radius:11px;font-size:14px;outline:none;transition:border-color .15s ease,background .15s ease}.add-input:focus{border-color:var(--accent);background:var(--surface)}.todo-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px;max-height:460px;overflow-y:auto}.empty{text-align:center;color:var(--text-muted);padding:40px 12px;font-size:14px}.group-label{font-size:11px;color:var(--text-muted);padding:14px 12px 6px;letter-spacing:.5px;text-transform:uppercase}.todo-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;transition:background .15s ease}.todo-item:hover{background:var(--surface-soft)}.todo-item.active{background:var(--accent-soft)}.todo-item.done .todo-title{color:var(--text-muted);text-decoration:line-through}.checkbox{width:22px;height:22px;border-radius:50%;border:2px solid var(--border);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0;transition:all .15s ease}.checkbox:hover{border-color:var(--accent)}.todo-item.done .checkbox{background:var(--accent);border-color:var(--accent)}.todo-title{flex:1;font-size:14px;cursor:pointer;-webkit-user-select:none;user-select:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pomos{font-size:12px;color:var(--text-soft);font-variant-numeric:tabular-nums;flex-shrink:0}.icon-btn{width:24px;height:24px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:6px;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s ease,color .15s ease}.icon-btn:hover{color:var(--accent)}.todo-item:hover .icon-btn{opacity:1}.chart-card{display:flex;flex-direction:column}.chart-legend{font-size:12px;color:var(--text-soft);display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:var(--surface-soft);border:1px solid var(--border);border-radius:8px}.legend-dot{width:10px;height:10px;border-radius:3px;background:var(--accent)}.chart-canvas-wrap{position:relative;height:240px;width:100%;margin-top:6px}.app-footer{text-align:center;color:var(--text-muted);font-size:12px;padding-top:4px}.todo-list::-webkit-scrollbar{width:6px}.todo-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.todo-list::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (max-width: 540px){.app{padding:16px;gap:16px}.ring-wrap{width:240px;height:240px}.time-display{font-size:50px}.stat-card{padding:14px}.stat-card-value{font-size:20px}.controls{flex-wrap:wrap;justify-content:center}.header-meta{width:100%;justify-content:space-between}}
