:root{--bg: #0f1226;--bg-elev: #181c3a;--panel: #1c2147;--line: #2a2f5e;--text: #e8eaf6;--muted: #9aa0d0;--accent: #7c5cff;--accent-2: #00d4ff;--green: #38e08a;--gold: #ffce4f;--danger: #ff5d73;--radius: 12px}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:radial-gradient(1100px 540px at 85% -10%,rgba(124,92,255,.18),transparent),radial-gradient(800px 460px at -10% 10%,rgba(0,212,255,.12),transparent),var(--bg);color:var(--text);min-height:100vh}#app{max-width:980px;margin:0 auto;padding:24px 20px;height:100vh;display:flex;flex-direction:column}.topbar{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}.brand{display:flex;align-items:center;gap:12px}.logo{font-size:30px}.brand h1{margin:0;font-size:21px}.subtitle{margin:2px 0 0;color:var(--muted);font-size:13px}.mode-pill{padding:7px 13px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap;border:1px solid var(--line);background:var(--bg-elev)}.mode-pill.supabase{color:var(--green);border-color:#38e08a66}.mode-pill.demo{color:var(--gold);border-color:#ffce4f66}.topbar-right{display:flex;align-items:center;gap:14px}.user-menu{display:flex;align-items:center;gap:10px}.user-info{display:flex;align-items:center;gap:8px}.user-name{font-weight:600;font-size:14px}.role-pill{padding:3px 9px;border-radius:999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border:1px solid var(--line)}.role-pill.coach{color:var(--accent);border-color:#7c5cff80;background:#7c5cff1f}.role-pill.athlete{color:var(--green);border-color:#38e08a66;background:#38e08a1a}.login-screen{flex:1;min-height:0;display:flex;align-items:center;justify-content:center}.login-card{width:100%;max-width:380px;padding:28px;background:linear-gradient(180deg,var(--panel),rgba(28,33,71,.55));border:1px solid var(--line);border-radius:14px;display:flex;flex-direction:column;gap:10px}.login-brand{display:flex;align-items:center;gap:10px}.login-brand .logo{font-size:28px}.login-brand h1{margin:0;font-size:22px}.login-sub{margin:0 0 6px;color:var(--muted);font-size:14px}.login-label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-top:6px}.role-row{display:flex;gap:8px}.role-btn{flex:1;padding:9px;border-radius:9px;cursor:pointer;font-weight:600;font-size:14px;border:1px solid var(--line);background:var(--bg-elev);color:var(--muted)}.role-btn:hover{color:var(--text)}.role-btn.active{color:var(--text);background:#7c5cff33;border-color:#7c5cff99}.login-submit{margin-top:10px;width:100%}.login-error{background:#ff5d731f;border:1px solid rgba(255,93,115,.4);color:var(--danger);padding:8px 10px;border-radius:8px;font-size:13px}.login-hint{margin:6px 0 0;color:var(--muted);font-size:12px;line-height:1.5}.login-hint code{background:var(--bg-elev);padding:1px 5px;border-radius:5px;font-size:11px}.login-toggle{color:var(--accent);text-decoration:none;font-weight:600}.login-toggle:hover{text-decoration:underline}.name-row{display:flex;gap:8px}.name-row .input{flex:1;min-width:0}.login-notice{background:#3fb96e1f;border:1px solid rgba(63,185,110,.4);color:var(--success, #3fb96e);padding:8px 10px;border-radius:8px;font-size:13px}.tabs{flex-shrink:0;display:flex;gap:8px;margin-bottom:16px}.tab{background:var(--bg-elev);color:var(--muted);border:1px solid var(--line);padding:9px 18px;border-radius:10px;cursor:pointer;font-weight:600;font-size:14px}.tab:hover{color:var(--text)}.tab.active{color:var(--text);background:#7c5cff38;border-color:#7c5cff99}.stage,.subtabbed{flex:1;min-height:0;display:flex;flex-direction:column}.subtabs{flex-shrink:0;display:flex;gap:6px;margin-bottom:12px}.subtab{background:transparent;color:var(--muted);border:1px solid var(--line);padding:6px 14px;border-radius:8px;cursor:pointer;font-weight:600;font-size:13px}.subtab:hover{color:var(--text)}.subtab.active{color:var(--text);background:#7c5cff29;border-color:#7c5cff80}.subtab-host{flex:1;min-height:0;display:flex;flex-direction:column}.panel{background:linear-gradient(180deg,var(--panel),rgba(28,33,71,.55));border:1px solid var(--line);border-radius:var(--radius);padding:20px;flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.panel-head{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.panel-head-actions{display:flex;align-items:center;gap:8px}.panel-head h2{margin:0;font-size:18px}.add-btn{background:linear-gradient(90deg,var(--accent),#5b7cff);color:#fff;border:none;padding:8px 15px;border-radius:9px;font-weight:700;font-size:14px;cursor:pointer}.add-btn:hover{filter:brightness(1.1)}.add-btn:disabled{opacity:.45;cursor:not-allowed;filter:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;padding:20px;background:#060814a8;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center}.modal{width:100%;max-width:560px;max-height:90vh;overflow:auto;background:var(--bg-elev);border:1px solid var(--line);border-radius:14px;padding:20px;box-shadow:0 24px 70px #0000008c}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.modal-head h3{margin:0;font-size:18px}.detail-grid{display:grid;grid-template-columns:auto 1fr;gap:6px 16px;margin:0}.detail-grid dt{color:var(--muted);font-size:13px}.detail-grid dd{margin:0;font-size:14px}.detail-subhead{margin:16px 0 6px;font-size:14px}.detail-list{margin:0;padding-left:18px}.detail-list li{font-size:14px;padding:2px 0}.detail-empty{color:var(--muted);font-size:14px;margin:0}.table td.clickable{cursor:pointer}.eval-grid{display:grid;gap:8px}.eval-athlete{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;text-align:left;padding:10px 12px;border-radius:9px;background:var(--bg-elev);border:1px solid var(--line);color:var(--text);cursor:pointer;font-weight:600;font-size:14px}.eval-athlete:hover{border-color:#7c5cff99}.eval-go{color:var(--accent);font-size:13px;white-space:nowrap}.eval-athlete-person,.enroll-person{display:flex;align-items:center;gap:10px}.roster-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0}.roster-avatar.initials{display:inline-flex;align-items:center;justify-content:center;background:#2a3354;color:#cdd5ee;font-size:11px;font-weight:700;border:1px solid #3a4570}.eval-sub{color:var(--muted);font-size:13px;margin:0 0 14px}.eval-group{margin-bottom:14px}.eval-group-title{margin:0 0 8px;font-size:14px}.eval-component{border:1px solid #2a3354;border-radius:8px;padding:10px 12px;margin-bottom:10px;background:#141a30}.eval-component-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}.eval-component-name{font-size:14px;font-weight:600}.eval-code{font-size:11px;color:#9aa4bf;font-family:ui-monospace,monospace}.eval-track{font-size:10px;font-weight:700;color:#cdd5ee;background:#2a3354;border-radius:4px;padding:1px 6px}.eval-drift{font-size:10px;font-weight:700;color:#ffcf8a;background:#3a2e16;border-radius:4px;padding:1px 6px}.eval-signal{font-size:12px;color:#9aa4bf;margin-bottom:6px}.eval-rubric{display:flex;flex-direction:column;gap:3px;margin-bottom:8px}.eval-level{font-size:12px;color:#cdd5ee;line-height:1.4}.eval-level-tag{display:inline-block;min-width:70px;font-size:10px;font-weight:700;text-transform:uppercase;margin-right:6px}.eval-level-tag.beg{color:#ff9d9d}.eval-level-tag.pro{color:#ffd27a}.eval-level-tag.adv{color:#8ad6a0}.eval-inputs{display:grid;grid-template-columns:90px minmax(0,1fr);gap:8px;align-items:center}.eval-rating{padding:6px 8px}.eval-note{padding:6px 10px}.measure-add{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:14px}.measure-add .input{flex:1 1 110px;min-width:0;padding:7px 10px}.measure-add .btn{flex:0 0 auto}.measure-add .measure-unit{flex:0 0 auto;min-width:32px;color:var(--muted);font-size:13px}.measure-table th,.measure-table td{padding:8px 10px}.measure-table tr.editing{background:#1b2150}.modal-close{background:transparent;border:none;color:var(--muted);cursor:pointer;font-size:18px;line-height:1;padding:4px 8px;border-radius:6px}.modal-close:hover{color:var(--text);background:#ffffff0f}.modal-tabs{display:flex;gap:6px;margin-bottom:16px;border-bottom:1px solid var(--line)}.modal-tab{background:transparent;color:var(--muted);border:none;border-bottom:2px solid transparent;padding:8px 12px;margin-bottom:-1px;cursor:pointer;font-weight:600;font-size:14px}.modal-tab:hover{color:var(--text)}.modal-tab.active{color:var(--text);border-bottom-color:var(--accent)}.enroll-add{display:flex;gap:8px;margin-bottom:14px}.enroll-add .input{flex:1}.enroll-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.enroll-item{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#141838;border:1px solid var(--line);border-radius:10px;padding:9px 13px;font-size:14px}.enroll-empty{color:var(--muted);font-size:14px;padding:8px 0}.hidden{display:none!important}.editing-pill{font-size:12px;color:var(--gold);border:1px solid rgba(255,206,79,.4);padding:3px 9px;border-radius:999px}.form{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:18px}.field{display:flex;flex-direction:column;gap:5px;flex:1;min-width:150px}.field span{font-size:12px;color:var(--muted)}.input{background:#0e1230;border:1px solid var(--line);color:var(--text);padding:9px 11px;border-radius:9px;font-size:14px;font-family:inherit;width:100%}.input:focus{outline:2px solid var(--accent)}.form-actions{display:flex;gap:8px}.btn{border:1px solid var(--line);background:var(--bg-elev);color:var(--text);padding:9px 15px;border-radius:9px;cursor:pointer;font-weight:600;font-size:14px}.btn:hover{filter:brightness(1.12)}.btn.primary{background:linear-gradient(90deg,var(--accent),#5b7cff);border:none}.btn.ghost{background:transparent;color:var(--muted)}.btn.small{padding:5px 11px;font-size:13px}.btn.danger{color:var(--danger);border-color:#ff5d7366}.btn.danger:hover{background:#ff5d7324}.table-wrap{flex:1;min-height:0;display:flex;flex-direction:column}.table-scroll{flex:1;min-height:0;overflow:auto}.table-scroll thead th{position:sticky;top:0;background:var(--panel);z-index:1}.table{width:100%;border-collapse:collapse}.table th,.table td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line);font-size:14px}.table th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.5px}.table tbody tr:hover{background:#ffffff08}.table .nowrap{white-space:nowrap}.actions-col{text-align:right}.actions-col .btn{margin:3px 0 3px 6px}.pager{flex-shrink:0;display:flex;align-items:center;gap:12px;margin-top:14px}.pager-info{color:var(--muted);font-size:13px}.pager .btn:disabled{opacity:.4;cursor:default}.pager-size-label{margin-right:auto;display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px}.pager-size{width:auto;padding:5px 8px;font-size:13px}.empty{color:var(--muted);text-align:center;padding:24px 0}.error{background:#ff5d731f;border:1px solid rgba(255,93,115,.4);color:#ffb3bd;padding:10px 14px;border-radius:9px;margin-bottom:14px;font-size:14px}.hint{background:#ffce4f1a;border:1px solid rgba(255,206,79,.4);color:var(--gold);padding:10px 14px;border-radius:9px;margin-bottom:14px;font-size:14px}.checkbox-group{display:flex;flex-direction:column;gap:6px;background:#0e1230;border:1px solid var(--line);border-radius:9px;padding:9px 11px;max-height:160px;overflow-y:auto}.checkbox-item{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text);cursor:pointer}.checkbox-item input{width:15px;height:15px;cursor:pointer}.field-hint{font-size:13px;color:var(--muted);margin:0 0 10px}.profile-section{margin-bottom:18px}.profile-section h4{margin:0 0 8px;font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.chip-row{display:flex;flex-wrap:wrap;gap:8px}.chip{background:#1b2150;border:1px solid var(--line);border-radius:999px;padding:4px 12px;font-size:13px;color:var(--text)}.danny-ask{margin-bottom:10px}.danny-card{background:#0e1230;border:1px solid var(--line);border-radius:11px;padding:14px 16px}.danny-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px}.danny-head h4{margin:0}.danny-badge{font-size:11px;text-transform:uppercase;letter-spacing:.04em;padding:2px 8px;border-radius:999px;border:1px solid var(--line);color:var(--muted)}.danny-badge.ai{color:#b9f6ca;border-color:#2e7d32}.danny-confidence{font-size:12px;color:var(--muted);margin-left:auto}.danny-assessment{margin:0 0 12px;color:var(--text)}.danny-card h5{margin:12px 0 6px;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.danny-list{margin:0;padding-left:18px}.danny-list li{margin:3px 0;font-size:14px}.field-relation{min-width:220px}.field-relation select[multiple]{height:auto;padding:4px}.field-relation select[multiple] option{padding:4px 7px;border-radius:5px}.field-relation select[multiple] option:checked{background:linear-gradient(0deg,#7c5cff80,#7c5cff80);color:#fff}.input:disabled{opacity:.5;cursor:not-allowed}.btn:disabled{opacity:.45;cursor:not-allowed;filter:none}
