:root{--color-primary:#1e3a5f;--color-primary-dark:#142740;--color-primary-light:#2d5a8a;--color-accent:#c9a227;--color-accent-light:#e8c84a;--color-accent-muted:#d4b45c;--color-bg:#f8f6f3;--color-bg-alt:#fff;--color-bg-elevated:#fffef9;--color-surface:#fff;--color-surface-hover:#f5f3ef;--color-text:#1a1a1a;--color-text-secondary:#5a5a5a;--color-text-muted:#8a8a8a;--color-text-inverse:#fff;--color-success:#2d7a4f;--color-success-bg:#e8f5ed;--color-warning:#b8860b;--color-warning-bg:#fef8e7;--color-error:#c23a3a;--color-error-bg:#fdeaea;--color-info:#2d5a8a;--color-info-bg:#e8f0f8;--font-display:"Fraunces",Georgia,serif;--font-body:"DM Sans",-apple-system,BlinkMacSystemFont,sans-serif;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--shadow-sm:0 1px 2px #1e3a5f0f;--shadow-md:0 4px 12px #1e3a5f14;--shadow-lg:0 8px 24px #1e3a5f1f;--shadow-xl:0 16px 48px #1e3a5f29;--transition-fast:150ms ease;--transition-normal:250ms ease;--transition-slow:400ms ease}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;scroll-behavior:smooth}body{background:#f8f6f3;background:var(--color-bg);color:#1a1a1a;color:var(--color-text);font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font-body);font-size:1rem;line-height:1.6;min-height:100vh}h1,h2,h3,h4,h5,h6{color:#142740;color:var(--color-primary-dark);font-family:Fraunces,Georgia,serif;font-family:var(--font-display);font-weight:500;line-height:1.2}h1{font-size:2.5rem;font-weight:600}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}p{margin-bottom:1rem}a{color:#1e3a5f;color:var(--color-primary);text-decoration:none;transition:color .15s ease;transition:color var(--transition-fast)}a:hover{color:#2d5a8a;color:var(--color-primary-light)}.app-container{display:flex;min-height:100vh}.sidebar{background:linear-gradient(180deg,#142740,#1e3a5f);background:linear-gradient(180deg,var(--color-primary-dark) 0,var(--color-primary) 100%);box-shadow:0 16px 48px #1e3a5f29;box-shadow:var(--shadow-xl);color:#fff;color:var(--color-text-inverse);display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;width:280px;z-index:100}.sidebar-header{border-bottom:1px solid #ffffff1a;padding:2rem;padding:var(--space-xl)}.sidebar-logo{align-items:center;color:#fff;color:var(--color-text-inverse);display:flex;font-family:Fraunces,Georgia,serif;font-family:var(--font-display);font-size:1.5rem;font-weight:600;gap:.5rem;gap:var(--space-sm)}.sidebar-logo svg{color:#c9a227;color:var(--color-accent)}.sidebar-subtitle{font-size:.875rem;margin-top:.25rem;margin-top:var(--space-xs);opacity:.7}.sidebar-nav{flex:1 1;overflow-y:auto;padding:1.5rem;padding:var(--space-lg)}.nav-section{margin-bottom:2rem;margin-bottom:var(--space-xl)}.nav-section-title{font-size:.75rem;letter-spacing:.1em;margin-bottom:.5rem;margin-bottom:var(--space-sm);opacity:.5;padding-left:1rem;padding-left:var(--space-md);text-transform:uppercase}.nav-link{align-items:center;border-radius:8px;border-radius:var(--radius-md);color:#fffc;display:flex;font-size:.9375rem;gap:1rem;gap:var(--space-md);margin-bottom:.25rem;margin-bottom:var(--space-xs);padding:1rem;padding:var(--space-md) var(--space-md);transition:all .15s ease;transition:all var(--transition-fast)}.nav-link:hover{background:#ffffff1a;color:#fff;color:var(--color-text-inverse)}.nav-link.active{background:#c9a22733;color:#e8c84a;color:var(--color-accent-light);font-weight:500}.nav-link svg{flex-shrink:0;height:20px;width:20px}.sidebar-footer{border-top:1px solid #ffffff1a;padding:1.5rem;padding:var(--space-lg)}.user-info{gap:1rem;gap:var(--space-md)}.user-avatar,.user-info{align-items:center;display:flex}.user-avatar{background:#c9a227;background:var(--color-accent);border-radius:9999px;border-radius:var(--radius-full);color:#142740;color:var(--color-primary-dark);font-size:1rem;font-weight:600;height:40px;justify-content:center;width:40px}.user-details{flex:1 1;min-width:0}.user-name{font-size:.9375rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{font-size:.8125rem;opacity:.7;text-transform:capitalize}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:280px;min-height:100vh}.page-header{background:#fffef9;background:var(--color-bg-elevated);border-bottom:1px solid #1e3a5f14;padding:2rem 3rem;padding:var(--space-xl) var(--space-2xl)}.page-header h1{margin-bottom:.25rem;margin-bottom:var(--space-xs)}.page-subtitle{color:#5a5a5a;color:var(--color-text-secondary);font-size:1rem}.page-content{flex:1 1;max-width:1400px;padding:3rem;padding:var(--space-2xl)}.card{background:#fff;background:var(--color-surface);border:1px solid #1e3a5f0f;border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 2px #1e3a5f0f;box-shadow:var(--shadow-sm);overflow:hidden;transition:all .25s ease;transition:all var(--transition-normal)}.card:hover{box-shadow:0 4px 12px #1e3a5f14;box-shadow:var(--shadow-md)}.card-header{align-items:center;border-bottom:1px solid #1e3a5f0f;display:flex;justify-content:space-between;padding:1.5rem 2rem;padding:var(--space-lg) var(--space-xl)}.card-title{color:#142740;color:var(--color-primary-dark);font-family:Fraunces,Georgia,serif;font-family:var(--font-display);font-size:1.125rem;font-weight:500}.card-body{padding:2rem;padding:var(--space-xl)}.card-footer{background:#f8f6f3;background:var(--color-bg);border-top:1px solid #1e3a5f0f;padding:1.5rem 2rem;padding:var(--space-lg) var(--space-xl)}.stats-grid{grid-gap:1.5rem;grid-gap:var(--space-lg);display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:3rem;margin-bottom:var(--space-2xl)}.stat-card,.stats-grid{gap:1.5rem;gap:var(--space-lg)}.stat-card{align-items:flex-start;background:#fff;background:var(--color-surface);border:1px solid #1e3a5f0f;border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 2px #1e3a5f0f;box-shadow:var(--shadow-sm);display:flex;padding:2rem;padding:var(--space-xl);transition:all .25s ease;transition:all var(--transition-normal)}.stat-card:hover{box-shadow:0 4px 12px #1e3a5f14;box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{align-items:center;border-radius:8px;border-radius:var(--radius-md);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.stat-icon.primary{background:#e8f0f8;background:var(--color-info-bg);color:#2d5a8a;color:var(--color-info)}.stat-icon.success{background:#e8f5ed;background:var(--color-success-bg);color:#2d7a4f;color:var(--color-success)}.stat-icon.warning{background:#fef8e7;background:var(--color-warning-bg);color:#b8860b;color:var(--color-warning)}.stat-icon.accent{background:#c9a22726;color:#c9a227;color:var(--color-accent)}.stat-content{flex:1 1}.stat-value{color:#142740;color:var(--color-primary-dark);font-family:Fraunces,Georgia,serif;font-family:var(--font-display);font-size:2rem;font-weight:600;line-height:1;margin-bottom:.25rem;margin-bottom:var(--space-xs)}.stat-label{color:#5a5a5a;color:var(--color-text-secondary);font-size:.875rem}.btn{align-items:center;border:none;border-radius:8px;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font-body);font-size:.9375rem;font-weight:500;gap:.5rem;gap:var(--space-sm);justify-content:center;padding:.5rem 1.5rem;padding:var(--space-sm) var(--space-lg);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.6}.btn svg{height:18px;width:18px}.btn-primary{background:#1e3a5f;background:var(--color-primary);color:#fff;color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background:#2d5a8a;background:var(--color-primary-light);box-shadow:0 4px 12px #1e3a5f14;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background:#f8f6f3;background:var(--color-bg);border:1px solid #1e3a5f26;color:#1a1a1a;color:var(--color-text)}.btn-secondary:hover:not(:disabled){background:#f5f3ef;background:var(--color-surface-hover);border-color:#1e3a5f40}.btn-accent{background:#c9a227;background:var(--color-accent);color:#142740;color:var(--color-primary-dark)}.btn-accent:hover:not(:disabled){background:#e8c84a;background:var(--color-accent-light);box-shadow:0 4px 12px #1e3a5f14;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-ghost{background:#0000;color:#5a5a5a;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background:#f8f6f3;background:var(--color-bg);color:#1a1a1a;color:var(--color-text)}.btn-danger{background:#c23a3a;background:var(--color-error);color:#fff;color:var(--color-text-inverse)}.btn-danger:hover:not(:disabled){background:#a82e2e}.btn-sm{font-size:.8125rem;padding:.25rem 1rem;padding:var(--space-xs) var(--space-md)}.btn-lg{font-size:1rem;padding:1rem 2rem;padding:var(--space-md) var(--space-xl)}.form-group{margin-bottom:1.5rem;margin-bottom:var(--space-lg)}.form-label{color:#1a1a1a;color:var(--color-text);display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem;margin-bottom:var(--space-sm)}.form-label.required:after{color:#c23a3a;color:var(--color-error);content:"*";margin-left:.25rem;margin-left:var(--space-xs)}.form-input,.form-select,.form-textarea{background:#fff;background:var(--color-surface);border:1px solid #1e3a5f26;border-radius:8px;border-radius:var(--radius-md);color:#1a1a1a;color:var(--color-text);font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font-body);font-size:1rem;padding:1rem;padding:var(--space-md);transition:all .15s ease;transition:all var(--transition-fast);width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#1e3a5f;border-color:var(--color-primary);box-shadow:0 0 0 3px #1e3a5f1a;outline:none}.form-input::placeholder{color:#8a8a8a;color:var(--color-text-muted)}.form-input.error,.form-select.error{border-color:#c23a3a;border-color:var(--color-error)}.form-error{color:#c23a3a;color:var(--color-error)}.form-error,.form-hint{font-size:.8125rem;margin-top:.25rem;margin-top:var(--space-xs)}.form-hint{color:#8a8a8a;color:var(--color-text-muted)}.form-row{grid-gap:1.5rem;grid-gap:var(--space-lg);display:grid;gap:1.5rem;gap:var(--space-lg);grid-template-columns:repeat(2,1fr)}.table-container{background:#fff;background:var(--color-surface);border:1px solid #1e3a5f0f;border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 2px #1e3a5f0f;box-shadow:var(--shadow-sm);overflow-x:auto}.table{border-collapse:collapse;width:100%}.table td,.table th{padding:1rem 1.5rem;padding:var(--space-md) var(--space-lg);text-align:left}.table th{background:#f8f6f3;background:var(--color-bg);border-bottom:1px solid #1e3a5f14;color:#5a5a5a;color:var(--color-text-secondary);font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.table td{border-bottom:1px solid #1e3a5f0a;font-size:.9375rem}.table tbody tr:hover{background:#f5f3ef;background:var(--color-surface-hover)}.table tbody tr:last-child td{border-bottom:none}.badge{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-size:.75rem;font-weight:500;padding:.25rem .5rem;padding:var(--space-xs) var(--space-sm);text-transform:capitalize}.badge-primary{background:#e8f0f8;background:var(--color-info-bg);color:#2d5a8a;color:var(--color-info)}.badge-success{background:#e8f5ed;background:var(--color-success-bg);color:#2d7a4f;color:var(--color-success)}.badge-warning{background:#fef8e7;background:var(--color-warning-bg);color:#b8860b;color:var(--color-warning)}.badge-error{background:#fdeaea;background:var(--color-error-bg);color:#c23a3a;color:var(--color-error)}.badge-neutral{background:#f8f6f3;background:var(--color-bg);color:#5a5a5a;color:var(--color-text-secondary)}.role-badge{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-size:.8125rem;font-weight:500;gap:.25rem;gap:var(--space-xs);padding:.25rem 1rem;padding:var(--space-xs) var(--space-md)}.role-badge.student{background:#e8f0f8;background:var(--color-info-bg);color:#2d5a8a;color:var(--color-info)}.role-badge.instructor{background:#c9a22726;color:#8b6914}.role-badge.admin{background:#1e3a5f;background:var(--color-primary);color:#fff;color:var(--color-text-inverse)}.calendar-header{justify-content:space-between;margin-bottom:2rem;margin-bottom:var(--space-xl)}.calendar-header,.calendar-nav{align-items:center;display:flex}.calendar-nav{gap:1rem;gap:var(--space-md)}.calendar-title{font-family:Fraunces,Georgia,serif;font-family:var(--font-display);font-size:1.25rem;font-weight:500;min-width:200px;text-align:center}.slots-grid{grid-gap:1rem;grid-gap:var(--space-md);display:grid;gap:1rem;gap:var(--space-md)}.slot-card{align-items:center;background:#fff;background:var(--color-surface);border:1px solid #1e3a5f14;border-radius:8px;border-radius:var(--radius-md);display:flex;justify-content:space-between;padding:1.5rem;padding:var(--space-lg);transition:all .15s ease;transition:all var(--transition-fast)}.slot-card:hover{border-color:#1e3a5f;border-color:var(--color-primary);box-shadow:0 1px 2px #1e3a5f0f;box-shadow:var(--shadow-sm)}.slot-card.booked{background:#f8f6f3;background:var(--color-bg);opacity:.7}.slot-card.my-booking{background:#e8f5ed;background:var(--color-success-bg);border-color:#2d7a4f;border-color:var(--color-success);opacity:1}.slot-time{color:#142740;color:var(--color-primary-dark);font-family:Fraunces,Georgia,serif;font-family:var(--font-display);font-size:1.125rem;font-weight:500}.slot-info{flex:1 1;margin-left:1.5rem;margin-left:var(--space-lg)}.slot-instructor{color:#1a1a1a;color:var(--color-text);font-weight:500}.slot-details{align-items:center;color:#5a5a5a;color:var(--color-text-secondary);display:flex;font-size:.875rem;gap:1rem;gap:var(--space-md);margin-top:.25rem;margin-top:var(--space-xs)}.date-picker,.slot-actions{display:flex;gap:.5rem;gap:var(--space-sm)}.date-picker{flex-wrap:wrap}.date-btn{background:#fff;background:var(--color-surface);border:1px solid #1e3a5f1a;border-radius:8px;border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;min-width:70px;padding:.5rem 1rem;padding:var(--space-sm) var(--space-md);text-align:center;transition:all .15s ease;transition:all var(--transition-fast)}.date-btn.selected,.date-btn:hover{border-color:#1e3a5f;border-color:var(--color-primary)}.date-btn.selected{background:#1e3a5f;background:var(--color-primary);color:#fff;color:var(--color-text-inverse)}.date-btn .day-name{display:block;font-size:.75rem;opacity:.7}.date-btn .day-num{display:block;font-size:1rem;font-weight:600}.modal-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#14274080;display:flex;inset:0;justify-content:center;padding:1.5rem;padding:var(--space-lg);position:fixed;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{animation:slideUp .3s ease;background:#fff;background:var(--color-surface);border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 16px 48px #1e3a5f29;box-shadow:var(--shadow-xl);max-height:90vh;max-width:500px;overflow-y:auto;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #1e3a5f14;display:flex;justify-content:space-between;padding:2rem;padding:var(--space-xl)}.modal-title{font-family:Fraunces,Georgia,serif;font-family:var(--font-display);font-size:1.25rem;font-weight:500}.modal-close{background:none;border:none;border-radius:4px;border-radius:var(--radius-sm);color:#8a8a8a;color:var(--color-text-muted);cursor:pointer;padding:.5rem;padding:var(--space-sm);transition:all .15s ease;transition:all var(--transition-fast)}.modal-close:hover{background:#f8f6f3;background:var(--color-bg);color:#1a1a1a;color:var(--color-text)}.modal-body{padding:2rem;padding:var(--space-xl)}.modal-footer{border-top:1px solid #1e3a5f14;justify-content:flex-end;padding:1.5rem 2rem;padding:var(--space-lg) var(--space-xl)}.modal-footer,.toast-container{display:flex;gap:1rem;gap:var(--space-md)}.toast-container{bottom:2rem;bottom:var(--space-xl);flex-direction:column;position:fixed;right:2rem;right:var(--space-xl);z-index:1100}.toast{align-items:center;animation:slideIn .3s ease;border-radius:8px;border-radius:var(--radius-md);box-shadow:0 8px 24px #1e3a5f1f;box-shadow:var(--shadow-lg);display:flex;gap:1rem;gap:var(--space-md);max-width:400px;padding:1rem 1.5rem;padding:var(--space-md) var(--space-lg)}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.toast.success{background:#2d7a4f;background:var(--color-success);color:#fff}.toast.error{background:#c23a3a;background:var(--color-error);color:#fff}.toast.info{background:#1e3a5f;background:var(--color-primary);color:#fff}.auth-container{align-items:center;background:linear-gradient(135deg,#142740,#1e3a5f 50%,#2d5a8a);background:linear-gradient(135deg,var(--color-primary-dark) 0,var(--color-primary) 50%,var(--color-primary-light) 100%);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:2rem;padding:var(--space-xl);position:relative}.auth-container:before{animation:pulse 15s ease infinite;background:radial-gradient(ellipse at center,#c9a2271a 0,#0000 70%);content:"";height:200%;left:-50%;position:absolute;top:-50%;width:200%}@keyframes pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.3;transform:scale(1.1)}}.auth-card{background:#fff;background:var(--color-surface);border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 16px 48px #1e3a5f29;box-shadow:var(--shadow-xl);max-width:440px;padding:3rem;padding:var(--space-2xl);position:relative;width:100%;z-index:1}.auth-header{margin-bottom:3rem;margin-bottom:var(--space-2xl);text-align:center}.auth-logo{align-items:center;color:#1e3a5f;color:var(--color-primary);display:flex;font-family:Fraunces,Georgia,serif;font-family:var(--font-display);font-size:1.75rem;font-weight:600;gap:.5rem;gap:var(--space-sm);justify-content:center;margin-bottom:.5rem;margin-bottom:var(--space-sm)}.auth-logo svg{color:#c9a227;color:var(--color-accent)}.auth-subtitle{color:#5a5a5a;color:var(--color-text-secondary);font-size:.9375rem}.auth-form{margin-bottom:2rem;margin-bottom:var(--space-xl)}.auth-footer{color:#5a5a5a;color:var(--color-text-secondary);font-size:.9375rem;text-align:center}.auth-footer a{color:#1e3a5f;color:var(--color-primary);font-weight:500}.auth-divider{align-items:center;color:#8a8a8a;color:var(--color-text-muted);display:flex;font-size:.875rem;gap:1rem;gap:var(--space-md);margin:2rem 0;margin:var(--space-xl) 0}.auth-divider:after,.auth-divider:before{background:#1e3a5f1a;content:"";flex:1 1;height:1px}.spinner{animation:spin .8s linear infinite;border:2px solid #1e3a5f1a;border-radius:50%;border-top:2px solid var(--color-primary);height:24px;width:24px}@keyframes spin{to{transform:rotate(1turn)}}.loading-overlay{align-items:center;background:#fffc;display:flex;inset:0;justify-content:center;position:absolute;z-index:10}.skeleton{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#f8f6f3 25%,#f5f3ef 50%,#f8f6f3 75%);background:linear-gradient(90deg,var(--color-bg) 25%,var(--color-surface-hover) 50%,var(--color-bg) 75%);background-size:200% 100%;border-radius:4px;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{padding:4rem 2rem;padding:var(--space-3xl) var(--space-xl);text-align:center}.empty-state svg{color:#8a8a8a;color:var(--color-text-muted);height:64px;margin-bottom:1.5rem;margin-bottom:var(--space-lg);width:64px}.empty-state h3{color:#5a5a5a;color:var(--color-text-secondary);margin-bottom:.5rem;margin-bottom:var(--space-sm)}.empty-state p{color:#8a8a8a;color:var(--color-text-muted);margin-bottom:2rem;margin-bottom:var(--space-xl)}@media (max-width:1024px){.sidebar{width:240px}.main-content{margin-left:240px}}@media (max-width:768px){.sidebar{transform:translateX(-100%);transition:transform .25s ease;transition:transform var(--transition-normal)}.sidebar.open{transform:translateX(0)}.main-content{margin-left:0}.page-content{padding:1.5rem;padding:var(--space-lg)}.form-row,.stats-grid{grid-template-columns:1fr}h1{font-size:1.75rem}}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:#8a8a8a;color:var(--color-text-muted)}.text-secondary{color:#5a5a5a;color:var(--color-text-secondary)}.text-success{color:#2d7a4f;color:var(--color-success)}.text-error{color:#c23a3a;color:var(--color-error)}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.mt-xs{margin-top:.25rem;margin-top:var(--space-xs)}.mt-sm{margin-top:.5rem;margin-top:var(--space-sm)}.mt-md{margin-top:1rem;margin-top:var(--space-md)}.mt-lg{margin-top:1.5rem;margin-top:var(--space-lg)}.mt-xl{margin-top:2rem;margin-top:var(--space-xl)}.mb-xs{margin-bottom:.25rem;margin-bottom:var(--space-xs)}.mb-sm{margin-bottom:.5rem;margin-bottom:var(--space-sm)}.mb-md{margin-bottom:1rem;margin-bottom:var(--space-md)}.mb-lg{margin-bottom:1.5rem;margin-bottom:var(--space-lg)}.mb-xl{margin-bottom:2rem;margin-bottom:var(--space-xl)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:.5rem;gap:var(--space-sm)}.gap-md{gap:1rem;gap:var(--space-md)}.gap-lg{gap:1.5rem;gap:var(--space-lg)}.hidden{display:none}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}:root{--bg-primary:#fff;--bg-secondary:#f3f4f6;--bg-card:#fff;--text-primary:#111827;--text-secondary:#6b7280;--border-color:#e5e7eb;--shadow:0 1px 3px #0000001a}.dark{--bg-primary:#111827;--bg-secondary:#1f2937;--bg-card:#1f2937;--text-primary:#f9fafb;--text-secondary:#9ca3af;--border-color:#374151;--shadow:0 1px 3px #0000004d;--color-bg:#111827;--color-bg-alt:#1a2332;--color-bg-elevated:#1f2937;--color-surface:#1f2937;--color-surface-hover:#263244;--color-text:#f1f5f9;--color-text-secondary:#94a3b8;--color-text-muted:#64748b;--color-primary:#4d8bcc;--color-primary-light:#5a9cd6;--color-accent:#c9a227;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080}.dark body{background-color:#fff;background-color:var(--bg-primary);color:#111827;color:var(--text-primary)}.dark .auth-card,.dark .card,.dark .modal{background-color:#fff;background-color:var(--bg-card);border-color:#e5e7eb;border-color:var(--border-color)}.dark .form-input,.dark input,.dark select,.dark textarea{border-color:#e5e7eb;border-color:var(--border-color);color:#111827;color:var(--text-primary)}.dark .form-input,.dark .sidebar,.dark input,.dark select,.dark textarea{background-color:#f3f4f6;background-color:var(--bg-secondary)}.dark .page-container{background-color:#fff;background-color:var(--bg-primary)}.dark .text-secondary{color:#6b7280;color:var(--text-secondary)}.dark .appointment-card,.dark .slot-card{background-color:#fff;background-color:var(--bg-card);border-color:#e5e7eb;border-color:var(--border-color)}.dark .card-title,.dark .slot-time,.dark .stat-value,.dark h1,.dark h2,.dark h3,.dark h4,.dark h5,.dark h6{color:#1a1a1a;color:var(--color-text)}.dark .card-footer{background:#f5f3ef;background:var(--color-surface-hover);border-top-color:#e5e7eb;border-top-color:var(--border-color)}.dark .appointments-date-header,.dark h3[style*=color-primary-dark],.dark h3[style*=primary-dark]{color:#1a1a1a!important;color:var(--color-text)!important}.dark .date-btn{background:#fff;background:var(--color-surface);border-color:#e5e7eb;border-color:var(--border-color);color:#1a1a1a;color:var(--color-text)}.dark .date-btn.active,.dark .date-btn:hover{background:#1e3a5f;background:var(--color-primary);color:#fff;color:var(--color-text-inverse)}.dark .table th{background-color:#1a2332;color:#5a5a5a;color:var(--color-text-secondary)}.dark .table td,.dark .table th{border-bottom-color:#e5e7eb;border-bottom-color:var(--border-color)}.dark .table td{color:#1a1a1a;color:var(--color-text)}.dark .table tr:hover td{background-color:#f5f3ef;background-color:var(--color-surface-hover)}.dark .page-header,.dark .page-header h1,.dark .page-header p{color:#1a1a1a;color:var(--color-text)}.dark .stat-card{background-color:#fff;background-color:var(--bg-card);border-color:#e5e7eb;border-color:var(--border-color)}.dark label{color:#1a1a1a;color:var(--color-text)}.dark .dropdown,.dark .dropdown-menu,.dark .modal-overlay .modal{background-color:#fff;background-color:var(--bg-card)}.dark .dropdown,.dark .dropdown-menu{border-color:#e5e7eb;border-color:var(--border-color)}.dark .dropdown-item:hover{background-color:#f5f3ef;background-color:var(--color-surface-hover)}.theme-toggle{align-items:center;background:none;border:none;border-radius:8px;color:#111827;color:var(--text-primary);cursor:pointer;display:flex;justify-content:center;padding:8px}.theme-toggle:hover{background-color:#f3f4f6;background-color:var(--bg-secondary)}.auth-split{display:flex;flex-direction:row;min-height:100vh}.auth-brand-panel{align-items:center;background:linear-gradient(150deg,#0d1f3c,#1e3a5f 45%,#2d5a8a);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:3rem;padding:var(--space-2xl);position:relative;width:45%}.auth-brand-inner{max-width:340px;position:relative;z-index:2}.auth-brand-logo{align-items:center;color:#fff;display:flex;font-family:Fraunces,Georgia,serif;font-family:var(--font-display);font-size:2rem;font-weight:600;gap:.75rem;margin-bottom:1.25rem}.auth-brand-logo svg{flex-shrink:0}.auth-brand-icon,.auth-brand-logo svg{color:#c9a227;color:var(--color-accent)}.auth-brand-icon{align-items:center;background:#c9a22733;border:2px solid #c9a22766;border-radius:50%;display:flex;height:72px;justify-content:center;margin-bottom:1.25rem;width:72px}.auth-brand-title{color:#fff;font-family:Fraunces,Georgia,serif;font-family:var(--font-display);font-size:1.75rem;font-weight:600;line-height:1.25;margin-bottom:.75rem}.auth-brand-tagline{color:#ffffffb3;font-size:1.0625rem;line-height:1.6;margin-bottom:2rem}.auth-brand-features{display:flex;flex-direction:column;gap:.75rem;list-style:none}.auth-brand-features li{align-items:center;color:#ffffffd9;display:flex;font-size:.9375rem;gap:.6rem}.auth-brand-features li svg{color:#c9a227;color:var(--color-accent);flex-shrink:0}.auth-brand-circle{background:#ffffff0a;border:1px solid #ffffff0f;border-radius:50%;position:absolute;z-index:1}.auth-brand-circle-1{animation:floatCircle 12s ease-in-out infinite;height:300px;right:-80px;top:-80px;width:300px}.auth-brand-circle-2{animation:floatCircle 9s ease-in-out infinite reverse;bottom:60px;height:200px;left:-60px;width:200px}.auth-brand-circle-3{animation:floatCircle 14s ease-in-out 3s infinite;bottom:-40px;height:140px;right:60px;width:140px}@keyframes floatCircle{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-20px) scale(1.05)}}.auth-form-panel{align-items:center;background:#fff;background:var(--color-bg-alt);display:flex;justify-content:center;min-height:100vh;padding:3rem;padding:var(--space-2xl);position:relative;transition:background .25s;width:55%}.auth-form-inner{animation:authFadeIn .4s ease;max-width:420px;width:100%}@keyframes authFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.auth-form-title{color:#1a1a1a;color:var(--color-text);font-family:Fraunces,Georgia,serif;font-family:var(--font-display);font-size:1.75rem;font-weight:600;margin-bottom:.4rem}.auth-form-subtitle{color:#5a5a5a;color:var(--color-text-secondary);font-size:.9375rem}.auth-mobile-logo{align-items:center;color:#1e3a5f;color:var(--color-primary);display:none;font-family:Fraunces,Georgia,serif;font-family:var(--font-display);font-size:1.25rem;font-weight:600;gap:.5rem;margin-bottom:1.5rem}.auth-mobile-logo svg{color:#c9a227;color:var(--color-accent)}.dark-toggle-auth{align-items:center;background:#f5f3ef;background:var(--color-surface-hover);border:1px solid #0000;border-radius:9999px;border-radius:var(--radius-full);cursor:pointer;display:flex;font-size:1rem;height:38px;justify-content:center;position:absolute;right:1.25rem;top:1.25rem;transition:background .2s,border-color .2s;width:38px;z-index:10}.dark-toggle-auth:hover{background:#f8f6f3;background:var(--color-bg);border-color:#00000014}.otp-row{display:flex;gap:.6rem;justify-content:center;margin-top:1.5rem}.otp-input{background:#fff;background:var(--color-surface);border:2px solid #8a8a8a;border:2px solid var(--color-text-muted,#d1d5db);border-radius:8px;border-radius:var(--radius-md);caret-color:#1e3a5f;caret-color:var(--color-primary);color:#1a1a1a;color:var(--color-text);font-family:Fraunces,Georgia,serif;font-family:var(--font-display);font-size:1.5rem;font-weight:700;height:60px;outline:none;text-align:center;transition:border-color .15s,box-shadow .15s;width:52px}.otp-input:focus{border-color:#1e3a5f;border-color:var(--color-primary);box-shadow:0 0 0 3px #1e3a5f1f}.otp-input:not(:placeholder-shown):not(:focus){border-color:#c9a227;border-color:var(--color-accent)}.dark .auth-form-panel{background:#f3f4f6;background:var(--bg-secondary)}.dark .auth-form-title{color:#111827;color:var(--text-primary)}.dark .auth-form-subtitle{color:#6b7280;color:var(--text-secondary)}.dark .dark-toggle-auth{background:#ffffff14;border-color:#ffffff1a;color:#111827;color:var(--text-primary)}.dark .otp-input{background:#f3f4f6;background:var(--bg-secondary);border-color:#e5e7eb;border-color:var(--border-color);color:#111827;color:var(--text-primary)}.dark .otp-input:focus{border-color:#c9a227;border-color:var(--color-accent);box-shadow:0 0 0 3px #c9a22726}@media (max-width:768px){.auth-split{flex-direction:column}.auth-brand-panel{display:none}.auth-form-panel{align-items:flex-start;min-height:100vh;padding:2rem 1rem;padding:var(--space-xl) var(--space-md);padding-top:4rem;width:100%}.auth-form-inner{max-width:100%}.auth-mobile-logo{display:flex}.otp-input{font-size:1.25rem;height:52px;width:44px}.otp-row{gap:.4rem}}
/*# sourceMappingURL=main.95b687a7.css.map*/