:root{color:#e8eaed;background:#1a1d21;font-family:Segoe UI,system-ui,sans-serif}*{box-sizing:border-box}body{min-height:100vh;margin:0}#app{width:100%;min-height:100vh}.layout{flex-direction:row;align-items:stretch;width:100%;height:100vh;min-height:100vh;display:flex}.panel{overscroll-behavior:contain;scrollbar-gutter:stable;background:linear-gradient(#22262c 0%,#1a1d21 100%);border-left:1px solid #333842;flex-shrink:0;width:420px;min-width:320px;height:100%;padding:12px 16px 12px 24px;overflow-y:scroll}html,body{height:100%;overflow:hidden}.panel{scrollbar-width:thin;scrollbar-color:#919baa80 #0000}.panel::-webkit-scrollbar{width:10px}.panel::-webkit-scrollbar-track{background:0 0}.panel::-webkit-scrollbar-thumb{background:#919baa73 padding-box padding-box;border:2px solid #0000;border-radius:10px}.panel::-webkit-scrollbar-thumb:hover{background:#919baaa6 padding-box padding-box;border:2px solid #0000}.panel h1{letter-spacing:.02em;margin:0 0 4px;font-size:1.05rem;font-weight:600}.panel__topbar{align-items:center;gap:8px;margin:10px 0;padding-right:6px;display:flex}.modeTabs{background:#14171c;border:1px solid #2a303a;border-radius:10px;gap:0;display:inline-flex;overflow:hidden}.modeTabs button{appearance:none;color:#aeb6c3;font:inherit;cursor:pointer;background:0 0;border:none;padding:6px 10px}.modeTabs button:hover{background:#ffffff0d}.modeTabs button[aria-selected=true]{color:#e8eaed;background:#5c6bc038}.panel__content[data-mode=params] #chat-mount,.panel__content[data-mode=params] #gallery-mount,.panel__content[data-mode=chat] #gui-mount,.panel__content[data-mode=chat] .hint{display:none}.panel__content[data-mode=chat] #chat-mount{display:block}.panel__content[data-mode=chat] #gallery-mount,.panel__content[data-mode=gallery] #gui-mount,.panel__content[data-mode=gallery] #chat-mount,.panel__content[data-mode=gallery] .hint{display:none}.panel__content[data-mode=gallery] #gallery-mount{display:block}.gallery{flex-direction:column;gap:10px;min-height:60vh;display:flex}.gallery__header{justify-content:space-between;align-items:center;gap:10px;display:flex}.gallery__title{color:#d5dae3;font-size:.9rem}.gallery__hint{color:#6d7582;font-size:.72rem;line-height:1.45}.gallery__list{flex-direction:column;gap:10px;display:flex}.gallery__empty{color:#8b929e;background:#ffffff08;border:1px dashed #2a303a;border-radius:12px;padding:12px 10px}.gallery__card{background:#111419;border:1px solid #2a303a;border-radius:12px;overflow:hidden}.gallery__img{aspect-ratio:16/9;object-fit:cover;background:#0d0f12;width:100%;display:block}.gallery__meta{flex-direction:column;gap:6px;padding:10px;display:flex}.gallery__prompt{color:#e8eaed;white-space:pre-wrap;font-size:.78rem}.gallery__time{color:#8b929e;font-size:.72rem}.gallery__actions{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.lightbox{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#000000b8;justify-content:center;align-items:center;padding:18px;display:none;position:fixed;inset:0}.lightbox--open{display:flex}.lightbox__inner{background:#0f1216;border:1px solid #ffffff1f;border-radius:14px;flex-direction:column;width:min(980px,96vw);max-height:90vh;display:flex;overflow:hidden;box-shadow:0 20px 60px #0000008c}.lightbox__img{object-fit:contain;background:#0b0e12;width:100%;height:auto;max-height:70vh;display:block}.lightbox__meta{flex-direction:column;gap:8px;padding:12px;display:flex}.lightbox__prompt{white-space:pre-wrap;color:#e8eaed;font-size:.82rem}.lightbox__time{color:#8b929e;font-size:.72rem}.lightbox__actions{flex-wrap:wrap;gap:8px;display:flex}.chat{flex-direction:column;gap:10px;min-height:60vh;display:flex}.chat__header{flex-direction:column;gap:8px;display:flex}.chat__title{color:#d5dae3;font-size:.9rem}.chat__keyRow{grid-template-columns:1fr auto;gap:8px;display:grid}.chat__keyInput{color:#e8eaed;background:#14171c;border:1px solid #2a303a;border-radius:10px;outline:none;width:100%;padding:8px 10px}.chat__btn{color:#e8eaed;cursor:pointer;background:#1f242c;border:1px solid #2a303a;border-radius:10px;padding:8px 10px}.chat__btn:disabled{opacity:.55;cursor:not-allowed}.chat__log{background:#111419;border:1px solid #2a303a;border-radius:12px;flex:1;min-height:260px;padding:10px;overflow:auto}.chat__msg{margin:8px 0;display:flex}.chat__msg--user{justify-content:flex-end}.chat__msg--assistant{justify-content:flex-start}.chat__bubble{white-space:pre-wrap;background:#ffffff0a;border:1px solid #ffffff0f;border-radius:12px;max-width:85%;padding:8px 10px;line-height:1.45}.chat__msg--user .chat__bubble{background:#5c6bc02e;border-color:#5c6bc04d}.chat__composer{grid-template-columns:1fr auto;align-items:end;gap:8px;display:grid}.chat__input{color:#e8eaed;resize:vertical;background:#14171c;border:1px solid #2a303a;border-radius:12px;outline:none;width:100%;min-height:42px;max-height:120px;padding:8px 10px}.chat__send{height:42px}.panel .sub{color:#8b929e;margin:0 0 12px;font-size:.78rem;line-height:1.4}#gui-mount{min-height:200px}#gui-mount .lil-gui{--background-color:#2a2f36;--widget-color:#3d4450;--focus-color:#5c6bc0;--hover-color:#4a5160;--font-family:inherit;width:100%;font-size:12px}.viewport{background:#0d0f12;flex:1;min-width:0;height:100vh;min-height:100vh;position:relative}.viewport canvas{width:100%;height:100%;display:block}.hint{color:#6d7582;margin-top:14px;font-size:.72rem;line-height:1.45}@media (width<=720px){.layout{flex-direction:column}.panel{width:100%;min-width:unset;border-top:1px solid #333842;border-left:none;order:2;height:auto;max-height:48vh}.viewport{flex:none;order:1;height:52vh;min-height:52vh}}
