.login-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.login-modal{max-width:min(400px,calc(100vw - 2rem));width:100%;background:var(--bg-card, #1c1c24);border:1px solid var(--border, #2a2a35);border-radius:12px;box-shadow:0 20px 40px #0006}.login-modal__body{padding:1.5rem}.login-modal__google{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem 1rem;font-size:1rem;font-weight:500;border:1px solid var(--border, #2a2a35);border-radius:8px;background:var(--bg-card, #1c1c24);color:var(--text, #f4f4f5);cursor:pointer;transition:background .2s,border-color .2s}.login-modal__google:hover:not(:disabled){background:#ffffff0f;border-color:#3f3f46}.login-modal__google:disabled{opacity:.7;cursor:not-allowed}.login-modal__error{margin:1rem 0 0;font-size:.875rem;color:#f87171}.app{min-height:100vh;display:flex;--header-height: 3.25rem;--sidebar-width: 15.125rem}.app.app--loading{align-items:center;justify-content:center}.app__sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;flex-shrink:0;background:#101019;border-right:1px solid var(--border);padding:0;overflow-y:auto;display:flex;flex-direction:column}.sidebar__brand{min-height:var(--header-height);padding:0 1.25rem;margin-top:.25rem;display:flex;align-items:center;font-size:1.5rem;font-weight:600;color:var(--text);letter-spacing:-.02em;box-sizing:border-box}.sidebar__nav{display:flex;flex-direction:column;flex:1;gap:.25rem;padding:.5rem .75rem 0}.sidebar__link{display:flex;align-items:center;gap:.6rem;width:100%;padding:.75rem;font-size:1.0625rem;font-weight:500;color:var(--text-muted);text-decoration:none;border:none;border-radius:6px;background:transparent;cursor:pointer;text-align:left;transition:color .2s,background .2s}.sidebar__link-icon{flex-shrink:0;display:block;width:16px;height:16px}.sidebar__link:hover{color:var(--text);background:#ffffff0d}.sidebar__link--active{color:var(--accent);background:#8b5cf61f}.sidebar__link--active:hover{color:var(--accent);background:#8b5cf62e}.sidebar__footer{margin-top:auto;padding-top:1rem;padding-bottom:1rem;display:flex;flex-direction:column;align-items:stretch}.sidebar__link--signout{color:#a78bfa;padding:.5rem .75rem;display:flex;align-items:center;justify-content:flex-start;gap:.5rem;width:100%;text-align:left}.sidebar__link--signout .sidebar__link-icon{display:block;flex-shrink:0}.sidebar__link--signout:hover{color:#c4b5fd;background:#8b5cf61f}.app__body{flex:1;min-width:0;margin-left:var(--sidebar-width);display:flex;flex-direction:column}.app__body-placeholder{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;font-size:.9375rem;color:var(--text-muted, #a1a1aa)}.page{flex:1;display:flex;flex-direction:column;width:100%;padding:0 0 3rem;min-height:0}.page__toolbar{display:flex;justify-content:flex-end;padding:.5rem 1.5rem 0;margin:0 auto}.page__toolbar--themes{width:100%;max-width:100%;margin:0;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);padding:0 1.5rem;box-sizing:border-box;height:54px;background-color:#101019}.page__toolbar--themes .page__toolbar-spacer,.page__toolbar--themes .page__toolbar-end{flex:1;min-width:0}.page__toolbar--themes .page__toolbar-end{display:flex;justify-content:flex-end}.page__toolbar--themes .tabs{margin-bottom:0;border-bottom:none;justify-content:center;flex-shrink:0;margin-left:0;margin-right:0;padding:0}.page__toolbar--themes .tabs__tab{padding:1rem 1.5rem;font-size:1rem;font-weight:500;margin-bottom:-1px}.page__toolbar--themes .app__add-btn{padding:.45rem .9rem;font-size:1rem}.page__toolbar .app__add-btn{margin:12px 0}.page__header{width:100%;min-height:var(--header-height);margin:0 0 .4rem;padding:0;display:flex;align-items:center;box-sizing:border-box;background:#101019;border-bottom:1px solid var(--border)}.page__header-inner{display:flex;align-items:center;justify-content:space-between;width:100%;margin:0 auto;padding:0 1.5rem}.app__header{width:100%;margin:0 0 .4rem;padding:.8rem 0;background:#101019;border-bottom:1px solid var(--border)}.app__header-inner{display:flex;align-items:center;justify-content:space-between;margin:0 auto;padding:0 1.5rem}.app__header-left{display:flex;align-items:center}.app__title{margin:0;font-size:clamp(1.05rem,2.1vw,1.3rem);font-weight:600;letter-spacing:-.02em;color:var(--text);line-height:1.2}.app__subtitle{margin:0;font-size:.85rem;color:var(--text-muted)}.app__add-btn{padding:.5rem 1.25rem;font-size:.875rem;font-weight:500;border:1px solid var(--accent);border-radius:8px;background:var(--accent);color:#fff;cursor:pointer;transition:background .2s,border-color .2s,opacity .2s}.app__add-btn:hover{background:#6d28d9;border-color:#6d28d9}.app__add-btn--center{margin-top:.5rem}.tabs{display:flex;justify-content:center;gap:0;margin-bottom:1.5rem;border-bottom:1px solid var(--border);margin-left:auto;margin-right:auto;padding:0 1.5rem}.tabs__tab{padding:.6rem 1.25rem;font-size:.875rem;font-weight:500;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;background:transparent;color:var(--text-muted);cursor:pointer;transition:color .2s,border-color .2s}.tabs__tab:hover{color:var(--text)}.tabs__tab--active{color:var(--accent);border-bottom-color:var(--accent)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;max-width:420px;width:100%;max-height:90vh;overflow:auto;scrollbar-width:none;-ms-overflow-style:none}.modal::-webkit-scrollbar{display:none}.modal--wide{max-width:710px;max-height:none;overflow:visible}.modal--wide .modal__textarea{min-height:60vh;line-height:1.5}.modal--theme-detail{position:relative;display:flex;flex-direction:column;max-width:1050px;width:100%;height:84vh;max-height:90vh;overflow:hidden;scrollbar-width:none;-ms-overflow-style:none}.theme-detail__close{position:absolute;top:1rem;right:1rem;z-index:1}.modal--theme-detail::-webkit-scrollbar{display:none}.modal--theme-detail .modal__body{flex:1;min-height:0;overflow:hidden}.modal__body--two-cols{display:flex;justify-content:space-between;gap:.35rem;padding:1.25rem 1.5rem;align-items:stretch;height:100%;min-height:0}.theme-detail__left{display:flex;flex-direction:column;gap:1rem;min-width:0;min-height:0;overflow-x:hidden;width:55%;overflow-y:auto;padding-right:10px;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.6) transparent}.theme-detail__left::-webkit-scrollbar{width:4px}.theme-detail__left::-webkit-scrollbar-track{background:transparent}.theme-detail__left::-webkit-scrollbar-thumb{background:#0009;border-radius:2px}.theme-detail__left::-webkit-scrollbar-thumb:hover{background:#000000bf}.theme-detail__right{display:flex;justify-content:center;align-items:center;min-height:0;flex:1;min-width:0}.theme-detail__image-wrap{position:relative;display:flex;justify-content:center;align-items:center;width:100%;height:100%;min-height:0}.theme-detail__image{width:auto;height:100%;object-fit:contain;border-radius:8px;border:1px solid var(--border)}.theme-detail__no-image{aspect-ratio:9 / 16;width:100%;background:var(--bg);border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.9375rem}.theme-detail__field{display:flex;flex-direction:column;gap:.35rem}.theme-detail__field--row{flex-direction:row;align-items:center;gap:.75rem}.theme-detail__label{font-size:.8125rem;font-weight:600;color:var(--text-muted)}.theme-detail__value{font-size:.9375rem;color:var(--text)}.theme-detail__origin{font-weight:500;color:var(--accent)}.theme-detail__origin-row{display:inline-flex;align-items:center;gap:.35rem}.theme-detail__origin-link{display:inline-flex;align-items:center;color:var(--accent)}.theme-detail__origin-link:hover{opacity:.85}.theme-detail__origin-icon{width:.875rem;height:.875rem;color:inherit}.theme-detail__prompt-info{display:flex;flex-direction:column;gap:.25rem}.theme-detail__prompt-type{font-weight:500;color:var(--accent)}.theme-detail__prompt-preview{margin:0;font-size:.8125rem;color:var(--text-muted);line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.theme-detail__muted{color:var(--text-muted)}.theme-detail__regen-box{margin-top:.5rem;padding:1rem;border:1px solid var(--border);border-radius:10px;display:flex;flex-direction:column;gap:1rem}.theme-detail__regen-box>.theme-detail__label:first-child{margin-bottom:0}.theme-detail__regen-inputs{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.theme-detail__regen-inputs .theme-detail__field{min-width:0}.theme-detail__regen-actions{display:flex;justify-content:flex-end;margin-top:.25rem}.theme-detail__current-model{margin:.35rem 0 0;font-size:.8125rem;color:var(--text-muted)}.theme-detail__current-model .theme-detail__value{font-weight:500;font-size:.8125rem;color:var(--text)}.theme-detail__additional-instructions{height:70px;min-height:70px;resize:vertical;margin-top:.35rem}.theme-detail__select{padding:.4rem 2rem .4rem .6rem;font-size:.875rem;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:6px;min-width:0;margin-top:7px;max-width:220px}.theme-detail__hint{margin:.35rem 0 0;font-size:.75rem;color:var(--text-muted)}.theme-detail__textarea{height:70px;min-height:70px;resize:none}.theme-detail__prompt-textarea{height:170px;min-height:170px;resize:none;cursor:default}.theme-detail__categories-select{margin-top:.35rem}.theme-detail-select__control{min-height:38px;background:var(--bg-card)!important;border:1px solid var(--border)!important;border-radius:8px;color:var(--text)}.theme-detail-select__control:hover,.theme-detail-select__control--is-focused{border-color:var(--accent)!important;box-shadow:0 0 0 1px var(--accent)}.theme-detail-select__input-container,.theme-detail-select__single-value{color:var(--text)!important}.theme-detail-select__placeholder{color:var(--text-muted)!important;font-size:.8125rem}.theme-detail-select__multi-value{background:var(--bg-card-hover)!important;border:1px solid var(--border);border-radius:6px}.theme-detail-select__multi-value__label{color:#fff!important}.theme-detail-select__multi-value__remove:hover{background:#ef444433;color:#f87171}.theme-detail-select__menu{background:var(--bg-card)!important;border:1px solid var(--border);border-radius:8px;z-index:100}.theme-detail-select__menu-list{padding:.25rem 0}.theme-detail-select__option{background:transparent!important;color:var(--text)}.theme-detail-select__option--is-focused{background:var(--bg-card-hover)!important}.theme-detail-select__option--is-selected{background:#7c3aed33!important;color:var(--accent)}.theme-detail-select__indicator-separator{background:var(--border)!important}.theme-detail-select__dropdown-indicator{color:var(--text-muted)!important}.theme-detail-select__dropdown-indicator:hover{color:var(--text)!important}.theme-detail__footer{display:flex;justify-content:space-between!important;align-items:center;border-top:none!important;width:100%;margin-top:12px!important;margin-left:0!important;margin-right:0!important;padding-top:0!important;padding-left:0!important;padding-right:0!important;border-top:1px solid var(--border)}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.modal__header-title-wrap{display:flex;flex-direction:column;gap:.25rem}.modal__title{margin:0;font-size:1.25rem;font-weight:600;color:var(--text)}.modal__subtitle{margin:0;font-size:.875rem;font-weight:400;color:var(--text-muted)}.modal__close{width:32px;height:32px;padding:0;border:none;border-radius:6px;background:transparent;color:var(--text-muted);font-size:1.5rem;line-height:1;cursor:pointer;transition:background .2s,color .2s}.modal__close:hover{background:var(--bg);color:var(--text)}.modal__body{padding:1.5rem}.modal__field{margin-bottom:1.25rem}.modal__label{display:block;margin-bottom:.35rem;font-size:.875rem;font-weight:500;color:var(--text)}.modal__label--step{color:var(--text-muted);margin-bottom:.75rem}.modal__mode-options{display:flex;flex-direction:column;gap:.5rem}.mode-grid{display:grid;grid-template-columns:1fr;grid-template-rows:repeat(4,1fr);gap:.75rem;min-height:14rem}.modal--add-theme .mode-grid{grid-template-columns:1fr;grid-template-rows:repeat(4,1fr)}.mode-grid .mode-card{min-height:0}.mode-card{display:flex;align-items:flex-start;gap:.75rem;padding:.9rem .95rem;text-align:left;border:1px solid var(--border);border-radius:10px;background:#14141f;color:var(--text);cursor:pointer;transition:border-color .2s,background .2s,transform .05s}.mode-card:hover:not(:disabled){border-color:#3f3f46;background:#171723}.mode-card:active:not(:disabled){transform:translateY(1px)}.mode-card:focus-visible{outline:none;box-shadow:0 0 0 2px var(--bg-card),0 0 0 4px var(--accent)}.mode-card:disabled{opacity:.7;cursor:not-allowed}.mode-card__icon{opacity:.6;color:var(--text-muted);flex:0 0 auto;margin-top:.05rem}.mode-card__text{display:flex;flex-direction:column;gap:.2rem;min-width:0}.mode-card__title{font-weight:600;font-size:1.05rem;color:var(--text)}.mode-card__desc{font-size:.85rem;color:var(--text-muted)}.modal__radio{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;color:var(--text);cursor:pointer}.modal__radio input{width:1rem;height:1rem}.modal__input{width:100%;padding:.5rem .75rem;font-size:.9375rem;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text)}.modal__input:focus{outline:none;border-color:var(--accent)}.modal__input:disabled{opacity:.7}select.modal__input{padding-right:2.25rem;-webkit-appearance:none;-moz-appearance:none;appearance:none}.add-theme-url-list__switch{display:flex;gap:.5rem;margin-bottom:.75rem}.add-theme-url-list__switch-btn{padding:.4rem .75rem;font-size:.875rem;font-weight:500;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text-muted);cursor:pointer;transition:border-color .2s,background .2s,color .2s}.add-theme-url-list__switch-btn:hover:not(:disabled){border-color:var(--accent);color:var(--text)}.add-theme-url-list__switch-btn--active{border-color:var(--accent);background:#7c3aed1f;color:var(--accent)}.add-theme-url-list__textarea{font-family:ui-monospace,monospace;font-size:.875rem}.add-theme-url-list{display:flex;flex-direction:column;gap:.75rem}.add-theme-url-list__row{display:flex;align-items:center;gap:.5rem}.add-theme-url-list__row .add-theme-url-list__input{flex:1;min-width:0}.add-theme-url-list__remove{flex-shrink:0;width:2.25rem;height:2.25rem;min-width:2.25rem;min-height:2.25rem;padding:0;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text-muted);font-size:1.25rem;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:border-color .2s,background .2s,color .2s}.add-theme-url-list__remove:hover:not(:disabled){border-color:#ef444480;background:#ef44441a;color:#f87171}.add-theme-url-list__remove:disabled{opacity:.5;cursor:not-allowed}.add-theme-url-list__add{margin-top:.25rem}.modal__textarea{width:100%;padding:.5rem .75rem;font-size:.9375rem;font-family:inherit;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);resize:vertical}.modal__textarea:focus{outline:none;border-color:var(--accent)}.modal__textarea:disabled{opacity:.7}.modal__textarea::placeholder{color:var(--text-muted)}textarea{scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.6) transparent}textarea::-webkit-scrollbar{width:4px}textarea::-webkit-scrollbar-track{background:transparent}textarea::-webkit-scrollbar-thumb{background:#0009;border-radius:2px}textarea::-webkit-scrollbar-thumb:hover{background:#000000bf}.modal__textarea--prompt{height:200px;min-height:200px;resize:vertical}.modal__hint{display:block;margin-top:.35rem;font-size:.8125rem;color:var(--text-muted)}.modal__hint--above{margin-top:.25rem;margin-bottom:.5rem}.modal__error{margin:0 0 1rem;font-size:.875rem;color:#f87171}.modal__error-bottom{margin:.75rem -1.5rem 0;padding:.75rem 1.5rem 0;border-top:1px solid var(--border);font-size:.875rem;color:#f87171}.modal__footer{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border);margin-left:-1.5rem;margin-right:-1.5rem;padding-left:1.5rem;padding-right:1.5rem}.modal__footer--with-back{justify-content:space-between}.modal__btn{padding:.5rem 1rem;font-size:.875rem;font-weight:500;border-radius:6px;cursor:pointer;transition:background .2s,border-color .2s,opacity .2s}.modal__btn:disabled{opacity:.6;cursor:not-allowed}.modal__btn--primary{border:1px solid var(--accent);background:var(--accent);color:#fff}.modal__btn--primary:hover:not(:disabled){background:#6d28d9;border-color:#6d28d9}.modal__btn--secondary{border:1px solid var(--border);background:transparent;color:var(--text)}.modal__btn--secondary:hover:not(:disabled){background:var(--bg);border-color:#3f3f46}.modal__btn--copy{margin-top:.5rem}.modal__btn--danger{border:1px solid #dc2626;background:#dc2626;color:#fff}.modal__btn--danger:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c}.modal__confirm-text{margin:0 0 .5rem;font-size:.9375rem;color:var(--text)}.modal__confirm-summary{margin:0 0 1rem;font-size:.875rem;color:var(--text-muted);font-style:italic}.theme-card__btn--delete{color:var(--text-muted)}.theme-card__btn--delete:hover:not(:disabled){border-color:#dc2626;color:#dc2626}.categories-page{padding:0 1.5rem 2rem;max-width:900px;margin-left:auto;margin-right:auto}.categories-page__form{margin:3rem 0 2rem;padding:1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:12px}.categories-page__form-row{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end}.categories-page__form-row .theme-detail__field{flex:1;min-width:140px}.categories-page__input{width:100%;padding:.5rem .75rem;font-size:.9375rem;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:8px;box-sizing:border-box}.categories-page__input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.categories-page__form-actions{flex-shrink:0}.categories-page__list{display:flex;flex-direction:column;gap:.75rem}.categories-page__card{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:12px}.categories-page__card-preview{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg);border-radius:8px;overflow:hidden}.categories-page__card-icon{width:100%;height:100%;object-fit:contain}.categories-page__card-icon-placeholder{font-size:.875rem;color:var(--text-muted)}.categories-page__card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.categories-page__card-id{font-size:.6875rem;font-family:ui-monospace,monospace;color:var(--text-muted);line-height:1.2}.categories-page__card-name{font-size:1rem;font-weight:500;color:var(--text);line-height:1.2}.categories-page__delete{flex-shrink:0;width:36px;height:36px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:8px;background:var(--bg-card-hover);color:var(--text-muted);cursor:pointer;transition:border-color .2s,background .2s,color .2s}.categories-page__delete:hover:not(:disabled){background:#ffffff0f;border-color:#3f3f46;color:var(--text)}.categories-page__delete:disabled{opacity:.7;cursor:not-allowed}.categories-page__delete-icon{display:block}.categories-page__delete-text{font-size:.8125rem;color:inherit}.jobs-page{padding:1.5rem 0 2rem;width:100%;max-width:100%;min-width:0}.jobs-page__header{display:flex;align-items:center;justify-content:flex-end;gap:1rem;margin-bottom:1.25rem}.jobs-page__title{margin:0;font-size:1.5rem;font-weight:600;color:var(--text)}.jobs-page__refresh-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;min-width:36px;min-height:36px;padding:0;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--text-muted);cursor:pointer;transition:color .2s,background .2s,border-color .2s}.jobs-page__refresh-btn:hover:not(:disabled){color:var(--text);border-color:var(--accent);background:#7c3aed14}.jobs-page__refresh-btn:disabled{opacity:.6;cursor:not-allowed}.jobs-page__refresh-btn svg{display:block}.jobs-page__empty{margin:0;padding:2rem;font-size:.9375rem;color:var(--text-muted)}.jobs-page__table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:10px;background:var(--bg-card)}.jobs-table{width:100%;border-collapse:collapse;font-size:.9375rem}.jobs-table th,.jobs-table td{padding:.65rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.jobs-table th{font-weight:600;color:var(--text-muted);background:#0003;white-space:nowrap}.jobs-table tbody tr:last-child td{border-bottom:none}.jobs-table tbody tr:hover{background:#ffffff08}.jobs-table__id{font-family:ui-monospace,monospace;font-size:.8125rem;max-width:12rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.jobs-table__status{display:inline-block;padding:.2rem .5rem;border-radius:6px;font-size:.8125rem;font-weight:500}.jobs-table__status--queued{background:#8b5cf633;color:var(--accent)}.jobs-table__status--processing{background:#eab30833;color:#eab308}.jobs-table__status--completed{background:#22c55e33;color:#22c55e}.jobs-table__status--failed{background:#ef444433;color:#ef4444}.jobs-table__th--variations,.jobs-table__variations{text-align:center}.jobs-table__date{white-space:nowrap;color:var(--text-muted);font-size:.875rem}.jobs-table__theme{vertical-align:middle}.jobs-table__theme-cell{display:flex;align-items:center;gap:.75rem;min-width:0}.jobs-table__theme-img{flex-shrink:0;width:auto;height:100px;object-fit:cover;border-radius:10px;border:1px solid var(--border)}.jobs-table__theme-placeholder{flex-shrink:0;width:56px;height:100px;background:var(--border);border-radius:10px}.jobs-table__theme-title{flex:1;min-width:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.35;font-size:.875rem;color:var(--text)}.transactions-page{padding:1.5rem 0 2rem;width:100%;max-width:100%;min-width:0}.transactions-page__header{display:flex;align-items:center;justify-content:flex-end;gap:1rem;margin-bottom:1.25rem}.transactions-page__refresh-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;min-width:36px;min-height:36px;padding:0;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--text-muted);cursor:pointer;transition:color .2s,background .2s,border-color .2s}.transactions-page__refresh-btn:hover:not(:disabled){color:var(--text);border-color:var(--accent);background:#7c3aed14}.transactions-page__refresh-btn:disabled{opacity:.6;cursor:not-allowed}.transactions-page__refresh-btn svg{display:block}.transactions-page__empty{margin:0;padding:2rem;font-size:.9375rem;color:var(--text-muted)}.transactions-page__table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:10px;background:var(--bg-card)}.transactions-table{width:100%;border-collapse:collapse;font-size:.9375rem}.transactions-table th,.transactions-table td{padding:.65rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.transactions-table th{font-weight:600;color:var(--text-muted);background:#0003;white-space:nowrap}.transactions-table tbody tr:last-child td{border-bottom:none}.transactions-table tbody tr:hover{background:#ffffff08}.transactions-table__id{font-family:ui-monospace,monospace;font-size:.8125rem;max-width:10rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transactions-table__user{max-width:12rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.875rem}.transactions-table__type{display:inline-block;padding:.2rem .5rem;border-radius:6px;font-size:.8125rem;font-weight:500}.transactions-table__type--purchase{background:#22c55e33;color:#22c55e}.transactions-table__type--spend{background:#eab30833;color:#eab308}.transactions-table__type--refund{background:#3b82f633;color:#3b82f6}.transactions-table__type--adjustment{background:#8b5cf633;color:var(--accent)}.transactions-table__amount{font-weight:600;font-variant-numeric:tabular-nums}.transactions-table__amount--plus{color:#22c55e}.transactions-table__amount--minus{color:var(--text-muted)}.transactions-table__ref{font-family:ui-monospace,monospace;font-size:.8125rem;max-width:10rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-muted)}.transactions-table__date{white-space:nowrap;color:var(--text-muted);font-size:.875rem}.analytics-page{display:flex;flex-direction:column;gap:1rem;width:100%}.analytics-page__header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.analytics-page__title{margin:0;font-size:1.25rem;font-weight:600;color:var(--text)}.analytics-page__refresh-btn{padding:.5rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);cursor:pointer;transition:background .2s,border-color .2s}.analytics-page__refresh-btn:hover:not(:disabled){background:#ffffff0f;border-color:#3f3f46}.analytics-page__refresh-btn:disabled{opacity:.6;cursor:not-allowed}.analytics-page__empty{margin:0;padding:2rem;color:var(--text-muted)}.analytics-page__table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:8px;background:var(--bg-card)}.analytics-table{width:100%;border-collapse:collapse;font-size:.9375rem}.analytics-table th,.analytics-table td{padding:.65rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.analytics-table th{font-weight:600;color:var(--text-muted);background:#0003}.analytics-table tbody tr:last-child td{border-bottom:none}.analytics-table tbody tr:hover{background:#ffffff08}.analytics-table__ref{font-weight:500;max-width:14rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.analytics-table__action{display:inline-block;padding:.2rem .5rem;border-radius:6px;font-size:.8125rem;font-weight:500;background:#8b5cf633;color:var(--accent)}.analytics-table__user{font-family:ui-monospace,monospace;font-size:.8125rem;max-width:12rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-muted)}.analytics-table__date{white-space:nowrap;color:var(--text-muted);font-size:.875rem}.app__main{flex:1;min-height:0;display:flex;flex-direction:column;width:100%;max-width:100%;margin:0;padding:0 1.5rem;box-sizing:border-box}.app__state{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.app__state--loading{flex:1;min-height:12rem;display:flex;align-items:center;justify-content:center;padding:2rem}.app__state--loading .app__spinner{margin:0}.app__state--error{color:#f87171}.app__hint{margin-top:1rem;font-size:.875rem;color:var(--text-muted)}.app__hint code{padding:.15em .4em;background:var(--bg-card);border-radius:4px;font-size:.9em}.app__spinner{width:40px;height:40px;margin:0 auto 1rem;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.prompts-by-type{display:flex;flex-direction:column;align-items:center;gap:2rem;margin-top:3rem;width:100%}.prompts-by-type .prompts-section{width:800px;max-width:100%}.prompts-section{border:1px solid var(--border);border-radius:10px;background:var(--bg-card);overflow:hidden;min-width:0}.prompts-section__header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.9rem 1.25rem;background:#0003;border-bottom:1px solid var(--border)}.prompts-section__header-text{display:flex;flex-direction:column;gap:.25rem;min-width:0}.prompts-section__title{margin:0;font-size:1.0625rem;font-weight:600;color:var(--text)}.prompts-section__description{margin:0;font-size:.8125rem;color:var(--text-muted);opacity:.68;line-height:1.35}.prompts-section__add-btn{margin:0;flex-shrink:0;padding:.45rem .9rem;font-size:1rem}.prompts-section__checkbox{display:inline-flex;align-items:center;gap:.5rem;font-size:.9375rem;color:var(--text);cursor:pointer}.prompts-section__checkbox input{width:1rem;height:1rem}.prompts-section__empty{margin:0;padding:1.25rem;font-size:.9375rem;color:var(--text-muted)}.prompts-list{margin:0;padding:0;list-style:none}.prompts-list__item{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:.9rem 1.25rem;border-bottom:1px solid var(--border);cursor:pointer;transition:background .2s}.prompts-list__item:hover{background:#8b5cf60f}.prompts-list__item:focus{outline:none}.prompts-list__item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.prompts-list__actions{display:flex;flex-shrink:0;gap:.5rem}.prompts-list__item:last-child{border-bottom:none}.prompts-list__content{flex:1;min-width:0;display:flex;flex-direction:column;align-items:flex-start;gap:.35rem;padding:.15rem 0}.prompts-list__content-top{display:flex;align-items:center;gap:.75rem;min-width:0;width:100%}.prompts-list__content-top .prompts-list__text{flex:1;min-width:0}.prompts-list__text{font-size:.9375rem;color:var(--text);white-space:pre-wrap;word-break:break-word;transition:color .2s}.prompts-list__date{font-size:.75rem;color:var(--text-muted);opacity:.68}.prompts-list__badge{flex-shrink:0;padding:.2rem .5rem;font-size:.75rem;font-weight:600;color:var(--accent);background:#8b5cf626;border-radius:4px}.prompts-list__btn{flex-shrink:0;padding:.4rem .75rem;font-size:.75rem;font-weight:500;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);cursor:pointer;transition:border-color .2s,background .2s}.prompts-list__btn:hover:not(:disabled){border-color:var(--accent);background:#8b5cf614;color:var(--accent)}.prompts-list__btn:disabled{opacity:.7;cursor:not-allowed}.prompts-list__btn[aria-pressed=true]{border-color:var(--accent);background:#8b5cf61f;color:var(--accent)}.prompts-view__default-badge{margin:0 0 .75rem;padding:.35rem .6rem;font-size:.8rem;font-weight:600;color:var(--accent);background:#8b5cf61f;border-radius:6px;display:inline-block}.prompts-view__full-text{margin:0 0 1rem;padding:1rem;font-size:.875rem;font-family:inherit;line-height:1.5;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:6px;white-space:pre-wrap;word-break:break-word;max-height:50vh;overflow:auto}.themes-grid{display:grid;grid-template-columns:repeat(auto-fill,300px);gap:1.5rem;margin-top:1.5rem}.themes-load-more-sentinel{min-height:1px;margin-top:1rem}.theme-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:background .2s,border-color .2s}.theme-card:hover{background:var(--bg-card-hover);border-color:#3f3f46}.theme-card--clickable{cursor:pointer}.theme-card__image-wrap{aspect-ratio:9 / 16;background:var(--bg);position:relative;min-height:0}.theme-card__image{width:100%;height:100%;object-fit:cover}.theme-card__placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.875rem}.theme-card--loading .theme-card__image-wrap{position:relative}.theme-card--loading .theme-card__placeholder{z-index:0}.theme-card__loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;display:flex;align-items:center;justify-content:center;background:linear-gradient(110deg,#0d0d0fd9,#0d0d0fd9 40%,#ffffff0f,#0d0d0fd9 60%,#0d0d0fd9);background-size:200% 100%;animation:theme-card-shimmer 1.5s ease-in-out infinite}.theme-card__loading-wrap{display:flex;align-items:center;justify-content:center}.theme-card__spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:theme-card-spin .8s linear infinite}@keyframes theme-card-shimmer{to{background-position:200% 0}}@keyframes theme-card-spin{to{transform:rotate(360deg)}}.theme-card__body{padding:1rem 1.25rem}.theme-card__description{margin:0 0 .5rem;font-size:.9375rem;color:var(--text);line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:3em}.theme-card__model-chip{display:inline-block;margin:0 0 .5rem;padding:.15rem .4rem;font-size:.625rem;font-weight:500;color:var(--text-muted);border:1px solid var(--border);border-radius:6px;background:var(--bg)}.theme-card__prompt-id{margin:-.15rem 0 .65rem;font-size:.75rem;color:var(--text-muted)}.theme-card__meta{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.5rem 1rem}.theme-card__actions{display:flex;flex-wrap:wrap;gap:.5rem}.theme-card__btn{padding:.35rem .65rem;font-size:.6875rem;font-weight:500;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);cursor:pointer;transition:background .2s,border-color .2s}.theme-card__btn-icon{width:13px;height:13px}.theme-card__btn:hover:not(:disabled){background:var(--bg-card-hover);border-color:#3f3f46}.theme-card__btn:disabled{opacity:.6;cursor:not-allowed}.theme-card__switch{position:relative;display:inline-flex;align-items:center;cursor:pointer;flex-shrink:0}.theme-card__switch-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.theme-card__switch-track{position:relative;display:block;width:2.5rem;height:1.25rem;border-radius:999px;background:var(--bg);border:1px solid var(--border);transition:background .2s,border-color .2s,box-shadow .2s}.theme-card__switch-track:after{content:"";position:absolute;top:2px;left:2px;width:1rem;height:1rem;border-radius:50%;background:var(--text-muted);transition:transform .2s,background .2s}.theme-card__switch-input:checked+.theme-card__switch-track{background:#7c3aed40;border-color:var(--accent)}.theme-card__switch-input:checked+.theme-card__switch-track:after{transform:translate(1.25rem);background:var(--accent)}.theme-card__switch-input:focus-visible+.theme-card__switch-track{box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--accent)}.theme-card__switch-input:disabled+.theme-card__switch-track{opacity:.6;cursor:not-allowed}.theme-card__switch--busy .theme-card__switch-track:after{opacity:.8}.theme-card__btn--regen,.theme-card__btn--delete{width:28px;height:28px;padding:0;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.theme-card__btn--regen .theme-card__btn-icon,.theme-card__btn--delete .theme-card__btn-icon{display:block}.theme-card__btn--regen:not(:disabled):hover,.theme-card__btn--view:hover{border-color:var(--accent);color:var(--accent)}.theme-card--enabled{border-color:#7c3aed66}.theme-card__regen-wrap{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;background:#0d0d0fd9;color:var(--text-muted);font-size:.875rem}.theme-card__spinner{width:32px;height:32px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.theme-card__regen-label{font-size:.8125rem}.models-page{flex:1;display:flex;justify-content:center;padding:3rem 0;min-height:0}.models-page .models-grid{display:grid;grid-template-columns:repeat(2,375px);gap:1.5rem;max-width:100%;height:max-content}.models-card{width:375px;box-sizing:border-box;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:.85rem 1.25rem 1.25rem;display:flex;flex-direction:column;align-items:stretch;gap:.75rem}.models-card__header{margin-left:-1.25rem;margin-right:-1.25rem;padding-left:1.25rem;padding-right:1.25rem;padding-bottom:.75rem;margin-bottom:0;border-bottom:1px solid var(--border)}.models-card__title{margin:0;font-size:1.125rem;font-weight:600;color:var(--text)}.models-card__hint{margin:.2rem 0 0;font-size:.8125rem;color:var(--text-muted)}.models-card__preview{aspect-ratio:9 / 16;background:var(--bg);border-radius:8px;overflow:hidden;border:1px solid var(--border)}.models-card__img{width:100%;height:100%;object-fit:cover;display:block}.models-card__file-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.models-card__btn{margin-top:.25rem;padding:.45rem .9rem;font-size:1rem}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23ffffff' d='M6 9L1 4h10z'/%3E%3C/svg%3E")!important;background-repeat:no-repeat!important;background-position:right .5rem center!important;background-size:12px}:root{--bg: #0d0d0f;--bg-card: #16161a;--bg-card-hover: #1c1c21;--text: #e4e4e7;--text-muted: #a1a1aa;--border: #27272a;--accent: #7c3aed}*,*:before,*:after{box-sizing:border-box;font-family:Figtree,system-ui,-apple-system,sans-serif}body{margin:0;font-family:Figtree,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5}#root{min-height:100vh}img{max-width:100%;height:auto;display:block}
