.photo-masonry{columns:2;column-gap:12px;padding-bottom:180px}@media (min-width:640px){.photo-masonry{columns:3}}@media (min-width:1024px){.photo-masonry{columns:4}}@media (min-width:1440px){.photo-masonry{columns:5}}.photo-masonry-item{break-inside:avoid;cursor:pointer;border:1px solid var(--wb-border);background:var(--wb-bg-2);border-radius:12px;margin-bottom:12px;transition:transform .2s cubic-bezier(.16,1,.3,1),box-shadow .25s;position:relative;overflow:hidden}.photo-masonry-item:hover{box-shadow:0 8px 32px var(--wb-overlay);border-color:var(--wb-border-hover);transform:scale(1.02)}.photo-masonry-item img{object-fit:cover;width:100%;height:auto;display:block}.photo-masonry-item:after{content:"";opacity:0;pointer-events:none;z-index:1;background:linear-gradient(#0000 55%,#1a1d2e14 75%,#1a1d2e73 100%);transition:opacity .25s;position:absolute;inset:0}.photo-masonry-item:hover:after{opacity:1}.photo-masonry-item:active:after{opacity:0}.photo-masonry-item:active{transform:none}.photo-item-overlay{z-index:2;pointer-events:none;opacity:0;transition:opacity .2s;position:absolute;inset:0}.photo-masonry-item:hover .photo-item-overlay{opacity:1;pointer-events:auto}.photo-masonry-item.is-selected:after{opacity:1}.photo-masonry-item.is-selected .photo-item-overlay{opacity:1;pointer-events:auto}.photo-masonry-item.is-selected{outline:2px solid var(--wb-accent);outline-offset:-2px}.photo-item-right-icons{flex-direction:column;gap:8px;display:flex;position:absolute;top:10px;right:10px}.photo-item-icon-btn{background:var(--wb-glass-bg);-webkit-backdrop-filter:blur(8px);border:1px solid var(--wb-border);width:36px;height:36px;color:var(--wb-text-2);cursor:pointer;box-shadow:0 2px 6px var(--wb-shadow,#0000000d);border-radius:50%;justify-content:center;align-items:center;transition:all .15s;display:flex}.photo-item-icon-btn:hover{background:var(--wb-bg-2);border-color:var(--wb-border-hover);color:var(--wb-text-1);box-shadow:0 4px 12px var(--wb-overlay);transform:scale(1.08)}.photo-item-icon-btn svg{width:16px;height:16px}.photo-item-select{cursor:pointer;background:0 0;border:2px solid #ffffffb3;border-radius:50%;width:24px;height:24px;transition:all .15s;position:absolute;top:10px;left:10px;box-shadow:0 1px 3px #1a1d2e26}.photo-item-select:hover{background:#ffffff4d;border-color:#fff}.photo-item-select.selected{border-color:var(--wb-accent);background:var(--wb-accent)}.photo-item-icon-btn.liked{color:#ef4444;background:#fee2e2f2;border-color:#ef444440}.photo-item-icon-btn.liked:hover{background:#fee2e2}.photo-item-bottom-bar{justify-content:space-between;align-items:center;gap:6px;padding:10px 12px;display:flex;position:absolute;bottom:0;left:0;right:0}.photo-item-model-name{color:#fff;text-transform:uppercase;letter-spacing:.04em;text-shadow:0 1px 4px #0006;white-space:nowrap;text-overflow:ellipsis;max-width:120px;font-size:12px;font-weight:700;overflow:hidden}.photo-item-bottom-actions{align-items:center;gap:4px;display:flex}.photo-item-action-btn{-webkit-backdrop-filter:blur(8px);color:#4b5068;cursor:pointer;background:#ffffffe6;border:1px solid #e2e4ed80;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex;box-shadow:0 2px 6px #1a1d2e1a}.photo-item-action-btn:hover{background:var(--wb-bg-2);border-color:var(--wb-border-hover);color:var(--wb-accent)}.photo-item-action-btn svg{width:14px;height:14px}.photo-item-action-btn-dropdown{align-items:center;gap:2px;width:auto;padding:0 8px 0 10px;display:flex}.photo-item-action-btn-dropdown svg:last-child{opacity:.6;width:10px;height:10px}.photo-bottom-bar{z-index:50;background:var(--wb-glass-bg);-webkit-backdrop-filter:blur(40px)saturate(1.3);border-top:1px solid var(--wb-border);box-shadow:0 -4px 16px var(--wb-overlay);flex-direction:column;align-items:center;gap:10px;padding:16px 24px 20px;display:flex;position:fixed;bottom:0;left:0;right:0}.photo-prompt-row{align-items:center;gap:10px;width:100%;max-width:840px;display:flex}.photo-prompt-input{background:var(--wb-bg-2);border:1.5px solid var(--wb-border);color:var(--wb-text-1);resize:none;border-radius:14px;outline:none;flex:1;min-height:44px;padding:12px 16px;font-size:14px;transition:border-color .2s,box-shadow .2s}.photo-prompt-input::placeholder{color:var(--wb-text-4)}.photo-prompt-input:focus{border-color:#cf3aa080;box-shadow:0 0 0 3px #cf3aa01a}.photo-chips-row{flex-wrap:wrap;align-items:center;gap:8px;width:100%;max-width:840px;display:flex}.photo-chip{color:var(--wb-text-3);background:var(--wb-bg-2);border:1px solid var(--wb-border);cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;border-radius:10px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:600;transition:all .2s;display:inline-flex;position:relative}.photo-chip:hover{background:var(--wb-bg-base);border-color:var(--wb-border-hover);color:var(--wb-text-1)}.photo-chip.active{background:var(--wb-bg-highlight);border-color:var(--wb-border-active);color:var(--wb-accent)}.photo-chip-icon{opacity:.7;width:14px;height:14px}.photo-generate-btn{color:#fff;background:linear-gradient(135deg,var(--wb-accent-light),var(--wb-accent));cursor:pointer;white-space:nowrap;border:none;border-radius:14px;flex-shrink:0;align-items:center;gap:8px;padding:12px 24px;font-size:14px;font-weight:700;transition:all .2s cubic-bezier(.16,1,.3,1);display:inline-flex;box-shadow:0 2px 12px #cf3aa040}.photo-generate-btn:hover{transform:translateY(-1px);box-shadow:0 4px 20px #cf3aa059}.photo-generate-btn:active{transform:scale(.97)}.photo-generate-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.photo-count-control{border:1px solid var(--wb-border);background:var(--wb-bg-2);border-radius:10px;align-items:center;gap:2px;display:inline-flex;overflow:hidden}.photo-count-btn{width:28px;height:28px;color:var(--wb-text-3);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;font-size:16px;font-weight:600;transition:all .15s;display:flex}.photo-count-btn:hover{color:var(--wb-accent);background:var(--wb-bg-highlight)}.photo-count-value{color:var(--wb-text-1);text-align:center;min-width:20px;font-size:12px;font-weight:700}.photo-dropdown{background:var(--wb-bg-2);border:1px solid var(--wb-border);min-width:220px;box-shadow:0 16px 48px var(--wb-overlay);z-index:60;border-radius:14px;padding:6px;animation:.15s ease-out photo-dropdown-in;position:absolute;bottom:calc(100% + 8px);left:0}@keyframes photo-dropdown-in{0%{opacity:0;transform:translateY(8px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.photo-dropdown-item{color:var(--wb-text-3);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-size:13px;transition:all .15s;display:flex}.photo-dropdown-item:hover{background:var(--wb-bg-base);color:var(--wb-text-1)}.photo-dropdown-item.selected{background:var(--wb-bg-highlight);color:var(--wb-accent)}.photo-dropdown-item-badge{background:var(--wb-bg-highlight);color:var(--wb-accent);border:1px solid #cf3aa026;border-radius:6px;margin-left:auto;padding:2px 6px;font-size:12px;font-weight:700}.photo-modal-backdrop{z-index:100;-webkit-backdrop-filter:blur(16px);background:#1a1d2e59;justify-content:center;align-items:center;animation:.2s ease-out photo-modal-fade-in;display:flex;position:fixed;inset:0}@keyframes photo-modal-fade-in{0%{opacity:0}to{opacity:1}}.photo-modal-content{background:var(--wb-bg-2);border:1px solid var(--wb-border);width:95vw;max-width:1100px;max-height:90vh;box-shadow:0 24px 80px var(--wb-overlay);border-radius:20px;gap:0;animation:.25s cubic-bezier(.16,1,.3,1) photo-modal-scale-in;display:flex;overflow:hidden}@keyframes photo-modal-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.photo-modal-image-area{background:var(--wb-bg-base);flex:1;justify-content:center;align-items:center;min-width:0;display:flex;position:relative;overflow:hidden}.photo-modal-image-area img{object-fit:contain;max-width:100%;max-height:90vh}.photo-modal-sidebar{background:var(--wb-bg-2);border-left:1px solid var(--wb-border);flex-direction:column;flex-shrink:0;width:340px;padding:24px;display:flex;overflow-y:auto}@media (max-width:768px){.photo-modal-content{flex-direction:column}.photo-modal-sidebar{border-left:none;border-top:1px solid var(--wb-border);width:100%;max-height:50vh}}.photo-modal-section{margin-bottom:20px}.photo-modal-section-title{letter-spacing:.06em;text-transform:uppercase;color:var(--wb-text-4);align-items:center;gap:6px;margin-bottom:10px;font-size:12px;font-weight:700;display:flex}.photo-modal-prompt-text{color:var(--wb-text-2);margin-top:8px;font-size:13px;line-height:1.6}.photo-modal-info-row{border-bottom:1px solid var(--wb-border);justify-content:space-between;align-items:center;padding:8px 0;display:flex}.photo-modal-info-label{color:var(--wb-text-4);font-size:13px}.photo-modal-info-value{color:var(--wb-text-1);font-size:13px;font-weight:500}.photo-modal-actions-row{flex-wrap:wrap;gap:6px;margin-top:16px;margin-bottom:16px;display:flex}.photo-modal-action-btn{color:var(--wb-text-3);background:var(--wb-bg-base);border:1px solid var(--wb-border);cursor:pointer;border-radius:10px;align-items:center;gap:6px;padding:8px 14px;font-size:12px;font-weight:600;transition:all .15s;display:inline-flex}.photo-modal-action-btn:hover{background:var(--wb-bg-highlight);color:var(--wb-accent);border-color:var(--wb-border-active)}.photo-modal-primary-action{color:#fff;background:linear-gradient(135deg,var(--wb-accent-light),var(--wb-accent));cursor:pointer;border:none;border-radius:14px;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px 20px;font-size:14px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 2px 12px #cf3aa033}.photo-modal-primary-action:hover{transform:translateY(-1px);box-shadow:0 4px 20px #cf3aa059}.photo-modal-secondary-btns{grid-template-columns:1fr 1fr;gap:8px;margin-top:8px;display:grid}.photo-modal-secondary-btn{color:var(--wb-text-3);background:var(--wb-bg-base);border:1px solid var(--wb-border);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;gap:6px;padding:10px 12px;font-size:12px;font-weight:600;transition:all .15s;display:flex}.photo-modal-secondary-btn:hover{background:var(--wb-bg-highlight);color:var(--wb-accent)}.photo-modal-bottom-row{align-items:center;gap:8px;margin-top:8px;display:flex}.photo-modal-icon-btn{border:1px solid var(--wb-border);background:var(--wb-bg-2);width:36px;height:36px;color:var(--wb-text-3);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;transition:all .15s;display:flex}.photo-modal-icon-btn:hover{background:var(--wb-bg-highlight);color:var(--wb-accent)}.photo-tabs{background:var(--wb-bg-deep);border:1px solid var(--wb-border);border-radius:12px;gap:4px;margin-bottom:16px;padding:4px;display:inline-flex}.photo-tab{color:var(--wb-text-3);cursor:pointer;background:0 0;border:none;border-radius:9px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.photo-tab:hover{color:var(--wb-text-2)}.photo-tab.active{background:var(--wb-bg-2);color:var(--wb-text-1);box-shadow:0 1px 3px var(--wb-overlay)}.photo-shimmer{background:linear-gradient(90deg,var(--wb-bg-base)0%,var(--wb-border)50%,var(--wb-bg-base)100%);background-size:200% 100%;border-radius:12px;animation:1.5s ease-in-out infinite photo-shimmer-anim}@keyframes photo-shimmer-anim{0%{background-position:200% 0}to{background-position:-200% 0}}.photo-ref-chip{background:var(--wb-bg-highlight);color:var(--wb-accent);border:1px solid #cf3aa033;border-radius:8px;align-items:center;gap:6px;padding:4px 8px 4px 4px;font-size:12px;font-weight:600;display:inline-flex}.photo-ref-chip img{object-fit:cover;border-radius:5px;width:24px;height:24px}.photo-ref-chip-remove{width:16px;height:16px;color:var(--wb-text-3);cursor:pointer;background:#cf3aa014;border:none;border-radius:50%;justify-content:center;align-items:center;margin-left:2px;font-size:12px;transition:all .15s;display:flex}.photo-ref-chip-remove:hover{color:#ef4444;background:#ef444426}.photo-modal-close{background:var(--wb-glass-bg);border:1px solid var(--wb-border);width:32px;height:32px;color:var(--wb-text-3);cursor:pointer;z-index:10;box-shadow:0 1px 3px var(--wb-overlay);border-radius:10px;justify-content:center;align-items:center;transition:all .15s;display:flex;position:absolute;top:12px;right:12px}.photo-modal-close:hover{background:var(--wb-bg-2);color:var(--wb-text-1);box-shadow:0 2px 8px var(--wb-overlay)}.photo-copy-btn{color:var(--wb-text-3);background:var(--wb-bg-base);border:1px solid var(--wb-border);cursor:pointer;text-transform:uppercase;letter-spacing:.04em;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:700;transition:all .15s}.photo-copy-btn:hover{background:var(--wb-bg-highlight);color:var(--wb-accent)}.idm-backdrop{z-index:100;-webkit-backdrop-filter:blur(12px);background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.idm-content{background:var(--background,#fff);border:1px solid var(--border,#e5e7eb);border-radius:20px;gap:0;width:95vw;max-width:1060px;max-height:92vh;display:flex;overflow:hidden;box-shadow:0 24px 80px #0003}.idm-image-area{background:var(--muted,#f5f5f5);flex-direction:column;flex:1;justify-content:center;align-items:center;min-width:0;display:flex;position:relative;overflow:hidden}.idm-image-wrap{flex:1;justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.idm-image-wrap img{object-fit:contain;max-width:100%;max-height:85vh}.idm-image-loading{flex-direction:column;justify-content:center;align-items:center;min-height:300px;display:flex}.idm-version-tabs{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;border-radius:10px;gap:4px;padding:8px 12px;display:flex;position:absolute;bottom:12px;right:12px}.idm-version-tab{color:#ffffffb3;cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:4px;padding:4px 12px;font-size:12px;font-weight:600;transition:all .15s;display:flex}.idm-version-tab:hover{color:#fff;background:#ffffff1a}.idm-version-tab.active{color:#fff;background:#fff3}.idm-version-tab.processing{color:#ffffff80}.idm-sidebar{background:var(--background,#fff);border-left:1px solid var(--border,#e5e7eb);flex-direction:column;flex-shrink:0;width:340px;padding:20px;display:flex;overflow-y:auto}@media (max-width:768px){.idm-content{flex-direction:column;max-height:95vh}.idm-sidebar{border-left:none;border-top:1px solid var(--border,#e5e7eb);width:100%;max-height:50vh}}.idm-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.idm-close-btn{background:var(--foreground,#1a1a2e);width:32px;height:32px;color:var(--background,#fff);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .15s;display:flex}.idm-close-btn:hover{opacity:.85;transform:scale(1.05)}.idm-section{margin-bottom:16px}.idm-section-label{color:var(--muted-foreground,#888);margin-bottom:4px;font-size:12px}.idm-separator{background:var(--border,#e5e7eb);height:1px;margin:12px -20px}.idm-info-toggle{cursor:pointer;width:100%;color:var(--foreground,#1a1a2e);background:0 0;border:none;justify-content:space-between;align-items:center;padding:0;display:flex}.idm-info-grid{margin-top:8px}.idm-info-row{border-bottom:1px solid var(--border,#e5e7eb);justify-content:space-between;padding:6px 0;display:flex}.idm-info-label{color:var(--muted-foreground,#888);font-size:13px}.idm-info-value{color:var(--foreground,#1a1a2e);font-size:13px;font-weight:500}.idm-quick-actions{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:4px;display:grid}.idm-action-btn{color:var(--foreground,#1a1a2e);background:var(--background,#fff);border:1px solid var(--border,#e5e7eb);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:10px 12px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.idm-action-btn:hover{background:var(--muted,#f5f5f5);border-color:var(--foreground,#1a1a2e)}.idm-improve-input-wrap{margin-bottom:8px}.idm-improve-input{border:1.5px solid var(--border,#e5e7eb);background:var(--background,#fff);width:100%;color:var(--foreground,#1a1a2e);border-radius:12px;outline:none;padding:10px 14px;font-size:14px;transition:border-color .15s}.idm-improve-input:focus{border-color:#b8e040}.idm-improve-input::placeholder{color:var(--muted-foreground,#999)}.idm-improve-btn{color:#1a1a2e;cursor:pointer;background:#c8e94e;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:10px 16px;font-size:14px;font-weight:700;transition:all .15s;display:flex}.idm-improve-btn:hover:not(:disabled){background:#b8d83e;transform:translateY(-1px)}.idm-improve-btn:disabled{opacity:.5;cursor:not-allowed}.idm-improve-cost{background:#00000014;border-radius:20px;align-items:center;gap:2px;padding:2px 8px;font-size:12px;font-weight:600;display:inline-flex}.idm-version-pills{flex-wrap:wrap;gap:4px;margin-bottom:8px;display:flex}.idm-version-pill{color:var(--muted-foreground,#888);background:var(--muted,#f5f5f5);cursor:pointer;border:1px solid #0000;border-radius:8px;padding:4px 14px;font-size:12px;font-weight:600;transition:all .15s}.idm-version-pill:hover{color:var(--foreground,#1a1a2e)}.idm-version-pill.active{color:var(--foreground,#1a1a2e);background:var(--background,#fff);border-color:var(--foreground,#1a1a2e)}.idm-version-timeline{max-height:120px;overflow-y:auto}.idm-timeline-entry{padding:6px 0}.idm-timeline-header{justify-content:space-between;align-items:center;display:flex}.idm-versions-section{min-height:0}.idm-bottom-row{border-top:1px solid var(--border,#e5e7eb);align-items:center;gap:8px;padding-top:12px;display:flex}.idm-download-btn{color:#1a1a2e;cursor:pointer;background:#c8e94e;border:none;border-radius:14px;flex:1;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:14px;font-weight:700;transition:all .15s;display:flex}.idm-download-btn:hover{background:#b8d83e}.idm-bottom-icons{gap:4px;display:flex}.idm-icon-btn{border:1px solid var(--border,#e5e7eb);background:var(--background,#fff);width:38px;height:38px;color:var(--muted-foreground,#888);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;transition:all .15s;display:flex}.idm-icon-btn:hover{color:var(--foreground,#1a1a2e);border-color:var(--foreground,#1a1a2e)}.idm-icon-btn.liked{color:#ef4444;border-color:#ef4444}
