:root{--bg: #FBF3E4;--bg2: #F5E9D6;--card: #FFFFFF;--text: #5B4A42;--muted: #A08C7D;--accent: #FF9E7D;--accent2: #8BD3C7;--butter: #FFD98E;--line: rgba(91, 74, 66, .12);--inset: rgba(91, 74, 66, .06);--shadow: rgba(91, 74, 66, .14);--up: #3FBF94;--down: #F2766F}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{margin:0;height:100%}body{font-family:"M PLUS Rounded 1c",system-ui,Hiragino Maru Gothic ProN,Noto Sans JP,sans-serif;color:var(--text);background:radial-gradient(circle at 50% 0%,#FFFDF8,var(--bg));min-height:100dvh}button{font-family:inherit;cursor:pointer}.btn{background:var(--accent);color:#fff;border:none;border-radius:14px;padding:12px 20px;font-size:16px;font-weight:700;box-shadow:0 5px 14px #ff9e7d73;transition:transform .08s ease,opacity .2s}.btn:active{transform:scale(.96)}.btn:disabled{opacity:.5}.btn--big{width:100%;padding:18px;font-size:18px}.btn-ghost{background:var(--card);color:var(--text);border:1px solid var(--line);border-radius:12px;padding:8px 14px;font-size:14px}input{font-family:inherit;font-size:16px;padding:12px 14px;border-radius:12px;border:1px solid var(--line);background:var(--card);color:var(--text);width:100%}input::placeholder{color:var(--muted)}.loading{display:grid;place-items:center;min-height:100dvh;color:var(--muted)}.auth{max-width:420px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:24px}.auth__logo{font-size:64px}.auth__title{margin:0;font-size:32px}.auth__sub{margin:0 0 12px;color:var(--muted)}.auth__form{width:100%;display:flex;flex-direction:column;gap:12px}.auth__error,.app__error,.scanner__error{color:var(--down);font-size:14px;margin:0}.app{max-width:480px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column}.app__header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px}.app__brand{font-weight:800;font-size:18px}.app__header-actions{display:flex;align-items:center;gap:8px}.app__main{flex:1;padding:8px 18px 100px}.app__footer{position:fixed;bottom:0;left:0;right:0;max-width:480px;margin:0 auto;padding:14px 18px calc(14px + env(safe-area-inset-bottom));background:linear-gradient(to top,var(--bg),transparent)}.pet{display:flex;flex-direction:column;align-items:center;gap:8px}.pet__stage{width:100%;display:grid;place-items:center;padding:12px;background:radial-gradient(circle at 50% 40%,rgba(255,158,125,.16),transparent 70%)}.pet__svg{animation:bob 3s ease-in-out infinite}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.pet__svg--play{transform-origin:50% 85%;animation:pet-hop .7s ease}.pet__svg--pat{transform-origin:50% 85%;animation:pet-wiggle .6s ease}@keyframes pet-hop{0%{transform:translateY(0) rotate(0)}25%{transform:translateY(-24px) rotate(-5deg)}45%{transform:translateY(0) rotate(0)}62%{transform:translateY(-12px) rotate(4deg)}80%,to{transform:translateY(0) rotate(0)}}@keyframes pet-wiggle{0%,to{transform:rotate(0)}20%{transform:rotate(-7deg)}45%{transform:rotate(6deg)}70%{transform:rotate(-4deg)}88%{transform:rotate(2deg)}}.pet__name{margin:0;font-size:24px;display:flex;align-items:center;gap:6px}.pet__name-btn{background:transparent;border:none;font-size:16px;opacity:.6}.pet__name-edit{display:flex;gap:8px;width:100%;max-width:280px}.pet__name-edit input{text-align:center;font-size:18px}.switcher{display:flex;gap:8px;overflow-x:auto;padding:4px 2px 10px;width:100%;-webkit-overflow-scrolling:touch}.switcher__item{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:2px;background:var(--card);border:2px solid var(--line);border-radius:14px;padding:6px 8px;box-shadow:0 2px 8px var(--shadow)}.switcher__item.is-active{border-color:var(--accent2)}.switcher__lv{font-size:10px;color:var(--muted)}.switcher__add{flex:0 0 auto;width:56px;border:2px dashed var(--line);border-radius:14px;background:transparent;color:var(--muted);font-size:24px}.history{width:100%;max-width:380px;margin:16px auto 0}.history__title{font-size:16px;margin:0 0 8px;display:flex;align-items:center;gap:8px}.history__count{font-size:12px;color:var(--muted);font-weight:400}.history__empty{color:var(--muted);font-size:13px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px;margin:0}.history__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.history__item{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:8px 12px;box-shadow:0 2px 8px var(--shadow)}.history__row{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.history__food{font-weight:700;font-size:14px}.history__date{font-size:11px;color:var(--muted);flex:0 0 auto}.history__narration{margin:4px 0 0;font-size:12px;color:var(--muted)}.history__fav{margin:0 0 8px;font-size:12px;color:var(--muted)}.history__controls{display:flex;gap:8px;margin-bottom:8px}.history__search{flex:1 1 auto;min-width:0;padding:7px 12px;border-radius:999px;border:1px solid var(--line);background:var(--card);color:var(--text);font-size:13px}.history__search::placeholder{color:var(--muted)}.history__sort{flex:0 0 auto;padding:7px 12px;border-radius:999px;border:1px solid var(--line);background:var(--card);color:var(--text);font-size:12px;cursor:pointer}.history__sort.is-active{border-color:var(--accent);color:var(--accent)}.history__chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.chip{font-size:12px;padding:4px 12px;border-radius:999px;border:1px solid var(--line);background:var(--card);color:var(--muted);cursor:pointer}.chip.is-active{background:var(--accent);border-color:var(--accent);color:#fff}.history__times{margin-left:6px;font-size:11px;color:var(--accent2);font-weight:600}.pdetail{width:100%;background:var(--inset);border-radius:12px;padding:10px 12px;display:flex;flex-direction:column;gap:6px;text-align:left}.pdetail__source{font-size:11px;color:var(--muted)}.pdetail__row,.ptags{display:flex;flex-wrap:wrap;gap:5px;align-items:center}.ptags{margin-top:4px}.ptag{font-size:11px;padding:2px 8px;border-radius:999px;background:var(--inset);color:var(--text)}.ptag--warn{background:#f2766f2e;color:#c9473f}.pdetail__line{margin:0;font-size:12px;color:var(--text)}.pdetail__k{color:var(--muted);margin-right:6px;font-size:11px}.pdetail__ingredients{margin:0;font-size:11px;color:var(--muted);line-height:1.4;max-height:3.2em;overflow:hidden}.app__delete{display:block;margin:18px auto 0;background:transparent;border:1px solid rgba(242,118,111,.4);color:var(--down);border-radius:10px;padding:8px 14px;font-size:13px}.pet__meta{display:flex;gap:10px;align-items:center}.pet__lv{background:var(--accent);color:#fff;border-radius:999px;padding:2px 12px;font-weight:700;font-size:14px}.pet__element{color:var(--muted);font-size:14px}.pet__stage-badge{background:var(--butter);color:#7a5a2e;border-radius:999px;padding:2px 10px;font-size:12px;font-weight:700}.pet__title{margin:6px 0 2px;font-size:13px;color:var(--text);text-align:center}.pet__title-hint{color:var(--muted);font-size:11px}.pet__actions{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin:6px 0 2px}.pet__action{font-size:13px}.pet__action:disabled{opacity:.5}.pet__care-msg{margin:2px 0 0;font-size:12px;color:var(--accent2);text-align:center}.pet__exp{width:100%;max-width:320px}.pet__exp-bar{height:10px;background:var(--inset);border-radius:999px;overflow:hidden}.pet__exp-fill{height:100%;background:linear-gradient(90deg,var(--accent2),#6FC2B4);transition:width .5s ease}.pet__exp-text{display:block;text-align:center;font-size:12px;color:var(--muted);margin-top:4px}.pet__personality{text-align:center;color:var(--text);background:var(--card);border:1px solid var(--line);border-radius:14px;padding:10px 14px;margin:4px 0;font-size:14px;max-width:360px;box-shadow:0 2px 8px var(--shadow)}.pet__stats{width:100%;max-width:360px;display:flex;flex-direction:column;gap:8px;margin-top:4px}.stat{display:grid;grid-template-columns:64px 1fr 36px;align-items:center;gap:8px;font-size:13px}.stat__label{color:var(--muted)}.stat__bar{height:8px;background:var(--inset);border-radius:999px;overflow:hidden}.stat__fill{height:100%;background:var(--accent2);transition:width .5s ease}.stat__val{text-align:right}.sheet{position:fixed;top:0;right:0;bottom:0;left:0;background:#3c2e2673;display:flex;align-items:flex-end;z-index:20}.scanner{width:100%;max-width:480px;margin:0 auto;background:var(--bg2);border-radius:20px 20px 0 0;padding:18px;display:flex;flex-direction:column;gap:12px}.scanner__header{display:flex;justify-content:space-between;align-items:center;font-weight:700}.scanner__view{position:relative;border-radius:14px;overflow:hidden;background:#000;aspect-ratio:4 / 3}.scanner__video{width:100%;height:100%;object-fit:cover}.scanner__frame{position:absolute;top:18%;right:12%;bottom:18%;left:12%;border:3px solid rgba(255,255,255,.85);border-radius:12px;box-shadow:0 0 0 9999px #00000040}.scanner__placeholder{display:grid;place-items:center;aspect-ratio:4 / 3;background:#000;border-radius:14px;color:var(--muted)}.scanner__manual{display:flex;gap:8px}.scanner__busy{text-align:center;color:var(--accent2);margin:0}.scanner__zoom{display:flex;align-items:center;gap:10px;font-size:16px}.scanner__zoom input[type=range]{flex:1;accent-color:var(--accent)}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#3c2e2673;display:grid;place-items:center;z-index:30;padding:20px}.modal__card{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:22px;width:100%;max-width:360px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;box-shadow:0 2px 8px var(--shadow);animation:pop .25s ease}@keyframes pop{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.modal__badge{background:var(--butter);color:#7a5a2e;font-weight:800;padding:6px 16px;border-radius:999px}.modal__food{font-weight:700;margin:4px 0 0}.modal__narration{color:var(--muted);margin:0;font-size:14px}.modal__deltas{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.delta{font-size:13px;font-weight:700;padding:3px 10px;border-radius:999px;background:var(--inset)}.delta--up{color:var(--up)}.delta--down{color:var(--down)}.delta--exp{color:#d98a2b}.modal__element{color:var(--muted);font-size:13px;margin:0}.modal__bonus{margin:0;font-size:13px;font-weight:700;color:#d98a2b;text-align:center}.app__dex-btn{width:100%;max-width:380px;margin:14px auto 0}.farewell__actions{display:flex;gap:10px;margin-top:6px;width:100%;justify-content:center}.farewell__confirm{background:var(--down);box-shadow:0 5px 14px #f2766f73}.summary{width:100%;max-width:380px;margin:16px auto 0}.summary__toggle{width:100%;background:var(--card);border:1px solid var(--line);color:var(--text);border-radius:12px;padding:10px 14px;font-size:15px;font-weight:700;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px var(--shadow)}.summary__hint{color:var(--muted);font-size:12px}.summary__body{margin-top:8px;display:flex;flex-direction:column;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px 14px;box-shadow:0 2px 8px var(--shadow)}.summary__sec{display:flex;flex-direction:column;gap:6px}.summary__h{margin:0;font-size:13px;color:var(--muted)}.summary__empty{margin:0;font-size:12px;color:var(--muted)}.summary__bars{display:flex;flex-direction:column;gap:5px}.sbar{display:grid;grid-template-columns:72px 1fr 28px;align-items:center;gap:8px;font-size:12px}.sbar__label{color:var(--muted)}.sbar__track{height:8px;background:var(--inset);border-radius:999px;overflow:hidden}.sbar__fill{height:100%;background:linear-gradient(90deg,var(--accent2),#6FC2B4)}.sbar__val{text-align:right}.summary__line{margin:0;font-size:13px}.summary__sub{color:var(--muted);font-size:11px}.summary__chips{display:flex;flex-wrap:wrap;gap:5px}.modal__card.dex{max-width:420px;width:92%;max-height:86vh;display:flex;flex-direction:column;gap:10px}.dex__title{margin:0;font-size:17px}.dex__tabs{display:flex;gap:8px}.dex__tab{flex:1;background:var(--bg2);border:1px solid var(--line);color:var(--muted);border-radius:999px;padding:7px 10px;font-size:13px;cursor:pointer}.dex__tab.is-active{background:var(--accent);border-color:var(--accent);color:#fff}.dex__count{font-size:11px;opacity:.8}.dex__body{overflow-y:auto;flex:1}.dex__empty{color:var(--muted);font-size:13px}.dex__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.dexcard{position:relative;background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:8px 4px 6px;display:flex;flex-direction:column;align-items:center;gap:2px;box-shadow:0 2px 8px var(--shadow)}.dexcard__kind{position:absolute;top:4px;left:4px;font-size:9px;font-weight:700;padding:1px 6px;border-radius:999px;background:var(--inset);color:var(--text)}.kind--birth{background:#8bd3c74d;color:#2f7a6e}.kind--evolution{background:#ffd98e73;color:#9a6b16}.kind--farewell{background:#f2766f38;color:#c0463f}.kind--alive{background:#3fbf9438;color:#1f8a63}.dexcard__name{font-size:11px;font-weight:700;text-align:center;line-height:1.2}.dexcard__meta{font-size:10px;color:var(--muted);text-align:center}.dexcard__date{font-size:9px;color:var(--muted)}.dexcard--btn{border:none;cursor:pointer;font:inherit;color:inherit}.dexcard__more{font-size:9px;color:var(--accent2);font-weight:700}.dexdetail{display:flex;flex-direction:column;gap:10px}.dexdetail__back{align-self:flex-start;background:var(--bg2);border:1px solid var(--line);color:var(--text);border-radius:999px;padding:5px 12px;font-size:12px;cursor:pointer}.dexdetail__name{margin:0;font-size:14px;text-align:center}.dexstages{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:4px}.dexstage{display:flex;align-items:center;gap:4px}.dexstage__arrow{color:var(--muted);font-size:16px}.dexstage__card{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:8px 6px;display:flex;flex-direction:column;align-items:center;gap:2px;min-width:96px}.dexstage__label{font-size:10px;font-weight:700;color:var(--accent2)}.dexstage__meta{font-size:10px;color:var(--muted)}.dexstage__date{font-size:9px;color:var(--muted)}
