:root{font-family:Poppins,sans-serif;line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:light;--primary-color: #e99292;--primary-dark: #e74c3c;--primary-light: #ffe5e5;--accent-color: #e99292;--text-dark: #1a202c;--text-light: #718096;--bg-white: #ffffff;--bg-gray: #f7fafc;--border-color: #e2e8f0;--error-color: #e53e3e;--success-color: #38a169;--transition-normal: .3s ease-in-out}html,body{margin:0;padding:0;width:100%;height:100%;height:100dvh;overflow:hidden;background:var(--bg-white);color:var(--text-dark);transition:background-color .3s ease-in-out,color .3s ease-in-out;-webkit-text-size-adjust:100%}#app{width:100%;height:100%;margin:0;padding:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-gray)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary-color)}*{scrollbar-color:var(--border-color) var(--bg-gray);scrollbar-width:thin}.loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:32px;color:var(--text-light);font-size:14px;text-align:center}.spinner{display:inline-block;width:20px;height:20px;border:3px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spinner-sm{width:16px;height:16px;border-width:2px}.spinner-lg{width:28px;height:28px;border-width:3px}.loading-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.loading-overlay .spinner{width:40px;height:40px;border-width:4px}.skeleton{background:linear-gradient(90deg,var(--bg-gray) 25%,var(--primary-light) 50%,var(--bg-gray) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:4px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:16px;margin:8px 0;width:100%}.skeleton-avatar{width:48px;height:48px;border-radius:50%}.skeleton-card{height:120px;border-radius:8px;margin:12px 0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 32px;text-align:center;color:var(--text-light)}.empty-state-icon{width:64px;height:64px;margin-bottom:24px;color:var(--border-color);opacity:.6}.empty-state-title{font-size:18px;font-weight:600;color:var(--text-dark);margin-bottom:8px}.empty-state-text{font-size:14px;color:var(--text-light);margin-bottom:24px;max-width:300px}.badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap;transition:all var(--transition-normal)}.badge-primary{background:var(--primary-color);color:#fff}.badge-accent{background:var(--accent-color);color:#fff}.badge-success{background:var(--success-color);color:#fff}.badge-error{background:var(--error-color);color:#fff}.badge-warning{background:#f59e0b;color:#fff}.badge-light{background:var(--bg-gray);color:var(--text-dark);border:1px solid var(--border-color)}.badge-pending{background:#fef3c7;color:#92400e}.badge-active{background:#d1fae5;color:#065f46}.badge-completed{background:#dbeafe;color:#1e40af}.badge-disabled{background:var(--bg-gray);color:var(--text-light);opacity:.6}.notification-container{position:fixed;top:24px;right:24px;z-index:9999;max-width:400px;pointer-events:none}.toast{background:var(--bg-white);border:1px solid var(--border-color);border-radius:8px;padding:16px 20px;margin-bottom:12px;box-shadow:0 10px 30px #00000026;display:flex;align-items:center;gap:12px;pointer-events:all;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(400px);opacity:0}}.toast-exit{animation:slideOut .3s ease-out forwards}.toast-icon{width:20px;height:20px;flex-shrink:0}.toast-success{border-left:4px solid var(--success-color);color:var(--text-dark)}.toast-success .toast-icon{color:var(--success-color)}.toast-error{border-left:4px solid var(--error-color);color:var(--text-dark)}.toast-error .toast-icon{color:var(--error-color)}.toast-warning{border-left:4px solid #f59e0b;color:var(--text-dark)}.toast-warning .toast-icon{color:#f59e0b}.toast-info{border-left:4px solid var(--accent-color);color:var(--text-dark)}.toast-info .toast-icon{color:var(--accent-color)}.toast-message{flex:1;font-size:14px;font-weight:500}.toast-close{background:transparent;border:none;color:var(--text-light);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color var(--transition-normal)}.toast-close:hover{color:var(--text-dark)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideLeft{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes slideRight{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.animate-fade-in{animation:fadeIn .3s ease-out}.animate-slide-up{animation:slideUp .3s ease-out}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}button,a,input,select,textarea{outline:none}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent-color);outline-offset:2px}@media(prefers-contrast:more){button:focus-visible,a:focus-visible{outline-width:3px}.badge{border:2px solid currentColor}}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.text-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.opacity-50{opacity:.5}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.transition-all{transition:all var(--transition-normal)}.transition-colors{transition:background-color,color,border-color var(--transition-normal)}.select-none{user-select:none;-webkit-user-select:none}@media print{#app{display:none!important}.invoice-print-container{display:block!important;position:static!important;background:#fff!important;overflow:visible!important;width:100%!important}}.btn,button{font-family:inherit;font-size:14px;font-weight:500;border:none;border-radius:8px;cursor:pointer;padding:12px 20px;min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;white-space:nowrap}.btn-primary,button.btn-primary{background:var(--primary-color);color:#fff;border:2px solid var(--primary-color)}.btn-primary:hover:not(:disabled),button.btn-primary:hover:not(:disabled){background:var(--primary-dark);border-color:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #3a455640}.btn-primary:active:not(:disabled),button.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px #3a455626}.btn-dark,button.btn-dark{background:#e74c3c;color:#fff;border:2px solid #e74c3c}.btn-dark:hover:not(:disabled),button.btn-dark:hover:not(:disabled){background:#14192d;border-color:#14192d;transform:translateY(-2px);box-shadow:0 4px 12px #1c1b574d}.btn-dark:active:not(:disabled),button.btn-dark:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px #1c1b5733}.btn-secondary,button.btn-secondary{background:var(--bg-gray);color:var(--text-dark);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled),button.btn-secondary:hover:not(:disabled){background:var(--primary-light);border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #3a45561a}.btn-accent,button.btn-accent{background:var(--accent-color);color:#fff;border:2px solid var(--accent-color)}.btn-accent:hover:not(:disabled),button.btn-accent:hover:not(:disabled){background:#3ea8e8;border-color:#3ea8e8;transform:translateY(-2px);box-shadow:0 4px 12px #e992924d}.btn-danger,button.btn-danger{background:var(--error-color);color:#fff;border:2px solid var(--error-color)}.btn-danger:hover:not(:disabled),button.btn-danger:hover:not(:disabled){background:#c92a2a;border-color:#c92a2a;transform:translateY(-2px);box-shadow:0 4px 12px #e53e3e40}.btn-success,button.btn-success{background:var(--success-color);color:#fff;border:2px solid var(--success-color)}.btn-success:hover:not(:disabled),button.btn-success:hover:not(:disabled){background:#2f8659;border-color:#2f8659;transform:translateY(-2px);box-shadow:0 4px 12px #38a16940}.btn-ghost,button.btn-ghost{background:transparent;color:var(--primary-color);border:2px solid var(--primary-color)}.btn-ghost:hover:not(:disabled),button.btn-ghost:hover:not(:disabled){background:var(--primary-color);color:#fff;box-shadow:0 4px 12px #3a455626}.btn-sm,button.btn-sm{padding:8px 16px;min-height:36px;font-size:13px}.btn-lg,button.btn-lg{padding:14px 28px;min-height:48px;font-size:16px;font-weight:600}.btn-full,button.btn-full{width:100%}button:disabled,.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}button:focus-visible,.btn:focus-visible{outline:2px solid var(--accent-color);outline-offset:2px}.card{background:var(--bg-white);border:1px solid var(--border-color);border-radius:8px;padding:20px;box-shadow:0 2px 8px #0000000d;transition:all .3s ease}.card:hover{box-shadow:0 4px 16px #0000001a;border-color:var(--primary-light)}.card-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.card-title{font-size:18px;font-weight:600;color:var(--text-dark);margin:0}.card-subtitle{font-size:14px;color:var(--text-light);margin-top:4px}.card-body{margin-bottom:16px}.card-footer{display:flex;gap:12px;justify-content:flex-end;margin-top:16px;padding-top:12px;border-top:1px solid var(--border-color)}.form-group{margin-bottom:20px;display:flex;flex-direction:column}.form-group label{font-size:14px;font-weight:500;margin-bottom:8px;color:var(--text-dark);display:block}.form-group label.required:after{content:" *";color:var(--error-color)}.form-input,input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],input[type=time],select,textarea{font-family:inherit;font-size:14px;padding:12px 14px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-white);color:var(--text-dark);transition:all .3s ease}input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,input[type=number]:focus,input[type=date]:focus,input[type=time]:focus,select:focus,textarea:focus,.form-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #e992921a}input::placeholder,textarea::placeholder{color:var(--text-light)}textarea{resize:vertical;min-height:100px}.form-error{color:var(--error-color);font-size:12px;margin-top:4px}.form-help{color:var(--text-light);font-size:12px;margin-top:4px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.section{padding:32px;margin:0 0 24px;background:var(--bg-white);border-radius:8px;border:1px solid var(--border-color)}.section-title{font-size:20px;font-weight:700;color:var(--text-dark);margin:0 0 16px;padding-bottom:12px;border-bottom:2px solid var(--primary-color)}.section-subtitle{font-size:14px;color:var(--text-light);margin-top:4px}.table-wrapper{overflow-x:auto;border-radius:8px;border:1px solid var(--border-color)}table thead{background:var(--bg-gray);border-bottom:2px solid var(--border-color)}table th{padding:14px;text-align:left;font-weight:600;color:var(--text-dark);text-transform:uppercase;font-size:12px;letter-spacing:.5px}table td{padding:14px;border-bottom:1px solid var(--border-color);color:var(--text-dark)}table tbody tr:hover{background:var(--bg-gray);transition:background .2s ease}table tbody tr:last-child td{border-bottom:none}@media(max-width:768px){.btn,button{padding:10px 16px;min-height:40px;font-size:13px}.btn-lg,button.btn-lg{padding:12px 20px;min-height:44px;font-size:14px}.card{padding:16px}.form-row{grid-template-columns:1fr;gap:16px}.section{padding:20px;margin:12px 0}table{font-size:13px}table th,table td{padding:10px}}:root{--primary-color: #e99292;--primary-dark: #e74c3c;--accent-color: #e99292;--white: #ffffff;--text-dark: #1a202c;--medium-gray: #718096;--light-gray: #cbd5e0;--lighter-gray: #f7fafc;--border-color: #e2e8f0}.layout-container{display:flex;width:100%;height:100%}.main-content{flex:1;overflow:auto;width:100%}@media(max-width:900px){.layout-container{flex-wrap:wrap}}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}@media(max-width:1024px){.grid-3{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}}@media(max-width:768px){.grid-2,.grid-3{grid-template-columns:1fr;gap:16px}}.btn,button,.btn-group button{min-height:44px;font-size:14px;padding:11px 18px}@media(max-width:768px){.btn,button,.btn-group button{min-height:40px;padding:10px 14px;font-size:13px}.btn-group{display:flex;gap:10px;flex-wrap:wrap}.btn-group button{flex:1;min-width:100px}}.form-group{margin-bottom:18px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}input[type=text],input[type=email],input[type=number],input[type=password],input[type=date],select,textarea{width:100%;min-height:44px;font-size:14px;padding:11px 14px;border:1px solid var(--border-color);border-radius:6px;transition:all .3s ease}input[type=text]:focus,input[type=email]:focus,input[type=number]:focus,input[type=password]:focus,input[type=date]:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3a455614}@media(max-width:768px){.form-row{grid-template-columns:1fr}input,select,textarea{font-size:16px!important;padding:12px}label{font-size:14px;margin-bottom:8px;display:block}}.card{background:var(--white);border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 6px #0000000d;border:1px solid var(--border-color)}@media(max-width:768px){.card{padding:16px;margin-bottom:16px}}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse;font-size:14px}th,td{padding:13px;text-align:left;border-bottom:1px solid var(--border-color)}th{background:var(--lighter-gray);font-weight:600;color:var(--text-dark)}@media(max-width:768px){table{font-size:13px}th,td{padding:11px 10px;word-wrap:break-word}.table-wrapper{margin:0 -16px}}.modal{max-width:520px;width:90%}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal-content{background:#fff;border-radius:12px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003}@media(max-width:768px){.modal-overlay{align-items:flex-end}.modal,.modal-content{max-width:100%;width:100%;max-height:95vh;margin:0;border-radius:16px 16px 0 0;animation:slideUpModal .3s ease-out}@keyframes slideUpModal{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{padding:20px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:#fff;border-radius:16px 16px 0 0;position:sticky;top:0;z-index:10}.modal-header h2{color:#fff;margin:0;font-size:18px}.modal-body{padding:20px;max-height:70vh;overflow-y:auto}.modal-footer{padding:16px 20px;gap:12px;flex-wrap:wrap;border-top:1px solid #e2e8f0;position:sticky;bottom:0;background:#fff}.modal-footer button{flex:1;min-width:120px;height:48px;font-size:15px}}.section{padding:28px;margin:20px 0}@media(max-width:768px){.section{padding:16px;margin:12px 0}}h1,.h1{font-size:28px;line-height:1.2;color:var(--text-dark)}h2,.h2{font-size:24px;line-height:1.3;color:var(--text-dark)}h3,.h3{font-size:20px;line-height:1.3;color:var(--text-dark)}p{line-height:1.6;color:var(--text-dark)}@media(max-width:768px){h1,.h1{font-size:24px}h2,.h2{font-size:20px}h3,.h3{font-size:18px}p{font-size:14px}}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-wrap{flex-wrap:wrap}@media(max-width:768px){.flex-between{flex-direction:column;align-items:flex-start;gap:14px}}.p-24{padding:24px}.p-16{padding:16px}.m-16{margin:16px}@media(max-width:768px){.p-24{padding:16px}.p-16{padding:12px}.m-16{margin:12px}}@media(max-width:768px){.hide-mobile{display:none!important}}@media(min-width:769px){.show-mobile{display:none!important}}@media(max-width:768px){button,a.button,.btn{min-width:44px;min-height:44px}.clickable{min-height:44px;display:flex;align-items:center}}@media(max-width:768px){::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-thumb{background:#0003}}button:focus-visible,.btn:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--accent-color);outline-offset:2px}.skip-to-main{position:absolute;top:-40px;left:0;background:var(--primary-color);color:#fff;padding:8px 16px;text-decoration:none;z-index:10000;border-radius:4px}.skip-to-main:focus-visible{top:10px;outline-offset:4px}a{transition:color var(--transition-normal),text-decoration var(--transition-normal)}a:focus-visible{color:var(--primary-dark);text-decoration:underline}label{display:block;font-weight:500;margin-bottom:8px}label[for]{cursor:pointer}input:invalid,select:invalid,textarea:invalid{border-color:var(--error-color);box-shadow:0 0 0 3px #e53e3e1a}input:invalid:focus,select:invalid:focus,textarea:invalid:focus{outline-color:var(--error-color)}input.is-valid,select.is-valid,textarea.is-valid{border-color:var(--success-color);box-shadow:0 0 0 3px #38a1691a}button:disabled,input:disabled,select:disabled,textarea:disabled{opacity:.6;cursor:not-allowed}::placeholder{color:var(--text-light);opacity:1}.nav-menu [role=menuitem]:focus-visible,.nav-menu [role=menuitem]:hover{background:var(--bg-gray);color:var(--primary-color)}[role=alert],[role=status]{padding:16px;border-radius:8px;margin:12px 0;font-weight:500}[role=alert]{background:var(--error-color);color:#fff;border:1px solid var(--error-color)}@media(prefers-contrast:more){body{color:var(--text-dark)}button,.btn,a{font-weight:700}.badge,.badge-light{border-width:2px;border-color:currentColor}}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:root{--primary-color: #e99292;--primary-dark: #e74c3c;--primary-light: #ffe5e5;--accent-color: #e99292;--success-bg: #ecfdf5;--success-text: #047857;--success-border: #d1fae5;--error-bg: #fef2f2;--error-text: #dc2626;--error-border: #fecaca;--white: #ffffff;--black: #000000;--text-dark: #1a202c;--medium-gray: #718096;--light-gray: #cbd5e0;--lighter-gray: #f7fafc;--border-gray: #e2e8f0;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(58, 69, 86, .1);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .12);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--spacing-3xl: 64px;--font-family: "Poppins", sans-serif;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-size-xs: 11px;--font-size-sm: 13px;--font-size-base: 14px;--font-size-lg: 15px;--font-size-xl: 18px;--font-size-2xl: 24px;--font-size-3xl: 28px;--font-size-4xl: 48px;--transition-fast: .2s ease;--transition-normal: .3s ease;--transition-slow: .5s ease-out;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--z-background: -1;--z-base: 1;--z-card: 10;--z-modal: 100}html{scroll-behavior:smooth;height:100%}body{font-family:var(--font-family);color:var(--text-dark);line-height:1.6;height:100%;margin:0;padding:0}#app{height:100%;width:100%}.login-container{min-height:100vh;height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:#e99292;font-family:var(--font-family);position:relative;overflow:hidden;padding:var(--spacing-md)}.login-background{position:absolute;inset:0;background:#00000005;pointer-events:none;z-index:var(--z-background)}.login-card{background:var(--white)!important;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:var(--spacing-3xl);width:100%;max-width:420px;z-index:var(--z-card);animation:slideUp var(--transition-slow);color:var(--text-dark)!important;position:relative;border:none}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:var(--spacing-2xl)}.salon-logo{width:90px;height:90px;margin:0 auto var(--spacing-lg);display:block;color:var(--primary-color);transition:transform .3s ease}.login-header h1{font-size:var(--font-size-3xl);color:var(--text-dark)!important;margin:var(--spacing-sm) 0;font-weight:var(--font-weight-bold);letter-spacing:.5px}.subtitle{color:var(--medium-gray)!important;font-size:var(--font-size-sm);margin:var(--spacing-xs) 0 0 0;font-weight:var(--font-weight-normal)}.login-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column}.form-group label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-dark)!important;margin-bottom:var(--spacing-sm);text-transform:uppercase;letter-spacing:.3px}.form-group input{padding:12px var(--spacing-md);border:2px solid var(--primary-color);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:var(--font-family);transition:all var(--transition-normal);background:var(--white);color:var(--text-dark)}.form-group input::placeholder{color:#a0aec0}.form-group input:focus{outline:none;border-color:#e99292;box-shadow:0 0 0 3px #e992921a;background-color:var(--primary-light)}.form-group input:disabled{background-color:var(--lighter-gray);cursor:not-allowed;border-color:var(--border-gray)}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{width:100%;padding-right:40px}.toggle-password{position:absolute;right:12px;background:none;border:none;cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;color:var(--text-light);transition:color .2s ease}.toggle-password:hover{color:var(--primary-color)}.toggle-password .icon{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.alert{padding:14px var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);text-align:center;animation:fadeIn var(--transition-normal);border-left:4px solid}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.alert-danger{background-color:var(--error-bg);color:var(--error-text);border-color:var(--error-text)}.alert-success{background-color:var(--success-bg);color:var(--success-text);border-color:var(--success-text)}.error-message{color:var(--error-text);font-size:var(--font-size-sm);margin-top:var(--spacing-xs);display:block}.btn-login{padding:13px 20px;background:#e99292;color:var(--white);border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-normal);text-transform:uppercase;letter-spacing:.5px;margin:var(--spacing-md) auto 0;box-shadow:0 2px 8px #3a455626;display:block;width:100%}.btn-login:hover:not(:disabled){transform:translateY(-2px);background:#c0392b;box-shadow:0 4px 12px #c0392b4d}.btn-login:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px #ff6b6b26}.btn-login:disabled{opacity:.6;cursor:not-allowed}.login-footer{text-align:center;margin-top:var(--spacing-lg);font-size:var(--font-size-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md)}.support-text,.info-text{margin:0;color:var(--medium-gray);line-height:1.6}.support-text a,.info-text a{color:var(--primary-color);text-decoration:none;font-weight:var(--font-weight-medium);transition:color var(--transition-normal),text-decoration var(--transition-normal)}.support-text a:hover,.info-text a:hover{color:var(--accent-color);text-decoration:underline}@media(min-width:1440px){.login-card{max-width:460px;padding:72px}.login-header h1{font-size:32px}}@media(max-width:1024px){.login-card{padding:48px 36px;max-width:400px}.login-header h1{font-size:28px}.salon-logo{width:72px;height:72px;margin-bottom:var(--spacing-sm)}}@media(max-width:768px){.login-container{padding:var(--spacing-lg)}.login-card{padding:40px 28px;max-width:380px;border-radius:var(--radius-lg)}.login-header{margin-bottom:var(--spacing-xl)}.login-header h1{font-size:24px;letter-spacing:.3px}.salon-logo{width:80px;height:80px;margin-bottom:var(--spacing-sm)}.subtitle{font-size:13px}.login-form{gap:var(--spacing-lg)}.form-group input{padding:12px 14px;font-size:15px}.btn-login{display:block;width:100%;padding:14px 20px;font-size:15px;min-height:50px;letter-spacing:.3px;margin-top:var(--spacing-md)}.login-footer{font-size:12px;gap:var(--spacing-sm)}}@media(max-width:480px){.login-container{padding:var(--spacing-sm)}.login-card{padding:32px 24px;margin:var(--spacing-sm);max-width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.login-header{margin-bottom:var(--spacing-lg)}.login-header h1{font-size:22px;letter-spacing:.3px;margin:var(--spacing-sm) 0}.salon-logo{width:70px;height:70px;margin-bottom:var(--spacing-sm)}.subtitle{font-size:12px}.login-form{gap:var(--spacing-md)}.form-group label{font-size:12px;margin-bottom:var(--spacing-xs)}.form-group input{padding:13px 14px;font-size:16px;border-radius:var(--radius-sm)}.form-group input:focus{box-shadow:0 0 0 2px #e9929233}.error-message{font-size:11px;margin-top:var(--spacing-xs)}.alert{padding:12px 14px;font-size:12px}.btn-login{display:block;width:100%;padding:15px 16px;font-size:15px;min-height:52px;letter-spacing:.3px;margin-top:var(--spacing-md);border-radius:var(--radius-sm)}.btn-login:active:not(:disabled){transform:scale(.98)}.login-footer{margin-top:var(--spacing-md);font-size:11px;flex-wrap:wrap;gap:var(--spacing-xs)}.divider{display:none}}@media(max-width:374px){.login-card{padding:24px 18px;margin:var(--spacing-xs)}.login-header{margin-bottom:var(--spacing-lg)}.login-header h1{font-size:20px;margin:6px 0}.salon-logo{width:60px;height:60px;margin-bottom:var(--spacing-xs)}.subtitle{font-size:11px}.login-form{gap:var(--spacing-md)}.form-group label{font-size:12px;margin-bottom:var(--spacing-xs)}.form-group input{padding:12px 11px;font-size:16px}.form-group input:focus{box-shadow:0 0 0 1px #e9929233}.btn-login{display:block;width:100%;padding:13px;font-size:14px;min-height:50px;margin-top:var(--spacing-md)}}@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}.login-container *:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}@media print{.login-container{background:var(--white)}.login-background{display:none}.login-card{box-shadow:none;border:1px solid var(--border-gray)}.btn-login{display:none}}.sidebar[data-v-76dd0a83]{width:260px;min-width:260px;background:var(--bg-white);color:var(--text-dark);display:flex;flex-direction:column;align-items:stretch;padding:0;height:100vh;height:100dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;box-shadow:2px 0 4px #0000000d}.sidebar-header[data-v-76dd0a83]{display:flex;align-items:center;gap:12px;padding:28px 20px;font-size:20px;font-weight:700;border-bottom:1px solid var(--border-color);background:var(--bg-white)}.sidebar-logo[data-v-76dd0a83]{font-size:32px;display:flex;align-items:center;justify-content:center}.sidebar-title[data-v-76dd0a83]{font-size:18px;font-weight:700;letter-spacing:.5px;color:var(--accent-color)}.sidebar-nav[data-v-76dd0a83]{display:flex;flex-direction:column;gap:8px;padding:24px 12px;flex:1}.nav-link[data-v-76dd0a83]{color:var(--accent-color);text-decoration:none;padding:12px 16px;font-size:14px;border:none;background:none;text-align:left;cursor:pointer;transition:all .3s ease;border-radius:8px;display:flex;align-items:center;gap:12px;font-weight:500;position:relative}.nav-icon[data-v-76dd0a83]{width:20px;height:20px;flex-shrink:0;stroke:currentColor}.nav-label[data-v-76dd0a83]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-link[data-v-76dd0a83]:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;background:var(--accent-color);border-radius:0 3px 3px 0;transition:height .3s ease}.nav-link[data-v-76dd0a83]:hover{background:#e992921a;color:var(--accent-color);transform:translate(4px)}.nav-link.active[data-v-76dd0a83]{background:#e9929226;color:var(--accent-color);font-weight:600}.nav-link.active[data-v-76dd0a83]:before{height:70%}.nav-link.logout-link[data-v-76dd0a83]{margin-top:auto;color:var(--error-color);font-weight:600;border-top:1px solid var(--border-color);padding-top:20px;margin-bottom:20px}.nav-link.logout-link[data-v-76dd0a83]:hover{background:#e53e3e26;color:#e99292;transform:translate(4px)}.nav-link.logout-link[data-v-76dd0a83]:before{background:var(--error-color)}@media(max-width:900px){.sidebar[data-v-76dd0a83]{position:fixed;left:-260px;top:0;bottom:0;width:260px;min-width:260px;z-index:1000;transition:left .3s ease;box-shadow:4px 0 12px #00000026}.sidebar.sidebar-open[data-v-76dd0a83]{left:0}.sidebar-header[data-v-76dd0a83]{padding:20px;border-bottom:1px solid var(--border-color)}.sidebar-title[data-v-76dd0a83]{display:block;font-size:20px}.user-profile[data-v-76dd0a83]{padding:16px;flex-direction:row;gap:12px}.profile-avatar[data-v-76dd0a83]{width:48px;height:48px;font-size:18px}.profile-info[data-v-76dd0a83]{display:block;text-align:left}.profile-name[data-v-76dd0a83]{font-size:14px;font-weight:600}.profile-role[data-v-76dd0a83]{font-size:12px;opacity:.8}.profile-email[data-v-76dd0a83]{font-size:11px;opacity:.7}.photo-btn[data-v-76dd0a83]{width:36px;height:36px;padding:8px}.nav-link[data-v-76dd0a83]{flex-direction:row;justify-content:flex-start;align-items:center;padding:14px 16px;gap:12px;font-size:14px}.nav-icon[data-v-76dd0a83]{width:22px;height:22px}.nav-label[data-v-76dd0a83]{display:block;text-align:left;font-weight:500}.nav-link.logout-link[data-v-76dd0a83]{margin-bottom:20px}}.layout-container[data-v-76dd0a83]{display:flex;height:100vh;height:100dvh;width:100vw;overflow:hidden}.mobile-bottom-nav[data-v-76dd0a83]{display:none}.main-content[data-v-76dd0a83]{flex:1;background:#f7fafc;overflow-y:auto;overflow-x:hidden;height:100%;width:100%}.mobile-topbar[data-v-76dd0a83]{display:none}.user-profile[data-v-76dd0a83]{display:flex;align-items:center;gap:10px;padding:15px;margin:10px;border-radius:8px;background:#ffffff1a;position:relative}.profile-avatar[data-v-76dd0a83]{width:45px;height:45px;border-radius:50%;background:#e74c3c;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px;flex-shrink:0;overflow:hidden;border:2px solid rgba(255,255,255,.3)}.profile-photo[data-v-76dd0a83]{width:100%;height:100%;object-fit:cover}.profile-info[data-v-76dd0a83]{flex:1;min-width:0}.profile-name[data-v-76dd0a83]{margin:0;font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-role[data-v-76dd0a83]{margin:2px 0 0;font-size:11px;opacity:.8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-email[data-v-76dd0a83]{margin:2px 0 0;font-size:10px;opacity:.6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.photo-btn[data-v-76dd0a83]{background:#3a455633;border:1px solid rgba(58,69,86,.5);color:#e99292;cursor:pointer;padding:5px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.photo-btn[data-v-76dd0a83]:hover{background:#e992924d;border-color:#e99292}.photo-upload[data-v-76dd0a83]{display:none}.logout-link[data-v-76dd0a83]{margin-top:auto;color:#e53e3e!important;font-weight:600;border-top:1px solid rgba(255,255,255,.1);padding-top:20px!important;margin-top:20px!important}.logout-link[data-v-76dd0a83]:hover{background:#e53e3e26!important;color:#e99292!important;transform:translate(4px)}.logout-link[data-v-76dd0a83]:before{background:#e53e3e}.hamburger-btn[data-v-76dd0a83]{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:none;border-radius:8px;cursor:pointer;flex-shrink:0;transition:background .2s}.hamburger-btn svg[data-v-76dd0a83]{width:22px;height:22px;stroke:#e99292}.hamburger-btn[data-v-76dd0a83]:active{background:#e9929226}.topbar-title[data-v-76dd0a83]{flex:1;text-align:center;font-size:16px;font-weight:700;color:#1a202c;letter-spacing:.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 8px}.topbar-avatar[data-v-76dd0a83]{width:36px;height:36px;border-radius:50%;background:#e99292;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;flex-shrink:0;cursor:pointer;-webkit-user-select:none;user-select:none}.sidebar-overlay[data-v-76dd0a83]{display:none;position:fixed;inset:0;background:#00000080;z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media(max-width:900px){.mobile-topbar[data-v-76dd0a83]{display:flex;align-items:center;position:fixed;top:0;left:0;right:0;height:56px;background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 2px 8px #0000000f;padding:0 12px;z-index:1001;gap:4px}.sidebar-overlay[data-v-76dd0a83]{display:block}.layout-container[data-v-76dd0a83]{padding-top:0}.main-content[data-v-76dd0a83]{margin-left:0;width:100%;padding-top:56px;padding-bottom:64px;overflow-y:auto;-webkit-overflow-scrolling:touch;height:100%}.main-content.pos-page-content[data-v-76dd0a83]{padding-bottom:0}.user-profile[data-v-76dd0a83]{flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:12px 8px;margin:8px}.profile-avatar[data-v-76dd0a83]{width:45px;height:45px;font-size:14px}.profile-info[data-v-76dd0a83]{display:none}.photo-btn[data-v-76dd0a83]{display:flex;width:32px;height:32px;padding:6px}.logout-link[data-v-76dd0a83]{margin-top:auto;border-top:1px solid #333;padding-top:12px!important;margin-top:12px!important}.logout-link .nav-icon[data-v-76dd0a83]{width:24px;height:24px}.logout-link .nav-label[data-v-76dd0a83]{display:block;text-align:center;width:100%}.mobile-bottom-nav[data-v-76dd0a83]{display:flex;position:fixed;bottom:0;left:0;right:0;height:64px;background:#fff;border-top:1px solid #e2e8f0;box-shadow:0 -2px 12px #00000012;z-index:1001;align-items:stretch;padding:0;padding-bottom:env(safe-area-inset-bottom,0px)}.bottom-tab[data-v-76dd0a83]{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;text-decoration:none;color:#9ca3af;font-size:10px;font-weight:500;background:none;border:none;cursor:pointer;padding:8px 4px;transition:color .2s,transform .1s;-webkit-tap-highlight-color:transparent}.bottom-tab svg[data-v-76dd0a83]{width:22px;height:22px;stroke:currentColor;stroke-width:2;fill:none;flex-shrink:0}.bottom-tab span[data-v-76dd0a83]{font-size:10px;font-weight:500;letter-spacing:.2px}.bottom-tab[data-v-76dd0a83]:active{transform:scale(.92)}.bottom-tab-active[data-v-76dd0a83]{color:#e99292!important}.bottom-tab-pos[data-v-76dd0a83]{position:relative}}.toast-enter-active[data-v-192bac2c],.toast-leave-active[data-v-192bac2c]{transition:all .3s ease}.toast-enter-from[data-v-192bac2c],.toast-leave-to[data-v-192bac2c]{transform:translate(400px);opacity:0}.notification-container[data-v-192bac2c]{position:fixed;top:24px;right:24px;z-index:9999;max-width:400px;pointer-events:none}.toast[data-v-192bac2c]{pointer-events:all;margin-bottom:12px}.sc-toast[data-v-4687de3f]{position:fixed;bottom:24px;right:20px;z-index:9999;display:flex;align-items:center;gap:12px;padding:12px 16px;background:linear-gradient(135deg,#059669,#047857);color:#fff;border-radius:14px;box-shadow:0 8px 30px #05966973,0 2px 8px #0000001f;min-width:240px;max-width:340px}.sc-toast__icon[data-v-4687de3f]{flex-shrink:0;width:34px;height:34px;background:#ffffff38;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:7px;animation:pop-in-4687de3f .4s cubic-bezier(.175,.885,.32,1.275)}.sc-toast__icon svg[data-v-4687de3f]{width:100%;height:100%}.sc-toast__body[data-v-4687de3f]{flex:1;display:flex;flex-direction:column;gap:2px}.sc-toast__title[data-v-4687de3f]{font-size:13px;font-weight:700;letter-spacing:.01em}.sc-toast__sub[data-v-4687de3f]{font-size:11px;opacity:.85}.sc-toast__dot[data-v-4687de3f]{width:9px;height:9px;border-radius:50%;background:#ffffffe6;flex-shrink:0;animation:pulse-dot-4687de3f 1.8s ease-in-out infinite}.sc-banner[data-v-4687de3f]{position:fixed;top:0;left:0;right:0;z-index:9998;overflow:hidden}.sc-banner__inner[data-v-4687de3f]{display:flex;align-items:center;gap:12px;padding:11px 20px}.sc-banner__shimmer[data-v-4687de3f]{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.65) 40%,rgba(255,255,255,.9) 50%,rgba(255,255,255,.65) 60%,transparent 100%);background-size:250% 100%;animation:shimmer-4687de3f 1.6s linear infinite}.sc-banner--connecting[data-v-4687de3f]{background:linear-gradient(135deg,#4f46e5,#6d28d9);box-shadow:0 4px 24px #4f46e566;color:#fff;border-bottom:1px solid rgba(255,255,255,.12)}.sc-banner--error[data-v-4687de3f]{background:linear-gradient(135deg,#dc2626,#991b1b);box-shadow:0 4px 24px #dc262666;color:#fff;border-bottom:1px solid rgba(255,255,255,.12)}.sc-banner--offline[data-v-4687de3f]{background:linear-gradient(135deg,#d97706,#92400e);box-shadow:0 4px 24px #d9770666;color:#fff;border-bottom:1px solid rgba(255,255,255,.12)}.sc-banner__icon[data-v-4687de3f]{flex-shrink:0;width:34px;height:34px;background:#ffffff2e;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:7px}.sc-banner__icon svg[data-v-4687de3f]{width:100%;height:100%}.sc-banner__icon--spin svg[data-v-4687de3f]{animation:spin-4687de3f 1s linear infinite}.sc-banner__text[data-v-4687de3f]{flex:1;display:flex;flex-direction:column;gap:1px}.sc-banner__title[data-v-4687de3f]{font-size:13px;font-weight:700;letter-spacing:.01em}.sc-banner__sub[data-v-4687de3f]{font-size:11px;opacity:.82}.sc-banner__pulse[data-v-4687de3f]{width:9px;height:9px;border-radius:50%;background:#ffffffe6;flex-shrink:0;animation:pulse-dot-4687de3f 1.4s ease-in-out infinite}@keyframes shimmer-4687de3f{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes spin-4687de3f{to{transform:rotate(360deg)}}@keyframes pulse-dot-4687de3f{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.4}}@keyframes pop-in-4687de3f{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.banner-drop-enter-active[data-v-4687de3f],.banner-drop-leave-active[data-v-4687de3f]{transition:transform .35s cubic-bezier(.4,0,.2,1),opacity .3s ease}.banner-drop-enter-from[data-v-4687de3f],.banner-drop-leave-to[data-v-4687de3f]{transform:translateY(-100%);opacity:0}.toast-pop-enter-active[data-v-4687de3f],.toast-pop-leave-active[data-v-4687de3f]{transition:transform .38s cubic-bezier(.4,0,.2,1),opacity .3s ease}.toast-pop-enter-from[data-v-4687de3f],.toast-pop-leave-to[data-v-4687de3f]{transform:translate(120px);opacity:0}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--border-color);gap:24px;flex-wrap:wrap}.page-header>div:first-child{flex:1}.header-title{display:flex;align-items:center;gap:12px;margin-bottom:8px}.title-icon{width:28px;height:28px;color:var(--primary-color);stroke:var(--primary-color)!important;fill:none;flex-shrink:0}.page-title{font-size:32px;font-weight:700;color:var(--text-dark);margin:0}.page-subtitle{font-size:15px;color:#64748b;margin:4px 0 0}.btn-primary{display:flex;align-items:center;gap:8px;padding:12px 28px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;font-size:14px}.btn-primary:hover{background:var(--accent-color);transform:translateY(-2px);box-shadow:0 4px 12px #e9929240}.btn-primary:active{transform:translateY(0);box-shadow:0 2px 6px #e9929233}.btn-primary .icon{width:20px;height:20px}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start;gap:16px;margin-bottom:24px;padding-bottom:20px}.btn-primary{width:100%;justify-content:center;padding:11px 20px}.page-title{font-size:26px}.title-icon{width:24px;height:24px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Poppins,sans-serif;background:#fff;color:#333;transition:background-color .3s,color .3s}html,body,#app{height:100%;width:100%}
