:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f6fa;color:#1f2937}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh}a{color:inherit}:root{--color-background: #f5f6fa;--color-surface: #ffffff;--color-border: #e5e7eb;--color-primary: #0d63c6;--color-primary-soft: rgba(13, 99, 198, .1);--color-text: #1f2937;--color-text-muted: #6b7280;--sidebar-width: 260px}.layout{display:grid;grid-template-columns:var(--sidebar-width) 1fr;min-height:100vh;background:var(--color-background);color:var(--color-text);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.sidebar{background:linear-gradient(180deg,#0f4470,#0d63c6);color:#fff;padding:2rem 1.5rem 1.75rem;display:flex;flex-direction:column;gap:2rem;box-shadow:0 20px 40px -20px #0a376c59;position:sticky;top:0;min-height:100vh}.sidebar__brand{display:flex;align-items:center;gap:.85rem}.sidebar__logo{width:48px;height:48px;object-fit:contain;border-radius:12px;background:#ffffff1f;padding:.4rem}.sidebar__brand-text{display:flex;flex-direction:column;gap:.3rem}.sidebar__brand-badge{font-size:.7rem;text-transform:uppercase;letter-spacing:.2em;opacity:.8}.sidebar__brand-name{font-weight:700;font-size:1.25rem;letter-spacing:.08em}.sidebar__nav{display:grid;gap:.5rem}.sidebar__link{padding:.75rem 1rem;border-radius:.75rem;font-weight:500;color:#fffc;text-decoration:none;transition:background-color .2s ease,color .2s ease}.sidebar__link:hover{background-color:#ffffff1a;color:#fff}.sidebar__link--active{background:#fff;color:var(--color-primary)}.main{display:flex;flex-direction:column;background:#ffffffa6}.topbar{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 2rem;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.topbar__title{margin:0;font-size:1.5rem;font-weight:600}.topbar__subtitle{margin:.25rem 0 0;color:var(--color-text-muted);font-size:.95rem}.topbar__user{display:flex;align-items:center;gap:1rem}.topbar__user-info{display:flex;flex-direction:column;gap:.15rem}.topbar__avatar{width:42px;height:42px;border-radius:50%;background:var(--color-primary-soft);color:var(--color-primary);display:inline-flex;align-items:center;justify-content:center;font-weight:600}.topbar__username{margin:0;font-weight:600}.topbar__role{margin:.15rem 0 0;font-size:.85rem;color:var(--color-text-muted)}.topbar__logout{margin-left:.5rem}.topbar__logout:hover{background:#ffffff40;color:#0f4470}.content{flex:1;padding:1.75rem 1.75rem 2.25rem;display:flex;flex-direction:column;gap:1.5rem;width:100%;margin:0 auto}@media(max-width:1080px){.layout{grid-template-columns:1fr}.sidebar{flex-direction:row;overflow-x:auto;gap:1.5rem;padding:1.5rem;position:static;min-height:auto}.sidebar__nav{display:flex;flex:1;gap:.5rem}.sidebar__link{white-space:nowrap}.topbar{flex-direction:column;align-items:flex-start;gap:1rem}.topbar__user{width:100%;justify-content:space-between}}.dashboard{display:grid;gap:2rem}.grid{width:100%}.timeline{list-style:none;padding:1.25rem 0 0;margin:0;display:grid;gap:1.4rem}.list{list-style:none;padding:0;margin:1.25rem 0 0;display:grid;gap:1rem}.card--inline .card__value{font-size:1.8rem}.backlog{gap:1rem}.alerts__item--high{border-color:#dc262659}.alerts__item--medium{border-color:#f59e0b59}.alerts__item--info{border-color:#2563eb59}@media(max-width:1080px){.list__item{grid-template-columns:1fr;text-align:left}.alerts__item{grid-template-columns:1fr}.alerts__action{justify-self:start}}.timeline{list-style:none;padding:1.5rem 0 0;margin:0;display:grid;gap:1.5rem}.timeline__item{display:grid;grid-template-columns:auto 1fr auto;gap:1rem;align-items:start}.timeline__bullet{width:12px;height:12px;border-radius:50%;background:var(--color-primary);margin-top:.4rem}.timeline__content{display:grid;gap:.35rem}.timeline__title{margin:0;font-weight:600}.timeline__description{margin:0;color:var(--color-text-muted);font-size:.95rem}.timeline__time{color:var(--color-text-muted);font-size:.9rem;font-weight:500}.panel--secondary{background:linear-gradient(180deg,#0d63c61a,#0d63c605)}.chart-placeholder{border:2px dashed rgba(13,99,198,.3);border-radius:1rem;padding:2rem;display:grid;place-items:center;text-align:center;gap:.75rem;min-height:220px}.chart-placeholder__legend{font-weight:600;color:var(--color-primary)}.chart-placeholder__hint{margin:0;max-width:280px;color:var(--color-text-muted);font-size:.9rem}.list{list-style:none;padding:0;margin:1.5rem 0 0;display:grid;gap:1rem}.list--ranking{counter-reset:ranking}.list__item{display:grid;grid-template-columns:auto 1fr auto;gap:1rem;align-items:center;padding:1rem;border-radius:.9rem;border:1px solid var(--color-border);background:#fff}.list__content{display:grid;gap:.25rem}.list__title{margin:0;font-weight:600}.list__subtitle{margin:0;color:var(--color-text-muted);font-size:.85rem}.list__meta{display:grid;gap:.35rem;text-align:right}.list__value{font-weight:600}.list__value--highlight{font-size:1.3rem;color:var(--color-primary)}.list__trend{font-size:.85rem;color:var(--color-text-muted)}.badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--color-primary);border:1px solid rgba(255,255,255,.35);font-weight:600;color:#fff}.card--inline{display:grid;gap:.5rem}.panel--wide{display:grid;gap:1.5rem}.alerts{list-style:none;margin:0;padding:0;display:grid;gap:1rem}.alerts__item{display:grid;grid-template-columns:1fr auto;gap:1rem;padding:1.25rem 1.5rem;border-radius:1rem;border:1px solid var(--color-border);background:#fff}.alerts__item--high{border-color:#dc262640}.alerts__item--medium{border-color:#f59e0b40}.alerts__item--info{border-color:#2563eb40}.alerts__content{display:grid;gap:.35rem}.alerts__title{margin:0;font-weight:600}.alerts__description{margin:0;color:var(--color-text-muted);font-size:.95rem}.alerts__action{align-self:center}@media(max-width:960px){.list__item{grid-template-columns:1fr;text-align:left}.alerts__item{grid-template-columns:1fr}.alerts__action{justify-self:start}}.requests__filters{display:flex;flex-wrap:wrap;gap:.75rem}.chip{border:1px solid var(--color-border);background:var(--color-surface);border-radius:999px;padding:.45rem 1.1rem;font-weight:500;font-size:.9rem;cursor:pointer;transition:all .2s ease}.chip--active{border-color:var(--color-primary);background:#0d63c61a;color:var(--color-primary)}.requests__link{font-weight:600;color:var(--color-primary);text-decoration:none}.requests__link:hover{text-decoration:underline}.panel__title{margin:0;font-size:1.1rem;font-weight:600}.description-list{margin:1.5rem 0 0;display:grid;gap:1.25rem}.description-list dt{font-size:.8rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;margin:0 0 .35rem}.description-list dd{margin:0;font-size:1rem;font-weight:600}.attachments{list-style:none;margin:1.5rem 0 0;padding:0;display:grid;gap:.75rem}.attachments__item{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1rem;border:1px solid var(--color-border);border-radius:.85rem;background:#0d63c60d;font-weight:500}.attachments__size{color:var(--color-text-muted);font-size:.9rem}.attachments__action{margin-top:1.25rem}.notes{margin:1.5rem 0 0;padding:0;list-style:none;display:grid;gap:1.25rem}.notes__item{border:1px solid var(--color-border);border-radius:1rem;padding:1.25rem;background:#fff;display:grid;gap:.75rem}.notes__author{margin:0;font-weight:600}.notes__timestamp{margin:.15rem 0 0;color:var(--color-text-muted);font-size:.85rem}.notes__content{margin:0;color:#111827;line-height:1.5}.notes__action,.request-detail__back{margin-top:1.5rem}.users{display:grid;gap:1.75rem}.user-tabs{display:flex;justify-content:space-between;align-items:center}.user-tabs__list{display:inline-flex;background:#0d63c614;border-radius:999px;padding:.25rem;gap:.35rem}.user-tabs__item{border:none;background:transparent;padding:.45rem 1rem;border-radius:999px;font-weight:600;color:var(--color-primary);cursor:pointer}.user-tabs__item--active{background:#fff;box-shadow:0 5px 18px -12px #0d63c6b3}.users__filters{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:1.25rem;align-items:center}.users__filter-group{display:grid;gap:.4rem;font-size:.85rem;color:var(--color-text-muted)}.users__actions{display:inline-flex;gap:.45rem}.users__actions .button--ghost{background:#fff;border:1px solid var(--color-border)}.users__table-panel{padding:0}.users__table-wrapper{width:100%;overflow-x:auto;padding:1rem 1rem 1.25rem}.users__table{width:100%;table-layout:fixed}.users__table th{white-space:nowrap}.users__table td{white-space:normal;word-break:break-word}.users__roles,.users__history{display:grid;gap:1.5rem}.users__roles h3,.users__history h3{margin:0;font-size:1.15rem;font-weight:600}.users__roles p,.users__history p{margin:0;color:var(--color-text-muted);line-height:1.5}.timeline__bullet--info{background:#2563eb}.timeline__bullet--warning{background:#f59e0b}@media(max-width:960px){.users__filters{grid-template-columns:1fr}.users__actions{flex-direction:column;gap:.35rem}}.report-card{display:grid;gap:1rem}.report-card__title{margin:0;font-size:1.15rem;font-weight:600}.report-card__description{margin:0;color:var(--color-text-muted);line-height:1.6}.report-card__footer{display:flex;justify-content:space-between;align-items:center}.report-card__timestamp{color:var(--color-text-muted);font-size:.9rem}.section-header__subtitle{margin:.35rem 0 0;color:var(--color-text-muted)}.settings__table th,.settings__table td{white-space:nowrap}.settings__action{padding:.45rem .9rem}.settings__placeholder{border:1px dashed rgba(13,99,198,.2);border-radius:1rem;padding:2rem;display:grid;gap:1rem;color:var(--color-text-muted)}.not-found{display:grid;place-items:center;gap:1rem;text-align:center}.not-found__badge{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:999px;background:#0d63c61f;color:var(--color-primary);font-weight:700;letter-spacing:.12em}.not-found__title{margin:0;font-size:1.8rem}.not-found__description{margin:0;color:var(--color-text-muted);max-width:360px;line-height:1.5}.login{min-height:100vh;background:linear-gradient(135deg,#0d63c626,#0f447073);display:flex;align-items:center;justify-content:center;padding:2rem}.login__card{width:min(420px,100%);background:#fff;border-radius:1.5rem;padding:2.5rem;box-shadow:0 30px 60px -35px #0d63c680;display:grid;gap:2rem}.login__header{display:grid;gap:1.25rem;text-align:center}.login__header img{width:72px;margin:0 auto}.login__header h1{margin:0;font-size:1.6rem;font-weight:700}.login__header p{margin:0;color:var(--color-text-muted);line-height:1.5}.login__form{display:grid;gap:1.25rem}.login__field{display:grid;gap:.5rem;text-align:left;font-weight:500}.login__field span{font-size:.9rem;color:var(--color-text-muted)}.login__field input{border-radius:.85rem;border:1px solid var(--color-border);padding:.65rem .85rem;font:inherit;box-shadow:0 1px 2px #0f46820d;transition:border-color .2s ease,box-shadow .2s ease}.login__field select{border-radius:.85rem;border:1px solid var(--color-border);padding:.65rem .85rem;font:inherit;background:#fff;box-shadow:0 1px 2px #0f46820d;transition:border-color .2s ease,box-shadow .2s ease}.login__hint{margin:.35rem 0 0;font-size:.82rem;color:var(--color-text-muted);line-height:1.4}.login__field input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #0d63c62e;outline:none}.login__field select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #0d63c62e;outline:none}.login__options{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:var(--color-text-muted)}.login__checkbox{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer}.login__checkbox input{width:16px;height:16px;accent-color:var(--color-primary)}.login__link{background:none;border:none;color:var(--color-primary);font-weight:600;cursor:pointer}.login__submit{border-radius:.9rem;border:none;background:var(--color-primary);color:#fff;padding:.75rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.login__submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px -12px #0d63c699}.login__submit:disabled{opacity:.65;cursor:progress}.login__footer{text-align:center;font-size:.85rem;color:var(--color-text-muted)}@media(max-width:560px){.login{padding:1.5rem}.login__card{padding:2rem}}.unauthorized{display:grid;place-items:center;gap:1rem;text-align:center;padding:3rem 2rem}.unauthorized__badge{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:999px;background:#dc262626;color:#b91c1c;font-weight:700;letter-spacing:.12em}.unauthorized__title{margin:0;font-size:1.8rem}.unauthorized__description{margin:0;color:var(--color-text-muted);max-width:360px;line-height:1.5}#root{min-height:100vh}.grid{display:grid;gap:1.25rem}.grid--3{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.card{background:var(--color-surface);border-radius:1rem;padding:1.5rem;border:1px solid var(--color-border);box-shadow:0 10px 30px -12px #0f468233}.card__title{margin:0;font-size:.95rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em}.card__value{margin:.75rem 0 0;font-size:2rem;font-weight:600}.card__trend{display:inline-flex;gap:.35rem;align-items:center;font-size:.9rem;margin-top:.75rem}.card__trend--up{color:#059669}.card__trend--down{color:#dc2626}.section-header{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.section-header__title{margin:0;font-size:1.35rem;font-weight:600}.section-header__actions{display:flex;gap:.6rem}.button{border-radius:.75rem;border:1px solid var(--color-border);background:var(--color-surface);padding:.55rem 1rem;font-weight:500;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.button--primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.button--ghost{background:transparent;color:var(--color-primary)}.button--ghost:hover{background:#0d63c614}.button:hover{transform:translateY(-1px);box-shadow:0 10px 20px -15px #0d63c699}.table{width:100%;border-collapse:collapse}.table th{text-align:left;padding:.65rem .85rem;font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border)}.table td{padding:.85rem;border-bottom:1px solid var(--color-border);font-size:.93rem}.table tr:hover td{background:#0d63c60d}.status-pill{padding:.35rem .75rem;border-radius:999px;font-weight:600;font-size:.85rem}.status-pill--pending{background:#f59e0b1f;color:#b45309}.status-pill--approved{background:#0596691f;color:#047857}.status-pill--rejected{background:#ef44441f;color:#b91c1c}.status-pill--active{background:#0596691f;color:#047857}.status-pill--invited{background:#3b82f61f;color:#2563eb}.status-pill--suspended{background:#f472b61f;color:#db2777}.tag{display:inline-flex;align-items:center;gap:.35rem;font-size:.85rem;background:#0d63c614;color:var(--color-primary);padding:.35rem .65rem;border-radius:999px}.panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:1rem;padding:1.5rem}.split{display:grid;gap:1.5rem}.split--2{grid-template-columns:2fr 1fr}@media(max-width:960px){.split--2{grid-template-columns:1fr}}.input,.select{box-shadow:0 1px 2px #0f46820d;transition:border-color .2s ease,box-shadow .2s ease}.input:focus,.select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0d63c62e}
