:root{font-family:Inter,Microsoft YaHei UI,PingFang SC,system-ui,sans-serif;color:#1f2329;background:#f5f6f8;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{min-width:320px;margin:0;background:#f5f6f8}button,input,textarea{font:inherit}button{border:0;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.48}h1,h2,h3,p{margin-top:0}.doubao-layout{display:grid;grid-template-columns:260px minmax(0,1fr);min-height:100vh;background:#f5f6f8}.sidebar{position:sticky;top:0;display:flex;height:100vh;flex-direction:column;gap:16px;padding:18px 14px;border-right:1px solid #eaedf2;background:#f7f8fa}.profile{display:flex;align-items:center;gap:10px;padding:8px 6px}.app-logo{width:36px;height:36px;flex:0 0 auto;border-radius:12px;object-fit:cover;box-shadow:0 6px 16px #1f23291a}.profile strong,.profile span{display:block}.profile strong{color:#1f2329;font-size:14px}.profile span{margin-top:3px;color:#8a9099;font-size:12px}.new-chat{width:100%;border-radius:14px;background:#fff;color:#1f2329;padding:12px 14px;text-align:left;font-weight:700;box-shadow:0 4px 14px #1f23290d;transition:background .18s ease,transform .18s ease,box-shadow .18s ease}.new-chat:hover{transform:translateY(-1px);background:#fdfdfd;box-shadow:0 8px 20px #1f232914}.side-nav{display:grid;gap:4px}.side-nav button,.recent button,.side-footer button{display:flex;width:100%;align-items:center;gap:10px;border-radius:12px;background:transparent;color:#5f6673;padding:11px 12px;text-align:left;transition:background .18s ease,color .18s ease}.side-nav button:hover,.recent button:hover,.side-footer button:hover{background:#eceff4;color:#1f2329}.side-nav button.active{background:#e9edf7;color:#2f66ff;font-weight:800}.side-nav span{display:grid;width:20px;place-items:center}.recent{min-height:0;flex:1;overflow:auto}.recent p{margin:10px 10px 8px;color:#a0a6b0;font-size:12px}.session-item{position:relative;display:block;margin:2px 0;border-radius:12px}.session-item.active{background:#f1f4ff}.session-link{display:flex;width:100%;min-height:34px;align-items:center;border-radius:12px;overflow:hidden;min-width:0;background:transparent;color:#6b7280;padding:8px 38px 8px 12px;font-size:13px;text-align:left;white-space:nowrap}.recent .session-link{width:100%;padding:8px 38px 8px 12px}.session-item:not(.active) .session-link:hover{background:transparent;color:#1f2329}.session-item.active .session-link{color:#2f66ff;font-weight:800}.session-title{display:block;overflow:hidden;text-overflow:ellipsis}.session-pin{display:none;margin-left:6px;color:#8a9099;font-size:11px;font-weight:700}.session-more{position:absolute;top:50%;right:4px;display:grid;width:28px;min-width:28px;height:28px;padding:0;place-items:center;border-radius:10px;background:transparent;color:#9aa1ad;font-size:12px;letter-spacing:0;opacity:0;pointer-events:none;transform:translateY(-50%);transition:opacity .18s ease,background .18s ease,color .18s ease}.recent .session-more{width:28px;flex:0 0 28px;padding:0}.session-item:hover .session-more,.session-item:focus-within .session-more{opacity:1;pointer-events:auto}.session-more:hover{background:#eceff4;color:#1f2329}.session-menu{position:absolute;top:42px;right:0;z-index:20;display:grid;min-width:132px;gap:4px;border:1px solid rgba(229,232,238,.96);border-radius:14px;background:#fffffffa;padding:6px;box-shadow:0 18px 36px #1f232924}.session-menu button{width:100%;justify-content:flex-start;border-radius:10px;background:transparent;color:#1f2329;padding:9px 10px;font-size:13px;font-weight:700}.session-menu button:hover{background:#f5f6f8}.session-menu button.danger{color:#e11d48}.recent>span{display:block;padding:10px;color:#a0a6b0;font-size:13px}.side-footer{padding-top:10px;border-top:1px solid #eaedf2}.main-panel{position:relative;min-width:0;background:radial-gradient(circle at 50% 0%,rgba(235,238,250,.86),transparent 360px),#fff}.gallery-heading button{display:grid;min-width:40px;height:40px;place-items:center;border-radius:999px;background:#f5f6f8;color:#5f6673;transition:background .18s ease,transform .18s ease}.gallery-heading button:hover{transform:translateY(-1px);background:#eceff4}.composer input,.composer textarea{width:100%;border:0;background:transparent;color:#1f2329;outline:none}.send-btn{display:grid;place-items:center;border-radius:999px;background:#2f66ff;color:#fff;font-weight:800;transition:transform .18s ease,box-shadow .18s ease,background .18s ease}.send-btn{width:42px;height:42px;font-size:22px}.send-btn:hover{transform:translateY(-1px);background:#2457df;box-shadow:0 8px 22px #2f66ff47}.image-page{display:flex;min-height:100vh;flex-direction:column;align-items:center;padding:22px 24px 140px}.page-heading{text-align:center}.mini-icon{width:46px;height:46px;margin:10px auto 14px;border-radius:14px;object-fit:cover;box-shadow:0 10px 28px #2f66ff29}.page-heading h1{margin-bottom:8px;font-size:34px;line-height:1.16}.page-heading p{margin-bottom:22px;color:#8a9099}.style-tabs,.quick-tools{display:flex;gap:10px;flex-wrap:wrap}.style-tabs{max-width:900px;justify-content:center}.style-tabs{margin-bottom:26px}.chat-thread{display:flex;width:min(980px,100%);min-height:420px;flex:1;flex-direction:column;gap:22px;padding:10px 0 24px}.chat-thread.compact{min-height:0;padding-top:22px}.chat-empty{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.showcase-head{display:flex;align-items:center;justify-content:space-between;gap:16px;grid-column:1 / -1;margin-bottom:4px}.showcase-head strong,.showcase-head span{display:block}.showcase-head strong{color:#1f2329;font-size:22px}.showcase-head span{margin-top:6px;color:#8a9099;font-size:13px}.showcase-head button{border-radius:999px;background:#f5f6f8;color:#1f2329;padding:10px 16px;font-size:13px;font-weight:800;transition:background .18s ease,transform .18s ease}.showcase-head button:hover{transform:translateY(-1px);background:#eceff4}.empty-card{display:grid;gap:8px;min-height:180px;align-content:end;padding:24px;border:1px solid rgba(229,232,238,.92);border-radius:26px;background:radial-gradient(circle at top left,rgba(238,243,255,.95),transparent 42%),#ffffffeb;box-shadow:0 18px 48px #1f232914}.empty-card.subtle{background:linear-gradient(135deg,#f5f7fcfa,#fcfdfff5),#ffffffeb}.hero-work-card{position:relative;aspect-ratio:1;overflow:hidden;border-radius:28px;background:#eef1f6;box-shadow:0 18px 48px #1f23291a;cursor:pointer;transition:transform .25s ease,box-shadow .25s ease}.hero-work-card:hover{transform:translateY(-4px);box-shadow:0 24px 58px #1f232924}.hero-work-card img{display:block;width:100%;height:100%;object-fit:cover;transition:transform .35s ease}.hero-work-card:hover img{transform:scale(1.03)}.hero-work-mask{position:absolute;right:0;bottom:0;left:0;display:grid;gap:4px;padding:58px 18px 18px;background:linear-gradient(180deg,transparent,rgba(17,20,28,.72));color:#fff}.hero-work-mask strong,.hero-work-mask span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hero-work-mask strong{font-size:16px}.hero-work-mask span{color:#ffffffc7;font-size:12px}.empty-card strong{font-size:20px}.empty-card span{color:#7c8491;line-height:1.7}.chat-message{display:grid;grid-template-columns:minmax(0,1fr) 44px;gap:14px;width:100%}.chat-message.assistant{grid-template-columns:44px minmax(0,1fr)}.chat-message.user{grid-template-columns:minmax(0,1fr) 44px}.message-avatar{display:grid;width:44px;height:44px;place-items:center;border-radius:16px;background:#edf1f8;color:#2f66ff;font-size:15px;font-weight:800;box-shadow:inset 0 0 0 1px #e5e8eee6}.message-avatar img{width:30px;height:30px;object-fit:cover}.message-body{min-width:0}.chat-message.assistant .message-avatar{order:0}.chat-message.assistant .message-body{order:1}.chat-message.user .message-body{display:flex;flex-direction:column;align-items:flex-end}.chat-message.user .message-avatar{order:1}.chat-message.user .message-body{order:0}.message-meta{display:flex;align-items:center;gap:10px;margin-bottom:8px}.chat-message.user .message-meta{justify-content:flex-end}.message-meta strong{color:#1f2329;font-size:14px}.message-meta span{color:#8a9099;font-size:12px}.message-bubble{max-width:min(760px,100%);border-radius:24px;padding:18px 20px;box-shadow:0 14px 40px #1f232914}.user-bubble{margin-left:auto;background:linear-gradient(135deg,#2f66ff,#5b86ff);color:#fff}.assistant-bubble{background:#fffffff0;border:1px solid rgba(229,232,238,.92)}.message-bubble p{margin:0;line-height:1.72;white-space:pre-wrap}.bubble-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.bubble-tags span{border-radius:999px;background:#ffffff29;padding:6px 10px;font-size:12px}.assistant-panel{display:grid;gap:12px}.loading-bubble{display:flex;align-items:center;gap:16px}.loading-bubble strong,.error-bubble strong{display:block;margin-bottom:4px;font-size:15px}.loading-bubble p,.error-bubble p{color:#707887}.loading-dots{display:inline-flex;align-items:center;gap:6px;padding:12px 0}.loading-dots span{width:10px;height:10px;border-radius:50%;background:#2f66ff;animation:dotPulse 1.1s infinite ease-in-out}.loading-dots span:nth-child(2){animation-delay:.14s}.loading-dots span:nth-child(3){animation-delay:.28s}.error-bubble{border-color:#ffd3dbfa;background:#fff5f7f5}.error-bubble strong,.error-bubble p{color:#d1435b}.assistant-result{max-width:min(760px,100%)}.result-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.result-header strong{font-size:15px}.result-header span{border-radius:999px;background:#edf4ff;color:#2f66ff;padding:7px 10px;font-size:12px;font-weight:800}.result-card{overflow:hidden;border:1px solid rgba(229,232,238,.92);border-radius:28px;background:#fffffff2;box-shadow:0 20px 48px #1f23291a}.result-card img{display:block;width:100%;max-height:680px;object-fit:cover}.result-actions{display:flex;flex-wrap:wrap;gap:10px;padding:16px}.result-actions button{border-radius:999px;background:#f5f6f8;color:#1f2329;padding:10px 14px;font-size:13px;font-weight:800;transition:background .18s ease,transform .18s ease}.result-actions button:hover{transform:translateY(-1px);background:#eceff4}.result-actions button.active,.work-mask button.active,.preview-actions button.active{background:#2f66ff;color:#fff}.result-info{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 2px 0}.result-info strong{color:#1f2329;font-size:14px}.result-info span{color:#8a9099;font-size:12px}.style-tabs button,.quick-tools button,.tool-btn,.publish-check{border-radius:999px;background:#f5f6f8;color:#5f6673;padding:10px 14px;font-weight:700;transition:background .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease}.style-tabs button:hover,.quick-tools button:hover,.tool-btn:hover,.publish-check:hover{transform:translateY(-1px);background:#eceff4}.style-tabs button.active,.quick-tools button.active{background:#1f2329;color:#fff;box-shadow:0 8px 20px #1f232929}.ratio-trigger{display:inline-flex;align-items:center;gap:8px}.ratio-trigger strong{color:inherit;font-size:13px}.image-canvas{display:grid;width:min(860px,100%);grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:0}.sample-tile{position:relative;height:220px;min-height:220px;overflow:hidden;border-radius:24px;background:#f0f2f6;box-shadow:0 14px 36px #1f232914;transition:transform .18s ease,box-shadow .18s ease}.sample-tile:hover{transform:translateY(-4px);box-shadow:0 18px 42px #1f23291f}.sample-tile img{width:100%;height:100%;min-height:100%;object-fit:cover}.sample-art{display:grid;width:100%;height:100%;min-height:100%;place-items:center;background:radial-gradient(circle at 30% 18%,rgba(255,255,255,.74),transparent 32%),linear-gradient(135deg,#d7e4ff,#f1d8e8 48%,#d8f1ea);color:#1f2329b3;font-weight:900}.quick-tools{min-width:0;overflow-x:auto;flex:1;flex-wrap:nowrap;padding-bottom:1px;scrollbar-width:none}.quick-tools::-webkit-scrollbar{display:none}.tool-btn,.publish-check{display:inline-flex;align-items:center;gap:6px}.tool-btn input{display:none}.publish-check input{width:16px;height:16px;accent-color:#2f66ff}.composer{position:fixed;right:24px;bottom:24px;left:284px;z-index:12;width:auto;min-height:116px;border:1px solid #e5e8ee;border-radius:24px;background:#fffffff2;padding:14px 14px 12px;box-shadow:0 18px 56px #1f232924;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.composer textarea{min-height:46px;resize:none;line-height:1.6}.reference-preview{display:inline-flex;max-width:100%;align-items:center;gap:8px;margin-bottom:10px;border-radius:14px;background:#f5f6f8;padding:6px 8px 6px 6px}.reference-preview img{width:42px;height:42px;border-radius:10px;object-fit:cover}.reference-preview span{max-width:260px;overflow:hidden;color:#5f6673;font-size:13px;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.reference-preview button{border-radius:999px;background:#fff;color:#7b8491;padding:6px 9px;font-size:12px;font-weight:800}.reference-preview button:hover{color:#1f2329}.composer-bottom{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:8px}.gallery-page{padding:28px 36px 80px}.gallery-heading{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:18px auto 22px;max-width:1080px}.gallery-heading h1{margin-bottom:6px;font-size:30px}.gallery-heading p{margin-bottom:0;color:#8a9099}.gallery-heading-actions{display:flex;align-items:center;gap:10px}.gallery-heading-actions button.primary{background:#2f66ff;color:#fff;box-shadow:0 10px 24px #2f66ff2e}.gallery-heading-actions button.primary:hover{background:#2457df;color:#fff}.gallery-filters{display:grid;max-width:1080px;margin:-6px auto 22px;grid-template-columns:minmax(220px,1.3fr) repeat(5,minmax(110px,.7fr)) auto;gap:10px;align-items:end;border:1px solid #eaedf2;border-radius:20px;background:#ffffffe6;padding:12px;box-shadow:0 14px 36px #1f23290f}.gallery-filters label{display:grid;min-width:0;gap:6px}.gallery-filters span{color:#7b8491;font-size:12px;font-weight:800}.gallery-filters input,.gallery-filters select{width:100%;height:40px;border:1px solid transparent;border-radius:12px;background:#f5f6f8;color:#1f2329;outline:none;padding:0 12px;font-size:13px;font-weight:700;transition:border-color .18s ease,background .18s ease,box-shadow .18s ease}.gallery-filters input:focus,.gallery-filters select:focus{border-color:#b9c9ff;background:#fff;box-shadow:0 0 0 4px #2f66ff17}.gallery-filters button{height:40px;border-radius:12px;background:#f5f6f8;color:#5f6673;padding:0 14px;font-size:13px;font-weight:900}.gallery-filters button:hover{background:#eceff4;color:#1f2329}.works-grid{display:grid;max-width:1080px;margin:0 auto;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.work-card{position:relative;overflow:hidden;border-radius:22px;background:#f0f2f6;box-shadow:0 12px 32px #1f232914}.work-card img{display:block;width:100%;aspect-ratio:1;object-fit:cover;transition:transform .3s ease}.work-card:hover img{transform:scale(1.04)}.work-mask{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;background:#14181f5c;opacity:0;z-index:2;padding:14px;transition:opacity .2s ease}.work-card:hover .work-mask{opacity:1}.work-mask button{position:relative;z-index:3;border-radius:999px;background:#ffffffeb;color:#1f2329;padding:8px 12px;font-size:13px;font-weight:800}.icon-pill{min-width:42px;padding:8px 10px;font-size:16px;line-height:1}@keyframes dotPulse{0%,80%,to{opacity:.28;transform:translateY(0)}40%{opacity:1;transform:translateY(-4px)}}.work-info{position:absolute;right:0;bottom:0;left:0;z-index:1;pointer-events:none;padding:42px 14px 14px;background:linear-gradient(180deg,transparent,rgba(0,0,0,.6));color:#fff}.work-info strong,.work-info span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.work-info strong{font-size:14px}.work-info span{margin-top:4px;color:#ffffffc7;font-size:12px}.tag-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:7px}.work-info .tag-list span,.tag-list span{display:inline-flex;max-width:100%;align-items:center;border-radius:999px;background:#fff3;color:#fff;padding:4px 8px;font-size:11px;font-weight:800;line-height:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tag-list.light span{background:#eef3ff;color:#2f66ff}.empty{grid-column:1 / -1;border-radius:18px;background:#f7f8fa;color:#8a9099;padding:28px;text-align:center}.admin-page{padding:28px 36px 90px}.admin-section-nav{display:flex;max-width:1080px;margin:0 auto 16px;flex-wrap:wrap;gap:10px}.admin-section-nav button{border:1px solid #e6ebf4;border-radius:999px;background:#ffffffe0;color:#5f6673;padding:10px 16px;font-weight:900;transition:all .2s ease}.admin-section-nav button.active{border-color:transparent;background:#1f2329;color:#fff;box-shadow:0 10px 26px #1f232924}.admin-stats{display:grid;max-width:1080px;margin:0 auto 16px;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px}.admin-stats article,.admin-panel{border:1px solid #eaedf2;border-radius:18px;background:#ffffffeb;box-shadow:0 14px 36px #1f23290f}.admin-stats article{display:grid;gap:8px;padding:14px}.admin-stats span,.admin-panel-head p,.admin-user-list span,.settings-form label span{color:#8a9099;font-size:12px}.admin-stats strong{color:#1f2329;font-size:22px}.admin-grid{display:grid;max-width:1080px;margin:0 auto;grid-template-columns:minmax(0,1.3fr) minmax(320px,.7fr);gap:16px}.admin-grid-single{grid-template-columns:minmax(0,1fr)}.admin-dashboard-summary{max-width:1080px;margin:0 auto}.admin-overview-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.admin-overview-grid article{display:grid;gap:8px;border-radius:16px;background:#f7f8fa;padding:16px}.admin-overview-grid span{color:#8a9099;font-size:12px}.admin-overview-grid strong{color:#1f2329;font-size:24px}.admin-panel{padding:18px}.admin-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px}.admin-panel-head h2{margin-bottom:6px;font-size:20px}.admin-panel-head p{margin-bottom:0;line-height:1.5}.admin-panel-head button{border-radius:999px;background:#2f66ff;color:#fff;padding:10px 14px;font-weight:900;white-space:nowrap}.admin-actions{display:flex;gap:8px;align-items:center}.admin-actions button:first-child{background:#f1f4fb;color:#1f2329}.settings-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.settings-form label{display:grid;gap:7px}.settings-form input,.admin-user-list select{width:100%;height:42px;border:1px solid transparent;border-radius:12px;background:#f5f6f8;color:#1f2329;outline:none;padding:0 12px;font-weight:700}.settings-form input:focus,.admin-user-list select:focus{border-color:#b9c9ff;background:#fff;box-shadow:0 0 0 4px #2f66ff17}.logo-setting{grid-column:1 / -1}.logo-upload-row{display:grid;grid-template-columns:72px minmax(0,1fr);gap:12px;align-items:center}.logo-upload{display:grid!important;width:72px;height:72px;place-items:center;overflow:hidden;border:1px dashed #c9d5ea;border-radius:18px;background:linear-gradient(135deg,#f8fbff,#eef3ff);box-shadow:inset 0 0 0 1px #ffffffb8;cursor:pointer}.logo-upload input{display:none}.logo-upload img{width:100%;height:100%;object-fit:cover}.setting-check{display:flex!important;grid-column:1 / -1;align-items:center;gap:8px!important;color:#5f6673;font-weight:800}.setting-check input{width:16px;height:16px;accent-color:#2f66ff}.openai-panel{grid-column:1 / -1}.provider-list{display:grid;gap:12px}.provider-card{display:grid;gap:14px;border:1px solid #eef1f6;border-radius:18px;background:linear-gradient(180deg,#fff,#f8faff);padding:14px}.provider-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.provider-card-head strong{color:#111827;font-size:15px}.provider-switch{display:flex;width:auto;align-items:center;gap:8px;border-radius:999px;background:#f1f4fb;color:#4b5563;padding:7px 10px;font-size:13px;font-weight:900}.provider-switch input{width:16px;height:16px;accent-color:#2f66ff}.provider-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.provider-fields label{display:grid;gap:7px}.provider-fields label span{color:#8a9099;font-size:12px}.provider-fields input{width:100%;height:42px;border:1px solid transparent;border-radius:12px;background:#f5f6f8;color:#1f2329;outline:none;padding:0 12px;font-weight:700}.provider-fields input:focus{border-color:#b9c9ff;background:#fff;box-shadow:0 0 0 4px #2f66ff17}.provider-fields .wide{grid-column:1 / -1}.provider-actions{display:flex;flex-wrap:wrap;gap:8px}.provider-actions button{border-radius:999px;background:#f1f4fb;color:#4b5563;padding:8px 12px;font-weight:900}.provider-actions button:disabled{cursor:not-allowed;opacity:.45}.provider-actions .danger{background:#fff1f2;color:#e11d48}.admin-user-list{display:grid;max-height:520px;overflow:auto;gap:10px}.admin-user-list article{display:grid;grid-template-columns:minmax(0,1fr) 110px;gap:10px;align-items:center;border-radius:14px;background:#f7f8fa;padding:12px}.admin-user-list strong,.admin-user-list span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-user-list strong{margin-bottom:4px}.toast{position:fixed;right:24px;bottom:160px;z-index:10000;pointer-events:none;max-width:calc(100vw - 48px);border-radius:999px;background:#1f2329eb;color:#fff;padding:12px 16px;box-shadow:0 12px 34px #1f23292e;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.toast-enter-active,.toast-leave-active{transition:opacity .2s ease,transform .2s ease}.toast-enter-from,.toast-leave-to{opacity:0;transform:translateY(8px)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;background:#14181f57;padding:18px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-modal,.metadata-modal,.ratio-modal,.upload-artwork-modal{position:relative;display:grid;width:min(420px,100%);gap:12px;border:1px solid rgba(234,237,242,.9);border-radius:24px;background:#fffffffa;padding:24px;box-shadow:0 24px 80px #14181f38}.modal-close{position:absolute;top:14px;right:14px;display:grid;width:34px;height:34px;place-items:center;border-radius:50%;background:#f5f6f8;color:#737b88;font-size:22px;line-height:1}.modal-close:hover{background:#eceff4;color:#1f2329}.image-preview-modal>.modal-close{z-index:4;background:#ffffff24;color:#fff;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.image-preview-modal>.modal-close:hover{background:#ffffff3d;color:#fff}.modal-head{padding-right:34px}.modal-head h2{margin-bottom:8px;font-size:24px;line-height:1.2}.modal-head p{margin-bottom:4px;color:#8a9099;line-height:1.6}.auth-switch{display:grid;grid-template-columns:1fr 1fr;gap:6px;border-radius:999px;background:#f5f6f8;padding:5px}.auth-switch button{border-radius:999px;background:transparent;color:#6b7280;padding:10px 12px;font-weight:800}.auth-switch button.active{background:#fff;color:#2f66ff;box-shadow:0 5px 14px #1f232914}.auth-code-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.auth-code-row button{min-width:108px;border-radius:14px;background:#f5f6f8;color:#2f66ff;padding:0 14px;font-size:13px;font-weight:900}.auth-code-row button:disabled{color:#99a2b0;cursor:not-allowed}.login-modal input{width:100%;height:46px;border:1px solid transparent;border-radius:14px;background:#f7f8fa;color:#1f2329;outline:none;padding:0 14px;transition:border-color .18s ease,background .18s ease,box-shadow .18s ease}.login-modal input:focus,.metadata-modal input:focus{border-color:#b9c9ff;background:#fff;box-shadow:0 0 0 4px #2f66ff1a}.metadata-modal{width:min(460px,100%)}.ratio-modal{width:min(500px,100%)}.ratio-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.ratio-grid button{display:grid;min-height:78px;place-items:center;gap:8px;border:1px solid #e5e8ee;border-radius:14px;background:#fff;color:#5f6673;font-weight:900;transition:border-color .18s ease,background .18s ease,color .18s ease,transform .18s ease}.ratio-grid button:hover{transform:translateY(-1px);border-color:#b9c9ff}.ratio-grid button.active{border-color:#2f66ff;background:#eef3ff;color:#2f66ff}.ratio-icon{display:block;width:28px;max-height:32px;min-height:10px;border:1.5px solid currentColor;border-radius:5px}.upload-artwork-modal{width:min(560px,100%);max-height:calc(100vh - 40px);overflow:auto}.metadata-modal label,.upload-artwork-modal label{display:grid;gap:8px}.metadata-modal label span,.upload-artwork-modal label span{color:#5f6673;font-size:13px;font-weight:800}.metadata-modal input,.upload-artwork-modal input,.upload-artwork-modal textarea{width:100%;border:1px solid transparent;border-radius:14px;background:#f7f8fa;color:#1f2329;outline:none;padding:0 14px;transition:border-color .18s ease,background .18s ease,box-shadow .18s ease}.metadata-modal input,.upload-artwork-modal input{height:46px}.upload-artwork-modal textarea{min-height:96px;resize:vertical;line-height:1.6;padding:12px 14px}.upload-artwork-modal input:focus,.upload-artwork-modal textarea:focus{border-color:#b9c9ff;background:#fff;box-shadow:0 0 0 4px #2f66ff1a}.upload-drop{display:grid;min-height:220px;place-items:center;overflow:hidden;border:1px dashed #cfd7e6;border-radius:18px;background:#f7f8fa;color:#7b8491;cursor:pointer;font-weight:900}.upload-drop input{display:none}.upload-drop img{width:100%;max-height:320px;object-fit:contain}.upload-options{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.upload-options>button{border-radius:999px;background:#f5f6f8;color:#5f6673;padding:10px 14px;font-weight:900}.upload-options>button.active{background:#1f2329;color:#fff}.form-error{margin:0;border-radius:12px;background:#fff1f2;color:#e11d48;padding:10px 12px;font-size:13px;font-weight:800;line-height:1.45}.modal-submit{height:46px;border-radius:999px;background:#2f66ff;color:#fff;font-weight:900;transition:transform .18s ease,background .18s ease,box-shadow .18s ease}.modal-submit:hover{transform:translateY(-1px);background:#2457df;box-shadow:0 10px 24px #2f66ff47}.modal-enter-active,.modal-leave-active{transition:opacity .18s ease}.modal-enter-active .login-modal,.modal-leave-active .login-modal,.modal-enter-active .metadata-modal,.modal-leave-active .metadata-modal,.modal-enter-active .ratio-modal,.modal-leave-active .ratio-modal{transition:transform .2s ease,opacity .2s ease}.modal-enter-from,.modal-leave-to{opacity:0}.modal-enter-from .login-modal,.modal-leave-to .login-modal,.modal-enter-from .metadata-modal,.modal-leave-to .metadata-modal,.modal-enter-from .ratio-modal,.modal-leave-to .ratio-modal{opacity:0;transform:translateY(14px) scale(.98)}.image-preview-modal{position:relative;isolation:isolate;display:grid;width:min(1440px,calc(100vw - 28px));height:min(820px,calc(100vh - 28px));grid-template-columns:minmax(0,1fr) 420px;gap:28px;overflow:hidden;border:1px solid rgba(255,255,255,.14);border-radius:28px;background:#0a0c0e7a;box-shadow:0 30px 90px #00000075;color:#fff}.preview-backdrop-art{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;overflow:hidden}.preview-backdrop-art img{width:100%;height:100%;opacity:1;filter:blur(10px) brightness(1.08) saturate(1.32);object-fit:cover;transform:scale(1.045)}.preview-backdrop-art:after{position:absolute;top:0;right:0;bottom:0;left:0;content:"";background:radial-gradient(circle at 32% 24%,rgba(255,255,255,.16),transparent 30%),radial-gradient(circle at 62% 48%,rgba(255,255,255,.08),transparent 36%),linear-gradient(90deg,#07080a14,#07080a66),linear-gradient(180deg,#07080a14,#07080a61)}.preview-stage,.preview-side{position:relative;z-index:1}.preview-stage{display:grid;min-width:0;align-content:center;gap:22px;padding:54px 0 42px 54px}.preview-image-frame{display:grid;width:fit-content;max-width:100%;min-height:0;justify-self:center;place-items:center;border:7px solid rgba(255,255,255,.82);border-radius:24px;background:#0000002e;box-shadow:0 24px 64px #00000061;overflow:hidden}.preview-image-frame img{display:block;width:auto;max-width:100%;max-height:calc(100vh - 220px);object-fit:contain}.preview-tags{display:grid;gap:12px}.preview-tags strong{font-size:16px;letter-spacing:0}.preview-tags div{display:flex;flex-wrap:wrap;gap:10px}.preview-tags span{border-radius:999px;background:#ffffff29;color:#ffffffe6;padding:8px 13px;font-size:13px;font-weight:800;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.preview-side{display:grid;min-height:0;align-content:center;gap:18px;padding:54px 54px 42px 0}.preview-info-card,.preview-prompt-card,.comment-panel{border:1px solid rgba(255,255,255,.12);border-radius:22px;background:#1a1d1fad;box-shadow:inset 0 1px #ffffff0f,0 18px 50px #00000047;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.preview-info-card{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px 18px;padding:24px}.preview-info-card span,.preview-author-card span,.preview-prompt-card p,.comment-head span,.comment-empty,.comment-item span{color:#ffffffad}.preview-info-card span{display:block;margin-bottom:8px;font-size:13px;font-weight:800}.preview-info-card strong{display:block;overflow:hidden;color:#fff;font-size:14px;text-overflow:ellipsis;white-space:nowrap}.preview-author-link{display:block;max-width:100%;overflow:hidden;background:transparent;color:#fff;padding:0;font-size:14px;font-weight:900;text-align:left;text-overflow:ellipsis;white-space:nowrap}.preview-author-link:hover{color:#dbe7ff}.preview-author-card{display:flex;width:100%;align-items:center;gap:12px;border-radius:18px;background:transparent;padding:0 18px;text-align:left;transition:background .18s ease,transform .18s ease}.preview-author-card:hover{background:#ffffff14;transform:translateY(-1px)}.preview-author-avatar{display:grid;width:54px;height:54px;place-items:center;border:2px solid rgba(255,255,255,.88);border-radius:50%;background:#ffffff1f;color:#fff;font-size:20px;font-weight:900}.preview-author-card strong,.preview-prompt-card strong,.comment-head strong{display:block;color:#fff}.preview-author-card span{display:block;margin-top:4px;font-size:12px}.preview-actions{display:flex;flex-wrap:wrap;gap:12px;border-top:1px solid rgba(255,255,255,.18);padding:20px 0 0}.preview-actions button,.comment-form button{border:1px solid rgba(255,255,255,.2);border-radius:999px;background:#ffffff1f;color:#fff;padding:10px 15px;font-size:13px;font-weight:900;transition:transform .18s ease,background .18s ease,box-shadow .18s ease}.preview-actions button:hover,.comment-form button:hover{transform:translateY(-1px);background:#fff3}.preview-actions .download-main{min-width:96px;background:#fff;color:#11161b;box-shadow:0 0 24px #ffffff3d}.preview-actions button.active{background:#2f66ff;color:#fff}.preview-prompt-card{display:grid;gap:10px;padding:18px 20px}.preview-prompt-card p{display:-webkit-box;overflow:hidden;margin:0;-webkit-box-orient:vertical;-webkit-line-clamp:4;font-size:13px;line-height:1.7}.comment-panel{display:grid;gap:12px;min-height:0;padding:18px 20px 20px}.comment-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.comment-list{display:grid;max-height:150px;overflow:auto;gap:10px}.comment-item{display:grid;gap:4px;border-radius:14px;background:#ffffff14;padding:10px 12px}.comment-item strong{color:#fff;font-size:13px}.comment-item p{margin:0;color:#ffffffc7;font-size:13px;line-height:1.6}.comment-empty{margin:0;border-radius:14px;background:#ffffff14;padding:14px;text-align:center}.comment-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px}.comment-form input{width:100%;border:1px solid rgba(255,255,255,.14);border-radius:999px;background:#ffffff1a;color:#fff;outline:none;padding:0 14px}.comment-form input::placeholder{color:#ffffff8f}.comment-form input:focus{border-color:#ffffff6b;box-shadow:0 0 0 4px #ffffff14}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}@media(max-width:980px){.doubao-layout{grid-template-columns:1fr}.sidebar{position:static;height:auto;flex-direction:row;align-items:center;overflow-x:auto;border-right:0;border-bottom:1px solid #eaedf2}.profile,.recent,.side-footer{display:none}.new-chat{width:auto;white-space:nowrap}.side-nav{display:flex;min-width:max-content}.image-canvas,.chat-empty{grid-template-columns:repeat(2,minmax(0,1fr))}.showcase-head{align-items:flex-start;flex-direction:column}.composer{right:16px;left:16px}.works-grid,.gallery-filters{grid-template-columns:repeat(2,minmax(0,1fr))}.gallery-search,.gallery-filters button{grid-column:1 / -1}.image-preview-modal{height:calc(100vh - 24px);grid-template-columns:1fr;overflow:auto}.preview-stage{padding:56px 20px 0}.preview-image-frame img{max-height:56vh}.preview-side{padding:0 20px 24px}.admin-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-grid{grid-template-columns:1fr}.admin-overview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.settings-form,.provider-fields{grid-template-columns:1fr}.admin-actions{width:100%;flex-wrap:wrap}}@media(max-width:620px){.image-page{padding:12px 12px 150px}.page-heading h1{font-size:28px}.chat-empty{grid-template-columns:1fr}.showcase-head{gap:12px}.hero-work-card{border-radius:22px}.chat-message{grid-template-columns:minmax(0,1fr) 38px;gap:10px}.chat-message.assistant{grid-template-columns:38px minmax(0,1fr)}.chat-message.user{grid-template-columns:minmax(0,1fr) 38px}.message-avatar{width:38px;height:38px;border-radius:14px}.message-bubble{border-radius:20px;padding:16px}.loading-bubble{flex-direction:column;align-items:flex-start}.result-info,.result-header{align-items:flex-start;flex-direction:column}.composer{bottom:12px;min-height:130px;border-radius:20px}.send-btn{width:42px}.gallery-page,.admin-page{padding:16px 12px 70px}.gallery-heading{align-items:flex-start;flex-direction:column}.admin-section-nav{gap:8px}.admin-section-nav button{flex:1 1 calc(50% - 8px);justify-content:center}.admin-overview-grid,.works-grid{grid-template-columns:1fr}.ratio-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
