@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--bg-primary: #f7f7f9;--bg-secondary: #ffffff;--bg-tertiary: #f0f0f3;--bg-card: #ffffff;--bg-card-hover: #fafafa;--bg-input: #f4f4f7;--bg-glass: rgba(255, 255, 255, .7);--text-primary: #16162a;--text-secondary: #5c5c7a;--text-tertiary: #9898b0;--border-color: #e6e6ee;--border-light: #f0f0f5;--accent: #c9a84c;--accent-hover: #b89440;--accent-light: rgba(201, 168, 76, .1);--accent-glow: rgba(201, 168, 76, .25);--success: #10b981;--success-bg: rgba(16, 185, 129, .08);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .08);--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .08);--info: #3b82f6;--info-bg: rgba(59, 130, 246, .08);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .06);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .08);--shadow-accent: 0 4px 20px rgba(201, 168, 76, .2);--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--radius-xl: 24px;--transition: .25s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--bg-primary: #0b0b12;--bg-secondary: #12121c;--bg-tertiary: #181825;--bg-card: #16162a;--bg-card-hover: #1e1e35;--bg-input: #181825;--bg-glass: rgba(18, 18, 28, .8);--text-primary: #ededf4;--text-secondary: #9898b8;--text-tertiary: #5c5c7a;--border-color: #252540;--border-light: #1e1e32;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .15);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .2);--shadow-md: 0 4px 16px rgba(0, 0, 0, .25);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .35);--shadow-accent: 0 4px 20px rgba(201, 168, 76, .15)}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .4s ease-out both}.pulse{animation:pulse 2s ease-in-out infinite}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;transition:background-color .35s,color .35s;overflow-x:hidden}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit;border:none;background:none;color:inherit}input,select{font-family:inherit}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:2rem 1.5rem 4rem}.booking-page{max-width:680px;margin:0 auto}.header{background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100;transition:background var(--transition)}.header-content{max-width:1200px;margin:0 auto;padding:0 1.5rem;height:64px;display:flex;align-items:center;justify-content:space-between}.header-logo{display:flex;align-items:center;gap:.75rem}.logo-icon{width:40px;height:40px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-accent)}.logo-text h1{font-size:1.15rem;font-weight:700;letter-spacing:-.02em;line-height:1.2;color:var(--text-primary)}.header-subtitle{font-size:.65rem;text-transform:uppercase;letter-spacing:.2em;color:var(--text-tertiary);font-weight:600}.menu-toggle{display:none;width:40px;height:40px;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-secondary)}.header-nav{display:flex;align-items:center;gap:.35rem}.nav-divider{width:1px;height:24px;background:var(--border-color);margin:0 .35rem}.nav-link{display:flex;align-items:center;gap:.5rem;padding:.5rem .9rem;border-radius:var(--radius-sm);font-size:.85rem;font-weight:500;color:var(--text-secondary);transition:all var(--transition)}.nav-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-link.active{background:var(--accent-light);color:var(--accent);font-weight:600}.nav-user-name{font-size:.82rem;font-weight:500;color:var(--text-secondary);padding:.3rem .5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.theme-toggle{padding:0;display:flex;align-items:center}.theme-toggle-track{width:48px;height:26px;border-radius:13px;background:var(--bg-tertiary);border:1px solid var(--border-color);position:relative;display:flex;align-items:center;justify-content:space-between;padding:0 5px;transition:all var(--transition)}.theme-icon{color:var(--text-tertiary);z-index:1;transition:color var(--transition)}.sun-icon{color:var(--warning)}.theme-toggle-thumb{position:absolute;left:3px;width:20px;height:20px;border-radius:50%;background:var(--accent);box-shadow:var(--shadow-sm);transition:transform var(--transition)}.theme-toggle-thumb.dark{transform:translate(22px)}.step-indicator{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:2rem;padding:1rem;background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.step{display:flex;align-items:center;gap:.5rem}.step:not(:last-child):after{content:"";width:32px;height:2px;background:var(--border-color);margin:0 .4rem;border-radius:1px;transition:background var(--transition)}.step.completed:not(:last-child):after{background:var(--accent)}.step-circle{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;border:2px solid var(--border-color);color:var(--text-tertiary);background:var(--bg-secondary);transition:all var(--transition);flex-shrink:0}.step.active .step-circle{border-color:var(--accent);background:var(--accent);color:#fff;box-shadow:0 0 0 4px var(--accent-light)}.step.completed .step-circle{border-color:var(--accent);background:var(--accent);color:#fff}.step-label{font-size:.78rem;color:var(--text-tertiary);font-weight:500;white-space:nowrap}.step.active .step-label{color:var(--text-primary);font-weight:600}.step.completed .step-label{color:var(--accent)}.page-header{margin-bottom:1.75rem}.page-header.centered{text-align:center}.page-header-icon{width:48px;height:48px;border-radius:var(--radius-md);background:var(--accent-light);color:var(--accent);display:inline-flex;align-items:center;justify-content:center;margin-bottom:.75rem}.page-header h2{font-size:1.5rem;font-weight:700;letter-spacing:-.03em;margin-bottom:.25rem}.page-header p{color:var(--text-secondary);font-size:.9rem}.back-button{display:inline-flex;align-items:center;gap:.4rem;color:var(--text-secondary);font-size:.85rem;font-weight:500;margin-bottom:1.25rem;padding:.4rem .75rem .4rem 0;border-radius:var(--radius-sm);transition:all var(--transition)}.back-button:hover{color:var(--accent)}.professionals-grid{display:flex;flex-direction:column;gap:.75rem}.professional-card{display:flex;align-items:center;gap:1rem;padding:1.1rem 1.25rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition);text-align:left;width:100%}.professional-card:hover{background:var(--bg-card-hover);border-color:var(--accent);box-shadow:var(--shadow-md),0 0 0 1px var(--accent-light);transform:translateY(-2px)}.professional-avatar-wrapper{position:relative;flex-shrink:0}.professional-avatar{width:56px;height:56px;border-radius:50%;object-fit:cover;border:2.5px solid var(--border-color);transition:border-color var(--transition)}.professional-card:hover .professional-avatar{border-color:var(--accent)}.avatar-status{position:absolute;bottom:2px;right:2px;width:12px;height:12px;border-radius:50%;border:2px solid var(--bg-card)}.avatar-status.online{background:var(--success)}.professional-info{flex:1}.professional-info h3{font-size:1rem;font-weight:600;margin-bottom:.1rem}.professional-specialty{font-size:.8rem;color:var(--text-secondary)}.professional-rating{display:inline-flex;align-items:center;gap:.25rem;color:var(--accent);font-size:.78rem;font-weight:700;margin-top:.3rem;background:var(--accent-light);padding:.15rem .5rem;border-radius:20px}.card-arrow{color:var(--text-tertiary);flex-shrink:0;transition:all var(--transition)}.professional-card:hover .card-arrow{color:var(--accent);transform:translate(3px)}.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.service-card{display:flex;flex-direction:column;padding:1.25rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition);text-align:left;width:100%;gap:0}.service-card:hover{background:var(--bg-card-hover);border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.service-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.35rem;background:var(--bg-tertiary);border-radius:var(--radius-sm);margin-bottom:.75rem;flex-shrink:0}.service-info{flex:1}.service-info h3{font-size:.92rem;font-weight:600;margin-bottom:.2rem}.service-description{font-size:.78rem;color:var(--text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.service-footer{display:flex;align-items:center;justify-content:space-between;margin-top:.75rem;padding-top:.65rem;border-top:1px solid var(--border-light)}.service-price{font-size:.95rem;font-weight:700;color:var(--accent)}.service-duration{font-size:.75rem;color:var(--text-tertiary);display:flex;align-items:center;gap:.25rem;font-weight:500}.datetime-layout{display:flex;flex-direction:column;gap:1.5rem}.calendar-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.calendar-month{font-size:.95rem;font-weight:600;text-transform:capitalize;display:flex;align-items:center;gap:.5rem;color:var(--text-primary)}.calendar-nav{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all var(--transition);border:1px solid var(--border-color)}.calendar-nav:hover:not(:disabled){background:var(--accent-light);color:var(--accent);border-color:var(--accent)}.calendar-nav:disabled{opacity:.3;cursor:not-allowed}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem}.calendar-day{display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.65rem .25rem;border-radius:var(--radius-sm);transition:all var(--transition);border:2px solid transparent;position:relative}.calendar-day:not(.past):hover{background:var(--bg-tertiary);border-color:var(--border-color)}.calendar-day.selected{background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;border-color:transparent;box-shadow:var(--shadow-accent)}.calendar-day.today:not(.selected){border-color:var(--accent)}.calendar-day.past{opacity:.25;cursor:not-allowed}.day-name{font-size:.68rem;text-transform:uppercase;font-weight:600;color:var(--text-tertiary);letter-spacing:.02em}.calendar-day.selected .day-name{color:#ffffffbf}.day-number{font-size:1.05rem;font-weight:700}.day-dot{width:4px;height:4px;border-radius:50%;background:var(--accent);position:absolute;bottom:4px}.time-slots-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem}.time-slots-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.time-slots-header h3{font-size:1rem;font-weight:600}.time-slots-count{font-size:.78rem;font-weight:600;color:var(--success);background:var(--success-bg);padding:.2rem .65rem;border-radius:20px}.time-slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(75px,1fr));gap:.5rem}.time-slot{padding:.55rem;text-align:center;font-size:.85rem;font-weight:600;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-secondary);transition:all var(--transition)}.time-slot:hover:not(.unavailable){border-color:var(--accent);background:var(--accent-light);color:var(--accent)}.time-slot.selected{background:linear-gradient(135deg,var(--accent),var(--accent-hover));border-color:transparent;color:#fff;box-shadow:var(--shadow-accent)}.time-slot.unavailable{opacity:.2;cursor:not-allowed;text-decoration:line-through}.booking-footer{position:sticky;bottom:0;padding:1rem 0;background:var(--bg-primary);display:flex;align-items:center;justify-content:space-between;gap:1rem;border-top:1px solid var(--border-color);margin-top:1rem}.booking-footer-info{display:flex;flex-direction:column;font-size:.85rem;color:var(--text-secondary);text-transform:capitalize}.booking-footer-info strong{font-size:1.1rem;color:var(--accent)}.confirm-layout{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.booking-summary h3,.client-form h3{font-size:1rem;font-weight:600;margin-bottom:.75rem}.summary-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1.25rem}.summary-row{display:flex;align-items:flex-start;gap:.75rem;padding:.6rem 0;border-bottom:1px solid var(--border-light)}.summary-row:last-of-type{border-bottom:none}.summary-icon{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);flex-shrink:0}.summary-row div:not(.summary-icon){display:flex;flex-direction:column}.summary-label{font-size:.7rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.summary-value{font-size:.9rem;font-weight:500;color:var(--text-primary)}.summary-total{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;margin-top:.5rem;border-top:2px solid var(--border-color);font-weight:600;font-size:.95rem}.total-price{font-size:1.25rem;font-weight:800;color:var(--accent)}.client-form{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1.5rem}.form-group{margin-bottom:1.15rem}.form-group label{display:flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.03em}.form-group input{width:100%;padding:.8rem 1rem;background:var(--bg-input);border:1.5px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;color:var(--text-primary);transition:all var(--transition);outline:none}.form-group input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-light);background:var(--bg-secondary)}.form-group input::placeholder{color:var(--text-tertiary)}.confirmation-success{text-align:center;padding:2.5rem 1rem}.success-icon-wrapper{position:relative;display:inline-flex;margin-bottom:1.5rem}.success-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--success),#059669);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 30px #10b9814d}.confetti-icon{position:absolute;top:-8px;right:-12px;color:var(--warning);animation:fadeIn .5s ease-out .3s both}.confirmation-success h2{font-size:1.5rem;margin-bottom:.35rem}.confirmation-success>p{color:var(--text-secondary);margin-bottom:1.5rem}.confirmation-details{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem;text-align:left;margin-bottom:1.5rem;max-width:420px;margin-left:auto;margin-right:auto}.detail-row{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid var(--border-light)}.detail-row:last-of-type{border-bottom:none}.detail-icon{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);flex-shrink:0}.detail-content{display:flex;flex-direction:column}.detail-label{font-size:.68rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.detail-value{font-size:.9rem;font-weight:500;color:var(--text-primary)}.detail-total{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;margin-top:.5rem;border-top:2px solid var(--border-color);font-weight:600}.confirmation-note{font-size:.82rem;color:var(--text-tertiary);margin-bottom:1.5rem}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;padding:.75rem 1.5rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;transition:all var(--transition);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:var(--shadow-accent);letter-spacing:.01em}.btn-primary:hover{box-shadow:var(--shadow-lg),var(--shadow-accent);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.btn-full{width:100%}.btn-lg{padding:.9rem 1.5rem;font-size:.95rem}.btn-small{padding:.35rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;transition:all var(--transition)}.btn-confirm{background:var(--success-bg);color:var(--success)}.btn-confirm:hover{background:var(--success);color:#fff;box-shadow:0 2px 8px #10b9814d}.btn-complete{background:var(--info-bg);color:var(--info)}.btn-complete:hover{background:var(--info);color:#fff;box-shadow:0 2px 8px #3b82f64d}.btn-cancel{background:var(--danger-bg);color:var(--danger)}.btn-cancel:hover{background:var(--danger);color:#fff;box-shadow:0 2px 8px #ef44444d}.action-buttons{display:flex;gap:.4rem}.admin-page{max-width:1100px;margin:0 auto}.admin-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-bottom:1.75rem}.admin-header h2{font-size:1.6rem;font-weight:700;letter-spacing:-.03em}.admin-header p{color:var(--text-secondary);font-size:.9rem;text-transform:capitalize}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.85rem;margin-bottom:2rem}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1.25rem;display:flex;align-items:center;gap:1rem;transition:all var(--transition)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-blue{background:var(--info-bg);color:var(--info)}.stat-green{background:var(--success-bg);color:var(--success)}.stat-yellow{background:var(--warning-bg);color:var(--warning)}.stat-purple{background:#a855f714;color:#a855f7}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:1.45rem;font-weight:800;line-height:1.2;letter-spacing:-.02em}.stat-label{font-size:.75rem;color:var(--text-secondary);font-weight:500}.dashboard-grid{display:grid;grid-template-columns:1fr minmax(320px,380px);gap:1.25rem}.dashboard-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-header h3{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600}.section-link{display:flex;align-items:center;gap:.2rem;font-size:.8rem;color:var(--accent);font-weight:600;transition:all var(--transition);padding:.3rem .5rem;border-radius:var(--radius-sm)}.section-link:hover{background:var(--accent-light)}.appointments-list{display:flex;flex-direction:column}.appointment-item{display:flex;align-items:center;gap:1rem;padding:.85rem 0;border-bottom:1px solid var(--border-light);transition:all var(--transition)}.appointment-item:last-child{border-bottom:none}.appointment-time{width:52px;height:52px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--accent-light);border-radius:var(--radius-sm)}.appointment-time span{font-size:.85rem;font-weight:800;color:var(--accent)}.appointment-details{flex:1;min-width:0}.appointment-client{font-size:.9rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.appointment-service{font-size:.78rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.appointment-price{font-size:.8rem;font-weight:700;color:var(--accent);margin-top:.15rem}.appointment-actions{display:flex;flex-direction:column;align-items:flex-end;gap:.4rem;flex-shrink:0}.financial-summary{display:flex;flex-direction:column}.financial-row{display:flex;justify-content:space-between;align-items:center;padding:.7rem 0;font-size:.85rem;color:var(--text-secondary);border-bottom:1px solid var(--border-light)}.financial-row:last-child{border-bottom:none}.financial-row.total{border-top:2px solid var(--border-color);border-bottom:none;padding-top:.85rem;margin-top:.35rem;font-weight:600;color:var(--text-primary)}.financial-value{font-weight:700;color:var(--text-primary)}.financial-value.highlight{color:var(--accent);font-size:1.15rem}.team-list{display:flex;flex-direction:column;gap:.85rem}.team-member{display:flex;align-items:center;gap:.75rem;padding:.5rem;border-radius:var(--radius-sm);transition:all var(--transition)}.team-member:hover{background:var(--bg-tertiary)}.team-member img{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid var(--border-color)}.team-info{display:flex;flex-direction:column}.team-name{font-size:.875rem;font-weight:600}.team-count{font-size:.75rem;color:var(--text-secondary)}.empty-state{text-align:center;padding:2.5rem 1rem;color:var(--text-tertiary)}.empty-state svg{margin-bottom:.75rem;opacity:.35}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .6rem;border-radius:20px;font-size:.7rem;font-weight:700;white-space:nowrap;letter-spacing:.01em}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.filters-bar{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.search-box{flex:1;min-width:250px;display:flex;align-items:center;gap:.6rem;padding:0 1rem;background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);transition:border-color var(--transition)}.search-box:focus-within{border-color:var(--accent)}.search-box input{flex:1;padding:.7rem 0;background:transparent;border:none;color:var(--text-primary);font-size:.85rem;outline:none}.search-box input::placeholder{color:var(--text-tertiary)}.filter-group{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary)}.filter-group select,.filter-group input[type=date]{padding:.7rem .85rem;background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.8rem;outline:none;transition:border-color var(--transition)}.filter-group select:focus,.filter-group input[type=date]:focus{border-color:var(--accent)}.appointments-table{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow-x:auto}.table-header{display:grid;grid-template-columns:minmax(120px,1fr) minmax(140px,1.2fr) minmax(100px,1fr) minmax(100px,1fr) 90px 100px minmax(100px,1fr);gap:.5rem;padding:.85rem 1.5rem;background:var(--bg-tertiary);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary)}.table-row{display:grid;grid-template-columns:minmax(120px,1fr) minmax(140px,1.2fr) minmax(100px,1fr) minmax(100px,1fr) 90px 100px minmax(100px,1fr);gap:.5rem;padding:.85rem 1.5rem;align-items:center;font-size:.85rem;border-bottom:1px solid var(--border-light);transition:background var(--transition)}.table-row:hover{background:var(--bg-card-hover)}.table-row:last-child{border-bottom:none}.cell-datetime{display:flex;flex-direction:column}.cell-datetime strong{font-size:.8rem}.cell-datetime small{color:var(--text-secondary);font-size:.75rem}.cell-client{display:flex;flex-direction:column;min-width:0}.cell-client strong{font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-client small{color:var(--text-tertiary);font-size:.72rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-price{font-weight:700;color:var(--accent)}.cell-actions{display:flex;gap:.35rem;flex-wrap:wrap}@media(max-width:960px){.main-content{max-width:100%}.dashboard-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.table-header{display:none}.table-row{display:flex;flex-wrap:wrap;gap:.5rem;padding:1rem 1.25rem}.cell-datetime{width:100%}.confirm-layout{grid-template-columns:1fr}.admin-header{flex-direction:column;align-items:flex-start;gap:.75rem}}@media(max-width:640px){.main-content{padding:1rem .75rem 4rem}.header-content{padding:0 .75rem}.logo-text h1{font-size:1rem}.menu-toggle{display:flex}.header-nav{display:none;position:absolute;top:64px;left:0;right:0;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:.75rem;flex-direction:column;gap:.25rem;box-shadow:var(--shadow-lg);z-index:100}.header-nav.open{display:flex}.nav-divider{width:100%;height:1px;margin:.25rem 0}.nav-link{width:100%;padding:.7rem;border-radius:var(--radius-sm)}.nav-user-name{padding:.4rem .7rem;font-size:.85rem;color:var(--text-secondary)}.theme-toggle{align-self:center;margin-top:.25rem}.services-grid{grid-template-columns:1fr}.step-indicator{padding:.6rem;margin-bottom:1.25rem}.step-label{display:none}.step:not(:last-child):after{width:16px}.stats-grid{grid-template-columns:1fr 1fr;gap:.5rem}.stat-card{padding:.85rem;gap:.65rem}.stat-icon{width:40px;height:40px}.stat-value{font-size:1.15rem}.stat-label{font-size:.7rem}.filters-bar{flex-direction:column}.search-box{min-width:100%}.filter-group{width:100%}.filter-group select,.filter-group input[type=date]{flex:1;width:100%}.page-header h2{font-size:1.25rem}.page-header p{font-size:.82rem}.booking-footer{padding:.75rem 0}.booking-page{max-width:100%}.calendar-section{padding:1rem}.calendar-days{gap:.25rem}.calendar-day{padding:.45rem .15rem}.day-name{font-size:.6rem}.day-number{font-size:.9rem}.calendar-month{font-size:.88rem}.calendar-nav{width:32px;height:32px}.time-slots-section{padding:1rem}.time-slots-grid{grid-template-columns:repeat(auto-fill,minmax(65px,1fr));gap:.35rem}.time-slot{padding:.45rem;font-size:.8rem}.confirm-layout{grid-template-columns:1fr;gap:1rem}.summary-card,.client-form{padding:1rem}.client-form h3,.booking-summary h3{font-size:.95rem}.confirmation-success{padding:1.5rem .5rem}.confirmation-success h2{font-size:1.25rem}.success-icon{width:64px;height:64px}.confirmation-details{padding:1rem;max-width:100%}.admin-page{max-width:100%}.admin-header{margin-bottom:1.25rem}.admin-header h2{font-size:1.3rem}.admin-header p{font-size:.82rem}.dashboard-section{padding:1rem}.section-header h3{font-size:.9rem}.appointment-item{gap:.65rem;padding:.75rem 0}.appointment-time{width:44px;height:44px}.appointment-time span{font-size:.78rem}.appointment-client{font-size:.82rem}.appointment-service{font-size:.72rem}.appointment-actions{flex-direction:row;flex-wrap:wrap}.appointments-table{border-radius:var(--radius-md)}.table-row{display:flex;flex-direction:column;gap:.4rem;padding:.85rem 1rem}.cell-client{order:-1}.cell-client strong{font-size:.9rem}.cell-actions{margin-top:.35rem;justify-content:flex-start}.professional-card{padding:.85rem 1rem;gap:.75rem}.professional-avatar{width:48px;height:48px}.professional-info h3{font-size:.92rem}.service-card{padding:1rem}.service-icon{width:38px;height:38px;font-size:1.15rem;margin-bottom:.6rem}.my-appointment-card{padding:.85rem 1rem}.my-apt-header{margin-bottom:.5rem}.my-apt-price{font-size:.95rem}.my-apt-row{font-size:.8rem}.crud-grid{grid-template-columns:1fr}.crud-card{padding:1rem}.crud-card-actions{flex-wrap:wrap}.booking-banner{flex-direction:column;text-align:center;padding:1rem .85rem;gap:.85rem}.banner-logo img,.banner-logo-fallback{width:56px;height:56px}.banner-name{font-size:1.15rem}.banner-details{justify-content:center;gap:.5rem}.banner-detail{font-size:.75rem}.banner-auth{width:100%}.banner-btn{width:100%;justify-content:center;padding:.55rem .9rem;font-size:.82rem}.banner-client-info{align-items:center;width:100%}.banner-client-greeting{font-size:.82rem}.banner-client-actions{width:100%;justify-content:center;flex-wrap:wrap;gap:.4rem}.banner-btn-outline{flex:1;justify-content:center;min-width:0}.form-group input{padding:.7rem .85rem;font-size:.85rem}.form-group label{font-size:.72rem}.btn-primary{padding:.7rem 1.25rem;font-size:.85rem}.btn-lg{padding:.8rem 1.25rem;font-size:.9rem}.empty-state{padding:2rem .5rem}.back-button{font-size:.8rem;margin-bottom:1rem}.login-page{padding:1rem .75rem}.login-card{padding:1.5rem 1.25rem}.login-header h1{font-size:1.3rem}.client-auth-page{max-width:100%}.auth-brand h1{font-size:1.3rem}.auth-brand-logo,.auth-brand-logo img{width:64px;height:64px}.modal-content{margin:.5rem;max-height:95vh}.modal-header{padding:1rem 1.25rem}.modal-form{padding:1.25rem}.form-row,.billing-stats{grid-template-columns:1fr}}@media(max-width:380px){.main-content{padding:.75rem .5rem 3rem}.header-content{padding:0 .5rem;height:56px}.header-nav{top:56px}.logo-icon{width:34px;height:34px}.logo-text h1{font-size:.9rem}.header-subtitle{font-size:.58rem}.page-header h2{font-size:1.1rem}.calendar-day{padding:.35rem .1rem}.day-name{font-size:.55rem}.day-number{font-size:.82rem}.step-circle{width:26px;height:26px;font-size:.68rem}.step:not(:last-child):after{width:12px}.stats-grid{grid-template-columns:1fr}.banner-logo img,.banner-logo-fallback{width:48px;height:48px}.banner-name{font-size:1.05rem}.my-apt-body{grid-template-columns:1fr}.time-slots-grid{grid-template-columns:repeat(auto-fill,minmax(58px,1fr))}}.login-page{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 70px);padding:2rem}.login-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:2.5rem;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:2rem}.login-logo{width:64px;height:64px;border-radius:var(--radius-md);background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.login-header h1{font-size:1.5rem;color:var(--text-primary);margin-bottom:.25rem}.login-header p{color:var(--text-secondary);font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:1rem}.login-error{background:var(--danger-bg);color:var(--danger);padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.85rem;display:flex;align-items:center;gap:.5rem}.crud-table{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.crud-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.crud-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.crud-card-header{display:flex;gap:1rem;align-items:flex-start}.crud-card-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover}.crud-card-icon{width:48px;height:48px;border-radius:var(--radius-sm);background:var(--accent-light);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.crud-card-info{flex:1;min-width:0;word-break:break-word}.crud-card-info h3{font-size:1rem;color:var(--text-primary);margin-bottom:.15rem}.crud-card-info p{font-size:.85rem;color:var(--text-secondary)}.professional-phone{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;color:var(--text-secondary);margin-top:.2rem}.crud-card-meta{display:flex;gap:1rem;margin-top:.5rem;font-size:.85rem}.crud-card-actions{display:flex;gap:.5rem;border-top:1px solid var(--border-color);padding-top:1rem}.btn-edit{background:var(--info-bg);color:var(--info);border:none;cursor:pointer;display:flex;align-items:center;gap:.35rem}.btn-edit:hover{background:var(--info);color:#fff}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-lg{max-width:600px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.modal-header h3{font-size:1.1rem;color:var(--text-primary)}.modal-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:var(--radius-sm)}.modal-close:hover{color:var(--text-primary);background:var(--bg-tertiary)}.modal-form{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-section-title{font-size:.9rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-top:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.row-inactive{opacity:.5}.billing-stats{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.billing-stats .stat-card small{display:block;margin-top:.25rem;font-size:.78rem;color:var(--text-tertiary)}.stat-accent{border-left:3px solid var(--accent)}.badge-role-super_admin{background:var(--danger-bg);color:var(--danger)}.badge-role-admin_empresa{background:var(--info-bg);color:var(--info)}.badge-role-funcionario{background:var(--success-bg);color:var(--success)}.booking-banner{display:flex;align-items:center;gap:1.25rem;padding:1.25rem 1.5rem;background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-tertiary) 100%);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:1.5rem;box-shadow:var(--shadow-md);position:relative;overflow:hidden}.booking-banner:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-hover),var(--accent))}.banner-logo{flex-shrink:0}.banner-logo img{width:70px;height:70px;border-radius:50%;object-fit:cover;border:3px solid var(--accent);box-shadow:var(--shadow-accent)}.banner-logo-fallback{width:70px;height:70px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-hover));display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:var(--shadow-accent)}.banner-info{flex:1;min-width:0}.banner-name{font-size:1.4rem;font-weight:700;color:var(--text-primary);margin:0 0 .35rem;letter-spacing:-.02em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.banner-details{display:flex;flex-wrap:wrap;gap:.75rem}.banner-detail{display:flex;align-items:center;gap:.35rem;font-size:.82rem;color:var(--text-secondary)}.banner-auth{flex-shrink:0}.banner-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.1rem;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;border:none;cursor:pointer;transition:all var(--transition);white-space:nowrap}.banner-btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;box-shadow:var(--shadow-accent)}.banner-btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 24px #c9a84c4d}.banner-btn-outline{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-color)}.banner-btn-outline:hover{background:var(--bg-card-hover);border-color:var(--accent);color:var(--accent)}.banner-btn-text{background:none;border:none;color:var(--text-tertiary);font-size:.8rem;cursor:pointer;padding:.3rem .5rem;transition:color var(--transition)}.banner-btn-text:hover{color:var(--danger)}.banner-client-info{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.banner-client-greeting{display:flex;align-items:center;gap:.4rem;font-size:.88rem;color:var(--text-primary)}.banner-client-actions{display:flex;align-items:center;gap:.5rem}.client-auth-page{max-width:440px;margin:0 auto}.auth-brand{text-align:center;margin-bottom:2rem}.auth-brand-logo{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-hover));display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto 1rem;box-shadow:var(--shadow-accent)}.auth-brand-logo img{width:80px;height:80px;border-radius:50%;object-fit:cover}.auth-brand h1{font-size:1.6rem;font-weight:700;color:var(--text-primary);margin:0 0 .3rem}.auth-brand p{color:var(--text-secondary);font-size:.9rem}.auth-tabs{display:flex;background:var(--bg-input);border-radius:var(--radius-sm);padding:4px;margin-bottom:1.5rem}.auth-tab{flex:1;padding:.65rem 1rem;border:none;background:transparent;color:var(--text-secondary);font-size:.9rem;font-weight:600;cursor:pointer;border-radius:calc(var(--radius-sm) - 2px);transition:all var(--transition)}.auth-tab.active{background:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm)}.auth-error{background:var(--danger-bg);color:var(--danger);padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:1rem;border:1px solid rgba(239,68,68,.15)}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-form .btn-primary{margin-top:.5rem}.auth-back{margin-top:1.5rem;justify-content:center;width:100%}.my-appointments-list{display:flex;flex-direction:column;gap:.75rem}.my-appointment-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1rem 1.25rem;transition:all var(--transition)}.my-appointment-card:hover{box-shadow:var(--shadow-sm)}.my-apt-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.my-apt-price{font-weight:700;font-size:1.05rem;color:var(--accent)}.my-apt-body{display:grid;grid-template-columns:1fr 1fr;gap:.5rem 1rem}.my-apt-row{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--text-secondary)}.my-apt-row svg{color:var(--text-tertiary);flex-shrink:0}.status-badge{display:inline-flex;padding:.25rem .7rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.badge-confirmed{background:var(--info-bg);color:var(--info)}.badge-pending{background:var(--warning-bg);color:var(--warning)}.badge-completed{background:var(--success-bg);color:var(--success)}.badge-cancelled{background:var(--danger-bg);color:var(--danger)}.input-readonly{opacity:.7;cursor:default;background:var(--bg-tertiary)!important}
