:root{--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-300: #93c5fd;--primary-400: #60a5fa;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--primary-800: #1e40af;--primary-900: #1e3a8a;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--success-50: #ecfdf5;--success-100: #d1fae5;--success-500: #10b981;--success-600: #059669;--error-50: #fef2f2;--error-100: #fee2e2;--error-500: #ef4444;--error-600: #dc2626;--warning-50: #fffbeb;--warning-100: #fef3c7;--warning-500: #f59e0b;--warning-600: #d97706;--font-family-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--spacing-16: 4rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25)}body{font-family:var(--font-family-sans);background:linear-gradient(135deg,var(--gray-50) 0%,var(--primary-50) 100%);color:var(--gray-900);line-height:1.6;font-size:var(--font-size-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.enhanced-app-container{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,var(--gray-50) 0%,var(--primary-50) 100%)}.enhanced-navbar{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--gray-200);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:50;transition:all var(--transition-normal)}.navbar-content{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-4) var(--spacing-6);max-width:1400px;margin:0 auto}.navbar-left{display:flex;align-items:center;gap:var(--spacing-4)}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;background:var(--gray-100);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);color:var(--gray-600)}.sidebar-toggle:hover{background:var(--primary-100);color:var(--primary-600);transform:translateY(-1px)}.sidebar-toggle-icon{width:1.25rem;height:1.25rem}.navbar-brand{display:flex;align-items:center;gap:var(--spacing-3)}.brand-icon{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;background:linear-gradient(135deg,var(--primary-600),var(--primary-700));border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}@media (max-width: 54px){.brand-icon{display:none}}.navbar-brand-icon{width:1.25rem;height:1.25rem;color:#fff}.navbar-brand-text{font-size:var(--font-size-xl);font-weight:700;color:var(--gray-900);letter-spacing:-.025em}.navbar-right{display:flex;align-items:center;gap:var(--spacing-4)}.user-info{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-4);background:var(--gray-50);border-radius:var(--radius-xl);border:1px solid var(--gray-200)}.user-avatar{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));border-radius:50%;box-shadow:var(--shadow-sm)}.user-avatar-icon{width:1rem;height:1rem;color:#fff}.user-details{display:flex;flex-direction:column;gap:.125rem}.user-name{font-size:var(--font-size-sm);font-weight:600;color:var(--gray-900);line-height:1.2}.user-role{font-size:var(--font-size-xs);color:var(--gray-500);line-height:1.2}.logout-button{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;background:var(--error-50);border:1px solid var(--error-200);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);color:var(--error-600)}.logout-button:hover{background:var(--error-100);border-color:var(--error-300);transform:translateY(-1px)}.logout-icon{width:1.125rem;height:1.125rem}.enhanced-sidebar{position:fixed;top:0;left:-320px;width:320px;height:100vh;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--gray-200);box-shadow:var(--shadow-xl);transition:all var(--transition-normal);z-index:40;overflow-y:auto}.enhanced-sidebar.sidebar-open{left:0}.sidebar-header{padding:var(--spacing-8) var(--spacing-6) var(--spacing-6);border-bottom:1px solid var(--gray-200);background:linear-gradient(135deg,var(--primary-50),var(--primary-100))}.sidebar-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--gray-900);margin-bottom:var(--spacing-1);letter-spacing:-.025em}.sidebar-subtitle{font-size:var(--font-size-sm);color:var(--gray-600);font-weight:500}.sidebar-content{padding:var(--spacing-6);display:flex;flex-direction:column;gap:var(--spacing-2)}.sidebar-item{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-4);background:transparent;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%;position:relative;overflow:hidden}.sidebar-item:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));opacity:0;transition:opacity var(--transition-fast);z-index:-1}.sidebar-item:hover:before{opacity:.05}.sidebar-item-active:before{opacity:.1}.sidebar-item:hover{transform:translate(4px);box-shadow:var(--shadow-md)}.sidebar-item-active{background:linear-gradient(135deg,var(--primary-50),var(--primary-100));border:1px solid var(--primary-200);box-shadow:var(--shadow-sm)}.sidebar-item-icon{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;background:var(--gray-100);border-radius:var(--radius-lg);color:var(--gray-600);transition:all var(--transition-fast)}.sidebar-item-active .sidebar-item-icon{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;box-shadow:var(--shadow-md)}.sidebar-item-icon svg{width:1.25rem;height:1.25rem}.sidebar-item-content{display:flex;flex-direction:column;gap:.125rem;flex:1}.sidebar-item-title{font-size:var(--font-size-base);font-weight:600;color:var(--gray-900);line-height:1.2}.sidebar-item-subtitle{font-size:var(--font-size-xs);color:var(--gray-500);line-height:1.2}.enhanced-main-wrapper{flex:1;margin-left:0;transition:margin-left var(--transition-normal);min-height:calc(100vh - 80px)}.enhanced-main-wrapper.sidebar-open{margin-left:320px}.enhanced-main-content{padding:var(--spacing-8) var(--spacing-6);max-width:1400px;margin:0 auto;animation:fadeInUp .6s ease-out}.page-header{margin-bottom:var(--spacing-8)}.header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-6);flex-wrap:wrap}.header-text{flex:1;min-width:300px}.page-title{font-size:var(--font-size-4xl);font-weight:800;color:var(--gray-900);margin-bottom:var(--spacing-2);letter-spacing:-.025em;background:linear-gradient(135deg,var(--gray-900),var(--primary-600));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-subtitle{font-size:var(--font-size-lg);color:var(--gray-600);font-weight:500;line-height:1.5}.refresh-button{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-5);background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;border:none;border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-md)}.refresh-button:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-600),var(--primary-700));transform:translateY(-2px);box-shadow:var(--shadow-lg)}.refresh-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.refresh-icon{width:1rem;height:1rem}.alert{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-4) var(--spacing-5);border-radius:var(--radius-lg);margin-bottom:var(--spacing-6);font-size:var(--font-size-sm);font-weight:500;border:1px solid;animation:slideInDown .3s ease-out}@keyframes slideInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-alert{background:var(--error-50);color:var(--error-600);border-color:var(--error-200)}.success-alert{background:var(--success-50);color:var(--success-600);border-color:var(--success-200)}.info-alert{background:var(--primary-50);color:var(--primary-600);border-color:var(--primary-200)}.alert-icon{width:1.25rem;height:1.25rem;flex-shrink:0}.profile-grid{display:grid;grid-template-columns:2fr 1fr;gap:var(--spacing-8)}.profile-main-card{background:#fffc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--gray-200);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);overflow:hidden;transition:all var(--transition-normal)}.profile-main-card:hover{box-shadow:var(--shadow-2xl);transform:translateY(-2px)}.profile-header-section{display:flex;align-items:center;gap:var(--spacing-6);padding:var(--spacing-8);background:linear-gradient(135deg,var(--primary-50),var(--primary-100));border-bottom:1px solid var(--gray-200)}.profile-avatar-large{position:relative;display:flex;align-items:center;justify-content:center;width:5rem;height:5rem;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));border-radius:50%;box-shadow:var(--shadow-lg);flex-shrink:0}.profile-avatar-icon-large{width:2.5rem;height:2.5rem;color:#fff}.avatar-status{position:absolute;bottom:.25rem;right:.25rem;width:1rem;height:1rem;border-radius:50%;border:2px solid white;box-shadow:var(--shadow-sm)}.avatar-status.online{background:var(--success-500)}.profile-info{flex:1}.profile-name{font-size:var(--font-size-3xl);font-weight:700;color:var(--gray-900);margin-bottom:var(--spacing-3);letter-spacing:-.025em}.profile-badges{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.badge{padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.badge.primary{background:var(--primary-100);color:var(--primary-700)}.badge.secondary{background:var(--gray-100);color:var(--gray-700)}.badge.success{background:var(--success-100);color:var(--success-700)}.badge.warning{background:var(--warning-100);color:var(--warning-700)}.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-4);padding:var(--spacing-6) var(--spacing-8);border-bottom:1px solid var(--gray-200)}.stat-card{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-4);background:var(--gray-50);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.stat-card:hover{background:var(--primary-50);transform:translateY(-1px)}.stat-icon{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));border-radius:var(--radius-lg);color:#fff;box-shadow:var(--shadow-md)}.stat-icon .icon{width:1.25rem;height:1.25rem}.stat-content{flex:1}.stat-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--gray-900);line-height:1.2}.stat-label{font-size:var(--font-size-xs);color:var(--gray-600);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.contact-info{padding:var(--spacing-8)}.section-title{font-size:var(--font-size-xl);font-weight:700;color:var(--gray-900);margin-bottom:var(--spacing-6);letter-spacing:-.025em}.contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4)}.contact-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-4);background:var(--gray-50);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.contact-item:hover{background:var(--primary-50);transform:translateY(-1px)}.contact-icon{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:var(--primary-100);border-radius:var(--radius-md);font-size:var(--font-size-sm);flex-shrink:0}.contact-details{display:flex;flex-direction:column;gap:.125rem;flex:1}.contact-label{font-size:var(--font-size-xs);color:var(--gray-500);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.contact-value{font-size:var(--font-size-sm);color:var(--gray-900);font-weight:600}.profile-side-panel{display:flex;flex-direction:column;gap:var(--spacing-6)}.rating-overview-card,.recent-reviews-card{background:#fffc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--gray-200);border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg);overflow:hidden;transition:all var(--transition-normal)}.rating-overview-card:hover,.recent-reviews-card:hover{box-shadow:var(--shadow-xl);transform:translateY(-2px)}.rating-overview-card{padding:var(--spacing-6)}.rating-summary{margin-top:var(--spacing-4)}.rating-display{text-align:center;padding:var(--spacing-6);background:linear-gradient(135deg,var(--primary-50),var(--primary-100));border-radius:var(--radius-lg);margin-bottom:var(--spacing-6)}.rating-number{font-size:var(--font-size-4xl);font-weight:800;color:var(--primary-600);line-height:1;margin-bottom:var(--spacing-2)}.rating-stars{display:flex;justify-content:center;gap:var(--spacing-1);margin-bottom:var(--spacing-2)}.star{width:1.25rem;height:1.25rem;transition:all var(--transition-fast)}.star.filled{color:#fbbf24;fill:currentColor}.star.half-filled{color:#fbbf24;fill:currentColor;opacity:.5}.star.empty{color:var(--gray-300);fill:none}.rating-text{font-size:var(--font-size-sm);color:var(--gray-600);font-weight:500}.rating-breakdown{display:flex;flex-direction:column;gap:var(--spacing-2)}.rating-row{display:flex;align-items:center;gap:var(--spacing-3)}.rating-label{font-size:var(--font-size-sm);font-weight:600;color:var(--gray-700);min-width:2rem}.rating-bar-container{flex:1;height:.5rem;background:var(--gray-200);border-radius:var(--radius-sm);overflow:hidden}.rating-bar{height:100%;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));border-radius:var(--radius-sm);transition:width var(--transition-normal)}.rating-count{font-size:var(--font-size-sm);font-weight:600;color:var(--gray-600);min-width:1.5rem;text-align:right}.recent-reviews-card{padding:var(--spacing-6)}.reviews-list{margin-top:var(--spacing-4);display:flex;flex-direction:column;gap:var(--spacing-4)}.review-item{padding:var(--spacing-4);background:var(--gray-50);border-radius:var(--radius-lg);border:1px solid var(--gray-200);transition:all var(--transition-fast)}.review-item:hover{background:var(--primary-50);border-color:var(--primary-200);transform:translateY(-1px)}.review-header{display:flex;align-items:flex-start;gap:var(--spacing-3);margin-bottom:var(--spacing-3)}.reviewer-avatar{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));border-radius:50%;flex-shrink:0}.reviewer-icon{width:1rem;height:1rem;color:#fff}.reviewer-info{flex:1}.reviewer-name{font-size:var(--font-size-sm);font-weight:600;color:var(--gray-900);margin-bottom:var(--spacing-1)}.review-rating{display:flex;gap:.125rem}.review-date{font-size:var(--font-size-xs);color:var(--gray-500);font-weight:500}.review-comment{font-size:var(--font-size-sm);color:var(--gray-700);line-height:1.5;margin-bottom:var(--spacing-3)}.review-meta{display:flex;align-items:center;gap:var(--spacing-2);flex-wrap:wrap}.service-name{font-size:var(--font-size-xs);color:var(--gray-600);font-weight:500;padding:var(--spacing-1) var(--spacing-2);background:var(--gray-200);border-radius:var(--radius-sm)}.recommend-badge{font-size:var(--font-size-xs);color:var(--success-600);font-weight:600;padding:var(--spacing-1) var(--spacing-2);background:var(--success-100);border-radius:var(--radius-sm)}.schedule-layout{display:grid;grid-template-columns:2fr 1fr;gap:var(--spacing-8)}.appointments-section{background:#fffc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--gray-200);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);overflow:hidden;transition:all var(--transition-normal)}.appointments-section:hover{box-shadow:var(--shadow-2xl);transform:translateY(-2px)}.section-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-6) var(--spacing-8);background:linear-gradient(135deg,var(--primary-50),var(--primary-100));border-bottom:1px solid var(--gray-200)}.appointment-count{font-size:var(--font-size-sm);color:var(--primary-600);font-weight:600;padding:var(--spacing-1) var(--spacing-3);background:var(--primary-100);border-radius:var(--radius-md)}.appointments-list{padding:var(--spacing-6) var(--spacing-8);max-height:600px;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-4)}.appointment-card{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-5);background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.appointment-card:hover{background:var(--primary-50);border-color:var(--primary-200);transform:translateY(-2px);box-shadow:var(--shadow-md)}.appointment-date-badge{display:flex;flex-direction:column;align-items:center;justify-content:center;width:3.5rem;height:3.5rem;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));border-radius:var(--radius-lg);color:#fff;flex-shrink:0;box-shadow:var(--shadow-md)}.date-day{font-size:var(--font-size-lg);font-weight:700;line-height:1}.date-month{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.appointment-details{flex:1}.appointment-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-2)}.appointment-title{font-size:var(--font-size-lg);font-weight:700;color:var(--gray-900);line-height:1.2}.status-badge{padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.status-badge.booked{background:var(--primary-100);color:var(--primary-700)}.status-badge.completed{background:var(--success-100);color:var(--success-700)}.status-badge.pending{background:var(--warning-100);color:var(--warning-700)}.appointment-info{display:flex;flex-direction:column;gap:var(--spacing-1)}.info-item{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--gray-600)}.info-icon{width:1rem;height:1rem;color:var(--gray-400);flex-shrink:0}.appointment-price{display:flex;flex-direction:column;align-items:flex-end;gap:var(--spacing-1);flex-shrink:0}.price-amount{font-size:var(--font-size-lg);font-weight:700;color:var(--primary-600)}.duration{font-size:var(--font-size-xs);color:var(--gray-500);font-weight:500}.next-appointment-section{display:flex;flex-direction:column;gap:var(--spacing-4)}.next-appointment-card{background:#fffc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--gray-200);border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg);padding:var(--spacing-6);transition:all var(--transition-normal)}.next-appointment-card:hover{box-shadow:var(--shadow-xl);transform:translateY(-2px)}.next-appointment-content{display:flex;gap:var(--spacing-4)}.next-date-display{display:flex;flex-direction:column;align-items:center;justify-content:center;width:4rem;height:4rem;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));border-radius:var(--radius-lg);color:#fff;flex-shrink:0;box-shadow:var(--shadow-md)}.next-date-large{font-size:var(--font-size-xl);font-weight:800;line-height:1}.next-date-info{display:flex;flex-direction:column;align-items:center;gap:.125rem}.next-month{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.next-year{font-size:var(--font-size-xs);font-weight:500;opacity:.8}.next-appointment-details{flex:1}.next-title{font-size:var(--font-size-lg);font-weight:700;color:var(--gray-900);margin-bottom:var(--spacing-3)}.next-info-list{display:flex;flex-direction:column;gap:var(--spacing-2);margin-bottom:var(--spacing-3)}.next-info-item{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--gray-600)}.next-icon{width:1rem;height:1rem;color:var(--gray-400);flex-shrink:0}.next-price{font-size:var(--font-size-xl);font-weight:700;color:var(--primary-600)}.attendance-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-8)}.attendance-main-card,.attendance-history-card{background:#fffc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--gray-200);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);overflow:hidden;transition:all var(--transition-normal)}.attendance-main-card:hover,.attendance-history-card:hover{box-shadow:var(--shadow-2xl);transform:translateY(-2px)}.attendance-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-6) var(--spacing-8);background:linear-gradient(135deg,var(--primary-50),var(--primary-100));border-bottom:1px solid var(--gray-200)}.card-title{font-size:var(--font-size-xl);font-weight:700;color:var(--gray-900);letter-spacing:-.025em}.attendance-status{display:flex;align-items:center;gap:var(--spacing-2)}.status-indicator{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background:#fffc;border-radius:var(--radius-md);border:1px solid var(--gray-200)}.status-dot{width:.75rem;height:.75rem;border-radius:50%;animation:pulse 2s infinite}.status-indicator.checked-in .status-dot{background:var(--success-500)}.status-indicator.checked-out .status-dot{background:var(--gray-400)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-text{font-size:var(--font-size-sm);font-weight:600;color:var(--gray-700)}.time-display-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-4);padding:var(--spacing-8);border-bottom:1px solid var(--gray-200)}.time-card{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-4);background:var(--gray-50);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.time-card:hover{background:var(--primary-50);transform:translateY(-1px)}.time-icon{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:var(--radius-lg);color:#fff;box-shadow:var(--shadow-md)}.time-icon.check-in{background:linear-gradient(135deg,var(--success-500),var(--success-600))}.time-icon.check-out{background:linear-gradient(135deg,var(--error-500),var(--error-600))}.time-icon .icon{width:1.25rem;height:1.25rem}.time-info{display:flex;flex-direction:column;gap:.125rem;flex:1}.time-label{font-size:var(--font-size-xs);color:var(--gray-500);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.time-value{font-size:var(--font-size-lg);font-weight:700;color:var(--gray-900)}.attendance-actions{display:flex;gap:var(--spacing-4);padding:var(--spacing-6) var(--spacing-8);border-bottom:1px solid var(--gray-200)}.action-button{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-5);border:none;border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-md);flex:1;justify-content:center}.check-in-btn{background:linear-gradient(135deg,var(--success-500),var(--success-500));color:#2c2b2b}.check-in-btn:hover:not(.disabled){background:linear-gradient(135deg,var(--success-600),var(--success-700));transform:translateY(-2px);box-shadow:var(--shadow-lg)}.check-out-btn{background:linear-gradient(135deg,var(--error-500),var(--error-600));color:#2c2b2b}.check-out-btn:hover:not(.disabled){background:linear-gradient(135deg,var(--error-600),var(--error-700));transform:translateY(-2px);box-shadow:var(--shadow-lg)}.absent-btn{background:linear-gradient(135deg,var(--warning-500),var(--warning-600));color:#2c2b2b}.absent-btn:hover{background:linear-gradient(135deg,var(--warning-600),var(--warning-700));transform:translateY(-2px);box-shadow:var(--shadow-lg)}.action-button.disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-icon{width:1rem;height:1rem}.absent-section{padding:var(--spacing-6) var(--spacing-8)}.absent-form{margin-top:var(--spacing-4);padding:var(--spacing-4);background:var(--gray-50);border-radius:var(--radius-lg);border:1px solid var(--gray-200)}.absent-textarea{width:100%;padding:var(--spacing-3);border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-family:inherit;resize:vertical;min-height:4rem;margin-bottom:var(--spacing-3);transition:border-color var(--transition-fast)}.absent-textarea:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f61a}.form-actions{display:flex;gap:var(--spacing-3)}.submit-btn{padding:var(--spacing-2) var(--spacing-4);background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast);flex:1}.submit-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-600),var(--primary-700));transform:translateY(-1px)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.cancel-btn{padding:var(--spacing-2) var(--spacing-4);background:var(--gray-200);color:var(--gray-700);border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast);flex:1}.cancel-btn:hover{background:var(--gray-300);transform:translateY(-1px)}.attendance-history-card{padding:var(--spacing-6) var(--spacing-8)}.history-list{margin-top:var(--spacing-4);max-height:500px;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-3)}.history-group{display:flex;flex-direction:column;gap:var(--spacing-2)}.history-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3);background:var(--gray-50);border-radius:var(--radius-lg);border:1px solid var(--gray-200);transition:all var(--transition-fast)}.history-item:hover{background:var(--primary-50);border-color:var(--primary-200);transform:translateY(-1px)}.history-icon{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:var(--radius-md);color:#fff;flex-shrink:0;box-shadow:var(--shadow-sm)}.history-icon.check-in{background:linear-gradient(135deg,var(--success-500),var(--success-600))}.history-icon.check-out{background:linear-gradient(135deg,var(--error-500),var(--error-600))}.history-icon.absent{background:linear-gradient(135deg,var(--warning-500),var(--warning-600))}.history-icon .icon{width:1rem;height:1rem}.history-content{display:flex;flex-direction:column;gap:.125rem;flex:1}.history-action{font-size:var(--font-size-sm);font-weight:600;color:var(--gray-900)}.history-time{font-size:var(--font-size-xs);color:var(--gray-600);font-weight:500}.history-hours{font-size:var(--font-size-xs);color:var(--gray-500);font-style:italic}.loading-state{display:flex;align-items:center;justify-content:center;gap:var(--spacing-3);padding:var(--spacing-8);color:var(--gray-600)}.loading-state.large{padding:var(--spacing-12);flex-direction:column;text-align:center}.loading-spinner{width:1.5rem;height:1.5rem;border:2px solid var(--gray-200);border-top:2px solid var(--primary-500);border-radius:50%;animation:spin 1s linear infinite}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8);text-align:center;color:var(--gray-500)}.empty-state.large{padding:var(--spacing-12)}.empty-icon{width:3rem;height:3rem;color:var(--gray-300);margin-bottom:var(--spacing-4)}.empty-state h3,.empty-state h4{font-size:var(--font-size-lg);font-weight:600;color:var(--gray-700);margin-bottom:var(--spacing-2)}.empty-state p{font-size:var(--font-size-sm);color:var(--gray-500);line-height:1.5}@media (max-width: 1200px){.profile-grid,.schedule-layout,.attendance-layout{grid-template-columns:1fr;gap:var(--spacing-6)}}@media (max-width: 768px){.enhanced-main-wrapper.sidebar-open{margin-left:0}.enhanced-sidebar.sidebar-open{width:100vw}.enhanced-main-content{padding:var(--spacing-4)}.header-content{flex-direction:column;align-items:flex-start;gap:var(--spacing-4)}.page-title{font-size:var(--font-size-3xl)}.profile-header-section{flex-direction:column;text-align:center;gap:var(--spacing-4)}.profile-stats,.contact-grid,.time-display-grid{grid-template-columns:1fr}.attendance-actions{flex-direction:column}.next-appointment-content{flex-direction:column;text-align:center;gap:var(--spacing-4)}}@media (max-width: 480px){.navbar-content{padding:var(--spacing-3) var(--spacing-4)}.user-details{display:none}.enhanced-main-content{padding:var(--spacing-3)}.page-title{font-size:var(--font-size-2xl)}.appointment-card{flex-direction:column;align-items:flex-start;gap:var(--spacing-3)}.appointment-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-2)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#f0f0f0,#e0e0e0);color:#333;line-height:1.6}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:1rem}.login-card{width:100%;max-width:28rem;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:1rem;box-shadow:0 25px 50px #0000001a;border:1px solid rgba(255,255,255,.2);overflow:hidden;animation:slideInUp .6s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;padding:2rem 1.5rem 1rem}.login-avatar{width:4rem;height:4rem;background:linear-gradient(135deg,#374151,#1f2937);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;box-shadow:0 8px 25px #00000026}.login-avatar-icon{width:2rem;height:2rem;color:#fff}.login-title{font-size:1.875rem;font-weight:700;color:#111827;margin-bottom:.5rem}.login-subtitle{color:#6b7280;font-size:.875rem}.login-content{padding:0 1.5rem 2rem}.login-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.875rem;font-weight:500;color:#374151}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:.75rem;width:1rem;height:1rem;color:#9ca3af;z-index:1}.form-input{width:100%;height:3rem;padding:0 .75rem 0 2.5rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;background:#fff;transition:all .2s ease}.form-input:focus{outline:none;border-color:#374151;box-shadow:0 0 0 3px #3741511a}.form-input:disabled{background-color:#f9fafb;color:#6b7280;cursor:not-allowed}.password-input{padding-right:2.5rem}.password-toggle{position:absolute;right:.75rem;background:none;border:none;cursor:pointer;color:#9ca3af;transition:color .2s ease;padding:.25rem;border-radius:.25rem}.password-toggle:hover{color:#6b7280}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.password-toggle svg{width:1rem;height:1rem}.login-button{width:100%;height:3rem;background:linear-gradient(135deg,#374151,#1f2937);color:#fff;border:none;border-radius:.5rem;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.login-button:hover:not(:disabled){background:linear-gradient(135deg,#1f2937,#111827);transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.loading-content{display:flex;align-items:center;gap:.5rem}.loading-spinner{width:1rem;height:1rem;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8fafc,#e2e8f0)}.app-loading-content{text-align:center}.app-loading-spinner{width:2rem;height:2rem;border:4px solid #e5e7eb;border-top:4px solid #374151;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.app-loading-text{color:#6b7280;font-size:.875rem}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8fafc,#e2e8f0)}.loading-content{text-align:center}.loading-icon{width:2rem;height:2rem;color:#6b7280;animation:spin 1s linear infinite;margin:0 auto 1rem}.loading-text{color:#6b7280;font-size:.875rem}.loading-message,.no-appointments,.no-next-appointment,.no-history{text-align:center;padding:2rem;color:#6b7280;font-style:italic}.error-alert{margin:1rem;padding:1rem;background-color:#fee;color:#c33;border-radius:.5rem;border:1px solid #fcc}.history-hours{display:block;font-size:.8rem;color:#6b7280;margin-top:.25rem}@media (max-width: 640px){.login-container{padding:.5rem}.login-card{max-width:100%}.login-header{padding:1.5rem 1rem .5rem}.login-content{padding:0 1rem 1.5rem}.login-title{font-size:1.5rem}}
