@import "https://fonts.googleapis.com/css2?family=Baloo+2:wght@500;700;800&family=Fredoka:wght@400;600;700&display=swap";:root{--ink:#192231;--ink-soft:#60738a;--muted:#4f6070;--card:#fffdf5;--page-top:#fff8d6;--page-bottom:#d6f7ff;color:var(--ink);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Fredoka,Trebuchet MS,sans-serif;font-weight:500;line-height:1.35}*{box-sizing:border-box}body{background:linear-gradient(180deg, var(--page-top), var(--page-bottom));min-width:320px;margin:0}h1,h2,h3,h4{font-family:"Baloo 2",Comic Sans MS,cursive;line-height:1.1}h1{margin:0 0 8px;font-size:clamp(2rem,4vw,3rem)}p{margin:0}.app-shell{box-sizing:border-box;min-height:100vh;padding:24px;position:relative}.dashboard-shell{max-width:1280px;margin:0 auto}.bg-shape{z-index:-1;filter:blur(2px);border-radius:50%;animation:8s ease-in-out infinite floaty;position:fixed}.bg-shape-left{background:radial-gradient(circle at 30% 30%,#ffd166,#f77f00);width:380px;height:380px;top:-90px;left:-100px}.bg-shape-right{background:radial-gradient(circle at 40% 40%,#5cd68f,#00a878);width:360px;height:360px;bottom:-120px;right:-120px}@keyframes floaty{0%{transform:translateY(0)scale(1)}50%{transform:translateY(-14px)scale(1.04)}to{transform:translateY(0)scale(1)}}.login-card,.panel,.stat-card{border:3px solid var(--ink);background:var(--card);border-radius:22px;box-shadow:0 10px #14182626}.login-card{max-width:520px;margin:40px auto;padding:28px}.subtitle{color:var(--muted);margin:0 0 18px}.form-grid{gap:12px;display:grid}label{text-align:left;color:var(--ink);gap:6px;font-weight:700;display:grid}input,textarea,select,button{font:inherit}input,textarea,select{border:2px solid var(--ink-soft);background:#fff;border-radius:14px;padding:10px 12px}textarea{resize:vertical;min-height:80px}button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#ff8a00,#ff4d6d);border:none;border-radius:14px;padding:10px 14px;font-weight:800;transition:transform .2s,filter .2s}button:hover{filter:brightness(1.05);transform:translateY(-2px)}button:disabled{cursor:not-allowed;opacity:.7;transform:none}.ghost-btn{color:var(--ink);border:2px solid var(--ink);background:#fff}.error-box{color:#7a1f1f;background:#ffe5e5;border:2px solid #b42318;border-radius:12px;margin-top:12px;padding:10px}.success-box{color:#13653a;background:#e8fff1;border:2px solid #1f8f4e;border-radius:12px;margin-top:12px;padding:10px}.demo-users{background:#f8f2d9;border-radius:12px;margin-top:14px;padding:10px}.topbar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.topbar-datetime{color:var(--ink);opacity:.7;text-align:center;text-transform:capitalize;flex:1;font-size:.8rem}.topbar-actions{align-items:center;gap:10px;display:flex}.kid-switcher{gap:4px;min-width:180px;display:grid}.kid-switcher span{color:var(--muted);font-size:.78rem}.kid-switcher select{padding:8px 10px}.admin-menu{position:relative}.admin-dropdown{border:2px solid var(--ink);z-index:40;background:#fffaf1;border-radius:16px;gap:6px;min-width:220px;padding:8px;display:grid;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 12px 24px #1418262e}.admin-dropdown-item{text-align:left;width:100%;color:var(--ink);background:#fff;border:2px solid #0000}.admin-dropdown-item:hover{border-color:var(--ink)}.avatar-pill{align-items:center;gap:12px;display:flex}.avatar-pill img{object-fit:cover;border:3px solid var(--ink);border-radius:50%;width:58px;height:58px}.avatar-pill h2{margin:0}.avatar-pill p{color:var(--muted);margin:0}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px;display:grid}.stat-card{padding:16px}.stat-card h3{margin:0;font-size:.95rem}.stat-card p{margin:10px 0 2px;font-size:2rem;font-weight:900}.star-card{background:linear-gradient(160deg,#ffe08a,#ffc300)}.minute-card{background:linear-gradient(160deg,#9fd3ff,#5bb8ff)}.honest-card{background:linear-gradient(160deg,#b8f39c,#68d66e)}.pending-card{background:linear-gradient(160deg,#ffd6a5,#ffad66)}.admin-layout,.kid-layout{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:12px;display:grid}.kid-layout{grid-template-columns:repeat(2,minmax(0,1fr))}.panel{padding:16px}.panel h3{margin-top:0}.records-list{gap:10px;display:grid}.record-item{border:2px dashed var(--ink-soft);background:#fff;border-radius:12px;padding:10px}.record-item.compact{justify-content:space-between;align-items:center;display:flex}.record-item p,.record-item small,.reward-card p{margin:4px 0}.tag{color:var(--muted);font-size:.86rem}.feedback-row{gap:8px;margin-top:8px;display:grid}.feedback-actions{gap:8px;display:flex}.reward-grid{gap:10px;display:grid}.reward-card{border:2px solid var(--ink-soft);background:#fff;border-radius:12px;padding:10px;transition:all .3s}.reward-card img{object-fit:cover;border-radius:10px;width:100%;height:130px;transition:filter .3s}.reward-card h4,.reward-card p,.reward-card strong,.reward-card small{transition:color .3s}.reward-card.unavailable{opacity:.7;background:#f0f0f0;border-color:#d0d0d0}.reward-card.unavailable img{filter:grayscale()contrast(.8)}.reward-card.unavailable h4,.reward-card.unavailable p,.reward-card.unavailable strong,.reward-card.unavailable small{color:#999}.reward-card.unavailable button{cursor:not-allowed;opacity:.6;background:#999;border-color:#777}.reward-card.unavailable button:hover{box-shadow:none;transform:none}.reward-card.available{opacity:1}.rewards-section{grid-template-columns:1fr;gap:16px;display:grid}.rewards-list-container{flex-direction:column;gap:10px;display:flex}.rewards-list-container h4{color:var(--ink);margin:0;font-size:.95rem;font-weight:700}.admin-rewards-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.reward-item-admin{border:2px solid var(--ink-soft);text-align:center;background:#fff;border-radius:12px;flex-direction:column;align-items:center;gap:6px;padding:10px;display:flex}.reward-item-admin img{object-fit:cover;border-radius:8px;width:60px;height:60px}.reward-item-admin h5{margin:0;font-size:.85rem;font-weight:700;line-height:1.2}.reward-item-admin p{color:var(--muted);margin:0;font-size:.75rem;line-height:1.1}.cost-badge{background:linear-gradient(135deg,#ffe08a,#ffc300);border-radius:6px;padding:4px 8px;font-size:.75rem;font-weight:700}.reward-requirement-note,.reward-availability,.reward-balance-hint{color:var(--muted);font-size:.8rem}.reward-requirement-note{text-align:center;display:block}.no-rewards{color:var(--muted);margin:0;font-size:.9rem;font-style:italic}.rewards-form{border:2px dashed var(--ink-soft);box-sizing:border-box;background:#ffffffb3;border-radius:12px;grid-template-columns:1fr;gap:12px;width:100%;padding:14px;display:grid}.rewards-form h4{color:var(--ink);margin:0;font-size:.95rem;font-weight:700}.rewards-form label{gap:4px}.rewards-form input,.rewards-form textarea{font-size:.9rem}.reward-actions{justify-content:center;gap:6px;width:100%;margin-top:4px;display:flex}.edit-btn,.delete-btn,.cancel-btn{cursor:pointer;border:none;border-radius:6px;padding:4px 8px;font-size:.8rem;font-weight:600;transition:all .2s}.edit-btn{color:#004e89;background:#7dd3fc}.edit-btn:hover{color:#fff;background:#06b6d4}.delete-btn{color:#7f1d1d;background:#fecaca}.delete-btn:hover{color:#fff;background:#ef4444}.cancel-btn{color:#374151;background:#d1d5db;padding:2px 6px;font-size:.75rem}.cancel-btn:hover{color:#fff;background:#9ca3af}.form-header{justify-content:space-between;align-items:center;gap:10px;display:flex}.form-header h4{flex:1;margin:0}.modal-header-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.modal-header-row h2{margin:0}.modal-secondary-btn{white-space:nowrap}.admin-modal{box-sizing:border-box;width:min(96vw,920px);max-width:920px;max-height:90vh;overflow-y:auto}.admin-modal-note{color:var(--muted);margin:0 0 14px}.admin-users-layout{gap:18px;width:100%;min-width:0;display:grid}.admin-users-section{gap:12px;min-width:0;display:grid}.admin-users-section h4{margin:0}.admin-users-list{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;width:100%;min-width:0;display:grid}.admin-user-card,.cleanup-card{border:2px solid var(--ink-soft);box-sizing:border-box;background:#fff;border-radius:14px;min-width:0;padding:12px}.admin-user-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.admin-user-card p,.admin-user-card small,.cleanup-card p{overflow-wrap:anywhere;margin:6px 0 0}.role-badge{border-radius:999px;padding:4px 8px;font-size:.75rem;font-weight:800}.role-badge.admin{color:#1d4ed8;background:#dbeafe}.role-badge.kid{color:#15803d;background:#dcfce7}.admin-user-form{box-sizing:border-box;background:#fffdf7;border-style:solid;align-content:start;width:100%;min-width:0;max-width:none;margin:0 auto}.admin-users-form-section{border-top:2px solid #14182614;padding-top:4px}.admin-users-form-section::-webkit-scrollbar{width:8px}.admin-users-form-section::-webkit-scrollbar-thumb{background:#14182640;border-radius:999px}.admin-user-actions{justify-content:flex-start;margin-top:8px}.avatar-upload-section{background:#fffc;border:1px dashed #ddd;border-radius:8px;flex-direction:column;gap:12px;min-width:0;padding:12px;display:flex}.avatar-preview{object-fit:cover;border:2px solid #f77f00;border-radius:8px;width:100%;max-width:150px;height:150px;margin:0 auto;display:block}.avatar-upload-inputs{flex-direction:column;gap:8px;display:flex}.avatar-upload-inputs input[type=file]{border:2px solid var(--ink);cursor:pointer;background:#fff;border-radius:6px;padding:8px;font-size:.9rem}.avatar-upload-inputs input[type=file]::file-selector-button{color:#fff;cursor:pointer;background:#f77f00;border:none;border-radius:4px;margin-right:8px;padding:6px 12px;font-weight:700;transition:background .2s}.avatar-upload-inputs input[type=file]::file-selector-button:hover{background:#f93}.avatar-upload-inputs input[type=text]{box-sizing:border-box;border:2px solid var(--ink);border-radius:6px;width:100%;padding:8px;font-size:.9rem}.cleanup-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.cleanup-card{gap:10px;display:grid}.cleanup-card h4{margin:0}.cleanup-card-danger{background:#fff5f4;border-color:#d92d20}.cleanup-confirm-box{border:2px dashed var(--ink);background:#fffaf1;border-radius:14px;gap:10px;margin-top:16px;padding:14px;display:grid}.cleanup-confirm-box h4,.cleanup-confirm-box p{margin:0}.cleanup-confirm-actions{flex-wrap:wrap;gap:10px;display:flex}.timeline-panel{margin-bottom:30px}.week-board-container{margin-bottom:16px}.week-board{grid-template-columns:repeat(7,minmax(0,1fr));gap:10px;margin-top:12px;display:grid}.day-card{border:3px solid var(--ink-soft);text-align:center;background:#fff;border-radius:14px;flex-direction:column;gap:8px;padding:12px;transition:transform .2s,border-color .2s;display:flex}.day-card.active{background:linear-gradient(135deg,#ff8a001a,#ff4d6d0d);border-color:#ff8a00;transform:translateY(-4px)}.day-card.inactive{opacity:.6}.day-name{color:var(--ink);margin:0;font-size:.95rem;font-weight:800}.day-date{color:var(--muted);font-size:.75rem}.faces-row,.stars-row,.minutes-row{justify-content:center;align-items:center;gap:6px;min-height:24px;display:flex}.big-emoji{font-size:1.8rem;display:inline-block}.no-data{color:var(--ink-soft);font-size:.9rem}.star-emoji{font-size:1.6rem}.face-detail-list{flex-direction:column;gap:6px;width:100%;display:flex}.face-detail-item{background:#ffffffbf;border:1px solid #ff8a0033;border-radius:10px;justify-content:flex-start;align-items:center;gap:6px;padding:4px 6px;display:flex}.face-habit-name{text-align:left;color:var(--ink);font-size:.72rem;font-weight:700;line-height:1.15}.star-count{color:#ff8a00;font-size:1rem;font-weight:800}.minutes-row small{color:var(--muted);font-size:.75rem}@media (width<=1024px){.week-board{grid-template-columns:repeat(4,minmax(0,1fr))}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-layout,.kid-layout{grid-template-columns:1fr}.topbar{flex-direction:column;align-items:flex-start}.topbar-actions{flex-wrap:wrap;justify-content:space-between;width:100%}.admin-users-list,.cleanup-grid{grid-template-columns:1fr}.admin-rewards-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=640px){.week-board{grid-template-columns:repeat(3,minmax(0,1fr))}.admin-modal{max-height:92vh;padding:16px}.admin-users-form-section{max-height:52vh;padding-right:4px;overflow-y:auto}.admin-user-submit-btn{z-index:2;width:100%;position:sticky;bottom:0;box-shadow:0 -6px 14px #fffdf7f2}.admin-rewards-grid{grid-template-columns:1fr}.app-shell,.panel{padding:12px}.rewards-form input,.rewards-form textarea{padding:8px 10px;font-size:.85rem}button{padding:8px 12px;font-size:.9rem}}.modal-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;padding:16px;animation:.3s ease-out fadeIn;display:flex;position:fixed;inset:0;overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{box-sizing:border-box;background:#fff;border-radius:16px;width:90%;max-width:400px;padding:24px;animation:.4s cubic-bezier(.34,1.56,.64,1) popIn;box-shadow:0 10px 40px #0003}@keyframes popIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.modal-content h2{color:var(--ink);text-align:center;margin:0 0 16px;font-size:1.5rem}.celebration-content{text-align:center;background:linear-gradient(135deg,#e0f7fa,#fff3e0);border-radius:12px;margin-bottom:16px;padding:16px}.tablet-minutes{color:#d32f2f;margin:0 0 8px;font-size:1.2rem;font-weight:700}.reward-criteria-modal{color:#8a4b00;margin:0 0 8px;font-size:1rem;font-weight:700}.status-pending{color:#f57c00;font-weight:600}.status-approved{color:#388e3c;font-weight:600}.modal-close-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#7dd3fc,#06b6d4);border:none;border-radius:8px;width:100%;padding:12px;font-size:1rem;font-weight:700;transition:all .2s}.modal-close-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #06b6d466}.checkbox-label{cursor:pointer;align-items:center;gap:8px;font-weight:600;display:flex}.checkbox-label input{cursor:pointer;width:20px;height:20px}.checkbox-label span{flex:1}.redemptions-list{grid-template-columns:1fr;gap:12px;display:grid}.redemption-item{background:#fff;border:2px solid #e0e0e0;border-radius:10px;flex-direction:column;gap:8px;padding:12px;display:flex}.redemption-item.status-approved{background:#f1f8e9;border-color:#4caf50}.redemption-item.status-pending{background:#fff3e0;border-color:#ff9800}.redemption-item.status-rejected{background:#ffebee;border-color:#f44336}.redemption-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.redemption-header h5{margin:0;font-size:.9rem;font-weight:700}.status-badge{white-space:nowrap;border-radius:6px;padding:4px 8px;font-size:.75rem;font-weight:600}.status-badge.approved{color:#1b5e20;background:#c8e6c9}.status-badge.pending{color:#e65100;background:#ffe0b2}.status-badge.rejected{color:#b71c1c;background:#ffcdd2}.redemption-item p{color:var(--muted);margin:0;font-size:.8rem}.redemption-details{color:var(--ink);justify-content:space-between;font-size:.8rem;font-weight:600;display:flex}.pending-redemptions-list{grid-template-columns:1fr;gap:12px;display:grid}.habit-type-filter{justify-content:center;gap:12px;margin-bottom:20px;display:flex}.filter-btn{border:2px solid var(--ink);cursor:pointer;max-width:180px;color:var(--ink);background:#fff;border-radius:14px;flex:1;padding:14px 20px;font-size:1.1rem;font-weight:700;transition:all .25s}.filter-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #14182633}.filter-btn.active{color:#000;background:#ffd166;border-color:#f77f00;box-shadow:0 6px #f77f004d}.habit-search{border:2px solid var(--ink);background:#fffc;border-radius:10px;width:100%;margin-bottom:16px;padding:10px 14px;font-family:inherit;font-size:.95rem}.habit-search::placeholder{color:var(--muted)}.habit-grid-selector{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:24px;display:grid}.habit-card{cursor:pointer;background:#fff;border:2px solid #ddd;border-radius:14px;flex-direction:column;align-items:center;gap:8px;padding:12px;font-family:inherit;transition:all .2s;display:flex;position:relative;overflow:hidden}.habit-card:before{content:"";opacity:0;pointer-events:none;background:#ffd1661a;transition:opacity .2s;position:absolute;inset:0}.habit-card:hover{border-color:#f77f00;transform:translateY(-2px);box-shadow:0 4px 12px #f77f0026}.habit-card:hover:before{opacity:1}.habit-card.selected{background:#fffdf7;border:3px solid #f77f00;transform:scale(1.02);box-shadow:0 6px 16px #f77f0040}.habit-card.selected:before{opacity:1}.habit-card-img{object-fit:cover;border-radius:8px;width:50px;height:50px}.habit-card-header{flex-direction:column;flex:1;justify-content:space-between;align-items:center;gap:4px;display:flex}.habit-card-header h5{text-align:center;color:var(--ink);margin:0;font-size:.85rem;font-weight:700;line-height:1.2}.habit-badge{text-align:center;min-width:40px;font-size:1rem;display:inline-block}.no-habits-msg{text-align:center;color:var(--muted);grid-column:1/-1;padding:24px;font-size:.95rem}.pending-redemption-item{background:#fff;border:2px solid #fff9c4;border-radius:10px;flex-direction:column;gap:12px;padding:12px;display:flex}.pending-header{justify-content:space-between;gap:12px;display:flex}.pending-header h5{color:var(--ink);margin:0;font-size:.9rem;font-weight:700}.pending-header p{color:var(--muted);margin:2px 0 0;font-size:.8rem}.redm-details{color:var(--ink);text-align:right;flex-direction:column;gap:4px;min-width:120px;font-size:.8rem;font-weight:600;display:flex}.pending-actions{gap:8px;display:flex}.approve-btn,.reject-btn{cursor:pointer;border:none;border-radius:6px;flex:1;padding:8px;font-size:.8rem;font-weight:600;transition:all .2s}.approve-btn{color:#fff;background:#4caf50}.approve-btn:hover:not(:disabled){background:#45a049}.reject-btn{color:#fff;background:#f44336}.reject-btn:hover:not(:disabled){background:#da190b}.approve-btn:disabled,.reject-btn:disabled{opacity:.6;cursor:not-allowed}.star-redemption-section{background:linear-gradient(135deg,#fff9c4,#fffde7);border:2px dashed #f9a825;border-radius:12px;padding:16px;transition:all .3s}.star-redemption-section.unavailable{opacity:.6;background:linear-gradient(135deg,#f0f0f0,#e8e8e8);border-color:#ccc}.star-redemption-section.unavailable .star-input-group button{cursor:not-allowed;background:#999}.star-redemption-section.unavailable .star-input-group button:hover{background:#999;transform:none}.star-redemption-section.unavailable .redeem-stars-btn{cursor:not-allowed;background:#999;border-color:#777}.star-redemption-form{flex-direction:column;gap:16px;display:flex}.star-input-group{align-items:center;gap:8px;margin-top:4px;display:flex}.star-input-group button{color:#fff;cursor:pointer;background:#ffc107;border:none;border-radius:6px;width:40px;height:40px;padding:0;font-size:1.2rem;font-weight:700;transition:all .2s}.star-input-group button:hover:not(:disabled){background:#ffb300;transform:scale(1.05)}.star-input-group button:disabled{opacity:.5;cursor:not-allowed}.star-input-group input{text-align:center;color:#f57c00;border:2px solid #ffc107;border-radius:6px;flex:1;height:40px;padding:8px;font-size:1.1rem;font-weight:700}.star-calculation{background:#fff;border-left:4px solid #f9a825;border-radius:8px;padding:12px}.star-calculation p{color:var(--ink);margin:4px 0;font-size:.9rem}.star-calculation p strong{color:#d32f2f;font-size:1rem}.star-calculation .available{color:var(--muted);font-size:.85rem}.redeem-stars-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#ffc107,#ff9800);border:none;border-radius:8px;padding:12px 16px;font-size:1rem;font-weight:700;transition:all .3s}.redeem-stars-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ffc10766}.redeem-stars-btn:disabled{opacity:.6;cursor:not-allowed}@media (width<=1024px){.pending-header{flex-direction:column}.redm-details{text-align:left}}
