*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#020617;--bg-card:#0f172a;--bg-card-hover:#1e293b;--bg-input:#1e293b;--bg-glass:#0f172ad9;--primary:#3b82f6;--primary-hover:#2563eb;--success:#22c55e;--warning:#f59e0b;--danger:#ef4444;--purple:#8b5cf6;--text:#f8fafc;--text-muted:#94a3b8;--text-dim:#64748b;--border:#1e293b;--border-input:#334155;--radius:14px;--radius-sm:8px;--shadow:0 4px 24px #0000004d;--font:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--accent:var(--primary)}html{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}input,select,textarea,input[type=date],input[type=time]{accent-color:var(--accent)}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.5}.app-shell{flex-direction:column;max-width:480px;height:100vh;margin:0 auto;display:flex}.pwa-install-banner{border-radius:var(--radius);color:var(--text-muted);background:linear-gradient(135deg,#863bff2e,#0f172af2);border:1px solid #863bff59;flex-direction:column;flex-shrink:0;gap:10px;margin:0 12px 8px;padding:10px 14px;font-size:13px;display:flex}.pwa-install-banner__text{align-items:flex-start;gap:10px;line-height:1.45;display:flex}.pwa-install-banner__icon{color:#a78bfa;flex-shrink:0;margin-top:2px}.pwa-install-banner__actions{justify-content:flex-end;align-items:center;gap:8px;display:flex}.pwa-install-banner__btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);color:var(--text);cursor:pointer;justify-content:center;align-items:center;padding:8px 14px;font-size:13px;font-weight:600;display:inline-flex}.pwa-install-banner__btn:hover{background:var(--bg-card-hover)}.pwa-install-banner__btn--primary{color:#ede9fe;background:#863bff59;border-color:#863bff80}.pwa-install-banner__btn--primary:hover{background:#863bff80}.app-header{background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;padding:12px 16px;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:8px;display:flex}.brand-icon{color:var(--primary)}.brand{font-size:18px;font-weight:700}.header-right{align-items:center;gap:10px;display:flex}.user-name{color:var(--text-muted);font-size:13px}.app-main{flex:1;padding-bottom:70px;overflow-y:auto}.tab-bar{padding:6px 10px calc(6px + env(safe-area-inset-bottom));background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--border);z-index:100;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;scrollbar-width:thin;flex-wrap:nowrap;justify-content:flex-start;align-items:center;gap:2px;width:100%;max-width:480px;display:flex;position:fixed;bottom:0;left:50%;overflow:auto hidden;transform:translate(-50%)}.tab-bar::-webkit-scrollbar{height:4px}.tab-item{min-width:52px;max-width:88px;min-height:44px;color:var(--text-dim);border-radius:8px;flex-direction:column;flex:none;justify-content:center;align-items:center;gap:2px;padding:4px 6px;font-size:10px;text-decoration:none;transition:all .2s;display:flex}.tab-item span{text-align:center;word-break:break-word;font-size:10px;line-height:1.15}.tab-item.active{color:var(--primary)}.icon-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;padding:6px;transition:all .15s;display:flex}.icon-btn:hover{background:var(--bg-card);color:var(--text)}.icon-btn.danger:hover{color:var(--danger)}.btn-primary{border-radius:var(--radius);background:linear-gradient(135deg, var(--primary), var(--purple));color:#fff;cursor:pointer;border:none;width:100%;padding:12px;font-size:15px;font-weight:600;transition:all .2s}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;background:0 0;padding:10px 20px;font-weight:500}.btn-danger{border-radius:var(--radius);color:#fff;cursor:pointer;background:linear-gradient(135deg,#dc2626,#ef4444);border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px;font-weight:600;display:flex}.fab{background:linear-gradient(135deg, var(--primary), var(--purple));color:#fff;cursor:pointer;z-index:50;border:none;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;font-size:24px;transition:transform .2s;display:flex;position:fixed;bottom:80px;right:calc(50% - 210px);box-shadow:0 4px 20px #3b82f666}.fab:hover{transform:scale(1.1)}.page-container{padding:16px}.page-title{margin-bottom:16px;font-size:22px;font-weight:700}.page-header-row{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.page-header-row .page-title{margin-bottom:0}.page-header-row .page-header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.page-help-btn{align-items:center;display:flex}.page-help-backdrop{z-index:149;background:#00000059;position:fixed;inset:0}.page-help-panel{z-index:150;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;width:calc(100vw - 32px);max-width:360px;position:fixed;box-shadow:0 8px 32px #0000002e}.page-help-panel--popover{max-height:min(70vh,100vh - 24px);overflow-y:auto}.page-help-panel--sheet{border-radius:var(--radius-sm) var(--radius-sm) 0 0;width:100%;max-width:none;max-height:min(85vh,100dvh);padding-bottom:env(safe-area-inset-bottom,0);border-bottom:none;bottom:0;left:0;right:0;overflow-y:auto}.page-help-panel__head{background:var(--bg-card);z-index:1;justify-content:space-between;align-items:flex-start;gap:8px;padding:12px 12px 0;display:flex;position:sticky;top:0}.page-help-panel__title{margin:0;padding-right:4px;font-size:16px;font-weight:700;line-height:1.3}.page-help-panel__close{color:var(--text-muted);flex-shrink:0}.page-help-panel__body{color:var(--text);padding:8px 12px 14px;font-size:14px;line-height:1.45}.page-help-panel__body p{margin:0 0 .65rem}.page-help-panel__body p:last-child{margin-bottom:0}.page-help-panel__body ul{margin:0 0 .65rem;padding-left:1.15rem}.form-group{margin-bottom:14px}.form-group label{color:var(--text-muted);margin-bottom:4px;font-size:13px;font-weight:500;display:block}.form-group input,.form-group select,.form-group textarea{background:var(--bg-input);border:1px solid var(--border-input);border-radius:var(--radius-sm);width:100%;color:var(--text);outline:none;padding:10px 12px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus{border-color:var(--primary)}.searchable-select{width:100%;margin-bottom:10px;position:relative}.searchable-select__label{color:var(--text-muted);margin-bottom:4px;font-size:13px;font-weight:500;display:block}.searchable-select__trigger{text-align:left;cursor:pointer;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-input);width:100%;color:var(--text);outline:none;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;font-size:14px;transition:border-color .15s,box-shadow .15s,background-color .15s;display:flex}.searchable-select__trigger:focus-visible{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f638}.searchable-select__trigger--loading{opacity:.75;cursor:wait}.searchable-select--open .searchable-select__trigger{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f62e}.searchable-select__trigger-value{text-overflow:ellipsis;white-space:nowrap;max-width:100%;display:inline-block;overflow:hidden}.searchable-select__caret{border-left:5px solid #0000;border-right:5px solid #0000;border-top:7px solid var(--text-dim);flex-shrink:0;width:0;height:0;transition:transform .15s}.searchable-select--open .searchable-select__caret{transform:rotate(180deg)}.searchable-select__panel{z-index:250;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);flex-direction:column;max-height:280px;margin-top:4px;display:flex;position:absolute;left:0;right:0;overflow:hidden}.searchable-select__panel--portal{flex-direction:column;display:flex;overflow:hidden}.searchable-select__panel--portal .searchable-select__list{flex:1;min-height:0;max-height:none}.searchable-select--portal-root{z-index:auto;position:relative}.searchable-select__search{border:none;border-bottom:1px solid var(--border);background:var(--bg-input);color:var(--text);border-radius:0;outline:none;padding:8px 10px}.searchable-select__search:focus{border-radius:0}.searchable-select__list{max-height:220px;margin:0;padding:0;list-style:none;overflow-y:auto}.searchable-select__option{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:10px 12px;font-size:14px;transition:background-color .12s,color .12s}.searchable-select__option:hover{background:var(--bg-card-hover)}.searchable-select__option:focus-visible{outline:none;box-shadow:inset 0 0 0 2px #3b82f659}.searchable-select__option--selected{color:var(--text);background:#3b82f624}.searchable-select__empty-hint{color:var(--text-muted);text-align:center;padding:12px 14px;font-size:13px;list-style:none}.password-wrap{position:relative}.password-wrap input{padding-right:40px}.toggle-pw{color:var(--text-dim);cursor:pointer;background:0 0;border:none;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.search-bar{background:var(--bg-card);border-radius:var(--radius);align-items:center;gap:8px;margin-bottom:12px;padding:8px 12px;display:flex}.search-bar input{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-size:14px}.search-bar svg{color:var(--text-dim)}.filter-chips,.lookup-chips{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.chip{background:var(--bg-card);color:var(--text-muted);border:1px solid var(--border);cursor:pointer;border-radius:20px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .15s}.chip.active,.chip:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.chip.muted{opacity:.5;cursor:default}.segment-control{background:var(--bg-card);border-radius:var(--radius);margin-bottom:16px;padding:3px;display:flex}.segment-control button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:11px;flex:1;padding:8px;font-weight:500;transition:all .2s}.segment-control button.active{background:var(--primary);color:#fff}.view-toggle{gap:4px;display:flex}.view-toggle button{border:1px solid var(--border);color:var(--text-dim);border-radius:var(--radius-sm);cursor:pointer;background:0 0;padding:6px 10px}.view-toggle button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.card-list{flex-direction:column;gap:8px;display:flex}.client-card,.user-card,.appointment-card,.plan-card,.notification-card{background:var(--bg-card);border-radius:var(--radius);align-items:center;gap:12px;padding:12px;transition:background .15s;display:flex}.client-card:hover,.user-card:hover{background:var(--bg-card-hover)}.avatar{background:linear-gradient(135deg, var(--primary), var(--purple));border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:16px;font-weight:700;display:flex}.client-info,.user-info,.appt-info,.plan-info,.notif-content{flex:1;min-width:0}.client-info h3,.user-info h3,.appt-info h3,.plan-info h3,.notif-content h3{font-size:14px;font-weight:600}.client-info p,.user-info p,.appt-info p,.plan-info p,.notif-content p{color:var(--text-muted);font-size:12px}.tag{color:var(--primary);background:#3b82f626;border-radius:10px;padding:2px 8px;font-size:11px}.status-badge{text-transform:uppercase;white-space:nowrap;border-radius:12px;padding:3px 10px;font-size:11px;font-weight:600}.status-badge.active,.status-badge.confirmed{color:var(--success);background:#22c55e26}.status-badge.pending{color:var(--warning);background:#f59e0b26}.status-badge.cancelled,.status-badge.inactive{color:var(--danger);background:#ef444426}.status-badge.completed{color:var(--primary);background:#3b82f626}.status-badge.admin{color:var(--purple);background:#8b5cf626}.status-badge.trainer{color:var(--primary);background:#3b82f626}.status-badge.client{color:var(--success);background:#22c55e26}.plan-actions{gap:4px;display:flex}.appt-time{color:var(--primary);min-width:50px;font-size:14px;font-weight:700}.empty-state{text-align:center;color:var(--text-dim);padding:40px;font-size:14px}.login-page{background:linear-gradient(135deg,#020617 0%,#0f172a 50%,#1e1b4b 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border);width:100%;max-width:380px;box-shadow:var(--shadow);border-radius:20px;padding:32px 24px}.login-brand{text-align:center;margin-bottom:28px}.login-brand svg{color:var(--primary);margin-bottom:8px}.login-brand h1{font-size:28px;font-weight:800}.login-brand p{color:var(--text-muted);font-size:14px}.login-form{margin-bottom:20px}.login-error{color:var(--danger);border-radius:var(--radius-sm);background:#ef444426;margin-bottom:12px;padding:8px 12px;font-size:13px}.dashboard-page{padding:16px}.hero-section{border-radius:var(--radius);background:linear-gradient(135deg,#3b82f626,#8b5cf61a);border:1px solid #3b82f633;margin-bottom:20px;padding:20px}.hero-section h1{margin-bottom:4px;font-size:22px}.hero-section p{color:var(--text-muted);font-size:14px}.kpi-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:24px;display:grid}.kpi-card{background:var(--bg-card);border-radius:var(--radius);border-left:3px solid var(--accent,var(--primary));padding:16px}.kpi-icon{color:var(--accent,var(--primary));margin-bottom:8px}.kpi-value{font-size:26px;font-weight:800}.kpi-title{color:var(--text-muted);font-size:12px}.quick-actions-section h2{margin-bottom:12px;font-size:16px}.quick-actions-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.quick-action{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;align-items:center;gap:10px;padding:14px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.quick-action:hover{background:var(--bg-card-hover);border-color:var(--primary)}.quick-action svg{color:var(--primary)}.home-dashboard{padding-bottom:24px}.home-dashboard__hero{margin-bottom:16px}.home-dashboard__date{color:var(--text-dim);margin-bottom:4px;font-size:12px}.home-dashboard__greeting{font-size:22px;font-weight:800;line-height:1.2}.home-dashboard__context{color:var(--text-muted);margin-top:6px;font-size:14px}.home-dashboard__notif-hint{align-items:center;gap:8px;margin-top:10px;font-size:13px;display:inline-flex}.home-dashboard__primary-cta{border-radius:var(--radius);width:100%;color:var(--text);cursor:pointer;background:linear-gradient(135deg,#3b82f640,#8b5cf633);border:1px solid #3b82f659;justify-content:space-between;align-items:center;margin-bottom:20px;padding:16px 18px;font-size:15px;font-weight:700;display:flex}.home-dashboard__primary-cta:hover{filter:brightness(1.08)}.home-dashboard__kpis{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;display:grid}.home-dashboard__kpi{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px}.home-dashboard__kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:11px}.home-dashboard__kpi-value{word-break:break-word;margin-top:4px;font-size:20px;font-weight:800}.home-dashboard__kpi-hint{color:var(--text-dim);margin-top:4px;font-size:11px}.home-dashboard__kpi-trend{color:var(--success);margin-top:2px;font-size:11px}.home-dashboard__kpi--clickable{cursor:pointer;font:inherit;color:inherit;width:100%;transition:border-color .15s,box-shadow .15s}.home-dashboard__kpi--clickable:hover{border-color:var(--primary);box-shadow:0 0 0 1px #3b82f633}.home-dashboard__section{margin-bottom:22px}.home-dashboard__section-title{margin-bottom:10px;font-size:15px;font-weight:700}.home-dashboard__attention{flex-direction:column;gap:8px;display:flex}.home-dashboard__attention-card{background:var(--bg-card);border-radius:var(--radius);text-align:left;align-items:flex-start;gap:10px;padding:12px;display:flex}.home-dashboard__attention-card[role=button]{cursor:pointer}.home-dashboard__attention-icon{color:var(--warning);flex-shrink:0;margin-top:2px}.home-dashboard__attention-title{font-size:14px;font-weight:600}.home-dashboard__attention-detail{color:var(--text-muted);margin-top:4px;font-size:12px}.home-dashboard__health-meta{color:var(--text-dim);margin:-4px 0 10px;font-size:11px}.home-dashboard__health{flex-direction:column;gap:8px;display:flex}.home-dashboard__health-card[role=button]{cursor:pointer}.home-dashboard__health-value{font-variant-numeric:tabular-nums;margin-top:6px;font-size:13px;font-weight:700}.home-dashboard__health-icon-wrap{align-items:center;display:flex}.home-dashboard__health-icon--ok{color:var(--success)}.home-dashboard__health-icon--warning{color:var(--warning)}.home-dashboard__health-icon--critical{color:#ef4444}.home-dashboard__list-label{color:var(--text-muted);margin:8px 0 4px;font-size:12px}.home-dashboard__list{margin:0 0 12px;padding:0;list-style:none}.home-dashboard__list-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;margin-bottom:6px;padding:10px 12px;font-size:13px;display:flex}.home-dashboard__list-time{font-weight:700}.home-dashboard__list-meta{color:var(--text-muted);margin-top:2px;font-size:12px}.home-dashboard__quick-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.home-dashboard__quick-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;text-align:left;flex-direction:column;align-items:flex-start;gap:8px;padding:14px;font-size:13px;font-weight:600;display:flex}.home-dashboard__quick-btn:hover{border-color:var(--primary);background:var(--bg-card-hover)}.home-dashboard__quick-btn svg{color:var(--primary)}.home-dashboard__filters{flex-direction:column;gap:10px;margin-top:12px;display:flex}.home-dashboard__filter span{color:var(--text-muted);margin-bottom:4px;font-size:12px;display:block}select.input,.home-dashboard select.input,input.input[type=date],input.input[type=time],input.input[type=datetime-local],input.input[type=number],input.input[type=text],input.input[type=password],textarea.input{border-radius:var(--radius-sm);border:1px solid var(--border-input);background:var(--bg-input);width:100%;color:var(--text);padding:10px 12px;font-size:14px}input.input[type=date],input.input[type=time]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}textarea.input.input-textarea-notes{resize:vertical;min-height:7rem;line-height:1.45}.btn{border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:6px;padding:10px 16px;font-size:14px;font-weight:600;display:inline-flex}.btn.primary{background:var(--primary);color:#fff}.btn.secondary{background:var(--bg-card);color:var(--text);border:1px solid var(--border)}.btn.secondary.active{background:var(--primary);border-color:var(--primary);color:#fff}.btn.small{padding:6px 12px;font-size:12px}.appt-legend{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);color:var(--text-muted);flex-wrap:wrap;gap:10px 14px;margin-bottom:12px;padding:10px 12px;font-size:11px;display:flex}.appt-legend__item{align-items:center;gap:6px;display:inline-flex}.appt-legend__swatch{border-radius:3px;flex-shrink:0;width:12px;height:12px}.appt-legend__swatch--free{border:2px dashed var(--text-dim);background:0 0}.appt-mobile-section{margin-bottom:16px}.appt-mobile-section h3{color:var(--text-muted);margin-bottom:8px;font-size:14px;font-weight:700}.staff-booking-sticky{bottom:calc(70px + env(safe-area-inset-bottom));z-index:120;width:100%;max-width:480px;padding:10px 12px;position:fixed;left:50%;transform:translate(-50%)}.staff-booking-sticky__panel{background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius);justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex;box-shadow:0 10px 32px #00000059}.staff-booking-sticky__summary{min-width:0;color:var(--text-muted);font-size:12px;line-height:1.25}.staff-booking-sticky__summary strong{color:var(--text)}.staff-booking-sticky__cta{flex-shrink:0;gap:8px;display:inline-flex}.timeline-slot-free{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.timeline-free-chip{color:var(--success);cursor:pointer;background:#22c55e14;border:1px dashed #22c55e80;border-radius:6px;padding:4px 8px;font-size:11px;font-weight:600}.timeline-free-chip:hover{background:#22c55e2e}.timeline-free-chip.selected{outline:2px solid var(--primary);color:#dbeafe;background:#3b82f62e;border-color:#3b82f699}.week-nav{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.week-label{font-size:14px;font-weight:600}.week-scroll{gap:6px;margin-bottom:16px;padding-bottom:4px;display:flex;overflow-x:auto}.day-btn{border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);cursor:pointer;flex-direction:column;align-items:center;min-width:48px;padding:8px 12px;transition:all .15s;display:flex}.day-btn.selected{background:var(--primary);color:#fff;border-color:var(--primary)}.day-btn.today{border-color:var(--primary)}.day-name{text-transform:uppercase;font-size:10px;font-weight:600}.day-num{font-size:16px;font-weight:700}.timeline{flex-direction:column;display:flex}.timeline-row{border-bottom:1px solid var(--border);align-items:flex-start;min-height:48px;display:flex}.timeline-hour{width:50px;color:var(--text-dim);flex-shrink:0;padding-top:4px;font-size:11px}.timeline-slot{flex-direction:column;flex:1;gap:2px;padding:2px 0;display:flex}.timeline-event{border-radius:var(--radius-sm);color:#fff;padding:6px 10px;font-size:12px;font-weight:500}.profile-card{text-align:center;background:var(--bg-card);border-radius:var(--radius);margin-bottom:16px;padding:24px}.profile-avatar{background:linear-gradient(135deg, var(--primary), var(--purple));border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 12px;font-size:24px;font-weight:800;display:flex}.profile-card h2{margin-bottom:2px;font-size:20px}.profile-email{color:var(--text-muted);margin-bottom:8px;font-size:13px}.settings-list{flex-direction:column;gap:1px;margin-bottom:20px;display:flex}.settings-item{background:var(--bg-card);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.settings-item h3{font-size:14px;font-weight:600}.settings-item p{color:var(--text-muted);font-size:12px}.settings-value{color:var(--primary);font-weight:700}.lang-switch{gap:4px;display:flex}.lang-switch button{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;padding:4px 12px;font-size:12px}.lang-switch button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.logout-full{margin-top:16px}.modal-overlay{z-index:200;background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);flex-direction:column;width:100%;max-width:400px;max-height:80vh;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--border);background:var(--bg-card);z-index:1;justify-content:space-between;align-items:center;padding:16px;display:flex;position:sticky;top:0}.modal-header h2{font-size:16px}.modal-body{flex:1;min-height:0;padding:16px;overflow:auto}.modal-footer{border-top:1px solid var(--border);background:var(--bg-card);z-index:1;gap:8px;padding:16px;display:flex;position:sticky;bottom:0}.modal-footer .btn-primary{flex:1}.alert{border:1px solid var(--border);border-radius:var(--radius);background:#0f172ab3;margin-bottom:12px;padding:12px 14px}.alert__title{margin-bottom:6px;font-size:13px;font-weight:800}.alert__body{opacity:.95;font-size:14px}.alert--info{background:#3b82f614;border-color:#3b82f680}.alert--success{background:#22c55e14;border-color:#22c55e80}.alert--warning{background:#f59e0b1a;border-color:#f59e0b99}.alert--danger{background:#ef444414;border-color:#ef4444b3}.audit-timeline{padding-left:20px}.audit-entry{border-left:2px solid var(--border);padding:0 0 20px 20px;position:relative}.audit-dot{background:var(--primary);border-radius:50%;width:12px;height:12px;position:absolute;top:4px;left:-7px}.audit-content h3{font-size:14px;font-weight:600}.audit-content p{color:var(--text-muted);font-size:12px}.audit-time{color:var(--text-dim);font-size:11px}.notification-card{cursor:pointer}.notification-card.unread{border-left:3px solid var(--primary)}.notification-card.read{opacity:.6}.notif-icon{color:var(--primary);flex-shrink:0}.notif-time{color:var(--text-dim);margin-top:4px;font-size:11px;display:block}.unread-dot{background:var(--primary);border-radius:50%;flex-shrink:0;width:8px;height:8px}.lookup-section{margin-bottom:20px}.lookup-section h2{color:var(--text-muted);margin-bottom:8px;font-size:15px}.catalogs-page{padding:16px 14px 88px}.catalogs-page .page-header{margin-bottom:16px}.catalogs-page .page-header h1{font-size:22px;font-weight:700}.catalogs-page .page-header p{color:var(--text-muted);margin-top:4px;font-size:13px}.catalog-tabs{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.catalog-tabs button{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);cursor:pointer;align-items:center;gap:6px;padding:8px 12px;font-size:13px;display:inline-flex}.catalog-tabs button.active{border-color:var(--primary);color:var(--primary);background:#3b82f61f}.catalog-tabs button:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.catalog-list{flex-direction:column;gap:10px;list-style:none;display:flex}.catalog-list li{background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:12px;padding:12px;display:flex}.catalog-list .muted{color:var(--text-muted);font-size:13px}.catalog-list .small{margin-top:4px;font-size:11px}.catalog-list .row-actions{flex-shrink:0;gap:4px;display:flex}.icon-btn.danger{color:var(--danger)}.toolbar{margin-bottom:12px}.catalog-modal-overlay{z-index:100;background:#00000073;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}@media (width>=480px){.catalog-modal-overlay{align-items:center;padding:16px}}.catalog-modal{background:var(--bg-card);border-radius:var(--radius) var(--radius) 0 0;border:1px solid var(--border);flex-direction:column;width:100%;max-width:440px;max-height:min(92vh,640px);display:flex;box-shadow:0 -4px 24px #0003}@media (width>=480px){.catalog-modal{border-radius:var(--radius);max-height:85vh}}.catalog-modal__header{border-bottom:1px solid var(--border);background:var(--bg-card);z-index:1;flex-shrink:0;padding:14px 16px;position:sticky;top:0}.catalog-modal__title{margin:0;font-size:17px;font-weight:700}.catalog-modal__banner{margin:8px 16px 0}.catalog-modal__body{flex:1;min-height:0;padding:12px 16px 16px;overflow-y:auto}.catalog-modal__footer{border-top:1px solid var(--border);background:var(--bg-card);z-index:1;flex-shrink:0;gap:10px;padding:12px 16px;display:flex;position:sticky;bottom:0}.catalog-modal__footer .btn-primary{flex:1}.catalog-field{flex-direction:column;gap:4px;margin-bottom:12px;font-size:13px;display:flex}.catalog-field>span:first-of-type{color:var(--text-muted);font-weight:500}.catalog-field input,.catalog-field select,.catalog-field textarea{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);padding:8px 10px}.catalog-field-row{grid-template-columns:1fr 1fr 1fr;gap:8px;display:grid}@media (width<=400px){.catalog-field-row{grid-template-columns:1fr}}.catalog-field--checkbox{flex-direction:row;align-items:center;gap:8px}.catalog-tenant-fieldset{border:1px dashed var(--border);border-radius:var(--radius-sm);margin:12px 0 0;padding:10px 12px}.catalog-tenant-fieldset legend{color:var(--text-muted);padding:0 6px;font-size:12px}.catalog-hint{color:var(--text-muted);margin-top:2px;font-size:11px;display:block}.field-error{color:var(--danger);font-size:12px}.input-error{border-color:var(--danger)!important}.gym-reports-page__header.page-header-row{margin-bottom:8px}.gym-reports-filter-card{margin-bottom:.5rem!important;padding:.5rem .75rem!important}.gym-reports-toolbar{flex-wrap:wrap;align-items:flex-end;gap:8px 12px;display:flex}.gym-reports-date-pair{flex-wrap:nowrap;align-items:flex-end;gap:10px 12px;display:flex}.gym-reports-date-pair .gym-reports-field .input{width:100%;min-width:0;max-width:200px}@media (width<=520px){.gym-reports-date-pair{flex-wrap:wrap;width:100%}.gym-reports-date-pair .gym-reports-field{flex:140px;min-width:0}.gym-reports-date-pair .gym-reports-field .input{max-width:none}}.gym-reports-field{color:var(--text-muted);flex-direction:column;gap:4px;font-size:12px;display:flex}.gym-reports-field .input{min-width:180px}.gym-reports-presets.catalog-tabs{margin-bottom:0}.gym-reports-presets-row{flex-wrap:wrap;align-items:flex-end;gap:8px 10px;display:flex}.gym-reports-compact-alert{margin-bottom:.5rem!important;padding:.65rem .75rem!important}.gym-reports-loading-line{margin-bottom:.5rem!important;padding:.65rem .85rem!important}.gym-reports-refresh-hint{color:var(--text-muted);margin:0 0 .35rem;font-size:.85rem}.gym-reports-page .segment-control.gym-reports-tabs{margin-top:0;margin-bottom:.5rem}.gym-reports-period-line{color:var(--text-muted);margin:0 0 .45rem;font-size:.9rem}.gym-reports-notes--compact{margin:.35rem 0 .65rem;padding:.55rem .75rem}.gym-reports-presets{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.gym-reports-notes{color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);margin:.75rem 0 1rem;padding:.75rem 1rem;font-size:.85rem;line-height:1.45}.gym-reports-notes ul{margin:.35rem 0 0;padding-left:1.1rem}.gym-reports-notes li{margin-bottom:.25rem}.gym-reports-detail{margin-top:1rem}.gym-reports-detail-title{margin:0 0 .35rem;font-size:1.05rem;font-weight:700}.gym-reports-detail-lead{color:var(--text-muted);margin:0 0 1rem;font-size:.88rem;line-height:1.45}.gym-reports-panel{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);overflow:hidden}.gym-reports-panel__head{text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);border-bottom:1px solid var(--border);background:#00000026;padding:.5rem .75rem;font-size:.75rem;font-weight:600}.gym-reports-table-wrap{overflow-x:auto}.gym-reports-chart-title{color:var(--text-muted);margin-bottom:.5rem;font-size:.75rem;font-weight:600}.gym-reports-kpis{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-bottom:.5rem;display:grid}.gym-reports-kpi{flex-direction:column;gap:6px;padding:12px;display:flex}.gym-reports-kpi-label{color:var(--text-muted);font-size:11px;line-height:1.3}.gym-reports-kpi strong{font-size:1.25rem;font-weight:700}.gym-reports-split{grid-template-columns:1fr;gap:20px;display:grid}@media (width>=720px){.gym-reports-split{grid-template-columns:1fr 1fr;align-items:start}}.gym-reports-table{width:100%;font-size:13px}.gym-reports-table th,.gym-reports-table td{padding:10px 12px}.gym-reports-table tbody tr:nth-child(2n){background:#ffffff05}.gym-report-bars{flex-direction:column;gap:8px;min-height:120px;display:flex}.gym-report-bar-row{grid-template-columns:minmax(0,1fr) minmax(80px,2fr) 36px;align-items:center;gap:8px;font-size:12px;display:grid}.gym-report-bar-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.gym-report-bar-track{background:var(--border);border-radius:4px;height:10px;overflow:hidden}.gym-report-bar-fill{background:linear-gradient(90deg, var(--primary), #3b82f6a6);border-radius:4px;min-width:2px;height:100%;transition:width .2s}.gym-report-bar-val{text-align:right;font-variant-numeric:tabular-nums;color:var(--text-muted)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}@media (width>=768px){.app-shell{border-left:1px solid var(--border);border-right:1px solid var(--border);max-width:480px}}
