*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:#0f172a;color:#e2e8f0;min-height:100vh}.container{max-width:1100px;margin:0 auto;padding:2rem 1rem}.header{text-align:center;margin-bottom:2.5rem}.header h1{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,#6366f1,#8b5cf6,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.header p{color:#94a3b8;font-size:1rem}.add-habit-form{background:#1e293b;border-radius:16px;padding:1.5rem;margin-bottom:2rem;border:1px solid #334155}.add-habit-form h2{font-size:1.1rem;font-weight:600;margin-bottom:1rem;color:#cbd5e1}.form-row{display:flex;gap:.75rem;flex-wrap:wrap}.form-input{flex:1 1;min-width:200px;padding:.65rem 1rem;border-radius:10px;border:1px solid #334155;background:#0f172a;color:#e2e8f0;font-size:.95rem;outline:none;transition:border-color .2s}.form-input:focus{border-color:#6366f1}.form-input::placeholder{color:#475569}.color-select{padding:.65rem 1rem;border-radius:10px;border:1px solid #334155;background:#0f172a;color:#e2e8f0;outline:none}.btn-primary,.color-select{font-size:.95rem;cursor:pointer}.btn-primary{padding:.65rem 1.5rem;border-radius:10px;border:none;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-weight:600;transition:opacity .2s,transform .1s;white-space:nowrap}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.habits-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));grid-gap:1.25rem;gap:1.25rem;margin-bottom:2.5rem}.habit-card{background:#1e293b;border-radius:16px;padding:1.25rem;border:1px solid #334155;transition:transform .2s,box-shadow .2s}.habit-card:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,.3)}.habit-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.habit-title-row{display:flex;align-items:center;gap:.6rem}.habit-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.habit-name{font-size:1rem;font-weight:600;color:#f1f5f9}.habit-actions{display:flex;gap:.4rem}.btn-icon{background:none;border:none;cursor:pointer;padding:.3rem;border-radius:6px;color:#64748b;transition:color .2s,background .2s;font-size:1rem;line-height:1}.btn-icon:hover{color:#e2e8f0;background:#334155}.btn-icon.danger:hover{color:#f87171;background:hsla(0,91%,71%,.1)}.streak-row{gap:1rem;margin-bottom:1rem}.streak-badge,.streak-row{display:flex;align-items:center}.streak-badge{gap:.3rem;padding:.3rem .75rem;border-radius:20px;font-size:.85rem;font-weight:700;background:rgba(251,191,36,.15);color:#fbbf24;border:1px solid rgba(251,191,36,.3)}.streak-badge .fire{font-size:1rem}.completion-rate{font-size:.8rem;color:#64748b}.week-dots{display:flex;gap:.4rem;margin-bottom:1rem}.week-dot-wrapper{display:flex;flex-direction:column;align-items:center;gap:.3rem}.week-dot-label{font-size:.65rem;color:#475569;text-transform:uppercase}.week-dot{width:28px;height:28px;border-radius:8px;cursor:pointer;transition:transform .15s,opacity .15s;border:2px solid transparent}.week-dot:hover{transform:scale(1.15)}.week-dot.completed{opacity:1}.week-dot.not-completed{background:#1e293b!important;border-color:#334155;opacity:.7}.week-dot.today{border-color:#6366f1}.check-btn{width:100%;padding:.6rem;border-radius:10px;border:1px dashed #334155;background:transparent;color:#64748b;font-size:.85rem;cursor:pointer;transition:all .2s}.check-btn:hover{border-color:#6366f1;color:#6366f1;background:rgba(99,102,241,.05)}.check-btn.checked{background:rgba(99,102,241,.1);border-color:#6366f1;color:#818cf8;border-style:solid}.chart-section{background:#1e293b;border-radius:16px;padding:1.5rem;border:1px solid #334155;margin-bottom:2rem}.chart-section h2{font-size:1.1rem;font-weight:600;color:#cbd5e1;margin-bottom:1.25rem}.chart-wrapper{width:100%;height:260px}.empty-state{text-align:center;padding:3rem 1rem;color:#475569}.empty-state .emoji{font-size:3rem;margin-bottom:1rem}.empty-state p{font-size:1rem}.stats-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:2rem}.stat-card{background:#1e293b;border-radius:12px;padding:1rem 1.25rem;border:1px solid #334155;text-align:center}.stat-value{font-size:2rem;font-weight:800;color:#818cf8;line-height:1;margin-bottom:.3rem}.stat-label{font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal{background:#1e293b;border-radius:16px;padding:1.5rem;width:100%;max-width:400px;border:1px solid #334155}.modal h3{font-size:1.1rem;font-weight:600;margin-bottom:1rem;color:#f1f5f9}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}.btn-secondary{padding:.6rem 1.25rem;border-radius:10px;border:1px solid #334155;background:transparent;color:#94a3b8;font-size:.9rem;cursor:pointer;transition:background .2s}.btn-secondary:hover{background:#334155}.btn-danger{padding:.6rem 1.25rem;border-radius:10px;border:none;background:#ef4444;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-danger:hover{opacity:.85}