:root{--font-body:"Iowan Old Style","Source Han Serif SC","Songti SC","Noto Serif SC",serif;--font-ui:"SF Pro Text","PingFang SC","Hiragino Sans GB","Noto Sans SC","Microsoft YaHei",sans-serif;--bg:#f6f2ea;--bg-soft:#efe8dc;--surface:#fffdfa;--surface-muted:#f8f3eb;--line:#ddd3c4;--ink:#201d19;--ink-soft:#5e554a;--hint:#857a6d;--accent:#2c2722;--accent-soft:#ebe2d4;--accent-strong:#1f1b17;--danger:#b42318;--ok:#0f6d41;--radius:16px;--shadow-sm:0 2px 8px rgba(34,26,15,.06);--shadow-md:0 10px 28px rgba(34,26,15,.1)}*{box-sizing:border-box}body,html{margin:0;padding:0;-webkit-text-size-adjust:100%}body{min-height:100vh;color:var(--ink);font-family:var(--font-ui);background:radial-gradient(circle at 8% -10%,hsla(0,0%,100%,.8),transparent 38%),radial-gradient(circle at 110% 110%,hsla(36,40%,82%,.4),transparent 40%),linear-gradient(165deg,#f9f6f1,#f4efe7 48%,#eee7dc)}a{color:inherit;text-decoration:none}h1,h2,h3,h4{margin:0;font-family:var(--font-body);letter-spacing:.01em}p{margin:0}button,input,select,textarea{font-family:var(--font-ui);font-size:16px;outline:none}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{box-shadow:0 0 0 3px rgba(57,45,31,.18)}.ghost-btn,.ghost-link,.primary-btn{min-height:42px;border-radius:14px;border:1px solid transparent;padding:8px 14px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:transform .14s ease,background-color .14s ease,border-color .14s ease,box-shadow .14s ease}.primary-btn{background:linear-gradient(180deg,#2f2a24,#201c17);border-color:#171410;color:#f8f2e8;font-weight:600}.primary-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.ghost-btn:active,.ghost-link:active,.primary-btn:active{transform:translateY(1px)}.ghost-btn,.ghost-link{border-color:var(--line);background:rgba(255,253,249,.86);color:var(--ink-soft)}.ghost-btn:hover,.ghost-link:hover{border-color:#c7baa8;background:#fffaf2;color:var(--ink)}.ghost-btn[aria-disabled=true],button:disabled{opacity:.55;cursor:not-allowed;pointer-events:none}.page-wrap{width:min(1120px,calc(100vw - 24px));margin:14px auto 24px;display:grid;grid-gap:16px;gap:16px}.page-head{display:grid;grid-gap:10px;gap:10px}.page-head h1{font-size:clamp(28px,4.2vw,40px)}.page-head p{color:var(--ink-soft)}.page-topbar{justify-content:space-between;align-items:center}.page-actions,.page-topbar,.page-topbar-links{display:flex;gap:8px;flex-wrap:wrap}.auth-card input,.composer textarea,.page-actions input,.pipeline-card input,.pipeline-card select,.pipeline-card textarea,.settings-grid input,.settings-grid select,select,textarea{width:100%;border:1px solid var(--line);background:var(--surface);color:var(--ink);border-radius:12px;padding:10px 12px}.page-actions button,.page-actions input{min-height:42px}.inline-error{color:var(--danger);font-size:14px}.upload-progress{color:var(--ink-soft);font-size:14px}.upload-success{color:var(--ok);font-size:14px}.novel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));grid-gap:12px;gap:12px}.novel-card{border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(180deg,#fffdfa,#f8f1e8);padding:14px;box-shadow:var(--shadow-sm);display:grid;grid-gap:10px;gap:10px}.novel-card h3{font-size:20px}.novel-card p{color:var(--ink-soft);line-height:1.65}.detail-cover,.novel-cover{border-radius:12px;color:#f7efe4;display:grid;place-items:center;background:linear-gradient(145deg,#3e372f,#2a2520 45%,#171513),repeating-linear-gradient(45deg,hsla(0,0%,100%,.04) 0 6px,transparent 6px 12px);box-shadow:inset 0 0 0 1px hsla(0,0%,100%,.04)}.novel-cover{height:132px;font-size:30px;font-family:var(--font-body)}.tags{display:flex;gap:6px;flex-wrap:wrap}.tags span{border-radius:999px;border:1px solid #d2c3af;background:rgba(255,252,246,.86);color:#665a4b;font-size:12px;padding:4px 9px}.card-actions{display:flex;gap:8px;flex-wrap:wrap}.auth-page{min-height:100vh;display:grid;place-items:center;padding:20px}.auth-card{width:min(460px,100%);border:1px solid var(--line);border-radius:18px;background:rgba(255,252,247,.9);box-shadow:var(--shadow-md);padding:20px;display:grid;grid-gap:12px;gap:12px}.auth-card p{color:var(--ink-soft)}.auth-card label,.pipeline-card label,.settings-grid label{display:grid;grid-gap:6px;gap:6px;color:var(--ink-soft);font-size:14px}.novel-detail{gap:14px}.detail-hero{border-radius:18px;border:1px solid var(--line);background:rgba(255,252,247,.88);box-shadow:var(--shadow-sm);display:grid;grid-template-columns:220px 1fr;grid-gap:18px;gap:18px;align-items:start;padding:16px}.detail-cover{min-height:220px;font-family:var(--font-body);font-size:44px}.detail-sessions{border-radius:16px;background:rgba(255,253,249,.86);padding:14px;grid-gap:12px;gap:12px}.detail-sessions,.session-setup{border:1px solid var(--line);display:grid}.session-setup{border-radius:12px;background:#fffdfa;padding:10px;grid-gap:8px;gap:8px}.session-setup p{color:var(--ink-soft);line-height:1.58}.setup-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.character-picker,.setup-grid{display:grid;grid-gap:8px;gap:8px}.character-option{border:1px solid var(--line);border-radius:12px;background:#fffefa;padding:10px;text-align:left;display:grid;grid-gap:6px;gap:6px}.character-option.active{border-color:#aa967f;background:#f8efe3;box-shadow:inset 0 0 0 1px rgba(111,86,54,.14)}.character-option-head{display:flex;align-items:center;gap:8px}.character-option-head span{border-radius:999px;border:1px solid #ccb89f;background:#fff7ea;color:#6a5b4a;font-size:12px;padding:2px 8px}.character-option p{color:var(--ink-soft);line-height:1.55}.detail-sessions h2{font-size:20px}.detail-sessions ul{margin:0;padding:0;list-style:none;display:grid;grid-gap:8px;gap:8px}.detail-sessions li{border:1px solid var(--line);border-radius:12px;background:#fffefa;padding:10px;display:flex;align-items:center;justify-content:space-between;gap:8px}.detail-sessions small{color:var(--hint)}.pipeline-card,.settings-grid{border-radius:16px;border:1px solid var(--line);background:rgba(255,253,248,.9);box-shadow:var(--shadow-sm);padding:14px}.pipeline-card{display:grid;grid-gap:12px;gap:12px}.pipeline-steps{margin:0;padding:0;list-style:none;display:grid;grid-gap:8px;gap:8px}.pipeline-steps li{border:1px dashed var(--line);border-radius:10px;padding:10px}.check-row{display:flex;align-items:center;gap:8px;color:var(--ink-soft);font-size:14px}.check-row input[type=checkbox]{width:18px;height:18px}.settings-grid{display:grid;grid-gap:12px;gap:12px}.session-page{width:min(1320px,calc(100vw - 12px));margin:6px auto 14px;display:grid;grid-gap:10px;gap:10px;min-height:calc(100svh - 8px);height:auto;overflow:auto}.session-header{position:-webkit-sticky;position:sticky;top:6px;z-index:20;border-radius:14px;border:1px solid var(--line);background:rgba(255,252,246,.95);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--shadow-sm);padding:10px 12px;display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;grid-gap:10px;gap:10px}.header-left{min-width:0;display:flex;align-items:center;gap:10px}.header-back{min-height:40px;padding:7px 12px;white-space:nowrap}.header-title{min-width:0;display:grid;grid-gap:2px;gap:2px}.header-title h1{font-size:clamp(18px,2.6vw,24px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-label{color:var(--hint);font-size:12px}.header-scene{max-width:320px;border-radius:999px;border:1px solid #d5c7b4;background:#f7efe4;color:#5f5548;padding:8px 12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-right{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.header-right>span{font-size:13px;color:var(--hint)}.connection-banner{border-radius:12px;border:1px solid var(--line);padding:8px 10px;display:flex;align-items:center;gap:8px;font-size:14px;background:rgba(255,252,246,.92)}.connection-online{color:var(--ok)}.connection-reconnecting{color:#86652c;background:#fff8ea;border-color:#eed6a7}.connection-offline{color:var(--danger);background:#fff1ef;border-color:#f4c2bc}.app-shell{min-height:0;height:100%;display:grid;grid-template-columns:minmax(0,1fr);grid-gap:8px;gap:8px}.shell-center,.shell-left,.shell-right{min-height:0;border:1px solid var(--line);border-radius:14px;background:rgba(255,253,248,.95)}.shell-center{padding:8px;overflow:hidden}.shell-left,.shell-right{display:none}.left-nav{height:100%;padding:12px;display:grid;align-content:start;grid-gap:14px;gap:14px}.left-nav.collapsed{width:100%}.left-nav-top{display:flex;gap:8px}.left-nav-section h3{color:var(--ink-soft);font-size:14px;margin-bottom:8px}.left-nav-section ul{margin:0;padding:0;list-style:none;display:grid;grid-gap:6px;gap:6px}.left-nav-section li{border-radius:10px;border:1px solid transparent}.left-nav-section li.active,.left-nav-section li:hover{border-color:var(--line);background:#fffdf9}.left-nav-section li a{display:grid;grid-gap:2px;gap:2px;padding:8px}.left-nav-section small{color:var(--hint)}.session-center{height:100%;grid-template-rows:auto minmax(0,1fr) auto;overflow:hidden}.session-center,.story-onboarding{min-height:0;display:grid;grid-gap:8px;gap:8px}.story-onboarding{border:1px solid #dbcbb8;border-radius:12px;background:linear-gradient(180deg,#f9f4ea,#f4ede3);padding:12px;max-height:min(42vh,320px);overflow:auto}.story-onboarding h3{font-size:18px}.story-onboarding-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.story-onboarding.collapsed{gap:0;padding-bottom:8px}.playbook-list,.story-onboarding p{color:var(--ink-soft)}.playbook-list{margin:0;padding-left:18px;display:grid;grid-gap:4px;gap:4px}.story-onboarding-actions button{min-height:32px}.turn-feed{min-height:0;overflow:auto;display:grid;grid-gap:10px;gap:10px;padding-right:2px;padding-bottom:4px;-webkit-overflow-scrolling:touch}.turn-empty{border-style:dashed}.turn-card{border:1px solid var(--line);border-radius:12px;background:#fffefa;padding:12px;display:grid;grid-gap:10px;gap:10px;transition:border-color .14s ease,box-shadow .14s ease,transform .14s ease}.turn-card.streaming{border-color:#cfbea9;box-shadow:inset 0 0 0 1px rgba(119,91,56,.14)}.turn-card.error{border-color:#efc3bb}.turn-card header{display:flex;justify-content:space-between;align-items:center;gap:8px;color:var(--hint);font-size:13px}.turn-blocks{display:grid;grid-gap:8px;gap:8px}.turn-block{border-radius:10px;padding:9px 10px}.turn-block p{margin-bottom:.66em;line-height:1.84}.turn-block p:last-child{margin-bottom:0}.turn-block.narration{border:1px solid #e2d8cb;background:#fffdf9}.turn-block.narration p{font-family:var(--font-body);text-indent:1.9em}.turn-block.dialogue{border:1px solid #d7ccbf;background:#faf5ee}.turn-block.dialogue h4{margin:0 0 6px;font-size:14px;color:#5b5044}.turn-block.dialogue p{text-indent:0;font-family:var(--font-body)}.turn-block.feedback{border-left:4px solid #9d8f7f;background:#f3eee7}.turn-block.user{border-left:4px solid #786a59;background:#eee6dc}.turn-block.feedback p,.turn-block.user p{font-family:var(--font-ui);text-indent:0}.turn-error{color:var(--danger);font-size:13px}.composer{border:1px solid var(--line);border-radius:12px;background:#fffefa;padding:10px;display:grid;grid-gap:9px;gap:9px;transition:border-color .14s ease,box-shadow .14s ease}.composer-bottom,.composer-top{display:flex;justify-content:space-between;gap:8px;align-items:center}.mode-switch{display:inline-flex;gap:6px;flex-wrap:wrap}.mode-switch button{border:1px solid var(--line);background:#fff;color:var(--ink-soft);border-radius:999px;min-height:38px;padding:7px 12px}.mode-switch button.active{border-color:#ad9a83;background:var(--accent-soft);color:var(--accent-strong)}.composer-tip,.quick-action-tip,.revision{font-size:12px;color:var(--hint)}.composer textarea{min-height:92px;resize:vertical;font-size:16px;line-height:1.58}.quick-actions{display:flex;gap:6px;flex-wrap:wrap;-webkit-overflow-scrolling:touch}.action-grid button,.quick-actions button,.tag-filter button{border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--ink-soft);min-height:36px;padding:6px 11px}.action-grid button:hover,.quick-actions button:hover,.tag-filter button:hover{border-color:#cdbda8;color:var(--ink);background:#fffaf1}.story-panel{height:100%;display:grid;grid-template-rows:auto minmax(0,1fr)}.panel-tabs{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));grid-gap:6px;gap:6px;padding:10px}.panel-tabs button{border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--ink-soft);min-height:38px;padding:7px 8px}.panel-tabs button.active{border-color:#ad9a83;background:#f3eadf;color:var(--ink)}.panel-body{min-height:0;overflow:auto;padding:0 10px 10px;-webkit-overflow-scrolling:touch}.panel-card,.panel-list{display:grid;grid-gap:8px;gap:8px}.panel-card{border:1px solid var(--line);border-radius:12px;background:#fffefa;padding:10px;transition:border-color .14s ease,box-shadow .14s ease}.panel-card h4{font-size:16px}.panel-card p{color:var(--ink-soft);line-height:1.62}.panel-card small{color:var(--hint)}.decision-option,.interactable-item{border:1px solid #e2d6c7;border-radius:10px;background:#fffdf9;padding:8px;display:grid;grid-gap:6px;gap:6px}.decision-option button,.interactable-item button{justify-self:start}.tag-filter{display:flex;gap:6px;flex-wrap:wrap}.tag-filter button.active{border-color:#ad9a83;background:#f3eadf;color:var(--ink)}.action-grid{display:flex;flex-wrap:wrap;gap:6px}.entity-mini-list{display:grid;grid-gap:4px;gap:4px;color:var(--ink-soft)}.mobile-panel-toggle{display:inline-flex;position:fixed;right:12px;bottom:calc(96px + env(safe-area-inset-bottom));z-index:22;min-height:38px;border-radius:12px;border:1px solid #2b251f;background:#2b251f;color:#f7f0e7;padding:6px 11px;box-shadow:0 6px 16px rgba(27,20,12,.2)}.mobile-drawer{display:block;position:fixed;inset:auto 0 0 0;max-height:82vh;transform:translateY(104%);transition:transform .2s ease;background:#fffefa;border-top-left-radius:16px;border-top-right-radius:16px;border-top:1px solid var(--line);box-shadow:0 -12px 30px rgba(23,18,12,.18);z-index:21}.mobile-drawer.open{transform:translateY(0)}.mobile-drawer-scrim{display:none}.drawer-header{border-bottom:1px solid var(--line);padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:10px}.drawer-content{max-height:calc(82vh - 56px);overflow:auto;-webkit-overflow-scrolling:touch}@media (min-width:1200px){.app-shell{grid-template-columns:220px minmax(0,1fr) 336px}.shell-left,.shell-right{display:block}.mobile-drawer,.mobile-drawer-scrim,.mobile-panel-toggle{display:none}}@media (max-width:1199px){.ghost-btn,.ghost-link,.primary-btn{min-height:34px;border-radius:12px;padding:5px 10px;font-size:14px}.mobile-drawer-scrim{display:block;position:fixed;inset:0;z-index:20;border:0;background:rgba(30,23,15,.34)}.session-page{width:calc(100vw - 16px);margin:6px auto 10px;gap:6px;min-height:calc(100svh - 6px);height:auto}.story-onboarding{max-height:min(36vh,260px)}.shell-center{padding:7px}.turn-feed{gap:8px}.composer{position:-webkit-sticky;position:sticky;bottom:0;z-index:18;border-radius:12px 12px 0 0;box-shadow:0 -8px 18px rgba(35,26,15,.12);padding:7px;gap:5px}.panel-tabs{grid-template-columns:repeat(3,minmax(0,1fr));gap:4px;padding:8px}.panel-tabs button{min-height:34px;padding:5px 6px}.mobile-panel-toggle{right:10px;bottom:calc(72px + env(safe-area-inset-bottom));min-height:34px;padding:5px 10px;font-size:13px}}@media (max-width:900px){.page-wrap{width:calc(100vw - 16px);margin:8px auto 14px;gap:12px}.detail-hero{padding:12px}.detail-hero,.setup-grid{grid-template-columns:1fr}.detail-cover{min-height:160px}.card-actions .ghost-btn,.card-actions .primary-btn{width:auto;min-width:104px}.session-header{grid-template-columns:1fr;align-items:start;gap:8px}.header-scene{max-width:100%}.header-right{width:100%;justify-content:flex-start}.page-actions{width:100%}.page-actions input{flex:1 1 100%}.page-actions .ghost-btn{flex:1 1 auto}.session-header{margin-inline:1px}}@media (max-width:640px){.ghost-btn,.ghost-link,.primary-btn{min-height:34px;padding:5px 10px;font-size:13px}.session-header{top:2px;border-radius:12px;padding:7px 9px;gap:6px}.header-title h1{font-size:19px}.header-back{min-height:32px;padding:4px 8px}.novel-grid{grid-template-columns:1fr}.session-setup{padding:8px;gap:6px}.playbook-list{padding-left:16px}.turn-card{padding:8px;gap:7px}.turn-block p{font-size:15px;line-height:1.64}.composer textarea{min-height:70px;font-size:16px}.composer-bottom{align-items:center;gap:6px}.quick-actions{flex:1 1 auto;overflow-x:auto;white-space:nowrap;padding-bottom:1px;gap:5px}.quick-actions button{white-space:nowrap;min-height:30px;padding:4px 8px;font-size:12px}.mode-switch button{min-height:28px;padding:3px 8px;font-size:12px}.mobile-panel-toggle{min-height:32px;padding:4px 9px;bottom:calc(78px + env(safe-area-inset-bottom))}}