#root{width:100%;height:100%}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--serif:"Cormorant Garamond","Noto Serif SC",Georgia,serif;--mono:"DM Mono",monospace;--transition-theme:background .6s cubic-bezier(.4,0,.2,1),color .6s cubic-bezier(.4,0,.2,1),border-color .6s cubic-bezier(.4,0,.2,1),box-shadow .6s cubic-bezier(.4,0,.2,1)}[data-theme=night]{--bg:#08080c;--surface:#111118;--surface2:#1a1a24;--surface3:#22222e;--accent:#c9a84c;--accent-dim:#8a7434;--accent-glow:#c9a84c26;--text:#e8e4dc;--text-dim:#8a867e;--text-muted:#5a5850;--grain-opacity:.035;--choice-hover-bg:var(--surface2);--card-shadow:0 20px 60px #00000080;--input-bg:var(--surface);--input-border:var(--surface3);--topbar-gradient:linear-gradient(180deg,var(--bg) 60%,transparent);--dialogue-captain:#5ea4d4;--dialogue-officer:#d4a05e;--image-overlay:radial-gradient(ellipse at center,transparent 50%,#08080cb3 100%);--settings-bg:#08080ceb}[data-theme=day]{--bg:#f5f0e8;--surface:#ece5d8;--surface2:#e2dac9;--surface3:#d4cbb8;--accent:#9a6b2a;--accent-dim:#c4975a;--accent-glow:#9a6b2a1a;--text:#2c2418;--text-dim:#7a6e5e;--text-muted:#a89c8a;--grain-opacity:.02;--choice-hover-bg:var(--surface2);--card-shadow:0 12px 40px #2c24181f;--input-bg:var(--surface);--input-border:var(--surface3);--topbar-gradient:linear-gradient(180deg,var(--bg) 60%,transparent);--dialogue-captain:#3a6e94;--dialogue-officer:#946e3a;--image-overlay:radial-gradient(ellipse at center,transparent 50%,#f5f0e880 100%);--settings-bg:#f5f0e8f2}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--serif);min-height:100vh;transition:var(--transition-theme);overflow-x:hidden}body:after{content:"";pointer-events:none;z-index:9999;opacity:var(--grain-opacity);mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");transition:opacity .6s;position:fixed;inset:0}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--accent-dim);border-radius:2px}::selection{background:var(--accent);color:var(--bg)}.screen{opacity:0;pointer-events:none;transition:opacity .8s cubic-bezier(.4,0,.2,1);position:fixed;inset:0;overflow:hidden auto}.screen.active{opacity:1;pointer-events:all}.settings-overlay{z-index:10000;opacity:0;pointer-events:none;-webkit-backdrop-filter:blur(4px);background:#0006;transition:opacity .4s;position:fixed;inset:0}.settings-overlay.open{opacity:1;pointer-events:all}.settings-panel{z-index:10001;background:var(--settings-bg);-webkit-backdrop-filter:blur(20px);border-left:1px solid var(--surface3);flex-direction:column;width:clamp(300px,30vw,380px);transition:transform .5s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;right:0;overflow-y:auto;transform:translate(100%)}.settings-panel.open{transform:translate(0)}.settings-header{justify-content:space-between;align-items:center;padding:32px 28px 0;display:flex}.settings-header h2{letter-spacing:.03em;font-size:22px;font-weight:400}.settings-close{color:var(--text-dim);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:8px;transition:color .3s,transform .3s;display:flex}.settings-close:hover{color:var(--accent);transform:rotate(90deg)}.settings-close svg{width:20px;height:20px}.settings-body{flex:1;padding:28px}.settings-section{margin-bottom:36px}.settings-section-title{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--surface3);margin-bottom:16px;padding-bottom:8px;font-size:10px}.theme-toggle-group{gap:10px;display:flex}.theme-option{border:1.5px solid var(--surface3);cursor:pointer;text-align:center;background:var(--surface);border-radius:6px;flex:1;padding:16px 12px;transition:all .35s;position:relative;overflow:hidden}.theme-option:hover{border-color:var(--accent-dim)}.theme-option.active{border-color:var(--accent);background:var(--accent-glow)}.theme-option .theme-icon{margin-bottom:8px;font-size:24px;transition:transform .3s;display:block}.theme-option:hover .theme-icon{transform:scale(1.15)}.theme-option .theme-label{letter-spacing:.04em;margin-bottom:4px;font-size:13px;font-weight:500;display:block}.theme-option .theme-desc{color:var(--text-muted);font-size:11px;font-family:var(--mono);letter-spacing:.05em}.theme-preview{border:1px solid var(--surface3);height:80px;transition:var(--transition-theme);border-radius:6px;margin-top:16px;display:flex;overflow:hidden}.theme-preview-night{background:linear-gradient(135deg,#08080c,#1a1a24,#08080c);flex:1;justify-content:center;align-items:center;display:flex;position:relative}.theme-preview-day{background:linear-gradient(135deg,#f5f0e8,#ece5d8,#f5f0e8);flex:1;justify-content:center;align-items:center;display:flex;position:relative}.theme-preview-dot{border-radius:50%;width:10px;height:10px;position:absolute;bottom:12px}.theme-preview-night .theme-preview-dot{background:#c9a84c;box-shadow:0 0 8px #c9a84c66}.theme-preview-day .theme-preview-dot{background:#9a6b2a;box-shadow:0 0 8px #9a6b2a4d}.theme-preview-label{font-family:var(--mono);letter-spacing:.15em;text-transform:uppercase;opacity:.5;font-size:9px}.theme-preview-night .theme-preview-label{color:#e8e4dc}.theme-preview-day .theme-preview-label{color:#2c2418}.font-size-group{align-items:center;gap:16px;display:flex}.font-size-btn{border:1.5px solid var(--surface3);background:var(--surface);width:40px;height:40px;color:var(--text);font-family:var(--serif);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:18px;transition:all .3s;display:flex}.font-size-btn:hover{border-color:var(--accent);color:var(--accent)}.font-size-display{text-align:center;font-family:var(--mono);color:var(--text-dim);letter-spacing:.1em;flex:1;font-size:13px}.font-size-sample{background:var(--surface);border:1px solid var(--surface3);border-radius:6px;margin-top:14px;padding:16px}.font-size-sample p{color:var(--text-dim);line-height:1.8;transition:font-size .3s}.toggle-row{justify-content:space-between;align-items:center;padding:12px 0;display:flex}.toggle-row+.toggle-row{border-top:1px solid var(--surface3)}.toggle-label{letter-spacing:.02em;font-size:14px}.toggle-label small{color:var(--text-muted);font-size:11px;font-family:var(--mono);letter-spacing:.05em;margin-top:2px;display:block}.toggle-switch{background:var(--surface3);cursor:pointer;border:none;border-radius:12px;width:44px;height:24px;padding:0;transition:background .3s;position:relative}.toggle-switch:after{content:"";background:var(--text-dim);border-radius:50%;width:18px;height:18px;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;top:3px;left:3px}.toggle-switch.on{background:var(--accent)}.toggle-switch.on:after{background:var(--bg);left:23px}.settings-footer{border-top:1px solid var(--surface3);text-align:center;padding:20px 28px}.settings-footer p{font-family:var(--mono);letter-spacing:.12em;color:var(--text-muted);font-size:10px}.settings-trigger{color:var(--text-dim);cursor:pointer;z-index:100;background:0 0;border:none;justify-content:center;align-items:center;padding:8px;transition:color .3s,transform .4s;display:flex;position:relative}.settings-trigger:hover{color:var(--accent);transform:rotate(60deg)}.settings-trigger svg{width:20px;height:20px;transition:stroke .3s}.settings-trigger:hover svg{stroke:var(--accent)}#gallery{background:var(--bg);transition:var(--transition-theme);flex-direction:column;display:flex}.gallery-header{z-index:2;padding:60px 60px 0;position:relative}.gallery-top-row{justify-content:space-between;align-items:flex-start;display:flex}.gallery-logo{align-items:baseline;gap:16px;margin-bottom:8px;display:flex}.gallery-logo h1{letter-spacing:.04em;color:var(--text);transition:var(--transition-theme);font-size:clamp(32px,5vw,52px);font-weight:300}.gallery-logo h1 span{color:var(--accent);font-style:italic}.gallery-logo .en{color:var(--text-muted);font-size:clamp(14px,1.5vw,18px);font-family:var(--mono);letter-spacing:.15em;text-transform:uppercase}.gallery-subtitle{color:var(--text-dim);letter-spacing:.02em;margin-top:4px;font-size:clamp(14px,1.3vw,17px);font-style:italic;font-weight:300}.gallery-divider{background:var(--accent-dim);width:60px;height:1px;transition:var(--transition-theme);margin:24px 0 0}.gallery-scroll{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;flex:1;align-items:center;gap:32px;padding:40px 60px 80px;display:flex;overflow-x:auto}.gallery-scroll::-webkit-scrollbar{height:0}.story-card{cursor:pointer;scroll-snap-align:start;border-radius:6px;flex:none;width:clamp(280px,22vw,340px);height:clamp(400px,55vh,520px);transition:transform .5s cubic-bezier(.4,0,.2,1),box-shadow .5s;position:relative;overflow:hidden}.story-card:hover{box-shadow:var(--card-shadow);transform:translateY(-8px)scale(1.02)}.story-card-bg{transition:transform .6s;position:absolute;inset:0}.story-card:hover .story-card-bg{transform:scale(1.08)}.story-card:after{content:"";pointer-events:none;transition:var(--transition-theme);background:linear-gradient(#0000 30%,#000000d9 100%);position:absolute;inset:0}.story-card-content{z-index:2;padding:28px;position:absolute;bottom:0;left:0;right:0}.story-genre{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent-dim);transition:var(--transition-theme);border-radius:2px;margin-bottom:12px;padding:4px 10px;font-size:11px;display:inline-block}.story-card-title{letter-spacing:.02em;color:#fff;margin-bottom:8px;font-size:clamp(22px,2.5vw,30px);font-weight:500;line-height:1.3}.story-card-desc{color:#ffffffa6;font-size:clamp(13px,1.1vw,15px);font-weight:300;line-height:1.6}.story-card-episodes{font-family:var(--mono);color:#ffffff59;letter-spacing:.1em;margin-top:14px;font-size:11px}#reading{background:var(--bg);transition:var(--transition-theme);flex-direction:column;display:flex}.reading-topbar{z-index:100;background:var(--topbar-gradient);justify-content:space-between;align-items:center;padding:16px 40px;transition:opacity .4s;display:flex;position:sticky;top:0}.reading-topbar.hidden{opacity:0;pointer-events:none}.reading-topbar-left{align-items:center;gap:12px;display:flex}.back-btn{color:var(--text-dim);font-family:var(--serif);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;font-size:15px;transition:color .3s;display:flex}.back-btn:hover{color:var(--accent)}.back-btn svg{width:18px;height:18px}.reading-title{color:var(--text-muted);font-size:14px;font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase}.reading-topbar-right{align-items:center;gap:8px;display:flex}.reading-progress{background:var(--surface2);width:100%;height:1px;transition:var(--transition-theme);position:absolute;bottom:0;left:0}.reading-progress-bar{background:var(--accent);width:0;height:100%;transition:width .3s}.reading-body{--reader-font-size:20px;flex:1;width:100%;max-width:720px;margin:0 auto;padding:0 24px 200px}.narrative-block{opacity:0;margin-bottom:48px;transition:opacity .9s cubic-bezier(.4,0,.2,1),transform .9s cubic-bezier(.4,0,.2,1);transform:translateY(24px)}.narrative-block.visible{opacity:1;transform:translateY(0)}.narrative-block p{font-size:var(--reader-font-size);letter-spacing:.01em;color:var(--text);transition:var(--transition-theme);font-weight:300;line-height:2}.narrative-block p+p{margin-top:1.4em}.narrative-block .dropcap:first-letter{float:left;color:var(--accent);margin:6px 10px 0 0;font-size:3.2em;font-weight:600;line-height:.8}.dialogue-block{opacity:0;margin-bottom:48px;padding:28px 0;transition:opacity .9s cubic-bezier(.4,0,.2,1),transform .9s cubic-bezier(.4,0,.2,1);transform:translateY(24px)}.dialogue-block.visible{opacity:1;transform:translateY(0)}.dialogue-row{align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.dialogue-row:last-child{margin-bottom:0}.dialogue-row.reverse{text-align:right;flex-direction:row-reverse}.dialogue-avatar{border:1px solid var(--accent-dim);width:40px;height:40px;transition:var(--transition-theme);white-space:nowrap;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:600;line-height:1;display:flex;overflow:hidden}.dialogue-text{flex:1}.dialogue-name{font-family:var(--mono);letter-spacing:.15em;text-transform:uppercase;margin-bottom:6px;font-size:11px;display:block}.dialogue-name.captain{color:var(--dialogue-captain);transition:var(--transition-theme)}.dialogue-name.officer{color:var(--dialogue-officer);transition:var(--transition-theme)}.dialogue-name.character{color:var(--accent-dim)}.dialogue-line{font-size:calc(var(--reader-font-size) * .92);color:var(--text);transition:var(--transition-theme);font-style:italic;font-weight:300;line-height:1.8}.story-image-block{opacity:0;margin:56px -24px;transition:opacity 1.2s cubic-bezier(.4,0,.2,1),transform 1.2s cubic-bezier(.4,0,.2,1);position:relative;transform:translateY(30px)}.story-image-block.visible{opacity:1;transform:translateY(0)}.story-image{aspect-ratio:16/9;border-radius:4px;width:100%;position:relative;overflow:hidden}.story-image-scene{position:absolute;inset:0}.story-image:after{content:"";background:var(--image-overlay);pointer-events:none;transition:var(--transition-theme);position:absolute;inset:0}.story-image-caption{font-family:var(--mono);color:var(--text-muted);letter-spacing:.08em;text-align:center;transition:var(--transition-theme);margin-top:14px;font-size:12px;font-style:italic}.choice-block{opacity:0;margin:64px 0 48px;transition:opacity .9s cubic-bezier(.4,0,.2,1),transform .9s cubic-bezier(.4,0,.2,1);transform:translateY(24px)}.choice-block.visible{opacity:1;transform:translateY(0)}.choice-prompt{text-align:center;margin-bottom:32px}.choice-prompt .label{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--accent);transition:var(--transition-theme);margin-bottom:8px;font-size:11px;display:block}.choice-prompt .question{color:var(--text);transition:var(--transition-theme);font-size:clamp(20px,2.2vw,26px);font-style:italic;font-weight:400}.choice-options{flex-direction:column;gap:14px;margin-bottom:24px;display:flex}.choice-btn{background:var(--surface);border:1px solid var(--surface3);text-align:left;cursor:pointer;font-family:var(--serif);color:var(--text);border-radius:4px;padding:18px 24px;font-size:clamp(15px,1.4vw,17px);line-height:1.5;transition:all .35s;position:relative;overflow:hidden}.choice-btn:before{content:"";background:var(--accent);width:2px;transition:transform .3s;position:absolute;top:0;bottom:0;left:0;transform:scaleY(0)}.choice-btn:hover{border-color:var(--accent-dim);background:var(--choice-hover-bg);transform:translate(4px)}.choice-btn:hover:before{transform:scaleY(1)}.choice-btn .choice-key{font-family:var(--mono);color:var(--accent);letter-spacing:.1em;transition:var(--transition-theme);margin-right:10px;font-size:11px}.choice-divider{align-items:center;gap:16px;margin:8px 0;display:flex}.choice-divider:before,.choice-divider:after{content:"";background:var(--surface3);flex:1;height:1px}.choice-divider span{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);font-size:10px}.custom-input-wrap{position:relative}.custom-input-area{background:var(--input-bg);border:1px solid var(--input-border);border-radius:4px;min-height:80px;padding:20px;transition:border-color .3s,box-shadow .3s;position:relative}.custom-input-area:focus-within{border-color:var(--accent-dim)}.custom-input{width:100%;color:var(--text);font-family:var(--serif);resize:none;min-height:48px;transition:var(--transition-theme);background:0 0;border:none;outline:none;font-size:clamp(16px,1.6vw,19px);line-height:1.7}.custom-input::placeholder{color:var(--text-muted);font-style:italic}.input-actions{justify-content:flex-end;gap:12px;margin-top:12px;display:flex}.input-submit{border:1px solid var(--accent-dim);color:var(--accent);font-family:var(--serif);cursor:pointer;letter-spacing:.05em;background:0 0;border-radius:3px;padding:8px 20px;font-size:14px;transition:all .3s}.input-submit:hover{background:var(--accent);color:var(--bg)}.choice-block.loading .choice-btn,.choice-block.loading .input-submit,.choice-block.loading .custom-input{opacity:.55;cursor:not-allowed}.choice-block.loading .custom-input-area{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow);animation:1.2s linear infinite inputPanelLoading}@keyframes inputPanelLoading{0%{box-shadow:0 0 0 0 #c9a84c0d,0 0 0 2px var(--accent-glow)}50%{box-shadow:0 0 0 6px #c9a84c1f,0 0 0 2px var(--accent-glow)}to{box-shadow:0 0 0 0 #c9a84c0d,0 0 0 2px var(--accent-glow)}}.pending-choice-note{opacity:0;margin:10px 0 28px;transition:opacity .4s,transform .4s;transform:translateY(16px)}.pending-choice-note.visible{opacity:1;transform:translateY(0)}.pending-choice-note.fade-out{opacity:0;transform:translateY(-8px)}.pending-choice-note p{font-size:calc(var(--reader-font-size) * .86);color:var(--text-dim);border-left:2px solid var(--accent-dim);padding-left:12px;font-style:italic;line-height:1.8}.weaving-block{opacity:0;text-align:center;margin:64px 0;transition:opacity .6s}.weaving-block.visible{opacity:1}.weaving-content{flex-direction:column;align-items:center;gap:20px;display:flex}.weaving-dots{gap:8px;display:flex}.weaving-dots span{background:var(--accent-dim);border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite weavePulse}.weaving-dots span:nth-child(2){animation-delay:.2s}.weaving-dots span:nth-child(3){animation-delay:.4s}@keyframes weavePulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1.2)}}.weaving-text{font-family:var(--mono);letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);font-size:12px;font-style:italic}.atmo-sonar{position:absolute;inset:0;overflow:hidden}.atmo-sonar .sonar-circle{border:1px solid #5ea4d426;border-radius:50%;animation:3s ease-out infinite sonarPing;position:absolute}.atmo-sonar .sonar-circle:first-child{width:120px;height:120px;animation-delay:0s;top:40%;left:55%}.atmo-sonar .sonar-circle:nth-child(2){width:120px;height:120px;animation-delay:1s;top:40%;left:55%}.atmo-sonar .sonar-circle:nth-child(3){width:120px;height:120px;animation-delay:2s;top:40%;left:55%}.atmo-sonar .blip{background:#5ea4d499;border-radius:50%;width:8px;height:8px;animation:3s ease-out infinite blipFade;position:absolute;top:38%;left:62%;box-shadow:0 0 10px #5ea4d466}@keyframes sonarPing{0%{opacity:.6;transform:scale(.5)}to{opacity:0;transform:scale(3)}}@keyframes blipFade{0%,60%{opacity:0}70%{opacity:1}to{opacity:0}}@media (width<=768px){.gallery-header{padding:40px 24px 0}.gallery-scroll{gap:20px;padding:30px 24px 60px}.story-card{width:260px;height:360px}.reading-topbar{padding:12px 20px}.reading-body{padding:0 16px 160px}.story-image-block{margin:40px -16px}.settings-panel{width:100%}}.login-screen{z-index:20000;background:linear-gradient(#07070b,#0f1018);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.login-card{color:#e8e4dc;background:#10111a;border:1px solid #2a2a38;border-radius:10px;flex-direction:column;gap:14px;width:min(92vw,460px);padding:36px;display:flex}.login-card h2{font-size:30px;font-weight:400}.login-card p{color:#9a968f;line-height:1.7}.login-card input{color:#f2eee8;height:46px;font-family:var(--serif);background:#151625;border:1px solid #323244;border-radius:6px;padding:0 14px;font-size:16px}.login-card button{color:#111118;cursor:pointer;background:#c9a84c;border:1px solid #8a7434;border-radius:6px;height:44px;font-size:15px}.login-card span{color:#f6a28d;font-size:13px}
