:root{font-family:Inter,-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,sans-serif;color:#1f2937;background:#eef3f8;line-height:1.5;font-weight:400;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(180deg,#f5f8fc,#edf3f8);color:#1f2937}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}button{cursor:pointer}#root{min-height:100vh}.app-shell{min-height:100vh;display:grid;grid-template-columns:280px 1fr;gap:24px;padding:24px}.sidebar-card{background:#0f172a;color:#e2e8f0;border-radius:24px;padding:24px;display:flex;flex-direction:column;gap:20px;box-shadow:0 24px 60px #0f172a29}.brand-block{display:flex;gap:14px;align-items:flex-start}.brand-block h1{margin:0;font-size:24px}.brand-block p{margin:6px 0 0;color:#94a3b8;font-size:14px}.brand-dot{width:14px;height:14px;border-radius:999px;background:linear-gradient(135deg,#60a5fa,#22c55e);margin-top:8px}.user-panel{background:#94a3b824;border:1px solid rgba(148,163,184,.16);border-radius:18px;padding:16px}.user-panel strong{display:block;font-size:18px;margin-top:4px}.section-kicker{display:inline-block;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#64748b}.sidebar-card .section-kicker{color:#93c5fd}.sidebar-nav{display:flex;flex-direction:column;gap:8px}.sidebar-nav a{padding:10px 14px;border-radius:12px;color:#cbd5e1}.sidebar-nav a.active{background:#60a5fa29;color:#fff}.sidebar-nav a:hover{background:#94a3b829;color:#fff}.logout-wide{width:100%;border:1px solid rgba(148,163,184,.3);background:transparent;color:#e2e8f0;padding:10px 12px;border-radius:12px}.logout-wide:hover{border-color:#e2e8f0}.content-shell{background:#fff;border-radius:20px;padding:20px 20px 32px;box-shadow:0 20px 50px #0f172a14}.main-panel{min-height:70vh}.footer{margin-top:24px;color:#94a3b8;font-size:13px}.page-shell{background:#f8fafc;border-radius:16px;padding:20px;min-height:70vh}.page-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.page-header h2{margin:4px 0}.card-grid.two{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}.card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:16px;box-shadow:0 10px 30px #0f172a0a;display:flex;flex-direction:column;gap:12px}label{display:flex;flex-direction:column;gap:6px;font-size:14px;color:#475569}label.inline{flex-direction:row;align-items:center;gap:8px}input[type=text],input[type=number],input[type=datetime-local],textarea,input:not([type]){padding:10px 12px;border-radius:10px;border:1px solid #e2e8f0;background:#fff}textarea{resize:vertical}.primary-btn{background:linear-gradient(135deg,#2563eb,#22c55e);color:#fff;border:none;border-radius:12px;padding:10px 16px;font-weight:600}.secondary-btn{background:#e2e8f0;border:none;border-radius:10px;padding:8px 12px;color:#0f172a}.text-btn{background:none;border:none;color:#2563eb}.muted{color:#94a3b8;font-size:13px}.loading{padding:24px;text-align:center;color:#475569}.routine-list{display:flex;flex-direction:column;gap:12px}.routine-item{border:1px solid #e2e8f0;border-radius:12px;padding:12px;background:#f8fafc;display:flex;flex-direction:column;gap:10px}.routine-header{display:flex;gap:8px;align-items:center}.routine-header input{flex:1}.routine-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 16px}.login-container{max-width:520px;width:100%;background:#fff;border-radius:20px;padding:28px;box-shadow:0 20px 60px #0f172a1f;text-align:center}.login-card{margin-top:12px;padding:20px;border-radius:16px;background:#f8fafc;border:1px solid #e2e8f0}.login-card h2{margin:0 0 4px}.subtitle{color:#64748b;margin:0}.wxwork-login-btn{display:inline-block;padding:10px 14px;border-radius:12px;background:linear-gradient(135deg,#2563eb,#22c55e);color:#fff;font-weight:600}.features ul{list-style:none;padding-left:0;margin:8px 0 0}.features li{margin:4px 0}.footer-note{margin-top:12px;color:#94a3b8;font-size:13px}.sidebar-nav a.active{font-weight:700}@media (max-width: 960px){.app-shell{grid-template-columns:1fr}.sidebar-card{flex-direction:row;flex-wrap:wrap}.content-shell{padding:16px}}.page-header-block{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}.page-header-block h2{margin:4px 0}.page-header-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.action-group{display:flex;gap:8px}.card-panel{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:16px;box-shadow:0 12px 40px #0f172a0f}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.panel-meta{color:#94a3b8;font-size:13px}.stack-list{display:flex;flex-direction:column;gap:12px}.stack-item{border:1px solid #e2e8f0;border-radius:12px;padding:12px;background:#f8fafc}.item-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.inline-actions{display:flex;align-items:center;gap:10px}.progress-track{background:#e2e8f0;border-radius:8px;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(135deg,#2563eb,#22c55e);height:100%}.status-badge{padding:4px 8px;border-radius:999px;font-size:12px;text-transform:uppercase;letter-spacing:.08em}.status-badge.completed{background:#dcfce7;color:#15803d}.status-badge.in_progress{background:#e0f2fe;color:#075985}.status-badge.not_started{background:#f1f5f9;color:#475569}.status-badge.blocked{background:#fee2e2;color:#b91c1c}.progress-badge{background:#0ea5e9;color:#fff;padding:4px 10px;border-radius:10px;font-weight:600}.tag-row{display:flex;flex-wrap:wrap;gap:8px}.tag{background:#e0f2fe;color:#0f172a;padding:4px 10px;border-radius:999px;font-size:12px}.tag-select{border:1px solid #e2e8f0;border-radius:12px;background:#fff;padding:6px 10px}.tag-select.active{background:#e0f2fe;border-color:#38bdf8}.content-grid{display:grid;gap:16px}.content-grid.two-columns{grid-template-columns:repeat(auto-fit,minmax(360px,1fr))}.align-start{align-items:start}.segmented-control{display:inline-flex;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;background:#fff}.segmented-control button{border:none;padding:8px 12px;background:transparent;color:#475569}.segmented-control button.active{background:#0ea5e9;color:#fff}.info-banner{padding:10px 12px;border-radius:12px;background:#fef3c7;color:#92400e;border:1px solid #fcd34d;margin-bottom:12px}.side-drawer{position:fixed;top:0;right:0;bottom:0;left:0;display:none;align-items:flex-start;justify-content:flex-end;padding:32px;z-index:30}.side-drawer.open{display:flex}.side-drawer__mask{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a59;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.drawer-panel{position:relative;width:min(480px,90vw);background:#fff;border-radius:16px;box-shadow:0 24px 60px #0f172a2e;padding:18px;max-height:calc(100vh - 64px);overflow:auto}.drawer-header{display:flex;align-items:center;justify-content:space-between}.drawer-close{background:none;border:none;font-size:20px}.goal-selector h4,.attachment-panel h4{margin:0 0 8px}.attachment-panel{border:1px dashed #e2e8f0;border-radius:12px;padding:10px;background:#f8fafc}.chips-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:10px 0}.pill{border:1px solid #e2e8f0;background:#fff;padding:6px 10px;border-radius:999px}.pill.warning{background:#fef3c7;border-color:#fcd34d}.empty-state{padding:16px;text-align:center;color:#94a3b8}.hero-panel{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px;background:#0f172a;color:#e2e8f0;padding:16px;border-radius:16px}.hero-side-note{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.metric-chip{background:#ffffff14;border:1px solid rgba(255,255,255,.16);border-radius:12px;padding:6px 10px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:12px}.stats-grid.compact-stats{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.stat-card-modern{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:12px;box-shadow:0 10px 30px #0f172a0a}.report-summary-box{background:#0f172a;color:#e2e8f0;border-radius:14px;padding:14px}.bullet-list{margin:8px 0;padding-left:18px}.bullet-list.compact{padding-left:16px}.warning-list li{color:#fbbf24}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}.info-grid label{color:#94a3b8;font-size:12px}.goal-selector .tag-row{gap:6px}@media (max-width: 640px){.page-header-block{flex-direction:column;align-items:flex-start}.page-header-actions{width:100%;justify-content:flex-start}.hero-panel{flex-direction:column;align-items:flex-start}.side-drawer{padding:16px}}
