:root{--alpyme-royal:#0c2461;--alpyme-royal-mid:#1e3799;--alpyme-royal-light:#4a69bd;--alpyme-royal-soft:#e8eef9;--alpyme-white:#fff;--alpyme-page:#f4f6f9;--alpyme-border:#e2e8f0;--alpyme-text:#1e293b;--alpyme-text-muted:#64748b;--alpyme-shadow:0 1px 3px #0c246114;--alpyme-shadow-md:0 4px 14px #0c24611a;--alpyme-radius:6px;--alpyme-sidebar-w:240px;--font-sans:"Source Sans 3", system-ui, "Segoe UI", Roboto, sans-serif}*,:before,:after{box-sizing:border-box}html{font-family:var(--font-sans);color:var(--alpyme-text);-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.5}body{background:var(--alpyme-page);min-height:100vh;margin:0}#root{text-align:left;border:none;width:100%;max-width:none;min-height:100vh;margin:0}.app-root{flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--alpyme-white);border-bottom:3px solid var(--alpyme-royal);height:56px;box-shadow:var(--alpyme-shadow);z-index:100;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 1.25rem;display:flex}.app-header__brand{align-items:center;gap:.75rem;display:flex}.app-header__logo{border-radius:var(--alpyme-radius);background:linear-gradient(145deg, var(--alpyme-royal), var(--alpyme-royal-mid));width:40px;height:40px;color:var(--alpyme-white);letter-spacing:.02em;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}.app-header__title{color:var(--alpyme-royal);letter-spacing:-.02em;margin:0;font-size:1.125rem;font-weight:600}.app-header__subtitle{color:var(--alpyme-text-muted);margin:0;font-size:.75rem}.app-header__actions{align-items:center;gap:.75rem;display:flex}.app-body{flex:1;min-height:0;display:flex}.app-sidebar{width:var(--alpyme-sidebar-w);background:var(--alpyme-white);border-right:1px solid var(--alpyme-border);flex-direction:column;flex-shrink:0;padding:1rem 0;display:flex}.app-sidebar__user{border-bottom:1px solid var(--alpyme-border);margin:0 .75rem 1rem;padding:.75rem 1rem 1rem;font-size:.875rem}.app-sidebar__user-name{color:var(--alpyme-royal);font-weight:600}.app-sidebar__user-role{color:var(--alpyme-text-muted);font-size:.75rem}.app-nav{flex-direction:column;gap:.25rem;padding:0 .5rem;display:flex}.app-nav__btn{border-radius:var(--alpyme-radius);width:100%;color:var(--alpyme-text);text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:.5rem;padding:.65rem .85rem;font-family:inherit;font-size:.9rem;font-weight:500;transition:background .15s,color .15s;display:flex}.app-nav__btn:hover{background:var(--alpyme-royal-soft);color:var(--alpyme-royal)}.app-nav__btn.is-active{background:var(--alpyme-royal);color:var(--alpyme-white)}.app-nav__icon{opacity:.85;font-size:.95rem}.app-main{background:var(--alpyme-page);flex:1;padding:1.5rem;overflow:auto}@media (width<=900px){.app-body{flex-direction:column}.app-sidebar{border-right:none;border-bottom:1px solid var(--alpyme-border);flex-flow:wrap;align-items:center;width:100%;padding:.75rem}.app-sidebar__user{width:100%;margin:0 0 .5rem;padding:.5rem .75rem}.app-nav{flex-flow:wrap;width:100%}.app-nav__btn{flex:auto;min-width:140px}}.panel{background:var(--alpyme-white);border-radius:var(--alpyme-radius);border:1px solid var(--alpyme-border);box-shadow:var(--alpyme-shadow);margin-bottom:1.25rem;overflow:hidden}.panel__header{background:var(--alpyme-white);border-bottom:1px solid var(--alpyme-border);color:var(--alpyme-royal);padding:.85rem 1.25rem;font-size:.95rem;font-weight:600}.panel__body{padding:1.25rem}.form-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));align-items:end;gap:.75rem;margin-bottom:1rem;display:grid}.input,.select{border:1px solid var(--alpyme-border);border-radius:var(--alpyme-radius);background:var(--alpyme-white);width:100%;color:var(--alpyme-text);padding:.55rem .75rem;font-family:inherit;font-size:.9rem}.input:focus,.select:focus{border-color:var(--alpyme-royal-light);box-shadow:0 0 0 3px var(--alpyme-royal-soft);outline:none}.btn{border-radius:var(--alpyme-radius);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.35rem;padding:.55rem 1rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:background .15s,box-shadow .15s;display:inline-flex}.btn--primary{background:var(--alpyme-royal);color:var(--alpyme-white)}.btn--primary:hover{background:var(--alpyme-royal-mid);box-shadow:var(--alpyme-shadow-md)}.btn--ghost{color:var(--alpyme-royal);border:1px solid var(--alpyme-border);background:0 0}.btn--ghost:hover{background:var(--alpyme-royal-soft)}.btn--danger{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;font-weight:600}.btn--danger:hover{background:#fee2e2}.table-list{border:1px solid var(--alpyme-border);border-radius:var(--alpyme-radius);overflow:hidden}.table-list__row{border-bottom:1px solid var(--alpyme-border);background:var(--alpyme-white);justify-content:space-between;align-items:center;gap:1rem;padding:.65rem 1rem;font-size:.9rem;display:flex}.table-list__row:last-child{border-bottom:none}.table-list__row:nth-child(2n){background:#fafbfc}.alert{border-radius:var(--alpyme-radius);margin-top:1rem;padding:.75rem 1rem;font-size:.875rem}.alert--info{background:var(--alpyme-royal-soft);color:var(--alpyme-royal);border:1px solid #c9d6f0}.login-page{background:linear-gradient(165deg, var(--alpyme-royal-soft) 0%, var(--alpyme-page) 45%, var(--alpyme-white) 100%);justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.login-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;width:100%;max-width:880px;display:grid}.login-card{background:var(--alpyme-white);border:1px solid var(--alpyme-border);box-shadow:var(--alpyme-shadow-md);border-radius:8px;overflow:hidden}.login-card__head{background:var(--alpyme-royal);color:var(--alpyme-white);padding:1rem 1.25rem;font-size:1rem;font-weight:600}.login-card__body{padding:1.25rem}.login-card__body .form-grid{margin-bottom:0}.login-brand{text-align:center;margin-bottom:2rem}.login-brand__badge{background:linear-gradient(145deg, var(--alpyme-royal), var(--alpyme-royal-mid));width:56px;height:56px;color:var(--alpyme-white);border-radius:12px;justify-content:center;align-items:center;margin-bottom:.75rem;font-size:1.1rem;font-weight:800;display:inline-flex}.login-brand h1{color:var(--alpyme-royal);letter-spacing:-.03em;margin:0 0 .35rem;font-size:1.5rem;font-weight:700}.login-brand p{color:var(--alpyme-text-muted);margin:0;font-size:.95rem}.login-brand__company{color:var(--alpyme-royal);letter-spacing:.06em;text-transform:uppercase;margin:.65rem 0 0;font-size:1rem;font-weight:700;line-height:1.35}
