:root{--bg:#efecfa;--card:#fff;--ink:#1b1830;--muted:#6b6781;--line:#e8e4f4;--closed:#f0eef9;--hover:#f7f5fd;--soft:#f3f1fb;--accent-soft:#ece8fb;--primary:#e6336e;--primary-d:#c61f5b;--danger:#ef4444;--radius:14px;--shadow-sm:0 1px 2px #261b3c0f;--shadow:0 1px 3px #261b3c0f, 0 10px 28px #4c33781a;--ring:0 0 0 3px #e6336e2e}*{box-sizing:border-box}html,body,#root{height:100%}body{background:linear-gradient(180deg, #faf8ff 0%, var(--bg) 260px);color:var(--ink);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.app{min-height:100%;padding:0}.panel{background:var(--card);width:100%;box-shadow:none;border:none;border-radius:0;margin:0;overflow:visible}.panel-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:16px;padding:14px 22px;display:flex}.panel-head-right{align-items:center;gap:12px;display:flex}.app-header{z-index:50;background:var(--card);position:sticky;top:0}.icon-nav{background:var(--soft);border-bottom:1px solid var(--line);flex-wrap:wrap;align-items:stretch;gap:4px;padding:8px 14px;display:flex;overflow:visible}.nav-item{min-width:78px;font:inherit;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:11px;flex-direction:column;flex:1 1 0;align-items:center;gap:5px;padding:8px 10px;font-size:10.5px;font-weight:700;transition:background .15s,color .15s,box-shadow .15s;display:flex}.nav-item .nav-ico{font-size:18px;line-height:1}.nav-item:hover{color:var(--ink);background:#fff}.nav-item.active{color:var(--primary-d);box-shadow:var(--shadow-sm);cursor:default;background:#fff}.appt-bar{flex-direction:column;align-items:stretch;gap:12px;margin:2px 2px 14px;display:flex}.appt-title{letter-spacing:-.02em;margin:0;font-size:20px;font-weight:800}.appt-tools{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.tools-spacer{flex:1 1 0;min-width:0}.date-cur{color:var(--ink);text-align:center;min-width:132px;padding:0 8px;font-size:13px;font-weight:700}.seg{background:var(--soft);border:1px solid var(--line);border-radius:9px;gap:2px;padding:3px;display:inline-flex}.seg-btn{font:inherit;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:7px;align-items:center;gap:5px;padding:6px 11px;font-size:12px;font-weight:700;line-height:1;transition:background .15s,color .15s,box-shadow .15s;display:inline-flex}.seg-btn:hover:not(:disabled){color:var(--ink)}.seg-btn.on{color:var(--primary-d);box-shadow:var(--shadow-sm);background:#fff}.seg-btn:disabled{opacity:.45;cursor:not-allowed}.filter-select{border:1px solid var(--line);font:inherit;color:var(--ink);cursor:pointer;background:#fff;border-radius:9px;padding:7px 10px;font-size:12px;font-weight:600}.filter-select:focus{border-color:var(--primary);box-shadow:var(--ring);outline:none}.appt-list{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:8px;max-height:calc(100vh - 250px);padding:10px;display:flex;overflow:auto}.appt-list-row{text-align:left;border:1px solid var(--line);width:100%;font:inherit;cursor:pointer;background:#fff;border-radius:11px;align-items:stretch;gap:12px;padding:10px 14px;transition:background .12s,border-color .12s,box-shadow .12s;display:flex}.appt-list-row:hover{background:var(--hover);box-shadow:var(--shadow-sm);border-color:#d9d2ee}.ali-time{min-width:62px;color:var(--ink);flex-direction:column;justify-content:center;font-size:13px;font-weight:800;line-height:1.25;display:flex}.ali-time small{color:var(--muted);font-size:11px;font-weight:600}.ali-bar{background:var(--primary);border-radius:99px;flex:none;width:5px}.ali-bar.block{background:repeating-linear-gradient(45deg,#cbd5e1,#cbd5e1 4px,#e2e8f0 4px 8px)}.ali-main{flex-direction:column;flex:1;justify-content:center;gap:2px;min-width:0;display:flex}.ali-main strong{font-size:14px}.ali-sub{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.ali-status{text-transform:capitalize;color:var(--muted);background:var(--soft);white-space:nowrap;border-radius:99px;align-self:center;padding:3px 10px;font-size:11px;font-weight:700}.appt-list-row.status-cancelled{opacity:.6}.appt-list-row.status-cancelled strong{text-decoration:line-through}.topbar{-webkit-backdrop-filter:saturate(180%)blur(12px);backdrop-filter:saturate(180%)blur(12px);border-bottom:1px solid var(--line);z-index:50;background:#ffffffd9;flex-wrap:wrap;align-items:center;gap:20px;padding:12px 24px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:12px;display:flex}.logo{object-fit:contain;background:var(--soft);width:42px;height:42px;box-shadow:inset 0 0 0 1px var(--line);border-radius:12px;padding:5px;display:block}.brand h1{letter-spacing:-.02em;margin:0;font-size:18px;font-weight:700}.tagline{color:var(--muted);margin:1px 0 0;font-size:12px}.date-nav{align-items:center;gap:10px;margin-left:auto;display:flex}.date-stepper{background:var(--soft);border:1px solid var(--line);border-radius:10px;align-items:center;gap:2px;padding:3px;display:inline-flex}.date-stepper .btn{box-shadow:none;background:0 0;border-color:#0000}.date-stepper .btn:hover{box-shadow:var(--shadow-sm);background:#fff;transform:none}.date-input{border:1px solid var(--line);font:inherit;color:var(--ink);cursor:pointer;background:#fff;border-radius:9px;padding:7px 10px}.date-input:focus-visible{border-color:var(--primary);box-shadow:var(--ring);outline:none}.date-label{color:var(--muted);min-width:150px;font-size:13px;font-weight:600}.actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.btn{color:var(--ink);font:inherit;white-space:nowrap;cursor:pointer;background:#fff;border:1px solid #0000;border-radius:9px;justify-content:center;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:600;transition:background .15s,border-color .15s,box-shadow .15s,transform .15s,color .15s;display:inline-flex}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:focus-visible{box-shadow:var(--ring);outline:none}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn.ghost{border-color:var(--line);color:var(--ink);box-shadow:var(--shadow-sm);background:#fff}.btn.ghost:hover{background:var(--hover);border-color:#cbd5e1}.btn.primary{background:var(--primary);color:#fff;box-shadow:0 1px 2px #e6336e47}.btn.primary:hover{background:var(--primary-d);box-shadow:0 6px 16px #e6336e57}.btn.danger{color:var(--danger);box-shadow:var(--shadow-sm);background:#fff;border-color:#fecaca}.btn.danger:hover{background:#fef2f2}.btn.icon{padding:8px 11px;font-size:16px;line-height:1}.btn.sm{padding:5px 10px;font-size:12px}.btn.wide{width:100%;margin-top:10px}.banner{padding:10px 16px;font-size:13px;font-weight:600}.banner.error{color:#b91c1c;cursor:pointer;background:#fef2f2;border-bottom:1px solid #fecaca}.banner.warn{color:#92400e;background:#fffbeb;border-radius:8px;margin-bottom:10px}.summary{padding:18px 24px 4px}.kpi-row{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:18px;display:grid}.kpi-card{background:linear-gradient(180deg, var(--accent-soft), #fff 85%);border:1px solid var(--line);border-radius:var(--radius);min-width:0;box-shadow:var(--shadow-sm);align-items:center;gap:14px;padding:15px 18px;transition:box-shadow .18s,transform .18s,border-color .18s;display:flex}.kpi-card:hover{box-shadow:var(--shadow);border-color:#d9d2ee;transform:translateY(-2px)}.kpi-icon{border:1px solid var(--line);width:46px;height:46px;box-shadow:var(--shadow-sm);background:#fff;border-radius:13px;flex:none;place-items:center;font-size:20px;display:grid}.kpi-body{flex-direction:column;gap:4px;min-width:0;display:flex}.kpi-label{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-size:10.5px;font-weight:700;line-height:1.3}.kpi-value{letter-spacing:-.02em;color:var(--ink);font-size:24px;font-weight:800;line-height:1}.summary-head{flex-wrap:wrap;align-items:baseline;gap:12px;margin-bottom:12px;display:flex}.summary-head h2{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:0;font-size:12px;font-weight:700}.summary-totals{color:var(--muted);font-size:13px}.summary-cards{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;display:grid}.sum-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px 16px;transition:box-shadow .18s,transform .18s,border-color .18s}.sum-card:hover{box-shadow:var(--shadow);border-color:#cdd6e4;transform:translateY(-2px)}.sum-top{align-items:center;gap:8px;margin-bottom:12px;display:flex}.sum-top strong{letter-spacing:-.01em;font-size:14px}.dot{border-radius:50%;flex:none;width:9px;height:9px;box-shadow:0 0 0 3px #0000000a}.sum-figures{gap:18px;margin-bottom:10px;display:flex}.sum-figures div{flex-direction:column;gap:2px;display:flex}.sum-figures b{letter-spacing:-.02em;font-size:18px;font-weight:700;line-height:1}.sum-figures span{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:10px}.sum-bar{background:var(--soft);border-radius:99px;height:6px;overflow:hidden}.sum-bar-fill{border-radius:99px;height:100%;transition:width .4s}.sum-shift{color:var(--muted);align-items:center;gap:6px;margin-top:10px;font-size:11px;display:flex}.sum-shift:before{content:"";background:currentColor;flex:none;width:12px;height:12px;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpolyline points='12 7 12 12 15 14'/%3E%3C/svg%3E") 50%/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpolyline points='12 7 12 12 15 14'/%3E%3C/svg%3E") 50%/contain no-repeat}.content{padding:12px 22px 28px}.loading,.empty{text-align:center;color:var(--muted);padding:60px}.coming-soon{text-align:center;background:var(--card);border:1px dashed var(--line);border-radius:var(--radius);flex-direction:column;justify-content:center;align-items:center;gap:8px;min-height:48vh;padding:40px;display:flex}.coming-soon-ico{background:var(--accent-soft);width:72px;height:72px;box-shadow:var(--shadow-sm);border-radius:20px;place-items:center;margin-bottom:6px;font-size:34px;display:grid}.coming-soon h2{letter-spacing:-.02em;margin:0;font-size:22px;font-weight:800}.coming-soon p{color:var(--muted);margin:0;font-size:14px}.manage-title{margin:2px 2px 16px}.manage-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;display:grid}.manage-card{text-align:left;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);width:100%;font:inherit;cursor:pointer;box-shadow:var(--shadow-sm);align-items:center;gap:14px;padding:16px 18px;transition:box-shadow .18s,transform .18s,border-color .18s;display:flex}.manage-card:hover{box-shadow:var(--shadow);border-color:#d9d2ee;transform:translateY(-2px)}.manage-ico{background:var(--accent-soft);border:1px solid var(--line);border-radius:13px;flex:none;place-items:center;width:48px;height:48px;font-size:22px;display:grid}.manage-text{flex-direction:column;gap:3px;min-width:0;display:flex}.manage-text strong{letter-spacing:-.01em;font-size:15px}.manage-text span{color:var(--muted);font-size:12.5px}.page-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin:2px 2px 16px;display:flex}.page-head .appt-title{margin:0}.page-only-title{margin:2px 2px 16px}.page-tools{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.page-search{width:240px}.crud-cards{flex-direction:column;gap:10px;display:flex}.crud-card{background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow-sm);border-radius:12px;padding:12px 14px}.crud-card-head{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.crud-card-title{color:var(--ink);word-break:break-word;min-width:0;font-size:15px;font-weight:700;line-height:1.3}.crud-card-actions{flex:none;margin:-4px -6px -4px 0;display:flex}.crud-card-main{flex-direction:column;gap:6px;margin-top:8px;display:flex}.crud-card-line{justify-content:space-between;align-items:baseline;gap:14px;font-size:13px;display:flex}.crud-card-k{color:var(--muted);flex:none;font-weight:600}.crud-card-v{color:var(--ink);text-align:right;word-break:break-word;min-width:0}.crud-state{text-align:center;color:var(--muted);padding:30px 8px;font-size:14px}.search-input{border:1px solid var(--line);font:inherit;min-width:200px;color:var(--ink);background:#fff;border-radius:9px;padding:8px 12px;font-size:13px}.search-input:focus{border-color:var(--primary);box-shadow:var(--ring);outline:none}.crud-table-wrap{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:auto}.crud-table{border-collapse:collapse;width:100%;font-size:13.5px}.crud-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);border-bottom:1px solid var(--line);white-space:nowrap;padding:12px 16px;font-size:11px;font-weight:700}.crud-table td{border-bottom:1px solid var(--line);color:var(--ink);vertical-align:middle;padding:12px 16px}.crud-table tbody tr:last-child td{border-bottom:none}.crud-table tbody tr:hover{background:var(--hover)}.crud-table .col-actions{text-align:right;white-space:nowrap;width:1%}.crud-table .col-actions .btn{margin-left:6px}.pill.ok{color:#0f7a48;background:#e7f7ef}.pill.warn{color:#9a5b00;background:#fff4e5}.pill.danger{color:#b91c1c;background:#fde8e8;margin-left:6px}.stars{color:#f5a623;letter-spacing:1px}.reviews-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px 20px}.reviews-card h2{margin:0 0 2px;font-size:16px}.review-list{flex-direction:column;gap:12px;margin:14px 0 0;padding:0;list-style:none;display:flex}.review-item{border:1px solid var(--line);background:var(--hover);border-radius:12px;padding:12px 14px}.review-item .stars{font-size:14px}.review-comment{color:var(--ink);margin:6px 0 0;font-size:13px;line-height:1.5}.feedback-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px 20px}.feedback-card h2{margin:0 0 2px;font-size:16px}.feedback-form{flex-direction:column;gap:12px;margin-top:12px;display:flex}.feedback-form textarea{border:1px solid var(--line);font:inherit;resize:vertical;border-radius:9px;padding:10px 12px}.feedback-form textarea:focus{border-color:var(--brand,#6d5efc);outline:none}.star-input{gap:6px;display:flex}.star-btn{cursor:pointer;color:#d6d9e0;background:0 0;border:none;padding:0;font-size:30px;line-height:1;transition:color .12s,transform .12s}.star-btn.on{color:#f5a623}.star-btn:hover{color:#f5a623;transform:scale(1.1)}.feedback-actions{justify-content:flex-end;gap:10px;display:flex}.cal-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px 20px}.cal-card h2{margin:0 0 2px;font-size:16px}.cal-card .muted-line{margin:0 0 12px}.customer-cal{margin-top:4px}.customer-cal .cal-col.bookable{cursor:pointer}.customer-cal .cal-col.bookable:hover{background:#e6336e0b}.slot-busy{z-index:5;cursor:not-allowed;color:#7b8493;background:repeating-linear-gradient(45deg,#eef1f5,#eef1f5 6px,#e6eaf0 6px 12px);border:1px solid #d7dce4;border-radius:7px;align-items:center;padding:0 6px;font-size:10px;font-weight:700;display:flex;position:absolute;left:3px;right:3px;overflow:hidden}.slot-pick{z-index:6;pointer-events:none;border:1.5px solid var(--primary);color:var(--primary-d);background:#e6336e29;border-radius:7px;align-items:center;padding:0 6px;font-size:10px;font-weight:800;display:flex;position:absolute;left:3px;right:3px}.book-form{flex-direction:column;gap:12px;display:flex}.book-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.book-form .btn.wide{margin-top:4px}.customer{flex-direction:column;gap:16px;padding-bottom:78px;display:flex}.my-appts{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px 20px}.my-appts h2{margin:0 0 2px;font-size:16px}.appt-item{border-bottom:1px solid var(--line);align-items:center;gap:10px;padding:10px 0;display:flex}.appt-item:last-child{border-bottom:none}.appt-item .dot{border-radius:50%;flex:none;width:10px;height:10px}.appt-item .ai-main{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.appt-item .ai-main strong{font-size:14px}.appt-item .ai-main span{color:var(--muted);font-size:12px}.cal-staff-chips{-webkit-overflow-scrolling:touch;gap:8px;margin-bottom:12px;padding-bottom:6px;display:flex;overflow-x:auto}.cal-staff-chips .chip{white-space:nowrap;flex:none;align-items:center;gap:6px;display:inline-flex}.chip-dot{border-radius:50%;width:8px;height:8px}.book-fab{z-index:48;background:var(--primary);color:#fff;cursor:pointer;font:inherit;border:none;border-radius:99px;align-items:center;gap:8px;padding:14px 22px;font-size:14px;font-weight:700;transition:background .15s,transform .15s,box-shadow .15s;display:inline-flex;position:fixed;bottom:78px;right:20px;box-shadow:0 10px 26px #e6336e6b}.book-fab:hover{background:var(--primary-d);transform:translateY(-1px);box-shadow:0 14px 30px #e6336e80}.book-fab:active{transform:translateY(0)}.book-fab-plus{margin-top:-1px;font-size:20px;line-height:1}.cust-tabbar,.admin-tabbar{z-index:49;background:var(--card);border-top:1px solid var(--line);padding-bottom:env(safe-area-inset-bottom,0);display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 14px #261b3c12}.admin-tabbar{display:none}.cust-tab,.admin-tab{cursor:pointer;min-width:0;font:inherit;color:var(--muted);background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:3px;padding:9px 4px 8px;font-size:11px;font-weight:600;transition:color .15s;display:flex}.cust-tab.on,.admin-tab.on{color:var(--primary-d)}.cust-tab-ico{font-size:20px;line-height:1}.admin-tab{font-size:10px}.admin-tab-ico{line-height:1;display:inline-flex}.admin-tab-lbl{text-overflow:ellipsis;white-space:nowrap;max-width:100%;overflow:hidden}.nav-ico .nav-svg{display:block}.page-head .appt-title{align-items:center;gap:4px;display:flex}.reports-subhead{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:24px 2px 12px;font-size:12px;font-weight:700}.report-back{padding:0 8px;font-size:18px;line-height:1}.report-split{grid-template-columns:1fr 1fr;align-items:start;gap:24px;display:grid}@media (width<=720px){.report-split{grid-template-columns:1fr}}.cal-scroll{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);max-height:calc(100vh - 250px);overflow:auto}.cal-grid{grid-template-columns:64px repeat(var(--cols), minmax(150px, 1fr));display:grid;position:relative}.cal-corner{z-index:30;background:var(--card);border-right:1px solid var(--line);border-bottom:1px solid var(--line);place-items:center;padding:6px;display:grid;position:sticky;top:0;left:0}.shop-hours-pill{color:var(--muted);text-align:center;font-size:9px;font-weight:700;line-height:1.3}.cal-head{z-index:20;background:var(--card);border-bottom:1px solid var(--line);border-right:1px solid var(--line);align-items:center;gap:10px;padding:11px 13px;display:flex;position:sticky;top:0}.cal-head .dot{margin-top:5px}.week-head{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1px}.week-head .wh-day{color:var(--ink);font-size:13px;font-weight:700}.week-head .wh-date{color:var(--muted);font-size:12px}.week-head .wh-hours{color:var(--muted);margin-top:1px;font-size:10px}.week-head .wh-hours.off{color:#b45309;font-weight:600}.cal-head.week-head.today{background:#fdf2f7}.cal-head.week-head.today .wh-day{color:var(--primary-d)}.cal-col.is-today{background:#e6336e09}.head-avatar{object-fit:cover;border:2px solid var(--line);border-radius:50%;flex:none;width:34px;height:34px}.head-avatar.fallback{color:#fff;border:none;place-items:center;font-size:14px;font-weight:700;display:grid;box-shadow:0 1px 3px #0f172a2e}.cal-head-text{flex-direction:column;min-width:0;line-height:1.4;display:flex}.cal-head-text strong{letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.cal-head-text .role{color:var(--muted);font-size:11px}.cal-head-text .work{color:var(--muted);align-items:center;gap:4px;font-size:11px;display:inline-flex}.cal-gutter{z-index:10;background:linear-gradient(90deg, var(--card), #fcfdff);border-right:1px solid var(--line);position:sticky;left:0}.hour-label{color:var(--muted);letter-spacing:.01em;font-size:10.5px;font-weight:600;position:absolute;right:8px;transform:translateY(-50%)}.cal-col{border-right:1px solid var(--line);background:var(--closed);cursor:copy;position:relative}.band-open{background:#fff;position:absolute;left:0;right:0}.band-work{border-left:3px solid;position:absolute;left:0;right:0}.hline{border-top:1px solid var(--line);position:absolute;left:0;right:0}.hline.half{border-top:1px dashed #eef2f7}.appt{color:#fff;cursor:grab;z-index:5;touch-action:none;border-radius:9px;padding:5px 9px;transition:filter .12s,box-shadow .12s,transform 80ms;position:absolute;left:4px;right:4px;overflow:hidden;box-shadow:0 1px 2px #0f172a2e,inset 0 1px #ffffff2e}.appt:before{content:"";background:#ffffff8c;width:3px;position:absolute;top:0;bottom:0;left:0}.appt:hover{filter:brightness(1.06);z-index:6;box-shadow:0 4px 12px #0f172a38}.appt.dragging{cursor:grabbing;z-index:30;pointer-events:none;filter:brightness(1.06);opacity:.95;transform:scale(1.01);box-shadow:0 12px 28px #0f172a52}.cal-col.drop-target{background:var(--accent-soft)}.cal-col.drop-target .band-open{background:#fbfcff}.appt-time{opacity:.92;font-size:10px;font-weight:600}.appt-name{white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:700;overflow:hidden}.appt-svc{opacity:.92;white-space:nowrap;text-overflow:ellipsis;font-size:10px;overflow:hidden}.appt.status-cancelled{opacity:.5;text-decoration:line-through}.appt.status-completed{box-shadow:inset 0 0 0 2px #ffffff80}.appt.status-no_show{opacity:.6}.now-line{z-index:7;border-top:2px solid #ef4444;position:absolute;left:0;right:0}.now-dot{background:#ef4444;border-radius:50%;width:8px;height:8px;position:absolute;top:-5px;left:-4px}.hint{color:var(--muted);margin:10px 2px 0;font-size:12px}.modal-backdrop{z-index:100;background:#0f172a73;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.modal{background:var(--card);border-radius:16px;width:100%;max-width:520px;max-height:92vh;overflow:auto;box-shadow:0 20px 60px #0000004d}.modal.wide{max-width:640px}.modal-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.modal-head h2{margin:0;font-size:17px}.x{cursor:pointer;color:var(--muted);background:0 0;border:none;font-size:26px;line-height:1}.x:hover{color:var(--ink)}.seg-toggle{background:var(--soft);border:1px solid var(--line);border-radius:11px;grid-template-columns:1fr 1fr;gap:4px;margin:14px 20px 0;padding:4px;display:grid}.seg-toggle button{font:inherit;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px 10px;font-size:13px;font-weight:600;transition:background .15s,color .15s,box-shadow .15s}.seg-toggle button:hover{color:var(--ink)}.seg-toggle button.on{color:var(--primary-d);box-shadow:var(--shadow-sm);background:#fff}.form-grid{grid-template-columns:1fr 1fr;gap:14px;padding:18px 20px;display:grid}.field{flex-direction:column;gap:5px;display:flex}.field.full{grid-column:1/-1}.field>span{color:var(--muted);font-size:12px;font-weight:600}.field input,.field select,.field textarea{border:1px solid var(--line);font:inherit;color:var(--ink);background:#fff;border-radius:9px;padding:9px 11px}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);box-shadow:var(--ring);outline:none}.slot-preview{color:var(--muted);border:1px solid var(--line);background:#f8fafc;border-radius:9px;padding:10px 12px;font-size:13px}.slot-preview strong{color:var(--ink)}.form-cols{grid-template-columns:1fr 1fr;gap:0 12px;display:grid}.form-cols .ant-form-item{min-width:0}.form-native-time{box-sizing:border-box;width:100%;height:32px;font:inherit;color:var(--ink);background:#fff;border:1px solid #d9d9d9;border-radius:8px;padding:4px 11px}.form-native-time:focus{border-color:var(--primary);box-shadow:var(--ring);outline:none}.ac-client{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.ac-client small{color:var(--muted);font-variant-numeric:tabular-nums}.modal-foot-row{align-items:center;gap:8px;display:flex}.form-native-time.sm{height:30px;padding:2px 8px}.page-head-left{align-items:center;gap:10px;display:flex}.page-head-left .appt-title{margin:0}.avatar-upload{cursor:pointer;display:inline-flex;position:relative}.avatar-upload .ant-avatar{box-shadow:0 0 0 3px #fff, 0 0 0 4px var(--line)}.avatar-upload-badge{background:var(--primary);color:#fff;border:2px solid #fff;border-radius:50%;place-items:center;width:26px;height:26px;font-size:13px;display:grid;position:absolute;bottom:-2px;right:-2px}.staff-edit-top{align-items:center;gap:16px;margin-bottom:18px;display:flex}.staff-edit-photo-meta{flex-direction:column;gap:2px;display:flex}.staff-edit-photo-meta strong{font-size:14px}.staff-edit-photo-meta span{color:var(--muted);font-size:12px}.section-label{text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:6px 0 10px;font-size:12px;font-weight:700}.section-label small{text-transform:none;letter-spacing:0;font-weight:500}.week-card,.week-grid{flex-direction:column;gap:8px;margin-bottom:18px;display:flex}.week-card{border:1px solid var(--line);background:#fff;border-radius:12px;max-width:520px;padding:12px}.week-row{border:1px solid var(--line);border-radius:9px;align-items:center;gap:10px;padding:6px 8px;display:flex}.week-row.is-off{opacity:.75;background:#f8fafc}.week-day{flex:1;font-size:13px;font-weight:600}.week-sep{color:var(--muted)}.week-off{color:var(--muted);align-items:center;gap:6px;margin-left:4px;font-size:12px;display:inline-flex}.col-off{pointer-events:none;background:repeating-linear-gradient(45deg,#f1f5f9,#f1f5f9 10px,#f8fafc 10px 20px);place-items:center;display:grid;position:absolute;inset:0}.col-off span{color:#94a3b8;box-shadow:var(--shadow-sm);background:#fff;border-radius:999px;padding:2px 10px;font-size:12px;font-weight:600}.cal-head-text .work.off{color:#b45309;font-weight:600}.modal-foot{border-top:1px solid var(--line);align-items:center;gap:10px;padding:14px 20px;display:flex}.spacer{flex:1}.staff-list{flex-direction:column;gap:8px;padding:8px 20px;display:flex}.staff-row{border:1px solid var(--line);border-radius:10px;align-items:center;gap:12px;padding:10px 12px;display:flex}.staff-info{flex-direction:column;line-height:1.35;display:flex}.staff-info strong{font-size:14px}.staff-info span{color:var(--muted);font-size:12px}.row-actions{gap:6px;margin-left:auto;display:flex}.pill{border-radius:99px;padding:2px 8px;font-size:11px;font-weight:700}.pill.muted{color:var(--muted);background:#f1f5f9}.staff-form{border:1px solid var(--line);border-radius:12px;margin:8px 20px}.staff-form .form-grid{padding:16px}.staff-form .modal-foot{border-top:1px solid var(--line)}.swatches{flex-wrap:wrap;gap:8px;display:flex}.swatch{cursor:pointer;border:2px solid #0000;border-radius:8px;width:28px;height:28px}.swatch.on{border-color:var(--ink);box-shadow:inset 0 0 0 2px #fff}.splash{height:100vh;color:var(--muted);place-items:center;display:grid}.login-screen{background:radial-gradient(1200px 700px at 50% -20%, #f3e3fb, var(--bg));place-items:center;min-height:100vh;padding:24px;display:grid}.login-shell{background:var(--card);border:1px solid var(--line);border-radius:24px;grid-template-columns:1.05fr 1fr;width:100%;max-width:940px;display:grid;overflow:hidden;box-shadow:0 4px 12px #0f172a0f,0 24px 60px #0f172a24}.login-hero{isolation:isolate;color:#fbe9f1;background:linear-gradient(155deg,#c61f5b 0%,#9333ea 55%,#6d28d9 100%);flex-direction:column;gap:28px;padding:40px 36px;display:flex;position:relative}.login-hero:before{content:"";z-index:-1;background:radial-gradient(520px 320px at 88% -8%,#5eead459,#0000 60%),radial-gradient(420px 300px at -10% 110%,#8b5cf673,#0000 60%);position:absolute;inset:0}.hero-top{align-items:center;gap:12px;display:flex}.hero-logo{object-fit:contain;background:#ffffff24;border-radius:13px;flex:none;width:44px;height:44px;padding:6px;display:block;box-shadow:inset 0 0 0 1px #ffffff2e}.hero-mark{letter-spacing:-.01em;color:#fff;font-size:17px;font-weight:700}.hero-body{margin-top:auto}.hero-body h2{letter-spacing:-.02em;color:#fff;margin:0 0 12px;font-size:30px;font-weight:800;line-height:1.15}.hero-body>p{color:#ffffffd1;max-width:34ch;margin:0 0 22px;font-size:14px;line-height:1.6}.hero-feats{gap:11px;margin:0;padding:0;list-style:none;display:grid}.hero-feats li{color:#ffffffeb;padding-left:28px;font-size:13.5px;font-weight:500;position:relative}.hero-feats li:before{content:"";background:#ffffff29 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") 50%/12px no-repeat;border-radius:50%;width:18px;height:18px;position:absolute;top:1px;left:0;box-shadow:inset 0 0 0 1px #ffffff38}.hero-foot{color:#ffffffa6;font-size:12px}.login-form{flex-direction:column;padding:40px 38px;display:flex}.login-tabs{border:1px solid var(--line);background:#f1f5f9;border-radius:11px;grid-template-columns:1fr 1fr;gap:4px;margin-bottom:24px;padding:4px;display:grid}.login-tabs button{font:inherit;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px 10px;font-size:13px;font-weight:600;transition:background .15s,color .15s,box-shadow .15s}.login-tabs button:hover{color:var(--ink)}.login-tabs button.on{color:var(--primary-d);box-shadow:var(--shadow);background:#fff}.login-form h1{letter-spacing:-.01em;margin:0 0 4px;font-size:23px}.form-sub{color:var(--muted);margin:0 0 20px;font-size:13.5px}.login-form .field{margin-bottom:14px}.login-form .banner.error{border:1px solid #fecaca;border-radius:10px;margin-bottom:16px}.pw-field{display:flex;position:relative}.pw-field input{flex:1;padding-right:58px}.pw-toggle{cursor:pointer;font:inherit;color:var(--primary-d);background:0 0;border:none;border-radius:7px;padding:4px 8px;font-size:12px;font-weight:600;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.pw-toggle:hover{background:#eef2ff}.btn .spinner{vertical-align:-2px;border:2px solid #ffffff73;border-top-color:#fff;border-radius:50%;width:15px;height:15px;margin-right:8px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.login-hint{color:var(--muted);text-align:center;margin:16px 0 0;font-size:12px}.login-hint code{background:#f1f5f9;border-radius:5px;padding:1px 6px}@media (width<=720px){.login-shell{grid-template-columns:1fr;max-width:420px}.login-hero{display:none}.login-form{padding:32px 26px}}@media (prefers-reduced-motion:reduce){.btn .spinner{animation:none}}.avatar{color:#fff;background:linear-gradient(135deg,#e6336e,#a64bd6);border-radius:50%;flex:none;place-items:center;width:34px;height:34px;font-size:13px;font-weight:700;display:grid;box-shadow:0 2px 6px #e6336e52}.profile-btn{border:1px solid var(--line);font:inherit;cursor:pointer;color:var(--ink);background:#fff;border-radius:99px;align-items:center;gap:8px;padding:3px 12px 3px 3px;transition:border-color .15s,box-shadow .15s;display:inline-flex}.profile-btn:hover{box-shadow:var(--shadow-sm);border-color:#d9d2ee}.profile-name{text-overflow:ellipsis;white-space:nowrap;max-width:150px;font-size:13px;font-weight:600;overflow:hidden}.profile-caret{color:var(--muted);flex:none}.profile-who{flex-direction:column;gap:5px;padding:4px 2px;display:flex}.profile-who strong{color:var(--ink);font-size:13px}.role-tag{text-transform:uppercase;letter-spacing:.04em;color:var(--primary-d);background:var(--accent-soft);border-radius:6px;padding:2px 7px;font-size:10px;font-weight:700;line-height:1.4}.legend{color:var(--muted);flex-wrap:wrap;align-items:center;gap:16px;margin:0 2px 10px;font-size:12px;display:flex}.legend span{align-items:center;gap:6px;display:inline-flex}.legend .lg{border-radius:4px;width:14px;height:14px;display:inline-block}.legend .lg.work{background:#a64bd629;border:1px solid #a64bd680}.legend .lg.closed{background:var(--closed);border:1px solid var(--line)}.legend .lg.blocked{background:repeating-linear-gradient(45deg,#cbd5e1,#cbd5e1 4px,#e2e8f0 4px 8px);border:1px solid #94a3b8}.legend-tip{margin-left:auto;font-style:italic}.block{color:#475569;cursor:pointer;z-index:4;background:repeating-linear-gradient(45deg,#d4dae3,#d4dae3 5px,#e7ebf1 5px 10px);border:1px solid #94a3b8;border-radius:8px;align-items:center;padding:2px 8px;display:flex;position:absolute;left:4px;right:4px;overflow:hidden}.block:hover{filter:brightness(.97)}.block-label{white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:700;overflow:hidden}.presets{flex-wrap:wrap;gap:6px;display:flex;flex-direction:row!important}.chip{border:1px solid var(--line);font:inherit;cursor:pointer;color:var(--muted);background:#fff;border-radius:99px;padding:4px 12px;font-size:12px;font-weight:600}.chip.on{background:var(--primary);color:#fff;border-color:var(--primary)}.shop-selector{border:1px solid var(--line);background:#fff;border-radius:99px;align-items:center;gap:6px;margin-left:auto;padding:4px 6px 4px 12px;display:inline-flex}.shop-selector-icon{font-size:14px}.shop-selector .ant-select{min-width:118px;font:inherit}.shop-selector .ant-select .ant-select-selector{padding-inline:4px}.shop-selector .ant-select-selection-item{color:var(--ink);padding-inline-end:20px;font-size:13px;font-weight:700}.shop-selector .ant-select-arrow{color:var(--muted);inset-inline-end:4px}.shop-badge{border:1px solid var(--line);background:#eef2ff;border-radius:10px;flex:none;place-items:center;width:38px;height:38px;font-size:18px;display:grid}.hours-list{flex-direction:column;gap:8px;padding:16px 20px;display:flex}.hours-row{border:1px solid var(--line);border-radius:10px;align-items:center;gap:10px;padding:8px 12px;display:flex}.hours-row.is-closed{background:#f8fafc}.hours-row.is-closed input[type=time]{opacity:.4}.hours-day{width:96px;font-size:13px;font-weight:700}.hours-row input[type=time]{border:1px solid var(--line);font:inherit;background:#fff;border-radius:8px;padding:6px 8px}.hours-sep{color:var(--muted)}.hours-closed{color:var(--muted);cursor:pointer;align-items:center;gap:6px;margin-left:auto;font-size:12px;font-weight:600;display:inline-flex}.hours-closed input{width:15px;height:15px}.attend-list{flex-direction:column;gap:8px;padding:12px 20px;display:flex}.attend-row{border:1px solid var(--line);border-radius:10px;align-items:center;gap:12px;padding:10px 12px;display:flex}.attend-row .staff-info{line-height:1.35}.attend-row .staff-info strong{font-size:14px}.attend-row .staff-info span{color:var(--muted);font-size:12px}.attend-row .btn{margin-left:auto}.muted-line{color:var(--muted);margin:0;font-size:12px;line-height:1.5}.menu{display:inline-flex;position:relative}.menu-caret{opacity:.7;margin-left:2px;font-size:10px}.menu-panel{background:var(--card);border:1px solid var(--line);min-width:216px;box-shadow:var(--shadow);z-index:60;border-radius:12px;flex-direction:column;gap:2px;padding:6px;animation:.12s menu-in;display:flex;position:absolute;top:calc(100% + 6px)}.menu-panel.right{right:0}.menu-panel.left{left:0}@keyframes menu-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}.menu-item{text-align:left;width:100%;font:inherit;color:var(--ink);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:9px;padding:9px 11px;font-size:13px;font-weight:600;display:flex}.menu-item:hover{background:var(--hover)}.section-title{text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:4px 0 0;font-size:12px;font-weight:700}.section-title.full{grid-column:1/-1}.logo-upload{align-items:center;gap:14px;display:flex}.logo-preview{object-fit:contain;background:var(--soft);border:1px solid var(--line);border-radius:12px;flex:none;width:56px;height:56px;padding:6px}.logo-preview.placeholder{color:var(--muted);text-align:center;justify-content:center;align-items:center;font-size:10px;font-weight:600;display:flex}.logo-upload-actions{flex-wrap:wrap;gap:8px;display:flex}.logo-upload-actions .btn{margin:0}.role-toggles{flex-direction:column;gap:6px;margin-top:8px;display:flex}.role-toggle{border:1px solid var(--line);cursor:pointer;color:var(--ink);border-radius:9px;align-items:center;gap:10px;padding:9px 11px;font-size:13px;font-weight:600;transition:border-color .15s,background .15s;display:flex}.role-toggle:hover{border-color:#cbd5e1}.role-toggle.on{border-color:var(--primary);background:var(--accent-soft)}.role-toggle input{width:16px;height:16px;accent-color:var(--primary)}.role-count{color:var(--muted);background:var(--soft);border-radius:99px;margin-left:auto;padding:1px 8px;font-size:11px;font-weight:700}@media (width<=640px){.app{padding:0}.panel{border-radius:0}.panel-head{z-index:60;background:var(--card);flex-wrap:nowrap;gap:8px;padding:10px 12px;position:sticky;top:0}.brand{flex:auto;gap:9px;min-width:0}.brand>div{min-width:0}.brand h1{display:none}.logo{width:34px;height:34px}.tagline{display:none}.panel-head-right{flex:none;gap:6px;width:auto}.shop-selector{margin-left:0;padding:3px 4px 3px 8px}.shop-selector .ant-select{min-width:0;max-width:124px}.shop-selector .ant-select-selection-item{font-size:12px}.profile-name{display:none}.profile-btn{padding:3px}.icon-nav{display:none}.admin-tabbar{display:flex}.appt-bar{flex-direction:column;align-items:flex-start;gap:10px}.appt-title{font-size:18px}.appt-tools{justify-content:flex-start;width:100%}.tools-spacer{display:none}.date-cur{min-width:0;padding:0 6px}.date-input{flex:auto}.appt-tools .btn.primary{flex:100%}.form-grid{grid-template-columns:1fr}.legend-tip{display:none}.summary{padding:14px 12px 2px}.kpi-row{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}.kpi-card{flex-direction:column;align-items:flex-start;gap:10px;padding:13px 14px}.kpi-icon{width:38px;height:38px;font-size:17px}.kpi-value{font-size:20px}.summary-cards{grid-template-columns:1fr 1fr;gap:10px}.sum-card{padding:12px}.sum-figures{gap:12px}.sum-figures b{font-size:16px}.content{padding:10px 10px calc(84px + env(safe-area-inset-bottom,0px))}.page-head{flex-direction:column;align-items:stretch;gap:10px}.page-tools{flex-direction:column;align-items:stretch;gap:10px;width:100%}.page-search,.page-add{width:100%}.cal-grid{grid-template-columns:50px repeat(var(--cols), minmax(124px, 1fr))}.cal-scroll{max-height:68vh}.cal-head{padding:9px 10px}.head-avatar{width:28px;height:28px}.cal-card,.my-appts,.reviews-card,.feedback-card{padding:14px}.book-fab{padding:12px 18px;font-size:13px;bottom:72px;right:14px}}@media (width<=380px){.summary-cards{grid-template-columns:1fr}}
