.toast-stack{z-index:80;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;top:24px;right:24px}.toast{color:#fff;pointer-events:auto;border-radius:12px;max-width:360px;padding:12px 16px;font-size:14px;font-weight:500;animation:.2s ease-out toast-in;box-shadow:0 2px 6px #00000014}.toast--info{background:#0f172a}.toast--success{background:#0f766e}.toast--error{background:#ef4444}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.sidebar{color:#fff;z-index:30;background:#0f172a;flex-direction:column;width:248px;height:100vh;padding:24px 16px;display:flex;position:sticky;top:0}.sidebar__brand{align-items:center;gap:12px;padding:0 8px 32px;display:flex}.sidebar__brand-mark{color:#0f172a;background:#14b8a6;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-weight:700;display:inline-flex}.sidebar__brand-text{letter-spacing:-.3px;font-size:20px;font-weight:700}.sidebar__nav{flex-direction:column;gap:4px;display:flex}.sidebar__link{color:#ffffffb3;border-radius:8px;align-items:center;gap:12px;padding:12px 16px;font-weight:500;text-decoration:none;transition:background .1s,color .1s;display:flex}.sidebar__link:hover{color:#fff;background:#ffffff0d;text-decoration:none}.sidebar__link--active{color:#2dd4bf;background:#14b8a626}.sidebar__icon{text-align:center;width:22px;font-size:18px}.chip{border-radius:9999px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:600;line-height:1.4;display:inline-flex}.chip--default{color:#475569;background:#e2e8f0}.chip--success{color:#0f766e;background:#ccfbf1}.chip--warning{color:#f59e0b;background:#fef3c7}.chip--danger{color:#ef4444;background:#fee2e2}.chip--info{color:#0f172a;background:#0f172a14}.chip--selected{color:#fff;background:#0f172a}.topbar{z-index:40;background:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;height:64px;padding:0 32px;display:flex;position:sticky;top:0}.topbar__title{font-size:18px;font-weight:600}.topbar__actions{align-items:center;gap:16px;display:flex}.topbar__user{color:#475569;font-size:14px;font-weight:500}.topbar__langs{background:#f8fafc;border-radius:8px;padding:2px;display:inline-flex}.topbar__lang{color:#475569;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 10px;font-size:12px;font-weight:600}.topbar__lang.is-active{color:#0f172a;background:#fff;box-shadow:0 2px 6px #00000014}.topbar__logout{color:#ef4444;cursor:pointer;background:0 0;border:none;font-size:14px;font-weight:600}.app-shell{min-height:100vh;display:flex}.app-shell__main{flex-direction:column;flex:1;min-width:0;display:flex}.app-shell__content{flex:1;width:100%;max-width:1440px;margin:0 auto;padding:24px 32px 48px}.skeleton{background:linear-gradient(90deg,#e2e8f0 0%,#f1f5f9 50%,#e2e8f0 100%) 0 0/200% 100%;animation:1.4s ease-in-out infinite skeleton-shimmer;display:inline-block}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (prefers-reduced-motion:reduce){.skeleton{animation:none}}.route-suspense{flex-direction:column;gap:32px;display:flex}.route-suspense__metrics{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}@media (width>=1024px){.route-suspense__metrics{grid-template-columns:repeat(4,1fr)}}.btn{letter-spacing:.1px;cursor:pointer;white-space:nowrap;border:1.5px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:8px;font-weight:600;transition:transform 80ms,background .12s,border-color .12s,opacity .12s;display:inline-flex}.btn:focus-visible{outline-offset:2px;outline:2px solid #14b8a6}.btn:active:not(:disabled){transform:scale(.98)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--primary{color:#fff;background:#14b8a6}.btn--primary:hover:not(:disabled){background:#0f766e}.btn--secondary{color:#0f172a;background:#fff;border-color:#0f172a}.btn--secondary:hover:not(:disabled){background:#f8fafc}.btn--ghost{color:#0f172a;background:0 0}.btn--ghost:hover:not(:disabled){background:#f8fafc}.btn--destructive{color:#fff;background:#ef4444}.btn--destructive:hover:not(:disabled){background:#ed2828}.btn--sm{height:36px;padding:0 12px;font-size:13px}.btn--md{height:44px;padding:0 16px;font-size:14px}.btn--lg{height:52px;padding:0 24px;font-size:16px}.btn--full{width:100%}.btn__spinner{border:2px solid;border-top-color:#0000;border-radius:50%;width:14px;height:14px;animation:.6s linear infinite btn-spin}@keyframes btn-spin{to{transform:rotate(360deg)}}.card{background:#fff;border:1px solid #e2e8f0;border-radius:16px}.card--elevated{border-color:#0000;box-shadow:0 8px 20px #0000000d}.card--padded{padding:24px}.field{flex-direction:column;gap:4px;display:flex}.field__label{color:#0b1c30;font-size:13px;font-weight:600}.field__row{background:#fff;border:1.5px solid #cbd5e1;border-radius:8px;align-items:center;gap:8px;padding:0 12px;transition:border-color .1s;display:flex}.field__row:focus-within{border-color:#14b8a6}.field__row--error{border-color:#ef4444}.field__icon{color:#475569;display:inline-flex}.field__input{color:#0b1c30;background:0 0;border:none;outline:none;flex:1;height:44px;font-size:14px}.field__input::placeholder{color:#475569}.field__error{color:#ef4444;margin:0;font-size:12px}.field__helper{color:#475569;margin:0;font-size:12px}.login-page{grid-template-columns:1fr;min-height:100vh;display:grid}@media (width>=1024px){.login-page{grid-template-columns:1fr 1fr}}.login-page__panel{flex-direction:column;justify-content:center;width:100%;max-width:480px;margin:0 auto;padding:48px 32px;display:flex}.login-page__brand{color:#0f172a;align-items:center;gap:12px;margin-bottom:48px;font-size:20px;font-weight:700;display:flex}.login-page__brand-mark{color:#14b8a6;background:#0f172a;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:inline-flex}.login-page__heading{letter-spacing:-.5px;margin:0 0 8px;font-size:32px;line-height:1.1}.login-page__sub{color:#475569;margin:0 0 32px}.login-page__form{flex-direction:column;gap:16px;padding:24px;display:flex}.login-page__error{color:#ef4444;margin:0;font-size:14px}.login-page__note{color:#475569;text-align:center;margin-top:32px;font-size:14px}.login-page__link{color:#14b8a6;font-weight:600;text-decoration:none}.login-page__link:hover{text-decoration:underline}.login-page__art{background:radial-gradient(at 30% 20%,#14b8a666,#0000 50%),radial-gradient(at 70% 80%,#f59e0b40,#0000 55%),#0f172a;display:none}@media (width>=1024px){.login-page__art{display:block}}.register-page{grid-template-columns:1fr;min-height:100vh;display:grid}@media (width>=1024px){.register-page{grid-template-columns:1fr 1fr}}.register-page__panel{flex-direction:column;justify-content:center;width:100%;max-width:560px;margin:0 auto;padding:48px 32px;display:flex}.register-page__brand{color:#0f172a;align-items:center;gap:12px;margin-bottom:40px;font-size:20px;font-weight:700;text-decoration:none;display:flex}.register-page__heading{letter-spacing:-.5px;margin:0 0 8px;font-size:32px;line-height:1.1}.register-page__sub{color:#475569;margin:0 0 32px}.register-page__form{flex-direction:column;gap:16px;padding:24px;display:flex}.register-page__grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.register-page__role{flex-direction:column;gap:8px;display:flex}.register-page__role-label{color:#475569;font-size:14px;font-weight:500}.register-page__role-row{gap:8px;display:flex}.register-page__error{color:#ef4444;margin:0;font-size:14px}.register-page__note{color:#475569;text-align:center;margin-top:32px;font-size:14px}.register-page__link{color:#14b8a6;font-weight:600;text-decoration:none}.register-page__link:hover{text-decoration:underline}.register-page__art{background:radial-gradient(at 30% 20%,#14b8a666,#0000 50%),radial-gradient(at 70% 80%,#f59e0b40,#0000 55%),#0f172a;display:none}@media (width>=1024px){.register-page__art{display:block}}*,:before,:after{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{color:#0b1c30;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"cv11", "ss01";background:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}a{color:#0f766e;text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit}input,textarea,select{color:inherit;font-family:inherit}img{max-width:100%;display:block}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:9999px}
