:root{
  --navy:#1b2a4a; --gold:#c9a227; --green:#2e7d32; --amber:#b8860b;
  --orange:#c1632f; --red:#b3261e; --gray:#6b7280; --teal:#0f766e; --purple:#6d28d9; --blue:#2563eb;
  --bg:#f5f6f8; --card:#ffffff; --border:#e2e5ea;
}
*{box-sizing:border-box;}
body{font-family:-apple-system,Segoe UI,Helvetica,Arial,sans-serif;margin:0;background:var(--bg);color:#222;}
a{color:var(--navy);text-decoration:none;}
a:hover{text-decoration:underline;}

/* Header / nav */
header.app{background:var(--navy);color:#fff;padding:14px 24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;}
header.app h1{margin:0;font-size:18px;}
header.app nav a{color:#cfd6e6;margin-left:16px;font-size:14px;font-weight:600;}
header.app nav a.active, header.app nav a:hover{color:#fff;}
header.app .logout{color:#f5c2c0;}

.container{max-width:1300px;margin:0 auto;padding:20px;}

/* Cards */
.card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:16px;}
.card h2{margin:0 0 12px;font-size:16px;color:var(--navy);}
.card h3{margin:18px 0 10px;font-size:14px;color:var(--navy);border-top:1px solid var(--border);padding-top:14px;}
.card h3:first-child{border-top:none;padding-top:0;margin-top:0;}

/* Grid form layout */
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;}
.form-grid label{display:block;font-size:12px;font-weight:700;color:var(--gray);margin-bottom:4px;}
.form-grid .full{grid-column:1/-1;}
input[type=text], input[type=email], input[type=tel], input[type=date], input[type=time],
input[type=number], input[type=url], select, textarea{
  width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:6px;font-size:14px;font-family:inherit;
}
textarea{min-height:80px;resize:vertical;}

/* Buttons */
.btn{display:inline-block;padding:9px 16px;border-radius:6px;border:1px solid var(--navy);background:var(--navy);color:#fff;font-size:13px;font-weight:600;cursor:pointer;text-decoration:none;margin:4px 6px 0 0;}
.btn:hover{opacity:.92;text-decoration:none;}
.btn.secondary{background:#fff;color:var(--navy);}
.btn.danger{background:#fff;color:var(--red);border-color:var(--red);}
.btn.small{padding:4px 10px;font-size:12px;}

/* KPI cards */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:16px;}
.kpi{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px;text-align:center;}
.kpi .num{font-size:26px;font-weight:800;color:var(--navy);}
.kpi .label{font-size:12px;color:var(--gray);margin-top:4px;}

/* Pipeline bar */
.pipeline-row{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:13px;}
.pipeline-row .name{width:170px;flex-shrink:0;}
.pipeline-row .bar-wrap{flex:1;background:#eef0f4;border-radius:5px;height:10px;overflow:hidden;}
.pipeline-row .bar{height:100%;background:var(--gold);}
.pipeline-row .count{width:30px;text-align:right;font-weight:700;color:var(--navy);}

/* Tables */
table{width:100%;border-collapse:collapse;font-size:13px;background:#fff;}
table th, table td{padding:8px 10px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top;}
table th{background:#f0f2f6;font-weight:700;color:var(--navy);}
.table-wrap{overflow-x:auto;}

/* Pills */
.pill{display:inline-block;padding:2px 9px;border-radius:10px;font-size:11px;font-weight:700;color:#fff;white-space:nowrap;}
.pill-gray{background:var(--gray);}
.pill-blue{background:var(--blue);}
.pill-teal{background:var(--teal);}
.pill-purple{background:var(--purple);}
.pill-amber{background:var(--amber);}
.pill-green{background:var(--green);}
.pill-red{background:var(--red);}

/* Score / readiness bands */
.band-red{background:linear-gradient(135deg,#b3261e,#7f1c16);}
.band-orange{background:linear-gradient(135deg,#c1632f,#9c4a1f);}
.band-yellow{background:linear-gradient(135deg,#b8860b,#8a6308);}
.band-green{background:linear-gradient(135deg,#2e7d32,#1b5e20);}
.score-total-box{padding:16px;border-radius:8px;text-align:center;color:#fff;}
.score-total-box .num{font-size:32px;font-weight:800;line-height:1;}
.score-total-box .label{font-size:13px;margin-top:4px;font-weight:600;}

/* Scoring form */
.score-cat{border:1px solid var(--border);border-radius:8px;margin-bottom:10px;overflow:hidden;}
.score-cat .cat-head{background:#f0f2f6;padding:8px 12px;font-weight:700;font-size:13px;color:var(--navy);display:flex;justify-content:space-between;}
.score-cat .cat-body{padding:10px 12px;}
.score-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:7px 4px;font-size:13px;cursor:pointer;border-radius:6px;}
.score-item:hover{background:#f7f8fa;}
.score-item input[type=number]{width:60px;text-align:center;}
.score-item input[type=checkbox]{width:18px;height:18px;flex:none;cursor:pointer;}
.score-item .muted{flex:none;min-width:50px;text-align:right;}
#scoreNotes{width:100%;font-family:inherit;font-size:13px;padding:8px;border:1px solid var(--border);border-radius:6px;resize:vertical;}

/* Tabs */
.tabs{display:flex;gap:4px;border-bottom:2px solid var(--border);margin-bottom:16px;flex-wrap:wrap;}
.tabs a{padding:9px 14px;font-size:13px;font-weight:600;color:var(--gray);border-bottom:3px solid transparent;margin-bottom:-2px;}
.tabs a.active{color:var(--navy);border-bottom-color:var(--gold);}

/* Login */
.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;}
.login-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:32px;width:340px;box-shadow:0 10px 30px rgba(0,0,0,.06);}
.login-card h1{font-size:18px;color:var(--navy);margin-top:0;}
.error{background:#fdecea;border:1px solid #f6c6c2;color:var(--red);padding:8px 12px;border-radius:6px;font-size:13px;margin-bottom:12px;}
.notice{background:#eef7ee;border:1px solid #cfe8cf;color:var(--green);padding:8px 12px;border-radius:6px;font-size:13px;margin-bottom:12px;}

.muted{color:var(--gray);font-size:12px;}
.checklist-item{padding:6px 0;border-bottom:1px solid #f0f1f3;font-size:13px;}
.checklist-item:last-child{border-bottom:none;}
.checklist-item .gap{color:var(--gray);font-size:11px;}

@media (max-width:700px){
  .pipeline-row .name{width:120px;}
}
