*{box-sizing:border-box;margin:0;padding:0}:root{--cream: #FAF3DD;--parchment: #F5EDD8;--parchment-deep: #F0E4C2;--bark: #6F4E37;--forest: #3A5F3A;--forest-deep: #2A4528;--moss: #5B8C3E;--moss-deep: #3F6529;--gold: #D4A437;--gold-deep: #A07F25;--berry: #B33951;--berry-soft: #F5DCDC;--berry-shadow: #D9B3B3;--ink: #2A2418;--rope: #C9B383;--bg-from: #FAF3DD;--bg-to: #F0E4C2;--shadow-tone: rgba(110, 78, 55, .35)}:root[data-theme=night]{--cream: #2A3850;--parchment: #1a2942;--parchment-deep: #0f1a2e;--bark: #c9b89a;--forest: #a8d4a0;--forest-deep: #6f9c6a;--moss: #7ba87f;--moss-deep: #4a7350;--gold: #e6b04a;--gold-deep: #b8821f;--berry: #e07a8f;--berry-soft: #4a2a30;--berry-shadow: #2a1a20;--ink: #f5e8d0;--rope: #4a3826;--bg-from: #1a2942;--bg-to: #0a1426;--shadow-tone: rgba(0, 0, 0, .6)}html,body{min-height:100vh;font-family:Nunito,system-ui,-apple-system,sans-serif;color:var(--ink);background:radial-gradient(ellipse at top,var(--bg-from) 0%,var(--bg-to) 100%);overflow-x:hidden;transition:background .6s ease,color .4s ease}.card,.modal,.goal-bar,.class-tab,.reports-controls,.reason-chips,.animal-grid,.class-emoji-grid,.delta-toggle,.modal-input,.history-entry,.backup-block,.report-card,.btn{transition:background-color .4s ease,color .4s ease,border-color .4s ease}.font-hand{font-family:Patrick Hand,cursive}.bg-decor{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background-image:radial-gradient(circle at 20% 30%,rgba(110,78,55,.05) 0,transparent 40%),radial-gradient(circle at 80% 70%,rgba(58,95,58,.05) 0,transparent 40%),radial-gradient(circle at 50% 90%,rgba(212,164,55,.04) 0,transparent 40%)}.bg-decor span{position:absolute;opacity:.18;font-size:4rem;animation:leafSway 4s ease-in-out infinite}.bg-decor span:nth-child(1){top:2rem;left:1.5rem;animation-delay:0s}.bg-decor span:nth-child(2){top:8rem;right:3rem;font-size:3rem;animation-delay:1s}.bg-decor span:nth-child(3){bottom:5rem;left:4rem;font-size:5rem;animation-delay:2s}.bg-decor span:nth-child(4){bottom:10rem;right:6rem;animation-delay:.5s}.bg-decor span:nth-child(5){top:50%;left:33%;font-size:2.5rem;animation-delay:1.5s;opacity:.1}[data-theme=night] .bg-decor span{animation-name:starTwinkle}[data-theme=night] .bg-decor .day-leaf{display:none}[data-theme=night] .bg-decor .night-star{display:inline}.bg-decor .night-star{display:none}.ambient-layer{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.ambient-layer .drift{position:absolute;top:-3rem;opacity:0;animation:driftFall linear forwards;will-change:transform,opacity;-webkit-user-select:none;user-select:none}[data-theme=night] .ambient-layer .drift{filter:drop-shadow(0 0 8px rgba(255,230,150,.7))}@keyframes driftFall{0%{transform:translate(0) rotate(0);opacity:0}10%{opacity:.65}50%{transform:translate(var(--drift, 0),50vh) rotate(180deg)}90%{opacity:.65}to{transform:translate(calc(var(--drift, 0) * 2),110vh) rotate(360deg);opacity:0}}@keyframes starTwinkle{0%,to{opacity:.18;transform:scale(1)}50%{opacity:.35;transform:scale(1.1)}}.container{position:relative;z-index:1;max-width:80rem;margin:0 auto;padding:0 1.5rem}[hidden]{display:none!important}header{padding:2rem 0 1rem}.header-inner{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:1rem}.title{font-family:Patrick Hand,cursive;font-size:clamp(2.5rem,5vw,3.75rem);color:var(--forest);line-height:1;font-weight:400}.subtitle{font-family:Patrick Hand,cursive;font-size:1.4rem;color:var(--bark);margin-top:.25rem}.header-actions{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center}.icon-btn{width:2.75rem;height:2.75rem;padding:0;justify-content:center;font-size:1.1rem}.divider{margin-top:1rem;height:4px;border-radius:999px;background:linear-gradient(to right,transparent,var(--rope),transparent)}.class-tabs{display:flex;gap:.4rem;overflow-x:auto;padding:1rem 0 .6rem;margin-bottom:.5rem;scrollbar-width:thin;scrollbar-color:var(--rope) transparent}.class-tabs::-webkit-scrollbar{height:6px}.class-tabs::-webkit-scrollbar-thumb{background:var(--rope);border-radius:999px}.class-tab{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .95rem;border:2px solid var(--rope);background:linear-gradient(180deg,var(--cream) 0%,color-mix(in srgb,var(--cream) 80%,var(--rope)) 100%);border-radius:999px;cursor:pointer;font-family:Patrick Hand,cursive;font-size:1.15rem;color:var(--bark);white-space:nowrap;flex-shrink:0;transition:all .2s ease;box-shadow:0 2px 0 var(--rope)}.class-tab:nth-of-type(odd):not(.active){transform:rotate(-1deg)}.class-tab:nth-of-type(2n):not(.active){transform:rotate(1.2deg)}.class-tab:hover{background:#d4a4372e;border-color:var(--gold);transform:rotate(0) translateY(-1px)}.class-tab.active{background:linear-gradient(180deg,var(--forest) 0%,var(--forest-deep) 100%);color:#fff;border-color:var(--forest-deep);box-shadow:0 3px 0 var(--forest-deep);transform:rotate(0)}.class-tab .tab-emoji{font-size:1.1rem}.class-tab .tab-edit{margin-left:.2rem;padding-left:.4rem;border-left:1px solid rgba(255,255,255,.35);opacity:.85;font-size:.95rem}.class-tab .tab-edit:hover{opacity:1}.class-tab.add-tab{border-style:dashed;background:transparent;color:var(--bark)}.class-tab.add-tab:hover{background:#5b8c3e1a;color:var(--forest);border-color:var(--moss)}.btn{font-family:Patrick Hand,cursive;font-size:1.25rem;border:none;border-radius:1rem;padding:.7rem 1.1rem;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;transition:transform .1s ease,opacity .15s;-webkit-user-select:none;user-select:none;line-height:1}.btn:active{transform:translateY(2px)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--forest);color:#fff;box-shadow:0 4px 0 var(--forest-deep)}.btn-secondary{background:var(--cream);color:var(--bark);border:2px solid var(--rope)}.btn-danger{background:var(--berry);color:#fff;box-shadow:0 4px #8a2a3d}.btn-gold{background:var(--gold);color:#fff;box-shadow:0 4px 0 var(--gold-deep)}.empty-state{text-align:center;max-width:28rem;margin:4rem auto 0;padding:0 1rem;animation:pop .3s ease-out}.empty-icon{font-size:6rem;margin-bottom:1rem}.empty-grove{margin:0 auto 1.25rem;height:8rem;position:relative;-webkit-user-select:none;user-select:none;pointer-events:none}.empty-grove .grove-trees{display:flex;justify-content:center;align-items:flex-end;gap:.4rem;line-height:1}.empty-grove .grove-trees span{animation:gentleSway 4s ease-in-out infinite;transform-origin:bottom center}.empty-grove .grove-trees span:nth-child(1){font-size:2.5rem;animation-delay:0s}.empty-grove .grove-trees span:nth-child(2){font-size:4rem;animation-delay:.5s}.empty-grove .grove-trees span:nth-child(3){font-size:3rem;animation-delay:1s}.empty-grove .grove-trees span:nth-child(4){font-size:3.5rem;animation-delay:1.5s}.empty-grove .grove-trees span:nth-child(5){font-size:2.5rem;animation-delay:2s}.empty-grove .grove-floor{position:absolute;bottom:-.25rem;left:50%;transform:translate(-50%);display:flex;gap:1.4rem;font-size:1.4rem}.empty-grove .grove-creature{position:absolute;bottom:0;left:30%;font-size:1.6rem;animation:peek 6s ease-in-out infinite}@keyframes gentleSway{0%,to{transform:rotate(-2deg)}50%{transform:rotate(2deg)}}@keyframes peek{0%,80%,to{transform:translateY(0);opacity:.85}40%,60%{transform:translateY(-6px);opacity:1}}.empty-state h2{font-family:Patrick Hand,cursive;font-size:2.25rem;color:var(--forest);margin-bottom:.75rem;font-weight:400}.empty-state p{font-size:1.125rem;color:var(--bark)}.goal-bar{background:var(--cream);border:3px solid var(--rope);border-radius:1rem;padding:.6rem 1rem;margin-bottom:1.25rem;display:flex;align-items:center;gap:1rem}.goal-bar .goal-label{font-family:Patrick Hand,cursive;color:var(--forest);font-size:1.1rem;white-space:nowrap}.goal-bar .goal-track{flex:1;height:.85rem;background:#fff;border:1px solid var(--rope);border-radius:999px;overflow:hidden}.goal-bar .goal-fill{height:100%;background:linear-gradient(to right,var(--moss),var(--gold));border-radius:999px;transition:width .4s ease-out}.goal-bar .goal-fill.over{background:linear-gradient(to right,var(--gold),var(--berry))}.goal-bar .goal-text{font-family:Patrick Hand,cursive;color:var(--bark);font-size:1.05rem;white-space:nowrap}.grid{display:grid;grid-template-columns:1fr;gap:1.25rem;padding-bottom:4rem}@media (min-width: 640px){.grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 768px){.grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1024px){.grid{grid-template-columns:repeat(4,1fr)}}.card{position:relative;background:var(--cream);border:3px solid var(--rope);border-radius:1.5rem;padding:1.25rem;box-shadow:0 6px 0 var(--rope),0 14px 24px -8px #6e4e3759;animation:pop .3s ease-out}.card.wobble{animation:wobble .4s ease-in-out}.corner-btn{position:absolute;top:.55rem;width:2rem;height:2rem;border:none;background:transparent;border-radius:999px;cursor:pointer;color:var(--bark);font-size:1rem;display:flex;align-items:center;justify-content:center;transition:background-color .15s}.corner-btn:hover{background:#d4a43733}.corner-btn-left{left:.55rem}.corner-btn-right{right:.55rem}.history-badge{position:absolute;top:-2px;right:-2px;min-width:1rem;height:1rem;padding:0 4px;background:var(--gold);color:#fff;border-radius:999px;font-size:.65rem;font-weight:800;display:flex;align-items:center;justify-content:center;line-height:1}.animal-display{font-size:4.5rem;text-align:center;line-height:1;margin-bottom:.25rem;-webkit-user-select:none;user-select:none}.name-display{font-family:Patrick Hand,cursive;font-size:1.875rem;text-align:center;color:var(--forest);line-height:1.1;word-break:break-word}.points-display{position:relative;margin:.75rem 0;display:flex;align-items:center;justify-content:center;gap:.5rem}.points-number{font-family:Patrick Hand,cursive;font-size:3rem;font-variant-numeric:tabular-nums;line-height:1}.points-positive{color:var(--forest)}.points-negative{color:var(--berry)}.points-neutral{color:var(--bark)}.leaf-deco{font-size:1.25rem;opacity:.7}.float-anim{position:absolute;left:50%;top:50%;transform:translate(-50%);font-family:Patrick Hand,cursive;font-size:2rem;pointer-events:none;animation:floatUp 1.1s ease-out forwards}.point-buttons{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:.5rem}.point-btn{position:relative;border:none;border-radius:1rem;padding:1rem;font-size:1.75rem;font-weight:800;cursor:pointer;transition:transform .1s ease;-webkit-user-select:none;user-select:none;overflow:hidden}.point-btn:active{transform:translateY(2px)}.point-btn:before{position:absolute;font-size:1.1rem;opacity:.55;pointer-events:none;top:.25rem;left:.4rem;transition:transform .2s ease}.point-btn:hover:before{transform:rotate(15deg) scale(1.15)}.point-btn-add:before{content:"🌰"}.point-btn-sub:before{content:"🍂"}.point-btn-add{background:var(--moss);color:#fff;box-shadow:0 3px 0 var(--moss-deep)}.point-btn-sub{background:var(--berry-soft);color:var(--berry);box-shadow:0 3px 0 var(--berry-shadow)}.note-btn{width:100%;border:2px dashed var(--rope);background:transparent;color:var(--bark);font-family:Patrick Hand,cursive;font-size:1.05rem;border-radius:.85rem;padding:.5rem;cursor:pointer;transition:all .15s}.note-btn:hover{background:#d4a43726;border-color:var(--gold);color:var(--forest)}.findbar{display:flex;gap:.6rem;align-items:center;margin-bottom:1.25rem;flex-wrap:wrap}.findbar .search-wrap{position:relative;flex:1;min-width:12rem}.findbar .search-wrap:before{content:"🔍";position:absolute;left:.85rem;top:50%;transform:translateY(-50%);font-size:1rem;opacity:.65;pointer-events:none}.findbar .search-input{width:100%;padding:.55rem .85rem .55rem 2.4rem;border-radius:999px;font-family:Patrick Hand,cursive;font-size:1.1rem;background:var(--cream);border:2px solid var(--rope);color:var(--ink);outline:none;transition:box-shadow .15s,border-color .15s}.findbar .search-input:focus{box-shadow:0 0 0 4px #5b8c3e38;border-color:var(--moss)}.findbar .search-clear{position:absolute;right:.4rem;top:50%;transform:translateY(-50%);width:1.6rem;height:1.6rem;border:none;background:transparent;border-radius:999px;cursor:pointer;color:var(--bark);font-size:1rem;display:flex;align-items:center;justify-content:center;opacity:.7}.findbar .search-clear:hover{background:#d4a43733;opacity:1}.findbar .sort-select{font-family:Patrick Hand,cursive;font-size:1.1rem;padding:.5rem .85rem;border:2px solid var(--rope);border-radius:999px;background:var(--cream);color:var(--bark);cursor:pointer;outline:none;transition:border-color .15s}.findbar .sort-select:focus{border-color:var(--moss)}.findbar .sort-select:hover{border-color:var(--gold)}.empty-search{text-align:center;padding:3rem 1rem;color:var(--bark)}.empty-search .icon{font-size:3rem;margin-bottom:.5rem;opacity:.7}.empty-search .text{font-family:Patrick Hand,cursive;font-size:1.4rem;color:var(--forest)}.danger-block{margin-top:1rem;padding:1rem 1.1rem;background:#b339510f;border:2px dashed color-mix(in srgb,var(--berry) 50%,var(--rope));border-radius:1rem}.danger-block h3{font-family:Patrick Hand,cursive;font-size:1.2rem;color:var(--berry);margin-bottom:.4rem;font-weight:400;display:flex;align-items:center;gap:.5rem}.danger-block p{color:var(--bark);font-size:.9rem;margin-bottom:.65rem;line-height:1.4}.danger-block .btn{width:100%;justify-content:center}.today-summary{margin-bottom:1.25rem;padding:1rem 1.25rem;background:var(--cream);border:3px solid var(--rope);border-radius:1.25rem;text-align:center;font-family:Patrick Hand,cursive}.today-summary .big{font-size:2.25rem;color:var(--forest);line-height:1}.today-summary .label{color:var(--bark);font-size:1.1rem;margin-top:.2rem}.today-stat-row{display:flex;justify-content:center;gap:1.5rem;margin-top:.75rem;flex-wrap:wrap}.today-stat-row .pill{background:#fff;border:2px solid var(--rope);border-radius:999px;padding:.3rem .85rem;font-size:1rem;color:var(--bark)}.today-stat-row .pill.pos{color:var(--forest-deep);border-color:var(--moss)}.today-stat-row .pill.neg{color:var(--berry);border-color:var(--berry-shadow)}.today-section{margin-bottom:1.5rem}.today-section h2{font-family:Patrick Hand,cursive;font-size:1.6rem;color:var(--forest);margin-bottom:.75rem;font-weight:400;display:flex;align-items:center;gap:.5rem}.today-section.struggles h2{color:var(--berry)}.standout-card{display:grid;grid-template-columns:3rem 1fr auto;gap:.75rem;align-items:center;background:var(--cream);border:2px solid var(--rope);border-radius:1rem;padding:.75rem 1rem;margin-bottom:.5rem}.standout-card .animal{font-size:2rem;line-height:1}.standout-card .name{font-family:Patrick Hand,cursive;font-size:1.4rem;color:var(--forest)}.standout-card .reasons{font-size:.9rem;color:var(--bark);margin-top:.15rem;line-height:1.35}.standout-card .delta-pill{font-family:Patrick Hand,cursive;font-size:1.4rem;font-weight:700;padding:.3rem .8rem;border-radius:999px}.standout-card .delta-pill.pos{background:#5b8c3e2e;color:var(--forest-deep)}.standout-card .delta-pill.neg{background:var(--berry-soft);color:var(--berry)}.today-empty{text-align:center;padding:1.25rem;color:var(--bark);font-style:italic;background:#fff6;border:2px dashed var(--rope);border-radius:1rem}.today-quiet{text-align:center;padding:4rem 1rem}.today-quiet .icon{font-size:4rem;margin-bottom:.75rem}.today-quiet h2{font-family:Patrick Hand,cursive;font-size:2rem;color:var(--forest);margin-bottom:.5rem;font-weight:400}.today-quiet p{color:var(--bark)}.welcome-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:1rem;background:#2a24188c;overflow-y:auto;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.welcome-card{background:var(--cream);border:3px solid var(--rope);border-radius:1.5rem;max-width:38rem;width:100%;max-height:calc(100vh - 2rem);overflow-y:auto;position:relative;animation:pop .4s cubic-bezier(.34,1.56,.64,1);box-shadow:0 25px 60px -15px #2a241880,inset 0 0 0 1px #d4a4372e;background-image:radial-gradient(ellipse at top left,rgba(212,164,55,.08) 0%,transparent 50%),radial-gradient(ellipse at bottom right,rgba(110,78,55,.06) 0%,transparent 50%)}.welcome-card:before,.welcome-card:after{content:"";position:absolute;left:.5rem;right:.5rem;height:.45rem;background:linear-gradient(180deg,var(--rope) 0%,color-mix(in srgb,var(--rope) 60%,var(--bark)) 100%);border-radius:999px;pointer-events:none;box-shadow:inset 0 1px #ffffff40}.welcome-card:before{top:.4rem}.welcome-card:after{bottom:.4rem}.welcome-body{padding:2.5rem 2rem 2rem}@media (max-width: 480px){.welcome-body{padding:2rem 1.25rem 1.5rem}}.welcome-hero{text-align:center;margin-bottom:1.25rem}.welcome-grove{height:6rem;margin:0 auto .75rem;position:relative;-webkit-user-select:none;user-select:none}.welcome-grove .trees{display:flex;justify-content:center;align-items:flex-end;gap:.5rem;line-height:1}.welcome-grove .trees span{animation:gentleSway 4s ease-in-out infinite;transform-origin:bottom center}.welcome-grove .trees span:nth-child(1){font-size:2rem;animation-delay:0s}.welcome-grove .trees span:nth-child(2){font-size:3rem;animation-delay:.6s}.welcome-grove .trees span:nth-child(3){font-size:4rem;animation-delay:1.2s}.welcome-grove .trees span:nth-child(4){font-size:3rem;animation-delay:1.8s}.welcome-grove .trees span:nth-child(5){font-size:2rem;animation-delay:2.4s}.welcome-grove .floor{position:absolute;bottom:-.25rem;left:50%;transform:translate(-50%);display:flex;gap:1.6rem;font-size:1.2rem}.welcome-title{font-family:Patrick Hand,cursive;font-size:2.5rem;color:var(--forest);margin-bottom:.25rem;line-height:1.05;font-weight:400}.welcome-subtitle{font-family:Patrick Hand,cursive;font-size:1.3rem;color:var(--bark)}.welcome-intro{text-align:center;font-size:1.05rem;line-height:1.55;color:var(--ink);padding:0 .5rem;margin-bottom:1.5rem}.welcome-intro strong{color:var(--forest-deep)}.welcome-tour{background:#fff;border:2px dashed var(--rope);border-radius:1rem;padding:1rem 1.1rem;margin-bottom:1.5rem}.welcome-tour h3{font-family:Patrick Hand,cursive;font-size:1.4rem;color:var(--forest);margin-bottom:.6rem;font-weight:400;text-align:center}.tour-row{display:grid;grid-template-columns:2.5rem 1fr;gap:.75rem;align-items:start;padding:.45rem 0}.tour-row+.tour-row{border-top:1px dotted var(--rope);margin-top:.1rem;padding-top:.55rem}.tour-icon{font-size:1.6rem;line-height:1.2;text-align:center;-webkit-user-select:none;user-select:none}.tour-text{font-size:.95rem;line-height:1.4;color:var(--ink)}.tour-text strong{font-family:Patrick Hand,cursive;font-size:1.1rem;color:var(--forest-deep);font-weight:400}.tour-text .tour-emoji-inline{display:inline-block;padding:0 .2rem}.welcome-footer{text-align:center;font-size:.9rem;color:var(--bark);margin-bottom:1.25rem;font-style:italic;line-height:1.45}.welcome-actions{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap}.welcome-actions .btn{font-size:1.3rem;padding:.85rem 1.5rem}.card.tree-card{padding:0;overflow:hidden;display:flex;flex-direction:column}.tree-scene{position:relative;height:14rem;overflow:hidden;background:linear-gradient(180deg,#b7dce6,#c8e5eb 45%,#8baa6e 65%,#6e8c58)}[data-theme=night] .tree-scene{background:linear-gradient(180deg,#1d2b4a,#2a3a5e 45%,#2c3a26 65%,#1a2418)}[data-season=spring] .tree-scene{background:linear-gradient(180deg,#dce9f0,#f5dce5 45%,#95b570 65%,#6e8c58)}[data-season=summer] .tree-scene{background:linear-gradient(180deg,#b0daea,#dceeaf 45%,#7fb05f 65%,#5c8a45)}[data-season=winter] .tree-scene{background:linear-gradient(180deg,#c9d8e8,#e5eaf0 45%,#dce3db 65%,#b5c4b0)}.tree-scene:before{content:"";position:absolute;top:.6rem;right:.8rem;width:1.5rem;height:1.5rem;border-radius:50%;background:radial-gradient(circle,#FFE89A 0%,#FFD66B 60%,transparent 70%);opacity:.85}[data-theme=night] .tree-scene:before{background:radial-gradient(circle,#F0EDD0 0%,#C9C2A0 60%,transparent 70%);box-shadow:0 0 20px #f0edd099}.tree-glyph{position:absolute;bottom:1.2rem;left:50%;transform-origin:bottom center;transform:translate(-50%) scale(var(--tree-scale, 1));font-size:4rem;line-height:1;transition:transform .6s cubic-bezier(.34,1.56,.64,1),font-size .4s ease;-webkit-user-select:none;user-select:none;filter:drop-shadow(0 4px 6px rgba(0,0,0,.15))}.tree-glyph.wilted{transform:translate(-50%) scale(var(--tree-scale, .7)) rotate(-6deg);filter:drop-shadow(0 4px 6px rgba(0,0,0,.15)) saturate(.5) brightness(.85)}.tree-extras{position:absolute;bottom:5.5rem;left:50%;transform:translate(-50%);display:flex;gap:.5rem;pointer-events:none}.tree-extras span{animation:floatBob 3s ease-in-out infinite;font-size:1.2rem}.tree-extras span:nth-child(2){animation-delay:.5s}.tree-extras span:nth-child(3){animation-delay:1s}.tree-extras span:nth-child(4){animation-delay:1.5s}.tree-extras span:nth-child(5){animation-delay:2s}@keyframes floatBob{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.tree-animal{position:absolute;bottom:.4rem;left:18%;font-size:2rem;-webkit-user-select:none;user-select:none;filter:drop-shadow(0 2px 3px rgba(0,0,0,.25))}.tree-name{font-family:Patrick Hand,cursive;font-size:1.5rem;text-align:center;color:var(--forest);padding:.6rem .5rem .2rem;word-break:break-word;line-height:1.1}.tree-card .points-display{margin:.2rem 0 .6rem}.tree-card .points-number{font-size:2.25rem}.tree-card .point-buttons,.tree-card .note-btn{margin-left:.85rem;margin-right:.85rem}.tree-card .note-btn{margin-bottom:.85rem}.tree-card .corner-btn{background:#ffffffb3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.tree-card .corner-btn:hover{background:#fffffff2}[data-theme=night] .tree-card .corner-btn{background:#14141e99;color:var(--ink)}.weather-layer{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.raindrop{position:absolute;top:-2rem;width:1px;height:20px;background:linear-gradient(180deg,transparent 0%,rgba(110,150,180,.5) 100%);animation:rainFall linear forwards;will-change:transform}@keyframes rainFall{0%{transform:translateY(0);opacity:0}10%{opacity:.6}90%{opacity:.6}to{transform:translateY(110vh);opacity:0}}.sunbeam{position:absolute;top:-10vh;width:4px;height:50vh;background:linear-gradient(180deg,rgba(255,230,140,.18) 0%,transparent 100%);transform-origin:top center;transform:rotate(15deg);animation:sunbeamShimmer 6s ease-in-out infinite;will-change:opacity}@keyframes sunbeamShimmer{0%,to{opacity:.5}50%{opacity:.85}}.snowflake{position:absolute;top:-2rem;color:#ffffffd9;animation:snowFall linear forwards;will-change:transform;-webkit-user-select:none;user-select:none}[data-theme=night] .snowflake{color:#dce6f5b3}@keyframes snowFall{0%{transform:translate(0) rotate(0);opacity:0}10%{opacity:.85}50%{transform:translate(var(--sway, 30px),50vh) rotate(180deg)}90%{opacity:.85}to{transform:translate(calc(var(--sway, 30px) * -.5),110vh) rotate(360deg);opacity:0}}.creature-layer{position:fixed;bottom:0;left:0;right:0;height:4rem;pointer-events:none;z-index:2;overflow:hidden}.wandering-creature{position:absolute;bottom:.5rem;font-size:2.5rem;line-height:1;-webkit-user-select:none;user-select:none;will-change:transform;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.creature-rtl{animation:wanderRTL linear forwards}.creature-ltr{animation:wanderLTR linear forwards}@keyframes wanderRTL{0%{transform:translate(110vw) scaleX(-1)}to{transform:translate(-10vw) scaleX(-1)}}@keyframes wanderLTR{0%{transform:translate(-10vw)}to{transform:translate(110vw)}}.firefly-cluster{position:absolute;pointer-events:none;top:0;right:0;bottom:0;left:0;overflow:visible}.firefly{position:absolute;width:6px;height:6px;border-radius:50%;background:radial-gradient(circle,rgba(255,240,150,1) 0%,rgba(255,220,100,.6) 50%,transparent 70%);box-shadow:0 0 8px #ffe682e6;animation:fireflyDrift 4s ease-in-out infinite;opacity:0}@keyframes fireflyDrift{0%,to{opacity:0;transform:translate(0)}20%,80%{opacity:1}25%{transform:translate(8px,-10px)}50%{transform:translate(-6px,-16px)}75%{transform:translate(10px,-8px)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:1rem;background:#2a241880;overflow-y:auto}.modal{background:var(--cream);border:3px solid var(--rope);border-radius:1.5rem;max-width:32rem;width:100%;overflow:hidden;animation:pop .3s ease-out;max-height:calc(100vh - 2rem);display:flex;flex-direction:column;position:relative;box-shadow:0 20px 50px -12px #2a241873,inset 0 0 0 1px #d4a43726;background-image:radial-gradient(ellipse at top left,rgba(212,164,55,.06) 0%,transparent 50%),radial-gradient(ellipse at bottom right,rgba(110,78,55,.05) 0%,transparent 50%)}.modal:before,.modal:after{content:"";position:absolute;left:.5rem;right:.5rem;height:.4rem;background:linear-gradient(180deg,var(--rope) 0%,color-mix(in srgb,var(--rope) 60%,var(--bark)) 100%);border-radius:999px;pointer-events:none;box-shadow:inset 0 1px #ffffff40}.modal:before{top:.4rem}.modal:after{bottom:.4rem}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.5rem 1rem;border-bottom:2px dashed var(--rope);flex-shrink:0}.modal-body{padding:1.5rem 1.5rem 1.75rem;overflow-y:auto}.modal-header h2{font-family:Patrick Hand,cursive;font-size:1.875rem;color:var(--forest);font-weight:400;display:flex;align-items:center;gap:.5rem}.modal-close{width:2.25rem;height:2.25rem;border:none;background:transparent;border-radius:999px;cursor:pointer;color:var(--bark);font-size:1.25rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.modal-close:hover{background:#d4a43733}.modal-label{font-family:Patrick Hand,cursive;font-size:1.25rem;color:var(--forest);display:block;margin-bottom:.5rem}.modal-label+.modal-label{margin-top:1.25rem}.modal-input{width:100%;padding:.75rem 1rem;border-radius:1rem;font-family:Patrick Hand,cursive;font-size:1.25rem;background:#fff;border:2px solid var(--rope);color:var(--ink);outline:none;transition:box-shadow .15s}.modal-input:focus{box-shadow:0 0 0 4px #5b8c3e40}.modal-help{font-size:.9rem;color:var(--bark);margin-top:.4rem}.modal-help.error{color:var(--berry)}.modal-help.success{color:var(--moss-deep)}.animal-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:.25rem;padding:.5rem;border-radius:1rem;background:#fff;border:2px solid var(--rope)}.animal-pick{aspect-ratio:1;font-size:1.75rem;border:none;background:transparent;border-radius:.75rem;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.animal-pick.selected{background:#d4e7c5;outline:2px solid var(--moss);transform:scale(1.1)}.modal-actions{display:flex;gap:.75rem;margin-top:1.5rem}.modal-actions .btn-primary{flex:1;justify-content:center}.btn-remove{background:var(--berry-soft);color:var(--berry);border:2px solid var(--berry-shadow)}.reset-modal{text-align:center;padding:2rem}.reset-modal .icon{font-size:4rem;margin-bottom:.75rem}.reset-modal h2{font-family:Patrick Hand,cursive;font-size:1.875rem;color:var(--forest);margin-bottom:.5rem;font-weight:400}.reset-modal p{color:var(--bark);margin-bottom:1.5rem}.reset-modal .modal-actions .btn{flex:1;justify-content:center}.delta-toggle{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;background:#fff;border:2px solid var(--rope);border-radius:1rem;padding:.3rem}.delta-opt{border:none;background:transparent;font-family:Patrick Hand,cursive;font-size:1.25rem;padding:.6rem;border-radius:.7rem;cursor:pointer;color:var(--bark);transition:all .15s}.delta-opt.active-add{background:var(--moss);color:#fff}.delta-opt.active-sub{background:var(--berry);color:#fff}.reason-chips{display:flex;flex-wrap:wrap;gap:.4rem;padding:.6rem;background:#fff;border:2px solid var(--rope);border-radius:1rem}.reason-chip{border:2px solid var(--rope);background:var(--cream);font-family:Nunito,sans-serif;font-weight:600;font-size:.95rem;padding:.4rem .75rem;border-radius:999px;cursor:pointer;color:var(--bark);transition:all .15s}.reason-chip:hover{border-color:var(--moss);color:var(--forest);transform:translateY(-1px)}.reason-chip.selected{background:var(--moss);color:#fff;border-color:var(--moss)}.history-summary{text-align:center;padding:.75rem 0 1rem;border-bottom:2px dashed var(--rope);margin-bottom:1rem}.history-summary .animal{font-size:3.5rem;line-height:1}.history-summary .name{font-family:Patrick Hand,cursive;font-size:1.75rem;color:var(--forest)}.history-summary .total{font-family:Patrick Hand,cursive;font-size:1.25rem;color:var(--bark);margin-top:.25rem}.history-list{display:flex;flex-direction:column;gap:.5rem;max-height:50vh;overflow-y:auto;padding-right:.25rem}.history-entry{display:flex;align-items:center;gap:.6rem;padding:.6rem .75rem;background:#fff;border:2px solid var(--rope);border-radius:.85rem}.history-delta{font-family:Patrick Hand,cursive;font-size:1.4rem;font-weight:700;min-width:2.2rem;text-align:center}.history-delta.pos{color:var(--forest)}.history-delta.neg{color:var(--berry)}.history-info{flex:1;min-width:0}.history-reason{font-size:.95rem;color:var(--ink);word-break:break-word;cursor:text;padding:.15rem .3rem;border-radius:.35rem;margin-left:-.3rem;transition:background-color .15s}.history-reason:hover{background:#d4a43726}.history-reason.empty{color:#6e4e378c;font-style:italic}.history-reason-edit{width:100%;border:2px solid var(--moss);border-radius:.5rem;padding:.3rem .5rem;font-family:Nunito,sans-serif;font-size:.95rem;outline:none}.history-time{font-size:.78rem;color:var(--bark);margin-top:.15rem}.history-delete{background:transparent;border:none;color:var(--bark);cursor:pointer;padding:.3rem;border-radius:999px;font-size:1.1rem;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.history-delete:hover{background:var(--berry-soft);color:var(--berry)}.empty-history{text-align:center;padding:2rem 1rem;color:var(--bark);font-style:italic}.class-emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:.3rem;padding:.5rem;border-radius:1rem;background:#fff;border:2px solid var(--rope)}.class-emoji-pick{aspect-ratio:1;font-size:1.5rem;border:none;background:transparent;border-radius:.75rem;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.class-emoji-pick.selected{background:#d4e7c5;outline:2px solid var(--moss);transform:scale(1.1)}.backup-block{background:#fff;border:2px solid var(--rope);border-radius:1rem;padding:1rem 1.1rem}.backup-block+.backup-block{margin-top:.75rem}.backup-block h3{font-family:Patrick Hand,cursive;font-size:1.4rem;color:var(--forest);margin-bottom:.4rem;font-weight:400;display:flex;align-items:center;gap:.5rem}.backup-block p{color:var(--bark);font-size:.95rem;margin-bottom:.75rem;line-height:1.45}.backup-block .btn{width:100%;justify-content:center}.backup-instructions{background:#d4a43721;border-left:4px solid var(--gold);padding:.85rem 1rem;border-radius:.5rem;margin-top:1rem;font-size:.9rem;color:var(--ink);line-height:1.55}.backup-instructions strong{color:var(--forest)}#backup-file-input{display:none}.reports-controls{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;margin:1rem 0 1.5rem;padding:1rem;background:var(--cream);border:3px solid var(--rope);border-radius:1.25rem}.reports-controls label{font-family:Patrick Hand,cursive;color:var(--forest);font-size:1.1rem}.reports-controls select{font-family:Patrick Hand,cursive;font-size:1.05rem;padding:.4rem .7rem;border:2px solid var(--rope);border-radius:.75rem;background:#fff;color:var(--ink);cursor:pointer}.toggle-wrap{display:inline-flex;align-items:center;gap:.4rem;cursor:pointer;font-family:Patrick Hand,cursive;color:var(--forest);font-size:1.1rem;margin-left:auto;padding:.3rem .6rem;border-radius:.6rem;transition:background-color .15s}.toggle-wrap:hover{background:#d4a43726}.toggle-wrap input{width:1.15rem;height:1.15rem;cursor:pointer;accent-color:var(--moss)}.report-card.summary-only .report-head{border-bottom:none;margin-bottom:0;padding-bottom:0}.summary-grid .report-stack{display:grid;grid-template-columns:repeat(auto-fit,minmax(20rem,1fr));gap:.75rem}@media print{.summary-grid .report-stack{grid-template-columns:repeat(2,1fr)!important;gap:.4rem!important}}.report-stack{display:flex;flex-direction:column;gap:1.25rem;padding-bottom:4rem}.report-card{background:var(--cream);border:3px solid var(--rope);border-radius:1.25rem;padding:1.25rem 1.5rem;page-break-inside:avoid}.report-head{display:flex;align-items:center;gap:1rem;padding-bottom:.75rem;border-bottom:2px dashed var(--rope);margin-bottom:.75rem}.report-head .animal{font-size:3rem;line-height:1}.report-head .name{font-family:Patrick Hand,cursive;font-size:2rem;color:var(--forest);flex:1}.report-head .stats{text-align:right;font-family:Patrick Hand,cursive;color:var(--bark)}.report-head .stats .big{font-size:2rem;color:var(--forest);line-height:1}.report-entries{display:flex;flex-direction:column;gap:.4rem}.report-entry{display:grid;grid-template-columns:3rem 1fr auto;gap:.75rem;align-items:center;padding:.4rem 0}.report-entry+.report-entry{border-top:1px dotted var(--rope)}.report-entry .delta{font-family:Patrick Hand,cursive;font-size:1.25rem;font-weight:700;text-align:center}.report-entry .delta.pos{color:var(--forest)}.report-entry .delta.neg{color:var(--berry)}.report-entry .reason{color:var(--ink)}.report-entry .reason.empty{color:#6e4e378c;font-style:italic}.report-entry .when{font-size:.85rem;color:var(--bark);white-space:nowrap}.report-empty-entries{text-align:center;color:var(--bark);font-style:italic;padding:.5rem 0}#celebration-root{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:100;overflow:hidden}.celebration-banner{position:absolute;top:18%;left:50%;transform:translate(-50%);background:var(--cream);border:4px solid var(--gold);border-radius:2rem;padding:1.5rem 2.5rem;text-align:center;box-shadow:0 10px 40px #d4a43780,0 0 0 8px #faf3dd99;animation:bannerPop .5s cubic-bezier(.34,1.56,.64,1) both,bannerFade .5s ease-in 3.6s forwards}.celebration-text{font-family:Patrick Hand,cursive;font-size:clamp(2rem,5vw,3rem);color:var(--forest);line-height:1}.celebration-sub{font-family:Patrick Hand,cursive;font-size:1.4rem;color:var(--bark);margin-top:.4rem}.confetti{position:absolute;top:-3rem;pointer-events:none;animation:confettiFall linear forwards;will-change:transform}@keyframes pop{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}@keyframes floatUp{0%{transform:translate(-50%) scale(.6);opacity:0}20%{opacity:1;transform:translate(-50%,-15px) scale(1.3)}to{transform:translate(-50%,-90px) scale(1);opacity:0}}@keyframes wobble{0%,to{transform:translate(0) rotate(0)}20%{transform:translate(-6px) rotate(-2deg)}40%{transform:translate(6px) rotate(2deg)}60%{transform:translate(-4px) rotate(-1deg)}80%{transform:translate(4px) rotate(1deg)}}@keyframes leafSway{0%,to{transform:rotate(-8deg)}50%{transform:rotate(8deg)}}@keyframes confettiFall{0%{transform:translateY(0) rotate(0);opacity:1}90%{opacity:1}to{transform:translateY(110vh) rotate(720deg);opacity:0}}@keyframes bannerPop{0%{transform:translate(-50%,-30px) scale(.7);opacity:0}to{transform:translate(-50%) scale(1);opacity:1}}@keyframes bannerFade{to{opacity:0;transform:translate(-50%,-20px) scale(.95)}}@media print{body{background:#fff!important}.bg-decor,.header-actions,.reports-controls,.class-tabs,.corner-btn,.point-buttons,.note-btn,.modal-overlay,#celebration-root,.goal-bar,#main-view{display:none!important}.container{max-width:none;padding:0}header{padding:.5rem 0;border-bottom:2px solid var(--rope)}.divider{display:none}.title{font-size:2rem}.subtitle{font-size:1rem}.report-card{border:1px solid #999;box-shadow:none;background:#fff;margin-bottom:.75rem;padding:.75rem 1rem}.report-stack{gap:.5rem}.report-head .name{font-size:1.5rem}.report-head .animal{font-size:2rem}@page{margin:.6in}}.boot-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;font-family:Patrick Hand,cursive;color:var(--forest);font-size:1.5rem}.boot-grove{font-size:3rem;animation:gentleSway 3s ease-in-out infinite}
