:root{--primary: #7c3aed;--primary-light: #ede9fe;--primary-dark: #6d28d9;--secondary: #ec4899;--secondary-light: #fce7f3;--bg: #f5f4f9;--sidebar-bg: #1a1a2e;--white: #ffffff;--border: #e8e4f0;--border-light: #f0ecf8;--text: #1a1a2e;--text-muted: #888;--text-light: #bbb;--green: #059669;--green-light: #d1fae5;--yellow: #d97706;--yellow-light: #fef3c7;--red: #dc2626;--red-light: #fee2e2;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 16px rgba(124,58,237,.08);--shadow-lg: 0 8px 32px rgba(0,0,0,.15);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px}html{overflow-x:hidden}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d4c9f0;border-radius:3px}.btn-primary{background:var(--primary);color:#fff;border:none;padding:8px 16px;border-radius:var(--radius-md);font-size:13px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:background .15s;font-family:inherit}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:#fff;color:var(--text-muted);border:1.5px solid var(--border);padding:8px 16px;border-radius:var(--radius-md);font-size:13px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .15s;font-family:inherit}.btn-secondary:hover{background:var(--bg);color:var(--text)}.btn-icon{width:32px;height:32px;border-radius:var(--radius-md);border:1px solid var(--border);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#666;font-size:12px;transition:all .1s}.btn-icon:hover{background:var(--bg)}.card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden}.card-header{padding:16px 20px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:14px;font-weight:600}.card-action{font-size:12px;color:var(--primary);cursor:pointer;font-weight:500}.form-group{margin-bottom:16px}.form-label{font-size:12px;font-weight:600;color:#555;margin-bottom:6px;display:block}.form-input,.form-select,.form-textarea{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--radius-md);font-size:13px;font-family:inherit;color:var(--text);transition:border-color .15s;background:#fff}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary)}.form-textarea{resize:vertical;min-height:70px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modal-overlay{position:fixed;inset:0;background:#00000073;z-index:500;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease}.modal{background:#fff;border-radius:var(--radius-xl);width:480px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border-light);display:flex;align-items:center}.modal-title{font-size:16px;font-weight:600;flex:1}.modal-close{width:32px;height:32px;border-radius:var(--radius-md);border:none;background:var(--bg);cursor:pointer;font-size:16px;color:#666;display:flex;align-items:center;justify-content:center}.modal-body{padding:20px 24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border-light);display:flex;gap:10px;justify-content:flex-end}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:12px;font-size:11px;font-weight:600}.badge-confirmed{background:var(--green-light);color:var(--green)}.badge-pending{background:var(--yellow-light);color:var(--yellow)}.badge-cancelled{background:#f1f5f9;color:#64748b}.badge-no_show{background:#f5f5f4;color:#78716c}.badge-completed{background:#f0fdf4;color:#15803d}.badge-vip{background:#fff7ed;color:#ea580c}.popover{position:fixed;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:280px;z-index:400;border:1px solid var(--border);animation:fadeIn .1s ease}.popover-header{padding:14px 16px 12px;border-bottom:1px solid var(--border-light)}.popover-body{padding:12px 16px}.popover-row{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:12px;color:#555}.popover-row i{color:var(--primary);width:14px;text-align:center;font-size:11px}.popover-actions{padding:10px 16px 14px;display:flex;gap:8px;flex-wrap:wrap}.pop-btn{flex:1;min-width:56px;padding:7px 8px;border-radius:7px;font-size:11px;font-weight:600;cursor:pointer;border:none;text-align:center;transition:opacity .1s}.pop-btn:hover{opacity:.85}.pop-btn.confirm{background:var(--green-light);color:var(--green)}.pop-btn.edit{background:var(--primary-light);color:var(--primary)}.pop-btn.call{background:var(--sidebar-bg);color:#fff}.pop-btn.cancel{background:var(--red-light);color:var(--red)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.toggle{position:relative;display:inline-block;width:36px;height:20px}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:#ddd;border-radius:10px;transition:.2s}.toggle-slider:before{content:"";position:absolute;width:14px;height:14px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}.toggle input:checked+.toggle-slider{background:var(--primary)}.toggle input:checked+.toggle-slider:before{transform:translate(16px)}@media(max-width:768px){.btn-primary,.btn-secondary{min-height:44px;padding:10px 18px;font-size:14px}.btn-icon{width:44px;height:44px;border-radius:10px}.form-row{grid-template-columns:1fr}.form-input,.form-select,.form-textarea{font-size:16px;padding:12px 14px;min-height:44px}.modal-overlay{align-items:flex-end;padding:0}.modal{width:100%;max-width:100%;border-radius:20px 20px 0 0;max-height:92dvh;animation:slideUpSheet .28s cubic-bezier(.4,0,.2,1)}.modal-header{padding:16px 20px 14px}.modal-body{padding:16px 20px}.modal-footer{padding:12px 20px;padding-bottom:max(12px,env(safe-area-inset-bottom));flex-direction:column-reverse}.modal-footer .btn-primary,.modal-footer .btn-secondary{width:100%;justify-content:center}.popover{position:fixed!important;inset:auto 0 0!important;width:100%!important;border-radius:20px 20px 0 0;padding-bottom:max(0px,env(safe-area-inset-bottom));animation:slideUpSheet .25s cubic-bezier(.4,0,.2,1);box-shadow:0 -8px 32px #0000002e}.popover:before{content:"";display:block;width:40px;height:4px;background:#e0d8f0;border-radius:2px;margin:12px auto 4px}.popover-actions{padding:12px 16px 20px;gap:10px}.pop-btn{padding:12px 10px;font-size:13px;border-radius:10px}.card{border-radius:12px}}@keyframes slideUpSheet{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:768px){[style*="height:100vh"],[style*="height: 100vh"]{height:auto!important;overflow:visible!important}.page-topbar{padding:0 14px!important;height:52px!important}.page-topbar .btn-primary{font-size:13px;padding:8px 12px}}.app-layout{display:flex;min-height:100vh;min-height:100dvh;overflow-x:hidden;width:100%}.sidebar{width:220px;min-height:100vh;background:#16162a;display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:200;overflow-y:auto;overflow-x:hidden;transition:width .22s cubic-bezier(.4,0,.2,1);border-right:1px solid rgba(255,255,255,.05)}.sidebar::-webkit-scrollbar{width:3px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.sidebar-logo{padding:14px 12px 12px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0;overflow:hidden}.logo-row{display:flex;align-items:center;gap:9px;white-space:nowrap}.logo-img{width:34px;height:34px;object-fit:contain;border-radius:8px;background:#ffffff14;flex-shrink:0}.logo-icon-fallback{width:34px;height:34px;border-radius:8px;background:#ffffff1a;display:flex;align-items:center;justify-content:center;flex-shrink:0}.logo-icon-fallback i{color:#a78bfa;font-size:16px}.logo-text{flex:1;min-width:0;overflow:hidden}.logo-title{color:#fff;font-size:13px;font-weight:700;letter-spacing:.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logo-sub{color:#ffffff47;font-size:10px;margin-top:1px}.sidebar-close-btn{display:none;width:28px;height:28px;background:#ffffff14;border:none;border-radius:6px;color:#fff9;cursor:pointer;font-size:12px;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.sidebar-close-btn:hover{background:#ffffff26}.sidebar-nav{flex:1;padding:6px 0 4px;overflow:hidden}.nav-section{padding:10px 10px 2px}.nav-section+.nav-section{padding-top:8px;margin-top:4px;border-top:1px solid rgba(255,255,255,.05)}.nav-label{display:block;color:#ffffff38;font-size:9.5px;font-weight:700;letter-spacing:.9px;text-transform:uppercase;padding:2px 8px 5px;white-space:nowrap;overflow:hidden;transition:opacity .15s}.nav-item{display:flex;align-items:center;gap:9px;padding:6px 10px;border-radius:7px;color:#ffffff85;font-size:12.5px;cursor:pointer;margin:1px 0;transition:background .13s,color .13s,padding .13s;text-decoration:none;min-height:33px;white-space:nowrap;overflow:hidden;position:relative}.nav-item:hover{background:#ffffff0f;color:#ffffffe0}.nav-item.active{background:#7c3aed38;color:#c4b5fd;font-weight:600;border-left:2px solid #7c3aed;padding-left:8px}.nav-item.active i{color:#a78bfa}.nav-item i{width:15px;text-align:center;font-size:12px;flex-shrink:0}.nav-item-label{flex:1;transition:opacity .15s}.nav-badge{background:#f43f5e;color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:8px}.sidebar-footer{padding:8px 10px 10px;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0;overflow:hidden;display:flex;flex-direction:column;gap:2px}.sidebar-toggle-btn{display:flex;align-items:center;gap:9px;width:100%;padding:6px 10px;border-radius:7px;background:none;border:none;cursor:pointer;color:#ffffff52;font-size:12px;transition:background .13s,color .13s;text-align:left;min-height:32px;white-space:nowrap;overflow:hidden}.sidebar-toggle-btn:hover{background:#ffffff0f;color:#ffffffb3}.sidebar-toggle-btn i{width:15px;text-align:center;flex-shrink:0;font-size:11px}.user-card{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:7px;cursor:pointer;min-height:36px;transition:background .13s;white-space:nowrap;overflow:hidden}.user-card:hover{background:#ffffff0f}.user-avatar{width:26px;height:26px;border-radius:50%;background:#7c3aed;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:700;flex-shrink:0}.user-info{flex:1;min-width:0;overflow:hidden}.user-name{color:#fffc;font-size:11.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{color:#ffffff4d;font-size:9.5px;margin-top:1px}.sidebar.sidebar-collapsed{width:52px}.sidebar.sidebar-collapsed .logo-text,.sidebar.sidebar-collapsed .nav-label,.sidebar.sidebar-collapsed .nav-item-label,.sidebar.sidebar-collapsed .nav-badge,.sidebar.sidebar-collapsed .user-info{opacity:0;width:0;overflow:hidden}.sidebar.sidebar-collapsed .nav-section{padding-left:6px;padding-right:6px}.sidebar.sidebar-collapsed .nav-item{justify-content:center;padding:6px;border-left:none;gap:0}.sidebar.sidebar-collapsed .nav-item.active{padding-left:6px;border-left:none;background:#7c3aed47}.sidebar.sidebar-collapsed .nav-item i{width:auto;font-size:13px}.sidebar.sidebar-collapsed .nav-section+.nav-section{margin-top:2px}.sidebar.sidebar-collapsed .sidebar-toggle-btn,.sidebar.sidebar-collapsed .user-card{justify-content:center;padding:6px;gap:0}.sidebar.sidebar-collapsed .sidebar-toggle-btn i,.sidebar.sidebar-collapsed .user-avatar{margin:0}.sidebar.sidebar-collapsed .nav-item:after{content:attr(data-label);position:absolute;left:56px;top:50%;transform:translateY(-50%);background:#1e293b;color:#e2e8f0;padding:5px 11px;border-radius:7px;font-size:12px;font-weight:500;white-space:nowrap;z-index:9999;pointer-events:none;opacity:0;transition:opacity .12s;box-shadow:0 4px 16px #00000059;border:1px solid rgba(255,255,255,.08)}.sidebar.sidebar-collapsed .nav-item:hover:after{opacity:1}.main-content{margin-left:220px;flex:1;min-width:0;display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;transition:margin-left .22s cubic-bezier(.4,0,.2,1);overflow-x:hidden}.layout-collapsed .main-content{margin-left:52px}.mobile-topbar{display:none;position:fixed;top:0;left:0;right:0;height:52px;background:#16162a;align-items:center;justify-content:space-between;padding:0 14px;z-index:150;box-shadow:0 2px 10px #0000004d;border-bottom:1px solid rgba(255,255,255,.06)}.mobile-logo{color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;gap:7px}.hamburger-btn{width:36px;height:36px;background:#ffffff14;border:none;border-radius:8px;color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center}.hamburger-btn:hover{background:#ffffff24}.mobile-notify-btn{width:36px;height:36px;background:#ffffff14;border:none;border-radius:8px;color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative}.mobile-notify-btn:hover{background:#ffffff24}.mobile-notify-dot{width:7px;height:7px;background:#f43f5e;border-radius:50%;position:absolute;top:7px;right:7px;border:1.5px solid #16162a}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0009;z-index:190;opacity:0;transition:opacity .28s}.sidebar-overlay.visible{opacity:1}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:58px;background:#fff;border-top:1px solid #e8e4f0;z-index:150;box-shadow:0 -3px 16px #00000012}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:#aaa;font-size:9px;font-weight:600;text-decoration:none;text-transform:uppercase;letter-spacing:.3px;padding:6px 0;-webkit-tap-highlight-color:transparent;transition:color .15s}.bottom-nav-item i{font-size:17px;transition:transform .15s}.bottom-nav-item.active{color:#7c3aed}.bottom-nav-item.active i{transform:translateY(-1px)}@media(max-width:768px){.mobile-topbar{display:flex}.sidebar-overlay{display:block;pointer-events:none}.sidebar-overlay.visible{pointer-events:all}.bottom-nav,.sidebar-close-btn{display:flex}.sidebar-toggle-btn{display:none}.sidebar{transform:translate(-100%);box-shadow:none}.sidebar.sidebar-open{transform:translate(0);box-shadow:6px 0 32px #0006;width:220px}.sidebar.sidebar-open .logo-text,.sidebar.sidebar-open .nav-label,.sidebar.sidebar-open .nav-item-label,.sidebar.sidebar-open .user-info{opacity:1;width:auto}.sidebar.sidebar-open .nav-item{justify-content:flex-start;padding:6px 10px;gap:9px}.sidebar.sidebar-open .nav-item.active{border-left:2px solid #7c3aed;padding-left:8px}.sidebar.sidebar-open .sidebar-toggle-btn,.sidebar.sidebar-open .user-card{justify-content:flex-start;padding:6px 8px;gap:8px}.main-content{margin-left:0;padding-top:52px;padding-bottom:58px}.layout-collapsed .main-content{margin-left:0}}@media(min-width:769px)and (max-width:1024px){.sidebar:not(.sidebar-collapsed){width:200px}.main-content{margin-left:200px}.layout-collapsed .main-content{margin-left:52px}}.login-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);padding:20px}.login-card{background:#fff;border-radius:20px;padding:48px 40px;width:100%;max-width:400px;box-shadow:0 25px 60px #0006}.login-logo{text-align:center;margin-bottom:32px}.login-logo-icon{width:64px;height:64px;background:linear-gradient(135deg,#7c3aed,#ec4899);border-radius:16px;display:inline-flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:16px}.login-logo h1{font-size:24px;font-weight:700;color:#1a1a2e;letter-spacing:-.5px;margin:0 0 4px}.login-logo p{font-size:13px;color:#9ca3af;margin:0}.login-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:20px;display:flex;align-items:center;gap:8px}.login-form{display:flex;flex-direction:column;gap:18px}.login-field label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:6px}.login-input-wrap{position:relative;display:flex;align-items:center}.login-input-wrap>.fas:first-child{position:absolute;left:14px;color:#9ca3af;font-size:13px;pointer-events:none}.login-input-wrap input{width:100%;padding:11px 14px 11px 38px;border:1.5px solid #e5e7eb;border-radius:10px;font-size:14px;color:#1a1a2e;outline:none;transition:border-color .2s;font-family:inherit}.login-input-wrap input:focus{border-color:#7c3aed}.login-toggle-pass{position:absolute;right:12px;background:none;border:none;cursor:pointer;color:#9ca3af;padding:4px;font-size:13px}.login-btn{width:100%;padding:13px;background:linear-gradient(135deg,#7c3aed,#ec4899);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;transition:opacity .2s,transform .1s;margin-top:4px;display:flex;align-items:center;justify-content:center;gap:8px}.login-btn:hover:not(:disabled){opacity:.92;transform:translateY(-1px)}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-footer{text-align:center;margin-top:28px;font-size:12px;color:#d1d5db}.dashboard{display:flex;flex-direction:column;height:100vh;overflow:hidden}.page-topbar{background:#fff;border-bottom:1px solid var(--border);padding:0 28px;height:60px;display:flex;align-items:center;gap:16px;flex-shrink:0}.page-title{font-size:16px;font-weight:600;flex:1}.topbar-date{color:#888;font-size:12px;white-space:nowrap}.lang-toggle{display:flex;background:var(--bg);border-radius:6px;padding:2px}.lang-btn{padding:4px 10px;border-radius:4px;font-size:11px;font-weight:600;cursor:pointer;color:#888}.lang-btn.active{background:#fff;color:var(--primary);box-shadow:0 1px 3px #0000001a}.dashboard-body{flex:1;overflow-y:auto;padding:24px 28px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.stat-card{background:#fff;border-radius:var(--radius-lg);padding:20px;border:1px solid var(--border);transition:box-shadow .15s}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;margin-bottom:12px}.stat-icon.purple{background:var(--primary-light);color:var(--primary)}.stat-icon.pink{background:var(--secondary-light);color:var(--secondary)}.stat-icon.green{background:var(--green-light);color:var(--green)}.stat-icon.orange{background:#ffedd5;color:#ea580c}.stat-value{font-size:24px;font-weight:700}.stat-label{font-size:12px;color:#888;margin-top:2px}.stat-change{font-size:11px;margin-top:8px}.stat-change.up{color:var(--green)}.stat-change.down{color:#888}.quick-actions{display:flex;gap:12px;margin-bottom:20px}.quick-btn{flex:1;padding:14px 12px;border-radius:10px;border:1.5px dashed #d4c9f0;background:#faf9fe;text-align:center;cursor:pointer;transition:all .15s;color:var(--primary);font-size:12px;font-weight:500;position:relative}.quick-btn:hover{background:var(--primary-light);border-color:var(--primary)}.quick-btn i{display:block;font-size:20px;margin-bottom:6px}.qb-badge{position:absolute;top:8px;right:8px;background:#f43f5e;color:#fff;font-size:10px;font-weight:700;padding:1px 5px;border-radius:8px}.dash-grid{display:grid;grid-template-columns:1fr 380px;gap:16px}.apt-list{overflow-y:auto;max-height:320px}.apt-item{display:flex;align-items:center;gap:12px;padding:10px 20px;border-bottom:1px solid var(--border-light)}.apt-item:last-child{border-bottom:none}.apt-time-col{text-align:right;min-width:44px}.apt-time{font-size:12px;font-weight:600;color:var(--primary)}.apt-dur{font-size:10px;color:#999}.apt-bar{width:3px;height:40px;border-radius:2px;flex-shrink:0}.apt-info{flex:1}.apt-name-text{font-size:13px;font-weight:500}.apt-svc-text{font-size:11px;color:#999;margin-top:1px}.empty-state{text-align:center;padding:32px;color:#bbb;font-size:13px}.client-list{overflow-y:auto}.client-item{display:flex;align-items:center;gap:10px;padding:10px 20px;border-bottom:1px solid var(--border-light);cursor:pointer}.client-item:last-child{border-bottom:none}.client-item:hover{background:var(--bg)}.client-avatar-sm{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:600;flex-shrink:0}.client-name-text{font-size:13px;font-weight:500}.client-meta-text{font-size:11px;color:#999;margin-top:1px}.client-last{font-size:11px;color:#888;white-space:nowrap}.luna-card{background:linear-gradient(135deg,#1a1a2e,#2d1b69);border-radius:var(--radius-lg);padding:16px}.luna-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.luna-avatar{width:36px;height:36px;background:#ffffff1a;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px}.luna-name{color:#fff;font-size:13px;font-weight:600}.luna-sub{color:#b48ee0;font-size:11px}.luna-status{margin-left:auto;display:flex;align-items:center;gap:5px}.luna-dot{width:7px;height:7px;background:#4ade80;border-radius:50%}.luna-status span{color:#4ade80;font-size:11px;font-weight:600}.luna-items{display:flex;flex-direction:column;gap:8px}.luna-item{background:#ffffff14;border-radius:8px;padding:10px 12px;display:flex;align-items:center;gap:10px}.luna-item i{color:#b48ee0;font-size:13px;width:16px;text-align:center}.luna-item>div:nth-child(2){flex:1}.li-title{color:#fff;font-size:11px;font-weight:500}.li-sub{color:#b48ee0;font-size:10px;margin-top:1px}.li-badge-ok{background:#4ade8026;color:#4ade80;font-size:10px;font-weight:600;padding:3px 8px;border-radius:6px}@media(max-width:768px){.dashboard{height:auto;overflow:visible}.dashboard-body{padding:16px;overflow-y:visible}.page-topbar{padding:0 16px;height:52px}.topbar-date,.lang-toggle{display:none}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px}.stat-card{padding:14px}.stat-value{font-size:20px}.stat-icon{width:34px;height:34px;font-size:14px;margin-bottom:8px}.quick-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px}.quick-btn{padding:14px 10px}.dash-grid{grid-template-columns:1fr;gap:14px}.apt-list{max-height:none}.luna-card{margin-top:0}}@media(max-width:375px){.stats-grid{grid-template-columns:1fr 1fr}.stat-value{font-size:18px}}.cal-page{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--bg)}.cal-topbar{background:#fff;border-bottom:1px solid var(--border);padding:0 20px;height:60px;display:flex;align-items:center;gap:12px;flex-shrink:0}.cal-nav{display:flex;align-items:center;gap:6px}.cal-period{font-size:15px;font-weight:600;min-width:200px}.cal-spacer{flex:1}.view-toggle{display:flex;background:var(--bg);border-radius:8px;padding:3px}.view-btn{padding:5px 14px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;color:#888;border:none;background:transparent;transition:all .15s;font-family:inherit}.view-btn.active{background:#fff;color:var(--primary);box-shadow:0 1px 3px #0000001a;font-weight:600}.staff-filter{display:flex;align-items:center;gap:6px}.filter-label{font-size:11px;color:#999;font-weight:600}.staff-chip{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;border:1.5px solid var(--border);font-size:11px;font-weight:500;cursor:pointer;color:#666;background:#fff;transition:all .15s}.staff-chip.active{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.staff-dot{width:7px;height:7px;border-radius:50%}.cal-body{display:flex;flex:1;overflow:hidden}.cal-sidebar{width:210px;background:#fff;border-right:1px solid var(--border);padding:16px;overflow-y:auto;flex-shrink:0;display:flex;flex-direction:column;gap:16px}.mini-cal-header{display:flex;align-items:center;gap:4px;margin-bottom:10px}.mini-cal-title{flex:1;text-align:center;font-size:12px;font-weight:600}.mini-cal-btn{width:22px;height:22px;border-radius:5px;border:1px solid var(--border);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:9px;color:#666}.mini-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.mini-day-label{text-align:center;font-size:9px;font-weight:600;color:#ccc;padding:3px 0}.mini-date{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:10px;border-radius:5px;cursor:pointer;transition:all .1s}.mini-date:hover{background:var(--bg)}.mini-date.other{color:#ddd}.mini-date.today{background:var(--primary);color:#fff;font-weight:600}.mini-date.selected{background:var(--primary-light);color:var(--primary);font-weight:600}.mini-date.today.selected{background:var(--primary);color:#fff}.legend-title{font-size:10px;font-weight:600;color:#bbb;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.legend-item{display:flex;align-items:center;gap:7px;padding:3px 0;font-size:11px;color:#555}.legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.today-summary{display:flex;flex-direction:column;gap:6px}.ts-item{display:flex;align-items:center;gap:6px;font-size:12px;color:#555}.ts-item span{font-size:18px;font-weight:700;color:var(--green)}.ts-item.pending span{color:var(--yellow)}.cal-main{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--bg)}.day-view{min-height:100%}.time-grid-wrap{display:flex}.time-col{width:56px;flex-shrink:0;background:#fff;border-right:1px solid var(--border)}.time-slot{height:60px;display:flex;align-items:flex-start;justify-content:flex-end;padding:4px 8px 0;border-bottom:1px solid var(--border-light)}.time-label{font-size:10px;color:#bbb;font-weight:500}.day-col-wrap{flex:1;background:#fff}.day-col{min-height:100%}.hour-line{position:absolute;left:0;right:0;height:1px;background:var(--border-light);pointer-events:none}.slot-click{position:absolute;left:0;right:0;cursor:pointer;z-index:1}.slot-click:hover{background:#7c3aed0a}.now-line{position:absolute;left:0;right:0;z-index:5;pointer-events:none;display:flex;align-items:center;transform:translateY(-50%)}.now-dot{width:8px;height:8px;background:#ef4444;border-radius:50%;flex-shrink:0;margin-left:-4px}.now-bar{flex:1;height:2px;background:#ef4444;opacity:.85}.apt-block{position:absolute;left:6px;right:6px;border-radius:8px;padding:4px 8px;cursor:pointer;z-index:10;box-shadow:0 1px 4px #0000000f;transition:all .15s;overflow:hidden}.apt-block:hover{transform:translate(2px);box-shadow:0 3px 12px #0000001a}.apt-name{font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.apt-svc{font-size:10px;opacity:.8;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.apt-time-label{font-size:10px;opacity:.75;margin-top:1px;line-height:1.3}.week-view{display:flex;flex-direction:column;min-height:100%}.week-header{display:grid;grid-template-columns:56px repeat(7,1fr);background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20;flex-shrink:0}.wh-time{border-right:1px solid var(--border)}.wh-day{padding:8px 6px 6px;text-align:center;border-right:1px solid var(--border-light)}.wh-day.today{background:#7c3aed08}.wh-day-name{font-size:10px;color:#999;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.wh-day-num{font-size:17px;font-weight:700;margin-top:2px}.wh-day-num.today-num{background:var(--primary);color:#fff;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:2px auto 0;font-size:14px}.wh-day-count{font-size:10px;color:#b0b7c3;margin-top:3px;font-weight:500;letter-spacing:.2px}.week-grid{display:grid;grid-template-columns:56px repeat(7,1fr);flex:1}.day-col{background:#fff;border-right:1px solid var(--border-light)}.day-col.today-col{background:#7c3aed05}.month-view{padding:0}.month-header{display:grid;grid-template-columns:repeat(7,1fr);background:#fff;border-bottom:1px solid var(--border)}.month-day-label{text-align:center;padding:10px 0;font-size:11px;font-weight:600;color:#999;text-transform:uppercase}.month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0}.month-day{min-height:100px;padding:8px;border-right:1px solid var(--border-light);border-bottom:1px solid var(--border-light);cursor:pointer;background:#fff;transition:background .1s}.month-day:hover{background:#7c3aed08}.month-day.today{background:#7c3aed0a}.month-day.other-month{background:#fafafa}.month-day-num{font-size:13px;font-weight:600;margin-bottom:6px}.month-day-num.today-num{background:var(--primary);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px}.month-apt-dots{display:flex;gap:3px;flex-wrap:wrap;margin-bottom:4px}.month-dot{width:8px;height:8px;border-radius:2px}.month-more{font-size:10px;color:#999}.month-apt-count{font-size:11px;color:#888}.luna-toggle-row{background:var(--primary-light);border-radius:8px;padding:10px 12px;display:flex;align-items:center;gap:10px;margin-top:4px}.luna-toggle-row i{color:var(--primary);font-size:13px}.luna-toggle-text{flex:1;font-size:12px;color:#444;font-weight:500}.luna-toggle-sub{font-size:10px;color:#888;font-weight:400;margin-top:1px}@media(max-width:768px){.cal-page{height:100dvh}.cal-topbar{flex-wrap:wrap;height:auto;padding:10px 12px 8px;gap:8px;row-gap:8px}.cal-nav{order:1}.cal-period{order:2;flex:1;font-size:13px;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.view-toggle{order:4;flex:1}.view-btn{flex:1;text-align:center;padding:6px 8px;font-size:12px}.staff-filter{order:5;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px;gap:6px}.staff-filter::-webkit-scrollbar{display:none}.filter-label{white-space:nowrap;font-size:11px}.staff-chip{white-space:nowrap;flex-shrink:0;padding:6px 12px;min-height:34px}.cal-nueva-btn{display:none!important}.cal-sidebar{display:none}.cal-body{flex-direction:column}.time-col{width:44px}.time-label{font-size:9px}.apt-block{left:4px;right:4px}.apt-name{font-size:12px}.apt-svc{font-size:10px}.week-header{grid-template-columns:44px repeat(7,1fr);overflow-x:auto}.week-grid{grid-template-columns:44px repeat(7,minmax(80px,1fr));overflow-x:auto}.wh-day-name{font-size:8px}.wh-day-num{font-size:14px}.wh-day-num.today-num{width:26px;height:26px;font-size:12px}.month-day{min-height:60px;padding:4px}.month-day-num{font-size:11px;margin-bottom:3px}.month-day-num.today-num{width:20px;height:20px;font-size:10px}.month-apt-dots{gap:2px}.month-dot{width:6px;height:6px}.month-day-label{font-size:9px;padding:6px 0}.cal-fab{display:flex!important}}.cal-fab{display:none;position:fixed;bottom:76px;right:16px;width:56px;height:56px;background:linear-gradient(135deg,#7c3aed,#ec4899);border-radius:16px;border:none;color:#fff;font-size:22px;cursor:pointer;align-items:center;justify-content:center;box-shadow:0 6px 20px #7c3aed73;z-index:100;transition:transform .15s,box-shadow .15s;-webkit-tap-highlight-color:transparent}.cal-fab:active{transform:scale(.92);box-shadow:0 3px 10px #7c3aed66}.day-artist-header{display:flex;background:#fff;border-bottom:2px solid var(--border);position:sticky;top:0;z-index:20;flex-shrink:0}.day-artist-header-spacer{width:56px;flex-shrink:0;border-right:1px solid var(--border)}.day-artist-cell{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border-right:1px solid var(--border-light);background:#fff}.day-artist-cell:last-child{border-right:none}.day-artist-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.day-artist-name{font-size:13px;font-weight:600;color:var(--text)}.day-artist-count{font-size:11px;color:var(--text-muted);background:var(--bg);padding:2px 8px;border-radius:10px}.day-view-multi{display:flex;flex-direction:column;min-height:100%}.day-col-bordered{border-right:1px solid var(--border-light)!important}@media(max-width:768px){.day-artist-header-spacer{width:44px}.day-artist-cell{flex-direction:column;gap:3px;padding:8px 6px;text-align:center}.day-artist-count{font-size:10px;padding:1px 6px}.day-artist-name{font-size:11px}.day-artist-dot{width:8px;height:8px}}.apt-block{cursor:grab}.apt-block:active{cursor:grabbing}.apt-block.dragging{opacity:.25;cursor:grabbing;pointer-events:none}.day-view.is-dragging{user-select:none;-webkit-user-select:none;cursor:grabbing}.day-view.is-dragging *{cursor:grabbing!important}.drop-indicator{position:absolute;left:0;right:0;height:2px;background:var(--primary);border-radius:1px;z-index:15;pointer-events:none}.drop-indicator:before{content:"";position:absolute;left:0;top:-3px;width:8px;height:8px;background:var(--primary);border-radius:50%}.drop-indicator-time{position:absolute;left:8px;top:-11px;background:var(--primary);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:6px;white-space:nowrap;box-shadow:0 2px 8px #7c3aed4d}.drag-ghost{position:fixed;pointer-events:none;z-index:1000;width:220px}.drag-ghost-time{background:var(--primary);color:#fff;font-size:11px;font-weight:700;padding:3px 9px;border-radius:6px 6px 0 0;display:inline-block;box-shadow:0 2px 8px #7c3aed59}.drag-ghost-block{border-radius:8px;box-shadow:0 8px 28px #0000002e;transform:rotate(-1.5deg) scale(1.03);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.drag-ghost-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drag-ghost-svc{font-size:11px;opacity:.8;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:768px){.drag-ghost{width:180px}}.clients-page{display:flex;flex-direction:column;height:100vh;overflow:hidden}.topbar-right{display:flex;align-items:center;gap:12px}.clients-body{display:flex;flex:1;overflow:hidden}.clients-list-panel{width:380px;flex-shrink:0;display:flex;flex-direction:column;border-right:1px solid var(--border);background:#fff}.clients-toolbar{padding:12px 16px;border-bottom:1px solid var(--border-light);display:flex;flex-direction:column;gap:8px}.search-box{display:flex;align-items:center;gap:8px;background:var(--bg);border-radius:8px;padding:8px 12px}.search-box i{color:#bbb;font-size:12px}.search-box input{border:none;background:transparent;font-family:inherit;font-size:13px;color:var(--text);flex:1;outline:none}.filter-tabs{display:flex;gap:4px}.filter-tab{padding:5px 14px;border-radius:20px;border:1.5px solid var(--border);font-size:12px;font-weight:500;cursor:pointer;color:#888;background:#fff;transition:all .15s;font-family:inherit}.filter-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.clients-count{padding:8px 16px;font-size:11px;color:#bbb;font-weight:500;border-bottom:1px solid var(--border-light)}.clients-list{flex:1;overflow-y:auto}.client-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border-light);cursor:pointer;transition:background .1s}.client-row:hover{background:var(--bg)}.client-row.selected{background:var(--primary-light);border-left:3px solid var(--primary)}.cr-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;font-weight:600;flex-shrink:0}.cr-info{flex:1}.cr-name{font-size:13px;font-weight:500}.cr-meta{font-size:11px;color:#999;margin-top:2px}.cr-date{font-size:11px;color:#bbb;white-space:nowrap}.client-detail{flex:1;display:flex;flex-direction:column;background:#fff;overflow:hidden}.client-detail.empty-detail{align-items:center;justify-content:center;color:#ccc;gap:12px}.client-detail.empty-detail i{font-size:48px}.client-detail.empty-detail p{font-size:13px}.cd-header{display:flex;align-items:center;gap:10px;background:#fff;padding:12px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.cd-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:700;flex-shrink:0}.cd-info{flex:1;min-width:0}.cd-name{font-size:14px;font-weight:700;color:#1e293b;display:flex;align-items:center;flex-wrap:wrap;gap:4px}.cd-sub{font-size:11px;color:#94a3b8;margin-top:1px;display:flex;align-items:center;gap:4px;overflow:hidden}.cd-stats-row{display:flex;align-items:center;background:linear-gradient(135deg,#faf8ff,#f5f3ff);padding:10px 14px;border-bottom:1px solid #ede9fe;flex-shrink:0}.cd-stat-pill{display:flex;flex-direction:column;align-items:center;flex:1;gap:2px}.cd-stat-val{font-size:17px;font-weight:800;color:var(--primary);line-height:1.2;letter-spacing:-.3px}.cd-stat-lbl{font-size:9px;color:#a78bfa;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.cd-stat-divider{width:1px;height:28px;background:#ddd6fe;flex-shrink:0}.cd-tabs{display:flex;background:#f1f5f9;border-bottom:1px solid var(--border);padding:6px 14px;gap:3px;flex-shrink:0}.cd-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:7px 8px;font-size:11.5px;font-weight:600;color:#64748b;background:none;border:none;cursor:pointer;border-radius:8px;transition:all .15s;white-space:nowrap;font-family:inherit}.cd-tab:hover{color:var(--primary);background:#7c3aed0f}.cd-tab.active{color:var(--primary);background:#fff;box-shadow:0 1px 4px #0000001a,0 0 0 1px #7c3aed21}.cd-tab-count{background:var(--primary);color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:8px;min-width:16px;text-align:center;line-height:1.5}.cd-tab.active .cd-tab-count{background:var(--primary);box-shadow:0 1px 3px #7c3aed4d}.cd-tab-body{flex:1;overflow-y:auto;padding:14px;background:#f8fafc}.cd-info-card{background:#fff;border-radius:10px;border:1px solid #e2e8f0;padding:10px 12px;margin-bottom:8px;box-shadow:0 1px 3px #0000000a}.cd-info-card-title{font-size:9.5px;font-weight:700;color:#a0aec0;text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px}.cd-info-grid{display:flex;flex-direction:column;gap:1px}.cd-field{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:#475569;padding:5px 0;border-bottom:1px solid #f8fafc}.cd-field:last-child{border-bottom:none}.cd-field i{color:var(--primary);width:13px;text-align:center;font-size:11px;flex-shrink:0;margin-top:1px}.cd-field-full{grid-column:1 / -1}.cd-apt-item{display:flex;align-items:center;gap:10px;padding:9px 12px;background:#fff;border-radius:9px;border:1px solid #e2e8f0;margin-bottom:6px;box-shadow:0 1px 3px #0000000a;transition:box-shadow .15s}.cd-apt-item:last-child{margin-bottom:0}.cd-apt-item:hover{box-shadow:0 2px 8px #00000014}.cd-apt-dot{width:8px;height:8px;border-radius:3px;flex-shrink:0;box-shadow:0 0 0 2px #ffffffe6}.cd-actions{display:flex;gap:8px;padding:10px 14px;background:#fff;border-top:1px solid var(--border);flex-shrink:0}.cd-section{background:#fff;border-radius:var(--radius-lg);padding:12px;margin-bottom:8px;border:1px solid var(--border)}.cd-section-title{font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px}.tag-chip{background:var(--primary-light);color:var(--primary);padding:2px 8px;border-radius:12px;font-size:10.5px;font-weight:500}@media(max-width:768px){.clients-page{height:auto;overflow:visible}.page-topbar{padding:0 14px;height:52px}.clients-body{flex-direction:column;overflow:visible;position:relative}.clients-list-panel{width:100%;border-right:none;border-bottom:1px solid var(--border);max-height:none}.client-row{padding:14px 16px}.cr-avatar{width:44px;height:44px;font-size:16px}.filter-tab{padding:7px 14px;min-height:36px}.client-detail:not(.empty-detail){position:fixed;inset:56px 0 60px;z-index:130;overflow-y:auto;padding:16px;background:var(--bg);animation:slideInRight .28s cubic-bezier(.4,0,.2,1)}.client-detail.empty-detail{display:none}.cd-back-btn{display:flex!important}.cd-stats{gap:8px}.cd-stat{padding:12px 8px}.cd-stat div{font-size:18px}.cd-actions{flex-direction:column}.cd-actions .btn-primary,.cd-actions .btn-secondary{justify-content:center}}.cd-back-btn{display:none;align-items:center;gap:8px;margin-bottom:16px;background:none;border:none;color:var(--primary);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;padding:0}.cd-back-btn i{font-size:12px}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}
