*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0f13;--bg-card:#1a1a22;--bg-card-hover:#21212c;--bg-modal:#1e1e28;--border:#ffffff12;--text:#f0f0f4;--text-muted:#7b7b8f;--text-dim:#4a4a5f;--success:#43d9ad;--fail:#ff6584;--accent:#6c63ff;--radius:16px;--radius-sm:10px;font-size:16px}html,body,#root{background:var(--bg);height:100%;color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif}button{cursor:pointer;font:inherit;color:inherit;background:0 0;border:none}textarea,input{font:inherit;color:inherit}a{color:inherit;text-decoration:none}.app{flex-direction:column;max-width:480px;min-height:100vh;margin:0 auto;display:flex;position:relative}.page{flex:1;padding:0 0 5rem;overflow-y:auto}.home-header{justify-content:space-between;align-items:center;padding:3.5rem 1.5rem 1.5rem;display:flex}.app-title{letter-spacing:-.03em;background:linear-gradient(135deg, var(--text) 0%, var(--text-muted) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.75rem;font-weight:800}.app-subtitle{color:var(--text-muted);margin-top:.2rem;font-size:.85rem}.btn-add{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 4px 20px #6c63ff66}.btn-add:hover,.btn-add:active{transform:scale(.95);box-shadow:0 2px 10px #6c63ff4d}.challenge-list{flex-direction:column;gap:.75rem;padding:.5rem 1.25rem;display:flex}.challenge-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);border-left:3px solid var(--accent);text-align:left;justify-content:space-between;align-items:center;gap:1rem;width:100%;padding:1.1rem 1.25rem;transition:background .15s,transform .15s;display:flex}.challenge-card:hover,.challenge-card:active{background:var(--bg-card-hover);transform:translateY(-1px)}.card-left{align-items:center;gap:.85rem;min-width:0;display:flex}.card-emoji{flex-shrink:0;font-size:1.75rem}.card-info{flex-direction:column;gap:.2rem;min-width:0;display:flex}.card-name{white-space:nowrap;text-overflow:ellipsis;font-size:1rem;font-weight:600;overflow:hidden}.card-stats{color:var(--text-muted);font-size:.75rem}.card-right{flex-shrink:0;align-items:center;gap:.6rem;display:flex}.streak-display{align-items:center;gap:.2rem;display:flex}.streak-fire{font-size:1rem}.streak-num{font-size:1.2rem;font-weight:800}.badge{letter-spacing:.02em;border-radius:99px;padding:.2rem .55rem;font-size:.7rem;font-weight:700}.badge-pending{color:var(--text-muted);background:#ffffff14}.badge-success{color:var(--success);background:#43d9ad26}.badge-fail{color:var(--fail);background:#ff658426}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:.75rem;padding:4rem 2rem;display:flex}.empty-icon{margin-bottom:.5rem;font-size:3.5rem}.empty-state h2{font-size:1.3rem;font-weight:700}.empty-state p{color:var(--text-muted);max-width:280px;font-size:.9rem;line-height:1.5}.detail-header{align-items:center;gap:.75rem;padding:3rem 1.25rem 1rem;display:flex}.btn-back{background:var(--bg-card);width:40px;height:40px;color:var(--text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s;display:flex}.btn-back:hover{background:var(--bg-card-hover);color:var(--text)}.detail-title-wrap{flex:1;align-items:center;gap:.6rem;min-width:0;display:flex}.detail-emoji{font-size:1.6rem}.detail-title{white-space:nowrap;text-overflow:ellipsis;font-size:1.3rem;font-weight:800;overflow:hidden}.btn-delete{color:var(--text-dim)}.btn-delete:hover{color:var(--fail)}.btn-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;transition:background .15s,color .15s;display:flex}.detail-desc{color:var(--text-muted);padding:0 1.25rem .5rem;font-size:.875rem;line-height:1.5}.stats-row{grid-template-columns:repeat(3,1fr);gap:.75rem;padding:.75rem 1.25rem 1.25rem;display:grid}.stat-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;flex-direction:column;align-items:center;gap:.25rem;padding:.9rem .75rem;display:flex}.stat-box--highlight{border-color:color-mix(in srgb, var(--accent) 40%, transparent);background:color-mix(in srgb, var(--accent) 8%, transparent)}.stat-val{font-size:1.4rem;font-weight:800}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.68rem;font-weight:500}.milestone-progress{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);margin:0 1.25rem 1.25rem;padding:.9rem 1rem}.milestone-progress-header{color:var(--text-muted);justify-content:space-between;margin-bottom:.6rem;font-size:.8rem;font-weight:500;display:flex}.milestone-progress-frac{color:var(--text);font-weight:700}.milestone-bar{background:#ffffff12;border-radius:99px;height:6px;overflow:hidden}.milestone-bar-fill{background:var(--accent);border-radius:99px;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.6rem;font-size:.72rem;font-weight:700}.checkin-section{margin:0 1.25rem 1.25rem}.checkin-buttons{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.btn-checkin{border-radius:var(--radius-sm);border:2px solid #0000;justify-content:center;align-items:center;gap:.4rem;padding:.9rem;font-size:.95rem;font-weight:700;transition:transform .15s,opacity .15s;display:flex}.btn-checkin:active{transform:scale(.97)}.btn-success{color:var(--success);background:#43d9ad1a;border-color:#43d9ad40}.btn-success:hover{background:#43d9ad2e}.btn-fail{color:var(--fail);background:#ff65841a;border-color:#ff658440}.btn-fail:hover{background:#ff65842e}.checkin-result{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:.5rem;padding:1rem;display:flex}.checkin-status{font-size:1rem;font-weight:700}.checkin-status.success{color:var(--success)}.checkin-status.fail{color:var(--fail)}.checkin-note{color:var(--text-muted);font-size:.85rem;font-style:italic;line-height:1.4}.btn-undo{color:var(--text-dim);align-self:flex-start;font-size:.78rem;text-decoration:underline}.btn-undo:hover{color:var(--text-muted)}.calendar-section{margin:0 1.25rem 1.25rem}.calendar-nav{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.calendar-month-label{font-size:.95rem;font-weight:700}.btn-cal-nav{background:var(--bg-card);width:32px;height:32px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;transition:background .15s,color .15s;display:flex}.btn-cal-nav:hover:not(:disabled){background:var(--bg-card-hover);color:var(--text)}.btn-cal-nav:disabled{opacity:.3;cursor:default}.cal-weekdays{grid-template-columns:repeat(7,1fr);margin-bottom:.35rem;display:grid}.cal-weekday{text-align:center;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;padding:.2rem 0;font-size:.65rem;font-weight:700}.cal-grid{grid-template-columns:repeat(7,1fr);gap:3px;display:grid}.cal-cell{aspect-ratio:1;background:var(--bg-card);border-radius:8px;justify-content:center;align-items:center;display:flex;position:relative}.cal-day-num{color:var(--text-muted);font-size:.75rem;font-weight:500}.cal-empty{background:0 0}.cal-future .cal-day-num{color:var(--text-dim)}.cal-future{background:0 0}.cal-today{border:1.5px solid var(--accent)}.cal-today .cal-day-num{color:var(--accent);font-weight:700}.cal-success{background:#43d9ad26}.cal-success .cal-day-num{color:var(--success);font-weight:700}.cal-fail{background:#ff65841f}.cal-fail .cal-day-num{color:var(--fail);font-weight:700}.cal-note-dot{background:var(--accent);border-radius:50%;width:4px;height:4px;position:absolute;bottom:3px;left:50%;transform:translate(-50%)}.achievements-section{margin:0 1.25rem 1.25rem}.achievements-grid{flex-wrap:wrap;gap:.6rem;display:flex}.achievement-badge{background:var(--bg-card);border:1px solid color-mix(in srgb, var(--accent) 25%, transparent);border-radius:99px;align-items:center;gap:.4rem;padding:.35rem .75rem .35rem .5rem;display:flex}.achievement-emoji{font-size:1rem}.achievement-label{color:var(--text-muted);font-size:.75rem;font-weight:600}.detail-footer{color:var(--text-dim);text-align:center;padding:0 1.25rem 2rem;font-size:.75rem}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding-bottom:env(safe-area-inset-bottom,0);background:#000000b3;justify-content:center;align-items:flex-end;animation:.15s fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-modal);border-radius:var(--radius) var(--radius) 0 0;padding:1.5rem 1.5rem calc(1.5rem + env(safe-area-inset-bottom,0));width:100%;max-width:480px;max-height:90vh;animation:.2s cubic-bezier(.4,0,.2,1) slide-up;overflow-y:auto}@keyframes slide-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal h3{margin-bottom:1rem;font-size:1.1rem;font-weight:700}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.modal-header h2{font-size:1.25rem;font-weight:800}.modal-new{border-radius:var(--radius);align-self:center;max-width:420px}.modal-buttons{gap:.75rem;margin-top:1.25rem;display:flex}.field-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-top:1.1rem;margin-bottom:.5rem;font-size:.75rem;font-weight:700;display:block}.field-label:first-child{margin-top:0}.optional{text-transform:none;letter-spacing:0;opacity:.6;font-weight:400}.field-error{color:var(--fail);margin-top:.35rem;font-size:.8rem}.text-input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);resize:none;background:#ffffff0d;outline:none;padding:.75rem .9rem;font-size:.95rem;transition:border-color .15s}.text-input:focus{border-color:var(--accent)}.text-input::placeholder{color:var(--text-dim)}.note-input{resize:none}.emoji-grid{flex-wrap:wrap;gap:.4rem;margin-bottom:.25rem;display:flex}.emoji-btn{border-radius:var(--radius-sm);background:#ffffff0a;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.4rem;transition:background .12s,transform .1s;display:flex}.emoji-btn:hover{background:#ffffff1a;transform:scale(1.1)}.emoji-btn--selected{outline:2px solid var(--accent);outline-offset:1px;background:#6c63ff33}.color-grid{flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem;display:flex}.color-btn{border-radius:50%;width:32px;height:32px;transition:transform .12s}.color-btn:hover{transform:scale(1.15)}.color-btn--selected{outline-offset:2px;outline:3px solid #fff;transform:scale(1.1)}.challenge-preview{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius-sm);align-items:center;gap:.75rem;margin:1rem 0 1.25rem;padding:.85rem 1rem;display:flex}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius-sm);padding:.8rem 1.5rem;font-size:.95rem;font-weight:700;transition:opacity .15s,transform .15s}.btn-primary:hover{opacity:.9}.btn-primary:active{transform:scale(.98)}.btn-full{width:100%}.btn-secondary{color:var(--text-muted);border-radius:var(--radius-sm);background:#ffffff12;flex:1;padding:.8rem 1.5rem;font-size:.95rem;font-weight:600;transition:background .15s}.btn-secondary:hover{background:#ffffff1a}.btn-danger{color:var(--fail);border-radius:var(--radius-sm);background:#ff658426;border:1px solid #ff658440;flex:1;padding:.8rem 1.5rem;font-size:.95rem;font-weight:700;transition:background .15s}.btn-danger:hover{background:#ff658440}.milestone-toast{color:#fff;border-radius:var(--radius);z-index:200;cursor:pointer;background:linear-gradient(135deg,#6c63ff,#a78bfa);align-items:center;gap:.85rem;max-width:calc(100vw - 2rem);padding:.9rem 1.25rem;animation:.3s cubic-bezier(.4,0,.2,1) toast-in;display:flex;position:fixed;top:1.5rem;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #6c63ff80}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(-20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.milestone-toast-emoji{font-size:2rem}.milestone-toast-title{text-transform:uppercase;letter-spacing:.1em;opacity:.85;font-size:.72rem;font-weight:700}.milestone-toast-label{font-size:1rem;font-weight:800}.notif-banner{background:linear-gradient(135deg,#6c63ff2e 0%,#6c63ff14 100%);border-bottom:1px solid #6c63ff40;align-items:center;gap:.75rem;padding:.85rem 1rem;display:flex}.notif-banner-icon{flex-shrink:0;font-size:1.4rem}.notif-banner-text{flex-direction:column;flex:1;gap:.1rem;min-width:0;display:flex}.notif-banner-text strong{font-size:.875rem;font-weight:700}.notif-banner-text span{color:var(--text-muted);font-size:.78rem}.notif-banner-actions{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.notif-btn-enable{background:var(--accent);color:#fff;border-radius:99px;padding:.35rem .85rem;font-size:.8rem;font-weight:700}.notif-btn-dismiss{width:28px;height:28px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;font-size:.8rem;display:flex}.notif-btn-dismiss:hover{background:var(--bg-card-hover)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}
