@import"https://fonts.googleapis.com/css2?family=Saira+Condensed:wght@500;600;700;800&family=Inter:wght@400;500;600;700&display=swap";:root{--navy:#003087;--navy-700:#002a73;--navy-900:#001b4d;--red:#cc0000;--gold:#ffd700;--gold-deep:#d8af00;--ink:#1a1a1a;--bg:#eef1f7;--card:#fff;--muted:#6b7280;--line:#e6e9f0;--soft:#f6f8fc;--ok:#1c8a4e;--ok-bg:#e7f6ee;--warn:#b9770a;--warn-bg:#fdf3e0;--danger:#c0271a;--danger-bg:#fdeceb;--radius:14px;--radius-sm:9px;--shadow:0 1px 2px rgba(16,24,40,.05),0 8px 24px rgba(16,24,40,.06);--shadow-lg:0 24px 60px rgba(0,27,77,.22);--display:"Saira Condensed",system-ui,sans-serif;--body:"Inter",system-ui,-apple-system,sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{font-family:var(--body);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;line-height:1.5}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}h1,h2,h3{font-family:var(--display);letter-spacing:.2px;margin:0;line-height:1.1}.btn{display:inline-flex;align-items:center;gap:.5rem;justify-content:center;border:1px solid transparent;border-radius:var(--radius-sm);padding:.62rem 1.05rem;font-weight:600;font-size:.92rem;transition:.15s;white-space:nowrap}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--navy);color:#fff}.btn-primary:hover{background:var(--navy-700)}.btn-gold{background:var(--gold);color:var(--navy-900)}.btn-gold:hover{background:var(--gold-deep)}.btn-ghost{background:#fff;border-color:var(--line);color:var(--ink)}.btn-ghost:hover{background:var(--soft)}.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:#f3c9c5}.btn-danger:hover{background:#fbe0dd}.btn-sm{padding:.4rem .7rem;font-size:.82rem;border-radius:8px}.btn:disabled{opacity:.55;cursor:not-allowed}label.field{display:block;margin-bottom:.85rem;font-size:.84rem;font-weight:600;color:#374151}label.field>span{display:block;margin-bottom:.32rem}input,select,textarea{width:100%;font-family:inherit;font-size:.95rem;color:var(--ink);border:1px solid var(--line);border-radius:var(--radius-sm);padding:.6rem .7rem;background:#fff;transition:.15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px #0030871f}textarea{min-height:96px;resize:vertical}.auth{min-height:100vh;display:grid;grid-template-columns:1.05fr 1fr}.auth-hero{background:radial-gradient(1200px 600px at -10% -10%,var(--navy-700),var(--navy-900) 60%);color:#fff;padding:3rem;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}.auth-hero:after{content:"";position:absolute;right:-120px;bottom:-120px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(255,215,0,.18),transparent 70%)}.crest-xl{width:84px;height:84px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:var(--navy-900);font-family:var(--display);font-weight:800;font-size:2rem;box-shadow:var(--shadow-lg)}.auth-hero h1{font-size:3.1rem;font-weight:800;margin:.4rem 0 .2rem}.auth-hero h1 em{color:var(--gold);font-style:normal}.auth-hero .tag{font-size:1.05rem;max-width:30ch;color:#cdd7ee}.auth-hero .meta{font-size:.85rem;color:#9fb0d6;display:flex;gap:1.2rem;flex-wrap:wrap;z-index:1}.auth-hero .meta b{color:#fff;font-weight:600}.auth-form{display:flex;align-items:center;justify-content:center;padding:2.5rem;background:var(--bg)}.auth-card{width:100%;max-width:400px;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:2rem}.auth-card h2{font-size:1.7rem}.auth-card .sub{color:var(--muted);font-size:.9rem;margin:.25rem 0 1.4rem}.auth-switch{display:flex;background:var(--soft);border:1px solid var(--line);border-radius:10px;padding:4px;margin-bottom:1.3rem}.auth-switch button{flex:1;border:0;background:transparent;padding:.5rem;border-radius:7px;font-weight:600;color:var(--muted)}.auth-switch button.on{background:#fff;color:var(--navy);box-shadow:var(--shadow)}.auth-msg{font-size:.86rem;padding:.6rem .75rem;border-radius:9px;margin-bottom:1rem}.auth-msg.err{background:var(--danger-bg);color:var(--danger)}.auth-msg.ok{background:var(--ok-bg);color:var(--ok)}.auth-msg.warn{background:var(--warn-bg);color:var(--warn)}.auth-foot{margin-top:1.1rem;font-size:.84rem;text-align:center;color:var(--muted)}.auth-foot a,.auth-foot button{color:var(--navy);font-weight:600;background:none;border:0}.auth-lang{display:flex;justify-content:flex-end;margin-bottom:.5rem}.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}.sidebar{background:linear-gradient(180deg,var(--navy),var(--navy-900));color:#fff;display:flex;flex-direction:column;padding:1.1rem .8rem;position:sticky;top:0;height:100vh;z-index:40}.brand{display:flex;align-items:center;gap:.7rem;padding:.4rem .5rem 1.1rem}.crest{width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:var(--navy-900);font-family:var(--display);font-weight:800;font-size:1.25rem;display:grid;place-items:center}.brand-txt strong{display:block;font-family:var(--display);font-size:1.2rem;letter-spacing:.5px}.brand-txt span{font-size:.72rem;color:var(--gold);letter-spacing:2px;text-transform:uppercase}.nav{display:flex;flex-direction:column;gap:2px;flex:1;overflow-y:auto;margin-top:.3rem}.nav-link{display:flex;align-items:center;gap:.75rem;padding:.62rem .7rem;border-radius:10px;color:#c7d2ee;font-size:.92rem;font-weight:500;border:0;background:transparent;text-align:left}.nav-link svg{flex:0 0 20px}.nav-link:hover{background:#ffffff14;color:#fff}.nav-link.active{background:#ffd70024;color:#fff;font-weight:600;box-shadow:inset 3px 0 0 var(--gold)}.nav-link.logout{margin-top:.4rem;color:#f1b4ae}.nav-link.logout:hover{background:#cc000038;color:#fff}.main{display:flex;flex-direction:column;min-width:0}.topbar{height:64px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:1rem;padding:0 1.4rem;position:sticky;top:0;z-index:30}.burger{display:none;border:0;background:transparent;color:var(--ink)}.page-title{font-family:var(--display);font-size:1.4rem;font-weight:700;flex:1}.topbar-right{display:flex;align-items:center;gap:1rem;margin-left:auto}.lang-toggle{display:flex;border:1px solid var(--line);border-radius:8px;overflow:hidden}.lang-toggle button{border:0;background:#fff;padding:.32rem .6rem;font-size:.78rem;font-weight:700;color:var(--muted)}.lang-toggle button.on{background:var(--navy);color:#fff}.user-chip{display:flex;align-items:center;gap:.6rem}.avatar{width:38px;height:38px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-weight:700;font-size:.85rem}.user-meta{line-height:1.15}.user-meta strong{display:block;font-size:.86rem}.user-meta span{font-size:.72rem;color:var(--muted)}.view{padding:1.6rem;max-width:1240px;width:100%}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1.3rem;flex-wrap:wrap}.page-head h2{font-size:1.7rem}.page-head p{color:var(--muted);margin:.2rem 0 0;font-size:.9rem}.head-actions{display:flex;gap:.6rem;flex-wrap:wrap}.grid{display:grid;gap:1rem}.kpis{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.card-pad{padding:1.2rem 1.3rem}.kpi{position:relative;overflow:hidden}.kpi:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--navy)}.kpi.gold:before{background:var(--gold)}.kpi.red:before{background:var(--red)}.kpi.green:before{background:var(--ok)}.kpi .label{font-size:.78rem;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);font-weight:600}.kpi .val{font-family:var(--display);font-size:2.2rem;font-weight:800;line-height:1;margin-top:.35rem}.kpi .hint{font-size:.78rem;color:var(--muted);margin-top:.3rem}.section-title{font-family:var(--display);font-size:1.25rem;font-weight:700;margin:1.6rem 0 .8rem}.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:#fff}table{width:100%;border-collapse:collapse;font-size:.9rem}thead th{background:var(--soft);text-align:left;padding:.7rem .9rem;font-size:.74rem;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);border-bottom:1px solid var(--line);white-space:nowrap}tbody td{padding:.72rem .9rem;border-bottom:1px solid var(--line);vertical-align:middle}tbody tr:last-child td{border-bottom:0}tbody tr:hover{background:var(--soft)}.badge{display:inline-flex;align-items:center;gap:.35rem;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.red{background:var(--danger-bg);color:var(--danger)}.badge.navy{background:#e6ecf8;color:var(--navy)}.badge.gold{background:#fff5cc;color:#8a6d00}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.toolbar{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:1rem}.toolbar input,.toolbar select{width:auto;min-width:160px}.toolbar .grow{flex:1;min-width:200px}.empty{text-align:center;color:var(--muted);padding:3rem 1rem}.spinner{width:30px;height:30px;border:3px solid var(--line);border-top-color:var(--navy);border-radius:50%;animation:spin .8s linear infinite;margin:2rem auto}@keyframes spin{to{transform:rotate(360deg)}}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#001b4d73;display:flex;align-items:center;justify-content:center;z-index:60;padding:1rem}.modal{background:#fff;border-radius:var(--radius);width:100%;max-width:520px;box-shadow:var(--shadow-lg);max-height:90vh;overflow:auto}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.3rem;border-bottom:1px solid var(--line)}.modal-head h3{font-size:1.3rem}.modal-head .x{border:0;background:var(--soft);width:32px;height:32px;border-radius:8px;font-size:1.1rem;color:var(--muted)}.modal-body{padding:1.3rem}.modal-foot{padding:1rem 1.3rem;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:.6rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}#toasts{position:fixed;right:1rem;bottom:1rem;display:flex;flex-direction:column;gap:.5rem;z-index:80}.toast{background:var(--ink);color:#fff;padding:.7rem 1rem;border-radius:10px;font-size:.88rem;box-shadow:var(--shadow-lg);animation:slidein .25s;max-width:340px}.toast.ok{background:var(--ok)}.toast.err{background:var(--danger)}.toast.warn{background:var(--warn)}@keyframes slidein{0%{opacity:0;transform:translate(20px)}}.bars{display:flex;align-items:flex-end;gap:.7rem;height:160px;padding-top:.5rem}.bars .bar{flex:1;background:linear-gradient(180deg,var(--navy),var(--navy-700));border-radius:6px 6px 0 0;position:relative;min-height:4px;transition:.4s}.bars .bar small{position:absolute;bottom:-1.4rem;left:0;right:0;text-align:center;font-size:.7rem;color:var(--muted)}.scrim{display:none}@media (max-width:980px){.form-row{grid-template-columns:1fr}}@media (max-width:860px){.auth{grid-template-columns:1fr}.auth-hero{display:none}}@media (max-width:900px){.shell{grid-template-columns:1fr}.sidebar{position:fixed;left:0;top:0;width:248px;transform:translate(-100%);transition:.25s}.sidebar.open{transform:translate(0)}.burger{display:block}.scrim.show{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:35}.user-meta{display:none}.view{padding:1.1rem}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition:none!important}}
