*,: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;--radius:14px;--radius-sm:8px;--shadow:0 4px 24px #0000004d;--font:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}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}.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 0 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;justify-content:space-around;align-items:center;width:100%;max-width:480px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.tab-item{color:var(--text-dim);border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:4px 8px;font-size:10px;text-decoration:none;transition:all .2s;display:flex}.tab-item.active{color:var(--primary)}.tab-item span{font-size:10px}.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}.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{background:var(--bg-input);border:1px solid var(--border);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)}.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)}.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);width:100%;max-width:400px;max-height:80vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px;display:flex}.modal-header h2{font-size:16px}.modal-body{padding:16px}.modal-footer{border-top:1px solid var(--border);gap:8px;padding:16px;display:flex}.modal-footer .btn-primary{flex:1}.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}::-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}}
