:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.navigation-engine{display:flex;flex-direction:column;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;width:100%}.organization-name-bar{background:#00000026;color:#fff;text-align:center;padding:.5rem;font-size:.875rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border-bottom:1px solid rgba(255,255,255,.1)}.navigation-header{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #0000001a}.navigation-header>*{max-width:800px;margin:0 auto}.progress-container{width:100%;height:6px;background:#667eea33;border-radius:10px;overflow:hidden;margin-bottom:1.5rem}.progress-bar{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:10px;transition:width .4s cubic-bezier(.4,0,.2,1);box-shadow:0 0 10px #667eea80}.step-info{text-align:center}.step-counter{display:inline-block;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:20px;font-size:.875rem;font-weight:600;margin-bottom:1rem}.step-title{font-size:2rem;font-weight:700;color:#1a202c;margin:.5rem 0;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.step-description{font-size:1.125rem;color:#4a5568;margin:.5rem 0 0}.navigation-content{flex:1;display:flex;align-items:center;justify-content:center;max-width:800px;margin:0 auto;width:100%}.navigation-footer{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;justify-content:space-between;gap:1rem;box-shadow:0 -4px 20px #0000001a}.navigation-footer:before{content:"";flex:1;max-width:calc((100% - 800px)/2)}.navigation-footer:after{content:"";flex:1;max-width:calc((100% - 800px)/2)}.nav-button{padding:.875rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;text-transform:none}.nav-button-back{background:#e2e8f0;color:#4a5568;display:flex;align-items:center;justify-content:center;gap:.5rem}.nav-button-back svg{flex-shrink:0}.nav-button-back:hover{background:#cbd5e0;transform:translate(-2px)}.nav-button-skip{background:transparent;color:#667eea;border:2px solid #667eea}.nav-button-skip:hover{background:#667eea1a;transform:translateY(-2px)}.navigation-error{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1.5rem;color:#e53e3e;background:#fff5f5}@media(max-width:768px){.navigation-header,.navigation-content,.navigation-footer{padding:1rem}.navigation-content{align-items:flex-start}.step-title{font-size:1.5rem}.step-description{font-size:1rem}.navigation-footer{flex-direction:column-reverse}.nav-button{width:100%}}.vademecum-container{background:linear-gradient(135deg,#f6f8fb,#fff);border-radius:12px;padding:.75rem 1rem;margin-bottom:1rem;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0000000a}.vademecum-title{font-size:1rem;font-weight:700;color:#2d3748;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.vademecum-icon{color:#ed8936;width:20px;height:20px}.vademecum-item-icon{color:#667eea;flex-shrink:0;width:18px;height:18px}.vademecum-items{display:flex;flex-direction:column;gap:.5rem}.vademecum-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:#fff;border-radius:10px;transition:all .2s ease}.vademecum-item:hover{transform:translate(2px);box-shadow:0 2px 8px #667eea14}.vademecum-image img{width:40px;height:40px;border-radius:6px;object-fit:cover;cursor:pointer}.vademecum-text{flex:1;color:#4a5568;line-height:1.4;margin:0;font-size:.9rem}.action-button{height:56px;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:0 2rem;font-size:1.125rem;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;font-family:inherit;min-width:200px;box-shadow:0 4px 15px #0000001a}.action-icon{display:inline-flex;align-items:center;justify-content:center}.actions-info{margin-top:2rem;font-size:.95rem;color:#4a5568;background:#f7fafc;padding:1rem;border-radius:12px;border-left:4px solid #667eea;display:flex;align-items:center;gap:.75rem;text-align:left}.actions-info svg{color:#ed8936;flex-shrink:0}.action-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.action-button:active:not(:disabled){transform:translateY(0)}.action-button:disabled{opacity:.5;cursor:not-allowed}.action-button-confirm{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff}.action-button-confirm:hover:not(:disabled){background:linear-gradient(135deg,#38a169,#2f855a)}.action-button-cancel{background:linear-gradient(135deg,#f56565,#e53e3e);color:#fff}.action-button-cancel:hover:not(:disabled){background:linear-gradient(135deg,#e53e3e,#c53030)}.action-button-reschedule{background:linear-gradient(135deg,#ed8936,#dd6b20);color:#fff}.action-button-reschedule:hover:not(:disabled){background:linear-gradient(135deg,#dd6b20,#c05621)}.timeslot-picker{background:#fff;border-radius:16px;padding:2rem;margin:2rem 0;box-shadow:0 4px 20px #00000014;animation:slideIn .4s ease-out}.picker-group{margin-bottom:1.5rem}.picker-group:last-child{margin-bottom:0}.picker-label{display:block;margin-bottom:.75rem;font-weight:600;color:#2d3748;font-size:1rem}.picker-select{width:100%;padding:1rem 2.5rem 1rem 1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;font-family:inherit;background:#fff;color:#2d3748;cursor:pointer;transition:all .3s ease;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%232d3748%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E);background-repeat:no-repeat;background-position:right 1.2rem center;background-size:.8rem auto}.picker-select:hover{border-color:#cbd5e0}.picker-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.success-overlay{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.success-card{background:#fff;border-radius:24px;padding:3rem;text-align:center;max-width:450px;width:90%;box-shadow:0 20px 60px #0006;animation:scaleIn .5s cubic-bezier(.34,1.56,.64,1);position:relative;z-index:1001}@keyframes scaleIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.success-icon{display:flex;justify-content:center;margin-bottom:2rem;animation:iconPulse .6s ease-out}@keyframes iconPulse{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.success-title{font-size:2rem;font-weight:700;color:#48bb78;margin-bottom:1rem}.success-message{font-size:1.125rem;color:#4a5568;line-height:1.6;margin-bottom:2rem}.success-button{padding:1rem 2.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:inherit}.success-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}@media(max-width:768px){.vademecum-container{padding:1rem}.vademecum-item{padding:.5rem}.action-button{width:100%;min-width:unset}.timeslot-picker{padding:1.5rem}.success-card{margin:1rem;padding:2rem}.success-title{font-size:1.5rem}}.flexibility-input{padding:1rem;background:#f8fafc;border-radius:20px;box-shadow:0 4px 15px #0000000d}.flex-explanation{margin-bottom:1.5rem;text-align:center;color:#2d3748;font-size:1rem;font-weight:600}.flex-explanation p{margin:0;line-height:1.6}.flex-calendar{margin-bottom:1.5rem}.flex-calendar-header{display:flex;justify-content:center;gap:1.5rem;align-items:center;margin-bottom:1rem}.flex-month-label{min-width:180px;text-align:center;font-weight:800;color:#1e293b;font-size:1.1rem;letter-spacing:1px;text-transform:uppercase}.flex-calendar-header button{background:#f1f5f9;border:none;width:36px;height:36px;border-radius:50%;cursor:pointer;font-weight:800;color:#475569;transition:all .2s;display:flex;align-items:center;justify-content:center;line-height:1;font-size:1.1rem;padding:0}.flex-calendar-header button:hover{background:#e2e8f0}.flex-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:#e2e8f0;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;padding:3px}.flex-day-header{background:#f8fafc;padding:.75rem .25rem;text-align:center;font-size:.7rem;font-weight:800;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.flex-day{background:#fff;min-height:52px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-weight:700;transition:all .2s cubic-bezier(.4,0,.2,1);font-size:.9rem;border:none;font-family:inherit;color:#1e293b;width:100%;margin:0;padding:0;box-sizing:border-box}.flex-day:hover:not(.empty):not(.disabled){background:#f1f5f9}.flex-day.selected{background:#667eea!important;color:#fff!important;border-radius:8px;z-index:1;box-shadow:0 2px 8px #667eea66}.flex-day.disabled{color:#cbd5e0;cursor:not-allowed;background:#fbfcfe}.flex-day.empty{cursor:default;background:#f8fafc}.flex-availability-dot{width:6px;height:6px;background:#48bb78;border-radius:50%;position:absolute;bottom:5px;left:50%;transform:translate(-50%)}.flex-day.selected .flex-availability-dot{background:#fff}.flex-entries-list{display:flex;flex-direction:column;gap:1rem}.flex-entry-item{background:#fff;border-radius:14px;padding:1rem;box-shadow:0 2px 10px #0000000a}.flex-entry-date{font-weight:700;color:#2d3748;margin-bottom:.75rem;text-transform:capitalize}.flex-entry-presets{display:flex;gap:.5rem;justify-content:space-between}.flex-preset-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:.75rem .25rem;border:1px solid #e2e8f0;border-radius:12px;background:#fff;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);min-height:48px}.flex-preset-btn:hover:not(.active){background:#f8fafc;border-color:#cbd5e0;transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.flex-preset-btn.active{background:#667eea;border-color:#5a67d8;color:#fff;box-shadow:0 4px 14px #667eea66;transform:scale(1.02)}.preset-name{font-size:.7rem;font-weight:700;text-transform:uppercase;color:#4a5568;letter-spacing:.5px}.flex-preset-btn.active .preset-name{color:#fff}.fixed-flex-actions{position:fixed!important;bottom:0;left:0;right:0;background:#fff;padding:1.5rem 1.25rem 2.5rem;border-radius:20px 20px 0 0;box-shadow:0 -4px 24px #0000001f;z-index:2100;display:flex;flex-direction:column;gap:.75rem;animation:slideUp .4s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media(max-width:640px){.flexibility-input{padding:1rem}}.appointment-management{width:100%;margin:0 auto;padding:1.5rem 0}.appointment-details{background:#fff;border-radius:16px;padding:1rem 1.5rem;margin-bottom:.75rem;box-shadow:0 4px 20px #00000014;transition:all .3s ease}.appointment-details.compact{padding:1rem 2rem;margin-bottom:1rem}.appointment-details.compact .details-title{margin-bottom:.75rem;padding-bottom:.5rem;font-size:1.1rem}.appointment-details.compact .details-grid{gap:.75rem}.appointment-details.compact .detail-value{font-size:1rem}.details-title{font-size:1.05rem;font-weight:700;color:#2d3748;margin-bottom:.5rem;padding-bottom:.4rem;border-bottom:1px solid #f1f5f9;display:flex;align-items:center;justify-content:space-between}.group-tag{background-color:#fce7f3;color:#be185d;font-size:.75rem;font-weight:700;padding:.2rem .6rem;border-radius:9999px;letter-spacing:.5px;text-transform:uppercase}.details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.detail-item{display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:.5rem;padding:.1rem 0}.detail-label{font-size:.8rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:.95rem;font-weight:700;color:#1e293b;text-align:right}.status-banner{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem;border-radius:16px;margin-bottom:1.5rem;box-shadow:0 4px 15px #0000000d;animation:slideIn .3s ease-out}.status-banner.cancelled{background:#fff5f5;border-left:5px solid #e53e3e}.status-banner.past{background:#fffbef;border-left:5px solid #ecc94b}.banner-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;font-size:1.2rem;flex-shrink:0}.status-banner.cancelled .banner-icon{background:#fed7d7;color:#c53030}.status-banner.past .banner-icon{background:#fefcbf;color:#b7791f}.banner-content h4{margin:0 0 .25rem;font-size:1.1rem;font-weight:700}.status-banner.cancelled .banner-content h4{color:#c53030}.status-banner.past .banner-content h4{color:#b7791f}.banner-content p{margin:0;font-size:.95rem;color:#4a5568;line-height:1.4}.actions-container{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px #00000014;text-align:center}.actions-title{font-size:1.5rem;font-weight:700;color:#2d3748;margin-bottom:2rem}.actions-buttons{display:flex;flex-direction:column;align-items:center;gap:1.25rem;max-width:320px;margin:0 auto}.actions-buttons button{width:100%}.reschedule-container{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px #00000014;animation:slideIn .4s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInMobile{0%{opacity:0}to{opacity:1}}.reschedule-title{font-size:1.5rem;font-weight:700;color:#2d3748;margin-bottom:1.5rem;text-align:center}.reschedule-actions{display:flex;flex-direction:column;gap:1rem;margin-top:2rem;align-items:center}.back-button{padding:.875rem 2rem;background:transparent;color:#667eea;border:2px solid #667eea;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:inherit;margin-top:1rem}.back-button:hover{background:#667eea1a}.nav-button{background:#f1f5f9;border:none;width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:100%;cursor:pointer;font-weight:700;color:#4a5568;transition:all .2s}.nav-button:disabled{opacity:.3;cursor:not-allowed;background:#f1f5f9!important;color:#cbd5e0!important}.nav-button:hover:not(:disabled){background:#e2e8f0;color:#667eea}.practitioner-grid{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.practitioner-card{background:#f8fafc;border:1px solid #edf2f7;border-radius:16px;padding:1rem 1.5rem;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:row;align-items:center;gap:1.25rem;text-align:left}.practitioner-card:hover{border-color:#cbd5e0;transform:translateY(-2px)}.practitioner-card.selected{border-color:#667eea;background:#fff;box-shadow:0 4px 12px #667eea26}.practitioner-avatar{width:50px;height:50px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;box-shadow:0 4px 10px #667eea4d;flex-shrink:0}.practitioner-name{display:block;font-weight:700;color:#2d3748;margin-bottom:.25rem}.practitioner-role{font-size:.8rem;color:#718096}.calendar-month{background:#fff;border-radius:12px;padding:.25rem}.calendar-header{display:flex;justify-content:center;align-items:center;gap:1.5rem;margin-bottom:1rem}.calendar-header strong{font-size:1rem;color:#2d3748;min-width:160px;text-align:center;white-space:nowrap;text-transform:uppercase;letter-spacing:1px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:#edf2f7;border:1px solid #edf2f7;border-radius:8px;overflow:hidden}.calendar-day-header{background:#f8fafc;padding:.4rem .25rem;text-align:center;font-size:.75rem;font-weight:700;color:#4a5568;text-transform:uppercase}.calendar-day{background:#fff;min-height:48px;padding:.25rem;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .1s;font-weight:600;position:relative}.calendar-day:hover:not(.empty):not(.disabled){background:#f1f5f9}.calendar-day.selected{background:#667eea!important;color:#fff!important;border-radius:6px;z-index:1}.calendar-day.available{color:#2d3748}.calendar-day.disabled{color:#cbd5e0;cursor:not-allowed;background:#fbfcfe}.calendar-day.empty{cursor:default;background:#f8fafc}.availability-dot{width:6px;height:6px;background:#48bb78;border-radius:50%;position:absolute;bottom:8px}.calendar-day.selected .availability-dot{background:#fff}.slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem;margin-top:1rem}.no-slots-message{grid-column:1 / -1;text-align:center;padding:2rem;color:#718096;background:#f8fafc;border-radius:12px;border:2px dashed #e2e8f0}.slot-item{padding:.875rem;border:2px solid #e2e8f0;border-radius:12px;text-align:center;cursor:pointer;font-weight:700;font-size:1rem;transition:all .2s;background:#fff;color:#2d3748}.slot-item:hover:not(.disabled){border-color:#667eea;color:#667eea;background:#f0f4ff}.slot-item.selected{background:#667eea;border-color:#667eea;color:#fff;box-shadow:0 4px 12px #667eea40}.slot-item.disabled{background:#f8fafc;color:#cbd5e0;cursor:not-allowed;border-style:dashed;border-width:1px}.wizard-step-title{font-size:1.125rem;font-weight:700;color:#2d3748;margin:1.5rem 0 1rem;text-align:left;display:flex;align-items:center;gap:.5rem}.wizard-step-info{font-size:.9rem;color:#718096;margin-bottom:1.5rem}@media(max-width:768px){.appointment-management{padding:1rem .75rem}.reschedule-container{animation:fadeInMobile .4s ease-out;padding:1.25rem 1rem;margin-bottom:1rem}.appointment-details{padding:1rem;margin-bottom:.75rem}.details-title{font-size:1.05rem;margin-bottom:.5rem;padding-bottom:.4rem}.details-grid{grid-template-columns:1fr;gap:.5rem}.detail-item{flex-direction:row;justify-content:space-between;align-items:center;gap:.75rem;padding:0}.detail-label{font-size:.75rem}.detail-value{font-size:.9rem;text-align:right}.reschedule-title{font-size:1.25rem;margin-bottom:1rem}.practitioner-grid{grid-template-columns:1fr;gap:.75rem}.practitioner-card{padding:1rem;flex-direction:row;align-items:center;text-align:left;gap:1rem}.practitioner-avatar{width:40px;height:40px;margin-bottom:0;font-size:1rem}.calendar-month{padding:.5rem}.calendar-day{min-height:45px;font-size:.9rem}.slots-grid{grid-template-columns:repeat(3,1fr);gap:.5rem}.slot-item{padding:.6rem .25rem;font-size:.85rem}.actions-container{position:fixed;bottom:0;left:0;right:0;width:100%;margin:0;padding:1.5rem 1.25rem 2.5rem;border-radius:20px 20px 0 0;box-shadow:0 -4px 24px #0000001f;z-index:1000;background:#fff}.reschedule-actions{position:fixed;bottom:0;left:0;right:0;width:100%;margin:0;padding:1.5rem 1.25rem 2.5rem;background:#fff;border-radius:20px 20px 0 0;box-shadow:0 -4px 24px #0000001f;z-index:1000;display:flex;flex-direction:column;gap:.75rem}.reschedule-actions button{width:100%;padding:.75rem}.back-button{width:100%;margin-top:0}.appointment-management{padding-bottom:250px}}.contact-appointments-list{padding:1.5rem;max-width:800px;margin:0 auto;animation:fadeIn .4s ease-out}.contact-welcome{text-align:center;margin-bottom:2.5rem}.contact-welcome h2{font-size:1.8rem;color:#fff;margin-bottom:.5rem;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.2)}.contact-welcome p{color:#e2e8f0;font-size:1rem}.appointments-grid{display:flex;flex-direction:column;gap:1.2rem;margin-bottom:3rem}.appointment-card{background:#fff;border-radius:16px;padding:1.25rem 1.5rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;border:1px solid #edf2f7;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden;width:100%}.appointment-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;border-color:#6366f1}.appointment-card:active{transform:scale(.98)}.card-content{display:flex;flex-direction:column;gap:.4rem;flex:1;min-width:0;padding-right:1rem}.service-header{display:flex;align-items:center;gap:.6rem;min-width:0}.service-name{font-size:1.15rem;font-weight:700;color:#1a202c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-badge-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:.75rem;font-weight:800;flex-shrink:0}.status-badge-icon.cancelled{background:#fff5f5;color:#e53e3e;border:1px solid #feb2b2}.status-badge-icon.past{background:#fffbef;color:#d69e2e;border:1px solid #f6e05e}.practitioner-name{font-size:.9rem;color:#4a5568;display:flex;align-items:center;gap:.4rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.practitioner-name:before{content:"👤";font-size:.8rem}.appointment-time-info{display:flex;flex-direction:column;align-items:flex-end;text-align:right;flex-shrink:0}.date-badge{background:#f0f4ff;color:#4338ca;padding:.4rem .8rem;border-radius:8px;font-size:.85rem;font-weight:600;margin-bottom:.4rem;white-space:nowrap}.time-range{font-size:.95rem;color:#4a5568;font-weight:500;white-space:nowrap}.card-arrow{margin-left:1rem;color:#cbd5e0}.policy-banner{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);padding:1rem 1.5rem;border-radius:12px;margin-bottom:2rem;display:flex;align-items:center;gap:1rem;color:#fff;font-size:.95rem;box-shadow:0 4px 12px #0000000d}.policy-icon{font-size:1.25rem}.policy-text strong{color:#fff;text-decoration:underline;text-underline-offset:2px}.appointment-card.is-locked{background:#fdfdfd;border-color:#f1f5f9}.appointment-card.is-locked .service-name{color:#718096}.status-badge-icon.locked{background:#f7fafc;color:#a0aec0;border:1px solid #e2e8f0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:600px){.appointment-card{padding:1.2rem}.service-name{font-size:1rem}.date-badge{font-size:.75rem}.policy-banner{padding:.8rem 1rem;font-size:.85rem;margin-bottom:1.5rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{width:100%;min-height:100vh;margin:0;padding:0;overflow-y:auto;background-color:var(--color-bg);display:flex;justify-content:center;align-items:flex-start}.app-loading{display:flex;flex-direction:column;justify-content:center;align-items:center;width:100vw;height:100vh;background:linear-gradient(135deg,#1a1c2c,#0d0f1a);color:#fff}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.1);border-left-color:#2e7bd6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.app-error{display:flex;flex-direction:column;justify-content:center;align-items:center;width:100vw;height:100vh;background-color:#0f1118;color:#fff;text-align:center;padding:2rem}.error-icon{font-size:3rem;margin-bottom:1rem}.app-error h2{font-size:1.5rem;margin-bottom:1rem;color:#ff4d4d}.app-error p{font-size:1.1rem;margin-bottom:2rem;color:#94a3b8;max-width:400px}.app-error button{padding:.75rem 2rem;background:linear-gradient(135deg,#2e7bd6,#1e40af);border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:transform .2s}.app-error button:hover{transform:scale(1.05)}
