:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.stat-bars{display:flex;flex-direction:column;gap:.6rem;width:100%}.stat-bars--compact .stat-bar-row{gap:.25rem}.stat-bar-row{display:flex;align-items:center;gap:.5rem}.stat-bar-label{display:flex;align-items:center;gap:.3rem;min-width:7rem;font-size:.85rem;color:#c4b5fd}.stat-bars--compact .stat-bar-label{min-width:2rem}.stat-icon{font-size:1rem}.stat-name{font-weight:500;letter-spacing:.02em}.stat-bar-track{flex:1;height:8px;background:#1e1b4b44;border-radius:4px;border:1px solid #4c1d9555;overflow:hidden}.stat-bar-fill{height:100%;border-radius:4px;transition:width .8s cubic-bezier(.4,0,.2,1);min-width:2px}.stat-bar-xp{min-width:4.5rem;text-align:right;font-size:.8rem;font-family:monospace;font-weight:600;letter-spacing:.02em}.dashboard h2{margin-bottom:2rem;color:#333}.dashboard h3{margin-top:2rem;margin-bottom:1rem;color:#333}.dashboard-stats{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:2rem}@media(min-width:480px){.dashboard-stats{grid-template-columns:repeat(3,1fr);gap:1rem}}@media(min-width:768px){.dashboard-stats{gap:1.5rem;margin-bottom:3rem}}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;text-align:center}@media(min-width:768px){.stat-card{padding:2rem}}.stat-number{font-size:2rem;font-weight:700;color:#3b82f6;margin-bottom:.5rem}@media(min-width:768px){.stat-number{font-size:3rem}}.stat-label{color:#666;font-size:.9rem}@media(min-width:768px){.stat-label{font-size:1rem}}.habits-section{margin-bottom:3rem}.habits-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:640px){.habits-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media(min-width:768px){.habits-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}}.habit-card{background:#fff;padding:1.25rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;gap:1rem;justify-content:space-between;transition:transform .2s,box-shadow .2s}@media(min-width:640px){.habit-card{flex-direction:row;align-items:center;gap:0}}@media(min-width:768px){.habit-card{padding:1.5rem}}.habit-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.habit-card.completed{opacity:.8}.habit-info h4{margin:0 0 .5rem;color:#333}.habit-info p{margin:0;color:#666;font-size:.9rem}.streak-badge{display:inline-block;background-color:#fef3c7;color:#92400e;padding:.25rem .75rem;border-radius:12px;font-size:.9rem;font-weight:500;margin-top:.5rem}.complete-btn{background-color:#10b981;color:#fff;border:none;padding:.75rem 1.25rem;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background-color .2s;width:100%}@media(min-width:640px){.complete-btn{width:auto}}@media(min-width:768px){.complete-btn{padding:.75rem 1.5rem;font-size:1rem}}.complete-btn:hover{background-color:#059669}.completed-badge{font-size:2rem;color:#10b981}.empty-message{text-align:center;color:#666;padding:2rem}.dragon-preview-banner{background:linear-gradient(135deg,#1e1b4b,#0a0614);border-radius:16px;padding:1rem 1.25rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem;border:1px solid #4c1d9555;box-shadow:0 0 20px #7c3aed22}.dragon-preview-svg{width:90px;height:72px;flex-shrink:0}.dragon-preview-info{flex:1}.dragon-preview-info h4{margin:0 0 .25rem;color:#c4b5fd;font-size:.95rem}.dragon-preview-xp{font-size:.8rem;color:#7c3aed;font-family:monospace;margin-bottom:.5rem}.dragon-preview-link{display:inline-block;font-size:.78rem;color:#a78bca;text-decoration:none;border:1px solid #4c1d95;border-radius:6px;padding:2px 10px;transition:all .2s}.dragon-preview-link:hover{background:#1e1b4b;color:#c4b5fd}.xp-toast{position:fixed;bottom:2rem;right:1.5rem;background:#1e1b4b;border:1px solid #7c3aed;border-radius:12px;padding:.75rem 1.25rem;color:#c4b5fd;font-size:.9rem;z-index:1000;box-shadow:0 0 20px #7c3aed55;animation:toastIn .3s ease}.xp-toast strong{color:#a78bca;display:block;margin-bottom:.25rem}.xp-toast-stat{font-size:.82rem;color:#7c3aed}@keyframes toastIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.timer-modal{text-align:center}.timer-display{font-size:3rem;font-family:monospace;color:#7c3aed;margin:1rem 0;letter-spacing:.05em}.timer-controls{display:flex;gap:.75rem;justify-content:center;margin-bottom:1.5rem}.timer-btn-start{background:#10b981;color:#fff;border:none;padding:.6rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600}.timer-btn-stop{background:#ef4444;color:#fff;border:none;padding:.6rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600}.timer-manual{margin-top:1rem;padding-top:1rem;border-top:1px solid #eee}.timer-manual label{font-size:.9rem;color:#666}.timer-manual input{width:5rem;padding:.4rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;text-align:center;margin:0 .5rem}.habit-list-page h2{margin:0;color:#333}.page-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}@media(min-width:480px){.page-header{flex-direction:row;justify-content:space-between;align-items:center;gap:0}}@media(min-width:768px){.page-header{margin-bottom:2rem}}.empty-state{text-align:center;padding:4rem 2rem;color:#666}.empty-state p{font-size:1.1rem;margin:.5rem 0}.habits-list{display:flex;flex-direction:column;gap:1rem}.habit-item{background:#fff;padding:1.25rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;align-items:center;transition:transform .2s,box-shadow .2s;cursor:pointer}@media(min-width:768px){.habit-item{padding:1.5rem}}.habit-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.habit-item-content{flex:1}.habit-item h3{margin:0 0 .5rem;color:#333}.habit-item p{margin:0;color:#666;font-size:.9rem}.delete-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;opacity:.6;transition:opacity .2s,transform .2s}.delete-btn:hover{opacity:1;transform:scale(1.1)}.modal--wide{max-width:580px;width:95vw}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.form-group--emoji{flex:0 0 auto;min-width:100px}.form-group--name{flex:1}.emoji-input{font-size:1.5rem;width:3rem;text-align:center;padding:.25rem;border:1px solid #ddd;border-radius:8px}.emoji-quick{display:flex;flex-wrap:wrap;gap:4px;margin-top:.4rem}.emoji-btn{background:#f5f5f5;border:1px solid #ddd;border-radius:6px;padding:2px 5px;font-size:1rem;cursor:pointer;transition:background .15s}.emoji-btn.selected{background:#e0e7ff;border-color:#6366f1}.emoji-btn:hover{background:#e0e7ff}.type-toggle{display:flex;gap:.5rem}.type-btn{flex:1;padding:.5rem;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;font-size:.9rem;transition:all .2s}.type-btn.active{border-color:#6366f1;background:#e0e7ff;color:#3730a3;font-weight:600}.range-input{width:100%;accent-color:#6366f1;height:4px;cursor:pointer}.range-labels{display:flex;justify-content:space-between;font-size:.75rem;color:#888;margin-top:.2rem}.stat-slider-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.stat-slider-label{min-width:90px;font-size:.88rem;color:#555}.stat-slider-value{min-width:3rem;text-align:right;font-size:.85rem;font-weight:600;color:#6366f1}.stat-total{font-size:.82rem;font-weight:600;padding:1px 8px;border-radius:12px;background:#f0fdf4;color:#16a34a}.stat-total.exact{background:#ede9fe;color:#7c3aed}.stat-total.over{background:#fef2f2;color:#dc2626}.habit-emoji{margin-right:.4rem}.habit-type-badge{font-size:.7rem;padding:1px 8px;border-radius:10px;margin-left:.5rem;vertical-align:middle;font-weight:500}.habit-type-badge.timer{background:#fff7ed;color:#c2410c;border:1px solid #fed7aa}.habit-stat-dots{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.4rem;font-size:.78rem;color:#888}.habit-detail{max-width:900px;margin:0 auto}.back-btn{background:none;border:none;color:#3b82f6;font-size:1rem;cursor:pointer;padding:.5rem;margin-bottom:1.5rem;transition:opacity .2s}.back-btn:hover{opacity:.7}.habit-header{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:1.5rem}@media(min-width:768px){.habit-header{padding:2rem;margin-bottom:2rem}}.habit-header h2{margin:0 0 .5rem;color:#333;font-size:1.5rem}@media(min-width:768px){.habit-header h2{font-size:2rem}}.habit-header p{margin:0;color:#666}.stats-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:2rem}@media(min-width:480px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:3rem}}.stat-box{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;text-align:center}@media(min-width:768px){.stat-box{padding:2rem}}.stat-icon{font-size:2rem;margin-bottom:.5rem}@media(min-width:768px){.stat-icon{font-size:2.5rem}}.stat-value{font-size:2rem;font-weight:700;color:#3b82f6;margin-bottom:.5rem}@media(min-width:768px){.stat-value{font-size:2.5rem}}.stat-label{color:#666;font-size:.85rem}@media(min-width:768px){.stat-label{font-size:.9rem}}.completions-section{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}@media(min-width:768px){.completions-section{padding:2rem}}.completions-section h3{margin-top:0;margin-bottom:1.5rem;color:#333}.completions-list{display:flex;flex-direction:column;gap:1rem}.completion-item{padding:1rem;background:#f9fafb;border-radius:8px;border-left:3px solid #3B82F6}.completion-date{font-weight:500;color:#333;margin-bottom:.5rem}.completion-note{color:#666;font-size:.95rem;font-style:italic}.empty-message{text-align:center;color:#999;padding:2rem}.goals-page h2{margin:0;color:#333}.goals-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:640px){.goals-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media(min-width:768px){.goals-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}}.goal-card{background:#fff;padding:1.25rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}@media(min-width:768px){.goal-card{padding:1.5rem}}.goal-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.goal-card.completed{background-color:#f0fdf4;border-left-color:#10b981!important}.goal-card.expired{background-color:#fef2f2;border-left-color:#ef4444!important}.goal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.goal-header h3{margin:0;color:#333;flex:1}.goal-description{margin:0 0 1rem;color:#666;font-size:.9rem}.goal-progress{margin-bottom:1rem}.progress-bar{width:100%;height:12px;background-color:#e5e7eb;border-radius:6px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background-color:#3b82f6;transition:width .3s ease}.goal-card.completed .progress-fill{background-color:#10b981}.progress-text{font-size:.9rem;color:#666;font-weight:500}.goal-deadline{font-size:.85rem;color:#999}.goal-card.expired .goal-deadline{color:#ef4444;font-weight:500}.dragon-page{min-height:100vh;background:radial-gradient(ellipse at top,#1e1b4b,#0a0614 60%);color:#e2d9f3;padding:1.5rem;font-family:Segoe UI,system-ui,sans-serif}.dragon-page h2{text-align:center;font-size:1.8rem;color:#a78bca;margin-bottom:.25rem;letter-spacing:.08em;text-shadow:0 0 20px #7c3aed88}.dragon-subtitle{text-align:center;color:#7c3aed;font-size:.95rem;margin-bottom:1.5rem;font-style:italic}.dragon-viewer{max-width:540px;margin:0 auto 2rem;border-radius:16px;border:1px solid #4c1d95;background:#0d0a1e;box-shadow:0 0 40px #7c3aed33,inset 0 0 60px #1e1b4b44;overflow:hidden;aspect-ratio:5/4}.dragon-stats-panel{max-width:540px;margin:0 auto 2rem;background:#0d0a1e99;border:1px solid #4c1d95;border-radius:12px;padding:1.25rem 1.5rem}.dragon-stats-panel h3{color:#a78bca;font-size:1rem;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.1em}.dragon-milestones{max-width:540px;margin:0 auto 2rem}.dragon-milestones h3{color:#a78bca;font-size:1rem;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.1em}.milestone-list{display:flex;flex-wrap:wrap;gap:.5rem}.milestone-badge{padding:.35rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600;background:#2e1065;border:1px solid #7c3aed;color:#c4b5fd;letter-spacing:.03em}.milestone-badge.locked{opacity:.3;border-color:#4c1d95;color:#6d28d9}.dragon-info-bar{max-width:540px;margin:0 auto 1.5rem;display:flex;gap:.75rem;flex-wrap:wrap}.dragon-info-card{flex:1;min-width:120px;background:#0d0a1e99;border:1px solid #4c1d9555;border-radius:10px;padding:.75rem 1rem;text-align:center}.dragon-info-card .info-value{font-size:1.4rem;font-weight:700;color:#a78bca;font-family:monospace}.dragon-info-card .info-label{font-size:.75rem;color:#7c3aed;text-transform:uppercase;letter-spacing:.08em;margin-top:.2rem}.dragon-actions{max-width:540px;margin:0 auto;text-align:center}.btn-recompute{background:transparent;border:1px solid #4c1d95;color:#7c3aed;padding:.5rem 1.25rem;border-radius:8px;font-size:.85rem;cursor:pointer;transition:all .2s}.btn-recompute:hover{background:#1e1b4b;border-color:#7c3aed;color:#c4b5fd}.dragon-loading{text-align:center;padding:4rem;color:#7c3aed;font-size:1.2rem}@keyframes egg-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.03)}}@keyframes breathe{0%,to{transform:scaleX(1) scaleY(1)}50%{transform:scaleX(1.03) scaleY(1.02)}}@keyframes eyeGlow{0%,to{opacity:.7}50%{opacity:1}}@keyframes tailSway{0%,to{transform:rotate(0)}50%{transform:rotate(3deg)}}@keyframes wingFlap{0%,to{transform:scaleY(1)}50%{transform:scaleY(.85)}}@keyframes wingFlapFast{0%,to{transform:scaleY(1)}50%{transform:scaleY(.7)}}@keyframes beardWave{0%,to{transform:translate(0)}50%{transform:translate(3px)}}@keyframes crystalPulse{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.egg-pulse{animation:egg-pulse 3s ease-in-out infinite;transform-origin:250px 210px}.dragon-breathe{animation:breathe 4s ease-in-out infinite;transform-origin:center}.eye-glow{animation:eyeGlow 2.5s ease-in-out infinite}.tail-sway{animation:tailSway 5s ease-in-out infinite;transform-origin:280px 230px}.wing-slow{animation:wingFlap 3s ease-in-out infinite}.wing-fast{animation:wingFlapFast 1.2s ease-in-out infinite}.beard-wave{animation:beardWave 4s ease-in-out infinite;transform-origin:265px 165px}.crystal-pulse{animation:crystalPulse 2s ease-in-out infinite}@keyframes starTwinkle{0%,to{opacity:.3;r:.4}50%{opacity:1;r:1.4}}.star-twinkle{animation:starTwinkle 3s ease-in-out infinite}.dev-panel{max-width:540px;margin:1.5rem auto;border:1px dashed #4c1d95;border-radius:12px;background:#08021488;overflow:hidden}.dev-panel-header{display:flex;justify-content:space-between;align-items:center;padding:.6rem 1rem;cursor:pointer;-webkit-user-select:none;user-select:none;color:#6d28d9;font-size:.82rem;font-family:monospace;letter-spacing:.06em;transition:background .2s}.dev-panel-header:hover{background:#1e1b4b44;color:#a78bca}.dev-panel-body{padding:1rem 1.25rem 1.25rem;border-top:1px dashed #4c1d9555}.dev-xp-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem 1rem;margin-bottom:1rem}.dev-xp-row{display:flex;flex-direction:column;gap:.2rem}.dev-xp-row label{font-size:.78rem;color:#7c3aed;font-family:monospace;letter-spacing:.04em}.dev-xp-input{background:#1e1b4b;border:1px solid #4c1d95;border-radius:6px;color:#c4b5fd;padding:.3rem .6rem;font-size:.9rem;font-family:monospace;width:100%}.dev-xp-input:focus{outline:none;border-color:#7c3aed}.dev-preset-row{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1rem}.dev-preset-btn{background:#1e1b4b;border:1px solid #4c1d95;border-radius:6px;color:#7c3aed;padding:.25rem .75rem;font-size:.75rem;cursor:pointer;font-family:monospace;transition:all .15s}.dev-preset-btn:hover{background:#2e1065;color:#c4b5fd;border-color:#7c3aed}.dev-submit-row{display:flex;align-items:center;gap:.75rem}.btn-dev-submit{background:#4c1d95;border:none;border-radius:8px;color:#e9d5ff;padding:.5rem 1.25rem;font-size:.85rem;font-family:monospace;cursor:pointer;transition:background .2s;letter-spacing:.04em}.btn-dev-submit:hover{background:#6d28d9}.dev-feedback{font-size:.8rem;color:#10b981;font-family:monospace;animation:toastIn .3s ease}*{box-sizing:border-box}.app{min-height:100vh;background-color:#f5f5f5}.navbar{background-color:#fff;box-shadow:0 2px 4px #0000001a;padding:1rem 0;margin-bottom:2rem}.nav-container{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center}.app-title{margin:0;font-size:1.3rem;color:#3b82f6}.nav-links{display:flex;gap:.5rem;flex-wrap:wrap}.nav-link{text-decoration:none;color:#333;font-weight:500;padding:.5rem .75rem;border-radius:6px;transition:background-color .2s;font-size:.9rem}.nav-link:hover{background-color:#f0f0f0}.nav-link.active{background-color:#e0e7ff;color:#3730a3}.nav-link--dragon{color:#7c3aed;font-weight:600}.nav-link--dragon:hover{background-color:#ede9fe}.nav-link--dragon.active{background-color:#1e1b4b;color:#c4b5fd}@media(min-width:768px){.nav-container{padding:0 2rem}.app-title{font-size:1.8rem}.nav-links{gap:1.5rem}.nav-link{padding:.5rem 1rem;font-size:1rem}}.main-content{max-width:1200px;margin:0 auto;padding:0 1rem 2rem}@media(min-width:768px){.main-content{padding:0 2rem 2rem}}.loading{text-align:center;padding:3rem;font-size:1.2rem;color:#666}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;padding:1.5rem;border-radius:12px;max-width:500px;width:95%;max-height:90vh;overflow-y:auto}@media(min-width:768px){.modal{padding:2rem;width:90%}}.modal h3{margin-top:0;margin-bottom:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;font-family:inherit}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#3b82f6}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:2rem;flex-direction:column}@media(min-width:480px){.modal-actions{flex-direction:row;gap:1rem}}.btn-primary,.btn-secondary{padding:.75rem 1.25rem;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}@media(min-width:768px){.btn-primary,.btn-secondary{padding:.75rem 1.5rem;font-size:1rem}}.btn-primary{background-color:#3b82f6;color:#fff}.btn-primary:hover{background-color:#2563eb}.btn-primary:disabled{background-color:#93c5fd;cursor:not-allowed}.btn-secondary{background-color:#f3f4f6;color:#333}.btn-secondary:hover{background-color:#e5e7eb}.color-picker{display:flex;gap:.5rem}.color-option{width:40px;height:40px;border-radius:6px;cursor:pointer;border:3px solid transparent;transition:transform .2s}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:#333}
