:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.topbar{position:sticky;top:0;grid-column:1 / -1;grid-row:1 / 2;display:flex;align-items:center;justify-content:space-between;height:var(--topbar-height);padding:0 .5rem;background:var(--color-bg);border-bottom:1px solid var(--color-border);z-index:20;transition:background var(--transition)}.topbar__left,.topbar__right{display:flex;align-items:center;gap:.5rem;width:calc(var(--sidebar-width) + .5rem);justify-content:center}.topbar__title{font-size:1.25rem;font-weight:600;letter-spacing:.01em}.topbar__icon{background:none;border:none;color:var(--color-fg);cursor:pointer;padding:.25rem;border-radius:50%;transition:background var(--transition)}.topbar__icon:focus{outline:2px solid var(--color-primary);outline-offset:2px;background:var(--color-border)}.sidebar{position:sticky;top:var(--topbar-height);grid-column:1 / 2;grid-row:2 / -1;width:var(--sidebar-width);height:calc(100vh - var(--topbar-height));background:var(--color-bg-secondary);border-right:1px solid var(--color-border);transition:background var(--transition),transform var(--transition);overflow-y:auto;z-index:10;padding:1rem .5rem}@media (max-width: 768px){.sidebar{position:fixed;left:0;transform:translate(calc(-1 * var(--sidebar-width)))}.sidebar.open{transform:translate(0)}}.sidebar__list{list-style:none;padding:0;margin:0;width:100%;display:flex;flex-direction:column;gap:2rem}.sidebar__item{width:100%;display:flex;justify-content:center}.sidebar__link{display:flex;flex-direction:column;align-items:center;text-decoration:none;color:var(--color-fg);font-size:.95rem;font-weight:500;padding:.5rem 0 .25rem;border-radius:8px;transition:background var(--transition),color var(--transition);width:100%}.sidebar__link:focus{outline:2px solid var(--color-primary);outline-offset:2px;background:var(--color-border)}.sidebar__link--active{color:var(--color-primary);background:#4f8cff14}.sidebar__icon{margin-bottom:.25rem}.sidebar__label{font-size:.85rem;margin-top:.1rem}@media (max-width: 700px){.sidebar{flex-direction:row;border-right:none;border-bottom:1px solid var(--color-border);grid-row:2 / 3;grid-column:1 / -1;padding:.5rem 0;min-width:0;height:auto;position:static}.sidebar__list{flex-direction:row;gap:1.5rem;width:100%;justify-content:center}.sidebar__item{width:auto}}:root{--card-bg: #ffffff;--card-border: rgba(0,0,0,.06);--card-shadow: 0 2px 5px rgba(0,0,0,.03), 0 1px 2px rgba(0,0,0,.04);--card-shadow-hover: 0 4px 12px rgba(0,0,0,.05), 0 2px 4px rgba(0,0,0,.06);--text-primary: #000000;--text-secondary: rgba(0,0,0,.65);--text-tertiary: rgba(0,0,0,.45);--border-color: rgba(0,0,0,.07);--row-hover: rgba(0,0,0,.02);--total-border: rgba(0,0,0,.09);--chart-label: rgba(0,0,0,.8)}@media (prefers-color-scheme: dark){:root{--card-bg: rgba(255,255,255,.06);--card-border: rgba(255,255,255,.08);--card-shadow: 0 2px 5px rgba(0,0,0,.2), 0 1px 2px rgba(0,0,0,.25);--card-shadow-hover: 0 4px 12px rgba(0,0,0,.3), 0 2px 4px rgba(0,0,0,.35);--text-primary: #ffffff;--text-secondary: rgba(255,255,255,.75);--text-tertiary: rgba(255,255,255,.55);--border-color: rgba(255,255,255,.1);--row-hover: rgba(255,255,255,.03);--total-border: rgba(255,255,255,.12);--chart-label: rgba(255,255,255,.9)}}.report-card{display:flex;flex-direction:column;background-color:var(--card-background);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;height:100%;transition:all .3s cubic-bezier(.4,0,.2,1)}.report-card:hover{box-shadow:var(--card-shadow-hover);transform:translateY(-2px)}.report-card h2{font-size:1.25rem;font-weight:500;letter-spacing:-.02em;color:var(--text-primary);margin:0 0 .5rem}.report-card-header{text-align:center;margin-bottom:1.5rem}.report-card-content{display:grid;grid-template-columns:auto 1fr;gap:2rem;align-items:start;flex:1}.report-card-chart{display:flex;justify-content:center;align-items:flex-start;padding:.5rem}.report-card-table{flex:1;min-width:0}.report-card table{width:100%;border-collapse:separate;border-spacing:0;font-size:.875rem}.report-card th,.report-card td{padding:.75rem;text-align:right}.report-card th:first-child,.report-card td:first-child{text-align:left;padding-left:0}.report-card th:last-child,.report-card td:last-child{padding-right:0}.report-card th{color:var(--text-secondary);font-weight:600;border-bottom:2px solid var(--border-color)}.report-card .department-column{display:flex;align-items:center;gap:.5rem}.report-card .department-color-dot{width:.75rem;height:.75rem;border-radius:50%;display:inline-block;flex-shrink:0}.report-card .total-row{font-weight:600;border-top:2px solid var(--total-border)}.report-card .total-row td{padding-top:1rem}@media (max-width: 768px){.report-card{padding:1rem}.report-card-content{grid-template-columns:1fr;gap:1.5rem}.report-card th,.report-card td{padding:.5rem}}.tab-navigation{display:flex;gap:.5rem}.tab-button{background:none;border:none;border-radius:6px;padding:.5rem 1rem;font-size:1rem;color:var(--text-secondary);cursor:pointer;transition:all .2s ease-in-out;font-weight:500;position:relative}.tab-button:after{content:"";position:absolute;bottom:-.5rem;left:0;width:100%;height:2px;background:var(--primary-color);transform:scaleX(0);transition:transform .2s ease-in-out}.tab-button.active{color:var(--text-primary)}.tab-button.active:after{transform:scaleX(1)}.tab-button:hover{color:var(--text-primary);background:var(--hover-bg)}@media (prefers-color-scheme: dark){.tab-button{color:var(--text-secondary)}.tab-button.active{color:var(--text-primary)}}:root{--page-bg: #f5f7fa;--text-primary: #1a1a1a;--text-secondary: #666;--border-color: #eaeaea;--primary-color: #2563eb;--primary-color-hover: #1d4ed8;--primary-light: rgba(37, 99, 235, .15)}@media (prefers-color-scheme: dark){:root{--page-bg: #121212;--text-primary: #ffffff;--text-secondary: #a0a0a0;--border-color: #333;--primary-color: #3b82f6;--primary-color-hover: #2563eb;--primary-light: rgba(59, 130, 246, .15)}.progress-bar-container{background:#404040;box-shadow:inset 0 1px 2px #0003}}.reports-page{background-color:var(--page-bg);color:var(--text-primary);min-height:100vh;display:flex;flex-direction:column;gap:2rem;padding:2rem;margin:0 auto;max-width:1200px}.reports-page h1{color:var(--text-primary);font-size:2rem;margin-bottom:1.5rem}.reports-page header{margin-bottom:1rem}.reports-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.reports-toolbar-left{display:flex;align-items:center;gap:1rem;flex:1}.reports-page input[type=search]{padding:.5rem 1rem;border-radius:6px;border:1px solid var(--border-color);background:var(--card-bg);color:var(--text-primary);min-width:220px;transition:all .2s ease}.reports-page input[type=search]:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px var(--primary-light)}.reports-page input[type=search]::placeholder{color:var(--text-secondary);opacity:.8}.button-import{padding:.5rem 1rem;font-size:1rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s,opacity .2s}.button-import:hover:not(:disabled){background-color:var(--primary-color-hover)}.button-import:disabled{opacity:.7;cursor:not-allowed}.reports-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:4.5rem 1rem;height:calc(100vh - 17rem);overflow-y:auto;overflow-x:hidden;padding-right:10px;padding-bottom:2rem;animation:fadein .3s ease-in-out;align-items:stretch}.reports-container>*{height:100%}.reports-error{color:var(--error-color);background-color:var(--error-bg);padding:1rem;border-radius:6px;margin-bottom:1rem}.departments-toolbar{display:flex;justify-content:space-between;align-items:center;margin:1.5rem 0}.button-create{padding:.5rem 1rem;font-size:1rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s,opacity .2s}.button-create:hover:not(:disabled){background-color:var(--primary-color-hover)}.button-create:disabled{opacity:.7;cursor:not-allowed}.departments-error{color:var(--error-color);background-color:var(--error-bg);padding:1rem;border-radius:6px;margin-bottom:1rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.modal-content{background:#fff;padding:2rem;border-radius:12px;width:90%;max-width:400px;position:relative;box-shadow:0 8px 24px #0000001f;animation:slideIn .3s ease-out}.modal-body{display:flex;flex-direction:column;align-items:center;text-align:center}.modal-spinner{width:40px;height:40px;border:3px solid var(--primary-color);border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1.5rem}.modal-title{font-size:1.25rem;font-weight:600;margin:0 0 .5rem;color:var(--text-primary)}.modal-description{color:var(--text-secondary);margin:0 0 1.5rem;font-size:.9375rem}.progress-bar-container{width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;margin-bottom:1.5rem;position:relative;box-shadow:inset 0 1px 2px #0000001a}.progress-bar{height:100%;background:var(--primary-color);transition:width .3s ease-out;border-radius:4px;position:relative;box-shadow:0 1px 2px #0000001a}.progress-text{position:absolute;right:0;top:-20px;font-weight:500;color:var(--text-primary);font-size:.875rem;color:var(--text-secondary)}.modal-status{text-align:center;font-size:.9375rem;color:var(--text-primary);margin:0;min-height:2.5em;display:flex;flex-direction:column;gap:.5rem;animation:fadeIn .2s ease-out}.modal-substatus{font-size:.875rem;color:var(--text-secondary);font-style:italic}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.reports-nav{border-bottom:1px solid var(--border-color);margin-bottom:1rem}.reports-nav-items{display:flex;align-items:center;gap:1rem;padding-bottom:.5rem}.reports-nav-items .button-create{margin-left:auto}.reports-nav-items :global(.search-input){width:220px}@media (max-width: 768px){.reports-page{padding:1rem}.reports-toolbar{flex-direction:column}.reports-page input[type=search]{width:100%}.reports-header{flex-direction:column;gap:1rem;align-items:stretch}.reports-header-left{flex-direction:column;gap:1rem}.button-create{width:100%}.reports-nav-items{flex-direction:column;align-items:stretch;gap:.5rem;padding:.5rem 0 1rem}.reports-nav-items .button-create{margin-left:0;margin-top:.5rem}.reports-nav-items :global(.search-input){width:100%}.reports-container{grid-template-columns:1fr}}:root{--color-bg: #f8f9fa;--color-bg-dark: #181a1b;--color-fg: #222;--color-fg-dark: #f8f9fa;--color-primary: #4f8cff;--color-primary-dark: #90caf9;--color-accent: #ffb300;--color-border: #e0e0e0;--transition: .2s cubic-bezier(.4,0,.2,1);--font-main: "Inter", system-ui, sans-serif;--sidebar-width: 90px;--topbar-height: 60px}[data-theme=dark]{--color-bg: var(--color-bg-dark);--color-fg: var(--color-fg-dark);--color-primary: var(--color-primary-dark);--color-border: #23272a}body{margin:0;padding:0;width:100vw;max-width:100vw;overflow-x:hidden;font-family:var(--font-main);background:var(--color-bg);color:var(--color-fg);transition:background var(--transition),color var(--transition)}.app-layout{display:grid;grid-template-columns:var(--sidebar-width) 1fr;grid-template-rows:auto 1fr;min-height:100vh;min-width:100%;width:100%;margin:0 auto;padding:0;background:var(--color-bg)}.app-main{grid-column:2 / -1;grid-row:2 / -1;margin-right:0;padding:0 2vw;min-width:0;min-height:0;width:100%;background:var(--color-bg);transition:background var(--transition)}.main-content{width:100%;max-width:1200px;margin:0 auto;background:var(--color-bg);border-radius:12px;box-shadow:0 2px 8px #0000000a;padding:2rem 0}.main-content h1{margin-top:0;margin-bottom:1.5rem;padding-left:0;font-size:2rem;font-weight:700;letter-spacing:.01em;text-align:left}.departments-toolbar{display:flex;gap:16px;align-items:center;margin-bottom:16px;justify-content:space-between}.departments-sort-btn{padding:.5rem 1rem;font-size:1rem;border-radius:6px;border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-fg);cursor:pointer;transition:background var(--transition),color var(--transition)}.departments-sort-btn:focus{outline:2px solid var(--color-primary);outline-offset:2px;background:var(--color-border)}.departments-error{color:red;margin-bottom:8px}.departments-table-container{width:100%;overflow-x:auto;text-align:left}.department-id{font-variant-numeric:tabular-nums;font-weight:500;text-align:left;display:block;font-size:.97rem}.department-name{display:block;min-width:120px;text-align:left;font-size:.97rem}.department-name-input{width:100%;min-width:120px;text-align:left;font-size:.97rem}.button-edit{background:#2563eb;color:#fff;border:none;border-radius:6px;padding:.4rem 1.1rem;font-size:1rem;font-weight:500;margin-right:.5rem;cursor:pointer;box-shadow:0 1px 2px #2563eb0f;transition:background .18s,color .18s,box-shadow .18s}.button-edit:hover,.button-edit:focus{background:#1e40af;color:#fff;box-shadow:0 2px 8px #1e40af21}.button-delete{background:#b91c1c;color:#fff;border:none;border-radius:6px;padding:.4rem 1.1rem;font-size:1rem;font-weight:500;margin-right:0;cursor:pointer;box-shadow:0 1px 2px #b91c1c0f;transition:background .18s,color .18s,box-shadow .18s}.button-delete:hover,.button-delete:focus{background:#991b1b;color:#fff;box-shadow:0 2px 8px #991b1b21}.button-create{background:#16a34a;color:#fff;border:none;border-radius:6px;padding:.4rem 1.1rem;font-size:1rem;font-weight:500;margin-right:.5rem;cursor:pointer;box-shadow:0 1px 2px #16a34a0f;transition:background .18s,color .18s,box-shadow .18s}.button-create:hover,.button-create:focus{background:#166534;color:#fff;box-shadow:0 2px 8px #16653421}.button-group{display:flex;flex-direction:row;gap:.5rem;align-items:center}@media (max-width: 700px){.app-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr;width:100%}.app-main{margin-left:0;padding:1rem 2vw;width:100vw;max-width:100vw}.main-content{width:100vw;max-width:100vw;padding:1rem}}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.app-main,.main-content{scrollbar-width:thin;scrollbar-color:var(--color-primary) var(--color-border)}.app-main::-webkit-scrollbar,.main-content::-webkit-scrollbar{width:8px;background:var(--color-border)}.app-main::-webkit-scrollbar-thumb,.main-content::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:4px}#root{max-width:1280px;margin:0 auto;padding:.5rem 0;text-align:center;width:100vw;height:100vh;max-width:100vw;max-height:calc(100vh - 1rem);overflow:hidden}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}table{width:100%;border-collapse:collapse;background:var(--color-bg);font-size:1rem}thead th{font-size:1.08rem;font-weight:600;color:var(--color-fg);border-bottom:2px solid var(--color-border);padding:.75rem .5rem .5rem;text-align:left;background:var(--color-bg)}tbody td{font-size:.97rem;color:var(--color-fg);border-bottom:1px solid var(--color-border);padding:.5rem;text-align:left;background:var(--color-bg)}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:#4f8cff0f}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000052;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--color-bg, #fff);color:var(--color-fg, #222);border-radius:12px;box-shadow:0 4px 32px #0000002e;padding:2.5rem 2.5rem 2rem;display:flex;flex-direction:column;align-items:center;min-width:260px;min-height:120px}.modal-spinner{width:2.5rem;height:2.5rem;border:4px solid #e0e0e0;border-top:4px solid #2563eb;border-radius:50%;animation:modal-spin 1s linear infinite;margin-bottom:1.2rem}@keyframes modal-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-message{font-size:1.15rem;font-weight:500;text-align:center}.modal-progress-log{font-family:var(--font-main, "Inter", system-ui, sans-serif);background:#f6f8fa;border-radius:8px;padding:.7rem 1rem;margin-top:1.2rem;max-height:180px;overflow-y:auto;width:100%;box-sizing:border-box;font-size:.98rem;color:#222}.custom-table{max-height:calc(100vh - 15rem);overflow-y:scroll;display:block}
