@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Cinzel:wght@500;600;700&family=JetBrains+Mono:wght@500;700&family=Pixelify+Sans:wght@400;500;600;700&family=Noto+Emoji:wght@300..700&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--bg-base: #0c0a07;--bg-deep: #131009;--bg-dark: #18140d;--bg-medium: #1f1a12;--bg-light: #28221a;--bg-elevated: #322a20;--surface-1: rgba(255, 255, 255, .02);--surface-2: rgba(255, 255, 255, .04);--surface-3: rgba(255, 255, 255, .06);--surface-4: rgba(255, 255, 255, .09);--border-1: rgba(255, 255, 255, .05);--border-2: rgba(255, 255, 255, .08);--border-3: rgba(255, 255, 255, .14);--border-glow: rgba(96, 165, 250, .35);--accent: #f5a623;--accent-strong: #e08e15;--accent-deep: #b86f0e;--accent-glow: rgba(245, 166, 35, .3);--steel: #7d9cc4;--steel-deep: #4a6788;--steel-glow: rgba(125, 156, 196, .25);--ember: #f5a623;--ember-deep: #c47914;--ember-glow: rgba(245, 166, 35, .32);--leaf: #6b9b3a;--leaf-deep: #4d7427;--leaf-glow: rgba(107, 155, 58, .3);--rose: #c84f3a;--rose-deep: #9b3a28;--rose-glow: rgba(200, 79, 58, .32);--parchment: #d9b88a;--parchment-deep: #a8855c;--primary: var(--rose);--primary-light: #ff6b6b;--secondary: #0f3460;--success: var(--leaf);--warning: var(--ember);--danger: var(--rose);--text-bright: #f4ead5;--text-primary: #ddd0b0;--text-secondary: #a59578;--text-muted: #6b6048;--text-dim: #4a4232;--space-0: 2px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--r-xs: 4px;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 18px;--r-2xl: 22px;--r-pill: 999px;--shadow-1: 0 1px 2px rgba(0, 0, 0, .4);--shadow-2: 0 4px 12px rgba(0, 0, 0, .45), 0 1px 2px rgba(0, 0, 0, .3);--shadow-3: 0 8px 24px rgba(0, 0, 0, .5), 0 2px 4px rgba(0, 0, 0, .35);--shadow-4: 0 20px 50px rgba(0, 0, 0, .6), 0 4px 12px rgba(0, 0, 0, .4);--shadow-inset: inset 0 1px 0 rgba(255, 255, 255, .05);--shadow-inset-strong: inset 0 1px 0 rgba(255, 255, 255, .1), inset 0 -1px 0 rgba(0, 0, 0, .4);--ring-accent: 0 0 0 1px var(--border-glow), 0 0 20px var(--accent-glow);--ring-ember: 0 0 0 1px rgba(245, 158, 11, .4), 0 0 20px var(--ember-glow);--ring-rose: 0 0 0 1px rgba(239, 68, 68, .4), 0 0 20px var(--rose-glow);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--t-fast: .12s;--t-base: .2s;--t-slow: .36s;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";--font-display: "Cinzel", "Inter", serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--font-pixel: "Pixelify Sans", cursive;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px)}html{font-size:calc(16px * var(--user-font-scale, 1));-webkit-text-size-adjust:100%}body{font-family:var(--font-body);background-color:var(--bg-base);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-smoothing:grayscale;overflow-x:hidden;background-image:radial-gradient(ellipse at top,rgba(245,166,35,.06),transparent 60%),radial-gradient(ellipse at bottom,rgba(155,58,40,.04),transparent 70%),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.7 0 0 0 0 0.55 0 0 0 0 0.3 0 0 0 0.1 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");background-attachment:fixed}.game-panel{position:relative;background:linear-gradient(180deg,#322a20a6,#1f1a12d9),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='p'><feTurbulence type='fractalNoise' baseFrequency='0.6' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.6 0 0 0 0 0.5 0 0 0 0 0.35 0 0 0 0.08 0'/></filter><rect width='100%25' height='100%25' filter='url(%23p)'/></svg>");border:1px solid var(--border-2);clip-path:polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px)}.game-panel:before,.game-panel:after{content:"";position:absolute;width:18px;height:18px;border:2px solid var(--accent);pointer-events:none;opacity:.7}.game-panel:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.game-panel:after{bottom:-1px;right:-1px;border-left:none;border-top:none}.btn-chunky{position:relative;font-family:var(--font-display);letter-spacing:.12em;text-transform:uppercase;font-weight:700;background:linear-gradient(180deg,var(--accent) 0%,var(--accent-deep) 100%);color:#1a0f00;border:1px solid var(--accent-deep);box-shadow:inset 0 1px #ffe6b480,inset 0 -2px #00000059,0 3px 0 var(--accent-deep),0 6px 14px #00000073;transition:transform var(--t-fast) var(--ease-spring),box-shadow var(--t-fast) var(--ease-out)}.btn-chunky:hover{filter:brightness(1.08)}.btn-chunky:active{transform:translateY(2px);box-shadow:inset 0 1px #ffe6b466,inset 0 -1px #0006,0 1px 0 var(--accent-deep),0 2px 6px #0006}.game-icon{font-family:"Noto Emoji",Inter,sans-serif;font-weight:500;display:inline-flex;align-items:center;justify-content:center;line-height:1;font-style:normal;color:var(--text-primary);filter:grayscale(1) brightness(1.2)}.game-font{font-family:var(--font-pixel)}.display-font{font-family:var(--font-display);letter-spacing:.02em}.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-deep)}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}::selection{background:var(--accent-strong);color:#fff}:focus{outline:2px solid var(--accent);outline-offset:2px}:focus:not(:focus-visible){outline:none}button{font-family:inherit;border:none;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.5}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes glow{0%,to{box-shadow:0 0 5px var(--accent)}50%{box-shadow:0 0 20px var(--accent)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.55}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pop-in{0%{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}@keyframes scan{0%{transform:translateY(-100%)}to{transform:translateY(100%)}}.text-center{text-align:center}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}@media(max-width:480px){html{font-size:14px}}body{overscroll-behavior-y:contain}.hide-scrollbar{-ms-overflow-style:none;scrollbar-width:none}.hide-scrollbar::-webkit-scrollbar{display:none}.game-container{min-height:100vh;display:flex;flex-direction:column;background:transparent;position:relative}.game-container:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;background:radial-gradient(ellipse at center,transparent 50%,rgba(0,0,0,.55) 100%)}.game-content{flex:1;padding-bottom:calc(96px + env(safe-area-inset-bottom,0px));overflow-y:auto;position:relative;z-index:1}.game-over-screen{position:fixed;inset:0;background:#05050cd9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:5000;animation:fadeIn .3s ease}.game-over-content{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-10);color:var(--rose);animation:pop-in .45s var(--ease-spring)}.game-over-content h2{font-family:var(--font-display);margin:var(--space-5) 0 var(--space-2);font-size:32px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;text-shadow:0 0 28px rgba(239,68,68,.5)}.game-over-content p{margin:0 0 var(--space-6);color:var(--text-secondary);font-size:14px}.restart-btn{display:flex;align-items:center;gap:var(--space-2);padding:14px 28px;background:linear-gradient(135deg,var(--leaf) 0%,var(--leaf-deep) 100%);border:1px solid rgba(255,255,255,.15);border-radius:var(--r-lg);color:#fff;font-size:15px;font-weight:700;letter-spacing:.02em;cursor:pointer;box-shadow:var(--shadow-3),var(--shadow-inset);transition:transform var(--t-base) var(--ease-spring),box-shadow var(--t-base) var(--ease-out)}.restart-btn:hover{transform:translateY(-2px);box-shadow:0 12px 32px var(--leaf-glow),var(--shadow-inset)}.restart-btn:active{transform:translateY(0)}.game-header{position:sticky;top:0;z-index:100;background:linear-gradient(180deg,#1f1a12f5,#120e08eb),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.5 0 0 0 0 0.4 0 0 0 0 0.25 0 0 0 0.12 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);border-bottom:2px solid var(--accent-deep);padding:var(--space-4);padding-top:calc(env(safe-area-inset-top,12px) + var(--space-4));box-shadow:var(--shadow-3)}.game-header:after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:1px;background:linear-gradient(90deg,transparent 5%,var(--accent) 50%,transparent 95%);pointer-events:none;opacity:.6}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.game-title{display:flex;align-items:center;gap:var(--space-3)}.title-icon{width:40px;height:40px;background:linear-gradient(180deg,var(--accent) 0%,var(--accent-deep) 100%);display:flex;align-items:center;justify-content:center;color:#1a0f00;position:relative;clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);box-shadow:inset 0 1px #ffe6b473,inset 0 -2px #0006,0 4px 14px var(--accent-glow)}.game-title h1{margin:0;font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--text-bright);letter-spacing:.06em;text-transform:uppercase}.header-actions{display:flex;align-items:center;gap:var(--space-3)}.icon-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#322a20b3,#18140dd9);border:1px solid var(--border-2);color:var(--text-secondary);cursor:pointer;clip-path:polygon(5px 0,100% 0,100% calc(100% - 5px),calc(100% - 5px) 100%,0 100%,0 5px);transition:background var(--t-fast) var(--ease-out),color var(--t-fast) var(--ease-out),transform var(--t-fast) var(--ease-spring),border-color var(--t-base) var(--ease-out);box-shadow:inset 0 1px #ffe6b414,inset 0 -1px #0006}.icon-btn:hover{background:var(--surface-3);color:var(--text-bright);transform:translateY(-1px);box-shadow:var(--shadow-2),var(--shadow-inset)}.icon-btn:active{transform:translateY(0)}.icon-btn.lang-btn{width:auto;padding:0 var(--space-3);gap:var(--space-1);font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary)}.icon-btn.lang-btn .lang-label{line-height:1}.icon-btn.lang-btn:hover{color:var(--accent)}.turn-badge{display:flex;flex-direction:column;align-items:center;background:linear-gradient(180deg,#322a20e6,#18140de6);border:1px solid var(--accent-deep);padding:6px 14px;clip-path:polygon(6px 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%,0 6px);box-shadow:inset 0 1px #ffe6b426,inset 0 -1px #00000080}.turn-text{font-family:var(--font-mono);font-size:9px;color:var(--text-muted);font-weight:700;letter-spacing:.18em;text-transform:uppercase}.turn-num{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--accent);line-height:1;text-shadow:0 0 12px var(--accent-glow)}.stats-container{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2);margin-bottom:var(--space-3)}.stat-card{display:flex;align-items:center;gap:var(--space-2);padding:10px var(--space-3);background:linear-gradient(180deg,#28221ab3,#18140dd9);border:1px solid var(--border-2);box-shadow:inset 0 1px #ffe6b414,inset 0 -1px #00000080;transition:border-color var(--t-base) var(--ease-out);clip-path:polygon(6px 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%,0 6px)}.stat-card.popup-open{clip-path:none;overflow:visible}.stat-card:hover{border-color:var(--accent-deep)}.stat-card.clickable{cursor:pointer}.stat-card.clickable:hover{border-color:var(--accent);background:linear-gradient(180deg,#322a20cc,#1c160ee6)}.stat-bar-wrap{flex:1;height:8px;background:#000000a6;position:relative;overflow:hidden;box-shadow:inset 0 1px 2px #000000b3;border:1px solid rgba(0,0,0,.5)}.stat-bar{height:100%;transition:width var(--t-slow) var(--ease-out),background var(--t-base) var(--ease-out);position:relative;-webkit-mask-image:repeating-linear-gradient(90deg,black 0 calc(10% - 2px),transparent calc(10% - 2px) 10%);mask-image:repeating-linear-gradient(90deg,black 0 calc(10% - 2px),transparent calc(10% - 2px) 10%);box-shadow:0 0 8px currentColor}.stat-num{font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--text-bright);min-width:24px;text-align:right;font-variant-numeric:tabular-nums}.stat-meta{display:flex;flex-direction:column;align-items:center;gap:var(--space-0)}.stat-decay{font-family:var(--font-mono);font-size:9px;color:var(--ember);font-weight:700;letter-spacing:.05em}.stat-decay.danger{color:var(--rose);text-shadow:0 0 6px var(--rose-glow)}.quick-action-btn{background:none;border:none;padding:3px;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--t-fast) var(--ease-out),color var(--t-fast) var(--ease-out),transform var(--t-fast) var(--ease-spring);border-radius:var(--r-xs)}.quick-action-btn:hover{background:var(--surface-3);color:var(--text-bright);transform:scale(1.12)}.quick-action-btn.eat:hover{color:var(--rose)}.quick-action-btn.drink:hover{color:var(--accent)}.quick-action-btn.heal:hover{color:var(--leaf)}.health-popup{position:absolute;top:100%;left:0;right:0;min-width:200px;margin-top:var(--space-1);background:linear-gradient(180deg,var(--bg-elevated),var(--bg-light));border:1px solid var(--border-3);border-radius:var(--r-lg);padding:var(--space-2);z-index:200;box-shadow:var(--shadow-4),var(--shadow-inset);animation:pop-in .18s var(--ease-spring)}.health-popup-title{font-family:var(--font-mono);font-size:10px;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:var(--space-1) 6px 6px}.health-popup-item{display:flex;align-items:center;gap:6px;width:100%;padding:var(--space-2) 6px;background:none;border:none;border-radius:var(--r-sm);color:var(--text-bright);cursor:pointer;font-size:12px;transition:background var(--t-fast) ease}.health-popup-item:hover{background:var(--surface-3)}.health-popup-icon{font-size:16px}.health-popup-name{flex:1;text-align:left;font-weight:500}.health-popup-count{color:var(--text-muted);font-size:11px;font-family:var(--font-mono)}.health-popup-effect{color:var(--leaf);font-weight:700;font-size:12px;font-family:var(--font-mono)}.health-popup-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-1) 6px 6px}.reset-default-btn{background:var(--surface-3);border:none;border-radius:var(--r-xs);color:var(--text-secondary);cursor:pointer;padding:3px 5px;display:flex;align-items:center;transition:all var(--t-fast) ease}.reset-default-btn:hover{background:#ef444433;color:var(--rose)}.health-popup-item.default-item{background:#3b82f61a;border-left:2px solid var(--accent-strong)}.default-badge{color:var(--ember);font-size:10px;margin-left:2px}.quick-action-btn.has-default{color:var(--ember);position:relative}.quick-action-btn.has-default:after{content:"";position:absolute;bottom:-1px;left:50%;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:var(--ember);box-shadow:0 0 6px var(--ember-glow)}.warning-strip{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:linear-gradient(90deg,#dc262626,#dc26260d);border:1px solid rgba(220,38,38,.25);border-radius:var(--r-md);margin-bottom:var(--space-3);color:var(--rose);font-size:12px;font-weight:600;box-shadow:inset 0 0 24px #ef444414;animation:pulse-warning 2s infinite}@keyframes pulse-warning{0%,to{opacity:1}50%{opacity:.65}}.turn-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:14px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-deep) 100%);border:1px solid rgba(255,255,255,.15);border-radius:var(--r-lg);color:#fff;font-size:15px;font-weight:700;letter-spacing:.03em;cursor:pointer;box-shadow:var(--shadow-2),var(--shadow-inset-strong);transition:transform var(--t-base) var(--ease-spring),box-shadow var(--t-base) var(--ease-out);position:relative;overflow:hidden}.turn-btn:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.18),transparent 50%);pointer-events:none}.turn-btn:hover{transform:translateY(-2px);box-shadow:0 12px 32px var(--accent-glow),var(--shadow-inset-strong)}.turn-btn:active{transform:translateY(0)}.turn-btn.restart{background:linear-gradient(135deg,var(--leaf) 0%,var(--leaf-deep) 100%)}.turn-btn.restart:hover{box-shadow:0 12px 32px var(--leaf-glow),var(--shadow-inset-strong)}@media(max-width:360px){.stat-card{padding:8px;gap:6px}.stat-num{font-size:12px}}.era-selector{position:relative;display:inline-flex}.era-current{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-bright);font-family:var(--font-mono);font-size:12px;cursor:pointer;transition:all .2s}.era-current.compact{padding:6px 8px;gap:5px}.era-current.compact .era-icon{font-size:15px;line-height:1}.era-current:hover{border-color:var(--accent);background:var(--bg-hover)}.era-icon{font-size:16px}.era-name{font-weight:600;text-transform:uppercase;letter-spacing:.05em}.era-year{color:var(--text-secondary);font-size:11px}.era-chevron{transition:transform .2s}.era-chevron.open{transform:rotate(180deg)}.era-menu{position:absolute;top:calc(100% + 4px);right:0;min-width:220px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 8px 24px #0006;z-index:100;overflow:hidden}.era-option{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;background:transparent;border:none;border-bottom:1px solid var(--border-soft);color:var(--text);text-align:left;cursor:pointer;transition:background .15s}.era-option:last-child{border-bottom:none}.era-option:hover:not(:disabled){background:var(--bg-hover)}.era-option:disabled{cursor:default}.era-option.current{background:var(--bg-hover);color:var(--accent)}.era-option.locked{opacity:.4}.era-option-icon{font-size:18px}.era-option-info{flex:1;display:flex;flex-direction:column}.era-option-name{font-family:var(--font-display);font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-bright)}.era-option.locked .era-option-name{color:var(--text-secondary)}.era-option-year{font-family:var(--font-mono);font-size:10px;color:var(--text-secondary)}.morality-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 9px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:11px;font-weight:600;transition:all .3s}.morality-badge.good{color:#22c55e;border-color:#22c55e66;background:#22c55e14}.morality-badge.evil{color:#dc2626;border-color:#dc262666;background:#dc262614}.morality-badge.neutral{color:var(--text-secondary)}.morality-val{letter-spacing:.05em}.status-badges{display:flex;gap:6px;flex-wrap:wrap;padding:4px 0}.status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 8px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;transition:all .25s}.status-badge.wound{color:#fca5a5;border-color:#f8717173;background:#f8717114;animation:wound-pulse 1.8s ease-in-out infinite}@keyframes wound-pulse{0%,to{box-shadow:0 0 #f8717100}50%{box-shadow:0 0 10px #f8717159}}.status-badge.critical{color:#fbbf24;border-color:#f59e0b73;background:#f59e0b14}.status-label{letter-spacing:.05em}.status-val{color:var(--text-bright);font-weight:700;background:#ffffff14;padding:1px 5px;border-radius:4px}.settings-overlay{position:fixed;inset:0;background:#000000b3;z-index:200;display:flex;align-items:center;justify-content:center;padding:16px;animation:settings-fade .18s ease-out}@keyframes settings-fade{0%{opacity:0}to{opacity:1}}.settings-modal{width:100%;max-width:460px;max-height:86vh;overflow-y:auto;background:linear-gradient(180deg,#322a20fa,#18140d);border:1px solid var(--accent-deep);color:var(--text);clip-path:polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px);box-shadow:inset 0 1px #ffe6b41a,0 12px 40px #000000b3}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 14px;border-bottom:1px solid var(--border-2)}.settings-header h2{margin:0;font-family:var(--font-display);font-size:16px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}.settings-close{background:transparent;border:1px solid var(--border-2);color:var(--text-muted);width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--t-fast) var(--ease-out)}.settings-close:hover{color:var(--accent);border-color:var(--accent-deep)}.settings-body{padding:8px 18px 18px;display:flex;flex-direction:column;gap:8px}.settings-section{padding:12px 0;border-bottom:1px dashed rgba(255,230,180,.1);display:flex;flex-direction:column;gap:10px}.settings-section:last-child{border-bottom:none}.settings-label{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary)}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.settings-toggle{padding:6px 12px;background:#00000059;border:1px solid var(--accent-deep);color:var(--accent);font-family:var(--font-mono);font-size:12px;cursor:pointer;clip-path:polygon(4px 0,100% 0,100% calc(100% - 4px),calc(100% - 4px) 100%,0 100%,0 4px);transition:filter var(--t-fast) var(--ease-out)}.settings-toggle:hover{filter:brightness(1.2)}.settings-options{display:flex;gap:6px}.settings-option{flex:1;padding:8px 6px;background:#0000004d;border:1px solid var(--border-2);color:var(--text-muted);font-family:var(--font-mono);font-size:12px;cursor:pointer;transition:all var(--t-fast) var(--ease-out)}.settings-option:hover{color:var(--text);border-color:var(--accent-deep)}.settings-option.active{background:linear-gradient(180deg,var(--accent),var(--accent-deep));color:#1a0f00;border-color:var(--accent);font-weight:700}.settings-switch{position:relative;width:44px;height:22px;background:#00000080;border:1px solid var(--border-2);border-radius:11px;cursor:pointer;padding:0;transition:background var(--t-base) var(--ease-out)}.settings-switch .switch-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;background:var(--text-muted);border-radius:50%;transition:all var(--t-base) var(--ease-out)}.settings-switch.on{background:var(--accent-deep);border-color:var(--accent)}.settings-switch.on .switch-knob{left:24px;background:var(--accent)}.settings-about{font-size:12px;color:var(--text-secondary);line-height:1.5}.settings-about p{margin:0}.settings-about .version{font-family:var(--font-mono);color:var(--text-muted);margin-top:4px}.settings-section.danger{border-color:#dc26264d}.settings-danger-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:9px 14px;background:#dc262626;border:1px solid rgba(220,38,38,.5);color:#fca5a5;font-family:var(--font-mono);font-size:12px;cursor:pointer;transition:all var(--t-fast) var(--ease-out);clip-path:polygon(4px 0,100% 0,100% calc(100% - 4px),calc(100% - 4px) 100%,0 100%,0 4px)}.settings-danger-btn:hover{background:#dc26264d;color:#fff}.settings-danger-btn.confirm{background:#dc262680;color:#fff;border-color:#dc2626e6}.settings-confirm{display:flex;flex-direction:column;gap:10px}.settings-confirm p{margin:0;font-size:13px;color:#fca5a5;line-height:1.4}.settings-confirm-actions{display:flex;gap:8px}.settings-cancel-btn{flex:1;padding:9px 14px;background:#0000004d;border:1px solid var(--border-2);color:var(--text-secondary);font-family:var(--font-mono);font-size:12px;cursor:pointer;clip-path:polygon(4px 0,100% 0,100% calc(100% - 4px),calc(100% - 4px) 100%,0 100%,0 4px)}.settings-cancel-btn:hover{color:var(--text)}.settings-confirm-actions .settings-danger-btn{flex:1}.save-slots-panel{display:flex;flex-direction:column;gap:8px}.save-slot{background:#0000004d;border:1px solid var(--border-2);padding:10px;clip-path:polygon(4px 0,100% 0,100% calc(100% - 4px),calc(100% - 4px) 100%,0 100%,0 4px);display:flex;flex-direction:column;gap:8px}.save-slot.active{border-color:var(--accent-deep);background:linear-gradient(180deg,#f5a6231a,#0000004d)}.save-slot.empty{opacity:.7}.save-slot-head{display:flex;align-items:center;justify-content:space-between}.save-slot-num{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:12px;color:var(--text);font-weight:700}.save-slot.active .save-slot-num{color:var(--accent)}.active-tag{padding:2px 6px;font-size:9px;background:var(--accent-deep);color:#1a0f00;letter-spacing:.08em;text-transform:uppercase;border-radius:2px}.slot-delete-btn{display:flex;align-items:center;gap:4px;background:transparent;border:1px solid rgba(220,38,38,.4);color:#fca5a5;padding:4px 6px;cursor:pointer;font-size:10px;font-family:var(--font-mono);transition:all var(--t-fast) var(--ease-out)}.slot-delete-btn:hover{background:#dc262633}.slot-delete-btn.confirm{background:#dc262666;color:#fff;border-color:#dc2626cc}.slot-empty-text{margin:0;font-size:11px;color:var(--text-muted);font-style:italic}.slot-meta{display:flex;flex-direction:column;gap:3px}.slot-meta-row{display:flex;justify-content:space-between;font-size:11px}.slot-meta-key{color:var(--text-muted);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em}.slot-meta-val{color:var(--text);font-family:var(--font-mono)}.slot-load-btn{display:flex;align-items:center;justify-content:center;gap:6px;background:#0006;border:1px solid var(--accent-deep);color:var(--accent);padding:7px 10px;cursor:pointer;font-family:var(--font-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;transition:all var(--t-fast) var(--ease-out)}.slot-load-btn:hover{background:#f5a62326;filter:brightness(1.15)}.slot-warning{font-size:10px;color:var(--text-muted);font-style:italic;line-height:1.4;margin:4px 0 0;padding:6px 8px;background:#0003;border-left:2px solid var(--accent-deep)}:root{--user-font-scale: 1}html.reduce-motion *,html.reduce-motion *:before,html.reduce-motion *:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:stretch;background:linear-gradient(180deg,#0f101cd9,#080912f5);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);border-top:1px solid var(--border-2);padding:var(--space-2) var(--space-3);padding-bottom:calc(env(safe-area-inset-bottom,8px) + var(--space-2));z-index:1000;box-shadow:0 -8px 32px #0006}.bottom-nav:before{content:"";position:absolute;left:0;right:0;top:-1px;height:1px;background:linear-gradient(90deg,transparent,var(--accent-glow),transparent);pointer-events:none}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2) var(--space-1);background:none;border:none;cursor:pointer;transition:color var(--t-base) var(--ease-out),transform var(--t-fast) var(--ease-spring);position:relative;color:var(--text-muted);border-radius:var(--r-md)}.nav-item>svg,.nav-icon-wrap>svg{transition:transform var(--t-base) var(--ease-spring),filter var(--t-base) var(--ease-out)}.nav-icon-wrap{position:relative;display:flex;align-items:center;justify-content:center}.nav-item:hover{color:var(--text-secondary)}.nav-item:hover .nav-icon-wrap>svg{transform:translateY(-2px) scale(1.05)}.nav-item.active{color:var(--accent)}.nav-item.active .nav-icon-wrap>svg{filter:drop-shadow(0 0 8px var(--accent-glow))}.nav-dot{position:absolute;top:-2px;right:-4px;width:8px;height:8px;background:var(--rose);border:1.5px solid var(--bg-base);border-radius:50%;box-shadow:0 0 8px var(--rose-glow);animation:nav-dot-pulse 1.4s var(--ease-out) infinite}.nav-dot.ready{background:var(--leaf);box-shadow:0 0 10px var(--leaf-glow)}@keyframes nav-dot-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.25)}}.nav-item.active:before{content:"";position:absolute;inset:4px 8px;background:radial-gradient(circle at center top,var(--accent-glow),transparent 70%);border-radius:var(--r-md);z-index:-1}.nav-item.active:after{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:28px;height:3px;background:linear-gradient(90deg,transparent,var(--accent),transparent);border-radius:0 0 var(--r-xs) var(--r-xs);box-shadow:0 0 10px var(--accent-glow)}.nav-label{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.fab-slot{flex:1.4;display:flex;align-items:flex-start;justify-content:center;position:relative;padding:0 var(--space-1)}.turn-fab{position:relative;transform:translateY(-22px);min-width:96px;padding:12px var(--space-3) 10px;display:flex;flex-direction:column;align-items:center;gap:2px;background:linear-gradient(180deg,var(--accent) 0%,var(--accent-deep) 100%);border:1px solid var(--accent-deep);color:#1a0f00;cursor:pointer;clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);box-shadow:inset 0 1px #ffe6b480,inset 0 -3px #00000059,0 4px 0 var(--accent-deep),0 12px 24px var(--accent-glow);transition:transform var(--t-base) var(--ease-spring);overflow:hidden}.turn-fab:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.22),transparent 50%);pointer-events:none}.turn-fab:after{content:"";position:absolute;inset:-50%;background:conic-gradient(from 0deg,transparent 0deg,rgba(255,255,255,.12) 30deg,transparent 60deg,transparent 360deg);animation:fab-sheen 6s linear infinite;pointer-events:none}@keyframes fab-sheen{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.turn-fab:hover{filter:brightness(1.08)}.turn-fab:active{transform:translateY(-18px);box-shadow:inset 0 1px #ffe6b466,inset 0 -1px #00000059,0 1px 0 var(--accent-deep),0 4px 12px var(--accent-glow)}.turn-fab.restart{background:linear-gradient(180deg,var(--rose) 0%,var(--rose-deep) 100%);border-color:var(--rose-deep);color:#fff;box-shadow:inset 0 1px #ffdcc866,inset 0 -3px #00000059,0 4px 0 var(--rose-deep),0 12px 24px var(--rose-glow);animation:fab-pulse 1.6s var(--ease-out) infinite}@keyframes fab-pulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.15)}}.fab-icon-wrap{display:flex;align-items:center;justify-content:center;width:30px;height:30px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4));position:relative;z-index:1}.fab-meta{display:flex;flex-direction:column;align-items:center;line-height:1;position:relative;z-index:1}.fab-label{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;text-shadow:0 1px 0 rgba(255,230,180,.3)}.fab-day{margin-top:3px;font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;opacity:.75}@media(max-width:360px){.nav-label{font-size:9px}.turn-fab{min-width:78px;padding:8px var(--space-2) 6px}.fab-label{font-size:10px}}.story-panel{background:linear-gradient(180deg,#322a20c7,#14100aeb),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.55 0 0 0 0 0.45 0 0 0 0 0.28 0 0 0 0.1 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");border:1px solid var(--accent-deep);padding:var(--space-4);margin-bottom:var(--space-4);clip-path:polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px);box-shadow:inset 0 1px #ffe6b41f,inset 0 -1px #00000080,0 6px 18px #0006,0 0 22px #f5a6231a}.story-panel.victory{text-align:center;padding:var(--space-6);border-color:var(--leaf-deep);box-shadow:inset 0 1px #ffe6b41f,0 0 30px var(--leaf-glow)}.story-victory-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);color:var(--leaf)}.story-victory-content h2{margin:0;font-family:var(--font-display);font-size:24px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;text-shadow:0 0 18px var(--leaf-glow)}.story-victory-content p{margin:0;color:var(--text-secondary);font-size:13px}.victory-subtitle{font-style:italic}.story-chapter-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px dashed var(--border-3)}.chapter-icon{font-size:28px;line-height:1;color:var(--accent);filter:drop-shadow(0 0 6px var(--accent-glow))}.chapter-info{flex:1;min-width:0}.chapter-label{font-family:var(--font-mono);font-size:10px;color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.18em}.chapter-info h3{margin:2px 0 0;font-family:var(--font-display);font-size:17px;font-weight:600;color:var(--text-bright);letter-spacing:.06em;text-transform:uppercase}.chapter-progress{background:linear-gradient(180deg,var(--accent),var(--accent-deep));color:#1a0f00;padding:6px 12px;font-family:var(--font-mono);font-size:13px;font-weight:800;letter-spacing:.05em;clip-path:polygon(5px 0,100% 0,100% calc(100% - 5px),calc(100% - 5px) 100%,0 100%,0 5px);box-shadow:inset 0 1px #ffe6b473,inset 0 -2px #00000059,0 3px 10px var(--accent-glow)}.chapter-desc{font-size:12px;color:var(--text-secondary);margin:0 0 var(--space-3);line-height:1.55;font-style:italic}.objectives-list{display:flex;flex-direction:column;gap:var(--space-2)}.objective-item{display:flex;flex-direction:column;gap:var(--space-2);padding:10px var(--space-3);background:linear-gradient(180deg,#1c160eb3,#0e0a06d9);border:1px solid var(--border-2);clip-path:polygon(7px 0,100% 0,100% calc(100% - 7px),calc(100% - 7px) 100%,0 100%,0 7px);box-shadow:inset 0 1px #ffe6b40d;transition:all var(--t-base) var(--ease-out)}.objective-row{display:flex;align-items:flex-start;gap:var(--space-2)}.obj-hint-toggle{width:28px;height:28px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#f5a6232e,#b86f0e14);border:1px solid var(--accent-deep);color:var(--accent);cursor:pointer;clip-path:polygon(5px 0,100% 0,100% calc(100% - 5px),calc(100% - 5px) 100%,0 100%,0 5px);transition:all var(--t-fast) var(--ease-out);box-shadow:inset 0 1px #ffe6b41a;animation:hint-glow 2.4s var(--ease-out) infinite}.obj-hint-toggle:hover,.obj-hint-toggle.open{background:linear-gradient(180deg,var(--accent),var(--accent-deep));color:#1a0f00;animation:none;box-shadow:0 0 12px var(--accent-glow)}@keyframes hint-glow{0%,to{box-shadow:inset 0 1px #ffe6b41a,0 0 #f5a62300}50%{box-shadow:inset 0 1px #ffe6b41a,0 0 12px #f5a62366}}.obj-hint{display:flex;align-items:flex-start;gap:var(--space-2);padding:8px var(--space-3);background:linear-gradient(180deg,#f5a6231a,#b86f0e0a);border:1px dashed var(--accent-deep);color:var(--accent);font-size:12px;line-height:1.45;clip-path:polygon(5px 0,100% 0,100% calc(100% - 5px),calc(100% - 5px) 100%,0 100%,0 5px);animation:pop-in .25s var(--ease-spring)}.obj-hint>svg{flex-shrink:0;margin-top:2px}.objective-item.completed{opacity:.7;border-color:var(--leaf-deep);background:linear-gradient(180deg,#6b9b3a1a,#4d74270d)}.obj-icon{color:var(--text-muted);flex-shrink:0;margin-top:2px}.obj-icon.done{color:var(--leaf);filter:drop-shadow(0 0 4px var(--leaf-glow))}.obj-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.obj-text{font-size:13px;color:var(--text-bright);line-height:1.4}.objective-item.completed .obj-text{text-decoration:line-through;color:var(--text-secondary)}.obj-progress-bar{height:4px;background:#00000080;overflow:hidden;border:1px solid rgba(0,0,0,.4)}.obj-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-deep));box-shadow:0 0 6px var(--accent-glow);transition:width var(--t-slow) var(--ease-out),background var(--t-base) var(--ease-out)}.objective-item.completed .obj-progress-fill{background:linear-gradient(90deg,var(--leaf),var(--leaf-deep));box-shadow:0 0 6px var(--leaf-glow)}.obj-counter{font-family:var(--font-mono);font-size:10px;color:var(--text-muted);letter-spacing:.05em;align-self:flex-end}.dialogue-overlay{position:fixed;inset:0;background:#050810c7;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:4000;padding:var(--space-6);animation:fadeIn .3s ease}.dialogue-box{background:linear-gradient(180deg,#322a20f5,#120e08fc),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.55 0 0 0 0 0.45 0 0 0 0 0.28 0 0 0 0.08 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");border:1px solid var(--accent-deep);padding:var(--space-5);max-width:440px;width:100%;clip-path:polygon(16px 0,100% 0,100% calc(100% - 16px),calc(100% - 16px) 100%,0 100%,0 16px);box-shadow:inset 0 1px #ffe6b41f,inset 0 -1px #00000080,0 24px 60px #000000b3,0 0 40px #f5a62326;animation:pop-in .35s var(--ease-spring)}.dialogue-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px dashed var(--border-3)}.dialogue-speaker-icon{font-size:24px;color:var(--accent);filter:drop-shadow(0 0 6px var(--accent-glow))}.dialogue-speaker{flex:1;font-family:var(--font-display);font-size:15px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);text-shadow:0 0 12px var(--accent-glow)}.dialogue-close{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:1px solid var(--border-2);border-radius:50%;color:var(--text-secondary);cursor:pointer;transition:all var(--t-fast) ease}.dialogue-close:hover{color:var(--text-bright);background:var(--surface-3)}.dialogue-lines{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.dialogue-line{font-size:14px;color:var(--text-primary);line-height:1.65;margin:0;padding-left:var(--space-3);border-left:2px solid var(--accent-deep);font-style:italic}.dialogue-continue{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:12px;background:linear-gradient(180deg,var(--accent),var(--accent-deep));border:1px solid var(--accent-deep);color:#1a0f00;font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);box-shadow:inset 0 1px #ffe6b473,inset 0 -2px #00000059,0 3px 0 var(--accent-deep),0 6px 16px var(--accent-glow);transition:filter var(--t-fast) var(--ease-out),transform var(--t-fast) var(--ease-spring)}.dialogue-continue:hover{filter:brightness(1.08)}.dialogue-continue:active{transform:translateY(2px)}.map-view{position:relative;display:flex;flex-direction:column;gap:16px;padding:76px 16px 16px;min-height:100%;overflow-y:auto}.map-hint{text-align:center;color:var(--text-muted);font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;margin-top:var(--space-3);opacity:.7}.quest-tracker{position:absolute;top:var(--space-3);left:var(--space-3);right:var(--space-3);z-index:20;display:flex;flex-direction:column;gap:6px;padding:10px 12px;background:linear-gradient(180deg,#322a20f5,#18140dfa);border:1px solid var(--accent-deep);color:var(--accent);font-family:var(--font-display);cursor:pointer;text-align:left;clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);box-shadow:inset 0 1px #ffe6b41f,inset 0 -1px #00000080,0 4px 12px #0006,0 0 18px #f5a6232e;transition:filter var(--t-base) var(--ease-out),transform var(--t-fast) var(--ease-spring)}.quest-tracker:hover{filter:brightness(1.12)}.quest-tracker.bounce{animation:quest-bounce 1.4s var(--ease-spring) infinite}.quest-tracker.all-done{border-color:var(--leaf-deep);box-shadow:inset 0 1px #ffe6b41f,inset 0 -1px #00000080,0 4px 12px #0006,0 0 22px var(--leaf-glow);animation:quest-pulse-done 1.2s var(--ease-out) infinite}.quest-tracker-top{display:flex;align-items:center;gap:8px}.quest-tracker-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;background:#00000059;border:1px solid var(--border-2);color:var(--accent);clip-path:polygon(4px 0,100% 0,100% calc(100% - 4px),calc(100% - 4px) 100%,0 100%,0 4px);flex-shrink:0}.quest-tracker-chapter{flex:1;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary)}.quest-tracker-count{font-family:var(--font-mono);font-size:13px;font-weight:800;color:var(--accent)}.quest-tracker.all-done .quest-tracker-count{color:var(--leaf)}.quest-tracker-next{display:flex;align-items:center;gap:6px;padding-left:30px;font-size:12px;color:#f5e9c8;text-transform:none;letter-spacing:0;line-height:1.3}.quest-tracker-next .quest-next-icon{color:#f5a623;flex-shrink:0;animation:quest-bob 1.6s ease-in-out infinite}.quest-tracker-next .quest-next-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quest-tracker-next .quest-next-progress{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);flex-shrink:0}.quest-tracker-next.done{color:var(--leaf)}.quest-pill{position:absolute;top:var(--space-3);right:var(--space-3);z-index:20;display:flex;align-items:center;gap:var(--space-2);padding:8px 12px;background:linear-gradient(180deg,#322a20f2,#18140dfa);border:1px solid var(--accent-deep);color:var(--accent);font-family:var(--font-display);cursor:pointer;clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);box-shadow:inset 0 1px #ffe6b41f,inset 0 -1px #00000080,0 4px 12px #0006,0 0 18px #f5a6232e;transition:filter var(--t-base) var(--ease-out),transform var(--t-fast) var(--ease-spring)}.quest-pill:hover{filter:brightness(1.15);transform:translateY(-1px)}.quest-pill.bounce{animation:quest-bounce 1.4s var(--ease-spring) infinite}.quest-pill.all-done{border-color:var(--leaf-deep);color:var(--leaf);box-shadow:inset 0 1px #ffe6b41f,inset 0 -1px #00000080,0 4px 12px #0006,0 0 22px var(--leaf-glow);animation:quest-pulse-done 1.2s var(--ease-out) infinite}@keyframes quest-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes quest-pulse-done{0%,to{filter:brightness(1)}50%{filter:brightness(1.2)}}.quest-pill-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#00000059;border:1px solid var(--border-2);clip-path:polygon(4px 0,100% 0,100% calc(100% - 4px),calc(100% - 4px) 100%,0 100%,0 4px)}.quest-pill-text{display:flex;flex-direction:column;line-height:1;gap:3px}.quest-pill-chapter{font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary)}.quest-pill-progress{font-family:var(--font-mono);font-size:12px;font-weight:800;letter-spacing:.05em;color:var(--accent)}.quest-pill.all-done .quest-pill-progress{color:var(--leaf)}.quest-tooltip{position:absolute;top:100%;right:0;margin-top:10px;padding:8px 12px;background:linear-gradient(180deg,var(--accent),var(--accent-deep));color:#1a0f00;font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;clip-path:polygon(6px 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%,0 6px);box-shadow:inset 0 1px #ffe6b473,inset 0 -1px #00000059,0 6px 18px var(--accent-glow);animation:tooltip-fade-in .35s var(--ease-spring);pointer-events:auto}.quest-tooltip-arrow{position:absolute;top:-6px;right:18px;width:12px;height:12px;background:var(--accent);transform:rotate(45deg);box-shadow:inset 0 1px #ffe6b473}@keyframes tooltip-fade-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.cell-sheet-backdrop{position:fixed;inset:0;background:#05081066;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:90;animation:fadeIn .2s ease}.cell-sheet{position:fixed;left:0;right:0;bottom:100px;z-index:95;max-height:70vh;display:flex;flex-direction:column;background:linear-gradient(180deg,var(--bg-elevated),var(--bg-medium));border-top:1px solid var(--border-3);border-radius:var(--r-2xl) var(--r-2xl) 0 0;box-shadow:0 -16px 48px #0009,0 -2px 6px #0006;transform:translateY(100%);transition:transform .32s var(--ease-out);padding-bottom:var(--space-4)}.cell-sheet.open{transform:translateY(0)}.cell-sheet:before{content:"";position:absolute;left:0;right:0;top:-1px;height:1px;background:linear-gradient(90deg,transparent,var(--accent-glow),transparent);pointer-events:none}.cell-sheet-handle{display:flex;align-items:center;justify-content:center;padding:10px 0 6px;cursor:pointer;flex-shrink:0}.cell-sheet-grip{width:44px;height:4px;background:var(--text-dim);border-radius:2px;transition:background var(--t-base) var(--ease-out)}.cell-sheet-handle:hover .cell-sheet-grip{background:var(--text-secondary)}.cell-sheet-close{position:absolute;top:10px;right:14px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:1px solid var(--border-2);border-radius:50%;color:var(--text-secondary);cursor:pointer;transition:all var(--t-fast) ease;z-index:2}.cell-sheet-close:hover{color:var(--text-bright);background:var(--surface-3)}.cell-sheet-body{flex:1;overflow-y:auto;padding:0 var(--space-4)}.cell-sheet .cell-panel{background:transparent;border:none;padding:0;border-radius:0}.cell-sheet .panel-header{padding-right:44px}.map-container{background:linear-gradient(180deg,#1f1a12d9,#120e08f2),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.5 0 0 0 0 0.4 0 0 0 0 0.25 0 0 0 0.1 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");border:1px solid var(--border-2);padding:var(--space-4);box-shadow:inset 0 1px #ffe6b414,inset 0 -1px #0009;clip-path:polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px)}.map-grid{display:flex;flex-direction:column;gap:4px}.map-row{display:flex;gap:4px;justify-content:center}.map-cell{width:46px;height:46px;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:transform var(--t-fast) var(--ease-spring),box-shadow var(--t-base) var(--ease-out);background:linear-gradient(180deg,#2a2418,#181208);border:1px solid var(--border-2);color:var(--text-muted);box-shadow:inset 0 1px #ffe6b40f,inset 0 -1px #00000080;clip-path:polygon(6px 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%,0 6px)}.map-cell:hover:not(.hidden){transform:scale(1.1);z-index:10;box-shadow:0 0 0 2px var(--accent),0 0 18px var(--accent-glow)}.map-cell.selected{box-shadow:0 0 0 2px var(--accent),0 0 22px var(--accent-glow);z-index:5}.era-shift-tag{font-size:10px;font-family:var(--font-mono);padding:2px 6px;margin-left:6px;border-radius:3px;letter-spacing:.05em}.era-shift-tag.ruin{background:#7850324d;color:#d4a574;border:1px solid rgba(212,165,116,.4)}.era-shift-tag.future{background:#508cb440;color:#a0e7ff;border:1px solid rgba(160,231,255,.4)}.current-building.era-ruin{opacity:.85;border-left:2px solid rgba(212,165,116,.5);padding-left:8px}.current-building.era-future{opacity:.85;border-left:2px solid rgba(160,231,255,.5);padding-left:8px}.map-cell.building-ruin{filter:grayscale(.7) brightness(.7)}.map-cell.building-ruin:after{content:"🏚";position:absolute;bottom:-2px;right:2px;font-size:10px;pointer-events:none;opacity:.85}.map-cell.building-future{filter:brightness(.85) saturate(.6);opacity:.7}.map-cell.building-future:after{content:"✦";position:absolute;bottom:-2px;right:2px;font-size:10px;color:#a0e7ff;pointer-events:none;opacity:.9}.map-cell.quest-target{box-shadow:0 0 0 2px #f5a623,0 0 22px #f5a6238c;z-index:6;animation:quest-pulse 1.6s ease-in-out infinite}.quest-marker{position:absolute;top:-8px;right:-8px;width:22px;height:22px;border-radius:50%;background:radial-gradient(circle,#ffd166,#f5a623 70%);color:#1a0f00;display:flex;align-items:center;justify-content:center;box-shadow:0 0 8px #f5a623e6,0 2px 4px #00000080;z-index:8;animation:quest-bob 1.8s ease-in-out infinite;pointer-events:none}@keyframes quest-pulse{0%,to{box-shadow:0 0 0 2px #f5a623,0 0 18px #f5a62373}50%{box-shadow:0 0 0 3px #ffd166,0 0 28px #f5a623d9}}@keyframes quest-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.map-cell.hidden{background:#0a080499;cursor:not-allowed;opacity:.45}.map-cell.explorable{background:linear-gradient(180deg,#3a2f1c,#1f1810);color:var(--accent);border-color:var(--accent-deep);animation:pulse 2s infinite;cursor:pointer}.map-cell.exploring{background:linear-gradient(180deg,var(--accent),var(--accent-deep));color:#1a0f00;border-color:var(--accent-deep)}.map-cell.region-beach{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#78350f}.map-cell.region-forest{background:linear-gradient(135deg,#22c55e,#16a34a);color:#052e16}.map-cell.region-mountain{background:linear-gradient(135deg,#64748b,#475569);color:#f1f5f9}.map-cell.region-grassland{background:linear-gradient(135deg,#84cc16,#65a30d);color:#1a2e05}@keyframes pulse{0%,to{opacity:.8}50%{opacity:1}}.exploring-content{display:flex;flex-direction:column;align-items:center;gap:2px}.explore-timer{font-size:10px;font-weight:700}.cell-panel{background:transparent;padding:var(--space-4) 0}.cell-panel.empty{display:flex;align-items:center;justify-content:center;min-height:80px;color:var(--text-muted);font-size:14px}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.panel-title{display:flex;align-items:center;gap:var(--space-2);color:var(--text-bright)}.panel-title h3{margin:0;font-family:var(--font-display);font-size:17px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.panel-desc{color:var(--text-secondary);font-size:13px;margin-bottom:var(--space-4);line-height:1.5}.current-building{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3);background:linear-gradient(180deg,#f5a62314,#b86f0e0a);border:1px solid var(--accent-deep);margin-bottom:var(--space-3);clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);box-shadow:inset 0 1px #ffe6b41a}.building-header-line{display:flex;align-items:center;gap:var(--space-2);color:var(--accent)}.building-name{font-size:13px;font-weight:700}.building-desc-inline{margin:4px 0 0;font-size:11px;color:#94a3b8;line-height:1.4}.building-production-status{display:flex;flex-direction:column;gap:4px}.production-progress-bar{height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.hazard-panel{display:flex;flex-direction:column;gap:8px;padding:12px;border-radius:12px;margin-bottom:12px;border:1px solid transparent}.hazard-heat{background:#ef44441a;border-color:#ef444433;color:#f87171}.hazard-cold{background:#60a5fa1a;border-color:#60a5fa33;color:#f5a623}.hazard-poison{background:#a855f71a;border-color:#a855f733;color:#a855f7}.hazard-header{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700}.hazard-damage{margin-left:auto;font-size:11px;background:#0003;padding:2px 6px;border-radius:4px}.hazard-mitigation{display:flex;flex-direction:column;gap:4px}.mitigation-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;opacity:.8}.mitigation-items{display:flex;flex-wrap:wrap;gap:6px}.mitigation-item{font-size:11px;padding:4px 8px;background:#0003;border-radius:6px;color:#f1f5f9;opacity:.5}.mitigation-item.equipped{opacity:1;background:#22c55e33;border:1px solid rgba(34,197,94,.3);color:#4ade80}.production-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-deep));box-shadow:0 0 6px var(--accent-glow);transition:width .4s ease}.production-info-text{display:flex;align-items:center;gap:4px;color:#94a3b8;font-size:11px;font-weight:500}.panel-tabs{display:flex;gap:6px;margin-bottom:var(--space-3)}.tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;background:linear-gradient(180deg,#322a2099,#18140dcc);border:1px solid var(--border-2);color:var(--text-muted);font-family:var(--font-display);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all var(--t-base) var(--ease-out);clip-path:polygon(6px 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%,0 6px);box-shadow:inset 0 1px #ffe6b40f}.tab.active{background:linear-gradient(180deg,var(--accent),var(--accent-deep));border-color:var(--accent-deep);color:#1a0f00;box-shadow:inset 0 1px #ffe6b473,inset 0 -2px #00000059,0 3px 10px var(--accent-glow)}.tab:hover:not(.active){color:var(--text-secondary);border-color:var(--accent-deep)}.panel-content{max-height:180px;overflow-y:auto}.no-items{color:#64748b;text-align:center;padding:20px;font-size:13px}.activities-list,.buildings-list{display:flex;flex-direction:column;gap:6px}.action-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:linear-gradient(180deg,#322a2073,#18140da6);border:1px solid var(--border-1);cursor:pointer;transition:all var(--t-base) var(--ease-out);text-align:left;clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);box-shadow:inset 0 1px #ffe6b40d}.action-item:hover:not(.disabled){background:linear-gradient(180deg,#f5a6231f,#b86f0e0f);border-color:var(--accent-deep)}.action-item.disabled{opacity:.5;cursor:not-allowed}.action-icon{width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#3c3224cc,#1c160ef2);border:1px solid var(--border-2);color:var(--accent);clip-path:polygon(6px 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%,0 6px);box-shadow:inset 0 1px #ffe6b41a}.action-info{flex:1;display:flex;flex-direction:column;gap:4px}.action-name{color:var(--text-bright);font-weight:600;font-size:13px}.action-desc{margin:0;font-size:11px;line-height:1.4;color:var(--text-muted);opacity:.9}.action-effect{display:inline-block;font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;color:var(--leaf);background:#6b9b3a14;border:1px solid rgba(107,155,58,.25);padding:2px 7px;border-radius:4px;width:fit-content;font-weight:600}.missing-req{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--rose)}.action-arrow{color:var(--text-muted)}.materials{display:flex;flex-wrap:wrap;gap:6px}.mat{font-family:var(--font-mono);font-size:10px;padding:3px 7px;font-weight:700;border:1px solid;letter-spacing:.02em}.mat.ok{color:var(--leaf);background:#6b9b3a1a;border-color:#6b9b3a4d}.mat.need{color:var(--rose);background:#c84f3a1a;border-color:#c84f3a4d}.action-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px;border:1px solid var(--accent-deep);font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:filter var(--t-fast) var(--ease-out),transform var(--t-fast) var(--ease-spring);clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px)}.action-btn.primary{background:linear-gradient(180deg,var(--accent),var(--accent-deep));color:#1a0f00;box-shadow:inset 0 1px #ffe6b473,inset 0 -2px #00000059,0 3px 0 var(--accent-deep),0 6px 14px var(--accent-glow)}.action-btn.primary:hover{filter:brightness(1.08)}.action-btn.primary:active{transform:translateY(2px)}.btn-badge{font-family:var(--font-mono);font-size:10px;padding:3px 8px;background:#00000059;border:1px solid rgba(0,0,0,.5);letter-spacing:.04em}.travel-cost-preview{display:flex;gap:var(--space-3);justify-content:center;margin:var(--space-2) 0;padding:6px 10px;background:#00000059;border:1px solid var(--border-2);clip-path:polygon(5px 0,100% 0,100% calc(100% - 5px),calc(100% - 5px) 100%,0 100%,0 5px)}.travel-cost-preview .cost-item{font-family:var(--font-mono);font-size:12px;color:var(--accent);font-weight:700;letter-spacing:.05em}@media(max-width:380px){.map-cell{width:40px;height:40px}}.map-cell.era-pirate{filter:hue-rotate(-12deg) saturate(.9) brightness(.92);box-shadow:inset 0 0 8px #6b1e1e40}.map-cell.era-colonial{filter:sepia(.45) saturate(.85) brightness(.9);box-shadow:inset 0 0 8px #9a8c5c40}.map-cell.era-ancient{filter:hue-rotate(20deg) saturate(1.1) brightness(.95);box-shadow:inset 0 0 8px #d4c4a04d}.map-cell.era-prehistoric{filter:hue-rotate(-25deg) saturate(.8) brightness(.88);box-shadow:inset 0 0 8px #6a5a3a4d}.map-cell.era-future{filter:hue-rotate(180deg) saturate(.7) brightness(.85) contrast(1.1);box-shadow:inset 0 0 10px #00f5d440}.crafting-view{display:flex;flex-direction:column;height:100%;background:transparent;color:var(--text-bright)}.view-header{padding:var(--space-5);display:flex;justify-content:space-between;align-items:center;background:linear-gradient(180deg,var(--surface-2),transparent);border-bottom:1px solid var(--border-1);position:relative}.view-header:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;background:linear-gradient(90deg,transparent,var(--accent-glow),transparent);pointer-events:none}.header-left{display:flex;align-items:center;gap:var(--space-3)}.header-left h2{margin:0;font-family:var(--font-display);font-size:20px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-bright)}.header-left p{margin:0;font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);letter-spacing:.05em}.crafting-controls{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-4);background:var(--surface-1)}.search-bar{position:relative;display:flex;align-items:center}.search-bar svg{position:absolute;left:14px;color:var(--text-muted);transition:color var(--t-base) var(--ease-out)}.search-bar input{width:100%;background:var(--surface-2);border:1px solid var(--border-2);border-radius:var(--r-lg);padding:12px 12px 12px 42px;color:var(--text-bright);font-family:var(--font-body);font-size:14px;transition:all var(--t-base) var(--ease-out);box-shadow:var(--shadow-inset)}.search-bar input::placeholder{color:var(--text-muted)}.search-bar input:focus{outline:none;background:var(--surface-3);border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow),var(--shadow-inset)}.search-bar input:focus+svg,.search-bar:focus-within svg{color:var(--accent)}.clear-search{position:absolute;right:12px;background:none;border:none;color:var(--text-muted);cursor:pointer;transition:color var(--t-fast) ease}.clear-search:hover{color:var(--text-bright)}.filter-chips{display:flex;gap:var(--space-2);overflow-x:auto;padding-bottom:var(--space-1);scrollbar-width:none}.filter-chips::-webkit-scrollbar{display:none}.chip{white-space:nowrap;padding:8px 16px;background:linear-gradient(180deg,#322a2099,#18140dcc);border:1px solid var(--border-2);color:var(--text-secondary);font-family:var(--font-display);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all var(--t-base) var(--ease-out);display:flex;align-items:center;gap:6px;clip-path:polygon(6px 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%,0 6px);box-shadow:inset 0 1px #ffe6b414,inset 0 -1px #0006}.chip:hover{color:var(--text-bright);border-color:var(--accent-deep)}.chip.active{background:linear-gradient(180deg,var(--accent) 0%,var(--accent-deep) 100%);border-color:var(--accent-deep);color:#1a0f00;box-shadow:inset 0 1px #ffe6b473,inset 0 -2px #0006,0 4px 12px var(--accent-glow)}.crafting-content{flex:1;overflow-y:auto;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-6)}.recipe-section{display:flex;flex-direction:column;gap:var(--space-3)}.section-title{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.16em;position:relative;padding-left:var(--space-3)}.section-title:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:14px;background:linear-gradient(180deg,var(--accent),var(--accent-deep));border-radius:2px;box-shadow:0 0 8px var(--accent-glow)}.recipes-grid{display:flex;flex-direction:column;gap:var(--space-3)}.recipe-card{background:linear-gradient(180deg,#322a20b3,#18140de0),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.55 0 0 0 0 0.45 0 0 0 0 0.28 0 0 0 0.08 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");border:1px solid var(--border-2);overflow:hidden;transition:transform var(--t-base) var(--ease-spring),border-color var(--t-base) var(--ease-out);box-shadow:inset 0 1px #ffe6b414,inset 0 -1px #00000080,0 4px 12px #00000073;position:relative;clip-path:polygon(12px 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%,0 12px)}.recipe-card:before{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(circle at top left,rgba(96,165,250,.06),transparent 60%);opacity:0;transition:opacity var(--t-base) var(--ease-out);pointer-events:none}.recipe-card:hover{transform:translateY(-2px);border-color:var(--border-2);box-shadow:var(--shadow-3),var(--shadow-inset)}.recipe-card.craftable{background:linear-gradient(135deg,#f5a62329,#28221ad9 70%),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.55 0 0 0 0 0.45 0 0 0 0 0.28 0 0 0 0.08 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");border-color:var(--accent-deep);box-shadow:inset 0 1px #ffe6b426,inset 0 -1px #00000080,0 0 0 1px #f5a62326,0 6px 18px #f5a6231f}.recipe-card.craftable:before{opacity:1}.recipe-card.craftable:hover{border-color:var(--border-glow);box-shadow:0 0 0 1px var(--border-glow),0 12px 32px var(--accent-glow),var(--shadow-inset)}.recipe-main{padding:var(--space-4);display:flex;gap:14px;position:relative;z-index:1}.recipe-icon-wrap{width:50px;height:50px;background:linear-gradient(180deg,#322a20cc,#18140df2);border:1px solid var(--border-2);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);flex-shrink:0;box-shadow:inset 0 1px #ffe6b41a,inset 0 -1px #00000080;transition:all var(--t-base) var(--ease-out);clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px)}.recipe-card.craftable .recipe-icon-wrap{background:linear-gradient(180deg,var(--accent) 0%,var(--accent-deep) 100%);border-color:var(--accent-deep);color:#1a0f00;box-shadow:inset 0 1px #ffe6b473,inset 0 -2px #0006,0 0 16px var(--accent-glow)}.recipe-info{flex:1;min-width:0}.recipe-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-1);gap:var(--space-2)}.recipe-top h3{margin:0;font-size:16px;font-weight:700;color:var(--text-bright);letter-spacing:-.01em}.fav-star{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:var(--space-1);border-radius:50%;transition:color var(--t-fast) ease,transform var(--t-fast) var(--ease-spring)}.fav-star:hover{color:var(--ember);transform:scale(1.2)}.fav-star.active{color:#fbbf24;filter:drop-shadow(0 0 4px rgba(251,191,36,.5))}.recipe-desc{margin:0 0 var(--space-3) 0;font-size:12px;color:var(--text-secondary);line-height:1.45}.recipe-requirements{display:flex;flex-wrap:wrap;gap:var(--space-1)}.mini-mat{padding:4px 8px;background:#00000059;border:1px solid var(--border-1);border-radius:var(--r-sm);font-family:var(--font-mono);font-size:10px;font-weight:600;display:flex;gap:var(--space-1);letter-spacing:.02em}.mini-mat.ok{color:var(--leaf);border-color:#22c55e40;background:#22c55e14}.mini-mat.missing{color:var(--rose);border-color:#ef444440;background:#ef444414}.mat-count{font-weight:800}.craft-action-btn{width:100%;padding:13px;border:none;background:var(--surface-2);border-top:1px solid var(--border-1);color:var(--text-secondary);font-family:var(--font-body);font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:var(--space-2);cursor:pointer;transition:all var(--t-base) var(--ease-out);position:relative;overflow:hidden}.recipe-card.craftable .craft-action-btn{background:linear-gradient(180deg,#f5a62333,#b86f0e1a);border-top-color:var(--accent-deep);color:var(--accent)}.recipe-card.craftable .craft-action-btn:hover{background:linear-gradient(180deg,var(--accent),var(--accent-deep));color:#1a0f00;letter-spacing:.14em}.craft-action-btn:disabled{cursor:not-allowed}.no-recipes{padding:var(--space-10) var(--space-5);text-align:center;color:var(--text-muted);font-size:14px;font-style:italic}.onboarding-hint{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:linear-gradient(180deg,#f5a6232e,#f5a62314);border:1px solid var(--accent-deep);color:#f5e9c8;font-size:12px;line-height:1.4;clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);box-shadow:inset 0 1px #ffe6b426,0 2px 8px #0000004d,0 0 16px #f5a6232e;animation:onboarding-slide .35s var(--ease-out);margin-bottom:4px}@keyframes onboarding-slide{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.onboarding-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:22px;height:22px;background:#f5a62340;border:1px solid var(--accent-deep);color:var(--accent);border-radius:50%;animation:onboarding-pulse 1.8s ease-in-out infinite}@keyframes onboarding-pulse{0%,to{box-shadow:0 0 #f5a62366}50%{box-shadow:0 0 0 5px #f5a62300}}.onboarding-text{flex:1;color:#f5e9c8}.onboarding-close{background:transparent;border:1px solid var(--border-2);color:var(--text-muted);width:22px;height:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all var(--t-fast) var(--ease-out)}.onboarding-close:hover{color:var(--text);border-color:var(--accent-deep)}.inventory-view{padding:16px;height:100%;overflow-y:auto}.inventory-search{position:relative;display:flex;align-items:center;gap:8px;margin:0 0 12px;padding:6px 10px 6px 32px;background:var(--bg-surface, #1f2937);border:1px solid var(--border, #334155);border-radius:8px;transition:border-color .15s}.inventory-search:focus-within{border-color:var(--accent, #38bdf8)}.inventory-search-icon{position:absolute;left:10px;color:var(--text-secondary, #94a3b8);pointer-events:none}.inventory-search-input{flex:1;background:transparent;border:none;outline:none;color:var(--text-bright, #f1f5f9);font-size:13px;padding:6px 0;font-family:inherit}.inventory-search-input::placeholder{color:var(--text-muted, #64748b)}.inventory-search-clear{background:transparent;border:1px solid var(--border, #334155);border-radius:50%;width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-secondary, #94a3b8);cursor:pointer;transition:all .15s}.inventory-search-clear:hover{border-color:var(--accent, #38bdf8);color:var(--text-bright, #f1f5f9)}.view-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;color:#f1f5f9}.view-header h2{margin:0;font-size:18px;font-weight:700}.view-header p{margin:2px 0 0;font-size:12px;color:#64748b}.empty-inventory{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:#64748b}.empty-inventory p{margin:16px 0 4px;font-size:16px;font-weight:600;color:#94a3b8}.empty-inventory span{font-size:13px}.inventory-categories{display:flex;flex-direction:column;gap:16px}.category-section{background:linear-gradient(180deg,#28221ab3,#120e08d9),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.55 0 0 0 0 0.45 0 0 0 0 0.28 0 0 0 0.08 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");border:1px solid var(--border-2);overflow:hidden;box-shadow:inset 0 1px #ffe6b414,inset 0 -1px #00000080;clip-path:polygon(12px 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%,0 12px)}.category-header{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#0000004d;border-bottom:1px solid var(--border-2);color:var(--accent);font-family:var(--font-display);font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;padding:12px}.item-card{display:flex;flex-direction:column;align-items:center;padding:14px 10px;background:linear-gradient(180deg,#322a208c,#18140dbf);border:1px solid var(--border-2);transition:all var(--t-base) var(--ease-out);gap:6px;clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);box-shadow:inset 0 1px #ffe6b40f}.item-card:hover{border-color:var(--accent-deep);background:linear-gradient(180deg,#463a28b3,#1e1810d9)}.item-card.usable{border-color:#6b9b3a4d}.item-icon{width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#3c3224cc,#1c160ef2);border:1px solid var(--border-2);color:var(--accent);clip-path:polygon(6px 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%,0 6px);box-shadow:inset 0 1px #ffe6b41a}.item-name{font-size:11px;color:#f1f5f9;font-weight:600;text-align:center}.item-amount{font-size:13px;color:#22c55e;font-weight:800}.use-btn{display:flex;align-items:center;gap:4px;margin-top:4px;padding:6px 10px;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:8px;color:#fff;font-size:11px;font-weight:700;cursor:pointer;transition:all .2s ease}.use-btn:hover{transform:scale(1.05)}.item-card.expanded{background:#ffffff0f;border-color:#94a3b833}.item-description{width:100%;padding:6px 0 0;border-top:1px solid rgba(255,255,255,.06);margin-top:2px;font-size:10px;color:#94a3b8;text-align:center;line-height:1.4}.item-card{cursor:pointer}@media(max-width:360px){.items-grid{grid-template-columns:repeat(3,1fr)}}.view-header{justify-content:space-between}.header-title{display:flex;align-items:center;gap:12px}.equipment-toggle{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#322a20b3,#18140dd9);border:1px solid var(--border-2);color:var(--text-secondary);transition:all var(--t-base) var(--ease-out);clip-path:polygon(6px 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%,0 6px)}.equipment-toggle.active{color:#f5a623;background:#f5a6231a;border-color:#f5a62333}.equipment-panel{background:linear-gradient(180deg,#322a20bf,#120e08e6),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.55 0 0 0 0 0.45 0 0 0 0 0.28 0 0 0 0.1 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");border:1px solid var(--accent-deep);padding:16px;margin-bottom:24px;clip-path:polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px);box-shadow:inset 0 1px #ffe6b41f,inset 0 -1px #00000080,0 6px 18px #00000080}.equipment-panel h3{margin:0;font-family:var(--font-display);font-size:14px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.14em}.equipment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.defense-badge{display:flex;align-items:center;gap:6px;padding:4px 8px;background:#f5a6231a;border:1px solid rgba(245,166,35,.2);border-radius:8px;color:#f5a623;font-size:11px;font-weight:700}.equipment-slots{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.equip-slot{background:linear-gradient(180deg,#1c160eb3,#0e0a06d9);border:1px dashed var(--border-3);padding:10px;display:flex;flex-direction:column;gap:8px;min-height:90px;cursor:pointer;transition:all var(--t-base) var(--ease-out);clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);box-shadow:inset 0 1px #ffe6b40a}.equip-slot:hover{border-color:var(--accent-deep)}.equip-slot.active{border-style:solid;border-color:var(--accent);background:linear-gradient(180deg,#f5a62326,#b86f0e0f);box-shadow:inset 0 1px #ffe6b426,0 0 18px var(--accent-glow)}.equip-slot.filled{border-style:solid;border-color:var(--accent-deep);background:linear-gradient(180deg,#f5a6231f,#b86f0e0d);box-shadow:inset 0 1px #ffe6b414}.slot-label{font-size:10px;font-weight:700;color:#64748b;text-transform:uppercase}.slot-content{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;justify-content:center}.equipped-name{font-size:10px;font-weight:600;color:#f1f5f9;text-align:center}.unequip-btn{padding:4px 8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#94a3b8;font-size:9px;font-weight:600;transition:all .2s ease}.unequip-btn:hover{background:#c84f3a1a;color:#c84f3a;border-color:#c84f3a33}.empty-slot-icon{display:flex;flex-direction:column;align-items:center;gap:8px;opacity:.4}.slot-hint{font-size:9px;color:#94a3b8;text-align:center;font-weight:600}.equip-slot.active .slot-hint{color:#f5a623}.filter-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:#f5a6231a;border:1px solid rgba(245,166,35,.2);border-radius:10px;margin-bottom:16px;font-size:12px;color:#f1f5f9}.filter-header strong{color:#f5a623;text-transform:uppercase}.clear-filter{padding:4px 10px;background:#ffffff1a;border:none;border-radius:6px;color:#fff;font-size:10px;font-weight:700;cursor:pointer}.clear-filter:hover{background:#fff3}.item-card.compatible{border-color:#e08e15;background:#f5a6230d;transform:scale(1.02);box-shadow:0 0 10px #f5a6231a}.equip-btn.highlight{animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #f5a62399}70%{box-shadow:0 0 0 10px #f5a62300}to{box-shadow:0 0 #f5a62300}}.item-actions{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;width:100%;margin-top:4px}.item-card.equippable{border-color:#f5a62333}.equip-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;background:linear-gradient(135deg,#e08e15,#b86f0e);border:none;border-radius:8px;color:#fff;font-size:11px;font-weight:700;cursor:pointer;transition:all .2s ease}.equip-btn:hover{transform:scale(1.05)}.journal-view{padding:var(--space-4);height:100%;overflow-y:auto}.view-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-5);color:var(--text-bright)}.view-header>svg{color:var(--accent);filter:drop-shadow(0 0 6px var(--accent-glow))}.view-header h2{margin:0;font-family:var(--font-display);font-size:18px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-bright)}.view-header p{margin:2px 0 0;font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);letter-spacing:.05em}.journal-entries{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-3)}.turn-group{background:linear-gradient(180deg,#28221ab3,#120e08d9),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.55 0 0 0 0 0.45 0 0 0 0 0.28 0 0 0 0.08 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");border:1px solid var(--border-2);overflow:hidden;clip-path:polygon(12px 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%,0 12px);box-shadow:inset 0 1px #ffe6b414,inset 0 -1px #00000080}.turn-header{padding:10px var(--space-4);background:#0000004d;border-bottom:1px solid var(--accent-deep);font-family:var(--font-display);font-size:11px;font-weight:600;color:var(--accent);letter-spacing:.14em;text-transform:uppercase}.entries-list{padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.journal-entry{display:flex;align-items:flex-start;gap:var(--space-3);padding:10px var(--space-3);background:linear-gradient(180deg,#322a2073,#18140da6);border:1px solid var(--border-1);font-size:12px;color:var(--text-primary);transition:all var(--t-base) var(--ease-out);clip-path:polygon(6px 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%,0 6px);box-shadow:inset 0 1px #ffe6b40d;position:relative}.journal-entry:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:currentColor;opacity:.6}.journal-entry>svg{flex-shrink:0;margin-top:1px;color:currentColor}.journal-entry>span{color:var(--text-primary);line-height:1.5;flex:1}.journal-entry:hover{background:linear-gradient(180deg,#463a288c,#1e1810bf);border-color:var(--accent-deep)}.journal-entry.type-info{color:var(--text-secondary)}.journal-entry.type-activity,.journal-entry.type-craft{color:var(--accent)}.journal-entry.type-build{color:var(--leaf)}.journal-entry.type-exploration{color:var(--accent)}.journal-entry.type-stats_decay{color:var(--rose)}.journal-entry.type-building_production{color:var(--leaf)}.journal-entry.type-exploration_complete{color:var(--accent)}.journal-entry.type-random_event{color:var(--ember)}.journal-entry.type-use{color:var(--leaf)}.empty-journal{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px var(--space-5);text-align:center;color:var(--text-muted)}.empty-journal>svg{color:var(--accent);opacity:.5}.empty-journal p{margin:var(--space-4) 0 0;font-family:var(--font-display);font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary)}.journal-tabs{display:flex;gap:var(--space-2);margin:var(--space-4) 0 var(--space-3);border-bottom:1px solid var(--border)}.journal-tab{display:flex;align-items:center;gap:6px;padding:8px 14px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:all .2s}.journal-tab:hover{color:var(--text-bright)}.journal-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.archive-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:var(--accent);color:var(--bg);border-radius:9px;font-size:10px;font-weight:700;margin-left:4px}.lore-archive{padding:var(--space-3);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.lore-archive-header{display:flex;align-items:center;gap:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--border);margin-bottom:var(--space-3);color:var(--text-bright)}.lore-archive-header>svg{color:var(--accent);filter:drop-shadow(0 0 6px var(--accent-glow))}.lore-archive-header h3{margin:0;font-family:var(--font-display);font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-bright)}.lore-archive-header p{margin:0;font-family:var(--font-mono);font-size:11px;color:var(--text-secondary)}.lore-archive-empty{text-align:center;padding:var(--space-5);color:var(--text-secondary)}.lore-archive-empty svg{margin-bottom:var(--space-2);opacity:.5}.lore-archive-empty p{margin:0;font-size:13px}.lore-archive-empty-hint{font-size:11px!important;color:var(--text-secondary);margin-top:var(--space-2)!important;line-height:1.5;max-width:340px;margin-left:auto;margin-right:auto;opacity:.8}.lore-category{margin-bottom:var(--space-3)}.lore-category-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);color:var(--text-bright);font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.05em}.lore-category-header .lore-count{margin-left:auto;color:var(--text-secondary);font-size:11px}.lore-items{display:flex;flex-direction:column;gap:4px}.lore-item{padding:var(--space-2) var(--space-3);background:var(--bg-surface);border:1px solid var(--border-soft);border-radius:var(--radius-sm);font-size:12px;transition:all .2s}.lore-item.locked{color:var(--text-tertiary);font-style:italic;text-align:center;opacity:.5}.lore-item.found{cursor:pointer;color:var(--text);border-color:var(--accent-dim, var(--border))}.lore-item.found:hover,.lore-item.open{background:var(--bg-hover);border-color:var(--accent)}.lore-item-title{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.lore-item-title>span:first-child{font-weight:600;color:var(--text-bright)}.lore-era{font-size:14px}.lore-item-body{margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px dashed var(--border-soft);color:var(--text);line-height:1.5;font-size:12px;white-space:pre-line}.reputation-panel{padding:var(--space-3);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.reputation-header{display:flex;align-items:center;gap:var(--space-2);padding-bottom:var(--space-3);border-bottom:1px solid var(--border);margin-bottom:var(--space-3);color:var(--text-bright)}.reputation-header>svg{color:var(--accent)}.reputation-header h3{margin:0;font-family:var(--font-display);font-size:13px;letter-spacing:.08em;text-transform:uppercase;flex:1}.rep-count{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary)}.reputation-list{display:flex;flex-direction:column;gap:4px}.rep-row{display:grid;grid-template-columns:auto 1fr auto auto;gap:var(--space-2);align-items:center;padding:6px 10px;background:var(--bg-surface);border:1px solid var(--border-soft);border-radius:var(--radius-sm);font-size:12px}.rep-icon{font-size:16px}.rep-name{color:var(--text-bright);font-weight:600}.rep-band{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.05em;padding:2px 7px;border-radius:10px}.rep-val{font-family:var(--font-mono);font-size:11px;min-width:28px;text-align:right;color:var(--text-secondary)}.rep-row.ally{border-color:#22c55e66}.rep-row.ally .rep-band{background:#22c55e26;color:#22c55e}.rep-row.friend .rep-band{background:#3b82f626;color:#3b82f6}.rep-row.neutral .rep-band{background:var(--bg-hover);color:var(--text-secondary)}.rep-row.tense .rep-band{background:#f59e0b26;color:#f59e0b}.rep-row.enemy{border-color:#dc262666}.rep-row.enemy .rep-band{background:#dc262626;color:#dc2626}.rep-row-wrap{display:flex;flex-direction:column;gap:4px}.rep-row{grid-template-columns:auto 1fr auto auto auto;cursor:pointer;text-align:left;color:var(--text);transition:all .18s;width:100%}.rep-row:hover{border-color:var(--accent);background:var(--bg-hover)}.rep-row.expanded{border-color:var(--accent)}.rep-actions{margin:0 var(--space-2) var(--space-2);padding:var(--space-2);background:#ffffff05;border:1px solid var(--border-soft);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:var(--space-2)}.rep-section-label{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#34d399}.rep-gifts{display:flex;flex-direction:column;gap:4px}.rep-gift-btn{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg-surface);border:1px solid rgba(52,211,153,.25);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;font-size:12px;text-align:left;transition:all .15s}.rep-gift-btn:hover{border-color:#34d399;background:var(--bg-hover);transform:translate(2px)}.rep-gift-icon{font-size:14px}.rep-gift-name{flex:1;color:var(--text-bright)}.rep-gift-rep{font-family:var(--font-mono);font-size:10px;color:#34d399;font-weight:700;background:#34d39926;padding:1px 6px;border-radius:6px}.rep-steal-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:#f871710d;border:1px solid rgba(248,113,113,.35);border-radius:var(--radius-sm);color:#fca5a5;cursor:pointer;font-size:12px;transition:all .15s;align-self:flex-start}.rep-steal-btn:hover{border-color:#f87171;background:#f871711f}.rep-empty-line{font-size:11px;color:var(--text-secondary);opacity:.7;font-style:italic}.rep-attempts{margin-left:auto;font-family:var(--font-mono);font-size:10px;color:#fbbf24;background:#f59e0b26;padding:1px 5px;border-radius:4px;font-weight:700}.rep-talk-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:var(--bg-surface);border:1px solid var(--accent);border-radius:var(--radius-sm);color:var(--text-bright);cursor:pointer;font-size:12px;font-weight:600;transition:all .15s;align-self:flex-start}.rep-talk-btn:hover{background:var(--accent-glow);box-shadow:0 0 12px var(--accent-glow)}.conv-overlay{position:fixed;inset:0;background:#000000bf;z-index:180;display:flex;align-items:center;justify-content:center;padding:16px;animation:conv-fade .18s ease-out}@keyframes conv-fade{0%{opacity:0}to{opacity:1}}.conv-modal{position:relative;width:100%;max-width:480px;max-height:84vh;overflow-y:auto;background:linear-gradient(180deg,#322a20fa,#18140d);border:1px solid var(--accent-deep);color:var(--text);clip-path:polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px);box-shadow:inset 0 1px #ffe6b41a,0 12px 40px #000000b3}.conv-close{position:absolute;top:10px;right:10px;background:transparent;border:1px solid var(--border-2);color:var(--text-muted);width:26px;height:26px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--t-fast) var(--ease-out);z-index:1}.conv-close:hover{color:var(--accent);border-color:var(--accent-deep)}.conv-header{display:flex;align-items:center;gap:12px;padding:16px 18px 14px;border-bottom:1px solid var(--border-2)}.conv-icon{font-size:32px;line-height:1}.conv-name{font-family:var(--font-display);font-size:16px;color:var(--accent);letter-spacing:.05em}.conv-sub{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10px;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;margin-top:2px}.conv-progress{margin-left:6px;padding:1px 5px;background:#0006;border:1px solid var(--border-2);color:var(--accent);font-size:9px;border-radius:2px}.conv-body{padding:18px;display:flex;flex-direction:column;gap:12px;min-height:80px}.conv-line{margin:0;font-size:14px;line-height:1.6;color:#f5e9c8}.conv-narrate{margin:0;font-size:13px;line-height:1.55;color:var(--text-muted);font-style:italic}.conv-empty{margin:0;text-align:center;color:var(--text-muted);font-style:italic;font-size:13px}.conv-actions{display:flex;flex-direction:column;gap:8px;padding:0 18px 18px}.conv-next-btn,.conv-end-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;cursor:pointer;transition:all var(--t-fast) var(--ease-out);clip-path:polygon(4px 0,100% 0,100% calc(100% - 4px),calc(100% - 4px) 100%,0 100%,0 4px)}.conv-next-btn{background:linear-gradient(180deg,var(--accent),var(--accent-deep));color:#1a0f00;border:1px solid var(--accent);font-weight:700}.conv-next-btn:hover{filter:brightness(1.1)}.conv-end-btn{background:#0000004d;border:1px solid var(--border-2);color:var(--text-secondary)}.conv-end-btn:hover{color:var(--text);border-color:var(--accent-deep)}.notification{position:fixed;top:calc(env(safe-area-inset-top,0px) + 16px);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;padding:12px 20px;background:#1e293b;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#f1f5f9;font-size:13px;font-weight:600;z-index:3000;animation:slideDown .3s ease;cursor:pointer;box-shadow:0 8px 32px #0006}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.notification.success{background:linear-gradient(135deg,#166534,#15803d);border-color:#22c55e4d}.notification.warning{background:linear-gradient(135deg,#92400e,#a16207);border-color:#f59e0b4d}.notification.error{background:linear-gradient(135deg,#991b1b,#b91c1c);border-color:#dc26264d}.notification.info{background:linear-gradient(135deg,#b86f0e,#925812);border-color:#f5a6234d}.event-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;padding:20px;z-index:4000;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.event-modal{background:#0f0f1a;border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:24px;max-width:380px;width:100%;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.event-header{display:flex;align-items:center;gap:14px;margin-bottom:16px}.event-icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#dc2626,#7f1d1d);border-radius:14px;color:#fff}.event-header h2{margin:0;font-size:20px;font-weight:800;color:#f1f5f9}.event-description{color:#94a3b8;font-size:14px;line-height:1.6;margin-bottom:24px;padding:14px;background:#ffffff05;border-radius:12px;border-left:3px solid #dc2626}.event-choices{display:flex;flex-direction:column;gap:10px}.choice-btn{display:flex;align-items:center;padding:16px;border:2px solid;border-radius:14px;cursor:pointer;transition:all .2s ease;text-align:left}.choice-btn:hover{transform:translate(4px)}.choice-btn:active{transform:translate(2px)}.choice-header{display:flex;align-items:center;gap:12px;width:100%}.choice-text{flex:1;font-size:15px;font-weight:700;color:#f1f5f9}.bonus-indicator{display:flex;align-items:center;justify-content:center;width:22px;height:22px;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:6px;color:#fff;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.choice-btn.danger-high{color:#dc2626}.choice-btn.danger-medium{color:#f59e0b}.choice-btn.danger-low{color:#22c55e}.event-modal.result{text-align:center}.result-icon{width:72px;height:72px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;border-radius:50%}.result-icon.success{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.result-icon.failure{background:linear-gradient(135deg,#dc2626,#991b1b);color:#fff}.event-modal.result h2{text-align:center;margin-bottom:12px}.event-modal.result.success h2{color:#22c55e}.event-modal.result.failure h2{color:#dc2626}.result-message{color:#94a3b8;font-size:14px;margin-bottom:20px}.result-rewards{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:16px}.reward-item{padding:8px 14px;background:#22c55e26;border:1px solid rgba(34,197,94,.3);border-radius:10px;color:#22c55e;font-size:13px;font-weight:700}.result-damage{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:16px}.damage-item{padding:8px 14px;background:#dc262626;border:1px solid rgba(220,38,38,.3);border-radius:10px;color:#dc2626;font-size:13px;font-weight:700}.continue-btn{width:100%;padding:16px;background:linear-gradient(135deg,#e08e15,#b86f0e);border:none;border-radius:14px;color:#fff;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s ease}.continue-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f5a62359}.mode-select-screen{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(ellipse at top,#1a1208,#0a0805 80%),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.5 0 0 0 0 0.4 0 0 0 0 0.25 0 0 0 0.08 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");padding:var(--space-6) var(--space-5);gap:var(--space-8);overflow:hidden}.mode-bg{position:absolute;inset:0;pointer-events:none;z-index:0}.mode-bg-stars{position:absolute;inset:0;background-image:radial-gradient(1px 1px at 12% 18%,#ffffff 50%,transparent),radial-gradient(1px 1px at 28% 42%,rgba(255,255,255,.6) 50%,transparent),radial-gradient(1.5px 1.5px at 54% 12%,#ffffff 50%,transparent),radial-gradient(1px 1px at 72% 28%,rgba(255,255,255,.5) 50%,transparent),radial-gradient(1px 1px at 88% 58%,#ffffff 50%,transparent),radial-gradient(1px 1px at 38% 72%,rgba(255,255,255,.7) 50%,transparent),radial-gradient(1.5px 1.5px at 18% 88%,#ffffff 50%,transparent),radial-gradient(1px 1px at 64% 82%,rgba(255,255,255,.5) 50%,transparent);background-size:100% 100%;opacity:.6;animation:starfield-drift 60s linear infinite}@keyframes starfield-drift{0%{transform:translateY(0);opacity:.4}50%{opacity:.8}to{transform:translateY(-20px);opacity:.4}}.mode-bg-glow{position:absolute;border-radius:50%;filter:blur(80px);opacity:.35;animation:glow-float 14s ease-in-out infinite alternate}.mode-bg-glow-1{top:-10%;left:-10%;width:50%;height:50%;background:radial-gradient(circle,var(--accent) 0%,transparent 70%);opacity:.25}.mode-bg-glow-2{bottom:-20%;right:-10%;width:60%;height:60%;background:radial-gradient(circle,var(--rose) 0%,transparent 70%);animation-delay:-7s;opacity:.18}@keyframes glow-float{0%{transform:translate(0) scale(1)}to{transform:translate(30px,-20px) scale(1.1)}}.mode-bg-wave{position:absolute;left:0;right:0;bottom:0;height:38%;background:linear-gradient(180deg,transparent,rgba(10,25,50,.6) 60%,rgba(5,10,25,.95) 100%),repeating-linear-gradient(180deg,transparent 0,transparent 28px,rgba(96,165,250,.04) 28px,rgba(96,165,250,.04) 30px);mask-image:linear-gradient(180deg,transparent 0%,black 30%);-webkit-mask-image:linear-gradient(180deg,transparent 0%,black 30%)}.settings-cog{position:absolute;top:calc(env(safe-area-inset-top,12px) + var(--space-4));right:var(--space-5);z-index:10;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:1px solid var(--border-2);border-radius:50%;color:var(--text-secondary);cursor:pointer;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:all var(--t-base) var(--ease-out)}.settings-cog:hover{color:var(--text-bright);border-color:var(--border-3);transform:rotate(45deg);box-shadow:var(--shadow-2)}.mode-hero{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-3);animation:pop-in .6s var(--ease-out)}.mode-hero-mark{width:92px;height:92px;border-radius:50%;background:radial-gradient(circle at 30% 30%,rgba(245,166,35,.22),transparent 70%);border:1px solid var(--accent-deep);display:flex;align-items:center;justify-content:center;color:var(--accent);box-shadow:inset 0 0 30px #f5a6232e,0 0 40px #f5a62338;margin-bottom:var(--space-2);animation:hero-pulse 4s ease-in-out infinite}@keyframes hero-pulse{0%,to{box-shadow:inset 0 0 30px #f5a6232e,0 0 40px #f5a62338}50%{box-shadow:inset 0 0 38px #f5a62347,0 0 64px #f5a62361}}.mode-title{margin:0;font-size:clamp(34px,8.5vw,52px);font-weight:700;letter-spacing:.18em;text-transform:uppercase;line-height:1;background:linear-gradient(180deg,#ffe2a0,#f5a623,#b86f0e 90%);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-stroke:1px rgba(20,12,4,.6);filter:drop-shadow(0 2px 0 rgba(0,0,0,.75)) drop-shadow(0 4px 0 rgba(0,0,0,.55)) drop-shadow(0 0 24px rgba(245,166,35,.5)) drop-shadow(0 0 50px rgba(245,166,35,.3));text-shadow:0 1px 0 rgba(255,230,180,.15)}.mode-title-flank{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-3)}.mode-title-flank:before,.mode-title-flank:after{content:"";flex:0 0 24px;height:1px;background:linear-gradient(90deg,transparent,var(--accent-deep));opacity:.6}.mode-title-flank:after{background:linear-gradient(90deg,var(--accent-deep),transparent)}.mode-subtitle{margin:0;color:var(--text-secondary);font-size:13px;letter-spacing:.06em;text-transform:uppercase;font-weight:500}.mode-divider{width:60px;height:1px;background:linear-gradient(90deg,transparent,var(--border-glow),transparent);margin-top:var(--space-2)}.mode-cards{position:relative;z-index:1;display:flex;flex-direction:column;gap:var(--space-4);width:100%;max-width:420px}.mode-card{position:relative;background:linear-gradient(180deg,#322a20c7,#14100aeb),url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.55 0 0 0 0 0.45 0 0 0 0 0.28 0 0 0 0.1 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");border:1px solid var(--border-2);padding:var(--space-5);cursor:pointer;text-align:left;color:var(--text-primary);font-family:var(--font-body);display:grid;grid-template-columns:64px 1fr;gap:var(--space-4);align-items:start;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:inset 0 1px #ffe6b41a,inset 0 -2px #00000080,0 8px 24px #00000080;clip-path:polygon(16px 0,100% 0,100% calc(100% - 16px),calc(100% - 16px) 100%,0 100%,0 16px);transition:transform var(--t-base) var(--ease-spring),border-color var(--t-base) var(--ease-out),filter var(--t-base) var(--ease-out);overflow:hidden}.mode-card:before{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(circle at top left,currentColor 0%,transparent 60%);opacity:0;transition:opacity var(--t-base) var(--ease-out);pointer-events:none}.mode-card:hover{transform:translateY(-3px);border-color:currentColor;filter:brightness(1.08)}.mode-card:hover:before{opacity:.08}.story-card{color:var(--accent)}.story-card .mode-card-icon{background:linear-gradient(180deg,var(--accent),var(--accent-deep));border-color:var(--accent-deep);color:#1a0f00;box-shadow:inset 0 1px #ffe6b473,inset 0 -2px #0006,0 0 20px var(--accent-glow)}.explore-card{color:var(--steel)}.explore-card .mode-card-icon{background:linear-gradient(180deg,var(--steel),var(--steel-deep));border-color:var(--steel-deep);color:#0a1218;box-shadow:inset 0 1px #dce6f566,inset 0 -2px #0006,0 0 20px var(--steel-glow)}.mode-card-icon{width:64px;height:64px;border:1px solid;display:flex;align-items:center;justify-content:center;flex-shrink:0;clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px)}.mode-card-body{grid-column:2;min-width:0}.mode-card h2{margin:0;font-family:var(--font-display);font-size:20px;font-weight:600;letter-spacing:.06em;color:var(--text-bright);text-transform:uppercase}.mode-card h3{margin:var(--space-1) 0 var(--space-2);font-size:12px;font-weight:600;color:currentColor;letter-spacing:.08em;text-transform:uppercase;opacity:.85}.mode-card p{margin:0 0 var(--space-3);font-size:13px;color:var(--text-secondary);line-height:1.55}.mode-features{display:flex;gap:var(--space-1);flex-wrap:wrap}.mode-features span{padding:4px 10px;border-radius:var(--r-pill);font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:#ffffff0a;border:1px solid var(--border-1);color:var(--text-secondary)}.story-card .mode-features span{background:#f5a62314;border-color:#f5a62340;color:var(--accent)}.explore-card .mode-features span{background:#7d9cc414;border-color:#7d9cc440;color:var(--steel)}.mode-card-cta{grid-column:1 / -1;margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px dashed var(--border-1);display:flex;justify-content:space-between;align-items:center;color:currentColor;font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.mode-card-cta svg{transition:transform var(--t-base) var(--ease-spring)}.mode-card:hover .mode-card-cta svg{transform:translate(4px)}.mode-card-title-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);flex-wrap:wrap}.mode-recommended-badge{display:inline-block;padding:3px 9px;font-family:var(--font-display);font-size:9px;font-weight:700;letter-spacing:.18em;line-height:1.2;background:linear-gradient(180deg,var(--rose),var(--rose-deep));color:#fff;border:1px solid var(--rose-deep);box-shadow:inset 0 1px #ffdcc873,inset 0 -1px #00000059,0 3px 8px var(--rose-glow);clip-path:polygon(5px 0,100% 0,100% calc(100% - 5px),calc(100% - 5px) 100%,0 100%,0 5px);white-space:nowrap;flex-shrink:0}.mode-settings-overlay{position:fixed;inset:0;background:#050810b3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .2s ease;padding:var(--space-5)}.mode-settings-panel{width:100%;max-width:360px;background:linear-gradient(180deg,var(--bg-elevated),var(--bg-light));border:1px solid var(--border-3);border-radius:var(--r-xl);padding:var(--space-5);box-shadow:var(--shadow-4);animation:pop-in .25s var(--ease-spring)}.mode-settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.mode-settings-header h3{margin:0;font-family:var(--font-display);font-size:16px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-bright)}.mode-settings-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:1px solid var(--border-2);border-radius:50%;color:var(--text-secondary);cursor:pointer;transition:all var(--t-fast) ease}.mode-settings-close:hover{color:var(--text-bright);background:var(--surface-3)}.mode-settings-row{width:100%;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--surface-2);border:1px solid var(--border-1);border-radius:var(--r-md);color:var(--text-primary);font-family:var(--font-body);cursor:pointer;transition:all var(--t-fast) ease}.mode-settings-row:hover{background:var(--surface-3);border-color:var(--border-2)}.mode-settings-row svg{color:var(--accent)}.mode-settings-row-label{flex:1;text-align:left;font-weight:600}.mode-settings-row-value{font-family:var(--font-mono);font-size:12px;font-weight:700;letter-spacing:.06em;color:var(--text-secondary)}.difficulty-panel{max-width:480px}.difficulty-list{display:flex;flex-direction:column;gap:var(--space-3)}.difficulty-card{width:100%;display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--surface-2);border:1.5px solid var(--border-2);border-radius:var(--r-md);color:var(--text-primary);cursor:pointer;text-align:left;transition:all var(--t-fast) ease}.difficulty-card:hover{background:var(--surface-3);transform:translate(2px);box-shadow:0 0 18px #ffffff0a}.difficulty-card svg{margin-top:2px;flex-shrink:0}.difficulty-text{flex:1;min-width:0}.difficulty-title{font-family:var(--font-display);font-size:15px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-bright);margin-bottom:4px;display:flex;align-items:center;gap:8px}.difficulty-rec{font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;padding:2px 6px;border-radius:4px;background:#34d39926;color:#34d399;font-weight:600}.difficulty-desc{font-size:12px;line-height:1.5;color:var(--text-secondary)}.npc-encounter-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:var(--space-4)}.npc-encounter{position:relative;max-width:540px;width:100%;max-height:85vh;background:var(--bg-elevated);border:1px solid var(--accent);border-radius:var(--radius-lg);box-shadow:0 12px 48px #0009,0 0 24px var(--accent-glow);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-4);overflow-y:auto;animation:npc-in .3s ease-out}@keyframes npc-in{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.npc-close{position:absolute;top:12px;right:12px;width:28px;height:28px;border-radius:50%;background:transparent;border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s}.npc-close:hover{border-color:var(--accent);color:var(--accent)}.npc-header{display:flex;align-items:center;gap:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--border)}.npc-icon{font-size:32px;filter:drop-shadow(0 0 8px var(--accent-glow))}.npc-name{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--text-bright);letter-spacing:.08em;text-transform:uppercase}.npc-era{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.npc-lines{display:flex;flex-direction:column;gap:var(--space-2);color:var(--text);line-height:1.6;font-size:14px}.npc-lines p{margin:0}.npc-lines .narrate{color:var(--text-secondary);font-style:italic;font-size:13px}.npc-lines .speech{color:var(--text-bright)}.npc-choices{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px dashed var(--border)}.npc-choices-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:var(--space-1);opacity:.85}.npc-choice{position:relative;padding:14px 18px 14px 36px;background:linear-gradient(135deg,#ffffff0a,#ffffff03);border:1.5px solid var(--accent);border-radius:var(--radius-md);color:var(--text-bright);font-size:14px;font-weight:500;text-align:left;cursor:pointer;transition:all .18s ease-out;line-height:1.45;box-shadow:inset 0 0 0 1px #ffffff08,0 1px #0000004d}.npc-choice:before{content:"▶";position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--accent);font-size:11px;opacity:.85;transition:transform .18s,opacity .18s}.npc-choice:hover{background:linear-gradient(135deg,var(--accent-glow),rgba(255,255,255,.04));border-color:var(--accent);color:#fff;transform:translate(3px);box-shadow:0 0 18px var(--accent-glow),inset 0 0 0 1px #ffffff14}.npc-choice:hover:before{transform:translateY(-50%) translate(2px);opacity:1}.npc-choice.end{text-align:center;color:var(--text-secondary)}.npc-choice.special{background:linear-gradient(135deg,#f59e0b1f,#a855f714);border-color:#f59e0b8c;color:#fbbf24;font-weight:600;position:relative;overflow:hidden}.npc-choice.special:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transform:translate(-100%);transition:transform .6s}.npc-choice.special:hover{background:linear-gradient(135deg,#f59e0b2e,#a855f724);border-color:#fbbf24;color:#fff;box-shadow:0 0 16px #f59e0b4d}.npc-choice.special:hover:before{transform:translate(100%)}.npc-actions{display:flex;gap:var(--space-2);padding:var(--space-2) 0;border-top:1px dashed var(--border);border-bottom:1px dashed var(--border);margin-top:var(--space-2)}.npc-action{position:relative;display:inline-flex;align-items:center;gap:6px;padding:8px 12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);font-size:12px;font-weight:500;cursor:pointer;transition:all .18s}.npc-action:hover:not(:disabled){border-color:var(--accent);color:var(--text-bright);background:var(--bg-hover)}.npc-action:disabled{opacity:.4;cursor:not-allowed}.npc-action.gift{border-color:#34d39966;color:#6ee7b7}.npc-action.gift:hover:not(:disabled){border-color:#34d399;box-shadow:0 0 12px #34d39940}.npc-action.steal{border-color:#f8717166;color:#fca5a5}.npc-action.steal:hover{border-color:#f87171;box-shadow:0 0 12px #f8717140}.npc-action-badge{background:#34d39933;border-radius:8px;padding:1px 6px;font-size:10px;font-weight:700;font-family:var(--font-mono);margin-left:2px}.npc-gift-menu{display:flex;flex-direction:column;gap:4px;padding:var(--space-2);background:#34d3990d;border:1px solid rgba(52,211,153,.25);border-radius:var(--radius-md);margin-top:var(--space-2)}.npc-gift-item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;text-align:left;font-size:13px;transition:all .15s}.npc-gift-item:hover{border-color:#34d399;background:var(--bg-hover);transform:translate(2px)}.npc-gift-icon{font-size:18px;flex-shrink:0}.npc-gift-name{flex:1;color:var(--text-bright)}.npc-gift-rep{font-family:var(--font-mono);font-size:11px;color:#34d399;font-weight:700;background:#34d39926;padding:2px 8px;border-radius:8px}.ending-overlay{position:fixed;inset:0;background:radial-gradient(ellipse at center,#140a1ef5,#000000fa);display:flex;align-items:center;justify-content:center;z-index:3000;padding:var(--space-4);animation:ending-fade .6s ease-out}@keyframes ending-fade{0%{opacity:0}to{opacity:1}}.ending-screen{max-width:600px;width:100%;text-align:center;color:var(--text-bright);animation:ending-rise 1s .2s ease-out backwards}@keyframes ending-rise{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.ending-icon{font-size:72px;filter:drop-shadow(0 0 24px var(--accent-glow));margin-bottom:var(--space-4);animation:ending-pulse 3s infinite ease-in-out}@keyframes ending-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.ending-title{font-family:var(--font-display);font-size:32px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;margin:0 0 var(--space-5);color:var(--text-bright);text-shadow:0 0 16px var(--accent-glow)}.ending-body{text-align:left;color:var(--text);line-height:1.8;font-size:15px;margin-bottom:var(--space-6);padding:0 var(--space-3)}.ending-body p{margin:0 0 var(--space-3)}.ending-restart{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:transparent;border:1px solid var(--accent);border-radius:var(--radius-md);color:var(--accent);font-family:var(--font-mono);font-size:13px;text-transform:uppercase;letter-spacing:.1em;cursor:pointer;transition:all .2s}.ending-restart:hover{background:var(--accent);color:var(--bg);box-shadow:0 0 16px var(--accent-glow)}.era-transition{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:4000;pointer-events:none;animation:era-overlay 1.8s ease-out forwards}@keyframes era-overlay{0%{opacity:0}15%{opacity:1}75%{opacity:1}to{opacity:0}}.era-transition.era-pirate{background:radial-gradient(ellipse,#6b1e1ef2,#000000f7)}.era-transition.era-colonial{background:radial-gradient(ellipse,#9a8c5ce6,#000000f7)}.era-transition.era-ancient{background:radial-gradient(ellipse,#d4c4a0d9,#000000f7)}.era-transition.era-prehistoric{background:radial-gradient(ellipse,#6a5a3af2,#000000f7)}.era-transition.era-future{background:radial-gradient(ellipse,#00f5d44d,#0a0a1efa)}.era-transition.era-present{background:radial-gradient(ellipse,#87ceeb66,#000000f7)}.era-transition-content{text-align:center;color:#fff;animation:era-content-in 1.8s ease-out forwards}@keyframes era-content-in{0%{opacity:0;transform:translateY(20px) scale(.95)}25%{opacity:1;transform:translateY(0) scale(1)}75%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-10px) scale(1.02)}}.era-transition-icon{font-size:88px;margin-bottom:16px;filter:drop-shadow(0 0 24px rgba(255,255,255,.4))}.era-transition-year{font-family:var(--font-mono);font-size:14px;letter-spacing:.3em;text-transform:uppercase;opacity:.7;margin-bottom:8px}.era-transition-name{font-family:var(--font-display);font-size:42px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;text-shadow:0 0 20px rgba(255,255,255,.3)}.era-transition-bar{width:80px;height:2px;background:#fff;margin:24px auto 0;animation:era-bar-grow 1.8s ease-out forwards}@keyframes era-bar-grow{0%{width:0;opacity:0}25%{width:80px;opacity:1}75%{width:80px;opacity:1}to{width:200px;opacity:0}}
