:root{--ink: #0b1d26;--deep: #0e2a38;--steel: #13384a;--sea: #1f6f8b;--teal: #2a9d9a;--brass: #c79b54;--brass-soft: #e8d2a3;--paper: #f4efe6;--paper-2: #ece4d6;--line: #d8cdb9;--ok: #3a8c5f;--warn: #c98a2b;--late: #c0492f;--hold: #7a6f5f;--white: #fbf8f2;--shadow: 0 18px 40px -22px rgba(11, 29, 38, .55);--radius: 14px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:Archivo,system-ui,sans-serif;background:radial-gradient(1200px 600px at 85% -10%,rgba(42,157,154,.1),transparent 60%),radial-gradient(900px 500px at -5% 110%,rgba(199,155,84,.1),transparent 55%),var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}.side{background:linear-gradient(180deg,var(--deep),var(--ink));color:var(--white);padding:26px 18px;display:flex;flex-direction:column;gap:6px;position:sticky;top:0;height:100vh;overflow-y:auto}.brand{display:flex;align-items:center;gap:11px;padding:4px 6px 22px}.brand .mark{width:38px;height:38px;border-radius:9px;flex:none;background:linear-gradient(135deg,var(--brass),var(--brass-soft));display:grid;place-items:center;color:var(--ink);font-family:Fraunces;font-weight:700;font-size:20px;box-shadow:0 6px 18px -6px #c79b54b3}.brand b{font-family:Fraunces;font-weight:600;font-size:18px;letter-spacing:.3px;display:block;line-height:1}.brand span{font-size:10.5px;letter-spacing:2.5px;text-transform:uppercase;color:var(--brass-soft);opacity:.85}.navlabel{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:#6f8794;margin:16px 8px 6px}.nav{display:flex;flex-direction:column;gap:3px}.nav button,.nav a{all:unset;cursor:pointer;display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;font-size:13.5px;color:#c4d3da;transition:.18s}.nav button:hover,.nav a:hover{background:#ffffff0f;color:#fff}.nav a.active{background:linear-gradient(90deg,#2a9d9a47,#2a9d9a0a);color:#fff}.side-foot{margin-top:auto;padding-top:18px;border-top:1px solid rgba(255,255,255,.08);font-size:11px;color:#7d94a0;line-height:1.6}.main{padding:26px 34px 60px;max-width:1280px;width:100%}.topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:22px}.crumb{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--sea);font-weight:600}h1{font-family:Fraunces;font-weight:600;font-size:30px;letter-spacing:.2px;line-height:1.1}.sub{color:#5b6e77;font-size:13.5px;margin-top:5px}.topactions{display:flex;gap:10px;align-items:center}.pill{display:inline-flex;align-items:center;gap:7px;background:var(--white);border:1px solid var(--line);padding:8px 14px;border-radius:30px;font-size:12.5px;font-weight:600;color:var(--steel);box-shadow:var(--shadow)}.btn{all:unset;cursor:pointer;background:var(--steel);color:#fff;padding:10px 16px;border-radius:10px;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:8px;transition:.18s}.btn:hover{background:var(--sea)}.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--steel)}.btn.ghost:hover{background:var(--white)}.btn:disabled{opacity:.55;cursor:not-allowed}.grid{display:grid;gap:16px}.g4{grid-template-columns:repeat(4,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g2{grid-template-columns:repeat(2,1fr)}.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow)}.card.flat{box-shadow:none}.kpi .lbl{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:#7a8a91;font-weight:600}.kpi .val{font-family:Fraunces;font-size:30px;font-weight:600;margin-top:7px;line-height:1}.kpi .delta{font-size:12px;margin-top:8px;font-weight:600}.delta.up{color:var(--ok)}.delta.dn{color:var(--late)}.cardhead{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.cardhead h3{font-family:Fraunces;font-weight:600;font-size:17px}.cardhead .meta{font-size:12px;color:#7a8a91}.hull{cursor:pointer;position:relative;overflow:hidden;transition:.2s}.hull:hover{transform:translateY(-3px);border-color:var(--sea)}.hull h3{font-family:Fraunces;font-size:20px;font-weight:600}.hull .model{color:var(--sea);font-size:12.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;margin-top:2px}.hull .row{display:flex;justify-content:space-between;font-size:13px;margin-top:14px;color:#41535b}.hull .row b{color:var(--ink)}.bar{height:9px;border-radius:6px;background:var(--paper-2);overflow:hidden;margin-top:16px}.bar>i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--teal),var(--sea))}.barlabel{display:flex;justify-content:space-between;font-size:11.5px;color:#6c7d84;margin-top:7px;font-weight:600}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:11.5px;font-weight:700;letter-spacing:.3px}.chip:before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}.chip.ok{color:var(--ok);background:#3a8c5f1f}.chip.warn{color:var(--warn);background:#c98a2b1f}.chip.late{color:var(--late);background:#c0492f1f}.chip.hold{color:var(--hold);background:#7a6f5f24}.chip.na{color:#9aa7ad;background:#9aa7ad1f}.matrix{width:100%;border-collapse:collapse;font-size:13px}.matrix th,.matrix td{padding:10px 12px;text-align:center;border-bottom:1px solid var(--line)}.matrix th:first-child,.matrix td:first-child{text-align:left;font-weight:600}.matrix thead th{font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:#6c7d84}.cell{display:inline-flex;flex-direction:column;gap:4px;min-width:64px}.cell .pct{font-weight:700}.cell.ok{color:var(--ok)}.cell.warn{color:var(--warn)}.cell.late{color:var(--late)}.cell.na{color:#b3bcc1}.cell .minibar{height:5px;border-radius:4px;background:var(--paper-2);overflow:hidden}.cell .minibar>i{display:block;height:100%}.cell.ok .minibar>i{background:var(--ok)}.cell.warn .minibar>i{background:var(--warn)}.cell.late .minibar>i{background:var(--late)}.table{width:100%;border-collapse:collapse;font-size:13px}.table th,.table td{padding:11px 12px;text-align:left;border-bottom:1px solid var(--line)}.table thead th{font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:#6c7d84}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:100%;max-width:380px;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:34px 30px;box-shadow:var(--shadow)}.login-card .brand{justify-content:center;padding-bottom:8px}.login-card h1{font-size:22px;text-align:center;margin-bottom:4px}.login-card .sub{text-align:center;margin-bottom:22px}.field{margin-bottom:14px}.field label{display:block;font-size:12px;font-weight:600;color:var(--steel);margin-bottom:6px}.input{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:10px;font-size:14px;font-family:inherit;background:var(--paper);color:var(--ink)}.input:focus{outline:none;border-color:var(--sea);box-shadow:0 0 0 3px #1f6f8b1f}.error{color:var(--late);font-size:13px;margin-bottom:12px}.btn.block{display:flex;justify-content:center;width:100%}.langsw{display:inline-flex;border:1px solid var(--line);border-radius:30px;overflow:hidden;background:var(--white)}.langsw button{all:unset;cursor:pointer;padding:7px 12px;font-size:12px;font-weight:600;color:#7a8a91}.langsw button.active{background:var(--steel);color:#fff}.muted{color:#7a8a91}.center-state{display:grid;place-items:center;padding:60px 0;color:#7a8a91;font-size:14px}.mask{letter-spacing:2px;color:#9aa7ad}
