*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0d0d0d;--surface:#151515;--surface-raised:#1f1f1f;--gray-mid:#6b6b6b;--gray-light:#b3b3b3;--gray-lighter:#d9d9d9;--text:#b3b3b3;--text-muted:#6b6b6b;--text-heading:#d9d9d9;--brand:#c0ffe2;--accent:#0f8;--accent-hover:#00cc6e;--accent-light:#00ff881a;--accent-border:#00ff8840;--streak:#ff6b00;--streak-light:#ff6b001f;--streak-border:#ff6b004d;--border:#252525;--border-subtle:#1a1a1a;--danger:#ef4444;--danger-light:#ef44441a;--success:#0f8;--success-light:#00ff881a;--sidebar-bg:#0d0d0d;--sidebar-border:#1a1a1a;--sidebar-text:#6b6b6b;--sidebar-text-hover:#b3b3b3;--sidebar-text-active:#d9d9d9;--sidebar-item-hover:#ffffff0a;--sidebar-item-active:#00ff8814;--sidebar-width:210px;--header-height:56px;--header-bg:#151515;--header-border:#1a1a1a;--radius-sm:4px;--radius:8px;--radius-lg:14px;--shadow-lg:0 12px 32px #000000b3;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font:14px/1.5 system-ui,Segoe UI,Roboto,sans-serif}html,body,#app{height:100%}.layout{height:100%;display:flex}.layout-main{background:var(--bg);flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.layout-content{flex:1;padding:32px;overflow-y:auto}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);flex-direction:column;flex-shrink:0;height:100%;display:flex}.sidebar-brand{height:var(--header-height);color:var(--brand);letter-spacing:-.2px;border-bottom:1px solid var(--sidebar-border);flex:1;align-items:center;padding:0 16px;font-size:15px;font-weight:800;text-decoration:none;transition:opacity .12s;display:flex}.sidebar-brand:hover{opacity:.8}.sidebar-top-row .sidebar-brand{border-bottom:none;padding-left:16px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:10px 8px;display:flex;overflow-y:auto}.sidebar-item{border-radius:var(--radius-sm);color:var(--sidebar-text);align-items:center;padding:9px 12px;font-size:13.5px;font-weight:500;text-decoration:none;transition:background .12s,color .12s;display:flex;position:relative}.sidebar-item:hover{background:var(--sidebar-item-hover);color:var(--sidebar-text-hover)}.sidebar-item.router-link-active{background:var(--sidebar-item-active);color:var(--sidebar-text-active)}.sidebar-item.router-link-active:before{content:"";background:var(--accent);border-radius:0 2px 2px 0;width:2px;position:absolute;top:5px;bottom:5px;left:0}.sidebar-profile-wrap{border-top:1px solid var(--sidebar-border);flex-shrink:0;position:relative}.sidebar-profile-btn{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:12px;font-family:inherit;transition:background .12s;display:flex}.sidebar-profile-btn:hover{background:var(--sidebar-item-hover)}.sidebar-avatar{background:var(--accent-light);border:1px solid var(--accent-border);width:30px;height:30px;color:var(--accent);-webkit-user-select:none;user-select:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.sidebar-user-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.sidebar-user-name{color:var(--text-heading);white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;font-weight:600;overflow:hidden}.sidebar-user-sub{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.sidebar-profile-chevron{color:var(--text-muted);flex-shrink:0;font-size:14px;transition:transform .15s;transform:rotate(0)}.sidebar-profile-menu{background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius);min-width:180px;box-shadow:var(--shadow-lg);z-index:300;overflow:hidden}.sidebar-profile-item{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;padding:9px 14px;font-family:inherit;font-size:13.5px;transition:background .1s;display:block}.sidebar-profile-item:hover{background:#ffffff0d}.sidebar-profile-item--danger{color:var(--danger)}.sidebar-profile-item--danger:hover{background:var(--danger-light)}.sidebar-profile-divider{background:var(--border);height:1px;margin:4px 0}.profile-menu-enter-active,.profile-menu-leave-active{transition:opacity .12s,transform .12s}.profile-menu-enter-from,.profile-menu-leave-to{opacity:0;transform:translate(-6px)}.app-header{height:var(--header-height);background:var(--header-bg);border-bottom:1px solid var(--header-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 24px;display:flex}.header-left{align-items:center;gap:4px;display:flex}.header-nav{align-items:center;gap:2px;display:flex}.header-nav-link{color:var(--text-muted);border-radius:8px;padding:6px 14px;font-size:13.5px;font-weight:500;text-decoration:none;transition:color .15s,background .15s}.header-nav-link:hover{color:var(--text-heading);background:var(--surface-raised)}.header-nav-link.router-link-active{color:var(--accent);background:var(--accent-light)}.header-right{align-items:center;gap:12px;display:flex}.user-avatar{background:var(--accent-light);border:1px solid var(--accent-border);width:32px;height:32px;color:var(--accent);cursor:default;-webkit-user-select:none;user-select:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.org-badge{background:var(--surface-raised);border:1px solid var(--border);color:var(--text-muted);border-radius:999px;padding:3px 10px;font-size:12px;font-weight:500}.auth-page{background:var(--bg);justify-content:center;align-items:center;min-height:100%;padding:24px;display:flex}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:380px;box-shadow:var(--shadow-lg);padding:40px}.auth-title{color:var(--brand);letter-spacing:-.1px;margin:0 0 6px;font-size:15px;font-weight:800}.auth-subtitle{color:var(--text-heading);letter-spacing:-.4px;margin:0 0 28px;font-size:22px;font-weight:600}.auth-message{color:var(--text-muted);margin-top:8px;font-size:14px;line-height:1.6}.auth-form{flex-direction:column;gap:16px;margin-bottom:20px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-muted);font-size:12.5px;font-weight:500}.form-group input,.form-group textarea,.form-group select,input[type=email],input[type=password],input[type=text],input[type=number],input[type=date]{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-raised);width:100%;color:var(--text-heading);outline:none;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .12s}.form-group textarea{resize:vertical}.form-group select{cursor:pointer}.field-readonly{border-radius:var(--radius);border:1px solid var(--border-subtle);background:var(--surface);color:var(--text-muted);cursor:default;-webkit-user-select:none;user-select:none;padding:10px 12px;font-size:14px;font-style:italic}.password-input-wrap{align-items:center;display:flex;position:relative}.password-input-wrap input{padding-right:40px}.password-toggle{cursor:pointer;color:var(--text-muted);background:0 0;border:none;align-items:center;padding:2px;transition:color .12s;display:flex;position:absolute;right:10px}.password-toggle:hover{color:var(--text-heading)}.form-group input:focus,input[type=email]:focus,input[type=password]:focus,input[type=text]:focus{border-color:var(--accent-border)}.form-error{color:var(--danger);border-radius:var(--radius-sm);background:var(--danger-light);border:1px solid #ef444433;padding:8px 12px;font-size:13px}.form-success{color:var(--success);border-radius:var(--radius-sm);background:var(--success-light);border:1px solid #0f83;padding:8px 12px;font-size:13px}.conflict-banner{background:var(--danger-light);color:var(--danger);border-radius:var(--radius-sm);border:1px solid #ef44444d;margin-bottom:12px;padding:10px 14px;font-size:14px}.trainer-badge{color:#a855f7;border-radius:var(--radius-sm);background:#a855f71a;border:1px solid #a855f74d;align-items:center;gap:6px;margin-bottom:12px;padding:6px 12px;font-size:13px;font-weight:500;display:inline-flex}.trainer-badge:before{content:"👤";font-size:14px}.routine-day--locked{opacity:.65;border-style:dashed!important}.day-lock-icon{font-size:10px;line-height:1;position:absolute;top:2px;right:2px}.btn-primary{border-radius:var(--radius);background:var(--accent);color:#0d0d0d;cursor:pointer;letter-spacing:.1px;border:none;width:100%;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:700;transition:background .12s,opacity .12s}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.auth-link{text-align:center;color:var(--text-muted);font-size:13px;text-decoration:none;transition:color .12s;display:block}.auth-link:hover{color:var(--gray-light)}.page{max-width:1200px}.page-title{color:var(--text-heading);letter-spacing:-.4px;margin:0 0 24px;font-size:22px;font-weight:700}.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 22px;transition:border-color .15s}.stat-card:hover{border-color:#333}.stat-card-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:10px;font-size:11.5px;font-weight:600}.stat-card-value{color:var(--text-heading);letter-spacing:-.5px;font-size:28px;font-weight:700}.stat-card--streak{border-color:var(--streak-border);background:var(--streak-light)}.stat-card--streak .stat-card-value{color:var(--streak)}.stat-card--placeholder{opacity:.5}.stat-card-sub{color:var(--text-muted);margin-top:6px;font-size:12px}.dashboard-loading{justify-content:center;padding:48px;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.page-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.page-header .page-title{margin:0}.filters-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.select-input{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-raised);color:var(--text);cursor:pointer;outline:none;padding:8px 12px;font-family:inherit;font-size:13.5px;transition:border-color .12s}.search-bar{align-items:center;min-width:220px;display:flex;position:relative}.search-icon{color:var(--text-muted);pointer-events:none;font-size:16px;position:absolute;left:10px}.search-input{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-raised);width:100%;color:var(--text-heading);outline:none;padding:8px 12px 8px 30px;font-family:inherit;font-size:13.5px;transition:border-color .12s}.search-input:focus{border-color:var(--accent-border)}.search-input::-webkit-search-cancel-button{display:none}.search-clear{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:16px;line-height:1;position:absolute;right:8px}.btn-sm{width:auto;padding:7px 16px;font-size:13px}.btn-secondary{border-radius:var(--radius);border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;padding:9px 20px;font-family:inherit;font-size:13.5px;font-weight:500;transition:background .12s,border-color .12s}.btn-secondary:hover{background:var(--surface-raised);border-color:var(--gray-mid)}.btn-danger{border-radius:var(--radius);background:var(--danger);color:#fff;cursor:pointer;border:none;padding:9px 20px;font-family:inherit;font-size:13.5px;font-weight:600;transition:opacity .12s}.btn-danger:hover{opacity:.85}.badge{text-transform:capitalize;border-radius:999px;align-items:center;padding:2px 9px;font-size:11.5px;font-weight:600;display:inline-flex}.badge--green{color:var(--accent);background:#00ff881f;border:1px solid #00ff8840}.badge--gray{color:var(--gray-mid);background:#6b6b6b26;border:1px solid #6b6b6b33}.table-wrapper{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;overflow-x:auto}.data-table{border-collapse:collapse;table-layout:fixed;width:100%;font-size:13.5px}.data-table thead tr{border-bottom:1px solid var(--border)}.data-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;background:var(--surface);white-space:nowrap;padding:11px 16px;font-size:11.5px;font-weight:600}.data-table td{color:var(--text);border-bottom:1px solid var(--border-subtle);vertical-align:middle;white-space:nowrap;text-overflow:ellipsis;padding:12px 16px;overflow:hidden}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:#ffffff05}.table-state{text-align:center;color:var(--text-muted);padding:48px 16px!important}.dropdown{display:inline-block;position:relative}.dropdown-trigger{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;background:0 0;padding:3px 10px;font-size:16px;line-height:1.2;transition:border-color .12s,color .12s}.dropdown-trigger:hover{border-color:var(--gray-mid);color:var(--text)}.dropdown-menu{background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius);min-width:150px;box-shadow:var(--shadow-lg);z-index:100;position:absolute;top:calc(100% + 4px);right:0;overflow:hidden}.dropdown-item{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;padding:9px 14px;font-family:inherit;font-size:13.5px;transition:background .1s;display:block}.dropdown-item:hover{background:#ffffff0d}.dropdown-item--danger{color:var(--danger)}.dropdown-item--danger:hover{background:var(--danger-light)}.pagination{justify-content:center;align-items:center;gap:4px;margin-top:16px;display:flex}.page-btn{border-radius:var(--radius-sm);border:1px solid var(--border);min-width:32px;height:32px;color:var(--text);cursor:pointer;background:0 0;padding:0 8px;font-family:inherit;font-size:13px;transition:background .12s,border-color .12s}.page-btn:hover:not(:disabled){background:var(--surface-raised)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-btn--active{background:var(--accent-light);border-color:var(--accent-border);color:var(--accent);font-weight:700}.page-ellipsis{color:var(--text-muted);padding:0 4px;font-size:13px}.modal-overlay{z-index:200;background:#000000b3;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-height:90vh;box-shadow:var(--shadow-lg);flex-direction:column;display:flex}.modal--sm{max-width:400px}.modal--md{max-width:540px}.modal--lg{max-width:680px}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.modal-title{color:var(--text-heading);margin:0;font-size:16px;font-weight:600}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:22px;line-height:1;transition:color .12s}.modal-close:hover{color:var(--text-heading)}.modal-body{flex:1;padding:24px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);flex-shrink:0;padding:16px 24px}.modal-actions{justify-content:flex-end;gap:10px;display:flex}.modal-form{flex-direction:column;gap:16px;display:flex}.confirm-message{color:var(--text);font-size:14px;line-height:1.6}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.settings-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.settings-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.settings-card-title{color:var(--text-heading);margin:0 0 18px;font-size:14px;font-weight:600}.settings-form{flex-direction:column;gap:14px;display:flex}.profile-meta{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;gap:24px;margin-bottom:24px;padding:14px 18px;display:flex}.profile-meta-item{flex-direction:column;gap:2px;display:flex}.profile-meta-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.profile-meta-value{color:var(--text-heading);text-transform:capitalize;font-size:13.5px;font-weight:500}.settings-options{flex-wrap:wrap;gap:10px;display:flex}.settings-option{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-raised);color:var(--text);cursor:pointer;flex-direction:column;align-items:center;gap:8px;min-width:90px;padding:16px 20px;font-family:inherit;font-size:13px;transition:border-color .12s,background .12s;display:flex}.settings-option:hover{border-color:var(--gray-mid)}.settings-option--active{border-color:var(--accent-border);background:var(--accent-light);color:var(--accent)}.option-preview{color:var(--text-heading);font-weight:700}.option-flag{font-size:22px}.contrast-preview--default{color:var(--text-muted);font-size:18px}.contrast-preview--high{color:#fff;font-size:18px}.modal-enter-active,.modal-leave-active{transition:opacity .15s}.modal-enter-from,.modal-leave-to{opacity:0}[data-font-size=large]{font-size:16px}[data-font-size=large] .sidebar-item{font-size:15px}[data-font-size=large] .sidebar-user-name{font-size:13.5px}[data-font-size=large] .sidebar-user-sub{font-size:12px}[data-font-size=large] .sidebar-profile-item,[data-font-size=large] .data-table{font-size:15px}[data-font-size=large] .data-table th{font-size:12.5px}[data-font-size=large] .form-group label{font-size:13.5px}[data-font-size=large] .form-group input,[data-font-size=large] input[type=email],[data-font-size=large] input[type=password],[data-font-size=large] input[type=text],[data-font-size=large] .select-input,[data-font-size=large] .search-input,[data-font-size=large] .btn-primary,[data-font-size=large] .btn-secondary{font-size:15px}[data-font-size=large] .btn-sm{font-size:14px}[data-font-size=large] .page-title{font-size:25px}[data-font-size=large] .settings-card-title,[data-font-size=large] .dropdown-item{font-size:15px}[data-font-size=large] .badge{font-size:12.5px}[data-contrast=high]{--bg:#fff;--surface:#f2f2f2;--surface-raised:#e8e8e8;--border:#999;--border-subtle:#bbb;--text:#1a1a1a;--text-muted:#555;--text-heading:#000;--sidebar-bg:#f0f0f0;--sidebar-border:#ccc;--sidebar-text:#555;--sidebar-text-hover:#111;--sidebar-text-active:#000;--sidebar-item-hover:#0000000f;--sidebar-item-active:#00b45a2e;--header-bg:#f2f2f2;--header-border:#ccc;--accent-light:#00a05026;--accent-border:#00a05066;--danger-light:#c81e1e1a;--success-light:#0096461a;--shadow-lg:0 8px 24px #0000002e}.attendance-page{max-width:480px;margin:0 auto;padding:32px 16px}.attendance-greeting{color:var(--text-heading);text-align:center;margin-bottom:24px;font-size:22px;font-weight:700}.attendance-card{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:16px;flex-direction:column;align-items:center;gap:16px;padding:32px 24px;display:flex}.attendance-question{color:var(--text-heading);font-size:18px;font-weight:600}.btn-attend{background:var(--accent);color:#000;cursor:pointer;border:none;border-radius:10px;padding:14px 36px;font-size:16px;font-weight:700;transition:background .15s}.btn-attend:hover:not(:disabled){background:var(--accent-hover)}.btn-attend:disabled{opacity:.5;cursor:not-allowed}.attendance-check{color:var(--accent);font-size:48px;line-height:1}.attendance-done-text{color:var(--text-heading);font-size:16px;font-weight:600}.attendance-card--done{border-color:var(--accent-border)}.attendance-card--missed{border-color:var(--danger)}.attendance-card--rest{border-color:var(--border)}.attendance-card--muted{border-color:var(--border);opacity:.7}.rest-icon{font-size:40px;line-height:1}.attendance-list{flex-direction:column;gap:8px;display:flex}.attendance-list-item{border:1px solid var(--border);background:var(--surface);border-radius:10px;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.attendance-list-item--ok{border-left:4px solid var(--success)}.attendance-list-item--miss{border-left:4px solid var(--danger)}.attendance-list-date{color:var(--text-heading);font-size:14px}.attendance-list-status{color:var(--text-muted);align-items:center;gap:6px;font-size:13px;display:flex}.attendance-status-dot{background:currentColor;border-radius:50%;width:8px;height:8px;display:inline-block}.attendance-list-item--ok .attendance-status-dot{background:var(--success);color:var(--success)}.attendance-list-item--miss .attendance-status-dot{background:var(--danger);color:var(--danger)}.attendance-empty{text-align:center;color:var(--text-muted);padding:24px 0;font-size:14px}.racha-hero{text-align:center;padding:48px 16px 32px}.racha-motivational{color:var(--text-muted);margin-bottom:20px;font-size:16px}.racha-counter{flex-direction:column;align-items:center;gap:4px;display:flex}.racha-number{color:var(--accent);font-size:72px;font-weight:800;line-height:1}.racha-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:14px}.racha-actions{flex-wrap:wrap;justify-content:center;gap:12px;padding:0 16px 32px;display:flex}.btn-racha-action{background:var(--surface);border:1px solid var(--border);color:var(--text-heading);cursor:pointer;border-radius:10px;padding:10px 20px;font-size:14px;transition:border-color .15s,background .15s}.btn-racha-action:hover{border-color:var(--accent-border);background:var(--accent-light)}.protector-slots{justify-content:center;gap:12px;margin-bottom:8px;display:flex}.protector-dot{border:2px solid var(--border);border-radius:50%;width:28px;height:28px}.protector-dot--active{background:var(--accent);border-color:var(--accent)}.protector-dot--empty{background:0 0}.protector-count{text-align:center;color:var(--text-muted);margin-bottom:16px;font-size:14px}.protector-empty{text-align:center;color:var(--text-muted);padding:12px 0;font-size:14px}.recovery-list{flex-direction:column;gap:12px;display:flex}.recovery-item{background:var(--surface-raised);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:6px;padding:12px 14px;display:flex}.recovery-row{color:var(--text);justify-content:space-between;font-size:13px;display:flex}.recovery-label{color:var(--text-muted)}.recovery-days{color:var(--streak);font-weight:700}.max-streak-display{flex-direction:column;align-items:center;gap:6px;padding:24px 0;display:flex}.max-streak-number{color:var(--streak);font-size:64px;font-weight:800;line-height:1}.max-streak-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:14px}.tips-list{flex-direction:column;gap:10px;padding:0;list-style:none;display:flex}.tips-list li{background:var(--surface-raised);color:var(--text);border-left:3px solid var(--accent);border-radius:8px;padding:10px 14px;font-size:14px}.coming-soon-card{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:16px;flex-direction:column;align-items:center;gap:12px;margin-top:24px;padding:48px 24px;display:flex}.coming-soon-icon{font-size:48px;line-height:1}.coming-soon-text{color:var(--text-muted);font-size:15px}.goals-filters{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.goal-filter-btn{border:1px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;border-radius:99px;padding:6px 16px;font-size:13px;transition:background .12s,border-color .12s,color .12s}.goal-filter-btn--active{background:var(--accent-light);border-color:var(--accent-border);color:var(--accent)}.goals-list{flex-direction:column;gap:10px;display:flex}.goal-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-left-width:4px;border-radius:12px;align-items:center;gap:12px;padding:14px 16px;transition:border-color .12s;display:flex}.goal-card:hover{opacity:.9}.goal-card--en_progreso{border-left-color:#eab308}.goal-card--completado{border-left-color:var(--success)}.goal-card--fallido{border-left-color:var(--danger)}.goal-card-info{flex:1;min-width:0}.goal-card-title{color:var(--text-heading);font-size:14px;font-weight:600}.goal-card-meta{color:var(--text-muted);margin-top:2px;font-size:12px}.goal-card-badge{white-space:nowrap;border-radius:99px;flex-shrink:0;padding:3px 10px;font-size:11px}.goal-card-badge--en_progreso{color:#eab308;background:#eab3081f}.goal-card-badge--completado{background:var(--success-light);color:var(--success)}.goal-card-badge--fallido{background:var(--danger-light);color:var(--danger)}.goal-card-actions{flex-shrink:0;gap:4px;display:flex}.btn-icon{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:14px;transition:color .12s,background .12s}.btn-icon:hover{color:var(--text-heading);background:var(--surface-raised)}.btn-icon--danger:hover{color:var(--danger)}.goal-detail-desc{color:var(--text);margin-bottom:16px;font-size:14px;line-height:1.6}.goal-detail-meta{flex-direction:column;gap:8px;display:flex}.goal-detail-row{color:var(--text);border-bottom:1px solid var(--border-subtle);justify-content:space-between;padding:6px 0;font-size:13px;display:flex}.goal-detail-label{color:var(--text-muted)}.duration-picker{gap:8px;display:flex}.duration-number,.duration-unit{flex:1}.form-hint{color:var(--text-muted);margin-top:6px;font-size:12px;display:block}.modal-form-actions{gap:8px;margin-top:8px;display:flex}.routine-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.routine-week-nav{align-items:center;gap:6px;display:flex}.routine-week-label{color:var(--text-heading);text-align:center;min-width:200px;font-size:14px;font-weight:600}.routine-nav-btn{background:var(--surface);border:1px solid var(--border);color:var(--text-heading);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;line-height:1;transition:background .12s;display:flex}.routine-nav-btn:hover{background:var(--surface-raised)}.routine-grid-wrap{width:100%}.routine-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;display:grid}.routine-day{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:8px;min-height:280px;max-height:420px;padding:10px 8px;display:flex}.routine-day--rest{opacity:.6}.routine-day--today{border-color:var(--accent-border)}.routine-day-header{text-align:center;border-bottom:1px solid var(--border-subtle);padding-bottom:6px}.routine-day-name{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:10px;font-weight:700}.routine-day-date{color:var(--text-heading);font-size:20px;font-weight:700;line-height:1.2}.routine-day--today .routine-day-date{color:var(--accent)}.routine-day-badge{text-align:center;white-space:nowrap;text-overflow:ellipsis;border:1px solid #0000;border-radius:99px;padding:3px 8px;font-size:10px;transition:opacity .12s;overflow:hidden}.routine-day-badge--training{background:var(--accent-light);color:var(--accent);border-color:var(--accent-border)}.routine-day-badge--rest{background:var(--surface-raised);color:var(--text-muted);border-color:var(--border)}.routine-exercises{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex-direction:column;flex:1 1 0;gap:6px;min-height:0;padding-right:2px;display:flex;overflow-y:auto}.routine-exercise-card{background:var(--surface-raised);border-radius:6px;padding:7px 8px;position:relative}.routine-exercise-group{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin-bottom:2px;font-size:9px;font-weight:700}.routine-exercise-name{color:var(--text-heading);padding-right:16px;font-size:12px;font-weight:600}.routine-exercise-meta{color:var(--text-muted);margin-top:2px;font-size:11px}.routine-exercise-notes{color:var(--text-muted);margin-top:2px;font-size:11px;font-style:italic}.routine-remove-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:13px;line-height:1;transition:color .12s;position:absolute;top:4px;right:4px}.routine-remove-btn:hover{color:var(--danger)}.routine-no-exercises{color:var(--text-muted);text-align:center;padding:8px 0;font-size:11px}.routine-add-exercise-btn{border:1px dashed var(--border);width:100%;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;margin-top:auto;padding:6px;font-size:11px;transition:border-color .12s,color .12s}.routine-add-exercise-btn:hover{border-color:var(--accent-border);color:var(--accent)}.routine-footer{align-items:center;gap:8px;margin-top:20px;display:flex}.select-input{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-raised);width:100%;color:var(--text-heading);cursor:pointer;appearance:auto;outline:none;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .12s}.select-input:focus{border-color:var(--accent-border)}.routine-page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.routine-nav-header{align-items:center;gap:6px;margin-bottom:20px;display:flex}.routine-period-label{color:var(--text-heading);text-align:center;min-width:200px;font-size:14px;font-weight:600}.view-mode-tabs{background:var(--surface);border:1px solid var(--border);border-radius:10px;gap:4px;padding:3px;display:flex}.view-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:7px;padding:5px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:background .12s,color .12s}.view-tab:hover{color:var(--text-heading)}.view-tab.active{background:var(--surface-raised);color:var(--text-heading);font-weight:600}.att-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.att-dot--attended{background:var(--success)}.att-dot--missed{background:var(--danger)}.att-dot--future{border:1px solid var(--border);background:0 0}.att-dot--nodata{background:var(--border)}.routine-day-header{flex-direction:column;align-items:center;gap:2px;display:flex;position:relative}.routine-day-header .att-dot{position:absolute;top:2px;right:2px}.month-calendar{flex-direction:column;gap:2px;display:flex}.month-cal-row{grid-template-columns:12px repeat(7,1fr);align-items:center;gap:4px;display:grid}.month-cal-row--header{margin-bottom:4px}.month-cal-row--week{cursor:pointer;border-radius:8px;padding:4px 2px;transition:background .12s}.month-cal-row--week:hover{background:var(--surface-raised)}.month-cal-badge-col{justify-content:center;align-items:center;display:flex}.month-week-indicator{border-radius:99px;width:3px;height:28px;display:block}.month-week-indicator--custom{background:var(--accent)}.month-week-indicator--default{background:var(--border)}.month-week-indicator--none{border:1px dashed var(--border);background:0 0}.month-week-indicator--trainer{background:#a855f7}.month-cal-cell{border-radius:6px;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:6px 2px;display:flex}.month-cal-cell--dayname{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);gap:0;padding:0;font-size:10px;font-weight:700}.month-cal-cell--out{opacity:.3}.month-cal-cell--today{background:var(--accent-light);border-radius:6px}.month-cal-day-num{color:var(--text-heading);font-size:12px;font-weight:500;line-height:1}.month-cal-cell--today .month-cal-day-num{color:var(--accent);font-weight:700}.year-view{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}@media (width<=900px){.year-view{grid-template-columns:repeat(3,1fr)}}@media (width<=600px){.year-view{grid-template-columns:repeat(2,1fr)}}.year-month-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:10px;flex-direction:column;gap:8px;padding:12px 14px;transition:border-color .12s,background .12s;display:flex}.year-month-card:hover{border-color:var(--accent-border);background:var(--surface-raised)}.year-month-name{color:var(--text-heading);text-transform:capitalize;font-size:12px;font-weight:600}.year-mini-grid{grid-template-columns:repeat(7,1fr) 6px;gap:2px;display:grid}.year-mini-trainer-col{justify-content:center;align-items:center;display:flex}.year-mini-trainer-dot{background:#a855f7;border-radius:50%;flex-shrink:0;width:5px;height:5px;display:block}.year-mini-day{aspect-ratio:1;border-radius:3px;justify-content:center;align-items:center;min-height:18px;display:flex;border:none!important;width:auto!important;height:auto!important}.year-mini-day--empty{background:0 0}.year-mini-day.att-dot--attended{background:var(--success)}.year-mini-day.att-dot--missed{background:var(--danger);opacity:.8}.year-mini-day.att-dot--nodata,.year-mini-day.att-dot--future{background:var(--surface-raised)}.year-mini-day-num{pointer-events:none;-webkit-user-select:none;user-select:none;font-size:8px;font-weight:600;line-height:1}.year-mini-day.att-dot--attended .year-mini-day-num{color:#003d1f}.year-mini-day.att-dot--missed .year-mini-day-num{color:#fff}.year-mini-day.att-dot--nodata .year-mini-day-num{color:var(--text-muted)}.year-mini-day.att-dot--future .year-mini-day-num{color:var(--border)}.year-mini-day.att-dot--rest{background:var(--border-subtle,#ffffff0f)}.year-mini-day.att-dot--rest .year-mini-day-num{color:var(--border)}.favorites-list{flex-direction:column;gap:4px;max-height:180px;margin-bottom:4px;display:flex;overflow-y:auto}.favorite-item{background:var(--surface-raised);border:1px solid var(--border);border-radius:6px;justify-content:space-between;align-items:center;padding:7px 10px;display:flex}.favorite-item-name{color:var(--text-heading);font-size:13px}.btn-danger{background:var(--danger-light);color:var(--danger);cursor:pointer;border:1px solid #ef444440;border-radius:6px;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:background .12s}.btn-danger:hover{background:#ef444433}.btn-danger.btn-sm{padding:5px 10px;font-size:12px}.btn-xs{padding:3px 8px!important;font-size:11px!important}.apply-target-options{flex-direction:column;gap:10px;display:flex}.radio-option{color:var(--text);cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.radio-option input[type=radio]{accent-color:var(--accent);cursor:pointer}.form-success{color:var(--success);margin-top:4px;font-size:13px}.btn-hamburger{cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-direction:column;flex-shrink:0;justify-content:center;gap:5px;width:36px;height:36px;margin-right:4px;padding:6px;display:none}.btn-hamburger span{background:var(--text-muted);border-radius:2px;width:100%;height:2px;transition:background .12s;display:block}.btn-hamburger:hover span{background:var(--text-heading)}.sidebar-close-btn{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0;padding:4px 8px;font-size:18px;transition:color .12s;display:none}.sidebar-close-btn:hover{color:var(--text-heading)}.sidebar-top-row{height:var(--header-height);border-bottom:1px solid var(--sidebar-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 16px 0 0;display:flex}.sidebar-top-row .sidebar-brand{border-bottom:none;height:auto}.sidebar-overlay{z-index:299;background:#0009;display:none;position:fixed;inset:0}.backdrop-enter-active,.backdrop-leave-active{transition:opacity .25s}.backdrop-enter-from,.backdrop-leave-to{opacity:0}@media (width<=767px){.sidebar{z-index:300;height:100%;transition:transform .25s cubic-bezier(.4,0,.2,1);position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar--mobile-open{transform:translate(0)}.sidebar-overlay{display:block}.sidebar-close-btn{align-items:center;display:flex}.btn-hamburger{display:flex}.layout-content{padding:16px}.auth-card{padding:28px 20px}.page-header{flex-wrap:wrap;gap:8px}.page-header .page-title{font-size:18px}.form-row{grid-template-columns:1fr}.routine-grid-wrap{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border) transparent;padding-bottom:8px;overflow-x:auto}.routine-grid{grid-template-columns:repeat(7,minmax(130px,1fr));min-width:720px}.header-nav{gap:0}.header-nav-link{padding:6px 8px;font-size:12.5px}.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:92vh;max-width:100%!important}.settings-grid{grid-template-columns:1fr}}@media (width>=768px){.btn-hamburger,.sidebar-close-btn,.sidebar-overlay{display:none!important}.sidebar{transition:none;position:relative;transform:none!important}}
