html,body,#root{margin:0;padding:0;min-height:100%}body{background:var(--color-bg-root, #f6f7ff);color:var(--color-text-primary, #080038);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased}button,input,select,textarea{font-family:inherit}button{cursor:pointer}button:disabled,input:disabled,select:disabled,textarea:disabled{cursor:not-allowed}a{color:inherit;text-decoration:none}*{box-sizing:border-box}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400}.theme-light{--color-bg-root: #f6f7ff;--color-bg-sidebar: #080038;--color-sidebar-item: rgba(255, 255, 255, .06);--color-sidebar-item-active: rgba(255, 255, 255, .16);--color-sidebar-badge-bg: rgba(255, 255, 255, .12);--color-text-primary: #080038;--color-text-secondary: #3b3f7a;--color-text-muted: rgba(8, 0, 56, .55);--color-text-inverse: #ffffff;--color-panel: #ffffff;--color-panel-alt: #eef0ff;--color-border-soft: rgba(8, 0, 56, .08);--color-border-strong: rgba(8, 0, 56, .16);--color-accent: #080038;--color-accent-soft: rgba(8, 0, 56, .08);--color-success: #1c1c6b;--color-success-soft: rgba(8, 0, 56, .12);--color-danger: #c62846;--color-danger-soft: rgba(198, 40, 70, .12);--color-overlay: rgba(8, 0, 56, .55);--shadow-soft: 0 18px 32px rgba(8, 0, 56, .08);--shadow-strong: 0 28px 52px rgba(8, 0, 56, .12);color-scheme:light}.theme-dark{--color-bg-root: #080038;--color-bg-sidebar: #050026;--color-sidebar-item: rgba(255, 255, 255, .08);--color-sidebar-item-active: rgba(255, 255, 255, .18);--color-sidebar-badge-bg: rgba(255, 255, 255, .18);--color-text-primary: #f4f6ff;--color-text-secondary: rgba(255, 255, 255, .78);--color-text-muted: rgba(255, 255, 255, .6);--color-text-inverse: #080038;--color-panel: #0f0a3f;--color-panel-alt: #130d46;--color-border-soft: rgba(255, 255, 255, .08);--color-border-strong: rgba(255, 255, 255, .18);--color-accent: #ffffff;--color-accent-soft: rgba(255, 255, 255, .1);--color-success: #e0e4ff;--color-success-soft: rgba(255, 255, 255, .18);--color-danger: #ff8aa3;--color-danger-soft: rgba(255, 138, 163, .18);--color-overlay: rgba(1, 0, 20, .75);--shadow-soft: 0 18px 32px rgba(1, 0, 20, .45);--shadow-strong: 0 28px 52px rgba(1, 0, 20, .6);color-scheme:dark}.app-shell{display:flex;min-height:100vh;background:var(--color-bg-root);color:var(--color-text-primary);transition:background .3s ease,color .3s ease}.page-section{background:var(--color-panel);border-radius:20px;border:1px solid var(--color-border-soft);box-shadow:var(--shadow-soft);padding:clamp(22px,4vw,30px);display:flex;flex-direction:column;gap:20px}.page-section__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.page-section__titles{display:flex;flex-direction:column;gap:6px}.page-section__titles h2{margin:0;font-size:clamp(1.2rem,2vw,1.5rem);color:var(--color-text-primary)}.page-section__titles p{margin:0;color:var(--color-text-secondary);font-size:.9rem}.page-section__actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.page-section__body{display:flex;flex-direction:column;gap:18px}.page-section__footer{padding-top:12px;border-top:1px solid var(--color-border-soft);color:var(--color-text-secondary);font-size:.85rem}.app-sidebar{width:clamp(240px,22vw,300px);background:var(--color-bg-sidebar);color:var(--color-text-inverse);display:flex;flex-direction:column;padding:32px 26px;gap:24px;box-shadow:6px 0 30px #08003847;position:relative;z-index:2}.app-sidebar__brand{display:flex;align-items:center;gap:12px}.app-sidebar__logo{width:46px;height:46px;border-radius:14px;background:#ffffff1f;display:grid;place-items:center;font-size:1.32rem;color:var(--color-text-inverse);box-shadow:inset 0 0 0 1px #ffffff2e}.app-sidebar__title{display:flex;flex-direction:column;font-weight:700;letter-spacing:.01em}.app-sidebar__title span{font-size:1rem}.app-sidebar__title small{font-size:.76rem;opacity:.7}.sidebar-nav{display:flex;flex-direction:column;gap:10px;flex:1}.sidebar-nav__item{background:var(--color-sidebar-item);border:1px solid transparent;color:inherit;text-align:left;border-radius:16px;padding:14px 18px;display:flex;flex-direction:column;gap:4px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease;position:relative}.sidebar-nav__item:hover{transform:translate(4px);border-color:#ffffff40;box-shadow:0 18px 34px #08003838}.sidebar-nav__item--active{background:var(--color-sidebar-item-active);border-color:#ffffff47;box-shadow:0 20px 40px #08003847}.sidebar-nav__label{font-size:.96rem;font-weight:600}.sidebar-nav__subtitle{font-size:.76rem;opacity:.75;line-height:1.4}.sidebar-nav__badge{position:absolute;top:10px;right:16px;background:var(--color-sidebar-badge-bg);color:var(--color-text-inverse);border-radius:999px;padding:2px 8px;font-size:.7rem;font-weight:600}.app-main{flex:1;padding:clamp(26px,5vw,46px);display:flex;flex-direction:column;gap:32px;position:relative;z-index:1}.app-header{display:flex;align-items:flex-start;justify-content:space-between;gap:24px}.app-header__titles{display:flex;flex-direction:column;gap:6px}.app-header__eyebrow{margin:0;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);font-weight:700}.app-header h1{margin:0;font-size:clamp(1.9rem,3vw,2.3rem);color:var(--color-text-primary);font-weight:700}.app-header__subtitle{margin:0;font-size:.92rem;color:var(--color-text-secondary);max-width:560px}.app-header__actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}.app-header__hint{font-size:.78rem;color:var(--color-text-muted);font-weight:600}.app-header__primary-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.app-content{display:flex;flex-direction:column;gap:28px;padding-bottom:40px}.action-button{border:1px solid var(--color-border-soft);border-radius:999px;padding:8px 18px;font-size:.86rem;font-weight:600;cursor:pointer;background:transparent;color:var(--color-text-primary);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.action-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-soft);border-color:#08003833}.action-button:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.action-button--primary{background:var(--color-accent);color:var(--color-text-inverse);border-color:transparent}.action-button--primary:hover:not(:disabled){box-shadow:var(--shadow-strong)}.action-button--ghost{background:transparent}.panel{background:var(--color-panel);border-radius:20px;padding:clamp(22px,4vw,30px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:20px;border:1px solid var(--color-border-soft)}.panel__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.panel__header h2{margin:0 0 6px;font-size:clamp(1.2rem,2vw,1.5rem);color:var(--color-text-primary)}.panel__header p{margin:0;color:var(--color-text-secondary);font-size:.9rem}.panel__footnote{font-size:.8rem;color:var(--color-text-secondary);background:var(--color-panel-alt);border-radius:12px;padding:10px 14px;border:1px solid var(--color-border-soft)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.quick-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.quick-links__card{border:1px solid var(--color-border-soft);border-radius:18px;padding:18px 20px;background:var(--color-accent-soft);color:var(--color-text-primary);text-align:left;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.quick-links__card:hover{transform:translateY(-3px);box-shadow:var(--shadow-soft);border-color:#08003833}.quick-links__card h3{margin:0 0 6px;font-size:1rem;font-weight:700}.quick-links__card p{margin:0;font-size:.84rem;color:var(--color-text-secondary)}.error-banner{background:var(--color-danger-soft);border:1px solid rgba(198,40,70,.35);color:var(--color-danger);padding:12px 14px;border-radius:14px;font-weight:600}.info-banner{background:var(--color-accent-soft);border:1px solid rgba(8,0,56,.18);color:var(--color-accent);padding:12px 14px;border-radius:14px;font-weight:600}.theme-toggle{border:1px solid var(--color-border-soft);background:transparent;color:var(--color-text-primary);border-radius:999px;padding:7px 14px;cursor:pointer;font-size:.82rem;font-weight:600;display:inline-flex;align-items:center;gap:6px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.theme-toggle:hover{transform:translateY(-1px);box-shadow:var(--shadow-soft);border-color:#0800382e}.user-menu{position:relative}.user-menu__button{display:inline-flex;align-items:center;gap:10px;padding:6px 10px;border-radius:999px;border:1px solid var(--color-border-soft);background:transparent;color:var(--color-text-primary);cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.user-menu__button:hover{transform:translateY(-1px);box-shadow:var(--shadow-soft);border-color:#0800382e}.user-menu__avatar{width:34px;height:34px;border-radius:50%;background:var(--color-accent);color:var(--color-text-inverse);display:grid;place-items:center;font-weight:600;font-size:.88rem}.user-menu__meta{display:flex;flex-direction:column;align-items:flex-start;line-height:1.2}.user-menu__name{font-size:.88rem;font-weight:600}.user-menu__role{font-size:.75rem;color:var(--color-text-muted)}.user-menu__dropdown{position:absolute;right:0;top:110%;width:260px;background:var(--color-panel);border:1px solid var(--color-border-soft);border-radius:18px;box-shadow:var(--shadow-strong);padding:18px;display:flex;flex-direction:column;gap:14px;z-index:10}.user-menu__section{display:flex;flex-direction:column;gap:6px}.user-menu__label{font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted)}.user-menu__value{font-size:.86rem;color:var(--color-text-primary);word-break:break-all}.user-menu__roles{display:flex;flex-wrap:wrap;gap:6px}.user-menu__role-chip{font-size:.75rem;padding:4px 10px;border-radius:999px;background:var(--color-accent-soft);color:var(--color-accent);font-weight:600}.user-menu__logout{border:none;background:var(--color-danger-soft);color:var(--color-danger);border-radius:12px;padding:10px 12px;font-size:.86rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.user-menu__logout:hover{transform:translateY(-1px);box-shadow:var(--shadow-soft)}.error-banner,.info-banner,.panel,.quick-links__card,.theme-toggle,.action-button,.user-menu__dropdown{transition:background .2s ease,color .2s ease,border-color .2s ease,box-shadow .2s ease}@media(max-width:1080px){.app-shell{flex-direction:column}.app-sidebar{width:100%;flex-direction:row;align-items:center;justify-content:space-between;gap:18px;padding:20px clamp(18px,4vw,28px);box-shadow:0 24px 40px #08003859}.sidebar-nav{flex-direction:row;flex-wrap:wrap}.sidebar-nav__item{flex:1 1 200px}.app-main{padding:clamp(24px,5vw,36px)}}@media(max-width:768px){.app-header{flex-direction:column}.app-header__actions{justify-content:flex-start}.quick-links__card{padding:18px}}.filter-bar{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;padding:18px;border-radius:18px;background:var(--color-panel-alt);border:1px solid var(--color-border-soft)}.filter-bar__group{display:flex;flex-wrap:wrap;gap:12px}.filter-bar select,.filter-bar input[type=search]{border:1px solid var(--color-border-soft);border-radius:12px;padding:10px 14px;font-size:.9rem;background-color:var(--color-panel);color:var(--color-text-primary);min-width:150px;transition:border-color .2s ease,box-shadow .2s ease}.filter-bar select:focus,.filter-bar input[type=search]:focus{outline:none;border-color:#0800383d;box-shadow:0 0 0 3px #08003814}.filter-bar__search{flex:1 1 240px}.filter-bar__search input{width:100%}.property-table__container{overflow:hidden;border-radius:18px;border:1px solid var(--color-border-soft);background-color:var(--color-panel);box-shadow:var(--shadow-soft)}.property-table{width:100%;border-collapse:collapse;min-width:780px}.property-table thead{background:var(--color-panel-alt);color:var(--color-text-primary)}.property-table th{text-align:left;padding:16px 18px;font-weight:600;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid var(--color-border-soft)}.property-table td{padding:16px 18px;font-size:.92rem;color:var(--color-text-primary);border-bottom:1px solid var(--color-border-soft)}.property-table tbody tr:hover{background-color:var(--color-accent-soft)}.property-table__areas{display:flex;flex-direction:column;gap:4px}.property-table__area-secondary{font-size:.76rem;color:var(--color-text-muted)}.property-table__tenant{display:flex;align-items:center;gap:8px}.occupancy{border-radius:999px;padding:6px 12px;font-size:.72rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;background:var(--color-accent-soft);color:var(--color-text-primary)}.property-table__actions{display:flex;gap:8px}.property-table__action{border:1px solid var(--color-border-soft);border-radius:999px;padding:6px 12px;font-size:.78rem;font-weight:600;background:transparent;color:var(--color-text-primary);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.property-table__action--delete{border-color:#c6284659;color:var(--color-danger)}.property-table__action:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.property-table__action:not(:disabled):hover{transform:translateY(-1px);box-shadow:var(--shadow-soft);border-color:#08003833}.property-table__loading,.property-table__empty{display:flex;align-items:center;justify-content:center;gap:12px;min-height:180px;border-radius:18px;background-color:var(--color-panel);border:1px dashed var(--color-border-soft);color:var(--color-text-muted);font-weight:600}.spinner{width:18px;height:18px;border-radius:50%;border:3px solid rgba(8,0,56,.15);border-top-color:var(--color-accent);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.property-form__backdrop{position:fixed;inset:0;background:var(--color-overlay);display:flex;align-items:center;justify-content:center;padding:clamp(16px,4vw,48px);z-index:1050}.property-form{background:var(--color-panel);width:min(960px,100%);max-height:92vh;border-radius:20px;box-shadow:var(--shadow-strong);overflow-y:auto;padding:clamp(20px,3vw,32px);display:flex;flex-direction:column;gap:18px;border:1px solid var(--color-border-soft)}.property-form__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.property-form__header h2{margin:0 0 6px;font-size:clamp(1.4rem,2.2vw,1.9rem);color:var(--color-text-primary)}.property-form__header p{margin:0;color:var(--color-text-secondary);font-size:.95rem}.property-form__close{background:transparent;border:none;font-size:1.35rem;color:var(--color-text-muted);cursor:pointer;padding:4px}.property-form__error{background:var(--color-danger-soft);border:1px solid rgba(198,40,70,.35);color:var(--color-danger);padding:12px 16px;border-radius:12px;font-weight:600}.property-form__hint{padding:10px 14px;border-radius:10px;background:var(--color-accent-soft);color:var(--color-accent);font-size:.9rem}.property-form__hint--error{background:var(--color-danger-soft);color:var(--color-danger)}.property-form__body{display:flex;flex-direction:column;gap:24px}.property-form__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.property-form__section{display:flex;flex-direction:column;gap:18px;padding:18px;border:1px solid var(--color-border-soft);border-radius:16px;background:var(--color-panel-alt)}.property-form__field-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.property-form__refresh{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.property-form__refresh-button{border:1px solid transparent;background:var(--color-accent);color:var(--color-text-inverse);border-radius:999px;padding:10px 18px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;box-shadow:var(--shadow-soft)}.property-form__refresh-button--secondary{background:var(--color-success)}label{display:flex;flex-direction:column;gap:6px;font-weight:600;color:var(--color-text-primary);font-size:.95rem}input,select,textarea{appearance:none;border-radius:12px;border:1px solid var(--color-border-soft);padding:10px 12px;font-size:.95rem;background-color:var(--color-panel);color:var(--color-text-primary);transition:border-color .2s ease,box-shadow .2s ease}input:focus,select:focus,textarea:focus{outline:none;border-color:#0800383d;box-shadow:0 0 0 3px #08003814}.property-form__checkbox{display:inline-flex;align-items:center;gap:10px;font-weight:600;color:var(--color-text-primary)}.property-form__actions{display:flex;justify-content:flex-end;gap:12px;padding-top:12px;border-top:1px solid var(--color-border-soft)}.property-form__button{border:1px solid var(--color-border-soft);border-radius:999px;padding:10px 20px;font-size:.95rem;font-weight:600;background:transparent;color:var(--color-text-primary);transition:transform .2s ease,box-shadow .2s ease}.property-form__button--primary{background:var(--color-accent);color:var(--color-text-inverse);border:none;box-shadow:var(--shadow-soft)}.property-form__button:not(.property-form__button--primary):hover{transform:translateY(-1px);box-shadow:var(--shadow-soft)}.user-panel{background:var(--color-panel);border-radius:20px;padding:26px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:22px;border:1px solid var(--color-border-soft)}.user-panel__header{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}.user-panel__actions{display:flex;align-items:center;gap:10px}.user-panel__error{background:var(--color-danger-soft);border:1px solid rgba(198,40,70,.35);color:var(--color-danger);border-radius:12px;padding:12px 16px;font-weight:600}.user-panel__table-container{overflow-x:auto}.user-panel__table{width:100%;border-collapse:collapse;min-width:780px}.user-panel__table thead th{text-align:left;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);border-bottom:1px solid var(--color-border-soft);padding-bottom:10px}.user-panel__table tbody td{padding:16px 12px;border-bottom:1px solid var(--color-border-soft);vertical-align:top}.user-panel__badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:4px 10px;font-size:.75rem;font-weight:600;background:var(--color-accent-soft);color:var(--color-text-primary)}.user-panel__primary{display:flex;align-items:center;gap:10px}.user-panel__badge[data-superuser=True]{background:#0800381f}.user-panel__contact{display:flex;flex-direction:column;gap:4px;font-size:.9rem;color:var(--color-text-secondary)}.user-panel__roles{display:flex;flex-direction:column;gap:8px}.user-panel__role{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--color-text-primary)}.user-panel__role input{width:16px;height:16px}.user-panel__role-label{font-size:.88rem}.user-panel__status{font-size:.78rem;color:var(--color-text-muted)}.user-panel__status--error{color:var(--color-danger)}.user-panel__row--busy{opacity:.75}.user-panel__action{border:1px solid rgba(198,40,70,.35);border-radius:999px;padding:8px 14px;font-size:.82rem;font-weight:600;background:transparent;color:var(--color-danger);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.user-panel__action:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.user-panel__action--delete:not(:disabled):hover{transform:translateY(-1px);box-shadow:var(--shadow-soft);border-color:#c6284680}.user-panel__action--save{border-color:#228b2259;color:#228b22;background:transparent}.user-panel__action--save:not(:disabled):hover{transform:translateY(-1px);box-shadow:var(--shadow-soft);border-color:#228b2280;background:#228b220d}.user-panel__action--cancel{border-color:#80808059;color:#666;background:transparent}.user-panel__action--cancel:not(:disabled):hover{transform:translateY(-1px);box-shadow:var(--shadow-soft);border-color:#80808080;background:#8080800d}.user-panel__action--edit{border-color:#3b82f659;color:#3b82f6;background:transparent}.user-panel__action--edit:not(:disabled):hover{transform:translateY(-1px);box-shadow:var(--shadow-soft);border-color:#3b82f680;background:#3b82f60d}.user-panel__roles-display{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}.user-panel__role-badge{display:inline-block;padding:4px 10px;font-size:.75rem;font-weight:600;border-radius:12px;background:#3b82f61a;color:#3b82f6;border:1px solid rgba(59,130,246,.2)}.user-panel__no-roles{font-size:.85rem;color:var(--color-text-muted);font-style:italic}.user-panel__status-badge{display:inline-block;padding:4px 12px;font-size:.75rem;font-weight:600;border-radius:12px;border:1px solid}.user-panel__status-badge--active{background:#228b221a;color:#228b22;border-color:#228b224d}.user-panel__status-badge--inactive{background:#c628461a;color:#c62846;border-color:#c628464d}.user-panel__empty{text-align:center;padding:24px 0;color:var(--color-text-muted);font-weight:600}.audit-panel{background-color:var(--color-panel);border-radius:20px;border:1px solid var(--color-border-soft);box-shadow:var(--shadow-soft);padding:24px;display:flex;flex-direction:column;gap:20px}.audit-panel__header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.audit-panel__error{padding:10px 12px;color:var(--color-danger);background-color:var(--color-danger-soft);border-radius:10px;font-weight:600}.audit-panel__filters{display:flex;flex-direction:column;gap:12px}.audit-panel__filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.audit-panel__filter-group{display:flex;flex-direction:column;gap:6px}.audit-panel__filter-group label{font-size:.72rem;color:var(--color-text-muted);letter-spacing:.06em;text-transform:uppercase;font-weight:600}.audit-panel__filter-actions{display:flex;gap:10px;flex-wrap:wrap}.audit-panel__filter-submit,.audit-panel__filter-reset{border-radius:999px;padding:8px 16px;font-weight:600;border:1px solid var(--color-border-soft);background:transparent;color:var(--color-text-primary)}.audit-panel__filter-submit{background:var(--color-accent);color:var(--color-text-inverse);border-color:transparent;box-shadow:var(--shadow-soft)}.audit-panel__table-wrapper{overflow-x:auto}.audit-panel__table{width:100%;border-collapse:collapse;min-width:720px}.audit-panel__table th,.audit-panel__table td{padding:12px 14px;border-bottom:1px solid var(--color-border-soft);font-size:.88rem}.audit-panel__table th{background-color:var(--color-panel-alt);text-transform:uppercase;letter-spacing:.04em;font-size:.72rem;color:var(--color-text-muted)}.stat-card{background:var(--color-panel);border-radius:16px;padding:18px 20px;display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow-soft);border:1px solid var(--color-border-soft);transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-strong)}.stat-card__label{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.stat-card__value{font-size:1.8rem;font-weight:700;color:var(--color-text-primary)}.user-modal__backdrop{position:fixed;inset:0;background:var(--color-overlay);display:flex;align-items:center;justify-content:center;padding:clamp(20px,5vw,60px);z-index:1100}.user-modal{background:var(--color-panel);border-radius:20px;width:min(720px,100%);max-height:92vh;overflow-y:auto;padding:clamp(20px,3vw,32px);box-shadow:var(--shadow-strong);display:flex;flex-direction:column;gap:20px;border:1px solid var(--color-border-soft)}.user-modal__header h2{margin:0 0 6px;color:var(--color-text-primary)}.user-modal__header p{margin:0;color:var(--color-text-secondary)}.user-modal__error{background:var(--color-danger-soft);border:1px solid rgba(198,40,70,.35);color:var(--color-danger);border-radius:12px;padding:12px 16px;font-weight:600}.user-modal__role-list{display:flex;flex-direction:column;gap:12px;max-height:200px;overflow-y:auto;border:1px solid var(--color-border-soft);border-radius:12px;padding:12px;background:var(--color-panel-alt)}.user-modal__role{display:flex;align-items:flex-start;gap:12px;padding:10px;border-radius:8px;cursor:pointer;transition:background .2s ease}.user-modal__role:hover{background:#3b82f60d}.user-modal__role input[type=checkbox]{margin-top:2px;width:18px;height:18px;cursor:pointer;flex-shrink:0}.user-modal__role>div{display:flex;flex-direction:column;gap:4px}.user-modal__role-name{font-weight:600;font-size:.95rem;color:var(--color-text-primary)}.user-modal__role-desc{font-size:.85rem;color:var(--color-text-muted);line-height:1.4}.user-modal__checkbox{display:flex;align-items:center;gap:10px;padding:10px;border-radius:8px;cursor:pointer;font-weight:500;transition:background .2s ease}.user-modal__checkbox:hover{background:#3b82f60d}.user-modal__checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.user-modal__roles{display:flex;flex-direction:column;gap:10px}.user-modal__roles>span{font-weight:600;font-size:.95rem;color:var(--color-text-primary)}.user-modal__footer{display:flex;justify-content:flex-end;gap:12px}.user-modal__button{border:1px solid var(--color-border-soft);border-radius:999px;padding:10px 20px;font-size:.95rem;font-weight:600;background:transparent;color:var(--color-text-primary)}.user-modal__button--primary{background:var(--color-success);color:var(--color-text-inverse);border:none;box-shadow:var(--shadow-soft)}.login-form{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg-root);padding:32px}.login-form__panel{background:var(--color-panel);border-radius:24px;box-shadow:var(--shadow-strong);border:1px solid var(--color-border-soft);padding:clamp(32px,6vw,48px);max-width:420px;width:100%;display:flex;flex-direction:column;gap:20px}.login-form__subtitle{margin:0;color:var(--color-text-secondary);font-size:.95rem}.login-form label{font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-muted)}.login-form input{margin-top:6px;margin-bottom:14px}.login-form button[type=submit]{border:none;border-radius:999px;padding:12px;font-size:.95rem;font-weight:600;background:var(--color-accent);color:var(--color-text-inverse);box-shadow:var(--shadow-soft)}.login-form__error{background:var(--color-danger-soft);border:1px solid rgba(198,40,70,.35);color:var(--color-danger);border-radius:12px;padding:12px 16px;font-weight:600}.login-form__consent-button{border:1px solid var(--color-border-soft);border-radius:999px;padding:10px 16px;font-weight:600;background:transparent;color:var(--color-text-primary)}
