:root{--bg:#fff1f2;--card:#fff;--ink:#111827;--muted:#6b7280;--line:#ffe4e6;--accent:#e11d48;--accent2:#fb7185;--green:#16a34a;--red:#dc2626;--shadow:0 20px 50px rgba(190,18,60,.12);--r:26px}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;color:var(--ink);background:radial-gradient(circle at 10% 0,rgba(251,113,133,.35),transparent 28rem),linear-gradient(180deg,#fff1f2,#f8fafc)}a{color:inherit;text-decoration:none}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:18px;margin:0 auto;padding:12px 18px;width:min(1180px,calc(100% - 28px));border:1px solid var(--line);border-top:0;border-radius:0 0 24px 24px;background:rgba(255,255,255,.9);box-shadow:var(--shadow);backdrop-filter:blur(16px)}.brand{display:flex;align-items:center;gap:12px;font-weight:900}.brand-logo{width:44px;height:44px;border-radius:16px;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;display:grid;place-items:center;box-shadow:0 12px 25px rgba(225,29,72,.25)}.brand small{display:block;color:var(--muted);font-size:12px;font-weight:700}.nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.nav a,.nav button,.btn{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:999px;padding:10px 14px;background:#fff;color:#374151;font-weight:800;box-shadow:inset 0 0 0 1px #f3f4f6;cursor:pointer}.nav a:hover,.nav button:hover,.btn:hover{background:#fff1f2;color:#be123c}.btn{background:var(--accent);color:#fff;box-shadow:none}.btn.secondary{background:#111827}.btn.light{background:#fff;color:#be123c;box-shadow:inset 0 0 0 1px #fecdd3}.btn.small{padding:8px 12px;font-size:13px}.inline{display:inline;margin:0}.shell{width:min(1180px,calc(100% - 28px));margin:0 auto;padding:34px 0 108px}.hero{display:grid;grid-template-columns:1.15fr .85fr;gap:24px;align-items:stretch}.card,.panel{background:rgba(255,255,255,.92);border:1px solid var(--line);border-radius:var(--r);padding:24px;box-shadow:var(--shadow)}.card h1,.card h2,.panel h1,.panel h2{margin-top:0}.lead{font-size:18px;line-height:1.55;color:#374151}.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.stat{padding:18px;border-radius:20px;background:#fff7f8;border:1px solid #ffe4e6}.stat b{display:block;font-size:28px}.muted{color:var(--muted)}.table-wrap{overflow:auto;border-radius:20px;border:1px solid var(--line)}table{width:100%;border-collapse:collapse;background:#fff}th,td{padding:13px 14px;border-bottom:1px solid #f3f4f6;text-align:left;vertical-align:top}th{font-size:12px;text-transform:uppercase;color:#6b7280;background:#fff7f8}.input, input, select, textarea{width:100%;border:1px solid #fecdd3;border-radius:16px;padding:12px 14px;background:#fff;color:#111827;font:inherit}.checkbox-input{width:auto}.form-row{margin-bottom:16px}.helptext{display:block;color:var(--muted);font-size:12px;margin-top:4px}.errorlist{color:var(--red)}.messages{display:grid;gap:10px;margin-bottom:18px}.message{padding:14px 16px;border-radius:18px;background:#fff;border:1px solid var(--line)}.message.success{border-color:#bbf7d0;background:#f0fdf4}.message.error{border-color:#fecaca;background:#fef2f2}.message.warning{border-color:#fde68a;background:#fffbeb}.actions{display:flex;gap:10px;flex-wrap:wrap}.badge{display:inline-flex;padding:6px 10px;border-radius:999px;background:#fff1f2;color:#be123c;font-weight:800;font-size:12px}.status{font-weight:900}.bottom-nav{display:none}.list{display:grid;gap:14px}.avatar{width:64px;height:64px;border-radius:20px;background:linear-gradient(135deg,#e11d48,#fb7185);display:grid;place-items:center;color:#fff;font-weight:900}.service-line{display:flex;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid #f3f4f6}@media(max-width:820px){.topbar{position:relative;align-items:flex-start}.nav{display:none}.hero,.grid,.grid.two{grid-template-columns:1fr}.shell{padding-top:18px}.bottom-nav{position:fixed;z-index:30;left:0;right:0;bottom:0;display:flex;justify-content:space-around;background:rgba(255,255,255,.94);border-top:1px solid var(--line);padding:8px 8px max(8px,env(safe-area-inset-bottom));backdrop-filter:blur(16px)}.bottom-nav a{display:grid;gap:2px;place-items:center;color:#374151;font-size:18px}.bottom-nav span{font-size:11px;font-weight:800}.card,.panel{padding:18px;border-radius:22px}}

/* Brand graphics */
:root{--accent:#009c9b;--accent2:#ff6f7b;--line:#d8fbfb;--bg:#f0fdfa;--shadow:0 20px 50px rgba(0,121,121,.13)}
body{background:radial-gradient(circle at 10% 0,rgba(0,196,190,.24),transparent 30rem),radial-gradient(circle at 95% 10%,rgba(255,111,123,.18),transparent 28rem),linear-gradient(180deg,#f0fdfa,#f8fafc)}
.brand-logo-img{width:48px;height:48px;border-radius:16px;display:block;object-fit:cover;box-shadow:0 12px 25px rgba(0,121,121,.22)}
.nav a:hover,.nav button:hover,.btn:hover{background:#ecfeff;color:#006b6a}.btn{background:linear-gradient(135deg,var(--accent),#00b8b4);color:#fff;box-shadow:none}.btn.light{background:#fff;color:#007c7b;box-shadow:inset 0 0 0 1px #a7f3f0}.badge{background:#ecfeff;color:#007c7b}.stat{background:rgba(255,255,255,.74);border-color:#ccfbf1}.hero-main{grid-template-columns:.82fr 1.18fr}.hero-copy h1{font-size:clamp(32px,5vw,58px);line-height:1.02;margin-bottom:18px}.hero-preview-card{padding:0;overflow:hidden;display:grid;place-items:center;min-height:360px;background:linear-gradient(135deg,rgba(255,255,255,.94),rgba(240,253,250,.82))}.hero-preview{display:block;width:100%;height:100%;min-height:360px;object-fit:cover}.business-card,.master-card{display:grid;gap:8px}.business-card-logo,.master-card-photo,.profile-image,.business-header-logo{object-fit:cover;border-radius:24px;box-shadow:0 16px 32px rgba(0,121,121,.14);background:#fff}.business-card-logo{width:72px;height:72px}.master-card-photo,.avatar{width:76px;height:76px;border-radius:24px}.profile-image{width:132px;height:132px;margin-bottom:14px}.profile-image-placeholder{display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;font-size:54px;font-weight:900}.business-header{display:flex;align-items:center;gap:18px}.business-header-logo{width:96px;height:96px;flex:none}.business-header-body{min-width:0}.business-public-card,.master-public-card{position:relative;overflow:hidden}.business-public-card:after,.master-public-card:after{content:"";position:absolute;right:-80px;top:-80px;width:220px;height:220px;border-radius:999px;background:radial-gradient(circle,rgba(0,184,180,.18),transparent 70%);pointer-events:none}.service-line b{white-space:nowrap;color:#007c7b}@media(max-width:820px){.brand-logo-img{width:44px;height:44px}.hero-main{grid-template-columns:1fr}.hero-preview-card{min-height:220px}.hero-preview{min-height:220px}.business-header{align-items:flex-start;flex-direction:column}.business-header-logo{width:84px;height:84px}.profile-image{width:112px;height:112px}.topbar{width:min(1180px,calc(100% - 20px));padding:10px 12px}.brand small{font-size:11px}}

/* Upload previews */
.upload-preview{display:flex;align-items:center;gap:16px;margin:0 0 18px;padding:14px;border:1px solid var(--line);border-radius:22px;background:rgba(255,255,255,.72)}
.upload-preview p{margin:0;font-weight:800}
.upload-preview img{width:112px;height:112px;object-fit:cover;border-radius:24px;box-shadow:0 14px 28px rgba(0,121,121,.14);background:#fff}
@media(max-width:640px){.upload-preview{align-items:flex-start;flex-direction:column}.upload-preview img{width:96px;height:96px}}

/* ServiceCRM extended public/catalog UI */
.nav a,.nav button,.btn{font-family:inherit;font-size:14px;line-height:1.2;text-decoration:none}.nav-form button{font:inherit}.business-nav-panel{margin-bottom:16px}.business-nav-actions{display:flex;gap:8px;flex-wrap:wrap}.filter-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr auto;gap:10px;align-items:end}.chip{display:inline-flex;align-items:center;gap:4px;margin:3px 4px 3px 0;padding:6px 10px;border-radius:999px;background:#ecfeff;color:#007c7b;font-weight:800;font-size:12px}.rating-line{display:block;color:#0f766e;font-weight:900}.favorite-card{position:relative}.favorite-form{position:absolute;right:12px;top:12px;z-index:2}.favorite-star{width:38px;height:38px;border:0;border-radius:999px;background:#fff;color:#cbd5e1;font-size:22px;line-height:1;display:grid;place-items:center;box-shadow:0 8px 22px rgba(15,118,110,.12);cursor:pointer}.favorite-star.active{color:#f59e0b;background:#fffbeb}.favorite-star.inline-star{position:static;width:32px;height:32px;font-size:18px;box-shadow:none;border:1px solid var(--line)}.master-card a{display:grid;gap:8px}.gallery-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.gallery-grid figure{margin:0;border:1px solid var(--line);border-radius:20px;overflow:hidden;background:#fff}.gallery-grid img{display:block;width:100%;aspect-ratio:4/3;object-fit:cover}.gallery-grid figcaption{padding:10px 12px;font-weight:800}.manage-gallery figure form{padding:0 10px 10px}.schedule-chips{display:flex;gap:8px;flex-wrap:wrap}.compact-schedule table{min-width:780px}.compact-schedule th,.compact-schedule td{padding:8px}.compact-schedule input[type=time]{min-width:96px;padding:8px 10px;border-radius:12px}.compact-schedule input[type=checkbox]{width:auto}.service-choice-block{display:grid;gap:8px;margin:0 0 16px}.form-label{display:block;font-weight:900;margin-bottom:4px}.service-checkbox-row{display:grid;grid-template-columns:24px 1fr;align-items:center;gap:10px;padding:12px 14px;border:1px solid var(--line);border-radius:16px;background:#fff}.service-checkbox-row input{width:18px;height:18px;margin:0}.map-placeholder{min-height:360px;border-radius:24px;border:1px dashed #99f6e4;background:radial-gradient(circle at 20% 20%,rgba(20,184,166,.16),transparent 18rem),linear-gradient(135deg,#ecfeff,#fff);display:grid;place-items:center;text-align:center;padding:34px}.list-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px;border:1px solid var(--line);border-radius:18px;background:#fff}.small-logo{width:52px;height:52px;object-fit:cover;border-radius:16px;float:left;margin:0 12px 0 0}.broadcast-client-list ul{list-style:none;margin:0 0 16px;padding:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;max-height:360px;overflow:auto}.broadcast-client-list li{padding:9px 10px;border:1px solid var(--line);border-radius:14px;background:#fff}.broadcast-client-list label{display:grid;grid-template-columns:24px 1fr;gap:8px;align-items:center}.broadcast-client-list input{width:18px;height:18px;margin:0}.card-with-actions .actions{margin-top:auto}
@media(max-width:960px){.filter-grid{grid-template-columns:1fr 1fr}.filter-grid .btn{width:100%}.gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.compact-schedule{overflow-x:auto}.business-nav-actions .btn{font-size:13px;padding:9px 11px}}
@media(max-width:640px){.broadcast-client-list ul{grid-template-columns:1fr}.filter-grid{grid-template-columns:1fr}.gallery-grid{grid-template-columns:1fr}.list-row{align-items:flex-start;flex-direction:column}.business-nav-actions{overflow:auto;flex-wrap:nowrap;padding-bottom:4px}.business-nav-actions .btn{white-space:nowrap}.bottom-nav{overflow-x:auto;justify-content:flex-start}.bottom-nav a{min-width:72px}}

/* ServiceCRM fixes: header typography, user indicator, clients, schedule */
.nav a,.nav button,.nav-register-link,.nav-logout-button{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif!important;font-size:14px!important;font-weight:800!important;line-height:1.2!important;letter-spacing:0!important;text-transform:none!important;appearance:none;-webkit-appearance:none}.nav-register-link{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:999px;padding:10px 14px;background:linear-gradient(135deg,var(--accent),#00b8b4)!important;color:#fff!important;box-shadow:none!important}.nav-form{display:inline-flex;margin:0}.nav-form button{margin:0}.current-user-pill{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:9px 12px;background:#ecfeff;color:#0f766e;font-size:13px;font-weight:900;box-shadow:inset 0 0 0 1px #a7f3f0;max-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.clients-page-sections{display:grid;grid-template-columns:1fr;gap:16px}.clients-page-grid{grid-template-columns:1fr}.clients-table-wrap{overflow-x:auto}.clients-table{min-width:980px}.compact-input{min-width:180px;padding:9px 10px;border-radius:12px}.compact-textarea{min-width:220px;padding:9px 10px;border-radius:12px;resize:vertical}.schedule-wide-panel{width:100%}.schedule-table-wide table{min-width:920px}.schedule-table-wide input[type=time]{min-width:108px}.schedule-master-filter{max-width:520px}.business-nav-actions{align-items:center}@media(max-width:1100px){.clients-page-grid{grid-template-columns:1fr}.schedule-table-wide table{min-width:860px}}@media(max-width:820px){.current-user-pill{max-width:100%;font-size:12px}.nav-register-link{font-size:13px!important;padding:9px 11px}.clients-table{min-width:900px}.schedule-table-wide table{min-width:820px}}

/* Latest UX fixes */
.upload-preview-vertical{align-items:flex-start;flex-direction:column}.upload-field-under-preview{width:100%;max-width:420px}.danger-badge{background:#fef2f2!important;color:#b91c1c!important}.manual-visit-note{font-size:12px;color:var(--muted)}

/* Navigation active states, footer and mobile overflow fixes */
html,body{max-width:100%;overflow-x:hidden}
img,svg,video,canvas{max-width:100%}
.card,.panel,.shell,.topbar{max-width:100%;min-width:0}
.grid>*{min-width:0}
.business-stats-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
@media(max-width:960px){.business-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:640px){.business-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.business-stats-grid .stat{padding:14px 12px}.business-stats-grid .stat b{font-size:24px}}

.nav a.active,.nav button.active,.current-user-pill.active,.nav-register-link.active{background:linear-gradient(135deg,var(--accent),#00b8b4)!important;color:#fff!important;box-shadow:0 10px 24px rgba(0,121,121,.18)!important}
.nav a.active:hover,.current-user-pill.active:hover,.nav-register-link.active:hover{color:#fff!important}
.bottom-nav a.active{color:#007c7b;font-weight:900;background:#ecfeff;border-radius:16px}
.site-footer{width:min(1180px,calc(100% - 28px));margin:0 auto 26px;padding:18px 22px;border:1px solid var(--line);border-radius:24px;background:rgba(255,255,255,.78);box-shadow:0 12px 32px rgba(0,121,121,.08);display:flex;justify-content:space-between;align-items:center;gap:12px;color:var(--muted);font-size:14px;font-weight:800}
.site-footer a{color:#007c7b;text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}
@media(max-width:820px){.site-footer{margin-bottom:86px;flex-direction:column;align-items:flex-start;width:min(1180px,calc(100% - 20px));padding:16px 18px}.bottom-nav a.active{padding:5px 8px}.table-wrap{max-width:100%;overflow-x:auto}.actions{min-width:0}.btn{white-space:normal}.topbar{overflow:hidden}.brand{min-width:0}.brand span{min-width:0}.brand b,.brand small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}
@media(max-width:640px){.bottom-nav{max-width:100vw}.bottom-nav a{flex:0 0 auto}.panel,.card{overflow-wrap:anywhere}}

/* Catalog filters, geolocation and mobile map button */
.catalog-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px}
.catalog-header h1{margin-bottom:6px}
.catalog-map-button{flex:0 0 auto}
.catalog-filter-form{margin-top:12px}
.master-filter-grid{grid-template-columns:2fr 1fr 1fr 1fr}
.map-filter-grid{grid-template-columns:1fr 1fr 1fr auto}
.geo-city-button{white-space:nowrap}
.geo-note{margin:6px 0 0;color:#0f766e;font-size:13px;font-weight:900}
[data-catalog-results]{position:relative;transition:opacity .18s ease}
[data-catalog-results].is-loading{opacity:.55;pointer-events:none}
@media(max-width:960px){.master-filter-grid,.map-filter-grid{grid-template-columns:1fr 1fr}.geo-city-button{width:100%}}
@media(max-width:640px){.catalog-header{display:block}.catalog-map-button{display:flex;width:100%;margin-top:12px;margin-bottom:16px}.catalog-filter-form{margin-top:0}.master-filter-grid,.map-filter-grid{grid-template-columns:1fr}.geo-city-button{width:100%}}


/* Sticky footer and improved bottom mobile navigation */
body{display:flex;flex-direction:column;min-height:100vh}
.shell{flex:1 0 auto}
.site-footer{flex:0 0 auto}
@media(max-width:820px){
  .bottom-nav{justify-content:space-between;gap:4px;overflow-x:hidden}
  .bottom-nav a{flex:1 1 0;min-width:0;width:auto;padding:6px 4px;border-radius:16px;text-align:center}
  .bottom-nav span{font-size:10px;line-height:1.05;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
}
@media(max-width:640px){
  .bottom-nav{justify-content:space-between;overflow-x:hidden}
  .bottom-nav a{flex:1 1 0;min-width:0}
}

/* Booking and catalog fixes 2026-05-26 */
.master-filter-grid{grid-template-columns:2fr 1fr 1fr 1fr}
.catalog-empty{grid-column:1 / -1;width:100%;text-align:center}
.booking-nearest-box{margin:0 0 16px}
.booking-asap-row{align-items:flex-start}
.booking-time-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:8px}
.booking-time-fields p{margin:0 0 12px}
@media(max-width:960px){.master-filter-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.master-filter-grid{grid-template-columns:1fr}.booking-time-fields{grid-template-columns:1fr}}

/* Client lists, broadcasts, registration and admin pages */
.clients-count-badge{font-size:20px;line-height:1;padding:7px 12px;vertical-align:middle}
.client-table-row td{padding-top:18px;padding-bottom:18px}
.client-messenger-links{display:flex;gap:8px;flex-wrap:wrap;margin-top:7px}
.client-messenger-links a{display:inline-flex;align-items:center;border-radius:999px;padding:5px 9px;background:#ecfeff;color:#007c7b;font-size:12px;font-weight:900}
.section-title-actions{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}
.section-title-actions h1,.section-title-actions h2{margin-bottom:0}
.broadcast-actions-row{justify-content:flex-end;margin-bottom:10px}
.broadcast-segment-note{font-size:13px;margin:-4px 0 10px}
.enhanced-broadcast-list{display:grid;gap:10px;max-height:420px;overflow:auto;padding-right:4px;margin-bottom:16px}
.enhanced-broadcast-list .broadcast-client-option{display:grid;grid-template-columns:24px minmax(0,1fr);gap:10px;align-items:flex-start;padding:12px 14px;border:1px solid var(--line);border-radius:16px;background:#fff;cursor:pointer}
.enhanced-broadcast-list input{width:18px;height:18px;margin-top:2px}
.broadcast-client-text{min-width:0;display:grid;gap:5px}
.broadcast-client-main{font-weight:900;overflow-wrap:anywhere}
.broadcast-client-channels,.broadcast-client-links{display:flex;flex-wrap:wrap;gap:6px;font-size:12px;font-weight:900;color:#0f766e}
.broadcast-client-links a{color:#007c7b;text-decoration:underline;text-underline-offset:3px}
.broadcast-empty{padding:12px 14px;border:1px dashed var(--line);border-radius:16px;background:#fff}
.master-card-main-link{display:grid;gap:8px;color:inherit;text-decoration:none}
.master-card-main-link:hover b{color:#007c7b;text-decoration:underline;text-underline-offset:3px}
.admin-card-link{display:grid;gap:8px;color:inherit;text-decoration:none}
.admin-card-link:hover h2{color:#007c7b;text-decoration:underline;text-underline-offset:3px}
.master-services-table input[type=checkbox]{width:20px;height:20px}
.master-services-table .price-col,.master-services-table .price-cell,.price-col,.price-cell{width:112px;min-width:96px;white-space:nowrap}
.compact-price-input{min-width:92px;width:96px;max-width:110px}
.master-services-table th:nth-child(4),.master-services-table th:nth-child(5),.master-services-table td.price-cell{padding-left:8px;padding-right:8px}
@media(max-width:820px){.compact-price-input{min-width:86px;width:90px}.master-services-table .price-col,.master-services-table .price-cell,.price-col,.price-cell{min-width:88px}}

.register-form .account-type-row{display:grid;grid-template-columns:160px minmax(0,1fr);gap:12px;align-items:start}
.register-form .account-type-row .form-label{margin:0;padding-top:7px}
.radio-options ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.radio-options li label{display:flex;align-items:center;gap:8px;font-weight:800}
.radio-options input{width:auto;margin:0}
.terms-row{display:grid;grid-template-columns:22px minmax(0,1fr);gap:10px;align-items:start;margin:14px 0;font-weight:800}
.terms-row input{width:18px;height:18px;margin:2px 0 0}
.terms-row a{text-decoration:underline;text-underline-offset:3px}
.legal-page h2{margin-top:22px}
@media(max-width:820px){.section-title-actions{flex-direction:column;align-items:stretch}.section-title-actions .btn{width:100%}.business-messages-grid{grid-template-columns:1fr}.broadcast-actions-row{justify-content:stretch}.broadcast-actions-row .btn{flex:1}.register-form .account-type-row{grid-template-columns:1fr}.register-form .account-type-row .form-label{padding-top:0}.compact-form-grid{grid-template-columns:1fr}}

/* ServiceCRM admin/client refinements */
.nav-admin-dropdown{position:relative;display:inline-flex;align-items:center}
.nav-admin-summary{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:999px;padding:10px 14px;background:#fff;color:#374151;font-weight:800;box-shadow:inset 0 0 0 1px #f3f4f6;cursor:pointer;list-style:none}
.nav-admin-summary::-webkit-details-marker{display:none}
.nav-admin-dropdown[open] .nav-admin-summary,.nav-admin-summary.active{background:#ecfeff;color:#006b6a}
.nav-admin-menu{position:absolute;right:0;top:calc(100% + 8px);z-index:50;display:grid;gap:6px;min-width:220px;padding:10px;border:1px solid var(--line);border-radius:18px;background:#fff;box-shadow:var(--shadow)}
.nav-admin-menu a{justify-content:flex-start;width:100%;box-shadow:none;background:#fff;border-radius:12px;padding:9px 10px}
.clients-title-row{align-items:flex-start;margin-bottom:14px}.clients-title-row h1{margin:0}.clients-header-actions{margin-left:auto;align-items:center}.clients-sort-form select{min-width:245px}.client-delivery-line{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;color:#0f766e;font-size:12px;font-weight:900}.client-table-empty{margin-top:10px}.broadcast-history-filter{display:grid;grid-template-columns:minmax(180px,1fr) 180px auto auto;gap:8px;align-items:center;margin:12px 0 16px}.broadcast-history-section{margin-top:14px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.66);padding:12px}.broadcast-history-section>summary{cursor:pointer;font-weight:900}.recipients-details summary{cursor:pointer;font-weight:800;color:#0f766e}.recipients-list{display:grid;gap:4px;margin-top:6px;max-height:180px;overflow:auto;font-size:12px;color:#374151}.recipients-list span{padding:4px 6px;border-radius:10px;background:#f8fafc}
@media(max-width:820px){.nav-admin-dropdown{display:none}.clients-title-row{flex-direction:column}.clients-header-actions,.clients-sort-form,.clients-sort-form select{width:100%}.broadcast-history-filter{grid-template-columns:1fr}.broadcast-history-filter .btn{width:100%}}

.enhanced-broadcast-list .broadcast-client-option[hidden],
.enhanced-broadcast-list .broadcast-client-option.is-hidden-by-segment{
  display:none !important;
}

/* Mobile business cabinet navigation: keep buttons inside viewport */
@media(max-width:820px){
  .business-nav-panel,
  .business-header-body{
    width:100%;
    max-width:100%;
    min-width:0;
    overflow:hidden;
  }
  .business-nav-actions{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px;
    width:100%;
    max-width:100%;
    overflow:visible;
    flex-wrap:initial;
    padding-bottom:0;
  }
  .business-nav-actions .btn{
    width:100%;
    min-width:0;
    max-width:100%;
    padding:9px 8px;
    font-size:13px;
    line-height:1.15;
    white-space:normal;
    text-align:center;
  }
}
@media(max-width:340px){
  .business-nav-actions{
    grid-template-columns:1fr;
  }
}

/* Main menu redesign: desktop dropdowns and mobile burger */
.mobile-menu-toggle{display:none;align-items:center;justify-content:center;width:44px;height:44px;border:0;border-radius:16px;background:#fff;color:#007c7b;font-size:26px;font-weight:900;box-shadow:inset 0 0 0 1px var(--line);cursor:pointer}
.main-nav{position:relative}.nav-dropdown{position:relative;display:inline-flex;align-items:center}.nav-dropdown-summary{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:999px;padding:10px 14px;background:#fff;color:#374151;font-weight:800;box-shadow:inset 0 0 0 1px #f3f4f6;cursor:pointer;list-style:none;line-height:1.2}.nav-dropdown-summary::-webkit-details-marker{display:none}.nav-dropdown-summary::after{content:"▾";font-size:11px;margin-left:7px;color:var(--muted)}.nav-dropdown[open]>.nav-dropdown-summary,.nav-dropdown-summary.active{background:linear-gradient(135deg,var(--accent),#00b8b4)!important;color:#fff!important;box-shadow:0 10px 24px rgba(0,121,121,.18)!important}.nav-dropdown[open]>.nav-dropdown-summary::after,.nav-dropdown-summary.active::after{color:#fff}.nav-dropdown-menu{position:absolute;right:0;top:calc(100% + 8px);z-index:60;display:grid;gap:6px;min-width:240px;padding:10px;border:1px solid var(--line);border-radius:18px;background:#fff;box-shadow:var(--shadow)}.nav-dropdown-menu a,.nav-dropdown-form button{justify-content:flex-start;width:100%;box-shadow:none;background:#fff;border-radius:12px;padding:9px 10px;color:#374151;text-align:left;font-weight:800}.nav-dropdown-menu a:hover,.nav-dropdown-form button:hover{background:#ecfeff;color:#006b6a}.nav-dropdown-form{margin:0}.nav-dropdown-form button{border:0;font:inherit;cursor:pointer}.user-summary{max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.branch-switch-form{min-width:150px;display:inline-flex;align-items:center;gap:6px}.branch-switch-label{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;background:#fff;box-shadow:inset 0 0 0 1px var(--line);font-size:17px}.branch-switch{height:40px;padding:8px 12px;border-radius:999px;font-weight:800;color:#007c7b}.business-active-branch{margin:.25rem 0 0}.business-header-compact{margin-bottom:16px}.business-header-compact h1{margin-bottom:6px}.bottom-nav{display:none!important}
@media(max-width:1100px){.user-summary{max-width:180px}.nav a,.nav button,.btn,.nav-dropdown-summary{font-size:13px;padding:9px 11px}.nav{gap:6px}.branch-switch-form{min-width:130px}}
@media(max-width:820px){.topbar{position:sticky;top:0;align-items:center;overflow:visible}.mobile-menu-toggle{display:inline-flex;flex:0 0 auto}.main-nav{display:none;position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:80;max-height:calc(100vh - 88px);overflow:auto;padding:12px;border:1px solid var(--line);border-radius:22px;background:rgba(255,255,255,.98);box-shadow:var(--shadow);backdrop-filter:blur(16px)}.main-nav.is-open{display:grid;grid-template-columns:1fr;gap:8px}.main-nav>a,.main-nav>.nav-dropdown,.main-nav>.nav-form{width:100%}.main-nav>a,.main-nav .nav-dropdown-summary{width:100%;justify-content:space-between;border-radius:16px;padding:12px 14px}.nav-dropdown{display:grid}.nav-dropdown-menu{position:static;min-width:0;width:100%;margin-top:6px;padding:8px;border-radius:16px;box-shadow:none;background:#f8fafc}.nav-dropdown[open] .nav-dropdown-menu{display:grid}.nav-dropdown-form button{border-radius:12px}.branch-switch-form{display:flex;min-width:0}.branch-switch-label{width:44px;height:44px;border-radius:16px;flex:0 0 44px}.branch-switch{width:100%;height:44px;border-radius:16px}.site-footer{margin-bottom:26px}.shell{padding-bottom:34px}.brand{max-width:calc(100% - 58px)}}
@media(max-width:820px){.main-nav .nav-admin-dropdown{display:grid}}

/* Mobile fixed header and iPhone safe-area support */
@supports (padding: max(0px)) {
  body{
    padding-top:env(safe-area-inset-top);
    min-height:100dvh;
  }
  body::before{
    content:"";
    position:fixed;
    left:0;
    right:0;
    top:0;
    height:env(safe-area-inset-top);
    z-index:90;
    background:rgba(255,255,255,.94);
    backdrop-filter:blur(16px);
    pointer-events:none;
  }
}

@media(max-width:820px){
  .topbar{
    position:sticky!important;
    top:env(safe-area-inset-top)!important;
    z-index:91;
    margin-top:0;
  }
  .main-nav{
    max-height:calc(100dvh - 88px - env(safe-area-inset-top));
  }
}

/* Main menu font size normalization */
.main-nav > a,
.main-nav > button,
.main-nav .nav-dropdown-summary,
.main-nav .nav-dropdown-menu a,
.main-nav .nav-dropdown-form button,
.main-nav .branch-switch,
.main-nav .user-summary,
.branch-switch-form .branch-switch{
  font-size:14px !important;
  line-height:1.2;
}

@media(max-width:820px){
  .main-nav > a,
  .main-nav > button,
  .main-nav .nav-dropdown-summary,
  .main-nav .nav-dropdown-menu a,
  .main-nav .nav-dropdown-form button,
  .main-nav .branch-switch,
  .main-nav .user-summary,
  .branch-switch-form .branch-switch{
    font-size:14px !important;
  }
}

/* Business accounts replace branches in the main menu */
.nav-dropdown-section-title{
  padding:4px 10px 2px;
  color:var(--muted);
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.nav-dropdown-divider{
  height:1px;
  margin:4px 0;
  background:var(--line);
}
.nav-dropdown-empty{
  padding:8px 10px;
  color:var(--muted);
  font-size:12px;
  font-weight:800;
}
.nav-dropdown-form .active-business-choice{
  background:#ecfeff;
  color:#007c7b;
  box-shadow:inset 0 0 0 1px #99f6e4;
}
.my-salons-layout{
  grid-template-columns:1.1fr .9fr;
}
.salon-list{
  display:grid;
  gap:12px;
  margin-top:14px;
}
.salon-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:14px;
  align-items:center;
  padding:16px;
  border:1px solid var(--line);
  border-radius:20px;
  background:#fff;
}
.salon-card.active{
  border-color:#99f6e4;
  background:#ecfeff;
}
.salon-card h3{
  margin:0 0 6px;
}
.salon-card p{
  margin:4px 0;
}
.salon-card-actions{
  justify-content:flex-end;
}
.badge.success{
  background:#dcfce7;
  color:#166534;
}
.form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.form-field{
  display:grid;
  gap:6px;
  font-weight:800;
}
.form-field.full,.form-grid .full{
  grid-column:1 / -1;
}
.error-text{
  color:var(--red);
  font-weight:800;
}
@media(max-width:960px){
  .my-salons-layout,
  .form-grid{
    grid-template-columns:1fr;
  }
  .salon-card{
    grid-template-columns:1fr;
  }
  .salon-card-actions,
  .salon-card-actions .btn,
  .salon-card-actions form{
    width:100%;
  }
}

/* Nested business salons menu */
.nav-nested-dropdown{
  display:grid;
  gap:6px;
}
.nav-nested-summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  width:100%;
  padding:9px 10px;
  border-radius:12px;
  background:#fff;
  color:#374151;
  font-size:12px;
  font-weight:800;
  line-height:1.2;
  cursor:pointer;
  list-style:none;
}
.nav-nested-summary::-webkit-details-marker{display:none}
.nav-nested-summary::after{
  content:"▾";
  color:var(--muted);
  font-size:11px;
}
.nav-nested-dropdown[open]>.nav-nested-summary{
  background:#ecfeff;
  color:#007c7b;
}
.nav-nested-menu{
  display:grid;
  gap:6px;
  margin-left:10px;
  padding:6px 0 0 8px;
  border-left:2px solid #ccfbf1;
}
.nav-nested-menu a,
.nav-nested-menu .nav-dropdown-form button{
  font-size:12px!important;
}

/* Business salon creation page */
.my-salons-layout{
  display:grid;
  grid-template-columns:1fr!important;
  gap:16px;
}

/* Coordinate picker */
.form-label-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.link-button{
  border:0;
  background:transparent;
  color:#007c7b;
  font:inherit;
  font-size:12px;
  font-weight:900;
  text-decoration:underline;
  text-underline-offset:3px;
  cursor:pointer;
  padding:0;
}
.map-pick-link{
  flex:0 0 auto;
  white-space:nowrap;
}
body.modal-open{overflow:hidden}
.location-picker-modal{
  position:fixed;
  inset:0;
  z-index:200;
  display:none;
  padding:24px;
}
.location-picker-modal.is-open{display:grid;place-items:center}
.location-picker-backdrop{
  position:absolute;
  inset:0;
  background:rgba(15,23,42,.48);
  backdrop-filter:blur(4px);
}
.location-picker-dialog{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-rows:auto auto auto minmax(260px,58vh) auto;
  gap:12px;
  width:min(960px,100%);
  max-height:calc(100dvh - 48px);
  padding:18px;
  border-radius:24px;
  background:#fff;
  box-shadow:0 24px 80px rgba(15,23,42,.28);
  overflow:hidden;
}
.location-picker-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
}
.location-picker-header h2{margin:0 0 4px}
.modal-close-button{
  width:38px;
  height:38px;
  border:0;
  border-radius:999px;
  background:#f8fafc;
  color:#334155;
  font-size:26px;
  line-height:1;
  cursor:pointer;
}
.location-picker-address{
  display:grid;
  gap:6px;
  font-size:12px;
  font-weight:900;
}
.location-picker-address .input{
  width:100%;
}
.location-picker-status{
  padding:9px 12px;
  border-radius:14px;
  background:#ecfeff;
  color:#0f766e;
  font-size:13px;
  font-weight:800;
}
.location-picker-status.error{
  background:#fef2f2;
  color:#b91c1c;
}
.location-picker-map{
  min-height:260px;
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  background:linear-gradient(135deg,#ecfeff,#fff);
}
.location-picker-footer{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.location-picker-coordinates{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,180px));
  gap:10px;
}
.location-picker-coordinates label{
  display:grid;
  gap:5px;
  font-size:12px;
  font-weight:900;
}
.location-picker-actions{justify-content:flex-end}
@media(max-width:640px){
  .location-picker-modal{padding:10px}
  .location-picker-dialog{
    grid-template-rows:auto auto auto minmax(220px,1fr) auto;
    max-height:calc(100dvh - 20px);
    padding:14px;
    border-radius:20px;
  }
  .location-picker-footer,
  .location-picker-actions,
  .location-picker-actions .btn{
    width:100%;
  }
  .location-picker-coordinates{
    width:100%;
    grid-template-columns:1fr;
  }
}

/* Compact columns for master service price list */
.master-services-table .duration-col,
.master-services-table .duration-cell{width:104px;min-width:88px;white-space:nowrap}
.master-services-table .order-col,
.master-services-table .order-cell{width:78px;min-width:68px;white-space:nowrap}
.master-services-table .duration-cell,
.master-services-table .order-cell{padding-left:6px;padding-right:6px}
.compact-number-input{min-width:68px!important;width:74px!important;text-align:center}
.compact-duration-input{min-width:78px!important;width:84px!important}
.compact-order-input{min-width:62px!important;width:66px!important}
@media(max-width:820px){
  .master-services-table .duration-col,
  .master-services-table .duration-cell{min-width:82px;width:88px}
  .master-services-table .order-col,
  .master-services-table .order-cell{min-width:64px;width:68px}
  .compact-duration-input{min-width:74px!important;width:78px!important}
  .compact-order-input{min-width:58px!important;width:60px!important}
}


/* Compact add-service button on business price list */
.service-add-button{
  padding:6px 10px!important;
  min-height:0!important;
  font-size:12px!important;
  line-height:1.15!important;
  border-radius:999px;
}
@media(max-width:820px){
  .service-add-button{
    width:auto;
    align-self:flex-start;
  }
}


/* Force compact add-service button on business services page */
.actions .service-add-button.service-add-button--force,
a.btn.small.service-add-button.service-add-button--force{
  height:30px!important;
  min-height:30px!important;
  max-height:30px!important;
  padding:0 10px!important;
  font-size:12px!important;
  line-height:30px!important;
  border-radius:999px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  flex:0 0 auto!important;
  width:auto!important;
}
@media(max-width:820px){
  .actions .service-add-button.service-add-button--force,
  a.btn.small.service-add-button.service-add-button--force{
    width:auto!important;
    min-width:0!important;
  }
}
/* Compact add master button on business masters page */
.actions .master-add-button.master-add-button--force,
a.btn.small.master-add-button.master-add-button--force{
  height:30px !important;
  min-height:30px !important;
  max-height:30px !important;
  padding:0 10px !important;
  font-size:12px !important;
  line-height:30px !important;
  border-radius:10px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  align-self:center !important;
  flex:0 0 auto !important;
  width:auto !important;
}

@media(max-width:640px){
  .actions .master-add-button.master-add-button--force,
  a.btn.small.master-add-button.master-add-button--force{
    height:30px !important;
    min-height:30px !important;
    max-height:30px !important;
    line-height:30px !important;
    width:auto !important;
  }
}


/* Compact title action buttons: business services / masters */
.compact-page-title-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:16px;
}
.compact-page-title-row h1{
  margin:0;
  line-height:1.15;
}
.compact-title-button,
.compact-title-button:visited{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:auto!important;
  min-width:0!important;
  max-width:max-content!important;
  height:28px!important;
  min-height:28px!important;
  max-height:28px!important;
  padding:10px 14px!important;
  border:0!important;
  border-radius:999px!important;
  background:var(--accent)!important;
  color:#fff!important;
  box-shadow: 0 10px 24px rgba(0, 121, 121, .18) !important;
  font-family:inherit!important;
  font-size:14px!important;
  font-weight:800!important;
  line-height:28px!important;
  text-decoration:none!important;
  white-space:nowrap!important;
  flex:0 0 auto!important;
  align-self:flex-start!important;
  margin-top:2px!important;
}
.compact-title-button:hover{
  background:#007c7b!important;
  color:#fff!important;
}
@media(max-width:640px){
  .compact-page-title-row{
    align-items:flex-start;
  }
  .compact-title-button{
    height:28px!important;
    min-height:28px!important;
    max-height:28px!important;
    padding:0 9px!important;
    font-size:12px!important;
    line-height:28px!important;
  }
}

/* User business accounts and business memberships */
.accounts-layout{
  display:grid;
  grid-template-columns:minmax(0,1.5fr) minmax(320px,.8fr);
  gap:16px;
  align-items:start;
}
@media(max-width:900px){
  .accounts-layout{grid-template-columns:1fr;}
}

/* Catalog cards and favorite organizations */
.catalog-mobile-page,.mobile-filter-sheet{display:none}.catalog-card-grid{align-items:stretch}.catalog-item-card{position:relative;display:flex;flex-direction:column;gap:8px;min-width:0}.catalog-card-media{display:block}.catalog-card-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;min-width:0}.catalog-card-title{min-width:0;color:var(--ink);font-size:17px;font-weight:900;line-height:1.18;text-decoration:none;overflow:hidden;text-overflow:ellipsis}.catalog-favorite-form{position:absolute;right:12px;top:12px;z-index:2;margin:0;line-height:0}.catalog-card-title-row>.catalog-favorite-star{position:absolute;right:12px;top:12px;z-index:2}.catalog-favorite-star{flex:0 0 auto;text-decoration:none}.catalog-card-rating{font-size:13px}.catalog-card-services{margin:0;min-height:20px;color:#0f766e;font-size:13px;font-weight:800;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.catalog-card-address{margin:0;font-size:13px;line-height:1.35}.catalog-card-chip{width:max-content;max-width:100%}.mobile-city-page{width:min(520px,100%);margin:0 auto;padding:22px;border:1px solid var(--line);border-radius:var(--r);background:rgba(255,255,255,.92);box-shadow:var(--shadow)}.mobile-city-search{margin:12px 0}.mobile-city-list{display:grid;gap:8px}.mobile-city-option{display:flex;align-items:center;justify-content:space-between;min-height:44px;padding:10px 14px;border:1px solid var(--line);border-radius:16px;background:#fff;font-weight:800;text-decoration:none}.mobile-city-option.active:after{content:"✓";color:var(--accent);font-weight:900}

/* Public service/review display */
.public-review-list{display:grid;gap:0}
.public-review-item{padding:12px 0;border-bottom:1px solid var(--line);background:transparent}
.public-review-item:last-child{border-bottom:0}
.public-review-rating{display:block;margin:0 0 5px;color:#0f766e;font-size:15px;font-weight:800;line-height:1.2}
.public-review-text{margin:0 0 6px;line-height:1.45}
.public-review-meta{display:block}
.service-line b{background:transparent!important;border:0!important;box-shadow:none!important}
@media(max-width:820px){.public-review-item{padding:10px 0}.public-review-rating{font-size:14px}}
