:root{--brand: #2F6F8F;--brand-dark: #255a73;--brand-soft: #eaf2f6;--brand-softer: #f4f8fa;--ink: #1f2a37;--muted: #6b7a88;--line: #e6ecf0;--bg: #ffffff;--bg-alt: #f7fafb;--ok: #16a34a;--ok-bg: #dcfce7;--warn: #b45309;--warn-bg: #fef3c7;--bad: #b91c1c;--bad-bg: #fee2e2;--radius: 14px;--shadow: 0 1px 3px rgba(16,40,52,.06), 0 8px 24px rgba(16,40,52,.05);--font: "Outfit", system-ui, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font);color:var(--ink);background:var(--bg-alt);-webkit-font-smoothing:antialiased}.shell{display:flex;height:100vh;overflow:hidden}.sidebar{width:232px;flex-shrink:0;background:var(--brand);color:#fff;display:flex;flex-direction:column;padding:1.1rem .9rem}.sidebar-brand{display:flex;align-items:center;gap:.6rem;padding:.4rem .6rem 1.4rem}.sidebar-brand img{height:38px;filter:brightness(0) invert(1)}.sidebar-brand span{font-weight:800;font-size:1.15rem;letter-spacing:.3px}.sidebar-company{padding:0 .6rem 1rem}.sidebar-company label{display:block;font-size:.68rem;text-transform:uppercase;letter-spacing:.5px;color:#fff9;margin-bottom:.35rem}.sidebar-company select{width:100%;padding:.5rem .6rem;border-radius:9px;border:1px solid rgba(255,255,255,.18);background:#ffffff1a;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer}.sidebar-company select option{color:#1a2b34}.nav{display:flex;flex-direction:column;gap:2px;margin-top:.4rem}.nav a{display:flex;align-items:center;gap:.7rem;padding:.62rem .7rem;border-radius:10px;color:#ffffffd9;text-decoration:none;font-weight:500;font-size:.93rem;transition:background .15s ease,color .15s ease}.nav a:hover{background:#ffffff1f;color:#fff}.nav a.active{background:#fff;color:var(--brand);font-weight:700}.nav a svg{width:18px;height:18px;flex-shrink:0}.sidebar-foot{margin-top:auto;font-size:.72rem;color:#fff9;padding:.6rem}.sidebar-foot button{margin-top:.5rem;width:100%;background:#ffffff24;color:#fff;border:none;padding:.55rem;border-radius:9px;cursor:pointer;font-family:inherit;font-weight:600}.sidebar-foot button:hover{background:#ffffff3d}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-alt)}.topbar{height:62px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 1.6rem;flex-shrink:0}.topbar h1{font-size:1.2rem;font-weight:700;color:var(--ink)}.topbar .amb{font-size:.78rem;font-weight:700;padding:.25rem .6rem;border-radius:999px;background:var(--brand-soft);color:var(--brand)}.content{flex:1;overflow-y:auto;padding:1.6rem}.content-inner{max-width:980px;margin:0 auto}.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.4rem}.card+.card{margin-top:1.1rem}.card h2{font-size:1.02rem;font-weight:700;margin-bottom:.2rem}.card .help{color:var(--muted);font-size:.86rem;margin-bottom:1rem}.grid{display:grid;gap:1.1rem}.grid.cols-4{grid-template-columns:repeat(4,1fr)}.grid.cols-3{grid-template-columns:repeat(3,1fr)}.grid.cols-2{grid-template-columns:repeat(2,1fr)}@media(max-width:820px){.grid.cols-4,.grid.cols-3,.grid.cols-2{grid-template-columns:1fr 1fr}}.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem;box-shadow:var(--shadow)}.stat .k{font-size:.8rem;color:var(--muted);font-weight:600}.stat .v{font-size:1.7rem;font-weight:800;color:var(--ink);margin-top:.2rem}.stat .v.brand{color:var(--brand)}.field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.9rem}.field label{font-size:.82rem;font-weight:600;color:var(--ink)}.input,select.input,textarea.input{width:100%;padding:.62rem .8rem;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:.92rem;color:var(--ink);background:#fff;transition:border-color .15s,box-shadow .2s}.input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px #2f6f8f1f}.row{display:flex;gap:.8rem;flex-wrap:wrap}.row>*{flex:1;min-width:140px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.62rem 1.1rem;border-radius:10px;font-family:inherit;font-weight:600;font-size:.9rem;cursor:pointer;border:1.5px solid transparent;transition:all .15s ease}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover:not(:disabled){background:var(--brand-dark)}.btn-outline{background:#fff;color:var(--brand);border-color:var(--brand)}.btn-outline:hover:not(:disabled){background:var(--brand-soft)}.btn-ghost{background:var(--brand-softer);color:var(--ink)}.btn-ghost:hover:not(:disabled){background:var(--brand-soft)}.btn-sm{padding:.4rem .7rem;font-size:.82rem;border-radius:8px}.table-wrap{overflow-x:auto}table.tbl{width:100%;border-collapse:collapse;font-size:.9rem}table.tbl th{text-align:left;padding:.7rem .8rem;color:var(--muted);font-weight:700;font-size:.76rem;text-transform:uppercase;letter-spacing:.4px;border-bottom:2px solid var(--line)}table.tbl td{padding:.7rem .8rem;border-bottom:1px solid var(--line)}table.tbl tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .55rem;border-radius:999px;font-size:.74rem;font-weight:700}.badge.ok{background:var(--ok-bg);color:var(--ok)}.badge.warn{background:var(--warn-bg);color:var(--warn)}.badge.bad{background:var(--bad-bg);color:var(--bad)}.badge.muted{background:#eef2f5;color:var(--muted)}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-dark) 100%);padding:1.5rem}.login-card{background:#fff;border-radius:18px;box-shadow:0 20px 60px #00000040;padding:2.2rem;width:100%;max-width:410px}.login-card .logo{display:flex;align-items:center;gap:.6rem;justify-content:center;margin-bottom:.4rem}.login-card .logo span{font-weight:800;font-size:1.4rem;color:var(--brand)}.login-card h1{text-align:center;font-size:1.15rem;margin-bottom:1.4rem;color:var(--ink)}.muted{color:var(--muted)}.toast{position:fixed;bottom:1.2rem;left:50%;transform:translate(-50%);background:var(--ink);color:#fff;padding:.7rem 1.2rem;border-radius:10px;font-size:.9rem;z-index:999;box-shadow:var(--shadow)}.spinner{width:38px;height:38px;border:3px solid var(--brand-soft);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite;margin:2rem auto}@keyframes spin{to{transform:rotate(360deg)}}.empty{text-align:center;color:var(--muted);padding:2.5rem}
