:root{--color-primary:#6366f1;--color-primary-hover:#4f46e5;--color-primary-light:#eef2ff;--color-primary-50:#e8e8fd;--color-primary-100:#c7d2fe;--color-primary-600:#4f46e5;--color-primary-700:#4338ca;--color-primary-rgb:99,102,241;--color-accent:#ec4899;--color-accent-light:#fdf2f8;--color-text:var(--color-gray-900);--color-text-primary:var(--color-gray-900);--color-text-secondary:var(--color-gray-500);--color-text-tertiary:var(--color-gray-400);--color-bg:var(--color-white);--color-bg-secondary:var(--color-gray-50);--bg-primary:var(--color-white);--bg-secondary:var(--color-gray-50);--text-secondary:var(--color-gray-500);--text-tertiary:var(--color-gray-400);--color-secondary:#64748b;--color-success:#10b981;--color-success-light:#ecfdf5;--color-danger:#f43f5e;--color-danger-light:#fff1f2;--color-warning:#f59e0b;--color-warning-light:#fffbeb;--color-info:#3b82f6;--color-info-light:#eff6ff;--color-white:#fff;--color-gray-50:#f8fafc;--color-gray-100:#f1f5f9;--color-gray-200:#e2e8f0;--color-gray-300:#cbd5e1;--color-gray-400:#94a3b8;--color-gray-500:#64748b;--color-gray-600:#475569;--color-gray-700:#334155;--color-gray-800:#1e293b;--color-gray-900:#0f172a;--font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;--font-mono:"SF Mono",Monaco,"Cascadia Code","Courier New",monospace;--font-size-xs:0.75rem;--font-size-sm:0.8125rem;--font-size-md:0.9375rem;--font-size-lg:1.0625rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height:1.6;--letter-spacing:-0.011em;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--sidebar-width:256px;--sidebar-collapsed-width:68px;--header-height:60px;--bottom-nav-height:60px;--safe-area-bottom:env(safe-area-inset-bottom,0px);--content-max-width:1440px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--border-color:var(--color-gray-200);--color-border:var(--color-gray-200);--color-border-light:var(--color-gray-100);--shadow-sm:0 1px 2px rgba(15,23,42,.04),0 1px 3px rgba(15,23,42,.06);--shadow-md:0 2px 4px rgba(15,23,42,.04),0 4px 8px rgba(15,23,42,.06);--shadow-lg:0 4px 8px rgba(15,23,42,.04),0 8px 24px rgba(15,23,42,.08);--shadow-xl:0 8px 16px rgba(15,23,42,.06),0 20px 40px rgba(15,23,42,.1);--shadow-primary:0 4px 14px rgba(99,102,241,.3);--shadow-card:0 1px 3px rgba(15,23,42,.03),0 1px 2px rgba(15,23,42,.06);--shadow-ring:0 0 0 3px rgba(99,102,241,.15);--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-normal:250ms cubic-bezier(0.4,0,0.2,1);--transition-slow:350ms cubic-bezier(0.4,0,0.2,1);--transition-spring:500ms cubic-bezier(0.34,1.56,0.64,1);--gradient-primary:linear-gradient(135deg,#6366f1,#4f46e5);--gradient-primary-hover:linear-gradient(135deg,#4f46e5,#4338ca);--gradient-brand:linear-gradient(135deg,#6366f1,#8b5cf6);--badge-success-bg:#dcfce7;--badge-success-text:#16a34a;--badge-danger-bg:#fef2f2;--badge-danger-text:#dc2626;--badge-warning-bg:#fef3c7;--badge-warning-text:#d97706;--badge-info-bg:#dbeafe;--badge-info-text:#2563eb;--overlay-bg:rgba(15,23,42,.4);--overlay-blur:blur(4px);--z-dropdown:100;--z-sticky:200;--z-modal-backdrop:300;--z-modal:400;--z-toast:500}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background-color:var(--color-gray-50);color:var(--color-gray-900);font-family:var(--font-family);font-size:var(--font-size-md);line-height:var(--line-height)}img,svg{display:block;max-width:100%}a{color:var(--color-primary);text-decoration:none}a:hover{color:var(--color-primary-hover)}button,input,select,textarea{color:inherit;font-family:inherit;font-size:inherit;line-height:inherit}button{background:none;border:none;cursor:pointer}table{border-collapse:collapse;width:100%}ol,ul{list-style:none}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing);line-height:1.3}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}p+p{margin-top:var(--spacing-md)}::selection{background-color:rgba(var(--color-primary-rgb),.15);color:var(--color-primary-hover)}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}html{overscroll-behavior:none}@supports (height:100dvh){.full-height{height:100dvh}}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.sr-only{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0,0,0,0);border:0;white-space:nowrap}#app{display:flex;min-height:100vh}.app-sidebar{background:var(--color-white);border-right:1px solid var(--color-gray-100);bottom:0;display:flex;flex-direction:column;left:0;overflow-x:hidden;overflow-y:auto;position:fixed;scrollbar-color:transparent transparent;scrollbar-width:thin;top:0;transition:width var(--transition-normal),box-shadow var(--transition-normal);width:var(--sidebar-width);z-index:calc(var(--z-sticky) + 1)}.app-sidebar:hover{scrollbar-color:var(--color-gray-200) transparent}.app-sidebar::-webkit-scrollbar{width:4px}.app-sidebar::-webkit-scrollbar-thumb{background:transparent;border-radius:2px}.app-sidebar:hover::-webkit-scrollbar-thumb{background:var(--color-gray-200)}.sidebar-overlay{backdrop-filter:var(--overlay-blur);-webkit-backdrop-filter:var(--overlay-blur);background:var(--overlay-bg);display:none;inset:0;opacity:0;position:fixed;transition:opacity var(--transition-normal);z-index:var(--z-modal-backdrop)}.sidebar-overlay.is-visible{display:block;opacity:1}.sidebar-logo{align-items:center;gap:10px;height:var(--header-height);overflow:hidden;padding:0 20px}.sidebar-logo,.sidebar-logo-icon{display:flex;flex-shrink:0}.sidebar-logo-text{background:var(--gradient-brand);-webkit-background-clip:text;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);letter-spacing:-.02em;-webkit-text-fill-color:transparent;background-clip:text;flex:1;min-width:0;white-space:nowrap}.sidebar-pin-link{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--color-gray-400);cursor:pointer;display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:10px;margin-bottom:4px;padding:8px 12px;text-align:left;transition:all var(--transition-fast);white-space:nowrap;width:100%}.sidebar-pin-link:hover{background:var(--color-gray-50);color:var(--color-gray-600)}.sidebar-nav{flex:1;overflow-y:auto;padding:4px 10px}.sidebar-section-label{color:var(--color-gray-400);font-size:.68rem;font-weight:var(--font-weight-semibold);letter-spacing:.05em;overflow:hidden;padding:16px 12px 6px;text-transform:uppercase;white-space:nowrap}.sidebar-divider{background:var(--color-gray-100);height:1px;margin:8px 12px}.sidebar-link{align-items:center;border-radius:var(--radius-md);color:var(--color-gray-500);display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:10px;margin-bottom:1px;padding:8px 12px;position:relative;text-decoration:none;transition:all var(--transition-fast);white-space:nowrap}.sidebar-link:hover{background:var(--color-gray-50);color:var(--color-gray-700)}.sidebar-link:active{background:var(--color-gray-100);transform:scale(.98)}.sidebar-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}.sidebar-link.active{background:var(--color-primary-light);color:var(--color-primary);font-weight:var(--font-weight-semibold)}.sidebar-link.active:before{background:var(--color-primary);border-radius:0 2px 2px 0;bottom:6px;content:"";left:0;position:absolute;top:6px;width:3px}.sidebar-icon{align-items:center;display:flex;flex-shrink:0;height:20px;justify-content:center;opacity:.75;width:20px}.sidebar-link:hover .sidebar-icon{opacity:.9}.sidebar-link.active .sidebar-icon{opacity:1}.sidebar-label{overflow:hidden;text-overflow:ellipsis}.sidebar-missed-calls{background:var(--badge-danger-bg);border:1px solid #fecaca;border-radius:var(--radius-md);flex-shrink:0;margin:0 10px;overflow:hidden}.sidebar-missed-header{align-items:center;border-bottom:1px solid #fecaca;display:flex;justify-content:space-between;padding:8px 10px}.sidebar-missed-title{align-items:center;color:var(--badge-danger-text);display:flex;font-size:.78rem;font-weight:600;gap:6px}.sidebar-missed-clear{background:none;border:none;color:var(--badge-danger-text);cursor:pointer;font-size:1.1rem;line-height:1;opacity:.6;padding:0 4px}.sidebar-missed-clear:hover{opacity:1}.sidebar-missed-item{border-bottom:1px solid #fecaca;cursor:pointer;display:flex;flex-direction:column;padding:6px 10px;text-decoration:none;transition:background .15s}.sidebar-missed-item:last-child{border-bottom:none}.sidebar-missed-item:hover{background:#fee2e2}.sidebar-missed-phone{color:var(--badge-danger-text);font-size:.82rem;font-weight:600}.sidebar-missed-meta{color:#b91c1c;font-size:.72rem}.sidebar-collapsed .sidebar-missed-calls .sidebar-label,.sidebar-collapsed .sidebar-missed-clear,.sidebar-collapsed .sidebar-missed-meta,.sidebar-collapsed .sidebar-missed-phone{display:none}.sidebar-collapsed .sidebar-missed-calls{margin:0 6px}.sidebar-collapsed .sidebar-missed-header{border-bottom:none;justify-content:center;padding:8px 4px}.sidebar-collapsed .sidebar-missed-item{display:none}.sidebar-user{align-items:center;background:var(--color-gray-50);border:1px solid var(--color-gray-100);border-radius:var(--radius-md);cursor:pointer;display:flex;flex-shrink:0;gap:var(--spacing-sm);margin:6px 10px 10px;padding:12px 14px;text-decoration:none;transition:background var(--transition-fast),border-color var(--transition-fast)}.sidebar-user:hover{background:var(--color-gray-100);border-color:var(--color-gray-200)}.sidebar-user-avatar{align-items:center;background:var(--gradient-brand);border-radius:var(--radius-full);color:var(--color-white);display:flex;flex-shrink:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);height:34px;justify-content:center;width:34px}.sidebar-user-info{flex:1;min-width:0;overflow:hidden}.sidebar-user-name{color:var(--color-gray-800);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-account-id{color:var(--color-gray-400);font-size:.7rem;font-weight:var(--font-weight-normal);margin-left:6px}.sidebar-user-role{color:var(--color-gray-400);font-size:.72rem;line-height:1.3}.sidebar-logout{align-items:center;border-radius:var(--radius-md);color:var(--color-gray-400);display:flex;flex-shrink:0;height:32px;justify-content:center;transition:all var(--transition-fast);width:32px}.sidebar-logout:hover{background:var(--color-danger-light);color:var(--color-danger)}.sidebar-logout:active{transform:scale(.9)}.sidebar-logout:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.sidebar-collapsed .app-sidebar{width:var(--sidebar-collapsed-width)}.sidebar-collapsed .app-sidebar:hover{box-shadow:var(--shadow-xl);width:var(--sidebar-width)}.sidebar-collapsed .app-main{margin-left:var(--sidebar-collapsed-width)}.sidebar-collapsed .sidebar-label,.sidebar-collapsed .sidebar-logo-text,.sidebar-collapsed .sidebar-logout,.sidebar-collapsed .sidebar-section-label,.sidebar-collapsed .sidebar-user-info,.sidebar-collapsed .sidebar-user-role{opacity:0;overflow:hidden;transition:opacity var(--transition-fast);width:0}.sidebar-collapsed .app-sidebar:hover .sidebar-label,.sidebar-collapsed .app-sidebar:hover .sidebar-logo-text,.sidebar-collapsed .app-sidebar:hover .sidebar-logout,.sidebar-collapsed .app-sidebar:hover .sidebar-section-label,.sidebar-collapsed .app-sidebar:hover .sidebar-user-info,.sidebar-collapsed .app-sidebar:hover .sidebar-user-role{opacity:1;width:auto}.sidebar-collapsed .sidebar-link{justify-content:center}.sidebar-collapsed .app-sidebar:hover .sidebar-link{justify-content:flex-start}.sidebar-collapsed .sidebar-user{justify-content:center}.sidebar-collapsed .app-sidebar:hover .sidebar-user{justify-content:flex-start}.sidebar-collapsed .sidebar-divider{margin:8px 6px}.sidebar-collapsed .sidebar-link.active:before{display:none}.sidebar-collapsed .app-sidebar:hover .sidebar-link.active:before{display:block}.app-main{background:var(--color-gray-50);display:flex;flex:1;flex-direction:column;margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left var(--transition-normal)}.app-header{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:hsla(0,0%,100%,.85);border-bottom:1px solid var(--color-gray-100);display:flex;gap:var(--spacing-sm);height:var(--header-height);padding:0 var(--spacing-xl);position:sticky;top:0;z-index:var(--z-sticky)}.header-menu-btn{align-items:center;border-radius:var(--radius-md);color:var(--color-gray-600);display:none;flex-shrink:0;height:44px;justify-content:center;transition:background var(--transition-fast);width:44px;-webkit-tap-highlight-color:transparent}.header-menu-btn:hover{background:var(--color-gray-100)}.header-title{color:var(--color-gray-900);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing);white-space:nowrap}.header-search-btn{align-items:center;background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);color:var(--color-gray-400);cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:8px;margin-left:auto;padding:7px 14px;transition:all var(--transition-fast)}.header-search-btn:hover{border-color:var(--color-gray-300);box-shadow:var(--shadow-sm)}.header-search-hint{background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);color:var(--color-gray-400);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:2px 6px}.header-actions{align-items:center;display:flex;gap:6px}.header-branch{position:relative}.header-branch-btn{align-items:center;background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);color:var(--color-gray-700);cursor:pointer;display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:6px;padding:7px 12px;transition:all var(--transition-fast)}.header-branch-btn:hover{border-color:var(--color-gray-300);box-shadow:var(--shadow-sm)}.header-branch-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-branch-arrow{flex-shrink:0}.header-dropdown{animation:dropdown-in .2s cubic-bezier(.34,1.56,.64,1);background:var(--color-white);border:1px solid var(--color-gray-100);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:200px;padding:6px;position:absolute;right:0;top:calc(100% + 6px);z-index:var(--z-dropdown)}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.header-dropdown-header{color:var(--color-gray-800);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing);padding:10px 12px 8px}.header-dropdown-item{background:none;border:none;border-radius:var(--radius-md);color:var(--color-gray-600);cursor:pointer;display:block;font-size:var(--font-size-sm);padding:9px 12px;text-align:left;text-decoration:none;transition:all var(--transition-fast);width:100%}.header-dropdown-item:hover{background:var(--color-gray-50);color:var(--color-gray-800)}.header-dropdown-item:active{background:var(--color-gray-100)}.header-dropdown-item--active{background:var(--color-primary-light);color:var(--color-primary);font-weight:var(--font-weight-medium)}.header-dropdown-item--danger{color:var(--color-danger)}.header-branch-dropdown{min-width:240px}.header-branch-dropdown-title{color:var(--color-gray-400);font-size:11px;font-weight:var(--font-weight-semibold);letter-spacing:.05em;padding:8px 12px 6px;text-transform:uppercase}.header-branch-item{align-items:flex-start!important;display:flex!important;flex-direction:column;gap:2px}.header-branch-item-name{color:var(--color-gray-800);font-weight:var(--font-weight-medium)}.header-branch-item-addr{color:var(--color-gray-400);font-size:11px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-dropdown-item--danger:hover{background:var(--color-danger-light)}.header-dropdown-divider{border:none;border-top:1px solid var(--color-gray-100);margin:4px 0}.header-online-indicator{border-radius:var(--radius-full);flex-shrink:0;height:8px;transition:background var(--transition-fast);width:8px}.header-online-indicator--online{background:var(--color-success);box-shadow:0 0 0 3px rgba(16,185,129,.15)}.header-online-indicator--offline{animation:pulse-offline 2s ease-in-out infinite;background:var(--color-danger);box-shadow:0 0 0 3px rgba(244,63,94,.15)}@keyframes pulse-offline{0%,to{opacity:1}50%{opacity:.4}}.header-notifications{align-items:center;border-radius:var(--radius-md);color:var(--color-gray-400);display:flex;height:44px;justify-content:center;position:relative;transition:all var(--transition-fast);width:44px}.header-notifications:hover{background:var(--color-gray-100);color:var(--color-gray-600)}.header-avatar:focus-visible,.header-branch-btn:focus-visible,.header-menu-btn:focus-visible,.header-notifications:focus-visible,.header-search-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.header-notif-badge{align-items:center;background:var(--color-danger);border:2px solid var(--color-white);border-radius:var(--radius-full);color:var(--color-white);display:flex;font-size:10px;font-weight:var(--font-weight-bold);height:17px;justify-content:center;min-width:17px;padding:0 5px;position:absolute;right:4px;top:4px}.header-profile{position:relative}.header-avatar{align-items:center;background:var(--gradient-brand);border:2px solid transparent;border-radius:var(--radius-full);color:var(--color-white);cursor:pointer;display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);height:34px;justify-content:center;transition:all var(--transition-fast);width:34px}.header-avatar:hover{border-color:rgba(var(--color-primary-rgb),.3);transform:scale(1.05)}.billing-banner{align-items:center;display:flex;font-size:13px;gap:12px;justify-content:space-between;line-height:1.4;padding:8px 20px}.billing-banner--warning{background:var(--color-warning-50,#fffbeb);border-bottom:1px solid var(--color-warning-200,#fde68a);color:var(--color-warning-800,#92400e)}.billing-banner--danger{background:var(--color-danger-50,#fef2f2);border-bottom:1px solid var(--color-danger-200,#fecaca);color:var(--color-danger-800,#991b1b)}.billing-banner__content{align-items:center;display:flex;flex:1;gap:8px;min-width:0}.billing-banner__icon{flex-shrink:0}.billing-banner__text{flex:1;min-width:0}.billing-banner__action{border-radius:var(--radius,6px);flex-shrink:0;font-weight:600;padding:4px 12px;text-decoration:none;transition:background .15s;white-space:nowrap}.billing-banner--warning .billing-banner__action{background:var(--color-warning-200,#fde68a);color:var(--color-warning-900,#78350f)}.billing-banner--warning .billing-banner__action:hover{background:var(--color-warning-300,#fcd34d)}.billing-banner--danger .billing-banner__action{background:var(--color-danger-200,#fecaca);color:var(--color-danger-900,#7f1d1d)}.billing-banner--danger .billing-banner__action:hover{background:var(--color-danger-300,#fca5a5)}.billing-banner__close{background:none;border:none;color:inherit;cursor:pointer;flex-shrink:0;line-height:0;opacity:.5;padding:4px;transition:opacity .15s}.billing-banner__close:hover{opacity:1}@media (max-width:768px){.billing-banner{font-size:12px;padding:8px 12px}.billing-banner__action{font-size:12px;padding:3px 8px}}.app-content{flex:1;max-width:var(--content-max-width);padding:var(--spacing-lg) var(--spacing-xl);width:100%}.app-content--fullpage{align-items:center;background:radial-gradient(ellipse at 20% 50%,rgba(99,102,241,.08) 0,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(139,92,246,.06) 0,transparent 50%),radial-gradient(ellipse at 50% 80%,rgba(236,72,153,.04) 0,transparent 50%),var(--color-gray-50);display:flex;justify-content:center;max-width:none;min-height:100vh;padding:0}.cp-backdrop{backdrop-filter:var(--overlay-blur);-webkit-backdrop-filter:var(--overlay-blur);background:var(--overlay-bg);inset:0;position:fixed;z-index:var(--z-modal-backdrop)}.cp-dialog{animation:cp-in .2s cubic-bezier(.34,1.56,.64,1);background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;left:50%;max-height:60vh;max-width:95vw;overflow:hidden;position:fixed;top:18%;transform:translateX(-50%);width:580px;z-index:var(--z-modal)}@keyframes cp-in{0%{opacity:0;transform:translateX(-50%) scale(.95) translateY(-10px)}to{opacity:1;transform:translateX(-50%) scale(1) translateY(0)}}.cp-search{align-items:center;border-bottom:1px solid var(--color-gray-100);display:flex;gap:var(--spacing-sm);padding:14px 18px}.cp-search-icon{flex-shrink:0}.cp-input{background:transparent;border:none;color:var(--color-gray-900);flex:1;font-size:var(--font-size-md);outline:none}.cp-input::placeholder{color:var(--color-gray-400)}.cp-esc{background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);color:var(--color-gray-400);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:3px 8px}.cp-results{flex:1;padding:6px}.cp-group-title{color:var(--color-gray-400);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:.06em;padding:10px 12px 6px;text-transform:uppercase}.cp-item{align-items:center;border-radius:var(--radius-md);cursor:pointer;display:flex;justify-content:space-between;padding:10px 12px;transition:all var(--transition-fast)}.cp-item--highlighted,.cp-item:hover{background:var(--color-gray-50)}.cp-item-label{color:var(--color-gray-800);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.cp-item-hint{font-size:var(--font-size-xs)}.cp-empty,.cp-item-hint{color:var(--color-gray-400)}.cp-empty{font-size:var(--font-size-sm);padding:var(--spacing-xl)}.app-bottom-nav{display:none;position:relative}.bottom-nav-item{align-items:center;color:var(--color-gray-400);display:flex;flex-direction:column;font-size:11px;font-weight:var(--font-weight-medium);gap:4px;justify-content:center;min-height:48px;min-width:48px;padding:8px 4px;text-decoration:none;transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent}.bottom-nav-item.active,.bottom-nav-item:hover{color:var(--color-primary)}.bottom-nav-icon{align-items:center;display:flex;height:24px;justify-content:center}.bottom-nav-label{font-weight:var(--font-weight-medium)}.bottom-nav-action{position:relative}.bottom-nav-plus{align-items:center;background:var(--gradient-primary);border-radius:var(--radius-full);box-shadow:var(--shadow-primary);color:var(--color-white);display:flex;height:46px;justify-content:center;margin-top:-18px;transition:transform var(--transition-fast);width:46px}.bottom-nav-plus:active{transform:scale(.92)}.bottom-drawer-overlay{backdrop-filter:var(--overlay-blur);-webkit-backdrop-filter:var(--overlay-blur);background:var(--overlay-bg);inset:0;position:fixed;z-index:var(--z-modal-backdrop)}.bottom-drawer{background:var(--color-white);border-radius:var(--radius-xl) var(--radius-xl) 0 0;bottom:var(--bottom-nav-height);box-shadow:var(--shadow-xl);left:0;max-height:70vh;overflow-y:auto;padding-bottom:var(--spacing-md);position:fixed;right:0;z-index:var(--z-modal)}.bottom-drawer-handle{background:var(--color-gray-300);border-radius:var(--radius-full);height:4px;margin:10px auto 6px;width:36px}.bottom-drawer-nav{display:grid;gap:var(--spacing-xs);grid-template-columns:repeat(3,1fr);padding:var(--spacing-xs) var(--spacing-md)}.bottom-drawer-item{align-items:center;border-radius:var(--radius-md);color:var(--color-gray-600);display:flex;flex-direction:column;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);gap:6px;padding:var(--spacing-md) var(--spacing-xs);text-align:center;text-decoration:none;transition:all var(--transition-fast)}.bottom-drawer-item:hover{background:var(--color-gray-50)}.bottom-drawer-item.active{background:var(--color-primary-light);color:var(--color-primary)}.bottom-drawer-icon{align-items:center;display:flex;justify-content:center}.badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:2px 8px}.badge--success{background:var(--badge-success-bg);color:var(--badge-success-text)}.badge--danger{background:var(--badge-danger-bg);color:var(--badge-danger-text)}.badge--warning{background:var(--badge-warning-bg);color:var(--badge-warning-text)}.badge--info{background:var(--badge-info-bg);color:var(--badge-info-text)}.card--hover{transition:box-shadow var(--transition-fast),transform var(--transition-fast)}.card--hover:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.overlay-blur{backdrop-filter:var(--overlay-blur);-webkit-backdrop-filter:var(--overlay-blur);background:var(--overlay-bg)}.btn{align-items:center;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-weight:var(--font-weight-medium);gap:var(--spacing-xs);justify-content:center;letter-spacing:var(--letter-spacing);position:relative;transition:all var(--transition-fast);user-select:none;white-space:nowrap}.btn--xs{font-size:10px;line-height:1;min-width:0;padding:3px 6px}.btn--sm{font-size:var(--font-size-sm);padding:7px 14px}.btn--md{font-size:var(--font-size-md);padding:9px 18px}.btn--lg{font-size:var(--font-size-lg);padding:12px 26px}a.btn{color:inherit}a.btn,a.btn:active,a.btn:hover,a.btn:visited{text-decoration:none}.btn--primary{background:var(--gradient-primary);box-shadow:var(--shadow-primary)}.btn--primary,a.btn--primary,a.btn--primary:active,a.btn--primary:hover,a.btn--primary:visited{color:var(--color-white)}.btn--primary:hover{background:var(--gradient-primary-hover);box-shadow:0 6px 20px rgba(99,102,241,.4);transform:translateY(-1px)}.btn--primary:active{box-shadow:var(--shadow-primary);transform:translateY(0) scale(.97)}.btn--secondary{background:var(--color-white);border-color:var(--color-gray-200);box-shadow:var(--shadow-sm)}.btn--secondary,a.btn--secondary,a.btn--secondary:active,a.btn--secondary:hover,a.btn--secondary:visited{color:var(--color-gray-700)}.btn--secondary:hover{background:var(--color-gray-50);border-color:var(--color-gray-300);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn--secondary:active{background:var(--color-gray-100);box-shadow:var(--shadow-sm);transform:translateY(0) scale(.97)}.btn--danger{background:linear-gradient(135deg,#f43f5e,#e11d48);box-shadow:0 4px 14px rgba(244,63,94,.3);color:var(--color-white)}.btn--danger:hover{box-shadow:0 6px 20px rgba(244,63,94,.4);transform:translateY(-1px)}.btn--danger:active{transform:translateY(0) scale(.97)}.btn--warning{background:linear-gradient(135deg,#f59e0b,#d97706);border:none;color:#fff}.btn--warning:hover{box-shadow:0 6px 20px rgba(245,158,11,.4);transform:translateY(-1px)}.btn--warning:active{transform:translateY(0) scale(.97)}.btn--ghost{background:transparent;color:var(--color-gray-700)}.btn--ghost:hover{background:var(--color-gray-100)}.btn--ghost:active{background:var(--color-gray-200)}.btn--link{background:transparent;border:none;color:var(--color-primary);padding:0}.btn--link:hover{color:var(--color-primary-hover);text-decoration:underline}.btn:focus-visible{box-shadow:var(--shadow-ring),var(--shadow-primary);outline:none}.input:focus-visible{box-shadow:var(--shadow-ring);outline:none}.btn--fullwidth{width:100%}.btn--loading,.btn:disabled{box-shadow:none!important;cursor:not-allowed;opacity:.55;transform:none!important}.btn--loading.btn--fullwidth{min-height:42px}.btn__spinner{animation:spin .6s linear infinite;border:2px solid;border-radius:50%;border-right:2px solid transparent;height:16px;width:16px}.btn__icon{align-items:center;display:flex}@keyframes spin{to{transform:rotate(1turn)}}.form-field{margin-bottom:var(--spacing-md)}.form-label{color:var(--color-gray-700);display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);letter-spacing:var(--letter-spacing);margin-bottom:6px}.form-required{color:var(--color-danger)}.input-wrapper{align-items:center;display:flex;position:relative}.input{background:var(--color-white);border:1.5px solid var(--color-gray-200);border-radius:var(--radius-md);color:var(--color-gray-900);font-size:var(--font-size-md);outline:none;padding:10px 14px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.input:hover:not(:focus):not(:disabled){border-color:var(--color-gray-300)}.input:focus{border-color:var(--color-primary);box-shadow:var(--shadow-ring)}.input::placeholder{color:var(--color-gray-400)}.input:disabled{background:var(--color-gray-50);color:var(--color-gray-500);cursor:not-allowed}.input--textarea{min-height:80px;resize:vertical}.input-wrapper--error .input{animation:inputErrorPulse .3s ease-out;border-color:var(--color-danger)}.input-wrapper--error .input:focus{box-shadow:0 0 0 3px rgba(244,63,94,.12)}@keyframes inputErrorPulse{0%{border-color:var(--color-gray-200)}50%{border-color:var(--color-danger);box-shadow:0 0 0 3px rgba(244,63,94,.15)}to{border-color:var(--color-danger);box-shadow:none}}.form-error{animation:fadeInDown .2s ease-out}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.input-clear{background:none;border:none;border-radius:var(--radius-sm);color:var(--color-gray-400);cursor:pointer;font-size:var(--font-size-lg);line-height:1;padding:2px;position:absolute;right:10px;transition:all var(--transition-fast)}.input-clear:hover{background:var(--color-gray-100);color:var(--color-gray-600)}.form-error,.form-hint{margin-top:var(--spacing-xs)}.form-error{color:var(--color-danger);font-size:var(--font-size-xs)}.form-hint--warning{color:var(--color-warning,#d97706)}.form-hint--warning a{color:var(--color-primary);cursor:pointer;text-decoration:underline}.select{position:relative}.select-trigger{align-items:center;background:var(--color-white);border:1.5px solid var(--color-gray-200);border-radius:var(--radius-md);cursor:pointer;display:flex;flex-wrap:wrap;gap:4px;min-height:42px;outline:none;padding:6px 34px 6px 14px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.select-trigger:hover:not(:focus){border-color:var(--color-gray-300)}.select--open .select-trigger,.select-trigger:focus{border-color:var(--color-primary);box-shadow:var(--shadow-ring)}.select--error .select-trigger{border-color:var(--color-danger)}.select--disabled .select-trigger{background:var(--color-gray-50);cursor:not-allowed}.select-arrow{border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid var(--color-gray-400);height:0;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:transform var(--transition-fast);width:0}.select--open .select-arrow{transform:translateY(-50%) rotate(180deg)}.select-placeholder{color:var(--color-gray-400)}.select-tag{align-items:center;background:var(--color-primary-light);border-radius:var(--radius-full);color:var(--color-primary);display:inline-flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:4px;padding:3px 8px}.select-tag-remove{color:var(--color-primary);cursor:pointer;font-size:14px;line-height:1;opacity:.7;transition:opacity var(--transition-fast)}.select-tag-remove:hover{opacity:1}.select-dropdown{animation:selectDropIn var(--transition-fast) ease-out;background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;left:0;max-height:240px;overflow:hidden;position:absolute;right:0;top:calc(100% + 6px);z-index:var(--z-dropdown)}@keyframes selectDropIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.select-search{border-bottom:1px solid var(--color-gray-100);padding:var(--spacing-sm)}.select-search-input{border:1.5px solid var(--color-gray-200);border-radius:var(--radius-sm);font-size:var(--font-size-sm);outline:none;padding:7px 10px;transition:border-color var(--transition-fast);width:100%}.select-search-input:focus{border-color:var(--color-primary)}.select-options{flex:1;overflow-y:auto;padding:4px}.select-option{border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-sm);margin-bottom:1px;padding:8px 12px;transition:background var(--transition-fast)}.select-option--highlighted,.select-option:hover{background:var(--color-gray-50)}.select-option--selected{background:var(--color-primary-light);color:var(--color-primary);font-weight:var(--font-weight-medium)}.select-option--disabled{color:var(--color-gray-400);cursor:not-allowed}.select-empty{color:var(--color-gray-400);font-size:var(--font-size-sm);padding:16px;text-align:center}.datepicker{position:relative}.datepicker-trigger{cursor:pointer;position:relative}.datepicker-input{cursor:pointer;padding-right:36px}.datepicker-icon{color:var(--color-gray-400);pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.datepicker--error .datepicker-input{border-color:var(--color-danger)}.dp-popup{animation:selectDropIn var(--transition-fast) ease-out;background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);left:0;min-width:290px;padding:var(--spacing-lg);position:absolute;top:calc(100% + 6px);z-index:var(--z-dropdown)}.dp-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-sm)}.dp-title{color:var(--color-gray-800);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.dp-nav{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--color-gray-600);cursor:pointer;display:flex;font-size:var(--font-size-lg);height:30px;justify-content:center;transition:all var(--transition-fast);width:30px}.dp-nav:hover{background:var(--color-gray-100)}.dp-grid{display:grid;gap:2px;grid-template-columns:repeat(7,1fr);text-align:center}.dp-weekday{color:var(--color-gray-400);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:.05em;padding:6px 4px;text-transform:uppercase}.dp-day{align-items:center;border-radius:var(--radius-md);cursor:pointer;display:flex;font-size:var(--font-size-sm);height:36px;justify-content:center;transition:all var(--transition-fast);width:36px}.dp-day:hover:not(.dp-day--empty):not(.dp-day--disabled){background:var(--color-gray-100)}.dp-day--empty{cursor:default}.dp-day--today{background:var(--color-primary-light);color:var(--color-primary);font-weight:var(--font-weight-bold)}.dp-day--selected{background:var(--gradient-primary)!important;box-shadow:0 2px 8px rgba(99,102,241,.3);color:var(--color-white);font-weight:var(--font-weight-medium)}.dp-day--in-range{background:var(--color-primary-light);color:var(--color-primary)}.dp-day--disabled{color:var(--color-gray-300);cursor:not-allowed}.modal-overlay{align-items:center;display:flex;inset:0;justify-content:center;opacity:0;pointer-events:none;position:fixed;transition:opacity var(--transition-normal);z-index:var(--z-modal)}.modal--visible{opacity:1;pointer-events:auto}.modal-backdrop{align-items:center;backdrop-filter:var(--overlay-blur);background:var(--overlay-bg);display:flex;inset:0;justify-content:center;position:absolute}.modal,.modal-container{background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-height:90vh;position:relative;transform:translateY(12px) scale(.97);transition:transform var(--transition-spring);z-index:2}.modal-backdrop .modal{overflow-y:auto;transform:none}.modal--visible .modal-container{transform:translateY(0) scale(1)}.modal--sm{max-width:95vw;width:420px}.modal--md{max-width:95vw;width:560px}.modal--lg{max-width:95vw;width:800px}.modal--fullscreen{border-radius:0;height:100vh;max-height:100vh;width:100vw}.modal-header{align-items:center;border-bottom:1px solid var(--color-gray-100);display:flex;justify-content:space-between;padding:var(--spacing-lg) var(--spacing-xl)}.modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing);margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--color-gray-400);cursor:pointer;display:flex;font-size:22px;height:34px;justify-content:center;transition:all var(--transition-fast);width:34px}.modal-close:hover{background:var(--color-gray-100);color:var(--color-gray-700)}.modal-body{flex:1;overflow-y:auto;padding:var(--spacing-xl)}.modal-footer{align-items:center;background:var(--color-gray-50);border-radius:0 0 var(--radius-xl) var(--radius-xl);border-top:1px solid var(--color-gray-100);justify-content:flex-end;padding:var(--spacing-md) var(--spacing-xl)}.modal-footer,.toast-container{display:flex;gap:var(--spacing-sm)}.toast-container{flex-direction:column;pointer-events:none;position:fixed;right:var(--spacing-lg);top:var(--spacing-lg);z-index:var(--z-toast)}.toast{align-items:center;background:var(--color-white);border-left:4px solid var(--color-gray-400);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);display:flex;gap:var(--spacing-sm);max-width:440px;min-width:300px;padding:14px 18px;pointer-events:auto;transform:translateX(110%);transition:transform var(--transition-spring)}.toast--visible{transform:translateX(0)}.toast--success{background:linear-gradient(135deg,var(--color-white),var(--color-success-light));border-left-color:var(--color-success)}.toast--success .toast-icon{color:var(--color-success)}.toast--error{background:linear-gradient(135deg,var(--color-white),var(--color-danger-light));border-left-color:var(--color-danger)}.toast--error .toast-icon{color:var(--color-danger)}.toast--warning{background:linear-gradient(135deg,var(--color-white),var(--color-warning-light));border-left-color:var(--color-warning)}.toast--warning .toast-icon{color:var(--color-warning)}.toast--info{background:linear-gradient(135deg,var(--color-white),var(--color-info-light));border-left-color:var(--color-info)}.toast--info .toast-icon{color:var(--color-info)}.toast-icon{flex-shrink:0}.toast-message{color:var(--color-gray-800);flex:1;font-size:var(--font-size-sm);line-height:1.5}.toast-close{background:none;border:none;border-radius:var(--radius-sm);color:var(--color-gray-400);cursor:pointer;flex-shrink:0;font-size:18px;line-height:1;padding:2px;transition:all var(--transition-fast)}.toast-close:hover{background:var(--color-gray-100);color:var(--color-gray-600)}.datatable-table{border-collapse:collapse;width:100%}.datatable-cards{display:none}.datatable-th{background:var(--color-gray-50);border-bottom:1.5px solid var(--color-gray-200);color:var(--color-gray-500);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:.04em;padding:12px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}.datatable-th--sortable{cursor:pointer;transition:color var(--transition-fast);user-select:none}.datatable-th--sortable:hover{color:var(--color-gray-800)}.datatable-td{border-bottom:1px solid var(--color-gray-100);color:var(--color-gray-700);font-size:var(--font-size-sm);padding:12px 14px}.datatable-tr--clickable{cursor:pointer;transition:all var(--transition-fast)}.datatable-tr--clickable:hover{background:var(--color-gray-50)}.datatable-tr--clickable:hover .datatable-td:first-child{box-shadow:inset 3px 0 0 var(--color-primary)}.datatable-tr--group{background:var(--color-gray-50)}.datatable-td--group{color:var(--color-gray-600);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);letter-spacing:.03em;padding:6px 12px!important;text-transform:uppercase}.datatable-tr--subgroup{background:var(--color-gray-25,#fafafa)}.datatable-td--subgroup{color:var(--color-gray-500);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:4px 12px 4px 24px!important}.datatable-tr--muted{opacity:.5}.datatable-empty{color:var(--color-gray-400);padding:var(--spacing-2xl);text-align:center}.datatable-card{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);margin-bottom:var(--spacing-sm);padding:var(--spacing-md);transition:all var(--transition-fast)}.datatable-card--clickable{cursor:pointer}.datatable-card--clickable:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.datatable-card-field{display:flex;justify-content:space-between;padding:6px 0}.datatable-card-field+.datatable-card-field{border-top:1px solid var(--color-gray-100)}.datatable-card-label{color:var(--color-gray-500);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.datatable-card-value{color:var(--color-gray-800);font-size:var(--font-size-sm);text-align:right}.skeleton{animation:skeleton-pulse 1.8s ease infinite;background:linear-gradient(90deg,var(--color-gray-100) 25%,var(--color-gray-50) 50%,var(--color-gray-100) 75%);background-size:200% 100%;border-radius:var(--radius-md)}.skeleton--text{height:16px;width:80%}.pagination{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm);justify-content:space-between;padding:var(--spacing-md) 0}.pagination-info{color:var(--color-gray-500);font-size:var(--font-size-sm)}.pagination-controls{align-items:center;display:flex;gap:4px}.pagination-btn{align-items:center;background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);color:var(--color-gray-700);cursor:pointer;display:flex;font-size:var(--font-size-sm);height:34px;justify-content:center;min-width:34px;padding:0 8px;transition:all var(--transition-fast)}.pagination-btn:hover:not(:disabled){background:var(--color-gray-50);border-color:var(--color-gray-300);transform:translateY(-1px)}.pagination-btn:active:not(:disabled){background:var(--color-gray-100);transform:scale(.95)}.pagination-btn--active{background:var(--gradient-primary);border-color:transparent;box-shadow:0 2px 8px rgba(99,102,241,.3);color:var(--color-white)}.pagination-btn--active:hover:not(:disabled){background:var(--gradient-primary-hover)}.pagination-btn:disabled{cursor:not-allowed;opacity:.4}.pagination-ellipsis{color:var(--color-gray-400);padding:0 4px}.tabs--horizontal .tabs-header{border-bottom:2px solid var(--color-gray-100);display:flex;gap:0}.tabs--horizontal .tabs-btn{background:none;border:none;border-bottom:2px solid transparent;color:var(--color-gray-500);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);letter-spacing:var(--letter-spacing);margin-bottom:-2px;padding:10px 18px;transition:all var(--transition-fast)}.tabs--horizontal .tabs-btn:hover{color:var(--color-gray-700)}.tabs--horizontal .tabs-btn:active{background:var(--color-gray-50)}.tabs--horizontal .tabs-btn--active{border-bottom-color:var(--color-primary);color:var(--color-primary);font-weight:var(--font-weight-semibold)}.tabs--vertical{display:flex;gap:var(--spacing-lg)}.tabs--vertical .tabs-header{border-right:2px solid var(--color-gray-100);display:flex;flex-direction:column;min-width:160px}.tabs--vertical .tabs-btn{background:none;border:none;border-radius:var(--radius-sm) 0 0 var(--radius-sm);border-right:2px solid transparent;color:var(--color-gray-500);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-right:-2px;padding:8px 16px;text-align:left;transition:all var(--transition-fast)}.tabs--vertical .tabs-btn:hover{background:var(--color-gray-50);color:var(--color-gray-700)}.tabs--vertical .tabs-btn--active{background:var(--color-primary-light);border-right-color:var(--color-primary);color:var(--color-primary)}.tabs-content{padding:var(--spacing-md) 0}.tabs--vertical .tabs-content{flex:1;padding:0}.page-not-found{align-items:center;color:var(--color-gray-500);display:flex;flex-direction:column;justify-content:center;min-height:50vh;padding:var(--spacing-2xl);text-align:center}.page-not-found-code{background:linear-gradient(135deg,var(--color-gray-200),var(--color-gray-300));-webkit-background-clip:text;font-size:5rem;font-weight:800;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:var(--spacing-sm)}.page-not-found h2{color:var(--color-gray-700);font-size:var(--font-size-xl);margin:0 0 var(--spacing-xs)}.page-not-found p{font-size:var(--font-size-sm);margin:0 0 var(--spacing-lg)}.page-not-found-actions{display:flex;gap:var(--spacing-sm)}.update-banner{align-items:center;background:var(--gradient-primary);border-radius:var(--radius-lg);bottom:24px;box-shadow:0 8px 32px rgba(99,102,241,.35);color:#fff;display:flex;font-size:14px;gap:12px;left:50%;max-width:calc(100vw - 32px);padding:14px 20px;position:fixed;transform:translateX(-50%) translateY(100px);transition:transform var(--transition-spring);z-index:var(--z-toast)}.update-banner.visible{transform:translateX(-50%) translateY(0)}.update-banner__text{white-space:nowrap}.update-banner__btn{background:#fff;border:none;border-radius:8px;color:var(--color-primary,#4f46e5);cursor:pointer;font-size:13px;font-weight:600;padding:6px 16px;transition:opacity .15s;white-space:nowrap}.update-banner__btn:hover{opacity:.9}.update-banner__close{background:none;border:none;color:hsla(0,0%,100%,.7);cursor:pointer;font-size:20px;line-height:1;padding:0 2px;transition:color .15s}.update-banner__close:hover{color:#fff}.update-banner--installed{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 8px 32px rgba(16,185,129,.35)}.debug-console{max-width:100%}.debug-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:var(--spacing-md)}.debug-header-actions{align-items:center;display:flex;gap:var(--spacing-sm)}.debug-live-wrap{align-items:center;display:flex;gap:6px}.debug-live-indicator{background:var(--color-gray-300);border-radius:50%;height:8px;transition:background .3s;width:8px}.debug-live-indicator--active{animation:debug-pulse 2s ease-in-out infinite;background:#22c55e}@keyframes debug-pulse{0%,to{box-shadow:0 0 0 0 rgba(34,197,94,.4);opacity:1}50%{box-shadow:0 0 0 4px rgba(34,197,94,0);opacity:.7}}.debug-auto-refresh{align-items:center;color:var(--color-gray-500);cursor:pointer;display:flex;font-size:var(--font-size-xs);gap:4px;user-select:none}.debug-auto-refresh input{cursor:pointer;height:14px;margin:0;width:14px}.debug-refresh-btn svg{transition:transform .3s}.debug-spin svg{animation:debug-spin-anim .6s linear}@keyframes debug-spin-anim{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.debug-health{align-items:center;background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);display:flex;flex-wrap:wrap;font-size:var(--font-size-xs);gap:12px;margin-bottom:var(--spacing-md);padding:8px 12px}.debug-health-item{align-items:center;color:var(--color-gray-600);display:inline-flex;gap:5px}.debug-health-label{font-weight:var(--font-weight-medium)}.debug-health-detail,.debug-health-refresh{color:var(--color-gray-400)}.debug-health-refresh{background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;margin-left:auto;padding:2px}.debug-health-refresh:hover{color:var(--color-primary)}.debug-health-status{font-size:11px;font-weight:var(--font-weight-semibold);letter-spacing:.3px;text-transform:uppercase}.debug-health-status--ok{color:#22c55e}.debug-health-status--bad{color:#ef4444}.debug-server-info{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.debug-server-tag{background:var(--color-gray-100);border-radius:var(--radius-full);color:var(--color-gray-500);font-family:var(--font-mono,monospace);font-size:11px;padding:2px 8px}.debug-simulator{background:var(--color-gray-50);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:12px;padding:12px}.debug-simulator-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.debug-simulator-title{align-items:center;color:var(--text-secondary);display:flex;font-size:var(--font-size-sm);font-weight:600;gap:6px;white-space:nowrap}.debug-simulator-controls{display:flex;flex-direction:column;gap:8px}.debug-simulator-row{gap:8px}.debug-sim-group,.debug-simulator-row{align-items:center;display:flex;flex-wrap:wrap}.debug-sim-group{gap:6px}.debug-sim-label{color:var(--color-gray-400);font-size:var(--font-size-xs);min-width:120px;white-space:nowrap}.debug-sim-log{border-top:1px solid var(--border-color);margin-top:10px;max-height:180px;overflow-y:auto;padding-top:8px}.debug-sim-log-entry{align-items:baseline;display:flex;font-family:var(--font-mono,monospace);font-size:12px;gap:8px;padding:2px 0}.debug-sim-log-time{color:var(--color-gray-400);flex-shrink:0}.debug-sim-log-cmd{flex-shrink:0;font-weight:600}.debug-sim-log-detail{color:var(--color-gray-500);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.debug-sim-log-entry--incoming .debug-sim-log-cmd{color:#22c55e}.debug-sim-log-entry--error .debug-sim-log-cmd{color:#ef4444}.debug-sim-log-entry--scenario .debug-sim-log-cmd{color:#8b5cf6}.debug-sim-log-empty{color:var(--color-gray-400);font-size:var(--font-size-xs);padding:4px 0}.debug-sim-replay-list{background:var(--color-white);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-top:8px;max-height:200px;overflow-y:auto;padding:4px}.debug-sim-replay-list .debug-sim-log-entry:hover{background:var(--color-gray-50);border-radius:var(--radius-sm)}.debug-toolbar{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.debug-date-input{background:var(--color-bg);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);color:var(--color-text);font-size:var(--font-size-sm);padding:6px 10px;width:150px}.debug-search-wrap{flex:1;position:relative}.debug-search-icon{color:var(--color-gray-400);left:10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.debug-search-input{background:var(--color-bg);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);color:var(--color-text);font-size:var(--font-size-sm);padding:6px 28px 6px 32px;width:100%}.debug-search-input::placeholder{color:var(--color-gray-400)}.debug-search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb,59,130,246),.1);outline:none}.debug-search-clear{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-gray-400);cursor:pointer;display:flex;justify-content:center;padding:2px;position:absolute;right:6px;top:50%;transform:translateY(-50%)}.debug-search-clear:hover{background:var(--color-gray-100);color:var(--color-text)}.debug-files{display:flex;gap:6px;margin-bottom:var(--spacing-md);overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.debug-date-shortcut{align-items:center;background:var(--color-bg);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);color:var(--color-gray-600);cursor:pointer;display:flex;flex-direction:column;font-size:var(--font-size-xs);min-width:60px;padding:6px 12px;transition:border-color .15s,background .15s;white-space:nowrap}.debug-date-shortcut:hover{background:var(--color-gray-50);border-color:var(--color-primary)}.debug-date-shortcut--active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.debug-date-shortcut--active,.debug-file-date{font-weight:var(--font-weight-medium)}.debug-file-size{color:var(--color-gray-400);font-size:10px;margin-top:2px}.debug-date-shortcut--active .debug-file-size{color:var(--color-primary);opacity:.7}.debug-stats{gap:8px;justify-content:space-between;margin-bottom:var(--spacing-md)}.debug-stats,.debug-stats-levels{align-items:center;display:flex;flex-wrap:wrap}.debug-stats-levels{gap:6px}.debug-stats-empty{color:var(--color-gray-400);font-size:var(--font-size-sm);padding:var(--spacing-md);text-align:center}.debug-level-btn{align-items:center;background:var(--color-bg);border:1px solid var(--color-gray-200);border-radius:999px;color:var(--color-gray-600);cursor:pointer;display:inline-flex;font-size:var(--font-size-xs);gap:5px;padding:4px 10px;transition:all .15s}.debug-level-btn:hover{background:var(--color-gray-50);border-color:var(--level-color)}.debug-level-btn--active{background:color-mix(in srgb,var(--level-color) 10%,transparent);border-color:var(--level-color);color:var(--level-color);font-weight:var(--font-weight-medium)}.debug-level-dot{border-radius:50%;flex-shrink:0;height:7px;width:7px}.debug-level-count{font-weight:var(--font-weight-semibold)}.debug-stats-right{align-items:center;display:flex;gap:12px}.debug-sparkline-wrap{align-items:center;display:flex;gap:6px}.debug-sparkline{display:block}.debug-sparkline-label{color:var(--color-gray-400);font-size:10px;white-space:nowrap}.debug-stats-total{color:var(--color-gray-400);font-size:var(--font-size-xs)}.debug-entries-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.debug-expand-all-btn{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:var(--font-size-xs);padding:2px 0}.debug-expand-all-btn:hover{text-decoration:underline}.debug-kbd-hints{color:var(--color-gray-400);display:flex;font-size:11px;gap:10px}.debug-kbd-hints kbd{background:var(--color-gray-100);border:1px solid var(--color-gray-200);border-radius:3px;color:var(--color-gray-500);display:inline-block;font-family:SF Mono,Fira Code,monospace;font-size:10px;padding:1px 5px}.debug-entries{border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);font-family:SF Mono,Fira Code,Cascadia Code,Consolas,monospace;font-size:12px;line-height:1.5;max-height:600px;overflow:hidden;overflow-y:auto;scroll-behavior:smooth}.debug-no-entries{align-items:center;color:var(--color-gray-400);display:flex;flex-direction:column;font-family:var(--font-family);font-size:var(--font-size-sm);gap:8px;padding:var(--spacing-xl) var(--spacing-md);text-align:center}.debug-no-entries p{margin:0}.debug-entry{border-bottom:1px solid var(--color-gray-100)}.debug-entry:last-child{border-bottom:none}.debug-entry-row{align-items:baseline;cursor:pointer;display:flex;gap:8px;padding:4px 12px;transition:background .1s}.debug-entry-row:hover{background:rgba(0,0,0,.025)}.debug-entry-time{color:var(--color-gray-400);flex-shrink:0;width:60px}.debug-entry-level{flex-shrink:0;font-size:11px;font-weight:600;text-transform:uppercase;width:60px}.debug-entry-msg{color:var(--color-text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.debug-entry--expanded .debug-entry-msg{white-space:normal;word-break:break-word}.debug-entry-actions{align-items:center;display:flex;flex-shrink:0;gap:4px;opacity:0;transition:opacity .15s}.debug-entry--expanded .debug-entry-actions,.debug-entry-row:hover .debug-entry-actions{opacity:1}.debug-entry-ctx-indicator{font-size:11px;font-weight:500}.debug-copy-entry{background:none;border:none;border-radius:var(--radius-sm);color:var(--color-gray-400);cursor:pointer;display:flex;padding:2px}.debug-copy-entry:hover{background:var(--color-gray-100);color:var(--color-primary)}.debug-no-context{color:var(--color-gray-400);font-family:var(--font-family);font-size:var(--font-size-xs);font-style:italic}.debug-highlight{background:rgba(245,158,11,.25);border-radius:2px;color:inherit;padding:0 1px}.debug-entry-context{padding:0 12px 8px}.debug-context-header{align-items:center;font-family:var(--font-family);font-size:var(--font-size-xs);justify-content:space-between;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.debug-context-header,.debug-copy-ctx{color:var(--color-gray-400);display:flex}.debug-copy-ctx{background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;padding:2px}.debug-copy-ctx:hover{background:var(--color-gray-100);color:var(--color-primary)}.debug-context-json{background:var(--color-gray-50);border:1px solid var(--color-gray-100);border-radius:var(--radius-md);color:var(--color-text);font-size:11px;line-height:1.6;margin:0;max-height:300px;overflow-x:auto;overflow-y:auto;padding:10px 12px;white-space:pre-wrap;word-break:break-word}.debug-json-key{color:#8b5cf6}.debug-json-string{color:#22863a}.debug-json-number{color:#005cc5}.debug-json-bool{color:#d73a49}.debug-pagination{align-items:center;display:flex;gap:var(--spacing-sm);justify-content:center;margin-top:var(--spacing-md)}.debug-pagination-info{color:var(--color-gray-500);font-size:var(--font-size-xs);min-width:100px;text-align:center}.debug-pagination-page{color:var(--color-gray-400)}@media (max-width:767px){.debug-toolbar{flex-direction:column}.debug-date-input{width:100%}.debug-health{font-size:11px;gap:8px}.debug-entries{font-size:11px;max-height:400px}.debug-entry-time{font-size:10px;width:52px}.debug-entry-level{font-size:10px;width:48px}.debug-entry-actions{opacity:1}.debug-kbd-hints{display:none}.debug-stats{align-items:flex-start;flex-direction:column}.debug-stats-right{justify-content:space-between;width:100%}}@media (max-width:1024px){.app-sidebar{width:var(--sidebar-collapsed-width)}.app-sidebar:hover{box-shadow:var(--shadow-xl);width:var(--sidebar-width)}.app-main{margin-left:var(--sidebar-collapsed-width)}.sidebar-label,.sidebar-logo-text,.sidebar-logout,.sidebar-section-label,.sidebar-user-info,.sidebar-user-role{opacity:0;overflow:hidden;transition:opacity var(--transition-fast);width:0}.app-sidebar:hover .sidebar-label,.app-sidebar:hover .sidebar-logo-text,.app-sidebar:hover .sidebar-logout,.app-sidebar:hover .sidebar-section-label,.app-sidebar:hover .sidebar-user-info,.app-sidebar:hover .sidebar-user-role{opacity:1;width:auto}.sidebar-link{justify-content:center}.app-sidebar:hover .sidebar-link{justify-content:flex-start}.sidebar-user{justify-content:center}.app-sidebar:hover .sidebar-user{justify-content:flex-start}.sidebar-divider{margin:8px 6px}.sidebar-link.active:before{display:none}.app-sidebar:hover .sidebar-link.active:before{display:block}.header-search-hint{display:none}.header-branch-name{max-width:80px}.sidebar-collapsed .app-sidebar,body:not(.sidebar-collapsed) .app-sidebar{width:var(--sidebar-collapsed-width)}.sidebar-collapsed .app-sidebar:hover,body:not(.sidebar-collapsed) .app-sidebar:hover{box-shadow:var(--shadow-xl);width:var(--sidebar-width)}.sidebar-collapsed .app-main,body:not(.sidebar-collapsed) .app-main{margin-left:var(--sidebar-collapsed-width)}}@media (max-width:767px){.app-sidebar{transform:translateX(-100%);z-index:var(--z-modal)}.app-sidebar,.app-sidebar:hover{box-shadow:none;width:var(--sidebar-width)}.app-sidebar .sidebar-label,.app-sidebar .sidebar-logo-text,.app-sidebar .sidebar-logout,.app-sidebar .sidebar-section-label,.app-sidebar .sidebar-user-info,.app-sidebar .sidebar-user-role{opacity:1;width:auto}.app-sidebar .sidebar-link{justify-content:flex-start}.app-sidebar .sidebar-link.active:before{display:block}.app-sidebar .sidebar-user{justify-content:flex-start}.sidebar-pin-link{display:none}.app-sidebar.is-open{box-shadow:var(--shadow-xl);transform:translateX(0)}.header-menu-btn{display:flex}.header-search-btn{background:none;border:none;min-height:44px;min-width:44px;padding:8px}.header-branch,.header-search-hint{display:none}.app-main{margin-left:0;padding-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom))}.sidebar-collapsed .app-sidebar,body:not(.sidebar-collapsed) .app-sidebar{width:var(--sidebar-width)}.sidebar-collapsed .app-main,body:not(.sidebar-collapsed) .app-main{margin-left:0}.app-content{padding:var(--spacing-md)}.app-bottom-nav{align-items:center;background:var(--color-white);border-top:1px solid var(--color-gray-200);bottom:0;box-shadow:0 -4px 12px rgba(15,23,42,.04);display:flex;height:calc(var(--bottom-nav-height) + var(--safe-area-bottom));justify-content:space-around;left:0;padding-bottom:var(--safe-area-bottom);position:fixed;right:0;z-index:var(--z-sticky)}.cp-dialog{border-radius:0;bottom:0;left:0;max-height:100%;max-width:100%;right:0;top:0;transform:none;width:100%}h1{font-size:var(--font-size-2xl)}h2{font-size:var(--font-size-xl)}h3{font-size:var(--font-size-lg)}.btn--sm{min-height:40px;padding:9px 14px}.btn--md{min-height:44px;padding:11px 18px}.btn--lg{min-height:48px;padding:13px 26px}.btn--icon-only{min-height:44px;min-width:44px}.input{font-size:16px;padding:12px 14px}.input.auth-input--with-icon{padding-left:38px}.input--sm{padding:10px 12px}.input--sm,select.input{font-size:16px}.form-field{min-width:0!important}.modal--lg,.modal--md,.modal--sm{border-radius:0;height:100dvh;max-height:100dvh;max-width:100vw;width:100vw}.modal-header{padding:var(--spacing-md) var(--spacing-md);top:0}.modal-footer,.modal-header{background:var(--color-white);position:sticky;z-index:1}.modal-footer{border-radius:0;bottom:0;padding-bottom:calc(var(--spacing-md) + var(--safe-area-bottom))}.modal-body{padding:var(--spacing-md)}.dp-popup{animation:none;border-radius:0;display:flex;flex-direction:column;inset:0;justify-content:center;max-height:none;min-width:auto;position:fixed;z-index:var(--z-modal)}.datatable-table{display:none}.datatable-cards{display:block}.pagination{align-items:stretch;flex-direction:column;gap:var(--spacing-sm);text-align:center}.pagination-controls{justify-content:center}.pagination-btn{height:40px;min-width:40px;padding:0 10px}.toast-container{bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom) + var(--spacing-sm));left:var(--spacing-sm);right:var(--spacing-sm);top:auto}.toast{min-width:auto}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.tabs-btn{padding:10px 14px;white-space:nowrap}.tabs--vertical{flex-direction:column}.tabs--vertical .tabs{border-bottom:1px solid var(--color-gray-200);border-right:none;flex-direction:row;overflow-x:auto}.tabs--vertical .tabs-btn{border-bottom:2px solid transparent;border-right:none}.tabs--vertical .tabs-btn--active{border-bottom-color:var(--color-primary);border-right-color:transparent}.bottom-drawer{bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom))}.table-scroll-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 calc(var(--spacing-md)*-1);padding:0 var(--spacing-md)}.visit-mobile-footer{padding-bottom:calc(var(--spacing-sm) + var(--safe-area-bottom))}}@media (max-width:374px){:root{--spacing-md:0.75rem;--spacing-lg:1rem}.app-content{padding:var(--spacing-sm)}.btn--sm{font-size:var(--font-size-xs);padding:8px 10px}.btn--md{padding:10px 14px}.bottom-nav-item{font-size:10px;min-width:40px}.modal-body,.modal-header{padding:var(--spacing-sm)}}.analytics-controls{margin-bottom:var(--spacing-md)}.analytics-period{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.analytics-tabs{border-bottom:2px solid var(--color-border);display:flex;gap:2px;margin-bottom:var(--spacing-lg)}.analytics-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--color-text-secondary);cursor:pointer;font-size:.875rem;font-weight:500;margin-bottom:-2px;padding:var(--spacing-sm) var(--spacing-md);transition:color .15s,border-color .15s}.analytics-tab:hover{color:var(--color-text)}.analytics-tab--active{border-bottom-color:var(--color-primary,#3b82f6);color:var(--color-primary,#3b82f6)}.analytics-summary{display:grid;gap:var(--spacing-sm);grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin-bottom:var(--spacing-lg)}.analytics-content{min-height:200px}.analytics-bar-inline{background:var(--color-border-light,#e2e8f0);border-radius:3px;display:inline-block;height:6px;margin-right:6px;overflow:hidden;vertical-align:middle;width:60px}.analytics-bar-fill{background:var(--color-primary,#3b82f6);border-radius:3px;height:100%}.analytics-retention-info{background:var(--color-bg-secondary,#f8fafc);border-radius:var(--radius-md,8px);color:var(--color-text-secondary);font-size:.8125rem;margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md)}@media (max-width:768px){.analytics-period{align-items:stretch;flex-direction:column}.analytics-tabs{overflow-x:auto}.analytics-summary{grid-template-columns:repeat(2,1fr)}}.auth-page{align-items:center;display:flex;flex:1;justify-content:center;padding:var(--spacing-lg);width:100%}@keyframes authCardIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes authShake{0%,to{transform:translateX(0)}15%,45%,75%{transform:translateX(-6px)}30%,60%,90%{transform:translateX(6px)}}.auth-card{animation:authCardIn .4s ease-out;background:var(--color-white);border:1px solid rgba(99,102,241,.08);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:420px;padding:40px;width:100%}.auth-card--wide{max-width:540px}.auth-card--shake{animation:authShake .5s ease-in-out}.auth-logo{align-items:center;display:flex;gap:var(--spacing-sm);justify-content:center;margin-bottom:var(--spacing-xl)}.auth-logo-text{background:var(--gradient-brand);-webkit-background-clip:text;font-size:var(--font-size-xl);-webkit-text-fill-color:transparent;background-clip:text}.auth-logo-text,.auth-title{font-weight:var(--font-weight-bold)}.auth-title{color:var(--color-gray-900);font-size:var(--font-size-2xl);letter-spacing:var(--letter-spacing);margin-bottom:var(--spacing-xs);text-align:center}.auth-subtitle{color:var(--color-gray-500);font-size:var(--font-size-sm);line-height:1.6;margin-bottom:var(--spacing-xl);text-align:center}.auth-success-icon{justify-content:center}.auth-alert,.auth-success-icon{display:flex;margin-bottom:var(--spacing-md)}.auth-alert{align-items:center;border-radius:var(--radius-md);font-size:var(--font-size-sm);gap:10px;line-height:1.5;padding:12px 16px}.auth-alert--error{background:var(--color-danger-light);border:1px solid rgba(244,63,94,.15);color:var(--color-danger)}.auth-alert svg{flex-shrink:0}.auth-form{display:flex;flex-direction:column}.auth-form-row{display:grid;gap:0 var(--spacing-md);grid-template-columns:1fr 1fr}.auth-input-icon{color:var(--color-gray-400);display:flex;left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);transition:color var(--transition-fast)}.input-wrapper:focus-within .auth-input-icon{color:var(--color-primary)}.input-wrapper--error .auth-input-icon{color:var(--color-danger)}.auth-input--with-icon{padding-left:38px}.auth-password-input{padding-right:40px}.auth-password-toggle{align-items:center;border-radius:var(--radius-md);color:var(--color-gray-400);cursor:pointer;display:flex;height:30px;justify-content:center;position:absolute;right:8px;top:50%;transform:translateY(-50%);transition:all var(--transition-fast);width:30px}.auth-password-toggle:hover{background:var(--color-gray-100);color:var(--color-gray-600)}.auth-actions-row{align-items:center;display:flex;gap:var(--spacing-md);justify-content:space-between;margin-bottom:var(--spacing-md)}.auth-link{color:var(--color-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-decoration:none;transition:color var(--transition-fast)}.auth-link:hover{color:var(--color-primary-hover);text-decoration:underline}.auth-footer{border-top:1px solid var(--color-gray-100);margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);text-align:center}.auth-consent,.auth-footer{color:var(--color-gray-500);font-size:var(--font-size-sm)}.auth-consent{align-items:flex-start;cursor:pointer;display:flex;gap:10px;line-height:1.5;user-select:none}.auth-consent input[type=checkbox]{accent-color:var(--color-primary);cursor:pointer;flex-shrink:0;height:18px;margin-top:2px;width:18px}.auth-consent a{color:var(--color-primary);text-decoration:underline;text-underline-offset:2px}.auth-consent a:hover{opacity:.8}.auth-consent--error{color:var(--color-danger)}.auth-consent--error input[type=checkbox]{border-radius:3px;outline:2px solid var(--color-danger);outline-offset:1px}.auth-legal-links{align-items:center;display:flex;font-size:var(--font-size-xs);gap:8px;justify-content:center;margin-top:var(--spacing-md);padding-top:var(--spacing-sm)}.auth-legal-links a{color:var(--color-gray-400);text-decoration:none;transition:color .15s}.auth-legal-links a:hover{color:var(--color-primary)}.auth-legal-sep{color:var(--color-gray-300);font-size:10px}.auth-pw-strength{display:flex;gap:4px;margin-top:6px}.auth-pw-bar{background:var(--color-gray-200);border-radius:2px;flex:1;height:3px;transition:background var(--transition-fast)}.auth-pw-bar--active.auth-pw--weak{background:var(--color-danger)}.auth-pw-bar--active.auth-pw--medium{background:var(--color-warning)}.auth-pw-bar--active.auth-pw--strong{background:var(--color-success)}.auth-pw-hint{color:var(--color-gray-400);font-size:var(--font-size-xs);margin-top:4px}.auth-pw-hint--weak{color:var(--color-danger)}.auth-pw-hint--medium{color:var(--color-warning)}.auth-pw-hint--strong{color:var(--color-success)}@keyframes authFieldSlideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.auth-steps{gap:0;justify-content:center;margin-bottom:var(--spacing-xl)}.auth-step,.auth-steps{align-items:center;display:flex}.auth-step{color:var(--color-text-tertiary);font-size:13px;font-weight:500;gap:var(--spacing-xs);transition:color .25s}.auth-step--active{color:var(--color-primary)}.auth-step--done{color:var(--color-success)}.auth-step-num{align-items:center;background:var(--color-bg);border:2px solid var(--color-border);border-radius:50%;display:flex;flex-shrink:0;font-size:13px;font-weight:600;height:28px;justify-content:center;transition:all .25s;width:28px}.auth-step--active .auth-step-num{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.auth-step--done .auth-step-num{background:var(--color-success);border-color:var(--color-success);color:#fff}.auth-step-label{white-space:nowrap}.auth-step-line{background:var(--color-border);border-radius:1px;height:2px;margin:0 var(--spacing-sm);transition:background .25s;width:40px}.auth-step-line--done{background:var(--color-success)}.auth-remember{align-items:center;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:13px;gap:var(--spacing-xs);user-select:none}.auth-remember input[type=checkbox]{accent-color:var(--color-primary);cursor:pointer;height:16px;width:16px}.auth-btn-row{display:flex;gap:var(--spacing-sm)}.auth-btn-row .btn{flex:1}.auth-btn-row .btn--outline{flex:0 0 auto}.auth-step-content{animation:authStepSlideRight .3s ease-out}.auth-step-content--slide-left{animation:authStepSlideLeft .3s ease-out}@keyframes authStepSlideRight{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes authStepSlideLeft{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.auth-resend-row{color:var(--color-text-tertiary);font-size:13px;margin-top:var(--spacing-md);text-align:center}.auth-resend-btn{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:13px;font-weight:500;padding:0;text-decoration:underline;text-underline-offset:2px}.auth-resend-btn:hover{color:var(--color-primary-dark)}.auth-resend-btn:disabled{color:var(--color-text-tertiary);cursor:default;text-decoration:none}@media (max-width:520px){.auth-card{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--spacing-xl) var(--spacing-lg)}.auth-card--wide{max-width:100%}.auth-form-row{grid-template-columns:1fr}.auth-step-label{display:none}.auth-step-line{width:32px}.auth-title{font-size:var(--font-size-xl)}.auth-btn-row{flex-direction:column-reverse}.auth-btn-row .btn{width:100%}}@media (max-width:400px){.auth-card{border-radius:var(--radius-md);padding:var(--spacing-lg) var(--spacing-md)}}@media (prefers-color-scheme:dark){.app-content--fullpage{background:radial-gradient(ellipse at 20% 50%,rgba(99,102,241,.12) 0,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(139,92,246,.08) 0,transparent 50%),radial-gradient(ellipse at 50% 80%,rgba(236,72,153,.05) 0,transparent 50%),var(--color-gray-900)}.auth-card{background:var(--color-gray-800);border-color:rgba(99,102,241,.15);box-shadow:0 8px 32px rgba(0,0,0,.3)}.auth-title{color:var(--color-gray-100)}.auth-footer,.auth-subtitle{color:var(--color-gray-400)}.auth-footer{border-top-color:var(--color-gray-700)}.auth-alert--error{background:rgba(244,63,94,.1);border-color:rgba(244,63,94,.2)}.auth-page .input{background:var(--color-gray-700);border-color:var(--color-gray-600);color:var(--color-gray-100)}.auth-page .input::placeholder{color:var(--color-gray-500)}.auth-page .input:focus{background:var(--color-gray-700);border-color:var(--color-primary)}.auth-page .input:hover:not(:focus):not(:disabled){border-color:var(--color-gray-500)}.auth-page .form-label{color:var(--color-gray-300)}.auth-input-icon{color:var(--color-gray-500)}.input-wrapper:focus-within .auth-input-icon{color:var(--color-primary-100)}.auth-password-toggle{color:var(--color-gray-500)}.auth-password-toggle:hover{background:var(--color-gray-600);color:var(--color-gray-300)}.auth-remember{color:var(--color-gray-400)}.auth-step{color:var(--color-gray-500)}.auth-step-num{background:var(--color-gray-700);border-color:var(--color-gray-600)}.auth-pw-bar,.auth-step-line{background:var(--color-gray-600)}}.cal-page{display:flex;flex-direction:column;height:calc(100vh - var(--header-height) - var(--spacing-lg)*2)}.cal-toolbar{flex-shrink:0;gap:var(--spacing-md);justify-content:space-between;padding-bottom:var(--spacing-md)}.cal-toolbar,.cal-toolbar-left{align-items:center;display:flex;flex-wrap:wrap}.cal-toolbar-left,.cal-toolbar-right{gap:var(--spacing-sm)}.cal-toolbar-right{align-items:center;display:flex;flex-wrap:wrap}.cal-view-switch{background:var(--color-gray-50);border:1.5px solid var(--color-gray-200);border-radius:var(--radius-md);display:flex;gap:2px;overflow:hidden;padding:2px}.cal-view-btn{background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-gray-600);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:6px 14px;transition:all var(--transition-fast)}.cal-view-btn+.cal-view-btn{border-left:none}.cal-view-btn:hover{background:var(--color-white);color:var(--color-gray-800)}.cal-view-btn--active{box-shadow:var(--shadow-sm);color:var(--color-primary)}.cal-view-btn--active,.cal-view-btn--active:hover{background:var(--color-white)}.cal-nav{gap:4px}.cal-nav,.cal-nav-btn{align-items:center;display:flex}.cal-nav-btn{background:var(--color-white);border:1.5px solid var(--color-gray-200);border-radius:var(--radius-md);color:var(--color-gray-600);cursor:pointer;font-size:var(--font-size-lg);height:34px;justify-content:center;transition:all var(--transition-fast);width:34px}.cal-nav-btn:hover{background:var(--color-gray-50);border-color:var(--color-gray-300)}.cal-nav-today{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:0 10px;width:auto}.cal-nav-today--active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.cal-date-display{color:var(--color-gray-800);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);white-space:nowrap}.cal-staff-filter{display:flex;flex-wrap:wrap;gap:4px}.cal-staff-chip{align-items:center;background:var(--color-white);border:1px solid var(--color-gray-300);border-radius:var(--radius-full);color:var(--color-gray-500);cursor:pointer;display:flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);gap:4px;padding:4px 10px;transition:all var(--transition-fast);white-space:nowrap}.cal-staff-chip--active{border-color:currentColor}.cal-staff-chip--show-all{border-style:dashed;color:var(--color-gray-500);cursor:pointer;font-size:.75rem}.cal-staff-chip--show-all:hover{border-color:var(--color-primary);color:var(--color-primary)}.cal-staff-chip-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.cal-loading{align-items:center;color:var(--color-gray-500);display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm);justify-content:center;padding:var(--spacing-lg)}.cal-viewport{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex:1;overflow:hidden}.cal-grid{display:flex;flex-direction:column;height:100%;position:relative}.cal-header-row{border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0}.cal-time-header{border-right:1px solid var(--border-color);flex-shrink:0;width:56px}.cal-staff-header{align-items:center;border-right:1px solid var(--color-gray-100);display:flex;flex:1;gap:var(--spacing-xs);min-width:120px;padding:8px 12px}.cal-staff-avatar{align-items:center;border-radius:50%;color:var(--color-white);display:flex;flex-shrink:0;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);height:28px;justify-content:center;width:28px}.cal-staff-name{color:var(--color-gray-800);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-body{display:flex;flex:1;min-height:0;overflow-x:auto;overflow-y:auto;position:relative}.cal-time-col{border-right:1px solid var(--border-color);flex-shrink:0;width:56px}.cal-time-cell{border-bottom:1px solid var(--color-gray-100);position:relative}.cal-time-label{background:var(--color-white);color:var(--color-gray-400);font-size:10px;padding:0 2px;position:absolute;right:6px;top:-8px}.cal-column{border-right:1px solid var(--color-gray-100);flex:1;min-width:120px;position:relative}.cal-slot{border-bottom:1px solid var(--color-gray-100);cursor:pointer;transition:background var(--transition-fast)}.cal-slot:hover{background:var(--color-primary-light)}.cal-slot--off{cursor:default;pointer-events:none}.cal-slot--off,.cal-slot--off:hover{background:var(--color-gray-50);background-image:repeating-linear-gradient(45deg,transparent,transparent 4px,var(--color-gray-100) 4px,var(--color-gray-100) 5px)}.cal-appointments{left:0;pointer-events:none;position:absolute;right:0;top:0}.cal-appointment{border-left:3px solid rgba(0,0,0,.15);border-radius:var(--radius-sm);cursor:grab;font-size:11px;left:2px;line-height:1.3;overflow:hidden;padding:3px 6px;pointer-events:auto;position:absolute;right:2px;transition:all var(--transition-fast)}.cal-appointment:hover{box-shadow:var(--shadow-md);transform:scale(1.02);z-index:2}.cal-appointment--dragging{box-shadow:var(--shadow-lg);cursor:grabbing;opacity:.8;z-index:10}.cal-appt-time{font-weight:var(--font-weight-semibold);white-space:nowrap}.cal-appt-client{font-weight:var(--font-weight-medium)}.cal-appt-client,.cal-appt-service{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-appt-service{color:var(--color-gray-500)}.cal-appt-status{font-size:10px;font-weight:var(--font-weight-semibold)}.cal-appt-resize-handle{bottom:0;cursor:ns-resize;height:8px;left:0;pointer-events:auto;position:absolute;right:0}.cal-appt-resize-handle:after{background:rgba(0,0,0,.15);border-radius:2px;bottom:2px;content:"";height:3px;left:50%;opacity:0;position:absolute;transform:translateX(-50%);transition:opacity .15s;width:20px}.cal-appointment:hover .cal-appt-resize-handle:after{opacity:1}.cal-now-line{height:2px;left:0;pointer-events:none;right:0;z-index:5}.cal-now-line,.cal-now-line:before{background:var(--color-danger);position:absolute}.cal-now-line:before{border-radius:50%;content:"";height:8px;left:-4px;top:-3px;width:8px}.cal-week .cal-header-row{min-height:44px}.cal-week-header{align-items:center;border-right:1px solid var(--color-gray-100);cursor:pointer;display:flex;flex:1;flex-direction:column;justify-content:center;padding:4px;transition:background var(--transition-fast)}.cal-week-header:hover{background:var(--color-gray-50)}.cal-week-header--today .cal-week-date{align-items:center;background:var(--color-primary);border-radius:50%;color:var(--color-white);display:flex;height:24px;justify-content:center;width:24px}.cal-week-day{color:var(--color-gray-400);font-size:10px;text-transform:uppercase}.cal-week-date,.cal-week-day{font-weight:var(--font-weight-semibold)}.cal-week-date{color:var(--color-gray-800);font-size:var(--font-size-sm)}.cal-week-column{border-right:1px solid var(--color-gray-100);flex:1;min-width:80px;position:relative}.cal-week-column--today{background:var(--color-primary-light)}.cal-week-appt,.cal-week-appt .cal-appt-time{font-size:10px}.cal-month{height:100%}.cal-month-grid{display:flex;flex-direction:column;height:100%}.cal-month-header{border-bottom:1px solid var(--border-color);display:grid;grid-template-columns:repeat(7,1fr)}.cal-month-weekday{color:var(--color-gray-500);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:8px;text-align:center;text-transform:uppercase}.cal-month-body{display:grid;flex:1;grid-template-columns:repeat(7,1fr)}.cal-month-cell{border-bottom:1px solid var(--color-gray-100);border-right:1px solid var(--color-gray-100);cursor:pointer;min-height:80px;overflow:hidden;padding:4px;transition:background var(--transition-fast)}.cal-month-cell--empty,.cal-month-cell:hover{background:var(--color-gray-50)}.cal-month-cell--empty{cursor:default}.cal-month-cell--today .cal-month-day-num{align-items:center;background:var(--color-primary);border-radius:50%;color:var(--color-white);display:inline-flex;height:24px;justify-content:center;width:24px}.cal-month-day-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2px}.cal-month-day-num{color:var(--color-gray-700);font-size:var(--font-size-sm)}.cal-month-count,.cal-month-day-num{font-weight:var(--font-weight-medium)}.cal-month-count{background:var(--color-gray-200);border-radius:var(--radius-full);color:var(--color-gray-600);font-size:10px;padding:0 5px}.cal-month-appt{align-items:center;cursor:pointer;display:flex;font-size:11px;gap:4px;padding:1px 0}.cal-month-appt:hover{background:var(--color-gray-100);border-radius:2px}.cal-month-appt-dot{border-radius:50%;flex-shrink:0;height:6px;width:6px}.cal-month-appt-time{color:var(--color-gray-500);flex-shrink:0}.cal-month-appt-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-month-more{color:var(--color-primary);cursor:pointer;font-size:10px;font-weight:var(--font-weight-medium);padding:1px 0}.cal-mobile-nav{align-items:center;background:var(--color-gray-50);border-bottom:1px solid var(--border-color);display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);justify-content:space-between;padding:var(--spacing-xs) var(--spacing-sm)}.cal-mobile-next,.cal-mobile-prev{align-items:center;background:var(--color-white);border:1px solid var(--color-gray-300);border-radius:var(--radius-sm);cursor:pointer;display:flex;font-size:var(--font-size-lg);height:28px;justify-content:center;width:28px}.cal-day-summary{align-items:center;color:var(--color-gray-500);display:flex;flex-wrap:wrap;font-size:var(--font-size-xs);gap:var(--spacing-md);margin-bottom:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm)}.cal-day-summary-item{align-items:center;display:flex;gap:4px}.cal-day-summary-num{color:var(--color-gray-700);font-weight:var(--font-weight-semibold)}.cal-day-summary-staff{align-items:center;display:flex;font-weight:var(--font-weight-medium);gap:4px}.cal-day-summary-dot{border-radius:50%;height:6px;width:6px}.cal-staff-count{background:var(--color-gray-100);border-radius:var(--radius-full);color:var(--color-gray-500);font-size:10px;font-weight:var(--font-weight-medium);margin-left:auto;padding:1px 6px}.cal-appt-top-row{align-items:center;display:flex;gap:4px;justify-content:space-between}.cal-appt-status-icon{flex-shrink:0;font-size:11px}.cal-appt-price{color:var(--color-gray-600);font-size:10px;font-weight:var(--font-weight-semibold)}.cal-appointment--cancelled{opacity:.5}.cal-appointment--cancelled,.cal-appointment--cancelled .cal-appt-client{text-decoration:line-through}.cal-week-count{align-items:center;background:var(--color-primary);border-radius:var(--radius-full);color:#fff;display:inline-flex;font-size:9px;font-weight:var(--font-weight-semibold);height:16px;justify-content:center;min-width:16px;padding:0 4px}.cal-month-revenue{color:var(--color-gray-400);font-size:9px;font-weight:var(--font-weight-medium);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-context-menu{animation:calCtxIn .1s ease;background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:160px;padding:4px;position:fixed;z-index:1000}@keyframes calCtxIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.cal-context-item{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-gray-700);cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:8px;padding:8px 12px;text-align:left;transition:background var(--transition-fast);width:100%}.cal-context-item:hover{background:var(--color-gray-50)}.cal-context-icon{text-align:center;width:16px}.cal-list{flex-direction:column;height:100%}.cal-list,.cal-list-toolbar{display:flex;gap:var(--spacing-sm)}.cal-list-toolbar{align-items:center;flex-wrap:wrap;padding:var(--spacing-sm) 0}.cal-list-search{flex:1;min-width:180px;position:relative}.cal-list-search svg{color:var(--color-gray-400);left:10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.cal-list-search-input{padding-left:32px!important;width:100%}.cal-list-filter{min-width:140px}.cal-list-stats{color:var(--color-gray-500);display:flex;font-size:var(--font-size-sm);gap:8px;margin-left:auto;white-space:nowrap}.cal-list-stat-rev{color:var(--color-primary);font-weight:600}.cal-list-table-wrap{flex:1;overflow-x:auto}.cal-list-table{border-collapse:collapse;width:100%}.cal-list-th{border-bottom:1px solid var(--color-gray-200);color:var(--color-gray-500);font-size:var(--font-size-sm);font-weight:500;padding:8px 12px;text-align:left;user-select:none;white-space:nowrap}.cal-list-th--sortable{cursor:pointer}.cal-list-th--sortable:hover{color:var(--color-gray-700)}.cal-list-th--active{color:var(--color-primary)}.cal-list-row{cursor:pointer;transition:background var(--transition-fast)}.cal-list-row:hover{background:var(--color-gray-50)}.cal-list-row--cancelled{opacity:.5}.cal-list-td{border-bottom:1px solid var(--color-gray-100);font-size:var(--font-size-sm);padding:10px 12px;vertical-align:middle}.cal-list-td--time{white-space:nowrap}.cal-list-time{color:var(--color-gray-500);font-size:11px}.cal-list-client{font-weight:500}.cal-list-phone{color:var(--color-gray-500);font-size:11px}.cal-list-staff-dot{border-radius:50%;display:inline-block;height:8px;margin-right:4px;vertical-align:middle;width:8px}.cal-list-td--price{font-weight:500;white-space:nowrap}.cal-list-td--dur{color:var(--color-gray-500);white-space:nowrap}.cal-list-status{border-radius:10px;display:inline-block;font-size:11px;font-weight:500;padding:2px 8px;white-space:nowrap}.cal-list-empty{color:var(--color-gray-400);padding:40px;text-align:center}.cal-list-date-range{align-items:center;display:flex;gap:4px}.cal-list-date{width:130px}.cal-list-date-sep{color:var(--color-gray-400)}.cal-staff-link{color:inherit;cursor:pointer;text-decoration:none}.cal-staff-link:hover{color:var(--color-primary);text-decoration:underline}@media (max-width:768px){.cal-list-toolbar{align-items:stretch;flex-direction:column}.cal-list-filter{width:100%}.cal-list-stats{justify-content:center}}.appt-stepper{gap:0;justify-content:center;margin-bottom:var(--spacing-md);padding:var(--spacing-sm) 0}.appt-step,.appt-stepper{align-items:center;display:flex}.appt-step{flex-direction:column;flex-shrink:0;gap:4px}.appt-step-dot{background:var(--color-white);border:2px solid var(--color-gray-300);border-radius:50%;height:12px;transition:all .2s;width:12px}.appt-step--active .appt-step-dot,.appt-step--done .appt-step-dot{border-color:currentColor}.appt-step--active .appt-step-dot{box-shadow:0 0 0 3px rgba(59,130,246,.2)}.appt-step-label{color:var(--color-gray-400);font-size:10px;white-space:nowrap}.appt-step--active .appt-step-label{color:var(--color-gray-700);font-weight:var(--font-weight-semibold)}.appt-step--done .appt-step-label{color:var(--color-gray-500)}.appt-step-line{background:var(--color-gray-200);height:2px;margin:0 4px 18px;width:32px}.appt-step-line--done{background:var(--color-primary)}.appt-stepper-cancelled{margin-bottom:var(--spacing-md);text-align:center}.appt-stepper-cancelled-badge{border-radius:var(--radius-full);display:inline-block;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);padding:6px 16px}.appt-detail-card{background:var(--color-gray-50);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md)}.appt-detail-datetime{display:flex;flex-direction:column;gap:6px}.appt-detail-date-block,.appt-detail-time-block{align-items:center;color:var(--color-gray-700);display:flex;font-size:var(--font-size-sm);gap:8px}.appt-detail-dur{background:var(--color-gray-200);border-radius:var(--radius-sm);color:var(--color-gray-400);font-size:var(--font-size-xs);padding:1px 6px}.appt-detail-info-row{align-items:center;display:flex;gap:var(--spacing-sm);padding:6px 0}.appt-detail-info-row+.appt-detail-info-row{border-top:1px solid var(--color-gray-100)}.appt-detail-info-icon{align-items:center;display:flex;flex-shrink:0;justify-content:center;width:20px}.appt-detail-info-main{color:var(--color-gray-800);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.appt-detail-info-sub{color:var(--color-gray-400);font-size:var(--font-size-xs)}.appt-detail-price-card{background:transparent;padding:0}.appt-detail-price-row{color:var(--color-gray-600);display:flex;font-size:var(--font-size-sm);justify-content:space-between;padding:4px 0}.appt-detail-price-discount{color:var(--color-danger)}.appt-detail-price-total{border-top:1px solid var(--color-gray-200);color:var(--color-gray-800);font-weight:var(--font-weight-semibold);margin-top:2px;padding-top:6px}.appt-detail-notes-card{background:#fffbeb;border:1px solid #fef3c7}.appt-detail-notes-label{color:var(--color-gray-400);font-size:var(--font-size-xs);margin-bottom:2px}.appt-detail-notes-text{color:var(--color-gray-700);font-size:var(--font-size-sm)}.appt-detail-meta{color:var(--color-gray-400);font-size:var(--font-size-xs);margin-bottom:var(--spacing-sm)}.appt-detail-meta-label{font-weight:var(--font-weight-medium)}.appt-detail-id{color:var(--color-gray-300);font-size:10px;margin-top:var(--spacing-xs);text-align:right}.appt-detail--cancelled{opacity:.8}.appt-action-icon{font-size:12px}.cal-empty-state{color:var(--color-gray-400);font-size:var(--font-size-sm);padding:var(--spacing-md);pointer-events:none;text-align:center}.cal-kbd-hint{display:none}@media (min-width:1025px){.cal-toolbar-right .cal-kbd-hint{color:var(--color-gray-400);cursor:help;display:inline;font-size:10px;margin-left:var(--spacing-xs);position:relative}.cal-kbd-hint:hover:after{background:var(--color-gray-800);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);color:#fff;content:"← → навигация\A T — сегодня\A D W M L — вид\A N — новая запись";font-size:11px;line-height:1.6;margin-top:6px;padding:8px 12px;pointer-events:none;position:absolute;right:0;top:100%;white-space:pre;z-index:100}}.appt-form{display:flex;flex-direction:column}.appt-form-row{display:grid;gap:0 var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.appt-form-client-selected{align-items:center;background:var(--color-primary-light);border-radius:var(--radius-md);color:var(--color-primary);display:flex;font-size:var(--font-size-sm);justify-content:space-between;padding:8px 12px}.appt-form-client-link{color:var(--color-primary);cursor:pointer;text-decoration:none}.appt-form-client-link:hover{font-weight:var(--font-weight-medium);text-decoration:underline}.appt-form-client-actions{align-items:center;display:flex;flex-shrink:0;gap:4px}.appt-form-client-change,.appt-form-client-clear{border-radius:var(--radius-sm);color:var(--color-gray-400);cursor:pointer;padding:2px;transition:color var(--transition-fast)}.appt-form-client-change:hover,.appt-form-client-clear:hover{color:var(--color-primary)}.appt-form-client-clear{font-size:var(--font-size-lg)}.appt-form-client-search{position:relative}.appt-form-client-results{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);left:0;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:var(--z-dropdown)}.appt-form-client-item{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:8px 12px;transition:background var(--transition-fast)}.appt-form-client-item:hover{background:var(--color-gray-50)}.appt-form-client-item-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.appt-form-client-item-phone{color:var(--color-gray-400);font-size:var(--font-size-xs)}.appt-form-search-wrap{position:relative}.appt-form-dropdown{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);display:none;left:0;max-height:240px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:var(--z-dropdown)}.appt-form-selected-pill{align-items:center;background:var(--color-primary-50,#eef2ff);border:1px solid var(--color-primary);border-radius:var(--radius-md);color:var(--color-primary);display:flex;font-size:var(--font-size-sm);font-weight:500;justify-content:space-between;padding:6px 10px}.appt-form-pill-clear{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:16px;padding:0 0 0 8px}.appt-form-slots{margin-bottom:var(--spacing-md)}.appt-form-slots-grid{display:flex;flex-wrap:wrap;gap:4px;margin-top:var(--spacing-xs)}.appt-form-slot{background:var(--color-white);border:1px solid var(--color-gray-300);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-xs);padding:4px 10px;transition:all var(--transition-fast)}.appt-form-slot:hover{border-color:var(--color-primary);color:var(--color-primary)}.appt-form-slot--active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.appt-form-slots-loading{color:var(--color-gray-400);font-size:var(--font-size-xs)}.appt-form-actions{align-items:center;border-top:1px solid var(--color-gray-100);display:flex;justify-content:space-between;margin-top:var(--spacing-md);padding-top:var(--spacing-md)}.appt-form-actions-right{display:flex;gap:var(--spacing-sm);margin-left:auto}.appt-detail-error,.appt-detail-loading{color:var(--color-gray-400);padding:var(--spacing-xl);text-align:center}.appt-detail-loading .btn__spinner{margin-right:6px}.appt-detail-error{color:var(--color-danger)}.appt-detail-link{color:var(--color-primary);font-weight:var(--font-weight-medium);text-decoration:none}.appt-detail-link:hover{text-decoration:underline}.appt-detail-staff-dot{border-radius:50%;display:inline-block;height:10px;width:10px}.appt-detail-actions{border-top:1px solid var(--color-gray-100);display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-md);padding-top:var(--spacing-md)}@media (max-width:767px){.cal-page{height:calc(100dvh - var(--header-height) - var(--bottom-nav-height) - var(--safe-area-bottom) - var(--spacing-md)*2)}.cal-toolbar{align-items:stretch;flex-direction:column;gap:var(--spacing-xs)}.cal-toolbar-left,.cal-toolbar-right{justify-content:space-between}.cal-staff-filter{display:none}.cal-date-display{font-size:var(--font-size-sm)}.cal-month-cell{min-height:50px;padding:2px}.cal-month-appts{display:none}.cal-month-count{font-size:9px}.cal-staff-header{min-width:auto}.appt-form-row{grid-template-columns:1fr}}.svc-catalog-toolbar{align-items:center;display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.svc-catalog-search-wrap{flex:1}.svc-catalog-modes{background:var(--color-gray-100);border-radius:var(--radius-sm);display:flex;gap:2px;padding:2px}.svc-catalog-mode-btn{align-items:center;background:none;border:none;border-radius:var(--radius-xs);color:var(--color-gray-400);cursor:pointer;display:flex;padding:4px 6px;transition:all .15s}.svc-catalog-mode-btn:hover{color:var(--color-gray-600)}.svc-catalog-mode-btn--active{background:var(--color-white);box-shadow:var(--shadow-sm);color:var(--color-primary)}.svc-catalog-list{max-height:400px;overflow-y:auto}.svc-catalog-group{margin-bottom:2px}.svc-catalog-group-title{background:var(--color-white);border-bottom:1px solid var(--color-gray-100);color:var(--color-gray-500);font-size:var(--font-size-xs);font-weight:600;letter-spacing:.05em;padding:var(--spacing-xs) 0;position:sticky;text-transform:uppercase;top:0;z-index:1}.svc-catalog-group-title--tree{align-items:center;cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:4px;letter-spacing:normal;text-transform:none}.svc-catalog-group-title--tree:hover{color:var(--color-gray-700)}.svc-catalog-toggle{color:var(--color-gray-400);font-size:11px;width:14px}.svc-catalog-toggle-spacer{width:14px}.svc-catalog-group-count{color:var(--color-gray-400);font-size:var(--font-size-xs);font-weight:400;margin-left:auto}.svc-catalog-tree-children{padding-left:18px}.svc-catalog-tree-children--collapsed{display:none}.svc-catalog-item{align-items:center;border-radius:var(--radius-sm);cursor:pointer;display:flex;justify-content:space-between;padding:8px 4px;transition:background .15s}.svc-catalog-item:hover{background:var(--color-gray-50)}.svc-catalog-item-name{font-size:var(--font-size-sm);font-weight:500}.svc-catalog-item-meta{color:var(--color-gray-500);font-size:var(--font-size-xs);white-space:nowrap}.svc-catalog-empty{color:var(--color-gray-400);font-size:var(--font-size-sm);text-align:center}.clients-page,.svc-catalog-empty{padding:var(--spacing-lg)}.clients-header{flex-wrap:wrap;justify-content:space-between;margin-bottom:var(--spacing-lg)}.clients-header,.clients-title{align-items:center;display:flex;gap:var(--spacing-sm)}.clients-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}.clients-count{background:var(--color-gray-100);border-radius:var(--radius-full);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-normal);padding:2px 8px}.clients-actions{display:flex;gap:var(--spacing-sm)}.clients-filters{margin-bottom:var(--spacing-md)}.clients-search-row{align-items:center;display:flex;gap:var(--spacing-sm)}.clients-search{flex:1;position:relative}.clients-search-icon{color:var(--color-gray-400);left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.clients-search-input{padding-left:36px!important}.clients-filter-panel{background:var(--color-gray-50);border-radius:var(--radius-md);display:flex;gap:var(--spacing-md);margin-top:var(--spacing-sm);padding:var(--spacing-md)}.clients-filter-panel .form-field{min-width:180px}.clients-table{overflow-x:auto}.clients-cards{display:none}.client-row-name{align-items:center;display:flex;gap:var(--spacing-sm)}.client-avatar{align-items:center;background:var(--gradient-brand);border-radius:var(--radius-full);color:#fff;display:flex;flex-shrink:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);height:34px;justify-content:center;width:34px}.client-cat-badge{background:var(--color-primary-light,rgba(99,102,241,.1));border-radius:var(--radius-full);color:var(--color-primary);display:inline-block;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:2px 8px}.client-card{border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;margin-bottom:var(--spacing-sm);padding:var(--spacing-md);transition:box-shadow var(--transition-fast)}.client-card:hover{box-shadow:var(--shadow-sm)}.client-card-header{align-items:center;display:flex;gap:var(--spacing-sm)}.client-card-info{flex:1;min-width:0}.client-card-name{font-weight:var(--font-weight-medium);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.client-card-phone,.client-card-stats{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.client-card-stats{border-top:1px solid var(--color-border);display:flex;justify-content:space-between;margin-top:var(--spacing-sm);padding-top:var(--spacing-sm)}.client-detail-page{padding:var(--spacing-lg)}.client-detail-layout{align-items:start;display:grid;gap:var(--spacing-xl);grid-template-columns:1fr 280px}.client-detail-header{margin-bottom:var(--spacing-lg)}.client-back{color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.client-detail-hero{align-items:center;display:flex;gap:var(--spacing-md)}.client-detail-avatar{align-items:center;background:var(--gradient-brand);border-radius:var(--radius-full);box-shadow:0 4px 12px rgba(99,102,241,.25);color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:24px;font-weight:var(--font-weight-bold);height:56px;justify-content:center;overflow:hidden;position:relative;width:56px}.client-detail-avatar--img{background:var(--color-gray-200)}img.client-avatar--img{flex-shrink:0;height:34px;width:34px}.client-avatar-img,img.client-avatar--img{border-radius:var(--radius-full);object-fit:cover}.client-avatar-img{height:100%;width:100%}.client-avatar-overlay{align-items:center;background:rgba(0,0,0,.4);border-radius:var(--radius-full);color:#fff;display:flex;inset:0;justify-content:center;opacity:0;position:absolute;transition:opacity .2s}.client-detail-avatar:hover .client-avatar-overlay{opacity:1}.client-avatar-wrap{align-items:center;display:flex;flex-shrink:0;gap:6px}.client-avatar-change-btn{color:var(--color-gray-500);padding:4px}.client-avatar-change-btn:hover{color:var(--color-primary)}.client-detail-info{flex:1;min-width:0}.client-detail-name{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:0}.client-detail-contacts{color:var(--color-text-secondary);display:flex;font-size:var(--font-size-sm);gap:var(--spacing-md);margin-top:4px}.client-detail-phone{color:var(--color-primary);text-decoration:none}.client-detail-quick{display:flex;flex-shrink:0;gap:var(--spacing-sm)}.client-detail-tab-content{margin-top:var(--spacing-md)}.client-info-grid{display:grid;gap:0}.client-info-row{border-bottom:1px solid var(--color-border);display:flex;padding:var(--spacing-sm) 0}.client-info-row:last-child{border-bottom:none}.client-info-label{color:var(--color-text-secondary);flex-shrink:0;font-size:var(--font-size-sm);width:160px}.client-finance-balance{background:var(--color-gray-50);border-radius:var(--radius-md);font-size:var(--font-size-md);margin-bottom:var(--spacing-md);padding:var(--spacing-md)}.client-loyalty{padding:var(--spacing-xl) 0;text-align:center}.client-loyalty-card{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark,#4338ca));border-radius:var(--radius-lg);color:#fff;display:inline-block;margin-bottom:var(--spacing-md);padding:var(--spacing-xl) var(--spacing-xxl,48px)}.client-loyalty-balance{font-size:36px;font-weight:var(--font-weight-bold)}.client-loyalty-label{font-size:var(--font-size-sm);margin-top:4px;opacity:.8}.client-loyalty-hint{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.client-status-badge{border-radius:var(--radius-full);display:inline-block;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:2px 8px}.client-status--completed{background:rgba(34,197,94,.1);color:var(--badge-success-text)}.client-status--confirmed{background:rgba(59,130,246,.1);color:var(--badge-info-text)}.client-status--pending{background:rgba(234,179,8,.1);color:#ca8a04}.client-status--cancelled{background:rgba(239,68,68,.1);color:var(--badge-danger-text)}.client-status--no_show{background:hsla(220,9%,46%,.1);color:#6b7280}.client-status--in_progress{background:rgba(168,85,247,.1);color:#9333ea}.client-detail-sidebar{background:var(--color-gray-50);border:1px solid var(--color-gray-100);border-radius:var(--radius-xl);padding:var(--spacing-xl);position:sticky;top:var(--spacing-lg)}.client-sidebar-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);margin:0 0 var(--spacing-md)}.client-sidebar-stat{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:var(--spacing-sm) 0}.client-sidebar-stat:last-child{border-bottom:none}.client-sidebar-label{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.client-sidebar-value{font-weight:var(--font-weight-medium)}.client-sidebar-discount{color:var(--color-success);font-size:var(--font-size-lg);font-weight:700}.client-sidebar-stat--discount{background:var(--color-success-bg,#f0fdf4);border-radius:var(--radius-sm);margin:-4px -8px;padding:4px 8px}.client-row-actions{text-align:center;width:40px}.client-quick-book{font-size:14px;line-height:1;opacity:0;padding:2px 8px!important;transition:opacity .15s}.datatable-tr:hover .client-quick-book{opacity:1}.client-source-icon{align-items:center;color:var(--color-primary);display:inline-flex;margin-left:4px;vertical-align:middle}.client-reg-date{white-space:nowrap}.client-chat-empty{align-items:center;display:flex;flex-direction:column;gap:8px;padding:40px 20px;text-align:center}.client-chat-empty-text{color:var(--color-gray-500);font-size:var(--font-size-md);margin:0}.client-chat-empty-hint{color:var(--color-gray-400);font-size:var(--font-size-sm);margin:0}.client-chat-channels{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.client-chat-channel{align-items:center;background:var(--color-gray-50);border-radius:var(--radius-full);color:var(--color-gray-600);display:inline-flex;font-size:var(--font-size-sm);gap:4px;padding:4px 10px}.client-chat-log{display:flex;flex-direction:column;gap:8px;max-height:500px;overflow-y:auto;padding:var(--spacing-md)}.client-chat-msg{display:flex}.client-chat-msg--user{justify-content:flex-start}.client-chat-msg--bot{justify-content:flex-end}.client-chat-bubble{border-radius:12px;font-size:var(--font-size-sm);max-width:70%;padding:8px 12px}.client-chat-msg--user .client-chat-bubble{background:var(--color-gray-100);border-bottom-left-radius:4px}.client-chat-msg--bot .client-chat-bubble{background:var(--color-primary-light);border-bottom-right-radius:4px;color:var(--color-primary-dark)}.client-chat-text{white-space:pre-wrap;word-break:break-word}.client-chat-meta{align-items:center;color:var(--color-gray-400);display:flex;font-size:10px;gap:4px;justify-content:flex-end;margin-top:4px}.client-chat-channel-icon{display:inline-flex}.client-chat-channel-icon svg{height:10px;width:10px}.client-detail-footer{border-top:1px solid var(--color-border);margin-top:var(--spacing-xl);padding-top:var(--spacing-md)}.client-delete-btn:hover{text-decoration:underline}.cf-section{border:none;margin:0 0 var(--spacing-md) 0;padding:0}.cf-section-title{border-bottom:1px solid var(--color-border);color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);letter-spacing:.05em;margin-bottom:var(--spacing-sm);padding:0 0 var(--spacing-xs) 0;text-transform:uppercase}.appt-form-row--4{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(4,1fr)}@media (max-width:768px){.appt-form-row--4{grid-template-columns:repeat(2,1fr)}}.client-tags-wrap{align-items:center;border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-wrap:wrap;gap:var(--spacing-xs);min-height:38px;padding:var(--spacing-xs)}.client-tag{align-items:center;background:var(--color-primary-light,rgba(99,102,241,.1));border-radius:var(--radius-full);color:var(--color-primary);display:inline-flex;font-size:var(--font-size-sm);gap:4px;padding:2px 8px}.client-tag-remove{background:none;border:none;color:inherit;cursor:pointer;font-size:16px;line-height:1;opacity:.6;padding:0}.client-tag-remove:hover{opacity:1}.client-tag-input{background:transparent;border:none;flex:1;font-size:var(--font-size-sm);min-width:100px;outline:none;padding:4px}.import-upload{text-align:center}.import-dropzone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);cursor:pointer;padding:var(--spacing-xxl,48px) var(--spacing-xl);transition:border-color var(--transition-fast),background var(--transition-fast)}.import-dropzone--active,.import-dropzone:hover{background:rgba(99,102,241,.03);border-color:var(--color-primary)}.import-dropzone-text{font-weight:var(--font-weight-medium);margin:var(--spacing-md) 0 4px}.import-dropzone-hint{margin:0}.import-dropzone-hint,.import-help{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.import-help{margin-top:var(--spacing-md)}.import-info,.import-table-wrap{margin-bottom:var(--spacing-md)}.import-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow-x:auto}.import-table{border-collapse:collapse;font-size:var(--font-size-sm);width:100%}.import-th{background:var(--color-gray-50);border-bottom:1px solid var(--color-border);padding:var(--spacing-sm);text-align:left;vertical-align:top}.import-col-name{font-weight:var(--font-weight-medium);margin-bottom:4px;white-space:nowrap}.import-mapping{font-size:var(--font-size-xs);width:100%}.import-td{border-bottom:1px solid var(--color-border);max-width:200px;overflow:hidden;padding:var(--spacing-xs) var(--spacing-sm);text-overflow:ellipsis;white-space:nowrap}.import-options{margin-bottom:var(--spacing-md)}.import-option{align-items:center;cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-xs)}.import-progress{padding:var(--spacing-xl) 0;text-align:center}.import-progress-text{font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-md)}.import-progress-bar{background:var(--color-gray-100);border-radius:var(--radius-full);height:8px;overflow:hidden}.import-progress-fill{background:var(--color-primary);border-radius:var(--radius-full);height:100%;transition:width .3s ease}.import-result{padding:var(--spacing-lg) 0;text-align:center}.import-result-icon{margin-bottom:var(--spacing-md)}.import-result-stats{display:flex;gap:var(--spacing-lg);justify-content:center;margin-top:var(--spacing-md)}.import-stat{color:var(--color-text-secondary);font-size:var(--font-size-sm);text-align:center}.import-stat-num{color:var(--color-text-primary);display:block;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.import-stat--error .import-stat-num{color:var(--color-danger)}@media (max-width:768px){.clients-page{padding:var(--spacing-md)}.clients-header{align-items:stretch;flex-direction:column}.clients-actions{justify-content:flex-end}.clients-table .datatable-table{display:none}.clients-cards{display:block}.clients-filter-panel{flex-direction:column}.clients-filter-panel .form-field,.clients-filter-panel select{min-width:auto;width:100%}.client-detail-page{padding:var(--spacing-md)}.client-detail-layout{grid-template-columns:1fr}.client-detail-sidebar{order:-1;position:static}.client-detail-hero{flex-wrap:wrap}.client-detail-quick{width:100%}.client-detail-quick .btn{flex:1}.client-info-row{flex-direction:column;gap:2px}.client-info-label{width:auto}}.dashboard-page{padding:var(--spacing-lg)}.dash-loading{font-size:var(--font-size-sm);gap:var(--spacing-sm);padding:var(--spacing-2xl)}.dash-empty,.dash-loading{align-items:center;color:var(--color-gray-500);display:flex;justify-content:center}.dash-empty{flex-direction:column;gap:var(--spacing-md);min-height:400px;padding:var(--spacing-2xl) var(--spacing-lg);text-align:center}.dash-empty-hero{height:120px;margin-bottom:var(--spacing-sm);width:120px}.dash-empty-title{color:var(--color-gray-900);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:0}.dash-empty-text{color:var(--color-gray-500);font-size:var(--font-size-sm);margin:0;max-width:320px}.dash-empty-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.dash-empty-section{align-items:center;color:var(--color-gray-400);display:flex;flex-direction:column;font-size:var(--font-size-sm);gap:var(--spacing-sm);padding:var(--spacing-xl) var(--spacing-md);text-align:center}.dash-empty-section p{margin:0}.dash-empty-icon{color:var(--color-gray-300);height:48px;margin-bottom:var(--spacing-xs);width:48px}.dash-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-xl)}.dash-title{font-size:1.5rem;letter-spacing:var(--letter-spacing);margin:0}.dash-subtitle{color:var(--color-gray-500);font-size:var(--font-size-sm);margin:4px 0 0}.branch-switcher{align-items:center;background:var(--color-gray-100);border-radius:var(--radius-lg);display:flex;flex-shrink:0;gap:2px;padding:3px}.branch-pill{align-items:center;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-gray-500);cursor:pointer;display:inline-flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:5px;padding:6px 14px;transition:all var(--transition-fast);white-space:nowrap}.branch-pill:hover{background:var(--color-gray-50);color:var(--color-gray-700)}.branch-pill--active{box-shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06)}.branch-pill--active,.branch-pill--active:hover{background:var(--color-white);color:var(--color-primary)}.branch-switcher--dropdown{background:var(--color-gray-100);border-radius:var(--radius-lg);gap:6px;padding:4px 10px}.branch-switcher-icon{color:var(--color-gray-400);flex-shrink:0}.branch-select{appearance:none;background:transparent;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none' viewBox='0 0 10 6'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m1 1 4 4 4-4'/%3E%3C/svg%3E");background-position:right 2px center;background-repeat:no-repeat;border:none;color:var(--color-gray-700);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);outline:none;padding:4px 20px 4px 0}.branch-select:focus{color:var(--color-primary)}.dash-actions{display:flex;gap:var(--spacing-xs)}.dash-actions .btn{align-items:center;display:inline-flex;gap:6px}.dash-actions .btn svg{flex-shrink:0}.dash-shift{align-items:center;border-radius:var(--radius-lg);display:flex;justify-content:space-between;margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md)}.dash-shift--closed{background:var(--color-gray-50);border:1px solid var(--color-gray-200)}.dash-shift--open{background:#f0fdf4;border:1px solid #bbf7d0}.dash-shift-info{align-items:center;display:flex;gap:var(--spacing-sm)}.dash-shift-dot{border-radius:50%;height:8px;width:8px}.dash-shift-dot--closed{background:var(--color-gray-400)}.dash-shift-dot--open{background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.2)}.dash-shift-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.dash-shift-meta{color:var(--color-gray-500);font-size:var(--font-size-xs)}.dash-kpi-grid{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(4,1fr);margin-bottom:var(--spacing-xl)}.dash-kpi-card{align-items:flex-start;background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);color:inherit;cursor:pointer;display:flex;gap:14px;overflow:hidden;padding:var(--spacing-lg);position:relative;text-decoration:none;transition:all var(--transition-fast)}.dash-kpi-card:before{background:linear-gradient(90deg,#6366f1,#8b5cf6);content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity var(--transition-fast)}.dash-kpi-card:hover{border-color:var(--color-gray-300);box-shadow:var(--shadow-md);color:inherit;text-decoration:none;transform:translateY(-2px)}.dash-kpi-card:hover:before{opacity:1}.dash-kpi-icon{align-items:center;background:var(--color-primary-light);border-radius:var(--radius-md);color:var(--color-primary);display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.dash-kpi-icon svg{height:20px;width:20px}.dash-kpi-body{flex:1;min-width:0}.dash-kpi-label{color:var(--color-gray-500);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);letter-spacing:.04em;margin-bottom:4px;text-transform:uppercase}.dash-kpi-value{color:var(--color-gray-900);font-size:1.5rem;font-weight:700;letter-spacing:var(--letter-spacing);line-height:1.2}.dash-kpi-trend{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);gap:2px;margin-top:4px;padding:2px 8px}.dash-kpi-trend--up{background:var(--color-success-light);color:var(--badge-success-text)}.dash-kpi-trend--down{background:var(--color-danger-light);color:var(--badge-danger-text)}.dash-content-grid{display:grid;gap:var(--spacing-lg);grid-template-columns:1.5fr 1fr}.dash-section{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.dash-section--full{grid-column:1/-1}.dash-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-md)}.dash-section-header .dash-section-title{margin:0}.dash-section-link{color:var(--color-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-decoration:none}.dash-section-link:hover{text-decoration:underline}.dash-section-title{color:var(--color-gray-900);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing);margin:0 0 var(--spacing-md) 0}.dash-chart-container{height:220px;min-height:160px}.dash-upcoming-item{border-bottom:1px solid var(--color-gray-100);color:inherit;display:flex;gap:var(--spacing-md);padding:10px 0;text-decoration:none;transition:background var(--transition-fast)}.dash-upcoming-item:last-child{border-bottom:0}.dash-upcoming-item:hover{background:var(--color-gray-50);border-radius:var(--radius-sm);color:inherit;margin:0 calc(var(--spacing-md)*-1);padding-left:var(--spacing-md);padding-right:var(--spacing-md);text-decoration:none}.dash-upcoming-time-block{align-items:flex-start;display:flex;flex-direction:column;min-width:50px}.dash-upcoming-time{color:var(--color-primary);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);line-height:1.3}.dash-upcoming-end-time{color:var(--color-gray-400);font-size:var(--font-size-xs);line-height:1.3}.dash-upcoming-info{flex:1;min-width:0}.dash-upcoming-top-row{align-items:center;display:flex;gap:var(--spacing-sm);margin-bottom:2px}.dash-upcoming-client{color:var(--color-gray-800);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.dash-upcoming-service{color:var(--color-gray-500);font-size:var(--font-size-sm)}.dash-upcoming-meta{color:var(--color-gray-400);display:flex;font-size:var(--font-size-xs);gap:var(--spacing-sm);margin-top:2px}.dash-upcoming-phone:before{-webkit-mask:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='currentColor' viewBox='0 0 16 16'%3E%3Cpath d='M3.654 1.328a.678.678 0 0 0-1.015-.063L1.605 2.3c-.483.484-.661 1.169-.45 1.77a17.6 17.6 0 0 0 4.168 6.608 17.6 17.6 0 0 0 6.608 4.168c.601.211 1.286.033 1.77-.45l1.034-1.034a.678.678 0 0 0-.063-1.015l-2.307-1.794a.68.68 0 0 0-.58-.122l-2.19.547a1.75 1.75 0 0 1-1.657-.459L5.482 8.062a1.75 1.75 0 0 1-.46-1.657l.548-2.19a.68.68 0 0 0-.122-.58z'/%3E%3C/svg%3E") no-repeat center;mask:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='currentColor' viewBox='0 0 16 16'%3E%3Cpath d='M3.654 1.328a.678.678 0 0 0-1.015-.063L1.605 2.3c-.483.484-.661 1.169-.45 1.77a17.6 17.6 0 0 0 4.168 6.608 17.6 17.6 0 0 0 6.608 4.168c.601.211 1.286.033 1.77-.45l1.034-1.034a.678.678 0 0 0-.063-1.015l-2.307-1.794a.68.68 0 0 0-.58-.122l-2.19.547a1.75 1.75 0 0 1-1.657-.459L5.482 8.062a1.75 1.75 0 0 1-.46-1.657l.548-2.19a.68.68 0 0 0-.122-.58z'/%3E%3C/svg%3E") no-repeat center}.dash-upcoming-duration:before,.dash-upcoming-phone:before{background:currentColor;content:"";display:inline-block;height:12px;margin-right:2px;vertical-align:-2px;width:12px}.dash-upcoming-duration:before{-webkit-mask:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='currentColor' viewBox='0 0 16 16'%3E%3Cpath d='M8 3.5a.5.5 0 0 0-1 0V8a.5.5 0 0 0 .252.434l3.5 2a.5.5 0 0 0 .496-.868L8 7.71z'/%3E%3Cpath d='M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16m7-8A7 7 0 1 1 1 8a7 7 0 0 1 14 0'/%3E%3C/svg%3E") no-repeat center;mask:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='currentColor' viewBox='0 0 16 16'%3E%3Cpath d='M8 3.5a.5.5 0 0 0-1 0V8a.5.5 0 0 0 .252.434l3.5 2a.5.5 0 0 0 .496-.868L8 7.71z'/%3E%3Cpath d='M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16m7-8A7 7 0 1 1 1 8a7 7 0 0 1 14 0'/%3E%3C/svg%3E") no-repeat center}.dash-status{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:10px;font-weight:var(--font-weight-semibold);letter-spacing:.02em;line-height:1.6;padding:1px 7px;white-space:nowrap}.dash-status--confirmed{background:var(--color-success-light);color:var(--badge-success-text)}.dash-status--pending{background:var(--color-warning-light);color:var(--badge-warning-text)}.dash-workload-item{align-items:center;display:flex;gap:var(--spacing-sm);padding:6px 0}.dash-workload-name{color:var(--color-gray-700);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);min-width:120px}.dash-workload-bar-wrap{background:var(--color-gray-100);border-radius:var(--radius-full);flex:1;height:8px;overflow:hidden}.dash-workload-bar{background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:var(--radius-full);height:100%;transition:width .5s cubic-bezier(.34,1.56,.64,1)}.dash-workload-stat{color:var(--color-gray-500);font-size:var(--font-size-sm);min-width:120px;text-align:right;white-space:nowrap}.dash-onboard-panel{background:var(--color-white);border:1px solid var(--color-primary-100);border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl);padding:var(--spacing-lg)}.dash-onboard-header{align-items:center;display:flex;gap:var(--spacing-lg);justify-content:space-between;margin-bottom:var(--spacing-md)}.dash-onboard-title{color:var(--color-gray-900);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0}.dash-onboard-subtitle{color:var(--color-gray-500);font-size:var(--font-size-sm);margin:2px 0 0}.dash-onboard-progress{align-items:center;display:flex;flex-shrink:0;gap:var(--spacing-sm)}.dash-onboard-progress-bar{background:var(--color-gray-100);border-radius:var(--radius-full);height:6px;overflow:hidden;width:100px}.dash-onboard-progress-fill{background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:var(--radius-full);height:100%;transition:width .4s ease}.dash-onboard-progress-text{color:var(--color-gray-500);font-size:var(--font-size-xs);white-space:nowrap}.dash-onboard-list{display:grid;gap:var(--spacing-sm);grid-template-columns:repeat(3,1fr)}.dash-onboard-item{align-items:center;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);color:var(--color-gray-700);display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--spacing-sm);padding:10px 14px;text-decoration:none;transition:all var(--transition-fast)}a.dash-onboard-item:hover{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary);text-decoration:none}.dash-onboard-item--done{background:var(--color-success-light);border-color:var(--color-success-light);color:var(--color-gray-400)}.dash-onboard-item--done .dash-onboard-label{text-decoration:line-through}.dash-onboard-check{align-items:center;border:2px solid var(--color-gray-300);border-radius:var(--radius-full);display:flex;flex-shrink:0;height:20px;justify-content:center;width:20px}.dash-onboard-item--done .dash-onboard-check{background:var(--color-success);border-color:var(--color-success);color:#fff}.dash-onboard-check svg{height:12px;width:12px}.dash-onboard-label{flex:1}@media (max-width:768px){.dashboard-page{padding:var(--spacing-md)}.dash-header{align-items:flex-start;flex-direction:column;gap:var(--spacing-sm)}.dash-kpi-grid{gap:var(--spacing-sm);grid-template-columns:repeat(2,1fr)}.dash-kpi-card{padding:var(--spacing-md)}.dash-kpi-icon{display:none}.dash-content-grid{grid-template-columns:1fr}.dash-workload-name{min-width:80px}.dash-chart-container{height:180px;min-height:140px}.dash-onboard-list{grid-template-columns:1fr}.dash-onboard-header{align-items:flex-start;flex-direction:column}}@media (max-width:374px){.analytics-summary,.dash-kpi-grid,.fin-stat-cards{grid-template-columns:1fr}}.dash-kpi-card--success{background:var(--color-success-light);border-color:var(--color-success)}.dash-status--active{background:var(--color-primary-light);color:var(--color-primary)}.staff-appt-list{display:flex;flex-direction:column;gap:2px}.staff-appt-item{align-items:center;border-radius:var(--radius-md);cursor:pointer;display:flex;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);transition:background var(--transition-fast)}.staff-appt-item:hover{background:var(--color-gray-50)}.staff-appt-list--timeline .staff-appt-item{padding-left:var(--spacing-lg);position:relative}.staff-appt-dot{background:var(--color-primary);border-radius:50%;flex-shrink:0;height:8px;left:4px;position:absolute;top:50%;transform:translateY(-50%);width:8px}.staff-appt-list--timeline .staff-appt-item:before{background:var(--color-gray-200);bottom:0;content:"";left:7px;position:absolute;top:0;width:2px}.staff-appt-list--timeline .staff-appt-item:first-child:before{top:50%}.staff-appt-list--timeline .staff-appt-item:last-child:before{bottom:50%}.staff-appt-list--timeline .staff-appt-item:only-child:before{display:none}.staff-appt-time{color:var(--color-gray-700);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);min-width:100px;white-space:nowrap}.staff-appt-info{display:flex;flex:1;flex-direction:column;gap:1px;min-width:0}.staff-appt-client{color:var(--color-gray-900);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.staff-appt-service{color:var(--color-gray-500);font-size:var(--font-size-xs)}@media (max-width:768px){.staff-appt-item{flex-wrap:wrap;gap:var(--spacing-xs) var(--spacing-md)}.staff-appt-time{min-width:auto}}.finance-page{padding:var(--spacing-lg)}.finance-header{align-items:flex-start;flex-wrap:wrap;justify-content:space-between;margin-bottom:var(--spacing-lg)}.finance-header,.finance-title{display:flex;gap:var(--spacing-sm)}.finance-title{align-items:center;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}.finance-nav{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.fin-stat-cards{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-bottom:var(--spacing-lg)}.fin-stat-card{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-fast)}.fin-stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.fin-stat-label{color:var(--color-gray-500);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);letter-spacing:.04em;margin-bottom:6px;text-transform:uppercase}.fin-stat-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing)}.fin-card--income .fin-stat-value{color:var(--badge-success-text)}.fin-card--expense .fin-stat-value{color:var(--badge-danger-text)}.fin-card--cash{background:linear-gradient(135deg,#eff6ff,#fff);border-color:#93c5fd}.fin-card--cash .fin-stat-value{color:#1d4ed8}.fin-card--revenue{background:linear-gradient(135deg,#f0fdf4,#fff);border-color:#86efac}.fin-card--revenue .fin-stat-value{color:#166534}.fin-account-icon{align-items:center;color:var(--color-gray-400);display:flex}.fin-quick-actions{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.fin-qa-btn{align-items:center;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:var(--font-size-sm);gap:6px;padding:8px 14px;transition:all var(--transition-fast)}.fin-qa-btn:hover{background:var(--bg-secondary);border-color:var(--color-primary)}.fin-qa--income{border-color:#bbf7d0;color:var(--badge-success-text)}.fin-qa--income:hover{background:#f0fdf4}.fin-qa--expense{border-color:#fecaca;color:var(--badge-danger-text)}.fin-qa--expense:hover{background:var(--badge-danger-bg)}.fin-qa--collection{border-color:#bfdbfe;color:var(--badge-info-text)}.fin-qa--collection:hover{background:#eff6ff}.fin-qa--supplier{border-color:#e9d5ff;color:#7c3aed}.fin-qa--supplier:hover{background:#faf5ff}.fin-qa--salary{border-color:#fed7aa;color:#ea580c}.fin-qa--salary:hover{background:#fff7ed}.fin-qa--correction{border-color:#d1d5db;color:#6b7280}.fin-qa--correction:hover{background:#f9fafb}.fin-qa--reconcile{border-color:#a7f3d0;color:#059669}.fin-qa--reconcile:hover{background:#ecfdf5}.fin-tx-filters{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.fin-tx-filters .input--sm{max-width:160px}.fin-tx-filters select.input--sm{max-width:180px}.fin-filter-sep{color:var(--color-gray-400);font-size:var(--font-size-sm)}.fin-pm-badge{border-radius:var(--radius-sm);display:inline-block;font-size:11px;font-weight:var(--font-weight-medium);letter-spacing:.02em;padding:2px 6px}.fin-pm--cash{background:#dcfce7;color:#166534}.fin-pm--card{background:#dbeafe;color:#1e40af}.fin-pm--transfer{background:#e0e7ff;color:#3730a3}.fin-pm--cert{background:#fef3c7;color:#92400e}.fin-tx-type-selector{border:1px solid var(--border-color);border-radius:var(--radius-md);display:flex;gap:0;margin-bottom:var(--spacing-md);overflow:hidden}.fin-tx-type-btn{background:var(--bg-primary);border:none;border-right:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;flex:1;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:10px 12px;text-align:center;transition:all var(--transition-fast)}.fin-tx-type-btn:last-child{border-right:none}.fin-tx-type-btn:hover:not([disabled]){background:var(--bg-secondary)}.fin-tx-type-btn--active.fin-tx-type-btn--income{background:#f0fdf4;border-color:#86efac;color:#166534}.fin-tx-type-btn--active.fin-tx-type-btn--expense{background:#fef2f2;border-color:#fca5a5;color:#991b1b}.fin-tx-type-btn--active.fin-tx-type-btn--transfer{background:#eff6ff;border-color:#93c5fd;color:#1e40af}.fin-tx-type-btn[disabled]{cursor:default;opacity:.6}.fin-tx-visit-link{background:var(--bg-secondary);border-radius:var(--radius-sm);color:var(--color-primary);display:inline-block;font-size:var(--font-size-xs);margin-bottom:var(--spacing-sm);padding:4px 8px;text-decoration:none}.fin-tx-visit-link:hover{background:var(--color-primary-bg,#eff6ff);text-decoration:underline}.input--highlighted{animation:input-highlight 1.2s ease-out;outline:2px solid var(--color-primary);outline-offset:-1px;transition:outline-color .3s ease}@keyframes input-highlight{0%{outline-color:var(--color-primary)}to{outline-color:transparent}}.btn--danger-ghost{background:none;border:1px solid transparent;color:var(--color-danger)}.btn--danger-ghost:hover{background:var(--color-danger-bg,#fef2f2);border-color:var(--color-danger)}.fin-td-date{white-space:nowrap;width:90px}.fin-td-desc{max-width:200px}.fin-td-account,.fin-td-desc{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fin-td-account{color:var(--color-gray-500);font-size:var(--font-size-xs);max-width:150px}.fin-summary-sep{color:var(--color-gray-300);margin:0 4px}.fin-dashboard-grid{display:grid;gap:var(--spacing-lg);grid-template-columns:2fr 1fr;margin-bottom:var(--spacing-lg)}.fin-dashboard-accounts,.fin-dashboard-chart,.fin-dashboard-transactions{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);padding:var(--spacing-md)}.fin-section-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-sm)}.fin-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-sm)}.fin-chart-container{min-height:200px;width:100%}.fin-loyalty-section{margin-top:var(--spacing-lg)}.fin-loyalty-grid{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(4,1fr)}.fin-loyalty-card{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);display:flex;gap:var(--spacing-sm);padding:var(--spacing-md)}.fin-loyalty-card-icon{flex-shrink:0;font-size:24px;text-align:center;width:36px}.fin-loyalty-card-body{flex:1;min-width:0}.fin-loyalty-card-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-xs)}.fin-loyalty-stat-row{color:var(--color-gray-600);display:flex;font-size:var(--font-size-xs);justify-content:space-between;padding:2px 0}.fin-loyalty-stat-row strong{color:var(--text-primary)}.fin-loyalty-stat-row--highlight{color:var(--color-primary);font-weight:var(--font-weight-medium)}.fin-loyalty-stat-row--highlight strong{color:var(--color-primary)}@media (max-width:1024px){.fin-loyalty-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.fin-loyalty-grid{grid-template-columns:1fr}}.fin-salary-section{margin-top:var(--spacing-lg)}.fin-salary-grid{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(2,1fr)}@media (max-width:640px){.fin-salary-grid{grid-template-columns:1fr}}.fin-salary-staff-row{align-items:center;border-bottom:1px solid var(--color-gray-100);display:flex;justify-content:space-between;padding:4px 0}.fin-salary-staff-row:last-child{border-bottom:none}.fin-salary-staff-name{color:var(--color-gray-700);font-size:var(--font-size-sm)}.fin-salary-staff-amount{color:var(--color-gray-900);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.fin-widget-settings{background:var(--bg-primary);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:0;max-height:0;opacity:0;overflow:hidden;transition:max-height .25s ease,opacity .2s ease,margin .25s ease}.fin-widget-settings.is-open{margin-bottom:var(--spacing-lg);max-height:600px;opacity:1}.fin-widget-settings-header{align-items:center;background:var(--color-gray-50);border-bottom:1px solid var(--color-gray-100);display:flex;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md)}.fin-widget-settings-title{color:var(--color-gray-700);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);letter-spacing:.03em;text-transform:uppercase}.fin-widget-settings-body{display:grid;gap:2px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));padding:var(--spacing-xs)}.fin-widget-toggle-item{align-items:center;border-radius:var(--radius-md);cursor:pointer;display:flex;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);transition:background .15s;user-select:none}.fin-widget-toggle-item:hover{background:var(--color-gray-50)}.fin-widget-toggle-icon{align-items:center;background:var(--color-gray-100);border-radius:var(--radius-md);color:var(--color-gray-500);display:flex;flex-shrink:0;font-size:14px;height:28px;justify-content:center;transition:background .15s,color .15s;width:28px}.fin-widget-toggle-item.is-active .fin-widget-toggle-icon{background:var(--color-primary-light,#dbeafe);color:var(--color-primary)}.fin-widget-toggle-label{color:var(--color-gray-700);flex:1;font-size:var(--font-size-sm)}.fin-widget-switch{flex-shrink:0;height:18px;position:relative;width:34px}.fin-widget-switch input{height:0;opacity:0;position:absolute;width:0}.fin-widget-switch-track{background:var(--color-gray-300);border-radius:9px;cursor:pointer;inset:0;position:absolute;transition:background .2s}.fin-widget-switch-track:after{background:#fff;border-radius:50%;box-shadow:0 1px 2px rgba(0,0,0,.15);content:"";height:14px;left:2px;position:absolute;top:2px;transition:transform .2s;width:14px}.fin-widget-switch input:checked+.fin-widget-switch-track{background:var(--color-primary)}.fin-widget-switch input:checked+.fin-widget-switch-track:after{transform:translateX(16px)}#toggleWidgetSettings.is-active{background:var(--color-primary-light,#dbeafe);color:var(--color-primary)}.fin-account-row{align-items:center;border-bottom:1px solid var(--color-gray-100);display:flex;justify-content:space-between;padding:var(--spacing-sm) 0}.fin-account-row:last-child{border-bottom:none}.fin-account-name{font-weight:var(--font-weight-medium)}.fin-account-type{color:var(--color-gray-500);font-size:var(--font-size-xs)}.fin-account-balance{font-weight:var(--font-weight-semibold)}.fin-type-badge{font-weight:var(--font-weight-medium);white-space:nowrap}.fin-amount--income{color:var(--badge-success-text)}.fin-amount--expense{color:var(--badge-danger-text)}.fin-col-amount{text-align:right}.fin-col-action{text-align:center;white-space:nowrap;width:70px}.fin-col-edit{width:40px}.fin-edit-cell{padding:0!important;text-align:center}.fin-edit-btn{opacity:.4;padding:4px;transition:opacity .15s}.datatable-tr:hover .fin-edit-btn{opacity:1}.cp-type-badge{border:1px solid;border-radius:var(--radius-sm);display:inline-block;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:2px 8px}.cp-avatar{border-radius:var(--radius-md);display:inline-flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);height:32px;min-width:32px;width:32px}.cp-avatar--lg{border-radius:var(--radius-lg);font-size:var(--font-size-lg);height:48px;min-width:48px;width:48px}.cp-name-cell{align-items:center;display:flex;gap:var(--spacing-sm)}.cp-name{font-weight:var(--font-weight-medium)}.cp-contact-sub,.cp-tx-sub{color:var(--text-muted);font-size:var(--font-size-xs)}.cp-detail-header{align-items:center;display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.cp-detail-name{font-size:var(--font-size-lg);margin:0}.cp-detail-meta{align-items:center;display:flex;gap:var(--spacing-sm);margin-top:4px}.cp-detail-inn{color:var(--text-muted);font-size:var(--font-size-sm)}.cp-detail-contacts{background:var(--bg-secondary);border-radius:var(--radius-md);display:flex;flex-direction:column;font-size:var(--font-size-sm);gap:4px;margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md)}.cp-detail-contacts a{color:var(--color-primary);text-decoration:none}.cp-detail-notes{background:var(--bg-secondary);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);white-space:pre-wrap}.cp-detail-stats{display:grid;gap:var(--spacing-sm);grid-template-columns:repeat(3,1fr);margin-bottom:var(--spacing-md)}.cp-detail-stat{background:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--spacing-sm);text-align:center}.cp-detail-stat-val{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}.cp-detail-stat-label{color:var(--text-muted);font-size:var(--font-size-xs)}.fin-me-summary{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:var(--spacing-lg)}.fin-me-summary-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-md)}.fin-me-summary-label{color:var(--text-secondary);font-size:var(--font-size-xs);margin-bottom:4px}.fin-me-summary-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.fin-me-summary-hint{color:var(--text-muted);font-size:11px;margin-top:2px}.fin-me-cat{border-radius:var(--radius-sm);font-size:var(--font-size-xs);padding:2px 6px}.fin-me-cat,.fin-me-total-row{background:var(--bg-secondary)}.fin-me-break-even{margin-top:4px}.fin-me-break-bar{background:var(--color-gray-200);border-radius:3px;height:6px;overflow:hidden}.fin-me-break-fill{background:var(--color-warning);border-radius:3px;height:100%;transition:width .3s ease}.fin-me-break-fill--ok{background:var(--color-success)}.fin-table-summary{border-top:2px solid var(--color-gray-200);display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--spacing-lg);margin-top:var(--spacing-sm);padding:var(--spacing-md)}.fin-report-controls{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.fin-report-controls .btn{align-items:center;display:inline-flex;gap:5px}.fin-date-presets{display:flex;gap:4px}.fin-date-preset{background:var(--bg-primary);border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-xs);padding:4px 10px;transition:all var(--transition-fast);white-space:nowrap}.fin-date-preset:hover{border-color:var(--color-primary);color:var(--color-primary)}.fin-date-preset--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.fin-date-preset--active:hover{background:color-mix(in srgb,var(--color-primary) 85%,#000);color:#fff}.fin-date-inputs{align-items:center;display:flex;gap:6px}.fin-date-sep{color:var(--color-gray-400);font-size:var(--font-size-sm)}.fin-report-period-label{color:var(--text-secondary);font-size:var(--font-size-sm);margin-left:var(--spacing-sm)}.fin-report-content{margin-top:var(--spacing-md)}.fin-report-empty{align-items:center;color:var(--color-gray-400);display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-xl) 0}.fin-report-empty p{font-size:var(--font-size-sm);margin:0}.tabs-btn svg{flex-shrink:0}.fin-report-grid{display:grid;gap:var(--spacing-lg);grid-template-columns:1fr 1fr}.fin-total-row{background:var(--color-gray-50)}.fin-report-profit{border-top:2px solid var(--color-gray-200);font-size:var(--font-size-lg);margin-top:var(--spacing-md);padding:var(--spacing-md);text-align:center}.fin-cat-name-cell{position:relative}.fin-cat-bar{border-radius:2px;bottom:0;height:3px;left:0;opacity:.3;position:absolute;transition:width .5s ease}.fin-col-pct{color:var(--text-secondary);font-size:13px}.fin-pnl-summary-icon{color:inherit;margin-bottom:4px;opacity:.7}.fin-cashflow-summary{display:grid;gap:var(--spacing-sm);grid-template-columns:repeat(4,1fr);margin-bottom:var(--spacing-lg)}.fin-cashflow-card{background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);text-align:center}.fin-cashflow-card--in{background:#f0fdf4;border-color:#bbf7d0}.fin-cashflow-card--in strong{color:var(--badge-success-text)}.fin-cashflow-card--out{background:var(--badge-danger-bg);border-color:#fecaca}.fin-cashflow-card--out strong{color:var(--badge-danger-text)}.fin-cashflow-card--result{background:#eff6ff;border-color:#bfdbfe}.fin-cashflow-card--result strong{color:var(--color-primary)}.fin-cashflow-label{color:var(--text-secondary);display:block;font-size:var(--font-size-xs);margin-bottom:2px}.fin-svc-name-cell{position:relative}.fin-svc-bar{background:var(--color-primary);border-radius:2px;bottom:0;height:3px;left:0;opacity:.2;position:absolute;transition:width .5s ease}.fin-tabs{background:var(--color-gray-100);border-radius:var(--radius-lg);display:flex;gap:2px;margin-bottom:var(--spacing-md);overflow-x:auto;padding:3px;-webkit-overflow-scrolling:touch}.fin-tab{align-items:center;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:6px;padding:8px 14px;text-decoration:none;transition:all .15s;white-space:nowrap}.fin-tab:hover{background:hsla(0,0%,100%,.6);color:var(--text-primary)}.fin-tab--active{background:var(--color-white);box-shadow:var(--shadow-sm);color:var(--color-primary)}.fin-tab svg{flex-shrink:0}@media (max-width:768px){.fin-tabs{gap:1px;padding:2px}.fin-tab{font-size:12px;padding:6px 10px}.fin-tab-label{display:none}}.fin-pnl-summary{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(3,1fr);margin-bottom:var(--spacing-lg)}.fin-pnl-summary-card{border-radius:var(--radius-lg);padding:var(--spacing-md) var(--spacing-lg);text-align:center}.fin-pnl-summary--income{background:#f0fdf4;border:1px solid #bbf7d0}.fin-pnl-summary--expense{background:var(--badge-danger-bg);border:1px solid #fecaca}.fin-pnl-summary--profit{background:#f0fdf4;border:1px solid #86efac}.fin-pnl-summary--loss{background:var(--badge-danger-bg);border:1px solid #fca5a5}.fin-pnl-summary-label{color:var(--text-secondary);font-size:var(--font-size-sm);margin-bottom:4px}.fin-pnl-summary-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.fin-pnl-summary--income .fin-pnl-summary-value{color:var(--badge-success-text)}.fin-pnl-summary--expense .fin-pnl-summary-value{color:var(--badge-danger-text)}.fin-pnl-summary--profit .fin-pnl-summary-value{color:var(--badge-success-text)}.fin-pnl-summary--loss .fin-pnl-summary-value{color:var(--badge-danger-text)}.fin-pnl-summary-sub{color:var(--text-secondary);font-size:var(--font-size-xs);margin-top:2px}.fin-dashboard-staff-ranking{margin-bottom:var(--spacing-lg)}.fin-staff-ranking{display:flex;flex-direction:column;gap:var(--spacing-xs)}.fin-staff-rank-card{align-items:center;background:var(--color-white);border:1px solid var(--color-gray-100);border-radius:var(--radius-md);display:flex;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);transition:box-shadow .15s}.fin-staff-rank-card:hover{box-shadow:var(--shadow-sm)}.fin-staff-rank-pos{flex-shrink:0;font-size:20px;min-width:32px;text-align:center}.fin-staff-rank-body{flex:1;min-width:0}.fin-staff-rank-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.fin-staff-rank-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.fin-staff-rank-revenue{color:var(--badge-success-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold)}.fin-staff-rank-bar-wrap{background:var(--color-gray-100);border-radius:3px;height:6px;margin-bottom:4px;overflow:hidden}.fin-staff-rank-bar{background:linear-gradient(90deg,#3b82f6,#6366f1);border-radius:3px;height:100%;transition:width .6s ease}.fin-staff-rank-meta{color:var(--text-secondary);display:flex;font-size:var(--font-size-xs);gap:var(--spacing-md)}@media (max-width:768px){.finance-page{padding:var(--spacing-md)}.finance-header{align-items:stretch;flex-direction:column}.finance-nav{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap}.finance-nav .btn{flex-shrink:0;white-space:nowrap}.fin-tx-filters .input--sm{max-width:130px}.fin-tx-filters select.input--sm{max-width:140px}.fin-tx-type-selector{flex-direction:row}.fin-tx-type-btn{font-size:var(--font-size-xs);padding:8px 6px}.fin-stat-cards{gap:var(--spacing-sm);grid-template-columns:repeat(2,1fr)}.fin-stat-card{padding:var(--spacing-md)}.fin-dashboard-grid,.fin-report-grid{grid-template-columns:1fr}.fin-table-summary{flex-direction:column;gap:var(--spacing-xs)}.fin-report-controls{align-items:stretch;flex-direction:column}.fin-date-presets{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.fin-date-presets::-webkit-scrollbar{display:none}.fin-pnl-summary{gap:var(--spacing-sm);grid-template-columns:1fr}.fin-cashflow-summary{grid-template-columns:repeat(2,1fr)}.fin-report-period-label,.fin-tab-label{display:none}}.shifts-page{margin:0 auto;max-width:900px;padding:var(--spacing-md)}.sh-header{justify-content:space-between;margin-bottom:var(--spacing-lg)}.sh-header,.sh-header-left{align-items:center;display:flex}.sh-header-left{gap:var(--spacing-sm)}.sh-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin:0}.sh-current{align-items:center;border-radius:var(--radius-lg);display:flex;gap:var(--spacing-md);justify-content:space-between;margin-bottom:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg)}.sh-current--loading{background:var(--color-gray-50,#f8fafc);justify-content:center;padding:var(--spacing-lg)}.sh-current--closed{background:var(--color-gray-50,#f8fafc);border:1px dashed var(--color-gray-200)}.sh-current--open{background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border:1px solid #bbf7d0}.sh-current-info{display:flex;flex-direction:column;gap:4px}.sh-current-status{align-items:center;display:flex;gap:8px}.sh-current-label{font-size:15px;font-weight:600}.sh-current-time{color:var(--color-gray-500);font-size:13px}.sh-current-hint{color:var(--color-gray-400);font-size:13px}.sh-current-details{color:var(--color-gray-500);display:flex;flex-wrap:wrap;font-size:13px;gap:12px}.sh-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.sh-dot--open{animation:pulse-dot 2s infinite;background:#22c55e}.sh-dot--closed{background:var(--color-gray-300)}.sh-stats{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(2,1fr);margin-bottom:var(--spacing-lg)}.sh-stat-card{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-md)}.sh-stat-label{color:var(--color-gray-500);font-size:12px;letter-spacing:.04em;margin-bottom:4px;text-transform:uppercase}.sh-stat-value{font-size:1.3rem;font-weight:700}.sh-stat-ok{color:#22c55e}.sh-stat-bad{color:#ef4444}.sh-stat-sub{color:var(--color-gray-400);font-size:12px;margin-top:2px}.sh-section-title{color:var(--color-gray-500);font-size:14px;font-weight:600;letter-spacing:.04em;margin-bottom:var(--spacing-sm);text-transform:uppercase}.sh-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.sh-card{align-items:center;background:var(--color-white);border-left:1px solid var(--color-gray-200);border:1px solid var(--color-gray-200);border-left-width:3px;border-radius:var(--radius-md);cursor:pointer;display:flex;gap:var(--spacing-md);justify-content:space-between;padding:12px var(--spacing-md);transition:all var(--transition-fast)}.sh-card:hover{border-color:var(--color-primary);box-shadow:0 2px 8px rgba(0,0,0,.04)}.sh-card--open{background:#fafffe;border-left-color:#22c55e}.sh-card--open:hover{border-color:#22c55e}.sh-card-left{display:flex;flex-direction:column;gap:2px}.sh-card-date{align-items:center;display:flex;gap:8px}.sh-card-day{font-size:14px;font-weight:600}.sh-card-time{color:var(--color-gray-500);font-size:13px}.sh-card-meta{color:var(--color-gray-400);display:flex;flex-wrap:wrap;font-size:12px;gap:8px}.sh-card-dur{color:var(--color-gray-500)}.sh-badge{border-radius:8px;font-size:10px;font-weight:600;padding:1px 6px;text-transform:uppercase}.sh-badge--open{background:var(--badge-success-bg);color:var(--badge-success-text)}.sh-card-right{align-items:center;display:flex;gap:var(--spacing-md);text-align:right}.sh-card-amounts{display:flex;flex-direction:column;gap:2px}.sh-card-cash{color:var(--color-gray-500);font-size:13px}.sh-card-cash-label{display:none}.sh-card-revenue{font-size:14px}.sh-card-revenue-label{color:var(--color-gray-400);font-size:11px;margin-right:4px}.sh-card-revenue-val,.sh-disc{font-weight:600}.sh-disc{border-radius:8px;font-size:12px;padding:2px 8px;white-space:nowrap}.sh-disc--ok{background:var(--badge-success-bg);color:var(--badge-success-text)}.sh-disc--neg{background:#fee2e2;color:#ef4444}.sh-disc--pos{background:var(--badge-warning-bg);color:#b45309}.sh-empty{color:var(--color-gray-400);padding:40px 16px;text-align:center}.sh-empty p{font-size:14px;margin:8px 0 0}.sh-pagination{align-items:center;display:flex;gap:var(--spacing-md);justify-content:center;margin-top:var(--spacing-md)}.sh-page-info{color:var(--color-gray-500);font-size:13px}.sh-close-summary{display:flex;flex-direction:column;gap:var(--spacing-md)}.sh-close-overview{align-items:center;background:var(--color-bg-secondary,#f8fafc);border-radius:var(--radius-lg);display:flex;justify-content:space-between;padding:var(--spacing-md)}.sh-close-total-label{color:var(--color-gray-500);font-size:12px;letter-spacing:.04em;text-transform:uppercase}.sh-close-total-val{font-size:1.5rem;font-weight:700;margin-top:2px}.sh-close-kpis{display:flex;gap:var(--spacing-lg)}.sh-close-kpi{text-align:center}.sh-close-kpi-num{font-size:1.1rem;font-weight:700;line-height:1.2}.sh-close-kpi-label{color:var(--color-gray-500);font-size:11px}.sh-close-breakdown{display:flex;flex-direction:column;gap:6px}.sh-close-row{display:flex;font-size:14px;justify-content:space-between}.sh-close-row--bold{font-weight:600}.sh-close-val-pos{color:#22c55e}.sh-close-val-neg{color:#ef4444}.sh-close-cats{border-top:1px solid var(--color-gray-100);padding-top:var(--spacing-sm)}.sh-close-cats-title{color:var(--color-gray-500);font-size:12px;font-weight:600;letter-spacing:.03em;margin-bottom:6px;text-transform:uppercase}.sh-cat-row{color:var(--color-gray-600);display:flex;font-size:13px;justify-content:space-between;padding:2px 0}.sh-exp-val{color:#ef4444}.sh-close-cash-block{border-top:1px solid var(--color-gray-100);display:flex;flex-direction:column;gap:6px;padding:var(--spacing-sm) 0}.sh-disc-display{align-items:center;background:var(--color-gray-50,#f8fafc);border-radius:var(--radius-md);display:flex;justify-content:space-between;padding:10px var(--spacing-md)}.sh-disc-label{color:var(--color-gray-600);font-size:14px}.sh-disc-value{font-size:1.1rem;font-weight:700}.sh-disc-value.sh-disc--ok{color:#22c55e}.sh-disc-value.sh-disc--bad{color:#ef4444}.sh-detail{display:flex;flex-direction:column;gap:var(--spacing-md)}.sh-detail-header{margin-bottom:var(--spacing-xs)}.sh-detail-time{font-size:15px;font-weight:600}.sh-detail-meta{color:var(--color-gray-500);display:flex;flex-wrap:wrap;font-size:13px;gap:8px;margin-top:2px}.sh-detail-notes{background:var(--color-gray-50,#f8fafc);border-radius:var(--radius-md);color:var(--color-gray-600);font-size:13px;padding:var(--spacing-sm)}@media (max-width:768px){.sh-current{align-items:stretch;flex-direction:column;text-align:center}.sh-current .btn{align-self:center}.sh-stats{grid-template-columns:1fr}.sh-card{align-items:stretch;flex-direction:column}.sh-card-right{flex-direction:row;justify-content:space-between;text-align:left}.sh-close-overview{align-items:flex-start;flex-direction:column;gap:var(--spacing-md)}}.shift-indicator{align-items:center;background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md)}.shift-indicator:empty{display:none}.shift-indicator-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.shift-indicator-dot--open{animation:shift-pulse 2s infinite;background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.2)}@keyframes shift-pulse{0%,to{box-shadow:0 0 0 3px rgba(34,197,94,.2)}50%{box-shadow:0 0 0 5px rgba(34,197,94,.1)}}.shift-indicator-label{color:var(--color-gray-700);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.shift-indicator-time{color:var(--color-gray-500);font-size:var(--font-size-xs);margin-right:auto}.fin-stat-card--link{color:inherit;cursor:pointer;text-decoration:none;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.fin-stat-card--link:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.fin-stat-card--link:active{transform:translateY(0)}.fin-card-change{font-size:11px;font-weight:var(--font-weight-medium);margin-top:4px}.fin-card-change--up{color:#22c55e}.fin-card-change--down{color:#ef4444}.fin-tx-filters .fin-date-inputs{align-items:center;display:flex;gap:var(--spacing-xs)}.fin-tx-bottom-bar{align-items:center;display:flex;gap:var(--spacing-md);justify-content:space-between;margin-top:var(--spacing-md)}.fin-limit-warn{color:#f59e0b;cursor:help;font-size:var(--font-size-sm);margin-left:6px}.fin-limit-warn--max{color:#ef4444}.form-hint{color:var(--color-gray-500);font-size:var(--font-size-xs);margin-top:2px}.intg-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-top:16px}.intg-card{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);display:flex;gap:16px;padding:20px;transition:all var(--transition-fast)}.intg-card:hover{border-color:var(--color-gray-300);box-shadow:var(--shadow-md);transform:translateY(-2px)}.intg-card-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.intg-card-body{flex:1;min-width:0}.intg-card-title{font-weight:var(--font-weight-semibold,600);margin-bottom:4px}.intg-card-desc{color:var(--color-text-secondary,#64748b);font-size:.82rem;line-height:1.4;margin-bottom:12px}.intg-card-footer{align-items:center;display:flex;gap:8px;justify-content:space-between}.intg-status{font-size:.82rem;font-weight:var(--font-weight-medium,500)}.intg-status--active{color:#22c55e}.intg-status--inactive{color:var(--color-text-secondary,#94a3b8)}.intg-test-result{border-radius:8px;font-size:.88rem;font-weight:500;margin-top:12px;padding:10px 14px}.intg-test--ok{background:var(--badge-success-bg);color:var(--badge-success-text)}.intg-test--fail{background:var(--badge-danger-bg);color:var(--badge-danger-text)}.intg-badge{border-radius:12px;display:inline-block;font-size:.78rem;font-weight:600;letter-spacing:.02em;padding:2px 10px}.intg-badge--active{background:var(--badge-success-bg);color:var(--badge-success-text)}.intg-badge--inactive{background:var(--badge-danger-bg);color:var(--badge-danger-text)}.intg-badge--new{background:var(--color-bg-tertiary,#f1f5f9);color:var(--color-text-secondary,#64748b)}.intg-actions{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0}.intg-danger-btn{color:var(--color-danger,#dc2626)!important}.intg-saved-mark{color:var(--color-success,#16a34a);font-weight:500}.form-required{color:var(--color-danger,#dc2626)}.intg-section{margin-top:28px}.intg-map-form{align-items:flex-end;display:flex;gap:8px}.intg-map-table{margin-bottom:12px}.intg-webhook-url{align-items:center;display:flex;gap:8px;margin-bottom:16px}.intg-webhook-input{flex:1;font-family:var(--font-mono,monospace)!important;font-size:.82rem!important}.intg-info-grid{background:var(--color-bg-tertiary,#f8fafc);border-radius:8px;display:flex;flex-wrap:wrap;gap:8px 24px;margin:16px 0;padding:12px}.intg-info-item{display:flex;flex-direction:column;gap:2px;min-width:100px}.intg-info-label{color:var(--color-text-secondary);font-size:.78rem;letter-spacing:.04em;text-transform:uppercase}.intg-info-value{font-size:.88rem}.intg-calls-table{font-size:.85rem}.intg-wh-panel{margin-top:16px}.intg-wh-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.intg-wh-table{font-size:.82rem;margin-top:12px}.intg-wh-error{color:var(--color-danger,#dc2626);font-size:.8rem;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.intg-wh-pager{align-items:center;display:flex;gap:12px;justify-content:center;margin-top:8px}.intg-wh-pager-text{color:var(--color-text-secondary);font-size:.82rem}.intg-wh-detail{font-size:.88rem;text-align:left}.intg-wh-detail-row{border-bottom:1px solid var(--color-border-light,#f1f5f9);display:flex;gap:12px;padding:4px 0}.intg-wh-detail-label{color:var(--color-text-secondary);font-size:.82rem;min-width:100px}.intg-wh-json{background:var(--color-bg-tertiary,#f1f5f9);border-radius:6px;font-family:var(--font-mono,monospace);font-size:.78rem;margin-top:4px;max-height:200px;overflow:auto;padding:10px;white-space:pre-wrap;word-break:break-all}.intg-features{list-style:none;margin:0;padding:0}.intg-features li{border-bottom:1px solid var(--color-border-light,#f1f5f9);color:var(--color-text-secondary,#64748b);font-size:.88rem;padding:6px 0}.intg-features li:last-child{border-bottom:none}.intg-features li:before{background:#22c55e;border-radius:50%;content:"";display:inline-block;height:6px;margin-right:8px;vertical-align:middle;width:6px}@media (max-width:768px){.intg-grid{grid-template-columns:1fr}.intg-info-grid,.intg-map-form{flex-direction:column}.intg-info-item,.intg-wh-detail-label{min-width:auto}}.call-dir{align-items:center;border-radius:50%;display:inline-flex;font-size:.9rem;font-weight:700;height:24px;justify-content:center;width:24px}.call-dir--inbound{background:var(--badge-info-bg);color:var(--badge-info-text)}.call-dir--outbound{background:#e0e7ff;color:#6366f1}.call-status{font-size:.88rem;font-weight:var(--font-weight-medium,500)}.call-client-link{color:var(--color-primary,#6366f1);font-weight:500;text-decoration:none}.call-client-link:hover{text-decoration:underline}.call-number-link{color:var(--color-primary,#6366f1);cursor:pointer;font-family:var(--font-mono,monospace);font-size:var(--font-size-sm);text-decoration:none}.call-number-link:hover{text-decoration:underline}.call-play-btn--active{background:var(--color-primary-light)!important;color:var(--color-primary)!important}.call-player-row td{background:var(--color-gray-50)}.call-audio-el{border-radius:var(--radius-sm);height:36px;width:100%}.call-popup{animation:callPopupIn .3s ease;background:var(--color-bg,#fff);border-radius:12px;bottom:24px;box-shadow:0 8px 32px rgba(0,0,0,.15),0 0 0 1px rgba(0,0,0,.05);overflow:hidden;position:fixed;right:24px;width:360px;z-index:var(--z-toast)}@keyframes callPopupIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.call-popup--enter,.call-popup--exit{opacity:0;transform:translateY(20px) scale(.95)}.call-popup--exit{transition:all .3s ease}.call-popup-header{align-items:center;background:#22c55e;color:#fff;display:flex;gap:10px;padding:14px 16px}.call-popup-icon{align-items:center;animation:callPulse 1.2s infinite;background:hsla(0,0%,100%,.2);border-radius:50%;display:flex;height:32px;justify-content:center;width:32px}@keyframes callPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.call-popup-title{flex:1;font-weight:600}.call-popup-close{background:none;border:none;color:#fff;cursor:pointer;font-size:1.4rem;line-height:1;opacity:.7}.call-popup-close:hover{opacity:1}.call-popup-body{padding:14px 16px}.call-popup-phone{font-family:var(--font-mono,monospace);font-size:1.1rem;font-weight:600;margin-bottom:8px}.call-popup-client-name{font-weight:500}.call-popup-client-meta{color:var(--color-text-secondary,#64748b);font-size:.82rem;margin-top:2px}.call-popup-unknown{color:var(--color-text-secondary,#94a3b8);font-size:.88rem;font-style:italic}.call-popup-actions{display:flex;gap:8px;justify-content:flex-end;padding:0 16px 14px}.call-popup-btn{font-size:.82rem!important}@media (max-width:480px){.call-popup{bottom:12px;left:12px;right:12px;width:auto}.intg-grid{grid-template-columns:1fr}}.loyalty-tabs{border-bottom:2px solid var(--color-border,#e2e8f0);display:flex;gap:0;margin-bottom:20px}.loyalty-tab{border-bottom:2px solid transparent;color:var(--color-text-secondary,#64748b);font-size:.9rem;font-weight:var(--font-weight-medium,500);margin-bottom:-2px;padding:10px 20px;text-decoration:none;transition:color .15s,border-color .15s}.loyalty-tab:hover{color:var(--color-text,#1e293b)}.loyalty-tab--active{border-bottom-color:var(--color-primary,#6366f1);color:var(--color-primary,#6366f1)}.loyalty-stats-row{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.loyalty-stat-card{background:var(--color-bg-secondary,#f8fafc);border:1px solid var(--color-border,#e2e8f0);border-radius:var(--radius-md,6px);min-width:100px;padding:12px 20px;text-align:center}.loyalty-stat-value{font-size:1.5rem;font-weight:var(--font-weight-bold,700);line-height:1.2}.loyalty-stat-label{color:var(--color-text-secondary,#64748b);font-size:.78rem;margin-top:2px}.loyalty-status-badge{border-radius:12px;display:inline-block;font-size:.78rem;font-weight:var(--font-weight-medium,500);padding:2px 10px}.loyalty-status-badge--active{background:#22c55e15;color:#22c55e}.loyalty-status-badge--expired,.loyalty-status-badge--inactive{background:#94a3b815;color:#94a3b8}.loyalty-status-badge--used{background:#64748b15;color:#64748b}.loyalty-type-badge{border-radius:var(--radius-sm,4px);display:inline-block;font-size:.82rem;padding:2px 8px}.loyalty-prog-name,.loyalty-type-badge{font-weight:var(--font-weight-medium,500)}.loyalty-rules-text{color:var(--color-text-secondary,#64748b);font-size:.85rem}.loyalty-rules-title,.loyalty-section-title{font-size:.9rem;font-weight:var(--font-weight-semibold,600);margin:16px 0 8px}.loyalty-card-code{font-size:.82rem;letter-spacing:.5px}.loyalty-balance{font-weight:var(--font-weight-semibold,600)}.loyalty-balance--positive{color:var(--color-success,#22c55e)}.loyalty-level-badge{color:var(--color-text-secondary,#64748b);font-size:.82rem;text-transform:capitalize}.loyalty-client-link{color:var(--color-primary,#6366f1);text-decoration:none}.loyalty-client-link:hover{text-decoration:underline}.loyalty-empty-state{color:var(--color-text-secondary,#64748b);padding:60px 20px;text-align:center}.loyalty-empty-icon{font-size:3rem;margin-bottom:12px;opacity:.7}.loyalty-empty-state h3{color:var(--color-text,#1e293b);font-size:1.1rem;margin:0 0 8px}.loyalty-empty-state p{font-size:.9rem;margin:0 0 20px}.loyalty-client-search-row{align-items:center;display:flex;gap:6px}.loyalty-client-search-row .input{flex:1}.loyalty-browse-clients-btn{flex-shrink:0;font-size:1rem;padding:6px 10px}.loyalty-client-results{background:var(--color-bg,#fff);border:1px solid var(--color-border,#e2e8f0);border-radius:var(--radius-md,6px);margin-top:4px;max-height:160px;overflow-y:auto;position:relative}.loyalty-client-results:empty{display:none}.loyalty-client-option{border-bottom:1px solid var(--color-border-light,#f1f5f9);cursor:pointer;font-size:.9rem;padding:8px 12px}.loyalty-client-option:hover{background:var(--color-bg-secondary,#f8fafc)}.loyalty-client-option--empty{color:var(--color-text-tertiary,#94a3b8);cursor:default}.loyalty-client-option small{color:var(--color-text-secondary,#64748b);margin-left:8px}.loyalty-detail-grid{display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:16px}.loyalty-detail-balance-card{background:var(--color-bg-secondary,#f8fafc);border-radius:var(--radius-md,6px);padding:20px}.loyalty-detail-balance-label{color:var(--color-text-secondary,#64748b);font-size:.82rem;margin-bottom:4px}.loyalty-detail-balance-value{font-size:2rem;font-weight:var(--font-weight-bold,700);line-height:1.2;margin-bottom:8px}.loyalty-detail-balance-sub{display:flex;font-size:.82rem;gap:16px}.loyalty-detail-info{display:flex;flex-direction:column;gap:8px}.loyalty-detail-row{align-items:center;display:flex;font-size:.9rem;justify-content:space-between;padding:4px 0}.loyalty-detail-label{color:var(--color-text-secondary,#64748b);font-size:.85rem}.loyalty-detail-actions{display:flex;gap:8px;margin-bottom:16px}.loyalty-tx-type{font-size:.85rem;font-weight:var(--font-weight-medium,500)}.loyalty-cert-balance-cell{display:flex;flex-direction:column;gap:4px}.loyalty-cert-progress{background:var(--color-border,#e2e8f0);border-radius:2px;height:3px;overflow:hidden;width:100%}.loyalty-cert-progress-bar{background:var(--color-success,#22c55e);border-radius:2px;height:100%;transition:width .3s}.loyalty-cert-service{color:var(--color-text-secondary,#64748b);font-size:.78rem;margin-top:2px}.loyalty-check-result{background:var(--color-bg-secondary,#f8fafc);border-radius:var(--radius-md,6px);margin-top:16px;padding:16px}.loyalty-check-result--error{background:#fef2f215}.loyalty-check-result--error p{font-size:.9rem;margin:8px 0 0}.loyalty-check-status{font-size:1.1rem;font-weight:var(--font-weight-semibold,600);margin-bottom:12px}.loyalty-check-grid{display:flex;flex-direction:column;gap:6px}.loyalty-tier-row{border-bottom:1px solid var(--color-border-light,#f1f5f9);padding:8px 0}.cl-loyalty{padding:4px 0}.cl-summary-row{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.cl-summary-item{align-items:center;background:var(--color-gray-50);border:1px solid var(--color-gray-100);border-radius:var(--radius-md);display:flex;flex:1;flex-direction:column;min-width:80px;padding:12px 20px}.cl-summary-value{color:var(--color-gray-800);font-size:1.4rem;font-weight:700;line-height:1.2}.cl-summary-earned{color:#22c55e}.cl-summary-spent{color:#ef4444}.cl-summary-label{color:var(--color-gray-400);font-size:.75rem;margin-top:2px}.cl-cards-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:20px}.cl-card{background:linear-gradient(135deg,var(--cl-accent,#6366f1) 0,color-mix(in srgb,var(--cl-accent) 70%,#000) 100%);border-radius:14px;color:#fff;overflow:hidden;padding:18px;position:relative}.cl-card:before{background:hsla(0,0%,100%,.08);border-radius:50%;content:"";height:100px;position:absolute;right:-30px;top:-30px;width:100px}.cl-card-top{justify-content:space-between;margin-bottom:14px}.cl-card-program,.cl-card-top{align-items:center;display:flex}.cl-card-program{font-size:.88rem;font-weight:600;gap:6px}.cl-card-type-dot{background:#fff!important;border-radius:50%;flex-shrink:0;height:8px;opacity:.7;width:8px}.cl-card-level{background:hsla(0,0%,100%,.15);border-radius:10px;font-size:.72rem;letter-spacing:.05em;opacity:.8;padding:2px 8px;text-transform:uppercase}.cl-card-balance-row{margin-bottom:14px}.cl-card-balance{font-size:2.2rem;font-weight:700;line-height:1.1}.cl-card-balance-label{font-size:.78rem;opacity:.7}.cl-card-stats{border-top:1px solid hsla(0,0%,100%,.15);display:flex;gap:20px;margin-bottom:14px;padding-top:10px}.cl-card-stat-value{color:#fff!important;font-size:.88rem;font-weight:600}.cl-card-stat-label{display:block;font-size:.72rem;opacity:.6}.cl-card-footer{align-items:center;display:flex;justify-content:space-between}.cl-card-number{font-family:var(--font-mono,monospace);font-size:.75rem;letter-spacing:.05em;opacity:.5}.cl-card-actions{display:flex;gap:4px}.cl-card-actions .btn{background:hsla(0,0%,100%,.1);border-color:hsla(0,0%,100%,.3);border-radius:6px;color:#fff;font-size:.75rem;padding:4px 10px}.cl-card-actions .btn:hover{background:hsla(0,0%,100%,.25)}.cl-empty{color:var(--color-gray-400);padding:32px 16px;text-align:center}.cl-empty svg{margin-bottom:12px}.cl-empty-text{color:var(--color-gray-500);font-size:.95rem;margin-bottom:4px}.cl-empty-hint{font-size:.82rem}.cl-empty-hint a{color:var(--color-primary);text-decoration:none}.cl-tx-section{margin-top:20px}.cl-tx-title{color:var(--color-gray-700);font-size:.95rem;font-weight:600;margin-bottom:10px}.cl-tx-list{display:flex;flex-direction:column;gap:2px}.cl-tx-row{align-items:center;border-radius:var(--radius-md);display:flex;gap:12px;padding:10px 12px;transition:background .15s}.cl-tx-row:hover{background:var(--color-gray-50)}.cl-tx-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:1rem;font-weight:700;height:32px;justify-content:center;width:32px}.cl-tx-info{display:flex;flex:1;flex-direction:column;min-width:0}.cl-tx-label{font-size:.85rem;font-weight:500}.cl-tx-desc{color:var(--color-gray-400);font-size:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cl-tx-right{flex-shrink:0;text-align:right}.cl-tx-amount{display:block;font-size:.92rem;font-weight:600}.cl-tx-date{color:var(--color-gray-400);font-size:.72rem}.cc-section{padding:4px 0}.cc-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.cc-card{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:12px;padding:16px;transition:box-shadow .15s}.cc-card:hover{box-shadow:0 2px 8px rgba(0,0,0,.06)}.cc-card--inactive{opacity:.6}.cc-card-top{justify-content:space-between;margin-bottom:10px}.cc-card-top,.cc-card-type{align-items:center;display:flex}.cc-card-type{color:var(--color-gray-500);font-size:.82rem;font-weight:500;gap:6px}.cc-status{border-radius:10px;font-size:.72rem;font-weight:600;letter-spacing:.03em;padding:3px 8px;text-transform:uppercase}.cc-code{color:var(--color-gray-800);font-family:var(--font-mono,monospace);font-size:1.1rem;font-weight:700;letter-spacing:.08em}.cc-balance-section,.cc-code{margin-bottom:12px}.cc-balance-row{align-items:baseline;display:flex;gap:8px;margin-bottom:6px}.cc-balance{color:var(--color-gray-800);font-size:1.4rem;font-weight:700}.cc-nominal{color:var(--color-gray-400);font-size:.82rem}.cc-progress{background:var(--color-gray-100);border-radius:3px;height:6px;overflow:hidden}.cc-progress-bar{border-radius:3px;height:100%;transition:width .3s}.cc-dates{color:var(--color-gray-400);font-size:.78rem;margin-bottom:4px}.cc-dates,.cc-detail-row{display:flex;justify-content:space-between}.cc-detail-row{border-top:1px solid var(--color-gray-50);font-size:.82rem;padding:4px 0}.cc-detail-label{color:var(--color-gray-400)}.cc-detail-value{font-weight:500}@media (max-width:768px){.cc-grid,.cl-cards-grid{grid-template-columns:1fr}.cl-summary-row{gap:8px}.cl-summary-item{min-width:60px;padding:10px 12px}.cl-summary-value{font-size:1.1rem}.cl-card-balance{font-size:1.8rem}.cl-card-actions{flex-direction:column;gap:2px}.cl-tx-row{gap:8px;padding:8px}.loyalty-stats-row{flex-wrap:wrap;gap:8px}.loyalty-stat-card{flex:1 1 calc(50% - 4px);min-width:0;padding:10px 14px}.loyalty-stat-value{font-size:1.2rem}.loyalty-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.loyalty-tab{font-size:.85rem;padding:8px 14px;white-space:nowrap}.loyalty-detail-grid{grid-template-columns:1fr}.loyalty-detail-balance-value{font-size:1.5rem}.loyalty-detail-balance-sub{flex-direction:column;gap:4px}}.header-notif-wrapper{position:relative}.notif-dropdown{animation:notifDropIn .18s ease;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:0 16px 48px rgba(0,0,0,.14),0 4px 12px rgba(0,0,0,.06);overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:380px;z-index:100}@keyframes notifDropIn{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.notif-dropdown-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;font-size:.92rem;font-weight:600;justify-content:space-between;padding:14px 16px}.notif-header-count{align-items:center;background:var(--color-primary);border-radius:10px;color:#fff;display:inline-flex;font-size:.72rem;font-weight:700;height:20px;justify-content:center;margin-left:6px;min-width:20px;padding:0 6px}.notif-mark-all{background:none;border:none;border-radius:var(--radius-sm);color:var(--color-primary);cursor:pointer;font-size:.78rem;padding:4px 8px;transition:background .15s}.notif-mark-all:hover{background:color-mix(in srgb,var(--color-primary) 8%,transparent)}.notif-dropdown-list{max-height:400px;overflow-y:auto}.notif-dropdown-group-label{background:var(--color-gray-50);color:var(--text-secondary);font-size:.7rem;font-weight:600;letter-spacing:.05em;padding:8px 16px 4px;position:sticky;text-transform:uppercase;top:0;z-index:1}.notif-dropdown-empty{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;gap:8px;padding:36px 16px;text-align:center}.notif-dropdown-empty p{font-size:.88rem;margin:0}.notif-dropdown-empty-sub{font-size:.78rem;line-height:1.4;max-width:240px;opacity:.6}.notif-dropdown-item{align-items:flex-start;border-bottom:1px solid var(--border-color);cursor:pointer;display:flex;gap:10px;padding:10px 16px;transition:background .15s}.notif-dropdown-item:last-child{border-bottom:none}.notif-dropdown-item:hover{background:var(--bg-secondary)}.notif-dropdown-item--unread{background:color-mix(in srgb,var(--color-primary) 5%,transparent)}.notif-dropdown-item--unread .notif-dropdown-item-title{font-weight:600}.notif-dropdown-icon{align-items:center;background:var(--color-gray-50);border-radius:var(--radius-md);display:flex;flex-shrink:0;font-size:1.1rem;height:28px;justify-content:center;width:28px}.notif-dropdown-item--unread .notif-dropdown-icon{background:color-mix(in srgb,var(--color-primary) 10%,transparent)}.notif-dropdown-item-content{flex:1;min-width:0}.notif-dropdown-item-title{font-size:.84rem;font-weight:500;line-height:1.3;margin-bottom:2px}.notif-dropdown-item-body{color:var(--text-secondary);font-size:.78rem;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-dropdown-item-time{color:var(--text-tertiary,#999);flex-shrink:0;font-size:.7rem;margin-top:2px;white-space:nowrap}.notif-dropdown-footer-links{border-top:1px solid var(--border-color);display:flex}.notif-dropdown-footer-link{align-items:center;color:var(--text-secondary);display:flex;flex:1;font-size:.8rem;gap:6px;justify-content:center;padding:10px 16px;text-decoration:none;transition:all .15s}.notif-dropdown-footer-link:hover{background:var(--bg-secondary);color:var(--color-primary)}.notif-dropdown-footer-link+.notif-dropdown-footer-link{border-left:1px solid var(--border-color)}@keyframes notifBadgePulse{0%{transform:scale(1)}30%{transform:scale(1.3)}60%{transform:scale(.9)}to{transform:scale(1)}}.notif-badge-pulse{animation:notifBadgePulse .4s ease}@keyframes notifBtnRing{0%,to{transform:rotate(0)}15%{transform:rotate(14deg)}30%{transform:rotate(-12deg)}45%{transform:rotate(8deg)}60%{transform:rotate(-6deg)}75%{transform:rotate(2deg)}}.notif-btn-ring svg{animation:notifBtnRing .6s ease}@media (max-width:480px){.notif-dropdown{right:-12px;width:calc(100vw - 24px)}}.ob-page{padding:var(--spacing-lg)}.ob-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:var(--spacing-sm);justify-content:space-between;margin-bottom:var(--spacing-lg)}.ob-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}.ob-subtitle{color:var(--color-gray-500);margin-top:4px}.ob-status,.ob-subtitle{font-size:var(--font-size-sm)}.ob-status{align-items:center;border-radius:var(--radius-full);display:flex;font-weight:var(--font-weight-medium);gap:6px;padding:6px 14px}.ob-status--active{background:var(--color-success-light);color:var(--badge-success-text)}.ob-status--inactive{background:var(--color-gray-100);color:var(--color-gray-500)}.ob-status-dot{border-radius:50%;height:8px;width:8px}.ob-status--active .ob-status-dot{background:#16a34a}.ob-status--inactive .ob-status-dot{background:var(--color-gray-400)}.ob-settings-grid{align-items:start;display:grid;gap:var(--spacing-lg);grid-template-columns:1fr 1fr}.ob-col{display:flex;flex-direction:column;gap:var(--spacing-md)}.ob-card{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.ob-card-header{gap:10px;margin-bottom:var(--spacing-md)}.ob-card-header,.ob-card-icon{align-items:center;display:flex}.ob-card-icon{background:var(--color-primary-light);border-radius:var(--radius-md);color:var(--color-primary);flex-shrink:0;height:36px;justify-content:center;width:36px}.ob-card-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold)}.ob-toggle-row{align-items:center;background:var(--color-gray-50);border-radius:var(--radius-md);display:flex;gap:12px;margin-bottom:var(--spacing-md);padding:12px 14px}.ob-toggle{cursor:pointer;flex-shrink:0;height:24px;position:relative;width:44px}.ob-toggle input{display:none}.ob-toggle-slider{background:var(--color-gray-300);border-radius:12px;inset:0;position:absolute;transition:background var(--transition-fast)}.ob-toggle-slider:before{background:#fff;border-radius:50%;box-shadow:0 1px 3px rgba(0,0,0,.15);content:"";height:18px;left:3px;position:absolute;top:3px;transition:transform var(--transition-fast);width:18px}.ob-toggle input:checked+.ob-toggle-slider{background:var(--color-primary)}.ob-toggle input:checked+.ob-toggle-slider:before{transform:translateX(20px)}.ob-toggle-text{display:flex;flex-direction:column;gap:2px}.ob-toggle-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.ob-toggle-hint{color:var(--color-gray-500);font-size:var(--font-size-xs)}.ob-form-grid{display:grid;gap:var(--spacing-sm) var(--spacing-md);grid-template-columns:1fr 1fr;margin-bottom:var(--spacing-md)}.ob-input-suffix{position:relative}.ob-input-suffix .input{padding-right:40px}.ob-suffix{color:var(--color-gray-400);font-size:var(--font-size-xs);pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.ob-checks-row{display:flex;flex-wrap:wrap;gap:var(--spacing-lg)}.ob-check{align-items:center;color:var(--color-gray-700);cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:8px}.ob-check input{display:none}.ob-check-mark{align-items:center;border:2px solid var(--color-gray-300);border-radius:4px;display:flex;flex-shrink:0;height:18px;justify-content:center;transition:all var(--transition-fast);width:18px}.ob-check input:checked~.ob-check-mark{background:var(--color-primary);border-color:var(--color-primary)}.ob-check input:checked~.ob-check-mark:after{border:solid #fff;border-width:0 2px 2px 0;content:"";height:9px;margin-top:-2px;transform:rotate(45deg);width:5px}.ob-prepay-field{margin-top:var(--spacing-sm);max-width:200px;transition:opacity var(--transition-fast)}.ob-prepay-field--hidden{opacity:.4;pointer-events:none}.ob-colors-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.ob-color-field{flex:1;min-width:100px}.ob-color-pick{align-items:center;display:flex;gap:8px;margin-top:4px}.ob-color-pick input[type=color]{background:none;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);cursor:pointer;height:36px;padding:2px;width:36px}.ob-color-value{color:var(--color-gray-500);font-family:var(--font-mono);font-size:var(--font-size-xs)}.ob-save-btn{width:100%}.ob-link-section{margin-bottom:var(--spacing-md)}.ob-copy-row{align-items:center;display:flex;gap:6px;margin-top:6px}.ob-copy-input{flex:1;font-family:var(--font-mono)}.ob-copy-input,.ob-embed-code{font-size:var(--font-size-xs)!important}.ob-embed-code{font-family:var(--font-mono)!important;margin-top:6px;resize:vertical}.ob-copy-embed-btn{margin-top:6px}.ob-token-section{align-items:center;border-top:1px solid var(--color-gray-100);display:flex;gap:var(--spacing-sm);justify-content:space-between;margin-top:var(--spacing-md);padding-top:var(--spacing-md)}.ob-token-info{align-items:center;display:flex;gap:6px;min-width:0}.ob-token-label{color:var(--color-gray-500);flex-shrink:0;font-size:var(--font-size-xs)}.ob-token-code{background:var(--color-gray-50);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:var(--font-size-xs);max-width:200px;overflow:hidden;padding:3px 8px;text-overflow:ellipsis;white-space:nowrap}.ob-empty-token{align-items:center;display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-xl) var(--spacing-md);text-align:center}.ob-empty-text{color:var(--color-gray-500);font-size:var(--font-size-sm);max-width:280px}.ob-card--preview{overflow:hidden;padding:0}.ob-card--preview .ob-card-header{border-bottom:1px solid var(--color-gray-100);margin-bottom:0;padding:var(--spacing-md) var(--spacing-lg)}.ob-preview-wrap{background:var(--color-gray-50)}.ob-preview-frame{border:none;display:block;height:500px;width:100%}.ob-preview-container{max-height:520px;overflow-y:auto}@media (max-width:900px){.ob-settings-grid{grid-template-columns:1fr}}@media (max-width:768px){.ob-page{padding:var(--spacing-md)}.ob-form-grid{grid-template-columns:1fr}.ob-colors-grid{flex-direction:column}.ob-preview-frame{height:350px}.ob-header,.ob-token-section{flex-direction:column}.ob-token-section{align-items:flex-start}.ob-token-code{max-width:160px}}.salary-page{margin:0 auto;max-width:1200px;padding:var(--spacing-md)}.sal-header{justify-content:space-between;margin-bottom:var(--spacing-md)}.sal-header,.sal-header-left{align-items:center;display:flex}.sal-header-left{gap:var(--spacing-sm)}.sal-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin:0}.sal-title-count{color:var(--color-gray-400);font-size:12px;font-weight:400}.sal-header-actions{align-items:center;display:flex;gap:var(--spacing-sm)}.sal-mode-toggle{background:var(--bg-secondary,var(--color-gray-100));border-radius:var(--radius-md);display:flex;gap:2px;padding:2px}.sal-rules-link{align-items:center;display:flex;gap:4px}.sal-back-btn{margin-right:var(--spacing-xs)}.sal-month-nav{align-items:center;display:flex;gap:var(--spacing-md);justify-content:center;margin-bottom:var(--spacing-lg)}.sal-month-label{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);min-width:200px;text-align:center}.sal-today-btn{font-size:12px}.sal-summary-cards{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(3,1fr);margin-bottom:var(--spacing-md)}.sal-summary-card{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-md) var(--spacing-lg);transition:box-shadow var(--transition-fast)}.sal-summary-card[data-filter]{cursor:pointer}.sal-summary-card[data-filter]:hover{box-shadow:0 2px 8px rgba(0,0,0,.06)}.sal-summary-card--total{border-left:3px solid var(--color-primary,#6366f1)}.sal-summary-card--paid{border-left:3px solid #22c55e}.sal-summary-card--pending{border-left:3px solid #f59e0b}.sal-summary-label{color:var(--color-gray-500);font-size:var(--font-size-xs);letter-spacing:.05em;margin-bottom:4px;text-transform:uppercase}.sal-summary-value{font-size:1.5rem;font-weight:var(--font-weight-bold)}.sal-summary-sub{color:var(--color-gray-400);font-size:var(--font-size-xs);margin-top:2px}.sal-progress{margin-bottom:var(--spacing-lg)}.sal-progress-bar{background:var(--color-gray-100);border-radius:4px;display:flex;height:8px;overflow:hidden}.sal-progress-seg{transition:width .4s ease}.sal-progress--paid{background:#22c55e}.sal-progress--approved{background:#f59e0b}.sal-progress-legend{display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-top:6px}.sal-progress-leg{align-items:center;color:var(--color-gray-500);display:flex;font-size:12px;gap:4px}.sal-dot--paid-lg{background:#22c55e}.sal-dot--approved-lg,.sal-dot--paid-lg{border-radius:50%;flex-shrink:0;height:8px;width:8px}.sal-dot--approved-lg{background:#f59e0b}.sal-dot--draft-lg{background:var(--color-gray-300);border-radius:50%;flex-shrink:0;height:8px;width:8px}.sal-filters{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm);justify-content:space-between;margin-bottom:var(--spacing-md)}.sal-status-tabs{background:var(--color-gray-100);border-radius:var(--radius-md);display:flex;gap:2px;padding:2px}.sal-status-tab{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-gray-500);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:4px;padding:5px 12px;transition:all var(--transition-fast)}.sal-status-tab:hover{color:var(--color-text)}.sal-status-tab--active{background:var(--color-white);box-shadow:0 1px 3px rgba(0,0,0,.08);color:var(--color-text)}.sal-tab-count{background:var(--color-gray-200);border-radius:8px;color:var(--color-gray-600);font-size:11px;min-width:18px;padding:0 5px;text-align:center}.sal-tab-count--warn{background:var(--badge-warning-bg);color:#b45309}.sal-tab-count--ok{background:var(--badge-success-bg);color:var(--badge-success-text)}.sal-status-tab--active .sal-tab-count{background:var(--color-primary);color:#fff}.sal-filters-right{align-items:center;display:flex;gap:var(--spacing-sm)}.sal-search-wrap{position:relative}.sal-search-icon{color:var(--color-gray-400);left:8px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.sal-search{padding-left:28px!important}.sal-search,.sal-staff-select{min-width:160px}.sal-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.sal-danger-btn{color:var(--color-danger,#ef4444)!important}.btn--success{background:#22c55e;border-color:#22c55e;color:#fff}.btn--success:hover{background:#16a34a;border-color:var(--badge-success-text)}.sal-staff-grid{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.sal-staff-card{background:var(--color-white);border-left:1px solid var(--color-gray-200);border:1px solid var(--color-gray-200);border-left-width:3px;border-radius:var(--radius-lg);cursor:pointer;padding:var(--spacing-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.sal-staff-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.06);transform:translateY(-1px)}.sal-staff-card--draft{border-left-color:#94a3b8}.sal-staff-card--draft:hover{border-color:#94a3b8}.sal-staff-card--approved{border-left-color:#f59e0b}.sal-staff-card--approved:hover{border-color:#f59e0b}.sal-staff-card--paid{border-left-color:#22c55e}.sal-staff-card--paid:hover{border-color:#22c55e}.sal-avatar{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:13px;font-weight:600;height:36px;justify-content:center;letter-spacing:.02em;width:36px}.sal-avatar--muted{font-weight:700}.sal-card-identity{align-items:center;display:flex;gap:10px}.sal-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:var(--spacing-sm)}.sal-card-name{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);line-height:1.3}.sal-card-meta{color:var(--color-gray-400);display:flex;flex-wrap:wrap;font-size:12px;gap:8px}.sal-card-meta span{align-items:center;display:flex;gap:2px}.sal-badge{border-radius:10px;font-size:11px;font-weight:600;letter-spacing:.03em;padding:2px 8px;text-transform:uppercase;white-space:nowrap}.sal-badge--draft{background:#f1f5f9;color:#64748b}.sal-badge--approved{background:var(--badge-warning-bg);color:#b45309}.sal-badge--paid{background:var(--badge-success-bg);color:var(--badge-success-text)}.sal-card-body{padding:0 0 var(--spacing-sm)}.sal-card-total{font-size:1.25rem;font-weight:var(--font-weight-bold);margin-bottom:4px}.sal-card-penalty{color:var(--color-danger,#ef4444);font-size:12px;margin-bottom:6px}.sal-card-bar{background:var(--color-gray-100);border-radius:3px;display:flex;height:5px;margin-bottom:8px;overflow:hidden}.sal-bar-seg{min-width:2px;transition:width .3s ease}.sal-bar-base{background:#6366f1}.sal-bar-comm{background:#3b82f6}.sal-bar-bonus{background:#22c55e}.sal-card-breakdown{display:flex;flex-wrap:wrap;gap:4px 12px}.sal-card-item{align-items:center;color:var(--color-gray-500);display:flex;font-size:12px;gap:3px}.sal-card-item--penalty{color:var(--color-danger)}.sal-dot{border-radius:50%;flex-shrink:0;height:7px;width:7px}.sal-dot--base{background:#6366f1}.sal-dot--comm{background:#3b82f6}.sal-dot--bonus{background:#22c55e}.sal-dot--penalty{background:#ef4444}.sal-card-actions{align-items:center;border-top:1px solid var(--color-gray-100);display:flex;gap:var(--spacing-xs);padding-top:var(--spacing-sm)}.sal-card-actions-right{display:flex;gap:2px;margin-left:auto}.sal-paid-label{align-items:center;color:var(--badge-success-text);display:flex;font-size:13px;font-weight:500;gap:4px}.sal-empty{color:var(--color-gray-400);padding:48px 16px;text-align:center}.sal-empty-icon{margin-bottom:12px}.sal-empty p{font-size:15px;margin:0 0 4px}.sal-empty-hint{color:var(--color-gray-400);font-size:13px}.sal-pay-summary{background:var(--color-bg-secondary,#f8fafc);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);padding:12px 16px}.sal-pay-summary-row{align-items:center;color:var(--color-gray-600);display:flex;font-size:14px;justify-content:space-between;padding:4px 0}.sal-pay-summary-total{border-top:1px solid var(--color-gray-200);font-size:15px;margin-top:4px;padding-top:8px}.sal-pay-summary-total strong{font-size:1.1rem}.sal-staff-card--empty{border-style:dashed;border-left:3px dashed var(--color-gray-200);cursor:default;opacity:.8}.sal-staff-card--empty:hover{border-color:var(--color-gray-300);box-shadow:none;opacity:1;transform:none}.sal-uncalc-section{margin-top:var(--spacing-xl,32px)}.sal-uncalc-header{align-items:center;display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.sal-uncalc-title{color:var(--color-gray-500);font-size:14px;font-weight:500;margin:0}.sal-uncalc-count{background:var(--color-gray-200);border-radius:8px;color:var(--color-gray-600);font-size:11px;padding:1px 6px}.sal-skeleton{padding:var(--spacing-md)}.sal-skeleton-header{animation:skeleton-pulse 1.5s ease-in-out infinite;background:var(--color-gray-100);border-radius:var(--radius-md);height:32px;margin-bottom:var(--spacing-lg);width:200px}.sal-skeleton-cards{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(3,1fr);margin-bottom:var(--spacing-lg)}.sal-skeleton-card{animation:skeleton-pulse 1.5s ease-in-out infinite;background:var(--color-gray-100);border-radius:var(--radius-lg);height:90px}.sal-skeleton-grid{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.sal-skeleton-item{animation:skeleton-pulse 1.5s ease-in-out infinite;background:var(--color-gray-100);border-radius:var(--radius-lg);height:180px}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.5}}.salary-detail-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:var(--spacing-sm)}.salary-detail-name{font-size:1.1rem;font-weight:600}.salary-detail-position{color:var(--color-gray-500);font-size:13px;margin-top:1px}.salary-detail-period{color:var(--color-gray-400);font-size:13px;margin-top:2px}.salary-detail-status-wrap{flex-shrink:0}.sal-steps{gap:0;justify-content:center;margin-bottom:var(--spacing-md);padding:12px 0}.sal-step,.sal-steps{align-items:center;display:flex}.sal-step{flex-direction:column;flex-shrink:0;gap:4px}.sal-step-dot{align-items:center;background:var(--color-gray-200);border-radius:50%;color:var(--color-gray-500);display:flex;font-size:11px;font-weight:600;height:24px;justify-content:center;transition:all .3s ease;width:24px}.sal-step--done .sal-step-dot{background:#22c55e;color:#fff}.sal-step--current .sal-step-dot{background:var(--color-primary,#6366f1);box-shadow:0 0 0 3px rgba(99,102,241,.2);color:#fff}.sal-step--current.sal-step--done .sal-step-dot{background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.2)}.sal-step-label{color:var(--color-gray-400);font-size:11px}.sal-step--done .sal-step-label{color:var(--color-gray-600)}.sal-step--current .sal-step-label{color:var(--color-text);font-weight:600}.sal-step-line{background:var(--color-gray-200);flex:1;height:2px;margin:0 8px 18px;min-width:32px;transition:background .3s ease}.sal-step-line--done{background:#22c55e}.salary-detail-overview{align-items:center;background:var(--color-bg-secondary,#f8fafc);border-radius:var(--radius-lg);display:flex;justify-content:space-between;margin-bottom:var(--spacing-md);padding:var(--spacing-md)}.salary-detail-total-label{color:var(--color-gray-500);font-size:12px;letter-spacing:.05em;text-transform:uppercase}.salary-detail-total-value{font-size:1.75rem;font-weight:700;margin-top:2px}.salary-detail-kpis{display:flex;gap:var(--spacing-lg)}.salary-kpi{text-align:center}.salary-kpi-num{font-size:1.25rem;font-weight:700;line-height:1.2}.salary-kpi-label{color:var(--color-gray-500);font-size:11px}.salary-detail-summary{border-bottom:1px solid var(--color-gray-100);display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md)}.salary-summary-item{align-items:center;display:flex;font-size:14px;gap:var(--spacing-sm)}.salary-summary-item span{align-items:center;color:var(--color-gray-500);display:flex;font-size:13px;gap:4px}.salary-summary-item strong{font-weight:600}.salary-detail-bar{background:var(--color-gray-100);border-radius:3px;display:flex;height:6px;margin-bottom:var(--spacing-md);overflow:hidden}.salary-detail-group{margin-bottom:var(--spacing-xs)}.salary-detail-group-title{align-items:center;border-bottom:1px solid var(--color-gray-100);color:var(--color-gray-600);cursor:pointer;display:flex;font-size:13px;font-weight:600;justify-content:space-between;padding:8px 0;user-select:none}.salary-detail-group-title:hover{color:var(--color-text)}.sal-group-right{align-items:center;display:flex;gap:8px}.sal-group-count{background:var(--color-gray-100);border-radius:8px;color:var(--color-gray-500);font-size:11px;padding:1px 6px}.sal-group-chevron{transition:transform .2s ease}.sal-group-chevron--collapsed{transform:rotate(-90deg)}.salary-detail-row{align-items:center;border-bottom:1px solid var(--color-border-light,#f1f5f9);display:flex;gap:var(--spacing-sm);padding:6px 0 6px 12px}.salary-detail-desc{align-items:center;color:var(--color-gray-600);display:flex;flex:1;font-size:13px;gap:4px}.salary-visit-link{align-items:center;color:var(--color-primary);display:inline-flex;font-size:12px;gap:4px;text-decoration:none}.salary-visit-link:hover{text-decoration:underline}.salary-detail-amount{font-size:13px;font-weight:500;white-space:nowrap}.salary-visit-group{border-left:2px solid var(--color-border);margin:2px 0;padding-left:10px}.salary-visit-header{align-items:center;display:flex;flex-wrap:wrap;font-size:12px;gap:8px;padding:5px 0 3px}.salary-visit-client,.salary-visit-date{color:var(--color-gray-500)}.salary-visit-client:before{content:"·";margin-right:4px}.salary-visit-total{font-size:12px;font-weight:600;margin-left:auto}.salary-detail-add{border-top:1px solid var(--color-gray-100);margin-top:var(--spacing-md);padding-top:var(--spacing-md)}.salary-detail-add-title{color:var(--color-gray-600);font-size:13px;font-weight:600;margin-bottom:var(--spacing-sm)}.salary-add-form{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.salary-add-form .input--sm{min-width:80px;width:auto}.sal-add-desc{flex:1;min-width:120px}.salary-detail-actions{align-items:center;border-top:1px solid var(--color-gray-100);justify-content:space-between;margin-top:var(--spacing-md);padding-top:var(--spacing-md)}.salary-detail-actions,.salary-detail-actions-right{display:flex;gap:var(--spacing-sm)}.sal-rules-group{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);margin-bottom:var(--spacing-md);overflow:hidden}.sal-rules-group-header{align-items:center;border-bottom:1px solid var(--color-gray-100);display:flex;justify-content:space-between;padding:var(--spacing-md)}.sal-rules-list{padding:0 var(--spacing-md)}.sal-rule-row{align-items:center;border-bottom:1px solid var(--color-gray-50,#f8fafc);display:flex;justify-content:space-between;padding:10px 0;transition:opacity var(--transition-fast)}.sal-rule-row:last-child{border-bottom:none}.sal-rule-row--inactive{opacity:.5}.sal-rule-info{display:flex;flex-direction:column;gap:2px}.sal-rule-type{font-size:14px;font-weight:500}.sal-rule-service{color:var(--color-gray-400);font-size:12px}.sal-rule-actions{align-items:center;display:flex;gap:var(--spacing-sm)}.sal-rule-value{font-size:14px;font-weight:600;min-width:60px;text-align:right}.sal-rule-toggle{cursor:pointer;display:inline-flex;position:relative}.sal-toggle-input{height:0;opacity:0;position:absolute;width:0}.sal-toggle-track{background:var(--color-gray-300);border-radius:9px;height:18px;position:relative;transition:background .2s ease;width:32px}.sal-toggle-track:after{background:#fff;border-radius:50%;box-shadow:0 1px 2px rgba(0,0,0,.15);content:"";height:14px;left:2px;position:absolute;top:2px;transition:transform .2s ease;width:14px}.sal-toggle-input:checked+.sal-toggle-track{background:#22c55e}.sal-toggle-input:checked+.sal-toggle-track:after{transform:translateX(14px)}.sal-no-rules-list{display:flex;flex-direction:column;gap:2px}.sal-no-rules-item{align-items:center;background:var(--color-white);border:1px dashed var(--color-gray-200);border-radius:var(--radius-md);display:flex;justify-content:space-between;padding:8px var(--spacing-md)}@media (max-width:768px){.sal-staff-grid,.sal-summary-cards{grid-template-columns:1fr}.sal-month-nav{margin-bottom:var(--spacing-md)}.sal-header{align-items:flex-start;flex-direction:column;gap:var(--spacing-sm)}.sal-filters{align-items:stretch;flex-direction:column}.sal-status-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.sal-filters-right{flex-wrap:wrap}.sal-search{min-width:120px}.salary-detail-overview{align-items:flex-start;flex-direction:column;gap:var(--spacing-md)}.salary-detail-kpis{gap:var(--spacing-md)}.salary-detail-summary{flex-direction:column;gap:var(--spacing-xs)}.salary-add-form{align-items:stretch;flex-direction:column}.sal-card-actions{flex-wrap:wrap}.sal-skeleton-cards,.sal-skeleton-grid{grid-template-columns:1fr}.sal-rules-group-header{align-items:flex-start;flex-direction:column;gap:var(--spacing-sm)}.sal-steps{gap:0;padding:8px 0}.sal-step-line{min-width:20px}.sal-toolbar{gap:var(--spacing-xs)}.sal-pay-summary{padding:10px 12px}}.services-page{padding:var(--spacing-lg)}.services-header{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm);justify-content:space-between;margin-bottom:var(--spacing-md)}.services-title{align-items:center;display:flex;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);gap:8px}.services-count{background:var(--color-gray-100);border-radius:10px;color:var(--color-gray-400);font-size:var(--font-size-sm);font-weight:500;padding:2px 8px}.services-actions{display:flex;gap:8px}.services-filters{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.services-search{flex:1;max-width:400px;min-width:200px;position:relative}.services-search-icon{color:var(--color-gray-400);left:10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.services-search-input{padding-left:32px;padding-right:28px;width:100%}.services-search-clear{background:none;border:none;color:var(--color-gray-400);cursor:pointer;font-size:18px;line-height:1;padding:0 4px;position:absolute;right:8px;top:50%;transform:translateY(-50%)}.services-search-clear:hover{color:var(--text-primary)}.services-table{margin-bottom:var(--spacing-md)}.services-cards{display:none}.svc-chips{display:flex;gap:6px;margin-bottom:var(--spacing-sm);overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px;scrollbar-width:none}.svc-chips::-webkit-scrollbar{display:none}.svc-chip{align-items:center;background:var(--color-white);border:1px solid var(--border-color);border-radius:16px;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:var(--font-size-sm);gap:5px;padding:4px 12px;transition:all var(--transition-fast);white-space:nowrap}.svc-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.svc-chip--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.svc-chip--active:hover{background:color-mix(in srgb,var(--color-primary) 85%,#000);color:#fff}.svc-chip-count{font-size:.7rem;opacity:.6}.svc-chip--active .svc-chip-count{opacity:.8}.svc-table-sticky thead th{background:var(--color-white);position:sticky;top:0;z-index:2}.svc-name-cell{align-items:center;display:flex;gap:8px}.svc-name{font-weight:500}.svc-col-dur{white-space:nowrap;width:100px}.svc-col-price{text-align:right;white-space:nowrap;width:120px}.svc-col-online{width:70px}.svc-col-actions{text-align:right;width:80px}.svc-row-actions{display:flex;gap:2px;justify-content:flex-end;opacity:0;transition:opacity var(--transition-fast)}.svc-row:hover .svc-row-actions{opacity:1}.svc-color{border-radius:50%;display:inline-block;flex-shrink:0;height:10px;width:10px}.svc-color--lg{height:14px;width:14px}.svc-badge{border-radius:10px;font-size:.72rem;font-weight:600;padding:2px 8px;white-space:nowrap}.svc-badge--online{background:var(--badge-success-bg);color:var(--badge-success-text)}.svc-badge--offline{background:var(--color-gray-100);color:var(--color-gray-400)}.svc-online-toggle{border:none;cursor:pointer;transition:all var(--transition-fast)}.svc-online-toggle:hover{opacity:.7;transform:scale(1.05)}.svc-card-name mark,.svc-name mark{background:#fef08a;border-radius:2px;color:inherit;padding:0 1px}.svc-group-header{cursor:pointer}.svc-group-header td{border-bottom:1px solid var(--border-color)}.svc-group-toggle{align-items:center;display:flex;gap:8px}.svc-group-arrow{color:var(--color-gray-400);flex-shrink:0;transition:transform .2s}.svc-group-arrow--collapsed{transform:rotate(-90deg)}.svc-group-count{background:var(--color-gray-200);border-radius:8px;color:var(--color-gray-400);font-size:var(--font-size-xs);padding:1px 6px}.svc-group-header-card{display:none}.svc-group-header--parent td{background:var(--color-gray-100);padding:14px 12px}.svc-group-header--parent .svc-group-name{color:var(--text-primary);font-size:var(--font-size-lg);font-weight:700;letter-spacing:.02em;text-transform:uppercase}.svc-group-header--child td{background:var(--color-gray-50);padding:12px 12px 12px 32px}.svc-group-header--child .svc-group-name{color:var(--text-primary);font-size:var(--font-size-base);font-weight:600}.svc-row--child td:first-child{padding-left:24px}.svc-group-header--grandchild td{background:var(--color-white);padding:10px 12px 10px 48px!important}.svc-group-header--grandchild .svc-group-name{color:var(--text-secondary);font-size:var(--font-size-base);font-weight:600}.svc-group-toggle--grandchild{padding-left:24px}.svc-group-header-card--grandchild{padding-left:48px}.svc-group-header-card--grandchild .svc-group-name{color:var(--text-secondary);font-size:var(--font-size-base);font-weight:600}.svc-settings-wrap{display:inline-block}.svc-settings-dropdown{background:var(--color-white);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:220px;padding:12px;position:absolute;right:0;top:calc(100% + 4px);white-space:nowrap;z-index:20}.svc-settings-section{margin-bottom:10px}.svc-settings-section:last-child{margin-bottom:0}.svc-settings-label{color:var(--color-gray-400);font-size:var(--font-size-xs);font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.svc-settings-modes{display:flex;gap:4px}.svc-settings-mode-btn{align-items:center;background:var(--color-white);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:var(--font-size-sm);gap:4px;padding:5px 10px;transition:all var(--transition-fast)}.svc-settings-mode-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.svc-settings-mode-btn--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.svc-settings-mode-btn--active:hover{background:color-mix(in srgb,var(--color-primary) 85%,#000);color:#fff}.svc-settings-check{align-items:center;color:var(--text-secondary);cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:6px;padding:3px 0}.svc-settings-check input{accent-color:var(--color-primary)}.svc-flat-header td{border-bottom:none!important;padding:10px 12px 4px!important}.svc-flat-header-card,.svc-flat-label{color:var(--color-primary);font-size:var(--font-size-sm);font-weight:600;letter-spacing:.3px;text-transform:uppercase}.svc-flat-header-card{padding:10px 4px 4px}.svc-cat-badge{color:var(--color-gray-400);font-size:var(--font-size-xs);margin-top:1px}.svc-table--compact .datatable-td{padding:4px 8px}.svc-table--compact .svc-name{font-size:var(--font-size-sm)}.svc-table--compact .svc-group-header--parent td{padding:6px 12px}.svc-table--compact .svc-group-header--child td{padding:4px 12px}.svc-table--compact .svc-flat-header td{padding:8px 8px 2px!important}.svc-table--compact .svc-card{padding:8px 10px}.svc-online-filter{display:inline-flex;gap:4px;margin-left:8px}.svc-card{background:var(--color-white);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;padding:12px 14px;transition:box-shadow var(--transition-fast),border-color var(--transition-fast)}.svc-card:hover{border-color:var(--color-primary);box-shadow:0 2px 8px rgba(99,102,241,.08)}.svc-card-header{align-items:center;display:flex;gap:10px}.svc-card-info{flex:1;min-width:0}.svc-card-name{font-size:var(--font-size-sm);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.svc-card-meta{color:var(--color-gray-400);font-size:var(--font-size-xs);margin-top:2px}.svc-card-price{color:var(--color-primary);font-size:var(--font-size-sm);font-weight:600;white-space:nowrap}.svc-card-footer{align-items:center;border-top:1px solid var(--color-gray-100);display:flex;gap:8px;margin-top:8px;padding-top:8px}.svc-card-dur{color:var(--color-gray-500);font-size:var(--font-size-xs)}.svc-card-footer .svc-del{margin-left:auto}.svc-cat-search{margin-bottom:12px;position:relative}.svc-cat-search .input{padding-left:32px}.svc-cat-search-icon{color:var(--color-gray-400);left:10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.svc-cat-list{display:flex;flex-direction:column;gap:1px;max-height:55vh;overflow-y:auto;padding:2px 0}.svc-cat-row{align-items:center;border-radius:var(--radius-md);display:flex;gap:8px;min-height:40px;padding:8px 12px;transition:background var(--transition-fast)}.svc-cat-row:hover{background:var(--color-gray-50)}.svc-cat-row--parent{border-bottom:1px solid var(--color-gray-100)}.svc-cat-row--parent>.svc-cat-name{font-weight:600}.svc-cat-row--child>.svc-cat-name{color:var(--text-secondary)}.svc-cat-row--editing{border:1px solid var(--color-primary);border-radius:var(--radius-md);flex-wrap:wrap;padding:12px}.svc-cat-row--drag-over,.svc-cat-row--editing,.svc-cat-row--editing:hover{background:var(--color-primary-50,#eff6ff)}.svc-cat-row--drag-over{box-shadow:inset 0 -2px 0 var(--color-primary)}.svc-cat-toggle{align-items:center;border-radius:var(--radius-sm);color:var(--color-gray-400);cursor:pointer;display:flex;flex-shrink:0;height:20px;justify-content:center;transition:transform .15s,color var(--transition-fast);width:20px}.svc-cat-toggle:hover{color:var(--color-gray-600)}.svc-cat-toggle--collapsed{transform:rotate(-90deg)}.svc-cat-toggle--hidden{visibility:hidden}.svc-cat-icon{color:var(--color-gray-400);flex-shrink:0;height:18px;width:18px}.svc-cat-row--parent>.svc-cat-icon{color:var(--color-warning,#f59e0b)}.svc-cat-name{cursor:default;flex:1;font-size:var(--font-size-sm);font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.svc-cat-name[data-id]{cursor:pointer}.svc-cat-name[data-id]:hover{color:var(--color-primary)}.svc-cat-count{background:var(--color-gray-100);border-radius:10px;color:var(--color-gray-500);font-size:11px;font-weight:500;padding:2px 8px;white-space:nowrap}.svc-cat-count--empty{opacity:.35}.svc-cat-edit-input{min-width:0}.svc-cat-edit-fields{display:flex;flex:1;gap:8px;min-width:0}.svc-cat-edit-fields .input{flex:1;min-width:100px}.svc-cat-parent-select{max-width:200px}.svc-cat-actions{display:flex;flex-shrink:0;gap:2px;opacity:0;transition:opacity var(--transition-fast)}.svc-cat-row--editing>.svc-cat-actions,.svc-cat-row:hover>.svc-cat-actions{opacity:1}.svc-cat-actions .btn--ghost{color:var(--color-gray-400)}.svc-cat-actions .btn--ghost:hover{background:var(--color-gray-100);color:var(--color-gray-700)}.svc-cat-drag-handle{align-items:center;color:var(--color-gray-300);cursor:grab;display:flex;padding:2px}.svc-cat-drag-handle:hover{color:var(--color-gray-500)}.svc-cat-drag-handle:active{cursor:grabbing}.svc-cat-inline-add{background:var(--color-gray-50);border:1px dashed var(--color-gray-300);border-radius:var(--radius-md)}.svc-cat-inline-input{flex:1;min-width:120px}.svc-cat-add{border-top:1px solid var(--color-gray-200);margin-top:8px;padding:12px 0 0}.svc-cat-add-row{align-items:center;display:flex;gap:8px}.svc-cat-add-row .input{flex:1}.svc-cat-empty{color:var(--color-gray-400);padding:32px 16px;text-align:center}.svc-cat-empty-icon{display:block;font-size:32px;margin-bottom:8px}.svc-cat-path,.svc-cat-stats{color:var(--color-gray-500);font-size:var(--font-size-xs)}.svc-cat-stats{background:var(--color-gray-50);border-radius:var(--radius-md);display:flex;gap:16px;margin-bottom:12px;padding:10px 12px}.svc-cat-stats strong{color:var(--text-primary);font-weight:600}@media (max-width:767px){.svc-cat-actions{opacity:1}.svc-cat-edit-fields{flex-direction:column}.svc-cat-parent-select{max-width:none}}.svc-form{display:flex;flex-direction:column;gap:14px}.svc-dur-presets{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.svc-dur-btn{background:var(--color-white);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);padding:5px 12px;transition:all var(--transition-fast)}.svc-dur-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.svc-dur-btn--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.svc-dur-custom{align-items:center;display:flex;gap:6px}.svc-dur-label{color:var(--color-gray-400);font-size:var(--font-size-sm)}.svc-color-picker{align-items:center;display:flex;gap:10px}.svc-color-swatches{display:flex;flex-wrap:wrap;gap:6px}.svc-color-swatch{border:2px solid transparent;border-radius:50%;cursor:pointer;height:26px;transition:transform .15s,border-color .15s;width:26px}.svc-color-swatch:hover{transform:scale(1.15)}.svc-color-swatch--active{border-color:var(--color-gray-700);transform:scale(1.15)}.svc-color-swatch--none{align-items:center;background:var(--color-white);border:2px dashed var(--color-gray-300);color:var(--color-gray-400);display:flex;font-size:12px;justify-content:center}.svc-color-swatch--none.svc-color-swatch--active{border-color:var(--color-gray-700);border-style:solid}.svc-color-input{border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;height:32px;padding:2px;width:32px}.svc-form-check{align-items:center;cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:8px}.svc-variants-list{display:flex;flex-direction:column;gap:6px}.svc-variant-row{align-items:center;display:flex;gap:8px}.svc-variant-row .svc-var-name{flex:2}.svc-variant-row .svc-var-price{flex:1}.svc-variant-row .svc-var-dur{flex:none;width:70px}.svc-variants-inline{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px}.svc-variant-tag{background:var(--bg-secondary);border-radius:var(--radius-sm);padding:1px 6px}.svc-staff-count,.svc-variant-tag{color:var(--text-secondary);font-size:var(--font-size-xs)}.svc-staff-count{font-weight:400}.svc-staff-list{border:1px solid var(--border-color);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto;padding:var(--spacing-sm)}.svc-staff-item{align-items:center;background:var(--bg-secondary);border-radius:var(--radius-sm);display:flex;justify-content:space-between;padding:6px 8px}.svc-staff-name{font-size:var(--font-size-sm);font-weight:500}.svc-staff-meta{color:var(--text-secondary);font-size:var(--font-size-xs)}.svc-staff-empty{color:var(--text-secondary);font-size:var(--font-size-sm);padding:var(--spacing-sm);text-align:center}.svc-staff-add{margin-top:var(--spacing-xs)}.svc-staff-remove{opacity:.5}.svc-staff-remove:hover{color:var(--color-danger);opacity:1}@media (max-width:768px){.services-page{padding:var(--spacing-md) var(--spacing-sm)}.services-filters{flex-direction:column}.services-search{max-width:none}.svc-chip{font-size:var(--font-size-xs);padding:3px 10px}.svc-chip-count{font-size:.65rem}.services-table .datatable-table{display:none}.services-cards{display:flex;flex-direction:column;gap:8px}.svc-group-header-card{align-items:center;cursor:pointer;display:flex;gap:8px;padding:10px 4px}.svc-group-header-card--parent{border-bottom:2px solid var(--color-gray-200);margin-top:8px;padding:12px 4px 8px}.svc-group-header-card--parent .svc-group-name{font-size:var(--font-size-lg);font-weight:700;letter-spacing:.02em;text-transform:uppercase}.svc-group-header-card--child{padding:10px 4px 8px 16px}.svc-group-header-card--child .svc-group-name{color:var(--text-primary);font-size:var(--font-size-base);font-weight:600}.svc-group-header-card--grandchild{padding:8px 4px 6px 32px}.svc-group-header-card--grandchild .svc-group-name{color:var(--text-secondary);font-size:var(--font-size-base);font-weight:600}}.settings-page{height:100%}.settings-layout{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);display:flex;gap:0;min-height:calc(100vh - var(--header-height) - 32px);overflow:hidden}.settings-nav{background:var(--color-gray-50);border-right:1px solid var(--color-gray-200);display:flex;flex-direction:column;gap:2px;min-width:280px;padding:var(--spacing-lg) 0;width:280px}.settings-nav-header{padding:0 var(--spacing-lg) var(--spacing-md)}.settings-title{color:var(--color-gray-900);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:0}.settings-nav-item{align-items:center;background:none;border:none;border-left:3px solid transparent;color:var(--color-gray-600);cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm);padding:10px var(--spacing-lg);text-align:left;transition:all var(--transition-fast);width:100%}.settings-nav-item:hover{background:var(--color-gray-100);color:var(--color-gray-900)}.settings-nav-item.active{background:var(--color-primary-light);border-left-color:var(--color-primary);color:var(--color-primary);font-weight:var(--font-weight-medium)}.settings-nav-icon{display:flex;flex-shrink:0}.settings-nav-label{flex:1}.settings-nav-arrow{display:none}.settings-content{flex:1;min-width:0;overflow-y:auto;padding:var(--spacing-xl)}.settings-back{align-items:center;background:none;border:none;color:var(--color-primary);cursor:pointer;display:none;font-size:var(--font-size-md);gap:var(--spacing-xs);margin-bottom:var(--spacing-md);padding:0}.settings-section{max-width:720px}.settings-section-title{color:var(--color-gray-900);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:0 0 var(--spacing-xs)}.settings-section-desc{color:var(--color-gray-500);font-size:var(--font-size-sm);margin:0 0 var(--spacing-xl)}.settings-subsection-title{color:var(--color-gray-800);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);margin:0 0 var(--spacing-md)}.settings-form-grid{display:grid;gap:var(--spacing-md);grid-template-columns:1fr 1fr}.settings-form-actions{background:var(--color-white);border-top:1px solid var(--color-gray-100);bottom:0;margin-top:var(--spacing-lg);padding:var(--spacing-md) 0;position:sticky;z-index:1}.settings-avatar{align-items:center;display:flex;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.settings-avatar-preview{align-items:center;background:var(--color-primary-light);border-radius:var(--radius-full);display:flex;flex-shrink:0;height:80px;justify-content:center;overflow:hidden;width:80px}.settings-avatar-img{height:100%;object-fit:cover;width:100%}.settings-avatar-initials{color:var(--color-primary);font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold)}.settings-avatar-actions{display:flex;flex-direction:column;gap:var(--spacing-xs)}.settings-logo-preview{border-radius:var(--radius-lg)}.settings-badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:2px 8px;white-space:nowrap}.settings-badge--success{background:#d1fae5;color:#065f46}.settings-badge--warning{background:#fef3c7;color:#92400e}.settings-badge--danger{background:#fee2e2;color:#991b1b}.settings-badge--role{background:var(--color-primary-light);color:var(--color-primary)}.settings-badge--owner{background:#fef3c7;color:#92400e}.settings-badge--admin{background:#dbeafe;color:#1e40af}.settings-badge--manager{background:#e0e7ff;color:#3730a3}.settings-badge--staff{background:var(--color-gray-100);color:var(--color-gray-600)}.settings-badge--plan{font-size:var(--font-size-sm);padding:4px 12px}.settings-badge--free{background:var(--color-gray-100);color:var(--color-gray-700)}.settings-badge--pro{background:#dbeafe;color:#1d4ed8}.settings-badge--business{background:#fef3c7;color:#b45309}.settings-checkbox{accent-color:var(--color-primary);cursor:pointer;flex-shrink:0;height:20px;width:20px}.settings-toggle-row{align-items:center;display:flex;gap:var(--spacing-md);justify-content:space-between;padding:var(--spacing-sm) 0}.settings-toggle-row--compact{padding:4px 0}.settings-strength{align-items:center;display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-xs)}.settings-strength-track{background:var(--color-gray-200);border-radius:2px;flex:1;height:4px;overflow:hidden}.settings-strength-bar{border-radius:2px;height:100%;transition:width var(--transition-normal),background var(--transition-normal);width:0}.strength--weak{background:var(--color-danger)}.strength--medium{background:var(--color-warning)}.strength--strong{background:var(--color-success)}.settings-strength-label{color:var(--color-gray-500);font-size:var(--font-size-xs);min-width:60px}.settings-sessions{display:flex;flex-direction:column;gap:var(--spacing-sm)}.settings-session-item{align-items:center;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);display:flex;gap:var(--spacing-md);justify-content:space-between;padding:var(--spacing-md)}.settings-session-device{color:var(--color-gray-800);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.settings-session-date{color:var(--color-gray-500);font-size:var(--font-size-xs)}.settings-notif-table{border-collapse:collapse;margin:var(--spacing-lg) 0;width:100%}.settings-notif-table td,.settings-notif-table th{border-bottom:1px solid var(--color-gray-100);font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md);text-align:left}.settings-notif-table th{color:var(--color-gray-500);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);letter-spacing:.5px;text-transform:uppercase}.settings-notif-td-channel,.settings-notif-th-channel{text-align:center;width:80px}.settings-notif-channels{background:var(--color-gray-50);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.settings-notif-card{border:1px solid var(--color-gray-200);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);padding:var(--spacing-md)}.settings-notif-card-title{font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-sm)}.settings-tg-link{background:var(--color-primary-light);border:1px solid rgba(99,102,241,.15);border-radius:var(--radius-md);display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.settings-tg-link-icon{flex-shrink:0;padding-top:2px}.settings-tg-code{align-items:center;display:flex;gap:var(--spacing-sm);margin:8px 0 4px}.settings-tg-code code{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);font-family:monospace;font-size:var(--font-size-sm);padding:6px 12px;user-select:all}.settings-personal-link{background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);display:flex;gap:var(--spacing-md);margin-top:var(--spacing-xl);padding:var(--spacing-md)}.settings-personal-link-icon{flex-shrink:0;padding-top:2px}.settings-danger-zone{border:1px solid var(--color-danger);border-radius:var(--radius-md);margin-top:var(--spacing-2xl);padding:var(--spacing-lg)}.settings-danger-title{color:var(--color-danger);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);margin:0 0 var(--spacing-sm)}.settings-danger-zone p{color:var(--color-gray-600);font-size:var(--font-size-sm);margin:0 0 var(--spacing-md)}.team-stats{display:flex;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.team-stat{text-align:center}.team-stat-value{display:block;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.team-stat-label{color:var(--color-gray-500);font-size:var(--font-size-xs)}.team-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.team-card{align-items:center;border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);display:flex;justify-content:space-between;padding:var(--spacing-md);transition:box-shadow var(--transition-fast)}.team-card:hover{box-shadow:var(--shadow-sm)}.team-card--inactive{opacity:.6}.team-card-main{align-items:center;display:flex;flex:1;gap:var(--spacing-md);min-width:0}.team-card-avatar{align-items:center;background:var(--color-primary-light);border:2px solid var(--color-gray-200);border-radius:var(--radius-full);color:var(--color-primary);display:flex;flex-shrink:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);height:40px;justify-content:center;overflow:hidden;width:40px}.team-card-avatar img{height:100%;object-fit:cover;width:100%}.team-card-info{min-width:0}.team-card-name{align-items:center;display:flex;flex-wrap:wrap;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--spacing-xs)}.team-card-email{color:var(--color-gray-500);font-size:var(--font-size-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.team-card-meta{color:var(--color-gray-400);display:flex;flex-wrap:wrap;font-size:11px;gap:var(--spacing-xs);margin-top:2px}.team-card-role{font-weight:var(--font-weight-medium)}.team-card-actions{display:flex;flex-shrink:0;gap:var(--spacing-xs)}.team-badge{border-radius:var(--radius-sm);display:inline-block;font-size:10px;font-weight:var(--font-weight-semibold);padding:1px 6px}.team-badge--inactive{background:var(--color-gray-100);color:var(--color-gray-500)}.team-badge--pending{background:var(--badge-warning-bg);color:#92400e}.team-role-cards{display:flex;flex-direction:column;gap:var(--spacing-xs)}.team-role-card{align-items:flex-start;background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);cursor:pointer;display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);text-align:left;transition:all var(--transition-fast)}.team-role-card:hover{border-color:var(--color-gray-300)}.team-role-card--active{background:var(--color-primary-light);border-color:var(--color-primary)}.team-role-card-dot{border-radius:50%;flex-shrink:0;height:10px;margin-top:4px;width:10px}.team-role-card-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.team-role-card-desc{color:var(--color-gray-500);font-size:11px}.team-permissions{border-top:1px solid var(--color-gray-100);padding-top:var(--spacing-md)}.team-perm-groups{display:grid;gap:var(--spacing-md);grid-template-columns:1fr 1fr}.team-perm-group-title{color:var(--color-gray-400);font-size:11px;font-weight:var(--font-weight-semibold);letter-spacing:.05em;margin-bottom:4px;text-transform:uppercase}.team-perm-item{align-items:center;cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-xs);padding:2px 0}.team-edit-header{align-items:center;display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.team-edit-avatar{align-items:center;background:var(--color-primary-light);border-radius:var(--radius-full);color:var(--color-primary);display:flex;flex-shrink:0;font-weight:var(--font-weight-semibold);height:48px;justify-content:center;overflow:hidden;width:48px}.team-edit-avatar img{height:100%;object-fit:cover;width:100%}.team-edit-name{font-weight:var(--font-weight-semibold)}.team-edit-email{color:var(--color-gray-500);font-size:var(--font-size-sm)}.settings-branch-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.settings-branch-card{align-items:center;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);display:flex;gap:var(--spacing-md);padding:var(--spacing-md)}.settings-branch-card--inactive{opacity:.6}.settings-branch-avatar{border-radius:var(--radius-md);flex-shrink:0;height:48px;object-fit:cover;width:48px}.settings-branch-avatar--lg{border-radius:var(--radius-lg);height:72px;width:72px}.settings-branch-avatar--placeholder{align-items:center;background:var(--color-primary-light);color:var(--color-primary);display:flex;font-size:1.1rem;font-weight:var(--font-weight-semibold);justify-content:center}.settings-branch-avatar--lg.settings-branch-avatar--placeholder{font-size:1.5rem}.settings-branch-info{flex:1;min-width:0}.settings-branch-name{font-weight:var(--font-weight-medium);margin-bottom:2px}.settings-branch-detail{color:var(--color-gray-500);font-size:var(--font-size-sm)}.settings-branch-tz{color:var(--color-gray-400);font-size:11px}.settings-branch-actions{display:flex;gap:var(--spacing-xs)}.sch-summary{display:flex;gap:var(--spacing-xl);margin-bottom:var(--spacing-lg)}.sch-summary-item{text-align:center}.sch-summary-value{color:var(--color-primary);display:block;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.sch-summary-value small{font-size:var(--font-size-sm)}.sch-summary-label{color:var(--color-gray-500);font-size:var(--font-size-xs)}.sch-presets{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg)}.sch-presets-label{color:var(--color-gray-400);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.sch-preset-btn{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);color:var(--color-gray-600);cursor:pointer;font-size:11px;padding:4px 10px;transition:all var(--transition-fast)}.sch-preset-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.sch-days{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg)}.sch-day{border:1px solid var(--color-gray-200);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);transition:all var(--transition-fast)}.sch-day:hover{border-color:var(--color-gray-300)}.sch-day--off{background:var(--color-gray-50);opacity:.7}.sch-day--weekend .sch-day-name{color:var(--color-danger)}.sch-day-header{align-items:center;display:flex;justify-content:space-between}.sch-day-toggle{align-items:center;cursor:pointer;display:flex;gap:var(--spacing-sm)}.sch-day-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.sch-day-meta{align-items:center;display:flex;gap:var(--spacing-sm)}.sch-day-hours{color:var(--color-gray-400);font-size:11px;font-weight:var(--font-weight-medium)}.sch-day-off-label{color:var(--color-gray-400);font-size:var(--font-size-xs)}.sch-copy-btn{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-gray-400);cursor:pointer;display:flex;height:28px;justify-content:center;transition:all var(--transition-fast);width:28px}.sch-copy-btn:hover{background:var(--color-gray-100);color:var(--color-gray-600)}.sch-day-times{border-top:1px solid var(--color-gray-100);display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-sm);padding-top:var(--spacing-sm)}.sch-time-row{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.sch-time-label{color:var(--color-gray-400);flex-shrink:0;font-size:var(--font-size-xs);width:80px}.sch-time-input{font-size:var(--font-size-sm);padding:5px 8px;width:100px}.sch-time-sep{color:var(--color-gray-400)}.sch-break-toggle{align-items:center;color:var(--color-gray-500);cursor:pointer;display:flex;flex-shrink:0;font-size:var(--font-size-xs);gap:4px;white-space:nowrap;width:80px}.settings-holidays{margin-bottom:var(--spacing-md)}.settings-holiday-row{align-items:center;border-bottom:1px solid var(--color-gray-100);display:flex;gap:var(--spacing-sm);padding:6px 0}.settings-holiday-row:last-of-type{border-bottom:none}.settings-holiday-date{font-size:var(--font-size-sm);font-weight:500;min-width:160px}.settings-holiday-name{color:var(--color-gray-500);flex:1;font-size:var(--font-size-sm)}.settings-holiday-add{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:8px}.settings-holiday-add .input{max-width:180px}.settings-schedule-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.settings-schedule-row{border-bottom:1px solid var(--color-gray-100);display:flex;flex-direction:column;gap:4px;padding:var(--spacing-sm) 0}.settings-schedule-row:last-child{border-bottom:none}.settings-schedule-row--disabled{opacity:.6}.settings-schedule-dayoff{color:var(--color-gray-400);font-size:var(--font-size-sm);font-style:italic}.settings-schedule-break,.settings-schedule-main{align-items:center;display:flex;gap:var(--spacing-sm)}.settings-schedule-break{font-size:var(--font-size-sm);padding-left:40px}.settings-schedule-break-label{align-items:center;cursor:pointer;display:flex;gap:4px;white-space:nowrap}.settings-schedule-break-text{color:var(--color-gray-400);white-space:nowrap}.settings-schedule-day{cursor:pointer;flex-shrink:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);width:32px}.settings-schedule-time{font-size:var(--font-size-sm);padding:6px 8px;width:100px}.settings-schedule-sep{color:var(--color-gray-400)}.settings-radio-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.settings-radio{align-items:center;cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm)}.settings-radio input[type=radio]{accent-color:var(--color-primary)}.billing-page{max-width:960px}.billing-header{margin-bottom:var(--spacing-lg)}.billing-empty{color:var(--color-gray-400);padding:48px 24px;text-align:center}.billing-empty p{margin-top:12px}.billing-notice{align-items:center;border-radius:var(--radius-lg);display:flex;font-size:13px;gap:10px;margin-bottom:var(--spacing-lg);padding:12px 16px}.billing-notice--warning{background:var(--color-warning-light);border:1px solid rgba(245,158,11,.2);color:var(--color-gray-700)}.billing-notice--warning svg{color:var(--color-warning);flex-shrink:0}.billing-section-block{margin-top:var(--spacing-xl)}.billing-section-title{align-items:center;border-bottom:1px solid var(--color-gray-100);color:var(--color-gray-800);display:flex;font-size:15px;font-weight:var(--font-weight-semibold);gap:8px;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm)}.billing-section-title svg{color:var(--color-gray-400);flex-shrink:0}.billing-current{align-items:center;background:var(--bg-primary);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:0 1px 3px rgba(0,0,0,.04);display:flex;flex-wrap:wrap;gap:var(--spacing-md);justify-content:space-between;padding:20px 24px}.billing-current__main{align-items:center;display:flex;gap:16px}.billing-current__icon{align-items:center;background:color-mix(in srgb,var(--plan-accent) 8%,transparent);border-radius:12px;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.billing-current__info{display:flex;flex-direction:column;gap:4px}.billing-current__plan-row{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.billing-current__name{color:var(--color-text-primary);font-size:17px;font-weight:var(--font-weight-semibold)}.billing-current__meta{align-items:center;color:var(--color-gray-500);display:flex;flex-wrap:wrap;font-size:13px;gap:12px}.billing-current__price{font-weight:var(--font-weight-medium)}.billing-current__detail{color:var(--color-gray-400)}.billing-current__payment{align-items:center;display:flex;gap:4px}.billing-current__payment svg,.billing-detach-card-btn{color:var(--color-gray-400)}.billing-detach-card-btn{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:flex;margin-left:2px;padding:2px}.billing-detach-card-btn:hover{background:color-mix(in srgb,var(--color-danger) 8%,transparent);color:var(--color-danger)}.billing-current__next{color:var(--color-gray-500);font-size:13px}.billing-current__actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.billing-status{align-items:center;border-radius:20px;display:inline-flex;font-size:12px;font-weight:var(--font-weight-medium);gap:4px;padding:3px 10px}.billing-status svg{height:14px;width:14px}.billing-status--active{background:var(--color-success-light);color:var(--color-success)}.billing-status--trial{background:var(--color-warning-light);color:#b45309}.billing-status--cancel{background:var(--color-danger-light);color:var(--color-danger)}.billing-status--free{background:var(--color-gray-100);color:var(--color-gray-500)}.billing-usage{gap:14px}.billing-usage,.billing-usage-row{display:flex;flex-direction:column}.billing-usage-row{gap:6px}.billing-usage-header{align-items:center;display:flex;justify-content:space-between}.billing-usage-label{align-items:center;color:var(--color-gray-700);display:flex;font-size:13px;font-weight:var(--font-weight-medium);gap:6px}.billing-usage-icon{color:var(--color-gray-400);flex-shrink:0}.billing-usage-count{color:var(--color-gray-600);font-size:13px;font-weight:var(--font-weight-medium)}.billing-usage-count--danger{color:var(--color-danger)}.billing-usage-of{color:var(--color-gray-400);font-weight:400}.billing-usage-bar{background:var(--color-gray-100);border-radius:3px;height:6px;overflow:hidden}.billing-usage-fill{background:var(--color-primary);border-radius:3px;height:100%;min-width:2px;transition:width .6s cubic-bezier(.4,0,.2,1)}.billing-usage-fill--warning{background:var(--color-warning)}.billing-usage-fill--danger{background:var(--color-danger)}.billing-usage-fill--unlimited{background:transparent}.billing-periods{background:var(--color-gray-100);border-radius:10px;display:flex;gap:4px;margin-bottom:var(--spacing-lg);padding:3px}.billing-period-btn{align-items:center;background:transparent;border:none;border-radius:8px;color:var(--color-gray-600);cursor:pointer;display:flex;flex:1;font-size:13px;font-weight:var(--font-weight-medium);gap:4px;justify-content:center;padding:8px 12px;transition:all .15s;white-space:nowrap}.billing-period-btn--active,.billing-period-btn:hover{color:var(--color-text-primary)}.billing-period-btn--active{background:var(--bg-primary);box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06)}.billing-period-discount{background:var(--color-success-light);border-radius:4px;color:var(--color-success);font-size:11px;font-weight:600;padding:1px 5px}.billing-coupon{margin-bottom:var(--spacing-lg)}.billing-coupon-toggle{align-items:center;background:none;border:none;color:var(--color-gray-500);cursor:pointer;display:inline-flex;font-size:13px;gap:6px;padding:0;transition:color .15s}.billing-coupon-toggle:hover{color:var(--color-primary)}.billing-coupon__form{align-items:center;display:flex;gap:8px}.billing-coupon__input{font-size:13px!important;letter-spacing:.05em;max-width:200px;text-transform:uppercase}.billing-coupon__success{align-items:center;color:var(--color-success);display:flex;font-size:12px;gap:6px;margin-top:8px}.billing-coupon__error{color:var(--color-danger);font-size:12px;margin-top:8px}.billing-plans-grid{display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.billing-plan-card{background:var(--bg-primary);border:2px solid var(--color-gray-200);border-radius:16px;display:flex;flex-direction:column;padding:24px 20px;position:relative;transition:all .2s}.billing-plan-card:hover{border-color:var(--plan-color,var(--color-gray-300));box-shadow:0 8px 25px rgba(0,0,0,.07);transform:translateY(-2px)}.billing-plan-card--current{background:color-mix(in srgb,var(--plan-color,var(--color-primary)) 3%,var(--bg-primary));border-color:var(--plan-color,var(--color-primary))}.billing-plan-card--recommended{border-color:var(--plan-color,var(--color-primary));box-shadow:0 4px 16px color-mix(in srgb,var(--plan-color) 15%,transparent)}.billing-plan-badge{background:var(--plan-color,var(--color-primary));border-radius:12px;color:#fff;font-size:11px;font-weight:600;left:50%;letter-spacing:.02em;padding:3px 14px;position:absolute;top:-11px;transform:translateX(-50%);white-space:nowrap}.billing-plan-icon{margin-bottom:12px}.billing-plan-name{color:var(--color-text-primary);font-size:16px;font-weight:var(--font-weight-semibold);margin-bottom:4px}.billing-plan-price{align-items:baseline;display:flex;gap:2px;margin-bottom:4px}.billing-plan-amount{color:var(--color-text-primary);font-size:32px;font-weight:700;letter-spacing:-.02em}.billing-plan-period{color:var(--color-gray-400);font-size:14px;font-weight:var(--font-weight-medium)}.billing-plan-total{color:var(--color-gray-500);font-size:12px;margin-bottom:2px}.billing-plan-original{color:var(--color-gray-400);margin-right:4px;text-decoration:line-through}.billing-plan-savings{background:var(--color-success-light);border-radius:4px;color:var(--color-success);display:inline-flex;font-size:11px;font-weight:600;margin-bottom:4px;padding:2px 8px}.billing-plan-divider{background:var(--color-gray-100);height:1px;margin:12px 0}.billing-plan-features{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.billing-feature{align-items:flex-start;color:var(--color-gray-600);display:flex;font-size:13px;gap:8px;line-height:1.4}.billing-feature svg{flex-shrink:0;margin-top:1px}.billing-feature strong{color:var(--color-text-primary)}.billing-plan-features--hidden{display:grid;grid-template-rows:0fr;list-style:none;margin:0;opacity:0;padding:0;transition:grid-template-rows .3s ease,opacity .3s ease}.billing-plan-features--hidden .billing-features-inner{display:flex;flex-direction:column;gap:8px;overflow:hidden;padding-top:8px}.billing-plan-features--hidden.billing-plan-features--visible{grid-template-rows:1fr;opacity:1}.billing-features-toggle-all{align-items:center;background:var(--color-gray-50);border:1px dashed var(--color-gray-200);border-radius:var(--radius-md);color:var(--color-gray-500);cursor:pointer;display:flex;font-size:13px;font-weight:var(--font-weight-medium);gap:6px;justify-content:center;margin-top:var(--spacing-md);padding:10px 16px;transition:all .2s;width:100%}.billing-features-toggle-all:hover{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.billing-features-toggle-all svg{flex-shrink:0;transition:transform .3s ease}.billing-features-toggle-all.billing-features-toggle--open svg{transform:rotate(180deg)}.billing-plan-action{margin-bottom:4px}.billing-plan-current-label{border:1.5px dashed var(--color-gray-200);border-radius:var(--radius-md);color:var(--color-gray-400);font-size:13px;font-weight:var(--font-weight-medium);padding:10px 0;text-align:center}.billing-alt-providers{display:flex;gap:4px;justify-content:center;margin-top:8px}.billing-alt-btn{background:none;border:none;border-radius:4px;color:var(--color-gray-400);cursor:pointer;font-size:11px;padding:4px 8px;transition:all .15s}.billing-alt-btn:hover{background:var(--color-primary-light);color:var(--color-primary)}.billing-checkout-error{background:var(--color-danger-light);border:1px solid rgba(244,63,94,.15);border-radius:12px;margin-top:var(--spacing-lg);padding:16px 20px}.billing-checkout-error__header{align-items:flex-start;display:flex;gap:10px;margin-bottom:12px}.billing-checkout-error__header svg{color:var(--color-danger);flex-shrink:0;margin-top:1px}.billing-checkout-error__title{color:var(--color-text-primary);font-size:14px;font-weight:600;margin-bottom:2px}.billing-checkout-error__msg{color:var(--color-gray-600);font-size:13px}.billing-checkout-error__actions{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.billing-checkout-back{align-items:center;background:none;border:none;color:var(--color-gray-500);cursor:pointer;display:inline-flex;font-size:14px;font-weight:var(--font-weight-medium);gap:6px;margin-bottom:var(--spacing-lg);padding:0;transition:color .15s}.billing-checkout-back:hover{color:var(--color-primary)}.billing-checkout{background:var(--bg-primary);border:1px solid var(--color-gray-200);border-radius:16px;box-shadow:0 1px 3px rgba(0,0,0,.04);margin:0 auto;max-width:560px;padding:28px}.billing-checkout__header{align-items:center;border-bottom:1px solid var(--color-gray-100);display:flex;gap:16px;margin-bottom:24px;padding-bottom:20px}.billing-checkout__plan-icon{align-items:center;border-radius:14px;display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.billing-checkout__title{color:var(--color-text-primary);font-size:20px;font-weight:700;margin-bottom:2px}.billing-checkout__subtitle{color:var(--color-gray-500);font-size:13px}.billing-checkout__section{margin-bottom:20px}.billing-checkout__section-title{color:var(--color-gray-500);font-size:13px;font-weight:600;letter-spacing:.04em;margin-bottom:10px;text-transform:uppercase}.billing-checkout__table{border-collapse:collapse;font-size:14px;width:100%}.billing-checkout__table td{border-bottom:1px solid var(--color-gray-100);color:var(--color-gray-600);padding:10px 0}.billing-checkout__table td:last-child{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.billing-checkout__discount-row td{color:var(--color-success)!important}.billing-checkout__total-row td{border-bottom:none;border-top:2px solid var(--color-gray-200);color:var(--color-text-primary)!important;font-size:17px;font-weight:700!important;padding-top:14px}.billing-checkout__savings-row td{border-bottom:none;color:var(--color-success)!important;font-size:12px;font-weight:500!important;padding-top:4px}.billing-checkout__actions{display:flex;flex-direction:column;gap:8px;margin-top:24px}.billing-checkout__divider{align-items:center;color:var(--color-gray-400);display:flex;font-size:13px;gap:12px;margin:4px 0}.billing-checkout__divider:after,.billing-checkout__divider:before{background:var(--color-gray-200);content:"";flex:1;height:1px}.billing-checkout__alt-providers{display:flex;gap:8px;justify-content:center;margin-top:10px}.billing-trial-banner{background:rgba(99,102,241,.04);border:1px solid rgba(99,102,241,.15);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:10px;margin-bottom:var(--spacing-lg);padding:16px 20px}.billing-trial-banner--warning{background:rgba(245,158,11,.04);border-color:rgba(245,158,11,.2)}.billing-trial-banner--urgent{background:rgba(239,68,68,.04);border-color:rgba(239,68,68,.2)}.billing-trial-banner__content{align-items:center;display:flex;gap:12px}.billing-trial-banner__icon{color:var(--color-primary);flex-shrink:0}.billing-trial-banner--warning .billing-trial-banner__icon{color:var(--color-warning)}.billing-trial-banner--urgent .billing-trial-banner__icon{color:var(--color-danger)}.billing-trial-banner__title{color:var(--color-text-primary);font-size:14px;font-weight:600}.billing-trial-banner__hint{color:var(--color-gray-500);font-size:12px;margin-top:2px}.billing-trial-banner__bar{background:var(--color-gray-200);border-radius:2px;height:4px;overflow:hidden}.billing-trial-banner__fill{background:var(--color-primary);border-radius:2px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.billing-trial-banner--warning .billing-trial-banner__fill{background:var(--color-warning)}.billing-trial-banner--urgent .billing-trial-banner__fill{background:var(--color-danger)}.billing-payment-cards-list{display:flex;flex-direction:column;gap:8px}.billing-payment-card{align-items:center;background:var(--bg-primary);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);display:flex;gap:var(--spacing-md);justify-content:space-between;padding:14px 18px;transition:border-color .15s}.billing-payment-card--default{background:color-mix(in srgb,var(--color-primary) 3%,var(--bg-primary));border-color:var(--color-primary)}.billing-payment-card__main{align-items:center;display:flex;gap:14px;min-width:0}.billing-payment-card__icon{align-items:center;display:flex;flex-shrink:0}.billing-payment-card__number{align-items:center;color:var(--color-text-primary);display:flex;flex-wrap:wrap;font-size:14px;font-variant-numeric:tabular-nums;font-weight:var(--font-weight-medium);gap:8px;letter-spacing:.03em}.billing-payment-card__badge{background:color-mix(in srgb,var(--color-primary) 10%,transparent);border-radius:10px;color:var(--color-primary);font-size:11px;font-weight:600;letter-spacing:0;padding:2px 8px;white-space:nowrap}.billing-payment-card__meta{color:var(--color-gray-500);display:flex;font-size:12px;gap:10px;margin-top:2px}.billing-payment-card__type{text-transform:capitalize}.billing-payment-card__actions{display:flex;flex-shrink:0;gap:4px}.billing-payment-card__note{align-items:center;color:var(--color-gray-500);display:flex;font-size:12px;gap:6px;margin-top:8px}.billing-payment-card__note svg{flex-shrink:0}.billing-payment-card__note--auto{color:var(--color-success)}.billing-payment-empty{align-items:center;color:var(--color-gray-400);display:flex;font-size:13px;gap:10px;padding:20px}.billing-pay-list{display:flex;flex-direction:column}.billing-pay-row{border-bottom:1px solid var(--color-gray-100);padding:12px 0}.billing-pay-row:last-child{border-bottom:none}.billing-pay-row__main{align-items:center;display:flex;gap:12px;justify-content:space-between}.billing-pay-row__left{align-items:center;display:flex;flex-wrap:wrap;gap:8px;min-width:0}.billing-pay-row__plan{color:var(--color-text-primary);font-size:14px;font-weight:500}.billing-pay-months{background:var(--color-gray-100);border-radius:4px;color:var(--color-gray-500);font-size:12px;padding:1px 6px}.billing-pay-discount{color:var(--color-success);font-size:12px;font-weight:500}.billing-pay-row__right{align-items:center;display:flex;flex-shrink:0;gap:10px}.billing-pay-row__amount{color:var(--color-text-primary);font-size:14px;font-weight:600;white-space:nowrap}.billing-pay-row--refunded .billing-pay-row__amount{color:var(--color-warning)}.billing-pay-row--failed .billing-pay-row__amount{color:var(--color-gray-400);text-decoration:line-through}.billing-pay-row__badge{align-items:center;display:inline-flex;font-size:11px;gap:3px}.billing-pay-row__date{color:var(--color-gray-400);font-size:12px;margin-top:4px}.billing-pay-count{background:var(--color-gray-100);border-radius:10px;color:var(--color-gray-400);font-size:11px;font-weight:600;margin-left:6px;padding:1px 8px}.billing-collapsible__toggle{cursor:pointer;user-select:none}.billing-collapsible__chevron{flex-shrink:0;margin-left:auto;transition:transform .2s ease}.billing-collapsible--collapsed .billing-collapsible__chevron{transform:rotate(-90deg)}.billing-collapsible__body{max-height:500px;opacity:1;overflow:hidden;transition:max-height .25s ease,opacity .2s ease}.billing-collapsible--collapsed .billing-collapsible__body{margin:0;max-height:0;opacity:0;padding:0}.billing-checkout__security{align-items:center;color:var(--color-gray-400);display:flex;font-size:12px;gap:6px;justify-content:center;margin-top:12px}.billing-balance-block .billing-section-title{margin-bottom:0}.billing-balance-header{align-items:center;display:flex;gap:12px;justify-content:space-between}.billing-balance-amount{color:var(--color-gray-400);font-size:20px;font-variant-numeric:tabular-nums;font-weight:700}.billing-balance-amount--positive{color:var(--color-success)}.billing-balance-hint{color:var(--color-gray-400);font-size:12px;margin-top:2px}.billing-balance-history{margin-top:12px}.billing-balance-row{align-items:center;border-bottom:1px solid var(--color-gray-50);display:flex;font-size:13px;gap:12px;padding:6px 0}.billing-balance-row__info{flex:1;min-width:0}.billing-balance-row__type{color:var(--color-gray-700);display:block}.billing-balance-row__desc{color:var(--color-gray-400);display:block;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.billing-balance-row__amount{font-weight:600;white-space:nowrap}.billing-balance-row__amount--credit{color:var(--color-success)}.billing-balance-row__amount--debit{color:var(--color-danger)}.billing-balance-row__date{color:var(--color-gray-400);font-size:12px;white-space:nowrap}.billing-checkout__renewal-info{align-items:flex-start;background:color-mix(in srgb,var(--color-primary) 6%,transparent);border:1px solid color-mix(in srgb,var(--color-primary) 15%,transparent);border-radius:var(--radius-lg);color:var(--color-gray-600);display:flex;font-size:13px;gap:8px;line-height:1.5;margin-bottom:16px;padding:12px 16px}.billing-checkout__renewal-info svg{color:var(--color-primary);flex-shrink:0;margin-top:1px}.billing-account-info{background:var(--color-gray-50);border:1px solid var(--color-gray-100);border-radius:var(--radius-lg);display:flex;gap:24px;margin-bottom:16px;padding:10px 16px}.billing-account-info__item{align-items:center;color:var(--color-gray-500);display:flex;font-size:13px;gap:6px}.billing-account-info__label{font-weight:500}.billing-account-info__value{color:var(--color-gray-700);font-weight:600}.billing-account-info__id{color:var(--color-gray-400);font-size:12px;font-weight:400}.btn-spinner{animation:spin .6s linear infinite;border:2px solid;border-radius:50%;border-top:2px solid transparent;display:inline-block;height:14px;margin-right:6px;vertical-align:middle;width:14px}.settings-permissions{max-height:300px;overflow-y:auto}.settings-empty{color:var(--color-gray-400);font-size:var(--font-size-sm)}.settings-empty,.settings-section-error{padding:var(--spacing-xl);text-align:center}.settings-section-error{color:var(--color-danger)}.billing-referral__link{align-items:center;display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.billing-referral__stats{display:flex;gap:var(--spacing-xl)}.billing-referral__stat{align-items:center;display:flex;flex-direction:column;gap:2px}.billing-referral__stat-value{color:var(--color-text-primary);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.billing-referral__stat-label{color:var(--color-gray-500);font-size:var(--font-size-xs)}@media (max-width:767px){.settings-layout{border:none;border-radius:0;flex-direction:column}.settings-nav{border-bottom:1px solid var(--color-gray-200);border-right:none;min-width:0;width:100%}.settings-nav-arrow{color:var(--color-gray-400);display:block}.settings-nav-item{border-left:none}.settings-nav-item.active{background:var(--color-primary-light);border-left:none}.settings-layout--section-open .settings-nav{display:none}.settings-content{padding:var(--spacing-md)}.settings-back{display:flex}.settings-form-grid,.team-grid{grid-template-columns:1fr}.team-invite-roles{grid-template-columns:1fr 1fr}.billing-plans-grid{grid-template-columns:1fr}.billing-current{align-items:flex-start;flex-direction:column;padding:16px}.billing-current__icon{height:40px;width:40px}.billing-periods{flex-wrap:wrap}.billing-period-btn{flex:0 1 auto}.billing-plan-card:hover{transform:none}.billing-plan-amount{font-size:26px}.billing-payment-card{align-items:flex-start;flex-direction:column;gap:10px}.billing-payment-card__actions{justify-content:flex-end;width:100%}.billing-trial-banner__content{gap:4px}.billing-trial-banner__content,.sch-summary{align-items:flex-start;flex-direction:column}.sch-presets,.sch-time-row{flex-wrap:wrap}.settings-branch-card{align-items:flex-start;flex-direction:column}.billing-referral__link{flex-direction:column}.billing-referral__link .btn{justify-content:center;width:100%}.billing-referral__stats{gap:var(--spacing-lg)}}.wl-section{max-width:640px}.wl-branding-form{display:flex;flex-direction:column;gap:16px}.form-row-group{display:grid;gap:16px;grid-template-columns:1fr 1fr}.color-input-wrap{align-items:center;display:flex;gap:8px}.color-input{background:none;border:1px solid var(--color-border);border-radius:8px;cursor:pointer;flex-shrink:0;height:40px;padding:2px;width:40px}.form-input--sm{flex:1}.form-check{align-items:center;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:14px;gap:8px}.form-check input[type=checkbox]{accent-color:var(--color-primary);height:18px;width:18px}.wl-domains{gap:12px;margin-bottom:16px}.wl-domain-card,.wl-domains{display:flex;flex-direction:column}.wl-domain-card{border:1px solid var(--color-border);border-radius:10px;gap:10px;padding:16px}.wl-domain-card--verified{border-left:3px solid var(--color-success)}.wl-domain-card--pending{border-left:3px solid var(--color-warning)}.wl-domain-info{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.wl-domain-name{color:var(--color-text);font-size:15px;font-weight:600}.wl-badge{border-radius:20px;font-size:11px;font-weight:500;letter-spacing:.03em;padding:2px 8px;text-transform:uppercase}.wl-badge--primary{background:var(--color-primary-50);color:var(--color-primary)}.wl-badge--ok{background:#ecfdf5;color:#059669}.wl-badge--warn{background:#fffbeb;color:#d97706}.wl-domain-actions{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.wl-verify-hint{margin-bottom:4px;width:100%}.wl-verify-hint code{background:var(--color-bg-secondary);border-radius:4px;font-size:12px;padding:2px 6px;word-break:break-all}.wl-add-domain{align-items:center;display:flex;gap:8px;margin-bottom:24px}.wl-add-domain .form-input{flex:1}.wl-setup-guide{background:var(--color-bg-secondary);border-radius:10px;margin-top:8px;padding:16px 20px}.wl-setup-guide h4{color:var(--color-text);font-size:14px;font-weight:600;margin-bottom:8px}.wl-setup-guide ol{color:var(--color-text-secondary);font-size:13px;line-height:1.8;padding-left:20px}.wl-setup-guide code{background:var(--color-white);border-radius:4px;font-size:12px;padding:1px 5px}@media (max-width:767px){.form-row-group{grid-template-columns:1fr}.wl-add-domain{flex-direction:column}.wl-add-domain .btn{width:100%}}.staff-avatar-sm{align-items:center;border-radius:var(--radius-full);color:var(--color-white);display:flex;flex-shrink:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);height:34px;justify-content:center;width:34px}.staff-avatar-sm--img{object-fit:cover}.staff-sub{color:var(--color-gray-500);margin-top:1px}.staff-comm-type,.staff-sub{font-size:var(--font-size-xs)}.staff-comm-type{color:var(--color-gray-400)}.staff-col-actions{text-align:center;width:50px}.staff-tab-switch{display:flex;gap:0;margin-right:8px}.team-sched-nav{align-items:center;display:flex;gap:12px;padding:8px 0}.team-sched-range{color:var(--color-gray-700);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.team-sched-wrap{border:1px solid var(--color-gray-200);border-radius:var(--radius);overflow-x:auto}.team-sched-table{border-collapse:collapse;font-size:var(--font-size-xs);white-space:nowrap;width:100%}.team-sched-th{background:var(--color-white);border-bottom:2px solid var(--color-gray-200);color:var(--color-gray-600);font-weight:var(--font-weight-medium);padding:6px 4px;position:sticky;text-align:center;top:0}.team-sched-name-th{left:0;min-width:160px;padding-left:12px;position:sticky;text-align:left;z-index:2}.team-sched-name-cell{align-items:center;background:var(--color-white);border-right:1px solid var(--color-gray-200);display:flex;gap:8px;left:0;min-width:160px;padding:8px 12px;position:sticky;z-index:1}.team-sched-name-link{color:var(--color-gray-800);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-decoration:none}.team-sched-name-link:hover{color:var(--color-primary)}.team-sched-day-num{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.team-sched-day-name{color:var(--color-gray-500);font-size:10px}.team-sched-cell{border-bottom:1px solid var(--color-gray-100);border-right:1px solid var(--color-gray-100);cursor:pointer;min-width:52px;padding:6px 4px;text-align:center;transition:background .15s}.team-sched-cell:hover{background:var(--color-gray-50)}.team-sched-work{background:#d1fae5;color:#065f46;font-size:11px;font-weight:var(--font-weight-medium);line-height:1.3}.team-sched-work:hover{background:#a7f3d0}.team-sched-off{background:#fee2e2;color:#991b1b;font-size:10px}.team-sched-empty{color:var(--color-gray-300)}.team-sched-weekend{background-color:#f9fafb}.team-sched-today{outline:2px solid var(--color-primary);outline-offset:-2px}.team-sched-warning{background:#fef3c7;border:1px solid #f59e0b;border-radius:var(--radius);color:#92400e;font-size:var(--font-size-sm);margin-bottom:8px;padding:8px 12px}.team-sched-warning-link{color:#92400e;font-weight:var(--font-weight-medium)}.datatable-tr--inactive{opacity:.5}.staff-color-picker{display:flex;flex-wrap:wrap;gap:6px}.staff-color-option{align-items:center;border:2px solid transparent;border-radius:var(--radius-full);cursor:pointer;display:flex;height:28px;justify-content:center;transition:transform var(--transition-fast),box-shadow var(--transition-fast);width:28px}.staff-color-option:hover{transform:scale(1.15)}.staff-color-option:has(input:checked){border-color:var(--color-white);box-shadow:0 0 0 2px currentColor,var(--shadow-md);transform:scale(1.1)}.staff-color-option input{display:none}.staff-detail-position{color:var(--color-gray-500);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.staff-detail-section{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);margin-bottom:16px;padding:20px}.staff-detail-section-header{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;margin-bottom:16px}.staff-detail-section-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);margin:0}.staff-stats-periods{display:flex;gap:4px}.staff-stats-grid{display:grid;gap:12px;grid-template-columns:repeat(4,1fr)}.staff-stat-card{background:var(--color-gray-50);border-radius:var(--radius-md);padding:12px 8px;text-align:center}.staff-stat-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);line-height:1.2}.staff-stat-label{color:var(--color-gray-500);font-size:var(--font-size-xs);margin-top:4px}.staff-schedule-grid{display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.staff-schedule-day{background:var(--color-gray-50);border-left:3px solid var(--color-primary);border-radius:var(--radius-md);padding:10px 12px}.staff-schedule-day--off{border-left-color:var(--color-gray-300);opacity:.7}.staff-schedule-date{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);margin-bottom:4px;text-transform:capitalize}.staff-schedule-time{color:var(--color-gray-700);font-size:var(--font-size-sm)}.staff-schedule-break{color:var(--color-gray-400);font-size:var(--font-size-xs);margin-top:2px}.staff-color-dot{border-radius:50%;display:inline-block;height:14px;margin-right:4px;vertical-align:middle;width:14px}.staff-form-avatar{align-items:center;border-radius:var(--radius-full);color:var(--color-white);cursor:pointer;display:flex;flex-shrink:0;font-size:24px;font-weight:var(--font-weight-bold);height:64px;justify-content:center;overflow:hidden;position:relative;width:64px}.staff-form-avatar img{height:100%;object-fit:cover;width:100%}.staff-form-avatar-overlay{align-items:center;background:rgba(0,0,0,.4);color:#fff;display:flex;inset:0;justify-content:center;opacity:0;position:absolute;transition:opacity var(--transition-fast)}.staff-form-avatar:hover .staff-form-avatar-overlay{opacity:1}.staff-section-edit-btn{color:var(--color-gray-500);gap:4px}.staff-section-edit-btn:hover{color:var(--color-primary)}.svc-edit-search-wrap{margin-bottom:12px}.svc-edit-header{color:var(--color-gray-500);display:grid;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);gap:8px;grid-template-columns:1fr 90px 90px;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.svc-edit-list{border:1px solid var(--color-gray-200);border-radius:var(--radius-md);max-height:50vh;overflow-y:auto}.svc-edit-row{align-items:center;border-bottom:1px solid var(--color-gray-100);display:grid;gap:8px;grid-template-columns:1fr auto;padding:8px 12px}.svc-edit-row:last-child{border-bottom:none}.svc-edit-check{align-items:center;cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:8px}.svc-edit-check input[type=checkbox]{flex-shrink:0}.svc-edit-check span{align-items:center;display:flex}.svc-edit-fields{display:flex;gap:6px}.svc-edit-fields--hidden{visibility:hidden}.svc-edit-dur,.svc-edit-price{text-align:center;width:80px!important}.sched-editor{min-height:200px}.sched-editor-tabs{border-bottom:1px solid var(--color-gray-200);display:flex;gap:4px;margin-bottom:16px;padding-bottom:12px}.sched-tab--hidden{display:none!important}.sched-tpl-presets{align-items:center;display:flex;flex-wrap:wrap;gap:4px;margin-bottom:12px}.sched-manual-list{border:1px solid var(--color-gray-200);border-radius:var(--radius-md);max-height:50vh;overflow-y:auto}.sched-day-row{align-items:center;border-bottom:1px solid var(--color-gray-100);display:flex;flex-wrap:wrap;gap:8px;padding:6px 12px}.sched-day-row:last-child{border-bottom:none}.sched-day-row--off{background:var(--color-gray-50);opacity:.7}.sched-day-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);min-width:120px;text-transform:capitalize}.sched-day-off-label{cursor:pointer;font-size:var(--font-size-xs);white-space:nowrap}.sched-day-off-label,.sched-day-times{align-items:center;display:flex;gap:4px}.sched-day-times{font-size:var(--font-size-sm)}.sched-day-times--hidden{visibility:hidden}.sched-day-times input[type=time]{padding:4px 6px;width:90px!important}.sched-day-times span{color:var(--color-gray-400)}@media (max-width:767px){.staff-stats-grid{grid-template-columns:repeat(2,1fr)}.staff-stats-periods{flex-wrap:wrap}.staff-schedule-grid{grid-template-columns:repeat(2,1fr)}.svc-edit-row{grid-template-columns:1fr}.svc-edit-fields{margin-left:28px}.sched-day-row{align-items:flex-start;flex-direction:column}.sched-day-times{flex-wrap:wrap}}.support-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-md)}.support-header-left{align-items:center;display:flex;gap:var(--spacing-sm)}.support-layout{border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:grid;gap:0;grid-template-columns:360px 1fr;height:calc(100vh - 200px);min-height:400px}.support-layout,.support-sidebar{background:var(--bg-primary);overflow:hidden}.support-sidebar{border-right:1px solid var(--border-color);display:flex;flex-direction:column}.support-filters{background:var(--color-gray-50);border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;gap:2px;overflow-x:auto;padding:8px;-webkit-overflow-scrolling:touch}.support-filter-btn{background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-size:.78rem;font-weight:500;padding:5px 12px;transition:all .15s;white-space:nowrap}.support-filter-btn:hover{background:var(--color-white);color:var(--text-primary)}.support-filter-btn--active{background:var(--color-white);box-shadow:var(--shadow-sm);color:var(--color-primary)}.support-ticket-list{flex:1;overflow-y:auto}.support-ticket-item{border-bottom:1px solid var(--border-color);cursor:pointer;padding:12px 14px;transition:background .15s}.support-ticket-item:hover{background:var(--bg-secondary)}.support-ticket-item--active{background:color-mix(in srgb,var(--color-primary) 8%,transparent);border-left:3px solid var(--color-primary);padding-left:11px}.support-ticket-item--unread .support-ticket-subject{font-weight:700}.support-ticket-item-header{align-items:flex-start;display:flex;gap:8px;justify-content:space-between;margin-bottom:4px}.support-ticket-subject{align-items:center;display:flex;flex:1;font-size:.88rem;font-weight:500;gap:4px;line-height:1.3;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.support-ticket-footer{align-items:center;display:flex;justify-content:space-between}.support-ticket-meta{color:var(--text-secondary);display:flex;font-size:.75rem;gap:8px}.support-ticket-time{color:var(--text-secondary);flex-shrink:0;font-size:.72rem}.support-ticket-preview{color:var(--text-secondary);font-size:.8rem;line-height:1.3;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.support-ticket-item-footer{align-items:center;display:flex;justify-content:space-between}.support-chat-source{background:var(--color-gray-100);border-radius:4px;color:var(--text-secondary);font-size:.7rem;font-weight:600;padding:1px 6px}.support-message--new{animation:supportMsgIn .3s ease}.support-priority{align-items:center;border-radius:50%;display:inline-flex;flex-shrink:0;font-size:10px;font-weight:800;height:16px;justify-content:center;width:16px}.support-priority--urgent{background:var(--badge-danger-bg);border:1px solid #fca5a5;color:var(--badge-danger-text)}.support-priority--high{background:#fff7ed;border:1px solid #fdba74;color:#ea580c}.support-empty{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;gap:8px;justify-content:center;padding:var(--spacing-xl) var(--spacing-md);text-align:center}.support-empty p{font-size:.88rem;margin:0}.support-empty-sub{font-size:.8rem;opacity:.7}.status-badge{background:color-mix(in srgb,var(--badge-color) 15%,transparent);border-radius:10px;color:var(--badge-color);flex-shrink:0;font-size:.72rem;font-weight:600;padding:2px 8px;white-space:nowrap}.support-chat{background:var(--color-gray-50);display:flex;flex-direction:column;overflow:hidden}.support-chat-header{align-items:center;background:var(--bg-primary);border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;gap:12px;justify-content:space-between;padding:10px 16px}.support-chat-header-left{align-items:center;display:flex;flex:1;gap:8px;min-width:0}.support-back-btn{display:none;flex-shrink:0}.support-chat-title{min-width:0}.support-chat-subject{font-size:.92rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.support-chat-meta-row{align-items:center;display:flex;gap:6px;margin-top:2px}.support-chat-cat,.support-chat-id{color:var(--text-secondary);font-size:.75rem}.support-chat-messages{display:flex;flex:1;flex-direction:column;gap:12px;overflow-y:auto;padding:16px}.support-chat-no-msgs{align-items:center;color:var(--text-secondary);display:flex;flex:1;font-size:.88rem;justify-content:center}.support-message{animation:supportMsgIn .2s ease;border-radius:var(--radius-lg);font-size:.88rem;line-height:1.5;max-width:75%;padding:10px 14px}@keyframes supportMsgIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.support-message--user{align-self:flex-end;background:var(--gradient-primary);border-bottom-right-radius:4px;box-shadow:0 2px 8px rgba(99,102,241,.15);color:#fff}.support-message--staff{align-self:flex-start;background:var(--color-white);border:1px solid var(--color-gray-100);border-bottom-left-radius:4px;box-shadow:0 1px 3px rgba(0,0,0,.04)}.support-message-header{display:flex;font-size:.73rem;gap:8px;justify-content:space-between;margin-bottom:4px}.support-message-author{font-weight:600}.support-message--user .support-message-header{color:hsla(0,0%,100%,.75)}.support-message--staff .support-message-header{color:var(--text-secondary)}.support-message-body{white-space:pre-wrap;word-break:break-word}.support-chat-input{align-items:flex-end;background:var(--bg-primary);border-top:1px solid var(--border-color);display:flex;flex-shrink:0;gap:8px;padding:12px 16px}.support-chat-input .input{flex:1;max-height:120px;min-height:40px;resize:none}.support-chat-closed{align-items:center;background:var(--bg-primary);border-top:1px solid var(--border-color);color:var(--text-secondary);display:flex;font-size:.85rem;gap:12px;justify-content:center;padding:14px 16px}.support-bots{margin-bottom:var(--spacing-md)}.support-bot-card,.support-bots{display:flex;gap:var(--spacing-sm)}.support-bot-card{align-items:center;border-radius:var(--radius-lg);flex:1;min-width:0;padding:10px 16px;text-decoration:none;transition:all .15s}.support-bot-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.support-bot--tg{background:#e0f2fe;border:1px solid #bae6fd;color:#08c}.support-bot--tg:hover{background:#d0ecfe}.support-bot--max{background:#f0fdf4;border:1px solid #bbf7d0;color:var(--badge-success-text)}.support-bot--max:hover{background:var(--badge-success-bg)}.support-bot-info{flex:1;min-width:0}.support-bot-name{font-size:var(--font-size-sm);font-weight:600}.support-bot-desc{font-size:var(--font-size-xs);opacity:.7}.support-bot-arrow{flex-shrink:0;opacity:.5}.support-welcome{align-items:center;color:var(--text-secondary);display:flex;flex:1;flex-direction:column;justify-content:center;padding:var(--spacing-xl);text-align:center}.support-welcome-icon{margin-bottom:var(--spacing-sm);opacity:.6}.support-welcome-title{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin-bottom:var(--spacing-xs)}.support-welcome-text{font-size:var(--font-size-sm);line-height:1.5;margin:2px 0;max-width:320px}.support-welcome-hint{margin-top:var(--spacing-sm);opacity:.8}@media (max-width:768px){.support-layout{grid-template-columns:1fr;height:calc(100vh - 220px)}.support-layout .support-chat,.support-layout--chat-open .support-sidebar{display:none}.support-layout--chat-open .support-chat{display:flex}.support-back-btn{display:inline-flex}.support-chat-messages{max-height:none}.support-chat-input{padding-bottom:calc(12px + var(--safe-area-bottom))}.support-bots{flex-direction:column}.support-header{flex-wrap:wrap;gap:8px}}.notification-settings-content{margin-top:16px}.channel-badge{border-radius:4px;display:inline-block;font-size:.75rem;font-weight:600;padding:2px 8px;text-transform:uppercase}.channel-badge--sms{background:#ede9fe;color:#6366f1}.channel-badge--email{background:var(--badge-info-bg);color:var(--badge-info-text)}.channel-badge--push{background:var(--badge-warning-bg);color:var(--badge-warning-text)}.channel-badge--telegram{background:#d1fae5;color:#059669}.text-success{color:#22c55e}.text-danger{color:#ef4444}.text-muted{color:var(--text-secondary)}.template-editor-overlay{align-items:center;background:rgba(0,0,0,.4);display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:var(--z-modal)}.template-editor{background:var(--bg-primary);border-radius:var(--radius-md);box-shadow:0 20px 60px rgba(0,0,0,.15);max-width:560px;width:100%}.template-editor-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:16px 20px}.template-editor-header h3{font-size:1rem;margin:0}.template-editor-body{padding:20px}.template-editor-footer{border-top:1px solid var(--border-color);display:flex;gap:8px;justify-content:flex-end;padding:12px 20px}.var-hints{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.var-hint{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;display:inline-block;font-family:monospace;font-size:.72rem;padding:2px 8px;transition:all .15s}.var-hint:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.visits-page{padding:var(--spacing-lg)}.visits-header{flex-wrap:wrap;justify-content:space-between;margin-bottom:var(--spacing-lg)}.visits-header,.visits-title{align-items:center;display:flex;gap:var(--spacing-sm)}.visits-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}.visit-status-badge{border-radius:999px;display:inline-block;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:2px 10px;white-space:nowrap}.visit-offline-banner{background:var(--badge-warning-bg);border-radius:var(--radius-md);color:#92400e;font-size:var(--font-size-sm);margin-bottom:var(--spacing-md);padding:8px 16px}.visit-offline-icon{font-size:var(--font-size-xs);opacity:.7}.visit-filters{margin-bottom:var(--spacing-md)}.visit-filters-row{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.visit-filters-row .clients-search{flex:1;min-width:200px}.visit-filter-status{min-width:140px;width:auto}.visit-filters-dates{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.visit-filters-dates .form-field{flex:1}.visit-date-presets{background:var(--color-gray-100);border-radius:var(--radius-md);display:flex;gap:2px;padding:2px}.visit-date-preset{background:none;border:none;border-radius:calc(var(--radius-md) - 2px);color:var(--color-gray-600);cursor:pointer;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:5px 12px;transition:all var(--transition-fast);white-space:nowrap}.visit-date-preset:hover{color:var(--color-gray-900)}.visit-date-preset--active{background:var(--color-white);box-shadow:var(--shadow-sm);color:var(--color-primary)}.visit-progress{align-items:center;display:flex;margin-bottom:var(--spacing-md);padding:var(--spacing-md) 0}.visit-progress-step{align-items:center;display:flex;flex-direction:column;flex-shrink:0;gap:4px}.visit-progress-dot{align-items:center;background:var(--color-white);border:2px solid var(--color-gray-300);border-radius:50%;color:var(--color-gray-400);display:flex;font-size:11px;font-weight:var(--font-weight-semibold);height:32px;justify-content:center;transition:all var(--transition-fast);width:32px}.visit-progress-dot svg{flex-shrink:0}.visit-progress-step--active .visit-progress-dot{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.visit-progress-step--done .visit-progress-dot{background:var(--color-success);border-color:var(--color-success);color:#fff;font-size:13px}.visit-progress-label{color:var(--color-gray-400);font-size:10px;font-weight:var(--font-weight-medium)}.visit-progress-step--active .visit-progress-label{color:var(--color-primary)}.visit-progress-step--done .visit-progress-label{color:var(--color-success)}.visit-progress-line{background:var(--color-gray-200);flex:1;height:2px;margin:0 4px 20px}.visit-assign-client{background:none;border:none;border-bottom:1px dashed var(--color-gray-400);color:var(--color-gray-500);cursor:pointer;font-size:var(--font-size-sm);padding:0}.visit-assign-client:hover{border-color:var(--color-primary);color:var(--color-primary)}.visit-notes-header{align-items:center;display:flex;gap:var(--spacing-sm)}.visit-notes-saving{color:var(--color-gray-400);font-size:var(--font-size-xs);font-style:italic}.visit-items-mobile{display:none}.visit-item-card{border:1px solid var(--color-gray-200);border-radius:var(--radius-md);margin-bottom:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md)}.visit-item-card-top{align-items:center;display:flex;justify-content:space-between}.visit-item-card-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.visit-item-card-staff{color:var(--color-gray-500);font-size:var(--font-size-xs);margin-top:2px}.visit-item-card-bottom{color:var(--color-gray-600);display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm);margin-top:4px}.visit-item-card-discount{color:var(--color-danger)}.visit-item-card-total{color:var(--color-gray-900);font-weight:var(--font-weight-semibold);margin-left:auto}.cp-search-wrap{margin-bottom:var(--spacing-sm);position:relative}.cp-search-icon{color:var(--color-gray-400);left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.cp-search-input{padding-left:36px!important;padding-right:32px!important}.cp-clear-btn{background:none;border:none;border-radius:var(--radius-sm);color:var(--color-gray-400);cursor:pointer;font-size:18px;line-height:1;padding:4px;position:absolute;right:8px;top:50%;transform:translateY(-50%)}.cp-clear-btn:hover{background:var(--color-gray-100);color:var(--color-gray-600)}.cp-toolbar{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-sm);padding:0 2px}.cp-results-count{color:var(--color-gray-400);font-size:var(--font-size-xs)}.cp-toolbar-actions{align-items:center;display:flex;gap:var(--spacing-xs)}.cp-results{border:1px solid var(--color-gray-200);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);max-height:320px;overflow-y:auto}.cp-result{align-items:center;border-bottom:1px solid var(--color-gray-100);cursor:pointer;display:flex;gap:var(--spacing-sm);padding:10px var(--spacing-md);transition:background var(--transition-fast)}.cp-result:last-child{border-bottom:none}.cp-result:hover{background:var(--color-gray-50)}.cp-result--active{background:var(--color-primary-light)}.cp-avatar{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:var(--font-weight-semibold);height:36px;justify-content:center;letter-spacing:.02em;width:36px}.cp-result-main{flex:1;min-width:0}.cp-result-name{align-items:center;display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:6px}.cp-result-name mark{background:#fef08a;border-radius:2px;padding:0 1px}.cp-result-phone{color:var(--color-gray-500);font-size:var(--font-size-xs);margin-top:2px}.cp-result-phone mark{background:#fef08a;border-radius:2px;padding:0 1px}.cp-result-discount{background:var(--color-success-light,#ecfdf5);border-radius:8px;color:var(--color-success);font-size:10px;font-weight:var(--font-weight-semibold);padding:1px 5px}.cp-result-right{align-items:center;display:flex;flex-shrink:0;gap:var(--spacing-sm)}.cp-result-stats{align-items:flex-end;display:flex;flex-direction:column;gap:2px}.cp-result-visits{color:var(--color-gray-600);font-size:var(--font-size-xs)}.cp-result-last{color:var(--color-gray-400);font-size:10px}.cp-result-new{color:var(--color-primary);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.cp-result-info{background:none;border:none;border-radius:var(--radius-sm);color:var(--color-gray-400);cursor:pointer;padding:6px;transition:color .15s,background .15s}.cp-result-info:hover{background:var(--color-primary-light);color:var(--color-primary)}.cp-loading{align-items:center;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm);justify-content:center;padding:var(--spacing-xl)}.cp-empty,.cp-loading{color:var(--color-gray-500);text-align:center}.cp-empty{padding:var(--spacing-xl) var(--spacing-lg)}.cp-empty__icon{font-size:32px;margin-bottom:var(--spacing-xs);opacity:.6}.cp-empty__text{font-size:var(--font-size-sm);margin-bottom:var(--spacing-sm)}.cp-empty__create{margin-top:var(--spacing-xs)}.cp-hint{border-top:1px solid var(--color-gray-100);color:var(--color-gray-400);font-size:11px;padding-top:var(--spacing-xs);text-align:center}.cp-client-info{display:flex;flex-direction:column;gap:var(--spacing-sm)}.cp-info-row{border-bottom:1px solid var(--color-gray-100);display:flex;font-size:var(--font-size-sm);justify-content:space-between;padding:var(--spacing-xs) 0}.cp-info-row:last-child{border-bottom:none}.cp-info-label{color:var(--color-gray-500)}.cp-create-form{background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);padding:var(--spacing-md)}.cp-create-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-sm)}.cp-create-fields{display:flex;flex-direction:column;gap:var(--spacing-xs)}.cp-create-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-sm)}.cp-create-error{color:var(--color-danger);font-size:var(--font-size-xs);margin-top:var(--spacing-xs)}.visit-card{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);cursor:pointer;margin-bottom:var(--spacing-sm);padding:var(--spacing-md);transition:box-shadow var(--transition-fast)}.visit-card:hover{box-shadow:var(--shadow-md)}.visit-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-xs)}.visit-card-client{font-weight:var(--font-weight-medium)}.visit-card-stats{color:var(--color-gray-600);display:flex;font-size:var(--font-size-sm);justify-content:space-between}.visit-card-date{margin-top:var(--spacing-xs)}.visit-card-date,.visit-list-phone{color:var(--color-gray-500);font-size:var(--font-size-xs)}.visit-list-muted{color:var(--color-gray-400)}.visit-card-staff{color:var(--color-gray-600);font-size:var(--font-size-sm);margin-top:2px}.visit-page{padding:var(--spacing-lg)}.visit-detail-layout{display:grid;gap:var(--spacing-lg);grid-template-columns:1fr 320px}.visit-detail-main{min-width:0}.visit-detail-header{margin-bottom:var(--spacing-lg)}.visit-detail-title-row{align-items:center;display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.visit-detail-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}.visit-detail-meta{align-items:center;color:var(--color-gray-600);display:flex;flex-wrap:wrap;font-size:var(--font-size-sm);gap:var(--spacing-sm);margin-top:var(--spacing-xs)}.visit-detail-sep{color:var(--color-gray-400)}.visit-detail-client-link{color:var(--color-primary);text-decoration:none}.visit-detail-client-link--lg{font-size:var(--font-size-lg);font-weight:600}.visit-detail-client-link:hover{text-decoration:underline}.visit-client-discount{background:var(--color-success);border-radius:var(--radius-sm);color:#fff;display:inline-block;font-size:var(--font-size-xs);font-weight:700;margin-left:6px;padding:1px 6px}.visit-detail-staff{align-items:center;display:inline-flex;gap:4px}.visit-assign-client,.visit-assign-staff{color:var(--color-gray-500);font-size:var(--font-size-sm);padding:0}.visit-change-staff{color:var(--color-gray-400);font-size:12px;padding:0}.visit-staff-list{display:flex;flex-direction:column;gap:4px;max-height:400px;overflow-y:auto}.visit-staff-option{align-items:center;border-radius:var(--radius-md);cursor:pointer;display:flex;justify-content:space-between;padding:10px 14px;transition:background .15s}.visit-staff-option:hover{background:var(--color-gray-100)}.visit-staff-option--active{background:var(--color-primary-light,#eef2ff);border:1px solid var(--color-primary)}.visit-staff-option-name{font-weight:var(--font-weight-medium)}.visit-staff-option-pos{color:var(--color-gray-500);font-size:var(--font-size-sm)}.visit-void-overlay{background:var(--badge-danger-bg);border-radius:var(--radius-md);color:var(--color-danger);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);padding:var(--spacing-xl);text-align:center}.visit-items-section{margin-bottom:var(--spacing-lg)}.visit-section-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-sm)}.visit-items-table{width:100%}.visit-col-num{text-align:right;width:90px}.visit-col-action{text-align:center;width:40px}.visit-inline-input{background:var(--color-white);border:1px solid var(--color-gray-300);border-radius:var(--radius-sm);font-size:var(--font-size-sm);padding:4px 6px;text-align:right;width:80px}.visit-inline-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-alpha);outline:none}.visit-remove-item{color:var(--color-gray-400);cursor:pointer}.visit-remove-item:hover{color:var(--color-danger)}.visit-add-btns{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.visit-notes-section{margin-bottom:var(--spacing-lg)}.visit-notes{min-height:48px;resize:vertical;width:100%}.visit-detail-sidebar{align-self:start;position:sticky;top:var(--spacing-lg)}.visit-summary{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);padding:var(--spacing-md)}.visit-summary-row{display:flex;font-size:var(--font-size-sm);justify-content:space-between;padding:6px 0}.visit-summary-divider{border-top:1px solid var(--color-gray-200);margin:var(--spacing-xs) 0}.visit-summary-total{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold)}.visit-summary-paid span:last-child{color:var(--color-success)}.visit-summary-remaining span:last-child{color:var(--color-danger);font-weight:var(--font-weight-medium)}.visit-summary-editable{border-bottom:1px dashed var(--color-gray-400);cursor:pointer}.visit-summary-editable:hover{color:var(--color-primary)}.visit-tips-method{color:var(--color-gray-400);font-weight:400}.visit-tips-edit{align-items:center;display:flex;gap:4px}.visit-discount-pct{color:var(--color-gray-400);font-weight:400}.visit-discount-edit{display:flex;flex-direction:column;gap:8px;padding:8px 0}.visit-discount-presets{display:flex;flex-wrap:wrap;gap:4px}.visit-discount-preset{background:var(--color-white);border:1px solid var(--color-gray-300);border-radius:var(--radius-full);color:var(--color-gray-600);cursor:pointer;font-size:11px;padding:3px 8px;transition:all var(--transition-fast)}.visit-discount-preset:hover{border-color:var(--color-primary);color:var(--color-primary)}.visit-discount-preset--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.visit-discount-inputs{align-items:center;display:flex;gap:6px}.visit-discount-input-group{align-items:center;display:flex;gap:2px}.visit-discount-input-group .visit-inline-input{width:64px}.visit-discount-unit{color:var(--color-gray-500);font-size:var(--font-size-xs)}.visit-discount-or{color:var(--color-gray-400);font-size:var(--font-size-xs)}.visit-discount-actions{align-items:center;display:flex;gap:6px}.visit-discount-clear{color:var(--color-danger)!important}.visit-inline-select{background:var(--bg-primary);border:1px solid var(--color-gray-300);border-radius:var(--radius-sm);font-size:var(--font-size-xs);padding:2px 4px}.visit-payment-change-method{background:none;border:none;color:var(--color-gray-400);cursor:pointer;font-size:12px;opacity:0;padding:0 2px;transition:opacity .15s}.visit-payment-row:hover .visit-payment-change-method{opacity:1}.visit-payment-change-method:hover{color:var(--color-primary)}.visit-method-options{display:flex;flex-direction:column;gap:var(--spacing-sm)}.visit-method-option{align-items:center;background:var(--bg-primary);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);transition:all .15s}.visit-method-option--active,.visit-method-option:hover{background:var(--color-primary-light);border-color:var(--color-primary)}.visit-method-option--active{font-weight:var(--font-weight-medium)}.visit-method-option-icon{font-size:18px;text-align:center;width:24px}.visit-actions{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.visit-action-btn{align-items:center;display:inline-flex;gap:6px;justify-content:center;width:100%}.visit-void-btn{color:var(--color-danger)!important}.visit-void-btn:hover{background:#fef2f2!important}.visit-add-btns .btn{align-items:center;display:inline-flex;gap:5px}.visit-empty-items{align-items:center;color:var(--color-gray-400);display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-xl) 0}.visit-empty-items p{font-size:var(--font-size-sm);margin:0}.visit-payments-list{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);padding:var(--spacing-md)}.visit-payment-row{display:flex;font-size:var(--font-size-sm);justify-content:space-between;padding:6px 0}.visit-payment-method{align-items:center;display:flex;gap:var(--spacing-xs)}.visit-payment-icon{font-size:var(--font-size-md)}.visit-payment-amount{align-items:center;display:flex;gap:6px}.visit-payment-remove{background:none;border:none;border-radius:var(--radius-sm);color:var(--color-gray-400);cursor:pointer;font-size:12px;line-height:1;padding:2px 4px;transition:color var(--transition-fast)}.visit-payment-remove:hover,.visit-payment-row--refund{color:var(--color-danger)}.visit-payment-amount--refund{color:var(--color-danger);font-weight:var(--font-weight-medium)}.visit-payment-ref{color:var(--color-gray-500);font-size:var(--font-size-xs);margin-bottom:4px;margin-top:-4px;padding-left:28px}.visit-refund-btn{border-color:var(--color-danger-light,#fecaca);color:var(--color-danger);margin-top:var(--spacing-sm);width:100%}.visit-refund-btn:hover{background:var(--color-danger-light,#fef2f2)}.refund-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.refund-info{background:var(--color-gray-50);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md)}.refund-info-row{display:flex;font-size:var(--font-size-sm);justify-content:space-between;padding:4px 0}.refund-quick-amounts{display:flex;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.refund-reason-presets{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:var(--spacing-xs)}.refund-quick-amt{font-size:var(--font-size-xs)}.payment-panel-overlay{align-items:center;background:rgba(0,0,0,.5);display:flex;inset:0;justify-content:center;padding:var(--spacing-md);position:fixed;z-index:var(--z-modal)}.payment-panel{background:var(--color-white);border-radius:var(--radius-lg);max-height:90vh;max-width:480px;overflow-y:auto;padding:var(--spacing-lg);width:100%}.payment-panel-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-md)}.payment-panel-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.payment-panel-remaining{font-size:var(--font-size-md);text-align:center}.payment-amount-wrap,.payment-panel-remaining{margin-bottom:var(--spacing-md)}.payment-amount-input{border:2px solid var(--color-gray-300);border-radius:var(--radius-md);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);padding:var(--spacing-sm);text-align:center;width:100%}.payment-amount-input:focus{border-color:var(--color-primary);outline:none}.payment-methods-grid{display:grid;gap:var(--spacing-sm);grid-template-columns:repeat(3,1fr);margin-bottom:var(--spacing-md)}.payment-method-card{align-items:center;background:var(--color-white);border:2px solid var(--color-gray-200);border-radius:var(--radius-md);cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:var(--spacing-sm);transition:border-color var(--transition-fast),background var(--transition-fast)}.payment-method-card:hover{background:var(--color-gray-50);border-color:var(--color-primary)}.payment-method-card--active{background:#eff6ff;border-color:var(--color-primary)}.payment-method-icon{font-size:24px}.payment-method-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.payment-method-balance{color:var(--color-gray-500);font-size:10px}.payment-cert-section,.payment-reference-wrap{margin-bottom:var(--spacing-md)}.payment-cert-input-row{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.payment-cert-input-row .input{flex:1;font-family:var(--font-mono,monospace);letter-spacing:1px}.payment-cert-card{background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md)}.payment-cert-card--inactive{opacity:.6}.payment-cert-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.payment-cert-code{font-family:var(--font-mono,monospace);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.payment-cert-status{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.payment-cert-details{color:var(--color-gray-500);font-size:var(--font-size-xs);margin-bottom:6px}.payment-cert-balance-row{align-items:center;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-xs)}.payment-cert-balance-row strong{color:var(--color-success)}.payment-cert-nominal{color:var(--color-gray-400);font-size:var(--font-size-xs)}.payment-cert-validity{color:var(--color-gray-500);font-size:var(--font-size-xs);margin-top:4px}.payment-cert-error{color:var(--color-danger);font-size:var(--font-size-sm);padding:var(--spacing-sm);text-align:center}.add-item-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.add-item-search-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.add-item-count{color:var(--color-gray-400);font-size:var(--font-size-xs);font-weight:400}.add-item-search-row{align-items:center;display:flex;gap:var(--spacing-xs)}.add-item-search-wrap{flex:1;position:relative}.add-item-search-icon{color:var(--color-gray-400);left:10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.add-item-search-input{padding-left:32px!important;padding-right:28px!important}.add-item-clear-btn{background:none;border:none;color:var(--color-gray-400);cursor:pointer;font-size:18px;line-height:1;padding:0 4px;position:absolute;right:6px;top:50%;transform:translateY(-50%)}.add-item-clear-btn:hover{color:var(--color-gray-600)}.add-item-results{border:1px solid var(--color-gray-200);border-radius:var(--radius-md);max-height:220px;overflow-y:auto}.add-item-results:empty{display:none}.add-item-result{border-bottom:1px solid var(--color-gray-100);cursor:pointer;padding:var(--spacing-sm) var(--spacing-md);transition:background var(--transition-fast)}.add-item-result:last-child{border-bottom:none}.add-item-result:hover{background:var(--color-gray-50)}.add-item-result--active{background:var(--color-primary-50,#eef2ff)}.add-item-result-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.add-item-result-name mark{background:#fef08a;border-radius:2px}.add-item-result-meta{color:var(--color-gray-500);display:flex;font-size:var(--font-size-xs);gap:var(--spacing-sm);margin-top:2px}.add-item-empty{align-items:center;color:var(--color-gray-400);display:flex;flex-direction:column;font-size:var(--font-size-sm);gap:var(--spacing-xs);padding:var(--spacing-lg)}.add-item-loading{color:var(--color-gray-500);font-size:var(--font-size-sm);padding:var(--spacing-md);text-align:center}.add-item-selected-pill{align-items:center;background:var(--color-primary-50,#eef2ff);border:1px solid var(--color-primary);border-radius:var(--radius-md);display:flex;gap:var(--spacing-sm);justify-content:space-between;padding:8px 12px}.add-item-selected-pill-info{display:flex;flex-direction:column;min-width:0}.add-item-selected-pill-name{color:var(--color-primary);font-size:var(--font-size-sm);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.add-item-selected-pill-meta{color:var(--color-gray-500);font-size:var(--font-size-xs);margin-top:1px}.add-item-selected-pill-clear{background:none;border:none;color:var(--color-primary);cursor:pointer;flex-shrink:0;font-size:18px;line-height:1;padding:0 0 0 8px}.add-item-selected-pill-clear:hover{color:var(--color-danger)}.add-item-discount-presets{display:flex;gap:4px;margin-top:4px}.add-item-discount-preset{background:var(--color-gray-100);border:none;border-radius:var(--radius-sm);color:var(--color-gray-600);cursor:pointer;font-size:var(--font-size-xs);padding:2px 8px;transition:all .15s}.add-item-discount-preset:hover{background:var(--color-primary-50,#eef2ff);color:var(--color-primary)}.add-item-total{font-size:var(--font-size-md);text-align:right}.visit-receipt{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);margin:var(--spacing-lg) auto 0;max-width:400px;padding:var(--spacing-lg)}.visit-receipt-header{margin-bottom:var(--spacing-md);text-align:center}.visit-receipt-salon{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold)}.visit-receipt-date{color:var(--color-gray-500);font-size:var(--font-size-xs)}.visit-receipt-client{font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}.visit-receipt-table{margin-bottom:var(--spacing-sm);width:100%}.visit-receipt-th{border-bottom:1px solid var(--color-gray-200);color:var(--color-gray-500);font-size:var(--font-size-xs);padding:4px 0;text-align:left}.visit-receipt-line,.visit-receipt-td{font-size:var(--font-size-sm);padding:4px 0}.visit-receipt-total{border-top:2px solid var(--color-gray-800);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);padding:var(--spacing-sm) 0}.visit-receipt-payments{padding:var(--spacing-xs) 0}.visit-receipt-pay-row{display:flex;font-size:var(--font-size-sm);justify-content:space-between;padding:2px 0}.visit-receipt-thanks{color:var(--color-gray-500);font-size:var(--font-size-sm);margin-top:var(--spacing-md);text-align:center}.visit-receipt-print{margin-top:var(--spacing-md);width:100%}@media print{body *{visibility:hidden!important}.visit-receipt,.visit-receipt *{visibility:visible!important}.visit-receipt{border:none!important;box-shadow:none!important;left:0;max-width:100%!important;padding:20px!important;position:absolute!important;top:0;width:100%!important}.bottom-nav,.header,.sidebar,.visit-mobile-footer,.visit-receipt-print{display:none!important}}.visit-status-tabs{background:var(--color-gray-100);border-radius:var(--radius-md);display:flex;gap:2px;margin-bottom:var(--spacing-md);overflow-x:auto;padding:3px}.visit-status-tab{background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-gray-600);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:6px 14px;transition:all var(--transition-fast);white-space:nowrap}.visit-status-tab:hover{color:var(--color-gray-900)}.visit-status-tab--active{background:var(--color-white);box-shadow:var(--shadow-sm);color:var(--color-primary)}.visit-status-tab-count{background:var(--color-gray-200);border-radius:10px;display:inline-block;font-size:11px;margin-left:2px;padding:0 6px}.visit-status-tab--active .visit-status-tab-count{background:var(--color-primary);color:var(--color-white)}.visit-hover-cell{position:relative}.visit-hover-action{opacity:0;transition:opacity var(--transition-fast);white-space:nowrap}.datatable-tr:hover .visit-hover-action{opacity:1}.visit-row--open{background:#eff6ff}.visit-row--checkout{background:#fffbeb}.visit-elapsed{color:var(--color-gray-400);font-size:11px;margin-top:1px}.visit-timer{background:var(--color-primary-light,#eff6ff);border-radius:var(--radius-sm);color:var(--color-primary);font-size:var(--font-size-xs);font-variant-numeric:tabular-nums;font-weight:var(--font-weight-medium);padding:2px 8px}.visit-no-client-banner{align-items:center;background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius-md);color:#92400e;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm);margin-top:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md)}.visit-created-badge{animation:visitCreatedFade 3s ease-out forwards;background:#f0fdf4;border-radius:var(--radius-md);color:var(--badge-success-text);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-md);padding:var(--spacing-sm);text-align:center}@keyframes visitCreatedFade{0%,70%{opacity:1}to{opacity:0}}.visit-quick-services{background:var(--color-gray-50);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);padding:var(--spacing-sm)}.visit-quick-services-label{color:var(--color-gray-500);font-size:var(--font-size-xs);margin-bottom:var(--spacing-xs)}.visit-quick-services-chips{display:flex;flex-wrap:wrap;gap:6px}.visit-quick-chip{align-items:center;background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:20px;cursor:pointer;display:inline-flex;font-size:var(--font-size-xs);gap:4px;padding:5px 10px;transition:all var(--transition-fast)}.visit-quick-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.visit-quick-chip:active{background:#eff6ff}.visit-quick-chip--loading{opacity:.5;pointer-events:none}.visit-quick-chip-price{color:var(--color-gray-400);font-size:10px}.visit-quick-pay{margin-bottom:var(--spacing-sm)}.visit-quick-pay-label{color:var(--color-gray-700);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-xs)}.visit-quick-pay-buttons{display:grid;gap:var(--spacing-xs);grid-template-columns:repeat(3,1fr)}.visit-quick-pay-btn{align-items:center;background:var(--color-white);border:2px solid var(--color-gray-200);border-radius:var(--radius-md);cursor:pointer;display:flex;flex-direction:column;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:4px;padding:var(--spacing-sm) var(--spacing-xs);transition:all var(--transition-fast)}.visit-quick-pay-btn:hover{background:#eff6ff;border-color:var(--color-primary);transform:translateY(-1px)}.visit-quick-pay-btn:active{transform:translateY(0)}.visit-quick-pay-btn:disabled{opacity:.5;pointer-events:none}.visit-quick-pay-icon{font-size:20px}.visit-actions-secondary{display:flex;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.visit-mobile-footer{display:none}.call-popup-client-card{background:var(--color-gray-50);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);padding:var(--spacing-sm)}.call-popup-freq{color:var(--color-gray-500);font-size:var(--font-size-xs);margin-top:4px}.call-popup-recent{margin-top:var(--spacing-xs)}.call-popup-recent-title{font-weight:var(--font-weight-medium);margin-bottom:4px}.call-popup-recent-item,.call-popup-recent-title{color:var(--color-gray-600);font-size:var(--font-size-xs)}.call-popup-recent-item{display:flex;gap:var(--spacing-sm);justify-content:space-between;padding:2px 0}.call-popup-recent-item span:nth-child(2){flex:1}@media (max-width:768px){.visit-page,.visits-page{padding:var(--spacing-md)}.visit-detail-layout{grid-template-columns:1fr;padding-bottom:80px}.visit-detail-sidebar{position:static}.visit-items-table{display:none}.visit-items-mobile{display:flex;flex-direction:column}.visit-col-num{width:60px}.visit-inline-input{width:56px}.payment-methods-grid{grid-template-columns:repeat(2,1fr)}.visit-filters-row{align-items:stretch;flex-direction:column}.visit-filters-row .clients-search{min-width:0}.visit-date-presets{flex-wrap:wrap;justify-content:center}.visit-filter-status{min-width:auto;width:100%}.visit-progress-label{font-size:9px}.visit-progress-dot{font-size:10px;height:24px;width:24px}.visit-quick-pay-buttons{grid-template-columns:repeat(2,1fr)}.visit-hover-action{display:none!important}.visit-status-tabs{overflow-x:auto}.visit-mobile-footer{align-items:center;background:var(--color-white);border-top:1px solid var(--color-gray-200);bottom:0;box-shadow:0 -2px 10px rgba(0,0,0,.1);display:flex;gap:var(--spacing-sm);justify-content:space-between;left:0;padding:var(--spacing-sm) var(--spacing-md) calc(var(--spacing-sm) + var(--safe-area-bottom));position:fixed;right:0;z-index:var(--z-dropdown)}.visit-mobile-total{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold)}.visit-mobile-footer .btn{flex:1}}.wh-content{min-height:200px}.wh-in-shell .finance-header{display:none}.wh-shell-title{min-width:0}.wh-products-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px}.wh-products-toolbar .services-actions{align-items:center;display:flex;flex-shrink:0;gap:8px}@media (max-width:767px){.wh-products-toolbar{align-items:stretch;flex-direction:column}.wh-products-toolbar .services-actions{justify-content:flex-end}}.wh-tabs{background:var(--color-gray-100);border-radius:var(--radius-lg);display:flex;flex-wrap:wrap;gap:2px;padding:3px}.wh-tab{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--color-gray-500);cursor:pointer;display:inline-flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:6px;line-height:1.4;padding:6px 14px;text-decoration:none;transition:all var(--transition-fast);white-space:nowrap}.wh-tab:hover{background:var(--color-gray-50);color:var(--color-gray-700)}.wh-tab--active{background:var(--color-white);box-shadow:0 1px 3px rgba(0,0,0,.08);color:var(--color-gray-900)}.wh-tab--accent{color:var(--color-primary)}.wh-tab--accent.wh-tab--active{background:var(--color-primary);box-shadow:0 1px 3px rgba(99,102,241,.3);color:#fff}.wh-tab__icon{font-size:14px;line-height:1}.wh-filters{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.wh-filters .input--sm{min-width:140px;width:auto}.wh-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);gap:4px;letter-spacing:.01em;padding:2px 10px}.wh-badge--sale{background:var(--color-info-light);color:var(--color-info)}.wh-badge--consumable{background:#f3e8ff;color:#7c3aed}.wh-mov-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);gap:4px;padding:3px 10px;white-space:nowrap}.wh-mov-badge--incoming{background:#ecfdf5;color:#059669}.wh-mov-badge--outgoing{background:#fef2f2;color:#dc2626}.wh-mov-badge--sale{background:#fffbeb;color:#d97706}.wh-mov-badge--consumption{background:#f5f3ff;color:#7c3aed}.wh-mov-badge--transfer_in{background:#eff6ff;color:#2563eb}.wh-mov-badge--transfer_out{background:#eef2ff;color:#4f46e5}.wh-mov-badge--inventory{background:var(--color-gray-100);color:var(--color-gray-600)}.wh-mov-badge__dot{background:currentColor;border-radius:50%;flex-shrink:0;height:6px;width:6px}.wh-branch-group{margin-bottom:var(--spacing-xl)}.wh-branch-title{align-items:center;border-bottom:2px solid var(--color-primary);color:var(--color-text);display:flex;font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);gap:var(--spacing-sm);margin:0 0 var(--spacing-sm) 0;padding-bottom:var(--spacing-xs)}.wh-branch-subtotal{color:var(--color-gray-400);font-size:var(--font-size-xs);font-weight:var(--font-weight-normal);margin-left:auto}.wh-row--low{background:var(--color-danger-light)}.wh-qty--low{color:var(--color-danger)!important;font-weight:var(--font-weight-semibold)}.wh-low-toggle{align-items:center;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:var(--font-size-sm);gap:6px;padding:4px 12px;transition:all var(--transition-fast);user-select:none;white-space:nowrap}.wh-low-toggle:hover{background:var(--color-gray-50)}.wh-low-toggle:has(input:checked){background:var(--color-danger-light);border-color:var(--color-danger);color:var(--color-danger)}.wh-low-toggle input[type=checkbox]{accent-color:var(--color-danger)}.wh-low-icon{font-size:14px}.wh-diff--plus{color:var(--color-success);font-weight:var(--font-weight-semibold)}.wh-diff--plus:before{content:"\2191 ";font-size:.75em}.wh-diff--minus{color:var(--color-danger);font-weight:var(--font-weight-semibold)}.wh-diff--minus:before{content:"\2193 ";font-size:.75em}.wh-qty-control{align-items:center;background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);display:inline-flex;overflow:hidden}.wh-qty-control__btn{align-items:center;background:none;border:none;color:var(--color-gray-600);cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;padding:0;transition:all var(--transition-fast);width:32px}.wh-qty-control__btn:hover{background:var(--color-gray-200);color:var(--color-gray-900)}.wh-qty-control__btn:active{background:var(--color-gray-300)}.wh-qty-control__input{-moz-appearance:textfield;background:var(--color-white);border:none;border-left:1px solid var(--color-gray-200);border-right:1px solid var(--color-gray-200);color:var(--color-gray-900);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);height:32px;padding:0;text-align:center;width:52px}.wh-qty-control__input::-webkit-inner-spin-button,.wh-qty-control__input::-webkit-outer-spin-button{-webkit-appearance:none}.wh-cp-row{align-items:center;display:flex;gap:var(--spacing-xs)}.wh-cp-row .input{flex:1}.wh-cp-row .btn{flex-shrink:0;font-size:18px;height:36px;padding:0;width:36px}.wh-product-picker-create{background:var(--color-primary-light);border-top:1px solid var(--color-gray-200)}.wh-product-picker-create:hover{background:var(--color-primary-50)}.wh-print-area{padding:var(--spacing-lg)}@media print{.finance-header,.wh-tabs{display:none!important}.wh-print-area{padding:0}}.wh-form-actions .btn--primary{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);padding:10px 28px}.wh-incoming-form,.wh-inventory-form{max-width:960px}.wh-writeoff-form{max-width:1100px}.wh-add-item-bar{align-items:center;display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.wh-add-item-bar .input--sm{flex:1;min-width:200px}.wh-form-actions{border-top:1px solid var(--color-gray-200);display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-lg);padding-top:var(--spacing-md)}.wh-summary-cards{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-bottom:var(--spacing-lg)}.wh-summary-card{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:4px;padding:var(--spacing-md) var(--spacing-lg);transition:all var(--transition-fast)}.wh-summary-card:hover{box-shadow:var(--shadow-sm,0 1px 4px rgba(0,0,0,.06));transform:translateY(-1px)}.wh-summary-card__icon{font-size:20px;line-height:1;margin-bottom:2px}.wh-summary-card__label{color:var(--color-gray-500);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);letter-spacing:.04em;text-transform:uppercase}.wh-summary-card__value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing)}.wh-summary-card--cost{background:linear-gradient(135deg,#eff6ff 0,var(--color-white) 100%);border-color:#93c5fd}.wh-summary-card--cost .wh-summary-card__value{color:#1d4ed8}.wh-summary-card--sell{background:linear-gradient(135deg,#f0fdf4 0,var(--color-white) 100%);border-color:#86efac}.wh-summary-card--sell .wh-summary-card__value{color:#166534}.wh-summary-card--danger{background:linear-gradient(135deg,#fef2f2 0,var(--color-white) 100%);border-color:#fca5a5}.wh-summary-card--danger .wh-summary-card__value{color:var(--color-danger)}.wh-wo-layout{display:grid;gap:var(--spacing-lg);grid-template-columns:minmax(260px,1fr) 1.6fr;margin-top:var(--spacing-md)}.wh-wo-picker{gap:var(--spacing-sm)}.wh-wo-picker,.wh-wo-product-list{display:flex;flex-direction:column}.wh-wo-product-list{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);gap:2px;max-height:420px;overflow-y:auto;padding:var(--spacing-xs)}.wh-wo-product-row{align-items:center;border-radius:var(--radius-sm);cursor:pointer;display:flex;gap:var(--spacing-sm);padding:8px var(--spacing-sm);transition:all var(--transition-fast)}.wh-wo-product-row:hover{background:var(--color-primary-light)}.wh-wo-product-info{flex:1;min-width:0}.wh-wo-product-info strong{display:block;font-size:var(--font-size-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wh-wo-sku{color:var(--color-gray-400);font-size:var(--font-size-xs)}.wh-wo-stock{color:var(--color-gray-500);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);white-space:nowrap}.wh-wo-section-title{display:flex;font-size:var(--font-size-md);gap:var(--spacing-sm);margin:0 0 var(--spacing-sm)}.wh-wo-section-count,.wh-wo-section-title{align-items:center;font-weight:var(--font-weight-semibold)}.wh-wo-section-count{background:var(--color-primary);border-radius:11px;color:#fff;display:inline-flex;font-size:var(--font-size-xs);height:22px;justify-content:center;min-width:22px;padding:0 6px}.wh-sale-layout{align-items:start;display:grid;gap:var(--spacing-lg);grid-template-columns:320px 1fr;margin-top:var(--spacing-md)}.wh-sale-picker{display:flex;flex-direction:column;gap:var(--spacing-sm);position:sticky;top:var(--spacing-md)}.wh-sale-product-list{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:2px;max-height:520px;overflow-y:auto;padding:var(--spacing-xs)}.wh-sale-product{align-items:center;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;display:flex;gap:var(--spacing-sm);padding:10px var(--spacing-sm);transition:all var(--transition-fast)}.wh-sale-product:hover{background:var(--color-primary-light);border-color:rgba(99,102,241,.15)}.wh-sale-product__info{flex:1;min-width:0}.wh-sale-product__info strong{display:block;font-size:var(--font-size-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wh-sale-product__sku{color:var(--color-gray-400);display:block;font-size:var(--font-size-xs);margin-top:2px}.wh-sale-product__meta{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0;gap:2px}.wh-sale-product__price{color:var(--color-gray-900);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.wh-sale-product__stock{color:var(--color-gray-400);font-size:var(--font-size-xs)}.wh-sale-cart{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);display:flex;flex-direction:column;min-width:0;padding:var(--spacing-lg)}.wh-sale-cart .datatable-table{margin:0 calc(var(--spacing-lg)*-1);width:calc(100% + var(--spacing-lg)*2)}.wh-sale-cart .datatable-table thead{position:sticky;top:0;z-index:1}.wh-sale-cart__unit{color:var(--color-gray-400);font-size:var(--font-size-xs);margin-top:2px}.wh-sale-cart__title{display:flex;font-size:var(--font-size-md);gap:var(--spacing-sm);margin:0 0 var(--spacing-md)}.wh-sale-cart__count,.wh-sale-cart__title{align-items:center;font-weight:var(--font-weight-semibold)}.wh-sale-cart__count{background:var(--color-primary);border-radius:11px;color:#fff;display:inline-flex;font-size:var(--font-size-xs);height:22px;justify-content:center;min-width:22px;padding:0 6px}.wh-sale-qty-control{align-items:center;display:flex;gap:2px}.wh-sale-qty-control .btn--xs{border-radius:var(--radius-sm);font-size:16px;height:28px;padding:0;width:28px}.wh-sale-summary{background:var(--color-gray-50);border-radius:0 0 var(--radius-lg) var(--radius-lg);border-top:1px solid var(--color-gray-200);display:flex;flex-direction:column;gap:var(--spacing-md);margin:var(--spacing-lg) calc(var(--spacing-lg)*-1) calc(var(--spacing-lg)*-1);padding:var(--spacing-lg)}.wh-sale-total{align-items:center;display:flex;font-size:var(--font-size-lg);justify-content:space-between}.wh-sale-total strong{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing)}.wh-sale-payment{align-items:center;display:flex;gap:var(--spacing-md)}.wh-sale-pay-label{color:var(--color-gray-500);font-size:var(--font-size-sm);white-space:nowrap}.wh-sale-pay-options{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.wh-sale-pay-opt{align-items:center;background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);color:var(--color-gray-600);cursor:pointer;display:inline-flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:6px;padding:8px 16px;transition:all var(--transition-fast)}.wh-sale-pay-opt:hover{border-color:var(--color-primary);color:var(--color-primary)}.wh-sale-pay-opt input{display:none}.wh-sale-pay-opt--active{background:var(--color-primary);border-color:var(--color-primary);box-shadow:0 2px 6px rgba(99,102,241,.25);color:#fff}.wh-sale-pay-opt__icon{font-size:16px;line-height:1}.wh-sale-submit{align-self:stretch;font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);margin-top:var(--spacing-xs);padding:12px 24px}.wh-product-picker-wrap{flex:1;min-width:200px;position:relative}.wh-product-picker-dropdown{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);box-shadow:0 8px 24px rgba(0,0,0,.12);left:0;margin-top:4px;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:20}.wh-product-picker-item{align-items:center;cursor:pointer;display:flex;gap:var(--spacing-sm);padding:8px var(--spacing-sm);transition:background var(--transition-fast)}.wh-product-picker-item:hover{background:var(--color-primary-light)}.wh-product-picker-item strong{flex:1;font-size:var(--font-size-sm)}.wh-product-picker-cost{color:var(--color-gray-400);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.wh-mov-notes{color:var(--color-gray-500);font-size:var(--font-size-sm);max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wh-qty-cell{align-items:center;display:inline-flex;font-weight:var(--font-weight-medium);gap:4px}.wh-qty-cell--plus{color:var(--color-success)}.wh-qty-cell--minus{color:var(--color-danger)}.wh-inv-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.wh-inv-toolbar .input--sm{flex:1;max-width:300px;min-width:200px}.wh-inv-stats{align-items:center;color:var(--color-gray-500);display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm);white-space:nowrap}.wh-inv-stats__count{background:var(--color-danger-light);border-radius:10px;color:var(--color-danger);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:2px 8px}.wh-inv-changed{background:#fffbeb}.wh-detail-grid{display:grid;gap:var(--spacing-xl);grid-template-columns:320px 1fr}.wh-detail-info{display:flex;flex-direction:column;gap:var(--spacing-md)}.wh-detail-card{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.wh-detail-card-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);margin:0 0 var(--spacing-sm)}.wh-detail-row{align-items:center;border-bottom:1px solid var(--color-gray-100);display:flex;font-size:var(--font-size-sm);justify-content:space-between;padding:8px 0}.wh-detail-row:last-child{border-bottom:none}.wh-detail-label{color:var(--color-gray-500)}.wh-detail-total{padding:var(--spacing-sm) 0;text-align:center}.wh-detail-total-qty{color:var(--color-primary);display:block;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold)}.wh-detail-total-val{color:var(--color-gray-400);display:block;font-size:var(--font-size-sm);margin-top:4px}.wh-detail-section{margin-bottom:var(--spacing-xl)}.wh-detail-section-title{align-items:center;display:flex;font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);gap:var(--spacing-sm);margin:0 0 var(--spacing-sm)}.wh-detail-section-title:before{background:var(--color-primary);border-radius:2px;content:"";height:16px;width:3px}.wh-product-badges{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px}.wh-sortable{cursor:pointer;user-select:none;white-space:nowrap}.wh-sortable:hover{color:var(--color-primary)}.wh-sort-icon{color:var(--color-gray-300);font-size:var(--font-size-xs);margin-left:2px}.wh-sort-icon--active{color:var(--color-primary)}.wh-cat-item{align-items:center;border-bottom:1px solid var(--color-gray-100);display:flex;font-size:var(--font-size-sm);gap:var(--spacing-xs);padding:6px 8px}.wh-cat-item:hover{background:var(--color-gray-50)}.wh-cat-item__name{flex:1}.wh-cat-item__count{background:var(--color-gray-100);border-radius:var(--radius-full);color:var(--color-gray-500);font-size:var(--font-size-xs);padding:1px 6px}.wh-cat-item__actions{display:flex;gap:2px;opacity:0;transition:opacity var(--transition-fast)}.wh-cat-item:hover .wh-cat-item__actions{opacity:1}.wh-cat-empty{color:var(--color-gray-400);padding:var(--spacing-lg);text-align:center}.wh-cat-tree{border:1px solid var(--color-gray-200);border-radius:var(--radius-md);max-height:400px;overflow-y:auto}.wh-badge--vat{background:var(--color-blue-50,#eff6ff);border-radius:var(--radius-sm);color:var(--color-blue-600,#2563eb);font-size:var(--font-size-xs);padding:1px 5px}.wh-badge--mark{font-size:var(--font-size-xs);padding:1px 3px}.wh-doc-new-btn{margin-left:auto;white-space:nowrap}.wh-doc-row{cursor:default}.wh-doc-id{background:var(--color-gray-50);border-radius:var(--radius-sm);color:var(--color-gray-500);display:inline-block;font-family:var(--font-mono,monospace);margin-right:6px;padding:1px 6px}.wh-doc-id,.wh-doc-meta{font-size:var(--font-size-xs)}.wh-doc-meta{color:var(--color-gray-400);font-weight:var(--font-weight-normal)}.wh-transfer-layout{display:grid;gap:var(--spacing-lg);grid-template-columns:1fr 1fr;margin-top:var(--spacing-md)}.wh-transfer-col{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-md)}.wh-transfer-col__title{align-items:center;display:flex;font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);gap:var(--spacing-xs);margin:0 0 var(--spacing-sm)}.wh-transfer-arrow{align-self:center;font-size:24px}.wh-empty,.wh-transfer-arrow{align-items:center;color:var(--color-gray-400);display:flex;justify-content:center}.wh-empty{flex-direction:column;padding:var(--spacing-2xl) var(--spacing-lg);text-align:center}.wh-empty__icon{font-size:48px;line-height:1;margin-bottom:var(--spacing-sm);opacity:.5}.wh-empty__text{color:var(--color-gray-500);font-size:var(--font-size-md)}.wh-empty__hint{color:var(--color-gray-400);font-size:var(--font-size-sm);margin-top:4px}@media (max-width:1024px){.wh-sale-layout{grid-template-columns:280px 1fr}.wh-sale-picker{position:static}.wh-detail-grid{grid-template-columns:260px 1fr}}@media (max-width:768px){.wh-tabs{gap:0}.wh-tab{font-size:var(--font-size-xs);padding:5px 10px}.wh-filters{align-items:stretch;flex-direction:column}.wh-filters .input--sm{min-width:auto;width:100%}.wh-add-item-bar{flex-direction:column}.wh-add-item-bar .input--sm{min-width:auto}.wh-sale-layout,.wh-wo-layout{grid-template-columns:1fr}.wh-sale-picker{position:static}.wh-sale-product-list{max-height:250px}.wh-sale-cart{background:none;border:none;padding:0}.wh-sale-cart .datatable-table{margin:0;width:100%}.wh-sale-summary{border-radius:var(--radius-lg);margin:var(--spacing-md) 0 0}.wh-detail-grid,.wh-transfer-layout{grid-template-columns:1fr}.wh-transfer-arrow{transform:rotate(90deg)}.wh-summary-cards{grid-template-columns:repeat(2,1fr)}.wh-sale-payment{align-items:flex-start;flex-direction:column}.wh-inv-toolbar .input--sm{max-width:none}.wh-sale-summary{padding:var(--spacing-md)}.wh-sale-total strong{font-size:var(--font-size-lg)}}@media (max-width:480px){.wh-summary-cards{grid-template-columns:1fr}}.sale-modal-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.sale-modal-products{border:1px solid var(--color-gray-200);border-radius:var(--radius-md);max-height:180px;overflow-y:auto}.sale-modal-product{align-items:center;border-bottom:1px solid var(--color-gray-100);cursor:pointer;display:flex;justify-content:space-between;padding:8px 12px;transition:background .15s}.sale-modal-product:last-child{border-bottom:none}.sale-modal-product:hover{background:var(--color-gray-50)}.sale-modal-product-info{display:flex;flex-direction:column;min-width:0}.sale-modal-product-name{font-size:var(--font-size-sm);font-weight:500}.sale-modal-product-sku{color:var(--color-gray-400);font-size:var(--font-size-xs)}.sale-modal-product-meta{display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm);white-space:nowrap}.sale-modal-product-stock{color:var(--color-gray-500)}.sale-modal-empty{color:var(--color-gray-400);font-size:var(--font-size-sm);padding:var(--spacing-md);text-align:center}.sale-modal-cart{background:var(--color-primary-50,#eef2ff);border:1px solid var(--color-primary);border-radius:var(--radius-md);padding:var(--spacing-sm)}.sale-modal-cart-title{align-items:center;display:flex;font-size:var(--font-size-sm);font-weight:600;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs)}.sale-modal-cart-count{background:var(--color-primary);border-radius:10px;color:#fff;font-size:var(--font-size-xs);min-width:18px;padding:0 6px;text-align:center}.sale-modal-cart-item{align-items:center;border-bottom:1px solid rgba(0,0,0,.06);display:flex;gap:var(--spacing-xs);justify-content:space-between;padding:6px 0}.sale-modal-cart-item:last-of-type{border-bottom:none}.sale-modal-cart-item-info{display:flex;flex:1;flex-direction:column;min-width:0}.sale-modal-cart-item-name{font-size:var(--font-size-sm);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sale-modal-cart-item-meta{color:var(--color-gray-500);font-size:var(--font-size-xs)}.sale-modal-cart-item-controls{align-items:center;display:flex;flex-shrink:0;gap:var(--spacing-xs)}.sale-modal-price{text-align:right;width:80px!important}.sale-modal-qty{align-items:center;border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);display:flex;gap:0;overflow:hidden}.sale-modal-qty-btn{align-items:center;background:var(--color-gray-100);border:none;cursor:pointer;display:flex;font-size:14px;height:26px;justify-content:center;width:26px}.sale-modal-qty-btn:hover{background:var(--color-gray-200)}.sale-modal-qty-val{font-size:var(--font-size-sm);font-weight:500;text-align:center;width:28px}.sale-modal-cart-item-total{font-size:var(--font-size-sm);font-weight:600;min-width:60px;text-align:right}.sale-modal-remove{background:none;border:none;color:var(--color-gray-400);cursor:pointer;font-size:14px;padding:2px}.sale-modal-remove:hover{color:var(--color-danger)}.sale-modal-footer{align-items:center;border-top:1px solid rgba(0,0,0,.08);display:flex;justify-content:space-between;margin-top:var(--spacing-xs);padding-top:var(--spacing-xs)}.sale-modal-pay-row{display:flex;gap:4px}.sale-modal-pay{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-xs);padding:3px 10px;transition:all .15s}.sale-modal-pay--active,.sale-modal-pay:hover{border-color:var(--color-primary)}.sale-modal-pay--active{background:var(--color-primary);color:#fff}.sale-modal-total{font-size:var(--font-size-md)}@media (max-width:480px){.sale-modal-cart-item-controls{flex-wrap:wrap}.sale-modal-price{width:65px!important}}.wh-stock-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.wh-stock-name{display:flex;flex-direction:column;gap:2px}.wh-stock-sku{color:var(--color-gray-400);font-family:var(--font-mono,monospace);font-size:var(--font-size-xs)}.wh-stock-qty-val{font-weight:var(--font-weight-semibold)}.wh-stock-unit{color:var(--color-gray-500)}.wh-stock-min,.wh-stock-unit{font-size:var(--font-size-xs)}.wh-stock-min{color:var(--color-danger);margin-top:2px}.wh-search-wrap{flex:1;max-width:400px;min-width:200px;position:relative}.wh-search-icon{color:var(--color-gray-400);left:10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.wh-search-input{padding-left:32px!important;padding-right:28px!important}.wh-search-clear{background:none;border:none;color:var(--color-gray-400);cursor:pointer;font-size:16px;line-height:1;padding:2px 4px;position:absolute;right:6px;top:50%;transform:translateY(-50%)}.wh-search-clear:hover{color:var(--color-gray-600)}.wh-results-count{color:var(--color-gray-400);font-size:var(--font-size-xs);margin-left:auto;white-space:nowrap}.wh-stock-cards{display:none}@media (max-width:768px){.wh-stock-table-wrap{display:none}.wh-stock-cards{display:flex;flex-direction:column;gap:var(--spacing-xs)}.wh-search-wrap{max-width:none}}.wh-stock-card{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);cursor:pointer;padding:var(--spacing-sm) var(--spacing-md);transition:all var(--transition-fast)}.wh-stock-card:hover{box-shadow:var(--shadow-sm,0 1px 4px rgba(0,0,0,.06))}.wh-stock-card--low{background:#fef2f2;border-color:#fca5a5}.wh-stock-card-header{align-items:center;display:flex;gap:var(--spacing-sm);justify-content:space-between}.wh-stock-card-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.wh-stock-card-name,.wh-stock-card-qty{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);white-space:nowrap}.wh-stock-card-qty{color:var(--color-gray-700)}.wh-stock-card-meta{color:var(--color-gray-400);display:flex;font-size:var(--font-size-xs);gap:var(--spacing-sm);margin-top:4px}.wh-stock-card-footer{align-items:center;border-top:1px solid var(--color-gray-100);color:var(--color-gray-500);display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm);justify-content:space-between;margin-top:6px;padding-top:6px}.wh-stock-card-alert{color:var(--color-danger);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);margin-top:4px}