*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #050505;--bg-secondary: #0a0a0a;--bg-card: #111111;--bg-card-hover: #181818;--bg-input: #080808;--bg-sidebar: #070707;--border-color: #1c1c1c;--border-hover: #2a2a2a;--text-primary: #e6e6e6;--text-secondary: #777777;--text-muted: #444444;--accent: #e0c897;--accent-hover: #ebd5aa;--accent-glow: rgba(224, 200, 151, .08);--accent-subtle: rgba(224, 200, 151, .04);--accent-text: #050505;--success: #6ec99e;--success-bg: rgba(110, 201, 158, .07);--danger: #cf7070;--late: #d45555;--late-bg: rgba(212,85,85,.08);--danger-bg: rgba(207, 112, 112, .07);--warning: #d4a64e;--warning-bg: rgba(212, 166, 78, .07);--info: #7ba8d4;--info-bg: rgba(123, 168, 212, .07);--shadow-sm: 0 1px 3px rgba(0,0,0,.5);--shadow-md: 0 4px 16px rgba(0,0,0,.6);--shadow-lg: 0 8px 32px rgba(0,0,0,.7);--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--font-display: "Sora", -apple-system, sans-serif;--font-body: "DM Sans", -apple-system, sans-serif;--font-mono: "JetBrains Mono", monospace;--transition: .2s ease;--sidebar-width: 260px}:root.light-mode{--bg-primary: #f4f4f6;--bg-secondary: #eaeaee;--bg-card: #ffffff;--bg-card-hover: #f8f8fa;--bg-input: #eeeeef;--bg-sidebar: #ffffff;--border-color: #d8d8de;--border-hover: #c0c0c8;--text-primary: #111118;--text-secondary: #5e5e6e;--text-muted: #9090a0;--accent: #9a7b4a;--accent-hover: #866a3e;--accent-glow: rgba(154, 123, 74, .1);--accent-subtle: rgba(154, 123, 74, .05);--accent-text: #ffffff;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.06);--shadow-lg: 0 8px 24px rgba(0,0,0,.08)}html,body{height:100%;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-body);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;transition:background var(--transition),color var(--transition)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}h1,h2,h3{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1.25}.app-shell{display:flex;min-height:100vh}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:100;transition:width .25s ease,transform .3s ease;overflow:hidden}.sidebar-brand{padding:24px 20px 20px;border-bottom:1px solid var(--border-color);white-space:nowrap;overflow:hidden}.sidebar-brand h1{font-size:20px;color:var(--accent);letter-spacing:3px;text-transform:uppercase;font-weight:800;transition:all .2s ease}.sidebar-brand p{font-size:10px;color:var(--text-muted);letter-spacing:2px;text-transform:uppercase;margin-top:2px;transition:all .2s ease}.sidebar-toggle{width:28px;height:28px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);flex-shrink:0}.sidebar-toggle:hover{border-color:var(--accent);color:var(--accent)}.sidebar.collapsed{width:72px}.sidebar.collapsed .sidebar-brand{padding:16px 8px 14px;text-align:center}.sidebar.collapsed .sidebar-nav{padding:8px}.sidebar.collapsed .sidebar-link{padding:10px 0;justify-content:center;gap:0;font-size:0}.sidebar.collapsed .sidebar-link .nav-icon{width:20px;height:20px}.sidebar.collapsed .sidebar-section{display:none}.sidebar.collapsed .sidebar-footer{padding:10px 8px}.sidebar-nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.sidebar-link{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius-sm);color:var(--text-secondary);text-decoration:none;font-size:13px;font-weight:500;transition:all var(--transition);cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:var(--font-body)}.sidebar-link:hover{background:var(--accent-subtle);color:var(--text-primary)}.sidebar-link.active{background:var(--accent-glow);color:var(--accent)}.sidebar-link .icon{font-size:16px;width:20px;text-align:center}.nav-icon{width:18px;height:18px;fill:currentColor;flex-shrink:0;opacity:.7}.sidebar-link.active .nav-icon{opacity:1}.sidebar-section{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:16px 14px 6px}.sidebar-footer{padding:16px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:8px}.sidebar-user{font-size:13px;color:var(--text-secondary)}.sidebar-user strong{color:var(--text-primary);display:block}.app-main{margin-left:var(--sidebar-width);flex:1;min-height:100vh;transition:margin-left .25s ease}.app-main.expanded{margin-left:72px}.mobile-header{display:none;position:sticky;top:0;z-index:90;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:12px 16px;align-items:center;justify-content:space-between}.mobile-header h1{font-size:16px;color:var(--accent);letter-spacing:2px;text-transform:uppercase}.burger{background:none;border:none;color:var(--text-primary);font-size:24px;cursor:pointer;padding:4px}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0009;z-index:99;backdrop-filter:blur(4px)}@media (max-width: 768px){.sidebar{transform:translate(-100%);width:280px}.sidebar.open{transform:translate(0)}.sidebar-overlay.open{display:block}.mobile-header{display:flex}.app-main{margin-left:0}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr!important}.page-container{padding:16px!important}.page-title{font-size:18px!important}.page-header{flex-direction:column!important;gap:10px!important;align-items:flex-start!important}.appointment-item{flex-direction:column;align-items:flex-start!important;gap:8px!important}.appointment-actions{width:100%}.modal{width:95%!important;padding:16px!important;max-height:90vh}.modal-split{overflow-y:auto!important;border-radius:var(--radius-lg)!important}.modal-body-flex{flex-direction:column!important}.modal-sidebar{width:100%!important;border-left:none!important;border-top:1px solid var(--border-color)!important;flex-direction:column!important;padding:16px!important}.modal-sidebar .modal-action-btn{width:100%!important;flex:none!important}.modal-sidebar-label{width:100%!important;margin-bottom:8px!important}.modal-sidebar .modal-action-btn span{display:none!important}.auth-card{padding:24px 16px!important}.calendar-grid .calendar-cell{font-size:11px}.stat-card{padding:14px!important}.stat-value{font-size:22px!important}.config-table{font-size:11px}.config-table th{padding:6px 8px;font-size:9px}.config-table td{padding:8px}.config-table input[type=time],.config-table input[type=number]{width:70px;font-size:11px;padding:4px 5px}.tab-bar{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{padding:8px 14px;white-space:nowrap;font-size:12px}.card{padding:14px}.card-header{margin-bottom:12px;padding-bottom:10px}.btn{padding:7px 14px;font-size:12px}.btn-sm{padding:4px 10px;font-size:11px}.form-input,.form-select,.form-textarea{padding:9px 12px;font-size:14px}.booking-steps{margin-bottom:16px}.guest-counter .count{font-size:18px}.action-links{gap:3px}.action-link{padding:3px 8px;font-size:11px}.empty-state{padding:32px 16px}}@media (min-width: 769px) and (max-width: 1024px){:root{--sidebar-width: 220px}.sidebar-brand h1{font-size:17px;letter-spacing:2px}.sidebar-link{font-size:12px;padding:9px 12px}.sidebar-section{font-size:9px;padding:14px 12px 4px}.page-container{padding:24px 20px}.grid-4{grid-template-columns:repeat(2,1fr)!important}.config-table{font-size:12px}.config-table input[type=time],.config-table input[type=number]{width:75px;font-size:12px}.modal{max-width:460px}.cal-week{gap:4px}.cal-event{padding:5px 6px;font-size:11px}}@media (min-width: 1025px) and (max-width: 1280px){:root{--sidebar-width: 240px}.page-container{padding:28px 24px}}.page-container{max-width:1600px;margin:0 auto;padding:32px 36px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;gap:16px;flex-wrap:wrap}.page-title{font-size:22px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.page-subtitle{color:var(--text-secondary);font-size:13px;margin-top:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 18px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13px;font-weight:600;border:1px solid transparent;cursor:pointer;transition:all var(--transition);text-decoration:none;white-space:nowrap}.btn-primary{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 20px var(--accent-glow)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{background:transparent;color:var(--text-primary);border-color:var(--border-color)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-ghost{background:transparent;color:var(--text-secondary);border:none;padding:6px 12px}.btn-ghost:hover{color:var(--accent)}.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:#cf707033}.btn-danger:hover{border-color:var(--danger)}.btn-success{background:var(--success-bg);color:var(--success);border-color:#6ec99e33}.btn-success:hover{border-color:var(--success)}.btn-warning{background:var(--warning-bg);color:var(--warning);border-color:#d4a64e33}.btn-warning:hover{border-color:var(--warning)}.btn-sm{padding:5px 12px;font-size:12px}.btn-icon{width:32px;height:32px;padding:0;border-radius:50%}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px;transition:all var(--transition)}.card:hover{border-color:var(--border-hover)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.card-title{font-family:var(--font-display);font-size:16px;font-weight:600}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:5px;letter-spacing:.03em;text-transform:uppercase}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-body);font-size:14px;transition:all var(--transition);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-input::placeholder{color:var(--text-muted)}.form-textarea{min-height:80px;resize:vertical}.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23777777' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.badge-pending{background:var(--warning-bg);color:var(--warning)}.badge-confirmed{background:var(--success-bg);color:var(--success)}.badge-rejected{background:var(--danger-bg);color:var(--danger)}.badge-rescheduled{background:var(--info-bg);color:var(--info)}.badge-cancelled{background:#787e8514;color:#787e85}.badge-completed{background:#9b8abf14;color:#9b8abf}.badge-late{background:var(--late-bg);color:var(--late)}.cal-event.late{border-left-color:var(--late)}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;gap:6px;transition:all var(--transition);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);opacity:0;transition:opacity var(--transition)}.stat-card:hover{border-color:var(--border-hover)}.stat-card:hover:before{opacity:1}.stat-value{font-family:var(--font-display);font-size:28px;font-weight:800;color:var(--text-primary);line-height:1;letter-spacing:-.03em}.stat-label{font-size:11px;color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.calendar-header-cell{text-align:center;font-size:11px;font-weight:600;color:var(--text-muted);padding:6px 0;text-transform:uppercase;letter-spacing:.05em}.calendar-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-size:13px;cursor:pointer;transition:all var(--transition);border:1px solid transparent;color:var(--text-secondary);position:relative}.calendar-cell:hover:not(.disabled){background:var(--accent-subtle);border-color:var(--accent);color:var(--accent)}.calendar-cell.today{background:var(--accent-glow);color:var(--accent);font-weight:600}.calendar-cell.selected{background:var(--accent);color:var(--accent-text);font-weight:600}.calendar-cell.disabled{opacity:.2;cursor:not-allowed}.time-slot{padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);text-align:center;font-size:13px;font-family:var(--font-mono);color:var(--text-secondary)}.time-slot:hover:not(.unavailable){border-color:var(--accent);color:var(--accent);background:var(--accent-subtle)}.time-slot.selected{background:var(--accent);color:var(--accent-text);border-color:var(--accent);font-weight:500}.time-slot.unavailable{opacity:.15;cursor:not-allowed;text-decoration:line-through}.appointment-item{display:flex;align-items:center;gap:16px;padding:14px 18px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition);margin-bottom:6px}.appointment-item:hover{border-color:var(--border-hover);box-shadow:var(--shadow-sm)}.appointment-time{font-family:var(--font-mono);font-size:13px;color:var(--accent);min-width:100px}.appointment-info{flex:1;min-width:0}.appointment-customer{font-weight:500;color:var(--text-primary);font-size:14px}.appointment-service{font-size:12px;color:var(--text-secondary)}.appointment-actions{display:flex;gap:6px;flex-wrap:wrap}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:20px}.auth-card{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:40px 32px;box-shadow:var(--shadow-lg)}.auth-logo{text-align:center;margin-bottom:32px}.auth-logo h1{font-size:24px;color:var(--accent);letter-spacing:5px;text-transform:uppercase;font-weight:800}.auth-logo p{font-size:10px;letter-spacing:3px;color:var(--text-muted);text-transform:uppercase;margin-top:3px}.auth-title{font-size:18px;text-align:center;margin-bottom:24px;color:var(--text-primary)}.error-message{background:var(--danger-bg);border:1px solid rgba(207,112,112,.2);color:var(--danger);padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:16px}.tab-bar{display:flex;gap:0;border-bottom:1px solid var(--border-color);margin-bottom:20px}.tab{padding:10px 20px;font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;transition:all var(--transition);font-family:var(--font-body)}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.config-table{width:100%;border-collapse:separate;border-spacing:0 3px}.config-table th{text-align:left;padding:8px 12px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.config-table td{padding:10px 12px;background:var(--bg-card);border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color)}.config-table td:first-child{border-left:1px solid var(--border-color);border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.config-table td:last-child{border-right:1px solid var(--border-color);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.config-table input[type=time],.config-table input[type=number]{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);padding:5px 8px;font-family:var(--font-mono);font-size:13px}.config-table input[type=number]{width:72px}.toggle{position:relative;display:inline-flex;width:40px;height:22px;cursor:pointer;flex-shrink:0;vertical-align:middle}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{position:absolute;inset:0;background:var(--border-color);border-radius:11px;transition:var(--transition)}.toggle-slider:before{content:"";position:absolute;height:16px;width:16px;left:3px;bottom:3px;background:var(--text-muted);border-radius:50%;transition:var(--transition)}.toggle input:checked+.toggle-slider{background:var(--accent)}.toggle input:checked+.toggle-slider:before{transform:translate(18px);background:var(--accent-text)}.modal-overlay{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .15s ease}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:28px;max-width:480px;width:92%;max-height:90vh;overflow-y:auto;animation:scaleIn .2s ease}.modal-title{font-family:var(--font-display);font-size:18px;margin-bottom:16px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}@keyframes scaleIn{0%{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}.booking-steps{display:flex;gap:4px;margin-bottom:24px}.booking-step{flex:1;height:3px;background:var(--border-color);border-radius:2px;transition:background var(--transition)}.booking-step.active{background:var(--accent)}.booking-step.done{background:var(--success)}.toast-container{position:fixed;top:16px;right:16px;z-index:1100;display:flex;flex-direction:column;gap:8px;max-width:400px}.toast{display:flex;align-items:center;gap:10px;padding:14px 16px;border-radius:var(--radius-sm);font-size:13px;animation:toastIn .3s ease;border:1px solid;backdrop-filter:blur(12px);box-shadow:var(--shadow-lg)}.toast-success{background:#111111eb;border-color:#6ec99e33;color:var(--success)}.toast-error{background:#111111eb;border-color:#cf707033;color:var(--danger)}.toast span{flex:1}@keyframes toastIn{0%{transform:translate(100%) scale(.95);opacity:0}to{transform:translate(0) scale(1);opacity:1}}.empty-state{text-align:center;padding:48px 20px;color:var(--text-muted)}.empty-state-icon{font-size:40px;margin-bottom:12px;opacity:.4}.empty-state-title{font-family:var(--font-display);font-size:16px;color:var(--text-secondary);margin-bottom:6px}.theme-toggle{width:34px;height:34px;border-radius:50%;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:all var(--transition)}.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}.fade-in{animation:fadeInUp .4s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.page-title{animation:slideInLeft .4s ease}.page-subtitle{animation:slideInLeft .5s ease}@keyframes slideInLeft{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}.live-clock{animation:fadeInScale .5s ease .1s backwards}.live-clock-label{animation:fadeIn .5s ease .2s backwards}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.stat-card{animation:statCardIn .4s ease backwards}.stat-card:nth-child(1){animation-delay:.05s}.stat-card:nth-child(2){animation-delay:.1s}.stat-card:nth-child(3){animation-delay:.15s}.stat-card:nth-child(4){animation-delay:.2s}@keyframes statCardIn{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.tab-bar{animation:fadeInUp .35s ease .15s backwards}.tab{transition:all .2s ease,border-bottom-color .2s ease}.week-col{animation:colSlideIn .35s ease backwards}.week-col:nth-child(1){animation-delay:.08s}.week-col:nth-child(2){animation-delay:.12s}.week-col:nth-child(3){animation-delay:.16s}.week-col:nth-child(4){animation-delay:.2s}.week-col:nth-child(5){animation-delay:.24s}.week-col:nth-child(6){animation-delay:.28s}.week-col:nth-child(7){animation-delay:.32s}@keyframes colSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.week-apt{animation:aptFadeIn .3s ease backwards}@keyframes aptFadeIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.pending-card{animation:fadeInUp .35s ease backwards}.pending-card:nth-child(1){animation-delay:.05s}.pending-card:nth-child(2){animation-delay:.1s}.pending-card:nth-child(3){animation-delay:.15s}.pending-card:nth-child(4){animation-delay:.2s}.pending-card:nth-child(5){animation-delay:.25s}.card{animation:fadeInUp .35s ease .1s backwards}.sidebar{animation:sidebarSlideIn .35s ease}@keyframes sidebarSlideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.sidebar-brand h1{animation:logoGlow .6s ease .3s backwards}@keyframes logoGlow{0%{opacity:0;filter:brightness(1.5)}to{opacity:1;filter:brightness(1)}}.sidebar-link{animation:fadeInUp .3s ease backwards}.sidebar-nav .sidebar-link:nth-child(1){animation-delay:.1s}.sidebar-nav .sidebar-link:nth-child(2){animation-delay:.14s}.sidebar-nav .sidebar-link:nth-child(3){animation-delay:.18s}.sidebar-nav .sidebar-link:nth-child(4){animation-delay:.22s}.sidebar-nav .sidebar-link:nth-child(5){animation-delay:.26s}.sidebar-nav .sidebar-link:nth-child(6){animation-delay:.3s}.sidebar-nav .sidebar-link:nth-child(7){animation-delay:.34s}.sidebar-nav .sidebar-link:nth-child(8){animation-delay:.38s}.btn:active:not(:disabled){transform:scale(.97)}.btn{transition:all .15s ease}@keyframes modalOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes modalCardIn{0%{opacity:0;transform:scale(.93) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.modal-overlay{animation:modalOverlayIn .2s ease}.modal{animation:modalCardIn .3s cubic-bezier(.16,1,.3,1)}.sidebar-link{position:relative;overflow:hidden}.sidebar-link:after{content:"";position:absolute;inset:0;background:var(--accent);opacity:0;transition:opacity .2s;border-radius:inherit}.sidebar-link:hover:after{opacity:.03}.sidebar-link.active:after{opacity:.06}.week-apt{transition:all .15s ease,transform .15s ease}.week-apt:hover{transform:translateY(-1px)}.pending-card{transition:all .15s ease,transform .15s ease}.pending-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.barber-chip{animation:chipIn .25s ease backwards}@keyframes chipIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.auth-card,.login-card{animation:authCardIn .5s cubic-bezier(.16,1,.3,1)}@keyframes authCardIn{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.cal-legend{animation:fadeIn .4s ease .2s backwards}.detail-row{animation:detailRowIn .25s ease backwards}.detail-row:nth-child(1){animation-delay:.02s}.detail-row:nth-child(2){animation-delay:.04s}.detail-row:nth-child(3){animation-delay:.06s}.detail-row:nth-child(4){animation-delay:.08s}.detail-row:nth-child(5){animation-delay:.1s}.detail-row:nth-child(6){animation-delay:.12s}.detail-row:nth-child(7){animation-delay:.14s}.detail-row:nth-child(8){animation-delay:.16s}.detail-row:nth-child(9){animation-delay:.18s}@keyframes detailRowIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.modal-action-btn{animation:actionBtnIn .25s ease backwards}.modal-action-btn:nth-child(2){animation-delay:.04s}.modal-action-btn:nth-child(3){animation-delay:.08s}.modal-action-btn:nth-child(4){animation-delay:.12s}.modal-action-btn:nth-child(5){animation-delay:.16s}.modal-action-btn:nth-child(6){animation-delay:.2s}@keyframes actionBtnIn{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}.stat-value{animation:numberPop .5s cubic-bezier(.16,1,.3,1) backwards}@keyframes numberPop{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}.guest-counter{display:flex;align-items:center;gap:12px}.guest-counter .count{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--accent);min-width:28px;text-align:center}.guest-counter button{width:32px;height:32px;border-radius:50%;border:1px solid var(--border-color);background:var(--bg-input);color:var(--text-primary);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.guest-counter button:hover{border-color:var(--accent);color:var(--accent)}.guest-counter button:disabled{opacity:.3;cursor:not-allowed}.action-links{display:flex;gap:4px;flex-wrap:wrap}.action-link{font-size:12px;font-weight:500;padding:4px 10px;border-radius:var(--radius-sm);cursor:pointer;border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);transition:all var(--transition);font-family:var(--font-body);white-space:nowrap}.action-link:hover{border-color:var(--accent);color:var(--accent)}.action-link.danger{color:var(--danger)}.action-link.danger:hover{border-color:var(--danger)}.action-link.warn{color:var(--warning)}.action-link.warn:hover{border-color:var(--warning)}.cal-week{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.cal-day{min-height:120px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:8px;transition:all var(--transition)}.cal-day:hover{border-color:var(--border-hover)}.cal-day-header{text-align:center;margin-bottom:6px;padding-bottom:6px;border-bottom:1px solid var(--border-color)}.cal-day-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.cal-day-num{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--text-primary)}.cal-day.today .cal-day-num{color:var(--accent)}.cal-day.today{border-color:var(--border-hover);background:var(--bg-card-hover)}.cal-event{padding:6px 8px;border-radius:8px;margin-bottom:4px;cursor:pointer;border-left:3px solid var(--accent);background:var(--bg-secondary);transition:all var(--transition);font-size:12px}.cal-event:hover{background:var(--bg-card-hover)}.cal-event .cal-time{font-family:var(--font-mono);font-size:11px;color:var(--accent)}.cal-event .cal-name{font-weight:500;margin-top:1px}.cal-event .cal-svc{color:var(--text-muted);font-size:11px}.cal-evt{padding:8px 9px;border-radius:10px;margin-bottom:5px;cursor:pointer;background:var(--bg-primary);border:1px solid var(--border-color);transition:all var(--transition);font-size:12px;position:relative;overflow:hidden}.cal-evt:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);border-radius:3px 0 0 3px}.cal-evt:hover{border-color:var(--border-hover);background:var(--bg-secondary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.cal-evt-top{display:flex;align-items:center;justify-content:space-between;gap:4px;margin-bottom:4px}.cal-evt-time{font-family:var(--font-mono);font-size:10px;font-weight:600;color:var(--text-secondary);letter-spacing:.02em}.cal-evt-badge{font-size:8px;font-weight:700;padding:1px 5px;border-radius:4px;text-transform:uppercase;letter-spacing:.04em;line-height:1.4}.cal-evt-badge.pending{background:#d4a64e1f;color:var(--warning)}.cal-evt-badge.confirmed{background:#6ec99e1f;color:var(--success)}.cal-evt-badge.rejected{background:#cf70701f;color:var(--danger)}.cal-evt-badge.rescheduled{background:#7ba8d41f;color:var(--info)}.cal-evt-badge.completed{background:#9b8abf1f;color:#9b8abf}.cal-evt-badge.cancelled{background:#9ca3af1f;color:#787e85}.cal-evt-badge.late{background:#d455551f;color:var(--late)}.cal-evt-name{font-weight:600;font-size:12px;color:var(--text-primary);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-evt-meta{font-size:10px;color:var(--text-muted);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;gap:3px}.cal-evt-delay{font-size:9px;font-weight:700;color:var(--late);margin-top:2px}.cal-evt.pending:before{background:var(--warning)}.cal-evt.confirmed:before{background:var(--success)}.cal-evt.rejected:before{background:var(--danger)}.cal-evt.rescheduled:before{background:var(--info)}.cal-evt.completed:before{background:#9b8abf}.cal-evt.cancelled:before{background:#787e85}.cal-evt.late:before{background:var(--late)}.cal-event.pending{border-left-color:var(--warning)}.cal-event.confirmed{border-left-color:var(--success)}.cal-event.rejected{border-left-color:var(--danger)}.cal-event.rescheduled{border-left-color:var(--info)}.cal-event.completed{border-left-color:#9b8abf}.cal-event.cancelled{border-left-color:#787e85}@media (max-width: 768px){.cal-week{grid-template-columns:1fr!important}.cal-day{min-height:auto}.action-links{gap:2px}.action-link{padding:3px 8px;font-size:11px}}.picker-nav{width:28px;height:28px;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.picker-nav:hover{border-color:var(--accent);color:var(--accent)}.picker-cell{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all var(--transition);color:var(--text-secondary)}.picker-cell:hover:not(.picker-disabled){background:var(--accent-subtle);color:var(--accent)}.picker-cell.picker-today{color:var(--accent);font-weight:700;background:var(--accent-glow)}.picker-cell.picker-selected{background:var(--accent)!important;color:var(--accent-text)!important;font-weight:700}.picker-cell.picker-disabled{opacity:.2;cursor:default}.picker-time{padding:8px 4px;border:1px solid var(--border-color);border-radius:6px;text-align:center;font-size:13px;font-family:var(--font-mono);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:var(--bg-card)}.picker-time:hover:not(.picker-time-taken){border-color:var(--accent);color:var(--accent);background:var(--accent-subtle)}.picker-time.picker-time-selected{background:var(--accent)!important;color:var(--accent-text)!important;border-color:var(--accent)!important;font-weight:600}.picker-time.picker-time-taken{opacity:.2;cursor:default;text-decoration:line-through}@media (max-width: 768px){.picker-cell{font-size:11px}.picker-time{font-size:12px;padding:6px 2px}}.cal-legend{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:16px;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm)}.cal-legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-secondary)}.cal-legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.live-clock{font-family:var(--font-mono);font-size:36px;font-weight:700;color:var(--accent);letter-spacing:-.02em;line-height:1}.live-clock-label{font-size:13px;color:var(--text-secondary);letter-spacing:.02em;margin-top:4px}.chart-bar-group{display:flex;flex-direction:column;gap:8px}.chart-bar-row{display:flex;align-items:center;gap:10px}.chart-bar-label{min-width:80px;font-size:12px;color:var(--text-secondary);text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chart-bar-track{flex:1;height:24px;background:var(--bg-input);border-radius:6px;overflow:hidden;position:relative}.chart-bar-fill{height:100%;border-radius:6px;transition:width .5s ease;display:flex;align-items:center;padding-left:8px;font-size:11px;font-weight:600;color:var(--accent-text);min-width:28px}.chart-bar-fill.accent{background:var(--accent)}.chart-bar-fill.success{background:var(--success)}.chart-bar-fill.info{background:var(--info)}.chart-bar-fill.warning{background:var(--warning)}.chart-bar-fill.danger{background:var(--danger)}.chart-bar-value{min-width:32px;font-size:12px;font-weight:600;color:var(--text-primary);text-align:right}.stamp-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}.stamp{width:100%;aspect-ratio:1;border-radius:8px;border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-size:16px;transition:all var(--transition);background:var(--bg-input)}.stamp.filled{background:var(--accent-glow);border-color:var(--accent);color:var(--accent)}.stamp.reward{background:var(--success-bg);border-color:var(--success);color:var(--success)}.changelog-link{position:relative}.changelog-dot{position:absolute;top:15px;right:15px;width:7px;height:7px;border-radius:50%;background:var(--accent)}.barber-filter{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.barber-chip{padding:5px 14px;border-radius:20px;font-size:12px;font-weight:500;cursor:pointer;border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);transition:all var(--transition);font-family:var(--font-body)}.barber-chip:hover{border-color:var(--accent);color:var(--accent)}.barber-chip.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.sidebar-link.locked{opacity:.45;cursor:default;position:relative}.sidebar-link.locked:hover{background:transparent;color:var(--text-muted)}.sidebar-link .lock-icon{margin-left:auto;flex-shrink:0;opacity:.6}.sidebar-link.locked .upgrade-hint{display:none;position:absolute;left:100%;top:50%;transform:translateY(-50%);background:var(--bg-card);border:1px solid var(--accent);color:var(--accent);font-size:11px;font-weight:600;padding:5px 12px;border-radius:var(--radius-sm);white-space:nowrap;z-index:100;box-shadow:0 4px 16px #0000004d;pointer-events:none}.sidebar-link.locked:hover .upgrade-hint{display:block}.locked-card-wrapper{position:relative}.locked-card-overlay{position:absolute;inset:0;z-index:10;background:#00000073;backdrop-filter:blur(2px);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:default}[data-theme=light] .locked-card-overlay{background:#fff9}.locked-card-overlay svg{opacity:.7}.locked-card-overlay .locked-label{font-size:13px;font-weight:600;color:var(--accent);background:var(--bg-card);padding:6px 16px;border-radius:20px;border:1px solid var(--accent);display:flex;align-items:center;gap:6px}.locked-card-overlay .locked-tier{font-size:11px;color:var(--text-muted);margin-top:2px}.btn.btn-locked{opacity:.45;cursor:not-allowed;position:relative;display:inline-flex;align-items:center;gap:6px}.btn.btn-locked:hover{opacity:.55}@media (max-width: 768px){.cal-legend{gap:8px;padding:8px 10px}.cal-legend-item{font-size:10px}.live-clock{font-size:26px}.chart-bar-label{min-width:60px;font-size:11px}.chart-bar-fill{font-size:10px}.stamp-grid{grid-template-columns:repeat(5,1fr);gap:4px}.stamp{font-size:13px}.barber-filter{gap:4px}.barber-chip{padding:4px 10px;font-size:11px}.sidebar-link.locked .upgrade-hint{left:auto;right:0;top:100%;transform:none;margin-top:4px}}.stats-chart-container{display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap;padding:8px 0}.stats-legend{display:flex;flex-direction:column;gap:6px;min-width:140px}.stats-legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary)}.stats-legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.stats-legend-val{margin-left:auto;font-weight:600;color:var(--text-primary);font-family:var(--font-mono);font-size:12px;padding-left:12px}.schedule-tracker{margin-top:20px}.schedule-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);margin-bottom:4px;font-size:13px;transition:all var(--transition)}.schedule-row:hover{border-color:var(--border-hover)}.schedule-time{font-family:var(--font-mono);color:var(--text-muted);min-width:90px;font-size:12px}.schedule-name{flex:1;font-weight:500}.schedule-svc{color:var(--text-muted);font-size:11px;margin-right:8px}.schedule-badge{font-size:10px;font-weight:600;padding:2px 10px;border-radius:12px;text-transform:uppercase;letter-spacing:.03em}.schedule-badge.on-time{background:var(--success-bg);color:var(--success)}.schedule-badge.delayed{background:var(--late-bg);color:var(--late)}.schedule-badge.upcoming{background:#e0c8970f;color:var(--text-muted)}.schedule-badge.done{background:#9b8abf14;color:#9b8abf}.schedule-summary{display:flex;gap:12px;margin-bottom:14px;flex-wrap:wrap}.schedule-kpi{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:12px}.schedule-kpi-dot{width:8px;height:8px;border-radius:50%}.schedule-kpi-label{color:var(--text-secondary)}.schedule-kpi-value{font-weight:700;color:var(--text-primary);font-family:var(--font-mono)}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0;border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;background:var(--bg-card)}.week-col{display:flex;flex-direction:column;min-height:220px;border-right:1px solid var(--border-color)}.week-col:last-child{border-right:none}.week-col-head{text-align:center;padding:14px 8px 12px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.week-col--today .week-col-head{background:var(--accent-glow)}.week-col-day{display:block;font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.week-col-num{display:block;font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--text-secondary);margin-top:2px}.week-col-num--today{color:var(--accent)}.week-col-body{flex:1;display:flex;flex-direction:column;gap:4px;padding:6px}.week-apt{padding:10px;border-radius:8px;cursor:pointer;background:var(--bg-secondary);border:1px solid var(--border-color);transition:all .15s ease;border-left:3px solid var(--border-hover)}.week-apt:hover{border-color:var(--border-hover);background:var(--bg-card-hover)}.week-apt-header{display:flex;align-items:baseline;gap:3px;margin-bottom:6px;padding-bottom:5px;border-bottom:1px solid var(--border-color)}.week-apt-time{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-secondary)}.week-apt-dash{font-size:10px;color:var(--text-muted)}.week-apt-name{font-size:12px;font-weight:600;color:var(--text-primary);line-height:1.3;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.week-apt-svc{font-size:10px;color:var(--text-muted);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.week-apt-barber{font-size:10px;color:var(--text-muted);opacity:.6;margin-top:1px}.week-apt-group{font-size:10px;color:var(--accent);font-weight:600;margin-top:4px;display:flex;align-items:center;gap:4px}.week-apt-delay{font-size:10px;color:var(--late);font-weight:600;margin-top:3px}.week-apt-empty{text-align:center;padding:32px 0;font-size:11px;color:var(--text-muted);opacity:.25}.week-apt--group{padding:14px 10px 28px;background:var(--bg-card);border-left-width:4px}.week-apt--group .week-apt-group{font-size:11px;padding:4px 8px;margin-top:8px;background:#e0c8970f;border:1px solid rgba(224,200,151,.12);border-radius:6px;display:inline-flex}.week-apt--confirmed{border-left-color:var(--success)}.week-apt--completed{border-left-color:#9b8abf}.week-apt--pending{border-left-color:var(--warning)}.week-apt--rescheduled{border-left-color:var(--info)}.week-apt--rejected{border-left-color:var(--danger)}.week-apt--cancelled{border-left-color:#555}.week-apt--late{border-left-color:var(--late)}@media (max-width: 768px){.week-grid{grid-template-columns:1fr!important;border-radius:var(--radius-sm)}.week-col{min-height:auto;border-right:none;border-bottom:1px solid var(--border-color)}.week-col:last-child{border-bottom:none}.week-col-head{display:flex;align-items:center;gap:8px;text-align:left;padding:10px 12px}.week-col-num{font-size:18px;margin-top:0}.week-apt{padding:10px}}@media (min-width: 769px) and (max-width: 1024px){.week-col{min-height:180px}.week-apt{padding:8px}.week-apt-name{font-size:11px}.week-apt-time{font-size:10px}.week-col-body{gap:3px;padding:4px}}.detail-row{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;font-size:13px;border-bottom:1px solid var(--border-color);background:var(--bg-input)}.detail-row:last-child{border-bottom:none}.detail-label{color:var(--text-muted);font-size:12px;flex-shrink:0;min-width:80px}.detail-value{color:var(--text-primary);text-align:right}.modal-action-btn{display:flex;align-items:center;gap:14px;width:100%;padding:14px 16px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);text-align:left;font-family:var(--font-body);color:var(--text-primary)}.modal-action-btn:hover{border-color:var(--border-hover);background:var(--bg-card-hover)}.modal-action-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--bg-card);border:1px solid var(--border-color)}.modal-action-btn div{display:flex;flex-direction:column}.modal-action-btn strong{font-size:13px;font-weight:600;line-height:1.3}.modal-action-btn span{font-size:11px;color:var(--text-muted);line-height:1.3;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.auth-option-card{display:flex;align-items:center;gap:16px;width:100%;padding:16px 18px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);text-align:left;font-family:var(--font-body);color:var(--text-primary)}.auth-option-card:hover{border-color:var(--border-hover);background:var(--bg-card-hover)}.auth-option-icon{width:42px;height:42px;border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-secondary)}.auth-option-text{display:flex;flex-direction:column}.auth-option-text strong{font-size:14px;font-weight:600;line-height:1.3;color:var(--text-primary)}.auth-option-text span{font-size:12px;color:var(--text-muted);line-height:1.3;margin-top:2px}.pending-card{display:flex;align-items:center;gap:16px;padding:16px 20px;margin-bottom:6px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);transition:all var(--transition);border-left:3px solid var(--warning)}.pending-card:hover{border-color:var(--border-hover)}.pending-card-left{min-width:120px;flex-shrink:0}.pending-card-date{font-size:14px;font-weight:600;color:var(--text-primary)}.pending-card-time{font-family:var(--font-mono);font-size:12px;color:var(--text-muted);margin-top:2px}.pending-card-info{flex:1;min-width:0}.pending-card-actions{display:flex;gap:6px;flex-shrink:0;flex-wrap:wrap}@media (max-width: 768px){.pending-card{flex-direction:column;align-items:flex-start;gap:10px}.pending-card-left{min-width:auto}.pending-card-actions{width:100%}}
