@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.absolute{position:absolute}.relative{position:relative}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.flex{display:flex}.hidden{display:none}.h-screen{height:100vh}.border{border-style:var(--tw-border-style);border-width:1px}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif}:root{--bg-primary:#14110d;--bg-secondary:#1a1510;--bg-card:#201a14;--text-primary:#fef3c7;--text-secondary:#e7d5b8;--text-muted:#a89070;--primary:#fbbf24;--primary-light:#fcd34d;--primary-dark:#f59e0b;--border:#fbbf2426;--shadow-card:0 1px 3px #0000004d;--font:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei",sans-serif}.jj-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:12px}.jj-scrollbar{scrollbar-width:thin;scrollbar-color:#fbbf244d transparent}.jj-scrollbar::-webkit-scrollbar{width:6px}.jj-scrollbar::-webkit-scrollbar-track{background:0 0}.jj-scrollbar::-webkit-scrollbar-thumb{background:#fbbf244d;border-radius:3px}.jj-scrollbar::-webkit-scrollbar-thumb:hover{background:#fbbf2480}.jj-placeholder{height:100%;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex}.jj-placeholder-icon{opacity:.4;font-size:32px}.jj-placeholder-text{font-size:12px}.jj-start-screen{background:var(--bg-primary);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.jj-start-bg{position:absolute;inset:0;overflow:hidden}.jj-start-bg video,.jj-start-bg img{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.jj-start-bg-overlay{background:linear-gradient(#14110dd9,#14110db3,#14110de6);position:absolute;inset:0}.jj-start-content{z-index:1;text-align:center;flex-direction:column;align-items:center;width:100%;max-width:480px;max-height:100vh;padding:32px 24px;display:flex;position:relative;overflow-y:auto}.jj-start-badge{letter-spacing:4px;color:#fbbf24cc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fbbf240f;border:1px solid #fbbf2433;border-radius:2px;margin-bottom:24px;padding:6px 20px;font-size:11px;display:inline-block}.jj-start-title{color:#0000;filter:drop-shadow(0 4px 20px #fbbf2480);letter-spacing:6px;background:linear-gradient(#fffbe6,#fbbf24 40%,#b8860b);-webkit-background-clip:text;background-clip:text;margin:0 0 16px;font-size:48px;font-weight:900;line-height:1.3}.jj-start-tagline{color:#fef3c773;letter-spacing:5px;margin:0 0 28px;font-size:12px}.jj-start-divider{transform-origin:50%;background:linear-gradient(90deg,#0000,#fbbf2480,#0000);width:60px;height:1px;margin:0 auto 12px}.jj-start-section-label{color:#fef3c766;letter-spacing:6px;text-transform:uppercase;margin:0 0 20px;font-size:11px}.jj-start-mission{color:#fef3c799;letter-spacing:.5px;margin:0 0 24px;font-size:13px;line-height:1.9}.jj-start-mission strong{color:var(--primary);font-weight:600}.jj-start-cards{justify-content:center;gap:12px;width:100%;margin-bottom:32px;display:flex}.jj-start-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#14110db3;border:1px solid #fbbf241f;border-radius:10px;flex:1;max-width:140px;transition:transform .3s,border-color .3s;overflow:hidden}.jj-start-card:hover{border-color:#fbbf244d;transform:translateY(-4px)}.jj-start-card-img{aspect-ratio:3/4;width:100%;position:relative;overflow:hidden}.jj-start-card-img img{object-fit:cover;width:100%;height:100%}.jj-start-card-gradient{background:linear-gradient(#0000 50%,#14110df2);position:absolute;inset:0}.jj-start-card-body{text-align:left;padding:10px}.jj-start-card-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.jj-start-card-name{color:var(--text-primary);font-size:14px;font-weight:700}.jj-start-card-role{letter-spacing:1px;background:#ffffff14;border-radius:3px;padding:2px 6px;font-size:9px;font-weight:600}.jj-start-card-threat{align-items:center;gap:4px;margin-bottom:8px;display:flex}.jj-start-card-threat-label{color:#fef3c759;letter-spacing:1px;font-size:9px}.jj-start-card-threat-stars{color:var(--primary);letter-spacing:-1px;font-size:10px}.jj-start-card-quote{color:#fef3c780;margin:0;font-size:11px;font-style:italic;line-height:1.5}.jj-start-hint{color:#fef3c740;letter-spacing:2px;margin:4px 0 0;font-size:11px}.jj-start-btn{color:#14110d;letter-spacing:3px;cursor:pointer;background:linear-gradient(135deg,#fbbf24,#d4a017);border:none;border-radius:8px;padding:14px 48px;font-size:16px;font-weight:700;transition:all .2s;display:inline-block;position:relative;box-shadow:0 4px 24px #fbbf2459,inset 0 1px #fff3}.jj-start-btn:hover{transform:translateY(-2px);box-shadow:0 8px 32px #fbbf2480,inset 0 1px #fff3}.jj-start-back{color:var(--text-muted);cursor:pointer;background:0 0;border:none;margin-top:16px;font-size:12px;transition:color .2s;display:block}.jj-start-back:hover{color:var(--text-secondary)}.jj-game{background:var(--bg-secondary);height:100vh;font-family:var(--font);flex-direction:column;display:flex}.jj-header{background:var(--bg-secondary);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;min-height:44px;padding:8px 16px;display:flex}.jj-header-left{align-items:center;gap:8px;display:flex}.jj-header-logo{font-size:18px}.jj-header-title{color:var(--primary);font-size:14px;font-weight:600}.jj-header-menu{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:8px 12px;font-size:14px;transition:all .2s}.jj-header-menu:hover{color:var(--text-primary);background:#fbbf241a}.jj-main{flex:1;display:flex;overflow:hidden}.jj-left{flex-shrink:0;width:280px}.jj-center{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.jj-right{flex-shrink:0}.jj-scene-card{aspect-ratio:16/9;position:relative;overflow:hidden}.jj-scene-card img,.jj-scene-card video{object-fit:cover;width:100%;height:100%}.jj-scene-tag{color:var(--text-primary);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#14110dd9;border-radius:100px;align-items:center;gap:4px;padding:4px 10px;font-size:11px;display:flex;position:absolute;bottom:10px;left:10px}.jj-portrait-card{aspect-ratio:3/4;position:relative;overflow:hidden}.jj-portrait-card img,.jj-portrait-card video{object-fit:cover;object-position:center top;width:100%;height:100%}.jj-info-card{padding:14px}.jj-info-title{color:var(--text-primary);margin-bottom:4px;font-size:16px;font-weight:600}.jj-info-meta{color:var(--text-muted);align-items:center;gap:6px;margin-bottom:10px;font-size:12px;display:flex}.jj-info-desc{color:var(--text-secondary);font-size:13px;line-height:1.6}.jj-char-list{grid-template-columns:repeat(2,1fr);gap:8px;padding:12px;display:grid}.jj-char-item{color:var(--text-secondary);cursor:pointer;background:#fbbf240d;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;padding:10px;font-size:13px;transition:all .15s;display:flex}.jj-char-item:hover{background:#fbbf241a;border-color:#fbbf2433}.jj-char-item.active{border-color:var(--primary);color:var(--text-primary);background:#fbbf2426;font-weight:500}.jj-dialogue-bg{border-radius:12px;position:absolute;inset:0;overflow:hidden}.jj-dialogue-bg img,.jj-dialogue-bg video{object-fit:cover;width:100%;height:100%}.jj-dialogue-bg-overlay{-webkit-backdrop-filter:blur(12px);background:#14110d59;position:absolute;inset:0}.jj-letter-card{-webkit-backdrop-filter:blur(20px);background:#ffffff1f;border:1px solid #fff3;border-radius:12px;margin-bottom:24px;padding:28px 24px 24px;position:relative;box-shadow:0 4px 16px #00000026}.jj-letter-seal{width:28px;height:28px;color:var(--primary);filter:drop-shadow(0 2px 4px #fbbf244d);position:absolute;top:-14px;left:50%;transform:translate(-50%)}.jj-letter-genre{color:var(--primary);letter-spacing:1px;background:#fbbf2426;border-radius:100px;margin-bottom:8px;padding:3px 10px;font-size:10px;font-weight:600;display:inline-block}.jj-letter-title{color:var(--text-primary);margin:0 0 16px;font-size:20px;font-weight:700}.jj-letter-body{color:var(--text-secondary);text-align:left;margin:0 0 20px;font-size:14px;line-height:1.8}.jj-letter-goals{text-align:left}.jj-letter-goals-label{color:var(--text-muted);text-align:center;margin-bottom:10px;font-size:11px;font-weight:600}.jj-letter-goal{color:var(--text-secondary);align-items:flex-start;gap:8px;margin-bottom:6px;font-size:13px;display:flex}.jj-letter-goal svg{width:14px;height:14px;color:var(--primary);flex-shrink:0;margin-top:2px}.jj-system-msg{text-align:center;color:var(--text-muted);background:#fbbf2414;border-radius:8px;margin-bottom:16px;padding:12px 16px;font-size:13px}.jj-player-bubble{-webkit-backdrop-filter:blur(20px);max-width:85%;color:var(--text-primary);background:#14110d8c;border:1px solid #ffffff1a;border-radius:16px 4px 16px 16px;padding:12px 16px;font-size:14px;box-shadow:0 4px 16px #0000004d}.jj-story-paragraph{-webkit-backdrop-filter:blur(20px);color:var(--text-primary);background:#14110d8c;border:1px solid #ffffff1a;border-radius:12px;margin-bottom:16px;padding:16px 20px;font-size:14px;line-height:1.9;box-shadow:0 4px 16px #00000026}.jj-story-paragraph .char-name{font-weight:600}.jj-story-paragraph .dialogue{color:var(--primary-light)}.jj-story-paragraph .action{color:#d4a574;font-style:italic}.jj-story-paragraph .narration{color:var(--text-secondary);margin:8px 0}.jj-story-paragraph .dialogue-line{margin:8px 0}.jj-story-paragraph .plain-text{color:var(--text-secondary)}.jj-story-paragraph .bold-text{color:var(--primary-light);font-weight:700}.jj-story-paragraph .jj-divider{border:none;border-top:1px solid var(--border);margin:16px 0}.jj-story-paragraph .jj-heading{color:var(--primary);margin:16px 0 8px;font-size:14px;font-weight:700}.jj-story-paragraph .jj-list-item{color:var(--text-secondary);margin:4px 0;padding-left:16px;position:relative}.jj-story-paragraph .jj-list-item:before{content:"•";color:var(--primary);position:absolute;left:4px}.jj-typing-dot{background:var(--primary);border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite jj-typing-bounce;display:inline-block}.jj-typing-dot:nth-child(2){animation-delay:.16s}.jj-typing-dot:nth-child(3){animation-delay:.32s}@keyframes jj-typing-bounce{0%,80%,to{opacity:.4;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.jj-quick-btn{color:var(--text-secondary);cursor:pointer;background:#fbbf2414;border:1px solid #fbbf2426;border-radius:16px;align-items:center;gap:4px;padding:6px 12px;font-size:12px;transition:all .15s;display:flex}.jj-quick-btn:hover:not(:disabled){color:var(--text-primary);background:#fbbf2426;border-color:#fbbf244d}.jj-quick-btn:disabled{opacity:.5;cursor:not-allowed}.jj-input{border:1px solid var(--border);color:var(--text-primary);background:#14110dcc;border-radius:12px;outline:none;flex:1;padding:12px 16px;font-size:14px;transition:all .2s}.jj-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #fbbf241a}.jj-input::placeholder{color:var(--text-muted)}.jj-send-btn{background:linear-gradient(135deg,var(--primary)0%,var(--primary-dark)100%);color:var(--bg-primary);cursor:pointer;border:none;border-radius:12px;padding:12px 20px;font-size:13px;font-weight:600;transition:all .2s}.jj-send-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #fbbf244d}.jj-send-btn:disabled{opacity:.5;cursor:not-allowed}.jj-nav-bar{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;flex-direction:column;width:52px;height:100%;padding:12px 8px;display:flex}.jj-nav-btn{cursor:pointer;background:0 0;border:none;border-radius:8px;flex-direction:column;align-items:center;gap:4px;padding:10px 0;transition:all .15s;display:flex}.jj-nav-btn:hover{background:#fbbf2414}.jj-nav-btn.active{background:#fbbf241f}.jj-nav-icon{font-size:18px}.jj-nav-label{color:var(--text-muted);font-size:9px}.jj-nav-btn.active .jj-nav-label{color:var(--primary)}.jj-nav-badge{background:var(--primary);min-width:16px;height:16px;color:var(--bg-primary);border-radius:100px;justify-content:center;align-items:center;padding:0 4px;font-size:10px;font-weight:600;display:flex;position:absolute;top:4px;right:4px}.jj-detail-panel{width:200px;height:100%}.jj-item-row{background:#fbbf240d;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;transition:all .15s;display:flex}.jj-item-row:hover:not(.disabled){background:#fbbf241a}.jj-item-row.disabled{opacity:.4}.jj-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#14110de6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.jj-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;width:90%;max-width:320px;padding:24px}.jj-modal-title{color:var(--text-primary);text-align:center;margin:0 0 20px;font-size:16px;font-weight:600}.jj-modal-btns{flex-direction:column;gap:4px;display:flex}.jj-modal-btn{width:100%;color:var(--text-secondary);text-align:left;cursor:pointer;background:#fbbf240d;border:none;border-radius:8px;padding:12px 16px;font-size:13px;text-decoration:none;transition:all .15s;display:block}.jj-modal-btn:hover{color:var(--text-primary);background:#fbbf241a}.jj-ending-modal{background:var(--bg-card);text-align:center;border:2px solid;border-radius:20px;width:90%;max-width:400px;padding:32px 24px}.jj-ending-modal.gold{border-color:gold}.jj-ending-modal.silver{border-color:silver}.jj-ending-modal.bronze{border-color:#cd7f32}.jj-ending-modal.black{border-color:#444}.jj-ending-badge{margin-bottom:8px;font-size:14px;font-weight:600}.jj-ending-modal.gold .jj-ending-badge{color:gold}.jj-ending-modal.silver .jj-ending-badge{color:silver}.jj-ending-modal.bronze .jj-ending-badge{color:#cd7f32}.jj-ending-modal.black .jj-ending-badge{color:#888}.jj-ending-title{color:var(--text-primary);margin:0 0 12px;font-size:24px;font-weight:700}.jj-ending-modal.gold .jj-ending-title{color:gold}.jj-ending-modal.black .jj-ending-title{color:#ef4444}.jj-ending-desc{color:var(--text-muted);margin:0 0 24px;font-size:14px;line-height:1.7}.jj-ending-stats{background:#0003;border-radius:12px;justify-content:center;gap:24px;margin-bottom:24px;padding:16px;display:flex}.jj-ending-stat{flex-direction:column;align-items:center;gap:4px;display:flex}.jj-ending-stat-icon{font-size:18px}.jj-ending-stat-label{color:var(--text-muted);font-size:10px}.jj-ending-stat-value{color:var(--text-primary);font-size:18px;font-weight:700}.jj-ending-actions{justify-content:center;gap:12px;display:flex}.jj-ending-btn{cursor:pointer;border-radius:20px;align-items:center;gap:6px;padding:12px 24px;font-size:13px;font-weight:600;transition:all .2s;display:inline-flex}.jj-ending-btn.primary{background:linear-gradient(135deg,var(--primary)0%,var(--primary-dark)100%);color:var(--bg-primary);border:none}.jj-ending-btn.primary:hover{transform:translateY(-2px);box-shadow:0 4px 16px #fbbf2466}.jj-ending-btn.secondary{border:1px solid var(--border);color:var(--text-muted);background:0 0}.jj-ending-btn.secondary:hover{border-color:var(--text-muted)}.jj-notification{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);z-index:200;border-radius:100px;align-items:center;gap:8px;padding:12px 20px;font-size:13px;display:flex;position:fixed;top:20px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #0000004d}.jj-notification.success{color:#22c55e;border-color:#22c55e}.jj-notification.error{color:#ef4444;border-color:#ef4444}.jj-notification.warning{color:#f59e0b;border-color:#f59e0b}.jj-mobile-header{background:var(--bg-card);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.jj-mobile-stats{color:var(--text-muted);gap:12px;font-size:12px;display:flex}.jj-mobile-stats span{align-items:center;gap:4px;display:flex}.jj-mobile-input-bar{background:var(--bg-card);border-top:1px solid var(--border);gap:8px;padding:12px 16px;display:flex}.jj-mobile-input{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);border-radius:20px;outline:none;flex:1;padding:10px 14px;font-size:14px}.jj-mobile-input::placeholder{color:var(--text-muted)}.jj-mobile-send{background:linear-gradient(135deg,var(--primary)0%,var(--primary-dark)100%);width:40px;height:40px;color:var(--bg-primary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:16px;display:flex}.jj-mobile-send:disabled{opacity:.5}.jj-mobile-nav{background:var(--bg-card);border-top:1px solid var(--border);justify-content:space-around;padding:8px 0;display:flex}.jj-mobile-nav-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:2px;padding:6px 12px;font-size:10px;display:flex}.jj-mobile-nav-btn.active{color:var(--primary)}.jj-mobile-nav-btn span:first-child{font-size:20px}.jj-drawer{z-index:50;background:var(--bg-primary);flex-direction:column;display:flex;position:fixed;inset:0}.jj-drawer-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px;display:flex}.jj-drawer-title{color:var(--text-primary);font-size:16px;font-weight:600}.jj-drawer-close{width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;font-size:20px;display:flex}.jj-drawer-content{flex:1;padding:16px;overflow-y:auto}.jj-highlight-btn{cursor:pointer;background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:16px;justify-content:center;align-items:center;width:40px;height:32px;font-size:16px;transition:all .2s;display:flex;position:relative;box-shadow:0 2px 8px #ef44444d}.jj-highlight-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #ef444466}.jj-highlight-btn:disabled{opacity:.5;cursor:not-allowed}.jj-highlight-badge{color:#ef4444;background:#fff;border-radius:100px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-6px;right:-6px}.jj-highlight-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;flex-direction:column;width:94%;max-width:480px;max-height:90vh;margin:0 auto;display:flex;overflow:hidden}.jj-highlight-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.jj-highlight-header h2{color:var(--text-primary);margin:0;font-size:18px;font-weight:600}.jj-highlight-close{width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;font-size:24px;transition:all .15s;display:flex}.jj-highlight-close:hover{color:var(--text-primary);background:#fbbf241a}.jj-highlight-steps{border-bottom:1px solid var(--border);color:var(--text-muted);justify-content:center;gap:24px;padding:12px;font-size:12px;display:flex}.jj-highlight-steps span.active{color:var(--primary);font-weight:600}.jj-highlight-content{flex:1;padding:20px;overflow-y:auto}.jj-highlight-loading{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;display:flex}.jj-highlight-spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;margin-bottom:16px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.jj-highlight-tip{color:var(--text-secondary);margin-bottom:12px;font-size:13px}.jj-highlight-list{flex-direction:column;gap:12px;display:flex}.jj-highlight-card{cursor:pointer;background:#fbbf240d;border:2px solid #0000;border-radius:12px;padding:14px;transition:all .15s}.jj-highlight-card:hover{background:#fbbf2414}.jj-highlight-card.selected{border-color:var(--primary);background:#fbbf241a}.jj-highlight-card-header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.jj-highlight-card-title{color:var(--text-primary);font-size:14px;font-weight:600}.jj-highlight-card-summary{color:var(--text-muted);margin:0 0 10px;font-size:12px;line-height:1.5}.jj-highlight-card-score{color:var(--text-muted);align-items:center;gap:8px;font-size:11px;display:flex}.jj-highlight-score-bar{background:var(--bg-secondary);border-radius:2px;flex:1;height:4px;overflow:hidden}.jj-highlight-score-bar>div{border-radius:2px;height:100%;transition:width .3s}.jj-highlight-type-btns{gap:8px;display:flex}.jj-highlight-type-btns button{color:var(--text-secondary);cursor:pointer;background:#fbbf240d;border:2px solid #0000;border-radius:10px;flex:1;padding:12px;font-size:14px;transition:all .15s}.jj-highlight-type-btns button:hover{background:#fbbf241a}.jj-highlight-type-btns button.active{border-color:var(--primary);color:var(--text-primary);background:#fbbf2426}.jj-highlight-style-grid{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.jj-highlight-style-card{cursor:pointer;background:#fbbf240d;border:2px solid #0000;border-radius:10px;padding:12px;transition:all .15s}.jj-highlight-style-card:hover{background:#fbbf2414}.jj-highlight-style-card.selected{border-color:var(--primary);background:#fbbf241a}.jj-highlight-style-label{color:var(--text-primary);margin-bottom:4px;font-size:13px;font-weight:600;display:block}.jj-highlight-style-desc{color:var(--text-muted);font-size:11px;line-height:1.4;display:block}.jj-highlight-result{text-align:center}.jj-highlight-error{color:#ef4444;padding:24px}.jj-highlight-error span{margin-bottom:12px;font-size:32px;display:block}.jj-highlight-error button{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:#fbbf241a;border-radius:8px;margin-top:16px;padding:10px 24px}.jj-highlight-success{flex-direction:column;align-items:center;display:flex}.jj-highlight-image,.jj-highlight-video{border-radius:12px;max-width:100%;max-height:300px;margin-bottom:16px}.jj-highlight-download{border:1px solid var(--border);color:var(--text-secondary);background:#fbbf241a;border-radius:8px;padding:10px 20px;font-size:13px;text-decoration:none;transition:all .15s;display:inline-block}.jj-highlight-download:hover{color:var(--text-primary);background:#fbbf2433}.jj-highlight-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:12px;padding:16px 20px;display:flex}.jj-highlight-btn{cursor:pointer;border-radius:10px;padding:12px 24px;font-size:13px;font-weight:600;transition:all .15s}.jj-highlight-btn.primary{background:linear-gradient(135deg,var(--primary)0%,var(--primary-dark)100%);color:var(--bg-primary);border:none}.jj-highlight-btn.primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #fbbf244d}.jj-highlight-btn.primary:disabled{opacity:.5;cursor:not-allowed}.jj-highlight-btn.secondary{border:1px solid var(--border);color:var(--text-muted);background:0 0}.jj-highlight-btn.secondary:hover{color:var(--text-secondary);background:#fbbf240d}@media(max-width:640px){.jj-highlight-modal{border-radius:0;width:100%;max-height:100vh;position:fixed;inset:0}.jj-highlight-header{padding:12px 16px}.jj-highlight-header h2{font-size:16px}.jj-highlight-steps{gap:16px;padding:10px;font-size:11px}.jj-highlight-content{padding:16px}.jj-highlight-card{padding:12px}.jj-highlight-card-title{font-size:13px}.jj-highlight-card-summary{font-size:11px}.jj-highlight-style-grid{grid-template-columns:1fr;gap:6px}.jj-highlight-style-card{padding:10px 12px}.jj-highlight-style-label{font-size:12px}.jj-highlight-style-desc{font-size:10px}.jj-highlight-type-btns{gap:6px}.jj-highlight-type-btns button{padding:10px;font-size:13px}.jj-highlight-footer{gap:8px;padding:12px 16px}.jj-highlight-btn{padding:10px 16px;font-size:12px}.jj-highlight-image,.jj-highlight-video{max-height:200px}.jj-highlight-error p{word-break:break-all;font-size:12px}}@media(max-width:900px){.jj-main{flex-direction:column}.jj-left{flex-direction:row;width:100%;overflow-x:auto}.jj-right{display:none}}@media(max-width:640px){.jj-header{padding:6px 12px}.jj-header-title{display:none}.jj-start-content{padding:20px 14px}.jj-start-title{letter-spacing:4px;font-size:36px}.jj-start-cards{gap:8px}.jj-start-card{max-width:120px}.jj-start-card-body{padding:8px}.jj-start-card-name{font-size:13px}.jj-start-card-quote{font-size:10px}}@media(max-width:390px){.jj-start-content{padding:16px 12px}.jj-start-badge{letter-spacing:2px;margin-bottom:16px;padding:4px 12px;font-size:9px}.jj-start-title{letter-spacing:3px;font-size:30px}.jj-start-tagline{letter-spacing:3px;margin-bottom:20px;font-size:10px}.jj-start-cards{gap:6px;margin-bottom:24px}.jj-start-card{max-width:105px}.jj-start-card-body{padding:6px}.jj-start-card-name{font-size:12px}.jj-start-card-role{font-size:8px}.jj-start-card-quote{font-size:9px}.jj-start-card-threat{margin-bottom:4px}.jj-start-btn{padding:12px 32px;font-size:14px}.jj-header{min-height:40px;padding:4px 10px}.jj-header-logo{font-size:16px}.jj-header-menu{padding:6px 10px;font-size:12px}.jj-mobile-header{padding:8px 12px}.jj-mobile-stats{gap:8px;font-size:10px}.jj-mobile-input-bar{gap:6px;padding:10px 12px}.jj-mobile-input{padding:8px 12px;font-size:13px}.jj-mobile-send{width:36px;height:36px;font-size:14px}.jj-mobile-nav{padding:6px 0}.jj-mobile-nav-btn{padding:4px 8px;font-size:9px}.jj-mobile-nav-btn span:first-child{font-size:18px}.jj-story-paragraph{padding:12px 14px;font-size:13px;line-height:1.8}.jj-player-bubble{padding:10px 12px;font-size:13px}.jj-letter-card{padding:20px 16px 16px}.jj-letter-title{font-size:16px}.jj-letter-body{font-size:12px;line-height:1.7}.jj-letter-goal{font-size:11px}.jj-modal{max-width:calc(100vw - 32px);padding:20px 16px}.jj-modal-title{font-size:14px}.jj-modal-btn{padding:10px 14px;font-size:12px}.jj-ending-modal{padding:24px 16px}.jj-ending-badge{font-size:12px}.jj-ending-title{font-size:20px}.jj-ending-desc{font-size:12px}.jj-ending-stats{gap:16px;padding:12px}.jj-ending-stat-icon,.jj-ending-stat-value{font-size:16px}.jj-ending-btn{padding:10px 18px;font-size:12px}}.jj-cutscene{z-index:9999;background:#000;position:fixed;inset:0}.jj-cutscene-bg{z-index:0;position:absolute;inset:0}.jj-cutscene-bg img{object-fit:cover;opacity:.15;filter:blur(6px)saturate(.5);width:100%;height:100%}.jj-cutscene-video-wrap{z-index:10;background:#000;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.jj-cutscene-video{object-fit:cover;width:100%;height:100%}.jj-cutscene-skip{color:#ffffffb3;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10;background:#00000080;border:1px solid #fff3;border-radius:20px;padding:8px 20px;font-size:13px;transition:all .2s;position:absolute;top:20px;right:20px}.jj-cutscene-skip:hover{color:#fff;background:#000000b3}.jj-cutscene-text-layer{z-index:5;background:linear-gradient(#0a0806eb,#14110de0,#0a0806f2);flex-direction:column;display:flex;position:absolute;inset:0}.jj-cutscene-text-content{flex-direction:column;flex:1;justify-content:center;gap:0;width:100%;max-width:640px;margin:0 auto;padding:60px 40px;display:flex;overflow-y:auto}.jj-cutscene-line-row{-webkit-backdrop-filter:blur(12px);background:#14110dbf;border:1px solid #fbbf2414;border-radius:12px;align-items:flex-start;gap:14px;margin-bottom:16px;padding:14px 18px;display:flex}.jj-cutscene-line-row.last-line{background:#fbbf241f;border-color:#fbbf2440}.jj-cutscene-line-row.last-line .jj-cutscene-line{color:var(--primary);font-weight:500}.jj-cutscene-npc-avatar{border:2px solid #fbbf2466;border-radius:50%;flex-shrink:0;width:48px;height:48px;margin-top:2px;overflow:hidden;box-shadow:0 2px 12px #00000080}.jj-cutscene-npc-avatar video{object-fit:cover;width:100%;height:100%}.jj-cutscene-line{color:#ffffffd9;letter-spacing:.3px;margin:0;font-size:16px;line-height:1.8}.jj-cutscene-footer{justify-content:center;padding:24px 40px 40px;display:flex}.jj-cutscene-enter{background:linear-gradient(135deg,var(--primary)0%,var(--primary-dark)100%);color:var(--bg-primary);cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:10px;padding:16px 48px;font-size:17px;font-weight:600;transition:transform .15s,box-shadow .15s;display:flex}.jj-cutscene-enter:hover{transform:translateY(-2px);box-shadow:0 6px 24px #fbbf244d}.jj-cutscene-enter:active{transform:translateY(0)}@media(max-width:767px){.jj-cutscene-text-content{padding:40px 20px}.jj-cutscene-line{font-size:15px}.jj-cutscene-line-row{gap:10px;margin-bottom:16px}.jj-cutscene-npc-avatar{width:40px;height:40px}.jj-cutscene-footer{padding:20px 24px 36px}.jj-cutscene-enter{width:100%;padding:14px 0;font-size:16px}.jj-cutscene-skip{font-size:12px;top:16px;right:16px}}.jj-tutorial-modal{background:linear-gradient(#2a2318,#1a1510);border:1px solid #fbbf244d;border-radius:16px;width:90%;max-width:400px;position:relative;overflow:hidden;box-shadow:0 20px 60px #0009}.jj-tutorial-header{text-align:center;padding:28px 24px 0}.jj-tutorial-header h2{color:var(--primary);letter-spacing:1px;margin:0;font-size:18px;font-weight:700}.jj-tutorial-content{flex-direction:column;gap:16px;padding:24px;display:flex}.jj-tutorial-rule{background:#fbbf240a;border:1px solid #fbbf241a;border-radius:10px;align-items:flex-start;gap:14px;padding:14px;display:flex}.jj-tutorial-rule-icon{flex-shrink:0;margin-top:2px;font-size:24px;line-height:1}.jj-tutorial-rule strong{color:var(--text-primary);letter-spacing:1px;margin-bottom:4px;font-size:15px;display:block}.jj-tutorial-rule p{color:#fef3c78c;margin:0;font-size:13px;line-height:1.5}.jj-tutorial-footer{padding:8px 24px 24px}.jj-tutorial-btn{letter-spacing:3px;color:#14110d;cursor:pointer;background:linear-gradient(135deg,#fbbf24,#d4a017);border:none;border-radius:8px;width:100%;padding:14px 0;font-size:16px;font-weight:700;transition:transform .15s,box-shadow .15s;display:block;box-shadow:0 4px 24px #fbbf2459}.jj-tutorial-btn:hover{transform:translateY(-1px);box-shadow:0 6px 28px #fbbf2473}.jj-tutorial-btn:active{transform:translateY(0)}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}
