:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;--bg: #1e1e2e;--bg-alt: #181825;--surface: #313244;--surface-alt: #2a2440;--border: #45475a;--text: #cdd6f4;--text-muted: #a6adc8;--text-subtle: #585b70;--accent: #cba6f7;--accent-soft: #b4befe;--accent-strong: #6c5ce7;--accent-strong-hover: #5549c0;--gold: #c8a96e;--card-bg: #1e1d2e;--tooltip-bg: #181825;--success: #a6e3a1;--warning: #f9e2af;--warning-strong: #b88a2a;--danger: #f38ba8;color:var(--text);background-color:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[data-theme=light]{--bg: #f7f1e2;--bg-alt: #f1e7d2;--surface: #eadfc7;--surface-alt: #e2d3b6;--border: #ccb996;--text: #3b2f21;--text-muted: #6c5b46;--text-subtle: #8b7a63;--accent: #b07a2a;--accent-soft: #c4913a;--accent-strong: #a86b1f;--accent-strong-hover: #8f5817;--gold: #c49a5a;--card-bg: #fbf6ea;--tooltip-bg: #f6ecda;--success: #6f9f63;--warning: #f0d08a;--warning-strong: #d7a75a;--danger: #c45b58}a{font-weight:500;color:var(--accent);text-decoration:inherit}a:hover{color:var(--accent-soft)}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--bg);color:var(--text)}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--surface);color:var(--text);cursor:pointer;transition:border-color .25s}button:hover{border-color:var(--accent)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}#root{width:100%;height:100%}.theme-toggle{position:fixed;top:16px;right:16px;z-index:11000}.theme-toggle button{display:flex;align-items:center;gap:6px;padding:.45rem .85rem;font-size:.85rem;background-color:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:999px;box-shadow:0 4px 12px #0003;cursor:pointer;transition:background-color .2s,border-color .2s,color .2s}.theme-toggle button:hover{background-color:var(--surface-alt);border-color:var(--accent);color:var(--accent)}.main-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem}.main-screen h1{font-size:3rem;margin-bottom:.5rem;color:var(--text)}.main-screen h2{font-size:1.1rem;color:var(--text-muted);margin-bottom:2rem;font-weight:400}.main-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.start-game-button{padding:1rem 2rem;font-size:1.2rem;background-color:var(--accent-strong);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background-color .3s}.start-game-button:hover{background-color:var(--accent-strong-hover)}.scenario-select-button{padding:1rem 2rem;font-size:1.2rem;background-color:var(--surface);color:var(--text);border:none;border-radius:8px;cursor:pointer;transition:background-color .3s}.scenario-select-button:hover{background-color:var(--surface-alt)}.footer{width:100%;text-align:center;padding:1rem;color:var(--text-subtle);font-size:.85rem}.footer a{color:var(--accent);text-decoration:none}.footer a:hover{text-decoration:underline}.chat-modal-layout{display:flex;flex-direction:row;height:450px}.chat-modal-sidebar{width:150px;flex-shrink:0;border-right:1px solid var(--border);overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:4px;background-color:var(--bg-alt)}.chat-sidebar-item{display:flex;align-items:center;gap:6px;padding:8px 10px;border-radius:8px;cursor:pointer;font-size:13px;color:var(--text-muted);transition:background-color .15s;word-break:break-word}.chat-sidebar-item:hover{background-color:var(--surface);color:var(--text)}.chat-sidebar-item.selected{background-color:var(--surface-alt);color:var(--accent);font-weight:600}.chat-sidebar-item input[type=radio]{display:none}.chat-sidebar-name{flex:1}.chat-modal-right{flex:1;display:flex;flex-direction:column;overflow:hidden;background-color:var(--bg)}.chat-modal-messages{padding:20px;flex:1;display:flex;flex-direction:column;gap:12px;overflow-y:auto}.modal-content:has(.chat-modal-layout){overflow:hidden}.chat-message{display:flex;flex-direction:column;max-width:70%}.chat-message.player{align-self:flex-end}.chat-message.npc{align-self:flex-start}.chat-message-npc-row{display:flex;flex-direction:row;align-items:flex-start;gap:8px}.chat-message-npc-content{display:flex;flex-direction:column}.chat-message-avatar{width:56px;height:56px;border-radius:6px;flex-shrink:0;background-repeat:no-repeat;background-color:var(--surface);border:1px solid var(--border)}.chat-message-avatar-clue{background-size:contain;background-position:center}.chat-message-avatar-npc{background-size:cover;background-position:top center}.chat-message-name{font-size:12px;color:var(--text-muted);margin-bottom:4px;padding:0 12px}.chat-message-bubble{padding:12px 16px;border-radius:18px;word-wrap:break-word;line-height:1.4}.chat-message.player .chat-message-bubble{background-color:var(--accent-strong);color:#fff;border-bottom-right-radius:4px}.chat-message.npc .chat-message-bubble{background-color:var(--surface);color:var(--text);border-bottom-left-radius:4px}.chat-modal-input-area{padding:16px 20px;width:100%;display:flex;flex-direction:column;gap:8px;position:relative;background-color:var(--bg-alt);border-top:1px solid var(--border)}.chat-modal-input-area.disabled{background-color:var(--bg)}.pressure-indicator{font-size:13px;color:#999}.chat-message.npc .chat-message-bubble.pending{color:#999}.chat-input-wrapper{flex:1;display:flex;gap:8px;position:relative}.chat-modal-input-editable{flex:1;padding:10px 16px;border:1px solid var(--border);border-radius:20px;font-size:14px;outline:none;min-height:40px;max-height:120px;overflow-y:auto;line-height:1.4;word-wrap:break-word;background-color:var(--surface);color:var(--text)}.chat-modal-input-editable:focus{border-color:var(--accent)}.chat-modal-input-editable:empty:before{content:attr(data-placeholder);color:var(--text-subtle)}.chat-modal-input-editable .reference-tag{display:inline-block;background-color:var(--surface-alt);color:var(--accent);border:1px solid var(--border);border-radius:4px;padding:2px 8px;margin:0 2px;font-size:13px;font-weight:500;cursor:default;-webkit-user-select:none;user-select:none}.reference-tag-display{display:inline-block;background-color:var(--surface-alt);color:var(--accent);border:1px solid var(--border);border-radius:4px;padding:2px 8px;margin:0 2px;font-size:13px;font-weight:500}.autocomplete-dropdown{position:absolute;bottom:100%;left:0;right:80px;background:var(--bg);border:1px solid var(--border);border-radius:8px;box-shadow:0 -4px 12px #0006;max-height:200px;overflow-y:auto;z-index:1000;margin-bottom:8px}.autocomplete-item{padding:10px 16px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background-color .15s;color:var(--text)}.autocomplete-item:hover,.autocomplete-item.selected{background-color:var(--surface)}.autocomplete-type{background-color:var(--surface);color:var(--text-muted);padding:2px 6px;border-radius:3px;font-size:11px;font-weight:600;text-transform:uppercase;min-width:50px;text-align:center}.autocomplete-name{font-size:14px;color:var(--text)}.chat-modal-input{flex:1;padding:10px 16px;border:1px solid var(--border);border-radius:20px;font-size:14px;outline:none;background-color:var(--surface);color:var(--text)}.chat-modal-input:focus{border-color:var(--accent)}.chat-modal-input:disabled{background-color:var(--bg-alt);cursor:not-allowed;color:var(--text-subtle)}.chat-modal-send-button{padding:10px 24px;background-color:var(--accent-strong);color:#fff;border:none;border-radius:20px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s}.chat-modal-send-button:hover:not(:disabled){background-color:var(--accent-strong-hover)}.chat-modal-send-button:disabled{background-color:var(--border);cursor:not-allowed;color:var(--text-subtle)}.chat-modal-disabled-notice{width:100%;text-align:center;color:var(--text-subtle);font-size:13px;padding:8px}.record-card-tooltip{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:8px;background:var(--tooltip-bg);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 20px #0009;padding:12px;width:250px;max-width:300px;z-index:1000;pointer-events:none;animation:tooltipFadeIn .2s ease-out}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(-5px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.record-card-tooltip:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:8px solid transparent;border-bottom-color:var(--tooltip-bg)}.record-card-tooltip-header{margin-bottom:8px}.record-card-tooltip-type{display:inline-block;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600;color:#11111b;margin-bottom:6px}.record-card-clue .record-card-tooltip-type{background-color:var(--success)}.record-card-npc .record-card-tooltip-type{background-color:#89b4fa}.record-card-fact .record-card-tooltip-type{background-color:var(--warning)}.record-card-tooltip-name{margin:6px 0 0;font-size:16px;font-weight:600;color:var(--text);word-break:break-word}.record-card-tooltip-content{margin:0;font-size:13px;color:var(--text-muted);line-height:1.5;word-break:break-word}.record-card-tooltip-above{top:auto;bottom:100%;margin-top:0;margin-bottom:8px}.record-card-tooltip-above:before{bottom:auto;top:100%;border-bottom-color:transparent;border-top-color:var(--tooltip-bg)}.revealed-records{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px;padding:0 4px}.revealed-record-icon{position:relative;display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:12px;font-size:12px;cursor:pointer;background-color:var(--surface-alt);border:1px solid var(--border);color:var(--text-muted);transition:background-color .15s,border-color .15s,color .15s;-webkit-user-select:none;user-select:none}.revealed-record-icon:hover{background-color:var(--surface);color:var(--text);border-color:var(--accent)}.revealed-record-emoji{font-size:12px;line-height:1}.revealed-record-name{font-size:11px;font-weight:500;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:10000}.modal{background-color:var(--bg);border-radius:12px;width:90%;display:flex;flex-direction:column;box-shadow:0 8px 40px #0009,0 2px 8px #c8a96e1a;max-height:85vh;border:1px solid var(--border)}.modal-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background-color:var(--bg-alt);border-radius:12px 12px 0 0}.modal-header h3{margin:0;font-size:18px;font-weight:600;color:var(--text)}.modal-close-button{background:none;border:none;font-size:24px;color:var(--text-muted);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px}.modal-close-button:hover{background-color:var(--surface);color:var(--text)}.modal-content{flex:1;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);padding:12px 20px;display:flex;justify-content:flex-end;gap:8px;flex-shrink:0}.solve-modal-content-wrapper{display:flex;flex-direction:column;flex:1}.solve-conversation{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:20px;min-height:200px;max-height:300px;background-color:var(--bg-alt);border-bottom:1px solid var(--border)}.solve-conversation-empty{display:block;text-align:center;color:var(--text-subtle);padding:40px 20px;font-style:italic}.solve-attempt{display:flex;flex-direction:column;gap:12px}.solve-message{display:flex;flex-direction:column}.solve-message.user{align-items:flex-end}.solve-message.npc{align-items:flex-start}.solve-message-bubble{max-width:75%;padding:14px 18px;border-radius:12px;word-wrap:break-word}.solve-message.user .solve-message-bubble{background-color:var(--accent-strong);color:#fff;border-bottom-right-radius:4px}.solve-message.npc .solve-message-bubble{background-color:var(--surface);color:var(--text);border-bottom-left-radius:4px}.solve-suspects{margin-bottom:8px;font-size:14px}.solve-reasoning{line-height:1.5}.solve-status{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;margin-bottom:8px;text-transform:uppercase}.solve-status[data-status=correct]{background-color:var(--success);color:#1f2a1f}.solve-status[data-status=partial]{background-color:var(--warning);color:#3a2e0e}.solve-status[data-status=incorrect]{background-color:var(--danger);color:#3a0e18}.solve-feedback-message{margin-bottom:8px;line-height:1.5}.solve-detailed-feedback,.solve-hints{margin-top:12px;padding-top:12px;border-top:1px solid var(--border);font-size:14px}.solve-hints ul{margin:8px 0 0;padding-left:20px}.solve-hints li{margin:4px 0}.solve-input-section{padding:20px;display:flex;flex-direction:column;gap:16px;background-color:var(--bg)}.solve-label{display:block;font-weight:600;margin-bottom:8px;color:var(--text);font-size:14px}.solve-suspects-section{display:flex;flex-direction:column}.solve-suspects-list{display:flex;flex-wrap:wrap;gap:12px}.solve-suspect-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background-color:var(--surface);border:2px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none;color:var(--text)}.solve-suspect-item:hover{background-color:var(--surface-alt);border-color:var(--accent)}.solve-suspect-item input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--accent)}.solve-suspect-item input[type=checkbox]:checked+span{font-weight:600;color:var(--accent)}.solve-reasoning-section{display:flex;flex-direction:column}.solve-reasoning-input{width:100%;padding:12px;border:1px solid var(--border);border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;outline:none;background-color:var(--surface);color:var(--text);box-sizing:border-box}.solve-reasoning-input:focus{border-color:var(--accent)}.solve-reasoning-input::placeholder{color:var(--text-subtle)}.solve-submit-button{padding:10px 24px;background-color:var(--accent-strong);color:#fff;border:none;border-radius:20px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s;align-self:flex-end}.solve-submit-button:hover:not(:disabled){background-color:var(--accent-strong-hover)}.solve-submit-button:disabled{background-color:var(--border);cursor:not-allowed;color:var(--text-subtle)}.record-card{position:relative;width:150px;height:150px;background:var(--card-bg);border-radius:8px;box-shadow:0 2px 8px #0006;border:1px solid var(--border);overflow:visible;transition:box-shadow .2s,border-color .2s;-webkit-user-select:none;user-select:none}.record-card:hover{box-shadow:0 4px 16px #cba6f733;border-color:var(--border)}.record-card-simple{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px;box-sizing:border-box}.record-card-image{width:100%;height:80px;background-size:contain;background-position:center;background-repeat:no-repeat;background-color:var(--surface);border-radius:4px;margin-bottom:8px;flex-shrink:0}.record-card-image-empty{background-color:var(--surface);border:2px dashed var(--border)}.record-card-memo-icon{width:100%;height:80px;background:linear-gradient(135deg,var(--warning) 0%,var(--warning-strong) 100%);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:40px;margin-bottom:8px;flex-shrink:0;box-shadow:inset 0 1px 3px #0006;border:1px solid var(--warning-strong)}.record-card-simple-name{font-size:14px;font-weight:600;color:var(--text);text-align:center;word-break:break-word;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.3}.record-card-highlighted{box-shadow:0 0 0 2px var(--accent),0 4px 20px #cba6f766;border-color:var(--accent);animation:highlightPulse 1.5s ease-in-out 3}@keyframes highlightPulse{0%,to{box-shadow:0 0 0 2px var(--accent),0 4px 20px #cba6f766}50%{box-shadow:0 0 0 4px var(--accent),0 4px 32px #cba6f7b3}}.records-modal-content{min-height:400px;max-height:68vh;overflow:auto;position:relative;resize:both}.records-toolbar{display:flex;align-items:center;gap:6px;padding:6px 10px;background-color:var(--bg);border-bottom:1px solid rgba(203,166,247,.15)}.records-zoom-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background-color:var(--bg-alt);border:1px solid rgba(203,166,247,.2);border-radius:4px;color:var(--text);font-size:16px;cursor:pointer;line-height:1;transition:background-color .15s,opacity .15s}.records-zoom-btn:hover:not(:disabled){background-color:#cba6f726}.records-zoom-btn:disabled{opacity:.35;cursor:not-allowed}.records-zoom-level{min-width:48px;height:28px;padding:0 6px;background-color:var(--bg-alt);border:1px solid rgba(203,166,247,.2);border-radius:4px;color:var(--text-muted);font-size:12px;cursor:pointer;transition:background-color .15s;text-align:center}.records-zoom-level:hover{background-color:#cba6f726}.records-canvas-footprint{position:relative;flex-shrink:0}.records-canvas{position:relative;width:2000px;height:1500px;background-color:var(--bg-alt);background-image:linear-gradient(rgba(203,166,247,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(203,166,247,.05) 1px,transparent 1px);background-size:20px 20px}.record-item-wrapper{transition:none}.records-loading{display:flex;align-items:center;justify-content:center;height:400px;color:var(--text-muted);font-size:16px}.records-empty{display:flex;align-items:center;justify-content:center;height:400px;color:var(--text-subtle);font-size:16px;text-align:center;padding:40px}.records-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-subtle);text-align:center;padding:40px}.records-empty-state-icon{font-size:64px;margin-bottom:16px}.records-empty-state-text{font-size:18px;margin:0}.records-empty-state-hint{font-size:14px;margin:8px 0 0;color:var(--text-subtle)}.error-screen{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:var(--bg);color:var(--text);font-family:Arial,sans-serif;text-align:center;padding:20px}.error-content{background-color:var(--bg-alt);border-radius:8px;box-shadow:0 4px 8px #0000001a;padding:40px;max-width:500px;width:100%}.error-content h1{font-size:3em;color:var(--danger);margin-bottom:20px}.error-message{font-size:1.2em;margin-bottom:30px;line-height:1.6}.home-button{background-color:var(--accent-strong);color:#fff;border:none;border-radius:5px;padding:10px 20px;font-size:1em;cursor:pointer;transition:background-color .3s ease}.home-button:hover{background-color:var(--accent-strong-hover)}.game-screen{display:flex;flex-direction:column;align-items:center;padding:2rem;min-height:100vh}.game-info{text-align:center;margin-bottom:1rem}.game-info h2{margin:0 0 .5rem;color:var(--text)}.game-info p{margin:.25rem 0;font-size:.85rem;color:var(--text-muted)}.game-shortcuts{display:flex;gap:.5rem;justify-content:center;margin-top:.75rem;flex-wrap:wrap}.game-shortcut-button{display:flex;align-items:center;gap:6px;padding:.4rem 1rem;font-size:.85rem;background-color:var(--surface);color:var(--accent);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:background-color .2s,border-color .2s,color .2s}.game-shortcut-button:hover{background-color:var(--surface-alt);border-color:var(--accent);color:var(--accent-soft)}.game-shortcut-button kbd{display:inline-block;padding:1px 5px;font-size:.75rem;font-family:inherit;background-color:var(--surface-alt);border:1px solid var(--border);border-radius:4px;color:var(--text-muted);line-height:1.4}.game-viewport{position:relative;border:2px solid var(--gold);background-color:var(--bg);box-shadow:0 4px 24px #c8a96e40,0 2px 8px #0006;overflow:hidden}.game-container{position:relative;background-color:var(--bg)}.result-screen{position:fixed;inset:0;background:linear-gradient(135deg,var(--bg) 0%,var(--bg-alt) 100%);display:flex;justify-content:center;align-items:center;z-index:10001}.result-container{background-color:var(--bg);border:1px solid var(--border);border-radius:20px;padding:40px;max-width:600px;width:90%;box-shadow:0 10px 40px #0009,0 2px 8px #cba6f71a;text-align:center}.result-header{margin-bottom:30px}.result-header h1{font-size:36px;color:var(--text);margin:0 0 10px}.result-status{display:inline-block;padding:8px 20px;border-radius:20px;font-weight:600;font-size:14px;text-transform:uppercase;background-color:var(--success);color:#1f2a1f}.result-scores{display:flex;gap:20px;margin-bottom:30px;justify-content:center}.score-item{background-color:var(--surface);border-radius:12px;padding:20px;flex:1;max-width:150px}.score-item.total{background-color:var(--surface-alt);border:1px solid var(--border)}.score-label{font-size:14px;color:var(--text-muted);margin-bottom:8px;font-weight:500}.score-item.total .score-label{color:var(--accent)}.score-value{font-size:32px;font-weight:700;color:var(--text)}.score-item.total .score-value{color:var(--accent-soft)}.result-message{background-color:var(--surface);border-radius:12px;padding:20px;margin-bottom:30px;text-align:left}.result-message h3{margin:0 0 12px;font-size:18px;color:var(--text)}.result-message p{margin:0;line-height:1.6;color:var(--text-muted)}.home-button{padding:14px 40px;background-color:var(--accent-strong);color:#fff;border:none;border-radius:25px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #6c5ce766}.home-button:hover{background-color:var(--accent-strong-hover);transform:translateY(-2px);box-shadow:0 6px 16px #6c5ce780}.home-button:active{transform:translateY(0)}.scenario-select-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;gap:1.5rem}.scenario-select-screen h1{font-size:3rem;margin:0;color:var(--text)}.scenario-select-screen h2{font-size:1.5rem;margin:0;color:var(--text)}.scenario-select-status{font-size:1rem;color:var(--text-muted)}.scenario-select-error{color:var(--danger)}.calendar{background:var(--bg-alt);border-radius:12px;padding:1.5rem;width:min(420px,90vw);box-shadow:0 4px 24px #0006}.calendar-header{display:flex;align-items:center;justify-content:space-between;font-size:1.3rem;font-weight:700;margin-bottom:1rem;color:var(--text)}.month-nav-button{background:none;border:none;color:var(--text);font-size:1.6rem;line-height:1;cursor:pointer;padding:0 .4rem;border-radius:6px;transition:background-color .15s,color .15s}.month-nav-button:hover{background:var(--surface);color:var(--accent)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-day-label{text-align:center;font-size:.75rem;font-weight:600;padding:4px 0;color:var(--text-muted)}.calendar-day-label.sunday{color:#f38ba8}.calendar-day-label.saturday{color:#89b4fa}.calendar-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:8px;border:none;background:transparent;cursor:default;font-size:.95rem;color:var(--text);padding:0;position:relative}.calendar-cell.empty{background:transparent}.calendar-cell.no-scenario{color:var(--text-subtle)}.calendar-cell.state-inactive{background:var(--bg-alt);color:var(--text-subtle);cursor:not-allowed}.calendar-cell.state-ready{background:var(--surface);cursor:pointer;color:#a6e3a1;font-weight:600;transition:background-color .15s,transform .1s}.calendar-cell.state-ready:hover{background:var(--surface-alt);transform:scale(1.08)}.calendar-cell.state-ready:active{transform:scale(.96)}.calendar-cell.state-visited{background:#2e2a1e;cursor:pointer;color:#f9e2af;font-weight:600;transition:background-color .15s,transform .1s}.calendar-cell.state-visited:hover{background:#3d3825;transform:scale(1.08)}.calendar-cell.state-visited:active{transform:scale(.96)}.calendar-cell.state-finished{background:var(--surface-alt);cursor:pointer;color:#89b4fa;font-weight:600;transition:background-color .15s,transform .1s}.calendar-cell.state-finished:hover{background:var(--surface);transform:scale(1.08)}.calendar-cell.state-finished:active{transform:scale(.96)}.calendar-cell.today{outline:2px solid var(--accent);outline-offset:-2px}.calendar-cell.today.state-ready{background:var(--accent-strong);color:#fff}.calendar-cell.today.state-visited{background:#b8860b;color:#fff}.calendar-cell.today.state-finished{background:#3b6bb5;color:#fff}.calendar-day-number{pointer-events:none;-webkit-user-select:none;user-select:none}.calendar-state-dot{display:block;width:4px;height:4px;border-radius:50%;position:absolute;bottom:4px;left:50%;transform:translate(-50%);pointer-events:none}.state-ready .calendar-state-dot{background:#a6e3a1}.state-visited .calendar-state-dot{background:#f9e2af}.state-finished .calendar-state-dot{background:#89b4fa}.state-inactive .calendar-state-dot{background:#585b70}.calendar-legend{display:flex;gap:1.5rem;font-size:.8rem;color:var(--text-muted)}.legend-item{display:flex;align-items:center;gap:6px}.legend-dot{display:inline-block;width:10px;height:10px;border-radius:50%}.legend-dot.state-inactive{background:#585b70}.legend-dot.state-ready{background:#a6e3a1}.legend-dot.state-visited{background:#f9e2af}.legend-dot.state-finished{background:#89b4fa}.back-button{padding:.75rem 1.75rem;font-size:1rem;background-color:var(--surface);color:var(--text);border:none;border-radius:8px;cursor:pointer;transition:background-color .2s}.back-button:hover{background-color:var(--surface-alt)}
