:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#102a43;background:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-width:320px;min-height:100vh;width:100%}body{background:#f8fafc;color:#102a43}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}#root{width:100%;min-height:100vh}.page-title{margin:0 0 16px;font-size:32px;font-weight:800;color:#102a43}.metrics-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.page-panel{background:#fff;border:1px solid #d9e2ec;border-radius:16px;padding:20px;box-shadow:0 1px 2px #102a430f}.panel-title{margin:0 0 14px;font-size:20px;font-weight:700;color:#102a43}.metric-card{background:#fff;border:1px solid #d9e2ec;border-radius:16px;padding:18px;box-shadow:0 1px 2px #102a430f}.metric-label{font-size:14px;color:#486581;margin-bottom:8px}.metric-value{font-size:34px;font-weight:800;color:#102a43;line-height:1}.feed-list{display:flex;flex-direction:column;gap:14px}.feed-card{background:#fff;border:1px solid #d9e2ec;border-radius:16px;padding:18px;box-shadow:0 1px 2px #102a430f}.feed-meta{font-size:13px;color:#486581;margin-bottom:8px}.feed-text{font-size:16px;color:#102a43;line-height:1.5}.feed-date{margin-top:10px;font-size:14px;color:#829ab1}.insight-box{margin-top:14px;padding:14px;background:#f8fbff;border:1px solid #d9e2ec;border-radius:14px}.insight-title{font-size:14px;font-weight:800;color:#102a43;margin-bottom:10px}.badge{display:inline-block;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700;line-height:1;margin-right:8px;margin-bottom:8px;border:1px solid transparent}.priority-high{background:#fde8e8;color:#b42318;border-color:#f5c2c7}.priority-medium{background:#fff4db;color:#b26a00;border-color:#f7d48b}.priority-low{background:#e8f7ee;color:#127a43;border-color:#b7e4c7}.risk-alert{background:#fde8e8;color:#b42318;border-color:#f5c2c7}.risk-none{background:#e8f7ee;color:#127a43;border-color:#b7e4c7}.default{background:#f0f4f8;color:#486581;border-color:#d9e2ec}.kpi-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px;margin-bottom:20px}.kpi-card{background:#fff;border:1px solid #d9e2ec;border-radius:16px;padding:16px;box-shadow:0 1px 2px #102a430f;display:flex;flex-direction:column;min-height:250px}.kpi-card-expanded{grid-column:span 2;min-height:340px}.kpi-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px}.kpi-period-tabs{display:flex;flex-wrap:wrap;gap:6px}.kpi-period-tab{border:1px solid #d9e2ec;background:#f8fafc;color:#486581;border-radius:999px;padding:4px 8px;font-size:11px;font-weight:700;cursor:pointer}.kpi-period-tab.active{background:#dbeafe;color:#1d4ed8;border-color:#93c5fd}.kpi-card-actions{display:flex;gap:6px}.kpi-icon-button{border:1px solid #d9e2ec;background:#fff;border-radius:10px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer}.kpi-icon-button.active{background:#eff6ff;border-color:#93c5fd}.kpi-title{font-size:14px;font-weight:600;color:#486581;margin-bottom:6px}.kpi-value{font-size:26px;font-weight:800;color:#102a43;margin-bottom:8px}.kpi-target{font-size:14px;font-weight:700;color:#243b53;margin-bottom:10px}.kpi-calculation{font-size:13px;color:#486581;line-height:1.5;margin-top:auto}.kpi-graph-wrap{margin-top:4px;display:flex;flex-direction:column;gap:8px}.kpi-graph{width:100%;height:150px}.kpi-axis{stroke:#d9e2ec;stroke-width:1}.kpi-line{fill:none;stroke:#2563eb;stroke-width:2.5}.kpi-dot{fill:#1d4ed8}.kpi-graph-labels{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:4px}.kpi-graph-label{font-size:10px;color:#829ab1;text-align:center}.kpi-graph-max{font-size:11px;color:#627d98}@media (max-width: 1200px){.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.kpi-card-expanded{grid-column:span 2}}@media (max-width: 1100px){.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 700px){.metrics-grid,.kpi-grid{grid-template-columns:1fr}.kpi-card-expanded{grid-column:span 1}}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 20px;background:radial-gradient(circle at top left,rgba(56,189,248,.12),transparent 30%),radial-gradient(circle at bottom right,rgba(59,130,246,.14),transparent 30%),linear-gradient(180deg,#0f172a,#111827)}.auth-card{width:100%;max-width:460px;background:#0f172aeb;border:1px solid rgba(148,163,184,.2);border-radius:20px;padding:32px 28px;box-shadow:0 24px 60px #00000059;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.auth-brand{display:inline-flex;align-items:center;justify-content:center;margin-bottom:14px;padding:8px 12px;border-radius:12px;background:#3b82f629;color:#93c5fd;font-weight:700;font-size:14px;letter-spacing:.02em}.auth-title{margin:0 0 8px;color:#f8fafc;font-size:30px;font-weight:700;line-height:1.1}.auth-subtitle{margin:0 0 24px;color:#94a3b8;font-size:15px;line-height:1.5}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-label{display:flex;flex-direction:column;gap:8px;color:#e2e8f0;font-size:14px;font-weight:600}.auth-input{width:100%;border:1px solid rgba(148,163,184,.22);background:#0f172ad1;color:#f8fafc;border-radius:12px;padding:13px 14px;font-size:15px;outline:none;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;box-sizing:border-box}.auth-input::placeholder{color:#64748b}.auth-input:focus{border-color:#60a5fa;box-shadow:0 0 0 4px #60a5fa26;background:#0f172af2}.auth-password-wrap{position:relative}.auth-input-password{padding-right:50px}.auth-eye-button{position:absolute;top:50%;right:10px;transform:translateY(-50%);border:0;background:transparent;color:#94a3b8;cursor:pointer;font-size:18px;line-height:1;padding:6px}.auth-eye-button:hover{color:#e2e8f0}.auth-error{border-radius:12px;padding:12px 14px;background:#ef44441f;border:1px solid rgba(239,68,68,.25);color:#fecaca;font-size:14px}.auth-submit{margin-top:4px;border:0;border-radius:12px;padding:14px 16px;font-size:15px;font-weight:700;color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb,#3b82f6);box-shadow:0 10px 24px #2563eb47;transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease}.auth-submit:hover{transform:translateY(-1px);box-shadow:0 14px 28px #2563eb52}.auth-submit:disabled{opacity:.7;cursor:not-allowed;transform:none}.auth-footer{margin-top:18px;color:#94a3b8;font-size:14px;text-align:center}.auth-link{border:0;background:transparent;color:#93c5fd;cursor:pointer;font-size:14px;font-weight:600;padding:0}.auth-link:hover{color:#bfdbfe;text-decoration:underline}.auth-legal-nav{margin-top:20px;padding-top:18px;border-top:1px solid rgba(148,163,184,.18);display:flex;flex-wrap:wrap;gap:10px 16px;justify-content:center;font-size:13px}.auth-legal-nav a{color:#94a3b8;text-decoration:none;font-weight:500}.auth-legal-nav a:hover{color:#cbd5e1;text-decoration:underline}.auth-consent{margin-top:14px;font-size:12px;line-height:1.45;color:#64748b;text-align:center}.auth-consent a{color:#93c5fd;font-weight:600;text-decoration:none}.auth-consent a:hover{text-decoration:underline}.app-sidebar-legal{margin-top:auto;padding-top:16px;border-top:1px solid rgba(148,163,184,.22);display:flex;flex-wrap:wrap;gap:8px 12px;font-size:12px;line-height:1.4}.app-sidebar-legal a{color:#94a3b8;text-decoration:none;font-weight:500}.app-sidebar-legal a:hover{color:#e2e8f0;text-decoration:underline}
