@import "https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap";:root{--bg:#edf2f8;--bg-accent:#e4ebf5;--surface:#ffffffeb;--surface-strong:#fff;--border:#94a3b838;--text:#0f172a;--text-muted:#64748b;--text-soft:#94a3b8;--primary:#2563eb;--primary-strong:#1d4ed8;--sidebar:#111827;--sidebar-soft:#1f2937;--danger:#ef4444;--warning:#f59e0b;--info:#3b82f6;--success:#10b981;--shadow-sm:0 10px 30px #0f172a0f;--shadow-md:0 18px 50px #0f172a1a;--radius-lg:16px;--radius-md:12px;--radius-sm:8px;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Manrope,Segoe UI,sans-serif;font-size:14px;font-weight:400;line-height:1.45}*{box-sizing:border-box}html,body,#root{height:100%}body{background:radial-gradient(circle at top left, #2563eb1f, transparent 28%), radial-gradient(circle at top right, #0ea5e91a, transparent 24%), linear-gradient(180deg, #f8fafc 0%, var(--bg) 100%);min-width:320px;min-height:100vh;margin:0;overflow:hidden}#root{min-height:100%}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.admin-shell{grid-template-columns:232px minmax(0,1fr);height:100dvh;transition:grid-template-columns .2s;display:grid;overflow:hidden}.admin-shell--sidebar-collapsed{grid-template-columns:84px minmax(0,1fr)}.sidebar{color:#e5eefb;background:linear-gradient(180deg, var(--sidebar) 0%, #0b1220 100%);border-right:1px solid #ffffff0f;flex-direction:column;gap:16px;height:100dvh;min-height:0;padding:16px 14px;display:flex;position:relative;overflow:hidden}.sidebar__header{z-index:1;flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:10px;display:flex;position:relative}.sidebar__glow{pointer-events:none;background:radial-gradient(circle,#3b82f659,#0000 70%);border-radius:50%;width:180px;height:180px;position:absolute;inset:auto -40px 120px auto}.brand{z-index:1;flex:1;align-items:center;gap:14px;min-width:0;display:flex;position:relative}.brand-mark{color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:12px;place-items:center;width:38px;height:38px;font-weight:800;display:grid;box-shadow:0 12px 30px #2563eb59}.brand-title{margin:0;font-size:.92rem;font-weight:700}.brand-subtitle{color:#94a3b8;margin:2px 0 0;font-size:.76rem}.menu{z-index:1;flex-direction:column;flex-shrink:0;gap:8px;display:flex;position:relative}.menu-link__label{white-space:nowrap}.sidebar-toggle{z-index:1;color:#dbe4f0;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;padding:0;transition:background .2s,color .2s,border-color .2s;display:inline-flex;position:relative}.sidebar-toggle svg{fill:currentColor;flex-shrink:0;width:16px;height:16px}.sidebar-toggle:hover{color:#fff;background:#ffffff14}.admin-shell--sidebar-collapsed .brand{justify-content:center}.admin-shell--sidebar-collapsed .sidebar__header{flex-direction:column;align-items:center}.admin-shell--sidebar-collapsed .brand-copy,.admin-shell--sidebar-collapsed .menu-link__label,.admin-shell--sidebar-collapsed .sidebar__footer{display:none}.admin-shell--sidebar-collapsed .menu-link{justify-content:center;padding-inline:10px}.menu-link{color:#cbd5e1;border-radius:10px;align-items:center;gap:10px;padding:8px 10px;font-size:.88rem;transition:background .2s,color .2s,transform .2s;display:flex}.menu-link__icon{background:#ffffff0a;border-radius:9px;place-items:center;width:30px;height:30px;display:grid}.menu-link__icon svg{fill:currentColor;width:15px;height:15px}.menu-link:hover{color:#fff;background:#ffffff0f;transform:translate(2px)}.menu-link.active{color:#fff;background:linear-gradient(135deg,#3b82f647,#2563eb2e);box-shadow:inset 0 0 0 1px #ffffff14}.menu-group{flex-direction:column;gap:4px;display:flex}.menu-group__toggle{width:100%;font:inherit;color:#cbd5e1;text-align:left;cursor:pointer;background:0 0;border:0;border-radius:10px;align-items:center;gap:10px;padding:8px 10px;font-size:.88rem;transition:background .2s,color .2s,transform .2s;display:flex}.menu-group__toggle:hover{color:#fff;background:#ffffff0f;transform:translate(2px)}.menu-group__toggle.active{color:#fff;background:linear-gradient(135deg,#3b82f633,#2563eb1f);box-shadow:inset 0 0 0 1px #ffffff0f}.menu-group__chevron{color:#94a3b8;place-items:center;width:20px;height:20px;margin-left:auto;transition:transform .2s,color .2s;display:grid}.menu-group__chevron svg{fill:currentColor;width:16px;height:16px}.menu-group--open .menu-group__chevron{color:#dbe4f0;transform:rotate(180deg)}.menu-group__items{border-left:1px solid #ffffff14;gap:4px;margin-left:14px;padding-left:8px;display:grid}.menu-link--child{font-size:.84rem}.menu-link--child .menu-link__icon{width:26px;height:26px}.menu-link--child .menu-link__icon svg{width:13px;height:13px}.admin-shell--sidebar-collapsed .menu-group__toggle,.admin-shell--sidebar-collapsed .menu-group__items{display:none}.sidebar__footer{z-index:1;background:#ffffff0a;border:1px solid #ffffff0f;border-radius:12px;flex-shrink:0;margin-top:auto;padding:12px;position:relative}.sidebar__footer p{color:#dbe4f0;margin:0;font-size:.8rem}.sidebar__footer span{color:#94a3b8;margin-top:6px;font-size:.78rem;display:block}.main-content{height:100dvh;min-height:0;padding:16px 18px;overflow:auto}.page{max-width:1440px;margin:0 auto}.page-header{justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:16px;display:flex}.page-header-copy h1{letter-spacing:-.02em;margin:4px 0 0;font-size:clamp(1.35rem,1.6vw,1.65rem)}.page-header-copy p{max-width:720px;color:var(--text-muted);margin:4px 0 0;font-size:.86rem}.page-eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--primary);margin:0;font-size:.68rem;font-weight:700}.page-header-actions,.detail-actions{flex-wrap:wrap;gap:10px;display:flex}.dashboard-filter{gap:6px;min-width:220px;display:grid}.dashboard-filter span{color:var(--text-muted);font-size:12px;font-weight:600}.dashboard-filter select{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-strong);min-width:220px;color:var(--text);box-shadow:var(--shadow-sm);padding:10px 12px}.dashboard-filter select:focus{border-color:#2563eb59;outline:2px solid #2563eb2e}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:14px;display:grid}.nhiem-vu-filter{grid-template-columns:repeat(2,minmax(180px,240px)) auto;align-items:end;gap:12px;margin-bottom:14px;display:grid}.don-filter,.nhiem-vu-list-filter{grid-template-columns:repeat(3,minmax(180px,1fr)) auto;align-items:end;gap:12px;margin-bottom:14px;display:grid}.don-filter__actions,.nhiem-vu-list-filter__actions{align-items:end;gap:8px;padding-bottom:2px;display:flex}.nhiem-vu-filter__actions{align-items:end;padding-bottom:2px;display:flex}@media (width<=760px){.nhiem-vu-filter,.don-filter,.nhiem-vu-list-filter{grid-template-columns:1fr}}.nhiem-vu-summary{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:14px;display:grid}.nhiem-vu-summary__item{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-strong);min-height:72px;box-shadow:var(--shadow-sm);gap:4px;padding:10px 12px;display:grid}.nhiem-vu-summary__label{color:var(--text-muted);margin:0;font-size:.8rem;font-weight:600}.nhiem-vu-summary__value{border-radius:var(--radius-sm);background:#d9ead3;margin:0;padding:6px 8px;font-size:1.35rem;font-weight:700;line-height:1.1}.nhiem-vu-summary__item--primary .nhiem-vu-summary__value{color:#1d4ed8}.nhiem-vu-summary__item--pending .nhiem-vu-summary__value{color:#92400e}.nhiem-vu-summary__item--danger .nhiem-vu-summary__value{color:#dc2626}@media (width<=960px){.nhiem-vu-summary{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=560px){.nhiem-vu-summary{grid-template-columns:1fr}}.nhiem-vu-dashboard{gap:14px;margin-top:32px;padding-top:8px;display:grid}.nhiem-vu-dashboard__header{gap:8px;display:grid}.nhiem-vu-dashboard__eyebrow{color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;margin:0;font-size:.78rem;font-weight:700}.nhiem-vu-dashboard__title{max-width:72ch;margin:0;font-size:1.05rem;line-height:1.45}.nhiem-vu-dashboard__range{color:var(--text-muted);margin:0;font-size:.85rem;font-weight:600}.nhiem-vu-dashboard__content{gap:14px;display:grid}.nhiem-vu-dashboard__table th,.nhiem-vu-dashboard__table td{white-space:nowrap}.data-table tbody tr.table-row--active{background:#3b82f614}.data-table tbody tr:not(.total-row){cursor:pointer}.don-vi-detail{gap:14px;display:grid}.stat-card{border-radius:var(--radius-md);background:var(--surface-strong);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:12px 14px 10px;position:relative;overflow:hidden}.stat-card:after{content:"";background:currentColor;width:4px;position:absolute;inset:0 auto 0 0}.stat-card--danger{color:var(--danger)}.stat-card--warning{color:var(--warning)}.stat-card--info{color:var(--info)}.stat-card--success{color:var(--success)}.stat-card__label{color:var(--text);margin:0;font-size:.8rem;font-weight:600}.stat-card__value{color:var(--text);margin:6px 0 4px;font-size:1.45rem;font-weight:800;line-height:1}.stat-card__hint{color:var(--text-muted);margin:0;font-size:.74rem}.panel{background:var(--surface);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:14px}.panel__header{margin-bottom:12px}.panel__header h2{margin:0;font-size:.95rem}.panel__header p{color:var(--text-muted);margin:4px 0 0;font-size:.8rem}.modal-overlay{z-index:1000;background:#0f172a6b;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface-strong);width:min(100%,520px);box-shadow:var(--shadow-md)}.modal-card__header{justify-content:space-between;align-items:flex-start;gap:12px;padding:20px 20px 0;display:flex}.modal-card__header h2{margin:0;font-size:1.15rem}.modal-card__header p{color:var(--text-muted);margin:6px 0 0;font-size:.86rem}.modal-card__body{gap:14px;padding:18px 20px 20px;display:grid}.modal-card__footer{justify-content:flex-end;gap:8px;padding:0 20px 20px;display:flex}.modal-export-fields{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.modal-export-presets{justify-content:flex-start;display:flex}@media (width<=760px){.modal-export-fields{grid-template-columns:1fr}}.dashboard-grid{grid-template-columns:1.15fr .85fr;gap:14px;display:grid}.chart-panel,.lists-panel,.table-panel{min-width:0}.table-panel{grid-column:1/-1}.chart-wrap{width:100%}.id-columns{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.group-tabs{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.group-tab{border:1px solid var(--border);min-height:32px;color:var(--text);cursor:pointer;background:#f8fafce6;border-radius:10px;align-items:center;gap:8px;padding:0 10px;font-size:.82rem;font-weight:700;transition:background .15s,border-color .15s,box-shadow .15s;display:inline-flex}.group-tab__count{border-radius:999px;place-items:center;min-width:22px;height:22px;padding:0 6px;font-size:.72rem;display:grid}.group-tab--danger .group-tab__count{color:var(--danger);background:#ef44441f}.group-tab--warning .group-tab__count{color:var(--warning);background:#f59e0b24}.group-tab--info .group-tab__count{color:var(--info);background:#3b82f61f}.group-tab.active{box-shadow:var(--shadow-sm);background:#fff}.group-tab--danger.active{border-color:#ef444447}.group-tab--warning.active{border-color:#f59e0b47}.group-tab--info.active{border-color:#3b82f647}.group-tab-panel{flex-direction:column;gap:10px;min-height:210px;display:flex}.group-don-list{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;max-height:220px;margin:0;padding:0;list-style:none;display:grid;overflow:auto}.group-don-list li a{background:#fff;border:1px solid #94a3b82e;border-radius:8px;padding:7px 9px;font-size:.82rem;font-weight:700;transition:transform .15s,box-shadow .15s,border-color .15s;display:block}.group-don-list li a:hover{border-color:#2563eb40;transform:translateY(-1px);box-shadow:0 8px 20px #2563eb14}.id-column{border-radius:var(--radius-md);border:1px solid var(--border);background:#f8fafccc;flex-direction:column;min-height:320px;display:flex;overflow:hidden}.id-column__header{justify-content:space-between;align-items:center;gap:8px;padding:14px 14px 10px;display:flex}.id-column__header h3{margin:0;font-size:.92rem}.id-column__header span{border-radius:999px;place-items:center;min-width:28px;height:28px;font-size:.82rem;font-weight:700;display:grid}.id-column--danger .id-column__header span{color:var(--danger);background:#ef44441f}.id-column--warning .id-column__header span{color:var(--warning);background:#f59e0b24}.id-column--info .id-column__header span{color:var(--info);background:#3b82f61f}.id-column ul{flex:1;margin:0;padding:0 10px 10px;list-style:none;overflow:auto}.id-column li{margin-top:8px}.id-column li a,.id-column__empty{border-radius:10px;padding:9px 12px;font-size:.9rem;display:block}.id-column li a{background:#fff;border:1px solid #94a3b82e;transition:transform .15s,box-shadow .15s,border-color .15s}.id-column li a:hover{border-color:#2563eb40;transform:translateY(-1px);box-shadow:0 8px 20px #2563eb14}.id-column__empty{color:var(--text-soft);text-align:center}.table-shell{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface-strong);overflow:auto}.table-shell--list{box-shadow:var(--shadow-sm)}.data-table{border-collapse:collapse;width:100%}.data-table th,.data-table td{text-align:left;vertical-align:top;border-bottom:1px solid #e2e8f0e6;padding:9px 11px;font-size:.84rem}.data-table th{z-index:1;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:#f8fafc;font-size:.72rem;position:sticky;top:0}.data-table tbody tr:hover{background:#2563eb08}.data-table--dashboard td:last-child,.data-table--dashboard th:last-child{width:140px}.total-row td{background:#f8fafc;font-weight:800}.status-dot{border-radius:50%;width:10px;height:10px;margin-right:10px;display:inline-block}.status-dot--danger{background:var(--danger)}.status-dot--warning{background:var(--warning)}.status-dot--info{background:var(--info)}.status-dot--success{background:var(--success)}.count-pill{min-width:34px;color:var(--primary-strong);background:#eef2ff;border-radius:999px;justify-content:center;padding:4px 8px;font-size:.8rem;font-weight:700;display:inline-flex}.count-pill--total{color:#fff;background:#111827}.code-chip{color:var(--primary-strong);background:#eef2ff;border-radius:999px;padding:4px 8px;font-size:.8rem;font-weight:700;display:inline-flex}.cell-strong{font-weight:700}.cell-muted{color:var(--text-muted);max-width:260px;font-size:.82rem}.cell-actions{white-space:nowrap;flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;min-width:168px;display:flex}.button--ghost.button--danger{color:#b91c1c;background:#ef44441a}.button--ghost.button--danger:hover{background:#ef444429}.badge{border-radius:999px;align-items:center;padding:4px 8px;font-size:.74rem;font-weight:700;display:inline-flex}.badge--policy{color:#047857;background:#10b9811f}.badge--land{color:#1d4ed8;background:#3b82f61f}.badge--other{color:#475569;background:#94a3b82e}.status-badge{border-radius:999px;align-items:center;padding:4px 10px;font-size:.78rem;font-weight:700;display:inline-flex}.status-badge--danger{color:#b91c1c;background:#ef44441f}.status-badge--warning{color:#c2410c;background:#f973161f}.status-badge--info{color:#1d4ed8;background:#3b82f61f}.status-badge--success{color:#047857;background:#10b9811f}.status-badge--neutral{color:#475569;background:#94a3b82e}.button,.link-button{cursor:pointer;border:0;border-radius:10px;justify-content:center;align-items:center;gap:6px;min-height:32px;padding:0 12px;font-size:.84rem;font-weight:700;transition:transform .15s,box-shadow .15s,background .15s;display:inline-flex}.button--primary,.link-button{color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 12px 24px #2563eb38}.button--secondary,.link-button.secondary{color:var(--text);box-shadow:none;background:#e8edf5}.button--ghost{min-height:28px;color:var(--primary-strong);box-shadow:none;background:#2563eb14;padding:0 10px}.button:hover,.link-button:hover{transform:translateY(-1px)}.button:disabled,.link-button:disabled{opacity:.55;cursor:not-allowed;transform:none}.pagination{align-items:center;gap:10px;margin-top:12px;display:flex}.pagination__meta{color:var(--text-muted);font-size:.82rem;font-weight:600}.state-card{border-radius:var(--radius-md);background:var(--surface-strong);border:1px solid var(--border);box-shadow:var(--shadow-sm);color:var(--text-muted);align-items:center;gap:10px;padding:12px 14px;font-size:.84rem;display:flex}.state-card--error{color:#b91c1c;background:#fff5f5;border-color:#ef44442e}.state-card--success{color:#047857;background:#ecfdf5;border-color:#10b9812e}.database-admin-grid{gap:14px;display:grid}.database-admin-grid .panel{gap:12px;display:grid}.state-card--empty{box-shadow:none;background:0 0;border:0;justify-content:center}.spinner{border:2px solid #2563eb2e;border-top-color:var(--primary);border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.detail-section{height:100%}.detail-fields{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.detail-field{background:#f8fafce6;border:1px solid #e2e8f0e6;border-radius:10px;flex-direction:column;gap:4px;padding:10px 11px;display:flex}.detail-field span{letter-spacing:.04em;text-transform:uppercase;color:var(--text-soft);font-size:.68rem;font-weight:700}.detail-field p{white-space:pre-wrap;color:var(--text);margin:0;font-size:.84rem}.detail-field.full{grid-column:1/-1}.form-panel{background:var(--surface-strong);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:16px}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.form-field{flex-direction:column;gap:6px;display:flex}.form-field span{color:var(--text-muted);font-size:.78rem;font-weight:600}.form-field input,.form-field select,.form-field textarea{background:#fff;border:1px solid #cbd5e1f2;border-radius:10px;width:100%;padding:8px 10px;font-size:.84rem;transition:border-color .15s,box-shadow .15s}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:#2563eb73;outline:none;box-shadow:0 0 0 4px #2563eb1f}.date-field{position:relative}.date-field label{color:var(--text-muted);font-size:.78rem;font-weight:600}.date-field__control{position:relative}.date-field__trigger{width:100%;min-height:38px;color:var(--text);text-align:left;cursor:pointer;background:#fff;border:1px solid #cbd5e1f2;border-radius:10px;align-items:center;gap:10px;padding:8px 10px;font-size:.84rem;transition:border-color .15s,box-shadow .15s,transform .15s;display:flex}.date-field--open .date-field__trigger,.date-field__trigger:hover{border-color:#2563eb59}.date-field--open .date-field__trigger{box-shadow:0 0 0 4px #2563eb1f}.date-field__icon{width:16px;height:16px;fill:var(--primary);flex-shrink:0}.date-field__value{flex:1;font-weight:600}.date-field__placeholder{color:var(--text-soft);flex:1}.date-field__clear{width:22px;height:22px;color:var(--text-muted);background:#94a3b824;border-radius:999px;justify-content:center;align-items:center;font-size:1rem;line-height:1;display:inline-flex}.date-field__clear:hover{background:#94a3b83d}.date-field__popover{z-index:40;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface-strong);width:min(320px,100vw - 48px);box-shadow:var(--shadow-md);padding:14px;position:absolute;top:calc(100% + 8px);left:0}.date-field__popover .rdp-root{--rdp-accent-color:var(--primary);--rdp-accent-background-color:#2563eb1f;--rdp-day_button-border-radius:10px;--rdp-day_button-height:36px;--rdp-day_button-width:36px;--rdp-selected-border:0;--rdp-today-color:var(--primary-strong);--rdp-weekday-opacity:.72;width:100%}.date-field__popover .rdp-month_caption{margin-bottom:8px}.date-field__popover .rdp-dropdowns{gap:8px}.date-field__popover .rdp-dropdown_root{background:#fff;border:1px solid #cbd5e1f2;border-radius:8px}.date-field__popover .rdp-day_button:hover{background:#2563eb14}.date-field__footer{border-top:1px solid var(--border);justify-content:space-between;gap:8px;margin-top:10px;padding-top:10px;display:flex}.button--small{min-height:32px;padding:0 12px;font-size:.8rem}.form-field.full{grid-column:1/-1}.form-stack{gap:14px;display:grid}.form-section__header{margin-bottom:12px}.form-section__header h2{color:var(--text);margin:0;font-size:.98rem}.form-section__header p{color:var(--text-muted);margin:6px 0 0;font-size:.82rem}.checkbox-group>span{color:var(--text-muted);font-size:.78rem;font-weight:600}.checkbox-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:6px;display:grid}.checkbox-field{cursor:pointer;background:#f8fafce6;border:1px solid #e2e8f0f2;border-radius:10px;align-items:center;gap:8px;padding:10px 12px;display:flex}.checkbox-field input{width:auto;margin:0}.checkbox-field span{color:var(--text);font-size:.82rem}.form-actions{margin-top:12px}.phan-loai-grid{grid-template-columns:minmax(0,1.4fr) minmax(280px,.8fr);gap:14px;display:grid}.phan-loai-form{gap:12px;display:grid}.form-error{color:var(--danger);margin:0;font-size:.82rem}@media (width<=1180px){.stats-grid,.dashboard-grid,.detail-grid,.group-don-list,.detail-fields,.form-grid,.checkbox-grid{grid-template-columns:1fr}.table-panel{grid-column:1/-1}}@media (width<=900px){.admin-shell,.admin-shell--sidebar-collapsed{grid-template-rows:auto minmax(0,1fr);grid-template-columns:1fr;height:100dvh}.sidebar{flex-shrink:0;gap:12px;height:auto;padding:14px;overflow:hidden}.sidebar__header{align-items:center}.menu{flex-flow:wrap}.sidebar__footer{display:none}.sidebar-toggle{margin-left:auto}.main-content{height:100%;min-height:0;padding:18px;overflow:auto}.page-header{flex-direction:column}}.auth-page{background:radial-gradient(circle at 0 0,#3b82f62e,#0000 40%),linear-gradient(#f8fafc 0%,#eef2ff 100%);place-items:center;min-height:100dvh;padding:24px;display:grid}.auth-card{background:#ffffffeb;border:1px solid #94a3b840;border-radius:24px;width:min(100%,420px);padding:28px;box-shadow:0 24px 60px #0f172a1f}.auth-card__header{align-items:center;gap:16px;margin-bottom:24px;display:flex}.auth-card__eyebrow{color:#64748b;margin:0 0 4px;font-size:.875rem}.auth-card h1{margin:0;font-size:1.5rem}.auth-card__hint{color:#475569;margin:0 0 16px;line-height:1.5}.auth-form{gap:16px;display:grid}.auth-form__actions{justify-content:flex-end;gap:12px;display:flex}.auth-form__submit{text-align:center;justify-content:center;width:100%}.auth-setup-panel{margin-top:24px}.auth-setup-panel__content{grid-template-columns:auto 1fr;align-items:start;gap:20px;margin-bottom:16px;display:grid}.auth-setup-panel__qr{background:#fff;border:1px solid #94a3b859;border-radius:16px;width:220px;height:220px}.auth-setup-panel__details{word-break:break-all;gap:12px;display:grid}.sidebar-user{gap:4px;margin-bottom:12px;display:grid}.sidebar-user__name{margin:0;font-weight:600}.sidebar-user__role{color:#94a3b8;margin:0;font-size:.875rem}.sidebar-user__logout{width:100%;margin-bottom:12px}.sidebar-user__password{justify-content:center;width:100%;margin-bottom:8px}.form-field--checkbox{align-items:center;gap:10px;display:flex}.form-field--checkbox input{width:auto}.permission-fieldset{border:1px solid #94a3b859;border-radius:16px;margin:0;padding:16px}.permission-fieldset legend{color:#475569;padding:0 8px}.permission-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;display:grid}@media (width<=720px){.auth-setup-panel__content{grid-template-columns:1fr}}.rdp-root{--rdp-accent-color:blue;--rdp-accent-background-color:#f0f0ff;--rdp-day-height:44px;--rdp-day-width:44px;--rdp-day_button-border-radius:100%;--rdp-day_button-border:2px solid transparent;--rdp-day_button-height:42px;--rdp-day_button-width:42px;--rdp-selected-border:2px solid var(--rdp-accent-color);--rdp-disabled-opacity:.5;--rdp-outside-opacity:.75;--rdp-today-color:var(--rdp-accent-color);--rdp-dropdown-gap:.5rem;--rdp-months-gap:2rem;--rdp-nav_button-disabled-opacity:.5;--rdp-nav_button-height:2.25rem;--rdp-nav_button-width:2.25rem;--rdp-nav-height:2.75rem;--rdp-range_middle-background-color:var(--rdp-accent-background-color);--rdp-range_middle-color:inherit;--rdp-range_start-color:white;--rdp-range_start-background:linear-gradient(var(--rdp-gradient-direction), transparent 50%, var(--rdp-range_middle-background-color) 50%);--rdp-range_start-date-background-color:var(--rdp-accent-color);--rdp-range_end-background:linear-gradient(var(--rdp-gradient-direction), var(--rdp-range_middle-background-color) 50%, transparent 50%);--rdp-range_end-color:white;--rdp-range_end-date-background-color:var(--rdp-accent-color);--rdp-week_number-border-radius:100%;--rdp-week_number-border:2px solid transparent;--rdp-week_number-height:var(--rdp-day-height);--rdp-week_number-opacity:.75;--rdp-week_number-width:var(--rdp-day-width);--rdp-weeknumber-text-align:center;--rdp-weekday-opacity:.75;--rdp-weekday-padding:.5rem 0rem;--rdp-weekday-text-align:center;--rdp-gradient-direction:90deg;--rdp-animation_duration:.3s;--rdp-animation_timing:cubic-bezier(.4, 0, .2, 1)}.rdp-root[dir=rtl]{--rdp-gradient-direction:-90deg}.rdp-root[data-broadcast-calendar=true]{--rdp-outside-opacity:unset}.rdp-root{box-sizing:border-box;position:relative}.rdp-root *{box-sizing:border-box}.rdp-day{width:var(--rdp-day-width);height:var(--rdp-day-height);text-align:center}.rdp-day_button{cursor:pointer;font:inherit;color:inherit;width:var(--rdp-day_button-width);height:var(--rdp-day_button-height);border:var(--rdp-day_button-border);border-radius:var(--rdp-day_button-border-radius);background:0 0;justify-content:center;align-items:center;margin:0;padding:0;display:flex}.rdp-day_button:disabled{cursor:revert}.rdp-caption_label{z-index:1;white-space:nowrap;border:0;align-items:center;display:inline-flex;position:relative}.rdp-dropdown:focus-visible~.rdp-caption_label{outline:5px auto highlight;outline:5px auto -webkit-focus-ring-color}.rdp-button_next,.rdp-button_previous{cursor:pointer;font:inherit;color:inherit;appearance:none;width:var(--rdp-nav_button-width);height:var(--rdp-nav_button-height);background:0 0;border:none;justify-content:center;align-items:center;margin:0;padding:0;display:inline-flex;position:relative}.rdp-button_next:disabled,.rdp-button_next[aria-disabled=true],.rdp-button_previous:disabled,.rdp-button_previous[aria-disabled=true]{cursor:revert;opacity:var(--rdp-nav_button-disabled-opacity)}.rdp-chevron{fill:var(--rdp-accent-color);display:inline-block}.rdp-root[dir=rtl] .rdp-nav .rdp-chevron{transform-origin:50%;transform:rotate(180deg)}.rdp-dropdowns{align-items:center;gap:var(--rdp-dropdown-gap);display:inline-flex;position:relative}.rdp-dropdown{z-index:2;opacity:0;appearance:none;width:100%;cursor:inherit;line-height:inherit;border:none;margin:0;padding:0;position:absolute;inset-block:0;inset-inline-start:0}.rdp-dropdown_root{align-items:center;display:inline-flex;position:relative}.rdp-dropdown_root[data-disabled=true] .rdp-chevron{opacity:var(--rdp-disabled-opacity)}.rdp-month_caption{height:var(--rdp-nav-height);align-content:center;font-size:large;font-weight:700;display:flex}.rdp-root[data-nav-layout=around] .rdp-month,.rdp-root[data-nav-layout=after] .rdp-month{position:relative}.rdp-root[data-nav-layout=around] .rdp-month_caption{justify-content:center;margin-inline-start:var(--rdp-nav_button-width);margin-inline-end:var(--rdp-nav_button-width);position:relative}.rdp-root[data-nav-layout=around] .rdp-button_previous{inset-inline-start:0;height:var(--rdp-nav-height);display:inline-flex;position:absolute;top:0}.rdp-root[data-nav-layout=around] .rdp-button_next{inset-inline-end:0;height:var(--rdp-nav-height);justify-content:center;display:inline-flex;position:absolute;top:0}.rdp-months{gap:var(--rdp-months-gap);flex-wrap:wrap;max-width:fit-content;display:flex;position:relative}.rdp-month_grid{border-collapse:collapse}.rdp-nav{height:var(--rdp-nav-height);align-items:center;display:flex;position:absolute;inset-block-start:0;inset-inline-end:0}.rdp-weekday{opacity:var(--rdp-weekday-opacity);padding:var(--rdp-weekday-padding);text-align:var(--rdp-weekday-text-align);text-transform:var(--rdp-weekday-text-transform);font-size:smaller;font-weight:500}.rdp-week_number{opacity:var(--rdp-week_number-opacity);height:var(--rdp-week_number-height);width:var(--rdp-week_number-width);border:var(--rdp-week_number-border);border-radius:var(--rdp-week_number-border-radius);text-align:var(--rdp-weeknumber-text-align);font-size:small;font-weight:400}.rdp-today:not(.rdp-outside){color:var(--rdp-today-color)}.rdp-selected{font-size:large;font-weight:700}.rdp-selected .rdp-day_button{border:var(--rdp-selected-border)}.rdp-outside{opacity:var(--rdp-outside-opacity)}.rdp-disabled:not(.rdp-selected){opacity:var(--rdp-disabled-opacity)}.rdp-hidden{visibility:hidden;color:var(--rdp-range_start-color)}.rdp-range_start{background:var(--rdp-range_start-background)}.rdp-range_start .rdp-day_button{background-color:var(--rdp-range_start-date-background-color);color:var(--rdp-range_start-color)}.rdp-range_middle{background-color:var(--rdp-range_middle-background-color)}.rdp-range_middle .rdp-day_button{border:unset;border-radius:unset;color:var(--rdp-range_middle-color)}.rdp-range_end{background:var(--rdp-range_end-background);color:var(--rdp-range_end-color)}.rdp-range_end .rdp-day_button{color:var(--rdp-range_start-color);background-color:var(--rdp-range_end-date-background-color)}.rdp-range_start.rdp-range_end{background:revert}.rdp-focusable{cursor:pointer}@keyframes rdp-slide_in_left{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes rdp-slide_in_right{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes rdp-slide_out_left{0%{transform:translate(0)}to{transform:translate(-100%)}}@keyframes rdp-slide_out_right{0%{transform:translate(0)}to{transform:translate(100%)}}.rdp-weeks_before_enter{animation:rdp-slide_in_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-weeks_before_exit{animation:rdp-slide_out_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-weeks_after_enter{animation:rdp-slide_in_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-weeks_after_exit{animation:rdp-slide_out_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_after_enter{animation:rdp-slide_in_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_before_exit{animation:rdp-slide_out_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_before_enter{animation:rdp-slide_in_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_after_exit{animation:rdp-slide_out_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}@keyframes rdp-fade_in{0%{opacity:0}to{opacity:1}}@keyframes rdp-fade_out{0%{opacity:1}to{opacity:0}}.rdp-caption_after_enter{animation:rdp-fade_in var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-caption_after_exit{animation:rdp-fade_out var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-caption_before_enter{animation:rdp-fade_in var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-caption_before_exit{animation:rdp-fade_out var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}
