:root{--p-primary:#1a1a2e;--p-primary-lt:#2d2d5e;--p-accent:#e94560;--p-accent-lt:#ff6b81;--p-purple:#8b5cf6;--p-purple-lt:#a78bfa;--s-bg:#f8fafc;--s-card:#fff;--s-sidebar:#0f172a;--s-sidebar-hover:#1e293b;--s-hover:#f1f5f9;--t-primary:#1f2937;--t-secondary:#6b7280;--t-muted:#94a3b8;--t-inverse:#fff;--b-default:#e2e8f0;--b-light:#f1f5f9;--sh-sm:0 1px 2px #0000000d;--sh-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--sh-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000d;--sh-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000000d;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:24px;--r-full:9999px;--t-fast:.15s ease;--t-smooth:.25s ease;--t-slow:.4s cubic-bezier(.4,0,.2,1);--f-sans:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Inter", sans-serif;--f-mono:"JetBrains Mono", "SF Mono", Menlo, monospace;--f-display:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--sidebar-w:240px;--sidebar-w-collapsed:64px;--topbar-h:56px}*,:before,:after{box-sizing:border-box}html,body{font-family:var(--f-sans);color:var(--t-primary);background:var(--s-bg);-webkit-font-smoothing:antialiased;margin:0;padding:0;line-height:1.55}#root{flex-direction:column;min-height:100vh;display:flex}a{color:var(--p-accent);transition:var(--t-fast);text-decoration:none}a:hover{text-decoration:underline}button{font:inherit;cursor:pointer;transition:var(--t-fast);background:0 0;border:none}button:disabled{cursor:not-allowed;opacity:.5}input,select,textarea{font:inherit;border:1.5px solid var(--b-default);border-radius:var(--r-sm);width:100%;transition:var(--t-fast);background:#fff;outline:none;padding:.65rem .85rem}input:focus,select:focus,textarea:focus{border-color:var(--p-accent);box-shadow:0 0 0 3px #e9456026}h1{letter-spacing:-.02em;margin:0 0 .5rem;font-size:1.5rem;font-weight:800}h2{margin:0 0 .5rem;font-size:1.15rem;font-weight:700}h3{margin:0 0 .35rem;font-size:1rem;font-weight:600}.app-layout{min-height:100vh;display:flex}.app-sidebar{width:var(--sidebar-w);background:var(--s-sidebar);transition:width var(--t-smooth);z-index:100;flex-direction:column;flex-shrink:0;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.app-sidebar.collapsed{width:var(--sidebar-w-collapsed)}.app-sidebar-brand{border-bottom:1px solid #ffffff14;align-items:center;gap:.75rem;padding:1.25rem 1rem;display:flex}.app-sidebar-brand img{width:32px;height:32px}.app-sidebar-brand span{color:var(--t-inverse);font-size:1.05rem;font-weight:800;font-family:var(--f-display);white-space:nowrap}.app-sidebar-brand .brand-dot{background:var(--p-accent);border-radius:50%;flex-shrink:0;width:8px;height:8px}.app-sidebar-nav{flex-direction:column;flex:1;gap:.15rem;padding:.75rem .5rem;display:flex;overflow-y:auto}.app-sidebar-nav a,.app-sidebar-nav button{border-radius:var(--r-sm);color:#ffffffa6;white-space:nowrap;transition:var(--t-fast);align-items:center;gap:.65rem;padding:.6rem .75rem;font-size:.85rem;font-weight:500;text-decoration:none;display:flex}.app-sidebar-nav a:hover,.app-sidebar-nav button:hover{background:var(--s-sidebar-hover);color:var(--t-inverse);text-decoration:none}.app-sidebar-nav a.active,.app-sidebar-nav button.active{background:var(--p-accent);color:#fff;font-weight:600}.app-sidebar-nav .nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:1.05rem;display:flex}.app-sidebar-nav .nav-label{transition:opacity var(--t-fast)}.app-sidebar.collapsed .nav-label,.app-sidebar.collapsed .brand-dot{display:none}.app-sidebar-footer{border-top:1px solid #ffffff14;padding:.75rem}.app-sidebar-footer button{border-radius:var(--r-sm);color:#ffffff80;width:100%;transition:var(--t-fast);align-items:center;gap:.65rem;padding:.5rem .75rem;font-size:.8rem;display:flex}.app-sidebar-footer button:hover{color:var(--p-accent);background:#ffffff0d}.app-main{margin-left:var(--sidebar-w);transition:margin-left var(--t-smooth);flex:1;min-width:0}.app-sidebar.collapsed~.app-main{margin-left:var(--sidebar-w-collapsed)}.app-main-content{width:100%;max-width:1200px;margin:0 auto;padding:1.5rem}.app-topbar{height:var(--topbar-h);border-bottom:1px solid var(--b-default);background:var(--s-card);z-index:50;justify-content:space-between;align-items:center;padding:0 1.5rem;display:flex;position:sticky;top:0}.app-topbar h1{color:var(--t-primary);margin:0;font-size:1.1rem}.app-topbar-right{align-items:center;gap:.75rem;display:flex}.app-topbar-right .user-avatar{background:var(--p-accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;font-weight:700;display:flex}.launchpad{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;display:grid}.launchpad-card{background:var(--s-card);border-radius:var(--r-lg);box-shadow:var(--sh-sm);transition:var(--t-smooth);cursor:pointer;color:var(--t-primary);border:1.5px solid #0000;flex-direction:column;gap:.35rem;padding:1.25rem;text-decoration:none;display:flex}.launchpad-card:hover{box-shadow:var(--sh-md);border-color:var(--p-accent);text-decoration:none;transform:translateY(-2px)}.launchpad-card .lc-icon{border-radius:var(--r-md);justify-content:center;align-items:center;width:44px;height:44px;font-size:1.3rem;display:flex}.launchpad-card .lc-title{font-size:.95rem;font-weight:700}.launchpad-card .lc-subtitle{color:var(--t-secondary);font-size:.8rem}.lc-icon-agenda{color:#3b82f6;background:#eff6ff}.lc-icon-clientes{color:#10b981;background:#f0fdf4}.lc-icon-dashboard{color:#ef4444;background:#fef2f2}.lc-icon-settings{color:#8b5cf6;background:#f5f3ff}.lc-icon-facturas{color:#f59e0b;background:#fffbeb}.lc-icon-plan{color:#06b6d4;background:#ecfeff}.lc-icon-empleados{color:#ec4899;background:#fdf2f8}.lc-icon-qr{color:#10b981;background:#f0fdf4}.card{background:var(--s-card);border-radius:var(--r-lg);box-shadow:var(--sh-sm);transition:var(--t-fast);padding:1.25rem}.card:hover{box-shadow:var(--sh-md)}.card-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.card-header h2{margin:0}.btn{border-radius:var(--r-sm);transition:var(--t-fast);white-space:nowrap;align-items:center;gap:.4rem;padding:.6rem 1.2rem;font-size:.85rem;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary{background:linear-gradient(135deg,var(--p-accent),var(--p-accent-lt));color:#fff;box-shadow:0 2px 8px #e945604d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #e9456066}.btn-secondary{background:var(--s-bg);color:var(--t-primary);border:1.5px solid var(--b-default)}.btn-secondary:hover{border-color:var(--p-accent);color:var(--p-accent)}.btn-ghost{color:var(--t-secondary);border-radius:var(--r-sm);padding:.45rem .85rem;font-weight:500}.btn-ghost:hover{background:var(--s-hover);color:var(--t-primary)}.btn-sm{padding:.35rem .65rem;font-size:.78rem}.btn-xs{padding:.25rem .5rem;font-size:.72rem}.btn-icon{border-radius:var(--r-sm);justify-content:center;align-items:center;width:36px;height:36px;padding:0;display:flex}.form-group{margin-bottom:.85rem}.form-group label{color:var(--t-secondary);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.3rem;font-size:.82rem;font-weight:600;display:block}.form-grid{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}@media (max-width:600px){.form-grid{grid-template-columns:1fr}}.form-field{flex-direction:column;gap:.2rem;display:flex}.form-field span{color:var(--t-secondary);text-transform:uppercase;letter-spacing:.03em;font-size:.78rem;font-weight:600}.form-error{color:#ef4444;border-radius:var(--r-sm);background:#fef2f2;margin-top:.4rem;padding:.4rem .65rem;font-size:.82rem}.form-actions{justify-content:flex-end;gap:.5rem;margin-top:1.25rem;display:flex}textarea{resize:vertical;min-height:60px}.banner-error{color:#dc2626;border-radius:var(--r-sm);background:#fef2f2;border-left:4px solid #ef4444;margin-bottom:1rem;padding:.65rem 1rem;font-size:.85rem}.banner-success{color:#059669;border-radius:var(--r-sm);background:#ecfdf5;border-left:4px solid #10b981;margin-bottom:1rem;padding:.65rem 1rem;font-size:.85rem}.table-responsive{-webkit-overflow-scrolling:touch;overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:.82rem}.table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--t-secondary);border-bottom:2px solid var(--b-default);padding:.55rem .65rem;font-size:.72rem;font-weight:600}.table td{border-bottom:1px solid var(--b-default);padding:.55rem .65rem}.table tbody tr:hover{background:var(--s-hover)}.text-center{text-align:center}.badge{border-radius:var(--r-full);text-transform:uppercase;letter-spacing:.02em;padding:.18rem .5rem;font-size:.72rem;font-weight:700;display:inline-block}.badge-basico{color:#4f46e5;background:#eef2ff}.badge-premium{color:#d97706;background:#fef3c7}.badge-activo{color:#059669;background:#ecfdf5}.badge-suspendido{color:#dc2626;background:#fef2f2}.landing-hero{background:linear-gradient(135deg,var(--s-sidebar),var(--p-primary-lt));text-align:center;color:#fff;justify-content:center;align-items:center;min-height:60vh;padding:3rem 1.5rem 2.5rem;display:flex}.landing-hero-inner{width:100%;max-width:500px}.landing-hero .hero-logo{background:var(--p-accent);border-radius:var(--r-md);color:#fff;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 1rem;font-size:1.6rem;font-weight:800;display:flex}.landing-hero h1{color:#fff;font-size:1.8rem;font-family:var(--f-display);margin-bottom:.35rem}.landing-hero p{opacity:.8;margin-bottom:1.5rem;font-size:.95rem}.landing-search{margin-bottom:2rem;position:relative}.landing-search input{border-radius:var(--r-full);text-align:center;width:100%;box-shadow:var(--sh-lg);transition:var(--t-fast);border:2px solid #0000;padding:.85rem 1.2rem;font-size:1.05rem}.landing-search input:focus{border-color:var(--p-accent);outline:none;box-shadow:0 0 0 4px #e9456033}.landing-search .search-icon{color:var(--t-muted);font-size:1.1rem;position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.landing-search .search-hint{color:#ffffff80;margin-top:.4rem;font-size:.78rem}.landing-features{grid-template-columns:repeat(3,1fr);gap:1rem;max-width:600px;margin:0 auto;display:grid}@media (max-width:500px){.landing-features{grid-template-columns:1fr}}.landing-feature{text-align:center;border-radius:var(--r-md);transition:var(--t-fast);background:#ffffff14;padding:1rem}.landing-feature:hover{background:#ffffff1f}.landing-feature .lf-icon{margin-bottom:.25rem;font-size:1.5rem}.landing-feature .lf-title{font-size:.82rem;font-weight:600}.landing-feature .lf-desc{opacity:.65;margin-top:.15rem;font-size:.72rem}.landing-links{text-align:center;margin-top:1.5rem}.landing-links a{color:#ffffffb3;margin:0 .75rem;font-size:.82rem;font-weight:500}.landing-links a:hover{color:#fff}.search-results{border-radius:var(--r-md);box-shadow:var(--sh-xl);z-index:200;background:#fff;max-height:240px;margin-top:.5rem;display:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.search-results.show{display:block}.search-results .sr-item{cursor:pointer;transition:var(--t-fast);border-bottom:1px solid var(--b-light);color:var(--t-primary);align-items:center;gap:.75rem;padding:.75rem 1rem;text-decoration:none;display:flex}.search-results .sr-item:hover{background:var(--s-hover)}.search-results .sr-item:last-child{border:none}.search-results .sr-item .sr-avatar{border-radius:var(--r-sm);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:.85rem;font-weight:700;display:flex}.search-results .sr-item .sr-info{flex:1;min-width:0}.search-results .sr-item .sr-name{font-size:.85rem;font-weight:600}.search-results .sr-item .sr-meta{color:var(--t-secondary);font-size:.72rem}.skeleton{background:linear-gradient(90deg,var(--b-light) 25%,var(--s-hover) 50%,var(--b-light) 75%);border-radius:var(--r-sm);background-size:200% 100%;animation:1.5s infinite shimmer}.skeleton-text{height:14px;margin-bottom:8px}.skeleton-text:last-child{width:60%}.skeleton-card{height:120px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.gap-1{gap:.5rem}.gap-2{gap:1rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.text-muted{color:var(--t-secondary);font-size:.85rem}.text-sm{font-size:.82rem}.text-xs{font-size:.72rem}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.w-full{width:100%}.toast-container{z-index:9999;flex-direction:column;gap:.5rem;display:flex;position:fixed;top:1rem;right:1rem}.toast{background:var(--s-card);border-radius:var(--r-md);box-shadow:var(--sh-lg);align-items:center;gap:.65rem;min-width:280px;max-width:400px;padding:.75rem 1rem;font-size:.85rem;animation:.3s slideIn;display:flex}.toast-success{border-left:4px solid #10b981}.toast-error{border-left:4px solid #ef4444}.toast-info{border-left:4px solid #3b82f6}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.dialog-overlay{z-index:9998;background:#0006;justify-content:center;align-items:center;padding:1rem;animation:.2s fadeIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.dialog-box{background:var(--s-card);border-radius:var(--r-lg);width:100%;max-width:420px;box-shadow:var(--sh-xl);padding:1.5rem;animation:.2s scaleIn}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.dialog-box h3{margin-bottom:.5rem}.dialog-box p{color:var(--t-secondary);margin-bottom:1.25rem;font-size:.85rem}.dialog-box .dialog-actions{justify-content:flex-end;gap:.5rem;display:flex}.error-boundary{text-align:center;justify-content:center;align-items:center;min-height:300px;padding:2rem;display:flex}.error-boundary h2{color:var(--p-accent);margin-bottom:.5rem}.error-boundary p{color:var(--t-secondary);margin-bottom:1rem}.mobile-nav{background:var(--s-card);border-top:1px solid var(--b-default);z-index:99;padding:.35rem 0;padding-bottom:env(safe-area-inset-bottom,.35rem);display:none;position:fixed;bottom:0;left:0;right:0}@media (max-width:768px){.mobile-nav{display:flex}.app-sidebar{display:none}.app-wrap .app-sidebar{z-index:200;display:block;position:fixed}.app-sidebar.collapsed~.app-main,.app-sidebar.mobile-open~.app-main{margin-left:0}.app-main{margin-left:0!important}}.mobile-nav .mn-item{color:var(--t-muted);transition:var(--t-fast);flex-direction:column;flex:1;align-items:center;gap:.15rem;padding:.3rem 0;font-size:.65rem;font-weight:500;text-decoration:none;display:flex}.mobile-nav .mn-item.active{color:var(--p-accent);font-weight:700}.mobile-nav .mn-item .mn-icon{font-size:1.15rem}[data-theme=dark]{--s-bg:#0f172a;--s-card:#1e293b;--s-sidebar:#020617;--s-sidebar-hover:#1e293b;--s-hover:#1e293b;--t-primary:#f1f5f9;--t-secondary:#94a3b8;--t-muted:#64748b;--b-default:#334155;--b-light:#1e293b}[data-theme=dark] input,[data-theme=dark] select,[data-theme=dark] textarea{color:#f1f5f9;background:#1e293b;border-color:#334155}[data-theme=dark] .search-results{color:#f1f5f9;background:#1e293b}[data-theme=dark] .search-results .sr-item{border-color:#334155}[data-theme=dark] .search-results .sr-item:hover{background:#334155}@media print{body{color:#000;background:#fff}.app-sidebar,.app-topbar,.mobile-nav,.toast-container,.dialog-overlay,.no-print{display:none!important}.app-main{margin-left:0!important}.card{box-shadow:none;break-inside:avoid;border:1px solid #ddd}.table th{background:#f5f5f5}}.salon-header-premium{text-align:center;color:#fff;padding:2rem 1rem 3.5rem;position:relative;overflow:hidden}.shp-inner{z-index:1;max-width:480px;margin:0 auto;position:relative}.shp-logo-ring{background:#ffffff26;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto .85rem;padding:3px;display:flex}.shp-logo{object-fit:cover;border-radius:50%;width:100%;height:100%}.shp-logo-fallback{border-radius:50%;justify-content:center;align-items:center;width:100%;height:100%;font-size:1.6rem;font-weight:800;display:flex}.shp-name{color:#fff;letter-spacing:-.01em;font-size:1.35rem;font-weight:800;font-family:var(--f-display);margin:0 0 .2rem}.shp-address{opacity:.75;margin:0;font-size:.85rem}.shp-meta{opacity:.6;justify-content:center;gap:1.5rem;margin-top:.5rem;font-size:.78rem;display:flex}.shp-code{font-family:var(--f-mono)}.shp-wave{line-height:0;position:absolute;bottom:-1px;left:0;right:0}.shp-wave svg{width:100%;height:auto}.svc-card{background:var(--s-card);border-radius:var(--r-md);box-shadow:var(--sh-sm);cursor:pointer;transition:var(--t-smooth);border:2px solid #0000;align-items:center;gap:.75rem;padding:.85rem 1rem;display:flex;position:relative}.svc-card:hover{box-shadow:var(--sh-md);transform:translateY(-1px)}.svc-card--selected{border-color:var(--p-accent)}.svc-card-icon{border-radius:var(--r-sm);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.15rem;display:flex}.svc-card-body{flex:1;min-width:0}.svc-card-name{margin-bottom:.15rem;font-size:.9rem;font-weight:700}.svc-card-meta{justify-content:space-between;align-items:center;display:flex}.svc-card-check{background:var(--p-accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.7rem;display:flex}.pro-chip-row{flex-wrap:wrap;gap:.65rem;display:flex}.pro-chip{border-radius:var(--r-md);cursor:pointer;border:2px solid var(--b-default);background:var(--s-card);transition:var(--t-smooth);flex-direction:column;align-items:center;gap:.35rem;min-width:80px;padding:.65rem .85rem;display:flex}.pro-chip:hover{border-color:var(--p-accent);transform:translateY(-1px)}.pro-chip--selected{border-color:var(--p-accent);background:#fef2f3}.pro-chip-avatar{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;font-size:.95rem;font-weight:700;display:flex}.pro-chip-name{text-align:center;font-size:.78rem;font-weight:600}.pro-chip-any{border-radius:var(--r-md);cursor:pointer;border:2px dashed var(--b-default);transition:var(--t-smooth);justify-content:center;align-items:center;gap:.35rem;padding:.65rem 1rem;font-size:.82rem;font-weight:500;display:flex}.pro-chip-any:hover{border-color:var(--p-pink);border-style:solid}.pro-chip-any--selected{border-color:var(--p-pink);background:#fef2f3;border-style:solid}.slot-section-label{color:var(--t-muted);text-transform:uppercase;letter-spacing:.04em;margin:.5rem 0 .35rem;font-size:.78rem;font-weight:600}.slot-grid-pm{grid-template-columns:repeat(auto-fill,minmax(85px,1fr));gap:.4rem;display:grid}.slot-chip{text-align:center;border-radius:var(--r-sm);border:1.5px solid var(--b-default);background:var(--s-card);cursor:pointer;transition:var(--t-fast);padding:.55rem .35rem;font-size:.82rem;font-weight:500}.slot-chip:hover{border-color:var(--p-accent)}.slot-chip--selected{background:var(--p-accent);color:#fff;border-color:var(--p-accent)}.date-picker-row{-webkit-overflow-scrolling:touch;gap:.35rem;margin-bottom:.75rem;padding-bottom:.35rem;display:flex;overflow-x:auto}.date-chip{border-radius:var(--r-md);cursor:pointer;border:1.5px solid var(--b-default);background:var(--s-card);transition:var(--t-fast);flex-direction:column;flex-shrink:0;align-items:center;gap:.1rem;min-width:58px;padding:.45rem .65rem;display:flex}.date-chip:hover{border-color:var(--p-accent)}.date-chip--selected{background:var(--p-accent);color:#fff;border-color:var(--p-accent)}.date-chip-dow{text-transform:uppercase;opacity:.7;font-size:.65rem}.date-chip-day{font-size:.95rem;font-weight:700;font-family:var(--f-display)}.success-hero{text-align:center;color:#fff;border-radius:0 0 var(--r-xl) var(--r-xl);background:linear-gradient(135deg,#10b981,#059669);margin:-1.5rem -1rem 1.5rem;padding:2.5rem 1rem}.success-icon-ring{background:#fff3;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto .85rem;font-size:1.8rem;display:flex}.success-hero h2{color:#fff;margin:0 0 .25rem;font-size:1.3rem}.success-detail-card{background:var(--s-card);border-radius:var(--r-md);margin-bottom:.75rem;padding:1rem}.success-detail-card .sdc-row{justify-content:space-between;padding:.35rem 0;font-size:.85rem;display:flex}.success-detail-card .sdc-row:not(:last-child){border-bottom:1px solid var(--b-light)}.success-detail-card .sdc-label{color:var(--t-secondary)}.empty-hint{text-align:center;color:var(--t-muted);padding:1.5rem 1rem}.empty-hint .eh-icon{opacity:.5;margin-bottom:.5rem;font-size:2rem}.empty-hint p{margin:0;font-size:.85rem}.service-card,.service-card--selected,.gc{display:none}.salon-header{text-align:center;background:var(--s-sidebar);color:#fff;border-radius:var(--r-lg);margin-bottom:1rem;padding:1.5rem 1rem}.salon-header__inner{max-width:400px;margin:0 auto}.salon-header__logo{object-fit:cover;border:3px solid #fff3;border-radius:50%;width:64px;height:64px;margin-bottom:.5rem}.salon-header__name{color:#fff;margin:0 0 .25rem;font-size:1.15rem}.salon-header__address{opacity:.7;margin:0;font-size:.82rem}.salon-header__code{opacity:.5;margin:.25rem 0 0;font-size:.72rem}.service-card{background:var(--s-card);border-radius:var(--r-md);box-shadow:var(--sh-sm);cursor:pointer;transition:var(--t-smooth);border:2px solid #0000;padding:1rem;position:relative}.service-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}.service-card.selected,.service-card--selected{border-color:var(--p-accent);box-shadow:0 0 0 3px #e9456026}.service-card__name{font-size:.9rem;font-weight:700}.service-card__meta{justify-content:space-between;align-items:center;margin-top:.25rem;display:flex}.service-card__price{color:var(--p-accent);font-size:1.05rem;font-weight:800}.grid-cards{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}@media (max-width:480px){.grid-cards{grid-template-columns:1fr}}.slot-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.5rem;display:grid}.slot-btn{text-align:center;border-radius:var(--r-sm);border:1.5px solid var(--b-default);background:var(--s-card);cursor:pointer;transition:var(--t-fast);padding:.5rem;font-size:.85rem;font-weight:500}.slot-btn:hover{border-color:var(--p-accent);color:var(--p-accent)}.slot-btn.selected,.slot-btn--selected{background:var(--p-accent);color:#fff;border-color:var(--p-accent);box-shadow:0 2px 8px #e945604d}.chip-row{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;display:flex}.chip{border-radius:var(--r-full);border:1.5px solid var(--b-default);background:var(--s-card);cursor:pointer;transition:var(--t-fast);align-items:center;gap:.35rem;padding:.45rem .85rem;font-size:.82rem;font-weight:500;display:inline-flex}.chip:hover{border-color:var(--p-accent)}.chip--selected{background:var(--p-accent);color:#fff;border-color:var(--p-accent)}.form-input{border:1.5px solid var(--b-default);border-radius:var(--r-sm);width:100%;transition:var(--t-fast);outline:none;padding:.65rem .85rem;font-size:.9rem}.form-input:focus{border-color:var(--p-accent);box-shadow:0 0 0 3px #e9456026}.field-error{color:#ef4444;margin-top:.25rem;font-size:.8rem;font-weight:500;display:block}.field-hint{color:var(--t-secondary);margin-top:.2rem;font-size:.78rem;display:block}.form-checkbox{cursor:pointer;align-items:center;gap:.5rem;font-size:.82rem;display:flex}.form-checkbox input[type=checkbox]{width:auto}.confirmation-card{text-align:center;padding:2rem 1rem}.confirmation-card .check-icon{color:#fff;background:linear-gradient(135deg,#10b981,#34d399);border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 1rem;font-size:1.8rem;animation:.3s pop;display:flex}@keyframes pop{0%{transform:scale(0)}50%{transform:scale(1.15)}to{transform:scale(1)}}.confirmation-card .booking-summary{text-align:left;background:var(--s-bg);border-radius:var(--r-sm);margin:1rem 0;padding:1rem}.confirmation-card .booking-summary div{justify-content:space-between;padding:.35rem 0;display:flex}.confirmation-card .booking-summary .label{color:var(--t-secondary);font-size:.78rem}.confirmation-actions{flex-wrap:wrap;justify-content:center;gap:.5rem;margin-top:1rem;display:flex}.skeleton-wrapper{flex-direction:column;gap:.75rem;padding:1rem;display:flex}.skeleton-item{background:linear-gradient(90deg,var(--b-light) 25%,var(--s-hover) 50%,var(--b-light) 75%);background-size:200% 100%;border-radius:4px;height:16px;animation:1.5s infinite shimmer}.skeleton-hero .skeleton-item:first-child{border-radius:var(--r-lg);height:200px}.skeleton-stat-card .skeleton-item{border-radius:var(--r-md);height:120px}.skeleton-table-row .skeleton-item{height:40px;margin-bottom:4px}.skeleton-day-tab .skeleton-item{border-radius:var(--r-full);width:80px;height:32px;margin-right:.5rem;display:inline-block}.skeleton-form .skeleton-item{height:36px}.skeleton-card .skeleton-item:first-child{border-radius:var(--r-md);height:140px}.skeleton-list-item .skeleton-item{height:48px;margin-bottom:4px}.skeleton-page{flex-direction:column;gap:1rem;display:flex}.error-fallback{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:300px;padding:2rem;display:flex}.error-fallback h1{color:var(--p-accent);margin-bottom:.5rem;font-size:1.3rem}.error-fallback p{color:var(--t-secondary);margin-bottom:1rem}.date-input{border-radius:var(--r-sm);border:1.5px solid var(--b-default);text-align:center;width:100%;transition:var(--t-fast);padding:.65rem;font-size:1rem}.date-input:focus{border-color:var(--p-accent)}.employee-grid{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}@media (max-width:480px){.employee-grid{grid-template-columns:1fr}}.employee-card{background:var(--s-card);border-radius:var(--r-md);box-shadow:var(--sh-sm);cursor:pointer;transition:var(--t-smooth);text-align:center;border:2px solid #0000;padding:1rem}.employee-card:hover{box-shadow:var(--sh-md)}.employee-card.selected{border-color:var(--p-accent);background:var(--s-bg)}.employee-card .emp-avatar{margin-bottom:.25rem;font-size:2rem}.employee-card .emp-name{font-size:.85rem;font-weight:600}.employee-card .emp-role{color:var(--t-secondary);font-size:.72rem}.booking-hero{text-align:center;background:linear-gradient(135deg,var(--s-sidebar),var(--p-primary-lt));color:#fff;border-radius:0 0 var(--r-lg) var(--r-lg);margin:-1.5rem -1rem 1.5rem;padding:2rem 0 1.5rem}.booking-hero h1{color:#fff;margin:0 0 .25rem;font-size:1.3rem}.stat-icon{margin-bottom:.25rem;font-size:1.5rem}.stat-number{font-size:1.8rem;font-weight:800;line-height:1}.stat-label{opacity:.85;margin-top:.25rem;font-size:.8rem}.stat-card{background:var(--s-card);border-radius:var(--r-lg);box-shadow:var(--sh-sm);transition:var(--t-smooth);text-align:center;padding:1.25rem}.stat-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}.stat-card:first-child{background:linear-gradient(135deg,var(--s-sidebar),var(--p-primary-lt));color:#fff}.stat-card:nth-child(2){background:linear-gradient(135deg,var(--p-accent),var(--p-accent-lt));color:#fff}.stat-card:nth-child(3){color:#fff;background:linear-gradient(135deg,#10b981,#34d399)}.stat-card:nth-child(4){color:#fff;background:linear-gradient(135deg,#f59e0b,#fbbf24)}.progress-bar{background:#ffffff4d;border-radius:3px;height:6px;margin-top:.5rem}.progress-fill{background:#fffc;border-radius:3px;height:100%;transition:width .5s}
