:root{
  --bg:#f4f7fb;
  --panel:#ffffff;
  --line:#dbe3ee;
  --text:#1f2937;
  --muted:#667085;
  --brand:#153e75;
  --brand-2:#1f5aa6;
  --danger:#b42318;
  --shadow:0 12px 32px rgba(16,24,40,.08);
  --radius:18px;
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family: Inter, Arial, Helvetica, sans-serif;
  background:var(--bg);
  color:var(--text);
}
.app-shell{
  display:grid;
  grid-template-columns:300px 1fr;
  min-height:100vh;
}
.sidebar{
  background:#0f2747;
  color:#fff;
  padding:24px 18px;
  display:flex;
  flex-direction:column;
  gap:22px;
}
.brand-wrap{display:flex;gap:14px;align-items:flex-start}
.brand-logo{
  width:54px;height:54px;border-radius:14px;background:#fff;padding:6px;object-fit:contain;
}
.brand-wrap h1{margin:0 0 6px;font-size:1.1rem}
.brand-wrap p{margin:0;color:#d5e1f3;font-size:.9rem;line-height:1.4}
.nav{display:flex;flex-direction:column;gap:10px}
.nav-btn{
  width:100%;padding:12px 14px;border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);color:#fff;text-align:left;border-radius:12px;cursor:pointer;font-size:.95rem
}
.nav-btn.active,.nav-btn:hover{background:#fff;color:#0f2747}
.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:10px}
.main{padding:24px}
.topbar{
  display:flex;justify-content:space-between;gap:20px;align-items:flex-start;margin-bottom:24px
}
.topbar h2{margin:0 0 6px}
.topbar p{margin:0;color:var(--muted)}
.topbar-actions{display:flex;gap:10px;flex-wrap:wrap}
.tab-pane{display:none}.tab-pane.active{display:block}
.grid{display:grid;gap:18px;margin-bottom:18px}
.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.compact{gap:12px}
.panel,.metric-card,.zoom-card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)
}
.panel,.zoom-card{padding:18px}
.metric-card{padding:18px;display:flex;flex-direction:column;gap:10px}
.metric-label{color:var(--muted);font-size:.92rem}
.metric-value{font-size:1.8rem;font-weight:800}
.panel-header{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:14px}
.panel-header h3{margin:0;font-size:1.05rem}
.badge{padding:6px 10px;background:#e8f1fb;color:var(--brand);border-radius:999px;font-size:.82rem;font-weight:700}
.clean-list{margin:0;padding-left:18px;line-height:1.6}
.number-list{margin:0;padding-left:18px;line-height:1.7}
.notes-box,.plan-output,textarea,input,select{
  width:100%;border:1px solid var(--line);border-radius:12px;padding:12px 14px;font:inherit;background:#fff
}
.plan-output{background:#fbfdff}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.form-grid label,label{display:flex;flex-direction:column;gap:7px;font-weight:600}
.wide{grid-column:1 / -1}
.checklist-grid{margin:16px 0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.checklist-grid label{flex-direction:row;align-items:center;font-weight:500}
.button-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.primary-btn,.secondary-btn,.danger-btn,.primary-link-btn,.import-label,.small-btn{
  border:none;border-radius:12px;padding:12px 14px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem
}
.small-btn{padding:8px 10px}
.primary-btn,.primary-link-btn{background:var(--brand);color:#fff}
.secondary-btn,.import-label,.small-btn{background:#edf3fb;color:var(--brand)}
.danger-btn{background:#fee4e2;color:var(--danger)}
.full{width:100%}
.score-wrap{display:grid;grid-template-columns:140px 1fr;gap:16px;align-items:center;margin-bottom:16px}
.score-ring{position:relative;width:120px;height:120px}
.score-ring svg{width:120px;height:120px;transform:rotate(-90deg)}
.ring-bg{fill:none;stroke:#e5edf7;stroke-width:10}
.ring-progress{fill:none;stroke:var(--brand-2);stroke-width:10;stroke-linecap:round;stroke-dasharray:326.73;stroke-dashoffset:326.73}
.score-number{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.6rem}
.score-summary{color:var(--muted);line-height:1.5}
.resource-box{min-height:220px;border:1px solid var(--line);border-radius:14px;background:#fbfdff;padding:16px;line-height:1.6}
.table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:12px 10px;border-bottom:1px solid var(--line);vertical-align:top}
th{color:var(--muted);font-size:.9rem}
.program-list{display:grid;gap:12px}
.program-card{border:1px solid var(--line);border-radius:14px;padding:14px;background:#fbfdff}
.program-grid{display:grid;grid-template-columns:2fr 1fr 1fr 2fr auto;gap:10px;align-items:end}
.muted{color:var(--muted)}
.zoom-screen{
  background:linear-gradient(180deg,#f7fbff,#eef5ff);border:1px solid #d6e3f3;border-radius:24px;padding:24px;box-shadow:var(--shadow)
}
.zoom-hero{display:flex;align-items:center;gap:16px;margin-bottom:22px}
.hero-logo{width:74px;height:74px;background:#fff;border-radius:18px;padding:8px;object-fit:contain}
.zoom-hero h1{margin:0 0 8px;font-size:2rem}
.zoom-hero p{margin:0;color:var(--muted);font-size:1.05rem}
.zoom-card h3{margin-top:0}
.zoom-cta{display:flex;flex-direction:column;justify-content:center;background:#153e75;color:#fff}
.zoom-cta p{color:#e2ecf9}
@media (max-width:1100px){.app-shell{grid-template-columns:1fr}.sidebar{padding-bottom:10px}}
@media (max-width:900px){
  .cols-2,.cols-3,.cols-4,.form-grid,.checklist-grid,.program-grid{grid-template-columns:1fr}
  .topbar{flex-direction:column}
  .score-wrap{grid-template-columns:1fr}
  .zoom-hero{flex-direction:column;align-items:flex-start}
}
