:root{--bg: #0c1a1a;--bg-card: #132626;--bg-hover: #1a3333;--accent: #f0a050;--accent-dim: #b07030;--text: #e8e4d8;--text-dim: #7a9a8a;--success: #4ade80;--warning: #fbbf24;--border: #1e3a3a;--bar-bg: #0a1515;--bar-fill: #f0a050;--bar-xp: #38bdf8;--card-shadow: 0 1px 4px rgba(0, 0, 0, .3);--phase-sky: #1a2a3a;--phase-glow: rgba(240, 160, 80, .3)}.phase-bare_hands{--accent: #c8b090;--accent-dim: #8a7a60;--bar-fill: #c8b090;--phase-sky: #1a2535;--phase-glow: rgba(200, 176, 144, .2)}.phase-bamboo{--accent: #7bc67b;--accent-dim: #4a8a4a;--bar-fill: #7bc67b;--phase-sky: #152a20;--phase-glow: rgba(123, 198, 123, .2)}.phase-fire{--accent: #f0a050;--accent-dim: #b07030;--bar-fill: #f0a050;--phase-sky: #251a10;--phase-glow: rgba(240, 160, 80, .3)}.phase-stone{--accent: #a0a8b8;--accent-dim: #6a7080;--bar-fill: #a0a8b8;--phase-sky: #1a1a22;--phase-glow: rgba(160, 168, 184, .2)}.phase-maritime{--accent: #50b0d0;--accent-dim: #307088;--bar-fill: #50b0d0;--phase-sky: #0c1a2a;--phase-glow: rgba(80, 176, 208, .3)}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg);background-image:radial-gradient(ellipse at 50% 0%,var(--phase-sky) 0%,var(--bg) 70%);transition:background-image 1.5s ease;color:var(--text);font-family:Segoe UI,system-ui,-apple-system,sans-serif;min-height:100dvh}.app{max-width:480px;margin:0 auto;display:flex;flex-direction:column;min-height:100dvh}.update-bar{background:var(--accent);color:var(--bg);text-align:center;padding:8px 16px;font-size:.82rem;font-weight:600;cursor:pointer;-webkit-user-select:none;user-select:none}.header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.header h1{font-size:1.25rem;color:var(--accent);letter-spacing:.05em;text-shadow:0 0 12px var(--phase-glow);transition:color 1s ease,text-shadow 1s ease}.header-actions{display:flex;gap:8px;align-items:center}.log-toggle-btn{background:transparent;border:1px solid var(--border);color:var(--text-dim);padding:4px 10px;border-radius:4px;font-size:.75rem;cursor:pointer}.log-toggle-btn:hover{border-color:var(--text-dim);color:var(--text)}.log-toggle-btn.active{border-color:var(--accent);color:var(--accent)}.log-drawer{max-height:200px;overflow-y:auto;padding:8px 16px;border-bottom:1px solid var(--border);background:var(--bg-card)}.settings-wrapper{position:relative}.settings-btn{background:transparent;border:1px solid var(--border);color:var(--text-dim);padding:4px 10px;border-radius:4px;font-size:.75rem;cursor:pointer}.settings-btn:hover{border-color:var(--accent);color:var(--accent)}.settings-menu{position:absolute;top:100%;right:0;margin-top:4px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;overflow:hidden;z-index:100;min-width:140px}.settings-menu-item{display:block;width:100%;background:transparent;border:none;color:var(--text);font-size:.8rem;padding:8px 14px;text-align:left;cursor:pointer}.settings-menu-item:hover{background:var(--bg-hover)}.settings-menu-item.danger{color:#f87171}.settings-menu-item.danger:hover{background:#f871711a}.app-body{display:flex;flex:1;min-height:0}.app-main{flex:1;display:flex;flex-direction:column;min-height:0}.inventory-sidebar{display:none}.resource-panel{display:flex;flex-wrap:wrap;gap:6px;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--bg-card)}.resource-chip{font-size:.75rem;background:var(--bar-bg);border:1px solid var(--border);border-radius:4px;padding:3px 8px;color:var(--text);white-space:nowrap}.resource-chip .amount{color:var(--success);font-weight:600}.resource-chip.at-cap{border-color:var(--warning)}.resource-chip.at-cap .amount{color:var(--warning)}.morale-chip{display:flex;align-items:center;gap:4px}.morale-chip{cursor:pointer}.morale-chip.low-morale{border-color:var(--accent)}.morale-tooltip{display:inline-block;font-size:.78rem;color:var(--text-dim);background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:4px 8px;cursor:pointer}.morale-chip.low-morale .amount{color:var(--accent)}.morale-bar-mini{display:inline-block;width:32px;height:6px;background:var(--bar-bg);border-radius:3px;overflow:hidden;vertical-align:middle}.morale-bar-fill{display:block;height:100%;background:var(--success);border-radius:3px;transition:width .3s}.low-morale .morale-bar-fill{background:var(--accent)}.morale-display{margin-bottom:10px;padding:8px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px}.morale-display.low-morale{border-color:var(--accent)}.morale-label{font-size:.78rem;font-weight:600}.morale-effect{font-weight:400;color:var(--text-dim);font-size:.7rem}.morale-bar{height:6px;background:var(--bar-bg);border-radius:3px;overflow:hidden;margin-top:4px}.morale-display .morale-bar-fill{display:block;height:100%;background:var(--success);border-radius:3px;transition:width .3s}.morale-display.low-morale .morale-bar-fill{background:var(--accent)}.current-action{padding:10px 16px;background:var(--bg-card);border-bottom:1px solid var(--border)}.current-action-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.current-action-name{font-size:.85rem;font-weight:600}.stop-btn{background:var(--accent-dim);border:none;color:#fff;padding:3px 10px;border-radius:4px;font-size:.75rem;cursor:pointer}.progress-bar{height:8px;background:var(--bar-bg);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--bar-fill),#f5c070,var(--bar-fill));background-size:200% 100%;border-radius:4px;transition:width .1s linear;animation:progress-shimmer 2s ease-in-out infinite;box-shadow:0 0 8px #f0a05066}@keyframes progress-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.progress-time{font-size:.7rem;color:var(--text-dim)}.repetition-status{margin-top:4px;font-size:.72rem;color:var(--text-dim)}.repetition-status.penalty{color:var(--warning)}.tabs{display:flex;border-bottom:1px solid var(--border)}.tab{flex:1;padding:10px;background:transparent;border:none;color:var(--text-dim);font-size:.85rem;cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent);text-shadow:0 0 8px rgba(240,160,80,.25)}.panel{flex:1;overflow-y:auto;padding:12px 16px}.action-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:12px;margin-bottom:8px;cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s;box-shadow:var(--card-shadow)}.action-card:hover:not(.disabled){border-color:var(--accent);transform:translateY(-1px);box-shadow:0 3px 12px #f0a05026}.action-card:active:not(.disabled){transform:translateY(0)}.action-card.active{border-color:var(--accent);box-shadow:0 0 0 2px #f0a05040,var(--card-shadow)}.action-card.disabled{opacity:.5;cursor:not-allowed}.action-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.action-name{font-weight:600;font-size:.9rem}.action-time{font-size:.75rem;color:var(--text-dim)}.action-desc{font-size:.78rem;color:var(--text-dim);margin-bottom:6px}.action-drops,.action-requires{font-size:.72rem;color:var(--text-dim)}.action-drops span{color:var(--success)}.action-requires span{color:var(--warning)}.action-xp{font-size:.72rem;color:var(--bar-xp)}.recipe-inputs{font-size:.72rem;color:var(--text-dim)}.recipe-inputs .has{color:var(--success)}.recipe-inputs .missing{color:var(--accent)}.recipe-output{font-size:.72rem;color:var(--success);font-weight:600}.skill-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:12px;margin-bottom:8px;box-shadow:var(--card-shadow)}.skill-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.skill-name{font-weight:600;font-size:.9rem}.skill-level{font-size:.8rem;color:var(--bar-xp);font-weight:600}.xp-bar{height:6px;background:var(--bar-bg);border-radius:3px;overflow:hidden;margin-top:4px}.xp-fill{height:100%;background:linear-gradient(90deg,var(--bar-xp),#7dd3fc,var(--bar-xp));background-size:200% 100%;border-radius:3px;transition:width .3s;box-shadow:0 0 6px #38bdf84d}.xp-text{font-size:.7rem;color:var(--text-dim);margin-top:2px}.milestone-list{margin-top:8px;border-top:1px solid var(--border);padding-top:6px}.milestone{display:flex;gap:8px;font-size:.72rem;padding:2px 0}.milestone-level{flex-shrink:0;font-weight:600;min-width:36px}.milestone.achieved .milestone-level{color:var(--success)}.milestone.achieved .milestone-desc,.milestone.upcoming .milestone-level{color:var(--text-dim)}.milestone.upcoming .milestone-desc{color:var(--text-dim);opacity:.6}.log-entry{font-size:.78rem;color:var(--text);padding:6px 0;border-bottom:1px solid var(--border);display:flex;align-items:baseline;gap:6px}.log-time{color:var(--text-dim);font-size:.65rem;flex-shrink:0}.log-type{font-size:.6rem;text-transform:uppercase;letter-spacing:.05em;padding:1px 5px;border-radius:3px;flex-shrink:0;background:var(--border);color:var(--text-dim)}.log-biome .log-type{color:var(--success);background:#4ade8018}.log-level .log-type{color:var(--warning);background:#fbbf2418}.log-building .log-type{color:var(--accent);background:#f0a05018}.log-resource .log-type{color:var(--bar-xp);background:#38bdf818}.log-craft .log-type{color:#c084fc;background:#c084fc18}.section-title{font-size:.75rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;margin:12px 0 6px}.section-title:first-child{margin-top:0}.section-title.collapsible{cursor:pointer;display:flex;align-items:center;gap:4px;user-select:none;-webkit-user-select:none;padding:4px 0}.section-title.collapsible:active{opacity:.7}.collapse-arrow{display:inline-block;font-size:.65rem;transition:transform .15s ease}.collapse-arrow.collapsed{transform:rotate(-90deg)}.section-count{margin-left:auto;font-size:.65rem;opacity:.6}.filter-bar{margin-bottom:8px}.filter-toggle{font-size:.75rem;padding:4px 10px;border-radius:12px;border:1px solid var(--border);background:transparent;color:var(--text-dim);cursor:pointer;font-family:inherit}.filter-toggle.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}.empty-message{color:var(--text-dim);font-size:.85rem;text-align:center;padding:32px 0}.biome-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.building-list{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}.building-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:12px;box-shadow:var(--card-shadow)}.building-card.built{border-color:var(--success);border-left:3px solid var(--success);box-shadow:0 1px 8px #4ade801a}.building-name{font-weight:600;font-size:.9rem;color:var(--text);margin-bottom:4px}.building-desc{font-size:.78rem;color:var(--text-dim);margin-bottom:4px}.building-unlocks{font-size:.72rem;color:var(--bar-xp)}.building-storage{font-size:.72rem;color:var(--success);margin-top:2px}.inventory-panel{display:flex;flex-direction:column}.inventory-filters{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.inventory-filter{background:var(--bar-bg);border:1px solid var(--border);border-radius:4px;color:var(--text-dim);font-size:.72rem;padding:3px 8px;cursor:pointer;transition:color .15s,border-color .15s}.inventory-filter:hover{color:var(--text);border-color:var(--text-dim)}.inventory-filter.active{color:var(--accent);border-color:var(--accent);background:var(--bg-hover)}.inventory-category{margin-bottom:8px}.inventory-items{display:flex;flex-direction:column;gap:4px}.inventory-item{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:8px 10px;box-shadow:var(--card-shadow);transition:border-color .15s}.inventory-item:hover{border-color:var(--text-dim)}.inventory-item.at-cap{border-color:var(--warning)}.inventory-item-header{display:flex;justify-content:space-between;align-items:center}.inventory-item-name{font-size:.82rem;font-weight:600}.inventory-item-count{font-size:.78rem;color:var(--success);font-weight:600}.inventory-item-count.at-cap{color:var(--warning)}.inventory-item-desc{font-size:.7rem;color:var(--text-dim);margin-top:2px}.tool-enables{margin-top:3px;color:var(--accent);font-style:italic}.station-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:12px;margin-bottom:8px;box-shadow:var(--card-shadow);transition:border-color .15s,transform .15s}.station-card.station-ready{border-color:var(--success);cursor:pointer;animation:station-pulse 2s ease-in-out infinite}.station-card.station-ready:hover{transform:translateY(-1px);box-shadow:0 3px 12px #4ade8033}.station-card.station-ready:active{transform:translateY(0)}@keyframes station-pulse{0%,to{box-shadow:0 1px 4px #0000004d}50%{box-shadow:0 1px 12px #4ade8040}}.station-progress{margin:6px 0}.station-collect-hint{font-size:.78rem;color:var(--success);font-weight:600;margin:4px 0}.station-at-max{font-size:.72rem;color:var(--text-dim);margin-top:4px}.station-ready-banner{padding:8px 16px;background:linear-gradient(90deg,#4ade8026,#4ade800d);border-bottom:1px solid var(--border);font-size:.82rem;color:var(--success);font-weight:600;cursor:pointer;text-align:center;animation:station-pulse 2s ease-in-out infinite}.station-ready-banner:hover{background:linear-gradient(90deg,#4ade8033,#4ade801a)}.toast-container{position:fixed;bottom:72px;left:50%;transform:translate(-50%);z-index:200;display:flex;flex-direction:column;gap:6px;pointer-events:none;width:calc(100% - 32px);max-width:400px}.toast{pointer-events:auto;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:10px 14px;box-shadow:0 4px 16px #0006;cursor:pointer;animation:toast-in .3s ease-out;font-size:.82rem;display:flex;align-items:center;font-weight:600;user-select:none;-webkit-user-select:none}.toast-exit{animation:toast-out .3s ease-in forwards}.toast-close{margin-left:8px;opacity:.6;font-size:1.1rem;cursor:pointer;flex-shrink:0}.toast-close:hover{opacity:1}.toast-biome{border-left:3px solid var(--success);color:var(--success)}.toast-level{border-left:3px solid var(--warning);color:var(--warning)}.toast-building{border-left:3px solid var(--accent);color:var(--accent)}.toast-resource{border-left:3px solid var(--bar-xp);color:var(--bar-xp)}.toast-craft{border-left:3px solid #c084fc;color:#c084fc}@keyframes toast-in{0%{opacity:0;transform:translateY(16px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toast-out{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-8px) scale(.95)}}@media(min-width:768px){.app{max-width:840px}.inventory-sidebar{display:block;width:280px;flex-shrink:0;border-left:1px solid var(--border);padding:12px;overflow-y:auto;background:var(--bg)}.resource-panel,.mobile-only-tab,.mobile-only-panel{display:none}}.island-banner{position:relative;height:92px;overflow:hidden;border-bottom:1px solid var(--border);user-select:none;-webkit-user-select:none;isolation:isolate}.island-banner-image{width:100%;height:100%;display:block;object-fit:cover;object-position:center}.island-banner-scrim{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0000001a,#0006);pointer-events:none}.island-phase-label{position:absolute;right:10px;bottom:8px;font-size:.58rem;text-transform:uppercase;letter-spacing:.14em;color:#f6efe3;opacity:.9;text-shadow:0 2px 8px rgba(0,0,0,.8);pointer-events:none}.chapter-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;display:flex;align-items:center;justify-content:center;background:#0000;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);transition:background .6s ease,backdrop-filter .6s ease;cursor:pointer}.chapter-overlay.visible{background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.chapter-overlay.exiting{background:#0000;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}.chapter-card{text-align:center;padding:32px 48px;opacity:0;transform:scale(.9) translateY(20px);transition:opacity .6s ease,transform .6s ease}.chapter-overlay.visible .chapter-card{opacity:1;transform:scale(1) translateY(0)}.chapter-overlay.exiting .chapter-card{opacity:0;transform:scale(1.05) translateY(-10px)}.chapter-index{font-size:.7rem;text-transform:uppercase;letter-spacing:.2em;color:var(--text-dim);margin-bottom:8px}.chapter-name{font-size:1.6rem;font-weight:700;color:var(--accent);text-shadow:0 0 24px var(--phase-glow);letter-spacing:.04em}.chapter-divider{width:40px;height:1px;background:var(--accent);opacity:.4;margin:12px auto}.chapter-tagline{font-size:.85rem;color:var(--text);font-style:italic;opacity:.8;max-width:260px}.chapter-tap{margin-top:24px;font-size:.65rem;text-transform:uppercase;letter-spacing:.15em;color:var(--text-dim);opacity:.5;animation:tap-pulse 2s ease-in-out infinite}@keyframes tap-pulse{0%,to{opacity:.3}50%{opacity:.7}}.phase-chapter-bare_hands .chapter-name{color:#c8b090;text-shadow:0 0 24px rgba(200,176,144,.4)}.phase-chapter-bamboo .chapter-name{color:#7bc67b;text-shadow:0 0 24px rgba(123,198,123,.4)}.phase-chapter-fire .chapter-name{color:#f0a050;text-shadow:0 0 24px rgba(240,160,80,.5)}.phase-chapter-stone .chapter-name{color:#a0a8b8;text-shadow:0 0 24px rgba(160,168,184,.4)}.phase-chapter-maritime .chapter-name{color:#50b0d0;text-shadow:0 0 24px rgba(80,176,208,.5)}
