*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#f5f5f5;--color-surface:#fff;--color-border:#e0e0e0;--color-text:#1a1a1a;--color-text-muted:#6b6b6b;--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-success:#16a34a;--color-warning:#d97706;--color-danger:#dc2626;--sidebar-width:220px;--radius:6px}body{color:var(--color-text);background:var(--color-bg);font-family:system-ui,-apple-system,sans-serif;line-height:1.5}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}.app-layout{min-height:100vh;display:flex}.main-content{flex:1;max-width:960px;padding:2rem}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);flex-direction:column;flex-shrink:0;padding:1.5rem 0;display:flex}.sidebar-header{border-bottom:1px solid var(--color-border);padding:0 1.25rem 1.5rem}.sidebar-title{letter-spacing:.05em;font-size:1.25rem;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:1rem 0;display:flex}.sidebar-link{color:var(--color-text-muted);border-left:3px solid #0000;padding:.5rem 1.25rem;font-size:.9rem;text-decoration:none;display:block}.sidebar-link:hover{color:var(--color-text);background:var(--color-bg);text-decoration:none}.sidebar-link.active{color:var(--color-primary);border-left-color:var(--color-primary);background:#eff6ff}.sidebar-footer{border-top:1px solid var(--color-border);flex-direction:column;gap:.5rem;padding:1rem 1.25rem 0;display:flex}.sidebar-email{color:var(--color-text-muted);text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem}.btn{border-radius:var(--radius);cursor:pointer;border:1px solid #0000;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:background .15s,border-color .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-outline{color:var(--color-text);border-color:var(--color-border);background:0 0}.btn-outline:hover:not(:disabled){background:var(--color-bg)}.btn-sm{padding:.25rem .75rem;font-size:.8rem}.table{border-collapse:collapse;width:100%;font-size:.875rem}.table th,.table td{text-align:left;border-bottom:1px solid var(--color-border);padding:.625rem .75rem}.table th{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:.8rem;font-weight:600}.table tbody tr:hover{background:#fafafa}.table-clickable tbody tr{cursor:pointer}.form-group{flex-direction:column;gap:.375rem;margin-bottom:1rem;display:flex}.form-label{font-size:.85rem;font-weight:500}.form-input{border:1px solid var(--color-border);border-radius:var(--radius);padding:.5rem .75rem;font-family:inherit;font-size:.875rem}.form-input:focus{outline:2px solid var(--color-primary);outline-offset:-1px;border-color:var(--color-primary)}.badge{border-radius:999px;padding:.15rem .5rem;font-size:.75rem;font-weight:500;display:inline-block}.badge-complete{color:var(--color-success);background:#dcfce7}.badge-in-progress{color:var(--color-warning);background:#fef3c7}.badge-new{color:var(--color-primary);background:#dbeafe}.badge-not-started{color:var(--color-text-muted);background:#f3f4f6}.loading-spinner-container{justify-content:center;align-items:center;padding:3rem;display:flex}.loading-spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:2rem;height:2rem;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-message{border-radius:var(--radius);color:var(--color-danger);background:#fef2f2;border:1px solid #fecaca;align-items:center;gap:1rem;padding:1rem;display:flex}.login-page{background:var(--color-bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{width:100%;max-width:380px}.login-card h1{margin-bottom:.25rem;font-size:1.5rem}.login-card p{color:var(--color-text-muted);margin-bottom:1.5rem;font-size:.85rem}.login-card .form-error{color:var(--color-danger);margin-bottom:1rem;font-size:.85rem}.page-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.page-header h1{font-size:1.5rem;font-weight:600}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.stat-card{text-align:center}.stat-value{color:var(--color-primary);font-size:2rem;font-weight:700}.stat-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:.8rem}.info-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;display:grid}.info-item label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:.75rem;display:block}.info-item span{font-size:.95rem}.session-grid{background:var(--color-border);border:1px solid var(--color-border);border-radius:var(--radius);grid-template-columns:auto 1fr 1fr 1fr;gap:1px;display:grid;overflow:hidden}.session-grid-header,.session-grid-label,.session-grid-cell{background:var(--color-surface);padding:.75rem}.session-grid-header{text-transform:uppercase;color:var(--color-text-muted);background:#fafafa;font-size:.8rem;font-weight:600}.session-grid-label{background:#fafafa;font-size:.85rem;font-weight:600}.session-grid-cell{font-size:.85rem}.session-grid-cell .condition{color:var(--color-text-muted);font-size:.75rem}.session-grid-cell .completed-at{color:var(--color-text-muted);margin-top:.25rem;font-size:.75rem}.empty-state{text-align:center;color:var(--color-text-muted);padding:3rem}.experiment-bg{color:#fff;cursor:none;-webkit-user-select:none;user-select:none;background:#000;justify-content:center;align-items:center;font-family:system-ui,sans-serif;display:flex;position:fixed;inset:0}.experiment-blank{width:100%;height:100%}.experiment-text{text-align:center;max-width:500px;font-size:1.2rem;line-height:1.6}.experiment-text h2{margin-bottom:.5rem}.experiment-image{object-fit:contain;max-width:80vw;max-height:80vh}.fixation-cross{color:#fff;font-family:monospace;font-size:72px;line-height:1}.rating-container{text-align:center}.rating-prompt{margin-bottom:1.5rem;font-size:1.5rem}.rating-scale{align-items:center;gap:.75rem;font-size:1.2rem;display:flex}.rating-anchor{color:#aaa;min-width:80px;font-size:.85rem}.rating-key{border:1px solid #555;border-radius:4px;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;font-weight:600;display:flex}.memory-prompt{text-align:center}.memory-title{margin-bottom:1.5rem;font-size:2rem}.memory-keys{justify-content:center;gap:3rem;font-size:1.2rem;display:flex}.memory-key-hint strong{text-align:center;border:1px solid #555;border-radius:4px;width:2rem;height:2rem;margin-right:.5rem;line-height:2rem;display:inline-block}.pause-screen{text-align:center}.pause-title{margin-bottom:1rem;font-size:2rem}.pause-countdown{font-variant-numeric:tabular-nums;margin-bottom:1rem;font-size:4rem;font-weight:700}.pause-hint{color:#aaa;font-size:.9rem}.practice-screen{text-align:center;max-width:500px;line-height:1.6}.practice-screen h2{margin-bottom:1rem;font-size:1.5rem}.practice-screen p{margin-bottom:.75rem}.practice-hint{color:#aaa;margin-top:1.5rem;font-size:.85rem}.practice-warning{color:#f59e0b;font-weight:500}.practice-ok{color:#22c55e}.image-load-screen{text-align:center}.image-load-bar-track{background:#333;border-radius:3px;width:300px;height:6px;margin-top:1rem;overflow:hidden}.image-load-bar-fill{background:var(--color-primary);height:100%;transition:width .2s}.sync-status{margin:1rem 0}.trial-counter{color:#555;font-size:.75rem}
