:root{--color-primary: #4a90a4;--color-primary-light: #6bb3c9;--color-primary-dark: #357a8c;--color-secondary: #7c9a92;--color-secondary-light: #9ab5ad;--color-secondary-dark: #5e7a72;--color-accent: #e8b87d;--color-accent-light: #f0cfa0;--color-accent-dark: #d4a05a;--color-background: #f8fafb;--color-surface: #ffffff;--color-surface-elevated: #ffffff;--color-text-primary: #2d3748;--color-text-secondary: #5a6777;--color-text-muted: #8a95a5;--color-text-inverse: #ffffff;--color-border: #e2e8f0;--color-border-light: #edf2f7;--color-success: #68b984;--color-success-light: #9dd4ae;--color-warning: #e8b87d;--color-warning-light: #f0cfa0;--color-warning-dark: #9a6b2e;--color-error: #e57373;--color-error-light: #ef9a9a;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: clamp(1.25rem, 4vw, 1.5rem);--font-size-3xl: clamp(1.5rem, 5vw, 1.875rem);--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--nav-width: 260px;--nav-width-collapsed: 72px;--header-height: 64px;--content-max-width: 1400px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px rgba(0, 0, 0, .06), 0 2px 4px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .08), 0 4px 6px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .1), 0 10px 10px rgba(0, 0, 0, .04);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--z-dropdown: 100;--z-sticky: 200;--z-modal-backdrop: 300;--z-modal: 400;--z-tooltip: 500}.nav-panel{position:fixed;top:0;left:0;width:var(--nav-width);height:100vh;background-color:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;z-index:var(--z-sticky);transition:width var(--transition-normal)}.nav-panel--collapsed{width:var(--nav-width-collapsed, 72px)}.nav-panel--collapsed .nav-panel__logo-text,.nav-panel--collapsed .nav-panel__section-title,.nav-panel--collapsed .nav-panel__label{opacity:0;width:0;overflow:hidden;white-space:nowrap}.nav-panel--collapsed .nav-panel__header{padding:var(--spacing-lg) var(--spacing-md);justify-content:center}.nav-panel--collapsed .nav-panel__logo{justify-content:center}.nav-panel--collapsed .nav-panel__link{justify-content:center;padding:var(--spacing-sm)}.nav-panel--collapsed .nav-panel__item{margin:var(--spacing-xs) var(--spacing-sm)}.nav-panel--collapsed .nav-panel__section-title{height:0;padding:0;margin:0}.nav-panel__header{padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--color-border-light)}.nav-panel__logo{display:flex;align-items:center;gap:var(--spacing-sm)}.nav-panel__logo-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-weight-bold);font-size:var(--font-size-lg)}.nav-panel__logo-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.nav-panel__content{flex:1;overflow-y:auto;padding:var(--spacing-md) 0}.nav-panel__section{margin-bottom:var(--spacing-md)}.nav-panel__section-title{padding:var(--spacing-sm) var(--spacing-xl);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.nav-panel__list{list-style:none}.nav-panel__item{margin:var(--spacing-xs) var(--spacing-md)}.nav-panel__link{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:all var(--transition-fast);text-decoration:none}.nav-panel__link:hover{background-color:var(--color-background);color:var(--color-text-primary)}.nav-panel__link--active{background-color:var(--color-primary);color:var(--color-text-inverse)}.nav-panel__link--active:hover{background-color:var(--color-primary-dark);color:var(--color-text-inverse)}.nav-panel__icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.nav-panel__icon svg{width:100%;height:100%}.nav-panel__label{flex:1}.app-shell{min-height:100vh}.app-shell__main{margin-left:var(--nav-width);min-height:100vh;display:flex;flex-direction:column;background-color:var(--color-background);transition:margin-left var(--transition-normal)}.app-shell__main--expanded{margin-left:var(--nav-width-collapsed, 72px)}.app-shell__content{flex:1;overflow-y:auto;padding:var(--spacing-xl);max-width:var(--content-max-width)}.nav-collapsed .nav-panel{width:var(--nav-width-collapsed, 72px)}.app-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-xl);background-color:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:var(--z-sticky)}.app-header__toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.app-header__toggle:hover{background-color:var(--color-background);color:var(--color-text-primary)}.app-header__spacer{flex:1}.app-header__user{display:flex;align-items:center;gap:var(--spacing-md)}.app-header__user-info{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.app-header__user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.app-header__user-email{font-size:var(--font-size-xs);color:var(--color-text-muted)}.app-header__avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:var(--color-text-inverse);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.nav-backdrop{display:none}@media(max-width:1024px){.nav-panel{transform:translate(-100%);transition:transform var(--transition-normal);z-index:var(--z-modal, 100)}.nav-panel--mobile-open{transform:translate(0)}.app-shell__main,.app-shell__main--expanded{margin-left:0}.app-shell__content{padding:var(--spacing-md)}.nav-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:calc(var(--z-modal, 100) - 1);opacity:0;pointer-events:none;transition:opacity var(--transition-normal)}.nav-backdrop--visible{opacity:1;pointer-events:auto}.nav-panel__link{min-height:44px}}@media(max-width:768px){.app-header__user-info{display:none}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);line-height:1;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background-color:var(--color-primary);color:var(--color-text-inverse)}.btn--primary:hover:not(:disabled){background-color:var(--color-primary-dark)}.btn--secondary{background-color:var(--color-background);color:var(--color-text-secondary);border:1px solid var(--color-border)}.btn--secondary:hover:not(:disabled){background-color:var(--color-border-light);color:var(--color-text-primary)}.btn--ghost{background-color:transparent;color:var(--color-text-secondary)}.btn--ghost:hover:not(:disabled){background-color:var(--color-background);color:var(--color-text-primary)}.btn--danger{background-color:var(--color-error);color:var(--color-text-inverse)}.btn--danger:hover:not(:disabled){background-color:#d32f2f}.btn--small{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs)}.btn--large{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-base)}.btn--icon{padding:var(--spacing-sm);width:36px;height:36px}.btn--icon.btn--small{width:28px;height:28px;padding:var(--spacing-xs)}.btn__icon{width:16px;height:16px}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;margin-bottom:var(--spacing-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.form-label--required:after{content:" *";color:var(--color-error)}.form-input{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--color-text-primary);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast)}.form-input:hover{border-color:var(--color-text-muted)}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4a90a426}.form-input::placeholder{color:var(--color-text-muted)}.form-input--error{border-color:var(--color-error)}.form-input--error:focus{box-shadow:0 0 0 3px #e5737326}.form-input:disabled{background-color:var(--color-background);color:var(--color-text-muted);cursor:not-allowed}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235a6777' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--spacing-md) center;padding-right:var(--spacing-2xl)}.search-box{position:relative;width:100%;max-width:320px}.search-box__icon{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--color-text-muted);pointer-events:none}.search-box__input{padding-left:var(--spacing-2xl)}.search-box__clear{position:absolute;right:var(--spacing-sm);top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;opacity:0;transition:all var(--transition-fast)}.search-box__input:not(:placeholder-shown)~.search-box__clear{opacity:1}.search-box__clear:hover{background-color:var(--color-background);color:var(--color-text-primary)}.form-error{margin-top:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-error)}.form-warning{margin-top:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-xs);color:var(--color-warning-dark);background:#e8b87d26;border:1px solid rgba(232,184,125,.4);border-radius:var(--radius-sm)}.form-helper{margin-top:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-text-muted)}input::-ms-reveal,input::-ms-clear{display:none}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper .form-input{padding-right:var(--spacing-2xl)}.password-toggle{position:absolute;right:var(--spacing-sm);display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.password-toggle:hover{background-color:var(--color-background);color:var(--color-text-primary)}.password-toggle:focus{outline:none;color:var(--color-primary)}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap}.toolbar__left,.toolbar__right{display:flex;align-items:center;gap:var(--spacing-md)}.toolbar__right .form-group{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:0}.toolbar__right .form-label{display:inline;margin-bottom:0;white-space:nowrap}.summary-stats{display:flex;align-items:center;gap:var(--spacing-lg)}.summary-stats__item{display:flex;align-items:baseline;gap:var(--spacing-sm)}.summary-stats__label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.summary-stats__value{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-variant-numeric:tabular-nums}.tpl-view__layout{display:flex;gap:var(--spacing-xl);min-height:400px;max-height:calc(100vh - 200px)}.tpl-view__sidebar{flex-shrink:0;width:200px;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);overflow-y:auto}.tpl-view__sidebar-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border-light)}.tpl-view__content{flex:1;min-width:0;overflow-y:auto}.tpl-view__placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:300px;color:var(--color-text-muted);text-align:center}.tpl-view__placeholder svg{margin-bottom:var(--spacing-md);opacity:.5}.tpl-view__placeholder p{font-size:var(--font-size-sm)}.tpl-list{list-style:none;margin:0;padding:0}.tpl-list__item{margin-bottom:var(--spacing-xs)}.tpl-list__button{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-align:left;color:var(--color-text-secondary);background-color:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.tpl-list__button:hover{background-color:var(--color-background);color:var(--color-text-primary)}.tpl-list__button--active{background-color:var(--color-primary);color:var(--color-text-inverse)}.tpl-list__button--active:hover{background-color:var(--color-primary-dark);color:var(--color-text-inverse)}@media(max-width:1024px){.btn{min-height:44px}.btn--small{min-height:44px;padding:var(--spacing-sm) var(--spacing-md)}.btn--icon{width:44px;height:44px}.btn--icon.btn--small{width:44px;height:44px;padding:var(--spacing-sm)}}@media(max-width:768px){.search-box{max-width:100%}.toolbar__left,.toolbar__right{width:100%}.summary-stats{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}}.data-table-container{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:auto;max-height:calc(100vh - 240px)}.data-table{min-width:100%;border-collapse:collapse}.data-table__header{background-color:var(--color-background)}.data-table__header-row{border-bottom:2px solid var(--color-border)}.data-table__header-cell{padding:var(--spacing-md) var(--spacing-lg);text-align:left;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);white-space:nowrap;transition:background-color var(--transition-fast),color var(--transition-fast);position:sticky;top:0;z-index:1;background-color:var(--color-background)}.data-table__header-cell--sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.data-table__header-cell--sortable:hover{background-color:var(--color-border-light);color:var(--color-text-primary)}.data-table__header-cell--active{background-color:var(--color-primary);color:var(--color-surface)}.data-table__header-cell--active:hover{background-color:var(--color-primary-dark);color:var(--color-surface)}.data-table__sort-indicator{display:inline-block;margin-left:var(--spacing-xs);font-size:10px;opacity:0;transition:opacity var(--transition-fast)}.data-table__header-cell--sortable:hover .data-table__sort-indicator{opacity:.4}.data-table__sort-indicator--active{opacity:1!important}.data-table__body{background-color:var(--color-surface)}.data-table__row{border-bottom:1px solid var(--color-border-light);transition:background-color var(--transition-fast)}.data-table__row:last-child{border-bottom:none}.data-table__row--clickable{cursor:pointer}.data-table__row--clickable:hover{background-color:var(--color-background)}.data-table__cell{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-sm);color:var(--color-text-primary);vertical-align:middle}.data-table__cell--mono{font-family:SF Mono,Consolas,monospace;font-size:var(--font-size-xs)}.data-table__cell--numeric{text-align:right;font-variant-numeric:tabular-nums}.data-table__cell--actions{text-align:right;white-space:nowrap}.data-table__empty{padding:var(--spacing-3xl);text-align:center;color:var(--color-text-muted)}.data-table__empty-icon{font-size:48px;margin-bottom:var(--spacing-md);opacity:.4}.data-table__empty-text{font-size:var(--font-size-sm)}.status-badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.status-badge--success{background-color:#68b98426;color:var(--color-success)}.status-badge--warning{background-color:#e8b87d26;color:var(--color-accent-dark)}.status-badge--error{background-color:#e5737326;color:var(--color-error)}.depletion-date--urgent{color:var(--color-error);font-weight:var(--font-weight-semibold)}.depletion-date--warning{color:var(--color-accent-dark);font-weight:var(--font-weight-medium)}.depletion-date--ok{color:var(--color-success)}.tpl-cell{font-size:var(--font-size-xs);line-height:1.4}.tpl-cell__row{display:flex;justify-content:space-between;gap:var(--spacing-sm)}.tpl-cell__row:not(:last-child){margin-bottom:2px}.tpl-cell__label{color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.tpl-cell__value{font-weight:var(--font-weight-semibold);font-variant-numeric:tabular-nums}.tpl-cell--clickable,.group-cell--clickable{cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.tpl-cell--clickable:hover,.group-cell--clickable:hover{transform:scale(1.02);box-shadow:0 2px 8px #00000026}.tpl-cell--empty{display:flex;align-items:center;justify-content:center;background:repeating-linear-gradient(-45deg,var(--color-background),var(--color-background) 4px,var(--color-border-light) 4px,var(--color-border-light) 8px);border:1px dashed var(--color-border);border-radius:4px;padding:12px 8px;min-height:70px}.tpl-cell__no-data{color:var(--color-text-muted);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.05em}.empty-value{display:inline-block;padding:2px 8px;background:var(--color-background);border:1px dashed var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:var(--font-size-xs);font-style:italic}@media(max-width:1024px){.data-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);animation:fadeIn var(--transition-fast)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background-color:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:560px;width:90%;max-height:90vh;display:flex;flex-direction:column;z-index:var(--z-modal);animation:slideUp var(--transition-normal)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal--large{max-width:800px}.modal--small{max-width:400px}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--color-border-light)}.modal__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.modal__close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.modal__close:hover{background-color:var(--color-background);color:var(--color-text-primary)}.modal__close svg{width:20px;height:20px}.modal__body{padding:var(--spacing-xl);overflow-y:auto;flex:1}.modal__footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-xl);border-top:1px solid var(--color-border-light)}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.detail-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.detail-item--full{grid-column:1 / -1}.detail-item__label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.detail-item__value{font-size:var(--font-size-base);color:var(--color-text-primary)}.detail-item__value--mono{font-family:SF Mono,Consolas,monospace;font-size:var(--font-size-sm)}.detail-item__value--large{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}@media(max-width:768px){.modal-overlay{align-items:flex-end}.modal{width:100%;max-width:100%;max-height:92vh;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.modal--large{max-width:100%}.detail-grid{grid-template-columns:1fr}}.login-view,.change-password-view{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-primary) 100%)}.login-container{width:100%;padding:var(--spacing-lg)}.login-card{max-width:400px;margin:0 auto;background-color:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--spacing-2xl)}.login-header{text-align:center;margin-bottom:var(--spacing-xl)}.login-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0}.login-subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0}.login-form .form-group{margin-bottom:var(--spacing-lg)}.login-btn{width:100%;margin-top:var(--spacing-md);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-error{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md);background-color:var(--color-error-light);color:var(--color-error);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:var(--font-size-sm)}.login-error svg{flex-shrink:0;margin-top:2px}.login-warning{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md);background-color:var(--color-warning-light);color:var(--color-warning-dark);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:var(--font-size-sm)}.login-warning svg{flex-shrink:0;margin-top:2px}.loading-spinner{width:16px;height:16px;border:2px solid var(--color-text-inverse);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-background);min-height:100vh}#app{min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--color-text-primary)}h1{font-size:var(--font-size-2xl)}h2{font-size:var(--font-size-xl)}h3{font-size:var(--font-size-lg)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.loading-spinner{display:inline-block;width:24px;height:24px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner--large{width:48px;height:48px;border-width:4px}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);text-align:center;color:var(--color-text-muted)}.empty-state__icon{font-size:48px;margin-bottom:var(--spacing-md);opacity:.5}.empty-state__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-sm);color:var(--color-text-secondary)}.empty-state__description{font-size:var(--font-size-sm);max-width:300px}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center;color:var(--color-error);background-color:var(--color-error-light);border-radius:var(--radius-md);margin:var(--spacing-md)}.error-state__message{font-size:var(--font-size-sm);margin-bottom:var(--spacing-md)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-background)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}::selection{background-color:var(--color-primary-light);color:var(--color-text-primary)}.users-view__role,.users-view__status{display:inline-block;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-transform:capitalize}.users-view__role--admin{background-color:#dc35451a;color:#dc3545}.users-view__role--user,.users-view__role--viewer{background-color:#6c757d1a;color:#6c757d}.users-view__status--active{background-color:#1987541a;color:#198754}.users-view__status--inactive{background-color:#6c757d1a;color:#6c757d}.view__subtitle{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}@media(max-width:1024px){.tpl-list__button{min-height:44px}}@media(max-width:768px){.tpl-view__layout{flex-direction:column;max-height:none}.tpl-view__sidebar{width:100%;max-height:160px}.tpl-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.tpl-list__item{margin-bottom:0}.toolbar,.toolbar__left,.toolbar__right{flex-wrap:wrap}}
