:root{--sky: #8dd7ff;--ink: #3d2b1f;--leaf: #65bf55;--sun: #ffdf5e;--cream: #fff8e7;--peach: #ffb28a;--pink: #ff7ba5;--teal: #4fb1a7;--blue: #62b6ff;--shadow: rgba(61, 43, 31, .22);color:var(--ink);font-family:Arial Rounded MT Bold,Avenir Next,Arial,sans-serif;font-synthesis:none;line-height:1.2;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#app{width:100%;height:100%;height:100dvh;margin:0}html{overflow:hidden;background:var(--sky);overscroll-behavior:none}body{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;background:var(--sky);touch-action:none;user-select:none;-webkit-touch-callout:none;-webkit-user-select:none;overscroll-behavior:none}button,input{font:inherit}button{border:0;cursor:pointer;touch-action:manipulation;user-select:none;-webkit-user-select:none}input{touch-action:manipulation;user-select:text;-webkit-user-select:text}#app{position:relative;isolation:isolate}#game{position:absolute;top:0;right:0;bottom:0;left:0}#game canvas{display:block}#hud{pointer-events:none;position:absolute;top:0;right:0;bottom:0;left:0;z-index:3}.branch-actions{position:absolute;top:0;right:0;bottom:0;left:0}.story-button,.story-card,.story-photo-link,.control-row,.branch-book,.family-form,.photo-viewer{pointer-events:auto}.story-card{position:absolute;top:max(14px,env(safe-area-inset-top));left:max(14px,env(safe-area-inset-left));width:min(360px,calc(100vw - 28px));display:grid;justify-items:start;gap:9px}.story-button{position:relative;width:100%;min-height:0;padding:12px 14px;display:grid;gap:2px;text-align:left;color:var(--ink);background:#fff8e7f5;border:5px solid #ffcf65;border-radius:22px;box-shadow:0 12px #92622c33,0 18px 28px var(--shadow)}.story-button:active,.story-photo-link:active,.hud-button:active,.branch-choice:active,.save-button:active,.danger-button:active,.icon-button:active{transform:translateY(4px)}.story-photo-link{min-height:42px;padding:8px 14px;color:var(--ink);background:#fff;border:4px solid #77cfe9;border-radius:999px;box-shadow:0 7px #2f709133,0 12px 18px var(--shadow);font-size:15px;font-weight:900}.story-card.has-photo .story-photo-link{background:#e7f8ff;border-color:#4aaed7}.story-name{font-size:clamp(21px,2.4vw,30px);font-weight:900}.story-relation{color:#7a5635;font-size:14px;font-weight:900;text-transform:uppercase}.story-birthday{width:fit-content;padding:3px 9px;color:#246982;background:#dff7ff;border:3px solid #77cfe9;border-radius:999px;font-size:13px;font-weight:900}.story-fact{font-size:clamp(14px,1.6vw,18px);font-weight:800}.control-row{position:absolute;right:max(14px,env(safe-area-inset-right));bottom:max(14px,env(safe-area-inset-bottom));width:min(410px,calc(100vw - 396px));min-width:300px;display:grid;grid-template-columns:repeat(4,minmax(72px,1fr));gap:10px}.hud-button{min-width:0;min-height:62px;padding:8px;color:var(--ink);background:#fff;border:5px solid #77c96a;border-radius:20px;box-shadow:0 8px #31702f3d,0 14px 22px var(--shadow);font-size:16px;font-weight:900}.hud-button.primary{background:#ffe070;border-color:#f09c3f}.hud-button.sound{border-color:var(--blue)}.hud-button.visit{background:#e7f8ff;border-color:#4aaed7}.branch-actions.visiting .control-row{gap:8px}.branch-actions.visiting .hud-button{min-width:66px;min-height:66px;padding:8px;font-size:16px}.branch-book{position:absolute;top:max(14px,env(safe-area-inset-top));right:max(14px,env(safe-area-inset-right));width:min(380px,calc(100vw - 28px));max-height:calc(100vh - 180px);overflow:auto;padding:12px;background:#fff8e7f7;border:5px solid #ffffff;border-radius:24px;box-shadow:0 16px 34px var(--shadow)}.branch-grid{display:grid;gap:9px}.branch-choice{min-height:64px;display:grid;grid-template-columns:28px 1fr;grid-template-rows:1fr 1fr;gap:0 10px;align-items:center;padding:9px 12px;text-align:left;color:var(--ink);background:#fff;border:4px solid transparent;border-radius:18px;font-weight:900}.branch-choice.selected{border-color:#ffcf65;background:#fff4c9}.branch-choice small{grid-column:2;color:#7a5635;font-size:13px;font-weight:900}.choice-dot{grid-row:1 / span 2;width:28px;height:28px;border-radius:50%;background:var(--branch-color);box-shadow:inset 0 0 0 4px #ffffff8c}#modal-root{position:absolute;top:0;right:0;bottom:0;left:0;z-index:4;pointer-events:none}.modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:max(18px,env(safe-area-inset-top)) max(18px,env(safe-area-inset-right)) max(18px,env(safe-area-inset-bottom)) max(18px,env(safe-area-inset-left));background:#2a363457;pointer-events:auto}.family-form{width:min(560px,100%);max-height:min(760px,calc(100vh - 36px));overflow:auto;display:grid;gap:14px;padding:18px;background:var(--cream);border:6px solid #ffffff;border-radius:28px;box-shadow:0 20px 46px #3d2b1f52}.photo-viewer{width:min(760px,100%);max-height:min(820px,calc(100vh - 36px));overflow:auto;display:grid;gap:14px;padding:18px;background:var(--cream);border:6px solid #ffffff;border-radius:28px;box-shadow:0 20px 46px #3d2b1f52}.form-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.form-top h1{margin:0;font-size:clamp(24px,4vw,34px)}.icon-button{width:54px;height:54px;color:#fff;background:#f27676;border-radius:50%;font-size:25px;font-weight:900;line-height:1}.family-form label{display:grid;gap:6px;color:#6e5137;font-size:15px;font-weight:900}.family-form input[type=text],.family-form input:not([type]){width:100%}.family-form input:not([type]){min-height:58px;padding:12px 14px;color:var(--ink);background:#fff;border:4px solid #ffd166;border-radius:18px;font-size:22px;font-weight:900;outline:none}.family-form input:not([type]):focus{border-color:var(--blue);box-shadow:0 0 0 4px #62b6ff38}fieldset{margin:0;padding:0;border:0}legend{margin-bottom:8px;color:#6e5137;font-size:15px;font-weight:900}.swatches{display:flex;gap:10px;flex-wrap:wrap}.swatch{display:block}.swatch input,.icon-picks input{position:absolute;opacity:0;pointer-events:none}.swatch span{width:46px;height:46px;display:block;border-radius:50%;background:var(--swatch);border:5px solid #ffffff;box-shadow:0 0 0 2px #3d2b1f24}.swatch input:checked+span,.icon-picks input:checked+span{outline:5px solid #3da7ff;outline-offset:2px}.icon-picks{display:flex;gap:8px;flex-wrap:wrap}.icon-picks label span{min-height:46px;display:grid;place-items:center;padding:0 14px;color:var(--ink);background:#fff;border:4px solid #74c66a;border-radius:16px;font-size:14px;text-transform:capitalize}.form-actions{display:flex;justify-content:flex-end;gap:12px;flex-wrap:wrap}.save-button,.danger-button{min-height:62px;padding:12px 18px;border-radius:20px;color:var(--ink);font-size:20px;font-weight:900}.save-button{background:#ffe070;border:5px solid #f09c3f}.danger-button{color:#fff;background:#e65f5f;border:5px solid #c44747}.danger-button.confirming{background:#ff9f66;border-color:#d87728}.photo-frame{min-height:280px;display:grid;place-items:center;overflow:hidden;background:#dff7ff;border:5px solid #77cfe9;border-radius:22px}.photo-frame.has-photo{background:#fff}.photo-frame img{max-width:100%;max-height:min(58vh,520px);display:block;object-fit:contain}.photo-empty{display:grid;gap:6px;padding:24px;text-align:center;color:#246982}.photo-empty strong{color:var(--ink);font-size:24px}.photo-empty span,.photo-error{font-size:15px;font-weight:900}.photo-error{min-height:20px;margin:0;color:#b84040}.photo-actions{display:flex;justify-content:flex-end;gap:12px;flex-wrap:wrap}.photo-picker{position:relative;display:inline-grid;place-items:center;cursor:pointer;overflow:hidden}.photo-file-input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}@media(max-width:840px),(orientation:portrait){.story-card{width:min(320px,calc(100vw - 28px))}.story-button{padding:10px 12px}.control-row{width:min(320px,calc(100vw - 28px));min-width:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr))}.hud-button{min-width:0;min-height:58px;padding:8px;font-size:16px;border-radius:18px}}@media(max-width:520px){.control-row{width:min(260px,calc(100vw - 28px));grid-template-columns:repeat(2,minmax(0,1fr))}.story-fact{display:none}}
