@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Outfit:wght@400;500;600;700;800&display=swap";.navbar{z-index:var(--z-sticky);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-light);height:var(--navbar-height);background:#ffffffd9;position:sticky;top:0}.navbar-inner{justify-content:space-between;align-items:center;gap:var(--space-4);height:100%;display:flex}.navbar-brand{align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.navbar-logo{background:var(--gradient-primary);border-radius:var(--radius-lg);color:#fff;justify-content:center;align-items:center;width:40px;height:40px;font-size:22px;font-weight:800;display:flex;box-shadow:0 2px 8px #3378ff4d}.navbar-brand-text{flex-direction:column;display:flex}.brand-name{font-family:var(--font-display);font-size:var(--text-lg);color:var(--text-primary);font-weight:800;line-height:1.2}.brand-tagline{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:500}.navbar-links{align-items:center;gap:var(--space-1);display:flex}.nav-link{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--text-secondary);transition:all var(--transition-fast);white-space:nowrap;font-weight:500;display:flex}.nav-link:hover{background:var(--gray-100);color:var(--text-primary)}.nav-link.active{background:var(--primary-50);color:var(--primary-600);font-weight:600}.navbar-actions{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.nav-icon-btn{border-radius:var(--radius-lg);width:40px;height:40px;color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;justify-content:center;align-items:center;display:flex;position:relative}.nav-icon-btn:hover{background:var(--gray-100);color:var(--text-primary)}.notif-badge{background:var(--danger-500);color:#fff;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:flex;position:absolute;top:4px;right:4px}.notif-wrapper{position:relative}.notif-dropdown{background:var(--bg-primary);border-radius:var(--radius-xl);width:360px;box-shadow:var(--shadow-xl);border:1px solid var(--border-light);z-index:var(--z-dropdown);animation:slideDown var(--transition-fast);position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}.notif-dropdown-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-light)}.notif-dropdown-header h4{font-size:var(--text-base);font-weight:700}.notif-dropdown-body{max-height:320px;overflow-y:auto}.notif-item{padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--border-light);cursor:pointer;transition:background var(--transition-fast)}.notif-item:hover{background:var(--gray-50)}.notif-item.unread{background:var(--primary-50);border-left:3px solid var(--primary-500)}.notif-title{font-size:var(--text-sm);margin-bottom:2px;font-weight:600}.notif-msg{font-size:var(--text-xs);color:var(--text-secondary);line-height:1.4}.notif-empty{padding:var(--space-8);text-align:center;color:var(--text-tertiary);font-size:var(--text-sm)}.nav-user-btn{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3) var(--space-1) var(--space-1);border-radius:var(--radius-full);background:var(--gray-100);transition:all var(--transition-fast);display:flex}.nav-user-btn:hover{background:var(--gray-200)}.nav-user-name{font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.nav-logout span{display:inline}.mobile-menu-btn{color:var(--text-primary);display:none}.mobile-overlay{display:none}@media (width<=768px){.navbar-inner{padding:0 var(--space-3)}.navbar-links{width:var(--sidebar-width);max-width:80vw;height:calc(100vh - var(--navbar-height));background:var(--bg-primary);border-right:1px solid var(--border-light);box-shadow:var(--shadow-2xl);padding:var(--space-6);gap:var(--space-2);transition:transform var(--transition-base);z-index:var(--z-overlay);-webkit-overflow-scrolling:touch;flex-direction:column;align-items:flex-start;position:absolute;top:100%;left:0;right:auto;overflow-y:auto;transform:translate(-100%)}.navbar-links.open{transform:translate(0)}.nav-link{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-base);border-radius:var(--radius-lg)}.mobile-overlay{height:100vh;z-index:calc(var(--z-overlay) - 1);background:#0000004d;display:block;position:absolute;top:100%;left:0;right:0}.mobile-menu-btn{display:flex}.nav-user-name,.nav-logout span{display:none}.nav-user-btn{padding:var(--space-1)}.navbar-actions{gap:var(--space-1)}.notif-dropdown{top:var(--navbar-height);left:var(--space-3);right:var(--space-3);width:auto;max-height:60vh;position:fixed}.notif-dropdown-body{max-height:50vh}}@media (width<=480px){.navbar-inner{padding:0 var(--space-2)}.brand-name{font-size:var(--text-base)}.brand-tagline{display:none}.navbar-logo{border-radius:var(--radius-md);width:34px;height:34px;font-size:18px}.nav-icon-btn{width:36px;height:36px}}@media (width<=375px){.navbar-brand{gap:var(--space-2)}.navbar-logo{width:30px;height:30px;font-size:16px}}.public-layout{flex-direction:column;min-height:100vh;display:flex}.public-main{flex:1;min-width:0}.site-footer{background:var(--gray-900);color:var(--gray-300);padding:var(--space-16) 0 0;margin-top:var(--space-16)}.footer-grid{gap:var(--space-10);grid-template-columns:1.5fr 1fr 1fr;display:grid}.footer-brand{align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.footer-brand .navbar-logo{background:var(--gradient-primary);border-radius:var(--radius-md);color:#fff;justify-content:center;align-items:center;font-weight:800;display:flex}.footer-brand h4{font-family:var(--font-display);font-size:var(--text-lg);color:#fff;font-weight:700}.footer-brand p{font-size:var(--text-xs);color:var(--gray-400)}.footer-desc{font-size:var(--text-sm);color:var(--gray-400);line-height:1.7}.footer-col h5{color:#fff;font-size:var(--text-base);margin-bottom:var(--space-4);font-weight:600}.footer-col ul li{margin-bottom:var(--space-3);font-size:var(--text-sm)}.footer-col ul li a{color:var(--gray-400);transition:color var(--transition-fast)}.footer-col ul li a:hover{color:#fff}.footer-bottom{border-top:1px solid var(--gray-800);margin-top:var(--space-10);padding:var(--space-6) 0;text-align:center}.footer-bottom p{font-size:var(--text-sm);color:var(--gray-500)}@media (width<=768px){.footer-grid{gap:var(--space-8);grid-template-columns:1fr}.site-footer{padding:var(--space-10) 0 0;margin-top:var(--space-10)}.footer-bottom{margin-top:var(--space-6);padding:var(--space-4) 0}}@media (width<=480px){.site-footer{padding:var(--space-8) 0 0;margin-top:var(--space-8)}.footer-desc{font-size:var(--text-xs)}.footer-col h5{font-size:var(--text-sm);margin-bottom:var(--space-3)}.footer-col ul li{font-size:var(--text-xs);margin-bottom:var(--space-2)}.footer-bottom p{font-size:var(--text-xs)}}.sidebar{top:var(--navbar-height);width:var(--sidebar-width);background:var(--bg-primary);border-right:1px solid var(--border-light);z-index:var(--z-sticky);transition:width var(--transition-base);flex-direction:column;display:flex;position:fixed;bottom:0;left:0;overflow:hidden}.sidebar.collapsed{width:72px}.sidebar-header{padding:var(--space-5) var(--space-4);border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;min-height:60px;display:flex}.sidebar-header h3{font-size:var(--text-base);color:var(--text-primary);white-space:nowrap;font-weight:700}.sidebar-toggle{border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-secondary);transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-toggle:hover{background:var(--gray-100);color:var(--text-primary)}.sidebar-nav{padding:var(--space-3);gap:var(--space-1);flex-direction:column;flex:1;min-width:0;display:flex;overflow-y:auto}.sidebar-link{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--text-sm);transition:all var(--transition-fast);white-space:nowrap;font-weight:500;text-decoration:none;display:flex}.sidebar-link:hover{background:var(--gray-100);color:var(--text-primary)}.sidebar-link.active{background:var(--primary-50);color:var(--primary-600);font-weight:600}.sidebar-link.active .sidebar-link-icon{color:var(--primary-600)}.sidebar-link-icon{flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--border-light)}.sidebar-footer-info{text-align:center}.sidebar-version{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:600}.sidebar-role{font-size:var(--text-xs);color:var(--text-tertiary)}@media (width<=768px){.sidebar{width:var(--sidebar-width);z-index:var(--z-overlay);transition:transform var(--transition-base);transform:translate(-100%)}.sidebar.collapsed{width:var(--sidebar-width);transform:translate(-100%)}.sidebar.open{box-shadow:var(--shadow-2xl);transform:translate(0)}.sidebar-header{padding:var(--space-4)}.sidebar-link{padding:var(--space-3) var(--space-4)}}@media (width<=480px){.sidebar{width:100%;max-width:280px}}.sidebar-overlay{display:none}@media (width<=768px){.sidebar-overlay{inset:0;top:var(--navbar-height);z-index:calc(var(--z-overlay) - 1);background:#0000004d;display:block;position:fixed}}.admin-layout{flex-direction:column;min-height:100vh;display:flex}.admin-body{flex:1;min-width:0;margin-top:0;display:flex}.admin-main{margin-left:var(--sidebar-width);padding:var(--space-8);min-height:calc(100vh - var(--navbar-height));transition:margin-left var(--transition-base);background:var(--bg-secondary);flex:1;min-width:0}.admin-main.sidebar-collapsed{margin-left:72px}@media (width<=768px){.admin-main{padding:var(--space-4);margin-left:0}.admin-main.sidebar-collapsed{margin-left:0}}@media (width<=480px){.admin-main{padding:var(--space-3)}}.doctor-layout{background:var(--bg-secondary);min-height:100vh}.doctor-topbar{padding:var(--space-3) var(--space-6);background:var(--bg-primary);border-bottom:1px solid var(--border-light);box-shadow:var(--shadow-sm);z-index:100;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.doctor-topbar-brand{align-items:center;gap:var(--space-3);text-decoration:none;display:flex}.doctor-topbar-logo{background:var(--gradient-primary);border-radius:var(--radius-lg);color:#fff;justify-content:center;align-items:center;width:40px;height:40px;font-size:22px;font-weight:800;display:flex}.doctor-topbar-name{font-family:var(--font-display);font-size:var(--text-lg);color:var(--text-primary);font-weight:800;display:block}.doctor-topbar-sub{font-size:var(--text-xs);color:var(--primary-500);font-weight:600;display:block}.doctor-topbar-right{align-items:center;gap:var(--space-4);display:flex}.doctor-topbar-user{align-items:center;gap:var(--space-3);display:flex}.doctor-topbar-user-info{flex-direction:column;display:flex}.doctor-topbar-user-name{font-size:var(--text-sm);color:var(--text-primary);font-weight:700}.doctor-topbar-user-role{font-size:var(--text-xs);color:var(--text-tertiary)}.doctor-main{min-height:calc(100vh - 64px)}@media (width<=640px){.doctor-topbar{padding:var(--space-3) var(--space-4)}.doctor-topbar-user-info{display:none}}@media (width<=480px){.doctor-topbar{padding:var(--space-2) var(--space-3)}.doctor-topbar-logo{width:34px;height:34px;font-size:18px}.doctor-topbar-name{font-size:var(--text-base)}.doctor-topbar-sub{font-size:10px}.doctor-topbar-right{gap:var(--space-2)}}.login-page{background:var(--gradient-hero);min-height:100vh;padding:var(--space-6);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.login-bg{pointer-events:none;position:absolute;inset:0}.login-bg-circle{opacity:.08;border-radius:50%;position:absolute}.login-bg-circle.c1{background:var(--primary-400);width:600px;height:600px;animation:8s ease-in-out infinite float;top:-200px;right:-100px}.login-bg-circle.c2{background:var(--teal-400);width:400px;height:400px;animation:10s ease-in-out 1s infinite float;bottom:-100px;left:-100px}.login-bg-circle.c3{background:var(--primary-300);width:300px;height:300px;animation:12s ease-in-out 2s infinite float;top:50%;left:50%;transform:translate(-50%,-50%)}.login-container{z-index:1;text-align:center;width:100%;max-width:720px;animation:.6s ease-out slideUp;position:relative}.login-logo{background:var(--gradient-primary);border-radius:var(--radius-2xl);width:72px;height:72px;margin:0 auto var(--space-5);color:#fff;justify-content:center;align-items:center;font-size:36px;font-weight:800;display:flex;box-shadow:0 8px 32px #3378ff66}.login-container h1{font-family:var(--font-display);font-size:var(--text-5xl);color:#fff;margin-bottom:var(--space-2);font-weight:800}.login-tagline{font-size:var(--text-xl);color:var(--primary-200);margin-bottom:var(--space-2);font-weight:500}.login-desc{font-size:var(--text-sm);color:var(--gray-400);margin-bottom:var(--space-10)}.login-cards{gap:var(--space-6);margin-bottom:var(--space-8);grid-template-columns:repeat(2,1fr);display:grid}.login-card{-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-2xl);padding:var(--space-8);text-align:center;transition:all var(--transition-base);cursor:pointer;align-items:center;gap:var(--space-4);background:#ffffff12;border:1px solid #ffffff1f;flex-direction:column;display:flex}.login-card:hover{background:#ffffff1f;border-color:#fff3;transform:translateY(-4px);box-shadow:0 20px 40px #0000004d}.login-card-icon{border-radius:var(--radius-xl);justify-content:center;align-items:center;width:64px;height:64px;display:flex}.patient-icon{color:var(--primary-300);background:#3378ff33}.admin-icon{color:var(--teal-300);background:#05c8ad33}.login-card h3{font-family:var(--font-display);font-size:var(--text-xl);color:#fff;font-weight:700}.login-card p{font-size:var(--text-sm);color:var(--gray-400);line-height:1.6}.login-card-features{gap:var(--space-4);flex-wrap:wrap;justify-content:center;display:flex}.login-card-features span{align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--gray-300);font-weight:500;display:inline-flex}.login-card-btn{padding:var(--space-3) var(--space-6);border-radius:var(--radius-full);font-size:var(--text-sm);color:#fff;transition:all var(--transition-fast);margin-top:auto;font-weight:600}.patient-card .login-card-btn{background:var(--gradient-primary)}.admin-card .login-card-btn{background:var(--gradient-teal)}.login-card:hover .login-card-btn{box-shadow:0 4px 16px #0000004d}.login-note{font-size:var(--text-sm);color:var(--gray-500)}@media (width<=900px){.login-cards{grid-template-columns:1fr}.login-container h1{font-size:var(--text-4xl)}.login-card{padding:var(--space-6)}}@media (width<=480px){.login-page{padding:var(--space-4)}.login-logo{width:56px;height:56px;font-size:28px}.login-container h1{font-size:var(--text-3xl)}.login-tagline{font-size:var(--text-base)}.login-desc{margin-bottom:var(--space-6)}.login-card{padding:var(--space-5);gap:var(--space-3)}.login-card-icon{width:52px;height:52px}.login-card h3{font-size:var(--text-lg)}.login-card-btn{padding:var(--space-3) var(--space-5);font-size:var(--text-xs)}}@media (width<=375px){.login-page{padding:var(--space-3)}.login-logo{width:48px;height:48px;margin-bottom:var(--space-3);font-size:24px}.login-container h1{font-size:var(--text-2xl)}.login-tagline{font-size:var(--text-sm)}.login-card{padding:var(--space-4)}.login-card-icon{width:44px;height:44px}.login-card h3{font-size:var(--text-base)}.login-card p{font-size:var(--text-xs)}.login-card-features{gap:var(--space-2)}.login-note{font-size:var(--text-xs)}}.page-top{margin-bottom:var(--space-8);justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.dept-list-grid{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(min(340px,100%),1fr));display:grid}.dept-list-card{color:inherit;transition:all var(--transition-base);text-decoration:none}.dept-list-card:hover{transform:translateY(-3px)}.dept-list-card-header{padding:var(--space-6) var(--space-6) 0;border-top:3px solid var(--primary-500);border-radius:var(--radius-xl) var(--radius-xl) 0 0;justify-content:space-between;align-items:center;display:flex}.dept-list-icon{border-radius:var(--radius-lg);justify-content:center;align-items:center;width:56px;height:56px;font-size:28px;display:flex}.dept-list-card h3{font-size:var(--text-xl);margin-bottom:var(--space-2);font-weight:700}.dept-list-card p{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-4);line-height:1.6}.dept-list-link{align-items:center;gap:var(--space-1);font-size:var(--text-sm);color:var(--primary-600);font-weight:600;display:inline-flex}@media (width<=768px){.dept-list-grid{grid-template-columns:1fr}.page-top{margin-bottom:var(--space-5)}}@media (width<=480px){.dept-list-card-header{padding:var(--space-4) var(--space-4) 0}.dept-list-icon{width:48px;height:48px;font-size:24px}.dept-list-card h3{font-size:var(--text-lg)}.dept-list-card p{font-size:var(--text-xs)}}.doctor-filters{align-items:center;gap:var(--space-4);margin-bottom:var(--space-8);flex-wrap:wrap;display:flex}.filter-group{align-items:center;gap:var(--space-2);color:var(--text-secondary);min-width:0;display:flex}.doctor-search-bar{flex:1;min-width:0;max-width:400px}.doctor-dept-filter{min-width:160px}.doctor-list-grid{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));display:grid}.doc-list-card{color:inherit;cursor:pointer;transition:all var(--transition-base);text-decoration:none;position:relative}.doc-list-card:hover{transform:translateY(-3px)}.doc-list-avatar{padding:var(--space-6) var(--space-6) 0;justify-content:center;display:flex;position:relative}.doc-list-card h4{font-size:var(--text-lg);margin-bottom:var(--space-1);font-weight:700}.doc-list-qual{font-size:var(--text-xs);color:var(--text-tertiary);margin-bottom:var(--space-3)}.doc-list-info{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-2);justify-content:space-between;align-items:center;display:flex}.doc-list-info span{align-items:center;gap:4px;display:flex}.doc-list-fee{color:var(--text-primary);font-weight:700}.doc-list-dept{font-size:var(--text-xs);color:var(--teal-600);margin-bottom:var(--space-4);padding:var(--space-1) var(--space-3);background:var(--teal-50);border-radius:var(--radius-full);font-weight:600;display:inline-block}@media (width<=768px){.doctor-filters{gap:var(--space-3);flex-direction:column}.doctor-search-bar{width:100%;max-width:100%}.filter-group{width:100%}.doctor-dept-filter{flex:1;width:100%;min-width:0}.filter-group select.form-input{flex:1}.doc-list-avatar{padding:var(--space-4) var(--space-4) 0}}@media (width<=480px){.doc-list-card h4{font-size:var(--text-base)}.doc-list-info{font-size:var(--text-xs)}}.doctor-detail-layout{gap:var(--space-8);grid-template-columns:1fr 1fr;align-items:flex-start;display:grid}.doctor-profile-header{padding:var(--space-8) var(--space-6);gap:var(--space-6);border-bottom:1px solid var(--border-light);align-items:center;display:flex}.doctor-profile-info h2{font-size:var(--text-2xl);margin-bottom:var(--space-1);margin-top:var(--space-2);font-weight:800}.dpi-spec{font-size:var(--text-base);color:var(--primary-600);font-weight:600}.dpi-qual{font-size:var(--text-sm);color:var(--text-tertiary)}.doctor-bio{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-6);line-height:1.7}.doctor-meta-grid{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:1fr 1fr;display:grid}.doctor-meta-item{align-items:flex-start;gap:var(--space-3);padding:var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-lg);color:var(--primary-600);display:flex}.doctor-meta-item div{flex-direction:column;display:flex}.meta-label{font-size:var(--text-xs);color:var(--text-tertiary)}.meta-value{font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.doctor-schedule h4{align-items:center;gap:var(--space-2);font-size:var(--text-base);margin-bottom:var(--space-3);color:var(--text-primary);display:flex}.schedule-list{gap:var(--space-1);flex-direction:column;display:flex}.schedule-row{padding:var(--space-2) var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md);font-size:var(--text-sm);justify-content:space-between;align-items:center;display:flex}.schedule-day{color:var(--text-primary);font-weight:600}.schedule-time{color:var(--text-secondary)}.doctor-booking-card h3{align-items:center;gap:var(--space-2);font-size:var(--text-xl);margin-bottom:var(--space-1);display:flex}.booking-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-6)}.date-scroll{gap:var(--space-2);padding-bottom:var(--space-3);margin-bottom:var(--space-4);display:flex;overflow-x:auto}.date-chip{padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);border:1.5px solid var(--border-color);background:var(--bg-primary);cursor:pointer;transition:all var(--transition-fast);flex-direction:column;flex-shrink:0;align-items:center;gap:2px;min-width:64px;display:flex}.date-chip:hover:not(.disabled){border-color:var(--primary-400);background:var(--primary-50)}.date-chip.selected{background:var(--primary-500);color:#fff;border-color:var(--primary-500);box-shadow:var(--shadow-glow)}.date-chip.selected .date-chip-day,.date-chip.selected .date-chip-month{color:#fffc}.date-chip.disabled{opacity:.3;cursor:not-allowed}.date-chip-day{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;font-weight:600}.date-chip-num{font-size:var(--text-xl);font-weight:800}.date-chip-month{color:var(--text-tertiary);text-transform:uppercase;font-size:10px}.selected-date-info{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-4);display:flex}.booking-fee-info{padding:var(--space-4);margin:var(--space-6) 0;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-light);justify-content:space-between;align-items:center;display:flex}.fee-label{font-size:var(--text-xs);color:var(--text-tertiary);display:block}.fee-amount{font-size:var(--text-xl);color:var(--text-primary);font-weight:800}@media (width<=1024px){.doctor-detail-layout{grid-template-columns:1fr}}@media (width<=768px){.doctor-profile-header{text-align:center;flex-direction:column}.doctor-meta-grid{grid-template-columns:1fr}.doctor-profile-info h2{font-size:var(--text-xl)}.date-scroll{-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:var(--space-2)}.date-scroll::-webkit-scrollbar{display:none}.date-chip{min-width:56px;padding:var(--space-2)}.date-chip-num{font-size:var(--text-lg)}.booking-fee-info{gap:var(--space-2);text-align:center;flex-direction:column}.doctor-booking-card h3{font-size:var(--text-lg)}.schedule-row{font-size:var(--text-xs);padding:var(--space-2)}}@media (width<=480px){.doctor-profile-header{padding:var(--space-5) var(--space-4);gap:var(--space-4)}.doctor-bio{font-size:var(--text-xs)}.doctor-meta-item{padding:var(--space-2);gap:var(--space-2)}.meta-value{font-size:var(--text-xs)}.date-chip{min-width:50px}.date-chip-num{font-size:var(--text-base)}.fee-amount{font-size:var(--text-lg)}}@media (width<=375px){.doctor-profile-info h2{font-size:var(--text-lg)}.dpi-spec{font-size:var(--text-sm)}.date-chip{min-width:44px;padding:var(--space-1)}.date-chip-day{font-size:10px}.date-chip-num{font-size:var(--text-sm)}}.booking-container{max-width:960px;margin:0 auto}.step-row-item{align-items:center;display:flex}.booking-grid{gap:var(--space-8);grid-template-columns:1fr 1fr;display:grid}.booking-step{animation:fadeIn var(--transition-base)}.patient-form h3,.review-card h3{align-items:center;gap:var(--space-2);font-size:var(--text-xl);margin-bottom:var(--space-6);display:flex}.step-actions{margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid var(--border-light);justify-content:space-between;align-items:center;display:flex}.review-grid{gap:var(--space-6);margin-bottom:var(--space-6);grid-template-columns:1fr 1fr;display:grid}.review-section h5{font-size:var(--text-sm);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3)}.review-row{padding:var(--space-2) 0;border-bottom:1px solid var(--border-light);font-size:var(--text-sm);justify-content:space-between;display:flex}.review-row span:first-child{color:var(--text-secondary)}.review-fee{padding:var(--space-4);background:var(--bg-secondary);border-radius:var(--radius-lg);margin-top:var(--space-4);justify-content:space-between;align-items:center;display:flex}.review-fee span{font-size:var(--text-sm);color:var(--text-secondary)}.review-fee strong{font-size:var(--text-xl);font-weight:800;display:block}.confirmation-card{max-width:560px;margin:0 auto}.confirm-icon{background:var(--success-100);width:80px;height:80px;color:var(--success-500);margin:0 auto var(--space-5);border-radius:50%;justify-content:center;align-items:center;display:flex}.confirmation-card h2{font-size:var(--text-2xl);margin-bottom:var(--space-2)}.confirm-subtitle{color:var(--text-secondary);margin-bottom:var(--space-6)}.token-display{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-8);margin-bottom:var(--space-6);background:var(--gradient-primary);color:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-glow);display:inline-flex}.token-label{font-size:var(--text-xs);opacity:.8;display:block}.token-number{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:800}.confirm-details{text-align:left;margin-bottom:var(--space-6)}.confirm-row{padding:var(--space-3) 0;border-bottom:1px solid var(--border-light);font-size:var(--text-sm);justify-content:space-between;display:flex}.confirm-actions{gap:var(--space-3);flex-wrap:wrap;justify-content:center;display:flex}.selected-doctor-info{margin-top:var(--space-4)}.selected-doctor-body{gap:var(--space-4);align-items:center;display:flex}@media (width<=768px){.booking-container{padding:0}.booking-grid,.form-grid,.review-grid{grid-template-columns:1fr}.step-actions{gap:var(--space-3);flex-direction:column-reverse}.step-actions .btn{justify-content:center;width:100%}.token-display{padding:var(--space-3) var(--space-5)}.token-number{font-size:var(--text-2xl)}.confirmation-card{max-width:100%}.review-fee{gap:var(--space-2);text-align:center;flex-direction:column}.confirm-row{font-size:var(--text-xs)}}@media (width<=480px){.booking-container{max-width:100%}.patient-form h3,.review-card h3{font-size:var(--text-lg);margin-bottom:var(--space-4)}.review-row{gap:var(--space-1);flex-direction:column}.review-row span:first-child{font-size:var(--text-xs)}.token-display{text-align:center;gap:var(--space-2);flex-direction:column}.token-number{font-size:var(--text-xl)}.confirm-icon{width:64px;height:64px}.confirmation-card h2{font-size:var(--text-xl)}.confirm-actions{flex-direction:column}.confirm-actions .btn{width:100%}}@media (width<=375px){.review-fee strong{font-size:var(--text-lg)}.token-display{padding:var(--space-2) var(--space-4)}.token-number{font-size:var(--text-lg)}}.appt-section{margin-bottom:var(--space-10)}.appt-section-title{align-items:center;gap:var(--space-2);font-size:var(--text-xl);margin-bottom:var(--space-5);display:flex}.appt-list{gap:var(--space-4);flex-direction:column;display:flex}.appt-card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.appt-card-doctor{align-items:center;gap:var(--space-3);display:flex}.appt-card-doctor h4{font-size:var(--text-base);font-weight:700}.appt-card-doctor p{font-size:var(--text-sm);color:var(--text-secondary)}.appt-card-details{gap:var(--space-4);font-size:var(--text-sm);color:var(--text-secondary);flex-wrap:wrap;display:flex}.appt-card-details span{align-items:center;gap:4px;display:flex}.appt-card-details em{color:var(--text-tertiary);font-style:normal}.appt-symptoms{font-size:var(--text-sm);color:var(--text-tertiary);margin-top:var(--space-3);font-style:italic}.appt-card-header-right{align-items:center;gap:var(--space-3);display:flex}.appt-delete-btn{border-radius:var(--radius-lg);width:36px;height:36px;color:var(--gray-400);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.appt-delete-btn:hover{background:var(--danger-50);color:var(--danger-500)}.token-list{gap:var(--space-3);flex-direction:column;display:flex}.token-item{padding:var(--space-4) var(--space-5);justify-content:space-between;align-items:center;display:flex}.token-item-left{align-items:center;gap:var(--space-4);display:flex}.token-num{border-radius:var(--radius-lg);background:var(--gradient-primary);color:#fff;width:48px;height:48px;font-family:var(--font-display);font-weight:800;font-size:var(--text-lg);justify-content:center;align-items:center;display:flex}.token-info h4{font-size:var(--text-sm);font-weight:700}.token-info p{font-size:var(--text-xs);color:var(--text-secondary)}.profile-card{max-width:600px}.profile-header{align-items:center;gap:var(--space-6);padding:var(--space-8) var(--space-6);border-bottom:1px solid var(--border-light);display:flex}.profile-info-grid{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.profile-info-item{padding:var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-lg)}.profile-info-item label{font-size:var(--text-xs);color:var(--text-tertiary);margin-bottom:2px;display:block}.profile-info-item span{font-size:var(--text-sm);font-weight:600}.profile-stats{gap:var(--space-4);margin-top:var(--space-6);grid-template-columns:repeat(3,1fr);display:grid}.profile-stat{text-align:center;padding:var(--space-4);background:var(--bg-secondary);border-radius:var(--radius-lg)}.profile-stat-num{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--primary-600);font-weight:800;display:block}.profile-stat-label{font-size:var(--text-xs);color:var(--text-secondary)}@media (width<=768px){.appt-card-header{align-items:flex-start;gap:var(--space-3);flex-direction:column}.appt-card-header-right{justify-content:flex-end;width:100%}.appt-card-details{gap:var(--space-2);flex-direction:column}.token-item{align-items:flex-start;gap:var(--space-3);flex-direction:column}.token-item-left{width:100%}.profile-header{text-align:center;padding:var(--space-6) var(--space-4);gap:var(--space-4);flex-direction:column}.profile-info-grid{grid-template-columns:1fr}.profile-stats{gap:var(--space-3);grid-template-columns:repeat(3,1fr)}.profile-card{max-width:100%}}@media (width<=480px){.appt-section-title{font-size:var(--text-lg)}.appt-card-doctor h4{font-size:var(--text-sm)}.appt-card-details span{font-size:var(--text-xs)}.token-num{width:40px;height:40px;font-size:var(--text-base)}.token-info h4{font-size:var(--text-xs)}.profile-stat-num{font-size:var(--text-xl)}.profile-stat{padding:var(--space-3)}.profile-info-item{padding:var(--space-2)}}@media (width<=375px){.profile-stats{grid-template-columns:1fr}.appt-delete-btn{width:32px;height:32px}}.admin-page{animation:fadeIn var(--transition-base)}.admin-page-header{margin-bottom:var(--space-8);justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.stat-grid{margin-bottom:var(--space-6)}.dashboard-grid{gap:var(--space-6);grid-template-columns:1fr 1fr;display:grid}.dash-section h3{align-items:center;gap:var(--space-2);font-size:var(--text-lg);margin-bottom:var(--space-4);display:flex}.dash-today-stats{gap:var(--space-3);grid-template-columns:repeat(4,1fr);display:grid}.dash-mini-stat{text-align:center;padding:var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-lg)}.dash-mini-num{font-family:var(--font-display);font-size:var(--text-xl);color:var(--primary-600);margin-bottom:2px;font-weight:800;display:block}.dash-mini-stat span:last-child{font-size:var(--text-xs);color:var(--text-tertiary)}.admin-toolbar{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.admin-toolbar-left{align-items:center;gap:var(--space-3);flex-wrap:wrap;min-width:0;display:flex}.admin-search-bar{flex:1;min-width:0;max-width:400px}.admin-filter-select{width:auto;min-width:140px}.mgmt-dept-icon{border-radius:var(--radius-lg);flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:28px;display:flex}.mgmt-grid{gap:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(min(320px,100%),1fr));display:grid}.mgmt-card{transition:all var(--transition-base)}.mgmt-card:hover{transform:translateY(-2px)}.mgmt-card-header{align-items:center;gap:var(--space-4);margin-bottom:var(--space-4);display:flex}.mgmt-card-actions{gap:var(--space-2);flex-wrap:wrap;display:flex}.queue-board{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));display:grid}.queue-card{border-left:4px solid var(--primary-500)}.queue-card.waiting{border-left-color:var(--warning-500)}.queue-card.in_consultation{border-left-color:var(--primary-500)}.queue-card.completed{border-left-color:var(--success-500)}.queue-card-top{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.queue-token{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--primary-600);font-weight:800}.queue-card-info{font-size:var(--text-sm);color:var(--text-secondary);gap:var(--space-1);margin-bottom:var(--space-3);flex-direction:column;display:flex}.queue-card-actions{gap:var(--space-2);display:flex}@media (width<=1024px){.dashboard-grid{grid-template-columns:1fr}}@media (width<=768px){.admin-page-header{margin-bottom:var(--space-5)}.admin-page-header .page-title{font-size:var(--text-xl)}.admin-page-header .page-subtitle{font-size:var(--text-sm);margin-bottom:var(--space-2)}.stat-grid.grid-4{gap:var(--space-3);grid-template-columns:repeat(2,1fr)}.stat-card{padding:var(--space-4)}.stat-card-icon{width:40px;height:40px;margin-bottom:var(--space-2)}.stat-card-icon svg{width:18px;height:18px}.stat-card-value{font-size:var(--text-xl)}.stat-card-label{font-size:var(--text-xs)}.dash-today-stats{grid-template-columns:repeat(2,1fr)}.dash-mini-num{font-size:var(--text-lg)}.mgmt-grid,.queue-board{grid-template-columns:1fr}.admin-toolbar{flex-direction:column;align-items:stretch}.admin-toolbar-left{width:100%}.admin-toolbar-left .search-bar,.admin-search-bar{flex:1;min-width:0;max-width:100%}.admin-filter-select{width:100%;min-width:0}.mgmt-dept-icon{width:48px;height:48px;font-size:24px}.table-header{padding:var(--space-3) var(--space-4)}.table-header h3{font-size:var(--text-base)}}@media (width<=480px){.stat-grid.grid-4{gap:var(--space-2)}.stat-card{padding:var(--space-3)}.stat-card-icon{width:36px;height:36px;margin-bottom:var(--space-1)}.stat-card-value{font-size:var(--text-lg)}.queue-token{font-size:var(--text-xl)}.queue-card-actions{flex-wrap:wrap}.queue-card-actions .btn{flex:1;min-width:0}}@media (width<=375px){.admin-page-header .page-title{font-size:var(--text-lg)}.dash-today-stats{grid-template-columns:1fr}.dash-mini-stat{padding:var(--space-2)}.mgmt-card-header{align-items:flex-start;gap:var(--space-2);flex-direction:column}.mgmt-card-actions{width:100%}.mgmt-card-actions .btn{flex:1}}.doctor-dashboard{padding:var(--space-8);max-width:1200px;margin:0 auto}.doctor-dash-header{margin-bottom:var(--space-8);justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.doctor-dash-date{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--bg-secondary);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--text-secondary);font-weight:600;display:flex}.doctor-stats-grid{gap:var(--space-5);margin-bottom:var(--space-8);grid-template-columns:repeat(4,1fr);display:grid}.doctor-stat-card{background:var(--bg-primary);border-radius:var(--radius-xl);border:1px solid var(--border-light);padding:var(--space-5);text-align:center;box-shadow:var(--shadow-card);transition:all var(--transition-base)}.doctor-stat-card:hover{box-shadow:var(--shadow-elevated);transform:translateY(-2px)}.doctor-stat-icon{border-radius:var(--radius-lg);width:48px;height:48px;margin:0 auto var(--space-3);justify-content:center;align-items:center;display:flex}.doctor-stat-icon.blue{background:var(--primary-50);color:var(--primary-600)}.doctor-stat-icon.amber{background:var(--warning-50);color:var(--warning-600)}.doctor-stat-icon.teal{background:var(--teal-50);color:var(--teal-600)}.doctor-stat-icon.green{background:var(--success-50);color:var(--success-600)}.doctor-stat-value{font-family:var(--font-display);font-size:var(--text-3xl);color:var(--text-primary);margin-bottom:2px;font-weight:800}.doctor-stat-label{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:500}.doctor-section{margin-bottom:var(--space-8)}.doctor-section-header{margin-bottom:var(--space-5);justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.doctor-section-header h2{align-items:center;gap:var(--space-2);font-size:var(--text-xl);font-weight:700;display:flex}.doctor-filter-group{gap:var(--space-2);background:var(--bg-secondary);border-radius:var(--radius-lg);padding:4px;display:flex}.doctor-filter-btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;font-weight:500}.doctor-filter-btn:hover{color:var(--text-primary)}.doctor-filter-btn.active{color:var(--primary-600);box-shadow:var(--shadow-sm);background:#fff;font-weight:600}.doctor-appt-list{gap:var(--space-4);flex-direction:column;display:flex}.doctor-appt-card{border-left:4px solid var(--primary-500);transition:all var(--transition-base)}.doctor-appt-card:hover{transform:translate(4px)}.doctor-appt-card.in-consult{border-left-color:var(--teal-500);background:linear-gradient(135deg,#05c8ad08,#0000)}.doctor-appt-card.done{border-left-color:var(--success-500);opacity:.7}.doctor-appt-top{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.token-badge{font-family:var(--font-display);font-size:var(--text-lg);color:var(--primary-600);background:var(--primary-50);padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-weight:800}.doctor-appt-badges{gap:var(--space-2);flex-wrap:wrap;display:flex}.doctor-appt-patient h4{font-size:var(--text-lg);margin-bottom:var(--space-2);font-weight:700}.doctor-appt-meta{gap:var(--space-4);font-size:var(--text-sm);color:var(--text-secondary);flex-wrap:wrap;display:flex}.doctor-appt-meta span{align-items:center;gap:4px;display:inline-flex}.doctor-appt-symptoms{margin-top:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--warning-50);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--warning-700);align-items:flex-start;gap:var(--space-2);line-height:1.6;display:flex}.doctor-appt-actions{margin-top:var(--space-4);gap:var(--space-3);align-items:center;display:flex}.doctor-completed-label{align-items:center;gap:var(--space-1);font-size:var(--text-sm);color:var(--success-600);font-weight:600;display:inline-flex}@media (width<=1024px){.doctor-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.doctor-dashboard{padding:var(--space-5)}.doctor-stats-grid{gap:var(--space-3);grid-template-columns:repeat(2,1fr)}.doctor-stat-value{font-size:var(--text-2xl)}.doctor-stat-icon{width:40px;height:40px;margin-bottom:var(--space-2)}.doctor-appt-meta{gap:var(--space-2);flex-direction:column}.doctor-filter-group{-webkit-overflow-scrolling:touch;scrollbar-width:none;width:100%;overflow-x:auto}.doctor-filter-group::-webkit-scrollbar{display:none}.doctor-appt-actions{flex-wrap:wrap}.doctor-appt-actions .btn{flex:1;min-width:0}.doctor-section-header{flex-direction:column;align-items:flex-start}.doctor-section-header h2{font-size:var(--text-lg)}.doctor-dash-header .page-title{font-size:var(--text-xl)}}@media (width<=480px){.doctor-dashboard,.doctor-stat-card{padding:var(--space-3)}.doctor-stat-value{font-size:var(--text-xl)}.doctor-stat-icon{width:36px;height:36px}.doctor-appt-patient h4{font-size:var(--text-base)}.token-badge{font-size:var(--text-base);padding:var(--space-1) var(--space-2)}.doctor-filter-btn{font-size:var(--text-xs);padding:var(--space-1) var(--space-3)}.doctor-appt-symptoms,.doctor-dash-date{font-size:var(--text-xs)}}@media (width<=375px){.doctor-stats-grid{grid-template-columns:1fr}.doctor-stat-value{font-size:var(--text-lg)}.doctor-dash-header{margin-bottom:var(--space-5)}}:root{--primary-50:#eef5ff;--primary-100:#d9e8ff;--primary-200:#bcd7ff;--primary-300:#8ec0ff;--primary-400:#599eff;--primary-500:#3378ff;--primary-600:#1b57f5;--primary-700:#1443e1;--primary-800:#1736b6;--primary-900:#19338f;--teal-50:#effefb;--teal-100:#c7fff4;--teal-200:#90ffe9;--teal-300:#51f7da;--teal-400:#1de4c6;--teal-500:#05c8ad;--teal-600:#00a18e;--teal-700:#058073;--teal-800:#0a655d;--teal-900:#0d534d;--success-50:#f0fdf4;--success-100:#dcfce7;--success-500:#22c55e;--success-600:#16a34a;--success-700:#15803d;--warning-50:#fffbeb;--warning-100:#fef3c7;--warning-500:#f59e0b;--warning-600:#d97706;--danger-50:#fef2f2;--danger-100:#fee2e2;--danger-500:#ef4444;--danger-600:#dc2626;--danger-700:#b91c1c;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--gray-950:#020617;--bg-primary:#fff;--bg-secondary:var(--gray-50);--bg-tertiary:var(--gray-100);--bg-dark:var(--gray-900);--text-primary:var(--gray-900);--text-secondary:var(--gray-600);--text-tertiary:var(--gray-400);--text-inverse:#fff;--border-color:var(--gray-200);--border-light:var(--gray-100);--gradient-primary:linear-gradient(135deg, var(--primary-500) 0%, var(--primary-700) 100%);--gradient-teal:linear-gradient(135deg, var(--teal-500) 0%, var(--teal-700) 100%);--gradient-hero:linear-gradient(135deg, #0f172a 0%, #1e3a5f 50%, #0f172a 100%);--gradient-card:linear-gradient(135deg, #ffffffe6 0%, #ffffffb3 100%);--gradient-glass:linear-gradient(135deg, #ffffff26 0%, #ffffff0d 100%);--gradient-mesh:radial-gradient(at 40% 20%, #1f8fff26 0px, transparent 50%), radial-gradient(at 80% 0%, #00ccb81a 0px, transparent 50%), radial-gradient(at 0% 50%, #66b3ff1a 0px, transparent 50%);--font-display:"Outfit", sans-serif;--font-body:"Inter", sans-serif;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--text-6xl:3.75rem;--leading-tight:1.25;--leading-normal:1.5;--leading-relaxed:1.75;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-full:9999px;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a, 0 10px 10px -5px #0000000a;--shadow-2xl:0 25px 50px -12px #00000040;--shadow-glow:0 0 20px #3378ff4d;--shadow-teal-glow:0 0 20px #05c8ad4d;--shadow-card:0 1px 3px #0000000a, 0 6px 16px #0000000f;--shadow-card-hover:0 4px 12px #00000014, 0 12px 28px #0000001a;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.35s cubic-bezier(.4, 0, .2, 1);--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown:100;--z-sticky:200;--z-overlay:300;--z-modal:400;--z-toast:500;--sidebar-width:280px;--navbar-height:72px;--container-max:1280px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}body{font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text-primary);background-color:var(--bg-secondary);-webkit-overflow-scrolling:touch;min-height:100vh;overflow-x:hidden}#root{flex-direction:column;min-height:100vh;display:flex}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);line-height:var(--leading-tight);font-weight:700}.container{width:100%;max-width:var(--container-max);padding:0 var(--space-6);margin:0 auto}.section{padding:var(--space-16) 0}.section-header{text-align:center;margin-bottom:var(--space-12)}.section-header h2{font-size:var(--text-3xl);color:var(--text-primary);margin-bottom:var(--space-3)}.section-header p{color:var(--text-secondary);font-size:var(--text-lg);max-width:600px;margin:0 auto}.section-label{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--primary-600);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3);font-weight:600;display:inline-flex}.page-wrapper{padding:var(--space-8) 0;flex:1}.page-title{font-size:var(--text-3xl);margin-bottom:var(--space-2);font-weight:800}.page-subtitle{color:var(--text-secondary);font-size:var(--text-lg);margin-bottom:var(--space-8)}.grid-2{gap:var(--space-6);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--space-6);grid-template-columns:repeat(3,1fr);display:grid}.grid-4{gap:var(--space-6);grid-template-columns:repeat(4,1fr);display:grid}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--text-sm);border-radius:var(--radius-lg);transition:all var(--transition-base);white-space:nowrap;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";opacity:0;transition:opacity var(--transition-fast);background:linear-gradient(#fff3,#0000);position:absolute;inset:0}.btn:hover:after{opacity:1}.btn:active{transform:scale(.97)}.btn-primary{background:var(--gradient-primary);color:var(--text-inverse);box-shadow:var(--shadow-md), 0 2px 8px #3378ff4d}.btn-primary:hover{box-shadow:var(--shadow-lg), 0 4px 16px #3378ff66;transform:translateY(-1px)}.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:1.5px solid var(--border-color)}.btn-secondary:hover{border-color:var(--primary-300);background:var(--primary-50);color:var(--primary-700)}.btn-teal{background:var(--gradient-teal);color:var(--text-inverse);box-shadow:var(--shadow-md), 0 2px 8px #05c8ad4d}.btn-teal:hover{box-shadow:var(--shadow-lg), 0 4px 16px #05c8ad66;transform:translateY(-1px)}.btn-danger{background:linear-gradient(135deg, var(--danger-500), var(--danger-700));color:var(--text-inverse)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--gray-100);color:var(--text-primary)}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--text-xs);border-radius:var(--radius-md)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-base);border-radius:var(--radius-xl)}.btn-icon{border-radius:var(--radius-lg);width:40px;height:40px;padding:0}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn .spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin}.card{background:var(--bg-primary);border-radius:var(--radius-xl);border:1px solid var(--border-light);box-shadow:var(--shadow-card);transition:all var(--transition-base);overflow:hidden}.card:hover{box-shadow:var(--shadow-card-hover)}.card-glass{background:var(--gradient-card);-webkit-backdrop-filter:blur(20px);border:1px solid #fff3}.card-body{padding:var(--space-6)}.card-header{padding:var(--space-6) var(--space-6) 0}.card-footer{padding:0 var(--space-6) var(--space-6)}.badge{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-full);white-space:nowrap;font-weight:600;display:inline-flex}.badge-primary{background:var(--primary-100);color:var(--primary-700)}.badge-success{background:var(--success-100);color:var(--success-700)}.badge-warning{background:var(--warning-100);color:var(--warning-600)}.badge-danger{background:var(--danger-100);color:var(--danger-700)}.badge-teal{background:var(--teal-100);color:var(--teal-700)}.badge-gray{background:var(--gray-100);color:var(--gray-600)}.badge-dot:before{content:"";background:currentColor;border-radius:50%;width:6px;height:6px}.form-group{margin-bottom:var(--space-5)}.form-label{font-size:var(--text-sm);color:var(--text-primary);margin-bottom:var(--space-2);font-weight:600;display:block}.form-input{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-primary);border:1.5px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast);outline:none}.form-input:hover{border-color:var(--gray-300)}.form-input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #3378ff1a}.form-input::placeholder{color:var(--text-tertiary)}.form-input.error{border-color:var(--danger-500);box-shadow:0 0 0 3px #ef44441a}.form-hint{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:var(--space-1)}.form-error{font-size:var(--text-xs);color:var(--danger-600);margin-top:var(--space-1)}.form-grid{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2364748b' viewBox='0 0 16 16'%3E%3Cpath d='M4.646 5.646a.5.5 0 0 1 .708 0L8 8.293l2.646-2.647a.5.5 0 0 1 .708.708l-3 3a.5.5 0 0 1-.708 0l-3-3a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}textarea.form-input{resize:vertical;min-height:100px}.table-container{background:var(--bg-primary);border-radius:var(--radius-xl);border:1px solid var(--border-light);box-shadow:var(--shadow-card);overflow:hidden}.table-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.table-header h3{font-size:var(--text-lg);font-weight:700}.data-table{border-collapse:collapse;width:100%;min-width:800px}.data-table th{text-align:left;padding:var(--space-3) var(--space-4);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);background:var(--bg-secondary);border-bottom:1px solid var(--border-light);font-weight:600}.data-table td{padding:var(--space-4);font-size:var(--text-sm);color:var(--text-primary);border-bottom:1px solid var(--border-light);vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--gray-50)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal);animation:fadeIn var(--transition-fast);padding:var(--space-4);background:#0f172a99;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-primary);border-radius:var(--radius-2xl);box-shadow:var(--shadow-2xl);width:100%;max-width:560px;max-height:90vh;animation:slideUp var(--transition-base);overflow-y:auto}.modal-header{padding:var(--space-6);border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;display:flex}.modal-header h3{font-size:var(--text-xl);font-weight:700}.modal-body{padding:var(--space-6)}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-light);display:flex}.modal-lg{max-width:640px}.toast-container{top:var(--space-4);right:var(--space-4);z-index:var(--z-toast);gap:var(--space-3);flex-direction:column;display:flex;position:fixed}.toast{align-items:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);border:1px solid var(--border-light);min-width:320px;max-width:420px;animation:slideInRight var(--transition-base);display:flex}.toast-success{border-left:4px solid var(--success-500)}.toast-error{border-left:4px solid var(--danger-500)}.toast-warning{border-left:4px solid var(--warning-500)}.toast-info{border-left:4px solid var(--primary-500)}.toast-icon{flex-shrink:0;width:20px;height:20px}.toast-body h4{font-size:var(--text-sm);margin-bottom:2px;font-weight:600}.toast-body p{font-size:var(--text-xs);color:var(--text-secondary)}.toast-close{color:var(--text-tertiary);transition:color var(--transition-fast);flex-shrink:0}.toast-close:hover{color:var(--text-primary)}.stat-card{background:var(--bg-primary);border-radius:var(--radius-xl);padding:var(--space-6);border:1px solid var(--border-light);box-shadow:var(--shadow-card);transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card:before{content:"";background:var(--gradient-primary);height:3px;position:absolute;top:0;left:0;right:0}.stat-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.stat-card-icon{border-radius:var(--radius-lg);width:48px;height:48px;margin-bottom:var(--space-4);justify-content:center;align-items:center;display:flex}.stat-card-icon.blue{background:var(--primary-100);color:var(--primary-600)}.stat-card-icon.teal{background:var(--teal-100);color:var(--teal-600)}.stat-card-icon.green{background:var(--success-100);color:var(--success-600)}.stat-card-icon.amber{background:var(--warning-100);color:var(--warning-600)}.stat-card-icon.red{background:var(--danger-100);color:var(--danger-600)}.stat-card-value{font-family:var(--font-display);font-size:var(--text-3xl);color:var(--text-primary);margin-bottom:var(--space-1);font-weight:800}.stat-card-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.search-bar{min-width:0;position:relative}.search-bar-icon{left:var(--space-4);color:var(--text-tertiary);width:18px;height:18px;position:absolute;top:50%;transform:translateY(-50%)}.search-bar input{width:100%;padding:var(--space-3) var(--space-4) var(--space-3) 44px;background:var(--bg-primary);border:1.5px solid var(--border-color);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--text-primary);transition:all var(--transition-fast);outline:none}.search-bar input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #3378ff1a}.step-indicator{justify-content:center;align-items:center;gap:var(--space-2);margin-bottom:var(--space-8);display:flex}.step{align-items:center;gap:var(--space-2);display:flex}.step-number{width:36px;height:36px;font-size:var(--text-sm);border:2px solid var(--border-color);color:var(--text-tertiary);background:var(--bg-primary);transition:all var(--transition-base);border-radius:50%;justify-content:center;align-items:center;font-weight:700;display:flex}.step.active .step-number{background:var(--gradient-primary);color:#fff;border-color:var(--primary-500);box-shadow:var(--shadow-glow)}.step.completed .step-number{background:var(--success-500);color:#fff;border-color:var(--success-500)}.step-label{font-size:var(--text-sm);color:var(--text-tertiary);transition:color var(--transition-fast);font-weight:500}.step.active .step-label{color:var(--primary-600);font-weight:600}.step.completed .step-label{color:var(--success-600)}.step-connector{background:var(--border-color);width:40px;height:2px;transition:background var(--transition-base)}.step-connector.completed{background:var(--success-500)}.skeleton{background:linear-gradient(90deg, var(--gray-200) 25%, var(--gray-100) 50%, var(--gray-200) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.skeleton-text{height:14px;margin-bottom:var(--space-2)}.skeleton-title{width:60%;height:24px;margin-bottom:var(--space-4)}.skeleton-avatar{border-radius:50%;width:48px;height:48px}.skeleton-card{border-radius:var(--radius-xl);height:200px}.empty-state{text-align:center;padding:var(--space-16) var(--space-8)}.empty-state-icon{width:80px;height:80px;margin:0 auto var(--space-6);background:var(--gray-100);border-radius:var(--radius-2xl);color:var(--text-tertiary);justify-content:center;align-items:center;display:flex}.empty-state h3{font-size:var(--text-xl);margin-bottom:var(--space-2)}.empty-state p{color:var(--text-secondary);margin-bottom:var(--space-6)}.avatar{object-fit:cover;background:var(--gradient-primary);color:#fff;width:40px;height:40px;font-weight:700;font-size:var(--text-sm);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.avatar-sm{width:32px;height:32px;font-size:var(--text-xs)}.avatar-lg{width:56px;height:56px;font-size:var(--text-lg)}.avatar-xl{width:80px;height:80px;font-size:var(--text-2xl)}.avatar-profile{width:100px;height:100px;font-size:2rem}.avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%}.slot-grid{gap:var(--space-2);grid-template-columns:repeat(auto-fill,minmax(100px,1fr));display:grid}.slot-btn{padding:var(--space-2) var(--space-3);border:1.5px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--text-sm);text-align:center;transition:all var(--transition-fast);cursor:pointer;background:var(--bg-primary);color:var(--text-primary);font-weight:500}.slot-btn:hover:not(.booked):not(.selected){border-color:var(--primary-400);background:var(--primary-50);color:var(--primary-700)}.slot-btn.selected{background:var(--primary-500);color:#fff;border-color:var(--primary-500);box-shadow:var(--shadow-glow)}.slot-btn.booked{background:var(--gray-100);color:var(--text-tertiary);cursor:not-allowed;border-color:var(--gray-200);opacity:.6;text-decoration:line-through}.calendar{border:1px solid var(--border-light);border-radius:var(--radius-xl);overflow:hidden}.calendar-header{padding:var(--space-4) var(--space-5);background:var(--bg-secondary);justify-content:space-between;align-items:center;display:flex}.calendar-header h4{font-size:var(--text-base);font-weight:600}.calendar-grid{background:var(--border-light);grid-template-columns:repeat(7,1fr);gap:1px;display:grid}.calendar-day-header{padding:var(--space-2);text-align:center;font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;background:var(--bg-primary);font-weight:600}.calendar-day{padding:var(--space-3);text-align:center;font-size:var(--text-sm);background:var(--bg-primary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;min-height:44px;display:flex}.calendar-day:hover:not(.disabled):not(.selected){background:var(--primary-50);color:var(--primary-700)}.calendar-day.today{color:var(--primary-600);font-weight:700}.calendar-day.selected{background:var(--primary-500);color:#fff;font-weight:600}.calendar-day.disabled{color:var(--text-tertiary);opacity:.4;cursor:not-allowed}.calendar-day.other-month{color:var(--text-tertiary);opacity:.3}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-100px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes gradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.animate-fade-in{animation:fadeIn var(--transition-base) ease-out}.animate-slide-up{animation:slideUp var(--transition-base) ease-out}.animate-slide-down{animation:slideDown var(--transition-base) ease-out}.animate-scale-in{animation:scaleIn var(--transition-base) ease-out}.stagger-children>*{animation:slideUp var(--transition-slow) ease-out both}.stagger-children>:first-child{animation-delay:0s}.stagger-children>:nth-child(2){animation-delay:50ms}.stagger-children>:nth-child(3){animation-delay:.1s}.stagger-children>:nth-child(4){animation-delay:.15s}.stagger-children>:nth-child(5){animation-delay:.2s}.stagger-children>:nth-child(6){animation-delay:.25s}.stagger-children>:nth-child(7){animation-delay:.3s}.stagger-children>:nth-child(8){animation-delay:.35s}.stagger-children>:nth-child(9){animation-delay:.4s}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}@media (width<=1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}.step-label{display:none}}@media (width<=768px){:root{--navbar-height:64px}.container{padding:0 var(--space-4)}.section{padding:var(--space-10) 0}.grid-4{gap:var(--space-3);grid-template-columns:repeat(2,1fr)}.grid-3,.grid-2{grid-template-columns:1fr}.page-title{font-size:var(--text-2xl)}.page-subtitle{font-size:var(--text-sm)}.section-header h2{font-size:var(--text-2xl)}.section-header p{font-size:var(--text-base)}.modal-overlay{align-items:flex-end;padding:0}.modal-content{border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;max-width:100%;max-height:90vh;animation:slideUp var(--transition-base);margin:0}.modal-body{padding:var(--space-5);-webkit-overflow-scrolling:touch;overflow-y:auto}.modal-header{padding:var(--space-4) var(--space-5)}.modal-footer{padding:var(--space-3) var(--space-5);flex-wrap:wrap}.modal-footer .btn{flex:1;min-width:0}.toast-container{left:var(--space-4);right:var(--space-4)}.toast{width:100%;min-width:auto;max-width:100%}.step-indicator{-webkit-overflow-scrolling:touch;padding-bottom:var(--space-2);scrollbar-width:none;justify-content:flex-start;overflow-x:auto}.step-indicator::-webkit-scrollbar{display:none}.step-connector{flex-shrink:0;width:24px}.step-number{width:32px;height:32px;font-size:var(--text-xs)}.table-container{border-radius:var(--radius-lg)}.data-table{font-size:var(--text-xs)}.data-table th,.data-table td{padding:var(--space-2) var(--space-3);white-space:nowrap}.stat-card{padding:var(--space-4)}.stat-card-icon{width:40px;height:40px;margin-bottom:var(--space-2)}.stat-card-value{font-size:var(--text-xl)}.stat-card-label{font-size:var(--text-xs)}.slot-grid{gap:var(--space-2);grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.slot-btn{padding:var(--space-2);font-size:var(--text-xs)}.calendar-day{padding:var(--space-2);min-height:38px;font-size:var(--text-xs)}.page-wrapper{padding:var(--space-5) 0}.form-group{margin-bottom:var(--space-4)}.empty-state{padding:var(--space-10) var(--space-4)}.empty-state-icon{width:64px;height:64px}.avatar-profile{width:80px;height:80px;font-size:1.5rem}.avatar-xl{width:64px;height:64px}.modal-lg{max-width:100%}.form-grid{grid-template-columns:1fr}.doctor-search-bar{flex:1;min-width:0;max-width:100%}.doctor-dept-filter{width:100%;min-width:0}}@media (width<=480px){.container{padding:0 var(--space-3)}.grid-4{grid-template-columns:1fr}.page-title,.section-header h2{font-size:var(--text-xl)}.stat-card{padding:var(--space-3)}.stat-card-icon{width:36px;height:36px;margin-bottom:var(--space-1);border-radius:var(--radius-md)}.stat-card-value{font-size:var(--text-lg)}.btn-lg{justify-content:center;width:100%}.section{padding:var(--space-8) 0}.section-label{font-size:var(--text-xs)}.avatar-profile{width:60px;height:60px;font-size:1.25rem}.page-subtitle{font-size:var(--text-xs);margin-bottom:var(--space-4)}.modal-header h3{font-size:var(--text-lg)}.modal-header{padding:var(--space-3) var(--space-4)}.modal-body{padding:var(--space-4)}.modal-footer{padding:var(--space-3) var(--space-4)}}@media (width<=375px){:root{--navbar-height:56px}.container{padding:0 var(--space-2)}.page-title{font-size:var(--text-lg)}.stat-card-value{font-size:var(--text-base)}.btn{padding:var(--space-2) var(--space-4);font-size:var(--text-xs)}.btn-lg{padding:var(--space-3) var(--space-5);font-size:var(--text-sm)}.card-body{padding:var(--space-4)}.slot-grid{grid-template-columns:repeat(3,1fr)}}
