.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.auth-container{width:100%;max-width:400px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2.5rem;box-shadow:var(--shadow-lg),var(--shadow-glow)}.auth-header{text-align:center;margin-bottom:2rem}.auth-logo{display:inline-flex;color:var(--color-accent);margin-bottom:1rem}.auth-header h1{font-size:1.75rem;font-weight:600;color:var(--color-text-primary);margin-bottom:.5rem}.auth-header p{color:var(--color-text-muted)}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.auth-form input{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.875rem 1rem;color:var(--color-text-primary);font-size:1rem;transition:border-color .2s,box-shadow .2s}.auth-form input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #4ade801a}.auth-form input::placeholder{color:var(--color-text-muted)}.unit-toggle{display:flex;background:var(--color-bg-secondary);border-radius:var(--radius-md);padding:.25rem}.unit-btn{flex:1;background:transparent;border:none;color:var(--color-text-muted);padding:.75rem;border-radius:var(--radius-sm);font-size:.875rem;transition:all .2s}.unit-btn:hover{color:var(--color-text-secondary)}.unit-btn.active{background:var(--color-accent);color:var(--color-bg-primary);font-weight:500}.auth-error{color:var(--color-error);font-size:.875rem;text-align:center;padding:.75rem;background:#ef44441a;border-radius:var(--radius-md)}.auth-submit{background:var(--color-accent);color:var(--color-bg-primary);border:none;padding:1rem;border-radius:var(--radius-md);font-size:1rem;font-weight:600;transition:background .2s,transform .1s;margin-top:.5rem}.auth-submit:hover:not(:disabled){background:var(--color-accent-hover)}.auth-submit:active:not(:disabled){transform:scale(.98)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-footer{text-align:center;margin-top:1.5rem;color:var(--color-text-muted);font-size:.875rem}.auth-footer a{color:var(--color-accent);font-weight:500}.chart-container{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem}.chart-empty{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:4rem 2rem;text-align:center;margin-bottom:1.5rem}.chart-empty p{color:var(--color-text-secondary);font-size:1.125rem}.chart-empty-sub{color:var(--color-text-muted)!important;font-size:.875rem!important;margin-top:.5rem}.weight-form{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.weight-form h3{font-size:1rem;font-weight:500;color:var(--color-text-secondary);margin:0}.btn-toggle-advanced{background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);padding:.25rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer;transition:all .2s}.btn-toggle-advanced:hover{border-color:var(--color-accent);color:var(--color-accent)}.form-row{display:flex;gap:1rem;align-items:flex-end}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-group.flex-1{flex:1}.input-group label{font-size:.875rem;color:var(--color-text-muted)}.input-with-unit{position:relative;display:flex;align-items:center}.input-with-unit input{padding-right:3rem}.input-with-unit .unit{position:absolute;right:1rem;color:var(--color-text-muted);font-family:var(--font-mono);font-size:.875rem}.weight-form input{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.75rem 1rem;color:var(--color-text-primary);font-size:1rem;transition:border-color .2s,box-shadow .2s;width:100%}.weight-form input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #4ade801a}.weight-form input::placeholder{color:var(--color-text-muted)}.btn-submit{background:var(--color-accent);color:var(--color-bg-primary);border:none;padding:.75rem 1.5rem;border-radius:var(--radius-md);font-size:1rem;font-weight:600;transition:background .2s,transform .1s;white-space:nowrap}.btn-submit:active:not(:disabled){transform:scale(.98)}.error-message{color:var(--color-error);font-size:.875rem;margin-top:.75rem}.select-clothing{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.75rem 1rem;color:var(--color-text-primary);font-size:1rem;min-width:180px;cursor:pointer;transition:border-color .2s}.select-clothing:focus{outline:none;border-color:var(--color-accent)}.select-clothing option{background:var(--color-bg-secondary);color:var(--color-text-primary)}.advanced-row{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border)}.weight-form input[type=date],.weight-form input[type=time]{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.75rem 1rem;color:var(--color-text-primary);font-size:1rem;transition:border-color .2s}.weight-form input[type=date]:focus,.weight-form input[type=time]:focus{outline:none;border-color:var(--color-accent)}.clothing-info{margin-top:.75rem;font-size:.875rem;color:var(--color-text-muted)}.clothing-info strong{color:var(--color-accent)}@media (max-width: 768px){.form-row{flex-direction:column;align-items:stretch}.btn-submit{width:100%}}.stats-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.5rem;opacity:0}.stats-label{font-size:.875rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.stats-value-container{display:flex;align-items:baseline;gap:.5rem}.stats-value{font-size:2rem;font-weight:600;font-family:var(--font-mono);color:var(--color-text-primary);display:flex;align-items:center;gap:.25rem}.stats-value.trend-up{color:var(--color-error)}.stats-value.trend-down{color:var(--color-success)}.trend-icon{font-size:1rem}.stats-unit{font-size:1rem;color:var(--color-text-muted);font-family:var(--font-mono)}.weight-history{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem}.weight-history h3{font-size:1rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:1rem}.history-list{display:flex;flex-direction:column;gap:.5rem}.history-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--color-bg-secondary);border-radius:var(--radius-md);transition:background .2s;opacity:0}.history-item:hover{background:var(--color-bg-tertiary)}.history-main{display:flex;flex-direction:column;gap:.25rem;min-width:150px}.history-weight{font-size:1.125rem;font-weight:600;font-family:var(--font-mono);color:var(--color-text-primary)}.history-unit{font-size:.875rem;color:var(--color-text-muted)}.history-date{font-size:.75rem;color:var(--color-text-muted)}.history-meta{flex:1;display:flex;align-items:center;gap:.75rem}.history-source{font-size:.75rem;padding:.25rem .5rem;border-radius:var(--radius-sm);background:var(--color-accent-muted);color:var(--color-accent)}.history-source.source-wii_board{background:#6366f133;color:#818cf8}.history-notes{font-size:.875rem;color:var(--color-text-secondary);font-style:italic}.history-clothing{font-size:.75rem;padding:.25rem .5rem;border-radius:var(--radius-sm);background:#fbbf2426;color:#fbbf24;display:flex;align-items:center;gap:.5rem}.history-clothing .raw-weight{font-size:.7rem;opacity:.7}.history-delete{background:transparent;border:none;color:var(--color-text-muted);font-size:1.25rem;padding:.25rem .5rem;border-radius:var(--radius-sm);opacity:0;transition:all .2s}.history-item:hover .history-delete{opacity:1}.history-delete:hover{color:var(--color-error);background:#ef44441a}.clothing-manager{margin-bottom:1.5rem}.btn-manage-clothing{background:var(--color-bg-card);border:1px solid var(--color-border);color:var(--color-text-secondary);padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.875rem;cursor:pointer;transition:all .2s}.btn-manage-clothing:hover{border-color:var(--color-accent);color:var(--color-accent)}.clothing-panel{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;margin-top:.75rem;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.clothing-panel h4{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin:0 0 .5rem}.clothing-description{font-size:.875rem;color:var(--color-text-muted);margin-bottom:1rem}.clothing-add-form{display:flex;gap:.5rem;margin-bottom:1rem}.clothing-add-form .input-name{flex:1;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.5rem .75rem;color:var(--color-text-primary);font-size:.875rem}.input-weight-wrapper{position:relative;display:flex;align-items:center}.clothing-add-form .input-weight{width:80px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.5rem 2rem .5rem .75rem;color:var(--color-text-primary);font-size:.875rem}.unit-label{position:absolute;right:.5rem;color:var(--color-text-muted);font-size:.75rem}.clothing-add-form input:focus{outline:none;border-color:var(--color-accent)}.btn-add{background:var(--color-accent);color:var(--color-bg-primary);border:none;width:36px;height:36px;border-radius:var(--radius-md);font-size:1.25rem;font-weight:700;cursor:pointer;transition:background .2s}.btn-add:hover:not(:disabled){background:var(--color-accent-hover)}.btn-add:disabled{opacity:.6;cursor:not-allowed}.error-msg{color:var(--color-error);font-size:.75rem;margin-bottom:.5rem}.clothing-list{list-style:none;padding:0;margin:0}.clothing-item{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid var(--color-border)}.clothing-item:last-child{border-bottom:none}.clothing-name{flex:1;color:var(--color-text-primary);font-size:.875rem}.clothing-weight{color:var(--color-accent);font-family:var(--font-mono);font-size:.875rem}.btn-delete{background:transparent;border:none;color:var(--color-text-muted);font-size:1.25rem;padding:.25rem .5rem;cursor:pointer;opacity:.5;transition:all .2s}.btn-delete:hover{opacity:1;color:var(--color-error)}.no-items{color:var(--color-text-muted);font-size:.875rem;font-style:italic;padding:.5rem 0}.loading-msg{color:var(--color-text-muted);font-size:.875rem;padding:.5rem 0}.comments-panel{background:#1a211d;border:1px solid #2d3a32;border-radius:16px;display:flex;flex-direction:column;max-height:500px}.comments-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #2d3a32}.comments-header h3{margin:0;font-size:1rem;color:#e8f0eb}.close-btn{background:transparent;border:none;color:#6b7c6f;font-size:1.5rem;cursor:pointer;padding:0;line-height:1}.close-btn:hover{color:#e8f0eb}.comments-list{flex:1;overflow-y:auto;padding:1rem 1.25rem}.loading,.no-comments{text-align:center;color:#6b7c6f;padding:2rem 0}.comment{background:#0d1210;border-radius:10px;padding:.875rem 1rem;margin-bottom:.75rem}.comment:last-child{margin-bottom:0}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.comment-author{font-weight:600;color:#4ade80;font-size:.9rem}.comment-time{font-size:.75rem;color:#6b7c6f}.comment-text{margin:0;color:#e8f0eb;font-size:.95rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.comment-form{display:flex;gap:.75rem;padding:1rem 1.25rem;border-top:1px solid #2d3a32}.comment-form input{flex:1;padding:.75rem 1rem;background:#0d1210;border:1px solid #2d3a32;border-radius:8px;color:#e8f0eb;font-size:.95rem}.comment-form input:focus{outline:none;border-color:#4ade80}.comment-form input::placeholder{color:#6b7c6f}.comment-form button{padding:.75rem 1.25rem;background:#4ade80;border:none;border-radius:8px;color:#0a0f0d;font-weight:600;cursor:pointer;transition:all .2s}.comment-form button:hover:not(:disabled){background:#22c55e}.comment-form button:disabled{opacity:.5;cursor:not-allowed}.goal-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem;transition:border-color .2s}.goal-card:hover{border-color:var(--color-accent)}.goal-card.overdue{border-color:var(--color-error)}.goal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.goal-type-badge{background:var(--color-accent-muted);color:var(--color-accent);padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.goal-actions{display:flex;gap:.25rem;opacity:0;transition:opacity .2s}.goal-card:hover .goal-actions{opacity:1}.goal-actions button{background:transparent;border:none;color:var(--color-text-muted);padding:.25rem .5rem;border-radius:var(--radius-sm);cursor:pointer;font-size:1rem;transition:all .2s}.goal-actions button:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}.goal-actions button:last-child:hover{color:var(--color-error)}.goal-main{margin-bottom:1rem}.goal-target{display:flex;align-items:baseline;gap:.5rem;flex-wrap:wrap}.target-label{font-size:1rem;color:var(--color-text-secondary)}.target-weight{font-size:1.5rem;font-weight:600;font-family:var(--font-mono);color:var(--color-text-primary)}.goal-description{margin-top:.5rem;font-size:.875rem;color:var(--color-text-muted);font-style:italic}.goal-progress{margin-bottom:1rem}.progress-bar{height:8px;background:var(--color-bg-secondary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;border-radius:var(--radius-full);transition:width .3s ease}.progress-stats{display:flex;justify-content:space-between;font-size:.875rem;color:var(--color-text-muted)}.goal-footer{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:var(--color-text-muted);padding-top:.75rem;border-top:1px solid var(--color-border)}.goal-deadline{font-weight:500}.goal-deadline.warning{color:var(--color-warning)}.goal-deadline.overdue{color:var(--color-error)}.progress-vs-expected{margin-top:.75rem;padding:.5rem .75rem;border-radius:var(--radius-md);font-size:.8rem;display:flex;flex-direction:column;gap:.25rem}.progress-vs-expected.ahead{background:#4ade801a;color:#4ade80}.progress-vs-expected.behind{background:#fbbf241a;color:#fbbf24}.progress-vs-expected small{font-size:.7rem;opacity:.8}.goal-timeline{margin-top:.5rem;text-align:center;color:var(--color-text-muted)}.goal-timeline small{font-size:.7rem}.goal-action-buttons{display:flex;gap:.5rem;margin-top:1rem}.invite-keeper-btn,.comments-btn{flex:1;padding:.625rem .75rem;background:transparent;border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:.85rem;cursor:pointer;transition:all .2s}.invite-keeper-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-muted)}.comments-btn:hover{border-color:#60a5fa;color:#60a5fa;background:#60a5fa1a}.goal-card .comments-panel{margin-top:1rem;border-radius:var(--radius-md)}.goal-form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease-out}.goal-form{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2rem;width:100%;max-width:450px;animation:slideUp .3s ease-out}.goal-form h3{font-size:1.25rem;font-weight:600;color:var(--color-text-primary);margin:0 0 1.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:.5rem}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.goal-type-buttons{display:flex;background:var(--color-bg-secondary);border-radius:var(--radius-md);padding:.25rem}.goal-type-buttons button{flex:1;background:transparent;border:none;color:var(--color-text-muted);padding:.5rem .75rem;border-radius:var(--radius-sm);font-size:.875rem;cursor:pointer;transition:all .2s}.goal-type-buttons button:hover{color:var(--color-text-secondary)}.goal-type-buttons button.active{background:var(--color-accent);color:var(--color-bg-primary);font-weight:500}.goal-form input[type=number],.goal-form input[type=date],.goal-form input[type=text]{width:100%;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.75rem 1rem;color:var(--color-text-primary);font-size:1rem;transition:border-color .2s}.goal-form input:focus{outline:none;border-color:var(--color-accent)}.goal-form input::placeholder{color:var(--color-text-muted)}.error-message{color:var(--color-error);font-size:.875rem;margin-bottom:1rem}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.btn-cancel{flex:1;background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary);padding:.75rem;border-radius:var(--radius-md);font-size:1rem;cursor:pointer;transition:all .2s}.btn-cancel:hover{border-color:var(--color-text-muted);color:var(--color-text-primary)}.btn-submit{flex:1;background:var(--color-accent);border:none;color:var(--color-bg-primary);padding:.75rem;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-submit:hover:not(:disabled){background:var(--color-accent-hover)}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.advanced-toggle{display:flex!important;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;color:var(--color-text-muted)}.advanced-toggle input[type=checkbox]{width:auto;margin:0}.help-text{display:block;margin-top:.25rem;font-size:.75rem;color:var(--color-text-muted);font-style:italic}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#1a211d;border:1px solid #2d3a32;border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 16px 48px #00000080}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #2d3a32}.modal-header h2{margin:0;font-size:1.25rem;color:#e8f0eb}.close-button{background:transparent;border:none;color:#6b7c6f;font-size:1.5rem;cursor:pointer;padding:.25rem;line-height:1}.close-button:hover{color:#e8f0eb}.modal-subtitle{padding:0 1.5rem;margin:1rem 0;color:#a3b8a8;font-size:.9rem}.modal-content form{padding:0 1.5rem 1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;color:#a3b8a8;font-size:.9rem}.form-group input[type=text],.form-group input[type=email]{width:100%;padding:.75rem 1rem;background:#0d1210;border:1px solid #2d3a32;border-radius:8px;color:#e8f0eb;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#4ade80}.form-group input::placeholder{color:#6b7c6f}.form-section{margin:1.5rem 0;padding-top:1rem;border-top:1px solid #2d3a32}.form-section h3{font-size:.9rem;color:#a3b8a8;margin:0 0 1rem;font-weight:500}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;margin-bottom:.75rem}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:#4ade80;cursor:pointer}.checkbox-label span{color:#e8f0eb;font-size:.95rem}.hint{margin:.5rem 0 0 1.75rem;font-size:.8rem;color:#6b7c6f}.modal-actions{display:flex;gap:1rem;margin-top:1.5rem}.btn-secondary{flex:1;padding:.875rem;background:transparent;border:1px solid #2d3a32;color:#a3b8a8;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#232b27;color:#e8f0eb}.btn-primary{flex:1;padding:.875rem;background:#4ade80;border:none;color:#0a0f0d;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary:hover:not(:disabled){background:#22c55e}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.goals-section{margin-bottom:1.5rem}.goals-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.goals-header h3{font-size:1.125rem;font-weight:600;color:var(--color-text-primary);margin:0}.goals-actions{display:flex;align-items:center;gap:1rem}.show-all-toggle{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--color-text-muted);cursor:pointer}.show-all-toggle input{accent-color:var(--color-accent)}.btn-add-goal{background:var(--color-accent);color:var(--color-bg-primary);border:none;padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-add-goal:hover{background:var(--color-accent-hover)}.goals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.goals-empty{background:var(--color-bg-card);border:1px dashed var(--color-border);border-radius:var(--radius-lg);padding:3rem 2rem;text-align:center}.goals-empty p{color:var(--color-text-muted);margin-bottom:1rem}.goals-empty button{background:transparent;border:1px solid var(--color-accent);color:var(--color-accent);padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.875rem;cursor:pointer;transition:all .2s}.goals-empty button:hover{background:var(--color-accent);color:var(--color-bg-primary)}.goals-loading{color:var(--color-text-muted);text-align:center;padding:2rem}.pending-invites{background:linear-gradient(135deg,#fbbf241a,#4ade801a);border:1px solid rgba(251,191,36,.3);border-radius:16px;padding:1.5rem;margin-bottom:2rem}.pending-invites.loading-state{background:#4ade800d;border-color:#4ade8033}.pending-invites.loading-state h3{color:#a3b8a8;margin:0}.pending-invites.error-state{background:#ef44441a;border-color:#ef44444d}.pending-invites.error-state h3{color:#ef4444}.pending-invites.error-state p{color:#a3b8a8;margin:.5rem 0}.pending-invites.error-state button{margin-top:.5rem;padding:.5rem 1rem;background:transparent;border:1px solid #ef4444;color:#ef4444;border-radius:6px;cursor:pointer}.pending-invites.error-state button:hover{background:#ef44441a}.pending-invites h3{margin:0 0 1rem;font-size:1.1rem;color:#fbbf24}.invite-card{background:#1a211d;border:1px solid #2d3a32;border-radius:12px;padding:1.25rem;margin-bottom:1rem}.invite-card:last-child{margin-bottom:0}.invite-header{margin-bottom:.75rem}.invite-from{color:#e8f0eb;font-size:.95rem}.invite-body{margin-bottom:1rem}.invite-description{color:#a3b8a8;margin:0 0 .5rem;font-size:.9rem}.invite-date{color:#6b7c6f;margin:0 0 .5rem;font-size:.85rem}.invite-stakes{display:flex;flex-direction:column;gap:.25rem;margin:.75rem 0;padding:.75rem;background:#0d1210;border-radius:8px;font-size:.85rem;color:#a3b8a8}.invite-expires{color:#6b7c6f;margin:0;font-size:.8rem}.invite-actions{display:flex;gap:.75rem}.btn-decline{flex:1;padding:.625rem;background:transparent;border:1px solid #2d3a32;color:#a3b8a8;border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .2s}.btn-decline:hover{border-color:#ef4444;color:#ef4444}.btn-accept{flex:2;padding:.625rem;background:#4ade80;border:none;color:#0a0f0d;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-accept:hover:not(:disabled){background:#22c55e}.btn-accept:disabled{opacity:.6;cursor:not-allowed}.dashboard{padding-bottom:3rem}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.dashboard-header h1{font-size:1.75rem;font-weight:600;color:var(--color-text-primary)}.time-range-selector{display:flex;gap:.5rem;background:var(--color-bg-secondary);padding:.25rem;border-radius:var(--radius-md)}.range-btn{background:transparent;border:none;color:var(--color-text-muted);padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;transition:all .2s}.range-btn:hover{color:var(--color-text-secondary)}.range-btn.active{background:var(--color-accent);color:var(--color-bg-primary);font-weight:500}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}.loading-state{display:flex;justify-content:center;align-items:center;height:50vh;font-size:1.125rem;color:var(--color-text-muted)}@media (max-width: 768px){.dashboard-header{flex-direction:column;align-items:flex-start}.time-range-selector{width:100%;overflow-x:auto}}.notification-bell{position:relative}.bell-button{background:transparent;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;position:relative;transition:transform .2s}.bell-button:hover{transform:scale(1.1)}.badge{position:absolute;top:0;right:0;background:#ef4444;color:#fff;font-size:.7rem;font-weight:700;padding:.1rem .4rem;border-radius:10px;min-width:18px;text-align:center}.notification-dropdown{position:absolute;top:100%;right:0;width:360px;max-height:480px;background:#1a211d;border:1px solid #2d3a32;border-radius:12px;box-shadow:0 8px 32px #0006;z-index:1000;overflow:hidden}.dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #2d3a32}.dropdown-header h3{margin:0;font-size:1rem;color:#e8f0eb}.mark-all-read{background:transparent;border:none;color:#4ade80;font-size:.85rem;cursor:pointer;padding:.25rem .5rem}.mark-all-read:hover{text-decoration:underline}.notification-list{max-height:400px;overflow-y:auto}.no-notifications{padding:2rem;text-align:center;color:#6b7c6f}.notification-item{display:flex;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid #2d3a32;cursor:pointer;transition:all .2s;position:relative;align-items:flex-start}.notification-item:hover{background:#232b27}.notification-item.clickable:hover{background:#4ade801a}.notification-item.unread{background:#4ade800d}.notification-item.unread:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:#4ade80}.notification-arrow{color:#6b7c6f;font-size:1rem;margin-left:auto;flex-shrink:0;align-self:center;transition:transform .2s,color .2s}.notification-item:hover .notification-arrow{color:#4ade80;transform:translate(3px)}.notification-icon{font-size:1.5rem;flex-shrink:0}.notification-content{flex:1;min-width:0}.notification-title{font-weight:500;color:#e8f0eb;margin-bottom:.25rem}.notification-message{font-size:.85rem;color:#a3b8a8;margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notification-time{font-size:.75rem;color:#6b7c6f}.layout{min-height:100vh;display:flex;flex-direction:column}.header{background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);padding:1rem 0;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-content{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:center}.logo{display:flex;align-items:center;gap:.75rem;color:var(--color-accent);font-size:1.5rem;font-weight:600}.logo a{display:flex;align-items:center;gap:.75rem;color:inherit;text-decoration:none}.nav{display:flex;align-items:center;gap:1rem}.nav-link{color:var(--color-text-secondary);text-decoration:none;padding:.5rem .75rem;border-radius:var(--radius-md);font-size:.9rem;transition:all .2s}.nav-link:hover{color:var(--color-text);background:var(--color-bg-tertiary)}.nav-link.active{color:var(--color-accent);background:var(--color-accent-muted)}.user-info{display:flex;align-items:center;gap:.75rem}.username{color:var(--color-text-secondary);font-weight:500}.unit-badge{background:var(--color-accent-muted);color:var(--color-accent);padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;font-family:var(--font-mono)}.btn-logout{background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary);padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.875rem;transition:all .2s}.btn-logout:hover{border-color:var(--color-error);color:var(--color-error)}.main{flex:1;padding:2rem 0}.keeper-dashboard{padding:2rem;max-width:1400px;margin:0 auto}.keeper-header{margin-bottom:2rem}.keeper-header h1{font-size:1.75rem;color:#e8f0eb;margin:0}.keeper-content{display:grid;grid-template-columns:280px 1fr;gap:2rem}.goal-list{background:#1a211d;border:1px solid #2d3a32;border-radius:16px;padding:1.25rem;height:fit-content}.goal-list h2{font-size:.9rem;color:#6b7c6f;text-transform:uppercase;letter-spacing:.5px;margin:0 0 1rem}.goal-item{width:100%;background:#0d1210;border:1px solid #2d3a32;border-radius:10px;padding:1rem;margin-bottom:.75rem;cursor:pointer;text-align:left;transition:all .2s}.goal-item:last-child{margin-bottom:0}.goal-item:hover{border-color:#4ade80}.goal-item.active{border-color:#4ade80;background:#4ade800d}.goal-owner{font-weight:600;color:#4ade80;margin-bottom:.25rem}.goal-desc{font-size:.85rem;color:#a3b8a8;margin-bottom:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.goal-progress-mini{height:4px;background:#2d3a32;border-radius:2px;overflow:hidden}.progress-bar-mini{height:100%;background:#4ade80;transition:width .3s}.goal-detail{display:flex;flex-direction:column;gap:1.5rem}.detail-header{display:flex;justify-content:space-between;align-items:flex-start}.detail-header h2{font-size:1.5rem;color:#e8f0eb;margin:0 0 .25rem}.detail-header .description{color:#a3b8a8;margin:0}.header-actions{display:flex;gap:.75rem}.btn-comments{padding:.5rem 1rem;background:#232b27;border:1px solid #2d3a32;color:#a3b8a8;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s}.btn-comments:hover{background:#2d3a32;color:#e8f0eb}.btn-resign{padding:.5rem 1rem;background:transparent;border:1px solid #ef4444;color:#ef4444;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s}.btn-resign:hover{background:#ef44441a}.stakes-card{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.stake{background:#1a211d;border:1px solid #2d3a32;border-radius:12px;padding:1.25rem;display:flex;gap:1rem;align-items:flex-start}.stake-icon{font-size:1.5rem}.stake-label{font-size:.8rem;color:#6b7c6f;margin-bottom:.25rem}.stake-text{color:#e8f0eb}.stake.reward{border-color:#4ade804d}.stake.penalty{border-color:#fbbf244d}.progress-card{background:#1a211d;border:1px solid #2d3a32;border-radius:16px;padding:2rem;text-align:center}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.status{padding:.35rem .75rem;border-radius:20px;font-size:.85rem;font-weight:500}.status.on-track{background:#4ade8026;color:#4ade80}.status.behind{background:#fbbf2426;color:#fbbf24}.days-left{color:#a3b8a8;font-size:.9rem}.big-percent{font-size:4rem;font-weight:700;color:#4ade80;line-height:1}.percent-label{color:#6b7c6f;font-size:.9rem;margin-bottom:1.5rem}.progress-bar-large{height:12px;background:#2d3a32;border-radius:6px;overflow:hidden;margin-bottom:1.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#4ade80,#22c55e);border-radius:6px;transition:width .5s ease-out}.progress-fill.behind{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.weight-details{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:1.5rem;background:#0d1210;border-radius:12px;margin-bottom:1rem}.weight-item{text-align:center}.weight-item .label{display:block;font-size:.75rem;color:#6b7c6f;text-transform:uppercase;margin-bottom:.25rem}.weight-item .value{font-size:1.1rem;font-weight:600;color:#e8f0eb}.weight-item.highlight .value{color:#4ade80}.date-range{color:#6b7c6f;font-size:.9rem}.weighins-card{background:#1a211d;border:1px solid #2d3a32;border-radius:16px;padding:1.5rem}.weighins-card h3{margin:0 0 1rem;font-size:1rem;color:#e8f0eb}.no-weighins{color:#6b7c6f;text-align:center;padding:2rem}.weighins-list{max-height:300px;overflow-y:auto}.weighin-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#0d1210;border-radius:8px;margin-bottom:.5rem}.weighin-item:last-child{margin-bottom:0}.weighin-date{color:#a3b8a8;font-size:.9rem}.weighin-stats{display:flex;gap:1rem;align-items:center}.weighin-stats .weight{font-weight:600;color:#e8f0eb}.weighin-stats .change{font-size:.85rem;padding:.2rem .5rem;border-radius:4px}.weighin-stats .change.down{background:#4ade8026;color:#4ade80}.weighin-stats .change.up{background:#ef444426;color:#ef4444}.weighin-stats .cumulative{font-size:.8rem;color:#6b7c6f}.empty-state{text-align:center;padding:4rem 2rem;background:#1a211d;border:1px solid #2d3a32;border-radius:16px}.empty-icon{font-size:4rem;display:block;margin-bottom:1rem}.empty-state h2{color:#e8f0eb;margin:0 0 .5rem}.empty-state p{color:#a3b8a8;margin:0}.empty-state .hint{color:#6b7c6f;font-size:.9rem;margin-top:1rem}.loading{text-align:center;padding:4rem;color:#6b7c6f}@media (max-width: 900px){.keeper-content{grid-template-columns:1fr}.goal-list{display:flex;gap:.75rem;overflow-x:auto;padding-bottom:.5rem}.goal-list h2{display:none}.goal-item{min-width:200px;margin-bottom:0}.stakes-card{grid-template-columns:1fr}.weight-details{grid-template-columns:repeat(2,1fr)}}.accept-invite-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#0a0f0d,#1a211d,#0d1210)}.invite-card{background:#1a211d;border:1px solid #2d3a32;border-radius:20px;padding:2.5rem;width:100%;max-width:480px;text-align:center;box-shadow:0 16px 64px #0006}.invite-card.loading,.invite-card.error,.invite-card.success{padding:3rem 2rem}.spinner{width:48px;height:48px;border:3px solid #2d3a32;border-top-color:#4ade80;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}@keyframes spin{to{transform:rotate(360deg)}}.error-icon,.success-icon{font-size:3rem;display:block;margin-bottom:1rem}.invite-icon{font-size:4rem;margin-bottom:1.5rem}.invite-card h1{font-size:1.5rem;color:#e8f0eb;margin:0 0 1rem}.invite-card h2{font-size:1.25rem;color:#e8f0eb;margin:0 0 .75rem}.invite-from{color:#a3b8a8;margin-bottom:2rem;font-size:1.1rem}.invite-from strong{color:#4ade80}.invite-details{background:#0d1210;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;text-align:left}.detail-item{display:flex;flex-direction:column;gap:.25rem;padding:.75rem 0;border-bottom:1px solid #2d3a32}.detail-item:last-child{border-bottom:none}.detail-item .label{font-size:.8rem;color:#6b7c6f;text-transform:uppercase;letter-spacing:.5px}.detail-item .value{color:#e8f0eb;font-size:1rem}.detail-item.reward .value{color:#4ade80}.detail-item.penalty .value{color:#fbbf24}.expires-info{font-size:.85rem;color:#6b7c6f;margin-bottom:1.5rem}.expired-notice{background:#ef44441a;border:1px solid #ef4444;color:#ef4444;padding:1rem;border-radius:8px;margin-top:1rem}.login-notice{background:#fbbf241a;border:1px solid #fbbf24;color:#fbbf24;padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-size:.9rem}.error-message{background:#ef44441a;border:1px solid #ef4444;color:#ef4444;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.invite-actions{display:flex;gap:1rem;margin-top:1.5rem}.invite-actions .btn-secondary{flex:1;padding:1rem;background:transparent;border:1px solid #2d3a32;color:#a3b8a8;border-radius:10px;font-size:1rem;cursor:pointer;transition:all .2s}.invite-actions .btn-secondary:hover:not(:disabled){background:#232b27;color:#e8f0eb}.invite-actions .btn-primary{flex:2;padding:1rem;background:#4ade80;border:none;color:#0a0f0d;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.invite-actions .btn-primary:hover:not(:disabled){background:#22c55e;transform:translateY(-1px)}.invite-actions button:disabled{opacity:.6;cursor:not-allowed}:root{--color-bg-primary: #0a0f0d;--color-bg-secondary: #141a17;--color-bg-tertiary: #1e2622;--color-bg-card: #1a211d;--color-accent: #4ade80;--color-accent-hover: #22c55e;--color-accent-muted: #166534;--color-text-primary: #f0fdf4;--color-text-secondary: #a3b8a8;--color-text-muted: #6b7c6f;--color-border: #2d3a32;--color-border-focus: #4ade80;--color-error: #ef4444;--color-success: #4ade80;--color-warning: #fbbf24;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(74, 222, 128, .15);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-full: 9999px;--font-sans: "Outfit", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px}body{font-family:var(--font-sans);background:var(--color-bg-primary);color:var(--color-text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at 20% 20%,rgba(74,222,128,.03) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(74,222,128,.02) 0%,transparent 50%);pointer-events:none;z-index:-1}#root{min-height:100vh}a{color:var(--color-accent);text-decoration:none;transition:color .2s}a:hover{color:var(--color-accent-hover)}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:fadeIn .4s ease-out forwards}.animate-slide-up{animation:slideUp .5s ease-out forwards}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}
