.layout-header{align-items:center;background:var(--surface);border-bottom:1px solid var(--border);display:flex;gap:1rem;padding:.75rem 1rem}.layout-logo{color:var(--text);font-size:1.25rem;font-weight:700}.layout-logo:hover{color:var(--accent);text-decoration:none}.layout-nav{display:flex;gap:1rem}.layout-user{align-items:center;display:flex;gap:.5rem;margin-left:auto}.layout-avatar,.layout-avatar-placeholder{border-radius:50%;height:32px;object-fit:cover;width:32px}.layout-avatar-placeholder{align-items:center;background:var(--accent);color:var(--bg);display:inline-flex;font-size:.9rem;justify-content:center}.layout-name{color:var(--text-muted);font-size:.9rem}.layout-logout{background:#0000;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:.85rem;padding:.35rem .75rem}.layout-logout:hover{border-color:var(--danger);color:var(--danger)}.layout-main{flex:1 1}.auth-page{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:1rem}.auth-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);max-width:360px;padding:2rem;width:100%}.auth-form h1{font-size:1.5rem;margin:0 0 1.5rem}.auth-google-link{color:#2563eb;color:var(--accent,#2563eb);text-decoration:none}.auth-google-link:hover{text-decoration:underline}.auth-form-message{text-align:center}.auth-success-text{color:var(--text);line-height:1.5;margin:0 0 .75rem}.auth-success-hint{color:var(--text-muted);font-size:.9rem;margin:0 0 1.5rem}.auth-form-message .auth-footer{margin-top:1rem}.auth-confirm-form{margin:1rem 0;text-align:left}.auth-confirm-form label{color:var(--text-muted);display:block;font-size:.9rem;margin-bottom:1rem}.auth-confirm-form input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);display:block;margin-top:.35rem;padding:.6rem .75rem;width:100%}.auth-code-input{font-size:1.25rem;letter-spacing:.3em;text-align:center}.auth-input-readonly{cursor:default;opacity:.85}.auth-confirm-form button{background:var(--accent);border:none;border-radius:var(--radius);color:var(--bg);cursor:pointer;font-size:1rem;margin-top:.5rem;padding:.65rem;width:100%}.auth-confirm-form button:disabled{cursor:not-allowed;opacity:.7}.auth-form label{color:var(--text-muted);display:block;font-size:.9rem;margin-bottom:1rem}.auth-form input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);display:block;margin-top:.35rem;padding:.6rem .75rem;width:100%}.auth-form input:focus{border-color:var(--accent);outline:none}.auth-form button{background:var(--accent);border:none;border-radius:var(--radius);color:var(--bg);font-weight:600;margin-top:.5rem;padding:.65rem;width:100%}.auth-form button:hover{background:var(--accent-hover)}.auth-error{background:#f7768e26;border-radius:var(--radius);color:var(--danger);font-size:.9rem;margin:0 0 1rem;padding:.5rem}.auth-footer{color:var(--text-muted);font-size:.9rem;margin:1.5rem 0 0;text-align:center}.assignee-avatar{align-items:center;border-radius:50%;display:inline-flex;flex-shrink:0;justify-content:center;object-fit:cover;overflow:hidden}.assignee-avatar-img{background:var(--border)}.assignee-avatar-initials{background:var(--accent);color:var(--bg);font-size:inherit;font-weight:600;line-height:1}.assignee-select{flex:1 1;min-width:0;position:relative}.assignee-select-trigger{align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--text);cursor:pointer;display:flex;font-size:.8rem;gap:.35rem;min-width:0;padding:.2rem .35rem;text-align:left;width:100%}.assignee-select-trigger:hover{border-color:var(--text-muted)}.assignee-select-trigger:focus{border-color:var(--accent);outline:none}.assignee-select-trigger-label{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.assignee-select-placeholder{color:var(--text-muted);flex:1 1}.assignee-select-chevron{color:var(--text-muted);flex-shrink:0;font-size:.6rem}.assignee-select-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:6px;box-shadow:0 4px 12px #00000026;left:0;list-style:none;margin:2px 0 0;max-height:200px;overflow-y:auto;padding:.25rem 0;position:absolute;right:0;top:100%;z-index:100}.assignee-select-option{align-items:center;background:none;border:none;color:var(--text);cursor:pointer;display:flex;font-size:.85rem;gap:.5rem;padding:.35rem .6rem;text-align:left;width:100%}.assignee-select-option:hover{background:var(--bg)}.assignee-select-option-selected{background:var(--bg);color:var(--accent)}.assignee-select-option-placeholder{color:var(--text-muted)}.quest-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);cursor:grab;display:flex;flex-direction:column;gap:.25rem;padding:.6rem .75rem;touch-action:none}.quest-card:active{cursor:grabbing}.quest-card-ghost{opacity:.5}.quest-card-top{align-items:flex-start;display:flex;gap:.25rem}.quest-card-title{flex:1 1;font-size:.9rem;min-width:0}.quest-card-delete{background:#0000;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;flex-shrink:0;font-size:.8rem;padding:.1rem .25rem}.quest-card-delete:hover{background:var(--surface);color:#c53030;color:var(--error,#c53030)}.quest-card-assignee-row{align-items:center;display:flex;font-size:.8rem;gap:.35rem}.quest-card-assignee-label{color:var(--text-muted);flex-shrink:0}.quest-card-assignee-select{background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--text);cursor:pointer;flex:1 1;font-size:.8rem;min-width:0;padding:.2rem .35rem}.quest-card-assignee-select:focus{border-color:var(--accent);outline:none}.quest-card-assignee{color:var(--text-muted);font-size:.8rem}.quest-card-xp{color:var(--success);font-size:.75rem}.kanban-column{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-height:200px;min-width:0;padding:.75rem;transition:border-color .15s;width:100%}.kanban-column-over{background:#7aa2f714;border-color:var(--accent)}.kanban-column-header{align-items:center;display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.75rem}.kanban-column-title{color:var(--text-muted);flex:1 1;font-size:.95rem;margin:0;min-width:0}.kanban-column-title[title]{cursor:pointer}.kanban-column-title-edit{flex:1 1;min-width:0}.kanban-column-title-edit input{background:var(--bg);border:1px solid var(--accent);border-radius:4px;color:var(--text);font-size:.95rem;padding:.2rem .35rem;width:100%}.kanban-column-btn{background:#0000;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;flex-shrink:0;font-size:.85rem;padding:.15rem .35rem}.kanban-column-btn:hover{background:var(--bg);color:var(--accent)}.kanban-column-delete:hover{color:#c53030;color:var(--error,#c53030)}.kanban-column-done-toggle{align-items:center;color:var(--text-muted);cursor:pointer;display:flex;font-size:.8rem;gap:.35rem;margin:0 0 .5rem}.kanban-column-done-toggle input{cursor:pointer;flex-shrink:0}.kanban-column-cards{display:flex;flex-direction:column;gap:.5rem;min-height:40px}.kanban-add-btn{background:#0000;border:1px dashed var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:.9rem;margin-top:.5rem;padding:.5rem;width:100%}.kanban-add-btn:hover{border-color:var(--accent);color:var(--accent)}.kanban-add-form{margin-top:.5rem}.kanban-add-description{color:var(--text-muted);display:flex;flex-direction:column;font-size:.85rem;gap:.25rem}.kanban-add-description textarea{background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:.85rem;min-height:2.5em;padding:.35rem .5rem;resize:vertical}.kanban-add-form input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);margin-bottom:.5rem;padding:.5rem;width:100%}.kanban-add-assignee{color:var(--text-muted);display:block;font-size:.85rem;margin-bottom:.5rem}.kanban-add-assignee select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);display:block;font-size:.9rem;margin-top:.25rem;padding:.4rem;width:100%}.kanban-add-actions{display:flex;gap:.5rem}.kanban-add-actions button{border-radius:var(--radius);font-size:.85rem;padding:.35rem .75rem}.kanban-add-actions button:first-child{background:var(--accent);border:none;color:var(--bg)}.kanban-add-actions button:last-child{background:#0000;border:1px solid var(--border);color:var(--text-muted)}.kanban-board{min-height:400px}.kanban-columns{align-items:flex-start;display:flex;gap:1rem;padding-bottom:1rem}.kanban-column-sortable{display:flex;flex:1 1 180px;flex-direction:column;gap:.25rem;max-width:280px;min-width:180px}.kanban-column-sortable-dragging{cursor:grabbing}.kanban-column-grip{align-self:flex-start;border-radius:4px;color:#888;color:var(--text-muted,#888);cursor:grab;font-size:1rem;line-height:1;padding:.2rem .5rem;-webkit-user-select:none;user-select:none}.kanban-column-grip:hover{background:#6495ed26;color:var(--accent)}.kanban-column-sortable .kanban-column{flex:1 1 auto}.quest-card-dragging{box-shadow:0 8px 24px #0006;cursor:grabbing;touch-action:none;transform:rotate(2deg)}.kanban-column-add{flex:0 0 auto;max-width:300px;min-width:200px}.kanban-add-column-btn{background:#2a2a2a;background:var(--surface,#2a2a2a);border:2px dashed #444;border:2px dashed var(--border,#444);border-radius:8px;border-radius:var(--radius,8px);color:#888;color:var(--text-muted,#888);cursor:pointer;font-size:.95rem;padding:1rem;width:100%}.kanban-add-column-btn:hover{border-color:#6495ed;border-color:var(--accent,#6495ed);color:var(--accent)}.kanban-add-column-form{background:var(--surface);padding:.75rem}.kanban-add-column-form,.kanban-add-column-input{border:1px solid var(--border);border-radius:var(--radius)}.kanban-add-column-input{background:var(--bg);color:var(--text);margin-bottom:.5rem;padding:.5rem;width:100%}.kanban-add-column-done{color:var(--text-muted);cursor:pointer;display:block;font-size:.85rem;margin-bottom:.75rem}.kanban-add-column-done input{margin-right:.35rem}.kanban-add-column-actions{display:flex;gap:.5rem}.kanban-add-column-submit{background:var(--accent);border:none;border-radius:var(--radius);color:var(--bg);cursor:pointer;font-weight:600;padding:.4rem .75rem}.kanban-add-column-submit:disabled{cursor:not-allowed;opacity:.6}.kanban-add-column-cancel{background:#0000;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;padding:.4rem .75rem}.board-page{overflow-x:auto;padding:1rem}.board-header-row{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.25rem}.board-actions{display:flex;gap:.25rem}.board-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;font-size:.9rem;padding:.25rem .5rem}.board-btn:hover{border-color:var(--accent);color:var(--accent)}.board-btn-delete:hover{border-color:#c53030;border-color:var(--error,#c53030);color:#c53030;color:var(--error,#c53030)}.board-edit-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;max-width:400px;padding:.75rem}.board-edit-form label{display:flex;flex-direction:column;font-size:.9rem;gap:.2rem}.board-edit-form input{background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:.35rem .5rem}.board-edit-actions{display:flex;gap:.5rem;margin-top:.25rem}.board-edit-actions button{border-radius:var(--radius);cursor:pointer;font-size:.9rem;padding:.45rem .9rem}.board-edit-actions button[type=submit]{background:var(--accent);border:none;color:var(--bg);font-weight:600}.board-edit-actions button[type=submit]:hover{filter:brightness(1.1)}.board-edit-actions button[type=button]{background:#0000;border:1px solid var(--border);color:var(--text-muted)}.board-edit-actions button[type=button]:hover{border-color:var(--accent);color:var(--accent)}.board-title{font-size:1.5rem;margin:0 0 .25rem}.board-desc{color:var(--text-muted);font-size:.9rem;margin:0 0 .25rem}.board-meta{color:var(--text-muted);font-size:.85rem;margin:0 0 1rem}.board-id{background:var(--surface);border-radius:4px;font-size:.8rem;margin-right:.5rem;padding:.15rem .4rem}.board-copy-id{background:#0000;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:.8rem;padding:.2rem .5rem}.board-copy-id:hover{border-color:var(--accent);color:var(--accent)}.board-quest-modal-overlay{align-items:center;background:#0006;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.board-quest-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0003;max-width:420px;width:90%}.board-quest-modal-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:.75rem 1rem}.board-quest-modal-header h3{font-size:1rem;margin:0}.board-quest-modal-close{background:#0000;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:.25rem .5rem}.board-quest-modal-close:hover{background:var(--bg);color:var(--text)}.board-quest-modal-body{font-size:.9rem;padding:1rem}.board-quest-modal-body p{margin:0 0 .5rem}.board-quest-modal-field{color:var(--text-muted);display:flex;flex-direction:column;font-size:.9rem;gap:.25rem;margin-bottom:.75rem}.board-quest-modal-field input,.board-quest-modal-field textarea{background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:.9rem;padding:.4rem .5rem}.board-quest-modal-field textarea{min-height:4em;resize:vertical}.board-quest-modal-actions{border-top:1px solid var(--border);margin-top:1rem;padding-top:.75rem}.board-quest-modal-actions button{background:var(--accent);border:none;border-radius:var(--radius);color:var(--bg);cursor:pointer;font-size:.9rem;font-weight:600;padding:.45rem .9rem}.board-quest-modal-actions button:disabled{cursor:not-allowed;opacity:.7}.board-quest-modal-desc{color:var(--text-muted);white-space:pre-wrap}.board-quest-modal-meta{color:var(--text-muted);font-size:.8rem;margin-top:.75rem!important}.quest-card-info{background:#0000;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;flex-shrink:0;font-size:.8rem;padding:.1rem .35rem}.quest-card-info:hover{background:var(--surface);color:var(--accent)}.home-page{padding:1.5rem}.home-character{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:2rem;padding:1rem}.home-character h2{font-size:1.1rem;margin:0 0 .5rem}.home-badge{background:var(--accent);border-radius:4px;color:var(--bg);display:inline-block;font-size:.85rem;margin-top:.5rem;padding:.25rem .5rem}.home-invites-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:2rem;padding:1rem}.home-invites-section h2{font-size:1.1rem;margin:0 0 1rem}.home-invites-list{list-style:none;margin:0;padding:0}.home-invite-item{align-items:center;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;padding:.75rem 0}.home-invite-item:last-child{border-bottom:none}.home-invite-text{flex:1 1;font-size:.95rem;min-width:0}.home-invite-accept-btn{background:var(--accent);border:none;border-radius:var(--radius);color:var(--bg);cursor:pointer;font-weight:600;padding:.4rem .75rem}.home-invite-accept-btn:hover:not(:disabled){background:var(--accent-hover)}.home-invite-accept-btn:disabled{cursor:not-allowed;opacity:.7}.home-invite-decline-btn{background:#0000;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;padding:.4rem .75rem}.home-invite-decline-btn:hover:not(:disabled){border-color:var(--text-muted);color:var(--text)}.home-invite-decline-btn:disabled{cursor:not-allowed;opacity:.7}.home-boards h2{font-size:1.1rem;margin:0 0 .75rem}.home-teams-list{list-style:none;margin:0 0 1.5rem;padding:0}.home-team-block{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1rem;padding:1rem}.home-team-header{align-items:center;display:flex;gap:.5rem;margin-bottom:.5rem}.home-team-name{color:var(--text);font-size:1rem;font-weight:600}.home-team-btn{background:#0000;border:1px solid var(--border);border-radius:4px;color:var(--text-muted);cursor:pointer;font-size:.85rem;padding:.2rem .4rem}.home-team-btn:hover{border-color:var(--accent);color:var(--accent)}.home-team-delete-btn:hover{border-color:#c62828;color:#c62828}.home-team-leave-btn{color:var(--text-muted);font-size:.85rem;margin-left:auto}.home-team-leave-btn:hover{border-color:var(--border);color:var(--text)}.home-team-edit-form{display:flex;flex:1 1;flex-direction:column;gap:.35rem;max-width:280px}.home-team-edit-form input{background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:.9rem;padding:.35rem .5rem}.home-team-edit-actions{display:flex;gap:.5rem}.home-team-edit-actions button{border-radius:4px;font-size:.85rem;padding:.35rem .6rem}.home-team-edit-actions button:first-child{background:var(--accent);border:none;color:var(--bg)}.home-team-expand{border-top:1px solid var(--border);margin-top:.75rem;padding-top:.5rem}.home-expand-btn{background:#0000;border:1px solid var(--border);border-radius:4px;color:var(--text-muted);cursor:pointer;font-size:.85rem;padding:.35rem .6rem}.home-expand-btn:hover{border-color:var(--accent);color:var(--accent)}.home-team-details{grid-gap:1rem;border-top:1px solid var(--border);display:grid;gap:1rem;grid-template-columns:1fr 1fr 1fr;margin-top:.75rem;padding-top:.75rem}@media (max-width:700px){.home-team-details{grid-template-columns:1fr}}.home-detail-section h4{color:var(--text-muted);font-size:.95rem;margin:0 0 .5rem}.home-kpi-section{overflow:hidden}.home-kpi-charts{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:1fr 1fr;margin-top:.5rem}@media (max-width:640px){.home-kpi-charts{grid-template-columns:1fr}}.home-kpi-chart{min-width:0}.home-kpi-chart h5{color:var(--text);font-size:.85rem;font-weight:600;margin:0 0 .5rem}.home-activity-list,.home-leaderboard-list,.home-members-list{font-size:.9rem;list-style:none;margin:0;padding:0}.home-member-item{align-items:center;display:flex;gap:.5rem;margin-bottom:.35rem}.home-member-name{color:var(--accent);margin-right:.5rem;text-decoration:none}.home-member-name:hover{text-decoration:underline}.home-member-avatar,.home-member-avatar-placeholder{align-items:center;background:var(--border);border-radius:50%;display:inline-flex;flex-shrink:0;font-size:.75rem;height:24px;justify-content:center;object-fit:cover;width:24px}.home-member-remove{background:#0000;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;font-size:.8rem;margin-left:auto;padding:.1rem .35rem}.home-member-remove:hover{background:#c5303026;color:#c53030;color:var(--error,#c53030)}.home-leaderboard-list li{margin-bottom:.25rem}.home-activity-list .home-activity-item{border-bottom:1px solid var(--border);font-size:.85rem;margin-bottom:.35rem;padding:.25rem 0}.home-team-refresh-boards{margin-left:0}.home-member-level{background:var(--bg);border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;font-size:.75rem;padding:.15rem .4rem}.home-member-level:hover{color:var(--accent)}.home-leaderboard-level{color:var(--text-muted);font-size:.8rem}.home-team-boards{list-style:none;margin:0;padding:0}.home-team-boards li{margin-bottom:.35rem}.home-team-boards a{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);display:inline-block;font-size:.9rem;padding:.4rem .6rem}.home-team-boards a:hover{border-color:var(--accent);text-decoration:none}.home-create-btn{background:var(--accent);border:none;border-radius:var(--radius);color:var(--bg);display:inline-block;font-size:.95rem;font-weight:600;margin-bottom:1rem;padding:.6rem 1rem}.home-create-btn:hover{background:var(--accent-hover)}.home-create-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1.5rem;max-width:360px;padding:1rem}.home-create-form h3{font-size:1rem;margin:0 0 1rem}.home-create-form label{color:var(--text-muted);display:block;font-size:.9rem;margin-bottom:.75rem}.home-create-form input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);display:block;margin-top:.35rem;padding:.5rem .75rem;width:100%}.home-create-error{background:#f7768e26;border-radius:var(--radius);color:var(--danger);font-size:.9rem;margin:0 0 .75rem;padding:.5rem}.home-create-actions{display:flex;gap:.5rem;margin-top:1rem}.home-create-actions button:first-child{background:var(--accent);border:none;border-radius:var(--radius);color:var(--bg);font-weight:600;padding:.5rem 1rem}.home-create-actions button:first-child:disabled{cursor:not-allowed;opacity:.7}.home-create-actions button:last-child{background:#0000;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);padding:.5rem 1rem}.home-add-board{margin-top:.5rem}.home-add-board-btn{background:#0000;border:1px dashed var(--border);border-radius:4px;color:var(--text-muted);cursor:pointer;font-size:.9rem;padding:.35rem .6rem}.home-add-board-btn:hover{border-color:var(--accent);color:var(--accent)}.home-add-board-form{display:flex;flex-direction:column;gap:.35rem;max-width:260px}.home-add-board-form input{border:1px solid var(--border);border-radius:4px;font-size:.9rem;padding:.4rem .5rem}.home-add-board-actions{display:flex;gap:.5rem}.home-add-board-actions button{border-radius:4px;cursor:pointer;font-size:.85rem;padding:.35rem .6rem}.home-add-board-actions button[type=submit]{background:var(--accent);border:none;color:var(--bg)}.home-add-board-error{color:#c62828;font-size:.85rem;margin:0}.home-team-invite{border-top:1px solid var(--border);margin-top:.75rem;padding-top:.75rem}.home-invite-btn{background:#0000;border:1px solid var(--accent);border-radius:var(--radius);color:var(--accent);font-size:.9rem;padding:.4rem .75rem}.home-invite-btn:hover{background:#6495ed1a;background:rgba(var(--accent-rgb,100,149,237),.1)}.home-invite-form input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);display:inline-block;font-size:.9rem;margin-bottom:.5rem;margin-right:.5rem;max-width:260px;padding:.45rem .6rem;width:100%}.home-invite-actions{display:flex;flex-wrap:wrap;gap:.5rem}.home-invite-actions button:first-child{background:var(--accent);border:none;border-radius:var(--radius);color:var(--bg);font-size:.9rem;padding:.45rem .75rem}.home-invite-actions button:last-child{background:#0000;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:.9rem;padding:.45rem .75rem}.home-invite-error{color:#c00;color:var(--danger,#c00);font-size:.85rem;margin:.5rem 0 0}.home-empty{color:var(--text-muted);font-size:.9rem}.profile-page{max-width:720px;padding:1.5rem}.profile-page h1{align-items:center;display:flex;flex-wrap:wrap;font-size:1.5rem;gap:1rem;margin:0 0 1.5rem}.profile-back-link{color:var(--accent);font-size:.9rem;font-weight:400;text-decoration:none}.profile-back-link:hover{text-decoration:underline}.profile-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:2rem;padding:1rem}.profile-section h2{font-size:1.1rem;margin:0 0 .75rem}.profile-avatar-section .profile-avatar-row{align-items:flex-start;display:flex;gap:1.25rem}.profile-avatar-preview{align-items:center;background:var(--border);border-radius:50%;display:flex;flex-shrink:0;height:80px;justify-content:center;overflow:hidden;width:80px}.profile-avatar-img{height:100%;object-fit:cover;width:100%}.profile-avatar-placeholder{color:var(--text-muted);font-size:2rem;font-weight:600}.profile-avatar-actions{display:flex;flex-direction:column;gap:.35rem}.profile-avatar-input{height:0;opacity:0;pointer-events:none;position:absolute;width:0}.profile-avatar-btn{align-self:flex-start;background:var(--accent);border:none;border-radius:var(--radius);color:var(--bg);cursor:pointer;font-size:.9rem;padding:.4rem .75rem}.profile-avatar-btn:hover:not(:disabled){opacity:.9}.profile-avatar-btn:disabled{cursor:not-allowed;opacity:.7}.profile-avatar-delete-btn{background:#0000;border:1px solid var(--border);color:var(--text-muted)}.profile-avatar-delete-btn:hover:not(:disabled){border-color:#c62828;color:#c62828}.profile-avatar-hint{color:var(--text-muted);font-size:.8rem;margin:0}.profile-avatar-error{color:#c62828;font-size:.85rem;margin:0}.profile-sub{color:var(--text-muted);font-size:.9rem;margin:0 0 .5rem}.profile-badge{background:var(--accent);border-radius:4px;color:var(--bg);display:inline-block;font-size:.85rem;margin-top:.5rem;padding:.25rem .5rem}.profile-achievements-list,.profile-skills-list,.profile-skills-tree-list,.profile-xp-list{font-size:.9rem;list-style:none;margin:0;padding:0}.profile-xp-list li{align-items:baseline;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:.35rem;padding:.35rem 0}.profile-xp-amount{color:var(--success);font-weight:600}.profile-xp-source{color:var(--text)}.profile-xp-date,.profile-xp-desc{color:var(--text-muted)}.profile-xp-date{font-size:.8rem;margin-left:auto}.profile-achievement-item,.profile-skill-item{align-items:flex-start;border-bottom:1px solid var(--border);display:flex;gap:.75rem;padding:.5rem 0}.profile-achievement-unlocked{opacity:1}.profile-achievement-item:not(.profile-achievement-unlocked){opacity:.7}.profile-achievement-icon,.profile-skill-icon{border-radius:4px;flex-shrink:0;height:32px;object-fit:contain;width:32px}.profile-achievement-icon-placeholder,.profile-skill-icon-placeholder{align-items:center;background:var(--border);border-radius:4px;display:inline-flex;flex-shrink:0;font-size:1.2rem;height:32px;justify-content:center;width:32px}.profile-achievement-desc,.profile-skill-desc{color:var(--text-muted);font-size:.85rem;font-weight:400;margin:.2rem 0 0}.profile-achievement-how{color:var(--accent);font-size:.85rem;font-weight:400;margin:.25rem 0 0}.profile-achievement-xp{display:inline-block;margin-right:.5rem}.profile-achievement-date,.profile-achievement-xp{color:var(--success);font-size:.8rem}.profile-achievement-locked{color:var(--text-muted);font-size:.8rem}.profile-skill-tree-details{font-size:.9rem;margin-top:.75rem}.profile-skill-tree-details summary{color:var(--accent);cursor:pointer}.profile-skills-tree-list{margin-top:.5rem;padding-left:1rem}.profile-skills-tree-list li{margin-bottom:.2rem}.profile-skill-unlocked{color:var(--success)}.profile-skill-how,.profile-skill-locked{color:var(--text-muted)}.profile-skill-how{font-size:.85rem;font-weight:400}.profile-skill-check{color:var(--success)}.profile-skill-dash{color:var(--text-muted)}.profile-empty{color:var(--text-muted);font-size:.9rem;margin:0}.profile-levels-list{font-size:.9rem;list-style:none;margin:0;padding:0}.profile-levels-list li{border-bottom:1px solid var(--border);padding:.3rem 0}.profile-level-current{color:var(--accent);font-weight:600}.users-page{max-width:720px;padding:1.5rem}.users-page h1{font-size:1.5rem;margin:0 0 .35rem}.users-page-sub{color:var(--text-muted);font-size:.9rem;margin:0 0 1.25rem}.users-table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow-x:auto}.users-table{border-collapse:collapse;font-size:.95rem;width:100%}.users-table td,.users-table th{border-bottom:1px solid var(--border);padding:.65rem 1rem;text-align:left}.users-table th{background:var(--bg);color:var(--text-muted);font-weight:600}.users-table tbody tr:last-child td{border-bottom:none}.users-table tbody tr:hover{background:var(--bg)}.users-table-name{color:var(--accent);font-weight:500;text-decoration:none}.users-table-name:hover{text-decoration:underline}.users-table-email{color:var(--text)}.users-table-link{color:var(--accent);font-size:.9rem;text-decoration:none}.users-table-link:hover{text-decoration:underline}.users-page-empty{color:var(--text-muted);margin:1.5rem 0 0}*{box-sizing:border-box}:root{--bg:#1a1b26;--surface:#24283b;--border:#3b4261;--text:#c0caf5;--text-muted:#565f89;--accent:#7aa2f7;--accent-hover:#89b4fa;--success:#9ece6a;--danger:#f7768e;--radius:8px}body{background:#1a1b26;background:var(--bg);color:#c0caf5;color:var(--text);font-family:Segoe UI,system-ui,sans-serif;margin:0;min-height:100vh}a{color:#7aa2f7;color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer}button,input,select,textarea{font:inherit}.app{display:flex;flex-direction:column;min-height:100vh}.page{flex:1 1;margin:0 auto;max-width:1400px;padding:1rem;width:100%}
/*# sourceMappingURL=main.99b74dba.css.map*/