:root{color:#28231d;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;--panel:#fff;--ink-soft:#756657;--line:#eadfc8;--sun:#ffd86b;--sprout:#69b99d;--coral:#f37b65;--sky:#80bdd7;background:#fff9ea;font-family:Hiragino Sans,Yu Gothic UI,Yu Gothic,Meiryo,system-ui,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button{color:inherit;font:inherit}.app-shell{background:radial-gradient(circle at 0 0,#ffd86b47,#0000 32%),linear-gradient(#fff7df 0%,#fffdf7 46%,#eef8f4 100%);width:min(100%,460px);min-height:100vh;margin:0 auto;padding:18px 16px 96px}.top-bar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.eyebrow{color:#8a6a29;margin:0 0 4px;font-size:.75rem;font-weight:800}h1,h2,h3,p{margin:0}h1{font-size:1.55rem}h2{font-size:1.05rem}h3{font-size:.96rem}.icon-button{border:1px solid var(--line);background:var(--panel);border-radius:8px;place-items:center;width:44px;height:44px;display:grid}.page-tabs{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:14px;display:grid}.page-tabs button{border:1px solid var(--line);min-height:44px;color:var(--ink-soft);background:#ffffffb8;border-radius:8px;justify-content:center;align-items:center;gap:7px;font-weight:900;display:flex}.page-tabs button.active{color:#fff;background:#2f8f74;border-color:#9fd6c2}.kokko-stage{border:1px solid var(--line);background:#ffffffe0;border-radius:8px;padding:18px;box-shadow:0 18px 36px #6450301f}.kokko-card{grid-template-columns:132px 1fr;align-items:center;gap:14px;display:grid}.kokko-aura{aspect-ratio:1;background:#fff;border:1px solid #f4e2a1;border-radius:50%;place-items:center;width:132px;display:grid;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #f2dfaa,0 8px 18px #78531514}.kokko-image{object-fit:contain;filter:drop-shadow(0 8px 8px #78531524);border-radius:50%;width:132px;height:132px}.kokko-emoji{font-size:4.8rem;line-height:1;display:none}.kokko-copy{min-width:0}.kokko-copy h2{margin-bottom:8px;font-size:1.35rem}.kokko-copy p:last-child{color:var(--ink-soft);font-size:.86rem;line-height:1.55}.status-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-top:16px;display:grid}.status-tile{background:#f8fbf9;border:1px solid #d9eee5;border-radius:8px;padding:12px}.status-tile span{color:#2b7f68;font-size:1.35rem;font-weight:900;display:block}.status-tile p{color:var(--ink-soft);font-size:.8rem}.exp-panel{margin-top:14px}.exp-label{color:var(--ink-soft);justify-content:space-between;margin-bottom:8px;font-size:.8rem;font-weight:800;display:flex}.exp-track{background:#f1e8d5;border-radius:999px;height:12px;overflow:hidden}.exp-fill{border-radius:inherit;background:linear-gradient(90deg, var(--sprout), var(--sun), var(--coral));height:100%}.section-block{margin-top:16px}.section-title{align-items:center;gap:8px;margin-bottom:10px;display:flex}.section-title svg{color:#2b7f68}.stamp-calendar{background:#ffffffeb;border:1px solid #dcefe7;border-radius:8px;margin-top:16px;padding:16px;box-shadow:0 14px 28px #436c5c1a}.calendar-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.calendar-header .section-title{margin-bottom:4px}.calendar-header p{color:var(--ink-soft);font-size:.86rem;font-weight:800}.calendar-header strong{color:#8a5b00;text-align:center;background:#fff1c2;border-radius:8px;min-width:62px;padding:8px 10px;font-size:1.15rem}.month-calendar{grid-template-columns:repeat(7,minmax(0,1fr));gap:6px;display:grid}.weekday{color:#7d705f;place-items:center;min-height:24px;font-size:.76rem;font-weight:900;display:grid}.month-day{background:#fffdf8;border:1px solid #edf0e7;border-radius:8px;place-items:center;min-height:48px;display:grid;position:relative}.month-day span{color:#7d705f;font-size:.72rem;font-weight:900;position:absolute;top:5px;left:6px}.month-day b{line-height:1}.month-day.stamped{background:#fff8db;border-color:#f4d46d}.month-day.today{outline-offset:-2px;outline:2px solid #2f8f74}.month-day.blank{background:0 0;border-color:#0000}.stamp-mark{place-items:center;width:38px;height:38px;display:grid;transform:rotate(-8deg)}.stamp-mark.double{transform:rotate(7deg)}.stamp-mark.flower{transform:rotate(-12deg)}.stamp-svg{width:100%;height:100%;overflow:visible}.stamp-svg path{fill:none;stroke:#df5b4d;stroke-linecap:round;stroke-linejoin:round;stroke-width:3.4px;filter:drop-shadow(.7px .6px #df5b4d47)}.double-stamp path:last-child{stroke-width:2.7px}.flower-stamp path:first-child{stroke-width:3px}.flower-stamp path:last-child{stroke-width:2.6px}.chore-list{gap:8px;display:grid}.row-card,.food-card,.parent-panel{border:1px solid var(--line);background:var(--panel);border-radius:8px}.row-card{justify-content:space-between;align-items:center;gap:12px;min-height:72px;padding:12px;display:flex}.row-card p{color:var(--ink-soft);margin-top:5px;font-size:.82rem}.points-badge{color:#8a5b00;background:#fff1c2;border-radius:999px;flex:none;padding:7px 10px;font-size:.82rem;font-weight:900}.food-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.food-card{text-align:center;align-content:center;justify-items:center;gap:6px;min-height:124px;padding:10px 6px;display:grid}.food-card svg{color:var(--coral)}.food-card p{color:#8a5b00;font-weight:900}.food-card span{color:var(--ink-soft);font-size:.78rem}.parent-panel{padding:14px}.shop-page{margin-top:14px}.shop-hero{border:1px solid var(--line);background:#fff;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding:16px;display:flex}.shop-hero h2{font-size:1.28rem}.shop-hero svg{color:var(--coral)}.approval-button{color:#fff;background:#2f8f74;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;min-height:48px;font-weight:900;display:flex}@media (width<=390px){.kokko-card{grid-template-columns:108px 1fr}.kokko-aura{width:108px}.kokko-emoji{font-size:4rem}.kokko-image{width:108px;height:108px}}
