:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#3d2817;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f1e8;font-family:KaiTi,STKaiti,楷体,Microsoft YaHei,PingFang SC,serif;font-weight:400;line-height:1.8}*{box-sizing:border-box}body{background:repeating-linear-gradient(0deg,#0000,#0000 2px,#00000008 2px 4px) 0 0/100% 4px,linear-gradient(90deg,#f5f1e8,#f0ebe0,#f5f1e8) 0 0/100% 100%;min-width:320px;min-height:100vh;margin:0;position:relative}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(circle at 20%,#8b45130d 0%,#0000 50%),radial-gradient(circle at 80% 80%,#6543210d 0%,#0000 50%);position:fixed;inset:0}p,li{font-family:KaiTi,STKaiti,楷体,Microsoft YaHei,PingFang SC,serif}h1,h2,h3,h4,h5,h6{color:#5c3a21;margin:0;font-family:KaiTi,STKaiti,楷体,serif;font-weight:600}a{color:#8b4513;-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:sienna}button{color:#5c3a21;cursor:pointer;background-color:#f5f1e8;border:1px solid #8b7355;border-radius:4px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:all .3s}button:hover{background-color:#e8ddd4;border-color:#6b5a42}button:focus,button:focus-visible{outline-offset:2px;outline:2px solid #8b7355}.page-container{z-index:1;max-width:1200px;margin:0 auto;padding:1.5rem;position:relative}.page-card{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fff9;border:1px solid #8b735540;border-radius:12px;padding:2rem}.page-title{text-align:center;letter-spacing:4px;margin-bottom:.5rem;font-size:1.8rem}.page-subtitle{text-align:center;color:#8b7355;margin-bottom:2rem;font-size:1rem}.section-divider{background:linear-gradient(90deg,#0000,#8b7355,#0000);width:80px;height:2px;margin:.75rem auto 1.5rem}.layout{z-index:1;flex-direction:column;min-height:100vh;display:flex;position:relative}.header{z-index:100;background:linear-gradient(#f5f1e8fa,#f0ebe0f2);border-bottom:1px solid #8b73554d;padding:.5rem 0;position:sticky;top:0}.header-content{justify-content:center;align-items:center;gap:.75rem;max-width:1400px;margin:0 auto;padding:0 1.5rem;display:flex}.site-title{color:#5c3a21;letter-spacing:1.5px;cursor:pointer;margin:0;font-family:KaiTi,STKaiti,楷体,serif;font-size:1.5rem;font-weight:600;transition:color .3s}.site-title:hover{color:#8b4513}.bgm-toggle{color:#5c3a21;cursor:pointer;background:#f5f1e8;border:none;border-radius:999px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:1rem;display:flex;box-shadow:0 1px 4px #00000014}.bgm-toggle:hover{background:#e8ddd4}.main-content{flex:1;padding-bottom:80px}.bottom-nav{z-index:100;background:linear-gradient(#f0ebe0f2,#f5f1e8fa);border-top:1px solid #8b735540;justify-content:center;gap:.5rem;padding:.6rem 1rem;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-btn{color:#8b7355;background:0 0;border:1px solid #0000;border-radius:6px;flex:1;max-width:160px;padding:.5rem .75rem;font-family:KaiTi,STKaiti,楷体,serif;font-size:.9rem;transition:all .3s}.bottom-nav-btn:hover{color:#5c3a21;background:#8b735514}.bottom-nav-btn.active{color:#5c3a21;background:#8b735526;border-color:#8b73554d}.home-page{justify-content:center;align-items:center;min-height:calc(100vh - 60px);padding:2rem 1rem;display:flex}.hero-section{flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:500px;display:flex}.hero-image-wrapper{aspect-ratio:3/4;justify-content:center;align-items:center;width:100%;max-width:420px;display:flex;position:relative}.hero-logo{object-fit:contain;border-radius:8px;width:100%;height:100%}.hero-title-fallback{background:linear-gradient(135deg,#e8ddd4 0%,#d4c4b0 100%);border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex;position:absolute;inset:0}.hero-seal{color:#8b4513;writing-mode:vertical-rl;letter-spacing:4px;border:3px solid #8b4513;border-radius:8px;justify-content:center;align-items:center;width:80px;height:80px;font-size:2rem;display:flex}.hero-main-title{color:#5c3a21;letter-spacing:8px;writing-mode:vertical-rl;font-size:3.5rem;font-weight:700}.hero-card{text-align:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffffbf;border:1px solid #8b735540;border-radius:12px;width:100%;padding:1.75rem 1.5rem}.hero-card-title{color:#5c3a21;letter-spacing:2px;margin-bottom:.75rem;font-size:1.3rem}.hero-card-desc{color:#8b7355;margin-bottom:1.25rem;font-size:.95rem;line-height:1.8}.hero-buttons{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.hero-btn{color:#5c3a21;cursor:pointer;background:#f5f1e8;border:1px solid #8b7355;border-radius:6px;flex:1;min-width:100px;padding:.65rem 1rem;font-family:KaiTi,STKaiti,楷体,serif;font-size:1rem;transition:all .3s}.hero-btn.primary{color:#fff;background:#8b7355;border-color:#8b7355}.hero-btn.primary:hover{background:#7a6548}.hero-btn:hover{background:#e8ddd4}.canal-map-page{justify-content:center;align-items:flex-start;min-height:calc(100vh - 140px);padding:1.5rem;display:flex}.map-wrapper{aspect-ratio:3/4;border-radius:8px;width:100%;max-width:720px;position:relative;overflow:hidden;box-shadow:0 4px 20px #00000014}.canal-map-bg{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.canal-map-svg{z-index:2;width:100%;height:100%;position:absolute;inset:0}.city-marker-group{transition:transform .2s}.city-marker-group:hover .city-dot{fill:sienna;r:2.2}.city-marker-group:hover text{fill:#8b4513}.nav-archive-card{padding:2rem 1.5rem}.city-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem;margin-top:1.5rem;display:grid}.city-card{text-align:center;cursor:pointer;color:#fff;background:#8b7355d9;border:1px solid #ffffff1a;border-radius:10px;padding:1.5rem 1rem;transition:all .3s}.city-card:hover{background:#8b7355f2;transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.city-card-icon{background:#ffffff26;border-radius:50%;width:48px;height:48px;margin:0 auto .75rem}.city-card-name{color:#fff;letter-spacing:2px;margin-bottom:.25rem;font-size:1.3rem}.city-card-hint{color:#ffffffb3;margin:0;font-size:.85rem}.puzzle-game{flex-direction:column;align-items:center;gap:1rem;display:flex}.puzzle-hint{color:#8b7355;margin:0;font-size:.9rem}.puzzle-board{background:#8b735526;border-radius:8px;gap:4px;width:240px;height:240px;padding:4px;display:grid}.puzzle-tile{cursor:pointer;background:linear-gradient(135deg,#e8ddd4,#d4c4b0);border:2px solid #0000;border-radius:4px;justify-content:center;align-items:center;transition:all .2s;display:flex;position:relative}.puzzle-tile:hover{transform:scale(.97);box-shadow:inset 0 0 8px #0000000d}.puzzle-tile.selected{border-color:#8b4513;box-shadow:0 0 0 2px #8b451333}.puzzle-tile.completed{background:linear-gradient(135deg,#d4e8d4,#c4d4b0)}.tile-number{color:#5c3a21;font-family:KaiTi,STKaiti,楷体,serif;font-size:1.2rem;font-weight:600}.city-archive-screen{min-height:calc(100vh - 60px);position:relative;overflow:hidden}.city-bg-wrapper{justify-content:center;align-items:center;width:100%;height:calc(100vh - 60px);display:flex;position:relative}.city-bg-placeholder{aspect-ratio:3/4;background:linear-gradient(135deg,#e8ddd4 0%,#d4c4b0 100%);border-radius:8px;justify-content:center;align-items:center;width:100%;max-width:520px;display:flex;position:relative;overflow:hidden}.city-name-center{flex-direction:column;align-items:center;gap:.5rem;display:flex;position:relative}.city-name-glow{pointer-events:none;background:radial-gradient(circle,#8b451314 0%,#0000 70%);position:absolute;inset:-40px}.city-name-text{color:#5c3a21;writing-mode:vertical-rl;letter-spacing:12px;text-shadow:0 2px 8px #00000014;z-index:1;font-size:4rem;font-weight:700}.archive-sheet{z-index:50;background:#f5f1e8f7;border-top:1px solid #8b73554d;border-radius:16px 16px 0 0;max-width:800px;margin:0 auto;transition:transform .35s;position:fixed;bottom:60px;left:0;right:0;transform:translateY(calc(100% - 50px));box-shadow:0 -4px 20px #0000000f}.archive-sheet.open{transform:translateY(0)}.sheet-handle{cursor:pointer;color:#8b7355;background:0 0;border:none;flex-direction:column;align-items:center;gap:.25rem;width:100%;padding:.5rem 0;font-family:KaiTi,STKaiti,楷体,serif;display:flex}.sheet-grabber{background:#8b735566;border-radius:2px;width:36px;height:4px}.sheet-hint{font-size:.8rem}.sheet-content{max-height:60vh;padding:0 1rem 1.5rem;overflow-y:auto}.archive-tabs{border-bottom:1px solid #8b735533;gap:.5rem;margin-bottom:1rem;padding-bottom:.5rem;display:flex}.archive-tab{color:#8b7355;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;flex:1;padding:.5rem;font-family:KaiTi,STKaiti,楷体,serif;font-size:.95rem;transition:all .2s}.archive-tab:hover{background:#8b735514}.archive-tab.active{color:#5c3a21;background:#8b735526;border-color:#8b735540}.entries-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;display:grid}.entry-card{cursor:pointer;background:#ffffffb3;border:1px solid #8b735533;border-radius:8px;transition:all .2s;overflow:hidden}.entry-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.entry-image{aspect-ratio:16/9;background:#e8ddd4;justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.entry-image img{object-fit:cover;width:100%;height:100%}.entry-image-placeholder{color:#8b7355;text-align:center;padding:.5rem;font-size:.9rem}.entry-image-emoji{justify-content:center;align-items:center;height:100%;font-size:3rem;display:flex}.entry-info{padding:.75rem}.entry-info h4{color:#5c3a21;margin-bottom:.25rem;font-size:1rem}.entry-info p{color:#8b7355;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.85rem;line-height:1.5;display:-webkit-box;overflow:hidden}.entry-detail{padding:.5rem}.back-btn{color:#8b4513;cursor:pointer;background:0 0;border:none;margin-bottom:.75rem;padding:0;font-size:.9rem}.entry-detail h3{margin-bottom:.5rem;font-size:1.2rem}.entry-summary{color:#8b7355;margin-bottom:1rem;font-style:italic}.entry-detail-text p{text-indent:2em;margin-bottom:.75rem;line-height:1.8}.research-panel h3{margin-bottom:.75rem;font-size:1.15rem}.research-content p{text-indent:2em;margin-bottom:.75rem;line-height:1.8}.puzzle-panel{justify-content:center;padding:1rem 0;display:flex}.passenger-card{padding:2rem 1.5rem}.passenger-tabs{justify-content:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.passenger-tab{color:#5c3a21;cursor:pointer;background:#f5f1e8;border:1px solid #8b7355;border-radius:6px;padding:.5rem 1.5rem;font-family:KaiTi,STKaiti,楷体,serif;font-size:1rem;transition:all .2s}.passenger-tab.active{color:#fff;background:#8b7355}.character-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;display:grid}.character-card{text-align:center;cursor:pointer;background:#ffffffb3;border:1px solid #8b735533;border-radius:10px;padding:1.25rem 1rem;transition:all .2s}.character-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.character-avatar{background:#8b73551a;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto .75rem;font-size:2.5rem;display:flex}.character-info h4{color:#5c3a21;margin-bottom:.25rem;font-size:1.1rem}.character-role{color:#5c3a21;background:#8b735526;border-radius:999px;padding:.15rem .6rem;font-size:.8rem;display:inline-block}.character-desc{color:#8b7355;white-space:pre-line;margin-top:.75rem;font-size:.85rem;line-height:1.6}.network-container{justify-content:center;display:flex}.network-graph{aspect-ratio:1;background:#ffffff80;border:1px solid #8b735526;border-radius:8px;width:100%;max-width:600px}.network-svg{width:100%;height:100%}.network-node-group{cursor:pointer}.network-node-group:hover circle{fill:sienna;r:3.5}.empty-network{text-align:center;color:#8b7355;padding:2rem}.poem-card{padding:2rem 1.5rem}.poems-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem;display:grid}.poem-item{cursor:pointer;background:#fff9;border:1px solid #8b735533;border-radius:8px;transition:all .2s;overflow:hidden}.poem-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.poem-item-inner{text-align:center;padding:1rem 1.25rem}.poem-item-inner h4{color:#5c3a21;margin-bottom:.25rem;font-size:1.05rem;font-weight:600}.poem-author{color:#8b7355;margin:0;font-size:.85rem}.poem-item-deco{background:linear-gradient(90deg,#0000,#8b735533,#0000);border-radius:3px;height:6px;margin:0 1rem .75rem}.poem-detail{text-align:center;max-width:600px;margin:0 auto}.poem-detail-title{color:#5c3a21;margin-bottom:.5rem;font-size:1.4rem}.poem-detail-author{color:#8b7355;margin-bottom:1rem;font-size:.95rem}.poem-divider{background:linear-gradient(90deg,#0000,#8b7355,#0000);width:60px;height:2px;margin:0 auto 1.5rem}.poem-content{color:#3d2817;font-size:1.1rem;line-height:2.2}.poem-content p{margin:0}.poem-placeholder{color:#8b7355;padding:2rem;font-style:italic}
