@import url("https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap");:root{--bg-primary:#faf8f5;--bg-secondary:#fff;--bg-tertiary:#f5f0ea;--bg-elevated:#ede6dc;--accent-primary:#8b5a2b;--accent-primary-hover:#6d4522;--accent-primary-light:#fdf6ed;--accent-secondary:#a67c52;--accent-gold:#c49a6c;--status-success:#2d6a4f;--status-success-bg:#f0fdf4;--status-success-border:#bbf7d0;--status-warning:#b45309;--status-warning-bg:#fffbeb;--status-warning-border:#fcd34d;--status-error:#b91c1c;--status-error-bg:#fef2f2;--status-error-border:#fecaca;--status-info:#0369a1;--status-info-bg:#f0f9ff;--status-info-border:#bae6fd;--text-primary:#3d2814;--text-secondary:#5c4033;--text-tertiary:#7c6252;--text-muted:#a89282;--border-primary:#e8dfd4;--border-secondary:#d4c4b0;--border-focus:var(--accent-primary);--shadow-xs:0 1px 2px rgba(61,40,20,.04);--shadow-sm:0 1px 3px rgba(61,40,20,.06),0 1px 2px rgba(61,40,20,.04);--shadow-md:0 4px 6px -1px rgba(61,40,20,.06),0 2px 4px -1px rgba(61,40,20,.04);--shadow-lg:0 10px 15px -3px rgba(61,40,20,.08),0 4px 6px -2px rgba(61,40,20,.04);--shadow-xl:0 20px 25px -5px rgba(61,40,20,.1),0 10px 10px -5px rgba(61,40,20,.04);--shadow-focus:0 0 0 3px rgba(139,90,43,.15);--gradient-primary:linear-gradient(135deg,#8b5a2b,#a67c52);--gradient-hero:linear-gradient(180deg,#faf8f5,#f5f0ea);--gradient-warm:linear-gradient(135deg,#fdf6ed,#f5f0ea);--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--space-4xl:96px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--font-family:"Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,sans-serif;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:2rem;--font-size-4xl:2.75rem;--font-size-5xl:3.5rem;--transition-fast:150ms ease;--transition-base:200ms ease;--transition-slow:300ms ease}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-layout{display:flex;min-height:100vh}.sidebar{width:280px;background:var(--bg-secondary);border-right:1px solid var(--border-primary);padding:var(--space-lg);position:fixed;height:100vh;overflow-y:auto;z-index:100}.sidebar-logo{display:flex;align-items:center;gap:var(--space-md);padding-bottom:var(--space-lg);border-bottom:1px solid var(--border-primary);margin-bottom:var(--space-lg)}.sidebar-logo-icon{width:44px;height:44px;background:var(--gradient-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);box-shadow:var(--shadow-md)}.sidebar-logo-text{font-size:var(--font-size-lg);font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.sidebar-logo-text span{color:var(--accent-primary)}.sidebar-nav{display:flex;flex-direction:column;gap:var(--space-xs)}.sidebar-section{margin-top:var(--space-xl)}.sidebar-section-title{font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:var(--space-sm);padding-left:var(--space-md)}.nav-link{display:flex;align-items:center;gap:var(--space-md);padding:10px var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;font-weight:500;font-size:var(--font-size-sm);transition:all var(--transition-fast);position:relative}.nav-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-link.active{background:var(--accent-primary-light);color:var(--accent-primary);font-weight:600}.nav-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--accent-primary);border-radius:var(--radius-full)}.nav-link-icon{font-size:var(--font-size-lg);width:24px;text-align:center}.main-content{flex:1 1;margin-left:280px;min-height:100vh;background:var(--bg-primary)}.page-header{padding:var(--space-xl) var(--space-2xl);background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:center}.page-title{font-size:var(--font-size-2xl);font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.page-subtitle{color:var(--text-tertiary);font-size:var(--font-size-sm);margin-top:var(--space-xs)}.page-content{padding:var(--space-2xl)}.hero-section{background:var(--gradient-hero);padding:var(--space-4xl) var(--space-2xl);text-align:center;border-bottom:1px solid var(--border-primary)}.hero-badge{display:inline-flex;align-items:center;gap:var(--space-sm);background:var(--accent-primary-light);color:var(--accent-primary);padding:6px 16px;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--space-lg);border:1px solid var(--border-secondary)}.hero-title{font-size:var(--font-size-4xl);font-weight:800;letter-spacing:-.03em;color:var(--text-primary);max-width:700px;margin:0 auto var(--space-lg);line-height:1.2}.hero-title span{color:var(--accent-primary)}.hero-subtitle{font-size:var(--font-size-lg);color:var(--text-tertiary);max-width:540px;margin:0 auto var(--space-xl);line-height:1.7}.hero-actions{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap}.features-section{padding:var(--space-3xl) var(--space-2xl);background:var(--bg-secondary)}.section-header{text-align:center;margin-bottom:var(--space-2xl)}.section-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-sm)}.section-subtitle{font-size:var(--font-size-base);color:var(--text-tertiary)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:var(--space-lg);gap:var(--space-lg);max-width:1000px;margin:0 auto}.feature-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center;transition:all var(--transition-base)}.feature-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--accent-gold)}.feature-icon{width:56px;height:56px;background:var(--gradient-warm);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.75rem;margin:0 auto var(--space-md);border:1px solid var(--border-primary)}.feature-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-sm)}.feature-description{font-size:var(--font-size-sm);color:var(--text-tertiary);line-height:1.6}.services-section{padding:var(--space-3xl) var(--space-2xl);background:var(--gradient-hero)}.services-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));grid-gap:var(--space-md);gap:var(--space-md);max-width:900px;margin:0 auto}.service-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center;cursor:pointer;transition:all var(--transition-base)}.service-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-md)}.service-icon{font-size:2rem;margin-bottom:var(--space-sm)}.service-name{font-size:var(--font-size-sm)}.card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-xl);transition:all var(--transition-base);box-shadow:var(--shadow-xs)}.card:hover{box-shadow:var(--shadow-md)}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-lg)}.card-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary)}.card-subtitle{font-size:var(--font-size-sm);color:var(--text-tertiary);margin-top:var(--space-xs)}.booking-card{position:relative;overflow:hidden}.booking-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-primary);opacity:0;transition:opacity var(--transition-base)}.booking-card:hover:before{opacity:1}.booking-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-md)}.booking-service{display:flex;align-items:center;gap:var(--space-md)}.booking-service-icon{width:48px;height:48px;background:var(--gradient-warm);border:1px solid var(--border-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl)}.booking-service-name{font-weight:600;font-size:var(--font-size-base);color:var(--text-primary)}.booking-id{font-size:var(--font-size-xs);color:var(--text-muted);font-family:SF Mono,Consolas,monospace}.booking-details{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:var(--space-md);gap:var(--space-md);margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--border-primary)}.booking-detail{display:flex;flex-direction:column;gap:var(--space-xs)}.booking-detail-label{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.booking-detail-value{font-size:var(--font-size-sm);color:var(--text-primary)}.booking-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--border-primary)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.03em;border:1px solid transparent}.status-badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.status-pending{background:var(--status-warning-bg);color:var(--status-warning);border-color:var(--status-warning-border)}.status-assigned{background:var(--accent-primary-light);color:var(--accent-primary);border-color:#d4c4b0}.status-accepted{background:#fef7ee;color:var(--accent-secondary);border-color:#e8dfd4}.status-rejected{background:var(--status-error-bg);color:var(--status-error);border-color:var(--status-error-border)}.status-in_progress{background:var(--status-info-bg);color:var(--status-info);border-color:var(--status-info-border)}.status-completed{background:var(--status-success-bg);color:var(--status-success);border-color:var(--status-success-border)}.status-cancelled{background:#f9fafb;color:#6b7280;border-color:#e5e7eb}.status-no_show{background:#fff7ed;color:#c2410c;border-color:#fed7aa}.status-failed{background:var(--status-error-bg);color:#991b1b;border-color:var(--status-error-border)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:12px 24px;border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast);border:1px solid transparent;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:var(--accent-primary-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-secondary)}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--text-tertiary)}.btn-success{background:var(--status-success);color:#fff}.btn-success:hover:not(:disabled){background:#1e5738}.btn-danger{background:var(--status-error);color:#fff}.btn-danger:hover:not(:disabled){background:#991b1b}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.btn-sm{padding:8px 14px;font-size:var(--font-size-xs)}.btn-lg{padding:16px 32px;font-size:var(--font-size-base)}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-md)}.form-group{margin-bottom:var(--space-lg)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-sm)}.form-input,.form-select,.form-textarea{width:100%;padding:14px 18px;background:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-size-base);transition:all var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:var(--shadow-focus)}.form-input::placeholder{color:var(--text-muted)}.form-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%237c6252' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;background-size:16px;padding-right:48px}.form-select option{background:var(--bg-secondary);color:var(--text-primary)}.form-textarea{min-height:120px;resize:vertical}.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));grid-gap:var(--space-lg);gap:var(--space-lg)}.grid-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));grid-gap:var(--space-md);gap:var(--space-md)}.stat-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-xs);text-align:center}.stat-value{font-size:var(--font-size-3xl);font-weight:700;letter-spacing:-.02em;color:var(--text-primary);margin-bottom:var(--space-xs)}.stat-label{font-size:var(--font-size-sm);color:var(--text-tertiary);font-weight:500}.event-log{max-height:600px;overflow-y:auto}.event-item{display:flex;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);transition:background var(--transition-fast)}.event-item:hover{background:var(--bg-tertiary)}.event-item+.event-item{border-top:1px solid var(--border-primary)}.event-icon{width:38px;height:38px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);flex-shrink:0}.event-content{flex:1 1}.event-title{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary)}.event-meta{display:flex;gap:var(--space-md);font-size:var(--font-size-xs);color:var(--text-tertiary);margin-top:var(--space-xs)}.event-time{font-family:SF Mono,Consolas,monospace}.table-container{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-primary);background:var(--bg-secondary)}.table{width:100%;border-collapse:collapse}.table td,.table th{padding:var(--space-md) var(--space-lg);text-align:left}.table th{background:var(--bg-tertiary);font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary)}.table td,.table th{border-bottom:1px solid var(--border-primary)}.table td{font-size:var(--font-size-sm);color:var(--text-primary)}.table tr:last-child td{border-bottom:none}.table tr:hover td,.tabs{background:var(--bg-tertiary)}.tabs{display:flex;gap:var(--space-xs);padding:var(--space-xs);border-radius:var(--radius-lg);margin-bottom:var(--space-lg)}.tab{flex:1 1;padding:12px 20px;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;transition:all var(--transition-fast)}.tab:hover{color:var(--text-primary)}.tab.active{background:var(--bg-secondary);color:var(--accent-primary);font-weight:600;box-shadow:var(--shadow-sm)}.modal-overlay{position:fixed;inset:0;background:rgba(61,40,20,.4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-fast)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp var(--transition-base)}@keyframes slideUp{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:var(--space-xl);border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary)}.modal-close{width:36px;height:36px;border-radius:var(--radius-full);background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);font-size:var(--font-size-lg)}.modal-close:hover{background:var(--status-error-bg);border-color:var(--status-error-border);color:var(--status-error)}.modal-body{padding:var(--space-xl)}.modal-footer{padding:var(--space-lg) var(--space-xl);border-top:1px solid var(--border-primary);display:flex;justify-content:flex-end;gap:var(--space-md)}.empty-state{text-align:center;padding:var(--space-3xl)}.empty-state-icon{font-size:3.5rem;margin-bottom:var(--space-lg);opacity:.7}.empty-state-title{font-size:var(--font-size-xl);font-weight:600;margin-bottom:var(--space-sm);color:var(--text-primary)}.empty-state-text{color:var(--text-tertiary);margin-bottom:var(--space-xl)}.spinner{width:44px;height:44px;border:3px solid var(--border-primary);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-lg{margin-bottom:var(--space-lg)}.text-center{text-align:center}.text-right{text-align:right}.text-secondary{color:var(--text-secondary)}.font-mono{font-family:SF Mono,Consolas,monospace}.login-bg-pattern{position:fixed;inset:0;background-image:radial-gradient(circle at 20% 20%,rgba(139,90,43,.08) 0,transparent 50%),radial-gradient(circle at 80% 80%,rgba(166,124,82,.08) 0,transparent 50%),radial-gradient(circle at 40% 60%,hsla(31,43%,60%,.05) 0,transparent 40%);pointer-events:none;z-index:0}.login-page>:not(.login-bg-pattern){position:relative;z-index:1}.login-description{font-size:var(--font-size-base);color:var(--text-tertiary);max-width:500px;margin:0 auto;margin-top:var(--space-md);line-height:1.7}.account-list{display:flex;flex-direction:column;gap:var(--space-sm)}.account-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);width:100%;text-align:left;font-family:var(--font-family)}.account-item:hover{background:var(--accent-primary-light);border-color:var(--accent-primary)}.account-avatar{width:44px;height:44px;background:var(--gradient-warm);border:1px solid var(--border-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl)}.account-info{flex:1 1}.account-name{font-size:var(--font-size-base);font-weight:600;color:var(--text-primary)}.account-email{font-size:var(--font-size-sm);color:var(--text-tertiary)}.account-arrow{font-size:var(--font-size-lg);color:var(--text-muted)}.user-avatar{width:40px;height:40px;border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:var(--font-size-lg)}.user-avatar,.user-avatar-lg{background:var(--gradient-warm);display:flex;align-items:center;justify-content:center}.user-avatar-lg{width:64px;height:64px;border:1px solid var(--border-primary);border-radius:var(--radius-lg);font-size:1.75rem}.service-type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));grid-gap:var(--space-sm);gap:var(--space-sm)}.service-type-option{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-md);background:var(--bg-tertiary);border:2px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-family)}.service-type-option:hover{border-color:var(--accent-secondary)}.service-type-option.selected{background:var(--accent-primary-light);border-color:var(--accent-primary)}.service-type-icon{font-size:1.5rem}.service-type-label{font-size:var(--font-size-xs);font-weight:500;color:var(--text-secondary);text-align:center}.service-type-option.selected .service-type-label{color:var(--accent-primary);font-weight:600}.provider-stats{display:flex;gap:var(--space-lg)}.stat-mini{text-align:center}.stat-mini-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--accent-primary)}.stat-mini-label{font-size:var(--font-size-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.alert{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.alert-error{background:var(--status-error-bg);color:var(--status-error);border:1px solid var(--status-error-border)}.alert-success{background:var(--status-success-bg);color:var(--status-success);border:1px solid var(--status-success-border)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);padding:0 var(--space-2xl);position:-webkit-sticky;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-xs)}.navbar-container{max-width:1400px;margin:0 auto;justify-content:space-between;height:70px}.navbar-container,.navbar-logo{display:flex;align-items:center}.navbar-logo{gap:var(--space-md);text-decoration:none}.navbar-logo-icon{width:40px;height:40px;background:var(--gradient-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);box-shadow:var(--shadow-sm)}.navbar-logo-text{font-size:var(--font-size-lg);font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.navbar-logo-text span{color:var(--accent-primary)}.navbar-nav{display:flex;align-items:center;gap:var(--space-xs)}.navbar-link{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;font-weight:500;font-size:var(--font-size-sm);transition:all var(--transition-fast)}.navbar-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.navbar-link.active{background:var(--accent-primary-light);color:var(--accent-primary);font-weight:600}.navbar-actions{display:flex;align-items:center;gap:var(--space-md)}.main-container{min-height:calc(100vh - 70px);background:var(--bg-primary)}.login-page{min-height:100vh;background:var(--gradient-hero);display:flex;flex-direction:column}.login-header{text-align:center;padding:var(--space-3xl) var(--space-2xl) var(--space-xl)}.login-logo{gap:var(--space-md);margin-bottom:var(--space-md)}.login-logo,.login-logo-icon{display:flex;align-items:center;justify-content:center}.login-logo-icon{width:56px;height:56px;background:var(--gradient-primary);border-radius:var(--radius-lg);font-size:1.75rem;box-shadow:var(--shadow-lg)}.login-logo-text{font-size:var(--font-size-3xl);font-weight:800;letter-spacing:-.03em;color:var(--text-primary)}.login-logo-text span{color:var(--accent-primary)}.login-tagline{font-size:var(--font-size-lg);color:var(--text-tertiary)}.login-content{flex:1 1;padding:var(--space-xl) var(--space-2xl) var(--space-3xl);max-width:1000px;margin:0 auto;width:100%}.login-title{text-align:center;font-size:var(--font-size-2xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-sm)}.login-subtitle{text-align:center;font-size:var(--font-size-base);color:var(--text-tertiary);margin-bottom:var(--space-2xl)}.role-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:var(--space-lg);gap:var(--space-lg)}.role-card{background:var(--bg-secondary);border:2px solid var(--border-primary);border-radius:var(--radius-xl);padding:var(--space-xl);text-decoration:none;text-align:center;transition:all var(--transition-base);display:flex;flex-direction:column;align-items:center}.role-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.role-card-admin{background:linear-gradient(180deg,var(--bg-secondary) 0,#fdf6ed 100%)}.role-icon{width:72px;height:72px;background:var(--gradient-warm);border:1px solid var(--border-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:2rem;margin-bottom:var(--space-lg)}.role-title{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-sm)}.role-description{color:var(--text-tertiary);line-height:1.6}.role-description,.role-features{font-size:var(--font-size-sm);margin-bottom:var(--space-lg)}.role-features{display:flex;flex-direction:column;gap:var(--space-xs);color:var(--text-secondary)}.role-features span{display:flex;align-items:center;gap:var(--space-sm)}.role-cta{font-weight:600;color:var(--accent-primary);margin-top:auto}.login-footer,.role-cta{font-size:var(--font-size-sm)}.login-footer{text-align:center;padding:var(--space-lg);color:var(--text-muted);border-top:1px solid var(--border-primary);background:var(--bg-secondary)}@media (max-width:1024px){.navbar{padding:0 var(--space-lg)}.hero-title{font-size:var(--font-size-3xl)}}@media (max-width:768px){.navbar-container{height:60px}.navbar-nav{display:none}.grid-cards{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.page-content,.page-header{padding:var(--space-lg)}.booking-details{grid-template-columns:1fr}.hero-section{padding:var(--space-2xl) var(--space-lg)}.hero-title{font-size:var(--font-size-2xl)}.features-grid,.role-cards{grid-template-columns:1fr}.login-header{padding:var(--space-2xl) var(--space-lg) var(--space-lg)}.login-logo-text{font-size:var(--font-size-2xl)}.login-content{padding:var(--space-lg)}}.hero-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:var(--space-lg)}.hero-bg{z-index:0}.hero-bg,.hero-gradient{position:absolute;inset:0}.hero-gradient{background:linear-gradient(135deg,#fef6e4,#ffe8d6 25%,#f5ebe0 50%,#edede9 75%,#d5c4a1);animation:gradientShift 15s ease infinite;background-size:400% 400%}@keyframes gradientShift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.hero-shapes{position:absolute;inset:0;overflow:hidden;pointer-events:none}.shape{position:absolute;border-radius:50%;opacity:.4;animation:float 20s ease-in-out infinite}.shape-1{width:300px;height:300px;background:linear-gradient(135deg,#ff6b6b,#feca57);top:-100px;left:-50px;animation-delay:0s}.shape-2{width:200px;height:200px;background:linear-gradient(135deg,#4ecdc4,#44b09e);top:20%;right:-60px;animation-delay:-5s}.shape-3{width:150px;height:150px;background:linear-gradient(135deg,#a8e6cf,#88d8b0);bottom:10%;left:5%;animation-delay:-10s}.shape-4{width:180px;height:180px;background:linear-gradient(135deg,plum,violet);bottom:-50px;right:20%;animation-delay:-7s}.shape-5{width:100px;height:100px;background:linear-gradient(135deg,#ffe66d,#ffd93d);top:40%;left:30%;animation-delay:-3s}@keyframes float{0%,to{transform:translateY(0) rotate(0deg) scale(1)}33%{transform:translateY(-30px) rotate(120deg) scale(1.1)}66%{transform:translateY(20px) rotate(240deg) scale(.9)}}.hero-container{display:flex;gap:var(--space-2xl);max-width:1200px;width:100%;z-index:1;align-items:center}.hero-left{flex:1.2 1;display:flex;flex-direction:column;gap:var(--space-lg)}.hero-brand{margin-bottom:var(--space-md)}.hero-logo{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-sm)}.hero-logo-icon{font-size:2.5rem;animation:sparkle 2s ease-in-out infinite}@keyframes sparkle{0%,to{transform:scale(1) rotate(0deg)}50%{transform:scale(1.2) rotate(15deg)}}.hero-logo h1{font-size:var(--font-size-4xl);font-weight:800;color:var(--text-primary);letter-spacing:-.03em}.hero-logo h1 span{background:linear-gradient(135deg,#8b5a2b,#c49a6c 50%,#d4a574);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-tagline{font-size:var(--font-size-xl);color:var(--text-secondary);font-weight:500}.services-showcase{background:hsla(0,0%,100%,.7);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-xl);padding:var(--space-lg);border:1px solid hsla(0,0%,100%,.5)}.services-label{font-size:var(--font-size-sm);font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-md)}.services-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:var(--space-sm);gap:var(--space-sm)}.service-pill{display:flex;align-items:center;gap:var(--space-sm);padding:10px 14px;background:#fff;border-radius:var(--radius-full);border:2px solid transparent;box-shadow:var(--shadow-sm);transition:all var(--transition-base);animation:popIn .5s ease backwards;cursor:default}.service-pill:hover{transform:translateY(-3px) scale(1.05);box-shadow:var(--shadow-lg);border-color:var(--pill-color,#8b5a2b)}@keyframes popIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.service-emoji{font-size:1.25rem}.service-name{font-size:var(--font-size-xs);font-weight:600;color:var(--text-primary);white-space:nowrap}.hero-stats{display:flex;align-items:center;gap:var(--space-md);font-size:var(--font-size-sm);color:var(--text-secondary)}.hero-stats .stat strong{color:var(--accent-primary);font-weight:700}.stat-divider{color:var(--text-muted)}.hero-right{flex:0.8 1}.login-panel{background:hsla(0,0%,100%,.95);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:0 20px 60px rgba(0,0,0,.1),0 0 0 1px hsla(0,0%,100%,.5);border:1px solid hsla(0,0%,100%,.3)}.login-heading{font-size:var(--font-size-2xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-xs)}.login-subheading{font-size:var(--font-size-sm);color:var(--text-tertiary);margin-bottom:var(--space-lg)}.login-options{display:flex;flex-direction:column;gap:var(--space-sm)}.login-option{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-primary);border:2px solid var(--border-primary);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-decoration:none;color:inherit}.login-option:hover{border-color:var(--accent-primary);background:var(--accent-primary-light);transform:translateX(4px)}.option-icon{width:44px;height:44px;background:var(--gradient-warm);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.option-content{flex:1 1;text-align:left}.option-title{display:block;font-weight:600;color:var(--text-primary);font-size:var(--font-size-base)}.option-desc{display:block;font-size:var(--font-size-xs);color:var(--text-tertiary)}.option-arrow{font-size:var(--font-size-lg);color:var(--accent-primary);opacity:0;transform:translateX(-10px);transition:all var(--transition-fast)}.login-option:hover .option-arrow{opacity:1;transform:translateX(0)}.login-footer-text{text-align:center;font-size:var(--font-size-xs);color:var(--text-muted);margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--border-primary)}.modal-compact{max-width:380px}@media (max-width:900px){.hero-container{flex-direction:column;gap:var(--space-xl)}.hero-left,.hero-right{flex:none;width:100%}.services-grid{grid-template-columns:repeat(2,1fr)}.hero-stats{flex-wrap:wrap;justify-content:center}}@media (max-width:600px){.hero-logo h1{font-size:var(--font-size-2xl)}.services-grid{grid-template-columns:1fr 1fr}.service-pill{padding:8px 12px}.hero-stats{font-size:var(--font-size-xs)}}.modal-login{max-width:400px;width:100%}.login-form{display:flex;flex-direction:column;gap:var(--space-md)}.login-form .form-group{margin-bottom:0}.login-error{gap:var(--space-sm);padding:var(--space-md);background:var(--status-error-bg);border:1px solid var(--status-error-border);border-radius:var(--radius-md);color:var(--status-error);font-size:var(--font-size-sm)}.login-error,.login-links{display:flex;align-items:center}.login-links{justify-content:center;gap:var(--space-md);margin-top:var(--space-sm)}.login-link{color:var(--accent-primary);font-size:var(--font-size-sm);text-decoration:none}.login-link:hover{text-decoration:underline}.login-divider{color:var(--text-muted)}.demo-hint{margin-top:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);text-align:center}.demo-label{display:inline-block;background:var(--accent-primary);color:#fff;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);margin-bottom:var(--space-xs)}.demo-hint p,.demo-label{font-size:var(--font-size-xs)}.demo-hint p{color:var(--text-tertiary);margin:0}.w-full{width:100%}