/* TerraDoc SPT — main.css
 * Generated from v3 monolith
 * Variables, layout, typography, core components
 */


*{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#0c0f14;--ink2:#2d3340;--ink3:#6b7585;
  --bg:#f5f4f0;--white:#ffffff;
  --border:#dedad2;--border2:#b8b4aa;
  --accent:#0f4c35;--accent-l:#e6f2ec;--accent-t:#1a7a55;--accent-s:#4db87a;
  --warn:#92400e;--warn-l:#fef3c7;
  --danger:#991b1b;--danger-l:#fee2e2;
  --blue:#1e3a5f;--blue-l:#e8f0f8;
  --mono:'DM Mono',monospace;
  --sans:'DM Sans',sans-serif;
  --display:'Sora',sans-serif;
}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);font-size:14px;line-height:1.55;height:100vh;overflow:hidden;display:flex;flex-direction:column}

/* ── TOPBAR ── */
#topbar{display:flex;align-items:center;gap:12px;padding:0 20px;height:48px;background:var(--ink);border-bottom:1px solid #1e2430;flex-shrink:0}
#topbar .logo{display:flex;align-items:center;gap:8px}
#topbar .logo-mark{width:28px;height:28px;background:var(--accent-t);border-radius:5px;display:flex;align-items:center;justify-content:center}
#topbar .logo-mark svg{width:16px;height:16px}
#topbar .brand-name{font-family:var(--display);font-size:14px;color:#fff;font-weight:700;letter-spacing:.3px}
#topbar .sep{width:1px;height:20px;background:#2a303e;margin:0 4px}
#topbar .country-pill{display:flex;align-items:center;gap:6px;background:#1a1f2a;border:1px solid #2a303e;border-radius:4px;padding:3px 10px;font-size:11px;color:#8a9bb0;font-family:var(--mono);cursor:pointer}
#topbar .country-pill span{color:#e0e8f0;font-weight:500}
#topbar .norm-tags{display:flex;gap:4px;margin-left:auto}
#topbar .norm-tag{font-size:10px;font-family:var(--mono);padding:2px 7px;border-radius:3px;background:#0f4c35;color:#4db87a;font-weight:500}
#topbar .version-tag{font-size:10px;color:#4a5568;font-family:var(--mono);margin-left:8px}

/* ── LAYOUT ── */
#shell{display:flex;flex:1;overflow:hidden}
#sidebar{width:208px;min-width:208px;background:var(--white);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto}
#main{flex:1;overflow:hidden;display:flex;flex-direction:column}
#content-area{flex:1;overflow-y:auto;padding:20px 24px}

