:root{--navy: #0d2b3e;--teal: #1d9e75;--teal-dk: #0f6e56;--teal-pl: #e1f5ee;--bg: #f7f6f3;--surface: #fff;--text: #111827;--text2: #4b5563;--text3: #9ca3af;--border: rgba(0, 0, 0, .09);--border-md: rgba(0, 0, 0, .16);--red-pl: #fcebeb;--red-dk: #791f1f;--font: "DM Sans", system-ui, sans-serif;--mono: "DM Mono", ui-monospace, monospace}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:13px}.shell{display:flex;height:100vh;overflow:hidden}.sidebar{width:200px;flex-shrink:0;background:var(--navy);color:#fff;display:flex;flex-direction:column}.logo{padding:16px 16px 14px;font-size:16px;font-weight:500;border-bottom:.5px solid rgba(255,255,255,.1)}.logo span{color:#5dcaa5}.logo-sub{font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:#fff6;margin-top:3px;font-family:var(--mono)}.nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:2px}.nav-item{padding:8px 11px;border-radius:6px;font-size:12px;color:#ffffff8c}.nav-item.active{background:#ffffff1f;color:#fff;font-weight:500}.nav-item.disabled{color:#ffffff47}.sidebar-foot{padding:12px 16px;font-size:10px;line-height:1.5;color:#ffffff4d;border-top:.5px solid rgba(255,255,255,.08);font-family:var(--mono)}.main{flex:1;display:flex;flex-direction:column;overflow:hidden}.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 22px;background:var(--surface);border-bottom:.5px solid var(--border)}.crumb{font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:var(--text3)}.topbar h1{font-size:17px;font-weight:500}.prop{text-align:right;font-weight:500}.prop-code{display:block;font-size:10px;color:var(--text3);font-family:var(--mono)}.content{flex:1;overflow-y:auto;padding:18px 22px}.hint{color:var(--text2);font-size:12px;max-width:720px;margin-bottom:16px;line-height:1.5}.loading{color:var(--text3);padding:40px;text-align:center}.banner{padding:8px 12px;border-radius:6px;font-size:12px;margin-bottom:14px}.banner.ok{background:var(--teal-pl);color:var(--teal-dk)}.banner.err{background:var(--red-pl);color:var(--red-dk)}.grid{width:100%;border-collapse:collapse;background:var(--surface);border:.5px solid var(--border);border-radius:10px;overflow:hidden}.grid th{text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--text3);font-weight:500;padding:9px 10px;background:var(--bg);border-bottom:.5px solid var(--border)}.grid td{padding:6px 10px;border-bottom:.5px solid var(--border);vertical-align:middle}.grid tr:last-child td{border-bottom:none}.grid .code{font-size:11px;color:var(--text2)}.mono{font-family:var(--mono)}.center{text-align:center}.grid input,.grid select,.add-row input,.add-row select{font-family:var(--font);font-size:12px;padding:5px 7px;border:.5px solid var(--border-md);border-radius:5px;background:#fff;width:100%}.grid input:focus,.grid select:focus,.add-row input:focus,.add-row select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 1px var(--teal-pl)}.grid .num{width:64px}.grid .features{min-width:150px}.btn{font-family:var(--font);font-size:11px;font-weight:500;padding:5px 12px;border-radius:5px;border:.5px solid var(--border-md);background:#fff;color:var(--text2);cursor:pointer}.btn:disabled{opacity:.45;cursor:default}.btn:not(:disabled):hover{border-color:var(--teal);color:var(--teal-dk)}.btn.primary{background:var(--teal);border-color:var(--teal-dk);color:#fff}.btn.primary:not(:disabled):hover{background:var(--teal-dk);color:#fff}.login-shell{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--navy)}.login-card{background:var(--surface);border-radius:12px;padding:30px 28px;width:340px;box-shadow:0 12px 40px #0000004d;display:flex;flex-direction:column}.login-logo{font-size:22px;font-weight:500;color:var(--navy)}.login-logo span{color:var(--teal)}.login-sub{font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--text3);font-family:var(--mono);margin-top:2px}.login-hint{font-size:12px;color:var(--text2);margin:14px 0 16px}.login-card label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text3);margin:10px 0 4px}.login-card input{font-family:var(--font);font-size:13px;padding:9px 11px;border:.5px solid var(--border-md);border-radius:6px}.login-card input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 2px var(--teal-pl)}.login-btn{margin-top:18px;padding:10px;font-size:13px}.topbar-right{display:flex;align-items:center;gap:18px}.user-box{display:flex;align-items:center;gap:10px;border-left:.5px solid var(--border);padding-left:16px}.user-email{font-size:11px;color:var(--text2)}.btn.logout{font-size:11px;padding:4px 10px}.subnav{display:flex;gap:2px;padding:0 22px;background:var(--surface);border-bottom:.5px solid var(--border)}.subtab{font-family:var(--font);font-size:12px;padding:9px 14px;border:none;background:none;color:var(--text2);border-bottom:2px solid transparent;margin-bottom:-.5px;cursor:pointer}.subtab:hover{color:var(--text)}.subtab.on{color:var(--navy);font-weight:500;border-bottom-color:var(--teal)}.comp-group{margin-bottom:18px}.comp-name{font-size:13px;font-weight:500;margin-bottom:7px;display:flex;align-items:baseline;gap:8px}.comp-count{font-size:10px;color:var(--text3);font-family:var(--mono);text-transform:uppercase;letter-spacing:.04em}.reason-cell{font-size:11px;color:var(--text2);font-style:italic;max-width:340px}.tick{color:var(--teal-dk)}.badge{font-size:10px;font-weight:500;padding:2px 7px;border-radius:20px;background:#f1efe8;color:#5f5e5a;white-space:nowrap}.badge.ai{background:#fff3cd;color:#633806}.badge.ai-sm{border-radius:3px;padding:1px 4px}.badge.confirmed{background:var(--teal-pl);color:var(--teal-dk)}.badge.unmapped{background:var(--red-pl);color:var(--red-dk)}.filter-row{display:flex;gap:6px;margin-bottom:12px}.chip{font-family:var(--font);font-size:11px;text-transform:capitalize;padding:4px 12px;border-radius:20px;border:.5px solid var(--border-md);background:var(--surface);color:var(--text2);cursor:pointer}.chip.on{background:var(--teal-pl);border-color:var(--teal-dk);color:var(--teal-dk);font-weight:500}.map-grid .map-from{font-weight:500}.map-grid .map-raw{font-size:11px;color:var(--text2)}.map-grid .arrow{color:var(--text3);text-align:center}.row-actions{display:flex;gap:5px}.confirmed-row td{background:#fafffc}.add-card{margin-top:18px;background:var(--surface);border:.5px solid var(--border);border-radius:10px;padding:14px}.add-card h2{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--text3);margin-bottom:10px}.add-row{display:flex;gap:8px;align-items:center}.add-row input,.add-row select{width:auto}.add-row .num{width:80px}
