@keyframes spin{to{transform:rotate(360deg)}}:root{--sh-bg:var(--tg-theme-bg-color, #f9fafb);--sh-text:var(--tg-theme-text-color, #111);--sh-hint:var(--tg-theme-hint-color, #6b7280);--sh-btn:var(--tg-theme-button-color, #15803d);--sh-btn-text:var(--tg-theme-button-text-color, #fff);--sh-card-bg:var(--tg-theme-secondary-bg-color, #fff);--sh-card-border:#e5e7eb;--sh-green:#15803d;--sh-green-light:#dcfce7;--sh-blue:#1d4ed8;--sh-blue-light:#dbeafe;--sh-red:#dc2626;--sh-red-light:#fee2e2;--sh-orange:#d97706;--sh-orange-light:#fef3c7;--sh-radius:10px}.cal-strip{display:flex;gap:4px;overflow-x:auto;padding-bottom:2px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.cal-strip::-webkit-scrollbar{display:none}.cal-day{min-width:40px;display:flex;flex-direction:column;align-items:center;gap:2px;padding:7px 4px;border-radius:var(--sh-radius);cursor:pointer;transition:background .15s}.cal-day:hover{background:#f0fdf4}.cal-day.active{background:var(--sh-green)}.cal-day-n{font-size:9px;color:#9ca3af;text-transform:uppercase}.cal-day.active .cal-day-n{color:#bbf7d0}.cal-day-d{font-size:14px;font-weight:600;color:var(--sh-text)}.cal-day.active .cal-day-d{color:#fff}.cal-dot{border-radius:50%;background:#16a34a}.cal-day.active .cal-dot{background:#bbf7d0}.cal-dot,.no-dot{width:4px;height:4px}.slot-card{background:var(--sh-card-bg);border:1px solid var(--sh-card-border);border-radius:var(--sh-radius);padding:10px 12px;transition:border-color .15s,box-shadow .15s}.slot-card:hover{border-color:#bbf7d0;box-shadow:0 1px 4px rgba(0,0,0,.04)}.slot-card.selected{border-color:var(--sh-green);box-shadow:0 0 0 2px rgba(21,128,61,.12)}.slot-card.booked{background:#f0fdf4;border-color:#bbf7d0}.slot-card.booked:hover{border-color:var(--sh-green)}.slot-card.full{background:#fff5f5;border-color:#fecaca}.slot-card.full:hover{border-color:#fca5a5}.slot-card.past{opacity:.5}.slot-card.past:hover{opacity:.7}.slot-card.cancelled{opacity:.4;background:var(--sh-bg);border-color:var(--sh-card-border)}.slot-card.cancelled:hover{opacity:.5}.slot-card.cancelled .slot-time{text-decoration:line-through}.slot-time{font-size:13px;font-weight:700;color:var(--sh-text)}.slot-title{font-size:12px;color:var(--sh-hint);margin-top:2px}.slot-price{font-size:12px;font-weight:600;color:#0098ea;display:flex;align-items:center;gap:3px}.badge{font-size:10px;padding:2px 7px;border-radius:10px;font-weight:500;display:inline-block;white-space:nowrap}.badge.bg,.cap-bar{background:var(--sh-green-light)}.badge.bg{color:var(--sh-green)}.badge.bb{background:var(--sh-blue-light);color:var(--sh-blue)}.badge.br{background:var(--sh-red-light);color:var(--sh-red)}.badge.bgr{background:#f3f4f6;color:var(--sh-hint)}.badge.bo{background:var(--sh-orange-light);color:#92400e}.badge.bton{background:#e0f2fe;color:#0369a1}.cap-bar{height:3px;border-radius:2px;margin-top:6px;overflow:hidden}.cap-fill{height:100%;border-radius:2px;transition:width .3s}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid #f3f4f6;font-size:12px}.detail-row:last-child{border-bottom:none}.detail-label{color:var(--sh-hint)}.detail-val{font-weight:600;color:var(--sh-text)}.card{background:var(--sh-card-bg);border:1px solid var(--sh-card-border);border-radius:var(--sh-radius);padding:12px}.card.no-pad{padding:0 12px}.section-title{font-size:11px;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.btn-primary{width:100%;padding:10px 16px;border:0;border-radius:8px;background:var(--sh-green);color:var(--sh-btn-text);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.btn-primary:hover{background:#166534}.btn-primary:disabled{background:#d1d5db;color:#9ca3af;cursor:default}.btn-sm{font-size:11px;font-weight:500;padding:5px 10px;border-radius:6px;border:0;cursor:pointer;white-space:nowrap}.btn-sm-green{background:var(--sh-green);color:#fff}.btn-sm-green:hover{background:#166534}.btn-sm-red{background:#fff;color:var(--sh-red);border:1px solid #fca5a5}.btn-sm-red:hover{background:#fecaca}.btn-sm-blue{background:var(--sh-blue-light);color:#2563eb}.btn-sm-blue:hover{background:#bfdbfe}.btn-sm-outline{background:#fff;color:#374151;border:1px solid #d1d5db}.btn-sm-outline:hover{background:var(--sh-bg)}.btn-sm-disabled{background:#f3f4f6;color:var(--sh-hint);cursor:default}.btn-outline,.form-input{width:100%;border-radius:8px;font-size:13px}.btn-outline{padding:9px 16px;border:1.5px solid #16a34a;background:#fff;color:var(--sh-green);font-weight:500;cursor:pointer;transition:background .15s}.btn-outline:hover{background:#f0fdf4}.form-input{padding:8px 10px;border:1px solid #d1d5db;color:var(--sh-text);background:var(--sh-card-bg);transition:border-color .15s}.form-label{font-size:11px;font-weight:600;color:#374151;margin-bottom:3px}.form-row{display:flex;gap:8px}.form-field{flex:1;min-width:0}.form-field .form-input{width:100%;box-sizing:border-box}.form-select{width:100%;padding:8px 10px;border:1px solid #d1d5db;border-radius:8px;font-size:13px;color:var(--sh-text);background:var(--sh-card-bg)}textarea.form-input{min-height:80px;resize:vertical;font-family:inherit}.type-toggle{display:flex;background:#f3f4f6;border-radius:8px;padding:2px}.type-opt{flex:1;padding:7px 8px;font-size:12px;font-weight:500;border-radius:6px;border:0;background:0 0;color:var(--sh-hint);cursor:pointer;text-align:center;transition:background .15s,color .15s}.type-opt.active{background:#fff;color:var(--sh-text);box-shadow:0 1px 2px rgba(0,0,0,.06)}.type-opt:not(.active):hover{background:rgba(255,255,255,.5)}.view{display:none;flex-direction:column;flex:1}.view.active{display:flex}.empty-state{text-align:center;padding:20px;color:var(--sh-hint);font-size:13px}.spinner{width:32px;height:32px;border:3px solid var(--sh-green-light);border-top-color:#16a34a;border-radius:50%;animation:spin 1s linear infinite}.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:var(--sh-text);color:#fff;padding:10px 20px;border-radius:8px;font-size:13px;font-weight:600;z-index:9999;opacity:0;transition:opacity .3s;pointer-events:none;max-width:400px;text-align:center}.toast.show{opacity:1;pointer-events:auto}.user-row{display:flex;align-items:center;gap:9px;padding:8px 0;border-bottom:1px solid #f3f4f6}.tx-row:last-child,.user-row:last-child{border-bottom:none}.tx-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f3f4f6}.tx-client{font-size:12px;font-weight:500}.tx-class{font-size:11px;color:var(--sh-hint);margin-top:1px}.month-nav{display:flex;align-items:center;justify-content:center;gap:12px}.month-nav-btn{font-size:18px;color:var(--sh-hint);cursor:pointer;background:0 0;border:0;padding:4px 8px}.month-nav-btn:hover{color:var(--sh-green)}.flex-col-4,.flex-col-6,.flex-col-8{display:flex;flex-direction:column;gap:4px}.flex-col-6,.flex-col-8{gap:6px}.flex-col-8{gap:8px}.flex-col-10,.flex-col-12,.flex-col-9{display:flex;flex-direction:column;gap:9px}.flex-col-10,.flex-col-12{gap:10px}.flex-col-12{gap:12px}.flex-between,.flex-between-top{display:flex;justify-content:space-between;align-items:center}.flex-between-top{align-items:flex-start}.flex-center-3{display:flex;align-items:center;gap:3px}.flex-center-4,.flex-center-6,.flex-center-8{display:flex;align-items:center;gap:4px}.flex-center-6,.flex-center-8{gap:6px}.flex-center-8{gap:8px}.flex-center-10,.flex-center-12{display:flex;align-items:center;gap:10px}.flex-center-12{gap:12px}.flex-gap-4{display:flex;gap:4px}.flex-gap-6,.flex-gap-8{display:flex;gap:6px}.flex-gap-8{gap:8px}.text-title{font-size:13px;font-weight:700;color:var(--sh-text)}.text-hint{font-size:11px;color:var(--sh-hint)}.text-muted,.text-small-muted{font-size:12px;color:var(--sh-hint)}.text-small-muted{font-size:10px}.mt-4{margin-top:4px}.mt-6{margin-top:6px}.mt-8{margin-top:8px}.mt-10{margin-top:10px}.mt-16{margin-top:16px}.mb-4{margin-bottom:4px}.mb-6{margin-bottom:6px}.mb-8{margin-bottom:8px}.mb-10{margin-bottom:10px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}