/* ── SIDEBAR ── */
.nav-grp{padding:14px 10px 2px;font-size:9.5px;font-weight:600;color:var(--ink3);letter-spacing:1.2px;text-transform:uppercase}
.nav-item{display:flex;align-items:center;gap:8px;padding:6px 10px;cursor:pointer;border-radius:5px;margin:1px 5px;font-size:12.5px;color:var(--ink2);transition:background .1s;white-space:nowrap;overflow:hidden}
.nav-item:hover{background:#f5f4f0}
.nav-item.active{background:var(--accent-l);color:var(--accent);font-weight:500}
.nav-item .ni{width:14px;height:14px;flex-shrink:0;opacity:.6}
.nav-item.active .ni{opacity:1}
.nav-badge{margin-left:auto;font-size:9px;background:var(--accent);color:#fff;padding:1px 5px;border-radius:8px;font-family:var(--mono)}
.spt-selector{padding:10px;border-top:1px solid var(--border);margin-top:auto}
.spt-pill{display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--accent-l);border:1px solid #a3c9b5;border-radius:5px;font-size:11.5px;color:var(--accent);font-weight:500;cursor:pointer;margin-bottom:4px}
.spt-add{display:flex;align-items:center;gap:5px;padding:5px 10px;border:1px dashed var(--border2);border-radius:5px;font-size:11px;color:var(--ink3);cursor:pointer;transition:all .15s}
.spt-add:hover{border-color:var(--accent-t);color:var(--accent)}

/* ── HEADER BAR ── */
#header-bar{display:flex;align-items:center;gap:12px;padding:10px 24px;background:var(--white);border-bottom:1px solid var(--border);flex-shrink:0}
#header-bar .proj-name{font-family:var(--display);font-size:15px;font-weight:700;color:var(--ink)}
#header-bar .proj-meta{display:flex;gap:10px;margin-left:8px}
#header-bar .meta-chip{font-size:11px;color:var(--ink3);font-family:var(--mono)}
#header-bar .meta-chip b{color:var(--ink2)}
#header-bar .run-btn{margin-left:auto;background:var(--accent);color:#fff;border:none;border-radius:5px;padding:6px 16px;font-family:var(--sans);font-size:12.5px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;transition:background .15s}
#header-bar .run-btn:hover{background:#0a3527}

/* ── SECTION LAYOUT ── */
.sec-title{font-family:var(--display);font-size:16px;font-weight:700;color:var(--ink);margin-bottom:4px}
.sec-sub{font-size:12px;color:var(--ink3);margin-bottom:16px}
.sec-sep{border:none;border-top:1px solid var(--border);margin:18px 0}

/* ── FORM ── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px}
.form-grid.g3{grid-template-columns:1fr 1fr 1fr}
.form-grid.g1{grid-template-columns:1fr}
.field{display:flex;flex-direction:column;gap:3px}
.field label{font-size:10.5px;font-weight:600;color:var(--ink3);text-transform:uppercase;letter-spacing:.6px}
.field input,.field select,.field textarea{border:1px solid var(--border2);border-radius:4px;padding:6px 9px;font-size:13px;font-family:var(--sans);color:var(--ink);background:#fff;transition:border .15s;-webkit-appearance:none}
.field input:focus,.field select:focus{outline:none;border-color:var(--accent)}
.field .hint{font-size:10.5px;color:var(--ink3);margin-top:1px}
.field input[readonly]{background:#f8f7f4;color:var(--ink3)}

/* ── CARDS ── */
.card{background:var(--white);border:1px solid var(--border);border-radius:7px;padding:14px}
.card h3{font-size:12.5px;font-weight:600;color:var(--ink);margin-bottom:10px;display:flex;align-items:center;gap:7px}
.card-grid{display:grid;gap:10px}
.card-grid.g2{grid-template-columns:1fr 1fr}
.card-grid.g3{grid-template-columns:1fr 1fr 1fr}
.card-grid.g4{grid-template-columns:1fr 1fr 1fr 1fr}

/* ── METRIC CARDS ── */
.metric{background:var(--white);border:1px solid var(--border);border-radius:6px;padding:12px}
.metric .val{font-family:var(--mono);font-size:21px;font-weight:500;color:var(--ink)}
.metric .lbl{font-size:10.5px;color:var(--ink3);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.metric .sub{font-size:10px;color:var(--ink3);margin-top:3px}
.metric.good .val{color:var(--accent)}
.metric.bad .val{color:var(--danger)}
.metric.warn .val{color:var(--warn)}

/* ── GAUGE ── */
.gauge-wrap{display:flex;flex-direction:column;align-items:center;gap:4px}
.gauge-arc{position:relative;width:90px;height:50px;overflow:hidden}
.gauge-arc svg{width:100%;height:100%}
.gauge-label{font-size:10px;color:var(--ink3);text-align:center}
.gauge-val{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--ink);text-align:center}

/* ── TABLE ── */
.tbl-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:6px}
table{width:100%;border-collapse:collapse;font-size:12px}
th{background:#f2f0eb;font-weight:600;padding:7px 10px;text-align:left;color:var(--ink2);border-bottom:1px solid var(--border);font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}
td{padding:7px 10px;border-bottom:1px solid var(--border);color:var(--ink2);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr.rec-row td{background:#e6f2ec}
tr.fail-row td{background:#fff5f5}

/* ── BADGE ── */
.badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:3px;font-size:10.5px;font-weight:600;font-family:var(--mono)}
.badge.ok{background:var(--accent-l);color:var(--accent)}
.badge.fail{background:var(--danger-l);color:var(--danger)}
.badge.warn{background:var(--warn-l);color:var(--warn)}
.badge.info{background:var(--blue-l);color:var(--blue)}
.badge.rec{background:var(--accent);color:#fff}
.badge.neutral{background:#f0eee9;color:var(--ink2)}

/* ── ALERT ── */
.alert{border-radius:5px;padding:9px 12px;font-size:12px;margin-bottom:12px;display:flex;gap:9px;align-items:flex-start;line-height:1.5}
.alert.ok{background:var(--accent-l);border:1px solid #a3c9b5;color:var(--accent)}
.alert.warn{background:var(--warn-l);border:1px solid #fcd34d;color:var(--warn)}
.alert.danger{background:var(--danger-l);border:1px solid #fca5a5;color:var(--danger)}
.alert.info{background:var(--blue-l);border:1px solid #93c5fd;color:var(--blue)}
.alert .ai{font-size:15px;margin-top:1px;flex-shrink:0}
.alert strong{display:block;margin-bottom:1px;font-size:12.5px}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border:1px solid var(--border2);border-radius:4px;font-size:12.5px;font-family:var(--sans);font-weight:500;cursor:pointer;background:#fff;color:var(--ink2);transition:all .12s}
.btn:hover{background:var(--bg);border-color:var(--ink3)}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.primary:hover{background:#0a3527}
.btn.sm{padding:4px 10px;font-size:11.5px}
.btn.xs{padding:3px 8px;font-size:11px}
.btn-row{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap;align-items:center}

/* ── SVG PANEL ── */
.svg-panel{background:var(--white);border:1px solid var(--border);border-radius:7px;overflow:hidden}
.svg-toolbar{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border)}
.svg-toolbar h3{font-size:12px;font-weight:600;color:var(--ink);flex:1;font-family:var(--mono)}
.svg-body{padding:10px;background:#fafaf9;overflow:auto;max-height:380px;display:flex;align-items:center;justify-content:center}
.svg-body svg{max-width:100%;height:auto}

/* ── MEASUREMENT ROW ── */
.meas-tbl{width:100%;border-collapse:collapse;font-size:12px}
.meas-tbl th{background:#f2f0eb;padding:6px 9px;text-align:left;border-bottom:1px solid var(--border);font-size:10.5px;font-weight:600;color:var(--ink2);text-transform:uppercase;letter-spacing:.4px}
.meas-tbl td{padding:5px 9px;border-bottom:1px solid var(--border)}
.meas-tbl td input{width:90px;padding:4px 6px;border:1px solid var(--border2);border-radius:3px;font-size:12px;font-family:var(--mono)}
.meas-tbl td input:focus{outline:none;border-color:var(--accent)}
.rho-val{font-family:var(--mono);font-weight:600;color:var(--accent);font-size:12.5px}

/* ── JSON VIEWER ── */
.json-view{background:#0c0f14;border-radius:5px;padding:12px;font-family:var(--mono);font-size:11px;color:#4db87a;overflow-x:auto;max-height:280px;overflow-y:auto;line-height:1.6}

/* ── PROGRESS OVERLAY ── */
#progress-overlay{display:none;position:fixed;inset:0;background:rgba(12,15,20,.75);z-index:1000;align-items:center;justify-content:center;flex-direction:column;gap:16px}
#progress-overlay.show{display:flex}
.progress-card{background:#fff;border-radius:8px;padding:28px 36px;width:320px;text-align:center}
.progress-card .pc-title{font-family:var(--display);font-size:15px;font-weight:700;color:var(--ink);margin-bottom:14px}
.progress-bar-wrap{background:#f0eee9;border-radius:4px;height:4px;margin-bottom:12px;overflow:hidden}
.progress-bar{background:var(--accent-t);height:4px;border-radius:4px;width:0;transition:width .4s}
.progress-step{font-size:12px;color:var(--ink3);font-family:var(--mono)}

/* ── SCROLL ── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}

/* ── DISCLAIMER ── */
.disclaimer{background:#f5f4f0;border:1px solid var(--border2);border-radius:5px;padding:10px 12px;font-size:11px;color:var(--ink3);line-height:1.6}

/* ── STEPPER ── */
#stepper{display:flex;align-items:center;padding:9px 24px;background:var(--white);border-bottom:1px solid var(--border);gap:0;flex-shrink:0}
.step{display:flex;align-items:center;gap:5px;padding:4px 8px;border-radius:20px;font-size:11px;color:var(--ink3)}
.step .sn{width:18px;height:18px;border-radius:50%;background:var(--border2);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff;flex-shrink:0}
.step.done .sn{background:var(--accent)}
.step.active{color:var(--ink);font-weight:500}
.step.active .sn{background:var(--accent-t);box-shadow:0 0 0 3px var(--accent-l)}
.step-line{flex:1;height:1px;background:var(--border);margin:0 2px}
.step-line.done{background:var(--accent)}

/* ── VALIDATION TABLE ── */
.val-table{width:100%;border-collapse:collapse;font-size:12px}
.val-table th{background:#f2f0eb;padding:6px 10px;text-align:left;border-bottom:1px solid var(--border);font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--ink2)}
.val-table td{padding:7px 10px;border-bottom:1px solid var(--border);vertical-align:middle}
.val-table tr:last-child td{border-bottom:none}
.val-bar-wrap{width:80px;height:8px;background:#f0eee9;border-radius:4px;overflow:hidden}
.val-bar{height:8px;border-radius:4px}

/* tabs */
.tab-bar{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:14px}
.tab{padding:7px 14px;font-size:12.5px;color:var(--ink3);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .12s}
.tab:hover{color:var(--ink2)}
.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:500}


/* ── PRINT STYLES ── */
@media print {
  body { overflow: visible !important; }
  #sidebar, #topbar, .btn, #progress-overlay { display: none !important; }
  #content-area { padding: 0; }
  .card { break-inside: avoid; }
  table { break-inside: avoid; }
}
