.btn{border:0;border-radius:10px;padding:10px 13px;font-weight:900;font-size:13px;display:inline-flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;transition:transform .12s ease,box-shadow .12s ease}.btn:hover{transform:translateY(-1px)}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;box-shadow:0 8px 18px rgba(230,51,40,.18)}.btn-secondary{background:#e7edf4;color:#344054}.btn-blue{background:#dbeafe;color:#1e40af}.btn-green{background:#dcfce7;color:#166534}.btn-red{background:#fee2e2;color:#991b1b}.btn-ghost{background:#fff;color:#344054;border:1px solid var(--line)}.btn-small{padding:7px 9px;font-size:12px;border-radius:8px}.status-pill,.badge{display:inline-flex;align-items:center;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:900}.status-pill{background:#eff6ff;color:#1e40af;border:1px solid #bfdbfe}.badge.green{background:#dcfce7;color:#166534}.badge.red{background:#fee2e2;color:#991b1b}.badge.amber{background:#fef3c7;color:#92400e}.badge.blue{background:#dbeafe;color:#1e40af}.badge.slate{background:#e2e8f0;color:#344054}.badge.brand{background:#ffe4e6;color:#9f1239;border:1px solid #fecdd3}.badge.purple{background:#ede9fe;color:#5b21b6}
.action-menu{position:relative}.dropdown-panel{display:none;position:absolute;right:0;top:calc(100% + 8px);min-width:245px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:7px;z-index:30}.dropdown-panel.open{display:grid}.dropdown-panel button{background:#fff;border:0;text-align:left;padding:10px 11px;border-radius:8px;font-weight:800;color:#344054}.dropdown-panel button:hover{background:#f3f6fa}.dropdown-panel hr{border:0;border-top:1px solid var(--line-soft);width:100%;margin:4px 0}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:16px}.card + .card{margin-top:14px}.module-title{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}.module-title h3{margin:0;font-size:18px;letter-spacing:-.02em}.module-title p{margin:4px 0 0;color:var(--muted);font-size:13px}.grid{display:grid;gap:14px}.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.grid-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(215px,1fr));gap:14px;margin-bottom:16px}.kpi-card{min-height:132px;position:relative;overflow:hidden}.kpi-card small{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:950}.kpi-card .value{font-size:28px;font-weight:950;letter-spacing:-.04em;margin-top:10px}.kpi-card .sub{font-size:13px;color:var(--muted);line-height:1.25;margin-top:4px}.kpi-card details{margin-top:10px;font-size:12px;color:#344054;border-top:1px solid var(--line-soft);padding-top:8px}.kpi-card summary{font-weight:900;cursor:pointer;color:var(--accent-dark)}
.form-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}label{display:grid;gap:6px;font-size:12px;color:#344054;font-weight:900}.span-2{grid-column:span 2}.span-3{grid-column:span 3}.span-4{grid-column:span 4}input,select,textarea{width:100%;border:1px solid #cfd8e3;border-radius:10px;background:#fff;color:var(--text);padding:10px 11px;font-size:13px;outline:0}textarea{min-height:82px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(230,51,40,.10)}.hint{font-weight:500;color:var(--muted);font-size:11px;line-height:1.3}.input-row{display:flex;gap:8px}.input-row input{flex:1}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:12px;background:#fff}table{width:100%;border-collapse:collapse;background:#fff}th,td{padding:10px 9px;border-bottom:1px solid var(--line-soft);text-align:left;vertical-align:top;font-size:12px}th{background:#f4f7fb;color:#344054;font-size:11px;text-transform:uppercase;letter-spacing:.05em;font-weight:950}.nowrap{white-space:nowrap}.empty{padding:18px;border:1px dashed #cbd5e1;border-radius:12px;background:#f8fafc;color:var(--muted);text-align:center}.delivery-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:12px;margin-bottom:14px}.delivery-card{border:1px solid var(--line);border-radius:14px;background:#fff;padding:13px;box-shadow:0 4px 14px rgba(15,23,42,.05)}.delivery-card h4{margin:0;font-size:15px}.delivery-card small{color:var(--muted)}.delivery-meta{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:10px 0}.delivery-meta div{background:#f8fafc;border:1px solid var(--line-soft);border-radius:10px;padding:8px}.delivery-meta span{display:block;font-size:10px;color:var(--muted);text-transform:uppercase;font-weight:950}.delivery-meta strong{font-size:12px}.card-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.tab-btn{border:1px solid var(--line);background:#fff;border-radius:999px;padding:8px 12px;font-weight:900;color:#344054}.tab-btn.active{background:#111827;color:#fff;border-color:#111827}.tab-panel{display:none}.tab-panel.active{display:block}.modal-root{display:none;position:fixed;inset:0;z-index:100;background:rgba(15,23,42,.65);padding:24px;overflow:auto}.modal-root.open{display:grid;place-items:start center}.modal{width:min(980px,100%);background:#fff;border-radius:18px;box-shadow:0 30px 100px rgba(0,0,0,.35);overflow:hidden}.modal-header{background:#111827;color:#fff;padding:16px 18px;display:flex;justify-content:space-between;gap:12px}.modal-header h3{margin:0;font-size:18px}.modal-body{padding:18px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;padding:14px 18px;border-top:1px solid var(--line);background:#f8fafc}.alert{padding:12px;border-radius:12px;border:1px solid;font-size:13px;line-height:1.35}.alert.green{background:#f0fdf4;border-color:#bbf7d0;color:#166534}.alert.amber{background:#fffbeb;border-color:#fde68a;color:#92400e}.alert.red{background:#fff1f2;border-color:#fecaca;color:#991b1b}.alert.blue{background:#eff6ff;border-color:#bfdbfe;color:#1e40af}.alert-list{display:grid;gap:8px}.progress-track{height:12px;background:#e2e8f0;border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:var(--blue);border-radius:999px}.formula-box{display:none;margin-top:10px}.formula-box.open{display:block}.view-note{color:var(--muted);font-size:12px;margin:8px 0 12px}
@media(max-width:1020px){.grid-2,.grid-3,.grid-4,.form-grid{grid-template-columns:1fr}.span-2,.span-3,.span-4{grid-column:auto}.module-title{flex-direction:column}.delivery-cards{grid-template-columns:1fr}}

/* V6.1 Route planner */
.input-with-action{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:end}.modal-wide{max-width:760px}.modal-route{max-width:980px}.route-options{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.route-card{border:1px solid var(--line);border-radius:16px;background:#fff;padding:14px;box-shadow:0 8px 24px rgba(15,23,42,.06)}.route-card.selected{border-color:var(--brand);background:#fff7f7}.route-card-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;margin-bottom:10px}.route-card h4{margin:0;font-size:15px}.badge-soft{display:inline-flex;padding:5px 8px;border-radius:999px;background:#eef2ff;color:#1e40af;font-size:11px;font-weight:800;white-space:nowrap}.route-metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:10px 0}.route-metrics div{border:1px solid #e5e7eb;border-radius:12px;padding:8px;background:#f8fafc}.route-metrics span{display:block;color:var(--muted);font-size:11px;font-weight:800}.route-metrics strong{font-size:13px}.route-points{display:grid;gap:4px;margin:10px 0;padding:10px;border-radius:12px;background:#f8fafc;border:1px dashed #cbd5e1}.route-points span{font-size:12px;color:#334155}.route-warning{border:1px solid #fde68a;background:#fffbeb;color:#78350f;border-radius:14px;padding:12px;margin-bottom:14px}.route-warning p{margin:5px 0 0;font-size:13px;line-height:1.35}.route-meta-line{margin-top:8px;color:var(--muted);font-size:12px;display:flex;gap:8px;flex-wrap:wrap}.route-meta-line b{color:#334155}
@media(max-width:1000px){.route-options{grid-template-columns:1fr}.input-with-action{grid-template-columns:1fr}}

/* V6.2 evidence attachments */
.evidence-list{display:grid;gap:8px}
.evidence-row{display:flex;justify-content:space-between;align-items:center;gap:10px;border:1px solid var(--line);border-radius:12px;background:#f8fafc;padding:9px 10px}
.evidence-row strong{display:block;font-size:13px;color:var(--text)}
.evidence-row small{display:block;font-size:11px;color:var(--muted);margin-top:2px}
.small-empty{padding:10px;font-size:12px}
.kpi-section-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px;margin:12px 0}
.kpi-strip{display:grid;gap:8px}
.kpi-line{display:grid;grid-template-columns:180px 1fr 90px;gap:10px;align-items:center;background:#f8fafc;border:1px solid var(--line-soft);border-radius:12px;padding:9px}
.kpi-line span{font-size:12px;color:var(--muted);font-weight:900}
.kpi-line strong{font-size:13px;text-align:right}
.kpi-bar{height:9px;background:#e2e8f0;border-radius:999px;overflow:hidden}
.kpi-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--blue),var(--green));border-radius:999px}
.phva-mode-actions{display:flex;gap:8px;flex-wrap:wrap}
.analysis-box{border:1px solid var(--line);background:#f8fafc;border-radius:14px;padding:12px;line-height:1.45;color:#334155}
.analysis-box h4{margin:0 0 6px;font-size:14px}
.analysis-box ul{margin:6px 0 0 18px;padding:0}
