*,:before,:after{box-sizing:border-box}:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg-page:#0f0f12;--bg-surface:#17171f;--bg-raised:#1f1f28;--bg-input:#22222c;--bg-hover:#2a2a36;--border:#34343f;--border-strong:#4a4a58;--border-dashed:#4a4a58;--text:#ebebf0;--text-secondary:#a8a8b8;--text-muted:#7a7a8a;--text-subtle:#888898;--pill-active-bg:#e8e8ee;--pill-active-fg:#121218;--modal-overlay:#000000a6;--vibes-accent:#6b6b7a;--panel-nav-accent:#6a6a78;--panel-filter-accent:#6b9bd1;--panel-filter-bg:#6b9bd117;--panel-view-accent:#c9a06c;--panel-view-bg:#c9a06c1a;color:var(--text);background:var(--bg-page);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Noto Sans JP,sans-serif}html{overflow-x:hidden}body{box-sizing:border-box;margin:0;padding:1.5rem;overflow-x:hidden}#root{min-width:0;max-width:100%;margin:0 auto}.app-shell{min-width:0;max-width:100%}.back-to-top-btn{z-index:50;right:max(12px, env(safe-area-inset-right,0px));bottom:max(12px, env(safe-area-inset-bottom,0px));border:1px solid var(--border-strong);background:var(--bg-surface);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;padding:0;font-family:system-ui,sans-serif;font-size:17px;line-height:1;display:flex;position:fixed;box-shadow:0 2px 10px #00000059}.back-to-top-btn:hover{background:var(--bg-hover);color:var(--text)}.site-header{border-bottom:1px solid var(--border);margin-bottom:1.5rem;padding:1.5rem 0 1rem}.site-title{letter-spacing:.04em;color:var(--text);font-family:Noto Serif JP,serif;font-size:24px;font-weight:600}.site-sub{color:var(--text-muted);margin-top:4px;font-size:12px}.control-panel{border:1px solid var(--border);border-left-width:4px;border-radius:10px;flex-direction:column;gap:14px;margin-bottom:1.5rem;padding:1rem 1.15rem 1.15rem;display:flex}.control-panel-heading{color:var(--text-secondary);letter-spacing:.02em;margin:0;font-family:inherit;font-size:13px;font-weight:600}.control-panel--nav{border-left-color:var(--panel-nav-accent);background:0 0}.control-panel--filter{border-left-color:var(--panel-filter-accent);background:var(--panel-filter-bg)}.control-panel--view{border-left-color:var(--panel-view-accent);background:var(--panel-view-bg)}.admin-settings{border-top:1px dashed var(--border);margin-top:.5rem;padding-top:.75rem}.admin-settings-summary{cursor:pointer;color:var(--text-muted);-webkit-user-select:none;user-select:none;font-size:12px}.admin-settings-summary:hover{color:var(--text-secondary)}.admin-settings-body{flex-direction:column;gap:10px;margin-top:10px;display:flex}.admin-settings-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.admin-settings-row .search-input{flex:180px;min-width:0}.admin-settings-on{color:var(--text-secondary);margin:0;font-size:12px}.control-panel .search-bar,.control-panel .filter-bar{background:0 0;border:none;border-radius:0;margin-bottom:0;padding:0}.control-panel .filter-checkbox-sort-block{margin-bottom:0}.search-bar{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:1.25rem;padding:.75rem 1rem;display:flex}.search-bar-label{color:var(--text-muted);flex-shrink:0;font-size:12px;font-weight:600}.search-input{border:1px solid var(--border-strong);background:var(--bg-input);min-width:0;color:var(--text);box-sizing:border-box;border-radius:20px;outline:none;flex:1;padding:8px 14px;font-family:Noto Sans JP,sans-serif;font-size:14px}.search-input:focus{border-color:var(--text-muted)}.search-fields-row{color:var(--text-secondary);flex-wrap:wrap;flex:100%;gap:12px;margin-top:8px;font-size:13px;display:flex}.search-field-check{cursor:pointer;align-items:center;gap:4px;display:inline-flex}.pref-nav{flex-wrap:wrap;gap:6px;display:flex}.pref-btn{border:1px solid var(--border-strong);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:20px;padding:4px 10px;font-family:Noto Sans JP,sans-serif;font-size:12px}.pref-btn:hover{background:var(--bg-hover);color:var(--text)}.filter-bar{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:1.5rem;padding:.75rem 1rem;display:flex}.filter-label{color:var(--text-muted);flex-shrink:0;font-size:12px}.pop-filter-bands{flex-wrap:wrap;flex:1;align-items:center;gap:8px 14px;min-width:0;display:flex}.pop-band-label{font-size:12px}.town-count{color:var(--text-muted);flex-shrink:0;font-size:12px}.load-status{color:var(--text-muted);margin-bottom:1rem;font-size:14px}.loading-dots{text-align:left;font-variant-numeric:tabular-nums;width:1.5em;display:inline-block}.loading-dots:before{content:".";animation:.6s infinite loading-dots-cycle}@keyframes loading-dots-cycle{0%,32.9%{content:"."}33%,65.9%{content:".."}66%,to{content:"..."}}.load-error{color:#f0a0a0;background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;margin-bottom:1.5rem;padding:1rem 1.25rem;font-size:14px;line-height:1.6}.load-error code{font-size:12px}.filter-checkbox-sort-block{flex-direction:column;gap:10px;margin-bottom:1.5rem;display:flex}.filter-checkbox-row{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.filter-sort-row{flex-wrap:wrap;align-items:center;gap:12px 16px;display:flex}.sort-select-label{color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;display:inline-flex}.sort-select-label select{background:var(--bg-surface);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:4px 8px;font-size:13px}.checkbox-label{color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:13px;display:inline-flex}.checkbox-label input{width:16px;height:16px;accent-color:var(--pill-active-bg);cursor:pointer}.pref-section{flex-direction:column;gap:1.25rem;scroll-margin-top:.5rem;display:flex}.town-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;min-width:0;max-width:100%;margin:0;padding:1.5rem 1.25rem 1.75rem;scroll-margin-top:.75rem}#townsContainer{flex-direction:column;gap:1.25rem;min-width:0;max-width:100%;display:flex}.town-header{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.25rem;display:flex}.pref-label{color:var(--text-subtle);letter-spacing:.08em;font-size:11px}.town-name{color:var(--text);font-family:Noto Serif JP,serif;font-size:20px;font-weight:600}.pop-badge{color:var(--text-secondary);border:1px solid var(--border);border-radius:20px;padding:2px 10px;font-size:12px}.like-btn{color:var(--text-secondary);border:1px solid var(--border);box-sizing:border-box;cursor:pointer;background:0 0;border-radius:999px;min-height:44px;padding:10px 18px;font-family:Noto Sans JP,sans-serif;font-size:16px;font-weight:600;line-height:1.2}.like-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text)}.like-btn:disabled{opacity:.6;cursor:not-allowed}.like-btn--active{color:#fff;background:#c62828;border-color:#c62828}.like-btn--active:hover:not(:disabled){filter:brightness(1.08);color:#fff}.ch-label{color:var(--text-subtle);letter-spacing:.1em;margin:1.25rem 0 .6rem;font-size:11px}.ch-label-spaced{margin-top:1.5rem}.image-row{flex-wrap:wrap;align-content:flex-start;align-items:flex-start;gap:8px;min-width:0;max-width:100%;padding-bottom:4px;display:flex}.image-row-scroll{display:contents}@media (width<=420px){.image-row{-webkit-overflow-scrolling:touch;scrollbar-width:thin;overflow-x:auto}.image-row::-webkit-scrollbar{height:6px}}.scene-card{border:1px solid var(--border);background:var(--bg-raised);border-radius:8px;flex:0 0 190px;height:120px;position:relative;overflow:hidden}.scene-caption{color:#fff;background:#0000008c;padding:4px 8px;font-size:11px;position:absolute;bottom:0;left:0;right:0}.scene-card--sv,.scene-card--photo{box-sizing:border-box;flex-direction:column;flex:0 0 380px;width:380px;min-width:380px;height:240px;min-height:240px;max-height:240px;padding:0;display:flex;position:relative}.scene-card-delete{color:#fff;cursor:pointer;background:#0000008c;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;padding:0;font-family:system-ui,sans-serif;font-size:20px;line-height:1;display:flex;box-shadow:0 1px 3px #00000059}.scene-card-delete:hover{color:#fff;background:#000000bf}.scene-card-actions{flex-direction:row;flex-shrink:0;align-items:center;gap:4px;display:flex}.scene-card-edit{color:#fff;cursor:pointer;background:#0000008c;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;padding:0;display:flex;box-shadow:0 1px 3px #00000059}.scene-card-edit:hover{color:#fff;background:#325a96e0}.scene-caption--editing{flex-direction:column;gap:6px;align-items:stretch!important}.scene-caption-edit-textarea{resize:vertical;border:1px solid var(--border);width:100%;min-height:52px;max-height:120px;color:var(--text);box-sizing:border-box;background:#fffffff5;border-radius:6px;outline:none;padding:6px 8px;font-family:inherit;font-size:11px;line-height:1.4}.scene-caption-edit-textarea:focus{border-color:var(--text-muted)}.scene-caption-edit-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.scene-caption-edit-actions .save-btn,.scene-caption-edit-actions .edit-btn{margin-top:0}.scene-sv-frame,.scene-img-frame{background:var(--bg-raised);flex:1;min-height:0;overflow:hidden}.scene-img-frame img{object-fit:cover;width:100%;height:100%;display:block}.scene-sv-iframe{vertical-align:top;border:0;width:100%;height:100%;min-height:0;display:block}.scene-card--sv .scene-caption--sv,.scene-card--photo .scene-caption--sv{flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:4px 8px;font-size:11px;display:flex;position:static}.scene-card--sv .scene-caption-text,.scene-card--photo .scene-caption-text{overflow-wrap:break-word;word-break:break-word;flex:1;min-width:0}.scene-placeholder{width:100%;height:100%;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:8px;font-size:11px;display:flex}.add-card{border:1px dashed var(--border-dashed);cursor:pointer;height:120px;color:var(--text-muted);background:0 0;border-radius:8px;flex-direction:column;flex:0 0 80px;justify-content:center;align-items:center;gap:4px;font-family:Noto Sans JP,sans-serif;font-size:11px;display:flex}.image-row:has(.scene-card) .add-card{height:240px;min-height:240px}@media (width<=640px){.image-row-scroll:empty{display:none}.image-row:not(:has(.scene-card)) .add-card{flex:100%;height:auto;min-height:120px}.image-row:has(.scene-card) .add-card{flex:0 0 80px;width:80px;height:240px;min-height:240px}}.add-card:hover{background:var(--bg-hover);color:var(--text-secondary)}.vibes-box{position:relative}.vibes-messages{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:8px;min-height:60px;max-height:220px;margin-bottom:8px;padding:.75rem 1rem;display:flex;overflow-y:auto}.vibe-msg-placeholder{opacity:.65}.vibe-item{border-left:2px solid var(--vibes-accent);padding-left:10px}.vibe-item-body{flex-direction:column;gap:6px;display:flex}.vibe-item-text{color:var(--text-secondary);white-space:pre-wrap;font-size:13px;line-height:1.65}.vibe-item-actions{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.vibe-item-actions .edit-btn,.vibe-item-actions .vibe-delete-btn{box-sizing:border-box;justify-content:center;align-self:center;align-items:center;min-height:26px;margin-top:0;line-height:1.25;display:inline-flex}.vibe-item-edit-actions .save-btn,.vibe-item-edit-actions .edit-btn{margin-top:0}.vibe-delete-btn{color:var(--text-muted);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:20px;padding:3px 10px;font-family:Noto Sans JP,sans-serif;font-size:11px}.vibe-delete-btn:hover{color:var(--text-secondary);background:var(--bg-hover)}.vibe-item-edit-actions{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.vibe-edit-textarea{margin-top:0}.vibe-input-row{align-items:flex-end;gap:8px;display:flex}.vibe-input-row textarea.chat-input{border:1px solid var(--border-strong);background:var(--bg-input);color:var(--text);box-sizing:border-box;resize:none;border-radius:8px;outline:none;flex:1;min-height:32px;max-height:32px;padding:6px 12px;font-family:Noto Sans JP,sans-serif;font-size:13px;line-height:1.35;overflow:hidden}.vibe-input-row textarea.chat-input:focus{border-color:var(--text-muted)}.vibe-input-row--expanded textarea.chat-input{resize:vertical;height:auto;min-height:72px;max-height:none;padding:7px 12px;line-height:1.5;overflow-y:auto}.vibes-text{color:var(--text-secondary);background:var(--bg-surface);border-left:2px solid var(--vibes-accent);white-space:pre-wrap;border-radius:8px;min-height:60px;padding:1rem 1.25rem;font-size:14px;line-height:1.8}.vibes-textarea{color:var(--text);background:var(--bg-input);border:1px solid var(--border-strong);resize:vertical;box-sizing:border-box;border-radius:8px;outline:none;width:100%;min-height:80px;padding:1rem 1.25rem;font-family:Noto Sans JP,sans-serif;font-size:14px;line-height:1.8}.vibes-textarea:focus{border-color:var(--text-muted)}.edit-btn{color:var(--text-muted);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:20px;margin-top:6px;padding:3px 10px;font-family:Noto Sans JP,sans-serif;font-size:11px}.edit-btn:hover{color:var(--text-secondary);background:var(--bg-hover)}.save-btn{color:var(--text);border:1px solid var(--border-strong);background:var(--bg-raised);cursor:pointer;border-radius:20px;margin-top:6px;padding:3px 10px;font-family:Noto Sans JP,sans-serif;font-size:11px}.save-btn:hover{background:var(--bg-hover)}.chat-messages{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:6px;min-height:60px;max-height:160px;margin-bottom:8px;padding:.75rem 1rem;display:flex;overflow-y:auto}.msg{border-radius:8px;max-width:85%;padding:6px 10px;font-size:13px;line-height:1.5}.msg-user{background:var(--bg-raised);border:1px solid var(--border);color:var(--text);align-self:flex-start}.msg-system{color:var(--text-muted);align-self:center;font-size:12px}.msg-item-body{flex-direction:row;justify-content:space-between;align-items:flex-start;gap:6px;display:flex}.msg-item-text{white-space:pre-wrap;flex:1;min-width:0}.msg-item-actions{flex-wrap:nowrap;flex-shrink:0;align-items:flex-start;gap:6px;display:flex}.msg-item-actions .edit-btn,.msg-item-actions .vibe-delete-btn{align-self:center;margin-top:0}.msg-item-edit-actions{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.msg-item-edit-actions .save-btn,.msg-item-edit-actions .edit-btn{margin-top:0}.chat-input-row{align-items:center;gap:8px;display:flex}.chat-input-row .like-btn{flex-shrink:0;min-height:0;padding:7px 14px;font-size:15px}.chat-input-row textarea.chat-input{border:1px solid var(--border-strong);background:var(--bg-input);color:var(--text);box-sizing:border-box;resize:none;border-radius:8px;outline:none;flex:1;min-height:32px;max-height:32px;padding:6px 12px;font-family:Noto Sans JP,sans-serif;font-size:13px;line-height:1.35;overflow:hidden}.chat-input-row textarea.chat-input:focus{border-color:var(--text-muted)}.chat-input-row--expanded{grid-template-rows:auto auto;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;display:grid}.chat-input-row--expanded textarea.chat-input{resize:vertical;flex:unset;grid-area:1/1/auto/-1;width:100%;min-width:0;height:auto;min-height:72px;max-height:none;padding:7px 12px;line-height:1.5;overflow-y:auto}.chat-input-row--expanded .like-btn{grid-area:2/1;justify-self:start}.chat-input-row--expanded .send-btn{grid-area:2/3;justify-self:end;margin-left:0}@media (width<=640px){.chat-input-row:not(.chat-input-row--expanded) textarea.chat-input{order:1}.chat-input-row:not(.chat-input-row--expanded) .send-btn{order:2}.chat-input-row:not(.chat-input-row--expanded) .like-btn{order:3}}.send-btn{border:1px solid var(--border-strong);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;padding:7px 14px;font-family:Noto Sans JP,sans-serif;font-size:13px}.send-btn:hover{background:var(--bg-hover);color:var(--text)}.modal-bg{background:var(--modal-overlay);z-index:100;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-bg.open{display:flex}.modal{background:var(--bg-surface);border:1px solid var(--border);box-sizing:border-box;width:320px;max-width:90vw;color:var(--text);border-radius:12px;padding:1.5rem}.modal--wide{width:min(440px,94vw);max-height:90vh;overflow-y:auto}.modal-tabs{gap:8px;margin-bottom:1rem;display:flex}.modal-tab{border:1px solid var(--border-strong);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;flex:1;padding:8px 10px;font-family:Noto Sans JP,sans-serif;font-size:12px}.modal-tab.active{background:var(--bg-hover);border-color:var(--text-muted);color:var(--text)}.modal-field-label{color:var(--text-muted);margin-bottom:1rem;font-size:11px;display:block}.modal-field-label span{margin-bottom:4px;display:block}.modal-field-label-title{color:var(--text-secondary);flex-wrap:wrap;align-items:baseline;gap:6px;margin-bottom:4px;font-size:12px;font-weight:600;display:flex!important}.modal-label-required{letter-spacing:.02em;color:#d66;background:#c844442e;border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:10px;font-weight:700;line-height:1.2}.modal-field-hint{color:var(--text-muted);margin-bottom:6px;font-size:11px;font-weight:400;line-height:1.45;display:block}.modal-field-label input{margin-bottom:0}.modal-field-error{color:#c44;margin:0 0 1rem;font-size:12px}.modal-warn{color:var(--text-secondary)}.modal-sv-preview{margin-bottom:1rem}.modal-sv-preview-title{color:var(--text-secondary);margin-bottom:8px;font-size:12px;font-weight:500}.modal-sv-preview-wrap{border:1px solid var(--border);aspect-ratio:16/9;background:#222;border-radius:8px;width:100%;max-width:100%;max-height:min(400px,50vh);overflow:hidden}.modal-sv-iframe{vertical-align:top;border:0;width:100%;height:100%;min-height:0;display:block}.modal-sv-fallback-btn{width:100%;color:var(--text-muted);text-align:left;cursor:pointer;text-underline-offset:2px;background:0 0;border:0;margin-top:8px;padding:0;font-family:Noto Sans JP,sans-serif;font-size:12px;line-height:1.5;text-decoration:underline;display:block}.modal-sv-fallback-btn:hover{color:var(--text-secondary)}.modal-upload-preview{margin-bottom:1rem}.modal-upload-preview-title{color:var(--text-secondary);margin-bottom:8px;font-size:12px;font-weight:500}.modal-upload-preview-wrap{border:1px solid var(--border);background:#222;border-radius:8px;justify-content:center;align-items:center;max-height:320px;display:flex;overflow:hidden}.modal-upload-preview-img{vertical-align:top;width:auto;max-width:100%;height:auto;max-height:320px;display:block}.modal h3{color:var(--text);margin:0 0 1rem;font-size:15px;font-weight:500}.modal input{border:1px solid var(--border-strong);background:var(--bg-input);width:100%;color:var(--text);box-sizing:border-box;border-radius:8px;outline:none;margin-bottom:8px;padding:7px 12px;font-family:Noto Sans JP,sans-serif;font-size:13px}.modal input:focus{border-color:var(--text-muted)}.modal-note{color:var(--text-muted);margin-bottom:1rem;font-size:12px;line-height:1.6}.modal-btns{justify-content:flex-end;gap:8px;display:flex}.modal-cancel{border:1px solid var(--border-strong);cursor:pointer;color:var(--text-secondary);background:0 0;border-radius:8px;padding:6px 14px;font-family:Noto Sans JP,sans-serif;font-size:13px}.modal-cancel:hover{background:var(--bg-hover);color:var(--text)}.modal-ok{border:1px solid var(--pill-active-bg);background:var(--pill-active-bg);color:var(--pill-active-fg);cursor:pointer;border-radius:8px;padding:6px 14px;font-family:Noto Sans JP,sans-serif;font-size:13px}.modal-ok:hover{filter:brightness(1.06)}.add-icon{opacity:.45;font-size:20px}.placeholder-q{opacity:.35;font-size:18px}
