.permissions-tab{padding:var(--spacing-lg);max-width:100%;box-sizing:border-box;overflow-x:hidden;width:100%}.permissions-tab-header{margin-bottom:var(--spacing-xl)}.permissions-tab-header h3{font-size:var(--font-size-xl);font-weight:600;color:var(--text);margin:0 0 var(--spacing-sm) 0}.permissions-tab-header p{color:var(--textSecondary);font-size:var(--font-size-sm);line-height:1.6;margin:0}.permissions-tab-header small{display:block;margin-top:var(--spacing-sm);color:var(--textSecondary);font-size:var(--font-size-xs)}.permissions-tab-modules{display:grid;grid-gap:var(--spacing-lg);gap:var(--spacing-lg);width:100%;box-sizing:border-box}.permission-module{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-normal);width:100%;box-sizing:border-box;overflow:hidden}.permission-module:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}.permission-module-disabled{background:var(--background);opacity:.7}.permission-module-disabled:hover{border-color:var(--border);box-shadow:none}.permission-module-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md);gap:var(--spacing-md)}.permission-module-info{display:flex;align-items:flex-start;gap:var(--spacing-md);flex:1 1}.permission-module-icon{font-size:2rem;line-height:1;flex-shrink:0}.permission-module-info h4{font-size:var(--font-size-lg);font-weight:600;color:var(--text);margin:0 0 var(--spacing-xs) 0}.permission-module-info p{font-size:var(--font-size-sm);color:var(--textSecondary);margin:0;line-height:1.4}.permission-module-badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);background:var(--primary-transparent);color:var(--primary);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:500;white-space:nowrap;flex-shrink:0}.permission-module-actions{flex-wrap:wrap;width:100%}.permission-action,.permission-module-actions{display:flex;gap:var(--spacing-sm);box-sizing:border-box}.permission-action{align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--background);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;-moz-user-select:none;user-select:none;max-width:100%}.permission-action:hover{background:var(--surface);border-color:var(--primary)}.permission-action-disabled{cursor:not-allowed;opacity:.6}.permission-action-disabled:hover{background:var(--background);border-color:var(--border)}.permission-checkbox{width:1.125rem;height:1.125rem;cursor:pointer;accent-color:var(--primary);flex-shrink:0}.permission-checkbox:disabled{cursor:not-allowed}.permission-action-label{font-size:var(--font-size-sm);font-weight:500;color:var(--text);position:relative;padding-left:var(--spacing-xs)}.permission-action-label:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--action-color,var(--primary));border-radius:var(--radius-sm)}.permission-checkbox:checked+.permission-action-label{color:var(--primary)}.permissions-tab-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-2xl);min-height:300px}.permissions-tab-icon{font-size:4rem;margin-bottom:var(--spacing-lg);opacity:.5}.permissions-tab-placeholder h3{font-size:var(--font-size-xl);font-weight:600;color:var(--text);margin:0 0 var(--spacing-sm) 0}.permissions-tab-placeholder p{color:var(--textSecondary);font-size:var(--font-size-md);max-width:400px;line-height:1.6;margin:0}.permissions-tab-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);min-height:300px;gap:var(--spacing-md)}.permissions-tab-loading p{color:var(--textSecondary);font-size:var(--font-size-sm)}.loading-spinner{width:2rem;height:2rem;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.permissions-tab-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);min-height:300px;gap:var(--spacing-md)}.error-icon{font-size:3rem}.permissions-tab-error p{color:var(--error);font-size:var(--font-size-md);text-align:center}.permissions-tab-empty{display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl);min-height:200px}.permissions-tab-empty p{color:var(--textSecondary);font-size:var(--font-size-md);text-align:center}@media (max-width:768px){.permissions-tab{padding:var(--spacing-sm) 0;box-sizing:border-box}.permission-module{padding:var(--spacing-md);box-sizing:border-box}.permission-module-header{flex-direction:column;align-items:flex-start}.permission-module-badge{align-self:flex-start}.permission-module-info{gap:var(--spacing-sm)}.permission-module-icon{font-size:1.5rem}.permission-module-info h4{font-size:var(--font-size-md)}.permission-module-info p{font-size:var(--font-size-xs)}.permissions-tab-header h3{font-size:var(--font-size-lg)}.permissions-tab-error,.permissions-tab-loading,.permissions-tab-placeholder{padding:var(--spacing-xl) var(--spacing-md);min-height:200px}.permissions-tab-icon{font-size:3rem}.permission-module-actions{gap:var(--spacing-xs)}.permission-action{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs)}}@media (max-width:639px){.permissions-tab{padding:0;box-sizing:border-box;width:100%}.permissions-tab-modules{gap:var(--spacing-md)}.permission-module{padding:var(--spacing-sm);box-sizing:border-box;width:100%}.permission-module-actions{flex-direction:column;gap:var(--spacing-xs)}.permission-action{width:100%;box-sizing:border-box;justify-content:flex-start}.permissions-tab-header{padding:0 var(--spacing-sm);margin-bottom:var(--spacing-md)}}@media (max-width:480px){.permissions-tab{padding:0}.permission-module{padding:var(--spacing-xs) var(--spacing-sm)}.permission-module-info p{font-size:.7rem;line-height:1.3}.permission-action{padding:var(--spacing-xs)}.permission-action-label{font-size:.75rem}.permissions-tab-header{padding:0 var(--spacing-xs)}}@media (max-width:360px){.permissions-tab{padding:0}.permission-module{padding:var(--spacing-xs)}.permission-module-info h4{font-size:var(--font-size-sm)}.permissions-tab-header h3{font-size:var(--font-size-md)}}.time-slot-badge{position:relative;display:inline-flex;align-items:center;gap:var(--spacing-xs,4px);padding:var(--spacing-xs,4px) var(--spacing-sm,8px);background:var(--primary,#3b82f6);color:var(--white,#ffffff);border-radius:var(--radius-full,9999px);font-size:var(--font-size-xs,12px);font-weight:600;cursor:pointer;transition:all .2s ease;z-index:10}.time-slot-badge:hover{background:var(--primary-dark,#2563eb);transform:scale(1.05)}.time-slot-badge:focus{outline:2px solid var(--primary,#3b82f6);outline-offset:2px}.time-slot-badge-icon{flex-shrink:0}.time-slot-badge-count{line-height:1}.time-slot-badge-tooltip{position:fixed;background:var(--surface,#ffffff);border:1px solid var(--border,#e5e7eb);border-radius:var(--radius-md,8px);box-shadow:0 4px 12px rgba(0,0,0,.15);padding:var(--spacing-sm,8px);min-width:200px;max-width:300px;z-index:10000;pointer-events:none}.time-slot-badge-tooltip-header{margin-bottom:var(--spacing-xs,4px);font-size:var(--font-size-sm,14px);color:var(--text,#1f2937)}.time-slot-badge-tooltip-list{list-style:none;padding:0;margin:0;max-height:200px;overflow-y:auto}.time-slot-badge-tooltip-item{padding:var(--spacing-xs,4px) 0;font-size:var(--font-size-sm,14px);color:var(--text,#1f2937);border-bottom:1px solid var(--border-light,#f3f4f6)}.time-slot-badge-tooltip-item:last-child{border-bottom:none}.time-slot-badge-tooltip-specialty{color:var(--text-secondary,#6b7280);font-size:var(--font-size-xs,12px)}@media (max-width:768px){.time-slot-badge{font-size:var(--font-size-xs,12px);padding:2px var(--spacing-xs,4px)}.time-slot-badge-tooltip{min-width:180px;max-width:250px}}.availability-filters{background:var(--surface,#ffffff);border:1px solid var(--border,#e5e7eb);border-radius:var(--radius-lg,12px);padding:var(--spacing-lg,24px);margin-bottom:var(--spacing-lg,24px)}.availability-filters-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md,16px)}.availability-filters-title{font-size:var(--font-size-lg,18px);font-weight:600;color:var(--text,#1f2937);margin:0}.availability-filters-clear{display:flex;align-items:center;gap:var(--spacing-xs,4px);padding:var(--spacing-xs,4px) var(--spacing-sm,8px);background:transparent;border:1px solid var(--border,#e5e7eb);border-radius:var(--radius-md,8px);color:var(--text-secondary,#6b7280);font-size:var(--font-size-sm,14px);cursor:pointer;transition:all .2s ease}.availability-filters-clear:hover{background:var(--surface-hover,#f9fafb);border-color:var(--border-hover,#d1d5db);color:var(--text,#1f2937)}.availability-filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:var(--spacing-md,16px);gap:var(--spacing-md,16px)}.availability-filter-field{position:relative;display:flex;flex-direction:column;gap:var(--spacing-xs,4px)}.availability-filter-label{display:flex;align-items:center;gap:var(--spacing-xs,4px);font-size:var(--font-size-sm,14px);font-weight:500;color:var(--text,#1f2937)}.availability-filter-label .required{color:var(--error,#ef4444)}.availability-filter-input-wrapper{position:relative;display:flex;align-items:center;gap:var(--spacing-xs,4px)}.availability-filter-icon{position:absolute;left:var(--spacing-sm,8px);color:var(--text-secondary,#6b7280);pointer-events:none;z-index:1}.availability-filter-input{width:100%;padding:var(--spacing-sm,8px) var(--spacing-sm,8px) var(--spacing-sm,8px) calc(var(--spacing-md, 16px) + var(--spacing-xs, 4px));border:1px solid var(--border,#e5e7eb);border-radius:var(--radius-md,8px);font-size:var(--font-size-sm,14px);color:var(--text,#1f2937);background:var(--surface,#ffffff);transition:all .2s ease}.availability-filter-input:focus{outline:none;border-color:var(--primary,#3b82f6);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.availability-filter-input::placeholder{color:var(--text-tertiary,#9ca3af)}.availability-filter-clear-btn{position:absolute;right:var(--spacing-sm,8px);display:flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;background:transparent;border:none;border-radius:var(--radius-full,9999px);color:var(--text-secondary,#6b7280);cursor:pointer;transition:all .2s ease;z-index:2}.availability-filter-clear-btn:hover{background:var(--surface-hover,#f9fafb);color:var(--text,#1f2937)}.availability-filter-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--surface,#ffffff);border:1px solid var(--border,#e5e7eb);border-radius:var(--radius-md,8px);box-shadow:0 4px 12px rgba(0,0,0,.15);max-height:200px;overflow-y:auto;z-index:1000;list-style:none;padding:var(--spacing-xs,4px);margin:0}.availability-filter-dropdown-item{padding:var(--spacing-sm,8px) var(--spacing-md,16px);font-size:var(--font-size-sm,14px);color:var(--text,#1f2937);cursor:pointer;border-radius:var(--radius-sm,4px);transition:background .2s ease}.availability-filter-dropdown-item:hover,.availability-filter-dropdown-item[aria-selected=true]{background:var(--surface-hover,#f9fafb)}@media (max-width:768px){.availability-filters{padding:var(--spacing-md,16px)}.availability-filters-grid{grid-template-columns:1fr;gap:var(--spacing-md,16px)}.availability-filter-dropdown{max-height:150px}}.doctor-schedule-view{display:flex;flex-direction:column;height:100%;background:var(--surface,#ffffff);border-radius:var(--radius-lg,12px);overflow:hidden}.dark .doctor-schedule-view{background:var(--surface,#1f2937)}.doctor-schedule-view-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--spacing-lg,24px);border-bottom:1px solid var(--border,#e5e7eb);background:var(--surface,#ffffff)}.dark .doctor-schedule-view-header{background:var(--surface,#1f2937);border-bottom-color:var(--border,#374151)}.doctor-schedule-view-title{display:flex;flex-direction:column;gap:var(--spacing-xs,4px)}.doctor-schedule-view-title h2{font-size:var(--font-size-xl,20px);font-weight:600;color:var(--text,#1f2937);margin:0}.dark .doctor-schedule-view-title h2{color:var(--text,#f9fafb)}.doctor-schedule-view-service-selector{display:flex;align-items:center}.doctor-schedule-view-select-compact{padding:var(--spacing-xs,4px) var(--spacing-sm,8px);border:1px solid var(--border,#e5e7eb);border-radius:var(--radius-md,8px);font-size:var(--font-size-sm,14px);color:var(--text,#1f2937);background:var(--surface,#ffffff);transition:all .2s ease;width:auto;min-width:200px;cursor:pointer;font-weight:500}.dark .doctor-schedule-view-select-compact{background:var(--surface,#1f2937);border-color:var(--border,#374151);color:var(--text,#f9fafb)}.doctor-schedule-view-select-compact:focus{outline:none;border-color:var(--primary,#3b82f6);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.doctor-schedule-view-select-compact:disabled{opacity:.6;cursor:not-allowed}.doctor-schedule-view-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md,8px);font-size:var(--font-size-xl,20px);color:var(--text-secondary,#6b7280);cursor:pointer;transition:all .2s ease}.doctor-schedule-view-close:hover{background:var(--surface-hover,#f9fafb);color:var(--text,#1f2937)}.doctor-schedule-view-controls{display:flex;justify-content:center;padding:var(--spacing-lg,24px);border-bottom:1px solid var(--border,#e5e7eb);background:transparent}.doctor-schedule-view-controls-wrapper{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md,16px);width:100%;max-width:600px}.doctor-schedule-view-date-picker{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm,8px);width:100%}.doctor-schedule-view-nav-button{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;padding:0;border:1px solid var(--border,#e5e7eb);border-radius:var(--radius-md,8px);background:var(--surface,#ffffff);color:var(--text-secondary,#6b7280);cursor:pointer;transition:all .2s ease;flex-shrink:0}.dark .doctor-schedule-view-nav-button{background:var(--surface,#1f2937);border-color:var(--border,#374151);color:var(--text-secondary,#9ca3af)}.doctor-schedule-view-nav-button:hover{background:var(--surface-hover,#f9fafb);border-color:var(--primary,#3b82f6);color:var(--primary,#3b82f6);transform:translateY(-1px);box-shadow:0 2px 4px rgba(0,0,0,.1)}.dark .doctor-schedule-view-nav-button:hover{background:var(--surface-hover,#374151);border-color:var(--primary,#3b82f6);color:var(--primary,#3b82f6)}.doctor-schedule-view-nav-button:active{transform:translateY(0);box-shadow:0 1px 2px rgba(0,0,0,.1)}.doctor-schedule-view-nav-button:focus{outline:none;border-color:var(--primary,#3b82f6);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.doctor-schedule-view-label{display:flex;align-items:center;gap:var(--spacing-xs,4px);font-size:var(--font-size-sm,14px);font-weight:500;color:var(--text,#1f2937)}.dark .doctor-schedule-view-label{color:var(--text,#f9fafb)}.doctor-schedule-view-input{padding:var(--spacing-sm,8px) var(--spacing-md,16px);border:1px solid var(--border,#e5e7eb);border-radius:var(--radius-md,8px);font-size:var(--font-size-sm,14px);color:var(--text,#1f2937);background:var(--surface,#ffffff);transition:all .2s ease}.doctor-schedule-view-input:focus{outline:none;border-color:var(--primary,#3b82f6);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.doctor-schedule-view-input-compact{padding:var(--spacing-xs,4px) var(--spacing-sm,8px);border:1px solid var(--border,#e5e7eb);border-radius:var(--radius-md,8px);font-size:var(--font-size-sm,14px);color:var(--text,#1f2937);background:var(--surface,#ffffff);transition:all .2s ease;width:auto;min-width:140px}.dark .doctor-schedule-view-input-compact{background:var(--surface,#1f2937);border-color:var(--border,#374151);color:var(--text,#f9fafb)}.doctor-schedule-view-input-compact:focus{outline:none;border-color:var(--primary,#3b82f6);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.doctor-schedule-view-filter-buttons{display:flex;gap:var(--spacing-sm,8px);flex-wrap:wrap;justify-content:center;width:100%}.doctor-schedule-view-filter-btn{padding:var(--spacing-sm,8px) var(--spacing-md,16px);border:1px solid var(--border,#e5e7eb);border-radius:var(--radius-md,8px);font-size:var(--font-size-sm,14px);font-weight:500;color:var(--text,#1f2937);background:var(--surface,#ffffff);cursor:pointer;transition:all .2s ease}.dark .doctor-schedule-view-filter-btn{background:var(--surface,#1f2937);border-color:var(--border,#374151);color:var(--text,#f9fafb)}.doctor-schedule-view-filter-btn:hover{background:var(--surface-hover,#f9fafb);border-color:var(--border-hover,#d1d5db)}.dark .doctor-schedule-view-filter-btn:hover{background:var(--surface-hover,#374151);border-color:var(--border-hover,#4b5563)}.doctor-schedule-view-filter-btn.active{background:var(--primary,#3b82f6);border-color:var(--primary,#3b82f6);color:var(--white,#ffffff)}.doctor-schedule-view-content{flex:1 1;padding:var(--spacing-lg,24px);overflow-y:auto}.doctor-schedule-view-day-title{font-size:var(--font-size-lg,18px);font-weight:600;color:var(--text,#1f2937);margin:0 0 var(--spacing-md,16px) 0}.dark .doctor-schedule-view-day-title{color:var(--text,#f9fafb)}.doctor-schedule-view-empty-hint{font-size:var(--font-size-xs,12px);color:var(--text-secondary,#6b7280);margin-top:var(--spacing-sm,8px)}.dark .doctor-schedule-view-empty-hint{color:var(--textSecondary,#9ca3af)}.doctor-schedule-view-slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));grid-gap:var(--spacing-md,16px);gap:var(--spacing-md,16px)}.doctor-schedule-view-slot{display:flex;flex-direction:column;gap:var(--spacing-xs,4px);padding:var(--spacing-md,16px);border:2px solid var(--border,#e5e7eb);border-radius:var(--radius-md,8px);background:var(--surface,#ffffff);transition:all .2s ease}.doctor-schedule-view-slot.available{border-color:var(--success,#10b981);background:var(--success-light,#d1fae5)}.doctor-schedule-view-slot.booked{border-color:var(--warning,#f59e0b);background:var(--warning-light,#fef3c7)}.doctor-schedule-view-slot.unavailable{border-color:var(--border,#e5e7eb);background:var(--surface-secondary,#f9fafb);opacity:.6}.doctor-schedule-view-slot-time{display:flex;align-items:center;gap:var(--spacing-xs,4px);font-size:var(--font-size-base,16px);font-weight:600;color:var(--text,#1f2937)}.dark .doctor-schedule-view-slot{background:var(--surface,#1f2937);border-color:var(--border,#374151)}.dark .doctor-schedule-view-slot.available{background:rgba(16,185,129,.2);border-color:var(--success,#10b981)}.dark .doctor-schedule-view-slot.booked{background:rgba(245,158,11,.2);border-color:var(--warning,#f59e0b)}.dark .doctor-schedule-view-slot.unavailable{background:var(--surface-secondary,#111827);border-color:var(--border,#374151);opacity:.5}.dark .doctor-schedule-view-slot-time,.dark .doctor-schedule-view-slot-time span{color:var(--text,#f9fafb)}.doctor-schedule-view-slot-patient{font-size:var(--font-size-sm,14px);color:var(--text-secondary,#6b7280);font-weight:500}.dark .doctor-schedule-view-slot-patient{color:var(--textSecondary,#d1d5db)}.doctor-schedule-view-slot-status{font-size:var(--font-size-xs,12px);color:var(--text-secondary,#6b7280);text-transform:uppercase;font-weight:500}.dark .doctor-schedule-view-slot-status{color:var(--textSecondary,#d1d5db)}.doctor-schedule-view-empty,.doctor-schedule-view-error,.doctor-schedule-view-loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl,48px);text-align:center;color:var(--text-secondary,#6b7280)}.doctor-schedule-view-error{color:var(--error,#ef4444)}@media (max-width:768px){.doctor-schedule-view-header{padding:var(--spacing-md,16px)}.doctor-schedule-view-controls{padding:var(--spacing-md,16px);flex-direction:column}.doctor-schedule-view-date-picker{min-width:100%;gap:var(--spacing-xs,4px)}.doctor-schedule-view-nav-button{width:2.25rem;height:2.25rem}.doctor-schedule-view-input-compact{flex:1 1;min-width:0}.doctor-schedule-view-filters{min-width:100%}.doctor-schedule-view-content{padding:var(--spacing-md,16px)}.doctor-schedule-view-slots-grid{grid-template-columns:1fr}}.service-schedules-container{margin-top:var(--spacing-md,16px);border-top:1px solid var(--border,#e5e7eb);padding-top:var(--spacing-md,16px)}.service-schedules-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--spacing-sm,8px) var(--spacing-md,16px);background:var(--surface-secondary,#f9fafb);border:1px solid var(--border,#e5e7eb);border-radius:var(--radius-md,8px);cursor:pointer;transition:all .2s ease;font-size:var(--font-size-sm,14px);font-weight:500;color:var(--text,#1f2937)}.service-schedules-toggle:hover{background:var(--surface-hover,#f3f4f6);border-color:var(--border-hover,#d1d5db)}.dark .service-schedules-toggle{background:var(--surface,#1f2937);border-color:var(--border,#374151);color:var(--text,#f9fafb)}.dark .service-schedules-toggle:hover{background:var(--surface-hover,#374151);border-color:var(--border-hover,#4b5563)}.service-schedules-toggle-label{display:flex;align-items:center;gap:var(--spacing-xs,4px)}.service-schedules-indicator{color:var(--success,#10b981);font-size:var(--font-size-lg,18px);line-height:1}.service-schedules-toggle-icon{color:var(--text-secondary,#6b7280);transition:transform .2s ease}.service-schedules-content{margin-top:var(--spacing-md,16px);padding:var(--spacing-md,16px);background:var(--surface-secondary,#f9fafb);border:1px solid var(--border,#e5e7eb);border-radius:var(--radius-md,8px)}.dark .service-schedules-content{background:var(--surface,#1f2937);border-color:var(--border,#374151)}.service-schedules-help-text{font-size:var(--font-size-xs,12px);color:var(--text-secondary,#6b7280);margin:0 0 var(--spacing-md,16px) 0;line-height:1.5}.dark .service-schedules-help-text{color:var(--textSecondary,#d1d5db)}.service-schedule-day-container{margin-bottom:var(--spacing-md,16px);padding:var(--spacing-sm,8px);background:var(--surface,#ffffff);border:1px solid var(--border,#e5e7eb);border-radius:var(--radius-sm,4px)}.dark .service-schedule-day-container{background:var(--surface-secondary,#111827);border-color:var(--border,#374151)}.service-schedule-day-header{margin-bottom:var(--spacing-xs,4px)}.service-schedule-day-checkbox{display:flex;align-items:center;gap:var(--spacing-xs,4px)}.service-schedule-day-checkbox input[type=checkbox]{cursor:pointer}.service-schedule-day-checkbox label{cursor:pointer;font-size:var(--font-size-sm,14px);font-weight:500;color:var(--text,#1f2937);-webkit-user-select:none;-moz-user-select:none;user-select:none}.dark .service-schedule-day-checkbox label{color:var(--text,#f9fafb)}.service-schedule-times-container{margin-top:var(--spacing-sm,8px);padding-left:var(--spacing-lg,24px)}.service-schedule-time-slot{margin-bottom:var(--spacing-xs,4px)}.service-schedule-times{display:flex;align-items:center;gap:var(--spacing-xs,4px);flex-wrap:wrap}.service-schedule-time-input{width:auto;min-width:100px;padding:var(--spacing-xs,4px) var(--spacing-sm,8px);font-size:var(--font-size-sm,14px)}.service-schedule-time-separator{font-size:var(--font-size-sm,14px);color:var(--text-secondary,#6b7280);margin:0 var(--spacing-xs,4px)}.dark .service-schedule-time-separator{color:var(--textSecondary,#d1d5db)}.service-schedule-remove-time-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:none;border-radius:var(--radius-sm,4px);color:var(--error,#ef4444);cursor:pointer;transition:all .2s ease}.service-schedule-remove-time-btn:hover{background:var(--error-light,rgba(239,68,68,.1))}.service-schedule-add-time-btn{display:flex;align-items:center;gap:var(--spacing-xs,4px);padding:var(--spacing-xs,4px) var(--spacing-sm,8px);margin-top:var(--spacing-xs,4px);background:transparent;border:1px dashed var(--border,#e5e7eb);border-radius:var(--radius-sm,4px);color:var(--text-secondary,#6b7280);font-size:var(--font-size-xs,12px);cursor:pointer;transition:all .2s ease}.service-schedule-add-time-btn:hover{background:var(--surface-hover,#f3f4f6);border-color:var(--primary,#3b82f6);color:var(--primary,#3b82f6)}.dark .service-schedule-add-time-btn{border-color:var(--border,#374151);color:var(--textSecondary,#d1d5db)}.dark .service-schedule-add-time-btn:hover{background:var(--surface-hover,#374151);border-color:var(--primary,#3b82f6);color:var(--primary,#3b82f6)}@media (max-width:768px){.service-schedules-toggle{padding:var(--spacing-xs,4px) var(--spacing-sm,8px);font-size:var(--font-size-xs,12px)}.service-schedules-content{padding:var(--spacing-sm,8px)}.service-schedule-times-container{padding-left:var(--spacing-sm,8px)}.service-schedule-time-input{min-width:80px;font-size:var(--font-size-xs,12px)}}.main-layout{width:100%;background:var(--background)}.main-content,.main-layout{display:flex;height:100vh;overflow:hidden;box-sizing:border-box;position:relative;z-index:1}.main-content{flex-direction:column;flex:1 1;min-width:0;margin-left:var(--sidebar-width);transition:margin-left var(--transition-slow) ease-in-out}.main-content.sidebar-collapsed{margin-left:var(--sidebar-collapsed-width)}.main-area{flex:1 1;overflow:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;background:var(--background);transition:opacity .3s ease-in-out;height:100%;box-sizing:border-box}.main-area.fade-in{opacity:1}.main-area.fade-out{opacity:0}@media (max-width:768px){.main-layout{width:100%}.main-content,.main-layout{height:100vh;overflow:hidden}.main-content{flex:1 1;min-width:0;transition:margin-left var(--transition-slow) ease-in-out}.main-content,.main-content.sidebar-collapsed{margin-left:var(--sidebar-mobile-width)}.main-area{height:100%;overflow:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}}@media (max-width:480px){.main-content{transition:margin-left var(--transition-slow) ease-in-out}.main-content,.main-content.sidebar-collapsed{margin-left:var(--sidebar-mobile-sm-width)}.main-area{height:100%;overflow:auto;overflow-x:hidden}}.sidebar{display:flex;flex-direction:column;background-color:var(--sidebar);border-right:1px solid var(--border);width:var(--sidebar-width);transition:width var(--transition-slow) ease-in-out;position:fixed;left:0;right:auto;top:0;bottom:0;height:auto;min-height:100dvh;z-index:1!important;overflow:hidden;box-sizing:border-box;isolation:auto}.sidebar-collapsed{width:var(--sidebar-collapsed-width)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid var(--border);transition:all var(--transition-normal);height:4rem;flex-shrink:0;box-sizing:border-box}.sidebar-collapsed .sidebar-header{justify-content:center;flex-direction:row;gap:0;position:relative;align-items:center}.sidebar-brand{display:flex;align-items:center;gap:var(--spacing-sm);transition:all var(--transition-normal);flex-shrink:0}.sidebar-collapsed .sidebar-brand{justify-content:center;width:2rem;position:static;left:auto;transform:none;height:2rem;display:flex;align-items:center;box-sizing:border-box}.sidebar-brand-icon{width:1.5rem;height:1.5rem;color:var(--primary);flex-shrink:0}.sidebar-collapsed .sidebar-brand-icon{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center}.sidebar-brand-text{font-weight:600;color:var(--text);transition:opacity var(--transition-normal),width var(--transition-normal);white-space:nowrap;overflow:hidden;font-size:var(--font-size-lg);flex-shrink:0}.sidebar-collapsed .sidebar-brand-text{opacity:0;width:0;overflow:hidden}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;border:none;background-color:transparent;color:var(--textSecondary);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.sidebar-toggle:hover{background-color:var(--surface);color:var(--text)}.sidebar-collapsed .sidebar-toggle{position:absolute;right:-.75rem;z-index:1!important}@media (max-width:768px){.sidebar-collapsed .sidebar-toggle{z-index:1!important}}.sidebar-toggle-icon{width:1rem;height:1rem;transition:transform var(--transition-normal);flex-shrink:0}.sidebar-nav{flex:1 1;padding:var(--spacing-md) 0;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--border) transparent;box-sizing:border-box}.sidebar-link{display:flex;align-items:center;width:calc(100% - var(--spacing-md));padding:var(--spacing-sm) var(--spacing-md);color:var(--textSecondary);text-decoration:none;border-radius:var(--radius-md);margin:0 var(--spacing-sm);transition:all var(--transition-fast);font-size:var(--font-size-sm);box-sizing:border-box;overflow:hidden}.sidebar-link:hover{background-color:var(--surface);color:var(--text)}.sidebar-link-active{background-color:var(--primary-transparent);color:var(--primary);font-weight:500}.sidebar-collapsed .sidebar-link{justify-content:center;margin:0 var(--spacing-xs);width:calc(100% - var(--spacing-xs))}.sidebar-icon-container{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;flex-shrink:0;margin-right:var(--spacing-sm)}.sidebar-collapsed .sidebar-icon-container{margin-right:0;width:2rem;height:2rem}.sidebar-icon-active{color:var(--primary)}.sidebar-icon{width:1.25rem;height:1.25rem;transition:all var(--transition-fast);flex-shrink:0}.sidebar-collapsed .sidebar-icon{width:1.5rem;height:1.5rem}.sidebar-tooltip{position:absolute;left:100%;top:50%;transform:translateY(-50%);background-color:var(--text);color:var(--background);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity var(--transition-fast);z-index:var(--z-tooltip);margin-left:var(--spacing-sm);box-shadow:var(--shadow-lg);max-width:200px;overflow:hidden;text-overflow:ellipsis}.sidebar-collapsed .sidebar-link:hover .sidebar-tooltip,.sidebar-collapsed .sidebar-search-btn:hover .sidebar-tooltip{opacity:1}.sidebar:not(.sidebar-collapsed) .sidebar-tooltip{display:none}.sidebar-text{font-weight:500;transition:opacity var(--transition-normal),width var(--transition-normal);white-space:nowrap;overflow:hidden;flex-shrink:0}.sidebar-collapsed .sidebar-text{opacity:0;width:0;overflow:hidden}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid var(--border);margin-top:auto;flex-shrink:0;box-sizing:border-box}.sidebar-logout,.sidebar-search-btn{display:flex;align-items:center;width:100%;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);border:none;background-color:transparent;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);box-sizing:border-box;overflow:hidden;gap:var(--spacing-sm)}.sidebar-search-btn{color:var(--textSecondary)}.sidebar-search-btn:hover{background-color:var(--surface);color:var(--text)}.sidebar-logout{color:var(--error)}.sidebar-logout:hover{background-color:var(--error-transparent)}.sidebar-logout-icon,.sidebar-search-icon{width:1rem;height:1rem;flex-shrink:0;margin-right:var(--spacing-sm);color:inherit}.sidebar-collapsed .sidebar-logout-icon,.sidebar-collapsed .sidebar-search-icon{margin-right:0}.sidebar-collapsed .sidebar-logout span,.sidebar-collapsed .sidebar-search-btn span{opacity:0;width:0;margin-left:0;overflow:hidden}.sidebar-collapsed .sidebar-logout,.sidebar-collapsed .sidebar-search-btn{justify-content:center}.sidebar-search-text{flex:1 1;text-align:left;white-space:nowrap;overflow:hidden;color:inherit}.sidebar-search-shortcut{font-size:var(--font-size-xs);color:var(--textSecondary);background:var(--background);padding:.125rem .375rem;border-radius:var(--radius-sm);border:1px solid var(--border);margin-left:auto;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace;line-height:1.2;flex-shrink:0}.sidebar-search-btn:hover .sidebar-search-shortcut{background:var(--surface);border-color:var(--primary);color:var(--primary)}.sidebar-logout-text{margin-left:var(--spacing-sm);transition:opacity var(--transition-normal),width var(--transition-normal);white-space:nowrap;overflow:hidden;flex-shrink:0}.sidebar-collapsed .sidebar-logout-text,.sidebar-collapsed .sidebar-search-shortcut,.sidebar-collapsed .sidebar-search-text{opacity:0;width:0;margin-left:0;overflow:hidden}@media (max-width:768px){.sidebar{left:0;right:auto;top:0;bottom:0;height:auto;min-height:100dvh;box-shadow:var(--shadow-lg);border-radius:0;z-index:1!important}.sidebar,.sidebar-collapsed{width:var(--sidebar-mobile-width)}.sidebar .sidebar-header{padding:var(--spacing-sm);height:3.5rem}.sidebar .sidebar-brand{justify-content:center;width:2rem}.sidebar .sidebar-brand-text,.sidebar .sidebar-text{display:none}.sidebar .sidebar-nav{padding:var(--spacing-sm) 0}.sidebar .sidebar-link:hover .sidebar-tooltip,.sidebar .sidebar-search-btn:hover .sidebar-tooltip{display:none}.sidebar .sidebar-link{justify-content:center;margin:0 var(--spacing-xs);padding:var(--spacing-sm)}.sidebar .sidebar-icon-container{margin-right:0;width:1.5rem;height:1.5rem}.sidebar .sidebar-icon{width:1rem;height:1rem}.sidebar .sidebar-footer{padding:var(--spacing-sm)}.sidebar .sidebar-logout,.sidebar .sidebar-search-btn{justify-content:center;padding:var(--spacing-sm)}}@media (max-width:480px){.sidebar{bottom:0;height:auto;min-height:100dvh}.sidebar,.sidebar-collapsed{width:var(--sidebar-mobile-sm-width)}.sidebar .sidebar-header{padding:var(--spacing-xs);height:3rem}.sidebar .sidebar-brand{width:1.5rem}.sidebar .sidebar-brand-icon{width:1.25rem;height:1.25rem}.sidebar .sidebar-toggle{width:1.5rem;height:1.5rem}.sidebar .sidebar-link{margin:0 var(--spacing-xs);padding:var(--spacing-xs);width:calc(100% - var(--spacing-xs))}.sidebar .sidebar-nav{padding:var(--spacing-xs) 0}.sidebar .sidebar-icon-container{width:1.25rem;height:1.25rem}.sidebar .sidebar-icon{width:.875rem;height:.875rem}.sidebar .sidebar-footer,.sidebar .sidebar-logout,.sidebar .sidebar-search-btn{padding:var(--spacing-xs)}}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:var(--z-sticky);width:100%;background-color:color-mix(in srgb,var(--topbar) 80%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:flex-end;padding:0 var(--spacing-lg);height:var(--topbar-height);gap:var(--spacing-md);box-sizing:border-box;overflow:visible}.topbar-notifications{position:relative}.topbar-notification-btn{position:relative;border-radius:50%;padding:var(--spacing-sm);border:none;background-color:transparent;color:var(--textSecondary);cursor:pointer;transition:all var(--transition-normal)}.topbar-notification-btn:hover{background-color:var(--surface);color:var(--text)}.topbar-notification-icon{width:1.5rem;height:1.5rem}.topbar-notification-badge{position:absolute;top:.25rem;right:.25rem;display:block;width:.5rem;height:.5rem;border-radius:50%;background-color:var(--error);border:2px solid var(--surface)}.topbar-dropdown{position:absolute;right:0;top:calc(100% + var(--spacing-sm));background-color:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--spacing-sm) 0;z-index:var(--z-modal);min-width:200px}.topbar-notifications-dropdown{width:20rem;max-width:90vw;max-height:70vh;overflow-y:auto}.topbar-dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--border)}.topbar-dropdown-title{font-weight:500;color:var(--text);font-size:var(--font-size-sm)}.topbar-mark-read-btn{font-size:var(--font-size-xs);color:var(--primary);background:none;border:none;cursor:pointer;text-decoration:underline}.topbar-mark-read-btn:hover{text-decoration:none}.topbar-notifications-list{max-height:18rem;overflow-y:auto}.topbar-no-notifications{padding:var(--spacing-lg) var(--spacing-md);text-align:center;color:var(--textSecondary);font-size:var(--font-size-sm)}.topbar-notification-item{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-md);font-size:var(--font-size-sm);cursor:pointer;transition:background-color var(--transition-fast);border-bottom:1px solid color-mix(in srgb,var(--border) 50%,transparent)}.topbar-notification-item:hover{background-color:var(--surface)}.topbar-notification-unread{background-color:var(--primary-transparent)}.topbar-notification-type-icon{flex-shrink:0}.topbar-icon-success{width:1.25rem;height:1.25rem;color:var(--success)}.topbar-icon-info{width:1.25rem;height:1.25rem;color:var(--primary)}.topbar-icon-warning{width:1.25rem;height:1.25rem;color:var(--warning)}.topbar-notification-content{flex:1 1;min-width:0}.topbar-notification-title{display:block;font-weight:500;color:var(--text);margin-bottom:var(--spacing-xs)}.topbar-notification-desc{margin-bottom:var(--spacing-xs)}.topbar-notification-desc,.topbar-notification-time{display:block;color:var(--textSecondary);font-size:var(--font-size-xs)}.topbar-notification-dot{width:.5rem;height:.5rem;border-radius:50%;background-color:var(--primary);flex-shrink:0;margin-left:var(--spacing-sm)}.topbar-dropdown-footer{padding:var(--spacing-sm) var(--spacing-md);border-top:1px solid var(--border);text-align:center}.topbar-view-all-link{color:var(--primary);text-decoration:none;font-size:var(--font-size-sm)}.topbar-view-all-link:hover{text-decoration:underline}.topbar-user{position:relative}.topbar-user-btn{display:flex;align-items:center;gap:var(--spacing-sm);border-radius:50px;padding:var(--spacing-sm) var(--spacing-md);border:none;background-color:transparent;cursor:pointer;transition:all var(--transition-normal)}.topbar-user-btn:hover{background-color:var(--surface)}.topbar-user-avatar{width:2rem;height:2rem;border-radius:50%;background-color:var(--primary-transparent);display:flex;align-items:center;justify-content:center}.topbar-user-avatar-icon{width:1.25rem;height:1.25rem;color:var(--primary)}.topbar-user-info{display:flex;flex-direction:column;align-items:flex-start;text-align:left}@media (max-width:640px){.topbar-user-info{display:none}}.topbar-user-name{font-weight:500;color:var(--text);font-size:var(--font-size-sm);line-height:1}.topbar-user-role{font-size:var(--font-size-xs);color:var(--textSecondary);line-height:1}.topbar-user-chevron{width:1rem;height:1rem;color:var(--textSecondary);margin-left:var(--spacing-xs)}@media (max-width:640px){.topbar-user-chevron{display:none}}.topbar-user-dropdown{width:14rem;right:0}.topbar-dropdown-item{display:flex;align-items:center;width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);color:var(--textSecondary);text-decoration:none;border:none;background:none;cursor:pointer;transition:background-color var(--transition-fast);text-align:left}.topbar-dropdown-item:hover{background-color:var(--surface);color:var(--text)}.topbar-logout-item{color:var(--error)}.topbar-logout-item:hover{background-color:var(--error-transparent)}.topbar-dropdown-icon{width:1rem;height:1rem;margin-right:var(--spacing-sm);flex-shrink:0}@media (max-width:768px){.topbar{padding:0 var(--spacing-md);height:var(--topbar-mobile-height);gap:var(--spacing-sm)}.topbar-user-btn{padding:var(--spacing-xs) var(--spacing-sm)}.topbar-user-avatar{width:1.75rem;height:1.75rem}.topbar-notification-btn{padding:var(--spacing-xs)}.topbar-notification-icon{width:1.25rem;height:1.25rem}.topbar-user-chevron,.topbar-user-info{display:none}.topbar-dropdown{right:0;min-width:250px}.topbar-notifications-dropdown,.topbar-user-dropdown{position:fixed;left:var(--spacing-sm);right:var(--spacing-sm);top:calc(var(--topbar-mobile-height) + var(--spacing-sm));width:auto;max-width:none;max-height:calc(100vh - var(--topbar-mobile-height) - (2 * var(--spacing-sm)));overflow-y:auto}}@media (max-width:480px){.topbar{padding:0 var(--spacing-sm);height:var(--topbar-mobile-sm-height);gap:var(--spacing-xs)}.topbar-user-avatar{width:1.5rem;height:1.5rem}.topbar-notification-icon{width:1rem;height:1rem}.topbar-dropdown{right:0;min-width:280px;max-width:calc(100vw - var(--spacing-md))}.topbar-notifications-dropdown,.topbar-user-dropdown{top:calc(var(--topbar-mobile-sm-height) + var(--spacing-sm));max-height:calc(100vh - var(--topbar-mobile-sm-height) - (2 * var(--spacing-sm)))}.topbar-user-detail-truncate{max-width:150px}}.topbar-user-details{padding:var(--spacing-md);border-bottom:1px solid var(--border);margin-bottom:var(--spacing-sm)}.topbar-user-detail-item{display:flex;flex-direction:column;gap:.25rem;margin-bottom:var(--spacing-sm)}.topbar-user-detail-item:last-child{margin-bottom:0}.topbar-user-detail-label{font-size:.75rem;color:var(--textSecondary);font-weight:500}.topbar-user-detail-value{font-size:.875rem;color:var(--text);word-wrap:break-word;overflow-wrap:break-word}.topbar-user-detail-truncate{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px;cursor:help}.topbar-dropdown-divider{height:1px;background-color:var(--border);margin:var(--spacing-sm) 0}.dashboard-container{padding:1rem;width:100%;box-sizing:border-box;overflow:hidden}.dashboard-header{margin-bottom:1rem;width:100%;box-sizing:border-box}.dashboard-title{font-size:1.5rem;font-weight:700;color:var(--text);margin-bottom:.5rem;line-height:1.2}.dashboard-subtitle,.dashboard-title{word-wrap:break-word;overflow-wrap:break-word}.dashboard-subtitle{color:var(--textSecondary);font-size:.875rem;line-height:1.4}.dashboard-user-info{margin-top:1rem;margin-bottom:1rem}.dashboard-user-card{background-color:var(--sidebar);border:1px solid var(--border);border-radius:8px;padding:1rem;display:flex;align-items:center;gap:1rem;box-shadow:0 1px 3px 0 rgba(0,0,0,.1)}.dashboard-user-icon{background-color:var(--primary);color:white;border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-icon{width:24px;height:24px}.dashboard-user-details{flex:1 1;min-width:0}.dashboard-user-name{font-size:1.125rem;font-weight:600;color:var(--text);margin:0 0 .25rem}.dashboard-user-email,.dashboard-user-name{word-wrap:break-word;overflow-wrap:break-word}.dashboard-user-email{font-size:.875rem;color:var(--textSecondary);margin:0 0 .75rem}.dashboard-user-badges{display:flex;flex-direction:column;gap:.5rem}.dashboard-user-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;text-align:center;word-wrap:break-word;overflow-wrap:break-word}.dashboard-user-badge-role{background-color:var(--primary);color:white;max-width:-moz-fit-content;max-width:fit-content}.dashboard-user-badge-clinic{background-color:var(--sidebar);color:var(--text);border:1px solid var(--border);max-width:-moz-fit-content;max-width:fit-content}.dashboard-stats-grid{display:grid;grid-template-columns:1fr;grid-gap:1rem;gap:1rem;margin-bottom:1.5rem;width:100%;box-sizing:border-box}.dashboard-stat-card{background-color:var(--sidebar);border:1px solid var(--border);border-radius:8px;box-shadow:0 1px 3px 0 rgba(0,0,0,.1);overflow:hidden;transition:all .2s ease-in-out;width:100%;box-sizing:border-box}.dashboard-stat-card:hover{box-shadow:0 4px 6px -1px rgba(0,0,0,.1);transform:translateY(-1px)}.dashboard-stat-content{padding:1rem;display:flex;align-items:center;gap:1rem;width:100%;box-sizing:border-box}.dashboard-stat-icon{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:6px;flex-shrink:0}.dashboard-stat-icon-blue{background-color:rgba(79,103,255,.1);color:var(--primary)}.dashboard-stat-icon-green{background-color:rgba(34,197,94,.1);color:var(--success)}.dashboard-stat-icon-purple{background-color:rgba(147,51,234,.1);color:#9333ea}.dashboard-stat-icon-orange{background-color:rgba(249,115,22,.1);color:#f97316}.dashboard-stat-icon-red{background-color:rgba(239,68,68,.1);color:#ef4444}.dashboard-stat-trend{font-size:.75rem;font-weight:500;margin-top:.25rem}.dashboard-stat-trend.trend-positive{color:var(--success)}.dashboard-stat-trend.trend-negative{color:var(--error)}.stat-icon{width:1.5rem;height:1.5rem}.dashboard-stat-data{flex:1 1;min-width:0;overflow:hidden}.dashboard-stat-label{font-size:.875rem;font-weight:500;color:var(--textSecondary);margin-bottom:.25rem;display:block}.dashboard-stat-label,.dashboard-stat-value{word-wrap:break-word;overflow-wrap:break-word}.dashboard-stat-value{font-size:1.5rem;font-weight:700;color:var(--text);line-height:1.1}.dashboard-content-grid{display:grid;grid-template-columns:1fr;grid-gap:1rem;gap:1rem;margin-bottom:1.5rem;width:100%;box-sizing:border-box}.dashboard-card{border:1px solid var(--border);border-radius:8px;box-shadow:0 1px 3px 0 rgba(0,0,0,.1);overflow:hidden}.dashboard-card,.dashboard-card-header{background-color:var(--sidebar);width:100%;box-sizing:border-box}.dashboard-card-header{padding:1rem;border-bottom:1px solid var(--border)}.dashboard-card-title{font-size:1rem;font-weight:600;color:var(--text);margin:0;word-wrap:break-word;overflow-wrap:break-word}.dashboard-card-content{padding:1rem;width:100%;box-sizing:border-box}.dashboard-appointments-list{display:flex;flex-direction:column;gap:.75rem;width:100%;box-sizing:border-box}.dashboard-appointment-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--background);border-radius:6px;transition:background-color .2s ease;width:100%;box-sizing:border-box;overflow:hidden}.dashboard-appointment-item:hover{background:var(--primary-transparent)}.dashboard-appointment-icon{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:var(--primary);border-radius:50%;flex-shrink:0}.appointment-clock-icon{width:1rem;height:1rem;color:var(--white)}.dashboard-appointment-info{flex:1 1;min-width:0;overflow:hidden}.dashboard-appointment-time{font-size:.875rem;font-weight:500;color:var(--text);margin:0 0 .25rem}.dashboard-appointment-time,.dashboard-appointment-type{line-height:1.2;word-wrap:break-word;overflow-wrap:break-word}.dashboard-appointment-type{font-size:.75rem;color:var(--textSecondary);margin:0}.dashboard-activities-list{flex-direction:column}.dashboard-activities-list,.dashboard-activity-item{display:flex;gap:.75rem;width:100%;box-sizing:border-box}.dashboard-activity-item{align-items:center;padding:.75rem;background:var(--background);border-radius:6px;transition:background-color .2s ease;overflow:hidden}.dashboard-activity-item:hover{background:var(--success-transparent)}.dashboard-activity-icon{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:var(--success);border-radius:50%;flex-shrink:0}.activity-check-icon{width:1rem;height:1rem;color:var(--white)}.dashboard-activity-info{flex:1 1;min-width:0;overflow:hidden}.dashboard-activity-action{font-size:.875rem;font-weight:500;color:var(--text);margin:0 0 .25rem}.dashboard-activity-action,.dashboard-activity-details{line-height:1.2;word-wrap:break-word;overflow-wrap:break-word}.dashboard-activity-details{font-size:.75rem;color:var(--textSecondary);margin:0}.dashboard-welcome-card{background:linear-gradient(135deg,var(--primary),rgba(79,103,255,.8));color:var(--white);padding:1.5rem;border-radius:8px;margin-top:1rem;width:100%;box-sizing:border-box;overflow:hidden}.dashboard-welcome-title{font-size:1.125rem;font-weight:600;margin:0 0 .75rem;line-height:1.2;word-wrap:break-word;overflow-wrap:break-word}.dashboard-welcome-text{font-size:.875rem;line-height:1.5;margin:0;opacity:.9;word-wrap:break-word;overflow-wrap:break-word}@media (min-width:768px){.dashboard-container{padding:1.5rem}.dashboard-header{margin-bottom:1.5rem}.dashboard-title{font-size:1.75rem}.dashboard-subtitle{font-size:.95rem}.dashboard-content-grid,.dashboard-stats-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem;margin-bottom:1.75rem}.dashboard-card-content,.dashboard-stat-content{padding:1.25rem}.dashboard-card-title{font-size:1.075rem}}@media (min-width:1024px){.dashboard-container{padding:2rem;max-width:1400px;margin:0 auto}.dashboard-header{margin-bottom:2rem}.dashboard-title{font-size:2rem}.dashboard-subtitle{font-size:1rem}.dashboard-stats-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem}.dashboard-content-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:2rem}.dashboard-stat-content{padding:1.5rem}.dashboard-stat-icon{width:3rem;height:3rem}.dashboard-stat-value{font-size:1.875rem}.dashboard-card-header{padding:1rem 1.5rem}.dashboard-card-content{padding:1.5rem}.dashboard-card-title{font-size:1.125rem}.dashboard-welcome-card{padding:2rem}.dashboard-welcome-title{font-size:1.25rem}}@media (min-width:1280px){.dashboard-stats-grid{grid-template-columns:repeat(4,1fr)}.dashboard-content-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.dashboard-container{padding:.75rem}.dashboard-title{font-size:1.25rem}.dashboard-subtitle{font-size:.8125rem}.dashboard-stat-content{padding:.875rem}.dashboard-stat-icon{width:2rem;height:2rem}.dashboard-stat-value{font-size:1.25rem}.dashboard-stat-label{font-size:.8125rem}.dashboard-card-content,.dashboard-card-header{padding:.875rem}.dashboard-card-title{font-size:.9375rem}.dashboard-activity-action,.dashboard-appointment-time{font-size:.8125rem}.dashboard-activity-details,.dashboard-appointment-type{font-size:.6875rem}.dashboard-welcome-card{padding:1.25rem}.dashboard-welcome-title{font-size:1rem}.dashboard-welcome-text{font-size:.8125rem}}.dashboard-tenants-table-wrapper{overflow-x:auto;width:100%;-webkit-overflow-scrolling:touch}.dashboard-tenants-table{width:100%;border-collapse:collapse;font-size:.875rem;min-width:800px}.dashboard-tenants-table thead{background-color:var(--background);border-bottom:2px solid var(--border)}.dashboard-tenants-table th{padding:.75rem;text-align:left;font-weight:600;color:var(--text);font-size:.8125rem;white-space:nowrap}.dashboard-tenants-table td{padding:.75rem;border-bottom:1px solid var(--border);color:var(--text)}.dashboard-tenants-table tbody tr{transition:background-color .2s ease}.dashboard-tenants-table tbody tr:hover{background-color:var(--primary-transparent)}.dashboard-tenants-table tbody tr:last-child td{border-bottom:none}.dashboard-tenants-table .tenant-name{font-weight:500;color:var(--text)}.dashboard-tenants-table .status-pending{background-color:rgba(249,115,22,.1);color:#f97316}.dashboard-tenants-table .status-approved,.dashboard-tenants-table .status-pending{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-weight:500;font-size:.75rem}.dashboard-tenants-table .status-approved{background-color:rgba(34,197,94,.1);color:var(--success)}.dashboard-loading{display:flex;align-items:center;justify-content:center;min-height:400px;width:100%}.dashboard-error{width:100%;padding:2rem}.dashboard-error-content{background-color:var(--error-transparent);border:1px solid var(--error);border-radius:8px;padding:1.5rem;text-align:center}.dashboard-error-content h3{font-size:1.125rem;font-weight:600;color:var(--error);margin:0 0 .5rem}.dashboard-error-content p{font-size:.875rem;color:var(--text);margin:0}.dashboard-empty{padding:2rem;text-align:center;color:var(--textSecondary)}.dashboard-placeholder{padding:2rem;text-align:center;background-color:var(--surface);border:1px solid var(--border);border-radius:8px}.dashboard-placeholder h3{font-size:1.125rem;font-weight:600;color:var(--text);margin:0 0 .5rem}.dashboard-placeholder p{font-size:.875rem;color:var(--textSecondary);margin:0}.dashboard-unknown-role{padding:2rem;text-align:center;color:var(--error)}@media (max-width:768px){.dashboard-tenants-table{font-size:.75rem}.dashboard-tenants-table td,.dashboard-tenants-table th{padding:.5rem}.dashboard-tenants-table th{font-size:.75rem}}.common-dashboard{width:100%}.common-dashboard>.dashboard-card{margin-bottom:1.5rem}.common-dashboard>.dashboard-card:last-child{margin-bottom:0}.common-dashboard .dashboard-charts-grid{margin-bottom:1.5rem}.dashboard-period-filter-wrapper{margin-bottom:1.5rem;width:100%;box-sizing:border-box}.dashboard-period-filter{display:flex;align-items:center;gap:1rem;padding:1rem;background-color:var(--sidebar);border:1px solid var(--border);border-radius:8px;box-shadow:0 1px 3px 0 rgba(0,0,0,.1);flex-wrap:wrap;width:100%;box-sizing:border-box}.dashboard-period-filter-header{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.dashboard-period-filter-icon{width:1.25rem;height:1.25rem;color:var(--primary)}.dashboard-period-filter-label{font-size:.875rem;font-weight:500;color:var(--text);white-space:nowrap}.dashboard-period-filter-buttons{display:flex;gap:.5rem;flex-wrap:wrap;flex:1 1}.dashboard-period-filter-btn{padding:.5rem 1rem;border:1px solid var(--border);border-radius:6px;background-color:var(--background);color:var(--text);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.dashboard-period-filter-btn:hover{background-color:var(--primary-transparent);border-color:var(--primary);color:var(--primary)}.dashboard-period-filter-btn.active{background-color:var(--primary);border-color:var(--primary);color:white}.dashboard-period-filter-btn.active:hover{background-color:var(--primary);opacity:.9}.dashboard-charts-grid{display:grid;grid-template-columns:1fr;grid-gap:1rem;gap:1rem;margin-bottom:1.5rem;width:100%;box-sizing:border-box}.dashboard-chart-container{width:100%;height:300px;padding:1rem;box-sizing:border-box}.dashboard-doctors-table-wrapper{overflow-x:auto;width:100%;-webkit-overflow-scrolling:touch}.dashboard-doctors-table{width:100%;border-collapse:collapse;font-size:.875rem;min-width:600px}.dashboard-doctors-table thead{background-color:var(--background);border-bottom:2px solid var(--border)}.dashboard-doctors-table th{padding:.75rem;text-align:left;font-weight:600;color:var(--text);font-size:.8125rem;white-space:nowrap}.dashboard-doctors-table td{padding:.75rem;border-bottom:1px solid var(--border);color:var(--text)}.dashboard-doctors-table tbody tr{transition:background-color .2s ease}.dashboard-doctors-table tbody tr:hover{background-color:var(--primary-transparent)}.dashboard-doctors-table tbody tr:last-child td{border-bottom:none}.dashboard-doctors-table .doctor-name{font-weight:500;color:var(--text)}.dashboard-doctors-table .appointments-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;background-color:rgba(79,103,255,.1);color:var(--primary);font-weight:600;font-size:.875rem}.dashboard-pending-appointments{display:flex;flex-direction:column;gap:.75rem;width:100%;box-sizing:border-box}.pending-appointment-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--background);border-radius:6px;transition:background-color .2s ease;width:100%;box-sizing:border-box;overflow:hidden}.pending-appointment-item:hover{background:var(--primary-transparent)}.pending-appointment-icon{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:rgba(249,115,22,.1);border-radius:50%;flex-shrink:0}.pending-appointment-icon .appointment-clock-icon{width:1rem;height:1rem;color:#f97316}.pending-appointment-info{flex:1 1;min-width:0;overflow:hidden}.pending-appointment-title{font-size:.875rem;font-weight:500;color:var(--text);margin:0 0 .25rem}.pending-appointment-details,.pending-appointment-title{line-height:1.2;word-wrap:break-word;overflow-wrap:break-word}.pending-appointment-details{font-size:.75rem;color:var(--textSecondary);margin:0}.dashboard-empty-state{padding:2rem;text-align:center;color:var(--textSecondary)}.dashboard-empty-state p{margin:0;font-size:.875rem}@media (min-width:768px){.dashboard-charts-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}.dashboard-chart-container{height:350px;padding:1.25rem}}@media (min-width:1024px){.dashboard-charts-grid{gap:1.5rem}.dashboard-chart-container{height:400px;padding:1.5rem}}@media (max-width:768px){.dashboard-doctors-table{font-size:.75rem;min-width:500px}.dashboard-doctors-table td,.dashboard-doctors-table th{padding:.5rem}.dashboard-doctors-table th{font-size:.75rem}.dashboard-chart-container{height:250px;padding:.75rem}.dashboard-period-filter{flex-direction:column;align-items:flex-start;gap:.75rem}.dashboard-period-filter-buttons{width:100%}.dashboard-period-filter-btn{flex:1 1;min-width:0}}.appointments-page{background:var(--background);min-height:100vh;width:100%;max-width:100%;box-sizing:border-box}.appointments-page-content{padding:var(--spacing-lg)}.appointments-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);flex-wrap:wrap;gap:var(--spacing-md);width:100%;box-sizing:border-box}.appointments-header-content{flex:1 1;min-width:0;overflow:hidden}.appointments-title{font-size:var(--font-size-3xl);font-weight:700;color:var(--text);margin:0;line-height:1.2}.appointments-subtitle,.appointments-title{word-wrap:break-word;overflow-wrap:break-word}.appointments-subtitle{color:var(--textSecondary);margin:var(--spacing-sm) 0 0 0;font-size:var(--font-size-md)}.appointments-new-button{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.appointments-filters{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-sm);width:100%;box-sizing:border-box;overflow:hidden}.appointments-filters-content{display:flex;flex-direction:column;gap:var(--spacing-md);width:100%;box-sizing:border-box}.appointments-search-container{flex:1 1;width:100%;box-sizing:border-box}.appointments-search-input-wrapper{position:relative;width:100%;box-sizing:border-box}.appointments-search-icon{position:absolute;left:var(--spacing-sm);top:50%;transform:translateY(-50%);width:1rem;height:1rem;color:var(--textSecondary)}.appointments-search-input{width:100%;padding:var(--spacing-sm) var(--spacing-sm) var(--spacing-sm) 2.5rem;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);color:var(--text);font-size:var(--font-size-md);transition:all var(--transition-normal);box-sizing:border-box}.appointments-search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-transparent)}.appointments-filter-button{display:flex;align-items:center;gap:var(--spacing-sm);white-space:nowrap;flex-shrink:0}.appointments-main-content{display:grid;grid-template-columns:1fr;grid-gap:var(--spacing-lg);gap:var(--spacing-lg)}.appointments-list-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden}.appointments-list-header{padding:var(--spacing-lg);border-bottom:1px solid var(--border);background:var(--surface)}.appointments-list-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text);margin:0}.appointments-list-content{padding:var(--spacing-lg)}.appointments-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.appointment-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);transition:all var(--transition-normal);cursor:pointer}.appointment-item:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-1px)}.appointment-info{display:flex;align-items:center;gap:var(--spacing-md);flex:1 1;min-width:0}.appointment-avatar{width:3rem;height:3rem;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.appointment-avatar-icon{width:1.5rem;height:1.5rem;color:white}.appointment-details{flex:1 1;min-width:0}.appointment-patient-name{font-size:var(--font-size-md);font-weight:600;color:var(--text);margin:0 0 var(--spacing-xs) 0;line-height:1.4}.appointment-meta{font-size:var(--font-size-sm);color:var(--textSecondary);margin:0}.appointment-schedule{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-xs)}.appointment-datetime{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--textSecondary)}.appointment-date{font-weight:500;color:var(--text)}.appointment-time{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--textSecondary)}.appointment-time-icon{width:.875rem;height:.875rem}.appointment-status{padding:var(--spacing-xs) var(--spacing-sm);border-radius:9999px;font-size:var(--font-size-xs);font-weight:500;text-transform:capitalize;white-space:nowrap}.appointment-status-confirmed{background:var(--success);color:white}.appointment-status-pending{background:var(--warning);color:white}.appointment-status-cancelled{background:var(--error);color:white}.appointment-status-completed{background:var(--secondary);color:white}.appointments-empty-state{text-align:center;padding:var(--spacing-2xl) var(--spacing-lg);color:var(--textSecondary)}.appointments-empty-icon{width:4rem;height:4rem;margin:0 auto var(--spacing-lg) auto;opacity:.5}.appointments-empty-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text);margin:0 0 var(--spacing-sm) 0}.appointments-empty-description{font-size:var(--font-size-sm);color:var(--textSecondary);margin:0}.appointments-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl) var(--spacing-lg);color:var(--textSecondary)}.appointments-loading-spinner{width:3rem;height:3rem;border-top:3px solid var(--border);border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:var(--spacing-lg)}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:768px){.appointments-page{padding:var(--spacing-sm)}.appointments-header{flex-direction:column;align-items:stretch;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.appointments-new-button{justify-content:center}.appointments-filters{padding:var(--spacing-md)}.appointments-filters-content{gap:var(--spacing-sm)}.appointments-search-input{padding:var(--spacing-sm) var(--spacing-sm) var(--spacing-sm) 2.5rem}.appointment-item{flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}.appointment-info{flex-direction:column;text-align:center}.appointment-datetime,.appointment-schedule,.appointment-time{justify-content:center}.appointments-list-content,.appointments-list-header{padding:var(--spacing-md)}}@media (max-width:480px){.appointments-page{padding:var(--spacing-xs)}.appointments-title{font-size:var(--font-size-2xl)}.appointments-header{margin-bottom:var(--spacing-sm)}.appointments-filters{padding:var(--spacing-sm)}.appointment-item{padding:var(--spacing-md)}.appointment-avatar{width:2.5rem;height:2.5rem}.appointment-avatar-icon{width:1.25rem;height:1.25rem}.appointment-patient-name{font-size:var(--font-size-sm)}.appointment-datetime,.appointment-meta,.appointment-status,.appointment-time{font-size:var(--font-size-xs)}.appointment-status{padding:var(--spacing-xs) var(--spacing-sm)}}.auth-page{min-height:100vh;background:var(--background);display:flex;width:100vw;overflow:hidden}.auth-left{background:var(--surface)}.auth-left,.auth-right{flex:1 1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl)}.auth-right{background:var(--background)}.auth-container{width:100%;max-width:400px}.auth-brand{text-align:center;max-width:384px}.auth-icon{width:4rem;height:4rem;margin:0 auto var(--spacing-2xl);background:var(--primary);border-radius:16px;display:flex;align-items:center;justify-content:center}.auth-icon svg{width:2rem;height:2rem;color:white}.auth-brand-title{font-size:var(--font-size-2xl);font-weight:600;color:var(--text);margin-bottom:var(--spacing-sm)}.auth-brand-subtitle{color:var(--textSecondary);font-size:var(--font-size-sm);line-height:1.4}.auth-tip{background:color-mix(in srgb,var(--primary) 5%,transparent);border-radius:var(--radius-md);padding:var(--spacing-lg);text-align:left;margin-top:var(--spacing-2xl)}.auth-tip-title{font-weight:500;color:var(--text);margin-bottom:var(--spacing-sm);font-size:var(--font-size-sm)}.auth-tip-text{font-size:var(--font-size-xs);color:var(--textSecondary);line-height:1.4;margin:0}.auth-back-btn{position:absolute;top:var(--spacing-md);left:var(--spacing-md);display:inline-flex;align-items:center;gap:var(--spacing-sm);color:var(--textSecondary);text-decoration:none;font-size:var(--font-size-sm);transition:color var(--transition-fast)}.auth-back-btn:hover{color:var(--text)}.auth-theme-toggle{position:absolute;top:var(--spacing-md);right:var(--spacing-md)}@media (max-width:1024px){.auth-right{display:none}.auth-left{flex:none;width:100%}}@media (max-width:768px){.auth-left{padding:var(--spacing-lg)}.auth-container{max-width:100%}.auth-back-btn{top:var(--spacing-sm);left:var(--spacing-sm)}.auth-theme-toggle{top:var(--spacing-sm);right:var(--spacing-sm)}}@media (max-width:480px){.auth-left{padding:var(--spacing-md)}.auth-back-btn{top:.5rem;left:.5rem;font-size:var(--font-size-sm)}.auth-theme-toggle{top:.5rem;right:.5rem}}