:root{
  --bg:#eef3f9;
  --sidebar:#0f172a;
  --sidebar-2:#111c34;
  --card:#ffffff;
  --line:#dbe4f0;
  --text:#0f172a;
  --muted:#64748b;
  --primary:#2563eb;
  --primary-soft:#dbeafe;
  --success-soft:#dcfce7;
  --warning-soft:#fef3c7;
}
*{box-sizing:border-box}
body{background:linear-gradient(180deg,#f8fbff 0%, var(--bg) 100%);font-family:Inter,Arial,sans-serif;color:var(--text)}
.app-shell{display:flex;min-height:100vh}
.sidebar{position:fixed;top:0;left:0;bottom:0;width:280px;background:linear-gradient(180deg,var(--sidebar) 0%,var(--sidebar-2) 100%);color:#fff;padding:18px 16px;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:#334155 transparent}
.sidebar::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-thumb{background:#334155;border-radius:99px}
.sidebar-brand{padding:8px 10px 18px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:10px}
.brand-title{font-size:1.18rem;font-weight:800;letter-spacing:.01em}
.brand-subtitle{font-size:.82rem;color:#93c5fd;margin-top:2px}
.sidebar-project{margin-top:14px;padding:12px;border-radius:16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08)}
.sidebar-project .label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:#93c5fd}
.sidebar-project .name{font-size:.92rem;font-weight:700;margin-top:4px;color:#f8fafc}
.sidebar-section{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:#94a3b8;margin:16px 8px 8px}
.sidebar-link{display:flex;align-items:center;gap:10px;color:#e5edf7;text-decoration:none;padding:11px 12px;border-radius:14px;margin-bottom:6px;border:1px solid transparent;transition:.18s ease}
.sidebar-link:hover,.sidebar-link.active{background:rgba(255,255,255,.08);border-color:rgba(147,197,253,.18);color:#fff;transform:translateX(1px)}
.sidebar-link .dot{width:8px;height:8px;border-radius:99px;background:#60a5fa;opacity:.85;flex:0 0 auto}
.sidebar-footer{margin-top:auto;padding-top:14px;border-top:1px solid rgba(255,255,255,.08)}
.content{margin-left:280px;flex:1;padding:28px 28px 36px}
.page-hero{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:20px}
.page-hero .title{font-size:1.7rem;font-weight:800;margin:0}
.page-hero .subtitle{color:var(--muted);margin-top:3px}
.project-pill{display:inline-flex;align-items:center;gap:8px;padding:.6rem 1rem;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-weight:700;border:1px solid #bfdbfe;box-shadow:0 8px 18px rgba(37,99,235,.08)}
.card-soft{background:var(--card);border:none;border-radius:22px;box-shadow:0 14px 34px rgba(15,23,42,.08);overflow:hidden}
.card-soft .card-body{padding:1.2rem 1.25rem}
.card-soft .card-header-clean{padding:1rem 1.25rem;background:transparent;border-bottom:1px solid var(--line)}
.metric{font-size:2.1rem;font-weight:800;line-height:1}
.metric-sm{font-size:1.35rem;font-weight:800}
.metric-label{font-size:.88rem;color:var(--muted);margin-bottom:8px}
.metric-icon{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary);font-weight:800}
.thumb{width:58px;height:58px;object-fit:cover;border-radius:12px;border:1px solid var(--line)}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top,#1d4ed8 0,#0f172a 65%)}
.login-card{width:100%;max-width:430px;border-radius:22px;box-shadow:0 22px 60px rgba(2,6,23,.35)}
.table{--bs-table-bg:transparent}.table > :not(caption) > * > *{padding:.85rem .85rem;border-color:#edf2f7}
.table thead th{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:#64748b;background:#f8fbff}
.table tbody tr:hover{background:#f8fbff}
.form-control,.form-select{border-radius:14px;border-color:#dbe4f0;padding:.7rem .85rem}.form-control:focus,.form-select:focus{box-shadow:0 0 0 .2rem rgba(37,99,235,.14);border-color:#93c5fd}
.btn{border-radius:14px;font-weight:600}.btn-primary{box-shadow:0 10px 18px rgba(37,99,235,.18)}
.alert{border:none;border-radius:16px;box-shadow:0 8px 18px rgba(15,23,42,.06)}
.info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.insight-box{padding:16px;border-radius:18px;background:#f8fbff;border:1px solid var(--line);height:100%}
.insight-box .label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:8px}
.insight-box .value{font-weight:700;line-height:1.45}
canvas{width:100%!important;min-height:300px}
.strategy-list li{margin-bottom:.55rem}
.badge-soft{display:inline-flex;align-items:center;padding:.45rem .7rem;border-radius:999px;background:#f8fafc;border:1px solid var(--line);font-weight:600;color:#334155}
.score-badge{display:inline-flex;align-items:center;gap:8px;padding:.55rem .85rem;border-radius:999px;border:1px solid var(--line);background:#fff;font-weight:700}
.score-high{background:#ecfdf5;color:#166534;border-color:#bbf7d0}
.score-medium{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}
.score-low{background:#fff7ed;color:#c2410c;border-color:#fed7aa}
.readonly-note{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;padding:.8rem 1rem;border-radius:16px}
.project-score-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
@media (max-width: 991.98px){
  .sidebar{position:static;width:100%;max-height:none}
  .content{margin-left:0;padding:20px}
  .app-shell{display:block}
  .info-grid,.project-score-grid{grid-template-columns:1fr}
}
.trend-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.timeline-list{display:flex;flex-direction:column;gap:12px}
.timeline-item{display:flex;gap:12px;padding:12px 14px;border-radius:16px;background:#f8fbff;border:1px solid var(--line)}
.timeline-dot{width:12px;height:12px;border-radius:999px;background:#2563eb;flex:0 0 auto;margin-top:6px}
.timeline-body{min-width:0}
.timeline-meta{font-size:.78rem;color:var(--muted)}
.status-pill{display:inline-flex;align-items:center;padding:.35rem .6rem;border-radius:999px;font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em}
.status-pending{background:#fff7ed;color:#c2410c}
.status-approved{background:#ecfdf5;color:#166534}
.status-rejected{background:#fef2f2;color:#b91c1c}
.mini-stat{padding:14px 16px;border-radius:18px;background:#fff;border:1px solid var(--line);box-shadow:0 8px 24px rgba(15,23,42,.04)}
.mini-stat .k{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.mini-stat .v{font-size:1.55rem;font-weight:800;margin-top:6px}
.filter-bar{display:flex;flex-wrap:wrap;gap:10px;align-items:end}
.chart-card canvas{min-height:320px}
.approval-card{border:1px solid var(--line);border-radius:18px;padding:16px;background:#fff}
.approval-card .meta{font-size:.82rem;color:var(--muted)}
@media (max-width: 991.98px){.trend-grid{grid-template-columns:1fr}}
