.sidebar{width:var(--sidebar-width);height:100vh;background-color:var(--color-bg-secondary);border-right:1px solid var(--color-border);display:flex;flex-direction:column;transition:width var(--transition-normal),transform var(--transition-normal);padding:var(--spacing-md);flex-shrink:0;z-index:100}@media(max-width:768px){.sidebar{position:fixed;left:0;top:0;bottom:0;transform:translate(-100%);width:80%!important;max-width:300px;box-shadow:2px 0 8px #00000080}.sidebar.mobile-open{transform:translate(0)}.desktop-collapse-btn{display:none!important}.mobile-close-btn{display:flex}}.mobile-close-btn{display:none}.sidebar.collapsed{width:var(--sidebar-width-collapsed);padding:var(--spacing-md) var(--spacing-sm);align-items:center}.sidebar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-xl);height:40px}.app-title{font-size:var(--font-size-lg);font-weight:600;white-space:nowrap;overflow:hidden}.sidebar-controls{display:flex;align-items:center;gap:var(--spacing-sm)}.collapse-btn{color:var(--color-text-secondary);padding:var(--spacing-xs);border-radius:4px;display:flex;align-items:center;justify-content:center;border:none;background:none;cursor:pointer}.collapse-btn:hover{color:var(--color-text-primary);background-color:var(--color-bg-tertiary)}.sidebar-nav{display:flex;flex-direction:column;gap:var(--spacing-sm);flex:1;width:100%}.nav-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);color:var(--color-text-secondary);border-radius:8px;transition:all var(--transition-fast);width:100%;height:40px;white-space:nowrap;overflow:hidden}.sidebar.collapsed .nav-item{justify-content:center;padding:var(--spacing-sm)}.sidebar.collapsed .app-title,.sidebar.collapsed .nav-item span{display:none}@media(max-width:768px){.sidebar.collapsed .app-title,.sidebar.collapsed .nav-item span{display:block}.sidebar.collapsed .nav-item{justify-content:flex-start;padding:var(--spacing-sm) var(--spacing-md)}.sidebar.collapsed{padding:var(--spacing-md);align-items:stretch}}.nav-item:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.nav-item.active{background-color:var(--color-accent);color:#fff}.nav-item.active:hover{background-color:var(--color-accent-hover)}.sidebar-footer{display:flex;flex-direction:column;gap:var(--spacing-sm);border-top:1px solid var(--color-border);padding-top:var(--spacing-md);width:100%}.help-modal-overlay{position:fixed;inset:0;background-color:var(--color-overlay);display:flex;justify-content:center;align-items:center;z-index:2000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.help-modal{background-color:var(--color-bg-secondary);border-radius:12px;width:90%;max-width:500px;border:1px solid var(--color-border);box-shadow:0 8px 32px #0006}.help-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.help-header h2{font-size:var(--font-size-lg);font-weight:600}.close-help-btn{color:var(--color-text-secondary);padding:4px;border-radius:4px}.close-help-btn:hover{color:var(--color-text-primary);background-color:var(--color-bg-tertiary)}.help-content{padding:var(--spacing-lg)}.help-content p{color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--spacing-lg)}.help-footer{font-size:var(--font-size-sm);color:var(--color-text-secondary);opacity:.7}.layout{display:flex;width:100vw;height:100vh;overflow:hidden;position:relative}.main-content{flex:1;height:100%;overflow-y:auto;background-color:var(--color-bg-primary);padding:var(--spacing-lg);position:relative;display:flex;flex-direction:column}.mobile-header{display:none;align-items:center;gap:var(--spacing-md);padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.mobile-menu-btn{color:var(--color-text-primary);padding:var(--spacing-xs);border-radius:4px;display:flex;align-items:center;justify-content:center}.mobile-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary)}.mobile-overlay{display:none;position:fixed;inset:0;background-color:#00000080;z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media(max-width:768px){.mobile-header{display:flex}.mobile-overlay{display:block}.main-content{padding:var(--spacing-md)}}.create-image-page{display:flex;flex-direction:column;height:100%;gap:var(--spacing-lg)}.input-section{flex-shrink:0;max-width:800px;margin:0 auto;width:100%}.prompt-form{display:flex;gap:var(--spacing-md);background-color:var(--color-bg-secondary);padding:var(--spacing-md);border-radius:12px;border:1px solid var(--color-border);transition:border-color var(--transition-fast)}.prompt-form:focus-within{border-color:var(--color-accent)}.prompt-input{flex:1;background:none;border:none;color:var(--color-text-primary);font-family:inherit;font-size:var(--font-size-md);resize:none;height:60px;outline:none}.prompt-input::placeholder{color:var(--color-text-secondary)}.form-actions{display:flex;gap:var(--spacing-sm);align-items:center}.settings-popover-container{position:relative}.settings-btn{display:flex;align-items:center;justify-content:center;background-color:transparent;color:var(--color-text-secondary);padding:8px;border-radius:8px;transition:all var(--transition-fast);border:1px solid transparent}.settings-btn:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.ratio-popover{position:absolute;top:calc(100% + 8px);right:0;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;padding:var(--spacing-md);min-width:280px;box-shadow:0 8px 24px #0000004d;z-index:100;animation:popoverSlideIn .2s ease-out}@keyframes popoverSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.popover-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.popover-title{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.current-ratio{font-size:var(--font-size-sm);color:var(--color-accent);font-weight:600}.model-selector{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.model-btn{flex:1;background:transparent;border:1px solid var(--color-border);border-radius:8px;padding:10px 12px;cursor:pointer;transition:all var(--transition-fast);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500}.model-btn:hover{background-color:var(--color-bg-tertiary);border-color:var(--color-text-secondary);color:var(--color-text-primary)}.model-btn.active{background-color:var(--color-bg-tertiary);border-color:var(--color-accent);color:var(--color-accent)}.ratio-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-sm)}.ratio-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;background:transparent;border:1px solid var(--color-border);border-radius:8px;padding:10px 8px;cursor:pointer;transition:all var(--transition-fast);color:var(--color-text-secondary)}.ratio-btn:hover{background-color:var(--color-bg-tertiary);border-color:var(--color-text-secondary);color:var(--color-text-primary)}.ratio-btn.active{background-color:var(--color-bg-tertiary);border-color:var(--color-accent);color:var(--color-accent)}.ratio-preview{border:2px solid currentColor;border-radius:2px;width:20px;box-sizing:content-box}.ratio-label{font-size:11px;font-weight:500}.generate-btn{display:flex;align-items:center;gap:var(--spacing-sm);background:linear-gradient(135deg,var(--color-accent) 0%,#7c84ff 100%);color:#fff;padding:12px var(--spacing-lg);border-radius:10px;font-weight:600;font-size:var(--font-size-md);transition:all var(--transition-fast);box-shadow:0 4px 12px #646cff4d;position:relative;overflow:hidden}.generate-btn:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#ffffff1a,#fff0);opacity:0;transition:opacity var(--transition-fast)}.generate-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--color-accent-hover) 0%,#8c94ff 100%);box-shadow:0 6px 20px #646cff66;transform:translateY(-1px)}.generate-btn:hover:not(:disabled):before{opacity:1}.generate-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #646cff4d}.generate-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{color:#ff4d4f;margin-top:var(--spacing-sm);font-size:var(--font-size-sm)}.gallery-section{flex:1;overflow-y:auto;padding-bottom:var(--spacing-xl)}.empty-state{display:flex;justify-content:center;align-items:center;height:100%;color:var(--color-text-secondary)}.masonry-grid{column-count:1;column-gap:var(--spacing-md)}@media(min-width:640px){.masonry-grid{column-count:2}}@media(min-width:1024px){.masonry-grid{column-count:3}}@media(min-width:1280px){.masonry-grid{column-count:4}}.gallery-item{break-inside:avoid;margin-bottom:var(--spacing-md);border-radius:12px;overflow:hidden;position:relative;cursor:pointer;background-color:var(--color-bg-secondary)}.gallery-item img{width:100%;display:block;transition:transform var(--transition-normal)}.gallery-item:hover img{transform:scale(1.05)}.item-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);padding:var(--spacing-md);opacity:0;transition:opacity var(--transition-fast)}.gallery-item:hover .item-overlay{opacity:1}.item-prompt{color:#fff;font-size:var(--font-size-sm);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.image-modal{position:fixed;inset:0;background-color:var(--color-overlay);display:flex;justify-content:center;align-items:center;z-index:1000;padding:var(--spacing-xl);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{background-color:var(--color-bg-secondary);border-radius:16px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;position:relative;border:1px solid var(--color-border)}.modal-actions{position:absolute;top:var(--spacing-md);right:var(--spacing-md);display:flex;gap:var(--spacing-sm);z-index:10}.icon-btn{display:flex;align-items:center;justify-content:center;color:#fff;background-color:#00000080;border:none;border-radius:50%;padding:6px;cursor:pointer;transition:background-color .2s}.icon-btn:hover{background-color:#000c}.modal-image{max-height:70vh;object-fit:contain;background-color:#000}.modal-details{padding:var(--spacing-lg);overflow-y:auto}.modal-details h3{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-xs)}.modal-details p{font-size:var(--font-size-md);line-height:1.6;margin-bottom:var(--spacing-md)}.timestamp{font-size:var(--font-size-sm);color:var(--color-text-secondary)}@media(max-width:768px){.create-image-page{gap:var(--spacing-md)}.prompt-form{flex-direction:column}.prompt-input{height:80px}.form-actions{justify-content:space-between;width:100%}.generate-btn{flex:1;justify-content:center}.ratio-popover{right:0;left:0;margin:0 auto;width:calc(100vw - 32px);min-width:unset;max-width:360px}.ratio-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.ratio-btn{padding:12px 10px}.ratio-preview{width:24px}.ratio-label{font-size:12px}.masonry-grid{column-count:1}}.describe-image-page{display:flex;flex-direction:column;gap:var(--spacing-xl);max-width:800px;margin:0 auto;width:100%;height:100%;overflow-y:auto}.upload-section{flex:1;display:flex;flex-direction:column;min-height:300px}.upload-area{flex:1;border:2px dashed var(--color-border);border-radius:16px;display:flex;justify-content:center;align-items:center;cursor:pointer;transition:all var(--transition-normal);background-color:var(--color-bg-secondary)}.upload-area:hover,.upload-area.drag-active{border-color:var(--color-accent);background-color:var(--color-bg-tertiary)}.upload-area.drag-active{transform:scale(1.02)}.hidden-input{display:none}.upload-placeholder{text-align:center;color:var(--color-text-secondary)}.upload-icon{margin-bottom:var(--spacing-md);color:var(--color-accent)}.upload-placeholder h3{font-size:var(--font-size-lg);margin-bottom:var(--spacing-xs);color:var(--color-text-primary)}.preview-area{display:flex;flex-direction:column;gap:var(--spacing-lg);align-items:center;height:100%}.image-preview{max-width:100%;max-height:40vh;border-radius:12px;box-shadow:0 4px 20px #0000004d;object-fit:contain}.preview-actions{display:flex;gap:var(--spacing-md)}.change-image-btn{padding:var(--spacing-sm) var(--spacing-lg);border:1px solid var(--color-border);border-radius:8px;cursor:pointer;font-weight:500;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.change-image-btn:hover{background-color:var(--color-bg-tertiary);border-color:var(--color-text-secondary)}.reset-btn{padding:var(--spacing-sm);border:1px solid var(--color-border);border-radius:8px;cursor:pointer;font-weight:500;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary)}.reset-btn:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary);border-color:var(--color-text-secondary)}.generate-caption-btn{display:flex;align-items:center;gap:var(--spacing-sm);background-color:var(--color-accent);color:#fff;padding:var(--spacing-sm) var(--spacing-lg);border-radius:8px;font-weight:600;transition:background-color var(--transition-fast)}.generate-caption-btn:hover:not(:disabled){background-color:var(--color-accent-hover)}.generate-caption-btn:disabled{opacity:.5;cursor:not-allowed}.result-section{background-color:var(--color-bg-secondary);padding:var(--spacing-lg);border-radius:12px;border:1px solid var(--color-border);animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.result-section h3{font-size:var(--font-size-md);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-md)}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.copy-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.copy-btn:hover{background-color:var(--color-accent);border-color:var(--color-accent);color:#fff}.copy-btn:active{transform:scale(.98)}.caption-box{max-height:200px;overflow-y:auto;padding-right:var(--spacing-sm)}.caption-box::-webkit-scrollbar{width:6px}.caption-box::-webkit-scrollbar-track{background:transparent}.caption-box::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:3px}.caption-box p{font-size:var(--font-size-lg);line-height:1.6}.error-message{color:#ff4d4f;margin-top:var(--spacing-sm);font-size:var(--font-size-sm);text-align:center}@media(max-width:768px){.describe-image-page{gap:var(--spacing-md)}.upload-section{min-height:200px}.preview-actions{flex-direction:column;width:100%}.change-image-btn,.generate-caption-btn,.reset-btn{width:100%}.caption-box{max-height:100px}.caption-box p{font-size:var(--font-size-md)}.copy-btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:12px}.copy-btn span{display:none}}:root{--color-bg-primary: #121212;--color-bg-secondary: #1e1e1e;--color-bg-tertiary: #2c2c2c;--color-text-primary: #ffffff;--color-text-secondary: #a0a0a0;--color-accent: #646cff;--color-accent-hover: #747bff;--color-border: #333333;--color-overlay: rgba(0, 0, 0, .8);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--font-family: "Inter", system-ui, Avenir, Helvetica, Arial, sans-serif;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.25rem;--font-size-xl: 1.5rem;--transition-fast: .2s ease;--transition-normal: .3s ease;--sidebar-width: 250px;--sidebar-width-collapsed: 64px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--color-bg-primary);color:var(--color-text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100vh;overflow:hidden}button{cursor:pointer;border:none;background:none;font-family:inherit;color:inherit}a{text-decoration:none;color:inherit}#root{height:100vh;width:100vw;display:flex}
