:root{--accent:rgb(40,68,119);--line:#E6E9EF;--text:#142033;--muted:#6B7280;--bg:#F7F9FC;--card:#FFFFFF;--danger:#B42318}
*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-size:14px;letter-spacing:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:12px;background:#fff;padding:10px 12px;color:var(--text)}textarea{resize:vertical}label{display:grid;gap:7px;color:var(--muted);font-size:12px}h1,h2,h3,p{margin:0}h1{font-size:28px}h2{font-size:17px}h3{font-size:14px;margin-top:6px}.topbar{height:68px;display:flex;align-items:center;gap:28px;padding:0 28px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.88);backdrop-filter:blur(14px);position:sticky;top:0;z-index:10}.brand{font-weight:700;color:var(--accent);font-size:18px}.topbar nav{display:flex;gap:6px;flex:1}.topbar nav a,.button,.ghost,.primary,.danger{border:1px solid transparent;border-radius:12px;padding:9px 13px;background:transparent;cursor:pointer}.topbar nav a{color:var(--muted)}.topbar nav a.active,.topbar nav a:hover{background:#EEF2F7;color:var(--accent)}.primary{background:var(--accent);color:#fff}.button{border-color:var(--line);background:#fff}.ghost{color:var(--muted)}.danger{background:var(--danger);color:#fff}.ghost-danger{background:#fff;color:var(--danger);border-color:#F2B8B5}.page{max-width:1500px;margin:0 auto;padding:24px 24px 40px}.section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:18px}.section-head p{color:var(--muted);margin-top:7px}.compact-head{margin-bottom:12px}.actions{display:flex;gap:9px;align-items:center;flex-wrap:wrap}.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:0 1px 2px rgba(16,24,40,.03)}.grid.two{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(320px,.7fr);gap:18px}.stack,.stack-form{display:grid;gap:14px}.inline-form{display:flex;gap:10px}.list,.table,.timeline{display:grid;gap:10px;margin-top:14px}.list-row,.table-row{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--line);border-radius:14px;padding:12px}.list-row small,.table-row small,.visit small{display:block;color:var(--muted);margin-top:4px}.link-row:hover{background:#F7F9FC}.empty{color:var(--muted)}.badge{border:1px solid var(--line);border-radius:999px;padding:6px 9px;color:var(--muted)}.tabs{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.tabs a{padding:10px 13px;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--muted)}.tabs a.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.month-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;margin-top:16px}.dow{color:var(--muted);font-size:12px;padding:0 6px}.day{min-height:96px;border:1px solid var(--line);border-radius:14px;background:#fff;padding:10px;display:grid;gap:8px;align-content:start}.day.muted{opacity:.38}.day-num{font-weight:700}.day select{padding:8px}.shift-day{position:relative;overflow:visible}.shift-day:hover,.shift-day:focus-within{z-index:8}.shift-day.has-shift{background:color-mix(in srgb,var(--admin-color) 13%,#fff);border-color:color-mix(in srgb,var(--admin-color) 45%,#fff);box-shadow:inset 0 4px 0 var(--admin-color)}.shift-day.is-today{border-color:#AEB7C6;box-shadow:inset 0 0 0 1px #AEB7C6}.shift-day.is-today.has-shift{box-shadow:inset 0 4px 0 var(--admin-color),inset 0 0 0 1px #AEB7C6}.shift-day.is-today .day-num{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:999px;background:#EEF2F7;color:var(--accent)}.shift-display{display:grid;gap:8px;min-width:0}.shift-name{color:var(--admin-color);font-weight:700;font-size:13px;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shift-empty{color:#A0A7B3;font-size:12px}.shift-hover-actions{position:absolute;left:8px;right:8px;top:42px;opacity:0;pointer-events:none;transition:opacity .12s ease}.shift-day:hover .shift-hover-actions,.shift-day:focus-within .shift-hover-actions{opacity:1;pointer-events:auto}.shift-hover-actions select{width:max-content;min-width:100%;max-width:220px;padding:8px 10px;border-radius:10px;font-size:12px;background:#fff;box-shadow:0 14px 30px rgba(16,24,40,.16)}.admin-color-row{display:flex;align-items:center;gap:9px}.admin-color-row i{width:12px;height:12px;border-radius:999px;display:inline-block}.link{border:0;background:transparent;color:var(--muted);padding:0;text-align:left;cursor:pointer}
.booking-layout{display:grid;grid-template-columns:260px minmax(0,1fr);gap:14px;align-items:start}.booking-sidebar{display:grid;gap:12px;position:sticky;top:84px}.mini-card{padding:14px}.mini-calendar-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.mini-button{width:34px;height:34px;display:grid;place-items:center;padding:0}.mini-calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.mini-dow{font-size:11px;color:var(--muted);text-align:center}.mini-day{height:30px;display:grid;place-items:center;border-radius:10px;color:var(--text)}.mini-day:hover{background:#EEF2F7}.mini-day.muted{color:#B5BBC6}.mini-day.active{background:var(--accent);color:#fff}.segmented,.side-tabs{display:grid;gap:8px;margin-top:12px}.segmented{grid-template-columns:1fr 1fr}.segmented a,.side-tabs a{border:1px solid var(--line);border-radius:12px;padding:9px 10px;text-align:center;color:var(--muted);background:#fff}.side-tabs a{text-align:left}.segmented a.active,.side-tabs a.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.schedule-card{overflow:auto;padding:12px}.schedule{--slot-height:10px;min-width:1080px;display:grid;grid-template-columns:58px repeat(var(--day-count),minmax(138px,1fr));grid-template-rows:36px 30px auto}.schedule.day-mode{min-width:720px}.schedule-head{border-bottom:1px solid var(--line);padding:9px;color:var(--muted);font-size:12px}.corner{grid-column:1;grid-row:1/3}.day-head{text-align:center}.courts-head{display:grid;grid-template-columns:repeat(var(--court-count),minmax(0,1fr));gap:1px;border-bottom:1px solid var(--line);color:var(--muted);font-size:11px}.courts-head span{text-align:center;padding:7px 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.time-col{grid-column:1;grid-row:3}.time-cell{height:var(--slot-height);border-bottom:1px solid #F2F4F7;color:var(--muted);font-size:10px;text-align:right;padding-right:6px;line-height:10px}.time-cell.hour{color:var(--accent);font-weight:700}.day-col{display:grid;grid-template-columns:repeat(var(--court-count),minmax(0,1fr));grid-row:3;border-left:1px solid var(--line)}.court-col{position:relative;min-height:1440px;border-right:1px solid var(--line);background:linear-gradient(to bottom,#E8ECF2 0 1px,transparent 1px 120px)}.slot{height:var(--slot-height);width:100%;display:block;border:0;border-bottom:1px solid #F4F6F8;background:transparent;cursor:pointer;position:relative;padding:0}.slot span{display:none}.slot:hover{background:#DCE8F7}.slot:hover span{display:block;position:absolute;left:6px;top:-4px;background:var(--accent);color:#fff;border-radius:8px;padding:3px 6px;font-size:11px;z-index:4;box-shadow:0 8px 18px rgba(40,68,119,.18)}.booking{position:absolute;left:3px;right:3px;border:1px solid #BFD0E5;background:#EAF2FC;color:var(--accent);border-radius:9px;padding:5px;text-align:left;overflow:hidden;z-index:2;cursor:pointer}.booking span{display:block;font-size:11px;margin-top:2px}.booking em{display:block;font-size:10px;font-style:normal;color:#42526B;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.booking.cancelled{background:#F3F4F6;color:var(--muted);text-decoration:line-through}
.modal{position:fixed;inset:0;background:rgba(40,68,119,.28);display:grid;place-items:center;padding:22px;z-index:20}.modal[hidden]{display:none}.modal-card{width:min(780px,100%);max-height:92vh;overflow:auto;background:#fff;border-radius:16px;padding:18px;border:1px solid var(--line);box-shadow:0 24px 80px rgba(40,68,119,.22);display:grid;gap:14px}.modal-head,.modal-actions,.modal-total,.card-head{display:flex;justify-content:space-between;align-items:center;gap:12px}.icon{width:34px;height:34px;border-radius:10px;border:1px solid var(--line);background:#fff;cursor:pointer}.time-summary{border:1px solid #CFD8E6;background:#F4F7FB;color:var(--accent);border-radius:12px;padding:10px 12px;font-weight:700}.form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;position:relative}.suggestions{position:absolute;left:0;right:0;top:100%;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 30px rgba(16,24,40,.1);z-index:3;display:none}.suggestions button{display:block;width:100%;border:0;background:#fff;text-align:left;padding:10px;cursor:pointer}.service-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.service-row{grid-template-columns:auto 1fr 66px;align-items:center;border:1px solid var(--line);border-radius:14px;padding:10px;color:var(--text)}.service-row input[type=checkbox]{width:auto}.service-row .qty{padding:7px}.modal-total{border-top:1px solid var(--line);padding-top:14px}.danger-row{justify-content:flex-start}.check{display:flex;align-items:center;gap:8px;color:var(--text)}.check input{width:auto}.search{min-width:240px}.visit{border:1px solid var(--line);border-radius:14px;padding:12px;display:grid;gap:8px}.note{color:var(--muted)}.login-body{min-height:100vh;display:grid;place-items:center;padding:20px}.login-card{width:min(420px,100%);background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px;display:grid;gap:16px;box-shadow:0 18px 70px rgba(40,68,119,.12)}.login-card p,.error{color:var(--muted)}.error{background:#FEF3F2;color:var(--danger);border:1px solid #FEE4E2;border-radius:12px;padding:10px}
.services-top{display:grid;gap:10px;margin-bottom:14px}.service-tabs{align-items:center;margin-bottom:0}.service-tabs .button{height:40px}.new-category-form{display:flex;gap:8px;max-width:380px}.new-category-form[hidden]{display:none}.new-category-form input{height:38px}.new-category-form button{height:38px;padding:8px 12px}.services-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:14px;align-items:start}.service-panel{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden}.service-list-header,.service-row-item{display:grid;grid-template-columns:minmax(0,1fr) 112px 72px 90px 150px;gap:12px;align-items:center}.service-list-header{padding:10px 14px;background:#F8FAFC;border-bottom:1px solid var(--line);color:var(--muted);font-size:11px;text-transform:uppercase}.service-rows{display:grid}.service-row-item{min-height:58px;padding:10px 14px;border-bottom:1px solid #EEF1F5;background:#fff}.service-row-item:last-child{border-bottom:0}.service-row-item:hover{background:#FAFBFD}.service-row-item.inactive{opacity:.58}.service-main{min-width:0}.service-main strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px}.service-main small{display:block;color:var(--muted);margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.service-duration{color:var(--muted);font-size:13px}.service-price{font-weight:700;color:var(--accent);white-space:nowrap}.service-actions{display:flex;align-items:center;justify-content:flex-end;gap:6px}.service-actions .ghost{padding:6px 8px;border-radius:9px}.danger-link{color:var(--danger)}.empty-state{padding:34px 16px;color:var(--muted);text-align:center}.service-editor{position:sticky;top:84px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px}.service-editor-form{display:grid;gap:10px}.service-editor-form input,.service-editor-form select,.service-editor-form textarea{border-radius:10px;padding:8px 10px}.service-editor-form label{gap:5px}.editor-title,.editor-footer{display:flex;align-items:center;justify-content:space-between;gap:10px}.editor-title{padding-bottom:4px}.tiny-reset{padding:5px 7px;border-radius:8px}.editor-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.editor-footer{padding-top:2px}.editor-footer .primary{padding:8px 12px;border-radius:10px}
.services-page{display:grid;gap:16px}.services-toolbar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:4px}.service-pill-tabs{margin-bottom:0;gap:8px}.service-pill-tabs a{display:inline-flex;align-items:center;min-height:40px;padding:9px 14px;border:1px solid var(--line);border-radius:999px;background:#fff;color:#566070;box-shadow:0 1px 2px rgba(16,24,40,.03)}.service-pill-tabs a.active{background:var(--accent);border-color:var(--accent);color:#fff}.service-pill-tabs a:hover{border-color:#CBD5E1;color:var(--accent)}.service-pill-tabs a.active:hover{color:#fff}.services-toolbar-actions{display:flex;align-items:center;gap:10px}.add-service-button,.soft-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px}.add-service-button svg,.soft-button svg,.icon-action svg,.empty-icon svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.soft-button{background:#fff;color:var(--text);border-color:var(--line)}.new-category-form{display:flex;gap:8px;max-width:460px;margin-top:-4px}.new-category-form input{height:42px}.new-category-form button{height:42px}.service-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;align-items:stretch}.service-card-modern{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px;box-shadow:0 1px 2px rgba(16,24,40,.04);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.service-card-modern:hover{transform:translateY(-2px);border-color:#D9E0EA;box-shadow:0 14px 34px rgba(16,24,40,.08)}.service-card-modern.inactive{opacity:.56}.service-card-body{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;height:100%}.service-card-main{min-width:0}.service-card-main strong{display:block;font-size:15px;line-height:1.35;color:var(--text);overflow-wrap:anywhere}.service-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}.service-meta span{display:inline-flex;align-items:center;min-height:24px;padding:4px 8px;border:1px solid #E8EDF3;border-radius:999px;background:#F5F7FA;color:#667085;font-size:12px;line-height:1}.service-card-main p{margin-top:10px;color:var(--muted);font-size:13px;line-height:1.45;overflow-wrap:anywhere}.service-card-side{display:grid;justify-items:end;align-content:start;gap:13px;min-width:98px}.service-card-price{font-size:22px;line-height:1;font-weight:750;color:var(--accent);white-space:nowrap}.icon-actions{display:flex;gap:7px}.icon-action{width:34px;height:34px;display:grid;place-items:center;border:1px solid var(--line);border-radius:10px;background:#fff;color:#667085;cursor:pointer;transition:background .14s ease,color .14s ease,border-color .14s ease,transform .14s ease}.icon-action:hover{background:#F5F7FA;color:var(--accent);border-color:#CBD5E1}.danger-icon:hover{background:#FFF5F4;color:var(--danger);border-color:#F4C7C3}.services-empty{grid-column:1/-1;min-height:280px;display:grid;place-items:center;text-align:center;background:#fff;border:1px dashed #CDD5DF;border-radius:16px;padding:34px;color:var(--muted)}.services-empty strong{display:block;color:var(--text);font-size:17px;margin-bottom:6px}.services-empty p{max-width:360px;margin:0 auto 16px;line-height:1.45}.empty-icon{width:46px;height:46px;display:grid;place-items:center;margin:0 auto 14px;border-radius:14px;background:#EEF2F7;color:var(--accent)}.slide-panel-backdrop{position:fixed;inset:0;z-index:30;display:flex;justify-content:flex-end;background:rgba(40,68,119,.22);backdrop-filter:blur(2px)}.slide-panel-backdrop[hidden]{display:none}.slide-panel{width:min(448px,100%);height:100%;background:#fff;border-left:1px solid var(--line);box-shadow:-24px 0 70px rgba(16,24,40,.18)}.slide-panel form{height:100%;display:grid;grid-template-rows:auto 1fr auto}.slide-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px;border-bottom:1px solid var(--line)}.slide-panel-head h2{font-size:20px;line-height:1.2}.slide-panel-head p{margin-top:5px;color:var(--muted);font-size:13px;line-height:1.4}.slide-panel-body{display:grid;gap:14px;align-content:start;padding:18px;overflow:auto}.slide-panel-body label{font-size:12px}.slide-panel-body input,.slide-panel-body select,.slide-panel-body textarea{border-radius:12px}.slide-panel-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 18px;border-top:1px solid var(--line);background:#FAFBFC}.confirm-modal{position:fixed;inset:0;z-index:40;display:grid;place-items:center;padding:20px;background:rgba(40,68,119,.28);backdrop-filter:blur(2px)}.confirm-modal[hidden]{display:none}.confirm-card{width:min(420px,100%);display:grid;gap:13px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:0 24px 80px rgba(16,24,40,.22)}.confirm-card h2{font-size:19px}.confirm-card p{color:var(--muted);line-height:1.45}
.booking.draft{background:#FFF7E6;border-color:#E7C46B;border-style:dashed;color:#7A4E00}
.mini-day{position:relative}.mini-day.today{box-shadow:inset 0 0 0 1px #93A4BA;background:#F3F6FA;color:var(--accent);font-weight:700}.mini-day.active.today{background:var(--accent);color:#fff;box-shadow:0 0 0 2px #D7DEE9}.mini-day.has-booking::after{content:"";position:absolute;left:50%;bottom:3px;width:5px;height:5px;border-radius:999px;background:#E5484D;transform:translateX(-50%)}.mini-day.active.has-booking::after{background:#fff}.side-tabs a{position:relative;display:flex;align-items:center;justify-content:space-between;gap:10px}.side-tabs a.has-booking::after{content:"";width:7px;height:7px;border-radius:999px;background:#E5484D;box-shadow:0 0 0 3px rgba(229,72,77,.12);flex:0 0 auto}.side-tabs a.active.has-booking::after{background:#fff;box-shadow:0 0 0 3px rgba(255,255,255,.22)}.day-head.today{background:#F3F6FA;color:var(--accent);font-weight:800;box-shadow:inset 0 -2px 0 var(--accent)}.courts-head.today{background:#F8FAFD}.day-col.today .court-col{background:linear-gradient(to bottom,rgba(40,68,119,.08) 0 1px,rgba(40,68,119,.025) 1px 120px)}.day-col.today{box-shadow:inset 0 0 0 1px rgba(40,68,119,.12)}
.schedule-card{max-height:calc(100vh - 126px);overflow:auto;position:relative;scroll-behavior:smooth}.schedule-head{position:sticky;top:0;z-index:6;background:#fff}.corner{left:0;z-index:9}.courts-head{position:sticky;top:36px;z-index:5;background:#fff}.time-col{position:sticky;left:0;z-index:4;background:#fff}.time-cell{background:#fff}.schedule-card::-webkit-scrollbar{width:10px;height:10px}.schedule-card::-webkit-scrollbar-thumb{background:#CBD5E1;border-radius:999px;border:2px solid #fff}.schedule-card::-webkit-scrollbar-track{background:#F1F5F9;border-radius:999px}
.stepper{display:grid;grid-template-columns:36px 1fr 36px;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}.stepper button{border:0;background:#F8FAFC;color:var(--accent);font-weight:700;cursor:pointer}.stepper input{border:0;border-left:1px solid var(--line);border-right:1px solid var(--line);border-radius:0;text-align:center;padding:9px 4px}
.price-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:18px;align-items:start}.price-sheet{display:grid;gap:14px}.price-category{background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px}.price-category h2{font-size:18px;margin-bottom:12px}.price-lines{display:grid;border-top:1px solid var(--line)}.price-line{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid #EEF1F5}.price-line span{font-weight:600}.price-line small{display:inline-block;margin-left:8px;color:var(--muted);font-weight:400}.price-line strong{color:var(--accent);white-space:nowrap}.price-copy{position:sticky;top:84px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px;display:grid;gap:10px}.price-copy textarea{min-height:340px;font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:13px;line-height:1.5;white-space:pre-wrap}
@media (max-width:900px){.topbar{gap:12px;padding:0 14px;overflow-x:auto}.page{padding:18px 14px}.section-head,.grid.two,.booking-layout,.services-layout,.price-layout{display:grid;grid-template-columns:1fr}.booking-sidebar,.service-editor,.price-copy{position:static}.form-grid,.service-list{grid-template-columns:1fr}.inline-form,.new-category-form{display:grid}.actions{flex-wrap:wrap}.schedule{min-width:900px}.service-list-header{display:none}.service-row-item{grid-template-columns:1fr;gap:8px}.service-actions{justify-content:flex-start;flex-wrap:wrap}.editor-grid{grid-template-columns:1fr}.services-toolbar{display:grid;gap:12px}.services-toolbar-actions{display:grid;grid-template-columns:1fr 1fr}.add-service-button,.soft-button{width:100%}.service-card-grid{grid-template-columns:1fr}.service-card-body{align-items:flex-start}.slide-panel{width:100%}}
.history-link{display:flex;justify-content:center;margin-top:12px}.booking.waiting,.booking.active{background:#EEF4FF;border-color:#B7C8EA;color:#173B72}.booking.in_progress{background:#EAF8EF;border-color:#A9DDB8;color:#146C2E}.booking.arrived{background:#EAF2FC;border-color:#BFD0E5;color:var(--accent)}.booking.no_show{background:#FFF3F0;border-color:#F3B5A8;color:#9B2C1F}.booking.cancelled,.booking.deleted{background:#F3F4F6;color:var(--muted);border-color:#D8DEE8;text-decoration:line-through}.booking.past{filter:saturate(.72);box-shadow:inset 3px 0 0 rgba(107,114,128,.45)}.booking-modal-card{width:min(880px,100%);padding:0;gap:0;overflow:hidden}.booking-modal-card .modal-head{padding:18px 20px;border-bottom:1px solid var(--line);background:#fff}.modal-subtitle{margin-top:4px;color:var(--muted);font-size:13px}.booking-modal-card .time-summary{margin:16px 20px 0}.status-picker{display:flex;flex-wrap:wrap;gap:8px;padding:14px 20px 0}.status-pill{border:1px solid var(--line);border-radius:999px;background:#fff;color:#566070;padding:8px 12px;cursor:pointer;transition:.14s ease}.status-pill:hover{border-color:#CBD5E1;color:var(--accent)}.status-pill.active{color:#fff;border-color:transparent}.status-pill.waiting.active{background:#315F9F}.status-pill.in_progress.active{background:#198A43}.status-pill.arrived.active{background:var(--accent)}.status-pill.no_show.active{background:#B42318}.booking-modal-section{padding:16px 20px 0}.compact-form-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.section-inline-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.section-inline-title span{color:var(--muted);font-size:12px}.booking-modal-card>label{margin:16px 20px 0}.booking-modal-footer{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:12px;margin-top:18px;padding:14px 20px;border-top:1px solid var(--line);background:#FAFBFC}.booking-danger-actions{display:flex;gap:8px;align-items:center}.save-booking-button{min-width:120px}.save-booking-button:disabled{opacity:.42;cursor:not-allowed}.booking-modal-card .modal-total{border:0;padding:0;gap:8px;color:var(--muted)}.booking-modal-card .modal-total strong{color:var(--accent);font-size:18px}.history-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:14px}.history-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;display:grid;gap:10px;box-shadow:0 1px 2px rgba(16,24,40,.03)}.history-card.deleted,.history-card.cancelled{opacity:.72}.history-main{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.history-main strong{display:block;font-size:15px}.history-main small{display:block;margin-top:4px;color:var(--muted);line-height:1.35}.history-meta{display:flex;flex-wrap:wrap;gap:8px}.history-meta span{border:1px solid #E8EDF3;background:#F5F7FA;color:#667085;border-radius:999px;padding:5px 8px;font-size:12px}.history-card p{color:var(--muted);line-height:1.45}.status-chip{display:inline-flex;align-items:center;white-space:nowrap;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:700;background:#EEF2F7;color:var(--accent)}.status-chip.waiting,.status-chip.active{background:#EEF4FF;color:#315F9F}.status-chip.in_progress{background:#EAF8EF;color:#198A43}.status-chip.arrived{background:#EEF2F7;color:var(--accent)}.status-chip.no_show,.status-chip.deleted{background:#FFF3F0;color:#B42318}.status-chip.cancelled{background:#F3F4F6;color:#667085}
@media (max-width:900px){.compact-form-grid{grid-template-columns:1fr}.booking-modal-footer{grid-template-columns:1fr}.booking-danger-actions{order:2;flex-wrap:wrap}.history-list{grid-template-columns:1fr}}
.booking-preview{position:fixed;z-index:80;width:min(340px,calc(100vw - 24px));pointer-events:none;opacity:0;transform:translateY(4px);transition:opacity .12s ease,transform .12s ease;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;box-shadow:0 18px 50px rgba(16,24,40,.18);display:grid;gap:9px}.booking-preview.visible{opacity:1;transform:translateY(0)}.booking-preview-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.booking-preview-head strong{font-size:15px;line-height:1.25;color:var(--text);overflow-wrap:anywhere}.booking-preview-head em{font-style:normal;border-radius:999px;padding:4px 8px;font-size:11px;font-weight:700;white-space:nowrap;background:#EEF2F7;color:var(--accent)}.booking-preview-head em.waiting,.booking-preview-head em.active{background:#EEF4FF;color:#315F9F}.booking-preview-head em.in_progress{background:#EAF8EF;color:#198A43}.booking-preview-head em.no_show,.booking-preview-head em.deleted{background:#FFF3F0;color:#B42318}.booking-preview-head em.cancelled{background:#F3F4F6;color:#667085}.booking-preview-time{color:var(--accent);font-weight:700;font-size:13px}.booking-preview-meta{display:flex;flex-wrap:wrap;gap:6px}.booking-preview-meta span,.booking-preview-meta strong{border:1px solid #E8EDF3;background:#F5F7FA;color:#667085;border-radius:999px;padding:5px 8px;font-size:12px}.booking-preview-meta strong{color:var(--accent);background:#EEF2F7}.booking-preview-services,.booking-preview p{color:var(--muted);font-size:12px;line-height:1.4}
.service-list-board{display:grid;gap:10px}.service-list-item{display:grid;grid-template-columns:38px minmax(0,1fr) 110px 82px;gap:12px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 14px;box-shadow:0 1px 2px rgba(16,24,40,.04);transition:box-shadow .14s ease,transform .14s ease,border-color .14s ease}.service-list-item:hover{border-color:#D5DCE7;box-shadow:0 10px 24px rgba(16,24,40,.06)}.service-list-item.dragging{opacity:.48;transform:scale(.995);border-style:dashed}.drag-handle{width:30px;height:30px;border:1px solid var(--line);border-radius:9px;background:#F8FAFC;color:#98A2B3;cursor:grab;font-weight:800;line-height:1}.drag-handle:active{cursor:grabbing}.service-list-main{min-width:0}.service-list-main strong{display:block;font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.service-list-price{font-size:18px;font-weight:750;color:var(--accent);text-align:right;white-space:nowrap}.service-list-item.inactive{opacity:.55}.price-category-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:12px}.price-category-head h2{margin:0}.price-script-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:start;margin-top:12px}.price-script{min-height:0;overflow:hidden;resize:none;font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:13px;line-height:1.45;background:#F8FAFC;white-space:pre-wrap}.price-script-row .button{height:40px;white-space:nowrap}.muted-text{color:var(--muted);margin-top:10px}
@media (max-width:900px){.service-list-item{grid-template-columns:34px minmax(0,1fr);align-items:start}.service-list-price{grid-column:2;text-align:left}.service-list-item .icon-actions{grid-column:2;justify-content:flex-start}.price-category-head{display:grid}.price-script-row{grid-template-columns:1fr}.price-script-row .button{width:100%}}

/* Compact desktop pass */
:root{--page-wide:1280px;--page-regular:1120px;--page-narrow:980px}
.topbar{height:60px;padding:0 22px;gap:22px}.brand{font-size:17px}.topbar nav a,.button,.ghost,.primary,.danger{padding:8px 12px;border-radius:11px}.page{max-width:var(--page-regular);padding:22px 18px 34px}.section-head{margin-bottom:14px}.section-head h1{font-size:26px}.section-head p{margin-top:5px}.card,.price-category{border-radius:14px;padding:14px}.price-sheet{max-width:920px;gap:12px}.price-category h2{font-size:17px;margin-bottom:10px}.price-lines{border-top-color:#EEF1F5}.price-line{display:grid;grid-template-columns:minmax(0,1fr) 86px;gap:14px;align-items:baseline;padding:9px 0}.price-line span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.price-line small{font-size:12px}.price-line strong{text-align:right}.price-script-row{grid-template-columns:minmax(0,1fr) 116px;gap:10px}.price-script{font-size:12px;padding:10px 12px}.price-script-row .button{height:38px;padding:8px 10px}.service-list-board{max-width:920px}.service-list-item{padding:10px 12px}.booking-layout{grid-template-columns:238px minmax(0,1fr)}.booking-sidebar{top:76px}.schedule-card{max-height:calc(100vh - 108px)}

@media (min-width:1500px){.page{max-width:var(--page-wide)}.price-sheet,.service-list-board{max-width:980px}}
@media (max-width:1280px){.page{max-width:var(--page-narrow);padding-left:16px;padding-right:16px}.topbar{padding:0 18px}.price-sheet,.service-list-board{max-width:860px}.price-line{grid-template-columns:minmax(0,1fr) 78px}.booking-layout{grid-template-columns:230px minmax(0,1fr);gap:12px}}
@media (max-width:1100px){body{font-size:13px}.page{max-width:940px;padding-top:18px}.section-head h1{font-size:24px}.price-sheet,.service-list-board{max-width:820px}.price-category{padding:12px}.price-line{padding:8px 0}.topbar{gap:16px}.topbar nav{gap:4px}.topbar nav a{padding:7px 10px}.booking-layout{grid-template-columns:220px minmax(0,1fr)}.mini-card{padding:12px}.schedule{min-width:960px}.schedule.day-mode{min-width:660px}}
@media (max-aspect-ratio:5/4) and (min-width:901px){.page{max-width:920px;padding:18px 14px 28px}.topbar{height:56px}.section-head{margin-bottom:12px}.price-sheet,.service-list-board{max-width:780px}.price-line{grid-template-columns:minmax(0,1fr) 74px;gap:10px}.price-script-row{grid-template-columns:minmax(0,1fr) 108px}.booking-layout{grid-template-columns:210px minmax(0,1fr)}.booking-sidebar{top:68px}.schedule-card{max-height:calc(100vh - 96px)}}

/* Work screens refinement */
.shifts-layout{display:grid;grid-template-columns:minmax(620px,1fr) minmax(220px,300px);gap:14px;align-items:start}.shift-side{display:grid;gap:12px}.shift-side-card{min-height:auto}.shift-side-card .inline-form{display:grid;grid-template-columns:minmax(0,1fr) auto}.shift-side-card .list{gap:8px}.shift-side-card .list-row{padding:10px 12px}.history-feed{display:grid;gap:8px;max-width:940px}.history-row{display:grid;grid-template-columns:112px minmax(0,1fr) 82px;gap:14px;align-items:start;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 14px}.history-row.cancelled,.history-row.deleted{opacity:.72}.history-row-time{display:grid;gap:3px;color:var(--muted)}.history-row-time strong{color:var(--accent);font-size:13px}.history-row-time span{font-size:12px}.history-row-main{display:grid;gap:6px;min-width:0}.history-row-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.history-row-main small{color:var(--muted)}.history-row-price{text-align:right;color:var(--accent);white-space:nowrap}.inline-service-list{margin:0;padding-left:18px;color:var(--muted);display:grid;gap:3px}.clients-layout{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:14px;align-items:start}.clients-list-card{min-width:0}.client-create-card{position:sticky;top:76px}.client-list{display:grid;gap:8px;margin-top:12px}.client-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;border:1px solid var(--line);border-radius:12px;padding:10px 12px;background:#fff}.client-row:hover{background:#F7F9FC}.client-row strong{display:block}.client-row small{display:block;color:var(--muted);margin-top:3px}.client-detail-layout{display:grid;grid-template-columns:300px minmax(0,1fr);gap:14px;align-items:start}.client-edit-card{position:sticky;top:76px}.price-sheet{max-width:760px}.price-line{grid-template-columns:minmax(0,1fr) 68px;gap:8px}.price-category{padding:12px}.price-line{padding:8px 0}.price-script-row{grid-template-columns:minmax(0,1fr) 104px}
@media (min-width:1500px){.shifts-layout{grid-template-columns:minmax(760px,1fr) 300px}.price-sheet{max-width:820px}}
@media (max-width:1280px){.shifts-layout{grid-template-columns:minmax(590px,1fr) 260px}.month-grid{gap:6px}.day{min-height:88px;padding:9px}.shift-side-card{padding:12px}.price-sheet{max-width:760px}.clients-layout{grid-template-columns:minmax(0,1fr) 270px}.client-detail-layout{grid-template-columns:270px minmax(0,1fr)}}
@media (max-width:1100px){.shifts-layout{grid-template-columns:minmax(560px,1fr) 230px;gap:12px}.shift-side-card .inline-form{grid-template-columns:1fr}.shift-side-card .inline-form button{width:100%}.day{min-height:78px;padding:8px}.shift-name{font-size:12px}.shift-empty{font-size:11px}.price-sheet{max-width:720px}.price-line{grid-template-columns:minmax(0,1fr) 64px}.history-row{grid-template-columns:96px minmax(0,1fr) 72px}.clients-layout{grid-template-columns:minmax(0,1fr) 250px}}
@media (max-aspect-ratio:5/4) and (min-width:901px){.shifts-layout{grid-template-columns:minmax(600px,1fr) 200px;gap:10px}.shift-side-card{padding:10px}.shift-side-card h2{font-size:15px}.shift-side-card .list-row{padding:8px 10px}.month-grid{gap:5px}.day{min-height:82px;padding:8px}.price-sheet{max-width:680px}.price-line{grid-template-columns:minmax(0,1fr) 62px;gap:6px}.price-category{padding:11px}.clients-layout{grid-template-columns:minmax(0,1fr) 230px}.client-detail-layout{grid-template-columns:230px minmax(0,1fr)}}
@media (max-width:900px){.shifts-layout,.clients-layout,.client-detail-layout{grid-template-columns:1fr}.client-create-card,.client-edit-card{position:static}.history-row{grid-template-columns:1fr}.history-row-price{text-align:left}.history-row-head{display:grid}.price-sheet{max-width:100%}}

/* Directory */
.directory-grid{display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));gap:14px;max-width:760px}.directory-tile{display:grid;gap:10px;min-height:170px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:0 1px 2px rgba(16,24,40,.03);transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.directory-tile:hover{transform:translateY(-2px);border-color:#D5DCE7;box-shadow:0 12px 28px rgba(16,24,40,.07)}.directory-tile strong{font-size:18px;color:var(--accent)}.directory-tile small{max-width:280px;color:var(--muted);line-height:1.45}.directory-icon{width:42px;height:42px;display:grid;place-items:center;border-radius:13px;background:#EEF2F7;color:var(--accent);font-size:20px;font-weight:800}.directory-shell{display:grid;grid-template-columns:220px minmax(0,1fr);gap:14px;align-items:start}.directory-nav{position:sticky;top:76px;display:grid;gap:8px;padding:10px}.directory-nav a{display:grid;gap:3px;border-radius:12px;padding:11px 12px;color:var(--muted)}.directory-nav a strong{color:var(--text)}.directory-nav a small{font-size:12px}.directory-nav a.active,.directory-nav a:hover{background:#EEF2F7;color:var(--accent)}.directory-nav a.active strong{color:var(--accent)}.directory-content{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:14px;align-items:start}.directory-list,.directory-form{display:grid;gap:14px}.directory-form{position:sticky;top:76px}.directory-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.directory-card-head h2{font-size:18px}.copy-status{min-height:18px;color:var(--muted);font-size:12px}.social-list{display:grid;gap:8px}.social-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;border:1px solid var(--line);border-radius:12px;background:#fff;padding:12px}.social-row strong{display:block;color:var(--text);margin-bottom:3px}.social-row a{display:block;color:var(--accent);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.social-row small,.template-card small{display:block;color:var(--muted);margin-top:4px;line-height:1.35}.row-actions{display:flex;align-items:center;justify-content:flex-end;gap:7px;flex-wrap:wrap}.row-actions form{margin:0}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:10px}.template-card{display:grid;gap:10px;border:1px solid var(--line);border-radius:12px;background:#fff;padding:13px;box-shadow:0 1px 2px rgba(16,24,40,.03)}.template-card strong{display:block;color:var(--text);font-size:15px}.template-card pre{max-height:180px;overflow:auto;margin:0;border:1px solid #EEF1F5;border-radius:10px;background:#F8FAFC;padding:10px;color:var(--text);font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:12px;line-height:1.45;white-space:pre-wrap}.directory-empty{display:grid;place-items:center;text-align:center;min-height:220px;border:1px dashed #CDD5DF;border-radius:14px;color:var(--muted);padding:24px}.directory-empty strong{color:var(--text);margin-bottom:4px}.directory-form textarea{resize:vertical}.directory-form .primary{width:100%}
@media (max-width:1100px){.directory-shell{grid-template-columns:190px minmax(0,1fr)}.directory-content{grid-template-columns:minmax(0,1fr) 280px}.directory-form{padding:12px}.social-row{grid-template-columns:1fr}.row-actions{justify-content:flex-start}.template-grid{grid-template-columns:1fr}}
@media (max-width:900px){.directory-grid,.directory-shell,.directory-content{grid-template-columns:1fr}.directory-nav,.directory-form{position:static}.directory-grid{max-width:100%}}

/* Booking schedule compression and modal redesign */
.shift-day.locked{cursor:default}.shift-day.locked:hover{z-index:1}.shift-day.locked .shift-display{pointer-events:none}
.schedule{--slot-height:30px;--minute-height:1px}.time-cell{height:var(--slot-height);line-height:var(--slot-height);font-size:11px}.court-col{min-height:720px;background:linear-gradient(to bottom,#E8ECF2 0 1px,transparent 1px 30px)}.day-col.today .court-col{background:linear-gradient(to bottom,rgba(40,68,119,.08) 0 1px,rgba(40,68,119,.025) 1px 30px)}.slot{height:var(--slot-height);border-bottom:1px solid #EDF1F5}.slot:hover span{top:3px}.booking{min-height:18px;padding:4px 5px}.booking span{font-size:10px}.booking em{font-size:9px}
.now-line{position:absolute;left:0;right:0;height:0;border-top:2px solid #E5484D;z-index:7;pointer-events:none}.now-line span{position:absolute;left:4px;top:-12px;background:#E5484D;color:#fff;border-radius:999px;padding:2px 6px;font-size:10px;font-weight:700;white-space:nowrap;box-shadow:0 6px 14px rgba(229,72,77,.18)}
.mini-day.has-future-booking::after,.mini-day.has-past-booking::after{content:"";position:absolute;left:50%;bottom:3px;width:5px;height:5px;border-radius:999px;transform:translateX(-50%)}.mini-day.has-future-booking::after{background:#E5484D}.mini-day.has-past-booking::after{background:#AEB7C6}.mini-day.active.has-future-booking::after,.mini-day.active.has-past-booking::after{background:#fff}
.booking-modal-redesign{width:min(1180px,calc(100vw - 32px));max-height:92vh;overflow:auto;padding:0;gap:0}.booking-modal-grid{display:grid;grid-template-columns:250px minmax(300px,1fr) 280px;gap:12px;padding:14px 18px 0}.booking-time-panel,.booking-services-panel,.booking-client-panel{display:grid;align-content:start;gap:12px;min-width:0;border:1px solid #EEF1F5;background:#FAFBFD;border-radius:14px;padding:12px}.panel-mini-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.panel-mini-head span{font-weight:750;color:var(--accent)}.panel-mini-head .ghost,.panel-mini-head .button{padding:6px 8px;border-radius:9px;font-size:12px}.time-edit-grid{display:grid;gap:9px}.duration-box{display:grid;gap:3px;border:1px solid var(--line);background:#fff;border-radius:12px;padding:10px}.duration-box small,.duration-box span{color:var(--muted);font-size:12px}.duration-box strong{font-size:20px;color:var(--accent)}.booking-service-list{grid-template-columns:1fr;gap:8px;max-height:430px;overflow:auto;padding-right:2px}.booking-service-list .service-row{border-radius:12px;padding:9px;grid-template-columns:auto minmax(0,1fr) 58px;background:#fff}.booking-service-list .service-row strong{font-size:13px}.booking-service-list .service-row small{font-size:11px;color:var(--muted)}.booking-client-panel{position:relative}.client-fields{display:grid;gap:10px}.client-history-panel{display:grid;gap:10px}.client-history-panel[hidden]{display:none}.client-history-list{display:grid;gap:8px;max-height:390px;overflow:auto}.client-history-item{display:grid;gap:6px;border:1px solid var(--line);border-radius:12px;background:#fff;padding:10px}.client-history-item strong{font-size:13px}.client-history-item small{display:block;color:var(--muted);margin-top:3px}.client-history-item b{color:var(--accent)}.client-history-item ul{margin:0;padding-left:18px;color:var(--muted);display:grid;gap:2px}.client-history-item p{color:var(--muted);font-size:12px;line-height:1.35}.booking-comment-wide{margin:14px 18px 0}.booking-modal-redesign .status-picker{padding:12px 18px 0}.booking-modal-redesign .modal-head{padding:14px 18px}.booking-modal-redesign .booking-modal-footer{margin-top:14px}
@media (max-width:1180px){.booking-modal-grid{grid-template-columns:230px minmax(280px,1fr) 250px;gap:10px;padding:12px 14px 0}.booking-time-panel,.booking-services-panel,.booking-client-panel{padding:10px}.booking-service-list{max-height:360px}.client-history-list{max-height:320px}}
@media (max-width:980px){.booking-modal-grid{grid-template-columns:1fr}.booking-service-list,.client-history-list{max-height:260px}.booking-modal-redesign{width:min(760px,calc(100vw - 24px))}}

/* Booking 15-minute grid and YClients-like modal */
.schedule{--slot-height:20px;--minute-height:1.333333px;padding-right:48px}.time-cell{height:var(--slot-height);line-height:var(--slot-height);font-size:10px}.court-col{min-height:1120px;background:linear-gradient(to bottom,#E8ECF2 0 1px,transparent 1px 20px)}.day-col.today .court-col{background:linear-gradient(to bottom,rgba(40,68,119,.08) 0 1px,rgba(40,68,119,.025) 1px 20px)}.slot{height:var(--slot-height)}.slot:hover span{top:1px}.now-line span{left:auto;right:-42px;top:-10px;padding:2px 7px;background:#fff;color:#E5484D;border:1px solid #F1B6B8;box-shadow:0 6px 16px rgba(16,24,40,.12)}
.booking-modal-redesign{width:min(1200px,calc(100vw - 36px));max-height:90vh;overflow:auto;padding:0;background:#fff;border-radius:18px;gap:0}.booking-modal-redesign .booking-modal-grid{display:grid;grid-template-columns:270px minmax(420px,1fr) 300px;gap:0;padding:0;min-height:min(720px,82vh)}.booking-side-panel,.booking-center-panel,.booking-client-panel{min-width:0}.booking-side-panel{display:grid;align-content:start;gap:16px;background:#F4F6F9;border-right:1px solid var(--line);padding:24px}.booking-side-card{display:grid;gap:12px;background:transparent;border:0;border-radius:0;padding:0}.booking-comment-card textarea{min-height:160px;resize:vertical;background:#fff}.booking-center-panel{display:grid;grid-template-rows:auto minmax(0,1fr) auto;gap:16px;padding:24px 28px}.booking-modal-title{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}.booking-modal-title h2{font-size:22px}.booking-modal-title p{margin-top:4px;color:var(--muted)}.booking-client-panel{display:grid;align-content:start;gap:18px;background:#F8FAFC;border-left:1px solid var(--line);padding:24px}.booking-client-panel .suggestions{position:relative;top:auto}.compact-status-picker{display:flex;flex-wrap:wrap;gap:7px;padding:0}.compact-status-picker .status-pill{padding:7px 10px;font-size:12px}.booking-service-list{grid-template-columns:1fr;gap:8px;max-height:none;overflow:auto;padding-right:4px}.booking-service-list .service-row{display:grid;grid-template-columns:auto minmax(0,1fr) 58px;border-radius:13px;background:#fff;padding:10px 12px}.booking-payline{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;border-top:1px solid var(--line);padding-top:16px}.booking-payline span{color:var(--muted);font-size:18px}.booking-payline strong{color:var(--accent);font-size:30px;line-height:1}.client-history-button{height:72px;border:1px solid var(--line);border-radius:14px;background:#fff;color:var(--accent);font-weight:700;cursor:pointer}.client-history-button:hover{background:#F3F6FA}.booking-client-extra{display:grid;gap:7px;margin-top:8px;color:var(--muted)}.booking-client-extra strong{color:var(--text);font-size:16px}.booking-modal-footer-redesign{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:0;padding:16px 24px;border-top:1px solid var(--line);background:#fff}.booking-modal-footer-redesign .save-booking-button{margin-left:auto;min-width:170px}.booking-modal-footer-redesign .booking-danger-actions{display:flex;gap:8px}.time-summary{font-size:15px}.duration-box{background:#fff}.client-history-list{max-height:260px}.client-history-item{background:#fff}
@media (max-width:1100px){.booking-modal-redesign .booking-modal-grid{grid-template-columns:240px minmax(340px,1fr) 260px}.booking-side-panel,.booking-center-panel,.booking-client-panel{padding:18px}.booking-payline strong{font-size:26px}}
@media (max-width:920px){.booking-modal-redesign{width:min(760px,calc(100vw - 24px))}.booking-modal-redesign .booking-modal-grid{grid-template-columns:1fr;min-height:0}.booking-side-panel,.booking-center-panel,.booking-client-panel{border:0;border-bottom:1px solid var(--line)}.booking-service-list{max-height:300px}.booking-modal-footer-redesign{position:sticky;bottom:0}}

/* Booking workbench modal */
.booking-modal-workbench{width:min(1220px,calc(100vw - 36px));max-height:90vh;overflow:hidden;padding:0;border-radius:20px;background:#fff;display:grid;grid-template-columns:260px minmax(440px,1fr) 286px;grid-template-rows:minmax(0,1fr) auto;gap:0}.booking-left{grid-column:1;grid-row:1 / 3;background:#F4F6FA;border-right:1px solid #E1E7EF;padding:16px;display:grid;align-content:start;gap:12px;overflow:auto}.booking-main{grid-column:2;grid-row:1;display:grid;grid-template-rows:auto auto minmax(0,1fr) auto;gap:14px;padding:18px;min-width:0;overflow:hidden}.booking-right{grid-column:3;grid-row:1 / 3;border-left:1px solid #E1E7EF;background:#fff;padding:18px;display:grid;align-content:start;gap:14px;overflow:auto}.booking-modal-workbench .booking-modal-footer-redesign{grid-column:2;grid-row:2;margin:0;padding:12px 18px;border-top:1px solid #E1E7EF;background:#fff}.booking-left-summary{display:grid;gap:5px;border:1px solid #E1E7EF;background:#fff;border-radius:14px;padding:14px}.booking-left-summary strong{font-size:15px;color:var(--accent);line-height:1.25}.booking-left-summary span{color:var(--muted);font-size:13px}.booking-left-card{display:grid;gap:10px;border:1px solid #E1E7EF;background:#fff;border-radius:14px;padding:12px}.booking-left-card label,.booking-right label{gap:5px}.time-pair{display:grid;grid-template-columns:1fr 1fr;gap:8px}.mini-title{font-size:14px;color:var(--accent)}.booking-comment-card textarea{min-height:104px;resize:vertical}.booking-modal-workbench .duration-box{border-color:#E1E7EF;padding:9px}.booking-modal-workbench .duration-box strong{font-size:18px}.booking-modal-workbench .compact-status-picker{display:flex;flex-wrap:wrap;gap:7px;padding:0}.booking-modal-workbench .status-pill{padding:7px 10px;font-size:12px}.booking-modal-workbench .status-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}.booking-modal-title{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}.booking-modal-title h2{font-size:22px}.booking-modal-title p{margin-top:4px;color:var(--muted);font-size:13px}.selected-services-panel{display:grid;gap:8px}.selected-services-list{display:grid;gap:8px;max-height:168px;overflow:auto}.selected-empty{border:1px dashed #CAD3DF;border-radius:12px;padding:16px;text-align:center;color:var(--muted);background:#F8FAFC}.selected-service-row{display:grid;grid-template-columns:minmax(0,1fr) 58px 82px 32px;gap:8px;align-items:center;border:1px solid #E1E7EF;border-radius:12px;background:#fff;padding:9px 10px}.selected-service-row strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.selected-service-row small{display:block;color:var(--muted);margin-top:3px}.selected-service-row input{padding:7px 6px;text-align:center;border-radius:9px}.selected-service-row b{text-align:right;color:var(--accent);white-space:nowrap}.selected-service-row button{width:30px;height:30px;border:1px solid #F1B6B8;background:#FFF7F7;color:var(--danger);border-radius:9px;cursor:pointer}.service-picker-panel{display:grid;grid-template-rows:auto auto minmax(0,1fr);gap:10px;min-height:0}.service-picker-tabs{display:grid;grid-template-columns:1fr 1fr;border:1px solid #E1E7EF;border-radius:12px;padding:3px;background:#F4F6FA}.service-picker-tabs button{border:0;border-radius:9px;background:transparent;padding:8px;color:var(--muted);cursor:pointer}.service-picker-tabs button.active{background:#fff;color:var(--accent);box-shadow:0 1px 2px rgba(16,24,40,.05)}.service-picker-tabs button:disabled{cursor:not-allowed;opacity:.55}.service-search{height:38px}.service-picker-list{display:grid;gap:8px;overflow:auto;padding-right:3px}.service-pick-row{display:grid;grid-template-columns:minmax(0,1fr) 34px;gap:10px;align-items:center;border:1px solid #E1E7EF;border-radius:12px;background:#fff;padding:9px 10px}.service-pick-row strong{display:block;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.service-pick-row small{display:block;color:var(--muted);font-size:12px;margin-top:3px}.service-add-button{width:32px;height:32px;border:0;border-radius:10px;background:var(--accent);color:#fff;font-size:18px;line-height:1;cursor:pointer}.hidden-service-fields{display:none}.booking-main-footer{display:flex;align-items:center;justify-content:space-between;gap:14px;border-top:1px solid #E1E7EF;padding-top:12px;background:#fff}.booking-main-footer .booking-payline{border:0;padding:0;display:flex;align-items:baseline;gap:10px}.booking-main-footer .booking-payline span{font-size:14px;color:var(--muted)}.booking-main-footer .booking-payline strong{font-size:28px;color:var(--accent)}.booking-main-footer .save-booking-button{min-width:158px}.booking-right .client-fields{display:grid;gap:10px;position:relative}.booking-right .suggestions{position:absolute;top:100%;left:0;right:0}.booking-right .client-history-button{height:68px}.booking-modal-workbench .client-history-list{max-height:260px}.booking-modal-footer-redesign .booking-danger-actions{display:flex;gap:8px;flex-wrap:wrap}.booking-modal-footer-redesign:empty{display:none}
.suggestions mark{background:#FFF2B8;color:inherit;border-radius:4px;padding:0 2px}
@media (max-width:1120px){.booking-modal-workbench{grid-template-columns:240px minmax(360px,1fr) 260px}.booking-left,.booking-main,.booking-right{padding:14px}.selected-service-row{grid-template-columns:minmax(0,1fr) 52px 72px 30px}}
@media (max-width:940px){.booking-modal-workbench{width:min(760px,calc(100vw - 24px));grid-template-columns:1fr;grid-template-rows:auto auto auto auto;overflow:auto}.booking-left,.booking-main,.booking-right,.booking-modal-workbench .booking-modal-footer-redesign{grid-column:1;grid-row:auto;border-left:0;border-right:0}.booking-left{max-height:none}.booking-main{overflow:visible}.service-picker-list{max-height:260px}.booking-main-footer{position:sticky;bottom:0}.booking-right{border-top:1px solid #E1E7EF}}

/* Booking modal compact corrections */
.booking-modal-workbench .booking-main{grid-template-rows:auto auto auto minmax(0,1fr) auto;gap:12px}.booking-top-status{padding-bottom:2px}.booking-modal-workbench .status-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}.booking-modal-workbench .selected-services-list{max-height:148px}.booking-modal-workbench .selected-empty{padding:12px}.booking-modal-workbench .selected-service-row{grid-template-columns:minmax(0,1fr) 98px 76px 32px;padding:8px 10px}.selected-qty-stepper{display:grid;grid-template-columns:28px 1fr 28px;border:1px solid #E1E7EF;border-radius:10px;overflow:hidden}.selected-qty-stepper button{width:auto!important;height:30px!important;border:0!important;border-radius:0!important;background:#F4F6FA!important;color:var(--accent)!important;cursor:pointer}.selected-qty-stepper input{border:0;border-left:1px solid #E1E7EF;border-right:1px solid #E1E7EF;border-radius:0;padding:5px 2px;text-align:center}.booking-modal-workbench .selected-service-row>button{width:30px;height:30px;border:1px solid #F1B6B8;background:#FFF7F7;color:var(--danger);border-radius:9px;cursor:pointer}.booking-modal-workbench .service-picker-panel{grid-template-rows:auto minmax(0,1fr);gap:10px}.booking-modal-workbench .service-picker-tabs{display:block;border:0;background:transparent;padding:0}.booking-modal-workbench .service-picker-tabs button{border:0;border-radius:10px;background:#EEF2F7;padding:8px 12px;color:var(--accent);font-weight:700}.booking-modal-workbench .service-search{height:36px}.booking-modal-workbench .service-picker-list{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:8px;align-content:start;max-height:260px}.booking-modal-workbench .service-pick-row{grid-template-columns:minmax(0,1fr) 32px;gap:8px;padding:8px 9px;min-height:58px}.booking-modal-workbench .service-pick-row small{font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.booking-modal-workbench .service-add-button{width:30px;height:30px}.booking-comment-card textarea::placeholder{color:transparent}

/* Unified services and price */
.services-price-page{gap:14px}.services-price-page .services-toolbar{align-items:flex-start}.service-price-card{display:grid;gap:12px;max-width:980px}.service-price-card .price-category-head{margin-bottom:0}.unified-service-list{max-width:100%;gap:8px}.service-price-item{grid-template-columns:38px minmax(0,1fr) 92px 132px}.service-price-item.temp-hidden{opacity:.42;background:#F1F4F8}.service-price-item.temp-hidden .service-list-main strong{text-decoration:line-through}.service-price-actions{justify-content:flex-end}.service-visibility-toggle{color:#475467}.service-price-item.temp-hidden .service-visibility-toggle{background:#EEF2F7;color:var(--accent);border-color:#CBD5E1}.copy-status{display:inline-block;min-height:18px;color:var(--muted);font-size:12px}
@media (max-width:900px){.service-price-item{grid-template-columns:34px minmax(0,1fr)}.service-price-item .service-list-price,.service-price-item .service-price-actions{grid-column:2}.service-price-actions{justify-content:flex-start}}

.service-public-check{
  align-self:end;
  min-height:42px;
  padding:10px 0;
}

.public-booking-widget .public-counter button:disabled{
  opacity:.38;
  cursor:not-allowed;
}

/* Commercial offers inside services */
.service-mode-tabs{display:inline-flex;align-items:center;gap:5px;width:max-content;max-width:100%;padding:4px;border:1px solid var(--line);border-radius:15px;background:#EEF2F7;margin-top:-4px}
.service-mode-tabs a{display:inline-flex;align-items:center;min-height:36px;padding:8px 13px;border-radius:11px;color:#566070;font-weight:650;white-space:nowrap}
.service-mode-tabs a.active{background:#fff;color:var(--accent);box-shadow:0 1px 2px rgba(16,24,40,.06)}
.offer-notes-card{max-width:1100px}
.offer-list-board{display:grid;gap:12px;max-width:100%}
.offer-note-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));align-items:stretch}
.offer-item{display:grid;grid-template-rows:1fr auto;gap:12px;align-items:start;min-height:190px;border:1px solid var(--line);border-radius:14px;background:#fff;padding:16px;box-shadow:0 1px 2px rgba(16,24,40,.03);transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease;user-select:text}
.offer-item:hover{transform:translateY(-2px);border-color:#D9E0EA;box-shadow:0 12px 28px rgba(16,24,40,.08)}
.offer-main{min-width:0}
.offer-main strong{display:block;color:var(--text);font-size:15px;line-height:1.35;overflow-wrap:anywhere}
.offer-main p{margin-top:6px;color:var(--muted);font-size:13px;line-height:1.45;white-space:pre-wrap;overflow-wrap:anywhere}
.offer-actions{justify-content:flex-end;align-self:end;user-select:none}
.offer-actions form{margin:0}
@media (max-width:900px){.service-mode-tabs{width:100%;overflow:auto}.offer-note-grid{grid-template-columns:1fr}.offer-actions{justify-content:flex-start}}

/* Trainers */
.trainers-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:16px;align-items:start}.trainer-list{display:grid;gap:12px}.trainer-card{display:grid;gap:14px}.trainer-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}.trainer-card-head p{margin-top:6px;color:var(--muted);line-height:1.45}.trainer-edit{border-top:1px solid var(--line);padding-top:10px}.trainer-edit summary{cursor:pointer;color:var(--accent);font-weight:700}.trainer-bookings{display:grid;gap:8px;border-top:1px solid var(--line);padding-top:12px}.trainer-booking-row{display:flex;justify-content:space-between;gap:12px;border:1px solid #EEF1F5;border-radius:12px;padding:9px 10px;background:#FAFBFD}.trainer-booking-row small{color:var(--muted)}.trainer-create-form{position:sticky;top:84px;display:grid;gap:12px}.trainer-public-page{max-width:1240px}.trainer-week-board{display:grid;grid-template-columns:repeat(7,minmax(150px,1fr));gap:10px;overflow-x:auto;padding-bottom:10px}.trainer-day-card{display:grid;gap:10px;min-width:150px}.trainer-day-card.locked{opacity:.6}.trainer-day-card.locked .trainer-time-rail{pointer-events:none}.trainer-day-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.trainer-day-head strong{display:block;color:var(--accent)}.trainer-day-head span,.trainer-day-head small{display:inline-block;margin-top:4px;color:var(--muted);font-size:12px}.trainer-timeline{--trainer-minute-height:.86px;display:grid;grid-template-columns:42px minmax(0,1fr);gap:6px;min-height:724px}.trainer-time-scale,.trainer-time-rail{position:relative;height:calc(840 * var(--trainer-minute-height))}.trainer-time-scale span{position:absolute;right:0;transform:translateY(-50%);font-size:11px;color:var(--muted)}.trainer-time-rail{border:1px solid #E1E7EF;border-radius:14px;background:linear-gradient(to bottom,#EEF2F7 0 1px,transparent 1px calc(60 * var(--trainer-minute-height)));overflow:hidden;touch-action:pan-x pan-y}.trainer-hour-slot{position:absolute;left:0;right:0;border:0;border-bottom:1px solid #EEF2F7;background:transparent;text-align:left;cursor:pointer;padding:0}.trainer-hour-slot span{display:none}.trainer-hour-slot:hover{background:#EEF6FF}.trainer-availability-block{position:absolute;left:6px;right:6px;min-height:38px;border:1px solid #9BB8E2;border-radius:12px;background:#EAF2FC;color:var(--accent);box-shadow:0 8px 20px rgba(40,68,119,.14);display:grid;place-items:center;padding:10px 28px 10px 10px;touch-action:none;cursor:grab;z-index:3}.trainer-availability-block:active{cursor:grabbing}.trainer-availability-block strong{font-size:12px;line-height:1;white-space:nowrap}.trainer-availability-block button{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:28px;height:28px;border:0;border-radius:9px;background:rgba(255,255,255,.78);color:var(--danger);font-weight:800;cursor:pointer}.trainer-availability-block i{position:absolute;left:18px;right:18px;height:16px;border-radius:999px;cursor:ns-resize}.trainer-availability-block i:first-child{top:-4px}.trainer-availability-block i:last-child{bottom:-4px}.trainer-availability-block i::after{content:"";position:absolute;left:50%;top:6px;width:28px;height:4px;border-radius:999px;background:rgba(40,68,119,.28);transform:translateX(-50%)}.trainer-day-actions{display:grid;gap:8px}.trainer-day-actions span{color:var(--muted);font-size:12px;line-height:1.35}.trainer-picker-panel{display:grid;gap:8px;border:1px solid #E1E7EF;border-radius:12px;background:#F8FAFC;padding:10px}.trainer-tags{display:flex;flex-wrap:wrap;gap:8px}.trainer-tag{border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--muted);padding:8px 11px;cursor:pointer}.trainer-tag.active{background:var(--accent);border-color:var(--accent);color:#fff}.trainer-tag.unavailable{border-style:dashed;color:#8A94A6}
@media (max-width:900px){.trainers-layout{grid-template-columns:1fr}.trainer-create-form{position:static}.trainer-card-head{display:grid}.trainer-booking-row{display:grid}.trainer-day-actions{display:grid}.trainer-public-page{padding-left:10px;padding-right:10px}.trainer-week-board{grid-template-columns:repeat(7,82vw);gap:10px;scroll-snap-type:x proximity}.trainer-timeline-day{scroll-snap-align:start}.trainer-timeline{--trainer-minute-height:1px;min-height:840px}.trainer-day-card{min-width:0}.trainer-availability-block{left:8px;right:8px;min-height:46px}.trainer-availability-block strong{font-size:13px}.trainer-availability-block button{width:34px;height:34px}.trainer-time-scale span{font-size:12px}}

/* Public booking flow */
.public-booking-flow-shell{display:grid;grid-template-columns:260px minmax(0,1fr);gap:16px;align-items:start}.public-booking-flow-steps{position:sticky;top:84px;display:grid;gap:8px}.public-booking-flow-steps div{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:12px;background:#fff;padding:10px;color:var(--muted)}.public-booking-flow-steps span{width:26px;height:26px;display:grid;place-items:center;border-radius:999px;background:#EEF2F7;color:var(--accent);font-weight:700;flex:0 0 auto}.public-booking-flow-steps div.active{border-color:#B7C7DC;color:var(--accent);box-shadow:0 10px 28px rgba(16,24,40,.06)}.public-booking-flow-steps div.active span,.public-booking-flow-steps div.done span{background:var(--accent);color:#fff}.public-booking-flow-panel{display:grid;gap:14px}.public-booking-flow-step{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;display:grid;gap:16px}.public-booking-flow-step[hidden]{display:none}.public-booking-flow-choice-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.public-booking-flow-choice-grid button,.public-booking-flow-row,.public-booking-flow-chip{border:1px solid var(--line);background:#fff;color:var(--text);border-radius:12px;padding:14px;text-align:left;cursor:pointer}.public-booking-flow-choice-grid button{min-height:86px;font-size:18px;font-weight:800;text-align:center}.public-booking-flow-choice-grid button:hover,.public-booking-flow-row:hover,.public-booking-flow-chip:hover{border-color:#B7C7DC;background:#F8FAFC}.public-booking-flow-list{display:grid;gap:9px}.public-booking-flow-list.compact{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.public-booking-flow-row{display:flex;justify-content:space-between;gap:12px}.public-booking-flow-row strong,.public-booking-flow-chip strong{display:block;color:var(--accent)}.public-booking-flow-row small,.public-booking-flow-chip small{display:block;color:var(--muted);margin-top:4px;line-height:1.35}.public-booking-flow-client-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.public-booking-flow-actions{display:flex;justify-content:flex-end;gap:10px}.public-booking-flow-summary dl{display:grid;gap:10px;margin:0}.public-booking-flow-summary div{display:grid;grid-template-columns:160px minmax(0,1fr);gap:12px;border-bottom:1px solid #EEF1F5;padding-bottom:10px}.public-booking-flow-summary dt{color:var(--muted)}.public-booking-flow-summary dd{margin:0;font-weight:700}.public-booking-flow-note{margin-top:12px;border:1px solid #F4D8A8;background:#FFF8EA;color:#7A4E00;border-radius:12px;padding:10px;line-height:1.45}.public-booking-flow-result{border:1px solid var(--line);border-radius:14px;padding:14px;display:grid;gap:10px}.public-booking-flow-result.success{border-color:#A6D8B8;background:#F1FAF4;color:#15572A}.public-booking-flow-result.error{border-color:#F2B8B5;background:#FEF3F2;color:var(--danger)}.public-booking-flow-result pre{max-height:360px;overflow:auto;margin:0;border-radius:12px;background:#0F172A;color:#E5E7EB;padding:12px;font-size:12px;white-space:pre-wrap}.public-booking-flow-step button:disabled{opacity:.5;cursor:not-allowed}
@media (max-width:900px){.public-booking-flow-shell{grid-template-columns:1fr}.public-booking-flow-steps{position:static;grid-template-columns:repeat(2,minmax(0,1fr))}.public-booking-flow-choice-grid,.public-booking-flow-client-grid{grid-template-columns:1fr}.public-booking-flow-summary div{grid-template-columns:1fr}}

/* Public booking */
.public-booking-body{background:#F4F7F8}.public-booking{width:min(980px,100%);margin:0 auto;padding:28px 18px 54px}.public-booking-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}.public-booking-head strong{display:block;color:var(--accent);font-size:15px}.public-booking-head h1{margin-top:5px;font-size:34px}.public-booking-head span{border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--muted);padding:8px 12px}.public-booking-stage{display:grid;gap:16px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:0 12px 34px rgba(16,24,40,.06)}.public-booking-stage[hidden]{display:none}.public-booking-stage h2{font-size:22px}.public-sport-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}.public-sport-grid button,.public-tag{border:1px solid var(--line);border-radius:12px;background:#fff;color:var(--text);padding:13px;text-align:left;cursor:pointer}.public-sport-grid button:hover,.public-tag:hover,.public-tag.active{border-color:#9DB2CC;background:#F4F8FC}.public-sport-grid strong,.public-tag strong{display:block;color:var(--accent);font-size:15px}.public-sport-grid small,.public-tag small{display:block;color:var(--muted);margin-top:5px}.public-service-block{display:grid;gap:10px;border-top:1px solid #EEF1F5;padding-top:14px}.public-service-block:first-child{border-top:0;padding-top:0}.public-tags,.public-date-row,.public-slot-grid{display:flex;gap:8px;flex-wrap:wrap}.public-counter-row{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid var(--line);border-radius:12px;padding:12px}.public-counter-row small{display:block;color:var(--muted);margin-top:4px}.public-counter{display:grid;grid-template-columns:34px 34px 34px;align-items:center;border:1px solid var(--line);border-radius:11px;overflow:hidden;background:#fff}.public-counter button{height:34px;border:0;background:#F4F6FA;color:var(--accent);font-weight:800;cursor:pointer}.public-counter span{text-align:center;font-weight:700}.public-total{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding-top:14px}.public-total strong{font-size:24px;color:var(--accent)}.public-actions{display:flex;justify-content:flex-end;gap:10px}.public-empty{border:1px dashed #C9D4E2;border-radius:14px;background:#F8FAFC;color:var(--muted);padding:18px;text-align:center}.yclients-transfer-status{border:1px solid var(--line);border-radius:12px;background:#F8FAFC;color:var(--muted);padding:10px;line-height:1.35}.yclients-transfer-button{color:var(--accent)}
@media (max-width:700px){.public-booking-head{display:grid}.public-booking-head h1{font-size:28px}.public-counter-row{display:grid}.public-actions{justify-content:stretch}.public-actions button{width:100%}}

/* Public booking polish */
.public-step-head{display:flex;align-items:center;gap:12px}
.public-step-head h2{min-width:0}
.public-back{width:38px;height:38px;display:grid;place-items:center;border:1px solid var(--line);border-radius:12px;background:#fff;color:var(--accent);font-size:20px;line-height:1;cursor:pointer;flex:0 0 auto}
.public-back:hover{background:#EEF2F7;border-color:#CBD5E1}
.public-date-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(116px,1fr));gap:8px}
.public-date-row .public-tag{text-align:center}
.public-date-row .public-tag strong{text-transform:lowercase}
.public-tag.active{border-color:var(--accent);background:#EEF4FF;box-shadow:inset 0 0 0 1px var(--accent)}
.public-slot-sections{display:grid;gap:16px}
.public-slot-section{display:grid;gap:8px;border-top:1px solid #EEF1F5;padding-top:14px}
.public-slot-section:first-child{border-top:0;padding-top:0}
.public-slot-section h3{font-size:15px;color:var(--accent)}
.public-slot-section .public-slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:8px}
.public-slot-section .public-tag{text-align:center;padding:11px 10px}
.public-slot-section .public-tag strong{font-size:14px}
.public-confirm-card{display:grid;gap:14px;border:1px solid #DDE5EF;border-radius:16px;background:#F8FAFC;padding:16px}
.public-confirm-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.public-confirm-grid>div{display:grid;gap:5px;border:1px solid #E6E9EF;border-radius:12px;background:#fff;padding:12px;min-width:0}
.public-confirm-grid span{color:var(--muted);font-size:12px}
.public-confirm-grid strong{color:var(--accent);font-size:15px;line-height:1.35;overflow-wrap:anywhere}
.public-confirm-grid small{color:var(--muted)}
.public-summary-list{display:grid;gap:8px;margin:0;padding:0;list-style:none}
.public-summary-list li{display:flex;justify-content:space-between;gap:12px;border-bottom:1px solid #E6E9EF;padding-bottom:8px}
.public-summary-list li:last-child{border-bottom:0;padding-bottom:0}
.public-summary-list span{min-width:0;overflow-wrap:anywhere}
.public-summary-list strong{white-space:nowrap;color:var(--accent)}

/* Booking modal scroll and trainer fit */
.booking-modal-workbench{height:min(820px,calc(100vh - 44px));max-height:calc(100vh - 44px)}
.booking-modal-workbench .booking-left,.booking-modal-workbench .booking-main,.booking-modal-workbench .booking-right{min-height:0}
.booking-modal-workbench .booking-main{overflow:auto}
.booking-modal-workbench .service-picker-panel{min-height:0}
.booking-modal-workbench .service-picker-list{min-height:120px}
.booking-modal-workbench .booking-main-footer{position:sticky;bottom:0;z-index:2}
.booking-modal-workbench .section-inline-title{align-items:flex-start;flex-wrap:wrap}
.booking-modal-workbench .section-inline-title span{line-height:1.35;max-width:100%}
.booking-modal-workbench .trainer-picker-panel{min-width:0;overflow:hidden}
.booking-modal-workbench .trainer-tags{max-height:98px;overflow:auto;align-content:start;padding-right:2px}
.booking-modal-workbench .trainer-tag{white-space:normal;line-height:1.2;text-align:left}
@media (max-width:940px){.booking-modal-workbench{height:auto;max-height:calc(100vh - 24px)}.booking-modal-workbench .booking-main{overflow:visible}.public-confirm-grid{grid-template-columns:1fr}.public-date-row{grid-template-columns:repeat(2,minmax(0,1fr))}}

/* Booking modal: use one central scroll instead of squeezed inner panes */
.booking-modal-workbench .booking-main{display:block!important;overflow-y:auto!important;overflow-x:hidden!important;padding:18px}
.booking-modal-workbench .booking-modal-title,.booking-modal-workbench .booking-top-status,.booking-modal-workbench .selected-services-panel,.booking-modal-workbench .trainer-picker-panel,.booking-modal-workbench .service-picker-panel{margin-bottom:14px}
.booking-modal-workbench .selected-services-list{max-height:none!important;overflow:visible!important}
.booking-modal-workbench .trainer-picker-panel{overflow:visible}
.booking-modal-workbench .trainer-tags{max-height:none;overflow:visible}
.booking-modal-workbench .service-picker-panel{display:grid;grid-template-rows:auto auto auto!important;min-height:auto!important}
.booking-modal-workbench .service-picker-list{max-height:none!important;min-height:0!important;overflow:visible!important}
.booking-modal-workbench .booking-main-footer{position:sticky;bottom:-18px;margin:0 -18px -18px;padding:14px 18px;border-top:1px solid #E1E7EF;background:#fff;box-shadow:0 -12px 24px rgba(255,255,255,.92);z-index:4}
@media (max-width:940px){.booking-modal-workbench .booking-main{overflow:visible!important}.booking-modal-workbench .booking-main-footer{bottom:0;margin:0;padding-top:12px}}
.yclients-record-link{display:flex;justify-content:center;margin-top:10px;color:var(--accent);font-weight:700}

/* Public booking widget shell */
.public-booking-widget-body{min-height:100vh;display:flex;justify-content:flex-end;align-items:stretch;background:#F3F6FA}
.public-booking-widget-body .public-booking{width:min(430px,100%);min-height:100vh;margin:0;padding:14px;background:#fff;box-shadow:-18px 0 50px rgba(16,24,40,.12)}
.public-booking-widget-body .public-booking-head{align-items:center;margin-bottom:12px}
.public-booking-widget-body .public-booking-head h1{margin-top:2px;font-size:25px;line-height:1.1;color:var(--accent)}
.public-booking-widget-body .public-booking-head strong{font-size:13px;text-transform:uppercase;letter-spacing:.04em}
.public-booking-widget-body .public-booking-head span{font-size:12px;padding:7px 10px;background:#F8FAFC}
.public-booking-widget-body .public-booking-stage{border-radius:14px;padding:15px;gap:13px;box-shadow:none}
.public-booking-widget-body .public-booking-stage h2{font-size:19px;line-height:1.15}
.public-booking-widget-body .public-sport-grid{grid-template-columns:1fr;gap:8px}
.public-booking-widget-body .public-sport-grid button,.public-booking-widget-body .public-tag{border-radius:11px;padding:11px 12px}
.public-booking-widget-body .public-service-block{gap:8px;padding-top:12px}
.public-booking-widget-body .public-service-block h3{font-size:13px;color:var(--accent)}
.public-booking-widget-body .public-counter-row{padding:10px;gap:10px}
.public-booking-widget-body .public-date-row{grid-template-columns:repeat(2,minmax(0,1fr))}
.public-booking-widget-body .public-slot-section .public-slot-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.public-booking-widget-body .public-confirm-card{padding:12px;border-radius:14px}
.public-booking-widget-body .public-confirm-grid{grid-template-columns:1fr;gap:8px}
.public-booking-widget-body .public-summary-list li{font-size:13px}
.public-agreements{display:grid;gap:9px;border-top:1px solid #E6E9EF;padding-top:11px}
.public-agreement{display:flex;align-items:flex-start;gap:9px;color:var(--text);font-size:12px;line-height:1.35}
.public-agreement input{width:16px;height:16px;margin-top:1px;flex:0 0 auto}
.public-agreement a{color:var(--accent);font-weight:700;text-decoration:underline;text-underline-offset:2px}
.yclients-refresh-button{color:var(--accent)}
.consent-badge{display:inline-flex;align-items:center;width:max-content;max-width:100%;margin-top:6px;border:1px solid #C9D8EC;border-radius:999px;background:#EEF4FF;color:var(--accent);padding:4px 8px;font-size:12px;font-style:normal;font-weight:750;line-height:1.2}.consent-badge.missing{border-color:#F4C7C3;background:#FFF5F4;color:var(--danger)}.consent-line{display:inline-flex;width:max-content;max-width:100%;border:1px solid #DDE8D4;border-radius:999px;background:#F3FAEF;color:#25612E;padding:5px 8px}.consent-line.missing{border-color:#F4C7C3;background:#FFF5F4;color:var(--danger)}
@media (max-width:700px){.public-booking-widget-body{display:block}.public-booking-widget-body .public-booking{width:100%;min-height:100vh;padding:12px;box-shadow:none}.public-booking-widget-body .public-booking-head h1{font-size:23px}.public-booking-widget-body .public-slot-section .public-slot-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}

/* Public booking widget v2 */
.public-booking-widget-body{background:#F5F6F8}
.public-booking-widget{width:min(430px,100%);min-height:100vh;overflow:auto}
.public-widget-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:18px;padding:2px 4px}
.public-widget-head h1{font-size:18px;line-height:1.1;color:var(--accent);font-weight:850}
.public-widget-head span{display:inline-flex;margin-top:9px;border:1px solid #DFE5EE;border-radius:999px;background:#fff;color:#7A8492;padding:4px 8px;font-size:10px;font-weight:750}
.public-widget-logo{width:92px;height:42px;display:grid;place-items:center;color:var(--accent);font-family:Georgia,serif;font-style:italic}
.public-widget-logo img{max-width:100%;max-height:100%;object-fit:contain}.public-widget-logo b{font-size:18px}
.public-toast{position:sticky;top:8px;z-index:5;margin-bottom:10px;border:1px solid #F4C7C3;border-radius:12px;background:#FFF5F4;color:var(--danger);padding:10px 12px;font-weight:750;box-shadow:0 12px 24px rgba(180,35,24,.1)}
.public-booking-widget .widget-stage{border-color:#DDE3EC;border-radius:8px;padding:9px;gap:13px;box-shadow:none}
.public-booking-widget .widget-stage h2{font-size:17px;line-height:1.2;color:#101828;font-weight:850}
.public-booking-widget .public-step-head{align-items:flex-start}
.public-step-subtitle{margin-top:3px;color:#6B7280;font-size:12px;line-height:1.35}
.public-booking-widget .public-back{width:28px;height:28px;border-radius:8px;font-size:17px}
.widget-sport-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:8px!important}
.widget-sport-grid button{display:grid;place-items:center;min-height:44px;border:0!important;border-radius:999px!important;background:var(--accent)!important;color:#fff!important;text-align:center!important;padding:10px 12px!important}
.widget-sport-grid button strong{color:#fff!important;font-size:15px!important;line-height:1.15}
.widget-sport-grid button:last-child:nth-child(odd){justify-self:start;min-width:170px}
.widget-service-block{border-top:0!important;padding-top:0!important;margin-top:2px}
.widget-section-title{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:7px}
.widget-section-title h3{margin:0!important;color:#101828!important;font-size:14px!important;font-weight:850}
.widget-price-badge{display:inline-flex;align-items:center;border-radius:999px;background:var(--accent);color:#fff;padding:5px 9px;font-size:13px;white-space:nowrap}
.widget-chip-row{display:flex;flex-wrap:wrap;gap:9px}
.public-booking-widget .widget-chip{display:inline-flex!important;align-items:center;justify-content:space-between;gap:9px;min-height:34px;border:1px solid #CBD5E1!important;border-radius:999px!important;background:#fff!important;color:#101828!important;padding:5px 6px 5px 11px!important}
.public-booking-widget .widget-chip strong{color:#101828!important;font-size:12px!important;line-height:1;white-space:nowrap}
.public-booking-widget .widget-chip small{display:inline-flex;margin:0;color:#fff;background:var(--accent);border-radius:999px;padding:3px 7px;font-size:11px;font-weight:850;line-height:1;white-space:nowrap}
.public-booking-widget .widget-chip.active{background:#EAF1FB!important;border-color:var(--accent)!important;box-shadow:inset 0 0 0 1px var(--accent)}
.widget-rental-row,.widget-trainer-row{gap:9px}
.widget-rental-row .widget-chip{min-width:108px}
.widget-trainer-row .widget-chip{min-width:174px}
.widget-service-list{display:grid!important;gap:14px!important;border-top:0!important;padding-top:2px!important}
.widget-counter-row{display:grid!important;grid-template-columns:minmax(0,1fr) auto;border:0!important;padding:0!important;align-items:center!important;justify-content:space-between!important;column-gap:14px}
.widget-counter-row>div:first-child{min-width:0}.widget-counter-row strong{display:block;font-size:14px;line-height:1.2}.widget-counter-row small{display:block;margin-top:3px;color:#667085;font-size:12px;line-height:1.2}
.widget-counter-row .public-counter{grid-template-columns:24px 34px 24px;border-radius:999px}.widget-counter-row .public-counter button{height:24px}.widget-counter-row .public-counter span{font-size:12px}
.widget-total{margin-top:10px;border-top:1px solid #AEB8CA!important;padding-top:13px!important}.widget-total span{font-weight:850;color:#101828}.widget-total strong{font-size:16px!important}
.public-booking-widget .public-actions{justify-content:stretch}.public-booking-widget .public-actions button{width:100%;border-radius:999px;font-weight:850;min-height:42px}
.widget-date-row{grid-template-columns:repeat(2,minmax(0,1fr))!important}
.widget-date{display:grid;place-items:center;text-align:center!important}.widget-date strong{text-transform:none!important}
.selected-date-strip{position:sticky;top:0;z-index:2;display:grid;gap:3px;border:1px solid #C8D5E8;border-radius:12px;background:#F8FBFF;padding:10px 12px;box-shadow:0 8px 18px rgba(255,255,255,.86)}
.selected-date-strip[hidden]{display:none}.selected-date-strip span{color:#6B7280;font-size:11px;font-weight:750;text-transform:uppercase}.selected-date-strip strong{color:var(--accent);text-transform:capitalize}
.widget-slot-section{gap:8px!important;border-top:0!important;padding-top:0!important}.widget-slot-section h3{color:#101828!important;font-size:14px!important}.widget-slot-grid{grid-template-columns:repeat(3,minmax(0,1fr))!important}
.widget-time{text-align:center!important;border-radius:999px!important}.widget-time strong{font-size:13px!important}
.widget-court-list{display:grid;gap:8px}.widget-court{display:grid!important;gap:2px;text-align:left!important}.widget-court.preferred{background:#EEF4FF!important;border-color:var(--accent)!important;box-shadow:inset 4px 0 0 var(--accent)}
.widget-court strong{font-size:15px!important}.widget-court small{font-size:12px!important}
.widget-client-fields{display:grid;gap:10px}.widget-client-fields label{font-size:12px;color:#667085;font-weight:750}.widget-client-fields input{height:44px;border-radius:12px;font-size:15px}
.widget-confirm-card{background:#fff!important;padding:0!important;border:0!important;gap:10px!important}
.widget-summary-main{display:grid;gap:3px;border-radius:14px;background:var(--accent);color:#fff;padding:14px}
.widget-summary-main span,.widget-summary-main small{color:#CFD8E8}.widget-summary-main strong{font-size:24px;line-height:1.1}
.widget-summary-section{display:grid;gap:8px;border:1px solid #E0E6EF;border-radius:12px;background:#fff;padding:12px}
.widget-summary-title{display:flex;align-items:center;justify-content:space-between;gap:10px}.widget-summary-title h3,.widget-summary-section h3{margin:0;color:#101828;font-size:14px}.widget-summary-title strong{color:var(--accent);font-size:18px}
.widget-summary-section p{line-height:1.45;font-weight:750}.widget-summary-section p span{color:#667085;font-weight:650}
.widget-confirm-actions{display:grid!important;grid-template-columns:1fr 1.45fr;gap:8px}.widget-confirm-actions button{width:100%}
@media (max-width:390px){.widget-sport-grid{grid-template-columns:1fr!important}.widget-sport-grid button:last-child:nth-child(odd){justify-self:stretch;min-width:0}.widget-slot-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}}

/* Telegram trainer mini app */
.tg-trainings-body{background:#F4F7F8;color:rgb(40,68,119)}
.tg-trainings{max-width:760px;margin:0 auto;padding:18px 14px 42px}
.tg-trainings-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}
.tg-trainings-head span{display:block;color:#5F6B7A;font-size:13px}
.tg-trainings-head h1{font-size:28px;margin-top:3px}
.tg-trainings-head button{border:1px solid #DDE5EF;border-radius:12px;background:#fff;color:rgb(40,68,119);padding:10px 12px;font-weight:700}
.tg-status,.tg-section{background:#fff;border:1px solid #DDE5EF;border-radius:16px;padding:14px;margin-bottom:12px}
.tg-admin-view,.tg-trainer-view{display:grid;gap:9px;background:#fff;border:1px solid #DDE5EF;border-radius:16px;padding:14px;margin-bottom:12px}
.tg-admin-view[hidden],.tg-trainer-view[hidden]{display:none}
.tg-trainer-view{grid-template-columns:minmax(0,1fr) auto;align-items:center}
.tg-trainer-view>small{grid-column:1/-1}
.tg-admin-view label,.tg-trainer-view span{color:#5F6B7A;font-size:13px}
.tg-trainer-view strong,.tg-trainer-view span{display:block}
.tg-trainer-view span{font-weight:800;color:rgb(40,68,119);font-size:16px}
.tg-trainer-view small{color:#5F6B7A}
.tg-admin-view select{width:100%;border:1px solid #DDE5EF;border-radius:12px;background:#fff;color:rgb(40,68,119);padding:11px 12px;font-weight:800}
.tg-admin-view button,.tg-trainer-view button{border:1px solid rgb(40,68,119);border-radius:12px;background:rgb(40,68,119);color:#fff;padding:11px 12px;font-weight:800}
.tg-admin-view button:disabled,.tg-trainer-view button:disabled{opacity:.62}
.tg-admin-view small{color:#5F6B7A;min-height:16px}
.tg-sync-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.tg-sync-row span{color:#5F6B7A;font-size:13px}
.tg-section h2{font-size:18px;margin-bottom:10px}
.tg-list{display:grid;gap:10px}
.tg-card{display:grid;gap:10px;border:1px solid #DDE5EF;border-radius:14px;background:#fff;padding:13px}
.tg-card-focus{animation:tg-card-focus 2.6s ease}
@keyframes tg-card-focus{0%,100%{border-color:#DDE5EF;box-shadow:none}15%,70%{border-color:rgb(40,68,119);box-shadow:0 0 0 4px rgba(40,68,119,.14)}}
.tg-card.undefined,.tg-card.ambiguous{background:#FFF8EA;border-color:#F4D8A8}
.tg-card.cancelled{opacity:.72}
.tg-card-top,.tg-line{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.tg-card-top strong{font-size:16px}
.tg-card-top span{border-radius:999px;background:#EEF2F7;color:#5F6B7A;padding:4px 8px;font-size:12px;white-space:nowrap}
.tg-line b,.tg-line span{min-width:0;overflow-wrap:anywhere}
.tg-line strong,.tg-line a{white-space:nowrap;color:rgb(40,68,119);font-weight:800}
.tg-client,.tg-comment{display:grid;gap:4px;border:1px solid #E8EDF3;border-radius:12px;background:#FAFBFC;padding:10px}
.tg-client span,.tg-comment span{color:#7A8594;font-size:12px;font-weight:800;text-transform:uppercase}
.tg-client strong{color:rgb(40,68,119);font-size:15px}
.tg-client a{color:#334155;font-weight:750}
.tg-card p{color:#334155;line-height:1.42;white-space:pre-wrap}
.tg-card small{color:#5F6B7A;line-height:1.35}
.tg-link{display:inline-flex;justify-content:center;border:1px solid #DDE5EF;border-radius:11px;padding:9px 10px;color:rgb(40,68,119);font-weight:700}
.tg-next{display:grid;gap:4px;background:rgb(40,68,119);color:#fff;border-radius:16px;padding:14px 16px;margin-bottom:12px}
.tg-next span,.tg-next small{color:#C8D3E0}
.tg-next strong{font-size:24px}
.tg-view-toggle{display:flex;justify-content:center;gap:8px;margin:-2px 0 12px}
.tg-view-toggle button{border:1px solid #DDE5EF;border-radius:12px;background:#fff;color:rgb(40,68,119);min-height:40px;padding:0 14px;font-weight:800}
.tg-view-toggle #resetAllButton{border-color:rgb(40,68,119);background:rgb(40,68,119);color:#fff}
.tg-calendar-card,.tg-day-panel{background:#fff;border:1px solid #DDE5EF;border-radius:16px;padding:14px;margin-bottom:12px}
.tg-calendar-head,.tg-day-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}
.tg-calendar-head button,.tg-day-head button{border:1px solid #DDE5EF;border-radius:12px;background:#fff;color:rgb(40,68,119);min-height:40px;padding:0 14px;font-weight:800}
.tg-calendar-head strong{text-transform:capitalize;font-size:17px}
.tg-calendar{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}
.tg-dow{display:grid;place-items:center;min-height:24px;color:#7A8594;font-size:12px;font-weight:800}
.tg-day{position:relative;display:grid;place-items:center;min-height:42px;border:1px solid transparent;border-radius:12px;background:#F6F8FB;color:rgb(40,68,119);font-weight:800}
.tg-day.muted{color:#A4ADBA;background:#FAFBFC}
.tg-day.today{border-color:rgb(40,68,119)}
.tg-day.active{background:rgb(40,68,119);color:#fff}
.tg-day.has-training::after{content:"";position:absolute;bottom:6px;width:6px;height:6px;border-radius:50%;background:#E23D3D}
.tg-day.active.has-training::after{background:#fff}
.tg-day-head h2{font-size:18px;text-transform:capitalize}
.tg-day-head span{display:block;color:#7A8594;margin-top:2px}
.tg-empty{border:1px dashed #DDE5EF;border-radius:14px;background:#FAFBFC;color:#7A8594;padding:16px;text-align:center}

/* Public booking widget v3 */
.public-booking-widget-body{min-height:100vh;background:#EEF2F6;display:flex;justify-content:flex-end;align-items:stretch}
.public-booking-widget-body .public-booking{width:min(456px,100%);min-height:100vh;margin:0;padding:18px;background:#fff;box-shadow:-24px 0 70px rgba(15,23,42,.14);overflow:auto}
.public-widget-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:0 0 28px;padding:0}
.public-widget-logo{width:118px;height:42px;display:grid;place-items:center;color:var(--accent);font-family:Georgia,serif;font-style:italic}
.public-widget-logo img{max-width:100%;max-height:100%;object-fit:contain}.public-widget-logo b{font-size:19px}
.public-account-button{width:42px;height:42px;display:grid;place-items:center;border:1px solid #DCE5F1;border-radius:999px;background:#F7FAFE;color:var(--accent);cursor:pointer}
.public-account-button span{position:relative;width:18px;height:18px;border:2px solid currentColor;border-radius:999px}
.public-account-button span::before{content:"";position:absolute;left:50%;top:3px;width:5px;height:5px;border:2px solid currentColor;border-radius:999px;transform:translateX(-50%)}
.public-account-button span::after{content:"";position:absolute;left:50%;bottom:1px;width:12px;height:6px;border:2px solid currentColor;border-top-left-radius:999px;border-top-right-radius:999px;border-bottom:0;transform:translateX(-50%)}
.public-booking-widget .widget-stage{border:0!important;border-radius:0!important;background:#fff!important;padding:0!important;gap:18px!important;box-shadow:none!important}
.public-booking-widget .widget-stage[hidden]{display:none!important}
.public-title-row,.public-booking-widget .public-step-head{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:14px}
.public-booking-widget .public-step-head{grid-template-columns:auto minmax(0,1fr) auto}
.public-booking-widget h1{margin:0;color:#102040;font-size:22px;line-height:1.15;font-weight:850}
.public-booking-widget .public-title-row p,.public-step-subtitle{margin-top:8px;color:#53617A;font-size:15px;line-height:1.35}
.public-title-row>span,.public-step-head>span{display:inline-flex;align-items:center;min-height:28px;border:1px solid #DDE5EF;border-radius:999px;background:#F6F8FB;color:#66758F;padding:5px 11px;font-size:12px;font-weight:800;white-space:nowrap}
.public-divider{height:1px;background:#DDE5EF}
.public-booking-widget .public-back{width:30px;height:30px;display:grid;place-items:center;border:1px solid #DDE5EF;border-radius:8px;background:#fff;color:var(--accent);font-size:24px;line-height:1;cursor:pointer}
.widget-sport-grid{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:16px!important}
.widget-sport-grid button{display:grid!important;place-items:center!important;gap:14px!important;min-height:130px!important;border:1px solid #DDE5EF!important;border-radius:12px!important;background:#fff!important;color:#102040!important;text-align:center!important;padding:18px 12px!important;box-shadow:0 10px 26px rgba(15,23,42,.035)!important}
.widget-sport-grid button:hover,.widget-sport-grid button:focus-visible{border-color:var(--accent)!important;background:#F9FBFF!important;outline:0}
.widget-sport-grid button strong{color:#1A2D54!important;font-size:16px!important;line-height:1.2}
.widget-sport-grid button:last-child:nth-child(odd){grid-column:1/-1;justify-self:stretch!important;min-width:0!important;min-height:78px!important;grid-template-columns:auto auto;justify-content:center}
.sport-icon{width:44px;height:44px;display:grid;place-items:center;border:1px solid #DCE5F1;border-radius:999px;background:#F5F8FC;color:var(--accent);font-size:25px;font-weight:800}
.public-service-block{display:grid!important;gap:12px!important;border:0!important;padding:0!important;margin:0!important}
.public-service-block h2{font-size:18px!important;color:#102040!important;font-weight:850!important}
.public-service-block p{margin:-5px 0 2px;color:#66758F;font-size:14px}
.widget-chip-row{display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px!important}
.widget-trainer-row{grid-template-columns:repeat(2,minmax(0,1fr))}
.public-booking-widget .widget-chip{display:grid!important;align-content:center;gap:8px!important;min-width:0!important;min-height:76px!important;border:1px solid #DDE5EF!important;border-radius:12px!important;background:#fff!important;color:#102040!important;padding:15px 16px!important;text-align:left!important;box-shadow:0 8px 20px rgba(15,23,42,.025)}
.public-booking-widget .widget-chip strong{display:block!important;color:#102040!important;font-size:15px!important;line-height:1.2!important;white-space:normal!important}
.public-booking-widget .widget-chip small{display:block!important;margin:0!important;background:transparent!important;border-radius:0!important;color:#243B68!important;padding:0!important;font-size:15px!important;font-weight:750!important;line-height:1.15!important;white-space:normal!important}
.public-booking-widget .widget-chip.active{border-color:var(--accent)!important;background:#F9FBFF!important;box-shadow:inset 0 0 0 1px var(--accent),0 10px 24px rgba(40,68,119,.08)!important}
.widget-service-list{display:grid!important;gap:14px!important}
.widget-counter-row{display:grid!important;grid-template-columns:minmax(0,1fr) auto;align-items:center!important;gap:14px!important;border:0!important;border-radius:0!important;background:transparent!important;padding:0!important}
.widget-counter-row>div:first-child{display:grid;grid-template-columns:34px minmax(0,1fr);gap:12px;align-items:center;min-width:0}
.widget-counter-row>div:first-child::before{content:"";width:34px;height:34px;border-radius:999px;background:#F1F5FA;border:1px solid #E2E8F2;grid-row:1/3}
.widget-counter-row strong{grid-column:2;display:block;color:#102040;font-size:15px;line-height:1.25;font-weight:800}
.widget-counter-row small{grid-column:2;display:block;margin-top:0;color:#53617A;font-size:14px;line-height:1.25}
.widget-counter-row .public-counter{display:grid;grid-template-columns:32px 42px 32px;border:1px solid #DDE5EF;border-radius:9px;overflow:hidden;background:#fff}
.widget-counter-row .public-counter button{height:34px;border:0;background:#F5F7FA;color:var(--accent);font-size:16px;font-weight:800;cursor:pointer}
.widget-counter-row .public-counter span{display:grid;place-items:center;color:#102040;font-weight:800}
.widget-total{display:flex!important;align-items:center!important;justify-content:space-between!important;margin-top:4px!important;border-top:1px solid #DDE5EF!important;padding-top:17px!important}
.widget-total span{color:#102040!important;font-size:16px;font-weight:850}.widget-total strong{color:var(--accent)!important;font-size:24px!important;line-height:1!important;font-weight:850!important}
.public-booking-widget .public-actions{display:flex;justify-content:stretch}.public-booking-widget .public-actions button{width:100%;min-height:62px;border-radius:14px!important;font-size:17px;font-weight:850}
.widget-date-row{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:12px!important}
.widget-date{display:grid!important;gap:4px!important;place-items:center!important;min-height:70px;border-radius:12px!important;text-align:center!important}
.widget-date strong{color:#102040!important;font-size:16px!important}.widget-date small{margin:0!important;text-transform:capitalize}
.selected-date-strip{position:sticky;top:0;z-index:2;display:grid;gap:3px;border:1px solid #C8D5E8;border-radius:12px;background:#F8FBFF;padding:12px 14px;box-shadow:0 10px 22px rgba(255,255,255,.9)}
.selected-date-strip[hidden]{display:none}.selected-date-strip span{color:#66758F;font-size:12px;font-weight:800;text-transform:uppercase}.selected-date-strip strong{color:var(--accent);font-size:15px;text-transform:capitalize}
.public-slot-sections{display:grid;gap:18px}.widget-slot-section{display:grid!important;gap:10px!important;border:0!important;padding:0!important}
.widget-slot-section h2{font-size:16px!important;color:#102040!important}.widget-slot-grid{display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:10px!important}
.widget-time{display:grid!important;place-items:center!important;min-height:48px;border-radius:12px!important;text-align:center!important}.widget-time strong{font-size:15px!important}
.widget-court-list{display:grid;gap:10px}
.widget-court{display:grid!important;grid-template-columns:38px minmax(0,1fr) 22px;align-items:center;gap:14px;min-height:78px;border:1px solid #DDE5EF!important;border-radius:12px!important;background:#fff!important;padding:15px 17px!important;text-align:left!important}
.widget-court.preferred{border-color:var(--accent)!important;background:#F8FBFF!important;box-shadow:inset 0 0 0 1px var(--accent),0 10px 26px rgba(40,68,119,.08)!important}
.widget-court-divider{display:flex;align-items:center;gap:10px;margin:10px 0 2px;color:#66758F;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.03em}
.widget-court-divider::before,.widget-court-divider::after{content:"";height:1px;background:#DDE5EF;flex:1}
.widget-court strong{color:#1A2D54!important;font-size:17px!important;line-height:1.2}.widget-court small{margin-top:5px!important;color:#53617A!important;font-size:14px!important}
.widget-court i{width:20px;height:20px;border:2px solid #D5DEEA;border-radius:999px}.widget-court.preferred i{border:6px solid var(--accent)}
.court-icon{width:34px;height:42px;border:1px solid #B8C5D8;border-radius:4px;background:linear-gradient(90deg,transparent 0 31%,#B8C5D8 31% 35%,transparent 35% 65%,#B8C5D8 65% 69%,transparent 69%),linear-gradient(0deg,transparent 0 48%,#B8C5D8 48% 52%,transparent 52%)}
.widget-confirm-card{display:grid!important;gap:16px!important;background:#fff!important;border:0!important;padding:0!important}
.widget-summary-main{display:grid;gap:9px;border-radius:12px;background:linear-gradient(135deg,var(--accent),#1C3A73);color:#fff;padding:20px}
.widget-summary-main span,.widget-summary-main small{color:#D7E0EE}.widget-summary-main strong{font-size:32px;line-height:1.05;font-weight:850}
.widget-summary-section{display:grid;gap:12px;border:1px solid #DDE5EF;border-radius:12px;background:#fff;padding:16px}
.widget-summary-title{display:flex;align-items:center;justify-content:space-between;gap:10px}.widget-summary-title h2,.widget-summary-section h2{margin:0;color:#102040!important;font-size:16px!important;font-weight:850}.widget-summary-title strong{color:#102040;font-size:22px}
.public-summary-list{display:grid;gap:10px;margin:0;padding:0;list-style:none}.public-summary-list li{display:flex;justify-content:space-between;gap:12px;border:0;padding:0;color:#24324A}.public-summary-list strong{white-space:nowrap;color:#243B68}
.widget-client-fields{display:grid;gap:12px}.widget-client-fields label{display:grid;gap:7px;color:#53617A;font-size:13px;font-weight:750}.widget-client-fields input{height:52px;border-radius:12px;border-color:#DDE5EF;font-size:16px}
.public-agreements{display:grid;gap:12px;border-top:1px solid #DDE5EF;padding-top:16px}
.public-agreement{display:grid;grid-template-columns:22px minmax(0,1fr);align-items:start;gap:11px;color:#24324A;font-size:14px;line-height:1.45}.public-agreement input{width:20px;height:20px;margin:0}.public-agreement a{color:var(--accent);font-weight:800;text-decoration:underline;text-underline-offset:2px}
.widget-confirm-actions{display:grid!important;grid-template-columns:1fr 1.55fr;gap:14px!important}.widget-confirm-actions button{width:100%;min-height:56px!important}
.public-toast{position:sticky;top:8px;z-index:5;margin-bottom:12px;border:1px solid #F4C7C3;border-radius:12px;background:#FFF5F4;color:var(--danger);padding:11px 13px;font-weight:750;box-shadow:0 12px 24px rgba(180,35,24,.1)}
@media (max-width:700px){.public-booking-widget-body{display:block;background:#fff}.public-booking-widget-body .public-booking{width:100%;min-height:100vh;padding:22px 18px 34px;box-shadow:none}.public-widget-head{margin-bottom:26px}}
@media (max-width:390px){.widget-sport-grid,.widget-chip-row,.widget-trainer-row,.widget-date-row,.widget-slot-grid{grid-template-columns:1fr!important}.widget-sport-grid button:last-child:nth-child(odd){grid-column:auto;grid-template-columns:1fr;min-height:118px!important}.widget-confirm-actions{grid-template-columns:1fr!important}}

/* Public booking widget v3 refinements */
#serviceArea{display:grid;gap:28px}
.public-service-block{gap:15px!important}
.public-service-block+.public-service-block{padding-top:2px!important}
.public-service-block h2{display:flex;align-items:center;gap:8px}
.widget-chip-row{gap:13px!important}
.public-booking-widget .widget-chip{position:relative;min-height:86px!important;padding:16px!important}
.public-booking-widget .widget-chip .widget-service-price,.widget-service-price{display:inline-flex!important;width:max-content;align-items:center;justify-content:center;margin-top:2px!important;border-radius:999px!important;background:var(--accent)!important;color:#fff!important;padding:5px 9px!important;font-size:13px!important;font-weight:850!important;line-height:1!important;white-space:nowrap!important}
.widget-service-list{display:grid!important;gap:18px!important}
.widget-trainer-list{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px!important}
.widget-choice-row{display:grid!important;width:100%;grid-template-columns:minmax(0,1fr);align-items:center;border:1px solid #DDE5EF!important;border-radius:12px!important;background:#fff!important;padding:14px 16px!important;text-align:left!important;box-shadow:0 8px 20px rgba(15,23,42,.025)}
.widget-choice-row strong{display:block;color:#102040;font-size:15px;line-height:1.25;font-weight:800}.widget-choice-row small:not(.widget-service-price){display:block;margin-top:5px;color:#66758F;font-size:13px;line-height:1.35}.widget-choice-row.active{border-color:var(--accent)!important;background:#F9FBFF!important;box-shadow:inset 0 0 0 1px var(--accent),0 10px 24px rgba(40,68,119,.08)!important}
.widget-counter-row{min-height:52px!important}
.widget-counter-row>div:first-child{row-gap:4px!important}
.widget-counter-row small:not(.widget-service-price){color:#66758F!important;font-size:13px!important;line-height:1.35!important}
.widget-counter-row .widget-service-price{grid-column:2;margin-top:1px!important}
.public-account-button[hidden]{display:none!important}
.widget-total .widget-total-label{display:inline-flex;align-items:center;gap:7px;position:relative}
.widget-payment-help{position:relative;display:inline-flex;align-items:center}
.widget-info-button{width:18px;height:18px;display:inline-grid;place-items:center;border:1px solid #D5DEEA;border-radius:999px;background:#F8FAFC;color:#8A97AA;font-size:11px;font-weight:700;line-height:1;cursor:pointer;vertical-align:middle}
.widget-payment-note{position:absolute;left:0;top:calc(100% + 8px);width:260px;max-width:calc(100vw - 48px);display:none;border:1px solid #DDE5EF;border-radius:10px;background:#fff;color:#24324A!important;padding:9px 10px;font-size:12px!important;font-weight:500!important;line-height:1.35!important;text-align:left;box-shadow:0 14px 32px rgba(15,23,42,.14);z-index:20;text-transform:none!important;letter-spacing:0!important}
.widget-payment-help:hover .widget-payment-note,.widget-payment-help.open .widget-payment-note{display:block}
.widget-total .widget-payment-note{top:auto;bottom:calc(100% + 8px);left:50%;transform:translateX(-18%);width:250px}
.widget-summary-price{display:inline-flex;align-items:center;gap:7px;position:relative}.widget-summary-price .widget-payment-note{top:calc(100% + 8px);bottom:auto;left:auto;right:0;transform:none;width:260px}
.widget-summary-main strong em{font-size:16px;font-style:normal;font-weight:750;color:#D7E0EE;white-space:nowrap}
.widget-confirm-actions{grid-template-columns:1fr!important}
.public-booking-flow-result{border:1px solid #DDE5EF;border-radius:14px;padding:16px;display:grid;gap:12px}
.public-booking-flow-result button{width:100%;min-height:48px;border-radius:12px;font-weight:850}
.widget-result-success{border-color:#A9D9BA!important;background:#F7FCF8!important;color:#12351F}
.widget-result-success>strong{font-size:20px;color:#0F5C2B}.widget-result-success>p{color:#3F5B49;line-height:1.45}
.widget-result-details{display:grid;gap:10px;border:1px solid #DDE5EF;border-radius:12px;background:#fff;padding:12px}
.widget-result-details div{display:grid;gap:3px}.widget-result-details span{color:#66758F;font-size:12px;font-weight:800;text-transform:uppercase}.widget-result-details strong{color:#102040;line-height:1.35}.widget-result-details em{font-style:normal;color:#66758F;font-size:13px}
.widget-result-note{display:grid;gap:4px;border:1px solid #DDE5EF;border-radius:12px;background:#F8FBFF;padding:12px;color:#24324A}
.widget-result-note strong{color:#102040}.widget-result-note span{color:#53617A;line-height:1.4}
@media (max-width:390px){.widget-trainer-list{grid-template-columns:1fr!important}}

.booking-user-comment-card{display:grid;gap:7px;background:#F8FBFF!important;border-color:#DDE5EF!important}
.booking-user-comment-card small{color:#66758F;font-weight:800;text-transform:uppercase}
.booking-user-comment-card p{margin:0;color:#24324A;line-height:1.4;overflow-wrap:anywhere}

/* Public account demo */
.public-account-stage{gap:18px}
.public-account-card,.public-account-dashboard{display:grid;gap:14px}
.public-account-card{border:1px solid #DDE5EF;border-radius:16px;background:#fff;padding:16px;box-shadow:0 10px 26px rgba(15,23,42,.04)}
.public-account-card label{display:grid;gap:7px;color:#53617A;font-size:13px;font-weight:750}
.public-account-card input{height:52px;border-radius:12px;border-color:#DDE5EF;font-size:16px}
.public-account-card button{min-height:54px;border-radius:14px;font-weight:850}
.public-account-intro{display:grid;gap:5px;margin-bottom:2px}.public-account-intro strong{color:#102040;font-size:18px}.public-account-intro span{color:#66758F;line-height:1.4}
.public-account-profile{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid #DDE5EF;border-radius:16px;background:#F8FBFF;padding:15px}
.public-account-profile div{display:grid;gap:3px}.public-account-profile span{color:#66758F;font-size:12px;font-weight:800;text-transform:uppercase}.public-account-profile strong{color:#102040;font-size:19px}.public-account-profile small{color:#53617A}.public-account-profile button{width:auto;white-space:nowrap}
.public-account-tabs{display:grid;grid-template-columns:1fr 1fr;gap:6px;border:1px solid #DDE5EF;border-radius:14px;background:#F3F6FA;padding:4px}
.public-account-tabs button{border:0;border-radius:11px;background:transparent;color:#66758F;padding:11px 8px;font-weight:850;cursor:pointer}.public-account-tabs button.active{background:#fff;color:var(--accent);box-shadow:0 1px 2px rgba(16,24,40,.08)}
.public-account-list{display:grid;gap:10px}.public-account-booking{display:grid;border:1px solid #DDE5EF;border-radius:14px;background:#fff;overflow:hidden}.public-account-booking.open{border-color:#B8C8DC;box-shadow:0 10px 24px rgba(40,68,119,.08)}.public-account-booking-toggle{display:grid;gap:5px;width:100%;border:0;background:#fff;padding:13px 14px;text-align:left;cursor:pointer}.public-account-booking-toggle:hover{background:#F9FBFF}.public-account-booking span{color:#66758F;font-size:12px;font-weight:800;text-transform:uppercase}.public-account-booking strong{color:#102040;font-size:15px;line-height:1.25}.public-account-booking small{display:flex;align-items:center;gap:8px;color:#53617A;font-size:13px}.public-account-booking small b{border-radius:999px;background:#EEF4FF;color:var(--accent);padding:4px 8px;font-size:12px;font-weight:800}.public-account-booking small em{font-style:normal;color:#53617A}
.public-account-detail{display:grid;gap:12px;border-top:1px solid #DDE5EF;background:#F8FBFF;padding:12px 14px 14px}.public-account-detail .widget-result-details{box-shadow:none}.public-account-detail .public-summary-list{border:1px solid #DDE5EF;border-radius:12px;background:#fff;padding:12px}

/* Clients sync and filters */
.clients-sync-result{margin:0 0 12px;border:1px solid #BFD8C7;border-radius:12px;background:#F4FBF6;color:#15572A;padding:11px 13px;font-weight:750}.error.clients-sync-result{border-color:#F2B8B5;background:#FEF3F2;color:var(--danger)}
.client-toolbar{display:grid;gap:12px}.client-toolbar>div{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.client-toolbar p{margin-top:4px;color:var(--muted);font-size:13px}
.client-filters{display:grid;grid-template-columns:minmax(220px,1.4fr) repeat(4,minmax(128px,1fr)) auto;gap:8px;align-items:center}.client-filters input,.client-filters select{height:40px;border-radius:10px;padding:8px 10px}.client-filters button{height:40px;white-space:nowrap}
.client-row.archived{opacity:.72;background:#FAFAFB}.client-row-side{display:grid;justify-items:end;gap:4px;color:var(--muted)}.client-row-side b{color:var(--accent);font-weight:750}
.client-badges{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:7px}.client-badge{display:inline-flex;align-items:center;width:max-content;max-width:100%;border:1px solid #DDE5EF;border-radius:999px;background:#F5F7FA;color:#667085;padding:4px 8px;font-size:12px;font-style:normal;font-weight:750;line-height:1.2}.client-badge.ok{border-color:#BFD8C7;background:#F1FAF4;color:#15572A}.client-badge.missing{border-color:#F4C7C3;background:#FFF5F4;color:var(--danger)}.client-badge.muted{color:#667085}.client-badge.source{border-color:#C9D8EC;background:#EEF4FF;color:var(--accent)}.client-badge.archived{border-color:#D1D5DB;background:#F3F4F6;color:#4B5563}
.client-meta-panel{display:grid;gap:8px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:13px 0}.client-meta-panel p{color:var(--muted);font-size:13px}
.history-row-actions{display:grid;justify-items:end;gap:8px}.history-row-actions .button{padding:7px 9px;border-radius:9px;font-size:12px}
.public-booking-embed-body{background:#fff}.public-booking-embed-body .public-booking{width:100%;min-height:100vh;padding:18px;box-shadow:none}.public-booking-embed-body .public-widget-head{display:none}.public-booking-embed-body .public-booking-stage{border:0!important;padding:0!important}.public-booking-embed-body .public-toast{position:sticky;top:0}

/* Booking event types */
.event-type-card{width:min(760px,100%)}
.event-type-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.event-type-grid button{display:grid;gap:5px;min-height:92px;border:1px solid var(--line);border-radius:12px;background:#fff;padding:14px;text-align:left;cursor:pointer}.event-type-grid button:hover{border-color:var(--accent);background:#F8FBFF}.event-type-grid strong{color:var(--text);font-size:15px}.event-type-grid small{color:var(--muted);line-height:1.35}
.booking-event-badge{display:inline-flex;width:max-content;max-width:100%;border-radius:999px;background:#fff;color:var(--accent);padding:2px 6px;margin-bottom:3px;font-size:9px;font-weight:800;line-height:1.2;white-space:nowrap}.booking.event-kids_group{background:#F0F9FF;border-color:#7DD3FC;color:#075985}.booking.event-adult_group{background:#F0FDF4;border-color:#86EFAC;color:#166534}.booking.event-tournament{background:#FFF7ED;border-color:#FDBA74;color:#9A3412}.booking.event-event{background:#F8F5FF;border-color:#C4B5FD;color:#5B21B6}
.booking-modal-workbench [hidden],.booking-modal-workbench [data-booking-panel][hidden],.booking-modal-workbench [data-event-panel][hidden],.booking-modal-workbench [data-group-panel][hidden],.booking-modal-workbench [data-simple-event-panel][hidden]{display:none!important}
.booking-modal-workbench.event-mode{width:min(1180px,calc(100vw - 36px));grid-template-columns:300px minmax(0,1fr);grid-template-rows:minmax(0,1fr) auto}.booking-modal-workbench.event-mode .booking-main{grid-column:2;grid-row:1;overflow:auto}.booking-modal-workbench.event-mode .booking-modal-footer-redesign{grid-column:2}.booking-modal-workbench.simple-event-mode{width:min(820px,calc(100vw - 36px));grid-template-columns:minmax(300px,1fr);grid-template-rows:minmax(0,1fr) auto}.booking-modal-workbench.simple-event-mode .booking-left{grid-column:1;grid-row:1;border-right:0}.booking-modal-workbench.simple-event-mode .booking-main{grid-column:1;grid-row:2;padding:0 18px 18px;overflow:visible}.booking-modal-workbench.simple-event-mode .booking-modal-title,.booking-modal-workbench.simple-event-mode .booking-top-status{display:none}.booking-modal-workbench.simple-event-mode .booking-modal-footer-redesign{grid-column:1;grid-row:3}
.booking-modal-workbench.event-mode .booking-comment-card textarea{min-height:190px}.booking-modal-workbench.group-mode .booking-comment-card textarea{min-height:150px}

/* Public booking sport start cards */
.public-booking-widget .widget-sport-grid{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:18px!important;
}
.public-booking-widget .sport-card{
  position:relative!important;
  min-height:168px!important;
  overflow:hidden!important;
  display:grid!important;
  align-content:start!important;
  justify-items:start!important;
  border:1px solid #111!important;
  border-radius:22px!important;
  background:#fff!important;
  color:#243B68!important;
  text-align:left!important;
  padding:28px 30px!important;
  box-shadow:none!important;
}
.public-booking-widget .sport-card:hover,
.public-booking-widget .sport-card:focus-visible{
  border-color:#243B68!important;
  background:#FBFCFF!important;
  outline:0;
}
.public-booking-widget .sport-card__title{
  position:relative;
  z-index:2;
  color:#2B4778;
  font-size:44px;
  font-weight:850;
  line-height:.95;
  letter-spacing:-.02em;
}
.public-booking-widget .sport-card__image{
  position:absolute;
  z-index:1;
  display:block;
  width:220px;
  height:220px;
  object-fit:contain;
  object-position:center;
  pointer-events:none;
}
.public-booking-widget .sport-card--featured{
  min-height:184px!important;
  border:0!important;
  background:#071F34!important;
  color:#fff!important;
  padding:30px 34px!important;
}
.public-booking-widget .sport-card--featured:hover,
.public-booking-widget .sport-card--featured:focus-visible{
  background:#09263F!important;
}
.public-booking-widget .sport-card--featured .sport-card__title{
  color:#fff;
  font-size:52px;
}
.public-booking-widget .sport-card__lunda{
  position:relative;
  z-index:2;
  display:flex;
  align-items:flex-end;
  gap:14px;
  margin-top:auto;
  padding-top:46px;
  color:#fff;
}
.public-booking-widget .sport-card__lunda em{
  font-size:28px;
  font-style:normal;
  font-weight:850;
  line-height:1;
}
.public-booking-widget .sport-card__lunda img{
  width:174px;
  height:auto;
  display:block;
}
.public-booking-widget .sport-card--padel .sport-card__image{
  right:-28px;
  bottom:-30px;
  width:228px;
  height:228px;
  opacity:.82;
}
.public-booking-widget .sport-card--squash .sport-card__image{
  right:-12px;
  bottom:-74px;
  width:236px;
  height:236px;
}
.public-booking-widget .sport-card--pickleball .sport-card__image{
  right:-18px;
  bottom:-54px;
  width:220px;
  height:220px;
}
.public-booking-widget .sport-card--badminton .sport-card__image{
  right:-16px;
  bottom:-56px;
  width:218px;
  height:218px;
}
.public-booking-widget .sport-card--table-tennis .sport-card__image{
  right:22px;
  bottom:18px;
  width:116px;
  height:116px;
}
.public-booking-widget .sport-icon{
  display:none!important;
}
@media (max-width:700px){
  .public-booking-widget .widget-sport-grid{gap:14px!important}
  .public-booking-widget .sport-card{
    min-height:138px!important;
    border-radius:18px!important;
    padding:22px 24px!important;
  }
  .public-booking-widget .sport-card__title{font-size:36px}
  .public-booking-widget .sport-card--featured{
    min-height:158px!important;
    padding:24px 26px!important;
  }
  .public-booking-widget .sport-card--featured .sport-card__title{font-size:42px}
  .public-booking-widget .sport-card__lunda{padding-top:34px}
  .public-booking-widget .sport-card__lunda em{font-size:23px}
  .public-booking-widget .sport-card__lunda img{width:142px}
  .public-booking-widget .sport-card--padel .sport-card__image{
    right:-40px;
    bottom:-36px;
    width:196px;
    height:196px;
  }
  .public-booking-widget .sport-card--squash .sport-card__image,
  .public-booking-widget .sport-card--pickleball .sport-card__image,
  .public-booking-widget .sport-card--badminton .sport-card__image{
    right:-26px;
    bottom:-72px;
    width:204px;
    height:204px;
  }
  .public-booking-widget .sport-card--table-tennis .sport-card__image{
    right:22px;
    bottom:16px;
    width:98px;
    height:98px;
  }
}
.event-trainer-panel,.group-participants-panel,.event-note-panel{display:grid;gap:12px;border:1px solid var(--line);border-radius:14px;background:#fff;padding:12px}.event-trainer-tags{display:flex;flex-wrap:wrap;gap:8px}.participants-list{display:grid;gap:12px}.participant-row{position:relative;display:grid;grid-template-columns:minmax(210px,1fr) minmax(190px,1fr) 40px;gap:12px;align-items:end;border:1px solid #E5EAF1;border-radius:12px;background:#FAFBFD;padding:14px;max-width:100%;overflow:visible}.participant-row.kids-participant{grid-template-columns:minmax(170px,1fr) minmax(160px,.9fr) minmax(160px,1fr) minmax(86px,.45fr) 40px}.participant-row label{min-width:0}.participant-row input,.participant-row select{min-height:42px}.participant-row .icon{align-self:end}.participant-row .participant-comment-field{grid-column:1/-2}.participant-row .suggestions{grid-column:1/-1;position:static;display:none;box-shadow:none}.participant-suggestions button{display:block;width:100%;border:0;background:#fff;text-align:left;padding:10px;cursor:pointer}.participant-suggestions button:hover{background:#F6F8FB}.participant-child-select[hidden]{display:none}.group-only-field[hidden],.event-only-field[hidden]{display:none}
.group-participants-panel{overflow:visible}.group-participants-panel #addParticipantButton{min-height:42px;border-radius:10px}.booking-modal-workbench.group-mode .booking-main{padding-bottom:80px}.booking-modal-workbench.group-mode .booking-main-footer{position:sticky;bottom:-18px}
@media (max-width:1100px){.participant-row,.participant-row.kids-participant{grid-template-columns:repeat(2,minmax(0,1fr)) 36px}.participant-row label{min-width:0}.participant-row .suggestions{grid-column:1/-1}}
@media (max-width:720px){.event-type-grid{grid-template-columns:1fr}.participant-row,.participant-row.kids-participant{grid-template-columns:1fr}.participant-row .icon{width:100%}}
@media (max-width:1100px){.client-filters{grid-template-columns:repeat(2,minmax(0,1fr))}.client-filters input{grid-column:1/-1}.client-filters button{width:100%}}
@media (max-width:640px){.client-filters{grid-template-columns:1fr}.client-toolbar>div{display:grid}.client-row-side,.history-row-actions{justify-items:start}}

/* Public booking sport start cards v2 */
.public-booking-widget .widget-sport-stage{
  width:min(590px,100%)!important;
  margin:0 auto!important;
}
.public-booking-widget .widget-sport-stage .public-title-row{
  margin-bottom:2px!important;
}
.public-booking-widget .widget-sport-stage .public-divider{
  margin-bottom:0!important;
}
.public-booking-widget .widget-sport-grid{
  width:100%!important;
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:28px!important;
}
.public-booking-widget .widget-sport-grid .sport-card{
  position:relative!important;
  width:100%!important;
  min-height:232px!important;
  overflow:hidden!important;
  display:block!important;
  border:1.5px solid #111!important;
  border-radius:20px!important;
  background:#fff!important;
  color:#284477!important;
  text-align:left!important;
  padding:30px 24px!important;
  box-shadow:none!important;
}
.public-booking-widget .widget-sport-grid .sport-card:hover,
.public-booking-widget .widget-sport-grid .sport-card:focus-visible{
  border-color:#284477!important;
  background:#fff!important;
  outline:0;
}
.public-booking-widget .widget-sport-grid .sport-card__title{
  position:relative!important;
  z-index:3!important;
  display:block!important;
  max-width:62%!important;
  color:#284477!important;
  font-size:56px!important;
  font-weight:850!important;
  line-height:.95!important;
  letter-spacing:-.02em!important;
}
.public-booking-widget .widget-sport-grid .sport-card__image{
  position:absolute!important;
  z-index:2!important;
  display:block!important;
  object-fit:contain!important;
  object-position:center!important;
  pointer-events:none!important;
}
.public-booking-widget .widget-sport-grid .sport-card--featured{
  min-height:232px!important;
  border:0!important;
  border-radius:20px!important;
  background:#071F34!important;
  padding:30px 24px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--featured:hover,
.public-booking-widget .widget-sport-grid .sport-card--featured:focus-visible{
  background:#071F34!important;
}
.public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
  color:#fff!important;
  font-size:56px!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda{
  position:absolute!important;
  z-index:4!important;
  left:24px!important;
  bottom:22px!important;
  display:flex!important;
  align-items:flex-end!important;
  gap:16px!important;
  margin:0!important;
  padding:0!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda em{
  color:#fff!important;
  font-size:32px!important;
  font-style:normal!important;
  font-weight:850!important;
  line-height:1!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda img{
  display:block!important;
  width:180px!important;
  height:auto!important;
}
.public-booking-widget .widget-sport-grid .sport-card--padel .sport-card__image{
  right:-28px!important;
  bottom:-46px!important;
  width:238px!important;
  height:238px!important;
  opacity:.92!important;
}
.public-booking-widget .widget-sport-grid .sport-card--squash .sport-card__image{
  right:-6px!important;
  bottom:-78px!important;
  width:250px!important;
  height:250px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--pickleball .sport-card__image{
  right:-8px!important;
  bottom:-62px!important;
  width:220px!important;
  height:220px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__image{
  right:-16px!important;
  bottom:-64px!important;
  width:238px!important;
  height:238px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__image{
  right:42px!important;
  bottom:34px!important;
  width:128px!important;
  height:128px!important;
}
@media (max-width:700px){
  .public-booking-widget .widget-sport-stage{
    width:100%!important;
  }
  .public-booking-widget .widget-sport-grid{
    gap:18px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card,
  .public-booking-widget .widget-sport-grid .sport-card--featured{
    min-height:172px!important;
    border-radius:18px!important;
    padding:24px 22px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card__title,
  .public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
    font-size:40px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card__lunda{
    left:22px!important;
    bottom:20px!important;
    gap:12px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card__lunda em{
    font-size:24px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card__lunda img{
    width:132px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--padel .sport-card__image{
    right:-46px!important;
    bottom:-42px!important;
    width:190px!important;
    height:190px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--squash .sport-card__image,
  .public-booking-widget .widget-sport-grid .sport-card--pickleball .sport-card__image,
  .public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__image{
    right:-34px!important;
    bottom:-62px!important;
    width:196px!important;
    height:196px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__image{
    right:28px!important;
    bottom:26px!important;
    width:104px!important;
    height:104px!important;
  }
}
/* Public booking sport start cards v3 */
.public-booking-widget .widget-sport-stage{
  width:min(486px,100%)!important;
  margin:0 auto!important;
  padding:18px 16px 48px!important;
  border-radius:16px!important;
  border:1px solid #D2D2D2!important;
  background:#fff!important;
  box-shadow:none!important;
}
.public-booking-widget .widget-sport-stage .public-title-row{
  display:block!important;
  margin:0 0 22px!important;
}
.public-booking-widget .widget-sport-stage .public-title-row h1{
  margin:0!important;
  color:#050505!important;
  font-size:28px!important;
  line-height:1.15!important;
  font-weight:800!important;
  letter-spacing:0!important;
}
.public-booking-widget .widget-sport-stage .public-title-row p,
.public-booking-widget .widget-sport-stage .public-title-row span,
.public-booking-widget .widget-sport-stage .public-divider{
  display:none!important;
}
.public-booking-widget .widget-sport-grid{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:24px!important;
  width:100%!important;
}
.public-booking-widget .widget-sport-grid .sport-card,
.public-booking-widget .widget-sport-grid .sport-card--featured{
  position:relative!important;
  min-height:114px!important;
  height:114px!important;
  width:100%!important;
  overflow:hidden!important;
  display:block!important;
  padding:12px 10px!important;
  border:1px solid #8798AE!important;
  border-radius:10px!important;
  background:#fff!important;
  color:#284477!important;
  text-align:left!important;
  cursor:pointer!important;
  box-shadow:none!important;
  transition:border-color .16s ease, transform .16s ease, box-shadow .16s ease!important;
}
.public-booking-widget .widget-sport-grid .sport-card:hover,
.public-booking-widget .widget-sport-grid .sport-card:focus-visible{
  border-color:#284477!important;
  transform:translateY(-1px)!important;
  box-shadow:0 8px 22px rgba(40,68,119,.12)!important;
  outline:0!important;
}
.public-booking-widget .widget-sport-grid .sport-card__title{
  position:relative!important;
  z-index:3!important;
  display:block!important;
  margin:0!important;
  color:#284477!important;
  font-size:28px!important;
  line-height:1.05!important;
  font-weight:800!important;
  letter-spacing:0!important;
  max-width:150px!important;
}
.public-booking-widget .widget-sport-grid .sport-card__image{
  position:absolute!important;
  z-index:2!important;
  display:block!important;
  max-width:none!important;
  height:auto!important;
  object-fit:contain!important;
  pointer-events:none!important;
}
.public-booking-widget .widget-sport-grid .sport-card--featured{
  border:0!important;
  background:#071F34!important;
  color:#fff!important;
}
.public-booking-widget .widget-sport-grid .sport-card--featured:hover,
.public-booking-widget .widget-sport-grid .sport-card--featured:focus-visible{
  background:#071F34!important;
  box-shadow:0 8px 22px rgba(7,31,52,.18)!important;
}
.public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
  color:#fff!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda{
  position:absolute!important;
  z-index:4!important;
  left:12px!important;
  bottom:9px!important;
  display:flex!important;
  align-items:flex-end!important;
  gap:6px!important;
  padding:0!important;
  color:#fff!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda em{
  color:#fff!important;
  font-size:22px!important;
  line-height:1!important;
  font-style:normal!important;
  font-weight:800!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda img{
  display:block!important;
  width:112px!important;
  height:auto!important;
}
.public-booking-widget .widget-sport-grid .sport-card__soon{
  position:absolute!important;
  z-index:4!important;
  left:12px!important;
  bottom:10px!important;
  color:#C84A37!important;
  font-size:12px!important;
  line-height:1!important;
  font-weight:700!important;
  text-transform:uppercase!important;
  letter-spacing:.02em!important;
}
.public-booking-widget .widget-sport-grid .sport-card--disabled{
  cursor:not-allowed!important;
  opacity:1!important;
  background:#fff!important;
}
.public-booking-widget .widget-sport-grid .sport-card--disabled:hover,
.public-booking-widget .widget-sport-grid .sport-card--disabled:focus-visible{
  transform:none!important;
  box-shadow:none!important;
  border-color:#8798AE!important;
}
.widget-inventory-list .widget-counter-row>div:first-child{
  grid-template-columns:minmax(0,1fr)!important;
}
.widget-inventory-list .widget-counter-row>div:first-child::before{
  display:none!important;
}
.widget-inventory-list .widget-counter-row strong,
.widget-inventory-list .widget-counter-row small,
.widget-inventory-list .widget-counter-row .widget-service-price{
  grid-column:1!important;
}
.public-booking-widget .widget-sport-grid .sport-card--padel .sport-card__image{
  right:-2px!important;
  bottom:-4px!important;
  width:78px!important;
  opacity:1!important;
}
.public-booking-widget .widget-sport-grid .sport-card--squash .sport-card__image{
  right:-1px!important;
  bottom:-5px!important;
  width:78px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--pickleball .sport-card__image{
  right:-10px!important;
  bottom:-4px!important;
  width:74px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__image{
  right:-1px!important;
  bottom:-6px!important;
  width:80px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__image{
  right:-8px!important;
  bottom:-4px!important;
  width:70px!important;
}
@media (max-width:540px){
  .public-booking-widget .widget-sport-stage{
    width:100%!important;
    padding:18px 14px 34px!important;
  }
  .public-booking-widget .widget-sport-grid{
    grid-template-columns:1fr!important;
    gap:14px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card,
  .public-booking-widget .widget-sport-grid .sport-card--featured{
    height:116px!important;
    min-height:116px!important;
  }
}

/* Public booking sport start cards v4 */
.public-booking-widget .widget-sport-stage{
  width:min(486px,100%)!important;
  margin:0 auto!important;
  padding:32px 16px 48px!important;
  border:1px solid #D2D2D2!important;
  border-radius:16px!important;
  background:#fff!important;
}
.public-booking-widget .widget-sport-stage .public-title-row{
  display:block!important;
  margin:0 0 24px!important;
}
.public-booking-widget .widget-sport-stage .public-title-row h1{
  margin:0!important;
  color:#050505!important;
  font-size:28px!important;
  line-height:1.15!important;
  font-weight:850!important;
  letter-spacing:0!important;
}
.public-booking-widget .widget-sport-stage .public-title-row span,
.public-booking-widget .widget-sport-stage .public-divider{
  display:none!important;
}
.public-booking-widget .widget-sport-grid{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:24px!important;
  align-items:stretch!important;
  width:100%!important;
}
.public-booking-widget .widget-sport-grid .sport-card,
.public-booking-widget .widget-sport-grid .sport-card--featured,
.public-booking-widget .widget-sport-grid .sport-card:last-child:nth-child(odd){
  grid-column:auto!important;
  justify-self:stretch!important;
  width:100%!important;
  min-width:0!important;
  height:114px!important;
  min-height:114px!important;
  display:block!important;
  position:relative!important;
  overflow:hidden!important;
  padding:12px 10px!important;
  border:1px solid #8798AE!important;
  border-radius:10px!important;
  background:#fff!important;
  color:#284477!important;
  text-align:left!important;
  box-shadow:none!important;
}
.public-booking-widget .widget-sport-grid .sport-card--featured{
  border-color:#071F34!important;
  background:#071F34!important;
  color:#fff!important;
}
.public-booking-widget .widget-sport-grid .sport-card:hover,
.public-booking-widget .widget-sport-grid .sport-card:focus-visible{
  border-color:#284477!important;
  background:#FBFCFF!important;
  transform:translateY(-1px)!important;
  box-shadow:0 8px 22px rgba(40,68,119,.12)!important;
  outline:0!important;
}
.public-booking-widget .widget-sport-grid .sport-card--featured:hover,
.public-booking-widget .widget-sport-grid .sport-card--featured:focus-visible{
  background:#071F34!important;
}
.public-booking-widget .widget-sport-grid .sport-card--disabled,
.public-booking-widget .widget-sport-grid .sport-card--disabled:hover,
.public-booking-widget .widget-sport-grid .sport-card--disabled:focus-visible{
  cursor:not-allowed!important;
  opacity:1!important;
  transform:none!important;
  box-shadow:none!important;
  border-color:#8798AE!important;
  background:#fff!important;
}
.public-booking-widget .widget-sport-grid .sport-card__title{
  position:relative!important;
  z-index:3!important;
  display:block!important;
  max-width:150px!important;
  margin:0!important;
  color:#284477!important;
  font-size:28px!important;
  line-height:1.05!important;
  font-weight:850!important;
  letter-spacing:0!important;
}
.public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
  max-width:92px!important;
  color:#fff!important;
}
.public-booking-widget .widget-sport-grid .sport-card__soon{
  position:absolute!important;
  z-index:4!important;
  left:12px!important;
  bottom:12px!important;
  color:#D14836!important;
  font-size:12px!important;
  line-height:1!important;
  font-weight:800!important;
  text-transform:uppercase!important;
  letter-spacing:0!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda{
  position:absolute!important;
  z-index:4!important;
  left:12px!important;
  bottom:11px!important;
  display:grid!important;
  grid-template-columns:auto;
  gap:0!important;
  align-items:start!important;
  color:#fff!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda em{
  display:block!important;
  color:#fff!important;
  font-size:20px!important;
  line-height:.92!important;
  font-style:normal!important;
  font-weight:850!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda img{
  display:block!important;
  width:92px!important;
  height:auto!important;
  margin-top:-2px!important;
}
.public-booking-widget .widget-sport-grid .sport-card__image{
  position:absolute!important;
  z-index:2!important;
  display:block!important;
  max-width:none!important;
  height:auto!important;
  object-fit:contain!important;
  pointer-events:none!important;
}
.public-booking-widget .widget-sport-grid .sport-card--padel .sport-card__image{
  right:-5px!important;
  bottom:-2px!important;
  width:82px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--squash .sport-card__image{
  right:-5px!important;
  bottom:-13px!important;
  width:84px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--pickleball .sport-card__image{
  right:-12px!important;
  bottom:-7px!important;
  width:78px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__image{
  right:-6px!important;
  bottom:-15px!important;
  width:90px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__image{
  right:-13px!important;
  bottom:-7px!important;
  width:78px!important;
}
@media (max-width:540px){
  .public-booking-widget .widget-sport-stage{
    padding:22px 14px 34px!important;
  }
  .public-booking-widget .widget-sport-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:14px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card,
  .public-booking-widget .widget-sport-grid .sport-card--featured{
    height:112px!important;
    min-height:112px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card__title{
    font-size:24px!important;
    max-width:132px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
    max-width:82px!important;
  }
}
@media (max-width:359px){
  .public-booking-widget .widget-sport-grid{
    gap:10px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card__title{
    font-size:21px!important;
    max-width:112px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card__lunda img{
    width:78px!important;
  }
}

/* Public booking sport start cards v5 */
.public-booking-widget .widget-sport-stage{
  width:min(486px,100%)!important;
  margin:0 auto!important;
  padding:32px 16px 34px!important;
  border:1px solid #D2D2D2!important;
  border-radius:16px!important;
  background:#fff!important;
}
.public-booking-widget .widget-sport-stage .public-title-row{
  display:block!important;
  margin:0 0 24px!important;
}
.public-booking-widget .widget-sport-stage .public-title-row h1{
  margin:0!important;
  color:#050505!important;
  font-size:28px!important;
  line-height:1.15!important;
  font-weight:850!important;
  letter-spacing:0!important;
}
.public-booking-widget .widget-sport-stage .public-title-row span,
.public-booking-widget .widget-sport-stage .public-divider{
  display:none!important;
}
.public-booking-widget .widget-sport-grid{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:14px!important;
  align-items:start!important;
  width:100%!important;
}
.public-booking-widget .widget-sport-grid .sport-card,
.public-booking-widget .widget-sport-grid .sport-card--featured,
.public-booking-widget .widget-sport-grid .sport-card:last-child:nth-child(odd){
  grid-column:auto!important;
  justify-self:stretch!important;
  position:relative!important;
  display:block!important;
  width:100%!important;
  min-width:0!important;
  height:auto!important;
  min-height:0!important;
  aspect-ratio:401/213!important;
  overflow:hidden!important;
  padding:0!important;
  border:1px solid #8798AE!important;
  border-radius:10px!important;
  background:#fff!important;
  color:#284477!important;
  text-align:left!important;
  box-shadow:none!important;
}
.public-booking-widget .widget-sport-grid .sport-card:hover,
.public-booking-widget .widget-sport-grid .sport-card:focus-visible{
  border-color:#284477!important;
  background:#FBFCFF!important;
  transform:translateY(-1px)!important;
  box-shadow:0 8px 22px rgba(40,68,119,.12)!important;
  outline:0!important;
}
.public-booking-widget .widget-sport-grid .sport-card--featured{
  border-color:#071F34!important;
  background:#071F34!important;
  color:#fff!important;
}
.public-booking-widget .widget-sport-grid .sport-card--featured:hover,
.public-booking-widget .widget-sport-grid .sport-card--featured:focus-visible{
  background:#071F34!important;
}
.public-booking-widget .widget-sport-grid .sport-card--disabled,
.public-booking-widget .widget-sport-grid .sport-card--disabled:hover,
.public-booking-widget .widget-sport-grid .sport-card--disabled:focus-visible{
  cursor:not-allowed!important;
  opacity:1!important;
  transform:none!important;
  box-shadow:none!important;
  border-color:#8798AE!important;
  background:#fff!important;
}
.public-booking-widget .widget-sport-grid .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--padel .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--squash .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--pickleball .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__image{
  position:absolute!important;
  z-index:1!important;
  inset:0!important;
  display:block!important;
  width:100%!important;
  height:100%!important;
  max-width:none!important;
  object-fit:fill!important;
  pointer-events:none!important;
}
.public-booking-widget .widget-sport-grid .sport-card__title{
  position:absolute!important;
  z-index:3!important;
  left:10px!important;
  top:50%!important;
  transform:translateY(-50%)!important;
  display:block!important;
  max-width:calc(100% - 64px)!important;
  margin:0!important;
  color:#284477!important;
  font-size:clamp(21px,5.6vw,28px)!important;
  line-height:1!important;
  font-weight:850!important;
  letter-spacing:0!important;
}
.public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
  top:42%!important;
  max-width:92px!important;
  color:#fff!important;
  font-size:clamp(22px,5.8vw,28px)!important;
}
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__title{
  top:45%!important;
  max-width:136px!important;
  line-height:.98!important;
}
.public-booking-widget .widget-sport-grid .sport-card__soon{
  position:absolute!important;
  z-index:4!important;
  left:10px!important;
  bottom:12px!important;
  color:#D14836!important;
  font-size:12px!important;
  line-height:1!important;
  font-weight:800!important;
  text-transform:uppercase!important;
  letter-spacing:0!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda{
  position:absolute!important;
  z-index:4!important;
  left:10px!important;
  bottom:10px!important;
  display:grid!important;
  grid-template-columns:auto;
  gap:0!important;
  color:#fff!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda em{
  display:block!important;
  color:#fff!important;
  font-size:clamp(16px,4.5vw,22px)!important;
  line-height:.9!important;
  font-style:normal!important;
  font-weight:850!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda img{
  display:block!important;
  width:clamp(78px,22vw,96px)!important;
  height:auto!important;
  margin-top:-1px!important;
}
@media (min-width:430px){
  .public-booking-widget .widget-sport-grid{
    gap:14px!important;
  }
}
@media (max-width:380px){
  .public-booking-widget .widget-sport-stage{
    padding:24px 12px 30px!important;
  }
  .public-booking-widget .widget-sport-grid{
    gap:10px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card__title{
    left:9px!important;
    max-width:calc(100% - 58px)!important;
    font-size:clamp(19px,5.8vw,23px)!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
    max-width:78px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__title{
    max-width:112px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card__soon{
    left:9px!important;
    bottom:10px!important;
    font-size:10px!important;
  }
}

/* Public booking sport start cards v6 */
.public-booking-widget .widget-sport-grid{
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:14px!important;
}
.public-booking-widget .widget-sport-grid .sport-card,
.public-booking-widget .widget-sport-grid .sport-card--featured,
.public-booking-widget .widget-sport-grid .sport-card:last-child:nth-child(odd){
  aspect-ratio:401/213!important;
  height:auto!important;
  min-height:0!important;
}
.public-booking-widget .widget-sport-grid .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--padel .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--squash .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--pickleball .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__image{
  inset:0!important;
  width:100%!important;
  height:100%!important;
  object-fit:fill!important;
}
.public-booking-widget .widget-sport-grid .sport-card__title{
  left:10px!important;
  top:50%!important;
  max-width:calc(100% - 58px)!important;
  font-size:clamp(20px,5.2vw,27px)!important;
  line-height:1!important;
}
.public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
  top:34%!important;
  max-width:88px!important;
  font-size:clamp(21px,5.4vw,28px)!important;
}
.public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__title{
  max-width:132px!important;
  font-size:clamp(20px,5vw,26px)!important;
}
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__title{
  top:47%!important;
  max-width:128px!important;
  font-size:clamp(20px,5vw,26px)!important;
  line-height:.98!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda{
  left:10px!important;
  bottom:9px!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda em{
  font-size:clamp(15px,3.9vw,18px)!important;
  line-height:.9!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda img{
  width:clamp(72px,19vw,84px)!important;
}
.public-booking-widget .widget-sport-grid .sport-card__soon{
  left:10px!important;
  bottom:12px!important;
  font-size:clamp(10px,2.7vw,12px)!important;
}
@media (max-width:380px){
  .public-booking-widget .widget-sport-grid{
    gap:10px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card__title{
    left:8px!important;
    max-width:calc(100% - 48px)!important;
    font-size:clamp(18px,5.6vw,21px)!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
    max-width:72px!important;
    font-size:clamp(19px,5.8vw,22px)!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__title,
  .public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__title{
    max-width:106px!important;
    font-size:clamp(18px,5.4vw,20px)!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card__soon{
    left:8px!important;
    bottom:8px!important;
    font-size:9px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card__lunda{
    left:8px!important;
    bottom:7px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card__lunda img{
    width:68px!important;
  }
}

/* Public booking sport start cards v7 */
.public-booking-widget .widget-sport-grid .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--padel .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--squash .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--pickleball .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__image{
  inset:auto!important;
  left:12%!important;
  top:0!important;
  right:auto!important;
  bottom:auto!important;
  width:100%!important;
  height:100%!important;
  object-fit:fill!important;
}
.public-booking-widget .widget-sport-grid .sport-card__title{
  left:10px!important;
  top:18%!important;
  transform:none!important;
  max-width:calc(100% - 58px)!important;
  font-size:clamp(20px,5.2vw,27px)!important;
  line-height:1!important;
}
.public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
  top:18%!important;
  max-width:88px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__title{
  top:18%!important;
  max-width:126px!important;
  line-height:.98!important;
}
.public-booking-widget .widget-sport-grid .sport-card__soon{
  left:10px!important;
  bottom:12px!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda{
  left:10px!important;
  bottom:9px!important;
}
@media (max-width:380px){
  .public-booking-widget .widget-sport-grid .sport-card__image,
  .public-booking-widget .widget-sport-grid .sport-card--padel .sport-card__image,
  .public-booking-widget .widget-sport-grid .sport-card--squash .sport-card__image,
  .public-booking-widget .widget-sport-grid .sport-card--pickleball .sport-card__image,
  .public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__image,
  .public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__image{
    left:14%!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card__title{
    left:8px!important;
    top:18%!important;
    max-width:calc(100% - 48px)!important;
    font-size:clamp(18px,5.6vw,21px)!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
    max-width:72px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__title{
    max-width:108px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card__soon{
    left:8px!important;
    bottom:8px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card__lunda{
    left:8px!important;
    bottom:7px!important;
  }
}

/* Public booking sport start cards v8 */
.public-booking-widget .widget-sport-grid .sport-card__title{
  top:16px!important;
  transform:none!important;
  max-width:112px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
  top:16px!important;
  max-width:82px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__title{
  max-width:116px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__title{
  top:16px!important;
  max-width:118px!important;
}
.public-booking-widget .widget-sport-grid .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--padel .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--squash .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--pickleball .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__image{
  inset:auto!important;
  top:0!important;
  right:auto!important;
  bottom:auto!important;
  width:100%!important;
  height:100%!important;
  object-fit:fill!important;
}
.public-booking-widget .widget-sport-grid .sport-card--padel .sport-card__image{
  left:22%!important;
}
.public-booking-widget .widget-sport-grid .sport-card--squash .sport-card__image{
  left:20%!important;
}
.public-booking-widget .widget-sport-grid .sport-card--pickleball .sport-card__image{
  left:30%!important;
}
.public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__image{
  left:23%!important;
}
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__image{
  left:30%!important;
}
@media (max-width:380px){
  .public-booking-widget .widget-sport-grid .sport-card__title{
    top:14px!important;
    max-width:96px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
    max-width:70px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__title,
  .public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__title{
    max-width:98px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--padel .sport-card__image{
    left:24%!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--squash .sport-card__image{
    left:22%!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--pickleball .sport-card__image{
    left:32%!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__image{
    left:25%!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__image{
    left:32%!important;
  }
}

/* Public booking sport start cards v9 */
.public-booking-widget .widget-sport-grid .sport-card__title{
  top:16px!important;
  left:10px!important;
  max-width:96px!important;
  font-size:clamp(19px,4.9vw,24px)!important;
  line-height:1!important;
  transform:none!important;
  z-index:3!important;
}
.public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
  max-width:76px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__title{
  max-width:102px!important;
  font-size:clamp(18px,4.7vw,23px)!important;
}
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__title{
  max-width:106px!important;
  font-size:clamp(18px,4.7vw,23px)!important;
  line-height:.98!important;
}
.public-booking-widget .widget-sport-grid .sport-card--padel .sport-card__image{
  left:30%!important;
}
.public-booking-widget .widget-sport-grid .sport-card--squash .sport-card__image{
  left:34%!important;
}
.public-booking-widget .widget-sport-grid .sport-card--pickleball .sport-card__image{
  left:42%!important;
}
.public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__image{
  left:38%!important;
}
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__image{
  left:42%!important;
}
.public-booking-widget .widget-sport-grid .sport-card__soon{
  left:10px!important;
  bottom:10px!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda{
  left:10px!important;
  bottom:8px!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda img{
  width:clamp(66px,17vw,78px)!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda em{
  font-size:clamp(14px,3.6vw,17px)!important;
}
@media (max-width:380px){
  .public-booking-widget .widget-sport-grid .sport-card__title{
    top:13px!important;
    left:8px!important;
    max-width:84px!important;
    font-size:clamp(17px,5.1vw,20px)!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
    max-width:64px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__title,
  .public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__title{
    max-width:88px!important;
    font-size:clamp(16px,5vw,19px)!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--padel .sport-card__image{
    left:32%!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--squash .sport-card__image{
    left:36%!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--pickleball .sport-card__image{
    left:44%!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__image{
    left:40%!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__image{
    left:44%!important;
  }
}

/* Public booking sport start cards v10 */
.public-booking-widget .widget-sport-grid .sport-card__title{
  font-size:clamp(17px,4.4vw,21px)!important;
  max-width:88px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
  max-width:68px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__title{
  max-width:94px!important;
  font-size:clamp(16px,4.2vw,20px)!important;
}
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__title{
  max-width:98px!important;
  font-size:clamp(16px,4.2vw,20px)!important;
}
.public-booking-widget .widget-sport-grid .sport-card--padel .sport-card__image{
  top:8px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--squash .sport-card__image{
  top:7px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--pickleball .sport-card__image{
  top:9px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__image{
  top:9px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__image{
  top:9px!important;
}
@media (max-width:380px){
  .public-booking-widget .widget-sport-grid .sport-card__title{
    font-size:clamp(15px,4.8vw,18px)!important;
    max-width:76px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
    max-width:58px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__title,
  .public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__title{
    max-width:82px!important;
    font-size:clamp(15px,4.6vw,17px)!important;
  }
}

/* Public booking sport start cards v11 */
.public-booking-widget .widget-sport-grid .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--padel .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--squash .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--pickleball .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__image{
  inset:auto!important;
  left:0!important;
  top:7px!important;
  right:auto!important;
  bottom:auto!important;
  width:100%!important;
  height:100%!important;
  object-fit:fill!important;
}
.public-booking-widget .widget-sport-grid .sport-card__title{
  top:14px!important;
  left:10px!important;
  transform:none!important;
  max-width:82px!important;
  font-size:clamp(16px,4vw,20px)!important;
  line-height:.98!important;
  z-index:3!important;
}
.public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
  max-width:62px!important;
}
.public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__title{
  max-width:88px!important;
  font-size:clamp(15px,3.8vw,19px)!important;
}
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__title{
  max-width:90px!important;
  font-size:clamp(15px,3.8vw,19px)!important;
}
.public-booking-widget .widget-sport-grid .sport-card__soon{
  left:10px!important;
  bottom:10px!important;
  font-size:clamp(10px,2.5vw,12px)!important;
  line-height:1!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda{
  left:10px!important;
  bottom:8px!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda img{
  width:clamp(62px,15.5vw,74px)!important;
}
.public-booking-widget .widget-sport-grid .sport-card__lunda em{
  font-size:clamp(13px,3.2vw,16px)!important;
}
@media (max-width:380px){
  .public-booking-widget .widget-sport-grid .sport-card__image,
  .public-booking-widget .widget-sport-grid .sport-card--padel .sport-card__image,
  .public-booking-widget .widget-sport-grid .sport-card--squash .sport-card__image,
  .public-booking-widget .widget-sport-grid .sport-card--pickleball .sport-card__image,
  .public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__image,
  .public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__image{
    left:0!important;
    top:7px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card__title{
    top:13px!important;
    left:9px!important;
    max-width:76px!important;
    font-size:clamp(15px,4.4vw,18px)!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--featured .sport-card__title{
    max-width:56px!important;
  }
  .public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__title,
  .public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__title{
    max-width:80px!important;
    font-size:clamp(14px,4.2vw,17px)!important;
  }
}

/* Public booking sport start cards v12 */
.public-booking-widget .widget-sport-grid .sport-card--squash .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--pickleball .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__image,
.public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__image{
  left:2px!important;
  width:calc(100% + 3px)!important;
}
@media (max-width:380px){
  .public-booking-widget .widget-sport-grid .sport-card--squash .sport-card__image,
  .public-booking-widget .widget-sport-grid .sport-card--pickleball .sport-card__image,
  .public-booking-widget .widget-sport-grid .sport-card--badminton .sport-card__image,
  .public-booking-widget .widget-sport-grid .sport-card--table-tennis .sport-card__image{
    left:2px!important;
    width:calc(100% + 3px)!important;
  }
}

/* Public booking sport brand v13 */
.public-booking-widget .widget-sport-brand{
  display:flex!important;
  align-items:center!important;
  justify-content:flex-start!important;
  width:100%!important;
  margin:0 0 16px!important;
}
.public-booking-widget .widget-sport-brand img{
  display:block!important;
  width:clamp(126px,34vw,154px)!important;
  height:auto!important;
  max-height:54px!important;
  object-fit:contain!important;
}
.public-booking-widget .public-widget-logo{
  width:clamp(118px,32vw,150px)!important;
  height:46px!important;
}
.public-booking-widget .public-widget-logo img{
  width:100%!important;
  height:100%!important;
  object-fit:contain!important;
}
@media (max-width:380px){
  .public-booking-widget .widget-sport-brand{
    margin-bottom:14px!important;
  }
  .public-booking-widget .widget-sport-brand img{
    width:clamp(118px,36vw,142px)!important;
    max-height:50px!important;
  }
}

/* Widget monitoring */
.monitor-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:14px}.monitor-stat{display:grid;gap:8px}.monitor-stat span{color:var(--muted)}.monitor-stat strong{font-size:30px;color:var(--accent);line-height:1}.monitor-stat.is-danger strong{color:var(--danger)}.monitor-layout{margin-bottom:14px}.monitor-funnel{display:grid;gap:12px;margin-top:16px}.monitor-funnel-row{display:grid;gap:7px}.monitor-funnel-row div{display:flex;align-items:center;justify-content:space-between;gap:12px}.monitor-funnel-row span{color:var(--muted);font-weight:700}.monitor-funnel-row i{display:block;height:9px;min-width:8px;border-radius:999px;background:var(--accent)}.monitor-table{display:grid;gap:10px;margin-top:16px}.monitor-table-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:10px;align-items:center;border:1px solid var(--line);border-radius:12px;padding:10px}.monitor-table-row span,.monitor-table-row em{color:var(--muted);font-style:normal}.monitor-table-row em.is-danger{color:var(--danger);font-weight:700}.monitor-events{margin-top:14px}.monitor-event-list{display:grid;gap:10px;margin-top:16px}.monitor-event{display:grid;gap:7px;border:1px solid var(--line);border-radius:12px;padding:11px;background:#fff}.monitor-event.is-error{border-color:#F4C7C3;background:#FFF8F7}.monitor-event-main,.monitor-event-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.monitor-event-main{justify-content:space-between}.monitor-event-main span,.monitor-event-meta span{color:var(--muted);font-size:12px}.monitor-event-meta span{border:1px solid #E8EDF3;border-radius:999px;padding:4px 7px;background:#F5F7FA}.monitor-event p{color:var(--danger);font-size:13px}
@media (max-width:960px){.monitor-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.monitor-layout{grid-template-columns:1fr}.monitor-table-row{grid-template-columns:1fr}}
@media (max-width:560px){.monitor-grid{grid-template-columns:1fr}.monitor-stat strong{font-size:26px}}

/* Public booking loading and fallback */
.public-booking-widget{position:relative}.public-loading-overlay{position:absolute;inset:0;z-index:25;display:grid;place-items:center;padding:20px;background:rgba(255,255,255,.76);backdrop-filter:blur(3px)}.public-loading-overlay[hidden]{display:none}.public-loading-overlay>div{width:min(300px,100%);display:grid;justify-items:center;gap:10px;padding:22px 18px;border:1px solid #DDE5EF;border-radius:16px;background:#fff;box-shadow:0 18px 50px rgba(16,24,40,.16);text-align:center}.public-loading-overlay strong{color:var(--accent);font-size:17px}.public-loading-overlay p{color:var(--muted);line-height:1.4}.public-spinner{width:34px;height:34px;border-radius:999px;border:3px solid #DDE5EF;border-top-color:var(--accent);animation:public-spin .72s linear infinite}@keyframes public-spin{to{transform:rotate(360deg)}}.public-booking-flow-result.error a{color:var(--accent);font-weight:800}.widget-result-actions{display:grid;grid-template-columns:1fr;gap:9px}.widget-result-actions .primary,.widget-result-actions .button{display:flex;align-items:center;justify-content:center;width:100%;min-height:48px;border-radius:12px;font-weight:850;text-align:center}.widget-result-actions .primary{background:var(--accent);color:#fff}.widget-result-actions .button{border:1px solid var(--line);background:#fff;color:var(--text)}

/* Sync feedback and compact direct widget */
.sync-result{display:grid;gap:5px;margin:-4px 0 14px;border:1px solid #CFE4D5;border-radius:12px;background:#F3FAF5;color:#15572A;padding:12px 14px}.sync-result.is-warning{border-color:#F1D39A;background:#FFF8EA;color:#7A4E00}.sync-result strong{font-size:14px}.sync-result span{line-height:1.35}.public-booking-widget-body{justify-content:center!important}.public-booking-embed-body{justify-content:flex-end!important}.public-booking-widget-body .public-booking{max-width:456px!important}.widget-result-details-toggle{display:grid;gap:10px;border:1px solid #DDE8D4;border-radius:12px;background:#fff;padding:12px;color:var(--text)}.widget-result-details-toggle summary{cursor:pointer;color:var(--accent);font-weight:850}.widget-result-details-toggle .button{width:100%;min-height:44px;border-radius:11px;font-weight:850}.widget-result-success>strong{font-size:19px}.widget-result-success>p{display:none}.widget-result-success button:disabled{opacity:.68;cursor:not-allowed}

/* Booking notifications and public source */
.booking.source-public,.booking[data-source="public_booking"]{background:#F1ECFF!important;border-color:#9B7BEA!important;color:#3D257E!important;box-shadow:inset 0 3px 0 #7C5AD9}.booking.source-public em,.booking[data-source="public_booking"] em{color:#5B49A2!important}.booking.source-public .booking-event-badge,.booking[data-source="public_booking"] .booking-event-badge{background:#7C5AD9!important;color:#fff!important}.booking-notifications{position:fixed;right:24px;bottom:24px;z-index:18}.booking-notifications-toggle{position:relative;width:48px;height:48px;display:grid;place-items:center;border:1px solid #DDE5EF;border-radius:999px;background:#fff;color:var(--accent);box-shadow:0 16px 38px rgba(16,24,40,.16);cursor:pointer}.booking-notifications-toggle svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.booking-notifications-toggle i{position:absolute;right:8px;top:8px;width:10px;height:10px;border-radius:999px;background:#E23D3D;box-shadow:0 0 0 3px #fff}.booking-notifications-toggle i[hidden],.booking-notifications-panel[hidden]{display:none}.booking-notifications-panel{position:absolute;right:0;bottom:58px;width:min(360px,calc(100vw - 32px));max-height:min(520px,calc(100vh - 110px));display:grid;grid-template-rows:auto minmax(0,1fr);overflow:hidden;border:1px solid #DDE5EF;border-radius:16px;background:#fff;box-shadow:0 24px 70px rgba(16,24,40,.2)}.booking-notifications-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 14px;border-bottom:1px solid #EEF1F5}.booking-notifications-head .ghost{padding:6px 8px;font-size:12px}.booking-notifications-list{display:grid;gap:8px;overflow:auto;padding:12px}.booking-notification-item{display:grid;gap:8px;border:1px solid #E3E8F0;border-radius:12px;background:#fff;padding:11px}.booking-notification-item.unread{border-color:#B9A6F4;background:#F6F2FF}.booking-notification-item>div:first-child,.booking-notification-item>div:last-child{display:flex;align-items:center;justify-content:space-between;gap:10px}.booking-notification-item strong{color:#2E236B}.booking-notification-item small{color:var(--muted);white-space:nowrap}.booking-notification-item p{color:#4B5565;line-height:1.38}.booking-notification-link{color:#6B52C8;font-weight:800;font-size:12px}.client-name-variants{display:grid;gap:8px;margin-top:14px;border-top:1px solid #EEF1F5;padding-top:14px}.client-name-variants p{color:var(--muted);font-size:13px}.client-name-variant-list{display:flex;flex-wrap:wrap;gap:8px}.client-name-variant-list form{display:inline-flex;align-items:center;gap:6px;border:1px solid #DDE5EF;border-radius:999px;background:#F8FAFC;padding:4px 5px 4px 10px}.client-name-variant-list button{width:24px;height:24px;display:grid;place-items:center;padding:0;border-radius:999px}

/* Public booking success state */
.public-booking-widget .widget-result-success{border:0!important;border-radius:0!important;background:#fff!important;color:var(--text)!important;padding:0!important;gap:14px!important;box-shadow:none!important}.public-booking-widget .widget-result-hero{display:grid;grid-template-columns:42px minmax(0,1fr);gap:12px;align-items:start;border:1px solid #DDE5EF;border-radius:14px;background:#F8FBFF;padding:14px}.public-booking-widget .widget-result-hero>span{width:42px;height:42px;display:grid;place-items:center;border-radius:999px;background:var(--accent);box-shadow:0 10px 22px rgba(40,68,119,.18)}.public-booking-widget .widget-result-hero>span::before{content:"";width:16px;height:9px;border-left:3px solid #fff;border-bottom:3px solid #fff;transform:rotate(-45deg) translate(1px,-1px)}.public-booking-widget .widget-result-hero strong{display:block;color:var(--accent);font-size:24px;line-height:1.1}.public-booking-widget .widget-result-hero p{display:block!important;margin-top:6px;color:#5D6980;font-size:14px;line-height:1.45}.public-booking-widget .widget-result-details-toggle{display:grid;gap:10px;border:1px solid #DDE5EF!important;border-radius:14px!important;background:#fff!important;padding:0!important;overflow:hidden;color:var(--text)!important}.public-booking-widget .widget-result-details-toggle summary{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:50px;padding:0 14px;cursor:pointer;color:var(--accent)!important;font-weight:850;list-style:none}.public-booking-widget .widget-result-details-toggle summary::-webkit-details-marker{display:none}.public-booking-widget .widget-result-details-toggle summary::after{content:"";width:9px;height:9px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);transition:transform .16s ease}.public-booking-widget .widget-result-details-toggle[open] summary{border-bottom:1px solid #EEF1F5}.public-booking-widget .widget-result-details-toggle[open] summary::after{transform:rotate(225deg)}.public-booking-widget .widget-result-details{border:0!important;border-radius:0!important;background:#fff!important;padding:12px 14px!important;gap:11px!important}.public-booking-widget .widget-result-details div{display:grid!important;grid-template-columns:minmax(96px,.65fr) minmax(0,1fr)!important;gap:10px!important;align-items:start}.public-booking-widget .widget-result-details span{font-size:11px!important;letter-spacing:0!important;color:#6A7588!important;text-transform:none!important}.public-booking-widget .widget-result-details strong{color:#142033!important;font-size:14px!important}.public-booking-widget .widget-result-details em{display:inline;color:#6A7588;font-size:12px}.public-booking-widget .widget-copy-button{width:calc(100% - 28px)!important;margin:0 14px 14px!important;min-height:44px!important;border-radius:12px!important;background:#EEF4FF!important;border-color:#CBD8EA!important;color:var(--accent)!important;font-weight:850!important}.public-booking-widget .widget-result-note{display:grid;gap:5px;border:1px solid #DDE5EF!important;border-radius:14px!important;background:#F8FBFF!important;padding:13px 14px!important;color:#24324A!important}.public-booking-widget .widget-result-note strong{color:var(--accent)!important;font-size:14px}.public-booking-widget .widget-result-note span{color:#5D6980!important;line-height:1.45}.public-booking-widget .widget-account-disabled{min-height:44px!important;border-radius:12px!important;border:1px dashed #CBD5E1!important;background:#F8FAFC!important;color:#8993A3!important;font-weight:800!important;opacity:1!important;cursor:not-allowed!important}
