@import"https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap";.platform-shell{display:flex;min-height:100vh;min-height:100dvh;position:relative;background:var(--bg)}.platform-shell:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,rgba(124,58,237,.07) 1px,transparent 1px);background-size:28px 28px;pointer-events:none;z-index:0}.platform-shell:after{content:"";position:fixed;width:500px;height:500px;top:-150px;right:-120px;border-radius:50%;background:radial-gradient(circle,rgba(168,85,247,.09) 0%,transparent 70%);filter:blur(70px);animation:blobDrift 18s ease-in-out infinite alternate;pointer-events:none;z-index:0}@keyframes blobDrift{0%{transform:translate(0) scale(1)}to{transform:translate(30px,20px) scale(1.06)}}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w-collapsed);background:linear-gradient(175deg,#fefeff,#faf8ff);border-right:1px solid var(--border);z-index:100;display:flex;flex-direction:column;transition:width .25s cubic-bezier(.22,1,.36,1);overflow:hidden}.sidebar.expanded{width:var(--sidebar-w-expanded)}.sb-brand{display:flex;align-items:center;gap:10px;padding:16px;height:64px;flex-shrink:0;text-decoration:none}.sb-brand-gem{width:32px;height:32px;border-radius:8px;background:var(--gradient);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sb-brand-name{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--ink);letter-spacing:-.3px;white-space:nowrap;opacity:0;transition:opacity .15s .05s}.sidebar.expanded .sb-brand-name{opacity:1}.sb-nav{flex:1;padding:8px 0;display:flex;flex-direction:column;gap:2px;overflow-y:auto;overflow-x:hidden}.sb-divider{height:1px;background:var(--border);margin:6px 12px;flex-shrink:0}.sb-item{display:flex;align-items:center;gap:12px;padding:8px 12px;margin:0 8px;min-height:44px;border-radius:10px;color:var(--muted);text-decoration:none;font-size:13px;font-family:var(--font-body);font-weight:400;position:relative;border-left:3px solid transparent;transition:all .15s;cursor:pointer;border:none;background:none;width:calc(100% - 16px);box-sizing:border-box;flex-shrink:0}.sb-item:hover{color:var(--ink);background:var(--p50)}.sb-item.active{background:var(--p100);color:var(--p500);font-weight:700;box-shadow:inset 3px 0 0 var(--p500)}.sb-item.locked{opacity:.35;cursor:not-allowed}.sb-item.locked:hover{background:none;color:var(--muted)}.sb-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0;position:relative}.sb-lock-badge{position:absolute;bottom:-2px;right:-4px;color:var(--muted)}.sb-label{white-space:nowrap;opacity:0;transition:opacity .15s .05s;overflow:hidden;text-overflow:ellipsis}.sidebar.expanded .sb-label{opacity:1}.sb-user{padding:12px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px;flex-shrink:0;min-height:56px}.sb-user-name{font-size:12px;color:var(--muted);font-family:var(--font-body);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;opacity:0;transition:opacity .15s .05s}.sidebar.expanded .sb-user-name{opacity:1}.sb-logout-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:none;background:none;color:var(--muted);cursor:pointer;flex-shrink:0;transition:color .15s,background .15s}.sb-logout-btn:hover{color:var(--red);background:#ef444414}.main-content{flex:1;margin-left:var(--sidebar-w-collapsed);position:relative;z-index:1;min-height:100vh;padding:16px}@media (min-width: 769px){.main-content{padding:24px 32px}}@media (min-width: 1201px){.main-content{padding:32px 40px}}.mobile-topbar,.tabbar{display:none}@media (max-width: 768px){.sidebar{display:none}.mobile-topbar{display:flex;position:fixed;top:0;left:0;right:0;height:52px;padding:0 16px;background:#fffffff2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);z-index:100;align-items:center;justify-content:space-between}.mobile-topbar-brand{display:flex;align-items:center;gap:10px}.mobile-topbar-title{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.mobile-topbar-avatar{width:32px;height:32px;border-radius:50%;background:var(--p100);color:var(--p600);font-family:var(--font-body);font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.main-content{margin-left:0;padding-top:52px;padding-bottom:calc(56px + env(safe-area-inset-bottom))}.tabbar{display:flex;position:fixed;bottom:0;left:0;right:0;height:calc(56px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background:#fffffff2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--border);z-index:100;justify-content:space-around;align-items:center}.tabbar-item{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:10px;font-family:var(--font-body);color:var(--muted);text-decoration:none;padding:6px 8px;min-width:48px;min-height:44px;justify-content:center;border-radius:8px;transition:color .15s}.tabbar-item.active{color:var(--p500)}}.auth-shell{display:flex;min-height:100vh;min-height:100dvh}.auth-left{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;background:var(--gradient);padding:48px;position:relative;overflow:hidden}.auth-left:before{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:#ffffff14;top:-100px;right:-100px}.auth-left:after{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:#ffffff0f;bottom:-80px;left:-60px}.auth-left-content{text-align:center;color:#fff;position:relative;z-index:1}.auth-logo{display:flex;align-items:center;gap:10px;justify-content:center;margin-bottom:32px;font-family:var(--font-display);font-size:18px;font-weight:700;color:#fff;letter-spacing:-.4px}.auth-logo-gem{width:38px;height:38px;border-radius:10px;background:#fff3;display:flex;align-items:center;justify-content:center;flex-shrink:0}.auth-slogan{font-family:var(--font-display);font-size:clamp(28px,3vw,42px);font-weight:800;line-height:1.1;color:#fff;margin-bottom:16px}.auth-subtitle{font-size:14px;color:#ffffffb3;max-width:300px;margin:0 auto;line-height:1.5}.auth-right{width:480px;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:40px 48px;background:var(--surface)}.auth-form-box{width:100%;max-width:380px;animation:authCardIn .5s cubic-bezier(.22,1,.36,1) both}@keyframes authCardIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.auth-form-title{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--ink);margin-bottom:4px}.auth-form-subtitle{font-size:14px;color:var(--muted);margin-bottom:28px}.auth-field{margin-bottom:18px}.auth-label{display:block;font-size:13px;font-weight:500;color:var(--ink2);margin-bottom:6px}.auth-input{width:100%;padding:12px 14px;background:var(--bg);border:1.5px solid var(--border-solid, #e0dce8);border-radius:10px;font-size:15px;font-family:var(--font-body);color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s}.auth-input:focus{border-color:var(--p500);box-shadow:0 0 0 3px #9b6dff1f}.auth-input.has-error{border-color:#ef4444;box-shadow:0 0 0 3px #ef444414}.auth-field-error{font-size:12px;color:#ef4444;margin-top:4px}.auth-error-block{background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:8px;padding:10px 14px;color:#dc2626;font-size:13px;margin-bottom:16px;line-height:1.4}.auth-btn{width:100%;padding:13px;background:var(--gradient);border:none;border-radius:10px;font-family:var(--font-display);font-size:14px;font-weight:600;color:#fff;cursor:pointer;transition:transform .2s,box-shadow .2s}.auth-btn:hover{transform:translateY(-1px)}.auth-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.auth-link-row{text-align:center;margin-top:20px;font-size:13px;color:var(--muted)}.auth-link-row a{color:var(--p600);font-weight:600;text-decoration:none}.auth-link-row a:hover{color:var(--p500)}.auth-password-wrap{position:relative}.auth-eye-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);border:none;background:none;cursor:pointer;color:var(--muted2);padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:color .15s}.auth-eye-btn:hover{color:var(--p600)}.auth-mobile-logo{display:none}@media (max-width: 768px){.auth-left{display:none}.auth-right{width:100%;padding:48px 20px 32px;align-items:flex-start}.auth-mobile-logo{display:flex;align-items:center;gap:8px;justify-content:center;margin-bottom:24px}}.platform-page{max-width:1100px}.platform-hero{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-xl);padding:32px 40px;margin-bottom:32px;position:relative;overflow:hidden}.platform-hero:before{content:"";position:absolute;width:200px;height:200px;top:-60px;right:-40px;border-radius:50%;background:radial-gradient(circle,rgba(155,109,255,.08) 0%,transparent 70%);pointer-events:none}.platform-hero:after{content:"";position:absolute;width:300px;height:200px;bottom:-80px;left:50%;transform:translate(-50%);border-radius:50%;background:radial-gradient(circle,rgba(155,109,255,.05) 0%,transparent 70%);pointer-events:none}.hero-greeting{font-size:14px;color:var(--muted);font-family:var(--font-body);margin:0 0 4px}.hero-title{font-family:var(--font-display);font-size:30px;font-weight:700;letter-spacing:-.5px;color:var(--ink);margin:0 0 8px}.hero-name{background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-desc{font-size:14px;color:var(--muted);font-family:var(--font-body);margin:0}.section-title{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--ink);margin:0 0 16px}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:14px;margin-bottom:32px}.inactive-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.product-card{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);padding:24px;min-height:190px;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s,border-color .2s;position:relative}.product-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--p300)}.product-card.inactive{padding:16px;min-height:auto}.product-icon{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;flex-shrink:0}.product-name{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--ink);margin:0 0 4px}.product-desc{font-size:13px;color:var(--muted);margin:0 0 16px;flex:1;font-family:var(--font-body);line-height:1.5}.product-btn{padding:8px 16px;border:1px solid var(--border-solid);border-radius:8px;background:none;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--ink);cursor:pointer;transition:all .15s;align-self:flex-start}.product-btn:hover{background:var(--p50);border-color:var(--p300);color:var(--p500)}.product-btn.outline:hover{border-color:var(--p300);color:var(--p500)}.skeleton-card{background:var(--p100);border-radius:var(--radius-lg);min-height:190px;animation:shimmer 1.2s ease-in-out infinite alternate}@keyframes shimmer{0%{opacity:.4}to{opacity:.8}}.empty-state{text-align:center;padding:48px 24px;background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);margin-bottom:32px}.empty-state-title{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--ink);margin:0 0 8px}.empty-state-desc{font-size:14px;color:var(--muted);margin:0;font-family:var(--font-body)}.empty-state-link{color:var(--p600);font-weight:600;text-decoration:none}.empty-state-link:hover{color:var(--p500)}.platform-error{background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius);padding:16px 20px;color:#dc2626;font-size:14px;font-family:var(--font-body);margin-bottom:24px}@media (max-width: 768px){.platform-hero{padding:24px}.hero-title{font-size:24px}.products-grid,.inactive-grid{grid-template-columns:1fr}}.loyalty-shell{display:flex;gap:0;height:100%;min-height:100%}.loyalty-subnav{width:220px;flex-shrink:0;border-right:1px solid var(--border-solid);padding:16px 8px;overflow-y:auto;background:var(--card)}.loyalty-content{flex:1;min-width:0;padding:24px 32px;overflow-y:auto}.subnav-group{margin-bottom:16px}.subnav-group-label{font-family:var(--font-body);font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted2);padding:0 12px;margin:0 0 4px}.subnav-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--radius);font-family:var(--font-body);font-size:13px;font-weight:400;color:var(--ink2);text-decoration:none;transition:background .15s}.subnav-item:hover{background:var(--p50)}.subnav-item.active{background:var(--p100);color:var(--p600);font-weight:700}@media (max-width: 768px){.loyalty-shell{flex-direction:column}.loyalty-subnav{width:100%;height:44px;display:flex;flex-direction:row;overflow-x:auto;overflow-y:hidden;white-space:nowrap;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;gap:0;border-right:none;border-bottom:1px solid var(--border-solid);padding:0 16px;align-items:center;flex-shrink:0;background:var(--card)}.loyalty-subnav::-webkit-scrollbar{display:none}.loyalty-subnav{-ms-overflow-style:none;scrollbar-width:none}.subnav-group{display:contents;margin-bottom:0}.subnav-group-label{display:none}.subnav-item{display:inline-flex;padding:6px 14px;border-radius:20px;white-space:nowrap;font-size:13px;scroll-snap-align:start;flex-shrink:0;gap:6px}.subnav-item.active{background:var(--p100);color:var(--p700);font-weight:600}.loyalty-content{padding:16px}.loyalty-stats-grid{grid-template-columns:1fr}.wifi-table-desktop{display:none}.wifi-cards-mobile{display:flex;flex-direction:column;gap:8px}.clients-table-wrap{background:transparent;border:none;border-radius:0;overflow:visible}.clients-table{display:block}.clients-table thead{display:none}.clients-table tbody{display:block}.clients-table-row{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--border-solid, #e5e7eb);border-radius:10px;margin-bottom:8px;padding:12px 16px}.clients-table td{display:block;padding:2px 0;font-size:14px;border:none}.client-arrow-cell{display:none}.loyalty-table-wrap{overflow-x:auto}.loyalty-form-actions{position:sticky;bottom:0;background:var(--card, #fff);border-top:1px solid var(--border-solid, #e5e7eb);padding:16px;margin:16px -16px -16px;z-index:10}}.loyalty-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:32px}.loyalty-stat-card{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);padding:16px 24px;box-shadow:var(--shadow-sm)}.loyalty-stat-icon{width:36px;height:36px;border-radius:10px;background:var(--pink-soft);display:flex;align-items:center;justify-content:center;color:var(--pink);margin-bottom:8px}.loyalty-stat-value{font-family:var(--font-display);font-size:30px;font-weight:700;color:var(--ink);line-height:1.2}.loyalty-stat-label{font-family:var(--font-body);font-size:13px;font-weight:400;color:var(--muted);margin-top:2px}.loyalty-quick-actions{display:flex;gap:12px;margin-bottom:32px;flex-wrap:wrap}.loyalty-btn-primary{display:inline-flex;align-items:center;gap:8px;padding:0 20px;min-height:44px;background:var(--gradient);border:none;border-radius:10px;font-family:var(--font-body);font-size:14px;font-weight:700;color:#fff;cursor:pointer;transition:transform .15s,opacity .15s;text-decoration:none}.loyalty-btn-primary:hover{transform:translateY(-1px);opacity:.9}.loyalty-btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.loyalty-btn-outline{display:inline-flex;align-items:center;gap:8px;padding:0 20px;min-height:44px;background:transparent;border:1px solid var(--border-solid);border-radius:10px;font-family:var(--font-body);font-size:14px;font-weight:700;color:var(--ink2);cursor:pointer;transition:background .15s,border-color .15s,color .15s;text-decoration:none}.loyalty-btn-outline:hover{background:var(--p50);border-color:var(--p300);color:var(--p500)}.loyalty-table-wrap{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);overflow:hidden}.loyalty-table{width:100%;border-collapse:collapse}.loyalty-table th{background:var(--bg);border-bottom:1px solid var(--border-solid);padding:8px 16px;font-family:var(--font-body);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted2);text-align:left}.loyalty-table td{padding:12px 16px;border-bottom:1px solid var(--border-solid);font-family:var(--font-body);font-size:14px;font-weight:400;color:var(--ink)}.loyalty-table tr:last-child td{border-bottom:none}.loyalty-table tr:hover td{background:var(--p50)}.loyalty-table .cell-secondary{font-size:13px;color:var(--muted)}.loyalty-points-badge{display:inline-block;font-size:13px;font-weight:700;color:var(--p600);background:var(--p50);border-radius:6px;padding:2px 8px}.loyalty-section-title{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--ink);margin-bottom:16px}.loyalty-skeleton-card{background:var(--p100);border-radius:var(--radius-lg);animation:loyaltyShimmer .5s ease-in-out infinite alternate}.loyalty-skeleton-row{height:44px;background:var(--p100);border-radius:var(--radius);animation:loyaltyShimmer .5s ease-in-out infinite alternate;margin-bottom:4px}@keyframes loyaltyShimmer{0%{opacity:.4}to{opacity:.8}}.loyalty-toast{position:fixed;bottom:24px;right:24px;z-index:1000;max-width:320px;padding:12px 16px;border-radius:var(--radius);font-family:var(--font-body);font-size:14px;font-weight:400;color:#fff;animation:loyaltyToastIn .2s cubic-bezier(.22,1,.36,1)}.loyalty-toast.success{background:var(--green)}.loyalty-toast.error{background:var(--red)}@keyframes loyaltyToastIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.loyalty-empty{text-align:center;padding:40px 24px;color:var(--muted)}.loyalty-empty h3{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--ink);margin-bottom:8px}.loyalty-empty p{font-size:14px;margin-bottom:16px}.loyalty-error{background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:8px;padding:10px 14px;color:#dc2626;font-size:13px;line-height:1.4}.loyalty-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}.loyalty-upgrade-prompt{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-xl);padding:40px;text-align:center}.loyalty-upgrade-prompt h2{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--ink);margin:16px 0 8px}.loyalty-upgrade-prompt p{font-size:14px;color:var(--muted);margin-bottom:20px;max-width:400px;margin-left:auto;margin-right:auto}.loyalty-btn-danger{display:inline-flex;align-items:center;gap:6px;padding:0 16px;min-height:36px;background:transparent;border:1px solid var(--border-solid);border-radius:10px;font-family:var(--font-body);font-size:13px;font-weight:700;color:var(--red);cursor:pointer;transition:background .15s,border-color .15s}.loyalty-btn-danger:hover{background:#ef444414;border-color:var(--red)}.badge-active{display:inline-block;font-size:13px;font-weight:700;color:var(--green);background:var(--green-soft);border-radius:6px;padding:2px 8px}.badge-inactive{display:inline-block;font-size:13px;font-weight:700;color:var(--amber);background:var(--amber-soft);border-radius:6px;padding:2px 8px}.badge-expired{display:inline-block;font-size:13px;font-weight:700;color:var(--muted);background:var(--p50);border-radius:6px;padding:2px 8px}.badge-sms{display:inline-block;font-size:13px;font-weight:700;color:var(--amber);background:var(--amber-soft);border-radius:6px;padding:2px 8px}.badge-email{display:inline-block;font-size:13px;font-weight:700;color:var(--blue);background:var(--blue-soft);border-radius:6px;padding:2px 8px}.loyalty-toggle{position:relative;width:36px;height:20px;border-radius:10px;background:var(--border-solid);border:none;cursor:pointer;transition:background .15s;padding:0}.loyalty-toggle.on{background:var(--p500)}.loyalty-toggle:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .15s}.loyalty-toggle.on:after{transform:translate(16px)}.loyalty-form-panel{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);padding:20px;margin-bottom:20px}.loyalty-form{display:flex;flex-direction:column;gap:18px;max-width:600px}.loyalty-field{display:flex;flex-direction:column}.loyalty-label{display:block;font-family:var(--font-body);font-size:13px;font-weight:400;color:var(--ink2);margin-bottom:6px}.loyalty-input{width:100%;padding:12px 16px;background:#fff;border:1.5px solid var(--border-solid, #e0dce8);border-radius:10px;font-size:14px;font-family:var(--font-body);color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.loyalty-input:focus{border-color:var(--p500);box-shadow:0 0 0 3px #9b6dff1f}.loyalty-textarea{width:100%;padding:12px 16px;background:#fff;border:1.5px solid var(--border-solid, #e0dce8);border-radius:10px;font-size:14px;font-family:var(--font-body);color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box;resize:vertical;min-height:100px}.loyalty-textarea:focus{border-color:var(--p500);box-shadow:0 0 0 3px #9b6dff1f}.loyalty-select{width:100%;padding:12px 16px;background:#fff;border:1.5px solid var(--border-solid, #e0dce8);border-radius:10px;font-size:14px;font-family:var(--font-body);color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box;cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.loyalty-select:focus{border-color:var(--p500);box-shadow:0 0 0 3px #9b6dff1f}.loyalty-form-actions{display:flex;gap:12px;margin-top:4px}.loyalty-inline-confirm{display:inline-flex;align-items:center;gap:8px;font-size:13px}.loyalty-inline-confirm .confirm-yes{color:var(--red);font-weight:700;cursor:pointer;background:none;border:none;font-family:var(--font-body);font-size:13px}.loyalty-inline-confirm .confirm-no{color:var(--muted);font-weight:400;cursor:pointer;background:none;border:none;font-family:var(--font-body);font-size:13px}.loyalty-clients-page{max-width:960px}.loyalty-page-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.clients-total-badge{font-size:13px;font-weight:700;color:var(--p600);background:var(--p50);border-radius:20px;padding:2px 10px}.clients-search-row{display:flex;gap:12px;margin-bottom:24px}.clients-search-input-wrap{position:relative;flex:1}.clients-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}.clients-search-input{width:100%;padding:10px 12px 10px 36px;background:#fff;border:1.5px solid var(--border-solid, #e0dce8);border-radius:10px;font-family:var(--font-body);font-size:14px;color:var(--ink);outline:none;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.clients-search-input:focus{border-color:var(--p500);box-shadow:0 0 0 3px #9b6dff1f}.clients-table-wrap{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:16px}.clients-table{width:100%;border-collapse:collapse}.clients-table thead tr{background:var(--bg);border-bottom:1px solid var(--border-solid)}.clients-table th{padding:8px 16px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted2);text-align:left}.clients-table-row{cursor:pointer;transition:background .12s}.clients-table-row:not(:last-child) td{border-bottom:1px solid var(--border-solid)}.clients-table-row:hover{background:var(--p50)}.clients-table td{padding:12px 16px;font-size:14px;color:var(--ink)}.client-name-cell{font-weight:700}.client-secondary{font-size:13px!important;color:var(--muted)!important}.client-phone-row{display:inline-flex;align-items:center;gap:4px}.client-arrow-cell{color:var(--muted2)!important;width:32px;text-align:right}.skeleton-row{height:48px;background:var(--p100);border-radius:var(--radius);margin-bottom:2px;animation:loyaltyShimmer .5s ease-in-out infinite alternate}.clients-pagination{display:flex;align-items:center;gap:12px;justify-content:center;padding:8px 0}.pagination-info{font-size:13px;color:var(--muted)}.client-detail-page{max-width:800px}.client-detail-header{margin-bottom:24px}.btn-back{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);background:none;border:none;cursor:pointer;padding:0;margin-bottom:16px;font-family:var(--font-body);transition:color .15s}.btn-back:hover{color:var(--p500)}.client-detail-title-row{display:flex;align-items:center;gap:12px}.client-avatar{width:44px;height:44px;border-radius:50%;background:var(--p100);color:var(--p600);display:flex;align-items:center;justify-content:center;flex-shrink:0}.segment-badge{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:700;border-radius:20px;padding:2px 10px;margin-top:4px}.btn-edit-client{margin-left:auto}.client-card{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);padding:20px 24px;margin-bottom:16px}.client-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.client-card-title{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--ink);display:flex;align-items:center;gap:6px;margin:0}.edit-actions{display:flex;gap:8px}.btn-sm{font-size:13px!important;padding:0 14px!important;min-height:34px!important}.client-fields-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 600px){.client-fields-grid{grid-template-columns:1fr}}.client-field{display:flex;flex-direction:column;gap:6px}.client-field-label{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:4px}.client-field-value{font-size:14px;color:var(--ink)}.client-points-row{display:flex;align-items:center;gap:8px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-solid);color:var(--muted);font-size:14px}.client-points-label{flex:1}.client-points-value{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--p600)}.client-detail-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 680px){.client-detail-cols{grid-template-columns:1fr}}.client-empty-section{font-size:13px;color:var(--muted);text-align:center;padding:16px 0}.client-campaigns-list,.client-triggers-list{display:flex;flex-direction:column;gap:8px}.client-campaign-row,.client-trigger-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border-solid);font-size:13px}.client-campaign-row:last-child,.client-trigger-row:last-child{border-bottom:none}.client-campaign-info,.client-trigger-name{display:flex;align-items:center;gap:8px;color:var(--ink)}.client-campaign-name{font-weight:700;color:var(--ink)}.client-campaign-meta{display:flex;align-items:center;gap:6px;color:var(--muted)}.status-dot{width:7px;height:7px;border-radius:50%}.status-dot.sent{background:var(--green)}.status-dot.failed{background:var(--red)}.client-trigger-meta{display:flex;align-items:center;gap:8px}.trigger-type-badge{font-size:12px;color:var(--amber);background:var(--amber-soft);border-radius:6px;padding:2px 8px}.gift-info{font-size:13px;color:var(--muted)}.channel-badge{font-size:11px;font-weight:700;padding:2px 6px;border-radius:4px}.channel-sms{color:var(--amber);background:var(--amber-soft)}.channel-email{color:#3b82f6;background:#3b82f61a}.channel-push{color:var(--p500);background:var(--p50)}.wifi-table-desktop{display:block}.wifi-cards-mobile{display:none}.wifi-contact-card{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius);padding:12px 16px}.wifi-contact-phone{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--ink)}.wifi-contact-secondary{font-size:13px;color:var(--muted);margin-top:4px}.wifi-portal-constructor{display:grid;grid-template-columns:1fr 360px;gap:32px;align-items:start}.wifi-phone-frame{width:300px;height:580px;border-radius:44px;border:10px solid #1a1a2e;background:#fff;box-shadow:0 8px 32px #00000038,0 2px 8px #0000001f,inset 0 0 0 1px #ffffff14;overflow:hidden;position:sticky;top:24px;display:flex;flex-direction:column}.wifi-router-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.wifi-router-card{padding:24px 16px;border:2px solid var(--border-solid, #e5e7eb);border-radius:var(--radius-lg, 12px);cursor:pointer;text-align:center;transition:border-color .15s,background .15s;background:var(--card)}.wifi-router-card:hover{border-color:var(--p300, #c4b5fd);background:var(--p50, #f5f0ff)}.wifi-router-card.selected{border-color:var(--p500, #9B6DFF);background:var(--p50, #f5f0ff)}.wifi-copy-btn{padding:4px 8px;font-size:13px;font-family:var(--font-body, "Plus Jakarta Sans", sans-serif);border:1px solid var(--border-solid, #e5e7eb);border-radius:6px;background:var(--card);color:var(--p500, #9B6DFF);cursor:pointer;transition:background .1s,color .1s;white-space:nowrap}.wifi-copy-btn:hover{background:var(--p50, #f5f0ff)}.wifi-copy-btn.copied{color:var(--green, #22c55e);border-color:var(--green, #22c55e)}.wifi-code-block{display:inline-block;padding:4px 8px;font-family:Courier New,monospace;font-size:13px;background:var(--p50, #f5f0ff);border-radius:4px;color:var(--ink, #1a1a2e);word-break:break-all}.wifi-instruction-step{display:flex;gap:12px;align-items:flex-start;margin-bottom:20px}.wifi-step-badge{flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--p500, #9B6DFF);color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center}.wifi-info-block{background:var(--p50, #f5f0ff);border-radius:var(--radius, 8px);padding:16px;margin-bottom:24px}.wifi-cost-hint{font-size:13px;color:var(--muted, #6b7280);margin-top:4px;display:block}.wifi-cost-hint.amber{color:var(--amber, #f59e0b)}.wifi-upload-label{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;border:1.5px dashed var(--p300, #c4b5fd);background:var(--p50, #f5f0ff);color:var(--p500, #9B6DFF);font-size:13px;font-weight:600;font-family:var(--font-body, "Plus Jakarta Sans", sans-serif);cursor:pointer;transition:background .15s,border-color .15s;-webkit-user-select:none;user-select:none}.wifi-upload-label:hover{background:var(--p100, #ede9fe);border-color:var(--p500, #9B6DFF)}@media (max-width: 768px){.wifi-portal-constructor{grid-template-columns:1fr}.wifi-phone-frame{display:none}.wifi-router-grid{grid-template-columns:repeat(2,1fr)}}.dash-root{max-width:1080px}.dash-metrics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.dash-metric-card{background:var(--card);border:1px solid var(--border-solid);border-radius:12px;padding:16px 20px;box-shadow:0 1px 3px #0000000a}.dash-metric-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:8px}.dash-metric-value{font-family:var(--font-display);font-size:28px;font-weight:700;color:var(--ink);line-height:1.2}.dash-metric-label{font-family:var(--font-body);font-size:13px;color:var(--muted);margin-top:2px}.dash-metric-sub{color:var(--muted2);font-size:12px}.dash-two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.dash-panel{background:var(--card);border:1px solid var(--border-solid);border-radius:12px;padding:20px;box-shadow:0 1px 3px #0000000a}.dash-panel-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--ink);margin:0 0 16px}.dash-chart-legend{display:flex;gap:16px;margin-bottom:12px;font-size:12px;color:var(--muted)}.dash-legend-item{display:inline-flex;align-items:center;gap:4px}.dash-legend-dot{width:8px;height:8px;border-radius:2px;display:inline-block}.dash-chart-wrap{display:flex;align-items:flex-end;gap:2px;height:140px}.dash-chart-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;position:relative}.dash-bar-group{flex:1;width:100%;display:flex;gap:1px;align-items:flex-end}.dash-bar{flex:1;border-radius:2px 2px 0 0;min-height:1px;transition:height .3s ease}.dash-bar-earned{background:#534ab7}.dash-bar-spent{background:#f59e0b}.dash-chart-label{font-size:10px;color:var(--muted2);margin-top:4px;position:absolute;bottom:-16px}.dash-levels-list{display:flex;flex-direction:column;gap:12px}.dash-level-row{display:flex;flex-direction:column;gap:4px}.dash-level-info{display:flex;justify-content:space-between;align-items:center}.dash-level-name{font-size:13px;font-weight:600;color:var(--ink)}.dash-level-count{font-size:13px;font-weight:700;color:var(--muted)}.dash-level-bar-bg{height:8px;background:var(--p50);border-radius:4px;overflow:hidden}.dash-level-bar-fill{height:100%;border-radius:4px;transition:width .4s ease}.dash-level-badge{display:inline-block;font-size:12px;font-weight:700;color:var(--p600);background:var(--p50);border-radius:6px;padding:2px 8px}.dash-txn-feed{display:flex;flex-direction:column;gap:0}.dash-txn-item{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--border-solid)}.dash-txn-item:last-child{border-bottom:none}.dash-txn-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0;margin-top:2px}.dash-txn-earn{background:#22c55e1a;color:#22c55e}.dash-txn-spend{background:#f59e0b1a;color:#f59e0b}.dash-txn-body{flex:1;min-width:0}.dash-txn-top{display:flex;align-items:center;gap:8px}.dash-txn-amount{font-family:var(--font-display);font-size:14px;font-weight:700}.dash-txn-earn-text{color:#22c55e}.dash-txn-spend-text{color:#f59e0b}.dash-txn-client{font-size:13px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-txn-meta{display:flex;gap:8px;font-size:12px;color:var(--muted);margin-top:2px}@media (max-width: 768px){.dash-metrics-grid{grid-template-columns:1fr 1fr;gap:10px}.dash-two-col{grid-template-columns:1fr}.dash-metric-value{font-size:22px}.dash-metric-card{padding:12px 14px}}@media (max-width: 480px){.dash-metrics-grid{grid-template-columns:1fr}}.cashier-page{max-width:100%;margin:0 auto;padding:0 16px 40px;background:#f8f7fc;min-height:100vh}.cashier-header{display:flex;align-items:center;justify-content:space-between;padding:20px 0 16px;border-bottom:1px solid rgba(83,74,183,.1);margin-bottom:20px}.cashier-header-left{display:flex;align-items:center;gap:16px}.cashier-title{font-family:var(--font-display, sans-serif);font-size:26px;font-weight:800;color:var(--ink, #1a1a2e);margin:0;letter-spacing:-.5px}.cashier-clock{display:inline-flex;align-items:center;gap:6px;font-size:15px;font-weight:600;color:var(--muted, #6b7280);background:#534ab70f;padding:6px 14px;border-radius:20px}.cashier-search-section{margin-bottom:20px}.cashier-search-form{display:flex;gap:10px}.cashier-search-input-wrap{flex:1;position:relative;display:flex;align-items:center}.cashier-search-icon{position:absolute;left:16px;color:var(--muted, #6b7280);pointer-events:none;flex-shrink:0}.cashier-search-input{width:100%;height:54px;padding:0 16px 0 48px;border:2px solid rgba(83,74,183,.15);border-radius:14px;background:#fff;font-family:var(--font-body, sans-serif);font-size:17px;font-weight:500;color:var(--ink, #1a1a2e);outline:none;transition:border-color .2s,box-shadow .2s}.cashier-search-input:focus{border-color:#534ab7;box-shadow:0 0 0 3px #534ab71a}.cashier-search-input::placeholder{color:var(--muted, #9ca3af);font-weight:400}.cashier-search-btn{height:54px;padding:0 24px;border:none;border-radius:14px;background:#534ab7;color:#fff;font-family:var(--font-body, sans-serif);font-size:15px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:8px;white-space:nowrap;transition:background .2s,transform .1s;flex-shrink:0}.cashier-search-btn:hover:not(:disabled){background:#433aa0}.cashier-search-btn:active:not(:disabled){transform:scale(.97)}.cashier-search-btn:disabled{opacity:.5;cursor:not-allowed}.cashier-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;color:var(--muted, #9ca3af);text-align:center}.cashier-empty-state svg{margin-bottom:12px;opacity:.4}.cashier-empty-state p{font-size:16px;font-weight:500;margin:0}.cashier-clients-list{max-height:400px;overflow-y:auto;-webkit-overflow-scrolling:touch}.cashier-clients-row{display:flex;align-items:center;gap:12px;padding:10px 8px;border-radius:10px;cursor:pointer;transition:background .15s}.cashier-clients-row:hover{background:#534ab70d}.cashier-clients-row:active{background:#534ab71a}.cashier-clients-avatar{width:36px;height:36px;border-radius:50%;background:#534ab71a;color:#534ab7;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;flex-shrink:0}.cashier-clients-phone{font-size:12px;color:var(--muted, #9ca3af);margin-top:1px}.cashier-clients-badges{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.cashier-clients-points{font-size:13px;font-weight:700;color:#534ab7;white-space:nowrap}.cashier-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000a;padding:20px;margin-bottom:16px;animation:cashier-slide-in .3s ease-out}@keyframes cashier-slide-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.cashier-card-title{font-family:var(--font-display, sans-serif);font-size:15px;font-weight:700;color:var(--ink, #1a1a2e);margin-bottom:12px}.cashier-client-card{position:relative;background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000a;padding:20px 20px 20px 24px;margin-bottom:16px;border-left:4px solid #534AB7;display:flex;align-items:center;justify-content:space-between;gap:16px;animation:cashier-slide-in .3s ease-out}.cashier-client-info{flex:1;min-width:0}.cashier-client-name{font-family:var(--font-display, sans-serif);font-size:20px;font-weight:700;color:var(--ink, #1a1a2e);line-height:1.2}.cashier-client-phone{font-size:14px;color:var(--muted, #6b7280);margin-top:2px}.cashier-client-meta{display:flex;align-items:center;gap:8px;margin-top:8px}.cashier-level-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:12px;font-size:13px;font-weight:600}.cashier-multiplier{font-size:13px;font-weight:600;color:var(--p600, #534AB7)}.cashier-balance{text-align:right;flex-shrink:0}.cashier-balance-value{font-family:var(--font-display, sans-serif);font-size:36px;font-weight:800;color:#534ab7;line-height:1;display:block}.cashier-balance-label{font-size:13px;color:var(--muted, #6b7280);font-weight:500}.cashier-history-list{display:flex;flex-direction:column}.cashier-history-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(0,0,0,.05)}.cashier-history-item:last-child{border-bottom:none;padding-bottom:0}.cashier-history-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}.cashier-history-icon.earn{background:#22c55e1f;color:#16a34a}.cashier-history-icon.spend{background:#ef44441f;color:#dc2626}.cashier-history-info{flex:1;display:flex;flex-direction:column;min-width:0}.cashier-history-label{font-size:13px;font-weight:500;color:var(--ink, #1a1a2e);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cashier-history-date{font-size:11px;color:var(--muted, #9ca3af)}.cashier-history-amount{font-size:14px;font-weight:700;flex-shrink:0}.cashier-history-amount.earn{color:#16a34a}.cashier-history-amount.spend{color:#dc2626}.cashier-tx-panel{padding:24px 20px}.cashier-toggle-wrap{display:flex;background:#f3f2f8;border-radius:12px;padding:4px;margin-bottom:20px}.cashier-toggle-btn{flex:1;padding:12px 16px;border:none;border-radius:10px;font-family:var(--font-body, sans-serif);font-size:15px;font-weight:700;cursor:pointer;transition:all .25s ease;background:transparent;color:var(--muted, #6b7280)}.cashier-toggle-btn.active{background:#534ab7;color:#fff;box-shadow:0 2px 8px #534ab740}.cashier-toggle-btn:not(.active):hover{color:var(--ink, #1a1a2e)}.cashier-quick-amounts{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.cashier-quick-btn{flex:1;min-width:0;padding:10px 8px;border:2px solid rgba(83,74,183,.12);border-radius:12px;background:#fff;color:var(--ink, #1a1a2e);font-family:var(--font-body, sans-serif);font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;text-align:center;white-space:nowrap}.cashier-quick-btn:hover{border-color:#534ab7;color:#534ab7;background:#534ab70a}.cashier-quick-btn.active{background:#534ab714;border-color:#534ab7;color:#534ab7}.cashier-field{margin-bottom:14px}.cashier-label{display:block;font-size:13px;font-weight:600;color:var(--muted, #6b7280);margin-bottom:6px}.cashier-input{width:100%;height:48px;padding:0 14px;border:2px solid rgba(83,74,183,.12);border-radius:12px;background:#fff;font-family:var(--font-body, sans-serif);font-size:16px;font-weight:500;color:var(--ink, #1a1a2e);outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.cashier-input:focus{border-color:#534ab7;box-shadow:0 0 0 3px #534ab71a}.cashier-input::placeholder{color:var(--muted, #9ca3af);font-weight:400}.cashier-input-points{font-size:20px;font-weight:700;height:52px}.cashier-calc-hint{font-size:13px;color:#534ab7;background:#534ab70f;padding:10px 14px;border-radius:10px;margin-bottom:14px;font-weight:600}.cashier-discount-calc{background:#7c3aed0f;border-radius:10px;padding:10px 14px;margin-bottom:14px;font-size:13px;color:var(--ink, #1a1a2e);font-weight:500}.cashier-discount-calc strong{color:#534ab7}.cashier-discount-detail{color:var(--muted, #9ca3af);margin-left:4px;font-size:12px}.cashier-action-btn{display:flex;align-items:center;justify-content:center;width:100%;height:54px;border:none;border-radius:14px;font-family:var(--font-body, sans-serif);font-size:16px;font-weight:700;cursor:pointer;transition:all .2s ease;letter-spacing:.2px;margin-top:4px}.cashier-action-btn.earn{background:linear-gradient(135deg,#534ab7,#7c3aed);color:#fff;box-shadow:0 4px 14px #534ab74d}.cashier-action-btn.earn:hover:not(:disabled){box-shadow:0 6px 20px #534ab766;transform:translateY(-1px)}.cashier-action-btn.spend{background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff;box-shadow:0 4px 14px #dc26264d}.cashier-action-btn.spend:hover:not(:disabled){box-shadow:0 6px 20px #dc262666;transform:translateY(-1px)}.cashier-action-btn:active:not(:disabled){transform:translateY(0) scale(.98)}.cashier-action-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.cashier-stamp-card{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid rgba(0,0,0,.05)}.cashier-stamp-card:last-child{border-bottom:none;padding-bottom:0}.cashier-stamp-icon{font-size:22px;flex-shrink:0}.cashier-stamp-info{flex:1;min-width:0}.cashier-stamp-name{font-weight:600;font-size:14px;color:var(--ink, #1a1a2e)}.cashier-stamp-dots{display:flex;gap:5px;margin-top:4px}.cashier-stamp-dot{width:10px;height:10px;border-radius:50%;background:#00000014;display:inline-block;transition:background .2s}.cashier-stamp-dot.filled{background:#534ab7}.cashier-stamp-count{font-size:13px;font-weight:600;color:var(--muted, #6b7280)}.cashier-stamp-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:2px solid rgba(83,74,183,.15);border-radius:10px;background:#fff;color:#534ab7;font-family:var(--font-body, sans-serif);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}.cashier-stamp-btn:hover{background:#534ab70f;border-color:#534ab7}.cashier-not-found-msg{font-size:15px;font-weight:600;color:var(--muted, #6b7280);margin-bottom:16px;text-align:center}.cashier-field-error{color:#dc2626;font-size:13px;margin-top:4px}.cashier-error{background:#ef444414;color:#dc2626;padding:10px 14px;border-radius:10px;font-size:13px;font-weight:500;margin-bottom:14px}.cashier-cert-accordion{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000a;margin-bottom:16px;overflow:hidden}.cashier-cert-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:16px 20px;border:none;background:transparent;font-family:var(--font-body, sans-serif);font-size:15px;font-weight:700;color:var(--ink, #1a1a2e);cursor:pointer;transition:background .15s}.cashier-cert-toggle:hover{background:#534ab708}.cashier-cert-body{padding:0 20px 20px;animation:cashier-slide-in .2s ease-out}.cashier-cert-form{display:flex;gap:10px;margin-bottom:12px}.cashier-cert-form .cashier-input{flex:1}.cashier-cert-check-btn{height:48px;padding:0 20px;font-size:14px}.cashier-cert-result{background:#f8f7fc;border-radius:12px;padding:16px;margin-top:8px}.cashier-cert-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.cashier-cert-code{font-family:monospace;font-size:13px;color:var(--ink, #1a1a2e);margin-bottom:4px}.cashier-cert-balance{font-family:var(--font-display, sans-serif);font-size:22px;font-weight:700;color:#534ab7}.cashier-cert-status{display:inline-flex;padding:4px 10px;border-radius:8px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.cashier-cert-status.active{background:#22c55e1f;color:#16a34a}.cashier-cert-status.used{background:#ef44441f;color:#dc2626}.cashier-cert-redeem{border-top:1px solid rgba(0,0,0,.06);margin-top:14px;padding-top:14px}.cashier-cert-redeem-row{display:flex;gap:10px;margin-top:6px}.cashier-cert-redeem-row .cashier-input{flex:1}.cashier-success-overlay{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#f8f7fceb;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;animation:cashier-fade-in .2s ease-out;pointer-events:none}@keyframes cashier-fade-in{0%{opacity:0}to{opacity:1}}.cashier-success-checkmark{width:80px;height:80px;margin-bottom:20px}.cashier-checkmark-svg{width:80px;height:80px}.cashier-checkmark-circle{stroke:#16a34a;stroke-width:2;stroke-dasharray:166;stroke-dashoffset:166;animation:cashier-stroke .5s ease-out forwards}.cashier-checkmark-check{stroke:#16a34a;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:48;stroke-dashoffset:48;animation:cashier-stroke .3s .3s ease-out forwards}@keyframes cashier-stroke{to{stroke-dashoffset:0}}.cashier-success-text{font-family:var(--font-display, sans-serif);font-size:28px;font-weight:800;animation:cashier-float-up .4s .2s ease-out both}.cashier-success-text.earn{color:#16a34a}.cashier-success-text.spend{color:#dc2626}@keyframes cashier-float-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.cashier-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);padding:12px 24px;border-radius:12px;font-size:14px;font-weight:600;z-index:10000;animation:cashier-toast-in .3s ease-out;box-shadow:0 8px 24px #0000001f;max-width:calc(100vw - 32px);text-align:center}.cashier-toast.success{background:#16a34a;color:#fff}.cashier-toast.error{background:#dc2626;color:#fff}@keyframes cashier-toast-in{0%{opacity:0;transform:translate(-50%) translateY(16px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (max-width: 640px){.cashier-page{padding:0 12px 32px}.cashier-title{font-size:22px}.cashier-search-form{flex-direction:column}.cashier-search-btn{width:100%;justify-content:center}.cashier-client-card{flex-direction:column;align-items:flex-start}.cashier-balance{text-align:left;margin-top:8px}.cashier-balance-value{font-size:32px}.cashier-quick-amounts{gap:6px}.cashier-quick-btn{padding:10px 6px;font-size:13px}.cashier-cert-redeem-row{flex-direction:column}.cashier-cert-redeem-row .cashier-action-btn{width:100%!important;padding:0!important}}.cashier-clients-list{display:flex;flex-direction:column;max-height:480px;overflow-y:auto}.cashier-clients-row{display:flex;align-items:center;gap:12px;padding:10px 8px;border-bottom:1px solid rgba(0,0,0,.04);cursor:pointer;border-radius:10px;transition:background .15s}.cashier-clients-row:hover{background:#534ab70a}.cashier-clients-row:last-child{border-bottom:none}.cashier-clients-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#534ab7,#7c3aed);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;flex-shrink:0}.cashier-clients-info{flex:1;min-width:0}.cashier-clients-name{font-size:14px;font-weight:600;color:var(--ink, #1a1a2e);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cashier-clients-phone{font-size:12px;color:var(--muted, #9ca3af)}.cashier-clients-badges{display:flex;align-items:center;gap:8px;flex-shrink:0}.cashier-clients-points{font-size:14px;font-weight:700;color:#534ab7;white-space:nowrap}.cashier-input[type=number]::-webkit-inner-spin-button,.cashier-input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.cashier-input[type=number]{-moz-appearance:textfield}.cashier-search-input[type=tel]::-webkit-inner-spin-button,.cashier-search-input[type=tel]::-webkit-outer-spin-button{-webkit-appearance:none}.loyalty-settings-page{max-width:600px}.loyalty-settings-title{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--ink);margin-bottom:24px}.token-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:500;animation:tokenBackdropIn .2s ease}@keyframes tokenBackdropIn{0%{opacity:0}to{opacity:1}}.token-modal-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:var(--radius-xl);padding:32px;max-width:440px;width:90%;z-index:501;animation:tokenPanelIn .25s cubic-bezier(.22,1,.36,1)}@keyframes tokenPanelIn{0%{opacity:0;transform:translate(-50%,-48%)}to{opacity:1;transform:translate(-50%,-50%)}}.token-modal-title{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--ink);margin-bottom:16px}.token-display{font-family:monospace;font-size:13px;background:var(--p50);border:1px solid var(--border-solid);border-radius:var(--radius);padding:12px;word-break:break-all;color:var(--ink);margin-bottom:12px}.token-warning{background:var(--amber-soft);border-left:3px solid var(--amber);border-radius:0 var(--radius) var(--radius) 0;padding:12px 14px;font-size:13px;color:var(--ink2);margin-bottom:16px}.token-modal-actions{display:flex;gap:12px;justify-content:flex-end}.code-block{font-family:monospace;font-size:13px;background:var(--p50);border:1px solid var(--border-solid);border-radius:var(--radius);padding:8px 12px;word-break:break-all;color:var(--ink)}.loyalty-info-text{font-size:13px;color:var(--muted);margin-bottom:16px;line-height:1.5}.loyalty-checkbox-row{display:flex;align-items:center;gap:8px}.loyalty-checkbox-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--p500)}.loyalty-checkbox-row label{font-family:var(--font-body);font-size:14px;color:var(--ink);cursor:pointer}.sms-balance{display:inline-flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius);padding:8px 14px;font-size:14px;color:var(--ink);margin-bottom:20px}.sms-balance strong{font-weight:700;color:var(--p600)}.token-status{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);padding:16px 20px;margin-bottom:20px}.token-status-text{font-size:14px;color:var(--ink);flex:1}.revoke-confirm{background:#ef44440a;border:1px solid rgba(239,68,68,.15);border-radius:var(--radius);padding:14px;margin-top:12px;font-size:13px;color:var(--ink2)}.revoke-confirm p{margin-bottom:12px}.revoke-confirm-actions{display:flex;gap:10px}.subs-page{max-width:900px}.subs-title{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--ink);margin-bottom:4px}.subs-desc{font-size:14px;color:var(--muted);margin-bottom:32px}.subs-product-name{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--ink);margin-bottom:16px;margin-top:24px}.subs-product-desc{font-size:14px;color:var(--muted);margin-bottom:16px;margin-top:-8px}.subs-error{background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:8px;padding:10px 14px;color:#dc2626;font-size:13px;line-height:1.4}.plans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-bottom:32px}.plan-card{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);padding:24px;display:flex;flex-direction:column;position:relative}.plan-card.featured{border:2px solid var(--p400);box-shadow:var(--shadow-md)}.plan-skeleton{min-height:280px;background:var(--p100);animation:planShimmer .5s ease-in-out infinite alternate}@keyframes planShimmer{0%{opacity:.4}to{opacity:.8}}.plan-badge{position:absolute;top:-10px;left:20px;background:var(--gradient);color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px}.plan-name{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--ink);margin-bottom:8px}.plan-price{margin-bottom:16px}.plan-price-value{font-family:var(--font-display);font-size:30px;font-weight:700;color:var(--ink)}.plan-card.featured .plan-price-value{color:var(--p600)}.plan-price-period{font-size:14px;color:var(--muted)}.plan-features{list-style:none;padding:0;margin:0 0 20px;flex:1}.plan-features li{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--ink);padding:4px 0}.plan-check{color:var(--green);flex-shrink:0}.plan-btn{padding:10px 20px;border:1px solid var(--p500);border-radius:10px;background:none;font-family:var(--font-body);font-size:14px;font-weight:600;color:var(--p500);cursor:pointer;transition:all .15s;min-height:44px}.plan-btn:hover{background:var(--p50);border-color:var(--p400)}.plan-btn.primary{background:var(--gradient);color:#fff;border:none}.plan-btn.primary:hover{transform:translateY(-1px)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:300;display:flex;align-items:center;justify-content:center;animation:modalFadeIn .2s}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-panel{background:#fff;border-radius:var(--radius-xl);padding:32px;max-width:440px;width:90%;position:relative;animation:modalSlideIn .25s cubic-bezier(.22,1,.36,1)}@keyframes modalSlideIn{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:6px;transition:color .15s;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:var(--ink)}.modal-title{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--ink);margin-bottom:8px}.modal-body{font-size:14px;color:var(--muted);margin-bottom:16px}.modal-link{display:flex;align-items:center;gap:6px;color:var(--p600);font-weight:600;font-size:14px;margin-bottom:8px;text-decoration:none}.modal-link:hover{color:var(--p500)}.help-page{display:flex;min-height:100%}.help-sidebar{width:260px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);padding:24px 0;position:sticky;top:0;height:calc(100vh - 72px);overflow-y:auto}.help-logo{font-size:16px;font-weight:700;color:var(--p600);padding:0 20px 20px;border-bottom:1px solid var(--border);margin-bottom:16px;font-family:var(--font-display)}.help-logo a{color:inherit;text-decoration:none}.help-logo a:hover{opacity:.9}.help-nav-group-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding:0 20px 8px;margin-top:16px}.help-nav-link{display:flex;align-items:center;gap:8px;padding:8px 20px;min-height:44px;color:var(--muted);background:none;border:none;border-left:3px solid transparent;font-size:13px;font-family:var(--font-body);cursor:pointer;transition:all .15s;width:100%;text-align:left}.help-nav-link:hover{color:var(--ink);background:var(--p50)}.help-nav-link.active{color:var(--p500);border-left-color:var(--p500);background:var(--p50);font-weight:600}.help-back{display:inline-flex;align-items:center;gap:4px;color:var(--p600);font-weight:600;font-size:13px;margin:24px 20px 0;text-decoration:none}.help-back:hover{text-decoration:underline;opacity:.9}.help-main{flex:1;padding:0 0 0 40px;max-width:720px}.help-section{display:none}.help-section.active{display:block}.help-section h1{font-family:var(--font-display);font-size:28px;font-weight:700;color:var(--ink);margin-bottom:8px}.help-section .help-lead{font-size:14px;color:var(--muted);margin-bottom:24px;line-height:1.55}.help-section h2{font-family:var(--font-display);font-size:18px;font-weight:700;margin:24px 0 12px;color:var(--ink)}.help-section h3{font-size:14px;font-weight:600;margin:20px 0 8px;color:var(--ink)}.help-section p{margin-bottom:12px;line-height:1.55;font-size:14px}.help-section ul,.help-section ol{margin:8px 0 16px 24px;font-size:14px}.help-section li{margin-bottom:4px;line-height:1.55}.help-step{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);padding:16px 20px;margin:12px 0;box-shadow:var(--shadow-sm);display:flex;align-items:flex-start;font-size:14px;line-height:1.55}.help-step-num{display:inline-flex;width:28px;height:28px;background:var(--p500);color:#fff;border-radius:50%;align-items:center;justify-content:center;font-weight:700;font-size:13px;margin-right:12px;flex-shrink:0}.help-tip{background:var(--p50);border-left:4px solid var(--p500);border-radius:0 var(--radius) var(--radius) 0;padding:16px;margin:16px 0;font-size:13px;line-height:1.55}.help-table{width:100%;border-collapse:collapse;font-size:13px;margin:12px 0;border:1px solid var(--border-solid);border-radius:var(--radius);overflow:hidden}.help-table th{background:var(--bg);padding:12px 16px;text-align:left;font-weight:600}.help-table td{padding:12px 16px;border-top:1px solid var(--border-solid)}.help-table tbody tr:hover td{background:var(--bg)}@media (max-width: 768px){.help-page{flex-direction:column}.help-sidebar{width:100%;height:auto;position:relative}.help-main{padding:0;max-width:100%}}.wifi-wizard{max-width:640px;margin:0 auto;padding:2rem 1rem}.wifi-wizard-steps{display:flex;align-items:center;justify-content:center;margin-bottom:32px;gap:0}.wifi-wizard-step-group{display:flex;align-items:center}.wifi-wizard-step-dot{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;border:2.5px solid var(--border-solid, #d1d5db);color:var(--muted, #9ca3af);background:transparent;transition:all .25s ease;position:relative}.wifi-wizard-step-dot.active{background:var(--gradient);border-color:#534ab7;color:#fff;box-shadow:0 4px 14px #534ab74d}.wifi-wizard-step-dot.completed{background:#22c55e;border-color:#22c55e;color:#fff}.wifi-wizard-step-line{width:48px;height:2.5px;background:var(--border-solid, #d1d5db);margin:0 6px;transition:background .25s ease;border-radius:2px}.wifi-wizard-step-line.active{background:#22c55e}.wifi-wizard-step-label{display:block;font-size:11px;color:var(--muted);text-align:center;margin-top:6px;font-weight:500}.wifi-wizard-step-dot.active+.wifi-wizard-step-label,.wifi-wizard-step-dot.completed+.wifi-wizard-step-label{color:var(--ink)}.wifi-wizard-content{animation:wizFadeIn .25s ease}@keyframes wizFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.wifi-wizard-title{font-family:var(--font-display, Outfit, sans-serif);font-size:22px;font-weight:700;color:var(--ink);margin-bottom:4px}.wifi-wizard-subtitle{font-size:14px;color:var(--muted);margin-bottom:24px}.wifi-color-swatches{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:8px}.wifi-color-swatch{width:40px;height:40px;border-radius:10px;border:3px solid transparent;cursor:pointer;transition:border-color .15s,transform .15s;padding:0;outline:none}.wifi-color-swatch:hover{transform:scale(1.1)}.wifi-color-swatch.selected{border-color:var(--ink, #1a1a2e);box-shadow:0 0 0 2px #fff,0 0 0 4px var(--ink, #1a1a2e)}.wifi-auth-methods{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.wifi-auth-method-card{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:12px;border:2px solid var(--border-solid, #e5e7eb);background:var(--card, #fff);cursor:pointer;transition:border-color .15s,background .15s}.wifi-auth-method-card:hover{border-color:var(--p300, #c4b5fd)}.wifi-auth-method-card.selected{border-color:#534ab7;background:#534ab70a}.wifi-auth-method-card input[type=radio]{accent-color:#534AB7;width:16px;height:16px;flex-shrink:0}.wifi-auth-method-info{flex:1}.wifi-auth-method-name{font-size:14px;font-weight:700;color:var(--ink);margin:0}.wifi-auth-method-desc{font-size:12px;color:var(--muted);margin:2px 0 0}.wifi-router-select-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;margin-bottom:20px}.wifi-router-select-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:16px 10px;border-radius:12px;border:2px solid var(--border-solid, #e5e7eb);background:var(--card, #fff);cursor:pointer;transition:border-color .15s,background .15s;font-size:13px;font-weight:600;color:var(--ink)}.wifi-router-select-card:hover{border-color:var(--p300, #c4b5fd)}.wifi-router-select-card.selected{border-color:#534ab7;background:#534ab70a}.wifi-wizard-code{display:block;background:var(--bg, #f3f4f6);border:1px solid var(--border-solid, #e5e7eb);border-radius:10px;padding:14px 16px;font-size:13px;font-family:JetBrains Mono,monospace;line-height:1.6;word-break:break-all;color:var(--ink);margin-bottom:8px}.wifi-wizard-copy-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:8px;border:1px solid var(--border-solid, #e5e7eb);background:var(--card, #fff);font-size:12px;font-weight:600;color:var(--ink);cursor:pointer;transition:background .15s}.wifi-wizard-copy-btn:hover{background:var(--p50, #f5f0ff)}.wifi-wizard-copy-btn.copied{color:#22c55e;border-color:#22c55e}.wifi-wizard-actions{display:flex;gap:12px;margin-top:28px}.wifi-wizard-btn{display:inline-flex;align-items:center;gap:6px;padding:12px 28px;border:none;border-radius:10px;font-family:var(--font-display, Outfit, sans-serif);font-size:14px;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s,opacity .15s;min-height:44px}.wifi-wizard-btn.primary{background:linear-gradient(135deg,#534ab7,#7c6dd8);color:#fff;box-shadow:0 6px 24px #534ab759}.wifi-wizard-btn.primary:hover{transform:translateY(-1px);box-shadow:0 10px 32px #534ab773}.wifi-wizard-btn.secondary{background:var(--bg, #f3f4f6);color:var(--ink);border:1px solid var(--border-solid, #e5e7eb)}.wifi-wizard-btn.secondary:hover{background:var(--p50, #f5f0ff)}.wifi-wizard-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.wifi-wizard-upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px;border:2px dashed var(--border-solid, #d1d5db);border-radius:12px;cursor:pointer;transition:border-color .15s,background .15s;text-align:center;min-height:100px}.wifi-wizard-upload-zone:hover{border-color:#534ab7;background:#534ab708}.wifi-wizard-upload-zone.has-logo{border-style:solid;border-color:var(--border-solid, #e5e7eb);background:var(--bg, #f9fafb)}.wifi-wizard-conditional{margin-top:12px;padding:14px 16px;background:var(--bg, #f9fafb);border-radius:10px;border:1px solid var(--border-solid, #e5e7eb)}.wifi-wizard-instructions{margin-top:16px;padding:16px;background:var(--bg, #f9fafb);border-radius:12px;border:1px solid var(--border-solid, #e5e7eb)}.wifi-wizard-instructions h4{font-size:14px;font-weight:700;color:var(--ink);margin:0 0 12px}.wifi-wizard-instructions ol{margin:0;padding-left:20px;font-size:13px;line-height:1.7;color:var(--ink)}@media (max-width: 640px){.wifi-wizard{padding:1rem}.wifi-wizard-step-line{width:32px}.wifi-router-select-grid{grid-template-columns:repeat(2,1fr)}.wifi-wizard-actions{flex-direction:column}}.wps-layout{display:grid;grid-template-columns:1fr 360px;gap:32px;align-items:start}.wps-form-col{display:flex;flex-direction:column;gap:16px;min-width:0}.wps-preview-col{position:sticky;top:24px}.wps-preview-label{font-size:13px;color:var(--muted);margin-bottom:12px}.wps-section{background:var(--card, #fff);border:1px solid var(--border-solid, #e5e7eb);border-radius:12px;padding:20px}.wps-section-title{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--ink);margin:0 0 16px}.wps-section-title svg{color:var(--p500, #9B6DFF);flex-shrink:0}.wps-status-bar{background:var(--card, #fff);border:1px solid var(--border-solid, #e5e7eb);border-radius:12px;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.wps-status-left{display:flex;align-items:center;gap:12px}.wps-status-label{font-size:14px;font-weight:600;color:var(--ink)}.wps-test-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--p500, #9B6DFF);text-decoration:none;padding:6px 14px;border-radius:8px;border:1px solid var(--p200, #ddd6fe);background:var(--p50, #f5f0ff);transition:background .15s,border-color .15s}.wps-test-link:hover{background:var(--p100, #ede9fe);border-color:var(--p300, #c4b5fd)}.wps-color-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.wps-color-swatch{width:40px;height:40px;padding:2px;border-radius:8px;border:1px solid var(--border-solid, #e5e7eb);cursor:pointer;background:none;flex-shrink:0}.wps-color-hex{width:110px;font-family:Courier New,monospace}.wps-color-presets{display:flex;gap:6px}.wps-preset-btn{padding:4px 12px;font-size:12px;font-weight:600;font-family:var(--font-body);border-radius:6px;border:1px solid var(--border-solid, #e5e7eb);background:var(--card, #fff);color:var(--ink2);cursor:pointer;transition:background .15s,border-color .15s,color .15s}.wps-preset-btn:hover{background:var(--p50, #f5f0ff);border-color:var(--p300, #c4b5fd);color:var(--p600)}.wps-auth-info{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;background:var(--p50, #f5f0ff);border-radius:10px;border:1px solid var(--p200, #ddd6fe)}.wps-auth-method{font-size:13px;font-weight:700;color:var(--ink);margin:0}.wps-auth-hint{font-size:12px;color:var(--muted);margin:2px 0 0}.wps-auth-link{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--p500, #9B6DFF);text-decoration:none;white-space:nowrap;font-weight:600;transition:color .15s}.wps-auth-link:hover{color:var(--p700)}.wps-legal-warning{padding:12px 16px;background:#fef9c3;border-radius:10px;border:1px solid #fde047;font-size:13px;color:#854d0e;line-height:1.5;margin-bottom:16px}.wps-template-btn{font-size:12px;color:var(--p500, #9B6DFF);background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:4px;font-family:var(--font-body);transition:color .15s}.wps-template-btn:hover{color:var(--p700)}.wps-consent-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.wps-hint{font-size:12px;color:var(--muted);margin-top:4px;display:block}.wps-hint a{color:var(--p500, #9B6DFF);text-decoration:none}.wps-hint a:hover{text-decoration:underline}.wps-optional{font-weight:400;color:var(--muted);font-size:12px}.wps-required{color:#ef4444}.wps-char-count{font-size:12px;color:var(--muted);margin-top:4px;text-align:right;display:block}.wps-check-desc{font-size:12px;color:var(--muted);margin-top:4px;padding-left:26px}.wps-logo-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.wps-logo-preview{position:relative}.wps-logo-img{height:36px;max-width:100px;object-fit:contain;border-radius:6px;border:1px solid var(--border-solid, #e5e7eb);padding:4px;background:#fff}.wps-logo-remove{position:absolute;top:-8px;right:-8px;width:18px;height:18px;border-radius:50%;border:none;background:#ef4444;color:#fff;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:background .15s}.wps-logo-remove:hover{background:#dc2626}.wps-logo-error{font-size:12px;color:#ef4444}.wps-remove-btn{padding:4px 10px;font-size:12px;font-weight:600;font-family:var(--font-body);border-radius:6px;border:1px solid var(--border-solid, #e5e7eb);background:var(--card, #fff);color:var(--muted);cursor:pointer;transition:background .15s,color .15s}.wps-remove-btn:hover{background:#ef44440f;color:#ef4444}@media (max-width: 768px){.wps-layout{grid-template-columns:1fr}.wps-preview-col{display:none}.wps-status-bar{flex-direction:column;align-items:stretch;gap:8px}.wps-test-link{justify-content:center}.wps-color-row{flex-wrap:wrap}}.crm-filter-bar{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:16px}.crm-filter-group{display:flex;flex-direction:column;gap:4px}.crm-filter-label{font-size:13px;color:var(--muted);font-family:var(--font-body)}.crm-filter-select{padding:6px 10px;border:1px solid var(--p100, #e9e0ff);border-radius:8px;font-size:14px;font-family:var(--font-body);background:#fff;color:var(--ink);min-width:140px}.crm-filter-date{padding:6px 10px;border:1px solid var(--p100, #e9e0ff);border-radius:8px;font-size:14px;font-family:var(--font-body);background:#fff;color:var(--ink)}.crm-reset-filters{font-size:13px;color:var(--p600, #7c3aed);background:none;border:none;cursor:pointer;padding:6px 0;font-family:var(--font-body)}.crm-reset-filters:hover{text-decoration:underline}.crm-source-toggle{display:flex;gap:0;border:1px solid var(--p200, #ddd0ff);border-radius:8px;overflow:hidden}.crm-source-btn{padding:6px 14px;font-size:13px;font-family:var(--font-body);border:none;background:#fff;color:var(--ink2, #666);cursor:pointer;transition:background .15s,color .15s}.crm-source-btn.active{background:var(--p600, #7c3aed);color:#fff}.crm-source-btn+.crm-source-btn{border-left:1px solid var(--p200, #ddd0ff)}.crm-sort-th{cursor:pointer;-webkit-user-select:none;user-select:none}.crm-sort-th:hover{color:var(--p600, #7c3aed)}.crm-sort-icon{margin-left:4px;vertical-align:middle}.crm-tags-cell{display:flex;flex-wrap:wrap;gap:4px}.tag-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:12px;font-family:var(--font-body);background:var(--p50, #f5f0ff);color:var(--p600, #7c3aed);border:1px solid var(--p200, #ddd0ff);white-space:nowrap}.tag-chip-remove{cursor:pointer;display:inline-flex;align-items:center;color:var(--muted);margin-left:2px}.tag-chip-remove:hover{color:var(--red, #ef4444)}.tag-input-wrap{display:flex;flex-wrap:wrap;gap:6px;align-items:center;padding:6px 10px;border:1px solid var(--p100, #e9e0ff);border-radius:8px;background:#fff;min-height:36px}.tag-input-wrap:focus-within{border-color:var(--p400, #a78bfa);box-shadow:0 0 0 2px #7c3aed1a}.tag-input-field{border:none;outline:none;font-size:14px;font-family:var(--font-body);color:var(--ink);flex:1;min-width:100px;background:transparent}.tag-input-field::placeholder{color:var(--muted2, #aaa)}.tag-autocomplete{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--p100, #e9e0ff);border-radius:8px;box-shadow:0 4px 12px #0000001a;max-height:160px;overflow-y:auto;z-index:10}.tag-autocomplete-item{padding:8px 12px;font-size:13px;font-family:var(--font-body);cursor:pointer;color:var(--ink)}.tag-autocomplete-item:hover{background:var(--p50, #f5f0ff)}.client-history-tabs{display:flex;gap:0;border-bottom:1px solid var(--p100, #e9e0ff);margin-bottom:16px}.client-history-tab{padding:8px 16px;font-size:13px;font-family:var(--font-body);border:none;background:none;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.client-history-tab.active{color:var(--p600, #7c3aed);border-bottom-color:var(--p600, #7c3aed)}.client-history-tab:hover:not(.active){color:var(--ink)}.history-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--p50, #f5f0ff);font-size:14px;font-family:var(--font-body)}.history-item:last-child{border-bottom:none}.history-item-main{display:flex;flex-direction:column;gap:2px}.history-item-title{color:var(--ink)}.history-item-meta{font-size:12px;color:var(--muted)}.history-item-date{font-size:13px;color:var(--muted);white-space:nowrap}.history-empty{text-align:center;padding:24px 0;color:var(--muted);font-size:14px}.crm-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}@media (max-width: 768px){.crm-filter-bar{flex-direction:column;gap:8px}.crm-filter-select,.crm-filter-date,.crm-source-toggle{width:100%}.crm-source-btn{flex:1;text-align:center}.crm-toolbar{flex-direction:column;align-items:stretch}}.crm-status-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:700;border-radius:20px;padding:2px 10px;font-family:var(--font-body);white-space:nowrap}.crm-dashboard{max-width:960px}.crm-dashboard-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:16px}@media (max-width: 900px){.crm-dashboard-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 500px){.crm-dashboard-grid{grid-template-columns:1fr}}.crm-metric-card{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);padding:16px 20px;box-shadow:var(--shadow-sm)}.crm-metric-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:8px}.crm-metric-value{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--ink);line-height:1.2}.crm-metric-label{font-family:var(--font-body);font-size:13px;color:var(--muted);margin-top:2px}.crm-dashboard-updated{font-size:13px;color:var(--muted);margin-bottom:20px}.crm-quick-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}.crm-quick-link{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--border-solid);border-radius:10px;background:var(--card);font-size:13px;font-family:var(--font-body);color:var(--ink2);cursor:pointer;transition:background .15s,border-color .15s,color .15s}.crm-quick-link:hover{background:var(--p50);border-color:var(--p300);color:var(--p500)}.crm-quick-link--warn{border-color:#ef44444d;color:#ef4444}.crm-quick-link--warn:hover{background:#ef44440f;border-color:#ef4444;color:#dc2626}.crm-segments-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.crm-segment-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius);cursor:pointer;transition:background .12s}.crm-segment-row:hover{background:var(--p50)}.crm-segment-info{display:flex;flex-direction:column;gap:2px}.crm-segment-name{font-weight:700;font-size:14px;color:var(--ink)}.crm-segment-meta{font-size:13px;color:var(--muted)}.crm-segment-actions{display:flex;gap:8px;align-items:center}.crm-filter-builder{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.crm-filter-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.crm-filter-row select,.crm-filter-row input{padding:6px 10px;border:1px solid var(--p100, #e9e0ff);border-radius:8px;font-size:14px;font-family:var(--font-body);background:#fff;color:var(--ink)}.crm-filter-row select{min-width:130px}.crm-filter-row input[type=text],.crm-filter-row input[type=number]{min-width:120px}.crm-filter-remove{background:none;border:none;cursor:pointer;color:var(--muted);padding:4px}.crm-filter-remove:hover{color:var(--red)}.crm-preview-count{font-size:14px;color:var(--p600);font-weight:600;padding:8px 0}.crm-segment-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:12px;flex-wrap:wrap}.crm-tasks-tabs{display:flex;gap:0;border-bottom:1px solid var(--p100, #e9e0ff);margin-bottom:16px}.crm-tasks-tab{padding:8px 16px;font-size:13px;font-family:var(--font-body);border:none;background:none;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.crm-tasks-tab.active{color:var(--p600, #7c3aed);border-bottom-color:var(--p600, #7c3aed)}.crm-tasks-tab:hover:not(.active){color:var(--ink)}.crm-tasks-tab .tab-count{font-size:12px;font-weight:700;margin-left:4px}.crm-tasks-tab .tab-count--red{color:#ef4444}.crm-task-card{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius);margin-bottom:8px;gap:12px}.crm-task-card--overdue{border-color:#ef44444d;background:#ef444408}.crm-task-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.crm-task-title{font-weight:700;font-size:14px;color:var(--ink)}.crm-task-meta{font-size:13px;color:var(--muted);display:flex;gap:8px;flex-wrap:wrap}.crm-task-due--overdue{color:#ef4444;font-weight:600}.crm-task-source-badge{font-size:11px;font-weight:700;padding:1px 6px;border-radius:4px;background:var(--p50);color:var(--p600)}.crm-task-actions{display:flex;gap:8px;flex-shrink:0}.crm-dup-pair{display:flex;gap:16px;padding:16px;background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);margin-bottom:12px;flex-wrap:wrap}.crm-dup-contact{flex:1;min-width:200px;padding:12px;background:var(--bg);border-radius:var(--radius)}.crm-dup-contact-name{font-weight:700;font-size:14px;color:var(--ink);margin-bottom:4px}.crm-dup-contact-detail{font-size:13px;color:var(--muted);line-height:1.6}.crm-dup-actions{display:flex;flex-direction:column;justify-content:center;gap:8px;min-width:140px}.crm-dup-confidence{font-size:12px;font-weight:700;padding:2px 8px;border-radius:20px;text-align:center}.crm-dup-confidence--high{color:#ef4444;background:#ef44441a}.crm-dup-confidence--medium{color:#f59e0b;background:#f59e0b1a}.crm-funnel-wrap{overflow-x:auto;padding-bottom:16px}.crm-kanban{display:flex;gap:12px;min-width:min-content}.crm-kanban-col{min-width:240px;max-width:280px;flex-shrink:0;background:var(--bg);border:1px solid var(--border-solid);border-radius:var(--radius-lg);display:flex;flex-direction:column}.crm-kanban-header{padding:12px 16px;border-bottom:1px solid var(--border-solid);display:flex;flex-direction:column;gap:4px}.crm-kanban-stage-name{font-weight:700;font-size:14px;color:var(--ink);display:flex;align-items:center;gap:6px}.crm-kanban-stage-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.crm-kanban-stage-stats{font-size:12px;color:var(--muted)}.crm-kanban-body{padding:8px;display:flex;flex-direction:column;gap:8px;flex:1;min-height:80px}.crm-deal-card{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius);padding:10px 12px;display:flex;align-items:flex-start;gap:8px;cursor:grab;transition:box-shadow .15s,transform .15s,opacity .15s;-webkit-user-select:none;user-select:none}.crm-deal-card:hover{box-shadow:0 2px 8px #00000014}.crm-deal-card:active{cursor:grabbing}.crm-deal-dragging{opacity:.4;transform:scale(.97);box-shadow:0 4px 16px #534ab733}.crm-deal-grip{color:var(--muted, #999);flex-shrink:0;padding-top:2px;cursor:grab}.crm-deal-content{flex:1;min-width:0}.crm-deal-title{font-weight:700;font-size:13px;color:var(--ink);margin-bottom:2px}.crm-deal-meta{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px}.crm-deal-amount{font-weight:600;color:var(--ink)}.crm-kanban-col-dragover{background:#534ab70a;outline:2px dashed rgba(83,74,183,.3);outline-offset:-2px}.crm-deal-drop-placeholder{border:2px dashed rgba(83,74,183,.3);border-radius:var(--radius);padding:16px;text-align:center;color:var(--p600, #7c3aed);font-size:13px;font-weight:600;background:#534ab70a}.crm-stage-settings{background:var(--card, #fff);border:1px solid var(--border-solid, #e8e8e8);border-radius:12px;padding:20px 24px;margin-bottom:24px}.crm-stage-settings-title{font-size:15px;font-weight:700;margin:0 0 4px}.crm-stage-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.crm-stage-row{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg, #f8f8fc);border-radius:8px;flex-wrap:wrap}.crm-stage-row-name{font-size:14px;font-weight:600;flex:1;min-width:100px}.crm-stage-row-count{font-size:12px;color:var(--muted);background:var(--card);padding:2px 8px;border-radius:10px;font-weight:600}.crm-stage-row-actions{display:flex;gap:4px;align-items:center}.crm-stage-arrow{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-solid, #e0e0e0);border-radius:6px;background:var(--card);cursor:pointer;font-size:13px;color:var(--muted)}.crm-stage-arrow:hover:not(:disabled){background:var(--p50, #f5f3ff);color:var(--p600, #7c3aed);border-color:var(--p200, #ddd0ff)}.crm-stage-arrow:disabled{opacity:.3;cursor:not-allowed}.crm-stage-edit-btn{font-size:12px;padding:4px 10px;border:1px solid var(--p200, #ddd0ff);border-radius:6px;background:var(--card);color:var(--p600, #7c3aed);cursor:pointer;font-weight:600}.crm-stage-edit-btn:hover{background:var(--p50, #f5f3ff)}.crm-stage-delete-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid #fecaca;border-radius:6px;background:var(--card);color:#ef4444;cursor:pointer}.crm-stage-delete-btn:hover{background:#fef2f2}.crm-stage-name-input{flex:1;min-width:120px}.crm-stage-colors{display:flex;gap:4px;align-items:center}.crm-color-dot{width:20px;height:20px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .1s,border-color .1s}.crm-color-dot:hover{transform:scale(1.2)}.crm-color-dot.active{border-color:var(--ink, #1a1a2e);transform:scale(1.15)}.crm-stage-btn{font-size:12px;padding:6px 14px;white-space:nowrap}.crm-stage-add-row{display:flex;align-items:center;gap:10px;padding-top:12px;border-top:1px solid var(--border-solid, #e8e8e8);flex-wrap:wrap}.crm-deal-detail-panel{position:fixed;right:0;top:0;width:420px;max-width:90vw;height:100vh;background:#fff;box-shadow:-4px 0 24px #0000001f;display:flex;flex-direction:column;z-index:1001;animation:crm-slide-in .2s ease-out}@keyframes crm-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.crm-detail-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-solid, #e8e8e8)}.crm-detail-header h3{margin:0;font-size:16px;font-weight:700}.crm-detail-close{background:none;border:none;cursor:pointer;color:var(--muted);padding:4px;border-radius:6px}.crm-detail-close:hover{background:var(--bg, #f5f5f5);color:var(--ink)}.crm-detail-body{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:16px}.crm-detail-body textarea.settings-input{resize:vertical;min-height:80px}.crm-detail-contact-link{background:none;border:1px solid var(--p200, #ddd0ff);border-radius:8px;padding:8px 14px;cursor:pointer;color:var(--p600, #7c3aed);font-size:13px;font-weight:600;text-align:left;transition:background .12s}.crm-detail-contact-link:hover{background:var(--p50, #f5f3ff)}.crm-detail-date{font-size:12px;color:var(--muted)}.crm-detail-footer{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-top:1px solid var(--border-solid, #e8e8e8)}.crm-detail-delete{background:none;border:none;cursor:pointer;color:#ef4444;font-size:13px;font-weight:600;display:flex;align-items:center;gap:4px;padding:6px 10px;border-radius:6px}.crm-detail-delete:hover{background:#fef2f2}.crm-kanban-add{padding:8px;text-align:center}.crm-kanban-add-btn{font-size:13px;color:var(--p600, #7c3aed);background:none;border:none;cursor:pointer;font-family:var(--font-body);display:inline-flex;align-items:center;gap:4px}.crm-kanban-add-btn:hover{text-decoration:underline}.crm-scenario-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius);margin-bottom:8px;gap:12px}.crm-scenario-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.crm-scenario-name{font-weight:700;font-size:14px;color:var(--ink)}.crm-scenario-trigger{font-size:13px;color:var(--muted)}.crm-scenario-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.crm-action-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:6px}.crm-action-badge--sms{color:var(--amber);background:var(--amber-soft)}.crm-action-badge--email{color:#3b82f6;background:#3b82f61a}.crm-action-badge--create_task{color:var(--p500);background:var(--p50)}.crm-log-panel{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);padding:16px;margin-top:12px}.crm-log-table{width:100%;border-collapse:collapse;font-size:13px}.crm-log-table th{text-align:left;padding:6px 10px;font-weight:700;color:var(--muted);border-bottom:1px solid var(--border-solid)}.crm-log-table td{padding:6px 10px;color:var(--ink);border-bottom:1px solid var(--p50)}.crm-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.crm-modal{background:var(--card);border-radius:var(--radius-lg);padding:24px;min-width:360px;max-width:500px;width:90%;box-shadow:0 12px 40px #0003}.crm-modal h3{font-family:var(--font-display);font-size:18px;font-weight:700;margin-bottom:16px;color:var(--ink)}.crm-modal-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.crm-modal-label{font-size:13px;color:var(--muted);font-family:var(--font-body)}.crm-modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}.crm-inline-form{padding:12px;background:var(--bg);border-radius:var(--radius)}.csv-dropzone{border:2px dashed var(--p200, #ddd0ff);border-radius:12px;padding:48px 24px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;background:#fff}.csv-dropzone:hover,.csv-dropzone.dragover{border-color:var(--p400, #a78bfa);background:var(--p50, #f5f0ff)}.csv-dropzone-icon{color:var(--p400, #a78bfa);margin-bottom:12px}.csv-dropzone-text{font-size:14px;color:var(--ink);font-family:var(--font-body);margin-bottom:4px}.csv-dropzone-hint{font-size:13px;color:var(--muted);font-family:var(--font-body)}.import-preview-wrap{overflow-x:auto;margin-top:16px}.import-preview-table{width:100%;border-collapse:collapse;font-size:14px;font-family:var(--font-body)}.import-preview-table th{text-align:left;padding:8px 12px;font-weight:600;font-size:13px;color:var(--muted);border-bottom:1px solid var(--p100, #e9e0ff)}.import-preview-table td{padding:8px 12px;border-bottom:1px solid var(--p50, #f5f0ff);color:var(--ink)}.import-row-duplicate{background:#f59e0b14}.import-duplicate-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:12px;background:#f59e0b26;color:#b45309}.import-row-actions{display:flex;gap:6px}.import-row-action{padding:4px 10px;border-radius:6px;font-size:12px;font-family:var(--font-body);border:1px solid var(--p200, #ddd0ff);background:#fff;color:var(--ink);cursor:pointer}.import-row-action:hover{background:var(--p50, #f5f0ff)}.import-row-action.selected{background:var(--p600, #7c3aed);color:#fff;border-color:var(--p600, #7c3aed)}.import-bulk-actions{display:flex;gap:8px;margin:12px 0;align-items:center}.import-bulk-btn{padding:6px 12px;border-radius:6px;font-size:13px;font-family:var(--font-body);border:1px solid var(--p200, #ddd0ff);background:#fff;color:var(--ink);cursor:pointer}.import-bulk-btn:hover{background:var(--p50, #f5f0ff)}.import-stats{font-size:13px;color:var(--muted);font-family:var(--font-body)}.import-confirm-bar{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:16px;border-top:1px solid var(--p100, #e9e0ff)}.crm-analytics-funnel{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.crm-funnel-row{display:flex;align-items:center;gap:12px}.crm-funnel-label{min-width:160px;flex-shrink:0;display:flex;flex-direction:column;gap:2px}.crm-funnel-stage-name{font-size:14px;font-weight:600;color:var(--ink);font-family:var(--font-body)}.crm-funnel-stage-stats{font-size:12px;color:var(--muted);font-family:var(--font-body)}.crm-funnel-conv{color:var(--p600, #7c3aed);font-weight:600}.crm-funnel-bar-wrap{flex:1;min-width:0;background:var(--bg, #f5f5f5);border-radius:6px;height:36px;position:relative}.crm-funnel-bar{height:36px;border-radius:6px;transition:width .5s ease;min-width:32px;display:flex;align-items:center;justify-content:flex-end;padding-right:10px}.crm-funnel-bar-pct{font-size:12px;font-weight:700;color:#fff;font-family:var(--font-body);text-shadow:0 1px 2px rgba(0,0,0,.3)}.crm-analytics-total{display:flex;align-items:center;gap:6px;padding:10px 0 0;border-top:1px solid var(--border-solid, #e8e8e8);font-size:14px;font-family:var(--font-body);color:var(--ink)}.crm-speed-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-bottom:16px}.crm-speed-card{background:var(--bg, #f8f8fc);border:1px solid var(--border-solid, #e8e8e8);border-radius:var(--radius, 10px);padding:14px 16px;position:relative}.crm-speed-card--slow{border-color:#ef44444d;background:#ef44440a}.crm-speed-card--fast{border-color:#22c55e4d;background:#22c55e0a}.crm-speed-card-value{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--ink);line-height:1.2}.crm-speed-card-unit{font-size:13px;font-weight:400;color:var(--muted)}.crm-speed-card-name{font-size:13px;font-weight:600;color:var(--ink);margin-top:4px;font-family:var(--font-body)}.crm-speed-card-count{font-size:12px;color:var(--muted);font-family:var(--font-body)}.crm-speed-badge{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px;margin-top:6px;font-family:var(--font-body)}.crm-speed-badge--slow{color:#ef4444;background:#ef44441f}.crm-speed-badge--fast{color:#22c55e;background:#22c55e1f}.crm-manager-best{background:#f59e0b0f}@media (max-width: 600px){.crm-funnel-row{flex-direction:column;align-items:stretch;gap:4px}.crm-funnel-label{min-width:auto;flex-direction:row;justify-content:space-between;align-items:center}.crm-speed-grid{grid-template-columns:repeat(2,1fr)}}.gift-page{min-height:100vh;background:#f8f7fc;font-family:Inter,system-ui,-apple-system,sans-serif;color:#1a1a2e;overflow-x:hidden;position:relative}.gift-page:before{content:"";position:fixed;top:-30%;left:-20%;width:60%;height:60%;background:radial-gradient(circle,rgba(83,74,183,.04) 0%,transparent 70%);pointer-events:none;z-index:0}.gift-page:after{content:"";position:fixed;bottom:-30%;right:-20%;width:60%;height:60%;background:radial-gradient(circle,rgba(83,74,183,.05) 0%,transparent 70%);pointer-events:none;z-index:0}.gift-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f8f7fc;color:#6b7280;font-size:15px;font-family:Inter,system-ui,sans-serif}.gift-error{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f8f7fc;color:#e53935;font-size:15px;font-family:Inter,system-ui,sans-serif}.gift-layout{position:relative;z-index:1;display:flex;min-height:100vh}.gift-sidebar{width:260px;padding:48px 28px;border-right:1px solid rgba(83,74,183,.08);flex-shrink:0;position:sticky;top:0;height:100vh;display:flex;flex-direction:column}.gift-sidebar-logo{display:flex;align-items:center;gap:12px;margin-bottom:48px}.gift-sidebar-logo img{width:40px;height:40px;border-radius:10px;object-fit:contain}.gift-sidebar-logo span{font-size:15px;font-weight:600;color:#1a1a2e}.gift-step-nav{display:flex;flex-direction:column;gap:4px;flex:1}.gift-step-item{display:flex;align-items:center;gap:14px;padding:12px 14px;border-radius:12px;cursor:pointer;transition:all .25s ease;border:1px solid transparent;background:transparent;color:#ffffff59;font-size:13px;font-weight:500;letter-spacing:.02em;text-align:left;width:100%;font-family:inherit}.gift-step-item:hover{background:#534ab70a;color:#6b7280}.gift-step-num{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;border:1.5px solid rgba(255,255,255,.12);transition:all .25s ease;flex-shrink:0}.gift-step-item.active{background:#534ab71f;border-color:#534ab740;color:#1a1a2e}.gift-step-item.active .gift-step-num{background:var(--gradient);border-color:#534ab7;color:#fff;box-shadow:0 0 20px #534ab766}.gift-step-item.completed .gift-step-num{background:#534ab74d;border-color:#534ab7;color:#fff}.gift-step-item.completed{color:#6b7280}.gift-main{flex:1;padding:48px 56px;max-width:800px;margin:0 auto}.gift-step-content{animation:giftFadeIn .4s ease}@keyframes giftFadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.gift-step-header{margin-bottom:40px}.gift-step-number{font-size:56px;font-weight:200;color:#534ab7;line-height:1;margin-bottom:8px;letter-spacing:-.04em}.gift-step-title{font-size:28px;font-weight:300;color:#1a1a2e;letter-spacing:-.01em;text-transform:lowercase}.gift-design-preview{margin-bottom:40px;display:flex;justify-content:center}.gift-design-main-card{width:340px;height:210px;border-radius:20px;position:relative;overflow:hidden;box-shadow:0 16px 48px #534ab726,0 4px 16px #00000014;transition:transform .15s ease,box-shadow .15s ease;cursor:pointer;transform-style:preserve-3d}.gift-design-main-card:hover{box-shadow:0 20px 56px #534ab733,0 6px 20px #0000001a}.gift-design-main-inner{position:absolute;top:0;right:0;bottom:0;left:0;padding:24px;display:flex;flex-direction:column;justify-content:space-between;z-index:2;color:#fff}.gift-design-main-biz{font-size:11px;text-transform:uppercase;letter-spacing:.2em;opacity:.8;font-weight:600;text-shadow:0 1px 4px rgba(0,0,0,.2)}.gift-design-main-label{font-size:10px;text-transform:uppercase;letter-spacing:.15em;opacity:.6;margin-top:auto;text-shadow:0 1px 4px rgba(0,0,0,.2)}.gift-design-main-amount{font-size:36px;font-weight:800;letter-spacing:-.03em;line-height:1;margin-top:4px;text-shadow:0 2px 8px rgba(0,0,0,.2)}.gift-design-main-message{font-size:12px;opacity:.7;margin-top:6px;line-height:1.4;max-height:34px;overflow:hidden}.gift-design-main-card:after{content:"";position:absolute;top:-80%;left:-120%;width:70%;height:260%;background:linear-gradient(90deg,transparent,rgba(83,74,183,.15),transparent);transform:rotate(12deg);animation:designSheen 5s ease-in-out infinite;pointer-events:none;z-index:3}@keyframes designSheen{0%,30%{left:-120%}55%{left:160%}to{left:160%}}.gift-designs-scroll{display:flex;gap:14px;overflow-x:auto;padding:4px 0 16px;scrollbar-width:thin;scrollbar-color:rgba(83,74,183,.15) transparent}.gift-designs-scroll::-webkit-scrollbar{height:4px}.gift-designs-scroll::-webkit-scrollbar-thumb{background:#534ab726;border-radius:2px}.gift-design-thumb{width:120px;height:75px;border-radius:12px;cursor:pointer;position:relative;overflow:hidden;flex-shrink:0;border:2px solid transparent;transition:all .25s ease;box-shadow:0 4px 12px #0000001a}.gift-design-thumb:hover{transform:translateY(-3px);box-shadow:0 8px 20px #534ab726}.gift-design-thumb.selected{border-color:#534ab7;box-shadow:0 0 0 2px #534ab74d,0 8px 20px #534ab726}.gift-design-thumb-label{position:absolute;bottom:5px;left:7px;font-size:9px;font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.4);letter-spacing:.03em}.gift-design-minimal .gift-design-thumb-label,.gift-design-thumb-label.dark{color:#000000b3;text-shadow:none}.gift-design-minimal{background:#fff;border-left:5px solid #534AB7}.gift-design-minimal .gift-design-main-inner,.gift-design-minimal .gift-design-main-biz,.gift-design-minimal .gift-design-main-label{color:#1a1a2e}.gift-design-minimal .gift-design-main-amount{color:#534ab7}.gift-design-aurora{background:linear-gradient(135deg,#534ab7,#667eea,#00c6ff 70%,#764ba2);background-size:300% 300%;animation:auroraShift 8s ease infinite}@keyframes auroraShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.gift-design-aurora:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 15% 25%,rgba(255,255,255,.3) 1px,transparent 1px),radial-gradient(circle at 45% 70%,rgba(255,255,255,.25) 1.5px,transparent 1.5px),radial-gradient(circle at 75% 20%,rgba(255,255,255,.2) 1px,transparent 1px),radial-gradient(circle at 85% 65%,rgba(255,255,255,.3) 1px,transparent 1px),radial-gradient(circle at 30% 85%,rgba(83,74,183,.15) 2px,transparent 2px);animation:auroraParticles 4s ease-in-out infinite alternate;pointer-events:none;z-index:1}@keyframes auroraParticles{0%{opacity:.6;transform:translateY(0)}to{opacity:1;transform:translateY(-6px)}}.gift-design-midnight{background:linear-gradient(135deg,#0a0e27,#1a1f4e 40%,#0d0d2b)}.gift-design-midnight:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:1px solid rgba(201,162,39,.3);border-radius:inherit;pointer-events:none;z-index:1}.gift-design-midnight .gift-midnight-stars{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1}.gift-design-midnight .gift-midnight-stars span{position:absolute;width:2px;height:2px;background:#c9a227;border-radius:50%;animation:starTwinkle 2s ease-in-out infinite}.gift-design-midnight .gift-midnight-stars span:nth-child(1){left:12%;top:18%;animation-delay:0s}.gift-design-midnight .gift-midnight-stars span:nth-child(2){left:38%;top:28%;animation-delay:.5s}.gift-design-midnight .gift-midnight-stars span:nth-child(3){left:62%;top:12%;animation-delay:1s}.gift-design-midnight .gift-midnight-stars span:nth-child(4){left:82%;top:35%;animation-delay:1.5s}.gift-design-midnight .gift-midnight-stars span:nth-child(5){left:25%;top:72%;animation-delay:.3s}.gift-design-midnight .gift-midnight-stars span:nth-child(6){left:70%;top:68%;animation-delay:.8s}@keyframes starTwinkle{0%,to{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.8)}}.gift-design-midnight .gift-design-main-inner{color:#f0e6d3}.gift-design-midnight .gift-design-main-amount,.gift-design-midnight .gift-design-main-biz{color:#c9a227}.gift-design-celebration{background:linear-gradient(135deg,#ff6b35,#f7418c,#ff85a1)}.gift-design-celebration .gift-celebration-dots{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:1}.gift-design-celebration .gift-celebration-dots span{position:absolute;width:6px;height:6px;border-radius:50%;animation:confettiRise 4s ease-in-out infinite}.gift-design-celebration .gift-celebration-dots span:nth-child(1){left:8%;bottom:-10px;background:#ffd166;animation-delay:0s}.gift-design-celebration .gift-celebration-dots span:nth-child(2){left:22%;bottom:-10px;background:#fff;animation-delay:.7s;width:4px;height:8px;border-radius:2px}.gift-design-celebration .gift-celebration-dots span:nth-child(3){left:45%;bottom:-10px;background:#06d6a0;animation-delay:1.4s}.gift-design-celebration .gift-celebration-dots span:nth-child(4){left:60%;bottom:-10px;background:#4cc9f0;animation-delay:2.1s;width:5px;height:10px;border-radius:2px}.gift-design-celebration .gift-celebration-dots span:nth-child(5){left:78%;bottom:-10px;background:#ffd166;animation-delay:2.8s}.gift-design-celebration .gift-celebration-dots span:nth-child(6){left:92%;bottom:-10px;background:#fff;animation-delay:3.5s}@keyframes confettiRise{0%{transform:translateY(0) rotate(0);opacity:.7}to{transform:translateY(-220px) rotate(360deg);opacity:0}}.gift-design-nature{background:linear-gradient(135deg,#2d8a4e,#56b87b,#7ed9a0)}.gift-design-nature .gift-nature-waves{position:absolute;bottom:0;left:0;right:0;height:50px;overflow:hidden;pointer-events:none;z-index:1}.gift-design-nature .gift-nature-waves:before{content:"";position:absolute;bottom:-8px;left:-50%;width:200%;height:40px;background:radial-gradient(ellipse at 50% 100%,rgba(255,255,255,.18) 0%,transparent 70%);animation:waveSlide 5s ease-in-out infinite}.gift-design-nature .gift-nature-waves:after{content:"";position:absolute;bottom:-15px;left:-30%;width:180%;height:35px;background:radial-gradient(ellipse at 50% 100%,rgba(83,74,183,.12) 0%,transparent 70%);animation:waveSlide 5s ease-in-out infinite reverse}@keyframes waveSlide{0%,to{transform:translate(0)}50%{transform:translate(20%)}}.gift-design-sunset{background:linear-gradient(135deg,#7c3aed,#ec4899 40%,#f97316)}.gift-design-sunset:before{content:"";position:absolute;top:30%;left:50%;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.2),transparent 70%);transform:translate(-50%);animation:sunsetPulse 3s ease-in-out infinite;pointer-events:none;z-index:1}@keyframes sunsetPulse{0%,to{transform:translate(-50%) scale(1);opacity:.6}50%{transform:translate(-50%) scale(1.3);opacity:1}}.gift-amounts-grid{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}.gift-amount-btn{padding:16px 28px;border-radius:14px;border:1.5px solid rgba(255,255,255,.12);background:#534ab70a;font-size:17px;font-weight:600;color:#4b5563;cursor:pointer;transition:all .25s ease;font-family:inherit;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.gift-amount-btn:hover{border-color:#534ab780;color:#fff;background:#534ab71f}.gift-amount-btn.selected{background:var(--gradient);border-color:#534ab7;color:#fff;box-shadow:0 0 24px #534ab766}.gift-custom-amount{display:flex;align-items:center;gap:10px;margin-top:4px}.gift-custom-amount input{width:160px;padding:14px 16px;border-radius:14px;border:1.5px solid rgba(255,255,255,.12);background:#534ab70a;color:#fff;font-size:16px;font-family:inherit;outline:none;transition:border-color .25s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.gift-custom-amount input::placeholder{color:#ffffff4d}.gift-custom-amount input:focus{border-color:#534ab7;box-shadow:0 0 16px #534ab733}.gift-custom-amount span{font-size:14px;color:#9ca3af}.gift-fields{display:flex;flex-direction:column;gap:20px}.gift-field{display:flex;flex-direction:column;gap:6px}.gift-field label{font-size:12px;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.1em}.gift-field input,.gift-field textarea{padding:14px 16px;border-radius:14px;border:1.5px solid rgba(83,74,183,.12);background:#534ab70a;color:#fff;font-size:15px;font-family:inherit;outline:none;transition:all .25s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.gift-field input::placeholder,.gift-field textarea::placeholder{color:#ffffff40}.gift-field input:focus,.gift-field textarea:focus{border-color:#534ab7;box-shadow:0 0 16px #534ab726}.gift-field textarea{min-height:120px;resize:vertical}.gift-field .gift-field-hint{font-size:12px;color:#ffffff4d}.gift-char-count{text-align:right;font-size:12px;color:#ffffff4d;margin-top:2px}.gift-char-count.over{color:#e53935}.gift-summary{display:flex;flex-direction:column;gap:20px}.gift-summary-card{background:#534ab70a;border:1px solid rgba(83,74,183,.1);border-radius:18px;padding:24px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.gift-summary-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.gift-summary-label{font-size:13px;color:#6b7280}.gift-summary-value{font-size:15px;font-weight:600;color:#fff}.gift-summary-total{font-size:28px;font-weight:800;color:#534ab7;letter-spacing:-.02em}.gift-security-badges{display:flex;gap:16px;justify-content:center;margin-top:8px}.gift-badge{display:flex;align-items:center;gap:6px;font-size:12px;color:#ffffff59}.gift-badge svg{width:14px;height:14px;opacity:.5}.gift-nav-buttons{display:flex;justify-content:space-between;align-items:center;margin-top:48px}.gift-btn-back{padding:14px 24px;border-radius:14px;border:1.5px solid rgba(83,74,183,.12);background:transparent;color:#6b7280;font-size:14px;font-weight:600;cursor:pointer;transition:all .25s;font-family:inherit}.gift-btn-back:hover{border-color:#ffffff40;color:#fff}.gift-btn-next{padding:16px 40px;border-radius:50px;border:none;background:var(--gradient);color:#fff;font-size:15px;font-weight:700;cursor:pointer;transition:all .25s;font-family:inherit;letter-spacing:.05em;text-transform:uppercase;box-shadow:0 8px 30px #534ab766}.gift-btn-next:hover:not(:disabled){background:#6358d4;box-shadow:0 12px 40px #534ab780;transform:translateY(-1px)}.gift-btn-next:active:not(:disabled){transform:translateY(0)}.gift-btn-next:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.gift-btn-pay{width:100%;padding:18px 40px;border-radius:50px;border:none;background:linear-gradient(135deg,#534ab7,#7b68ee);color:#fff;font-size:17px;font-weight:700;cursor:pointer;transition:all .25s;font-family:inherit;letter-spacing:.03em;box-shadow:0 8px 30px #534ab766;margin-top:24px}.gift-btn-pay:hover:not(:disabled){box-shadow:0 12px 40px #534ab780;transform:translateY(-1px)}.gift-btn-pay:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.gift-submit-error{color:#e53935;font-size:14px;margin-top:12px;text-align:center}@media (max-width: 768px){.gift-layout{flex-direction:column}.gift-sidebar{width:100%;height:auto;position:relative;padding:20px 16px;border-right:none;border-bottom:1px solid rgba(83,74,183,.08)}.gift-sidebar-logo{margin-bottom:16px}.gift-step-nav{flex-direction:row;gap:4px;overflow-x:auto;padding-bottom:4px}.gift-step-item{padding:8px 12px;white-space:nowrap;font-size:12px;gap:8px}.gift-step-num{width:26px;height:26px;font-size:11px}.gift-main{padding:28px 16px}.gift-step-number{font-size:40px}.gift-step-title{font-size:22px}.gift-design-main-card{width:100%;max-width:340px;height:200px}.gift-amounts-grid{gap:8px}.gift-amount-btn{padding:12px 18px;font-size:15px}.gift-nav-buttons{margin-top:32px}}.gift-editor{max-width:900px}.gift-presets-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media (max-width: 600px){.gift-presets-grid{grid-template-columns:repeat(2,1fr)}}.gift-preset-item{position:relative}.gift-preset-card{position:relative;aspect-ratio:16 / 10;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #00000014}.gift-preset-item label{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:13px;font-weight:500;color:#444;cursor:pointer}.gift-preset-item input[type=checkbox]{accent-color:#534AB7;width:16px;height:16px}.gift-custom-section{display:flex;gap:32px;flex-wrap:wrap;align-items:flex-start}.gift-custom-form{flex:1 1 320px;display:flex;flex-direction:column;gap:16px}.gift-custom-preview-wrap{flex:0 0 280px}.gift-color-row{display:flex;align-items:center;gap:10px}.gift-color-swatch{width:40px;height:40px;border-radius:8px;border:1.5px solid #d8d5e8;cursor:pointer;padding:2px}.gift-upload-area{border:2px dashed #d8d5e8;border-radius:12px;padding:24px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}.gift-upload-area:hover{border-color:#534ab7;background:#534ab708}.gift-upload-area p{margin:8px 0 0;font-size:13px;color:#666}.gift-cover-preview{width:100%;max-height:160px;object-fit:cover;border-radius:8px;margin-bottom:8px}.gift-settings-row{display:flex;align-items:center;gap:12px;margin-bottom:14px}.gift-settings-row label{font-size:14px;font-weight:500;color:#444;min-width:160px}.gift-settings-row select,.gift-settings-row input{padding:8px 12px;border-radius:8px;border:1.5px solid #d8d5e8;font-size:14px;font-family:inherit;outline:none}.gift-settings-row select:focus,.gift-settings-row input:focus{border-color:#534ab7}.gift-preview-card{position:relative;border-radius:16px;padding:24px;min-height:160px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;box-shadow:0 4px 24px #0000001f}.gift-preview-amount{font-size:32px;font-weight:800;margin:0}.gift-preview-message{font-size:14px;margin:8px 0 0;line-height:1.5;opacity:.9;word-break:break-word}.gift-preview-label{font-size:11px;text-transform:uppercase;letter-spacing:1px;opacity:.7}.gift-covers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.gift-cover-card{border:1px solid #e8e5f0;border-radius:12px;overflow:hidden;background:#fff}.gift-cover-img-wrap{position:relative;aspect-ratio:680 / 420;overflow:hidden}.gift-cover-img{width:100%;height:100%;object-fit:cover;display:block}.gift-cover-remove{position:absolute;top:6px;right:6px;width:24px;height:24px;border-radius:50%;border:none;background:#00000080;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.gift-cover-img-wrap:hover .gift-cover-remove{opacity:1}.gift-cover-name-input{width:100%;border:none;border-top:1px solid #e8e5f0;padding:8px 10px;font-size:13px;font-family:inherit;outline:none}.gift-cover-name-input:focus{background:#f5f3ff}.gift-cover-toggle{display:flex;align-items:center;gap:6px;padding:6px 10px;font-size:12px;color:#666;border-top:1px solid #f0edf5;cursor:pointer}.gift-cover-add{border:2px dashed #d0cde0;cursor:pointer;display:flex;align-items:center;justify-content:center;min-height:140px;transition:border-color .2s,background .2s}.gift-cover-add:hover{border-color:#534ab7;background:#f5f3ff}.gift-cover-add-inner{display:flex;flex-direction:column;align-items:center;gap:8px;color:#999;font-size:13px}.gift-cover-add:hover .gift-cover-add-inner{color:#534ab7}.gift-success{min-height:100vh;background:#f8f7fc;display:flex;align-items:center;justify-content:center;padding:24px;font-family:Inter,system-ui,sans-serif}.gift-success-card{background:#ffffff0d;border:1px solid rgba(83,74,183,.12);border-radius:24px;padding:40px 32px;text-align:center;max-width:440px;width:100%;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 20px 60px #0000004d}.gift-success-icon{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#534ab7,#7b68ee);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:28px}.gift-success-card h1{font-size:24px;font-weight:700;color:#fff;margin:0 0 8px}.gift-success-card p{font-size:15px;color:#6b7280;margin:0 0 24px;line-height:1.5}.gift-test-links{background:#534ab714;border:1px solid rgba(83,74,183,.2);border-radius:12px;padding:16px 20px;margin-bottom:24px}.gift-test-links h3{font-size:14px;font-weight:600;color:#534ab7;margin:0 0 10px}.gift-test-links a{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:#534ab7;text-decoration:none;margin-right:20px;font-weight:500}.gift-test-links a:hover{text-decoration:underline}.onboarding-page{max-width:640px;margin:0 auto;padding:2rem}.onboarding-title{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--ink);margin-bottom:4px}.onboarding-subtitle{font-size:14px;color:var(--muted);margin-bottom:24px}.onboarding-step-indicator{display:flex;align-items:center;justify-content:center;margin-bottom:32px}.onboarding-step-dot-group{display:flex;align-items:center}.onboarding-step-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;border:2px solid var(--muted);color:var(--muted);background:transparent;transition:all .2s}.onboarding-step-dot.active{background:var(--p500);border-color:var(--p500);color:#fff}.onboarding-step-line{width:48px;height:2px;background:var(--muted);margin:0 8px;transition:background .2s}.onboarding-step-line.active{background:var(--p500)}.onboarding-step{animation:onbFadeIn .25s ease}@keyframes onbFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.onboarding-field{margin-bottom:1.25rem}.onboarding-label{display:block;font-size:13px;font-weight:500;color:var(--ink2);margin-bottom:6px}.onboarding-input{width:100%;padding:12px 14px;background:var(--bg);border:1.5px solid var(--border-solid, #e0dce8);border-radius:10px;font-size:15px;font-family:var(--font-body);color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.onboarding-input:focus{border-color:var(--p500);box-shadow:0 0 0 3px #9b6dff1f}.onboarding-products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-bottom:24px}.product-select-card{border:2px solid var(--muted);border-radius:12px;padding:1.5rem;cursor:pointer;transition:border-color .2s,background .2s;position:relative}.product-select-card:hover{border-color:var(--p300)}.product-select-card.selected{border-color:var(--p500);background:#9b6dff0d}.product-select-header{display:flex;align-items:center;gap:10px;margin-bottom:8px;color:var(--ink)}.product-select-name{font-family:var(--font-display);font-size:16px;font-weight:600}.product-select-desc{font-size:13px;color:var(--muted);margin-bottom:8px}.product-trial-badge{display:inline-block;font-size:11px;font-weight:600;color:var(--p600);background:var(--p50);padding:3px 10px;border-radius:20px}.product-select-check{position:absolute;top:16px;right:16px}.product-select-check input[type=checkbox]{width:18px;height:18px;accent-color:var(--p500);cursor:pointer}.onboarding-btn{display:inline-flex;align-items:center;gap:6px;padding:12px 24px;border:none;border-radius:10px;font-family:var(--font-display);font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s,opacity .2s;min-height:44px}.onboarding-btn.primary{background:var(--gradient);color:#fff}.onboarding-btn.primary:hover{transform:translateY(-1px)}.onboarding-btn.secondary{background:var(--bg);color:var(--ink);border:1px solid var(--border-solid)}.onboarding-btn.secondary:hover{background:var(--p50)}.onboarding-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.onboarding-btn-row{display:flex;gap:12px;margin-top:8px}.onboarding-btn-sm{display:inline-flex;align-items:center;padding:6px 14px;border:1px solid var(--p500);border-radius:8px;background:none;font-family:var(--font-body);font-size:12px;font-weight:600;color:var(--p500);cursor:pointer;transition:background .15s}.onboarding-btn-sm:hover{background:var(--p50)}.onboarding-btn-sm:disabled{opacity:.55;cursor:not-allowed}.onboarding-summary{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.onboarding-summary-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg);border-radius:10px;border:1px solid var(--border-solid)}.onboarding-summary-info{display:flex;align-items:center;gap:10px;color:var(--ink)}.onboarding-summary-name{font-weight:600;font-size:14px}.onboarding-loading{display:flex;align-items:center;gap:10px;justify-content:center;padding:48px 0;color:var(--muted);font-size:14px}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.onboarding-error{background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:8px;padding:10px 14px;color:#dc2626;font-size:13px;line-height:1.4;margin-bottom:16px}.grace-banner{background:#fef3cd;border-left:4px solid #F0AD4E;padding:12px 16px;border-radius:8px;display:flex;gap:12px;align-items:flex-start;margin-bottom:16px}.grace-banner-icon{color:#856404;flex-shrink:0;margin-top:2px}.grace-banner-content strong{display:block;color:#856404;font-size:14px;margin-bottom:4px}.grace-banner-text{font-size:13px;color:#664d03;margin:0 0 6px;line-height:1.4}.grace-banner-link{font-size:13px;font-weight:600;color:#856404;text-decoration:underline}.grace-banner-link:hover{color:#664d03}@media (max-width: 640px){.onboarding-page{padding:1rem}.onboarding-products-grid{grid-template-columns:1fr}.onboarding-btn-row{flex-direction:column}}.billing-page{max-width:800px;margin:0 auto;padding:2rem}.billing-title{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--ink);margin-bottom:24px}.billing-skeleton{display:flex;flex-direction:column;gap:18px}.billing-skeleton-bar{height:48px;width:100%;background:var(--p100);border-radius:10px;animation:billingShimmer .5s ease-in-out infinite alternate}@keyframes billingShimmer{0%{opacity:.4}to{opacity:.8}}.billing-error{background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:8px;padding:10px 14px;color:#dc2626;font-size:13px;line-height:1.4}.billing-section{margin-bottom:2rem}.billing-section-title{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--ink);display:flex;align-items:center;gap:8px;margin-bottom:16px}.billing-empty{font-size:14px;color:var(--muted)}.billing-empty a{color:var(--p600);font-weight:600;text-decoration:none}.billing-empty a:hover{text-decoration:underline}.billing-sub-card{border:1px solid var(--border-solid);border-radius:12px;padding:1.5rem;margin-bottom:12px;background:var(--card)}.billing-sub-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.billing-sub-name{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:8px}.billing-plan-name{font-size:13px;font-weight:400;color:var(--muted)}.billing-status-badge{padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:600;white-space:nowrap}.billing-status-active{background:#d4edda;color:#155724}.billing-status-trial{background:#d1ecf1;color:#0c5460}.billing-status-grace{background:#fff3cd;color:#856404}.billing-status-expired{background:#f8d7da;color:#721c24}.billing-sub-details{display:flex;flex-wrap:wrap;align-items:center;gap:16px}.billing-sub-meta{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted)}.billing-sub-actions{display:flex;align-items:center;gap:16px;margin-left:auto}.billing-toggle-label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ink);cursor:pointer}.billing-toggle-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--p500);cursor:pointer}.billing-change-plan{font-size:13px;font-weight:600;color:var(--p600);text-decoration:none}.billing-change-plan:hover{text-decoration:underline}.billing-table-wrap{overflow-x:auto}.billing-history-table{width:100%;border-collapse:collapse}.billing-history-table th{text-align:left;padding:10px 12px;border-bottom:2px solid var(--border-solid);font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.billing-history-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border-solid);font-size:14px;color:var(--ink)}.billing-amount{font-weight:600;font-family:var(--font-display)}.billing-pay-badge{padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:600}.pay-status-ok{background:#d4edda;color:#155724}.pay-status-pending{background:#fff3cd;color:#856404}.pay-status-fail{background:#f8d7da;color:#721c24}@media (max-width: 640px){.billing-page{padding:1rem}.billing-sub-info{flex-direction:column;align-items:flex-start;gap:8px}.billing-sub-details{flex-direction:column;align-items:flex-start}.billing-sub-actions{margin-left:0}}.org-settings-page{max-width:800px;margin:0 auto;padding:2rem}.org-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}.org-settings-title{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--ink);display:flex;align-items:center;gap:10px;margin:0}.org-skeleton{display:flex;flex-direction:column;gap:18px}.org-skeleton-bar{height:48px;width:100%;background:var(--p100);border-radius:10px;animation:orgShimmer .5s ease-in-out infinite alternate}@keyframes orgShimmer{0%{opacity:.4}to{opacity:.8}}.org-form{display:flex;flex-direction:column;gap:0}.org-section{background:#fff;border-radius:14px;padding:24px;margin-bottom:20px;box-shadow:0 1px 6px #0000000a}.org-section-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--ink);margin:0 0 4px}.org-section-hint{font-size:13px;color:var(--muted);margin:0 0 16px}.org-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.org-grid:last-child{margin-bottom:0}.org-grid-3{grid-template-columns:1fr 1fr 1fr}.org-form-group{margin-bottom:0}.org-form-group label{display:block;margin-bottom:6px;font-size:13px;font-weight:600;color:var(--ink2)}.org-form-group input,.org-form-group select{width:100%;padding:10px 14px;background:#fff;border:1.5px solid var(--border-solid, #e0dce8);border-radius:10px;font-size:14px;font-family:var(--font-body);color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.org-form-group input:focus,.org-form-group select:focus{border-color:var(--p500);box-shadow:0 0 0 3px #9b6dff1f}.org-form-group input::placeholder{color:var(--muted2, #9ca3af)}.org-hint{display:block;font-size:11px;color:var(--muted, #9ca3af);margin-top:4px}.org-entity-types{display:flex;gap:6px;flex-wrap:wrap}.org-entity-btn{flex:0 0 auto;padding:9px 16px;border:1.5px solid var(--border-solid, #e0dce8);border-radius:10px;background:#fff;font-family:var(--font-body);font-size:13px;font-weight:600;color:var(--ink2);cursor:pointer;transition:all .15s;text-align:center;white-space:nowrap}.org-entity-btn:hover{border-color:var(--p400, #9B6DFF);color:var(--p600, #6c3ce7)}.org-entity-btn.active{background:var(--gradient);border-color:transparent;color:#fff}.org-error{background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:8px;padding:10px 14px;color:#dc2626;font-size:13px;line-height:1.4;margin-top:12px}.org-save-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 24px;background:var(--gradient);border:none;border-radius:10px;font-family:var(--font-body);font-size:14px;font-weight:700;color:#fff;cursor:pointer;transition:opacity .15s;min-height:42px}.org-save-btn:hover{opacity:.9}.org-save-btn:disabled{opacity:.5;cursor:not-allowed}.org-toast{position:fixed;bottom:24px;right:24px;background:#16a34a;color:#fff;padding:12px 20px;border-radius:10px;font-size:14px;font-weight:600;z-index:200;animation:orgToastIn .3s ease}@keyframes orgToastIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.org-settings-page{padding:1rem}.org-grid,.org-grid-3{grid-template-columns:1fr}.org-header{flex-direction:column;align-items:flex-start;gap:12px}}.integrations-page{max-width:900px;margin:0 auto;padding:2rem}.integrations-title{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--ink);margin-bottom:24px;display:flex;align-items:center;gap:10px}.intg-skeleton{display:flex;flex-direction:column;gap:18px}.intg-skeleton-bar{height:48px;width:100%;background:var(--p100);border-radius:10px;animation:intgShimmer .5s ease-in-out infinite alternate}@keyframes intgShimmer{0%{opacity:.4}to{opacity:.8}}.intg-error{background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:8px;padding:10px 14px;color:#dc2626;font-size:13px;line-height:1.4}.intg-section{margin-bottom:2rem}.intg-section-title{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--ink);display:flex;align-items:center;gap:8px;margin-bottom:16px}.intg-key-card{border:1px solid var(--border-solid);border-radius:12px;padding:1.5rem;background:var(--card)}.intg-key-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.intg-key-value{font-family:monospace;font-size:14px;color:var(--ink);background:var(--p50, #f5f3ff);padding:6px 12px;border-radius:6px;-webkit-user-select:all;user-select:all}.intg-key-empty{font-size:14px;color:var(--muted);margin-bottom:12px}.intg-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;border:none;cursor:pointer;transition:opacity .15s}.intg-btn:disabled{opacity:.5;cursor:not-allowed}.intg-btn-primary{background:var(--gradient);color:#fff}.intg-btn-primary:hover:not(:disabled){opacity:.9}.intg-btn-danger{background:#ef44441a;color:#dc2626}.intg-btn-danger:hover:not(:disabled){background:#ef44442e}.intg-btn-secondary{background:var(--p100, #ede9fe);color:#534ab7}.intg-btn-secondary:hover:not(:disabled){background:var(--p200, #ddd6fe)}.intg-webhooks-table-wrap{overflow-x:auto;margin-bottom:16px}.intg-webhooks-table{width:100%;border-collapse:collapse}.intg-webhooks-table th{text-align:left;padding:10px 12px;border-bottom:2px solid var(--border-solid);font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.intg-webhooks-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border-solid);font-size:14px;color:var(--ink)}.intg-wh-url{font-family:monospace;font-size:13px;word-break:break-all}.intg-wh-events{display:flex;flex-wrap:wrap;gap:4px}.intg-wh-event-tag{padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;background:var(--p100, #ede9fe);color:#534ab7}.intg-wh-status-active{color:#16a34a;font-weight:600;font-size:13px}.intg-wh-status-inactive{color:var(--muted);font-weight:600;font-size:13px}.intg-empty{font-size:14px;color:var(--muted);margin-bottom:12px}.intg-wh-form{border:1px solid var(--border-solid);border-radius:12px;padding:1.25rem;background:var(--card);margin-top:12px}.intg-wh-form-title{font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--ink);margin-bottom:12px}.intg-form-group{margin-bottom:12px}.intg-form-group label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:4px}.intg-form-group input[type=text],.intg-form-group input[type=url]{width:100%;padding:8px 12px;border:1px solid var(--border-solid);border-radius:8px;font-size:14px;color:var(--ink);background:var(--bg, #fff);box-sizing:border-box}.intg-form-group input:focus{outline:none;border-color:#534ab7;box-shadow:0 0 0 2px #534ab726}.intg-checkbox-grid{display:flex;flex-wrap:wrap;gap:8px 16px}.intg-checkbox-label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ink);cursor:pointer}.intg-checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:#534AB7;cursor:pointer}.intg-wh-form-actions{display:flex;gap:8px;margin-top:12px}.intg-connectors-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.intg-connector-card{border:1px solid var(--border-solid);border-radius:12px;padding:1.5rem;background:var(--card)}.intg-connector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.intg-connector-name{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--ink)}.intg-status-badge{padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:600;white-space:nowrap}.intg-status-active{background:#d4edda;color:#155724}.intg-status-inactive{background:#e5e7eb;color:#6b7280}.intg-connector-body{display:flex;flex-direction:column;gap:12px}.intg-connector-input-row{display:flex;gap:8px}.intg-connector-input-row input{flex:1;padding:8px 12px;border:1px solid var(--border-solid);border-radius:8px;font-size:14px;color:var(--ink);background:var(--bg, #fff)}.intg-connector-input-row input:focus{outline:none;border-color:#534ab7;box-shadow:0 0 0 2px #534ab726}.intg-connector-meta{font-size:12px;color:var(--muted)}.intg-toast{position:fixed;bottom:24px;right:24px;background:var(--gradient);color:#fff;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;box-shadow:0 4px 12px #00000026;z-index:1000;animation:intgToastIn .3s ease}@keyframes intgToastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 640px){.integrations-page{padding:1rem}.intg-key-row{flex-direction:column;align-items:flex-start}.intg-connectors-grid{grid-template-columns:1fr}.intg-connector-input-row{flex-direction:column}}.apilog-page{max-width:1100px;margin:0 auto;padding:2rem}.apilog-title{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--ink);margin-bottom:24px;display:flex;align-items:center;gap:10px}.apilog-skeleton{display:flex;flex-direction:column;gap:18px}.apilog-skeleton-bar{height:48px;width:100%;background:var(--p100);border-radius:10px;animation:apilogShimmer .5s ease-in-out infinite alternate}@keyframes apilogShimmer{0%{opacity:.4}to{opacity:.8}}.apilog-error{background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:8px;padding:10px 14px;color:#dc2626;font-size:13px;line-height:1.4}.apilog-filters{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;margin-bottom:20px;padding:16px;border:1px solid var(--border-solid);border-radius:12px;background:var(--card)}.apilog-filter-group{display:flex;flex-direction:column;gap:4px}.apilog-filter-group label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.apilog-filter-group select,.apilog-filter-group input[type=date]{padding:7px 10px;border:1px solid var(--border-solid);border-radius:8px;font-size:13px;color:var(--ink);background:var(--bg, #fff);min-width:130px}.apilog-filter-group select:focus,.apilog-filter-group input:focus{outline:none;border-color:#534ab7;box-shadow:0 0 0 2px #534ab726}.apilog-filter-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;border:none;cursor:pointer;background:var(--gradient);color:#fff;transition:opacity .15s}.apilog-filter-btn:hover{opacity:.9}.apilog-auto-refresh{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ink);cursor:pointer;margin-left:auto}.apilog-auto-refresh input[type=checkbox]{width:16px;height:16px;accent-color:#534AB7;cursor:pointer}.apilog-table-wrap{overflow-x:auto}.apilog-table{width:100%;border-collapse:collapse}.apilog-table th{text-align:left;padding:10px 12px;border-bottom:2px solid var(--border-solid);font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.apilog-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border-solid);font-size:14px;color:var(--ink);white-space:nowrap}.apilog-table tbody tr{cursor:pointer;transition:background .1s}.apilog-table tbody tr:hover{background:var(--p50, #f5f3ff)}.apilog-time{font-size:13px;color:var(--muted)}.apilog-path{font-family:monospace;font-size:13px;max-width:280px;overflow:hidden;text-overflow:ellipsis}.apilog-duration{font-family:monospace;font-size:13px}.apilog-source-badge{padding:2px 10px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.apilog-src-rest_api{background:#dbeafe;color:#1e40af}.apilog-src-webhook_out{background:#ede9fe;color:#6d28d9}.apilog-src-webhook_in_evotor{background:#ffedd5;color:#c2410c}.apilog-src-webhook_in_moysklad{background:#dcfce7;color:#166534}.apilog-src-1c{background:#e5e7eb;color:#374151}.apilog-status-badge{padding:2px 10px;border-radius:12px;font-size:12px;font-weight:700;white-space:nowrap}.apilog-status-2xx{background:#d4edda;color:#155724}.apilog-status-4xx{background:#fff3cd;color:#856404}.apilog-status-5xx{background:#f8d7da;color:#721c24}.apilog-status-none{background:#e5e7eb;color:#6b7280}.apilog-empty{text-align:center;padding:40px 20px;color:var(--muted);font-size:14px}.apilog-pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:20px;flex-wrap:wrap}.apilog-page-btn{padding:6px 12px;border:1px solid var(--border-solid);border-radius:6px;background:var(--card);color:var(--ink);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.apilog-page-btn:hover:not(:disabled){border-color:#534ab7;color:#534ab7}.apilog-page-btn:disabled{opacity:.4;cursor:not-allowed}.apilog-page-btn.active{background:var(--gradient);color:#fff;border-color:#534ab7}.apilog-page-info{font-size:13px;color:var(--muted);margin-left:12px}.apilog-detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:999;animation:apilogFadeIn .15s ease}@keyframes apilogFadeIn{0%{opacity:0}to{opacity:1}}.apilog-detail-panel{position:fixed;top:0;right:0;bottom:0;width:560px;max-width:100vw;background:var(--card, #fff);box-shadow:-4px 0 20px #00000026;z-index:1000;overflow-y:auto;padding:1.5rem;animation:apilogSlideIn .2s ease}@keyframes apilogSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.apilog-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.apilog-detail-title{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--ink)}.apilog-detail-close{background:none;border:none;cursor:pointer;color:var(--muted);padding:4px}.apilog-detail-close:hover{color:var(--ink)}.apilog-detail-meta{display:grid;grid-template-columns:auto 1fr;gap:8px 16px;margin-bottom:20px;font-size:14px}.apilog-detail-label{font-weight:600;color:var(--muted)}.apilog-detail-value{color:var(--ink);word-break:break-all}.apilog-detail-section{margin-bottom:16px}.apilog-detail-section-title{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--ink);margin-bottom:8px}.apilog-detail-body{background:#1e1e2e;color:#cdd6f4;padding:12px;border-radius:8px;font-family:monospace;font-size:12px;line-height:1.5;max-height:300px;overflow:auto;white-space:pre-wrap;word-break:break-all}.apilog-detail-error{background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:8px;padding:10px;color:#dc2626;font-size:13px}@media (max-width: 640px){.apilog-page{padding:1rem}.apilog-filters{flex-direction:column;align-items:stretch}.apilog-auto-refresh{margin-left:0}.apilog-detail-panel{width:100vw}.apilog-table td,.apilog-table th{padding:8px 6px;font-size:12px}}.fit-section-heading{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--ink);margin:24px 0 12px}.fit-pending-section{margin-top:8px}.fit-checkin-search{position:relative;margin-bottom:20px;max-width:600px}.fit-checkin-search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}.fit-checkin-search-input{width:100%;padding:16px 16px 16px 48px;background:var(--bg);border:2px solid transparent;border-radius:14px;font-family:var(--font-body);font-size:16px;color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.fit-checkin-search-input:focus{border-color:#534ab7;box-shadow:0 0 0 4px #534ab71f}.fit-checkin-results{display:flex;flex-direction:column;gap:8px;max-width:600px}.fit-checkin-searching,.fit-checkin-empty{text-align:center;padding:20px;color:var(--muted);font-size:14px}.fit-checkin-member-card{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);cursor:pointer;transition:background .12s,border-color .12s;text-align:left;font-family:var(--font-body);width:100%}.fit-checkin-member-card:hover{background:var(--p50);border-color:var(--p300)}.fit-checkin-member-avatar{width:40px;height:40px;border-radius:50%;background:#534ab71a;color:#534ab7;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0}.fit-checkin-avatar-lg{width:52px;height:52px;font-size:20px}.fit-checkin-member-info{flex:1;min-width:0}.fit-checkin-member-name{font-size:14px;font-weight:700;color:var(--ink)}.fit-checkin-member-phone{font-size:13px;color:var(--muted)}.fit-status-badge{display:inline-block;font-size:12px;font-weight:700;border-radius:6px;padding:2px 8px;white-space:nowrap}.fit-status-active{color:#22c55e;background:#22c55e1a}.fit-status-expired{color:#ef4444;background:#ef44441a}.fit-status-frozen{color:#3b82f6;background:#3b82f61a}.fit-status-cancelled,.fit-status-pending{color:#6b7280;background:#6b72801a}.fit-checkin-detail{max-width:600px}.fit-checkin-detail-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.fit-checkin-detail-name{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--ink);margin:0}.fit-checkin-detail-phone{font-size:13px;color:var(--muted);margin:2px 0 0}.fit-checkin-no-membership{display:flex;align-items:center;gap:12px;padding:20px;background:#ef44440f;border:1px solid rgba(239,68,68,.15);border-radius:var(--radius-lg);color:#ef4444;font-size:14px;font-weight:600;margin-top:16px}.fit-checkin-membership-card{background:var(--card);border:2px solid rgba(83,74,183,.2);border-radius:var(--radius-lg);padding:20px 24px;margin-top:16px}.fit-checkin-plan-name{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--ink);margin-bottom:8px}.fit-checkin-plan-meta{display:flex;align-items:center;gap:16px;font-size:14px;color:var(--ink2);margin-bottom:16px;flex-wrap:wrap}.fit-checkin-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px;background:var(--gradient);border:none;border-radius:12px;font-family:var(--font-body);font-size:16px;font-weight:700;color:#fff;cursor:pointer;box-shadow:0 6px 24px #534ab759;transition:transform .15s,box-shadow .15s}.fit-checkin-btn:hover{transform:translateY(-1px);box-shadow:0 10px 32px #534ab773}.fit-checkin-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.fit-checkin-success{text-align:center;padding:48px 24px;max-width:400px;margin:0 auto;color:#22c55e}.fit-checkin-success h2{font-family:var(--font-display);font-size:24px;font-weight:700;margin:16px 0 8px;color:var(--ink)}.fit-checkin-name{font-size:16px;color:var(--ink2);margin:0 0 8px}.fit-checkin-visits{font-size:14px;color:var(--muted);margin:0}.fit-checkin-expired-note{font-size:13px;color:#ef4444;margin:8px 0 0}.fit-members-search{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.fit-members-search-wrap{position:relative;flex:1;min-width:200px}.fit-members-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}.fit-members-search-input{width:100%;padding:10px 12px 10px 36px;background:var(--bg);border:1.5px solid var(--border-solid, #e0dce8);border-radius:10px;font-family:var(--font-body);font-size:14px;color:var(--ink);outline:none;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.fit-members-search-input:focus{border-color:#534ab7;box-shadow:0 0 0 3px #534ab71f}.fit-member-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.fit-member-avatar{width:56px;height:56px;border-radius:50%;background:#534ab71a;color:#534ab7;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:22px;flex-shrink:0}.fit-member-header-info h2{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--ink);margin:0}.fit-member-header-contacts{font-size:13px;color:var(--muted);margin-top:4px;display:flex;gap:16px}.fit-member-actions{display:flex;gap:10px;margin-bottom:24px;flex-wrap:wrap}.fit-membership-card{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);padding:16px 20px;margin-bottom:16px}.fit-membership-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.fit-membership-plan-name{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--ink)}.fit-membership-meta{display:flex;gap:16px;font-size:13px;color:var(--ink2);flex-wrap:wrap}.fit-plans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-bottom:24px}.fit-plan-card{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);padding:20px;position:relative;transition:box-shadow .15s}.fit-plan-card:hover{box-shadow:var(--shadow-sm)}.fit-plan-color-bar{width:4px;height:32px;border-radius:2px;position:absolute;top:20px;left:0}.fit-plan-name{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--ink);margin-bottom:4px;padding-left:8px}.fit-plan-type-badge{display:inline-block;font-size:11px;font-weight:700;border-radius:4px;padding:2px 6px;margin-left:8px;margin-bottom:12px;text-transform:uppercase;letter-spacing:.05em}.fit-plan-type-visits{color:#534ab7;background:#534ab71a}.fit-plan-type-period{color:#f59e0b;background:#f59e0b1a}.fit-plan-type-unlimited{color:#22c55e;background:#22c55e1a}.fit-plan-details{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--ink2);margin-bottom:12px;padding-left:8px}.fit-plan-price{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--ink);padding-left:8px;margin-bottom:12px}.fit-plan-actions{display:flex;gap:8px;padding-left:8px}.fit-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.fit-modal{background:var(--card, #fff);border-radius:var(--radius-xl, 16px);padding:24px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 16px 48px #0003}.fit-modal h3{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--ink);margin:0 0 20px}.fit-modal-actions{display:flex;gap:12px;margin-top:20px;justify-content:flex-end}@media (max-width: 768px){.fit-checkin-search-input{font-size:16px;padding:14px 14px 14px 44px}.fit-checkin-btn{font-size:15px;padding:14px}.fit-plans-grid{grid-template-columns:1fr}.fit-member-header,.fit-checkin-detail-header{flex-wrap:wrap}}.booking-public-url{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}.booking-setup-card{display:flex;flex-direction:column;gap:8px;background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);padding:20px;text-decoration:none;transition:border-color .15s,box-shadow .15s;cursor:pointer}.booking-setup-card:hover{border-color:#534ab7;box-shadow:0 4px 16px #534ab71f}.booking-setup-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center}.booking-setup-label{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--ink)}.booking-setup-hint{font-size:13px;color:var(--muted)}.booking-setup-status{font-size:12px;font-weight:700}.booking-profile-form{max-width:900px}.booking-profile-grid{display:grid;grid-template-columns:1fr 280px;gap:32px;align-items:start}.booking-profile-left{display:flex;flex-direction:column;gap:18px}.booking-profile-right{display:flex;flex-direction:column;gap:24px}.booking-contacts-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.booking-hours-list{display:flex;flex-direction:column;gap:8px;max-width:600px}.booking-hours-row{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--bg);border-radius:10px}.booking-hours-day{display:flex;align-items:center;gap:10px;min-width:180px}.booking-hours-times{display:flex;align-items:center;gap:8px}.booking-time-input{width:120px!important;padding:8px 10px!important}.booking-services-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}.booking-category-group{margin-bottom:24px}.booking-category-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-solid)}.booking-category-name{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--ink)}.booking-service-card{display:flex;align-items:center;gap:16px;padding:14px 16px;background:var(--card);border:1px solid var(--border-solid);border-radius:10px;margin-bottom:8px;transition:border-color .15s}.booking-service-card:hover{border-color:#534ab7}.booking-service-info{flex:1;min-width:0}.booking-service-name{font-weight:700;font-size:14px;color:var(--ink)}.booking-service-meta{font-size:13px;color:var(--muted);margin-top:2px}.booking-service-price{font-family:var(--font-display);font-size:16px;font-weight:700;color:#534ab7;white-space:nowrap}.booking-service-actions{display:flex;gap:6px}.booking-btn-icon{width:32px;height:32px;border-radius:8px;border:1px solid var(--border-solid);background:var(--card);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s,background .15s}.booking-btn-icon:hover{color:#534ab7;border-color:#534ab7;background:#534ab70d}.booking-btn-icon.danger:hover{color:#ef4444;border-color:#ef4444;background:#ef44440d}.booking-staff-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.booking-staff-card{background:var(--card);border:1px solid var(--border-solid);border-radius:var(--radius-lg);padding:20px;text-align:center;cursor:pointer;transition:border-color .15s,box-shadow .15s}.booking-staff-card:hover{border-color:#534ab7;box-shadow:0 4px 16px #534ab71f}.booking-staff-photo{width:64px;height:64px;border-radius:50%;object-fit:cover;margin:0 auto 12px;display:block;background:var(--p100);color:#534ab7}.booking-staff-avatar{width:64px;height:64px;border-radius:50%;background:#534ab71a;color:#534ab7;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:24px;font-weight:700}.booking-staff-name{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--ink);margin-bottom:4px}.booking-staff-spec{font-size:13px;color:var(--muted);margin-bottom:8px}.booking-schedule-staff-select{margin-bottom:24px}.booking-schedule-grid{display:flex;flex-direction:column;gap:8px;max-width:700px}.booking-schedule-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg);border-radius:10px}.booking-schedule-day{min-width:100px;font-size:14px;font-weight:600;color:var(--ink)}.booking-schedule-times{display:flex;align-items:center;gap:6px;flex:1;flex-wrap:wrap}.booking-schedule-label{font-size:12px;color:var(--muted);min-width:48px}.booking-exceptions-list{display:flex;flex-direction:column;gap:6px;margin-top:16px;max-width:500px}.booking-exception-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px;background:var(--card);border:1px solid var(--border-solid);border-radius:8px;font-size:14px}.booking-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:900;display:flex;align-items:center;justify-content:center;padding:24px}.booking-modal{background:var(--card, #fff);border-radius:16px;padding:28px;width:100%;max-width:520px;max-height:85vh;overflow-y:auto;box-shadow:0 16px 48px #0003}.booking-modal h2{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--ink);margin:0 0 20px}.booking-modal-actions{display:flex;gap:12px;margin-top:20px}.booking-add-category-row{display:flex;gap:8px;align-items:center;margin-bottom:16px}.booking-add-category-row input{flex:1;max-width:250px}.booking-btn-sm{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;min-height:28px;background:transparent;border:1px solid var(--border-solid);border-radius:6px;font-family:var(--font-body);font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;transition:color .15s,border-color .15s}.booking-btn-sm:hover{color:#534ab7;border-color:#534ab7}@media (max-width: 768px){.booking-profile-grid,.booking-contacts-grid{grid-template-columns:1fr}.booking-contacts-grid .loyalty-field[style*=grid-column]{grid-column:auto}.booking-hours-row{flex-wrap:wrap}.booking-hours-day{min-width:0;flex:1}.booking-schedule-row{flex-wrap:wrap}.booking-staff-grid{grid-template-columns:1fr 1fr}}@media (max-width: 480px){.booking-staff-grid{grid-template-columns:1fr}}.bw-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}.bw-modal{position:relative;background:#fff;border-radius:20px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000040;padding:28px 24px}.bw-close{position:absolute;top:16px;right:16px;background:none;border:none;cursor:pointer;color:#888;padding:4px;border-radius:8px;transition:color .15s,background .15s}.bw-close:hover{color:#333;background:#0000000f}.bw-steps{display:flex;justify-content:center;gap:24px;margin-bottom:24px}.bw-step-dot{display:flex;flex-direction:column;align-items:center;gap:6px}.bw-dot{width:10px;height:10px;border-radius:50%;background:#ddd;transition:background .2s,transform .2s}.bw-step-dot.active .bw-dot{background:var(--gradient);transform:scale(1.3)}.bw-step-dot.done .bw-dot{background:#22c55e}.bw-step-label{font-size:11px;color:#999;font-weight:500}.bw-step-dot.active .bw-step-label{color:#534ab7;font-weight:700}.bw-step-dot.done .bw-step-label{color:#22c55e}.bw-step-content{min-height:200px}.bw-title{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:20px;font-weight:700;color:#1a1a2e;margin:0 0 20px}.bw-subtitle{font-size:14px;font-weight:600;color:#1a1a2e;margin:16px 0 10px}.bw-loading{text-align:center;padding:32px 0;color:#888;font-size:14px}.bw-no-data{text-align:center;padding:20px;color:#999;font-size:14px}.bw-service-confirm{background:#f8f7ff;border-radius:14px;padding:20px;border:1px solid rgba(83,74,183,.12)}.bw-service-name{font-size:18px;font-weight:700;color:#1a1a2e;margin-bottom:8px}.bw-service-details{display:flex;gap:16px;align-items:center;font-size:14px;color:#666}.bw-service-price{font-weight:700;color:#534ab7}.bw-service-desc{margin-top:10px;font-size:13px;color:#777;line-height:1.4}.bw-staff-list{display:flex;flex-direction:column;gap:8px}.bw-staff-card{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:12px;border:2px solid #eee;cursor:pointer;transition:border-color .15s,background .15s}.bw-staff-card:hover{border-color:#534ab7;background:#f8f7ff}.bw-staff-card.selected{border-color:#534ab7;background:#f0eeff}.bw-staff-photo{width:48px;height:48px;border-radius:50%;object-fit:cover;flex-shrink:0}.bw-staff-avatar,.bw-staff-avatar-any{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0}.bw-staff-avatar{background:#534ab71a;color:#534ab7}.bw-staff-avatar-any{background:#22c55e1a;color:#22c55e}.bw-staff-info{min-width:0}.bw-staff-name{font-weight:600;font-size:15px;color:#1a1a2e}.bw-staff-spec{font-size:13px;color:#888;margin-top:2px}.bw-dates-scroll{display:flex;gap:8px;overflow-x:auto;padding:4px 0 12px;-webkit-overflow-scrolling:touch}.bw-dates-scroll::-webkit-scrollbar{height:4px}.bw-dates-scroll::-webkit-scrollbar-track{background:transparent}.bw-dates-scroll::-webkit-scrollbar-thumb{background:#ddd;border-radius:4px}.bw-date-pill{flex-shrink:0;padding:8px 14px;border-radius:20px;border:2px solid #eee;background:#fff;font-size:13px;font-weight:600;color:#333;cursor:pointer;transition:border-color .15s,background .15s,color .15s;white-space:nowrap}.bw-date-pill:hover:not(:disabled){border-color:#534ab7;background:#f8f7ff}.bw-date-pill.selected{border-color:#534ab7;background:var(--gradient);color:#fff}.bw-date-pill.unavailable{opacity:.4;cursor:not-allowed}.bw-slots-section{margin-top:8px}.bw-slots-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.bw-slot{padding:10px 8px;border-radius:10px;border:2px solid #eee;background:#fff;font-size:14px;font-weight:600;color:#333;cursor:pointer;text-align:center;transition:border-color .15s,background .15s,color .15s}.bw-slot:hover{border-color:#534ab7;background:#f8f7ff}.bw-slot.selected{border-color:#534ab7;background:var(--gradient);color:#fff}.bw-form{display:flex;flex-direction:column;gap:16px}.bw-field{display:flex;flex-direction:column;gap:4px}.bw-label{font-size:13px;font-weight:600;color:#555}.bw-input{padding:10px 14px;border-radius:10px;border:1px solid #ddd;font-size:15px;font-family:inherit;transition:border-color .15s;outline:none}.bw-input:focus{border-color:#534ab7;box-shadow:0 0 0 3px #534ab71a}.bw-summary{background:#f8f7ff;border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:8px;border:1px solid rgba(83,74,183,.1)}.bw-summary-row{display:flex;justify-content:space-between;font-size:14px}.bw-summary-row span:first-child{color:#888}.bw-summary-row span:last-child{font-weight:600;color:#1a1a2e}.bw-price-highlight{color:#534ab7!important}.bw-confirmation{text-align:center;padding:16px 0}.bw-success-title{color:#22c55e!important;margin-top:12px!important}.bw-confirm-note{font-size:13px;color:#888;margin:16px 0 20px}.bw-error{background:#fef2f2;color:#dc2626;padding:10px 14px;border-radius:10px;font-size:13px;margin-top:12px;text-align:center}.bw-nav{display:flex;justify-content:space-between;align-items:center;margin-top:24px;gap:12px}.bw-btn{padding:10px 24px;border-radius:10px;font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;border:none;transition:background .15s,opacity .15s;display:inline-flex;align-items:center;gap:8px}.bw-btn-primary{background:var(--gradient);color:#fff}.bw-btn-primary:hover:not(:disabled){background:#453da0}.bw-btn-primary:disabled{opacity:.5;cursor:not-allowed}.bw-btn-back{background:transparent;color:#666;padding:10px 16px}.bw-btn-back:hover{color:#333;background:#0000000a}@media (max-width: 520px){.bw-modal{max-width:100%;border-radius:16px 16px 0 0;max-height:95vh;margin-top:auto;padding:24px 18px}.bw-overlay{align-items:flex-end;padding:0}.bw-slots-grid{grid-template-columns:repeat(3,1fr)}.bw-steps{gap:16px}}.pb-page{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#fff;color:#1a1a2e;min-height:100vh;line-height:1.5}.pb-page *,.pb-page *:before,.pb-page *:after{box-sizing:border-box}.pb-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:16px}.pb-spinner{width:40px;height:40px;border:3px solid #eee;border-top-color:#534ab7;border-radius:50%;animation:pb-spin .7s linear infinite}@keyframes pb-spin{to{transform:rotate(360deg)}}.pb-loading-text{font-size:15px;color:#666}.pb-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:32px}.pb-not-found-code{font-size:72px;font-weight:800;color:#534ab7;opacity:.3;line-height:1;margin-bottom:12px}.pb-not-found h2{font-size:22px;font-weight:700;margin:0 0 8px}.pb-not-found p{color:#666;font-size:15px;margin:0}.pb-hero{position:relative;width:100%;height:280px;overflow:hidden}.pb-hero-cover{width:100%;height:100%;object-fit:cover;display:block}.pb-hero-gradient{width:100%;height:100%;background:linear-gradient(135deg,#534ab7,#7b6fdb,#a49bef)}.pb-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,0,0,.5) 0%,transparent 60%)}.pb-hero-info{position:relative;max-width:800px;margin:-60px auto 0;padding:0 20px;display:flex;align-items:flex-end;gap:20px}.pb-logo{width:96px;height:96px;border-radius:50%;border:4px solid #fff;background:var(--gradient);color:#fff;font-size:36px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;box-shadow:0 4px 16px #00000026}.pb-logo img{width:100%;height:100%;object-fit:cover}.pb-hero-text{padding-bottom:8px;min-width:0}.pb-title{font-size:26px;font-weight:800;color:#1a1a2e;margin:0 0 6px;line-height:1.2}.pb-category-badge{display:inline-block;background:#eeedfe;color:#534ab7;font-size:13px;font-weight:600;padding:4px 12px;border-radius:20px;margin-right:8px}.pb-address{display:flex;align-items:center;gap:6px;font-size:14px;color:#666;margin-top:6px}.pb-address svg{flex-shrink:0;color:#534ab7}.pb-content{max-width:800px;margin:0 auto;padding:32px 20px 60px}.pb-section{margin-bottom:40px}.pb-section-title{font-size:20px;font-weight:700;color:#1a1a2e;margin:0 0 20px;display:flex;align-items:center;gap:10px}.pb-section-title svg{color:#534ab7}.pb-description{font-size:15px;color:#444;line-height:1.7;margin-bottom:24px;white-space:pre-line}.pb-hours{display:flex;flex-direction:column;gap:6px;margin-bottom:24px}.pb-hours-row{display:flex;align-items:center;gap:12px;padding:8px 14px;background:#f8f8fc;border-radius:10px;font-size:14px}.pb-hours-day{font-weight:600;min-width:90px;color:#1a1a2e}.pb-hours-time{color:#666}.pb-hours-closed{color:#999;font-style:italic}.pb-contacts{display:flex;flex-wrap:wrap;gap:12px}.pb-contact-item{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:#f8f8fc;border-radius:10px;font-size:14px;color:#1a1a2e;text-decoration:none;transition:background .15s,color .15s}.pb-contact-item:hover{background:#eeedfe;color:#534ab7}.pb-contact-item svg{color:#534ab7;flex-shrink:0}.pb-services-group{margin-bottom:24px}.pb-services-group-title{font-size:16px;font-weight:700;color:#1a1a2e;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid #eee}.pb-service-card{display:flex;align-items:center;gap:16px;padding:14px 16px;background:#fff;border:1px solid #eee;border-radius:12px;margin-bottom:8px;transition:border-color .15s,box-shadow .15s}.pb-service-card:hover{border-color:#d4d0f0;box-shadow:0 2px 8px #534ab70f}.pb-service-info{flex:1;min-width:0}.pb-service-name{font-size:15px;font-weight:600;color:#1a1a2e}.pb-service-meta{font-size:13px;color:#666;margin-top:2px}.pb-service-right{display:flex;align-items:center;gap:16px;flex-shrink:0}.pb-service-price{font-size:16px;font-weight:700;color:#1a1a2e;white-space:nowrap}.pb-book-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;background:var(--gradient);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:not-allowed;opacity:.5;white-space:nowrap;position:relative}.pb-book-btn:hover:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#1a1a2e;color:#fff;font-size:12px;padding:4px 10px;border-radius:6px;white-space:nowrap;margin-bottom:6px;pointer-events:none}.pb-staff-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.pb-staff-card{background:#fff;border:1px solid #eee;border-radius:14px;padding:24px 16px;text-align:center;transition:border-color .15s,box-shadow .15s}.pb-staff-card:hover{border-color:#d4d0f0;box-shadow:0 4px 16px #534ab714}.pb-staff-photo{width:80px;height:80px;border-radius:50%;object-fit:cover;margin:0 auto 14px;display:block;background:#f0eefc}.pb-staff-avatar{width:80px;height:80px;border-radius:50%;background:#eeedfe;color:#534ab7;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:28px;font-weight:700}.pb-staff-name{font-size:15px;font-weight:700;color:#1a1a2e;margin-bottom:4px}.pb-staff-spec{font-size:13px;color:#666}.pb-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.pb-gallery-item{aspect-ratio:1;border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .15s}.pb-gallery-item:hover{transform:scale(1.02)}.pb-gallery-item img{width:100%;height:100%;object-fit:cover;display:block}.pb-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;cursor:pointer}.pb-lightbox img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:8px}.pb-lightbox-close{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:50%;background:#ffffff26;border:none;color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}.pb-footer{text-align:center;padding:24px 20px;border-top:1px solid #f0f0f0;color:#999;font-size:13px}.pb-footer a{color:#534ab7;text-decoration:none;font-weight:600}.pb-footer a:hover{text-decoration:underline}@media (max-width: 600px){.pb-hero{height:200px}.pb-hero-info{margin-top:-48px;gap:14px}.pb-logo{width:72px;height:72px;font-size:28px}.pb-title{font-size:20px}.pb-content{padding:24px 16px 48px}.pb-service-card{flex-direction:column;align-items:flex-start;gap:10px}.pb-service-right{width:100%;justify-content:space-between}.pb-gallery-grid{grid-template-columns:repeat(2,1fr)}.pb-staff-grid{grid-template-columns:repeat(2,1fr);gap:10px}.pb-staff-card{padding:16px 12px}.pb-staff-photo,.pb-staff-avatar{width:64px;height:64px;font-size:24px}.pb-contacts{flex-direction:column}}.bc-page{padding:0}.bc-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.bc-nav-group{display:flex;align-items:center;gap:8px}.bc-nav-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--border-solid, #e2e2e2);background:var(--card, #fff);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted, #888);transition:color .15s,border-color .15s}.bc-nav-btn:hover{color:#534ab7;border-color:#534ab7}.bc-today-btn{padding:6px 14px;border-radius:8px;border:1px solid var(--border-solid, #e2e2e2);background:var(--card, #fff);font-size:13px;font-weight:600;color:var(--ink, #1a1a2e);cursor:pointer;transition:border-color .15s,background .15s}.bc-today-btn:hover{border-color:#534ab7;background:#534ab70a}.bc-date-title{font-family:var(--font-display, -apple-system, sans-serif);font-size:16px;font-weight:700;color:var(--ink, #1a1a2e);margin-left:8px}.bc-controls{display:flex;align-items:center;gap:12px}.bc-select{padding:6px 12px;border-radius:8px;border:1px solid var(--border-solid, #e2e2e2);background:var(--card, #fff);font-size:13px;color:var(--ink, #1a1a2e);cursor:pointer;outline:none}.bc-select:focus{border-color:#534ab7}.bc-view-toggle{display:flex;border-radius:8px;border:1px solid var(--border-solid, #e2e2e2);overflow:hidden}.bc-view-btn{padding:6px 14px;border:none;background:var(--card, #fff);font-size:13px;font-weight:600;color:var(--muted, #888);cursor:pointer;transition:background .15s,color .15s}.bc-view-btn+.bc-view-btn{border-left:1px solid var(--border-solid, #e2e2e2)}.bc-view-btn.active{background:var(--gradient);color:#fff}.bc-view-btn:hover:not(.active){background:#534ab70f;color:#534ab7}.bc-container{background:var(--card, #fff);border:1px solid var(--border-solid, #e2e2e2);border-radius:var(--radius-lg, 12px);overflow-x:auto;min-height:400px}.bc-loading{display:flex;align-items:center;justify-content:center;min-height:300px;color:var(--muted, #888);font-size:14px}.bc-day-grid{display:grid;grid-template-columns:60px repeat(var(--staff-cols, 1),1fr);min-width:400px}.bc-time-header{padding:12px 8px;background:var(--bg, #f9f9fb);border-bottom:1px solid var(--border-solid, #e2e2e2);position:sticky;top:0;z-index:2}.bc-staff-header{padding:12px 8px;text-align:center;font-size:13px;font-weight:700;color:var(--ink, #1a1a2e);background:var(--bg, #f9f9fb);border-bottom:1px solid var(--border-solid, #e2e2e2);border-left:1px solid var(--border-solid, #e2e2e2);position:sticky;top:0;z-index:2}.bc-time-row-group{display:contents}.bc-time-label{padding:8px 6px 8px 10px;font-size:12px;font-weight:500;color:var(--muted, #888);border-bottom:1px solid rgba(0,0,0,.05);text-align:right;height:60px;display:flex;align-items:flex-start}.bc-cell{position:relative;height:60px;border-bottom:1px solid rgba(0,0,0,.05);border-left:1px solid var(--border-solid, #e2e2e2)}.bc-appointment{position:absolute;left:2px;right:2px;min-height:24px;background:var(--apt-color, #534AB7);border-radius:6px;padding:3px 6px;cursor:pointer;z-index:1;overflow:hidden;transition:opacity .15s,transform .1s;display:flex;flex-direction:column;gap:1px}.bc-appointment:hover{opacity:.85;transform:scale(1.02);z-index:3}.bc-apt-time{font-size:10px;font-weight:700;color:#ffffffe6}.bc-apt-name{font-size:11px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bc-apt-service{font-size:10px;color:#fffc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bc-apt-compact{height:22px;flex-direction:row;gap:6px;align-items:center}.bc-apt-compact .bc-apt-service{display:none}.bc-week-grid{display:grid;grid-template-columns:60px repeat(7,1fr);min-width:600px}.bc-week-day-header{padding:10px 8px;text-align:center;background:var(--bg, #f9f9fb);border-bottom:1px solid var(--border-solid, #e2e2e2);border-left:1px solid var(--border-solid, #e2e2e2);position:sticky;top:0;z-index:2}.bc-week-day-header.today{background:#534ab714}.bc-week-day-name{display:block;font-size:11px;font-weight:600;color:var(--muted, #888);text-transform:uppercase}.bc-week-day-num{display:block;font-size:16px;font-weight:700;color:var(--ink, #1a1a2e);margin-top:2px}.bc-week-day-header.today .bc-week-day-num{color:#534ab7}.bc-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:900;display:flex;align-items:center;justify-content:center;padding:16px}.bc-popup{position:relative;background:var(--card, #fff);border-radius:16px;padding:24px;width:100%;max-width:400px;box-shadow:0 16px 48px #0003}.bc-popup-close{position:absolute;top:12px;right:12px;background:none;border:none;cursor:pointer;color:var(--muted, #888);padding:4px;border-radius:6px}.bc-popup-close:hover{color:var(--ink, #1a1a2e);background:#0000000d}.bc-popup-title{font-family:var(--font-display, -apple-system, sans-serif);font-size:17px;font-weight:700;color:var(--ink, #1a1a2e);margin:0 0 12px}.bc-popup-status{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700;color:var(--status-color, #534AB7);background:color-mix(in srgb,var(--status-color, #534AB7) 12%,transparent);margin-bottom:16px}.bc-popup-details{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.bc-popup-row{display:flex;justify-content:space-between;font-size:14px}.bc-popup-row span:first-child{color:var(--muted, #888)}.bc-popup-row span:last-child{font-weight:600;color:var(--ink, #1a1a2e)}.bc-popup-actions{display:flex;gap:8px;flex-wrap:wrap}.bc-action-btn{flex:1;min-width:100px;padding:8px 12px;border-radius:8px;border:none;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s;color:#fff}.bc-action-btn:disabled{opacity:.5;cursor:not-allowed}.bc-action-complete{background:#22c55e}.bc-action-complete:hover:not(:disabled){background:#16a34a}.bc-action-cancel{background:#ef4444}.bc-action-cancel:hover:not(:disabled){background:#dc2626}.bc-action-noshow{background:#f59e0b}.bc-action-noshow:hover:not(:disabled){background:#d97706}@media (max-width: 768px){.bc-toolbar{flex-direction:column;align-items:flex-start}.bc-date-title{font-size:14px}.bc-day-grid{min-width:320px}.bc-week-grid{min-width:520px}}.bc-payment-dot{position:absolute;top:4px;right:4px;width:8px;height:8px;border-radius:50%;background:var(--pay-color, #94a3b8);flex-shrink:0}.bc-popup-payment{font-weight:500;color:var(--pay-color, #94a3b8)}.wgt-root{max-width:400px;margin:0 auto;background:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;color:#1a1a2e;min-height:100vh;display:flex;flex-direction:column}.wgt-header{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid #eee}.wgt-logo{width:32px;height:32px;border-radius:8px;object-fit:cover}.wgt-logo-placeholder{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#7c3aed,#a78bfa);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}.wgt-biz-name{font-size:15px;font-weight:600;color:#1a1a2e;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wgt-back{display:inline-flex;align-items:center;gap:4px;background:none;border:none;cursor:pointer;color:#7c3aed;font-size:13px;font-weight:500;padding:8px 16px 0}.wgt-back:hover{color:#6d28d9}.wgt-section{padding:12px 16px 16px;flex:1}.wgt-section-title{font-size:16px;font-weight:700;color:#1a1a2e;margin-bottom:12px}.wgt-group-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#888;margin:12px 0 6px}.wgt-group-title:first-child{margin-top:0}.wgt-service-card{display:flex;align-items:center;padding:10px 12px;border:1px solid #eee;border-radius:10px;margin-bottom:6px;cursor:pointer;transition:border-color .15s,background .15s}.wgt-service-card:hover{border-color:#d4d4d8;background:#fafafa}.wgt-service-info{flex:1;min-width:0}.wgt-service-name{font-size:14px;font-weight:600;color:#1a1a2e;margin-bottom:2px}.wgt-service-meta{font-size:12px;color:#888}.wgt-service-arrow{font-size:20px;color:#ccc;margin-left:8px}.wgt-staff-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid #eee;border-radius:10px;margin-bottom:6px;cursor:pointer;transition:border-color .15s,background .15s}.wgt-staff-card:hover{border-color:#d4d4d8;background:#fafafa}.wgt-staff-avatar{width:36px;height:36px;border-radius:50%;background:#e5e7eb;color:#555;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}.wgt-staff-any{background:linear-gradient(135deg,#22c55e,#4ade80);color:#fff}.wgt-staff-photo{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}.wgt-staff-info{flex:1;min-width:0}.wgt-staff-name{font-size:14px;font-weight:600;color:#1a1a2e}.wgt-staff-spec{font-size:12px;color:#888}.wgt-dates{display:flex;gap:6px;overflow-x:auto;padding-bottom:8px;margin-bottom:12px;scrollbar-width:none}.wgt-dates::-webkit-scrollbar{display:none}.wgt-date-pill{flex-shrink:0;padding:6px 12px;border:1px solid #e5e7eb;border-radius:20px;background:#fff;font-size:12px;font-weight:500;color:#1a1a2e;cursor:pointer;white-space:nowrap;transition:all .15s}.wgt-date-pill:hover:not(:disabled){border-color:#7c3aed;color:#7c3aed}.wgt-date-pill.selected{background:#7c3aed;border-color:#7c3aed;color:#fff}.wgt-date-pill.unavailable{opacity:.4;cursor:not-allowed}.wgt-slots-section{margin-bottom:12px}.wgt-slots-label{font-size:13px;font-weight:600;color:#555;margin-bottom:8px}.wgt-slots-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.wgt-slot{padding:8px 4px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;font-size:13px;font-weight:500;color:#1a1a2e;cursor:pointer;text-align:center;transition:all .15s}.wgt-slot:hover{border-color:#7c3aed;color:#7c3aed}.wgt-slot.selected{background:#7c3aed;border-color:#7c3aed;color:#fff}.wgt-form{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.wgt-field{display:flex;flex-direction:column;gap:3px}.wgt-label{font-size:12px;font-weight:600;color:#555}.wgt-input{padding:8px 10px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;color:#1a1a2e;outline:none;transition:border-color .15s}.wgt-input:focus{border-color:#7c3aed}.wgt-input::placeholder{color:#bbb}.wgt-summary{background:#f8f8fc;border-radius:10px;padding:10px 12px;margin-bottom:14px}.wgt-summary-row{display:flex;justify-content:space-between;padding:4px 0;font-size:13px}.wgt-summary-row span:first-child{color:#888}.wgt-summary-row span:last-child{font-weight:600;color:#1a1a2e;text-align:right}.wgt-price{color:#7c3aed!important}.wgt-btn-primary{display:block;width:100%;padding:12px;background:#7c3aed;color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.wgt-btn-primary:hover:not(:disabled){background:#6d28d9}.wgt-btn-primary:disabled{opacity:.5;cursor:not-allowed}.wgt-btn-secondary{display:block;width:100%;padding:10px;background:#f3f4f6;color:#1a1a2e;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.wgt-btn-secondary:hover{background:#e5e7eb}.wgt-done{text-align:center;padding-top:24px}.wgt-done-title{font-size:18px;font-weight:700;color:#22c55e;margin:10px 0 14px}.wgt-done-note{font-size:13px;color:#888;margin:12px 0 16px}.wgt-error{background:#fef2f2;color:#dc2626;padding:8px 12px;border-radius:8px;font-size:13px;margin-bottom:10px}.wgt-empty{text-align:center;color:#aaa;font-size:13px;padding:16px 0}.wgt-loading{text-align:center;color:#888;font-size:13px;padding:20px 0}.wgt-not-found{text-align:center;color:#888;font-size:14px;padding:40px 16px}.wgt-footer{text-align:center;padding:12px;font-size:11px;color:#bbb;border-top:1px solid #f0f0f0;margin-top:auto}.wgt-footer a{color:#7c3aed;text-decoration:none;font-weight:600}.wgt-footer a:hover{text-decoration:underline}.ps-page{padding:0}.ps-loading{text-align:center;padding:48px 0;color:var(--muted)}.ps-form{max-width:600px}.ps-section{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px;margin-bottom:20px}.ps-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.ps-section-title{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--ink);margin:0}.ps-status{font-size:13px;padding:4px 12px;border-radius:20px;background:var(--border);color:var(--muted)}.ps-status-ok{background:#dcfce7;color:#16a34a}.ps-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.ps-field:last-child{margin-bottom:0}.ps-label{font-size:13px;font-weight:500;color:var(--ink)}.ps-input{padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-size:14px;background:var(--bg);color:var(--ink);transition:border-color .15s}.ps-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #534ab71a}.ps-input::placeholder{color:var(--muted)}.ps-input-narrow{width:100px}.ps-percent-input{display:flex;align-items:center;gap:8px}.ps-percent-sign{font-size:14px;color:var(--muted);font-weight:500}.ps-hint{font-size:12px;color:var(--muted)}.ps-toggle-field{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;cursor:pointer}.ps-toggle{position:relative;width:44px;height:24px;border-radius:12px;background:var(--border);border:none;cursor:pointer;transition:background .2s;flex-shrink:0}.ps-toggle-on{background:var(--accent)}.ps-toggle-thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px #0003}.ps-toggle-on .ps-toggle-thumb{transform:translate(20px)}.ps-error{background:#fef2f2;color:#dc2626;padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:16px}.ps-success{background:#dcfce7;color:#16a34a;padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:16px}.ps-save-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 28px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .15s}.ps-save-btn:hover{opacity:.9}.ps-save-btn:disabled{opacity:.5;cursor:not-allowed}.emp-page{padding:24px 32px;max-width:1100px;font-family:var(--font-body)}.emp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:12px}.emp-header h1{font-family:var(--font-display);font-size:22px;margin:0}.emp-count{background:var(--surface);border-radius:12px;padding:2px 10px;font-size:13px;color:var(--muted);margin-left:8px}.emp-add-btn{padding:8px 20px;background:var(--accent, #534AB7);color:#fff;border:none;border-radius:8px;font-size:14px;font-family:var(--font-body);cursor:pointer;white-space:nowrap}.emp-add-btn:hover{opacity:.9}.emp-table-wrap{border:1px solid var(--border);border-radius:10px;overflow:hidden}.emp-table{width:100%;border-collapse:collapse;font-size:14px}.emp-table thead tr{background:var(--surface)}.emp-table th{text-align:left;padding:10px 16px;font-weight:500;color:var(--muted);font-size:12px}.emp-table td{padding:10px 16px;border-top:1px solid var(--border)}.emp-table tbody tr{cursor:pointer;transition:background .15s}.emp-table tbody tr:hover{background:var(--surface)}.emp-role-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:500}.emp-role-owner{background:#fef3c7;color:#b45309}.emp-role-admin{background:#ede9fe;color:#7c3aed}.emp-role-manager{background:#dbeafe;color:#2563eb}.emp-role-cashier{background:#d1fae5;color:#059669}.emp-status-active{font-size:12px;color:#27ae60;font-weight:500}.emp-status-inactive{font-size:12px;color:#e74c3c;font-weight:500}.emp-status-pending{font-size:12px;color:#f59e0b;font-weight:500}.emp-modules{display:flex;gap:4px;flex-wrap:wrap}.emp-module-tag{font-size:11px;padding:1px 6px;border-radius:4px;background:var(--surface);color:var(--muted)}.emp-module-tag.active{background:#ede9fe;color:#7c3aed}.emp-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.emp-modal{background:#fff;border-radius:12px;width:560px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0000002e}.emp-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}.emp-modal-header h2{font-family:var(--font-display);font-size:18px;margin:0}.emp-modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--muted);padding:4px}.emp-modal-body{padding:16px 24px 24px}.emp-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:16px}.emp-tab{padding:8px 16px;font-size:14px;font-family:var(--font-body);background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);cursor:pointer}.emp-tab.active{color:var(--accent, #534AB7);border-bottom-color:var(--accent, #534AB7);font-weight:500}.emp-form-group{margin-bottom:14px}.emp-form-label{display:block;font-size:13px;color:var(--muted);margin-bottom:4px}.emp-form-input,.emp-form-select{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:6px;font-size:14px;font-family:var(--font-body);background:var(--bg, #fff);box-sizing:border-box}.emp-checkbox-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.emp-checkbox-item{display:flex;align-items:center;gap:8px;font-size:14px}.emp-checkbox-item input[type=checkbox]{accent-color:var(--accent, #534AB7);width:16px;height:16px}.emp-section-title{font-size:13px;font-weight:600;color:var(--ink);margin:16px 0 8px}.emp-reset-btn{font-size:13px;color:var(--accent, #534AB7);background:none;border:none;cursor:pointer;padding:0;margin-bottom:8px}.emp-reset-btn:hover{text-decoration:underline}.emp-pin-display{display:flex;align-items:center;gap:12px;padding:16px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;margin-top:8px}.emp-pin-digits{font-family:monospace;font-size:28px;font-weight:700;letter-spacing:8px;color:#059669}.emp-pin-warning{font-size:13px;color:#b45309;margin-top:8px}.emp-actions-row{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}.emp-btn-primary{padding:8px 20px;background:var(--accent, #534AB7);color:#fff;border:none;border-radius:8px;font-size:14px;cursor:pointer;font-family:var(--font-body)}.emp-btn-primary:hover{opacity:.9}.emp-btn-primary:disabled{opacity:.5;cursor:not-allowed}.emp-btn-secondary{padding:8px 20px;background:var(--surface);color:var(--ink);border:1px solid var(--border);border-radius:8px;font-size:14px;cursor:pointer;font-family:var(--font-body)}.emp-btn-danger{padding:8px 20px;background:transparent;color:#e74c3c;border:1px solid #e74c3c;border-radius:8px;font-size:14px;cursor:pointer;font-family:var(--font-body)}.emp-btn-danger:hover{background:#fef2f2}.emp-btn-pin{padding:6px 14px;background:#d1fae5;color:#059669;border:none;border-radius:6px;font-size:13px;cursor:pointer;font-family:var(--font-body)}.emp-btn-pin:hover{background:#a7f3d0}.audit-page{padding:24px 32px;max-width:1100px;font-family:var(--font-body)}.audit-page h1{font-family:var(--font-display);font-size:22px;margin:0 0 24px}.audit-filters{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:16px}.audit-filter-group{display:flex;flex-direction:column;gap:4px}.audit-filter-label{font-size:13px;color:var(--muted)}.audit-filter-select,.audit-filter-date{padding:6px 10px;border:1px solid var(--p100, #e9e0ff);border-radius:8px;font-size:14px;font-family:var(--font-body);background:#fff;color:var(--ink);min-width:140px}.audit-table-wrap{border:1px solid var(--border);border-radius:10px;overflow:hidden}.audit-table{width:100%;border-collapse:collapse;font-size:14px}.audit-table thead tr{background:var(--surface)}.audit-table th{text-align:left;padding:10px 16px;font-weight:500;color:var(--muted);font-size:12px}.audit-table td{padding:10px 16px;border-top:1px solid var(--border)}.audit-action-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:500}.audit-action-create{background:#d1fae5;color:#059669}.audit-action-update{background:#dbeafe;color:#2563eb}.audit-action-delete,.audit-action-deactivate{background:#fee2e2;color:#dc2626}.audit-action-redeem{background:#ffedd5;color:#ea580c}.audit-action-reset_pin{background:#fef3c7;color:#b45309}.audit-action-other{background:var(--surface);color:var(--muted)}.audit-pagination{display:flex;align-items:center;justify-content:space-between;margin-top:16px;font-size:14px;color:var(--muted)}.audit-pagination button{padding:6px 14px;border:1px solid var(--border);border-radius:6px;background:#fff;font-size:13px;cursor:pointer;font-family:var(--font-body)}.audit-pagination button:disabled{opacity:.4;cursor:not-allowed}.pin-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#faf9ff;font-family:var(--font-body)}.pin-card{background:#fff;border-radius:16px;padding:40px 48px;box-shadow:0 4px 24px #534ab71a;text-align:center;max-width:400px;width:90%}.pin-card h1{font-family:var(--font-display);font-size:22px;margin:0 0 8px;color:var(--ink)}.pin-subtitle{font-size:14px;color:var(--muted);margin-bottom:24px}.pin-logo{width:48px;height:48px;background:var(--accent, #534AB7);border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.pin-inputs{display:flex;gap:12px;justify-content:center;margin-bottom:24px}.pin-digit{width:56px;height:64px;border:2px solid var(--border);border-radius:12px;font-size:28px;font-weight:600;text-align:center;font-family:var(--font-body);color:var(--ink);outline:none;transition:border-color .2s}.pin-digit:focus{border-color:var(--accent, #534AB7);box-shadow:0 0 0 3px #534ab726}.pin-error{color:#e74c3c;font-size:14px;margin-top:-12px;margin-bottom:16px}.pin-code-input{margin-bottom:20px}.pin-code-input input{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-size:14px;font-family:var(--font-body);text-align:center;box-sizing:border-box}.pin-code-label{font-size:13px;color:var(--muted);margin-bottom:6px}@keyframes pin-shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}.pin-shake{animation:pin-shake .4s ease}@media (max-width: 640px){.emp-page,.audit-page{padding:16px}.emp-checkbox-grid{grid-template-columns:1fr}.emp-modal{width:100%;max-width:100%;border-radius:12px 12px 0 0;max-height:95vh}.pin-digit{width:48px;height:56px;font-size:24px}.pin-card{padding:32px 24px}.audit-filters{flex-direction:column;align-items:stretch}.emp-table th:nth-child(4),.emp-table td:nth-child(4),.emp-table th:nth-child(5),.emp-table td:nth-child(5){display:none}}:root{--p50: #f5f0ff;--p100: #ede5ff;--p200: #d9c5ff;--p300: #be9eff;--p400: #a87aff;--p500: #9B6DFF;--p600: #7c3aed;--p700: #6d28d9;--ink: #1C0B40;--ink2: #3d2b6b;--muted: #6B5F7E;--muted2: #9B87C0;--surface: #ffffff;--bg: #f5f0ff;--gradient: linear-gradient(135deg, #9B6DFF 0%, #C9A0FF 60%, #E0C6FF 100%);--font-display: "Outfit", sans-serif;--font-body: "Plus Jakarta Sans", sans-serif;--card: #ffffff;--border: rgba(124,58,237,.1);--border-hover: rgba(124,58,237,.22);--border-solid: #EAE6F5;--shadow-sm: 0 1px 3px rgba(80,50,160,.05), 0 3px 10px rgba(80,50,160,.04);--shadow-md: 0 4px 16px rgba(80,50,160,.09), 0 1px 3px rgba(80,50,160,.05);--sidebar-w-collapsed: 72px;--sidebar-w-expanded: 240px;--header-h: 56px;--radius: 12px;--radius-lg: 16px;--radius-xl: 22px;--green: #22c55e;--green-soft: rgba(34,197,94,.1);--amber: #f59e0b;--amber-soft: rgba(245,158,11,.1);--red: #ef4444;--blue: #3b82f6;--blue-soft: rgba(59,130,246,.1);--pink: #ec4899;--pink-soft: rgba(236,72,153,.1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:var(--font-display)}a{color:var(--p500);text-decoration:none}
