:root{color-scheme:only light;color:#f5f7fb;font-family:PingFang SC,Hiragino Sans GB,Noto Sans SC,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg: #0b0c15;--panel: rgba(17, 21, 28, .72);--panel-strong: rgba(7, 10, 18, .9);--line: rgba(255, 255, 255, .08);--line-strong: rgba(255, 255, 255, .16);--text-soft: #cbd5e1;--accent-a: #8b5cf6;--accent-b: #2dd4bf;--accent-c: #a5b4fc}*{box-sizing:border-box}html{color-scheme:only light;scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--bg);background-image:radial-gradient(circle at 20% 0%,rgba(139,92,246,.15) 0%,transparent 42vw),radial-gradient(circle at 80% 100%,rgba(45,212,191,.1) 0%,transparent 50vw);background-attachment:fixed;position:relative}body:before{content:"";position:fixed;bottom:-20vh;left:-50vw;width:200vw;height:80vh;background-image:linear-gradient(rgba(139,92,246,.22) 1px,transparent 1px),linear-gradient(90deg,rgba(139,92,246,.22) 1px,transparent 1px);background-size:80px 80px;transform:perspective(600px) rotateX(75deg);transform-origin:top center;-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 80%);mask-image:linear-gradient(to bottom,transparent 0%,black 80%);z-index:-1;pointer-events:none}body:after{content:"";position:fixed;top:12vh;left:5vw;width:32vw;height:32vw;border-radius:50%;background:radial-gradient(circle,rgba(139,92,246,.38),rgba(45,212,191,.08) 60%,transparent 82%);filter:blur(84px);z-index:-2;pointer-events:none}a{color:inherit;text-decoration:none}button,input,textarea,select{color-scheme:only light;font:inherit}.site-shell{width:min(1360px,calc(100% - 48px));margin:0 auto;padding:24px 0 56px}.topbar-shell{width:min(1360px,calc(100% - 48px));margin:0 auto;padding:24px 0 0}.bookshelf-section{margin-top:18px}.topbar-tool-link{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;min-height:38px;padding:8px 14px;border-radius:8px;color:#dbeafe;font-size:.95rem;background:#0f172aad;border:1px solid rgba(148,163,184,.26);transition:transform .16s ease,border-color .16s ease,background .16s ease}.topbar-tool-link:hover{transform:translateY(-1px);border-color:#7dd3fcbd;background:#0ea5e929}.bookshelf-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:28px 22px}.empty-state{max-width:780px;min-height:320px;display:flex;flex-direction:column;justify-content:center;gap:14px}.empty-state-kicker{color:#c7d2fe;font-size:.92rem;letter-spacing:.12em;text-transform:uppercase}.empty-state h1{margin:0;font-size:clamp(2.2rem,4vw,3.4rem);line-height:1.08}.book-card{display:flex;flex-direction:column;position:relative}.book-link{display:flex;flex-direction:column;align-items:center;gap:12px}.template-shelf-cover{position:relative;display:block;width:100%;aspect-ratio:.72;border-radius:4px 14px 14px 4px;overflow:hidden;box-shadow:0 18px 30px #00000057,8px 0 #ffffff0d inset,-1px 0 #ffffff1f;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,#08080c14,#08080c4d),linear-gradient(145deg,#8b5cf661,#2dd4bf2e);transition:transform .18s ease,box-shadow .18s ease}.template-shelf-cover.has-cover-image{background:linear-gradient(180deg,#08080c14,#08080c4d),linear-gradient(145deg,#8b5cf661,#2dd4bf2e)}.template-shelf-image{position:absolute;inset:0;z-index:1;display:block;width:100%;height:100%;object-fit:cover;object-position:center top}.book-link:hover .template-shelf-cover{transform:translateY(-4px);box-shadow:0 24px 42px #0000006b,8px 0 #ffffff0f inset,-1px 0 #ffffff24}.book-cover{position:relative;display:block;aspect-ratio:.72;border-radius:4px 14px 14px 4px;overflow:hidden;box-shadow:0 18px 30px #00000057,8px 0 #ffffff0d inset,-1px 0 #ffffff1f;border:1px solid rgba(255,255,255,.08);transition:transform .18s ease,box-shadow .18s ease}.book-cover.has-cover-image{background-image:linear-gradient(180deg,#08080c0a,#08080c38),var(--cover-image);background-size:cover;background-position:center}.book-cover:hover{transform:translateY(-4px);box-shadow:0 24px 42px #0000006b,8px 0 #ffffff0f inset,-1px 0 #ffffff24}.template-shelf-cover:before{content:"";position:absolute;left:0;top:0;bottom:0;width:15px;background:linear-gradient(180deg,#ffffff0a,#0000004d);z-index:3}.template-shelf-cover:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#ffffff08,#00000029),linear-gradient(90deg,rgba(7,9,14,.18) 0 3%,transparent 3% 100%);pointer-events:none;z-index:3}.template-shelf-montage{position:absolute;inset:0;display:grid;grid-template-rows:17% 58% 25%;gap:6px;padding:8px;background:#140d0b}.template-shelf-lane{display:block;border-radius:10px}.template-shelf-cover.has-cover-image .template-shelf-montage,.template-shelf-cover:not(.has-cover-image) .template-shelf-montage{display:none}.template-code-badge{position:relative;display:inline-flex;align-items:center;justify-content:center;min-width:104px;padding:11px 24px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.2);color:#fff;background:linear-gradient(145deg,#8b5cf6cc,#2dd4bf99);box-shadow:0 15px 30px #8b5cf680,0 0 20px #2dd4bf4d,inset 0 4px 10px #fff9,inset 0 -4px 12px #0006,inset 0 0 0 1px #ffffff4d;transform:translateY(-2px) scale(1.01);overflow:hidden;text-shadow:0 1px 1px rgba(0,0,0,.28);font:800 15px/1 ui-monospace,SFMono-Regular,Menlo,monospace;letter-spacing:.18em}.template-code-badge:before{content:"";position:absolute;top:0;left:10%;width:80%;height:34%;background:linear-gradient(180deg,rgba(255,255,255,.42) 0%,transparent 100%);border-radius:999px;pointer-events:none}.book-link:hover .template-code-badge{box-shadow:0 18px 36px #8b5cf694,0 0 24px #2dd4bf5c,inset 0 4px 10px #ffffff9e,inset 0 -4px 12px #00000061,inset 0 0 0 1px #ffffff4d}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.cover-shanmen-night-snow{background:linear-gradient(180deg,#08080c1a,#08080c6b),radial-gradient(circle at 50% 14%,rgba(255,255,255,.18),transparent 28%),linear-gradient(180deg,#23324c,#10131d 42%,#ece6db 42%,#d5cfbf)}.cover-shanmen-night-snow:before{content:"";position:absolute;inset:18% 14% 12% auto;width:28%;background:linear-gradient(180deg,#0f1522f0,#232e48bd);clip-path:polygon(100% 0,0 26%,72% 100%)}.cover-shanmen-night-snow:after{content:"";position:absolute;inset:auto 12% 16% auto;width:34%;height:26%;background:#ffffffb3;filter:blur(18px);opacity:.3}.cover-neon-embassy{background:linear-gradient(160deg,rgba(24,255,205,.15),transparent 32%),linear-gradient(180deg,#12192a,#0a0f18)}.cover-neon-embassy:before{content:"";position:absolute;inset:22% 0 18%;background:repeating-linear-gradient(180deg,#ffffff0a 0 8%,#0000 8% 12%),linear-gradient(90deg,transparent 0 14%,rgba(45,212,191,.75) 14% 17%,transparent 17% 24%,rgba(139,92,246,.62) 24% 28%,transparent 28% 100%)}.cover-neon-embassy:after{content:"";position:absolute;left:10%;right:10%;bottom:14%;height:14%;background:linear-gradient(90deg,#2dd4bf29,#8b5cf642);border:1px solid rgba(255,255,255,.08)}.cover-moonlit-court{background:radial-gradient(circle at 72% 16%,rgba(255,236,201,.4),transparent 22%),linear-gradient(180deg,#403b55,#1a1928 48%,#efe0db 48%,#d4c7c8)}.cover-moonlit-court:before{content:"";position:absolute;inset:18% 12% auto auto;width:34%;height:34%;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:#ffffff0f}.cover-moonlit-court:after{content:"";position:absolute;left:0;right:0;bottom:22%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent)}.cover-system-panel{background:radial-gradient(circle at 50% 10%,rgba(255,255,255,.14),transparent 24%),linear-gradient(180deg,#f3e8d2,#e8dcc3 56%,#d1bfa0)}.cover-system-panel:before{content:"系统";position:absolute;top:18%;left:18%;color:#6b2626eb;font-size:2rem;letter-spacing:.3em;writing-mode:vertical-rl}.cover-system-panel:after{content:"";position:absolute;inset:12% 10%;border:1px solid rgba(139,58,58,.18);box-shadow:inset 0 0 0 1px #ffffff3d,inset 0 0 36px #502c1c0f}.cover-unsolved-cases-revealed{background:linear-gradient(180deg,#0c0b0914,#0c0b0938),linear-gradient(180deg,#eadfca,#d8c8ad)}.cover-unsolved-cases-revealed:before,.cover-unsolved-cases-revealed:after{display:none}.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:24px}.brand{display:flex;align-items:center;gap:14px;min-width:0}.brand-home-link{display:inline-flex;flex:0 0 auto;border-radius:14px;transition:transform .16s ease,filter .16s ease}.brand-home-link:hover{transform:translateY(-1px);filter:brightness(1.08)}.brand-mark{width:52px;height:52px;border-radius:14px;overflow:hidden;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);box-shadow:0 12px 28px #00000047}.brand-logo-image{display:block;width:100%;height:100%;object-fit:cover}.brand-title{margin:0;font-size:1.2rem;font-weight:800;letter-spacing:.04em;background:linear-gradient(180deg,#fff,#c7d2fe);-webkit-background-clip:text;-webkit-text-fill-color:transparent;overflow-wrap:anywhere}.topbar-actions{display:flex;align-items:center;gap:12px;margin-left:auto}.account-menu{position:relative;display:flex}.account-trigger{display:inline-grid;place-items:center;width:36px;height:36px;padding:0;border:0;border-radius:50%;background:transparent;box-shadow:none;cursor:pointer;opacity:1;transition:opacity .16s ease,transform .16s ease,filter .16s ease;filter:brightness(1.85) contrast(1.08) drop-shadow(0 0 8px rgba(165,180,252,.28))}.account-trigger[aria-expanded=true]{opacity:1;filter:brightness(2.05) contrast(1.1) drop-shadow(0 0 12px rgba(165,180,252,.48))}.account-trigger:hover{opacity:1;transform:translateY(-1px);filter:brightness(2.05) contrast(1.1) drop-shadow(0 0 12px rgba(165,180,252,.46))}.account-avatar{width:36px;height:36px;object-fit:contain}.account-popover{position:absolute;top:calc(100% + 10px);right:0;z-index:20;min-width:172px;padding:8px 0;border:1px solid rgba(255,255,255,.12);border-radius:12px;background:#0a0d18f5;box-shadow:0 18px 40px #0006,inset 0 1px #ffffff0f;backdrop-filter:blur(18px)}.account-menu-section{display:grid;gap:2px}.account-menu-label{padding:6px 14px 5px;color:#cbd5e1a3;font-size:.72rem;line-height:1}.account-menu-item{display:flex;width:100%;align-items:center;justify-content:flex-start;min-height:34px;padding:8px 14px;border:0;border-radius:0;color:#dbeafe;background:transparent;cursor:pointer;font-size:.9rem;line-height:1.2;white-space:nowrap}.account-menu-item:hover{background:#ffffff0f}.account-menu-item-primary{color:#fff;background:linear-gradient(145deg,#8b5cf6d1,#2dd4bfad)}.account-email{display:block;max-width:190px;padding:5px 14px 8px;color:var(--text-soft);font-size:.8rem;line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pill-link,.primary-link,.ghost-link,.inline-link{display:inline-flex;align-items:center;gap:8px;transition:transform .2s ease,background .2s ease,border-color .2s ease}.pill-link{padding:12px 16px;color:#f8fbff;border-radius:999px;background:linear-gradient(145deg,#8b5cf680,#2dd4bf47);border:1px solid rgba(255,255,255,.2);box-shadow:0 12px 26px #8b5cf647,0 0 18px #2dd4bf24,inset 0 3px 9px #ffffff4d,inset 0 -4px 10px #00000047;text-shadow:0 1px 1px rgba(0,0,0,.32)}.primary-link{padding:14px 18px;border-radius:18px;color:#fff;background:linear-gradient(145deg,#8b5cf6d6,#2dd4bfb8);box-shadow:0 14px 32px #8b5cf647,inset 0 1px #ffffff4d}.ghost-link{padding:14px 18px;border-radius:18px;color:#dbeafe;border:1px solid rgba(255,255,255,.1);background:#ffffff08}.inline-link{color:#c4b5fd}.pill-link:hover,.primary-link:hover,.ghost-link:hover,.inline-link:hover{transform:translateY(-1px)}.pill-link:hover{box-shadow:0 15px 30px #8b5cf65c,0 0 22px #2dd4bf33,inset 0 3px 10px #ffffff57,inset 0 -4px 10px #00000042}.pill-link-arrow{font-size:1.1em}.hero{position:relative;overflow:hidden;padding:42px;border-radius:36px;background:linear-gradient(180deg,#04060af2,#0b0c15e0);border:1px solid rgba(255,255,255,.06);box-shadow:inset 4px 4px 12px #000000c7,inset -2px -2px 6px #ffffff08,0 24px 46px #0006}.hero:before{content:"";position:absolute;inset:-20% auto auto -10%;width:60%;height:65%;background:radial-gradient(circle,rgba(139,92,246,.25),transparent 70%);pointer-events:none}.hero:after{content:"";position:absolute;right:-4%;bottom:-18%;width:44%;height:55%;background:radial-gradient(circle,rgba(45,212,191,.16),transparent 72%);pointer-events:none}.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.85fr);gap:28px;align-items:stretch}.hero-copy h1,.page-title{margin:0;font-size:clamp(2.8rem,5vw,4.8rem);line-height:1.06;letter-spacing:-.03em}.hero-copy p,.page-subtitle,.muted{color:var(--text-soft)}.hero-copy p{margin:18px 0 0;max-width:760px;font-size:1.02rem;line-height:1.8}.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:26px}.hero-card,.panel,.template-card,.stat-card,.runner-panel,.region-card{background:linear-gradient(145deg,#161a27e6,#0c0f19db);border:1px solid var(--line);box-shadow:0 14px 30px #00000047,inset 0 1px #ffffff0f}.hero-card{padding:26px;border-radius:28px}.hero-kicker{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;color:#c7d2fe;background:#818cf81f;border:1px solid rgba(165,180,252,.18);font-size:.9rem}.hero-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:22px}.stat-card{padding:18px;border-radius:22px}.stat-label{display:block;color:#94a3b8;font-size:.88rem}.stat-value{display:block;margin-top:8px;font-size:1.35rem;font-weight:800}.section{margin-top:34px}.section-header{display:flex;align-items:end;justify-content:space-between;gap:16px;margin-bottom:18px}.section-header h2{margin:0;font-size:1.6rem}.section-header p{margin:8px 0 0;color:var(--text-soft)}.template-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.template-card{display:flex;flex-direction:column;gap:18px;padding:22px;border-radius:26px}.template-card-cover{min-height:180px;border-radius:22px;border:1px solid rgba(255,255,255,.08);background:radial-gradient(circle at top,rgba(255,255,255,.12),transparent 36%),linear-gradient(145deg,#8b5cf661,#2dd4bf29)}.template-card h3,.panel h3,.runner-panel h3,.region-card h3{margin:0}.template-card p{margin:0;color:var(--text-soft);line-height:1.75}.badge-row,.feature-list,.meta-list,.cta-list{display:flex;flex-wrap:wrap;gap:10px}.badge{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:999px;color:#dbeafe;background:#0f172abf;border:1px solid rgba(255,255,255,.08);font-size:.88rem}.feature{padding:8px 12px;border-radius:14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);color:#cbd5e1;font-size:.9rem}.detail-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(300px,.8fr);gap:20px}.template-focus{margin-top:22px}.template-focus-grid{display:grid;grid-template-columns:minmax(260px,320px) minmax(0,1fr);gap:28px;align-items:start}.template-focus-grid-minimal{grid-template-columns:minmax(240px,340px);justify-content:center;gap:22px}.template-detail-cover{width:100%}.template-intro{min-height:100%}.template-entry-actions{display:flex;justify-content:center}.template-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}.template-actions-minimal{margin-top:0;justify-content:center;flex-wrap:nowrap}.template-mode-link{position:relative;min-width:144px;min-height:58px;justify-content:center;border-radius:18px;overflow:hidden;font-weight:700;letter-spacing:.02em;text-shadow:0 1px 1px rgba(0,0,0,.32)}.template-mode-link:before{content:"";position:absolute;top:1px;left:8px;right:8px;height:38%;border-radius:999px 999px 18px 18px;background:linear-gradient(180deg,rgba(255,255,255,.46) 0%,rgba(255,255,255,.2) 46%,transparent 100%);opacity:.68;filter:blur(.4px);pointer-events:none}.template-mode-link:after{content:"";position:absolute;inset:1px;border-radius:17px;box-shadow:inset 0 1px #ffffff47,inset 0 -10px 18px #00000038;pointer-events:none}.template-actions-minimal .primary-link{border:1px solid rgba(255,255,255,.22);background:linear-gradient(145deg,#8b5cf6db,#2dd4bfb8);box-shadow:0 18px 34px #8b5cf66b,0 0 24px #2dd4bf42,inset 0 5px 12px #ffffff94,inset 0 -6px 16px #0000006b,inset 0 0 0 1px #ffffff3d}.template-actions-minimal .ghost-link{color:#e5edff;border:1px solid rgba(255,255,255,.14);background:linear-gradient(145deg,#1e2334c7,#080c168a);box-shadow:0 12px 24px #00000042,inset 0 5px 12px #ffffff57,inset 0 -4px 10px #00000057;backdrop-filter:blur(14px)}.template-actions-minimal .template-mode-link:hover{transform:translateY(-2px)}.template-actions-minimal .primary-link:hover{box-shadow:0 22px 42px #8b5cf680,0 0 30px #2dd4bf52,inset 0 4px 10px #ffffff94,inset 0 -5px 14px #00000057,inset 0 0 0 1px #ffffff42}.template-actions-minimal .ghost-link:hover{border-color:#ffffff38;box-shadow:0 16px 30px #00000052,0 0 18px #8b5cf62e,inset 0 3px 8px #fff3,inset 0 -4px 10px #00000052}.template-mode-link.is-pending{opacity:.8}.template-mode-link.is-pending:hover{transform:translateY(-1px)}.feedback-widget{position:fixed;right:env(safe-area-inset-right);top:50%;transform:translateY(-50%);z-index:80}.feedback-trigger{position:relative;display:block;width:58px;height:120px;padding:0;border:0;border-radius:24px;background:transparent;filter:drop-shadow(0 18px 26px rgba(10,15,28,.42)) drop-shadow(0 0 16px rgba(244,114,182,.26));cursor:pointer;transition:transform .18s ease,filter .18s ease}.feedback-trigger:hover,.feedback-trigger:focus-visible{transform:translate(-2px) scale(1.03);filter:drop-shadow(0 20px 30px rgba(10,15,28,.48)) drop-shadow(0 0 20px rgba(244,114,182,.36))}.feedback-trigger:focus-visible{outline:2px solid rgba(244,114,182,.78);outline-offset:3px}.feedback-trigger img{display:block;width:100%;height:100%;object-fit:contain;object-position:right center;pointer-events:none}.feedback-panel{position:absolute;top:50%;right:calc(100% + 14px);transform:translateY(-50%);width:min(360px,calc(100vw - 32px));padding:18px;border:1px solid rgba(255,255,255,.16);border-radius:24px;background:linear-gradient(145deg,#121827f0,#080d18e6),#0a0f1ceb;box-shadow:0 24px 60px #0000006b,0 0 28px #8b5cf62e,inset 0 1px #ffffff29;backdrop-filter:blur(22px)}.feedback-panel-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px}.feedback-panel-header h2{margin:0;color:#f8fbff;font-size:1.05rem}.feedback-close{width:34px;height:34px;border:1px solid rgba(255,255,255,.12);border-radius:50%;color:#dbeafe;background:#ffffff0f;cursor:pointer}.feedback-field{display:grid;gap:8px;margin-bottom:13px;color:#dbeafe;font-weight:700}.feedback-field small{color:#7d89a3;font-size:.76rem}.feedback-field input,.feedback-field select,.feedback-field textarea{width:100%;border:1px solid rgba(255,255,255,.12);border-radius:14px;color:#f8fbff;background:#ffffff0f;outline:none;padding:12px 13px;font:inherit}.feedback-field textarea{resize:vertical;min-height:122px}.feedback-field input:focus,.feedback-field select:focus,.feedback-field textarea:focus{border-color:#2dd4bf73;box-shadow:0 0 0 3px #2dd4bf1f}.feedback-honeypot{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}.feedback-status{min-height:20px;margin:2px 0 12px;color:#aeb9d1;font-size:.88rem}.feedback-submit{width:100%;justify-content:center;border:1px solid rgba(255,255,255,.18);cursor:pointer}.feedback-submit:disabled{cursor:wait;opacity:.7}.panel{padding:24px;border-radius:28px}.panel p{margin:0;line-height:1.8;color:var(--text-soft)}.panel+.panel{margin-top:20px}.page-stack{display:flex;flex-direction:column;gap:24px}.page-hero{padding:28px 0 6px}.page-hero .page-subtitle{margin:14px 0 0;max-width:760px;line-height:1.8}.runner-grid{display:grid;grid-template-columns:minmax(0,360px) minmax(0,1fr);gap:20px}.runner-panel{padding:22px;border-radius:28px}.runner-panel p{color:var(--text-soft);line-height:1.75}.form-stack{display:flex;flex-direction:column;gap:16px;margin-top:18px}.field{display:flex;flex-direction:column;gap:8px}.field label{color:#dbeafe;font-size:.95rem}.field input,.field select,.field textarea{width:100%;padding:14px 16px;color:#f8fafc;background:#05080fc7;border:1px solid rgba(255,255,255,.08);border-radius:16px;outline:none}.field textarea{min-height:148px;resize:vertical}.config-actions,.input-actions{display:flex;flex-wrap:wrap;gap:12px}.game-shell{display:flex;flex-direction:column;gap:18px}.preview-note{padding:14px 16px;border-radius:18px;color:#cbd5e1;background:#818cf81f;border:1px solid rgba(165,180,252,.16)}.story-card{min-height:420px;padding:22px;border-radius:28px}.story-card .content{color:#f8fafc;line-height:2;font-size:1rem}.story-card .content p:first-child{margin-top:0}.region-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.region-card{padding:18px;border-radius:22px}.region-card .content{margin-top:12px;color:var(--text-soft);line-height:1.7;white-space:pre-wrap}.input-panel{padding:20px;border-radius:28px}.input-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px}.input-row textarea{min-height:100px}body[data-engine-status=playing] .config-panel{display:none}body[data-engine-status=playing] .game-shell{display:flex}body[data-engine-status=ready] .game-shell,body[data-engine-status=idle] .game-shell,body[data-engine-status=error] .game-shell{display:none}.footer-note{margin-top:28px;text-align:center;color:#7c8aa5;font-size:.9rem}@media(max-width:1100px){.hero-grid,.detail-grid,.runner-grid,.template-grid,.region-grid{grid-template-columns:1fr}.bookshelf-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.template-focus-grid{grid-template-columns:1fr}.template-focus-grid-minimal{justify-items:center}}@media(max-width:720px){.site-shell{width:min(100% - 24px,1360px);padding:18px 0 44px}.topbar-shell{width:min(100% - 24px,1360px);padding-top:14px}.topbar{flex-direction:row;align-items:center;gap:12px;margin-bottom:14px}.brand{gap:10px}.brand-mark{width:48px;height:48px;border-radius:13px}.brand-title{font-size:1.22rem;line-height:1.1}.topbar-actions{flex:0 0 auto;gap:8px}.account-trigger,.account-avatar{width:34px;height:34px}.account-popover{right:0;min-width:158px}.bookshelf-section{margin-top:22px}.bookshelf-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:28px 16px;align-items:start}.book-link{gap:10px}.template-shelf-cover{border-radius:4px 11px 11px 4px}.template-code-badge{min-width:82px;padding:9px 18px 10px;font-size:12px}.hero,.panel,.runner-panel,.template-card,.story-card,.input-panel{padding:20px;border-radius:24px}.hero-copy h1,.page-title{font-size:clamp(2.3rem,11vw,3.5rem)}.template-detail-cover{max-width:228px}.template-entry-actions{width:100%}.template-actions-minimal{width:min(100%,320px);flex-direction:column;flex-wrap:nowrap}.template-mode-link{min-width:0;width:100%}.input-row{grid-template-columns:1fr}.feedback-widget{right:env(safe-area-inset-right);top:50%;transform:translateY(-50%)}.feedback-trigger{width:46px;height:94px;border-radius:18px}.feedback-panel{right:calc(100% + 8px);width:calc(100vw - 66px);max-height:calc(100dvh - 28px);overflow-y:auto}}.auth-page{display:flex;justify-content:center;padding-top:48px}.auth-card{width:min(100%,420px)}.auth-title{margin:0 0 24px;font-size:1.6rem;font-weight:800}.auth-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:1px solid var(--line)}.auth-tab{padding:10px 20px;background:none;border:none;color:var(--text-soft);font-size:.95rem;font-family:inherit;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .2s,border-color .2s}.auth-tab:hover{color:#f5f7fb}.auth-tab.is-active{color:#f5f7fb;border-bottom-color:var(--accent-a)}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-form .field{display:flex;flex-direction:column;gap:6px}.auth-form .field label{font-size:.88rem;color:var(--text-soft)}.auth-form .field input{padding:12px 14px;background:var(--panel);border:1px solid var(--line);border-radius:10px;color:#f5f7fb;font-size:.95rem;font-family:inherit;outline:none;transition:border-color .2s}.auth-form .field input:focus{border-color:var(--accent-a)}.auth-form .field input::placeholder{color:#cbd5e166}.auth-error{color:#f87171;font-size:.88rem;min-height:0}.auth-error:empty{display:none}.auth-success{color:var(--accent-b);font-size:.88rem}.auth-submit{width:100%;justify-content:center;cursor:pointer;border:none;font-size:1rem;margin-top:4px}.auth-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-footer{margin-top:20px;font-size:.88rem;text-align:center}.auth-footer-tight{margin-top:6px}.auth-hint{font-size:.88rem;color:var(--text-soft);margin:0;line-height:1.5}.auth-callback-status{font-size:.95rem}.auth-toast{display:none;padding:10px 14px;border-radius:8px;font-size:.88rem;text-align:center;margin-bottom:8px;animation:toast-fade 3s ease forwards}@keyframes toast-fade{0%{opacity:0;transform:translateY(-6px)}10%{opacity:1;transform:translateY(0)}80%{opacity:1}to{opacity:0}}.password-field{position:relative;display:flex;align-items:center}.password-field input{flex:1;padding-right:48px}.password-toggle{position:absolute;right:10px;display:inline-grid;place-items:center;width:30px;height:30px;padding:0;background:transparent;border:none;color:var(--text-soft);cursor:pointer;border-radius:50%}.password-toggle:hover{color:#f5f7fb;background:#ffffff0d}.password-toggle-icon{position:relative;display:block;width:18px;height:12px;border:1.8px solid currentColor;border-radius:50%/58%}.password-toggle-icon:before{content:"";position:absolute;top:50%;left:50%;width:5px;height:5px;border-radius:50%;background:currentColor;transform:translate(-50%,-50%)}.password-toggle[aria-pressed=true] .password-toggle-icon:after{content:"";position:absolute;top:50%;left:-2px;width:22px;height:1.8px;border-radius:999px;background:currentColor;transform:rotate(-38deg);transform-origin:center}@media(max-width:720px){.auth-page{padding-top:24px}}
