.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}.forgot-password-link{font-size:.8125rem;color:var(--color-text-muted);text-align:right;margin-top:.25rem;transition:color .2s}.forgot-password-link:hover{color:var(--color-accent)}.auth-card{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);text-align:center}.auth-card h1{font-size:1.5rem;font-weight:600;color:var(--color-text-primary);margin-bottom:1rem}.auth-card form{display:flex;flex-direction:column;gap:1.25rem;text-align:left}.auth-card 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;width:100%}.auth-card input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #4ade801a}.auth-subtitle{color:var(--color-text-muted);font-size:.9375rem;margin-bottom:1.5rem;text-align:left}.auth-button{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;width:100%;margin-top:.5rem}.auth-button:hover:not(:disabled){background:var(--color-accent-hover)}.auth-button:disabled{opacity:.6;cursor:not-allowed}.auth-success-message{color:var(--color-success, var(--color-accent));font-size:.9375rem;padding:1rem;background:#4ade801a;border-radius:var(--radius-md);margin-bottom:1rem}.auth-error-message{color:var(--color-error);font-size:.9375rem;padding:1rem;background:#ef44441a;border-radius:var(--radius-md);margin-bottom:1rem}.auth-info{color:var(--color-text-muted);font-size:.875rem;margin-bottom:1.5rem}.auth-links{display:flex;justify-content:center;gap:.5rem;margin-top:1.5rem;font-size:.875rem}.auth-links a{color:var(--color-accent);font-weight:500}.auth-separator{color:var(--color-text-muted)}.auth-branding{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--color-border);text-align:center;font-size:.8125rem;color:var(--color-text-muted);display:flex;justify-content:center;align-items:center;gap:.75rem;flex-wrap:wrap}.auth-branding a{color:var(--color-text-secondary);transition:color .2s}.auth-branding a:hover{color:var(--color-accent)}.branding-separator{color:var(--color-border)}.developed-by{display:flex;align-items:center;gap:.25rem}.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}.goal-completed-modal{text-align:center;max-width:400px}.celebration-icon,.sad-icon{font-size:4rem;margin-bottom:1rem;animation:bounce .5s ease-out}@keyframes bounce{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.goal-completed-modal h2{color:var(--color-text-primary);margin:0 0 1rem;font-size:1.5rem}.goal-message{color:var(--color-text-secondary);font-size:1rem;margin:0 0 .5rem;line-height:1.5}.goal-message strong{color:var(--color-accent)}.goal-details{color:var(--color-text-muted);font-size:.9rem;margin:0 0 1rem}.encouragement{color:var(--color-text-secondary);font-size:.95rem;font-style:italic;margin:1rem 0;padding:1rem;background:var(--color-bg-tertiary);border-radius:var(--radius-md)}.additional-goals{color:var(--color-text-muted);font-size:.85rem;margin:.5rem 0 1rem}.modal-actions{display:flex;gap:.75rem;justify-content:center;margin-top:1.5rem}.modal-actions .btn-primary{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:500;cursor:pointer;transition:background .2s}.modal-actions .btn-primary:hover{background:var(--color-accent-hover)}.modal-actions .btn-secondary{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border);padding:.75rem 1.5rem;border-radius:var(--radius-md);font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.modal-actions .btn-secondary:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.modal-content{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:2rem;max-width:450px;width:100%;box-shadow:var(--shadow-lg);border:1px solid var(--color-border)}.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)}.nav-link.icon-link{font-size:1.25rem;padding:.4rem .6rem}.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-details.percent-only{grid-template-columns:1fr;text-align:center}.weight-details.percent-only .weight-item .value{font-size:1.5rem;color:#4ade80}.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}.import-export{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-md);border:1px solid var(--color-border)}.import-export-header h3{margin:0 0 1rem;font-size:1.1rem;color:var(--color-text-primary)}.tabs{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:1px solid var(--color-border);padding-bottom:.5rem}.tab{padding:.5rem 1rem;border:none;background:transparent;cursor:pointer;font-size:.9rem;color:var(--color-text-secondary);border-radius:var(--radius-md) var(--radius-md) 0 0;transition:all .2s}.tab:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.tab.active{background:var(--color-accent);color:var(--color-bg-primary)}.tab-content{padding:1rem 0}.description{color:var(--color-text-secondary);font-size:.9rem;margin-bottom:1rem}.import-export .error-message{background:#ef44441a;color:var(--color-error);padding:.75rem 1rem;border-radius:var(--radius-md);margin-bottom:1rem;font-size:.9rem;border:1px solid var(--color-error)}.import-export .success-message{background:var(--color-accent-muted);color:var(--color-accent);padding:.75rem 1rem;border-radius:var(--radius-md);margin-bottom:1rem;font-size:.9rem;border:1px solid var(--color-accent)}.export-btn{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:500;cursor:pointer;transition:background .2s}.export-btn:hover:not(:disabled){background:var(--color-accent-hover)}.export-btn:disabled{background:var(--color-text-muted);cursor:not-allowed}.format-info{margin-top:1.5rem;padding:1rem;background:var(--color-bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--color-border)}.format-info h4{margin:0 0 .5rem;font-size:.9rem;color:var(--color-text-primary)}.format-info code{background:var(--color-bg-secondary);padding:.2rem .5rem;border-radius:var(--radius-sm);font-size:.85rem;color:var(--color-accent);font-family:var(--font-mono)}.format-info p{margin:.5rem 0 0;font-size:.85rem;color:var(--color-text-secondary)}.file-input-wrapper{margin-bottom:1rem}.file-input-wrapper input[type=file]{display:none}.file-label{display:inline-block;padding:.75rem 1.5rem;background:var(--color-bg-tertiary);border:2px dashed var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-size:.9rem;color:var(--color-text-secondary);transition:all .2s}.file-label:hover{border-color:var(--color-accent);background:var(--color-bg-secondary);color:var(--color-text-primary)}.preview-btn{background:var(--color-bg-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border);padding:.5rem 1rem;border-radius:var(--radius-md);cursor:pointer;font-size:.9rem;transition:all .2s}.preview-btn:hover:not(:disabled){background:var(--color-bg-secondary);border-color:var(--color-accent)}.preview-section{margin-top:1rem;padding:1rem;background:var(--color-bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--color-border)}.preview-section h4{margin:0 0 .75rem;font-size:1rem;color:var(--color-text-primary)}.preview-stats{display:flex;gap:1rem;margin-bottom:1rem}.preview-stats .stat{padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.85rem;font-weight:500}.preview-stats .stat.valid{background:var(--color-accent-muted);color:var(--color-accent)}.preview-stats .stat.invalid{background:#ef44441a;color:var(--color-error)}.preview-table{width:100%;border-collapse:collapse;margin-bottom:1rem;font-size:.85rem}.preview-table th,.preview-table td{padding:.5rem;text-align:left;border-bottom:1px solid var(--color-border)}.preview-table th{background:var(--color-bg-secondary);font-weight:600;color:var(--color-text-primary)}.preview-table td{color:var(--color-text-secondary)}.preview-errors{background:#ef44441a;padding:.75rem;border-radius:var(--radius-md);margin-bottom:1rem;border:1px solid var(--color-error)}.preview-errors h5{margin:0 0 .5rem;color:var(--color-error);font-size:.9rem}.preview-errors ul{margin:0;padding-left:1.5rem;font-size:.8rem;color:var(--color-text-secondary)}.preview-errors p{margin:.5rem 0 0;font-size:.8rem;color:var(--color-text-muted)}.import-actions{display:flex;gap:.75rem}.import-btn{background:var(--color-accent);color:var(--color-bg-primary);border:none;padding:.5rem 1rem;border-radius:var(--radius-md);cursor:pointer;font-size:.9rem;font-weight:500;transition:background .2s}.import-btn:hover:not(:disabled){background:var(--color-accent-hover)}.import-btn:disabled{background:var(--color-text-muted);cursor:not-allowed}.cancel-btn{background:transparent;border:1px solid var(--color-border);padding:.5rem 1rem;border-radius:var(--radius-md);cursor:pointer;font-size:.9rem;color:var(--color-text-secondary);transition:all .2s}.cancel-btn:hover{background:var(--color-bg-secondary);border-color:var(--color-text-muted)}.import-result{background:var(--color-accent-muted);padding:1rem;border-radius:var(--radius-md);margin-top:1rem;border:1px solid var(--color-accent)}.import-result h4{margin:0 0 .5rem;color:var(--color-accent)}.import-result p{margin:.25rem 0;font-size:.9rem;color:var(--color-text-primary)}.no-batches{color:var(--color-text-muted);text-align:center;padding:2rem}.batches-list{display:flex;flex-direction:column;gap:.5rem}.batch-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--color-bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--color-border)}.batch-info{display:flex;flex-direction:column;gap:.25rem}.batch-filename{font-weight:500;color:var(--color-text-primary);font-size:.95rem}.batch-count{font-size:.85rem;color:var(--color-accent)}.batch-date{font-size:.8rem;color:var(--color-text-muted)}.delete-batch-btn{background:transparent;border:none;font-size:1.2rem;cursor:pointer;padding:.5rem;border-radius:var(--radius-md);transition:background .2s}.delete-batch-btn:hover:not(:disabled){background:#ef44441a}.delete-batch-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 480px){.tabs{flex-wrap:wrap}.tab{flex:1;text-align:center;padding:.5rem;font-size:.8rem}.batch-item{flex-direction:column;align-items:flex-start;gap:.5rem}.delete-batch-btn{align-self:flex-end}}.settings-page{padding:2rem 1rem;max-width:800px;margin:0 auto}.settings-page h1{margin-bottom:2rem;font-size:1.75rem;color:var(--color-text-primary)}.settings-section{margin-bottom:2rem}.settings-section h2{font-size:1.1rem;color:var(--color-text-secondary);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.settings-card{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-md);border:1px solid var(--color-border)}.setting-item{margin-bottom:1.5rem}.setting-item:last-child{margin-bottom:0}.setting-item>label{display:block;font-weight:500;margin-bottom:.5rem;color:var(--color-text-primary)}.setting-item input[type=text],.setting-item input[type=email]{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;background:var(--color-bg-tertiary);color:var(--color-text-primary);transition:border-color .2s}.setting-item input[type=text]:focus,.setting-item input[type=email]:focus{outline:none;border-color:var(--color-accent)}.setting-item input.disabled{background:var(--color-bg-secondary);color:var(--color-text-muted);cursor:not-allowed}.help-text{display:block;font-size:.8rem;color:var(--color-text-muted);margin-top:.25rem}.radio-group{display:flex;gap:1.5rem}.radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:400;color:var(--color-text-primary)}.radio-label input[type=radio]{width:18px;height:18px;accent-color:var(--color-accent)}.message{padding:.75rem 1rem;border-radius:var(--radius-md);margin-bottom:1rem;font-size:.9rem}.message.success{background:var(--color-accent-muted);color:var(--color-accent);border:1px solid var(--color-accent)}.message.error{background:#ef44441a;color:var(--color-error);border:1px solid var(--color-error)}.save-btn{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:500;cursor:pointer;transition:background .2s;margin-top:1rem}.save-btn:hover:not(:disabled){background:var(--color-accent-hover)}.save-btn:disabled{background:var(--color-text-muted);cursor:not-allowed}.muted{color:var(--color-text-muted);font-size:.9rem;margin:0}.danger-zone h2{color:var(--color-error)}.danger-card{border-color:var(--color-error)}.danger-item{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--color-border)}.danger-item:last-child{border-bottom:none;padding-bottom:0}.danger-item:first-child{padding-top:0}.danger-info h3{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin:0 0 .25rem}.danger-info p{font-size:.875rem;color:var(--color-text-muted);margin:0}.btn-danger{background:transparent;color:var(--color-error);border:1px solid var(--color-error);padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-danger:hover:not(:disabled){background:var(--color-error);color:#fff}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.modal-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}.modal-content{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:1.5rem;max-width:450px;width:100%;box-shadow:var(--shadow-lg);border:1px solid var(--color-border)}.danger-modal h2{color:var(--color-error);margin:0 0 1rem;font-size:1.25rem}.warning-text{color:var(--color-text-secondary);font-size:.9rem;margin:0 0 .75rem;line-height:1.5}.warning-text strong{color:var(--color-error)}.confirm-instruction{color:var(--color-text-primary);font-size:.9rem;margin:1rem 0 .5rem}.confirm-instruction code{background:var(--color-bg-tertiary);padding:.125rem .375rem;border-radius:var(--radius-sm);font-family:monospace;color:var(--color-error)}.confirm-input{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;background:var(--color-bg-tertiary);color:var(--color-text-primary);margin-bottom:1rem}.confirm-input:focus{outline:none;border-color:var(--color-error)}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.btn-secondary{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border);padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}@media (max-width: 600px){.settings-page{padding:1rem}.radio-group{flex-direction:column;gap:.75rem}.danger-item{flex-direction:column;align-items:flex-start}.danger-item .btn-danger{width:100%;margin-top:.5rem}}: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)}
