:root{--bg: #f7f8fa;--surface: #ffffff;--border: #e6e8eb;--text: #1a1d21;--text-muted: #6b7280;--accent: #1e3a8a;--accent-hover: #1c3478;--accent-soft: #eef2ff;--danger: #dc2626;--danger-soft: #fef2f2;--success: #16a34a;--warning: #d97706;--radius: 10px;--radius-sm: 7px;--shadow: 0 1px 2px rgba(16, 24, 40, .05), 0 1px 3px rgba(16, 24, 40, .08);--tabbar-h: 64px;--sidebar-w: 240px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-size:15px}a{color:var(--accent);text-decoration:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:16px;font-weight:600;padding:12px 18px;border-radius:var(--radius);border:1px solid transparent;cursor:pointer;min-height:48px;transition:background .15s,border-color .15s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border)}.btn-secondary:hover{background:var(--bg)}.btn-block{width:100%}.btn:disabled{opacity:.6;cursor:not-allowed}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.field label{font-size:13px;font-weight:600;color:var(--text-muted)}.input,.select,.textarea{width:100%;font-size:16px;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text)}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}.alert{border-radius:var(--radius-sm);padding:12px 14px;font-size:14px;margin-bottom:16px}.alert-error{background:var(--danger-soft);color:var(--danger)}.app-shell{min-height:100%;display:flex}.sidebar{display:none;width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);flex-direction:column;padding:20px 14px;position:sticky;top:0;height:100vh}.sidebar .brand{font-weight:800;font-size:18px;color:var(--accent);padding:6px 10px 18px;letter-spacing:-.02em}.sidebar nav{display:flex;flex-direction:column;gap:4px}.nav-link{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:var(--radius-sm);color:var(--text-muted);font-weight:600;font-size:15px}.nav-link.active{background:var(--accent-soft);color:var(--accent)}.nav-link .ico{font-size:20px;width:24px;text-align:center}.sidebar .spacer{flex:1}.main{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:10}.topbar .title{font-weight:700;font-size:17px}.topbar .user{font-size:13px;color:var(--text-muted)}.content{flex:1;padding:16px;padding-bottom:calc(var(--tabbar-h) + 24px);max-width:960px;width:100%;margin:0 auto}.tabbar{position:fixed;bottom:0;left:0;right:0;height:var(--tabbar-h);background:var(--surface);border-top:1px solid var(--border);display:flex;justify-content:space-around;align-items:stretch;padding-bottom:env(safe-area-inset-bottom);z-index:20}.tab-link{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--text-muted);font-size:11px;font-weight:600}.tab-link.active{color:var(--accent)}.tab-link .ico{font-size:22px}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.login-card{width:100%;max-width:380px}.login-card .brand{text-align:center;font-weight:800;font-size:24px;color:var(--accent);margin-bottom:4px}.login-card .sub{text-align:center;color:var(--text-muted);font-size:14px;margin-bottom:24px}.page-title{font-size:22px;font-weight:700;margin:4px 0 16px}.muted{color:var(--text-muted)}.center-screen{min-height:100vh;display:grid;place-items:center;color:var(--text-muted)}.badge{display:inline-block;font-size:12px;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--accent-soft);color:var(--accent)}@media (min-width: 900px){.sidebar{display:flex}.tabbar{display:none}.content{padding-bottom:24px}}
