:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#111827de;background-color:#f9fafb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}.user-management{width:100%;animation:fadeIn .3s ease-in}.page-icon{width:48px;height:48px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px #6366f14d}.search-input:hover{border-color:#6366f1}.search-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.filter-select:hover{border-color:#6366f1}.filter-select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--spacing-xl)}.user-card{background:var(--card-background);border-radius:var(--radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-sm);border:1.5px solid var(--border-color);transition:all var(--transition-base);position:relative;overflow:hidden}.user-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#6366f1,#4f46e5);transform:scaleX(0);transition:transform var(--transition-base)}.user-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:#6366f1}.user-card:hover:before{transform:scaleX(1)}.user-card-header{display:flex;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.user-avatar-large{width:64px;height:64px;border-radius:var(--radius-full);background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.5rem;flex-shrink:0;box-shadow:0 4px 12px #6366f14d;transition:all var(--transition-fast)}.user-card:hover .user-avatar-large{transform:scale(1.05)}.user-info h3{font-size:1.25rem;font-weight:700;margin-bottom:var(--spacing-xs);color:var(--text-primary)}.user-email{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:var(--text-secondary);font-weight:500}.user-card-body{display:flex;flex-direction:column;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.user-role,.user-sites{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast)}.user-role:hover,.user-sites:hover{background:var(--background)}.user-role svg,.user-sites svg{color:#6366f1;flex-shrink:0;margin-top:.125rem}.role-badge{padding:.375rem .75rem;border-radius:var(--radius-md);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;box-shadow:var(--shadow-xs)}.role-owner{background:var(--success-light);color:var(--success-color);border:1px solid var(--success-color)}.role-admin{background:#ddd6fe;color:#7c3aed;border:1px solid #7c3aed}.role-staff{background:var(--info-light);color:var(--info-color);border:1px solid var(--info-color)}.sites-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);flex:1}.site-tag{padding:.375rem .75rem;background:var(--background);border:1.5px solid var(--border-color);border-radius:var(--radius-md);font-size:.75rem;font-weight:600;color:var(--text-primary);transition:all var(--transition-fast)}.site-tag:hover{border-color:#6366f1;background:var(--card-background)}.text-muted{color:var(--text-secondary);font-size:.875rem;font-weight:500}.user-card-footer{display:flex;gap:var(--spacing-md);padding-top:var(--spacing-lg);border-top:2px solid var(--border-color)}.user-card-footer button{flex:1;transition:all var(--transition-fast)}.modal-header h2:before{content:"";width:4px;height:24px;background:linear-gradient(135deg,#6366f1,#4f46e5);border-radius:var(--radius-full)}.form-group label svg{color:#6366f1;flex-shrink:0}.form-group input[type=email],.form-group input[type=text]{width:100%;padding:var(--spacing-md) var(--spacing-lg);border:1.5px solid var(--border-color);border-radius:var(--radius-md);font-size:.9375rem;transition:all var(--transition-fast);background:var(--card-background);color:var(--text-primary);font-weight:500}.form-group input[type=email]:hover,.form-group input[type=text]:hover{border-color:#6366f1}.form-group input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 4px #6366f11a;background:var(--card-background)}.form-group input:disabled{background:var(--background-secondary);color:var(--text-secondary);cursor:not-allowed;opacity:.7}.form-group input::placeholder{color:var(--text-tertiary)}.form-section-title svg{color:#6366f1}.role-selector{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.role-option{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);border:2px solid var(--border-color);border-radius:var(--radius-lg);background:var(--card-background);cursor:pointer;transition:all var(--transition-fast);text-align:left;position:relative;overflow:hidden}.role-option:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#6366f1,#4f46e5);transform:scaleX(0);transition:transform var(--transition-base)}.role-option:hover{border-color:#6366f1;background:#6366f10d;transform:translateY(-2px);box-shadow:var(--shadow-md)}.role-option.active{border-color:#6366f1;background:#6366f11a;box-shadow:0 0 0 3px #6366f11a}.role-option.active:before{transform:scaleX(1)}.role-option svg{color:#6366f1;flex-shrink:0;width:24px;height:24px}.role-option strong{display:block;font-size:.9375rem;margin-bottom:.25rem;color:var(--text-primary);font-weight:600}.role-option span{display:block;font-size:.8125rem;color:var(--text-secondary);line-height:1.4}.sites-selector{display:flex;flex-direction:column;gap:var(--spacing-sm);max-height:320px;overflow-y:auto;padding:var(--spacing-md);border:1.5px solid var(--border-color);border-radius:var(--radius-lg);background:var(--background);overscroll-behavior:contain}.sites-selector::-webkit-scrollbar{width:6px}.sites-selector::-webkit-scrollbar-track{background:transparent}.sites-selector::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}.site-checkbox{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:var(--card-background);border:1.5px solid transparent}.site-checkbox:hover{background:var(--card-background);border-color:#6366f1;transform:translate(4px)}.site-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#6366f1;flex-shrink:0}.site-info strong{display:block;font-size:.9375rem;margin-bottom:.25rem;color:var(--text-primary);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.site-info span{display:block;font-size:.8125rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:768px){.users-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.role-selector{grid-template-columns:1fr}.modal{max-height:100vh;border-radius:0}}.site-management{width:100%;animation:fadeIn .3s ease-in}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--border-color)}.header-left{display:flex;align-items:center;gap:var(--spacing-lg)}.page-icon{width:48px;height:48px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px #db27774d}.page-header h1{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.page-header p{color:var(--text-secondary);font-size:.9375rem}.alert{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-xl);border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl);font-size:.9375rem;font-weight:500;animation:slideDown .3s ease-out;box-shadow:var(--shadow-sm)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert-error{background:var(--danger-light);color:#991b1b;border:2px solid #fecaca}.alert-success{background:var(--success-light);color:#166534;border:2px solid #bbf7d0}.filter-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-xl);padding:var(--spacing-lg) var(--spacing-xl);background:var(--card-background);border-radius:var(--radius-lg);border:1.5px solid var(--border-color);box-shadow:var(--shadow-sm)}.filter-group{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.search-box{position:relative;display:flex;align-items:center;flex:1;max-width:400px}.search-box svg:first-child{position:absolute;left:var(--spacing-md);color:var(--text-secondary);pointer-events:none}.search-input{width:100%;padding:var(--spacing-sm) var(--spacing-lg);padding-left:2.75rem;padding-right:2.5rem;border:1.5px solid var(--border-color);border-radius:var(--radius-md);font-size:.875rem;background:var(--card-background);color:var(--text-primary);transition:all var(--transition-fast);font-weight:500}.search-input:hover{border-color:var(--primary-color)}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #db27771a}.search-input::placeholder{color:var(--text-tertiary)}.search-clear{position:absolute;right:var(--spacing-sm);background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.search-clear:hover{background:var(--background);color:var(--text-primary)}.filter-select{padding:var(--spacing-sm) var(--spacing-lg);border:1.5px solid var(--border-color);border-radius:var(--radius-md);font-size:.875rem;background:var(--background);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);font-weight:500;min-width:150px}.filter-select:hover{border-color:var(--primary-color)}.filter-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #db27771a}.filter-info{font-size:.875rem;color:var(--text-secondary);font-weight:500;padding:var(--spacing-sm) var(--spacing-md);background:var(--background);border-radius:var(--radius-md)}.sites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:var(--spacing-xl)}.site-card{background:var(--card-background);border-radius:var(--radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-sm);border:1.5px solid var(--border-color);transition:all var(--transition-base);position:relative;overflow:hidden}.site-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-color),var(--primary-hover));transform:scaleX(0);transition:transform var(--transition-base)}.site-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--primary-color)}.site-card:hover:before{transform:scaleX(1)}.site-card.status-inactive{opacity:.75;background:var(--background)}.site-card.status-archived{opacity:.6;background:var(--background-secondary)}.site-card-header{display:flex;align-items:flex-start;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.site-icon{width:56px;height:56px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px #db27774d;transition:all var(--transition-fast)}.site-card:hover .site-icon{transform:scale(1.05)}.site-info{flex:1;min-width:0}.site-info h3{font-size:1.25rem;font-weight:700;margin-bottom:var(--spacing-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary)}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:var(--radius-md);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;box-shadow:var(--shadow-xs)}.status-badge svg{flex-shrink:0;vertical-align:middle}.status-badge.status-active{background:var(--success-light);color:var(--success-color);border:1px solid var(--success-color)}.status-badge.status-inactive{background:var(--warning-light);color:var(--warning-color);border:1px solid var(--warning-color)}.status-badge.status-archived{background:var(--background-secondary);color:var(--text-secondary);border:1px solid var(--border-color)}.site-card-body{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.site-detail{display:flex;align-items:flex-start;gap:var(--spacing-md);color:var(--text-secondary);font-size:.9375rem;padding:var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast)}.site-detail:hover{background:var(--background)}.site-detail svg{flex-shrink:0;margin-top:.125rem;color:var(--primary-color)}.site-detail span{flex:1;word-break:break-word;color:var(--text-primary);font-weight:500}.phone-numbers{display:flex;flex-direction:column;gap:.25rem;flex:1}.phone-label{font-size:.75rem;font-weight:600;color:var(--text-primary)}.site-card-footer{display:flex;gap:var(--spacing-md);padding-top:var(--spacing-lg);border-top:2px solid var(--border-color)}.site-card-footer button{flex:1;transition:all var(--transition-fast)}.empty-state{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl) var(--spacing-xl);text-align:center;color:var(--text-secondary);background:var(--card-background);border-radius:var(--radius-xl);border:2px dashed var(--border-color)}.empty-state svg{color:var(--border-color);margin-bottom:var(--spacing-lg);opacity:.5}.empty-state h3{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-sm);color:var(--text-primary)}.empty-state p{margin-bottom:var(--spacing-xl);font-size:.9375rem}.modal-overlay{position:fixed;inset:0;background:#0f172abf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg);animation:modalOverlayFadeIn .2s ease-out}@keyframes modalOverlayFadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--card-background);border-radius:var(--radius-xl);max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040;animation:modalSlideIn .3s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}.modal form{display:flex;flex-direction:column;height:100%;flex:1;min-height:0}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-large{max-width:800px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-xl) var(--spacing-xl) var(--spacing-lg);border-bottom:2px solid var(--border-color);background:linear-gradient(to bottom,var(--background),var(--card-background));flex-shrink:0;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.modal-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:var(--spacing-md)}.modal-header h2:before{content:"";width:4px;height:24px;background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));border-radius:var(--radius-full)}.modal-body{padding:var(--spacing-xl);overflow-y:auto;overflow-x:hidden;flex:1 1 auto;min-height:0;overscroll-behavior:contain}.modal-body::-webkit-scrollbar{width:6px}.modal-body::-webkit-scrollbar-track{background:var(--background);border-radius:var(--radius-full)}.modal-body::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}.modal-body::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.form-group{margin-bottom:var(--spacing-xl)}.form-group:last-child{margin-bottom:0}.form-group label{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:600;margin-bottom:var(--spacing-sm);color:var(--text-primary);font-size:.9375rem}.form-group label svg{color:var(--primary-color);flex-shrink:0}.form-group input[type=email],.form-group input[type=text],.form-group input[type=tel],.form-group select,.form-group textarea{width:100%;padding:var(--spacing-md) var(--spacing-lg);border:1.5px solid var(--border-color);border-radius:var(--radius-md);font-size:.9375rem;transition:all var(--transition-fast);font-family:inherit;background:var(--card-background);color:var(--text-primary);font-weight:500}.form-group input[type=email]:hover,.form-group input[type=text]:hover,.form-group input[type=tel]:hover,.form-group select:hover,.form-group textarea:hover{border-color:var(--primary-color)}.form-group textarea{resize:vertical;min-height:100px;line-height:1.6}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 4px #db27771a;background:var(--card-background)}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:var(--background-secondary);color:var(--text-secondary);cursor:not-allowed;opacity:.7}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-tertiary)}.form-group small{display:block;margin-top:var(--spacing-sm);font-size:.8125rem;color:var(--text-secondary);line-height:1.5;padding-left:var(--spacing-xs)}.form-group small:before{content:"💡 ";margin-right:var(--spacing-xs)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}.form-section{margin-bottom:var(--spacing-2xl);padding-bottom:var(--spacing-xl);border-bottom:1px solid var(--border-color)}.form-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.form-section-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-sm)}.form-section-title svg{color:var(--primary-color)}.modal-footer{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-xl) var(--spacing-xl);border-top:2px solid var(--border-color);background:var(--background);flex-shrink:0;border-radius:0 0 var(--radius-xl) var(--radius-xl)}.modal-footer button{flex:1;padding:var(--spacing-md) var(--spacing-xl);font-size:.9375rem;font-weight:600}@media(max-width:768px){.sites-grid{grid-template-columns:1fr}.page-header,.filter-bar{flex-direction:column;align-items:flex-start;gap:1rem}.form-row{grid-template-columns:1fr}.modal{max-height:100vh;border-radius:0}}.dashboard{width:100%;animation:fadeIn .3s ease-in}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-xl)}.dashboard-header h1{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.dashboard-header p{color:var(--text-secondary);font-size:.9375rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.stat-card{background:var(--card-background);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);display:flex;gap:var(--spacing-lg);transition:all var(--transition-fast);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-color),var(--primary-hover));opacity:0;transition:opacity var(--transition-fast)}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.stat-card:hover:before{opacity:1}.stat-card.stat-primary .stat-icon{background:linear-gradient(135deg,var(--primary-color),var(--primary-hover))}.stat-card.stat-secondary .stat-icon{background:linear-gradient(135deg,#6366f1,#4f46e5)}.stat-card.stat-success .stat-icon{background:linear-gradient(135deg,var(--success-color),#047857)}.stat-card.stat-info .stat-icon{background:linear-gradient(135deg,var(--info-color),#0369a1)}.stat-card.stat-warning .stat-icon{background:linear-gradient(135deg,var(--warning-color),#d97706)}.stat-card.stat-danger .stat-icon{background:linear-gradient(135deg,var(--danger-color),#dc2626)}.stat-icon{width:64px;height:64px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:var(--shadow-md)}.stat-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.stat-label{font-size:.875rem;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:2rem;font-weight:700;color:var(--text-primary);line-height:1}.stat-detail{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;margin-top:var(--spacing-xs)}.stat-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.stat-badge.success{background:var(--success-light);color:var(--success-color)}.stat-badge.warning{background:var(--warning-light);color:var(--warning-color)}.stat-badge.info{background:var(--info-light);color:var(--info-color)}.stat-badge.danger{background:#fee2e2;color:var(--danger-color)}.diagnostics-section{margin-bottom:var(--spacing-xl)}.diagnostics-section:last-child{margin-bottom:0}.diagnostics-section h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--border-color)}.diagnostic-item{background:#fef3c7;border:1px solid #fbbf24;border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-md)}.diagnostic-item:last-child{margin-bottom:0}.diagnostic-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm);font-size:.9375rem}.diagnostic-header strong{color:var(--text-primary)}.diagnostic-badge{margin-left:auto;padding:.25rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.diagnostic-badge.unhealthy{background:#fee2e2;color:#dc2626}.diagnostic-badge.warning{background:#fef3c7;color:#d97706}.diagnostic-message{color:var(--text-secondary);font-size:.875rem;line-height:1.6;padding-left:26px}.diagnostic-message ul{margin-top:var(--spacing-xs);margin-bottom:0;padding-left:var(--spacing-lg)}.diagnostic-message li{margin-bottom:.25rem;color:var(--text-primary)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.dashboard-card{background:var(--card-background);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);overflow:hidden;transition:all var(--transition-fast)}.dashboard-card:hover{box-shadow:var(--shadow-md)}.dashboard-card.full-width{grid-column:1 / -1}.card-header{padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;background:var(--background)}.card-header h2{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.card-link{font-size:.875rem;color:var(--primary-color);text-decoration:none;font-weight:600;transition:color var(--transition-fast)}.card-link:hover{color:var(--primary-hover)}.card-body{padding:var(--spacing-xl)}.quick-actions{display:flex;flex-direction:column;gap:var(--spacing-md)}.quick-action-item{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-lg);border-radius:var(--radius-md);background:var(--background);border:1.5px solid var(--border-color);text-decoration:none;transition:all var(--transition-fast)}.quick-action-item:hover{border-color:var(--primary-color);background:var(--card-background);transform:translate(4px);box-shadow:var(--shadow-sm)}.quick-action-icon{width:56px;height:56px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.quick-action-icon.primary{background:linear-gradient(135deg,var(--primary-color),var(--primary-hover))}.quick-action-icon.secondary{background:linear-gradient(135deg,#6366f1,#4f46e5)}.quick-action-content h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.quick-action-content p{font-size:.875rem;color:var(--text-secondary)}.recent-sites-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.recent-site-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md);background:var(--background);transition:all var(--transition-fast)}.recent-site-item:hover{background:var(--border-color-light);transform:translate(4px)}.site-icon-small{width:40px;height:40px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.site-info-small{flex:1;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.site-info-small h4{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.status-badge-small{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-transform:capitalize}.status-badge-small svg{flex-shrink:0}.status-badge-small.status-active{background:var(--success-light);color:var(--success-color)}.status-badge-small.status-inactive{background:var(--warning-light);color:var(--warning-color)}.status-badge-small.status-archived{background:var(--background-secondary);color:var(--text-secondary)}.empty-state-small{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center;color:var(--text-secondary)}.empty-state-small svg{color:var(--border-color);margin-bottom:var(--spacing-md)}.empty-state-small p{font-size:.875rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-xl)}.info-item{display:flex;flex-direction:column;gap:var(--spacing-sm)}.info-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.info-value{font-size:1rem;color:var(--text-primary);font-weight:600;display:flex;align-items:center;gap:var(--spacing-sm)}.status-indicator{width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0}.status-indicator.success{background:var(--success-color);box-shadow:0 0 8px #05966966}.status-indicator.warning{background:var(--warning-color);box-shadow:0 0 8px #f59e0b66}.status-indicator.error{background:var(--danger-color);box-shadow:0 0 8px #dc262666}@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.dashboard-grid{grid-template-columns:1fr}}@media(max-width:768px){.dashboard-header h1{font-size:1.5rem}.stats-grid{grid-template-columns:1fr}.stat-card{padding:var(--spacing-lg)}.stat-icon{width:56px;height:56px}.stat-value{font-size:1.75rem}.info-grid{grid-template-columns:1fr;gap:var(--spacing-lg)}}.analytics-container{padding:2rem;max-width:1600px;margin:0 auto}.analytics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.header-title{display:flex;align-items:center;gap:1rem}.header-title h1{margin:0;font-size:2rem;color:#1a1a1a}.header-actions{display:flex;gap:1rem}.btn-export{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#10b981;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s}.btn-export:hover{background:#059669;transform:translateY(-1px)}.btn-sync{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#4f46e5;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s}.btn-sync:hover:not(:disabled){background:#4338ca;transform:translateY(-1px)}.btn-sync:disabled{opacity:.6;cursor:not-allowed}.spinning{animation:spin 1s linear infinite}.analytics-filters{display:flex;gap:1rem;align-items:flex-end;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.analytics-filter-group{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:150px}.analytics-filter-group label{font-size:.875rem;font-weight:500;color:#4b5563;display:flex;align-items:center;gap:.5rem}.analytics-filter-group input[type=checkbox]{width:auto;margin:0}.analytics-filter-group select,.analytics-filter-group input[type=date]{padding:.625rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;transition:border-color .2s}.analytics-filter-group select:focus,.analytics-filter-group input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.btn-refresh{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#10b981;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.btn-refresh:hover{background:#059669}.analytics-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.summary-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;transition:transform .2s,box-shadow .2s}.summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.card-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:10px;flex-shrink:0}.card-icon.phone{background:#dbeafe;color:#2563eb}.card-icon.success{background:#d1fae5;color:#10b981}.card-icon.warning{background:#fef3c7;color:#f59e0b}.card-icon.info{background:#e0e7ff;color:#6366f1}.card-content{flex:1}.card-content h3{margin:0 0 .5rem;font-size:.875rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.metric-value{margin:0;font-size:2rem;font-weight:700;color:#1a1a1a;line-height:1}.metric-subtitle{margin:.25rem 0 0;font-size:.875rem;color:#6b7280}.site-breakdown{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:1.5rem;margin-bottom:2rem}.site-breakdown h2{margin:0 0 1.5rem;font-size:1.5rem;color:#1a1a1a}.breakdown-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.breakdown-card{padding:1.25rem;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.breakdown-card h3{margin:0 0 1rem;font-size:1.125rem;color:#1a1a1a;font-weight:600}.breakdown-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.stat{display:flex;justify-content:space-between;align-items:center}.stat-label{font-size:.875rem;color:#6b7280}.stat-value{font-size:1.125rem;font-weight:600;color:#1a1a1a}.analytics-table{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.analytics-table h2{margin:0 0 1.5rem;font-size:1.5rem;color:#1a1a1a}.no-data{text-align:center;padding:3rem;color:#6b7280;font-size:1rem}.table-wrapper{overflow-x:auto}.analytics-table table{width:100%;border-collapse:collapse}.analytics-table th{text-align:left;padding:.75rem;font-size:.875rem;font-weight:600;color:#4b5563;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #e5e7eb}.analytics-table td{padding:1rem .75rem;font-size:.875rem;color:#1a1a1a;border-bottom:1px solid #f3f4f6}.analytics-table tbody tr:hover{background:#f9fafb}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:capitalize}.status-badge svg{flex-shrink:0}.status-initiated{background:#dbeafe;color:#1e40af}.status-in_progress{background:#fef3c7;color:#92400e}.status-completed{background:#d1fae5;color:#065f46}.status-failed,.status-no_answer,.status-busy{background:#fee2e2;color:#991b1b}.status-transferred{background:#e0e7ff;color:#3730a3}.transferred-yes{color:#f59e0b;font-weight:600}.transferred-no{color:#6b7280}.btn-transcript{padding:8px 16px;background:#4f46e5;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.btn-transcript:hover:not(:disabled){background:#4338ca}.btn-transcript:disabled{opacity:.5;cursor:not-allowed}.btn-booking{padding:8px 16px;background:#10b981;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.btn-booking:hover:not(:disabled){background:#059669}.btn-booking:disabled{opacity:.5;cursor:not-allowed}.transcript-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.transcript-content{background:#fff;border-radius:12px;padding:2rem;max-width:800px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.transcript-content h2{margin:0 0 1rem;font-size:1.5rem;color:#1a1a1a}.transcript-meta{padding:1rem;background:#f9fafb;border-radius:8px;margin-bottom:1.5rem}.transcript-meta p{margin:.5rem 0;font-size:.875rem;color:#4b5563}.transcript-text{padding:1.5rem;background:#f9fafb;border-radius:8px;margin-bottom:1.5rem;line-height:1.6;color:#1a1a1a;white-space:pre-wrap;font-size:.9375rem}.btn-transcript-close{width:100%;padding:.75rem;background:#6b7280;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:background .2s}.btn-transcript-close:hover{background:#4b5563}.booking-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.booking-content{background:#fff;border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;padding:1.5rem}.booking-content h2{margin:0 0 1.5rem;font-size:1.5rem;color:#111827}.booking-details{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.booking-detail-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #f3f4f6}.booking-detail-row:last-child{border-bottom:none}.booking-label{font-weight:600;color:#6b7280;font-size:.875rem}.booking-value{color:#111827;font-size:.875rem;text-align:right}.booking-status{padding:.25rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600}.booking-status.status-pending{background:#fef3c7;color:#92400e}.booking-status.status-confirmed{background:#d1fae5;color:#065f46}.booking-status.status-cancelled{background:#fee2e2;color:#991b1b}.booking-status.status-completed{background:#dbeafe;color:#1e40af}.booking-status.status-no_show{background:#f3f4f6;color:#374151}.btn-booking-close{width:100%;padding:.75rem;background:#6b7280;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:background .2s}.btn-booking-close:hover{background:#4b5563}.analytics-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#4f46e5;border-radius:50%;animation:spin 1s linear infinite}.analytics-loading p{color:#6b7280;font-size:1rem}@media(max-width:1024px){.analytics-container{padding:1rem}.analytics-header{flex-direction:column;align-items:flex-start;gap:1rem}.header-actions{width:100%}.analytics-filters{flex-direction:column}.analytics-filter-group{width:100%}.breakdown-grid{grid-template-columns:1fr}}@media(max-width:768px){.analytics-summary{grid-template-columns:1fr}.analytics-table{padding:1rem}.table-wrapper{overflow-x:scroll}.analytics-table table{min-width:900px}}.skeleton-prompt-page{padding:2rem;max-width:1400px;margin:0 auto}.prompts-list{display:flex;flex-direction:column;gap:1.5rem}.prompt-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:all .2s ease;border:2px solid transparent}.prompt-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.prompt-card.inactive{opacity:.7;background:#f9f9f9}.prompt-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.prompt-title{display:flex;align-items:center;gap:.75rem;flex:1;flex-wrap:wrap}.prompt-title h3{margin:0;font-size:1.25rem;color:#1a1a1a}.prompt-title svg{color:#4a90e2}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600}.badge-default{background:gold;color:#856404}.prompt-actions{display:flex;gap:.5rem}.prompt-description{color:#666;margin-bottom:1rem;font-size:.95rem;line-height:1.5}.prompt-template{margin-bottom:1rem}.template-label{display:flex;align-items:center;gap:.5rem;font-weight:600;color:#333;margin-bottom:.5rem;font-size:.9rem}.template-label svg{color:#4a90e2}.template-preview{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;padding:1rem;font-family:Courier New,monospace;font-size:.85rem;line-height:1.6;overflow-x:auto;white-space:pre-wrap;word-wrap:break-word;color:#333;margin:0}.prompt-meta{display:flex;gap:1.5rem;font-size:.85rem;color:#999;padding-top:1rem;border-top:1px solid #e0e0e0}.variables-help{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:1rem;margin-bottom:1rem}.variables-help strong{display:block;margin-bottom:.75rem;color:#333}.variables-grid{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.variable-chip{background:#fff;border:1px solid #4a90e2;color:#4a90e2;padding:.375rem .75rem;border-radius:6px;font-family:Courier New,monospace;font-size:.85rem;cursor:pointer;transition:all .2s ease}.variable-chip:hover{background:#4a90e2;color:#fff;transform:translateY(-1px);box-shadow:0 2px 4px #4a90e24d}.variables-help small{display:block;color:#666;font-size:.8rem;margin-top:.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}@media(max-width:768px){.skeleton-prompt-page{padding:1rem}.prompt-card-header{flex-direction:column}.prompt-actions{width:100%}.prompt-actions button{flex:1}.variables-grid{gap:.375rem}.variable-chip{font-size:.75rem;padding:.25rem .5rem}}.credentials-management{padding:2rem;max-width:900px;margin:0 auto}.page-header{margin-bottom:2rem}.header-content{display:flex;align-items:center;gap:1rem}.header-content h1{margin:0;font-size:2rem;color:#1a1a1a}.header-content p{margin:.5rem 0 0;color:#666}.alert{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:8px;margin-bottom:1rem;position:relative}.alert-success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.alert-error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.alert-close{margin-left:auto;background:none;border:none;cursor:pointer;padding:.25rem;opacity:.7;transition:opacity .2s}.alert-close:hover{opacity:1}.test-details{margin-top:.5rem;padding:.5rem;background:#0000000d;border-radius:4px;font-size:.85rem;overflow-x:auto}.credential-form{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a}.credential-status{background:#f8f9fa;border-radius:8px;padding:1.5rem;margin-bottom:2rem;border-left:4px solid #28a745}.status-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.status-header h3{margin:0;font-size:1.1rem;color:#1a1a1a;flex:1}.status-configured{margin:0;color:#28a745;font-weight:600}.btn-test{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#007bff;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-test:hover:not(:disabled){background:#0056b3}.btn-test:disabled{opacity:.6;cursor:not-allowed}.credential-info{background:#fff;border-radius:6px;padding:1rem}.info-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #e0e0e0}.info-row:last-child{border-bottom:none}.info-label{font-weight:600;color:#666}.info-value{color:#1a1a1a}.form-section{margin-bottom:2rem}.form-section h3{margin:0 0 .5rem;font-size:1.25rem;color:#1a1a1a}.form-description{color:#666;margin-bottom:1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#333;font-size:.9rem}.form-input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:.95rem;transition:border-color .2s;font-family:inherit}.form-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper .form-input{padding-right:3rem}.password-toggle{position:absolute;right:.75rem;background:none;border:none;cursor:pointer;padding:.25rem;color:#666;transition:color .2s;display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:#007bff}textarea.form-input{resize:vertical;min-height:60px}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background:#0056b3;box-shadow:0 2px 8px #007bff4d}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#545b62}.security-notice{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;margin-top:2rem}.security-notice p{margin:0;font-size:.9rem;color:#856404;line-height:1.5}.security-notice strong{color:#533f03}.security-notice code{background:#0000001a;padding:.125rem .375rem;border-radius:3px;font-size:.85rem}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:#666}.loading-state p{margin-top:1rem;font-size:1.1rem}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.credentials-management{padding:1rem}.credential-form{padding:1.5rem}.status-header{flex-direction:column;align-items:flex-start}.btn-test{width:100%;justify-content:center}.form-actions{flex-direction:column}.btn{width:100%;justify-content:center}}:root{--primary-color: #db2777;--primary-hover: #be185d;--primary-light: #fce7f3;--primary-dark: #9f1239;--secondary-color: #6b7280;--success-color: #059669;--success-light: #d1fae5;--danger-color: #dc2626;--danger-light: #fee2e2;--warning-color: #f59e0b;--warning-light: #fef3c7;--info-color: #0284c7;--info-light: #e0f2fe;--background: #f8fafc;--background-secondary: #f1f5f9;--card-background: #ffffff;--border-color: #e2e8f0;--border-color-light: #f1f5f9;--text-primary: #0f172a;--text-secondary: #64748b;--text-tertiary: #94a3b8;--sidebar-width: 280px;--sidebar-collapsed-width: 80px;--sidebar-bg: #1e293b;--sidebar-text: #cbd5e1;--sidebar-text-active: #ffffff;--sidebar-hover: #334155;--sidebar-active: #db2777;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-sm: 0 2px 4px 0 rgba(0, 0, 0, .06);--shadow-md: 0 4px 8px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 20px -5px rgba(0, 0, 0, .15);--shadow-xl: 0 20px 30px -10px rgba(0, 0, 0, .2);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background);color:var(--text-primary);overflow-x:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--background-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.loading-container,.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--primary-light) 0%,var(--background) 100%);padding:var(--spacing-lg)}.loading-content{text-align:center;animation:fadeIn var(--transition-slow) ease-in}.loading-content h2{margin-top:var(--spacing-lg);font-size:1.5rem;color:var(--text-primary);font-weight:600}.loading-content p{margin-top:var(--spacing-sm);color:var(--text-secondary);font-size:.875rem}.spinner{width:56px;height:56px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:var(--radius-full);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-card{background:var(--card-background);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:440px;width:100%;overflow:hidden;animation:slideUp var(--transition-slow) ease-out}.login-card-header{padding:var(--spacing-2xl) var(--spacing-2xl) var(--spacing-xl);text-align:center;background:linear-gradient(135deg,var(--primary-color),var(--primary-dark))}.login-logo{height:80px;filter:brightness(0) invert(1)}.login-card-body{padding:var(--spacing-2xl);text-align:center}.login-card-body h1{font-size:1.875rem;margin-bottom:var(--spacing-sm);color:var(--text-primary);font-weight:700}.login-card-body p{color:var(--text-secondary);margin-bottom:var(--spacing-xl);font-size:.9375rem;line-height:1.6}.login-card-footer{padding:var(--spacing-lg) var(--spacing-2xl) var(--spacing-xl);background:var(--background);border-top:1px solid var(--border-color);text-align:center}.login-card-footer p{font-size:.8125rem;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.support-link{color:var(--primary-color);text-decoration:none;font-weight:600;transition:all var(--transition-fast)}.support-link:hover{color:var(--primary-hover);text-decoration:underline}.admin-layout{min-height:100vh;display:flex;background:var(--background)}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;transition:width var(--transition-base);z-index:100;box-shadow:var(--shadow-lg)}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-header{padding:var(--spacing-lg);border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between;min-height:80px}.sidebar-brand{display:flex;align-items:center;gap:var(--spacing-md);overflow:hidden}.sidebar-logo{height:40px;width:40px;object-fit:contain;flex-shrink:0;filter:brightness(0) invert(1)}.sidebar-brand-text{overflow:hidden;white-space:nowrap}.sidebar-brand-text h1{font-size:1.25rem;color:var(--sidebar-text-active);font-weight:700;margin-bottom:.125rem}.sidebar-brand-text p{font-size:.75rem;color:var(--sidebar-text);opacity:.8}.sidebar-toggle,.sidebar-close{background:transparent;border:none;color:var(--sidebar-text);cursor:pointer;padding:var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-toggle:hover,.sidebar-close:hover{background:var(--sidebar-hover);color:var(--sidebar-text-active)}.sidebar-nav{flex:1;padding:var(--spacing-lg) var(--spacing-md);overflow-y:auto;overflow-x:hidden}.sidebar-nav .nav-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);color:var(--sidebar-text);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast);margin-bottom:var(--spacing-sm);font-weight:500;font-size:.9375rem;white-space:nowrap;position:relative}.sidebar-nav .nav-item:hover{background:var(--sidebar-hover);color:var(--sidebar-text-active);transform:translate(4px)}.sidebar-nav .nav-item.active{background:var(--sidebar-active);color:var(--sidebar-text-active);box-shadow:0 4px 12px #db27774d}.sidebar-nav .nav-item svg{flex-shrink:0}.sidebar.collapsed .sidebar-nav .nav-item{justify-content:center;padding:var(--spacing-md)}.sidebar.collapsed .sidebar-nav .nav-item span{display:none}.sidebar-footer{padding:var(--spacing-lg);border-top:1px solid rgba(255,255,255,.1)}.sidebar-user{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:#ffffff0d;border-radius:var(--radius-md);margin-bottom:var(--spacing-md);overflow:hidden}.sidebar-user .user-avatar{width:40px;height:40px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0}.sidebar-user .user-info{overflow:hidden;flex:1;min-width:0}.sidebar-user .user-name{font-weight:600;font-size:.875rem;color:var(--sidebar-text-active);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user .user-email{font-size:.75rem;color:var(--sidebar-text);opacity:.8;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar.collapsed .sidebar-user{justify-content:center;padding:var(--spacing-md) var(--spacing-sm)}.sidebar.collapsed .sidebar-user .user-info{display:none}.main-wrapper{flex:1;margin-left:var(--sidebar-width);transition:margin-left var(--transition-base);display:flex;flex-direction:column;min-height:100vh}.sidebar.collapsed~.main-wrapper{margin-left:var(--sidebar-collapsed-width)}.top-bar{background:var(--card-background);border-bottom:1px solid var(--border-color);padding:var(--spacing-lg) var(--spacing-xl);display:flex;align-items:center;gap:var(--spacing-lg);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:50}.mobile-menu-btn{display:none;background:transparent;border:none;color:var(--text-primary);cursor:pointer;padding:var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast)}.mobile-menu-btn:hover{background:var(--background)}.top-bar-title h2{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.main-content{flex:1;padding:var(--spacing-xl);max-width:1600px;width:100%;margin:0 auto}.app-footer{background:var(--card-background);border-top:1px solid var(--border-color);padding:var(--spacing-lg) var(--spacing-xl);text-align:center;margin-top:auto}.app-footer p{font-size:.875rem;color:var(--text-secondary);margin:0}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:99;animation:fadeIn var(--transition-fast) ease-in}.desktop-only{display:flex}.mobile-only{display:none}.btn-primary,.btn-secondary,.btn-danger,.btn-login,.btn-logout{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:.75rem 1.5rem;border:none;border-radius:var(--radius-md);font-weight:600;font-size:.875rem;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-decoration:none;line-height:1}.btn-primary{background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));color:#fff;box-shadow:0 2px 8px #db277740}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #db277759}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--card-background);color:var(--text-primary);border:1.5px solid var(--border-color)}.btn-secondary:hover{background:var(--background);border-color:var(--primary-color);color:var(--primary-color)}.btn-danger{background:var(--danger-color);color:#fff;box-shadow:0 2px 8px #dc262640}.btn-danger:hover{background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc262659}.btn-login{background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));color:#fff;padding:1rem 2rem;font-size:1rem;box-shadow:0 4px 12px #db27774d}.btn-login:hover{transform:translateY(-2px);box-shadow:0 6px 16px #db277766}.btn-logout{background:#ffffff1a;color:var(--sidebar-text);padding:var(--spacing-md) var(--spacing-lg);width:100%;justify-content:flex-start}.btn-logout:hover{background:#ffffff26;color:var(--sidebar-text-active)}.sidebar.collapsed .btn-logout{justify-content:center;padding:var(--spacing-md)}.sidebar.collapsed .btn-logout span{display:none}.btn-sm{padding:.5rem 1rem;font-size:.8125rem}.btn-close{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.btn-close:hover{background:var(--background);color:var(--text-primary)}@media(max-width:1024px){.main-content{padding:var(--spacing-lg)}}@media(max-width:768px){.sidebar{transform:translate(-100%);transition:transform var(--transition-base)}.sidebar.mobile-open{transform:translate(0)}.sidebar-overlay{display:block}.main-wrapper{margin-left:0!important}.mobile-menu-btn{display:flex}.desktop-only{display:none}.mobile-only{display:flex}.top-bar{padding:var(--spacing-md) var(--spacing-lg)}.main-content{padding:var(--spacing-md)}.btn-primary,.btn-secondary,.btn-danger{width:100%;justify-content:center}}@media(max-width:480px){.login-card{border-radius:0;box-shadow:none}.login-card-header,.login-card-body{padding:var(--spacing-xl)}.main-content{padding:var(--spacing-sm)}}
