:root{--noir-black: #0d0d0d;--noir-dark: #1a1a2e;--noir-surface: #16213e;--noir-border: #2a2a4e;--noir-accent: #e94560;--noir-gold: #d4af37;--noir-paper: #e6e6e6;--noir-muted: #6b6b8d}.arcana-game,.arcana-menu,.arcana-tarot-reveal,.arcana-case-report,.arcana-upgrade,.arcana-error{font-family:Georgia,Times New Roman,serif;background:var(--noir-black);color:var(--noir-paper);min-height:100vh;min-height:100dvh}.arcana-menu{display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,var(--noir-black) 0%,var(--noir-dark) 50%,var(--noir-surface) 100%)}.menu-content{text-align:center;max-width:500px}.menu-title{margin-bottom:1rem}.menu-title .title-small{display:block;font-size:1rem;letter-spacing:.5em;color:var(--noir-gold);font-weight:300;text-transform:uppercase}.menu-title .title-large{display:block;font-size:3rem;font-weight:700;background:linear-gradient(135deg,#fff,#aaa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.menu-tagline{font-style:italic;color:var(--noir-muted);margin-bottom:3rem}.menu-actions{display:flex;flex-direction:column;gap:1rem;margin-bottom:3rem}.menu-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 2rem;font-size:1rem;font-weight:600;border-radius:4px;cursor:pointer;transition:all .3s ease}.menu-btn.primary{background:linear-gradient(135deg,var(--noir-accent) 0%,#c23a52 100%);color:#fff;border:none;box-shadow:0 4px 20px #e945604d}.menu-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 30px #e9456066}.menu-btn.secondary{background:transparent;color:var(--noir-paper);border:1px solid var(--noir-border)}.menu-btn.secondary:hover{border-color:var(--noir-gold);color:var(--noir-gold)}.menu-case-info{padding:1.5rem;background:#ffffff08;border:1px solid var(--noir-border);border-radius:4px}.case-badge{display:inline-block;padding:.25rem .5rem;background:var(--noir-gold);color:var(--noir-black);font-size:.625rem;font-weight:700;letter-spacing:.05em;border-radius:2px;margin-bottom:.5rem}.menu-case-info h3{font-size:1.25rem;color:#fff;margin-bottom:.5rem}.menu-case-info p{font-size:.875rem;color:var(--noir-muted);font-style:italic}.arcana-game{display:flex;flex-direction:column;height:100vh;height:100dvh}@media(min-width:768px){.arcana-game{flex-direction:row}}@media(max-width:767px){.arcana-game{height:auto;min-height:100vh;min-height:100dvh}}.narrative-panel{flex:1;display:flex;flex-direction:column;background:var(--noir-dark);border-right:1px solid var(--noir-border);min-width:0;min-height:0}@media(max-width:767px){.narrative-panel{flex:none;max-height:50vh;max-height:50dvh;border-right:none;border-bottom:1px solid var(--noir-border);overflow:hidden}}.game-header{height:4rem;display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;background:#0000004d;border-bottom:1px solid var(--noir-border);flex-shrink:0}@media(max-width:767px){.game-header{height:3rem;padding:0 1rem}.header-title{font-size:1rem}}.header-title{font-size:1.25rem;letter-spacing:.1em;font-weight:400}.header-title .accent{color:var(--noir-accent)}.audio-controls{display:flex;align-items:center;gap:.5rem}.mute-btn{width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--noir-border);border-radius:50%;color:var(--noir-gold);cursor:pointer;transition:all .3s ease}.mute-btn.muted{color:var(--noir-muted)}.mute-btn:hover{border-color:var(--noir-gold)}.audio-indicator{color:var(--noir-gold);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.case-header-display{padding:1.5rem 1.5rem 1rem;border-bottom:2px solid rgba(212,175,55,.3);background:linear-gradient(180deg,rgba(212,175,55,.05) 0%,transparent 100%);flex-shrink:0}@media(max-width:767px){.case-header-display{padding:.75rem 1rem}.case-header-display .case-title{font-size:1.1rem}.case-header-display .case-tagline{font-size:.85rem;margin-bottom:.5rem}}.case-header-display .case-number{font-size:.75rem;color:#d4af37b3;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem;font-family:Courier New,monospace}.case-header-display .case-title{font-size:1.5rem;font-weight:600;color:var(--noir-paper);margin:0 0 .5rem;line-height:1.2;font-family:Courier New,monospace}.case-header-display .case-tagline{font-size:.95rem;color:#e8e6e3cc;font-style:italic;margin:0 0 1rem;line-height:1.5}.case-header-display .volume-badge{display:inline-block;font-size:.7rem;padding:.25rem .75rem;background:#d4af3726;border:1px solid rgba(212,175,55,.4);color:#d4af37;border-radius:2px;text-transform:uppercase;letter-spacing:.05em;font-family:Courier New,monospace}.narrative-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:2rem;scroll-behavior:smooth;min-height:0}@media(max-width:767px){.narrative-content{padding:1rem;flex:1;overflow-y:scroll}}.message{margin-bottom:2rem;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{display:flex;justify-content:flex-end}.user-action{display:inline-block;max-width:80%;padding:.75rem 1rem;background:var(--noir-surface);border-left:2px solid var(--noir-accent);font-family:monospace;font-size:.875rem;font-style:italic}.narrative-text{max-width:65ch;line-height:1.8}.narrative-text p{margin-bottom:1.5rem;font-size:1.125rem}.narrative-text strong{color:var(--noir-accent);font-weight:600}.narrative-text em{color:var(--noir-muted)}.narrative-text h2,.narrative-header{font-size:1.5rem;color:var(--noir-gold);margin:2rem 0 1rem;letter-spacing:.1em;border-bottom:1px solid var(--noir-border);padding-bottom:.5rem}.narrative-text blockquote{border-left:3px solid var(--noir-border);padding-left:1rem;margin:1.5rem 0;font-style:italic;color:var(--noir-muted)}.loading-indicator{text-align:center;padding:2rem;color:var(--noir-accent);font-family:monospace;font-size:.75rem;letter-spacing:.2em;text-transform:uppercase}.loading-indicator .loading-text{display:inline-block;animation:textFade 2s ease-in-out infinite}@keyframes textFade{0%,to{opacity:1}45%,55%{opacity:0}}.actions-panel{width:100%;display:flex;flex-direction:column;background:var(--noir-black);border-top:1px solid var(--noir-border)}@media(min-width:768px){.actions-panel{width:400px;flex-shrink:0;border-top:none}}@media(max-width:767px){.actions-panel{flex:1;min-height:45vh;min-height:45dvh;overflow-y:auto;-webkit-overflow-scrolling:touch}}.actions-header{height:4rem;display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;border-bottom:1px solid var(--noir-border);font-family:monospace;font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--noir-muted);flex-shrink:0}@media(max-width:767px){.actions-header{height:2.5rem;padding:0 1rem;font-size:.7rem}}.loading-dot{width:8px;height:8px;background:var(--noir-accent);border-radius:50%;animation:pulse 1s infinite}.actions-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:1.5rem;background:linear-gradient(to bottom,var(--noir-black),var(--noir-dark));min-height:0}@media(max-width:767px){.actions-content{padding:1rem 1rem 2rem}}.actions-loading{display:flex;align-items:center;justify-content:center;height:200px}.spinner{width:40px;height:40px;border:2px solid var(--noir-border);border-top-color:var(--noir-accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.choices-list{display:flex;flex-direction:column;gap:1rem}.choice-btn{display:flex;align-items:flex-start;gap:1rem;width:100%;padding:1rem;background:linear-gradient(to right,var(--noir-dark),transparent);border:1px solid var(--noir-border);border-radius:4px;text-align:left;cursor:pointer;transition:all .3s ease}.choice-btn:hover{border-color:#d4af3780;transform:translate(4px);box-shadow:0 0 20px #d4af371a}.choice-btn:hover:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--noir-gold)}.choice-icon{flex-shrink:0;width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;background:var(--noir-black);border:1px solid var(--noir-border);border-radius:4px;font-size:1.5rem;transition:all .3s ease}.choice-btn:hover .choice-icon{border-color:#d4af374d;transform:scale(1.1)}.choice-text{flex:1;min-width:0}.choice-text h4{font-size:1rem;font-weight:600;color:var(--noir-paper);margin-bottom:.25rem;transition:color .3s ease}.choice-btn:hover .choice-text h4{color:var(--noir-gold)}.choice-text p{font-family:monospace;font-size:.75rem;color:var(--noir-muted);border-top:1px solid rgba(255,255,255,.05);padding-top:.5rem;margin-top:.5rem}.manual-input-form{padding:1rem;margin-top:1rem;border:1px dashed var(--noir-border);border-radius:4px;background:#ffffff05}.choices-list+.manual-input-form{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid var(--noir-border);border-top-style:dashed}.manual-input-form label{display:block;font-family:monospace;font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--noir-muted);margin-bottom:.75rem}.manual-input-form textarea{width:100%;padding:.75rem;background:var(--noir-black);border:1px solid var(--noir-border);border-radius:4px;color:var(--noir-paper);font-family:monospace;font-size:.875rem;resize:none;margin-bottom:.75rem}.manual-input-form textarea:focus{outline:none;border-color:var(--noir-accent)}.manual-input-form textarea::placeholder{color:var(--noir-muted)}.submit-btn{width:100%;padding:.75rem;background:var(--noir-dark);border:1px solid var(--noir-border);border-radius:4px;color:var(--noir-gold);font-family:monospace;font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;cursor:pointer;transition:all .3s ease}.submit-btn:hover{background:var(--noir-surface);border-color:var(--noir-gold)}.cancel-btn{width:100%;padding:.5rem;background:transparent;border:none;color:var(--noir-muted);font-size:.75rem;cursor:pointer;margin-top:.5rem}.cancel-btn:hover{color:var(--noir-paper)}.actions-footer{padding:1rem 1.5rem;border-top:1px solid var(--noir-border);background:#0000004d}.solve-btn{width:100%;padding:.875rem;background:#e945601a;border:1px solid rgba(233,69,96,.4);border-radius:4px;color:var(--noir-accent);font-family:monospace;font-size:.75rem;text-transform:uppercase;letter-spacing:.2em;cursor:pointer;transition:all .3s ease;box-shadow:0 0 10px #e945601a}.solve-btn:hover{background:var(--noir-accent);color:var(--noir-black);box-shadow:0 0 20px #e9456066}.footer-info{display:flex;justify-content:space-between;margin-top:.75rem;font-family:monospace;font-size:.625rem;color:var(--noir-muted)}.arcana-tarot-reveal{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:#000000f2}.tarot-title{font-size:1.5rem;color:var(--noir-gold);letter-spacing:.2em;margin-bottom:3rem;animation:fadeIn 1s ease}.tarot-cards{display:flex;flex-wrap:wrap;justify-content:center;gap:2rem;margin-bottom:3rem}.tarot-card{width:180px;height:280px;background:linear-gradient(135deg,#f5f5f0,#e8e6e3);border-radius:8px;border:3px solid var(--noir-gold);display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:1rem;color:var(--noir-black);box-shadow:0 10px 30px #000000b3,0 0 20px #d4af374d;animation:cardReveal .8s ease forwards;opacity:0;position:relative}@keyframes cardReveal{0%{opacity:0;transform:rotateY(180deg) scale(.8)}to{opacity:1;transform:rotateY(0) scale(1)}}.tarot-card.reversed{transform:rotate(180deg)}.tarot-card:before{content:"";position:absolute;inset:8px;border:1px solid rgba(212,175,55,.3);border-radius:4px;pointer-events:none}.card-top{font-family:monospace;font-size:.625rem;text-transform:uppercase;letter-spacing:.1em;color:var(--noir-gold);font-weight:600}.card-center{text-align:center}.card-symbol{width:80px;height:80px;border:3px solid var(--noir-gold);background:#d4af371a;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:2.5rem;box-shadow:0 2px 10px #0003}.card-center h3{font-size:1rem;font-weight:700}.card-bottom{font-family:monospace;font-size:.625rem;text-transform:uppercase;letter-spacing:.05em;border-top:1px solid rgba(212,175,55,.4);padding-top:.5rem;width:100%;text-align:center;color:var(--noir-gold);font-weight:600}.interpret-btn{padding:1rem 2rem;background:transparent;border:1px solid var(--noir-gold);color:var(--noir-gold);font-family:monospace;font-size:.875rem;letter-spacing:.1em;cursor:pointer;transition:all .3s ease;animation:pulse 2s infinite}.interpret-btn:hover{background:var(--noir-gold);color:var(--noir-black)}.arcana-case-report{display:flex;flex-direction:column;align-items:center;padding:4rem 2rem;text-align:center;max-width:800px;margin:0 auto}.report-title{font-size:2rem;letter-spacing:.3em;color:var(--noir-gold);margin-bottom:2rem;border-bottom:1px solid var(--noir-border);padding-bottom:1rem}.outcome-badge{padding:.5rem 1.5rem;font-size:1.5rem;font-weight:700;letter-spacing:.2em;border-radius:4px;margin-bottom:2rem}.outcome-badge.solved{background:#22c55e33;border:1px solid rgba(34,197,94,.5);color:#22c55e}.outcome-badge.failed{background:#ef444433;border:1px solid rgba(239,68,68,.5);color:#ef4444}.final-narrative{font-size:1.125rem;line-height:1.8;color:var(--noir-paper);margin-bottom:3rem;text-align:left;max-width:65ch}.restart-btn{padding:1rem 2rem;background:var(--noir-accent);border:none;border-radius:4px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.restart-btn:hover{transform:translateY(-2px);box-shadow:0 4px 20px #e9456066}.accusation-modal{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;padding:2rem;z-index:100}.modal-content{background:var(--noir-dark);border:1px solid var(--noir-border);border-radius:8px;padding:2rem;max-width:500px;width:100%;text-align:center}.modal-content h2{font-size:1.5rem;color:var(--noir-gold);margin-bottom:.5rem}.modal-content>p{color:var(--noir-muted);margin-bottom:2rem}.suspects-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}.suspect-btn{display:block;width:100%;padding:1rem;background:var(--noir-surface);border:1px solid var(--noir-border);border-radius:4px;text-align:left;cursor:pointer;transition:all .3s ease}.suspect-btn:hover{border-color:var(--noir-accent)}.suspect-btn.selected{border-color:var(--noir-accent);background:#e945601a}.suspect-btn h4{font-size:1rem;color:var(--noir-paper);margin-bottom:.25rem}.suspect-btn p{font-size:.75rem;color:var(--noir-muted)}.modal-actions{display:flex;gap:1rem}.confirm-btn{flex:1;padding:.875rem;background:var(--noir-accent);border:none;border-radius:4px;color:#fff;font-weight:600;cursor:pointer;transition:all .3s ease}.confirm-btn:disabled{opacity:.5;cursor:not-allowed}.confirm-btn:not(:disabled):hover{background:#c23a52}.modal-actions .cancel-btn{flex:1;padding:.875rem;background:transparent;border:1px solid var(--noir-border);border-radius:4px;color:var(--noir-paper);cursor:pointer;transition:all .3s ease}.modal-actions .cancel-btn:hover{border-color:var(--noir-paper)}.arcana-error,.arcana-upgrade{display:flex;align-items:center;justify-content:center;padding:2rem}.error-content,.upgrade-content{text-align:center;max-width:400px}.error-icon{font-size:3rem;display:block;margin-bottom:1rem}.error-content h2,.upgrade-content h2{font-size:1.5rem;color:var(--noir-accent);margin-bottom:1rem}.error-content p,.upgrade-content p{color:var(--noir-muted);margin-bottom:2rem}.retry-btn,.upgrade-btn{display:inline-block;padding:.875rem 2rem;background:var(--noir-accent);border:none;border-radius:4px;color:#fff;font-weight:600;cursor:pointer;text-decoration:none;transition:all .3s ease}.retry-btn:hover,.upgrade-btn:hover{background:#c23a52}.dismiss-btn{display:block;margin-top:1rem;background:transparent;border:none;color:var(--noir-muted);cursor:pointer}.dismiss-btn:hover{color:var(--noir-paper)}.upgrade-icon{font-size:4rem;display:block;margin-bottom:1.5rem}.upgrade-content h2{color:var(--noir-gold)}.upgrade-price{margin-bottom:2rem}.upgrade-price .price{font-size:2.5rem;font-weight:700;color:var(--noir-gold)}.upgrade-price .price-note{display:block;font-size:.875rem;color:var(--noir-muted);margin-top:.25rem}.model-selector{position:relative;margin-bottom:2rem}.model-toggle{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#ffffff0d;border:1px solid var(--noir-border);border-radius:4px;cursor:pointer;transition:all .3s ease;margin:0 auto}.model-toggle:hover{border-color:var(--noir-gold)}.model-label{font-size:.75rem;color:var(--noir-muted);text-transform:uppercase;letter-spacing:.05em}.model-name{color:var(--noir-gold);font-weight:500}.toggle-icon{font-size:.625rem;color:var(--noir-muted)}.model-dropdown{position:absolute;top:100%;left:50%;transform:translate(-50%);width:280px;margin-top:.5rem;background:var(--noir-dark);border:1px solid var(--noir-border);border-radius:4px;overflow:hidden;z-index:10;animation:fadeIn .2s ease}.model-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:1rem;background:transparent;border:none;border-bottom:1px solid var(--noir-border);cursor:pointer;text-align:left;transition:all .3s ease}.model-option:last-child{border-bottom:none}.model-option:hover:not(.locked){background:#ffffff0d}.model-option.selected{background:#d4af371a}.model-option.locked{opacity:.5;cursor:not-allowed}.model-info{display:flex;flex-direction:column;gap:.25rem}.model-option-name{color:var(--noir-paper);font-weight:500}.model-desc{font-size:.75rem;color:var(--noir-muted)}.lock-icon,.check-icon{font-size:.875rem}.check-icon{color:var(--noir-gold)}.access-badge{margin-bottom:1.5rem}.access-badge .full-access{display:inline-block;padding:.25rem .75rem;background:#d4af3733;border:1px solid var(--noir-gold);color:var(--noir-gold);font-size:.75rem;font-weight:600;border-radius:4px;text-transform:uppercase;letter-spacing:.05em}.access-badge .free-access{display:inline-block;padding:.25rem .75rem;background:#ffffff0d;border:1px solid var(--noir-border);color:var(--noir-muted);font-size:.75rem;font-weight:500;border-radius:4px;text-transform:uppercase;letter-spacing:.05em}.menu-upgrade{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--noir-border)}.menu-upgrade p{font-size:.875rem;color:var(--noir-muted);margin-bottom:1rem}.upgrade-link{display:inline-block;padding:.75rem 1.5rem;background:transparent;border:1px solid var(--noir-gold);color:var(--noir-gold);font-size:.875rem;font-weight:500;border-radius:4px;cursor:pointer;transition:all .3s ease}.upgrade-link:hover{background:var(--noir-gold);color:var(--noir-black)}.header-controls{display:flex;align-items:center;gap:1rem}.save-indicator{font-size:.75rem;color:var(--noir-muted);animation:pulse 1s infinite}@media(max-width:767px){.arcana-game.is-mobile{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden}.arcana-game.is-mobile .narrative-panel{flex:1;max-height:none;min-height:0;display:flex;flex-direction:column}.arcana-game.is-mobile .narrative-content{flex:1;min-height:0;overflow-y:auto}.arcana-game.is-mobile .game-header{transition:height .3s ease,padding .3s ease}.arcana-game.is-mobile .game-header.collapsed{height:2.5rem;padding:0 .75rem}.arcana-game.is-mobile .game-header.collapsed .header-title{font-size:.9rem}.arcana-game.is-mobile .game-header.collapsed .mute-btn{width:2rem;height:2rem}.arcana-game.is-mobile .case-header-display{transition:padding .3s ease,max-height .3s ease;overflow:hidden}.arcana-game.is-mobile .case-header-display.collapsed{padding:.5rem 1rem;max-height:2rem}.case-mini{display:flex;align-items:center}.case-mini-title{font-size:.75rem;font-weight:600;color:var(--noir-gold);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:Courier New,monospace}}.mobile-actions-drawer{position:fixed;bottom:0;left:0;right:0;background-color:#0d0d0d!important;border-top:2px solid var(--noir-gold);z-index:100;transition:max-height .3s ease,transform .3s ease;max-height:3.5rem;overflow:hidden;box-shadow:0 -4px 20px #000c;isolation:isolate;-webkit-backdrop-filter:none;backdrop-filter:none}.mobile-actions-drawer.expanded{max-height:70vh;max-height:70dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;background-color:#0d0d0d!important}.mobile-actions-drawer:before{content:"";position:absolute;inset:0;background-color:#0d0d0d;z-index:-1}.drawer-handle{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;padding:.75rem 1rem;background-color:#1a1a2e!important;border:none;cursor:pointer;gap:.25rem;position:relative;z-index:2}.handle-bar{width:40px;height:4px;background:var(--noir-gold);border-radius:2px;opacity:.6}.handle-text{font-size:.8rem;color:var(--noir-paper);text-transform:uppercase;letter-spacing:.1em;font-weight:500}.handle-arrow{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:var(--noir-gold);font-size:.75rem}.drawer-content{padding:.75rem .75rem 2rem;background-color:#0d0d0d!important;position:relative;z-index:1}.mobile-special-actions{display:flex;gap:.5rem;margin-bottom:.75rem;padding:.5rem;background-color:#0d0d0d!important;position:relative;z-index:1}.mobile-special-btn{flex:1;padding:.75rem;border-radius:4px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.mobile-special-btn.tarot{background-color:#2a2a1a!important;border:1px solid var(--noir-gold);color:var(--noir-gold)}.mobile-special-btn.tarot:hover:not(:disabled),.mobile-special-btn.tarot:active:not(:disabled){background-color:#3a3a2a!important;border-color:var(--noir-gold)}.mobile-special-btn.solve{background-color:#2a1a1e!important;border:1px solid var(--noir-accent);color:var(--noir-accent)}.mobile-special-btn.solve:hover,.mobile-special-btn.solve:active{background-color:#3a2a2e!important;border-color:var(--noir-accent)}.mobile-special-btn:disabled{opacity:.5;cursor:not-allowed}.drawer-divider{display:flex;align-items:center;margin:.75rem 0;gap:.75rem}.drawer-divider:before,.drawer-divider:after{content:"";flex:1;height:1px;background:var(--noir-border)}.drawer-divider span{font-size:.65rem;color:var(--noir-muted);text-transform:uppercase;letter-spacing:.1em;white-space:nowrap}.choices-list.compact{display:flex;flex-direction:column;gap:.5rem}.choice-btn-compact{display:flex;align-items:center;gap:.75rem;width:100%;padding:.6rem .75rem;background:#1a1a2e;border:1px solid var(--noir-border);border-radius:4px;text-align:left;cursor:pointer;transition:all .2s ease}.choice-btn-compact:hover,.choice-btn-compact:active{border-color:var(--noir-gold);background:#16213e}.choice-icon-sm{flex-shrink:0;width:1.75rem;height:1.75rem;display:flex;align-items:center;justify-content:center;background:#0d0d0d;border:1px solid var(--noir-border);border-radius:3px;font-size:1rem}.choice-title{flex:1;font-size:.85rem;font-weight:500;color:var(--noir-paper);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.custom-action-details{margin-top:.75rem;border:1px dashed var(--noir-border);border-radius:4px;overflow:hidden;background:#0d0d0d}.custom-action-details summary{padding:.5rem .75rem;font-size:.75rem;color:var(--noir-muted);cursor:pointer;background:#1a1a2e}.custom-action-details summary:hover{color:var(--noir-paper)}.manual-input-form-compact{padding:.75rem;display:flex;gap:.5rem;background:#0d0d0d}.manual-input-form-compact textarea{flex:1;padding:.5rem;background:#1a1a2e;border:1px solid var(--noir-border);border-radius:4px;color:var(--noir-paper);font-family:monospace;font-size:.8rem;resize:none}.manual-input-form-compact textarea:focus{outline:none;border-color:var(--noir-accent)}.submit-btn-sm{padding:.5rem 1rem;background:var(--noir-dark);border:1px solid var(--noir-border);border-radius:4px;color:var(--noir-gold);font-family:monospace;font-size:.75rem;text-transform:uppercase;cursor:pointer;transition:all .2s ease}.submit-btn-sm:hover:not(:disabled){background:var(--noir-surface);border-color:var(--noir-gold)}.submit-btn-sm:disabled{opacity:.5;cursor:not-allowed}.mobile-fab{position:fixed;bottom:4rem;right:1rem;z-index:60;display:flex;flex-direction:column-reverse;align-items:center;gap:.75rem}.fab-main{width:3.5rem;height:3.5rem;border-radius:50%;background:linear-gradient(135deg,var(--noir-accent) 0%,#c23a52 100%);border:none;color:#fff;font-size:1.5rem;cursor:pointer;box-shadow:0 4px 20px #e9456066;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.fab-main:hover,.fab-main:active{transform:scale(1.05);box-shadow:0 6px 30px #e9456080}.mobile-fab.expanded .fab-main{background:var(--noir-dark);box-shadow:0 4px 20px #00000080}.fab-menu{display:flex;flex-direction:column;gap:.5rem;animation:fadeIn .2s ease}.fab-item{padding:.6rem 1rem;border-radius:2rem;border:1px solid var(--noir-border);background:var(--noir-dark);color:var(--noir-paper);font-size:.8rem;font-weight:500;cursor:pointer;white-space:nowrap;box-shadow:0 2px 10px #0000004d;transition:all .2s ease}.fab-item.tarot{border-color:#d4af3766;color:var(--noir-gold)}.fab-item.tarot:hover:not(:disabled){background:#d4af371a;border-color:var(--noir-gold)}.fab-item.solve{border-color:#e9456066;color:var(--noir-accent)}.fab-item.solve:hover{background:#e945601a;border-color:var(--noir-accent)}.fab-item:disabled{opacity:.5;cursor:not-allowed}@media(max-width:767px){.arcana-game.is-mobile .narrative-content{padding-bottom:4rem}}.special-actions{display:flex;gap:.75rem;margin-bottom:.75rem}.tarot-btn{flex:1;padding:.75rem;background:#d4af371a;border:1px solid rgba(212,175,55,.4);border-radius:4px;color:var(--noir-gold);font-family:monospace;font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;cursor:pointer;transition:all .3s ease}.tarot-btn:hover:not(:disabled){background:#d4af3733;border-color:var(--noir-gold)}.tarot-btn:disabled{opacity:.5;cursor:not-allowed}.special-actions .solve-btn{flex:1}.model-indicator{color:var(--noir-gold);font-size:.625rem}.anon-banner{position:absolute;top:0;left:0;right:0;z-index:100;padding:.5rem 1rem;background:linear-gradient(90deg,#d4af3726,#d4af370d);border-bottom:1px solid rgba(212,175,55,.3);text-align:center;font-size:.75rem;color:var(--noir-paper)}.anon-banner a{color:var(--noir-gold);font-weight:600;text-decoration:underline}.anon-banner a:hover{color:#fff}.case-select{width:100%;max-width:1200px;margin:0 auto;padding:2rem 1rem;min-height:100vh;color:var(--noir-paper, #e8e6e3)}.case-select-loading,.case-select-error,.case-select-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem}.loading-spinner{font-size:2rem;animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{color:#d4af37;font-size:1rem}.retry-btn{padding:.75rem 1.5rem;background:#d4af371a;border:1px solid #d4af37;color:#d4af37;cursor:pointer;font-family:Courier New,monospace;transition:all .3s ease}.retry-btn:hover{background:#d4af3733}.case-select-header{text-align:center;margin-bottom:3rem;border-bottom:2px solid rgba(212,175,55,.3);padding-bottom:2rem}.casebook-title{font-size:2.5rem;font-weight:700;color:#d4af37;margin:0 0 .5rem;font-family:Courier New,monospace;text-transform:uppercase;letter-spacing:.1em;text-shadow:0 0 10px rgba(212,175,55,.3)}.volume-title{font-size:1.5rem;font-weight:600;color:var(--noir-paper);margin:0 0 1rem;font-family:Courier New,monospace}.volume-subtitle{font-size:1rem;color:#e8e6e3b3;font-style:italic;max-width:600px;margin:0 auto;line-height:1.6}.cases-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:3rem}.case-card{background:linear-gradient(135deg,#1e1e1ee6,#141414f2);border:1px solid rgba(212,175,55,.3);padding:1.5rem;cursor:pointer;transition:all .3s ease;text-align:left;position:relative;overflow:hidden;display:flex;flex-direction:column;gap:1rem;min-height:200px}.case-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(212,175,55,.05) 0%,transparent 100%);opacity:0;transition:opacity .3s ease;pointer-events:none}.case-card.available:hover:before{opacity:1}.case-card.available:hover{border-color:#d4af37;transform:translateY(-2px);box-shadow:0 4px 20px #d4af3733}.case-card.locked{opacity:.6;background:linear-gradient(135deg,#141414e6,#0f0f0ff2)}.case-card.locked:hover{opacity:.8;border-color:#d4af3780}.case-card.free{border-color:#4caf5080}.case-card.free:before{background:linear-gradient(135deg,rgba(76,175,80,.05) 0%,transparent 100%)}.case-header{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.case-number{font-size:.75rem;color:#d4af37b3;text-transform:uppercase;letter-spacing:.05em;font-family:Courier New,monospace}.case-badge{font-size:.65rem;padding:.25rem .5rem;border-radius:2px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.case-badge.free{background:#4caf5033;color:#4caf50;border:1px solid rgba(76,175,80,.5)}.case-badge.locked{background:#64646433;color:#888;border:1px solid rgba(100,100,100,.5)}.case-title{font-size:1.25rem;font-weight:600;color:var(--noir-paper);margin:0;font-family:Courier New,monospace;line-height:1.3}.case-tagline{font-size:.9rem;color:#e8e6e3cc;font-style:italic;margin:0;line-height:1.5;flex-grow:1}.case-footer{display:flex;justify-content:flex-end;align-items:center;margin-top:auto;padding-top:1rem;border-top:1px solid rgba(212,175,55,.2)}.case-cta{font-size:.85rem;color:#d4af37;font-weight:500;font-family:Courier New,monospace}.case-card.locked .case-cta{color:#888}.bundle-cta{background:linear-gradient(135deg,#d4af371a,#d4af370d);border:2px solid rgba(212,175,55,.3);padding:2rem;text-align:center;margin-top:2rem}.bundle-info{margin-bottom:2rem}.bundle-info h3{font-size:1.5rem;color:#d4af37;margin:0 0 .5rem;font-family:Courier New,monospace}.bundle-info p{font-size:1rem;color:#e8e6e3cc;margin:0 0 1.5rem;line-height:1.6}.bundle-features{list-style:none;padding:0;margin:0;display:inline-block;text-align:left}.bundle-features li{font-size:.95rem;color:var(--noir-paper);margin-bottom:.5rem;font-family:Courier New,monospace}.bundle-purchase-btn{background:linear-gradient(135deg,#d4af37,#b8941f);color:#0d0d0d;border:none;padding:1rem 2rem;font-size:1.1rem;font-weight:700;font-family:Courier New,monospace;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.05em;box-shadow:0 4px 15px #d4af374d}.bundle-purchase-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #d4af3766;background:linear-gradient(135deg,#e0bd44,#d4af37)}@media(max-width:768px){.case-select{padding:1rem .5rem}.casebook-title{font-size:2rem}.volume-title{font-size:1.25rem}.cases-grid{grid-template-columns:1fr;gap:1rem}.bundle-cta{padding:1.5rem 1rem}.bundle-purchase-btn{font-size:1rem;padding:.875rem 1.5rem}}.arcana-wrapper{position:fixed;inset:0;z-index:50;background:#0d0d0d;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.arcana-wrapper~.starfield,body>.starfield{display:none}@media(max-width:768px){.arcana-wrapper{position:absolute;min-height:100vh;min-height:100dvh;height:auto}html,body{overflow-x:hidden;overflow-y:auto}}
