:root{font-family:Elms Sans,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color-scheme:light dark}body{margin:0;min-height:100vh;background:#000;color:#f1f5f9}#root{min-height:100vh;display:flex;flex-direction:column}main{flex:1;display:block;padding:2rem 1rem}main>*{margin-left:auto;margin-right:auto}h1,h2{font-weight:400}input[type=datetime-local]{color-scheme:dark}input[type=datetime-local]::-webkit-calendar-picker-indicator{cursor:pointer}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:linear-gradient(90deg,#0d1422,#161f33 55%,#243149);border-bottom:1px solid #1f2937;position:sticky;top:0;z-index:10;opacity:.9}.app-header__brand{font-size:1.25rem;letter-spacing:.02em;color:#f8fafc}.app-header__nav{display:flex;align-items:center;gap:1.25rem}.app-header__nav a{color:#cbd5e1;text-decoration:none;font-size:.95rem}.app-header__nav a:hover{color:#fff}.app-header__signout{padding:.4rem .9rem;border:0;border-radius:6px;background:#ef4444;color:#fff;cursor:pointer;font-size:.9rem}.app-header__signout:hover{background:#dc2626}.card{background:linear-gradient(180deg,#243149,#161f33 55%,#0d1422);border:1px solid #1f2c45;padding:1rem 2.5rem;border-radius:12px;text-align:center;min-width:320px}.avatar{width:72px;height:72px;border-radius:50%;margin-bottom:.75rem}button.signout{margin-top:1rem;padding:.5rem 1rem;border:0;border-radius:6px;background:#ef4444;color:#fff;cursor:pointer}button.signout:hover{background:#dc2626}.error{color:#fca5a5;margin-top:1rem;font-size:.9rem}.legal{max-width:760px;width:100%;background:#1e293b;padding:2.5rem 2.75rem;border-radius:12px;box-shadow:0 10px 30px #0006;line-height:1.6}.legal__header{margin-bottom:1.5rem}.legal__header h1{margin:0 0 .25rem}.legal__effective{color:#94a3b8;font-size:.9rem;margin:0 0 .75rem}.legal h2{margin-top:1.75rem;margin-bottom:.5rem;font-size:1.1rem;color:#e2e8f0}.legal ul{padding-left:1.25rem}.legal li{margin:.25rem 0}.legal a{color:#93c5fd}.legal__back{margin-top:2rem}.browse{width:100%;max-width:960px}.browse__title{margin:0 0 .5rem;text-align:center}.browse__subtitle{margin:0 0 1.75rem;text-align:center;color:#94a3b8}.browse__grid{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.category-chip{display:inline-flex;align-items:center;justify-content:center;padding:.6rem 1.25rem;border-radius:9999px;background:#1e293b;color:#e2e8f0;text-decoration:none;font-size:.95rem;font-weight:500;border:1px solid #334155;transition:background .15s ease,border-color .15s ease,transform .05s ease}.category-chip:hover{background:#334155;border-color:#475569}.category-chip:active{transform:translateY(1px)}.category-picker{display:flex;flex-wrap:wrap;gap:.5rem}.category-chip--toggle{background:transparent;font:inherit;cursor:pointer}.category-chip--selected{background:#2563eb;border-color:#3b82f6;color:#fff}.category-chip--selected:hover{background:#1d4ed8;border-color:#2563eb}.form-card{width:560px;max-width:560px;background:linear-gradient(180deg,#243149,#161f33 55%,#0d1422);border:1px solid #1f2c45;padding:2rem 2.25rem;border-radius:12px;box-shadow:0 10px 30px #0006;display:flex;flex-direction:column;gap:1rem}.form-card h1{margin:0 0 .5rem}.form-page__title{width:100%;max-width:560px;margin:0 0 .75rem}.upload-layout{width:100%;display:flex;flex-direction:column;align-items:center}.upload-layout,.upload-layout textarea,.upload-layout .field select,.upload-layout pre{scrollbar-width:thin;scrollbar-color:#334155 #0f172a}.upload-layout *::-webkit-scrollbar,.upload-layout textarea::-webkit-scrollbar,.upload-layout .field select::-webkit-scrollbar{width:10px;height:10px}.upload-layout *::-webkit-scrollbar-track,.upload-layout textarea::-webkit-scrollbar-track,.upload-layout .field select::-webkit-scrollbar-track{background:#0f172a;border-radius:8px}.upload-layout *::-webkit-scrollbar-thumb,.upload-layout textarea::-webkit-scrollbar-thumb,.upload-layout .field select::-webkit-scrollbar-thumb{background:#334155;border-radius:8px;border:2px solid #0f172a}.upload-layout *::-webkit-scrollbar-thumb:hover,.upload-layout textarea::-webkit-scrollbar-thumb:hover,.upload-layout .field select::-webkit-scrollbar-thumb:hover{background:#2563eb}.upload-layout *::-webkit-scrollbar-corner{background:#0f172a}.upload-layout--with-preview{display:grid;grid-template-columns:auto auto;justify-content:center;gap:2rem;align-items:start;max-width:1400px}.upload-layout--with-preview .upload-layout__form{justify-self:center;width:100%;max-width:560px}.upload-layout--with-preview .form-page__title{margin-left:0;margin-right:0}.upload-layout__preview{position:sticky;top:5rem;display:flex;justify-content:center}.upload-layout__preview img{max-width:100%;max-height:calc(100vh - 6rem);border-radius:12px;background:#0b1220;box-shadow:0 10px 30px #0006}@media (max-width: 1000px){.upload-layout--with-preview{grid-template-columns:1fr}.upload-layout--with-preview .upload-layout__form{justify-self:center}.upload-layout__preview{position:static;justify-content:center}}.field{display:flex;flex-direction:column;gap:.35rem}.field--row{flex-direction:row;gap:.75rem}.field--row>.field{flex:1}.upload-file-row{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-top:.6rem}.upload-file-row>input{flex:1;min-width:0}.upload-file-thumb{width:52px;height:52px;object-fit:cover;border-radius:4px;flex:0 0 auto;display:block}.upload-file-thumb-wrap{position:relative;flex:0 0 auto}.upload-file-thumb-remove{position:absolute;top:-6px;right:-6px;width:18px;height:18px;padding:0;border:none;border-radius:50%;background:#000000b3;color:#fff;font-size:13px;line-height:18px;text-align:center;cursor:pointer}.upload-file-thumb-remove:hover{background:#000000e6}.home-gallery{width:100%;max-width:1700px;margin-top:3rem}.home-gallery__title{margin:0 0 1rem}.home-gallery .gallery{justify-content:center}.toggle{display:inline-flex;align-items:center;gap:.6rem;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle__input{position:absolute;opacity:0;pointer-events:none;width:0;height:0}.toggle__track{position:relative;width:44px;height:24px;background:#334155;border-radius:999px;transition:background .15s ease;flex-shrink:0}.toggle__thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#f1f5f9;border-radius:50%;transition:transform .15s ease}.toggle__input:checked+.toggle__track{background:#2563eb}.toggle__input:checked+.toggle__track .toggle__thumb{transform:translate(20px)}.toggle__input:focus-visible+.toggle__track{outline:2px solid #60a5fa;outline-offset:2px}.toggle__label{font-size:.9rem;color:#f1f5f9}.field span{font-size:.85rem;color:#cbd5e1}.field--collapsible>summary{font-size:.85rem;color:#cbd5e1;cursor:pointer;-webkit-user-select:none;user-select:none;list-style:revert;padding:.15rem 0}.field--collapsible>summary:hover{color:#e2e8f0}.field--collapsible[open]>summary{margin-bottom:.35rem}.field--collapsible--empty>summary{color:#64748b;opacity:.6}.field input,.field textarea,.field select{background:#0f172a;color:#f1f5f9;border:1px solid #334155;border-radius:6px;padding:.55rem .7rem;font:inherit;width:100%;box-sizing:border-box}.field select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none' stroke='%23cbd5e1' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='1,1.5 6,6.5 11,1.5'/></svg>");background-repeat:no-repeat;background-position:right .7rem center;background-size:.7rem;padding-right:1.9rem;cursor:pointer}.field select option{background:#0f172a;color:#f1f5f9}.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:#60a5fa}.btn-primary{align-self:flex-start;padding:.6rem 1.1rem;background:#2563eb;color:#fff;border:0;border-radius:6px;cursor:pointer;font-weight:500;text-decoration:none;display:inline-block;font-family:inherit}.btn-primary:hover{background:#1d4ed8}.btn-primary:disabled{background:#475569;cursor:not-allowed}.field input[type=file]{padding:.35rem .5rem;cursor:pointer}.field input[type=file]::file-selector-button{margin-right:.75rem;padding:.5rem 1rem;background:#2563eb;color:#fff;border:0;border-radius:6px;cursor:pointer;font:inherit;font-weight:500}.field input[type=file]::file-selector-button:hover{background:#1d4ed8}.your-prompts{width:100%;max-width:1064px;justify-self:stretch}.your-prompts__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.search{width:100%;max-width:1700px}.search-layout{display:grid;grid-template-columns:minmax(280px,612px) minmax(0,1fr);gap:1.5rem;align-items:start;width:100%;justify-self:stretch}.search-layout__form{margin:0;width:100%;max-width:530px}.search-layout__results{min-width:0}@media (max-width: 800px){.search-layout{grid-template-columns:1fr}}.gallery{display:grid;grid-template-columns:repeat(auto-fill,200px);gap:1rem}.thumb{position:relative;display:block;background:#1e293b;border-radius:10px;overflow:hidden;text-decoration:none;color:inherit;border:1px solid #1f2937;transition:transform .1s ease,border-color .1s ease}.thumb:hover{border-color:#475569}.thumb img{display:block;width:200px;height:200px;object-fit:cover}.thumb__caption{position:absolute;top:0;right:0;bottom:0;left:0;padding:.75rem;font-size:.85rem;background:#0f172ad9;color:#f1f5f9;overflow:hidden;white-space:pre-wrap;transform:translateY(100%);transition:transform .25s ease;pointer-events:none}.thumb:hover .thumb__caption,.thumb:focus-visible .thumb__caption{transform:translateY(0)}.thumb--album{width:200px;height:200px;display:flex;align-items:center;justify-content:center;text-align:center;font-size:1rem;background:#1f2937}.thumb--album .thumb__caption{position:static;background:transparent;transform:none;padding:0;font-size:1rem}.image-detail{width:100%;max-width:1700px;display:grid;grid-template-columns:minmax(0,1fr);gap:1.5rem}@media (min-width: 800px){.image-detail{grid-template-columns:minmax(0,3fr) minmax(0,2fr)}.image-detail .comments{grid-column:1 / -1}}@media (min-width: 1200px){.image-detail{grid-template-columns:minmax(0,3fr) minmax(0,2fr) minmax(0,2fr)}.image-detail .comments{grid-column:3 / 4}}.image-detail__image{width:100%;border-radius:12px;background:#0b1220}.image-detail__left{display:flex;flex-direction:column;gap:.75rem;align-self:stretch;height:100%}.image-detail .comments{background:linear-gradient(180deg,#22304a,#141d30 55%,#0c1320);padding:1.25rem 1.5rem;border-radius:12px;border:1px solid #1f2c45;box-shadow:0 10px 30px #00000040;align-self:start}.image-detail__title{margin:0;font-size:1.5rem;line-height:1.2}.image-detail__image-wrap{position:sticky;top:5rem}.image-detail__viewport{container-type:inline-size;overflow:hidden;width:100%}.image-detail__track{display:flex;align-items:center;transform:translate(calc(15cqw - 70cqw * var(--i, 0)));transition:transform .35s ease}.image-detail__track--single{transform:none;justify-content:flex-end}.image-detail__slide{flex:0 0 70cqw;display:flex;justify-content:center;opacity:.45;transform:scale(.85);transition:opacity .35s ease,transform .35s ease;cursor:pointer}.image-detail__track--single .image-detail__slide{flex-basis:100%}.image-detail__slide.is-active{opacity:1;transform:scale(1);cursor:zoom-in}.image-detail__slide .image-detail__image{width:auto;max-width:100%;max-height:calc(100vh - 6rem);object-fit:contain;display:block}.image-detail__track--single .image-detail__slide .image-detail__image{margin-left:auto;margin-right:0}.image-detail__expand{position:absolute;top:.6rem;right:.6rem;width:36px;height:36px;border-radius:8px;border:0;background:#0f172ab3;color:#f1f5f9;font-size:1.1rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.image-detail__expand:hover{background:#1e293be6}.image-detail__nav{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;border:0;background:#0f172ab3;color:#f1f5f9;font-size:1.5rem;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.image-detail__nav:hover{background:#1e293be6}.image-detail__nav--prev{left:.6rem}.image-detail__nav--next{right:.6rem}.image-detail__counter{position:absolute;bottom:.6rem;left:50%;transform:translate(-50%);padding:.2rem .6rem;border-radius:999px;background:#0f172ab3;color:#f1f5f9;font-size:.8rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.image-detail__actions{display:inline;float:right;gap:.5rem;margin-bottom:.75rem;justify-content:flex-end}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;padding:.45rem .9rem;border-radius:8px;background:#334155;color:#f1f5f9;border:1px solid #3f4c65;cursor:pointer;font-size:.9rem;text-decoration:none;font-family:inherit}.btn-secondary:hover{background:#475569}.form-card__actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:0;margin-bottom:-1rem}.btn-danger{padding:.45rem .9rem;border-radius:8px;background:#b91c1c;color:#fff;border:0;cursor:pointer;font-size:.9rem;font-family:inherit}.btn-danger:hover{background:#991b1b}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.image-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;display:grid;place-items:center;z-index:100;cursor:zoom-out;animation:image-overlay-in .2s ease forwards}.image-overlay--closing{animation:image-overlay-out .2s ease forwards}.image-overlay__image{width:100%;height:100%;cursor:zoom-out;padding:0;margin:0;animation:image-overlay-image-in .2s ease forwards;object-position:left 50% top 50%;position:absolute;left:0;top:0;object-fit:contain;z-index:-1}.image-overlay--closing .image-overlay__image{animation:image-overlay-image-out .2s ease forwards}@keyframes image-overlay-image-out{0%{opacity:1}to{opacity:0}}@keyframes image-overlay-in{0%{opacity:0}to{opacity:1}}@keyframes image-overlay-out{0%{opacity:1}to{opacity:0}}@keyframes image-overlay-image-in{0%{opacity:0}to{opacity:1}}.image-overlay__image--next,.image-overlay__image--prev{animation:image-overlay-image-in .2s ease forwards}.image-overlay__image--out-next,.image-overlay__image--out-prev{animation:image-overlay-image-out .2s ease forwards}.image-overlay__close{position:fixed;top:1rem;right:1rem;width:40px;height:40px;border-radius:50%;border:0;background:#1e293bd9;color:#f1f5f9;font-size:1.5rem;line-height:1;cursor:pointer}.image-overlay__close:hover{background:#1e293b}.image-overlay__nav{position:fixed;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;border:0;background:#1e293bd9;color:#f1f5f9;font-size:2rem;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.image-overlay__nav:hover{background:#1e293b}.image-overlay__nav--prev{left:1.5rem}.image-overlay__nav--next{right:1.5rem}.image-detail__meta{background:linear-gradient(180deg,#243149,#161f33 55%,#0d1422);padding:1.25rem 1.5rem;border-radius:12px;border:1px solid #1f2c45;box-shadow:0 10px 30px #00000040}.image-detail__prompt{font-size:1rem;line-height:1.5;margin:4px 0 1rem}.kv{margin:2rem 0 1rem}.kv-row{border-bottom:1px solid #1e293b}.kv-row>summary{cursor:pointer;-webkit-user-select:none;user-select:none;list-style:revert;color:#94a3b8;font-size:.85rem;padding:.5rem 0}.kv-row>summary:hover{color:#cbd5e1}.kv-row__value{font-size:.9rem;max-width:100%;word-break:break-word;padding:0 0 .6rem 1rem}.kv-flags{padding:.75rem 0 .25rem}.kv-details>summary{cursor:pointer;-webkit-user-select:none;user-select:none;color:#cbd5e1;font-size:.9rem;padding:.4rem 0;list-style:revert}.kv-details>.kv{margin-top:.75rem}.muted{color:#94a3b8}.chips{display:flex;flex-wrap:wrap;gap:.4rem;margin:.5rem 0;align-items:center}.chips__label{color:#94a3b8;font-size:.8rem;margin-right:.25rem}.chip{background:#1e293b;border:1px solid #475569;color:#e2e8f0;padding:.2rem .6rem;border-radius:9999px;font-size:.8rem}.chip--alt{background:#1f2937;border:1px solid #334155}.btn-copy{display:inline;margin:.25rem auto .75rem}.chip--link{text-decoration:none;cursor:pointer;transition:background .15s ease,color .15s ease}.chip--link:hover{background:#334155;border-color:#475569;color:#fff}.stars{display:inline-flex;gap:2px}.star{background:none;border:0;color:#475569;font-size:1.1rem;cursor:pointer;padding:0;line-height:1}.star--on{color:#facc15}.my-rating{margin-top:.75rem}.image-detail__rating{background:#1e293b;padding:1.25rem 1.5rem;border-radius:12px;border:1px solid #2f3c55}.image-detail__rating h2{margin:0 0 .75rem;font-size:1.1rem}.image-detail__comments{background:#1e293b;padding:1.25rem 1.5rem;border-radius:12px;border:1px solid #2f3c55;margin-top:2rem}.image-detail__comments h2{margin:0 0 .75rem;font-size:1.1rem}.image-detail__comments__list{list-style:none;padding:0;margin:0 0 1rem;display:flex;flex-direction:column;gap:.75rem}.image-detail__comment{border-top:1px solid #334155;padding-top:.75rem}.image-detail__comment:first-child{border-top:0;padding-top:0}.image-detail__comment__author{font-size:.85rem;color:#cbd5e1;margin-bottom:.2rem}.comment-form{display:flex;flex-direction:column;gap:.5rem}.comment-form textarea{background:#0f172a;color:#f1f5f9;border:1px solid #334155;border-radius:6px;padding:.55rem .7rem;font:inherit}
