*{box-sizing:border-box}:root{font-family:Hiragino Sans,Hiragino Kaku Gothic ProN,Noto Sans JP,system-ui,sans-serif;line-height:1.5;font-weight:400;color:#333;background-color:#f5f5f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}button,input,select,textarea{font-family:inherit}@media(max-width:480px){html{font-size:15px}}@media(min-width:481px)and (max-width:768px){html{font-size:16px}}@media(min-width:769px){#root{max-width:480px;margin:0 auto;box-shadow:0 0 30px #0000001a}}.task-list{padding:0 1rem;display:flex;flex-direction:column;gap:.75rem}.task-list-empty{text-align:center;padding:2rem;color:#888}.task-list-empty p{margin:.5rem 0}.task-list-empty .hint{font-size:.9rem;color:#aaa}.task-item{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:1rem 1.25rem;border-radius:16px;box-shadow:0 2px 8px #00000014;transition:all .3s ease}.task-item.completed{background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.task-info{display:flex;flex-direction:column;gap:.25rem}.task-category{font-size:.75rem;color:#888;background:#f0f0f0;padding:.15rem .5rem;border-radius:8px;width:fit-content}.task-name{font-size:1.15rem;font-weight:600;color:#333}.stamp-button{width:70px;height:70px;border-radius:50%;border:none;background:linear-gradient(145deg,#ffb347,#ff8c42);color:#fff;font-size:.8rem;font-weight:700;cursor:pointer;box-shadow:0 4px 12px #ff8c4266;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.stamp-button:hover:not(:disabled){transform:scale(1.05);box-shadow:0 6px 16px #ff8c4280}.stamp-button:active:not(:disabled){transform:scale(.95)}.stamp-button.stamped{background:linear-gradient(145deg,#81c784,#4caf50);box-shadow:0 4px 12px #4caf5066;cursor:default}.stamp-text{text-align:center;line-height:1.3}.stamp-done{font-size:2rem}.timeslot-stamps{display:flex;gap:.5rem}.timeslot-stamp-button{width:50px;height:50px;border-radius:50%;border:none;background:linear-gradient(145deg,#ffb347,#ff8c42);color:#fff;font-size:.85rem;font-weight:700;cursor:pointer;box-shadow:0 3px 8px #ff8c424d;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.timeslot-stamp-button:hover:not(:disabled){transform:scale(1.08);box-shadow:0 4px 12px #ff8c4266}.timeslot-stamp-button:active:not(:disabled){transform:scale(.95)}.timeslot-stamp-button.stamped{background:linear-gradient(145deg,#81c784,#4caf50);box-shadow:0 3px 8px #4caf504d;cursor:default}.timeslot-stamp-button .stamp-done{font-size:1.5rem}.slot-label{font-size:.85rem}.calendar-view{background:#fff;margin:0 1rem;border-radius:20px;padding:1rem;box-shadow:0 2px 12px #00000014}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.nav-button{background:none;border:none;font-size:1.2rem;color:#ff8c42;cursor:pointer;padding:.5rem;border-radius:8px;transition:background .2s}.nav-button:hover{background:#fff3e0}.month-year{font-size:1.1rem;font-weight:700;color:#333}.weekday-header{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:.5rem}.weekday{font-size:.85rem;color:#666;padding:.25rem}.weekday.sunday{color:#e57373}.weekday.saturday{color:#64b5f6}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:10px;transition:all .2s;padding:2px}.calendar-day.empty{cursor:default}.calendar-day.clickable{cursor:pointer}.calendar-day.clickable:hover{background:#f5f5f5}.calendar-day.future{cursor:default;opacity:.4}.calendar-day.today{background:#fff3e0;border:2px solid #FF8C42}.calendar-day.has-stamps{background:linear-gradient(135deg,#fffde7,#fff9c4)}.calendar-day.has-stamps.clickable:hover{transform:scale(1.1);box-shadow:0 2px 8px #00000026}.day-number{font-size:.9rem;font-weight:600;color:#333}.stars{font-size:.6rem;line-height:1;margin-top:1px}.date-popup-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.date-popup{background:#fff;border-radius:20px;padding:1.5rem;max-width:320px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.date-popup h4{margin:0 0 .5rem;font-size:1.2rem;color:#333;text-align:center}.popup-subtitle{margin:0 0 1rem;font-size:.9rem;color:#666;text-align:center}.no-stamps-message{margin:1rem 0;font-size:.95rem;color:#888;text-align:center}.stamp-list{list-style:none;padding:0;margin:0 0 1rem}.stamp-list li{padding:.5rem 0;border-bottom:1px solid #eee;font-size:1rem}.stamp-list li:last-child{border-bottom:none}.add-stamp-button{width:100%;padding:.75rem;background:linear-gradient(145deg,#4caf50,#43a047);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;margin-bottom:.5rem}.close-button{width:100%;padding:.75rem;background:linear-gradient(145deg,#ffb347,#ff8c42);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer}.back-to-view-button{width:100%;padding:.75rem;background:#f5f5f5;color:#666;border:none;border-radius:12px;font-size:1rem;font-weight:500;cursor:pointer;margin-top:.5rem}.task-select-list{list-style:none;padding:0;margin:0 0 .5rem}.task-select-item{margin-bottom:.5rem}.task-select-item.timeslot-task{background:#f9f9f9;border-radius:10px;padding:.75rem}.task-select-name{display:block;font-size:.95rem;font-weight:500;color:#333;margin-bottom:.5rem}.timeslot-buttons{display:flex;gap:.5rem}.timeslot-btn{flex:1;padding:.5rem;background:#fff;border:2px solid #ddd;border-radius:8px;font-size:.85rem;cursor:pointer;transition:all .2s}.timeslot-btn:hover:not(:disabled){border-color:#ff8c42;background:#fff3e0}.timeslot-btn.stamped{background:#fff9c4;border-color:#ffd54f;cursor:default}.timeslot-btn:disabled{cursor:default}.task-select-btn{width:100%;padding:.75rem 1rem;background:#fff;border:2px solid #ddd;border-radius:10px;font-size:1rem;text-align:left;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:space-between}.task-select-btn:hover:not(:disabled){border-color:#ff8c42;background:#fff3e0}.task-select-btn.stamped{background:#fff9c4;border-color:#ffd54f;cursor:default}.task-select-btn:disabled{cursor:default}.stamped-label{font-size:.8rem;color:#888}.mascot-container{display:flex;flex-direction:column;align-items:center;padding:1rem;margin:0 1rem}.speech-bubble{background:#fff;padding:1rem 1.5rem;border-radius:20px;box-shadow:0 2px 8px #0000001a;position:relative;margin-bottom:.5rem;max-width:280px;text-align:center}.speech-bubble:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);border-left:12px solid transparent;border-right:12px solid transparent;border-top:12px solid white}.speech-bubble p{margin:0;font-size:1.1rem;color:#333;line-height:1.5}.speech-bubble.bounce{animation:bubbleBounce .5s ease}@keyframes bubbleBounce{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.mascot{display:flex;flex-direction:column;align-items:center}.mascot-svg{width:100px;height:85px}.mascot-name{font-size:.85rem;color:#888;margin:.5rem 0 0;text-align:center}.mofu-cat .mascot-svg{width:110px;height:90px;animation:mofuBounce 2s ease-in-out infinite}@keyframes mofuBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.beyblade .mascot-svg{width:100px;height:100px}.beyblade .mascot-svg.spinning{animation:spin 3s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.mofu-cat:hover .mascot-svg{animation:mofuWiggle .5s ease}@keyframes mofuWiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}.beyblade:hover .mascot-svg.spinning{animation:spin .5s linear infinite}.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999;overflow:hidden}.confetti-piece{position:absolute;top:-20px;opacity:1;animation:confetti-fall linear forwards,confetti-shake ease-in-out infinite}.confetti-circle{border-radius:50%}.confetti-square{border-radius:2px;transform:rotate(45deg)}.confetti-star{background:transparent!important;clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%);background-color:var(--confetti-color)!important}@keyframes confetti-fall{0%{top:-20px;opacity:1;transform:translate(0) rotate(0)}25%{opacity:1}to{top:100vh;opacity:0;transform:translate(100px) rotate(720deg)}}@keyframes confetti-shake{0%,to{transform:translate(0)}25%{transform:translate(30px) rotateY(180deg)}50%{transform:translate(-20px) rotateX(180deg)}75%{transform:translate(40px) rotateY(-180deg)}}.reward-popup-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.reward-popup{background:linear-gradient(135deg,#fff8e1,#ffecb3);border-radius:30px;padding:2rem;max-width:320px;width:100%;text-align:center;position:relative;overflow:hidden;box-shadow:0 12px 40px #0000004d;animation:popIn .5s ease-out}@keyframes popIn{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}.confetti{position:absolute;inset:0;pointer-events:none;overflow:hidden}.confetti-piece{position:absolute;width:10px;height:10px;border-radius:50%;animation:fall 3s ease-in-out infinite}.piece-0{background:#ff6b6b;left:10%;animation-delay:0s}.piece-1{background:#4ecdc4;left:25%;animation-delay:.5s}.piece-2{background:#45b7d1;left:40%;animation-delay:1s}.piece-3{background:#96ceb4;left:55%;animation-delay:1.5s}.piece-4{background:#ffeaa7;left:70%;animation-delay:2s}@keyframes fall{0%{top:-10%;transform:rotate(0) scale(1);opacity:1}to{top:100%;transform:rotate(720deg) scale(.5);opacity:0}}.reward-content{position:relative;z-index:1}.trophy{font-size:4rem;animation:bounce 1s ease infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.reward-popup h2{font-size:1.8rem;color:#ff6b35;margin:.5rem 0;text-shadow:2px 2px 0 rgba(255,255,255,.5)}.reward-popup h3{font-size:1.3rem;color:#333;margin:.5rem 0 1rem}.reward-detail{font-size:1.4rem;color:#ff8c42;font-weight:700;background:#fff;padding:.75rem 1rem;border-radius:12px;margin:1rem 0;box-shadow:0 2px 8px #0000001a}.reward-instruction{font-size:.95rem;color:#666;line-height:1.6;margin-bottom:1rem}.claim-button{background:linear-gradient(145deg,#ff6b35,#f7931e);color:#fff;border:none;padding:1rem 2.5rem;font-size:1.2rem;font-weight:700;border-radius:30px;cursor:pointer;box-shadow:0 4px 15px #ff6b3566;transition:all .2s}.claim-button:hover{transform:scale(1.05);box-shadow:0 6px 20px #ff6b3580}.claim-button:active{transform:scale(.98)}.stamp-animation{position:fixed;transform:translate(-50%,-50%);pointer-events:none;z-index:1000}.stamp-star{font-size:3rem;animation:stampPop .5s ease-out forwards;display:block}@keyframes stampPop{0%{transform:scale(0);opacity:1}50%{transform:scale(1.3);opacity:1}to{transform:scale(1);opacity:0}}.stamp-sparkle{position:absolute;font-size:1.5rem;animation:sparkle .6s ease-out forwards}.sparkle-1{top:-20px;left:0;animation-delay:.1s}.sparkle-2{top:0;right:-25px;animation-delay:.15s}.sparkle-3{bottom:-20px;left:0;animation-delay:.2s}.sparkle-4{top:0;left:-25px;animation-delay:.25s}@keyframes sparkle{0%{transform:scale(0) rotate(0);opacity:1}50%{transform:scale(1.2) rotate(180deg);opacity:1}to{transform:scale(.5) rotate(360deg) translateY(-20px);opacity:0}}.points-breakdown-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.points-breakdown-popup{background:#fff;border-radius:20px;width:100%;max-width:400px;max-height:80vh;display:flex;flex-direction:column;animation:popup-in .3s ease}@keyframes popup-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.popup-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #eee}.popup-header h2{margin:0;font-size:1.2rem;color:#333}.close-btn{background:none;border:none;font-size:1.5rem;color:#999;cursor:pointer;padding:0;line-height:1}.close-btn:hover{color:#666}.total-points{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1.5rem;background:linear-gradient(135deg,#ffe082,#ffd54f);margin:0}.total-icon{font-size:2rem}.total-value{font-size:2.5rem;font-weight:700;color:#e65100}.total-unit{font-size:1rem;color:#e65100}.tab-buttons{display:flex;padding:.5rem;gap:.5rem;border-bottom:1px solid #eee}.tab-btn{flex:1;padding:.8rem;border:none;background:#f5f5f5;border-radius:10px;font-size:1rem;color:#666;cursor:pointer;transition:all .2s}.tab-btn.active{background:#ff8c42;color:#fff}.popup-content{flex:1;overflow-y:auto;padding:1rem}.no-data{text-align:center;color:#999;padding:2rem}.breakdown-list,.reward-list{list-style:none;padding:0;margin:0}.breakdown-item{display:flex;justify-content:space-between;align-items:center;padding:.8rem;border-bottom:1px solid #f0f0f0}.breakdown-item:last-child{border-bottom:none}.item-info{display:flex;flex-direction:column;gap:.2rem}.item-category{font-size:.75rem;color:#999}.item-name{font-size:1rem;color:#333}.item-stats{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem}.item-stamps{font-size:.8rem;color:#666}.item-points{font-size:1.1rem;font-weight:700;color:#ff8c42}.reward-item{padding:1rem;background:#f9f9f9;border-radius:12px;margin-bottom:.8rem}.reward-item.completed{background:#e8f5e9}.reward-item:last-child{margin-bottom:0}.reward-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.reward-title{font-size:1.1rem;font-weight:700;color:#333}.reward-badge{font-size:.75rem;padding:.2rem .5rem;border-radius:10px;font-weight:700}.reward-badge.completed{background:#4caf50;color:#fff}.reward-badge.repeat{background:#2196f3;color:#fff}.reward-target{font-size:.8rem;color:#666;margin-bottom:.8rem}.progress-bar{height:12px;background:#e0e0e0;border-radius:6px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#ffb74d,#ff8c42);border-radius:6px;transition:width .3s ease}.reward-progress{display:flex;justify-content:space-between;font-size:.85rem;color:#666}.remaining{color:#ff8c42;font-weight:700}.stamp-counter.clickable{border:none;cursor:pointer;transition:transform .2s,box-shadow .2s}.stamp-counter.clickable:hover{transform:scale(1.05);box-shadow:0 2px 8px #0003}.stamp-counter.clickable:active{transform:scale(.98)}.child-dashboard{min-height:100vh;background:linear-gradient(180deg,#fff8e7,#fffdf5);padding-bottom:2rem}.child-header{padding:1rem 1.5rem;color:#fff;display:flex;justify-content:space-between;align-items:center;border-radius:0 0 24px 24px;box-shadow:0 4px 12px #0000001a}.child-header h1{font-size:1.3rem;font-weight:700;margin:0;text-shadow:1px 1px 2px rgba(0,0,0,.2)}.header-counters{display:flex;gap:.5rem}.stamp-counter,.reward-counter{display:flex;align-items:center;gap:.3rem;background:#ffffff4d;padding:.5rem .8rem;border-radius:20px}.stamp-icon,.reward-icon{font-size:1.3rem}.stamp-count,.reward-count{font-size:1rem;font-weight:700}.today-section{text-align:center;padding:1.5rem 1rem}.today-date{font-size:1.4rem;color:#ff8c42;margin:0 0 .5rem;font-weight:700}.progress-info{font-size:1rem;color:#666}.section-title{font-size:1.2rem;color:#4a4a4a;padding:0 1.5rem;margin:1rem 0;font-weight:700}.task-section{margin-bottom:1.5rem}.calendar-section{margin-top:1rem;margin-bottom:4rem}.back-to-select-btn{position:fixed;top:1rem;left:1rem;padding:.5rem 1rem;background:#ffffffe6;color:#666;border:1px solid #ddd;border-radius:20px;font-size:.9rem;cursor:pointer;z-index:50;box-shadow:0 2px 8px #0000001a;transition:all .2s}.back-to-select-btn:hover{background:#fff;border-color:#bbb}.stamp-calendar-manager{background:#fff;border-radius:12px;padding:1rem;box-shadow:0 2px 8px #00000014}.calendar-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.calendar-nav-btn{background:none;border:none;font-size:1.2rem;color:#ff8c42;cursor:pointer;padding:.5rem;border-radius:8px;transition:background .2s}.calendar-nav-btn:hover{background:#fff3e0}.calendar-month-year{font-size:1.1rem;font-weight:700;color:#333}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:.5rem}.calendar-weekday{font-size:.8rem;color:#666;padding:.25rem}.calendar-weekday.sunday{color:#e57373}.calendar-weekday.saturday{color:#64b5f6}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.calendar-cell{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:8px;padding:2px;min-height:40px}.calendar-cell.empty{cursor:default}.calendar-cell.today{background:#fff3e0;border:2px solid #FF8C42}.calendar-cell.has-stamps{background:linear-gradient(135deg,#fffde7,#fff9c4)}.calendar-cell.clickable{cursor:pointer;transition:all .2s}.calendar-cell.clickable:hover{transform:scale(1.05);box-shadow:0 2px 8px #00000026}.cell-day{font-size:.85rem;font-weight:600;color:#333}.stamp-indicators{font-size:.5rem;line-height:1;margin-top:1px}.stamp-popup-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.stamp-popup{background:#fff;border-radius:16px;padding:1.5rem;max-width:360px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.stamp-popup-title{margin:0 0 .5rem;font-size:1.1rem;color:#333;text-align:center}.stamp-popup-hint{margin:0 0 1rem;font-size:.85rem;color:#888;text-align:center}.stamp-popup-list{list-style:none;padding:0;margin:0 0 1rem}.stamp-popup-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border:1px solid #eee;border-radius:10px;margin-bottom:.5rem;cursor:pointer;transition:all .2s}.stamp-popup-item:hover{background:#fff3e0;border-color:#ff8c42}.stamp-popup-item:last-child{margin-bottom:0}.stamp-item-info{display:flex;align-items:center;gap:.5rem;flex:1}.stamp-item-icon{font-size:1.2rem}.stamp-item-details{display:flex;flex-direction:column;flex:1}.stamp-item-name{font-size:.95rem;font-weight:500;color:#333}.stamp-item-timeslot{font-size:.75rem;color:#888}.stamp-item-points{font-size:.85rem;font-weight:600;color:#ff8c42;margin-right:.5rem}.stamp-item-delete{font-size:.8rem;color:#e74c3c;padding:.25rem .5rem;border:1px solid #e74c3c;border-radius:6px;transition:all .2s}.stamp-popup-item:hover .stamp-item-delete{background:#e74c3c;color:#fff}.stamp-popup-close{width:100%;padding:.75rem;background:#f5f5f5;color:#666;border:none;border-radius:10px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}.stamp-popup-close:hover{background:#eee}.stamp-edit-popup{max-width:400px}.stamp-edit-item{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;border:2px solid #e0e0e0;border-radius:12px;margin-bottom:.5rem;cursor:pointer;transition:all .2s;background:#fafafa}.stamp-edit-item:hover{border-color:#ffb74d;background:#fff8e1}.stamp-edit-item.stamped{border-color:#ff8c42;background:linear-gradient(135deg,#fff8e1,#ffecb3)}.stamp-edit-item:last-child{margin-bottom:0}.stamp-edit-info{display:flex;align-items:center;gap:.75rem;flex:1}.stamp-toggle-icon{font-size:1.5rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.stamp-toggle-icon.off{color:#ccc;background:#f0f0f0;font-size:1.2rem}.stamp-toggle-icon.on{background:#fff3e0}.stamp-edit-details{display:flex;flex-direction:column;gap:.15rem}.stamp-edit-name{font-size:1rem;font-weight:600;color:#333}.stamp-edit-points{font-size:.8rem;color:#ff8c42;font-weight:500}.stamp-status{font-size:.85rem;font-weight:700;padding:.35rem .75rem;border-radius:20px;min-width:50px;text-align:center}.stamp-status.off{background:#f0f0f0;color:#999}.stamp-status.on{background:#ff8c42;color:#fff}.no-tasks-message{text-align:center;color:#888;padding:2rem 1rem;font-size:.95rem}.stamp-popup-summary{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f5f5f5;border-radius:10px;margin:1rem 0}.summary-label{font-size:.9rem;color:#666}.summary-count{font-size:1.1rem;font-weight:700;color:#ff8c42}.change-password-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.change-password-modal{background:#fff;border-radius:16px;padding:2rem;max-width:400px;width:100%;position:relative;box-shadow:0 10px 40px #0003}.change-password-close-btn{position:absolute;top:1rem;right:1rem;width:32px;height:32px;border:none;background:#f5f5f5;border-radius:50%;font-size:1.5rem;line-height:1;color:#666;cursor:pointer;transition:all .2s}.change-password-close-btn:hover{background:#e0e0e0;color:#333}.change-password-title{font-size:1.5rem;color:#333;margin:0 0 1.5rem;text-align:center}.change-password-form{display:flex;flex-direction:column;gap:1rem}.change-password-form .form-group{text-align:left}.change-password-form .form-label{display:block;color:#666;font-size:.9rem;margin-bottom:.4rem}.change-password-input{width:100%;padding:.875rem 1rem;border:2px solid #e0e0e0;border-radius:12px;font-size:1rem;box-sizing:border-box;background:#fff;transition:border-color .2s}.change-password-input:focus{outline:none;border-color:#5c6bc0}.change-password-input:disabled{background:#f5f5f5;color:#999}.change-password-error{color:#c62828;font-size:.9rem;margin:0;text-align:left;padding:.5rem;background:#c628281a;border-radius:8px}.change-password-success{color:#2e7d32;font-size:.9rem;margin:0;text-align:left;padding:.5rem;background:#2e7d321a;border-radius:8px}.change-password-buttons{display:flex;gap:1rem;margin-top:.5rem}.change-password-cancel-btn{flex:1;padding:.875rem 1rem;background:#f5f5f5;border:none;border-radius:12px;font-size:1rem;font-weight:600;color:#666;cursor:pointer;transition:all .2s}.change-password-cancel-btn:hover:not(:disabled){background:#e0e0e0}.change-password-cancel-btn:disabled{opacity:.5;cursor:not-allowed}.change-password-submit-btn{flex:1;padding:.875rem 1rem;background:linear-gradient(145deg,#5c6bc0,#3f51b5);border:none;border-radius:12px;font-size:1rem;font-weight:600;color:#fff;cursor:pointer;transition:all .2s}.change-password-submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 15px #3f51b54d}.change-password-submit-btn:disabled{opacity:.7;cursor:not-allowed}.parent-dashboard{min-height:100vh;background:#f5f5f5}.parent-header{background:linear-gradient(145deg,#5c6bc0,#3f51b5);color:#fff;padding:1rem 1.5rem;text-align:center;position:relative}.parent-header h1{margin:0;font-size:1.3rem}.parent-back-btn{position:absolute;left:1rem;top:50%;transform:translateY(-50%);padding:.4rem .75rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:16px;font-size:.85rem;cursor:pointer;transition:all .2s}.parent-back-btn:hover{background:#ffffff4d}.child-selector{display:flex;gap:.5rem;padding:1rem;overflow-x:auto;background:#fff;border-bottom:1px solid #eee}.child-tab{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border:2px solid #ddd;border-radius:20px;cursor:pointer;white-space:nowrap;transition:all .2s}.child-tab.active{background:#f0f0ff;border-color:#5c6bc0}.child-avatar,.child-avatar-small{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.9rem}.child-avatar-small{width:32px;height:32px}.child-name{font-size:.95rem}.tabs{display:flex;background:#fff;border-bottom:1px solid #eee}.tab{flex:1;padding:.75rem;background:none;border:none;border-bottom:3px solid transparent;font-size:.9rem;color:#666;cursor:pointer;transition:all .2s}.tab.active{color:#5c6bc0;border-bottom-color:#5c6bc0;font-weight:600}.tab:disabled{color:#ccc;cursor:not-allowed}.tab-content{padding:1rem}.add-button{width:100%;padding:.75rem;background:linear-gradient(145deg,#5c6bc0,#3f51b5);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;margin-bottom:1rem}.form-card{background:#fff;border-radius:16px;padding:1.5rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000001a}.form-card h3{margin:0 0 1rem;font-size:1.1rem;color:#333}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.9rem;color:#666;margin-bottom:.5rem}.form-group input[type=text],.form-group input[type=number],.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;box-sizing:border-box}.color-picker{display:flex;gap:.5rem;flex-wrap:wrap}.color-option{width:36px;height:36px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:all .2s}.color-option.selected{border-color:#333;transform:scale(1.1)}.avatar-type-picker{display:flex;gap:.5rem;flex-wrap:wrap}.avatar-type-option{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem .75rem;border:2px solid #ddd;border-radius:12px;background:#fff;cursor:pointer;transition:all .2s}.avatar-type-option.selected{border-color:#5c6bc0;background:#f0f0ff}.avatar-type-icon{font-size:1.5rem}.avatar-type-label{font-size:.75rem;color:#666}.list-item-container{margin-bottom:.5rem}.list-item-container .form-card.edit-form{margin:0}.day-picker{display:flex;gap:.25rem}.day-option{width:36px;height:36px;border-radius:50%;border:1px solid #ddd;background:#fff;cursor:pointer;font-size:.85rem;transition:all .2s}.day-option.selected{background:#5c6bc0;color:#fff;border-color:#5c6bc0}.points-picker{display:flex;gap:.5rem}.point-option{width:40px;height:40px;border-radius:50%;border:2px solid #ddd;background:#fff;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s}.point-option.selected{background:gold;color:#333;border-color:orange;transform:scale(1.1)}.checkbox-label{display:flex!important;align-items:center;gap:.5rem;cursor:pointer}.checkbox-label input{width:auto!important}.form-actions{display:flex;gap:.5rem;margin-top:1rem}.cancel-btn,.submit-btn{flex:1;padding:.75rem;border:none;border-radius:8px;font-size:1rem;cursor:pointer}.cancel-btn{background:#eee;color:#666}.submit-btn{background:#5c6bc0;color:#fff}.list{display:flex;flex-direction:column;gap:.5rem}.list-item{display:flex;align-items:center;gap:.75rem;background:#fff;padding:1rem;border-radius:12px;box-shadow:0 1px 4px #0000000d}.list-item.inactive{opacity:.5}.item-name{font-weight:600;color:#333}.item-stats,.item-category,.item-days{font-size:.85rem;color:#888}.item-actions{margin-left:auto;display:flex;gap:.5rem}.edit-btn,.toggle-btn,.delete-btn{padding:.4rem .75rem;border:none;border-radius:6px;font-size:.85rem;cursor:pointer}.edit-btn{background:#fff3e0;color:#e65100}.toggle-btn{background:#e3f2fd;color:#1976d2}.delete-btn{background:#ffebee;color:#c62828}.edit-form .form-group{margin-bottom:.75rem}.edit-form .form-actions{margin-top:.75rem}.task-info-parent{display:flex;flex-direction:column;gap:.25rem;flex:1}.reward-item{flex-direction:column;align-items:flex-start}.reward-info{display:flex;flex-direction:column;gap:.25rem;width:100%}.reward-title{font-size:1.1rem;font-weight:600;color:#333}.reward-detail{color:#5c6bc0;font-weight:500}.reward-progress{font-size:.85rem;color:#888}.reward-item .delete-btn{align-self:flex-end;margin-top:.5rem}.section-subtitle{font-size:1rem;color:#333;margin:1.5rem 0 .75rem}.achievement-item{background:linear-gradient(135deg,#fff8e1,#ffecb3)}.achievement-icon{font-size:1.5rem}.achievement-info{flex:1;display:flex;flex-direction:column}.achievement-title{font-weight:600}.achievement-date{font-size:.85rem;color:#888}.achievement-status{font-size:.8rem;padding:.25rem .5rem;border-radius:8px}.achievement-status.claimed{background:#e8f5e9;color:#2e7d32}.achievement-status.unclaimed{background:#fff3e0;color:#e65100}.stats-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.5rem}.stat-card{background:#fff;padding:1rem;border-radius:12px;text-align:center;box-shadow:0 2px 8px #0000000d}.stat-value{display:block;font-size:1.8rem;font-weight:700;color:#5c6bc0}.stat-label{font-size:.8rem;color:#888}.stats-item{display:grid;grid-template-columns:1fr 2fr auto;gap:.75rem;align-items:center}.progress-bar-container{height:8px;background:#eee;border-radius:4px;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,#81c784,#4caf50);border-radius:4px;transition:width .3s}.stamp-count-badge{background:#e8f5e9;color:#2e7d32;padding:.25rem .5rem;border-radius:8px;font-size:.85rem;font-weight:600}.settings-tab .form-card{margin-bottom:1rem}.settings-description{font-size:.9rem;color:#666;margin:.5rem 0 1rem;line-height:1.5}.family-id-display{display:flex;align-items:center;gap:.75rem;background:#f5f5f5;padding:1rem;border-radius:12px}.family-id-code{font-size:1.5rem;font-weight:700;font-family:monospace;letter-spacing:.1em;color:#5c6bc0;flex:1}.copy-btn{padding:.5rem 1rem;background:#5c6bc0;color:#fff;border:none;border-radius:8px;font-size:.9rem;cursor:pointer}.copy-btn:hover{background:#3f51b5}.user-info{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f5f5f5;border-radius:12px;margin-bottom:1rem}.user-avatar{width:48px;height:48px;border-radius:50%}.user-details{display:flex;flex-direction:column;gap:.25rem}.user-name{font-weight:600;color:#333}.user-email{font-size:.85rem;color:#666}.logout-btn{width:100%;padding:.75rem;background:#f44336;color:#fff;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:background .2s}.logout-btn:hover{background:#d32f2f}.change-password-btn{width:100%;padding:.75rem;background:#5c6bc0;color:#fff;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:background .2s;margin-top:.5rem}.change-password-btn:hover{background:#3f51b5}.stamp-history-item{display:flex;align-items:center;justify-content:space-between}.stamp-history-info{display:flex;flex-direction:column;gap:.25rem}.stamp-history-date{font-size:.85rem;color:#888}.scope-badge{display:inline-block;margin-left:.5rem;padding:.15rem .4rem;border-radius:4px;font-size:.7rem;font-weight:600;vertical-align:middle}.scope-badge.family{background:#e3f2fd;color:#1565c0}.form-help{display:block;font-size:.8rem;color:#888;margin-top:.25rem}.schedule-picker{display:flex;gap:.5rem}.schedule-option{flex:1;padding:.6rem .75rem;border:2px solid #ddd;border-radius:8px;background:#fff;font-size:.9rem;cursor:pointer;transition:all .2s}.schedule-option.selected{background:#5c6bc0;color:#fff;border-color:#5c6bc0}.scope-badge.spot{background:#fff3e0;color:#e65100}.form-group input[type=date]{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;box-sizing:border-box}.stats-hint{text-align:center;font-size:.85rem;color:#888;margin:0 0 .75rem}.stat-card.clickable{cursor:pointer;transition:all .2s}.stat-card.clickable:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-card.clickable:active{transform:translateY(0)}.stats-popup-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.stats-popup{background:#fff;border-radius:16px;padding:1.5rem;max-width:400px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.stats-popup-title{margin:0 0 1rem;font-size:1.1rem;color:#333;text-align:center}.stats-popup-list{list-style:none;padding:0;margin:0 0 1rem}.stats-popup-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-bottom:1px solid #eee}.stats-popup-item:last-child{border-bottom:none}.stats-child-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1rem}.stats-child-avatar.small{width:24px;height:24px;font-size:.75rem}.stats-child-name{flex:1;font-weight:500;color:#333}.stats-child-value{font-size:1.1rem;font-weight:700;color:#5c6bc0}.stats-popup-common{border-top:1px dashed #ddd;padding-top:.75rem;margin-top:.5rem}.stats-common-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#e3f2fd;border-radius:50%;font-size:1rem}.stats-popup-close{width:100%;padding:.75rem;background:#f5f5f5;color:#666;border:none;border-radius:10px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}.stats-popup-close:hover{background:#eee}.all-children-calendar{background:#fff;border-radius:12px;padding:1rem;box-shadow:0 2px 8px #00000014;margin-bottom:1.5rem}.all-children-calendar .calendar-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.all-children-calendar .calendar-nav-btn{background:none;border:none;font-size:1.2rem;color:#5c6bc0;cursor:pointer;padding:.5rem;border-radius:8px;transition:background .2s}.all-children-calendar .calendar-nav-btn:hover{background:#f0f0ff}.all-children-calendar .calendar-month-year{font-size:1.1rem;font-weight:700;color:#333}.all-children-calendar .calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:.5rem}.all-children-calendar .calendar-weekday{font-size:.8rem;color:#666;padding:.25rem}.all-children-calendar .calendar-weekday.sunday{color:#e57373}.all-children-calendar .calendar-weekday.saturday{color:#64b5f6}.all-children-calendar .calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.all-children-calendar .calendar-cell{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:8px;padding:2px;min-height:40px}.all-children-calendar .calendar-cell.empty{cursor:default}.all-children-calendar .calendar-cell.today{background:#e8eaf6;border:2px solid #5C6BC0}.all-children-calendar .calendar-cell.has-stamps{background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.all-children-calendar .calendar-cell.clickable{cursor:pointer;transition:all .2s}.all-children-calendar .calendar-cell.clickable:hover{transform:scale(1.05);box-shadow:0 2px 8px #00000026}.all-children-calendar .cell-day{font-size:.85rem;font-weight:600;color:#333}.all-children-calendar .cell-points{font-size:.6rem;color:#2e7d32;font-weight:600}.date-stamps-detail{margin-top:1rem;padding-top:1rem;border-top:1px solid #eee}.date-stamps-detail h5{margin:0 0 .75rem;font-size:.95rem;color:#666}.child-stamps-section{margin-bottom:1rem}.child-stamps-header{display:flex;align-items:center;gap:.5rem;font-weight:600;color:#333;margin-bottom:.5rem;font-size:.9rem}.child-stamps-list{list-style:none;padding:0;margin:0 0 0 2rem}.child-stamp-item{display:flex;justify-content:space-between;padding:.35rem 0;font-size:.85rem;color:#555}.stamp-task-name{flex:1}.stamp-task-points{color:#5c6bc0;font-weight:600}.no-stamps-message{text-align:center;color:#888;padding:1rem;font-size:.9rem}.tab-child-selector{display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem;background:#f5f5f5;border-radius:12px;margin-bottom:1rem}.child-chip{display:flex;align-items:center;gap:.4rem;padding:.5rem .85rem;background:#fff;border:2px solid #ddd;border-radius:20px;font-size:.9rem;cursor:pointer;transition:all .2s}.child-chip:hover{border-color:#5c6bc0;background:#f8f8ff}.child-chip.active{background:#5c6bc0;border-color:#5c6bc0;color:#fff}.child-chip.active .chip-avatar{border:2px solid white}.chip-avatar{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.75rem}.task-owner-badge{flex-shrink:0;margin-right:.5rem}.task-owner{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.85rem}.edit-btn{padding:.35rem .75rem;background:#5c6bc0;color:#fff;border:none;border-radius:6px;font-size:.85rem;cursor:pointer;transition:background .2s}.edit-btn:hover{background:#3f51b5}.item-actions{display:flex;gap:.5rem;flex-shrink:0}.edit-form{width:100%}.child-stamp-item.deletable{display:flex;justify-content:space-between;align-items:center}.stamp-item-info{display:flex;gap:.5rem;align-items:center}.stamp-delete-btn{padding:.25rem .5rem;background:#ef5350;color:#fff;border:none;border-radius:4px;font-size:.75rem;cursor:pointer;transition:background .2s}.stamp-delete-btn:hover{background:#e53935}.task-checkbox-list{display:flex;flex-direction:column;gap:.5rem;max-height:200px;overflow-y:auto;border:1px solid #ddd;border-radius:8px;padding:.5rem;background:#fafafa}.task-checkbox-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#fff;border-radius:6px;cursor:pointer;transition:background .2s}.task-checkbox-item:hover{background:#f0f0f0}.task-checkbox-item input[type=checkbox]{width:18px;height:18px;cursor:pointer}.task-checkbox-name{flex:1;font-size:.9rem}.task-checkbox-points{font-size:.8rem;color:#666;background:#e0e0e0;padding:.15rem .4rem;border-radius:4px}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#5c6bc0,#3f51b5);padding:2rem;position:relative}.login-back-btn{position:absolute;top:1rem;left:1rem;padding:.5rem 1rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:20px;font-size:.9rem;cursor:pointer;transition:all .2s}.login-back-btn:hover{background:#ffffff4d}.login-content{text-align:center;max-width:360px;width:100%}.login-title{color:#fff;font-size:1.8rem;margin:0 0 .5rem}.login-subtitle{color:#ffffffe6;font-size:1rem;margin:0 0 1.5rem;line-height:1.6}.login-form{display:flex;flex-direction:column;gap:.75rem}.login-form .form-group{margin:0}.login-input{width:100%;padding:1rem;border:none;border-radius:12px;font-size:1rem;box-sizing:border-box;background:#fff}.login-input:focus{outline:3px solid rgba(255,255,255,.5)}.login-input:disabled{background:#f5f5f5;color:#999}.login-error{color:#ffcdd2;font-size:.9rem;margin:.5rem 0;text-align:left;padding:.5rem;background:#c628284d;border-radius:8px}.login-success{color:#c8e6c9;font-size:.9rem;margin:.5rem 0;text-align:left;padding:.5rem;background:#2e7d324d;border-radius:8px}.login-submit-btn{width:100%;padding:1rem 1.5rem;background:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;color:#5c6bc0;cursor:pointer;box-shadow:0 4px 15px #0003;transition:all .2s;margin-top:.5rem}.login-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.login-submit-btn:active:not(:disabled){transform:translateY(0)}.login-submit-btn:disabled{opacity:.7;cursor:not-allowed}.login-links{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.link-btn{background:none;border:none;color:#ffffffe6;font-size:.9rem;cursor:pointer;text-decoration:underline;padding:.25rem}.link-btn:hover{color:#fff}.login-note{color:#ffffffb3;font-size:.85rem;margin:1.5rem 0 0;line-height:1.5}.visually-hidden-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.family-id-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fff8e7,#ffe0b2);padding:2rem}.family-id-content{text-align:center;max-width:360px;width:100%}.family-id-title{font-size:2rem;color:#ff8c42;margin:0 0 .5rem;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.family-id-subtitle{color:#666;font-size:1.1rem;margin:0 0 1.5rem}.family-id-form{display:flex;flex-direction:column;gap:.75rem}.family-id-input{width:100%;padding:1rem;border:3px solid #FFB347;border-radius:12px;font-size:1.2rem;text-align:center;letter-spacing:.2em;font-weight:600;box-sizing:border-box;background:#fff;text-transform:uppercase}.family-id-input:focus{outline:none;border-color:#ff8c42;box-shadow:0 0 0 3px #ff8c4233}.family-id-input::placeholder{font-size:.9rem;letter-spacing:normal;font-weight:400;color:#aaa}.family-id-password-input{width:100%;padding:1rem;border:3px solid #FFB347;border-radius:12px;font-size:1rem;box-sizing:border-box;background:#fff}.family-id-password-input:focus{outline:none;border-color:#ff8c42;box-shadow:0 0 0 3px #ff8c4233}.family-id-password-input::placeholder{color:#aaa}.family-id-error{color:#c62828;font-size:.9rem;margin:0;text-align:left;padding:.5rem;background:#c628281a;border-radius:8px}.family-id-join-btn{width:100%;padding:1rem 1.5rem;background:linear-gradient(145deg,#ffb347,#ff8c42);border:none;border-radius:12px;font-size:1.1rem;font-weight:600;color:#fff;cursor:pointer;box-shadow:0 4px 15px #ff8c424d;transition:all .2s}.family-id-join-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ff8c4266}.family-id-join-btn:disabled{opacity:.5;cursor:not-allowed}.family-id-divider{display:flex;align-items:center;margin:1.5rem 0}.family-id-divider:before,.family-id-divider:after{content:"";flex:1;height:1px;background:#00000026}.family-id-divider span{padding:0 1rem;color:#999;font-size:.9rem}.family-id-create-btn{width:100%;padding:1rem 1.5rem;background:linear-gradient(145deg,#5c6bc0,#3f51b5);border:none;border-radius:12px;font-size:1.1rem;font-weight:600;color:#fff;cursor:pointer;box-shadow:0 4px 15px #3f51b54d;transition:all .2s}.family-id-create-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #3f51b566}.family-id-create-btn:disabled{opacity:.5;cursor:not-allowed}.family-id-note{margin-top:1.5rem;padding:1rem;background:#ffffffb3;border-radius:12px;color:#666;font-size:.9rem;line-height:1.6}.set-password-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#5c6bc0,#3f51b5);padding:2rem;position:relative}.set-password-back-btn{position:absolute;top:1rem;left:1rem;padding:.5rem 1rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:20px;font-size:.9rem;cursor:pointer;transition:all .2s}.set-password-back-btn:hover{background:#ffffff4d}.set-password-content{text-align:center;max-width:400px;width:100%}.set-password-title{color:#fff;font-size:1.8rem;margin:0 0 .5rem}.set-password-subtitle{color:#ffffffe6;font-size:1rem;margin:0 0 1.5rem;line-height:1.6}.set-password-form{display:flex;flex-direction:column;gap:1rem}.set-password-form .form-group{text-align:left}.set-password-input{width:100%;padding:.875rem 1rem;border:none;border-radius:12px;font-size:1rem;box-sizing:border-box;background:#fff}.set-password-input:focus{outline:3px solid rgba(255,255,255,.5)}.set-password-input:disabled{background:#f5f5f5;color:#999}.set-password-select{width:100%;padding:.875rem 1rem;border:none;border-radius:12px;font-size:1rem;box-sizing:border-box;background:#fff;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}.set-password-select:focus{outline:3px solid rgba(255,255,255,.5)}.set-password-select:disabled{background-color:#f5f5f5;color:#999}.set-password-error{color:#ffcdd2;font-size:.9rem;margin:.5rem 0;text-align:left;padding:.5rem;background:#c628284d;border-radius:8px}.set-password-submit-btn{width:100%;padding:1rem 1.5rem;background:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;color:#5c6bc0;cursor:pointer;box-shadow:0 4px 15px #0003;transition:all .2s;margin-top:.5rem}.set-password-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.set-password-submit-btn:active:not(:disabled){transform:translateY(0)}.set-password-submit-btn:disabled{opacity:.7;cursor:not-allowed}.set-password-note{color:#ffffffb3;font-size:.85rem;margin:1.5rem 0 0;line-height:1.5}.password-reset-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#5c6bc0,#3f51b5);padding:2rem;position:relative}.password-reset-back-btn{position:absolute;top:1rem;left:1rem;padding:.5rem 1rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:20px;font-size:.9rem;cursor:pointer;transition:all .2s}.password-reset-back-btn:hover{background:#ffffff4d}.password-reset-content{text-align:center;max-width:400px;width:100%}.password-reset-title{color:#fff;font-size:1.8rem;margin:0 0 .5rem}.password-reset-subtitle{color:#ffffffe6;font-size:1rem;margin:0 0 1.5rem;line-height:1.6}.password-reset-form{display:flex;flex-direction:column;gap:1rem}.password-reset-form .form-group{text-align:left}.form-label{display:block;color:#ffffffe6;font-size:.9rem;margin-bottom:.4rem}.family-id-display,.security-question-display{padding:.75rem 1rem;background:#fff3;border-radius:12px;color:#fff;font-size:1rem}.security-question-display{font-weight:500}.password-reset-input{width:100%;padding:.875rem 1rem;border:none;border-radius:12px;font-size:1rem;box-sizing:border-box;background:#fff}.password-reset-input:focus{outline:3px solid rgba(255,255,255,.5)}.password-reset-input:disabled{background:#f5f5f5;color:#999}.password-reset-error{color:#ffcdd2;font-size:.9rem;margin:.5rem 0;text-align:left;padding:.5rem;background:#c628284d;border-radius:8px}.password-reset-success{color:#c8e6c9;font-size:.9rem;margin:.5rem 0;text-align:left;padding:.5rem;background:#2e7d324d;border-radius:8px}.password-reset-submit-btn{width:100%;padding:1rem 1.5rem;background:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;color:#5c6bc0;cursor:pointer;box-shadow:0 4px 15px #0003;transition:all .2s;margin-top:.5rem}.password-reset-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.password-reset-submit-btn:active:not(:disabled){transform:translateY(0)}.password-reset-submit-btn:disabled{opacity:.7;cursor:not-allowed}.password-reset-back-link{background:none;border:none;color:#ffffffe6;font-size:1rem;cursor:pointer;text-decoration:underline;margin-top:1rem}.password-reset-back-link:hover{color:#fff}.app{min-height:100vh;font-family:Hiragino Sans,Hiragino Kaku Gothic ProN,Noto Sans JP,sans-serif}.mode-select{min-height:100vh;background:linear-gradient(135deg,#fff8e7,#ffe0b2);display:flex;align-items:center;justify-content:center;padding:2rem}.mode-select-content{text-align:center;width:100%;max-width:400px}.app-title{font-size:2rem;color:#ff8c42;margin:0 0 .5rem;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.app-subtitle{font-size:1.1rem;color:#888;margin:1.5rem 0 1rem}.mode-buttons{display:flex;flex-direction:column;gap:1rem}.mode-button{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.5rem 2rem;border:none;border-radius:20px;font-size:1.3rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0000001a}.mode-button:hover{transform:translateY(-3px);box-shadow:0 6px 20px #00000026}.mode-button:active{transform:translateY(0)}.child-mode{background:linear-gradient(145deg,#ffb347,#ff8c42);color:#fff}.parent-mode{background:linear-gradient(145deg,#5c6bc0,#3f51b5);color:#fff}.mode-button.disabled{background:linear-gradient(145deg,#ccc,#aaa);cursor:not-allowed;opacity:.6}.mode-button.disabled:hover{transform:none;box-shadow:0 4px 15px #0000001a}.no-children-note{margin-top:1.5rem;padding:1rem;background:#ffffffb3;border-radius:12px;color:#666;font-size:.95rem;line-height:1.6}.mode-icon{font-size:2rem}.mode-label{font-size:1.2rem}.child-select-section{margin:1rem 0 .5rem;padding:1rem;background:#fff9;border-radius:16px}.child-select-label{color:#666;margin:0 0 1rem;font-size:1.1rem;font-weight:600}.child-select-buttons{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem}.child-select-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#fff;border:3px solid #e0e0e0;border-radius:30px;font-size:1rem;cursor:pointer;transition:all .2s;opacity:.7}.child-select-btn:hover{opacity:.9;transform:translateY(-2px)}.child-select-btn.active{border-color:var(--child-color);background:linear-gradient(145deg,#fff,#fff8f0);opacity:1;box-shadow:0 4px 12px #00000026;transform:scale(1.05)}.child-select-btn .child-name-btn{font-weight:500}.child-select-btn.active .child-name-btn{font-weight:700;color:#333}.child-select-btn .check-icon{color:var(--child-color);font-weight:700;font-size:1.1rem}.child-avatar-btn{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1rem}.child-select-btn.active .child-avatar-btn{box-shadow:0 2px 8px #0003}.back-button{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);padding:.75rem 2rem;background:#000000b3;color:#fff;border:none;border-radius:30px;font-size:1rem;cursor:pointer;z-index:50;transition:all .2s}.back-button:hover{background:#000000d9}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#fff8e7,#ffe0b2);gap:1rem}.loading-screen p{color:#ff8c42;font-size:1.2rem;font-weight:600}.loading-spinner{width:50px;height:50px;border:4px solid #FFE0B2;border-top-color:#ff8c42;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
