@import"https://fonts.googleapis.com/css2?family=Fredoka+One&family=Nunito:wght@400;600;700;800&family=Inter:wght@400;500;600&display=swap";.child-page{min-height:100vh;background:var(--bg-child);font-family:var(--font-body);overflow-x:hidden;padding-bottom:3rem}.child-loading,.child-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem;text-align:center;font-family:var(--font-body);font-size:1.2rem;color:#555;padding:2rem}.child-loading__spinner{font-size:3rem;animation:spin 1.5s linear infinite}.child-error div:first-child{font-size:4rem}.child-error h2{font-family:var(--font-child);font-size:1.8rem;color:#333}@keyframes spin{to{transform:rotate(360deg)}}.child-header{position:relative;background:linear-gradient(135deg,#ffb347,#ff6b6b,#c850c0);padding:2.5rem 2rem 5rem;overflow:hidden}.child-header__wave{position:absolute;bottom:-2px;left:0;right:0;height:60px;background:var(--bg-child);clip-path:ellipse(55% 100% at 50% 100%)}.child-header__content{position:relative;text-align:center;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.15)}.child-header__name{font-family:var(--font-child);font-size:clamp(1.8rem,5vw,3rem);letter-spacing:.01em;margin-bottom:.5rem}.child-header__subtitle{font-family:var(--font-body);font-size:clamp(.9rem,2.5vw,1.2rem);font-weight:600;opacity:.9}.jars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;padding:1.5rem 1rem 1rem;max-width:520px;margin:0 auto}@media (max-width: 480px){.jars-grid{grid-template-columns:1fr;max-width:260px}}.jar{background:#ffffffb8;border:2px solid rgba(0,0,0,.06);border-radius:22px;padding:.75rem .5rem .6rem;display:flex;flex-direction:column;align-items:center;gap:.25rem;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;cursor:pointer;box-shadow:0 2px 10px #0000000f}.jar:active{transform:scale(.96)}.jar--active,.jar:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a;border-color:#0000001a}.jar--active canvas,.jar:hover canvas{filter:drop-shadow(0 6px 12px rgba(0,0,0,.15))}.jar__emoji{font-size:clamp(2rem,5vw,2.8rem);line-height:1;animation:bounce 2s ease-in-out infinite}.jar--active .jar__emoji{animation:wiggle .5s ease}.jar__label{font-family:var(--font-child);font-size:clamp(.9rem,2.5vw,1.2rem);letter-spacing:.02em;margin-bottom:.2rem}.jar__amount{font-family:var(--font-child);font-size:clamp(1.2rem,3.5vw,1.7rem);font-weight:400;margin-top:.15rem}.jar__tap-hint{font-size:.65rem;font-weight:700;opacity:0;text-transform:uppercase;letter-spacing:.1em;transition:opacity .2s}.jar:hover .jar__tap-hint,.jar--active .jar__tap-hint{opacity:.6}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes wiggle{0%{transform:rotate(0)}25%{transform:rotate(-8deg)}75%{transform:rotate(8deg)}to{transform:rotate(0)}}.items-panel{margin:.75rem 1rem 0;max-width:520px;margin-left:auto;margin-right:auto;border-radius:20px;padding:1.25rem;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.items-panel__title{font-family:var(--font-child);font-size:clamp(1rem,3vw,1.3rem);color:#333;margin-bottom:1rem;text-align:center}.items-panel__empty{text-align:center;padding:1.5rem;color:#666;font-weight:600}.items-panel__empty span{font-size:2.5rem;display:block;margin-bottom:.5rem}.items-section{border-radius:16px;padding:.75rem;margin-bottom:.75rem}.items-section--yes{background:#22c55e1a;border:2px solid rgba(34,197,94,.4)}.items-section--no{background:#ef44440f;border:2px solid rgba(239,68,68,.25)}.items-section__label{font-family:var(--font-child);font-size:.95rem;font-weight:400;margin-bottom:.6rem;color:#333}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.6rem}.item-card{background:#fff;border:1.5px solid transparent;border-radius:16px;box-shadow:0 2px 8px #0000000f;position:relative;overflow:hidden;display:flex;flex-direction:column}.item-card--dimmed{opacity:.55}.item-card__tap{background:none;border:none;padding:.75rem .5rem .5rem;display:flex;flex-direction:column;align-items:center;gap:.25rem;cursor:pointer;width:100%;transition:transform .15s ease}.item-card__tap:active{transform:scale(.96)}.item-card:not(.item-card--dimmed):hover{box-shadow:0 6px 20px #0000001f;transform:translateY(-2px)}.item-card__img{width:52px;height:52px;object-fit:contain;border-radius:8px}.item-card__emoji{font-size:2rem;line-height:1}.item-card__name{font-weight:700;font-size:.75rem;color:#333;text-align:center;line-height:1.2}.item-card__price{font-family:var(--font-child);font-size:1rem}.item-card__speaker{font-size:.7rem;opacity:.35}.item-card__link{display:block;text-align:center;padding:4px;font-size:.8rem;border-top:1px solid rgba(0,0,0,.06);text-decoration:none;color:#555;background:#00000005;transition:background .15s}.item-card__link:hover{background:#0000000f}.confetti-layer{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:100;overflow:hidden}.confetti-piece{position:absolute;top:-10%;font-size:1.5rem;animation:confettiFall 1.8s ease-in forwards}@keyframes confettiFall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(110vh) rotate(720deg);opacity:0}}.admin-layout{display:flex;min-height:100vh;font-family:var(--font-admin);background:var(--bg-admin)}.admin-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-family:var(--font-admin);color:var(--text-muted)}.admin-sidebar{width:220px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto}.admin-sidebar__brand{display:flex;align-items:center;gap:.6rem;padding:1.5rem 1.25rem 1rem;font-family:var(--font-child);font-size:1.2rem;color:var(--text);border-bottom:1px solid var(--border);margin-bottom:.5rem}.admin-nav{display:flex;flex-direction:column;gap:2px;padding:0 .5rem;flex:1}.admin-nav__item{display:flex;align-items:center;gap:.6rem;padding:.6rem .75rem;border-radius:10px;font-size:.875rem;font-weight:500;color:var(--text-muted);text-decoration:none;transition:all .15s ease}.admin-nav__item:hover{background:var(--bg-admin);color:var(--text)}.admin-nav__item--active{background:var(--accent-light);color:var(--accent);font-weight:600}.admin-sidebar__footer{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-top:1px solid var(--border)}.admin-sidebar__user{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;color:var(--text)}.admin-sidebar__avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}.admin-sidebar__logout{background:none;font-size:1.1rem;color:var(--text-muted);padding:4px 8px;border-radius:6px;transition:all .15s}.admin-sidebar__logout:hover{background:#fee2e2;color:#ef4444}.admin-content{flex:1;overflow-y:auto;padding:2rem}@media (max-width: 768px){.admin-layout{flex-direction:column;padding-bottom:64px}.admin-sidebar{position:fixed;bottom:0;left:0;right:0;top:auto;width:100%;height:64px;flex-direction:row;align-items:stretch;border-right:none;border-top:1px solid var(--border);padding:0;z-index:100;overflow:visible}.admin-sidebar__brand,.admin-sidebar__footer{display:none}.admin-nav{flex-direction:row;flex:1;padding:0;gap:0;align-items:stretch}.admin-nav__item{flex:1;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:6px 4px;border-radius:0;font-size:.6rem;font-weight:600}.admin-nav__item span:first-child{font-size:1.3rem;line-height:1}.admin-nav__item span:last-child{display:block}.admin-nav__item--active{background:var(--accent-light);color:var(--accent);border-radius:0}.admin-content{padding:1rem;flex:1}}.admin-section{max-width:1000px}.admin-section__header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.admin-section__title{font-size:1.5rem;font-weight:700;color:var(--text)}.admin-section__subtitle{font-size:.875rem;color:var(--text-muted);margin-top:.2rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;box-shadow:0 1px 4px #0000000a}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;display:flex;flex-direction:column;gap:.3rem}.stat-card__label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.stat-card__value{font-size:1.75rem;font-weight:700;color:var(--text)}.stat-card__sub{font-size:.8rem;color:var(--text-muted)}.data-table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table th{text-align:left;padding:.6rem 1rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap}.data-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border);color:var(--text)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg-admin)}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:20px;font-size:.75rem;font-weight:700}.badge--spend{background:var(--spend-light);color:#c0392b}.badge--save{background:var(--save-light);color:#16a085}.badge--give{background:var(--give-light);color:#b7950b}.badge--interest{background:#eef0ff;color:#6c63ff}.badge--allowance{background:#f0fff4;color:#276749}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1rem;border-radius:10px;font-size:.875rem;font-weight:600;transition:all .15s ease}.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover{background:#5a52d5;transform:translateY(-1px)}.btn--secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn--secondary:hover{border-color:var(--accent);color:var(--accent)}.btn--danger{background:#fee2e2;color:#dc2626}.btn--danger:hover{background:#fecaca}.btn--sm{padding:.3rem .6rem;font-size:.8rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.form-field{display:flex;flex-direction:column;gap:.4rem}.form-field label{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.form-field input,.form-field select,.form-field textarea{padding:.55rem .75rem;border:1px solid var(--border);border-radius:8px;font-size:.9rem;color:var(--text);background:#fff;transition:border-color .15s}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #6c63ff1a}.amount-positive{color:#16a34a;font-weight:700}.amount-negative{color:#dc2626;font-weight:700}.login-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-family:var(--font-admin);padding:2rem}.login-card{background:#fff;border-radius:24px;padding:3rem 2.5rem;text-align:center;box-shadow:0 20px 60px #0003;max-width:360px;width:100%}.login-card__icon{font-size:3.5rem;margin-bottom:.5rem}.login-card__title{font-family:var(--font-child);font-size:2rem;color:#1a1a2e;margin-bottom:.25rem}.login-card__subtitle{color:var(--text-muted);font-size:.9rem;margin-bottom:2rem}.login-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.85rem 1.5rem;background:#fff;border:2px solid #E5E7EB;border-radius:12px;font-size:.95rem;font-weight:600;color:#374151;transition:all .2s ease;margin-bottom:1.5rem}.login-btn:hover{border-color:#667eea;box-shadow:0 4px 16px #667eea33;transform:translateY(-1px)}.login-card__note{font-size:.75rem;color:var(--text-muted)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--spend: #FF6B6B;--spend-light: #FFE5E5;--save: #4ECDC4;--save-light: #E0FAF8;--give: #FFD93D;--give-light: #FFF8DC;--bg-child: #FFF9F0;--font-child: "Fredoka One", cursive;--font-body: "Nunito", sans-serif;--bg-admin: #F7F8FA;--surface: #FFFFFF;--border: #E5E7EB;--text: #111827;--text-muted: #6B7280;--accent: #6C63FF;--accent-light: #EEF0FF;--font-admin: "Inter", sans-serif;--radius: 16px;--radius-sm: 8px;--shadow: 0 4px 24px rgba(0,0,0,.08);--shadow-lg: 0 8px 40px rgba(0,0,0,.12)}html,body,#root{height:100%}body{font-family:var(--font-body)}button{cursor:pointer;border:none;font-family:inherit}input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
