.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,var(--color-cream) 0%,#e8f0e0 50%,var(--color-cream) 100%)}.login-container{width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:32px}.login-header svg{margin-bottom:16px;filter:drop-shadow(0 4px 12px rgba(45,80,22,.2))}.login-title{font-size:2.5rem;font-weight:300;letter-spacing:.15em;text-transform:uppercase;color:var(--color-oak-dark);margin:0}.login-subtitle{font-size:.875rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--color-trunk-medium);margin-top:4px}.login-card{padding:32px;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl)}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column}.login-authenticating{padding:40px 0;text-align:center}.login-action{display:flex;flex-direction:column}.welcome-text{font-size:1.125rem;text-align:center;margin-bottom:24px;color:var(--color-gray-700)}.welcome-text strong{color:var(--color-oak-dark)}.action-section{margin-bottom:12px}.login-footer{text-align:center;margin-top:24px}@media(max-width:480px){.login-card{padding:24px}.login-title{font-size:2rem}}.theme-switcher{position:relative}.theme-switcher-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:var(--color-white);color:var(--color-gray-700);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.theme-switcher-button:hover:not(:disabled){background:var(--color-gray-100);transform:translateY(-2px);box-shadow:var(--shadow-md)}.theme-switcher-button:disabled{opacity:.5;cursor:not-allowed}.theme-switcher-button svg{width:20px;height:20px}.theme-switcher-backdrop{position:fixed;inset:0;z-index:999}.theme-switcher-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--color-white);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:8px;min-width:180px;z-index:1000;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.theme-option{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;border:none;background:none;color:var(--color-gray-700);font-size:.875rem;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);text-align:left}.theme-option:hover:not(:disabled){background:var(--color-gray-100)}.theme-option:disabled{opacity:.5;cursor:not-allowed}.theme-option.active{color:var(--color-oak-dark);font-weight:500}.theme-option-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px}.theme-option-icon svg{width:18px;height:18px}.theme-option-label{flex:1}.theme-option-check{color:var(--color-oak-dark);font-weight:600}.services-management-table{width:100%;border-collapse:collapse}.services-management-table thead tr{border-bottom:2px solid var(--color-gray-200)}.services-management-table thead th{padding:10px;text-align:left;color:var(--color-gray-900);font-weight:600}.services-management-table tbody tr{border-bottom:1px solid var(--color-gray-200)}.services-management-table tbody td{padding:10px;color:var(--color-gray-900)}.services-management-table tbody td small{color:var(--color-gray-500)}.services-management-table tbody td code{font-size:12px;color:var(--color-gray-700);background:var(--color-gray-100);padding:2px 6px;border-radius:4px}.service-icon-cell{display:inline-flex;padding:8px;border-radius:8px}.form-group{margin-bottom:16px}.form-group .label{display:block;margin-bottom:6px;font-size:.875rem;font-weight:500;color:var(--color-gray-700)}.icon-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:8px;max-height:300px;overflow-y:auto;padding:12px;background:var(--color-gray-100);border-radius:var(--radius-md)}.icon-picker-button{display:flex;align-items:center;justify-content:center;padding:12px;border:2px solid transparent;background:var(--color-white);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);color:var(--color-gray-700)}.icon-picker-button:hover{border-color:var(--color-oak-medium);background:var(--color-gray-100)}.icon-picker-button.selected{border-color:var(--color-oak-dark);background:var(--color-oak-light);color:#fff}.color-picker-palette{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}.color-picker-swatch{width:40px;height:40px;border-radius:var(--radius-sm);border:3px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.color-picker-swatch:hover{transform:scale(1.1)}.color-picker-swatch.selected{border-color:var(--color-gray-900);box-shadow:0 0 0 2px var(--color-white)}.user-permissions-table{width:100%;border-collapse:collapse}.user-permissions-table thead tr{border-bottom:2px solid var(--color-gray-200)}.user-permissions-table thead th{padding:10px;text-align:left;color:var(--color-gray-900);font-weight:600}.user-permissions-table thead th.sticky-column{position:sticky;left:0;background:var(--color-white);z-index:1}.user-permissions-table thead th.service-column{text-align:center;min-width:100px;font-size:12px}.user-permissions-table tbody tr{border-bottom:1px solid var(--color-gray-200)}.user-permissions-table tbody td{padding:10px;color:var(--color-gray-900)}.user-permissions-table tbody td.sticky-column{position:sticky;left:0;background:var(--color-white);z-index:1}.user-permissions-table tbody td small{color:var(--color-gray-500)}.user-permissions-table tbody td .admin-badge{margin-left:5px;color:var(--color-oak-dark);font-size:12px}.user-permissions-table tbody td.checkbox-cell{text-align:center}.user-permissions-table tbody td.checkbox-cell input[type=checkbox]{width:20px;height:20px;cursor:pointer}.permissions-actions{margin-top:20px;display:flex;gap:10px}.logs-viewer{display:flex;flex-direction:column;height:100%;max-height:80vh}.logs-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-gray-200)}.logs-header h2{margin:0;font-size:1.25rem;color:var(--color-gray-900)}.btn-close{background:none;border:none;padding:8px;cursor:pointer;color:var(--color-gray-500);transition:color var(--transition-fast)}.btn-close:hover{color:var(--color-gray-900)}.btn-close svg{width:20px;height:20px}.logs-tabs{display:flex;border-bottom:1px solid var(--color-gray-200);padding:0 20px}.logs-tab{padding:12px 20px;background:none;border:none;color:var(--color-gray-500);cursor:pointer;position:relative;font-weight:500;transition:color var(--transition-fast)}.logs-tab:hover{color:var(--color-gray-700)}.logs-tab.active{color:var(--color-oak-dark)}.logs-tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--color-oak-dark)}.logs-content{flex:1;overflow:auto;padding:16px 20px}.logs-loading{display:flex;justify-content:center;align-items:center;min-height:200px}.logs-filters{background:var(--color-gray-100);border-radius:var(--radius-md);padding:12px 16px;margin-bottom:16px}.filter-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:8px}.filter-row:last-child{margin-bottom:0}.filter-row input,.filter-row select{padding:8px 12px;border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);font-size:.875rem;background:var(--color-white);color:var(--color-gray-900);min-width:140px}.filter-row input:focus,.filter-row select:focus{outline:none;border-color:var(--color-oak-medium)}.filter-row input[type=datetime-local]{min-width:180px}.logs-count{font-size:.875rem;color:var(--color-gray-500);margin-bottom:12px}.logs-table-container{overflow-x:auto;border:1px solid var(--color-gray-200);border-radius:var(--radius-md)}.logs-table{width:100%;border-collapse:collapse;font-size:.875rem}.logs-table th,.logs-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--color-gray-200)}.logs-table th{background:var(--color-gray-100);font-weight:600;color:var(--color-gray-700);white-space:nowrap}.logs-table tbody tr:hover{background:var(--color-gray-100)}.logs-table tbody tr:last-child td{border-bottom:none}.col-time{white-space:nowrap;font-family:monospace;font-size:.8125rem}.col-user{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.col-ip{font-family:monospace;font-size:.8125rem}.col-path{max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.no-data{text-align:center;color:var(--color-gray-500);padding:32px!important}.badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-transform:uppercase}.level-error,.badge.level-error{background:var(--color-error-light);color:var(--color-error)}.level-warn,.badge.level-warn{background:#fff3e0;color:#e65100}.level-info,.badge.level-info{background:#e3f2fd;color:#1565c0}.level-debug,.badge.level-debug{background:var(--color-gray-100);color:var(--color-gray-500)}.action-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;background:var(--color-gray-100);color:var(--color-gray-700)}.action-badge.action-success{background:var(--color-success-light);color:var(--color-success)}.action-badge.action-error{background:var(--color-error-light);color:var(--color-error)}.action-badge.action-warn{background:#fff3e0;color:#e65100}.method-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;font-family:monospace}.method-badge.method-get{background:#e3f2fd;color:#1565c0}.method-badge.method-post{background:var(--color-success-light);color:var(--color-success)}.method-badge.method-put{background:#fff3e0;color:#e65100}.method-badge.method-delete{background:var(--color-error-light);color:var(--color-error)}.status-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;font-family:monospace}.status-badge.status-success{background:var(--color-success-light);color:var(--color-success)}.status-badge.status-warn{background:#fff3e0;color:#e65100}.status-badge.status-error{background:var(--color-error-light);color:var(--color-error)}.btn-icon{background:none;border:none;padding:4px;cursor:pointer;color:var(--color-gray-500);transition:color var(--transition-fast)}.btn-icon:hover{color:var(--color-oak-dark)}.stats-container{padding:8px}.stats-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.stats-header label{display:flex;align-items:center;gap:8px;color:var(--color-gray-700);font-size:.875rem}.stats-header select{padding:8px 12px;border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);background:var(--color-white);color:var(--color-gray-900)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);padding:20px;text-align:center}.stat-card.stat-warn .stat-value{color:#e65100}.stat-value{font-size:2rem;font-weight:700;color:var(--color-oak-dark);line-height:1;margin-bottom:8px}.stat-label{font-size:.875rem;color:var(--color-gray-500)}.stats-section{margin-bottom:24px}.stats-section h3{font-size:1rem;color:var(--color-gray-700);margin-bottom:12px}.stats-table{width:100%;border-collapse:collapse;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);overflow:hidden}.stats-table th,.stats-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--color-gray-200)}.stats-table th{background:var(--color-gray-100);font-weight:600;font-size:.875rem;color:var(--color-gray-700)}.stats-table td{font-size:.875rem}.stats-table tbody tr:last-child td{border-bottom:none}.log-detail-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1100;animation:fadeIn .2s ease}.log-detail-modal{background:var(--color-white);border-radius:var(--radius-lg);max-width:600px;width:90%;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .3s ease}.log-detail-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-gray-200)}.log-detail-header h3{margin:0;font-size:1rem}.log-detail-body{padding:20px;overflow-y:auto}.log-detail-list{display:grid;grid-template-columns:120px 1fr;gap:8px 12px;margin:0}.log-detail-list dt{color:var(--color-gray-500);font-size:.875rem;font-weight:500}.log-detail-list dd{margin:0;font-size:.875rem;color:var(--color-gray-900)}.log-detail-list dd.mono{font-family:monospace;font-size:.8125rem}.log-detail-list dd.wrap{word-break:break-all}.log-detail-list dd.error-text{color:var(--color-error)}.metadata-json{background:var(--color-gray-100);border-radius:var(--radius-sm);padding:12px;font-size:.75rem;font-family:monospace;overflow-x:auto;margin:0;white-space:pre-wrap;word-break:break-all}.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all var(--transition-fast);border:none}.btn-sm{padding:8px 12px;font-size:.875rem}.btn-primary{background:var(--color-oak-dark);color:#fff}.btn-primary:hover{background:var(--color-oak-medium)}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover{background:#b71c1c}.alert{padding:12px 16px;border-radius:var(--radius-md);margin:12px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px}.alert button{background:none;border:none;font-size:1.25rem;cursor:pointer;opacity:.7;color:inherit}.alert button:hover{opacity:1}.alert-error{background:var(--color-error-light);color:var(--color-error)}.alert-success{background:var(--color-success-light);color:var(--color-success)}@media(max-width:768px){.logs-viewer{max-height:100vh}.filter-row{flex-direction:column}.filter-row input,.filter-row select{width:100%;min-width:auto}.logs-table{font-size:.8125rem}.logs-table th,.logs-table td{padding:8px}.stat-card{padding:16px}.stat-value{font-size:1.5rem}.log-detail-list{grid-template-columns:100px 1fr}}[data-theme=dark] .logs-filters,[data-theme=dark] .stat-card,[data-theme=dark] .logs-table th{background:var(--color-gray-100)}[data-theme=dark] .logs-table-container,[data-theme=dark] .stats-table,[data-theme=dark] .stat-card{border-color:var(--color-gray-200)}[data-theme=dark] .filter-row input,[data-theme=dark] .filter-row select,[data-theme=dark] .stats-header select{background:var(--color-gray-100);border-color:var(--color-gray-200);color:var(--color-gray-900)}[data-theme=dark] .log-detail-modal{background:var(--color-white)}[data-theme=dark] .metadata-json{background:var(--color-gray-100)}.site-switcher-management{padding:0}.ssm-header{margin-bottom:1.5rem}.ssm-header h3{margin:0 0 .5rem;font-size:1.25rem}.ssm-loading{display:flex;justify-content:center;padding:3rem}.ssm-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.ssm-tab{padding:.5rem 1rem;background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:.9rem;border-radius:4px;transition:all .2s}.ssm-tab:hover{background:var(--bg-hover);color:var(--text-color)}.ssm-tab.active{background:var(--accent-color);color:#fff}.ssm-sites-list{display:flex;flex-direction:column;gap:.75rem}.ssm-site-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;transition:all .2s}.ssm-site-item.disabled{opacity:.5}.ssm-site-order{display:flex;flex-direction:column;align-items:center;gap:2px}.ssm-order-btn{padding:2px 6px;background:var(--bg-hover);border:1px solid var(--border-color);border-radius:4px;font-size:10px;cursor:pointer;color:var(--text-muted);transition:all .2s}.ssm-order-btn:hover:not(:disabled){background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.ssm-order-btn:disabled{opacity:.3;cursor:not-allowed}.ssm-order-num{font-size:.75rem;color:var(--text-muted);min-width:20px;text-align:center}.ssm-site-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.ssm-site-info{flex:1;min-width:0}.ssm-site-name{display:block;font-weight:500;color:var(--text-color)}.ssm-site-url{display:block;font-size:.8rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ssm-toggle{position:relative;display:inline-block;width:48px;height:26px;flex-shrink:0}.ssm-toggle input{opacity:0;width:0;height:0}.ssm-toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--border-color);transition:.3s;border-radius:26px}.ssm-toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.ssm-toggle input:checked+.ssm-toggle-slider{background-color:var(--success-color, #22c55e)}.ssm-toggle input:checked+.ssm-toggle-slider:before{transform:translate(22px)}.ssm-actions{margin-top:1.5rem;display:flex;justify-content:flex-end;gap:.75rem}.ssm-user-select{margin-bottom:1.5rem}.ssm-user-select label{display:block;margin-bottom:.5rem;font-weight:500}.ssm-user-select select{width:100%;max-width:400px}.ssm-user-access{margin-top:1rem}.ssm-restriction-toggle{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.75rem;background:var(--bg-hover);border-radius:8px;cursor:pointer}.ssm-restriction-toggle input{width:18px;height:18px;accent-color:var(--accent-color)}.ssm-restriction-toggle span{font-weight:500}.ssm-user-sites{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px}.ssm-user-site-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;cursor:pointer;border-radius:4px;transition:background .2s}.ssm-user-site-item:hover{background:var(--bg-hover)}.ssm-user-site-item input{width:18px;height:18px;accent-color:var(--accent-color)}.ssm-site-icon-small{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.ssm-no-restrictions{padding:1rem;background:var(--bg-hover);border-radius:8px;text-align:center}.admin-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;padding:20px;z-index:1000;animation:fadeIn .2s ease}.admin-panel{background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--color-gray-200)}.admin-header h2{margin:0;font-size:1.5rem}.admin-close{background:none;border:none;cursor:pointer;padding:8px;color:var(--color-gray-500);transition:color var(--transition-fast)}.admin-close:hover{color:var(--color-gray-900)}.admin-close svg{width:24px;height:24px}.admin-tabs{display:flex;border-bottom:1px solid var(--color-gray-200);padding:0 24px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.admin-tabs::-webkit-scrollbar{display:none}.admin-tab{background:none;border:none;padding:16px 24px;font-size:.875rem;font-weight:500;color:var(--color-gray-500);cursor:pointer;position:relative;transition:color var(--transition-fast);white-space:nowrap;flex-shrink:0}.admin-tab:hover{color:var(--color-gray-700)}.admin-tab.active{color:var(--color-oak-dark)}.admin-tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--color-oak-dark)}.admin-content{flex:1;overflow-y:auto;padding:24px}.admin-loading{display:flex;justify-content:center;padding:40px}.admin-users h3,.admin-whitelist h3,.admin-email h3{margin:0 0 16px;font-size:1rem}.users-list{display:flex;flex-direction:column;gap:12px}.user-item{display:flex;align-items:center;justify-content:space-between;padding:16px;background:var(--color-gray-100);border-radius:var(--radius-md);gap:16px}.user-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.user-name{font-weight:600;display:flex;align-items:center;gap:8px}.admin-badge{font-size:.625rem;font-weight:600;text-transform:uppercase;padding:2px 6px;background:var(--color-oak-dark);color:#fff;border-radius:4px}.user-email{font-size:.875rem;color:var(--color-gray-600)}.user-meta{font-size:.75rem;color:var(--color-gray-500)}.user-actions{display:flex;gap:8px;flex-shrink:0}.whitelist-form{background:var(--color-gray-100);padding:16px;border-radius:var(--radius-md);margin-bottom:20px}.form-row{display:flex;gap:12px;margin-bottom:12px}.form-row:last-child{margin-bottom:0}.form-row .input{flex:1}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:.875rem;cursor:pointer;flex:1}.checkbox-label input{width:18px;height:18px;cursor:pointer}.whitelist-list{display:flex;flex-direction:column;gap:8px}.whitelist-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--color-gray-100);border-radius:var(--radius-md);gap:16px}.whitelist-info{display:flex;flex-direction:column;gap:2px;flex:1}.whitelist-name{font-weight:500}.whitelist-email{font-size:.875rem;color:var(--color-gray-600)}.whitelist-status{font-size:.75rem;font-weight:500}.whitelist-status.registered{color:var(--color-success)}.whitelist-status.pending{color:var(--color-gray-500)}.email-test-form{display:flex;gap:12px}.email-test-form .input{flex:1}.user-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:20px;z-index:1100}.user-modal{background:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:80vh;overflow:auto}.user-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-gray-200)}.user-modal-header h3{margin:0}.user-modal-header button{background:none;border:none;font-size:24px;cursor:pointer;color:var(--color-gray-500);line-height:1}.user-modal-body{padding:20px}.user-modal-body h4{margin:20px 0 12px;font-size:.875rem;color:var(--color-gray-700)}.credentials-list{display:flex;flex-direction:column;gap:8px}.credential-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--color-gray-100);border-radius:var(--radius-sm)}.credential-name{font-weight:500;display:block}.credential-date{font-size:.75rem;color:var(--color-gray-500)}@media(max-width:640px){.admin-panel{max-height:100vh;border-radius:0}.admin-tabs{padding:0 12px}.admin-tab{padding:16px 12px;font-size:.8125rem}.admin-content{padding:16px}.user-item{flex-direction:column;align-items:flex-start}.user-actions{width:100%}.user-actions .btn{flex:1}.form-row,.email-test-form{flex-direction:column}}.tokens-modal{display:flex;flex-direction:column}.tokens-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:15px}.tokens-filter{display:flex;align-items:center;gap:10px}.tokens-filter label{font-size:14px;color:var(--color-gray-500)}.tokens-filter .select{padding:8px 12px;border:1px solid var(--color-gray-300);border-radius:6px;background:var(--color-white);color:var(--color-gray-900);font-size:14px;min-width:180px}.tokens-empty{text-align:center;padding:60px 20px;color:var(--color-gray-500)}.tokens-empty span{font-size:48px;display:block;margin-bottom:15px}.tokens-empty p{margin:5px 0}.tokens-list{overflow-x:auto}.tokens-table{width:100%;border-collapse:collapse;font-size:14px}.tokens-table th{text-align:left;padding:12px 10px;border-bottom:2px solid var(--color-gray-300);font-weight:600;color:var(--color-gray-500);white-space:nowrap}.tokens-table td{padding:12px 10px;border-bottom:1px solid var(--color-gray-200);vertical-align:middle}.tokens-table tr:hover{background:var(--color-gray-100)}.tokens-table tr.token-inactive{opacity:.6}.token-subdomain{display:inline-block;padding:2px 8px;background:#3d7a1e26;color:var(--color-oak-dark);border-radius:4px;font-size:12px;font-weight:500}.token-scopes{display:flex;flex-wrap:wrap;gap:4px}.scope-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.scope-read{background:#e3f2fd;color:#1565c0}.scope-write{background:#fff3e0;color:#e65100}.scope-delete{background:#ffebee;color:#c62828}.scope-admin{background:#f3e5f5;color:#7b1fa2}.status-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}.status-active{background:#e8f5e9;color:#2e7d32}.status-inactive{background:var(--color-gray-100);color:var(--color-gray-500)}.token-form{max-width:500px}.token-form h3,.token-form .form-group{margin-bottom:20px}.token-form .form-group .label{display:block;margin-bottom:6px;font-weight:500;color:var(--color-gray-700)}.token-form .form-group .input,.token-form .form-group select.input,.tokens-filter .select{width:100%;padding:10px 12px;border:2px solid var(--color-gray-300);border-radius:6px;font-size:14px;background-color:var(--color-white);color:var(--color-gray-900);-webkit-appearance:none;-moz-appearance:none;appearance:none}.token-form .form-group select.input,.tokens-filter .select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23555' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer}.token-form .form-group .input:focus,.token-form .form-group select.input:focus,.tokens-filter .select:focus{outline:none;border-color:var(--color-oak-medium);box-shadow:0 0 0 3px #3d7a1e26}.token-form .form-group .input::placeholder{color:var(--color-gray-500)}.token-form .form-group select.input option,.tokens-filter .select option{background-color:var(--color-white);color:var(--color-gray-900);padding:10px}.scopes-checkboxes{display:flex;flex-direction:column;gap:10px}.scope-checkbox{display:flex;align-items:center;gap:10px;cursor:pointer;padding:8px 12px;border:2px solid var(--color-gray-300);border-radius:6px;transition:background .15s;background:var(--color-white)}.scope-checkbox:hover{background:var(--color-gray-100)}.scope-checkbox input{width:18px;height:18px;cursor:pointer;accent-color:var(--color-oak-medium)}.scope-description{color:var(--color-gray-500);font-size:13px}.form-actions{display:flex;gap:10px;margin-top:30px}.token-created-modal{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.token-created-content{background:var(--color-white);border-radius:12px;padding:30px;max-width:500px;width:100%;text-align:center}.token-created-icon{font-size:48px;margin-bottom:15px}.token-created-content h3{margin:0 0 10px;color:var(--color-success)}.token-warning{background:#fff3cd;color:#856404;padding:12px;border-radius:6px;margin-bottom:20px;font-size:14px}.token-display{display:flex;align-items:center;gap:10px;background:var(--color-gray-100);padding:12px;border-radius:6px;margin-bottom:20px;border:1px solid var(--color-gray-300)}.token-display code{flex:1;font-family:Monaco,Menlo,monospace;font-size:12px;word-break:break-all;text-align:left;color:var(--color-gray-900)}.btn-copy{padding:8px 16px;font-size:13px;white-space:nowrap}.btn-copy.copied{background:var(--color-success);color:#fff}.token-details{text-align:left;margin-bottom:20px;padding:15px;background:var(--color-gray-100);border-radius:6px}.token-details p{margin:5px 0;font-size:14px}.btn-warning{background:#ff9800;color:#fff;border:none}.btn-warning:hover{background:#f57c00}.btn-success{background:#4caf50;color:#fff;border:none}.btn-success:hover{background:#43a047}.text-danger{color:#dc3545}[data-theme=dark] .scope-read{background:#1e3a5f;color:#64b5f6}[data-theme=dark] .scope-write{background:#4a2c00;color:#ffb74d}[data-theme=dark] .scope-delete{background:#4a1c1c;color:#ef9a9a}[data-theme=dark] .scope-admin{background:#3a1c4a;color:#ce93d8}[data-theme=dark] .status-active{background:#1b4332;color:#81c784}[data-theme=dark] .status-inactive{background:var(--color-gray-200);color:var(--color-gray-500)}[data-theme=dark] .token-warning{background:#4a3800;color:#ffc107}[data-theme=dark] .token-form .form-group .input,[data-theme=dark] .token-form .form-group select.input,[data-theme=dark] .tokens-filter .select{background-color:var(--color-gray-100);border-color:var(--color-gray-300);color:var(--color-gray-900)}[data-theme=dark] .token-form .form-group select.input,[data-theme=dark] .tokens-filter .select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23aaa' d='M6 8L1 3h10z'/%3E%3C/svg%3E")}[data-theme=dark] .token-form .form-group select.input option,[data-theme=dark] .tokens-filter .select option{background-color:var(--color-gray-100);color:var(--color-gray-900)}[data-theme=dark] .scope-checkbox{background:var(--color-gray-100);border-color:var(--color-gray-300)}[data-theme=dark] .scope-checkbox:hover{background:var(--color-gray-200)}@media(max-width:768px){.tokens-header,.tokens-filter{flex-direction:column;align-items:stretch}.tokens-filter .select{width:100%}.tokens-table{font-size:12px}.tokens-table th,.tokens-table td{padding:8px 6px}.form-actions{flex-direction:column}.form-actions .btn{width:100%}}.dashboard{min-height:100vh;display:flex;flex-direction:column}.dashboard-header{background:var(--color-white);border-bottom:1px solid var(--color-gray-200);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.header-content{max-width:1200px;margin:0 auto;padding:12px 24px;display:flex;align-items:center;justify-content:space-between}.header-brand{display:flex;align-items:center;gap:12px}.header-titles h1{font-size:1.5rem;font-weight:300;letter-spacing:.1em;text-transform:uppercase;color:var(--color-oak-dark);margin:0}.header-user{display:flex;align-items:center;gap:16px}.user-name{font-weight:500;color:var(--color-gray-700)}.dashboard-main{flex:1;max-width:1200px;margin:0 auto;padding:40px 24px;width:100%}.dashboard-welcome{margin-bottom:40px}.dashboard-welcome h2{font-size:1.75rem;font-weight:600;color:var(--color-gray-900);margin-bottom:8px}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}.service-card{display:flex;flex-direction:column;padding:24px;text-decoration:none;color:inherit;transition:all var(--transition-normal);border:1px solid transparent}.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-gray-200)}.service-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:16px}.service-icon svg{width:24px;height:24px}.service-card h3{font-size:1.125rem;font-weight:600;margin-bottom:8px}.service-card p{font-size:.875rem;color:var(--color-gray-500);margin:0}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:20px;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:90vh;overflow:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--color-gray-200)}.modal-header h2{font-size:1.25rem;margin:0}.modal-close{background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;color:var(--color-gray-500);transition:color var(--transition-fast)}.modal-close:hover{color:var(--color-gray-900)}.modal-close svg{width:20px;height:20px}.modal-body{padding:24px}.passkeys-section h3,.add-passkey-section h3{font-size:1rem;font-weight:600;margin-bottom:12px}.passkeys-list{display:flex;flex-direction:column;gap:12px}.passkey-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--color-gray-100);border-radius:var(--radius-md)}.passkey-info{display:flex;flex-direction:column}.passkey-name{font-weight:500}.passkey-date{font-size:.75rem;color:var(--color-gray-500)}.add-passkey-form{display:flex;gap:12px}.add-passkey-form .input{flex:1}@media(max-width:768px){.header-content{padding:12px 16px}.user-name{display:none}.dashboard-main{padding:24px 16px}.services-grid{grid-template-columns:1fr}.add-passkey-form{flex-direction:column}}:root{--color-oak-dark: #2d5016;--color-oak-medium: #3d7a1e;--color-oak-light: #5a9c2e;--color-trunk-dark: #5d4037;--color-trunk-medium: #795548;--color-trunk-light: #8d6e63;--color-cream: #faf8f5;--color-white: #ffffff;--color-gray-100: #f5f5f5;--color-gray-200: #e8e8e8;--color-gray-300: #d0d0d0;--color-gray-500: #888888;--color-gray-700: #555555;--color-gray-900: #222222;--color-error: #c62828;--color-error-light: #ffebee;--color-success: #2e7d32;--color-success-light: #e8f5e9;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 40px rgba(0, 0, 0, .15);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 16px;--radius-xl: 24px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:linear-gradient(135deg,var(--color-cream) 0%,var(--color-gray-100) 100%);color:var(--color-gray-900);min-height:100vh;line-height:1.6}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--color-gray-900)}h1{font-size:2.5rem;letter-spacing:-.02em}h2{font-size:1.75rem;letter-spacing:-.01em}h3{font-size:1.25rem}p{color:var(--color-gray-700)}a{color:var(--color-oak-medium);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-oak-dark)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;font-size:1rem;font-weight:500;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--color-oak-medium) 0%,var(--color-oak-dark) 100%);color:var(--color-white);box-shadow:var(--shadow-md)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--color-white);color:var(--color-gray-700);border:1px solid var(--color-gray-200)}.btn-secondary:hover:not(:disabled){background:var(--color-gray-100);border-color:var(--color-gray-300)}.btn-danger{background:var(--color-error);color:var(--color-white)}.btn-danger:hover:not(:disabled){background:#b71c1c}.btn-sm{padding:8px 16px;font-size:.875rem}.btn-lg{padding:16px 32px;font-size:1.125rem}.input{width:100%;padding:12px 16px;font-size:1rem;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);background:var(--color-white);transition:all var(--transition-fast)}.input:focus{outline:none;border-color:var(--color-oak-medium);box-shadow:0 0 0 3px #3d7a1e1a}.input::placeholder{color:var(--color-gray-500)}.label{display:block;margin-bottom:6px;font-size:.875rem;font-weight:500;color:var(--color-gray-700)}.card{background:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:24px}.alert{padding:12px 16px;border-radius:var(--radius-md);font-size:.875rem;display:flex;align-items:center;gap:8px}.alert-error{background:var(--color-error-light);color:var(--color-error);border:1px solid rgba(198,40,40,.2)}.alert-success{background:var(--color-success-light);color:var(--color-success);border:1px solid rgba(46,125,50,.2)}.spinner{width:24px;height:24px;border:3px solid var(--color-gray-200);border-top-color:var(--color-oak-medium);border-radius:50%;animation:spin .8s linear infinite}.spinner-lg{width:40px;height:40px;border-width:4px}@keyframes spin{to{transform:rotate(360deg)}}.text-center{text-align:center}.text-sm{font-size:.875rem}.text-muted{color:var(--color-gray-500)}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mt-8{margin-top:32px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.w-full{width:100%}[data-theme=dark]{--color-cream: #1a1a1a;--color-white: #242424;--color-gray-100: #2a2a2a;--color-gray-200: #333333;--color-gray-300: #444444;--color-gray-500: #aaaaaa;--color-gray-700: #cccccc;--color-gray-900: #f0f0f0;--color-oak-dark: #5a9c2e;--color-oak-medium: #6bb23a;--color-oak-light: #7cc746;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 40px rgba(0, 0, 0, .6)}[data-theme=dark] body{background:linear-gradient(135deg,#1a1a1a,#242424);color:var(--color-gray-900)}.page-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;min-height:100vh}@media(max-width:640px){h1{font-size:2rem}h2{font-size:1.5rem}.card{padding:20px}.btn{padding:10px 20px}}
