:root {
  --bg: #f5f5f7;
  --bg-card: #ffffff;
  --bg-input: #f0f0f3;
  --bg-hover: #e8e8ec;
  --border: #e0e0e4;
  --border-focus: #e63946;
  --text: #1a1a1a;
  --text2: #555;
  --text3: #999;
  --accent: #e63946;
  --accent-light: #fef0f1;
  --accent-hover: #d32f3c;
  --danger: #e74c3c;
  --success: #27ae60;
  --r: 12px;
  --r-sm: 8px;
  --shadow: 0 1px 3px rgba(0,0,0,0.05), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-lg: 0 4px 20px rgba(0,0,0,0.08);
  --gal-cols: 5;
}

[data-theme="dark"] {
  --bg: #0d0c0e;
  --bg-card: #161518;
  --bg-input: #1e1d20;
  --bg-hover: #2a292c;
  --border: #2e2d30;
  --border-focus: #e63946;
  --text: #e8e8e8;
  --text2: #aaa;
  --text3: #777;
  --accent: #e63946;
  --accent-light: rgba(230,57,70,.15);
  --accent-hover: #f04555;
  --danger: #e74c3c;
  --success: #2ecc71;
  --shadow: none;
  --shadow-lg: 0 4px 20px rgba(0,0,0,0.3);
}

/* Theme toggle */
.theme-icon-dark{display:none}
[data-theme="dark"] .theme-icon-light{display:none}
[data-theme="dark"] .theme-icon-dark{display:block}

/* Sidebar collapse button */
.sb-top-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:14px;flex-shrink:0}
.sb-logo-link{display:flex;align-items:center;text-decoration:none;padding:2px;border-radius:6px;transition:opacity .15s}
.sb-logo-link:hover{opacity:.75}
.sb-logo{width:28px;height:28px;object-fit:contain;display:block}
.sb-logo-dark{display:none}
[data-theme="dark"] .sb-logo-light{display:none}
[data-theme="dark"] .sb-logo-dark{display:block}
.sidebar.collapsed .sb-logo-link{display:none}
.sidebar.collapsed .sb-top-row{justify-content:center}
.sb-collapse-header{background:none;border:none;color:var(--text3);cursor:pointer;padding:6px;border-radius:var(--r-sm);transition:all .15s;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sb-collapse-header:hover{color:var(--text)}
.sb-icon-closed{display:none}
.sidebar.collapsed .sb-icon-open{display:none}
.sidebar.collapsed .sb-icon-closed{display:block}
.sidebar.collapsed .sb-collapse-header{justify-content:center}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

html{scrollbar-gutter:stable}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100vh;min-height:100dvh;overflow-x:hidden}
body.auth-screen{overflow:hidden;height:100vh;height:100dvh}

#app{min-height:100vh;min-height:100dvh}

/* Screens */
@keyframes screen-fade-in{from{opacity:0}to{opacity:1}}
.screen{display:none}
.screen.active{display:flex}
#screen-email.active,#screen-code.active,#screen-key.active{align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:16px;overflow:hidden}
#screen-main.active{display:block}

/* Auth cards */
.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:44px 36px;max-width:400px;width:100%;text-align:center;box-shadow:var(--shadow-lg)}
.auth-logo{width:56px;height:56px;border-radius:14px;margin-bottom:16px}
.auth-title{font-size:24px;font-weight:700;margin-bottom:4px;letter-spacing:-.3px}
.auth-sub{font-size:14px;color:var(--text2);margin-bottom:24px}
.legal{font-size:11px;color:var(--text3);margin-top:20px;line-height:1.4}
.err{color:var(--danger);font-size:13px;margin-top:10px;min-height:18px}

/* Fields */
.field{margin-bottom:12px}
.field-label{display:block;font-size:12px;font-weight:500;color:var(--text2);margin-bottom:4px}
.field input,.field select,.field textarea{width:100%;padding:11px 14px;background:var(--bg-input);border:1.5px solid transparent;border-radius:var(--r);color:var(--text);font-size:14px;outline:none;transition:border .15s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent)}
.field input::placeholder,.field textarea::placeholder{color:var(--text3)}
.field input:disabled{background:var(--bg-hover);color:var(--text3);cursor:not-allowed}
.hint{font-size:12px;color:var(--text3);margin:4px 0 12px}
.code-cells{display:flex;gap:10px;justify-content:center;margin:16px 0 20px}
.code-cell{width:46px;height:56px;text-align:center;font-size:28px;font-weight:700;background:var(--bg-input);border:2px solid var(--border);border-radius:var(--r);color:var(--text);outline:none;transition:border .15s,box-shadow .15s;padding:0;caret-color:var(--accent)}
.code-cell:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(220,53,69,.15)}
.code-cell.filled{border-color:var(--accent)}
.code-cells.shake{animation:shake .4s}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}

/* Buttons */
.btn-main{display:inline-flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:11px 20px;background:var(--accent);color:#fff;border:none;border-radius:var(--r);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}
.btn-main:hover{background:var(--accent-hover)}
.btn-main:disabled{opacity:.45;cursor:not-allowed}
.btn-main.btn-sm{width:auto;padding:7px 16px;font-size:13px}
.btn-main.btn-gen{padding:14px;font-size:15px;margin-top:4px}
.btn-ghost{display:inline-flex;align-items:center;justify-content:center;width:100%;padding:10px 20px;background:transparent;color:var(--text2);border:1.5px solid var(--border);border-radius:var(--r);font-size:14px;cursor:pointer;transition:all .15s;margin-top:8px}
.btn-ghost:hover{background:var(--bg-hover);border-color:var(--border)}
.btn-ghost.btn-sm{width:auto;padding:7px 16px;font-size:13px;margin:0}
.btn-icon{background:none;border:none;color:var(--text2);cursor:pointer;padding:6px;border-radius:var(--r-sm);transition:background .15s}
.btn-icon:hover{background:var(--bg-hover);color:var(--text)}
.loading{opacity:.6;pointer-events:none}

/* Close / Delete buttons */
.btn-close-lb{display:inline-flex;align-items:center;justify-content:center;padding:7px 16px;background:#fff;color:var(--text);border:none;border-radius:var(--r);font-size:13px;font-weight:600;cursor:pointer}
.btn-close-lb:hover{background:#f0f0f0}
.btn-del{display:inline-flex;align-items:center;justify-content:center;padding:7px 16px;background:var(--danger);color:#fff;border:none;border-radius:var(--r);font-size:13px;font-weight:600;cursor:pointer}
.btn-del:hover{background:#c0392b}

/* App layout */
.app-layout{min-height:100vh}

/* Sidebar */
.sidebar{width:220px;background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:20px 14px;position:fixed;top:0;left:0;bottom:0;z-index:50;transition:width .2s ease}
.sb-header{display:flex;align-items:center;gap:10px;margin-bottom:14px;padding:0 6px;cursor:default;min-height:36px}
.sb-avatar-wrap{width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--accent-light)}
.sb-avatar{width:100%;height:100%;object-fit:cover}
.sb-brand{font-size:15px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sb-nav{display:flex;flex-direction:column;gap:2px;flex:1}
.sb-link{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:10px 14px;border-radius:var(--r);background:none;border:none;color:var(--text2);font-size:14px;cursor:pointer;transition:all .12s;white-space:nowrap;overflow:hidden}
.sb-link svg{flex-shrink:0}
.sb-link:hover{background:var(--bg-hover);color:var(--text)}
.sb-link.active{background:var(--accent-light);color:var(--accent);font-weight:600}
.sb-collapse{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text3);cursor:pointer;padding:8px;border-radius:var(--r-sm);transition:all .15s;margin-bottom:8px;width:100%}
.sb-collapse:hover{background:var(--bg-hover);color:var(--text)}
.sb-collapse svg{flex-shrink:0}
.sb-footer{margin-top:auto;padding-top:16px;border-top:1px solid var(--border)}
.sb-email{font-size:12px;color:var(--text3);margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer;padding:4px 0;transition:color .12s}
.sb-email:hover{color:var(--accent)}
.sb-logout{background:none;border:none;color:var(--text3);font-size:13px;cursor:pointer;padding:4px 0;white-space:nowrap;overflow:hidden}
.sb-logout:hover{color:var(--danger)}

/* Sidebar collapsed */
.sidebar.collapsed{width:60px;padding:20px 8px}
.sidebar.collapsed .sb-brand,
.sidebar.collapsed .sb-link-text,
.sidebar.collapsed .sb-email,
.sidebar.collapsed .sb-logout{display:none}
.sidebar.collapsed .sb-header{justify-content:center;padding:0}
.sidebar.collapsed .sb-link{justify-content:center;padding:10px}
.sidebar.collapsed .sb-footer{border-top:none;padding-top:8px}

/* Content */
.content{margin-left:220px;padding:28px 40px 0;min-height:100vh;transition:margin-left .2s ease,padding .2s ease}
.sb-collapsed .content{margin-left:60px}
@keyframes tab-fade-in{from{opacity:0}to{opacity:1}}
.tab{display:none}
.tab.active{display:block}
#tab-settings{max-width:860px;margin-left:auto;margin-right:auto}
.tab-title{font-size:20px;font-weight:700;margin-bottom:20px}

/* Async-loaded blocks fade in together once /models, /balance, /model-costs all resolve */
.async-block{opacity:0;transition:opacity .18s ease}
body.data-loaded .async-block{opacity:1}

/* Editor tab */
.ed-head{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:8px}
.ed-canvas-head-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0;flex-wrap:wrap}
.ed-current-project{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:999px;font-size:13px;color:var(--text);max-width:100%;min-width:0}
.ed-project-title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;max-width:260px}
.ed-project-rename{background:none;border:none;color:var(--text3);cursor:pointer;padding:2px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;transition:color .12s,background .12s}
.ed-project-rename:hover{color:var(--accent);background:var(--accent-light)}
.ed-project-title{outline:none;border-radius:4px;padding:0 2px;transition:background .12s,box-shadow .12s}
.ed-project-title.editing{background:var(--bg-input);box-shadow:0 0 0 1.5px var(--accent);max-width:none;overflow:visible;cursor:text;caret-color:var(--accent)}
.ed-project-status{font-size:10px;color:var(--text3);font-weight:500;white-space:nowrap;flex-shrink:0;text-transform:lowercase}
.ed-project-status.saving{color:var(--text3)}
.ed-project-status.saved{color:var(--accent)}
.ed-project-status.err{color:var(--danger)}

/* Gallery view */
.ed-gallery{display:flex;flex-direction:column;gap:18px;padding-bottom:24px}
.ed-gallery[hidden]{display:none !important}
#ed-canvas-view[hidden]{display:none !important}

/* No reveal animation on gallery/canvas — display:block changes inside .tab were
   re-triggering the fade-in on every tab switch and looked jittery. Keep keyframe
   for the loading-card. */
@keyframes edFadeIn{from{opacity:0}to{opacity:1}}

/* Editor tips modal — bigger than default, scrollable body */
.ed-tips-box{max-width:620px;width:100%;max-height:88vh;display:flex;flex-direction:column}
.ed-tips-body{overflow-y:auto;display:flex;flex-direction:column;padding-right:4px}
.ed-tip{display:flex;align-items:flex-start;gap:14px;padding:14px 0;border-bottom:1px solid var(--border)}
.ed-tip:first-child{padding-top:4px}
.ed-tip:last-child{border-bottom:none;padding-bottom:4px}
.ed-tip-num{flex:0 0 28px;width:28px;height:28px;border-radius:50%;background:var(--accent-light);color:var(--accent);font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;font-variant-numeric:tabular-nums;flex-shrink:0;margin-top:2px}
.ed-tip-content{flex:1;min-width:0}
.ed-tip-content h4{font-size:14px;font-weight:600;color:var(--text);margin:0 0 4px;letter-spacing:-.005em}
.ed-tip-content p{font-size:13px;color:var(--text2);line-height:1.55;margin:0}
.ed-tip-content b{color:var(--text);font-weight:600}
.ed-tip-list{margin:6px 0 0;padding:0 0 0 4px;list-style:none;display:flex;flex-direction:column;gap:5px}
.ed-tip-list li{font-size:13px;color:var(--text2);line-height:1.5;padding-left:14px;position:relative}
.ed-tip-list li::before{content:'';position:absolute;left:2px;top:.7em;width:4px;height:4px;border-radius:50%;background:var(--text3)}

/* Fullscreen loading overlay during project open — fully opaque so any flicker
   underneath (image swap, viewport resize, fit-zoom) is hidden. */
.ed-loading-overlay{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .22s ease;flex-direction:column;gap:14px}
.ed-loading-overlay.show{opacity:1;pointer-events:auto}
.ed-loading-card{display:flex;align-items:center;gap:14px;padding:18px 24px;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;box-shadow:0 14px 36px rgba(0,0,0,.18);font-size:14px;color:var(--text);font-weight:500;animation:edFadeIn .25s ease}
[data-theme="dark"] .ed-loading-card{box-shadow:0 14px 36px rgba(0,0,0,.55)}
.ed-loading-spinner{width:24px;height:24px;border:2.5px solid color-mix(in srgb,var(--text3) 30%,transparent);border-top-color:var(--accent);border-radius:50%;animation:edLoadSpin .85s linear infinite;flex-shrink:0}
@keyframes edLoadSpin{to{transform:rotate(360deg)}}
.ed-loading-text{white-space:nowrap;text-overflow:ellipsis;overflow:hidden;max-width:340px}
.ed-gallery-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}
.ed-gallery-head h2{margin:0}
.ed-gallery-head .ed-lead{margin:0;max-width:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ed-gallery-head button{flex-shrink:0}
.ed-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}
.ed-gallery-grid:empty{display:none}
.ed-gallery-note{font-size:11px;color:var(--text3);text-align:center;padding-top:6px;line-height:1.5}
.ed-gallery-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:14px;padding:60px 24px;border:2px dashed var(--border);border-radius:14px;color:var(--text3)}
.ed-gallery-empty[hidden]{display:none}
.ed-gallery-empty p{margin:0;font-size:14px}
.ed-gallery-empty svg{margin-bottom:-4px}

/* Project card (Photoshop-style start screen) */
.ed-pcard{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;overflow:hidden;cursor:pointer;transition:border-color .12s;display:flex;flex-direction:column}
.ed-pcard-thumb{aspect-ratio:4/3;background:var(--bg-input);display:flex;align-items:center;justify-content:center;color:var(--text3);overflow:hidden;position:relative}
.ed-pcard-thumb::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,0);transition:background .2s;pointer-events:none;z-index:2}
.ed-pcard:hover .ed-pcard-thumb::after{background:rgba(0,0,0,.35)}
.ed-pcard-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.ed-pcard-thumb .ed-pcard-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;font-size:11px;color:var(--text3);opacity:.7}
.ed-pcard-info{padding:8px 10px 10px;display:flex;flex-direction:column;gap:2px}
.ed-pcard-name{font-size:12px;font-weight:600;color:var(--text);letter-spacing:-.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ed-pcard-meta{font-size:10px;color:var(--text3)}
.ed-pcard-actions{position:absolute;top:6px;right:6px;display:flex;gap:4px;opacity:0;transition:opacity .15s;z-index:2}
.ed-pcard:hover .ed-pcard-actions{opacity:1}
.ed-pcard-act{width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.92);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .12s,color .12s;color:#333}
.ed-pcard-act:hover{background:#fff}
.ed-pcard-act svg{width:12px;height:12px}
.ed-pcard-act.del:hover{background:var(--danger);color:#fff}
[data-theme="dark"] .ed-pcard-act{background:rgba(40,40,40,.92);color:#eee}
[data-theme="dark"] .ed-pcard-act:hover{background:rgba(60,60,60,1)}
/* "+ Новый проект" — keep accent treatment */
.ed-pcard.new{border-style:dashed;background:transparent;display:flex;align-items:center;justify-content:center;min-height:150px;color:var(--text3);font-size:13px;font-weight:600;transition:color .12s,border-color .12s,background .12s}
.ed-pcard.new:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-light)}
.ed-pcard.new .ed-pcard-thumb,.ed-pcard.new .ed-pcard-info{display:none}
.ed-pcard-new-inner{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px}
.ed-head .tab-title{margin-bottom:0;display:flex;align-items:center;gap:10px}
.ed-head-actions{display:flex;gap:8px;flex-wrap:wrap}
.ed-lead{color:var(--text3);font-size:13px;margin:-4px 0 16px;max-width:760px;line-height:1.5}

/* Unified BETA pill — soft amber, dark text */
.sb-beta,.m-tab-beta,.ed-beta-pill{font-size:10px;font-weight:700;background:#fbbf24;color:#1c1410;padding:2px 7px;border-radius:999px;letter-spacing:.05em;line-height:1.25;display:inline-block;text-transform:uppercase}
.sb-beta,.m-tab-beta{font-size:9px;padding:1px 5px;margin-left:6px;border-radius:6px}
[data-theme="dark"] .sb-beta,[data-theme="dark"] .m-tab-beta,[data-theme="dark"] .ed-beta-pill{background:#fbbf24;color:#1c1410}
.sidebar.collapsed .sb-beta{display:none}

/* Hidden helpers — enforce display:none even with flex/grid parents */
.ed-empty[hidden],.ed-canvas-box[hidden],.ed-progress[hidden],.ed-head-actions [hidden],.ed-toolbar[hidden],.ed-toolbar [hidden],.ed-viewport[hidden],.ed-brush-cursor[hidden],.ed-brush-control[hidden],.ed-marquee[hidden],#ed-resolution-section[hidden]{display:none !important}

.ed-workspace{display:flex;flex-direction:column;gap:10px;min-height:560px;height:calc(100vh - 220px)}
.ed-toolbar{display:flex;align-items:center;gap:14px;padding:8px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;flex-wrap:wrap;flex-shrink:0}
.ed-tool-group{display:inline-flex;background:var(--bg-input);border-radius:8px;padding:2px;gap:2px}
.ed-tool{display:flex;align-items:center;justify-content:center;width:32px;height:30px;border:none;border-radius:6px;background:transparent;color:var(--text3);cursor:pointer;transition:all .12s}
.ed-tool:hover{color:var(--text)}
.ed-tool.active{background:var(--bg-card);color:var(--text);box-shadow:0 1px 2px rgba(0,0,0,.06)}
.ed-tool:disabled{opacity:.4;cursor:default}
.ed-tool:disabled:hover{color:var(--text3)}
#ed-undo,#ed-redo,#ed-zoom-in,#ed-zoom-out{font-size:14px}
#ed-zoom-fit{font-size:11px;padding:0 8px;width:auto;letter-spacing:.04em}
.ed-zoom-readout{font-size:12px;font-weight:600;color:var(--text2);font-variant-numeric:tabular-nums;min-width:50px;text-align:center}
.ed-brush-control{display:flex;align-items:center;gap:8px;flex:1;max-width:320px;min-width:200px}
.ed-brush-control label{font-size:11px;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}
.ed-brush-control input[type=range]{flex:1;accent-color:var(--accent);cursor:pointer;height:4px;min-width:60px}
.ed-brush-control b{font-size:12px;font-weight:600;font-variant-numeric:tabular-nums;color:var(--text);min-width:40px;text-align:right}
/* Tight right-side cluster: reset · tips · download, closer together than other groups */
.ed-toolbar .ed-toolbar-right{margin-left:auto;display:inline-flex;align-items:center;gap:6px}

.ed-main{display:grid;grid-template-columns:1fr 320px;gap:12px;min-height:0;flex:1}

.ed-stage{position:relative;background:#f1f3f5;border:1px solid var(--border);border-radius:12px;overflow:hidden;min-height:0;display:flex;align-items:center;justify-content:center;touch-action:none;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}
.ed-stage canvas,.ed-stage .ed-viewport,.ed-stage .ed-marquee{touch-action:none}
[data-theme="dark"] .ed-stage{background:#000}
.ed-stage.drop-active{border-color:var(--accent);box-shadow:inset 0 0 0 2px var(--accent)}
.ed-stage.panning,.ed-stage.panning *{cursor:grabbing !important}
.ed-stage.pan-mode{cursor:grab}
.ed-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:48px 24px;color:#9ca3af;width:100%;height:100%}
.ed-empty p{font-size:14px;margin:0 0 18px;max-width:340px;line-height:1.5}
.ed-empty svg{margin-bottom:14px}
.ed-viewport{position:absolute;top:0;left:0;transform-origin:0 0;will-change:transform;transition:transform .08s ease-out}
.ed-viewport.no-anim{transition:none}
.ed-canvas-box{position:relative;display:block;line-height:0}
.ed-canvas-box.reveal-in{animation:img-reveal .45s ease}
/* Photoshop-style transparency checker — visual only, exported PNG keeps real alpha */
.ed-canvas-box.transparent-bg{background-color:#fff;background-image:linear-gradient(45deg,#c5c8cc 25%,transparent 25%,transparent 75%,#c5c8cc 75%,#c5c8cc),linear-gradient(45deg,#c5c8cc 25%,transparent 25%,transparent 75%,#c5c8cc 75%,#c5c8cc);background-position:0 0,20px 20px;background-size:40px 40px}
#ed-canvas-base,#ed-canvas-mask{display:block}
#ed-canvas-mask{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:auto;cursor:crosshair}
.ed-brush-cursor{position:absolute;border:1.5px solid #fff;border-radius:50%;box-shadow:0 0 0 1px rgba(0,0,0,.65),inset 0 0 0 1px rgba(0,0,0,.4);pointer-events:none;transform:translate(-50%,-50%);z-index:6;will-change:transform}

/* Marching ants selection */
.ed-marquee{position:absolute;pointer-events:auto;cursor:move;z-index:5;display:block;overflow:visible}
.ed-marquee.dragging{cursor:grabbing}
.ed-marquee svg{width:100%;height:100%;display:block;overflow:visible;pointer-events:none}
.ed-marquee .ants{animation:ed-ants .5s linear infinite}
@keyframes ed-ants{to{stroke-dashoffset:-12}}
.ed-marquee:hover ~ .ed-brush-cursor{display:none !important}

/* Unified shape-tool group: brush + eraser + rect on one shared background */
.ed-tool-group-shape .ed-tool-group-brush{background:transparent;padding:0;border:none;display:inline-flex;gap:2px;position:relative}
/* Brush size popover (appears on hover over brush/eraser group) */
.ed-tool-group-brush{position:relative}
.ed-brush-popover{position:absolute;top:calc(100% + 6px);left:0;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:10px 12px;min-width:240px;box-shadow:0 8px 24px rgba(0,0,0,.12);display:flex;flex-direction:column;gap:6px;opacity:0;visibility:hidden;transform:translateY(-4px);transition:opacity .15s,visibility .15s,transform .15s;transition-delay:.18s;pointer-events:none;z-index:50}
.ed-brush-popover::before{content:'';position:absolute;top:-6px;left:0;right:0;height:6px}
.ed-brush-popover label{font-size:10px;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.ed-brush-popover-row{display:flex;align-items:center;gap:10px}
.ed-brush-popover input[type=range]{flex:1;accent-color:var(--accent);cursor:pointer}
.ed-brush-popover b{font-size:12px;font-weight:600;font-variant-numeric:tabular-nums;color:var(--text);min-width:48px;text-align:right}
.ed-tool-group-brush:hover .ed-brush-popover,.ed-tool-group-brush:focus-within .ed-brush-popover,.ed-brush-popover:hover{opacity:1;visibility:visible;transform:none;pointer-events:auto;transition-delay:0s}
[data-theme="dark"] .ed-brush-popover{box-shadow:0 8px 24px rgba(0,0,0,.4)}
.ed-progress{position:absolute;inset:0;background:rgba(10,10,10,.86);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:#fff;z-index:10}
.ed-progress-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.15);border-top-color:var(--accent);border-radius:50%;animation:ed-spin 1s linear infinite}
@keyframes ed-spin{to{transform:rotate(360deg)}}
.ed-progress-text{font-size:13px;font-weight:500}

.ed-right{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:14px;overflow-y:auto;min-height:0}
.ed-balance-bar{margin:0 0 4px}
.ed-section{display:flex;flex-direction:column;gap:6px}
.ed-label,.ed-section-title{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.04em;margin:0}
.ed-section textarea{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--bg-input);color:var(--text);font-family:inherit;font-size:13px;line-height:1.45;resize:vertical;min-height:64px;overflow:hidden}
.ed-prompt-wrap{position:relative}
.ed-prompt-wrap textarea{padding-right:34px;resize:none}
/* Small × inside the prompt — clears the textarea (pushed near right edge) */
.ed-prompt-clear{position:absolute;top:6px;right:6px;width:20px;height:20px;border-radius:50%;border:none;background:rgba(0,0,0,.06);color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .12s,color .12s;z-index:1}
.ed-prompt-clear:hover{background:rgba(0,0,0,.12);color:var(--text)}
[data-theme="dark"] .ed-prompt-clear{background:rgba(255,255,255,.08)}
[data-theme="dark"] .ed-prompt-clear:hover{background:rgba(255,255,255,.16)}
/* Touch-resize grip at the bottom edge — works on iPad where the native textarea
   handle isn't a touch target. */
.ed-prompt-grip{position:absolute;bottom:0;left:0;right:0;height:14px;cursor:ns-resize;display:flex;align-items:center;justify-content:center;touch-action:none;user-select:none;-webkit-user-select:none;opacity:.45;transition:opacity .12s}
.ed-prompt-grip::before{content:'';width:30px;height:3px;background:var(--text3);border-radius:2px}
.ed-prompt-grip:hover,.ed-prompt-wrap:hover .ed-prompt-grip{opacity:.8}
/* Inherits .prompt-actions (overflow-x:auto, mask fade, etc.) — both classes applied in HTML. */
.ed-prompt-actions{margin:6px 0}
.ed-section textarea:focus{outline:none;border-color:var(--accent)}
.ed-select{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--bg-input);color:var(--text);font-family:inherit;font-size:13px;cursor:pointer}
.ed-select:focus{outline:none;border-color:var(--accent)}
.ed-model-hint{font-size:11px;color:var(--text3);font-variant-numeric:tabular-nums}
.ed-generate-btn{display:flex;align-items:center;justify-content:center;gap:8px;font-weight:600;width:100%}
.ed-generate-btn:disabled{opacity:.45;cursor:not-allowed}

.ed-layers{display:flex;flex-direction:column;gap:8px;max-height:480px;overflow-y:auto}
.ed-layer{border:1px solid var(--border);border-radius:10px;background:var(--bg-input);transition:border-color .12s,background .12s;font-size:12px;overflow:hidden}
.ed-layer.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 5%,var(--bg-input))}
.ed-layer.dragging{opacity:.45;cursor:grabbing}
.ed-layer.drag-over{box-shadow:0 -2px 0 var(--accent) inset}
.ed-layer-head{cursor:grab}
.ed-layer.dragging .ed-layer-head{cursor:grabbing}
/* Variant switcher row inside layer card */
.ed-layer-variants{display:flex;align-items:center;gap:6px;padding:0 10px 8px;flex-wrap:wrap}
.ed-layer-variants-label{font-size:9px;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-right:2px}
.ed-variant-chip{width:24px;height:24px;border:1px solid var(--border);border-radius:6px;background:var(--bg-card);color:var(--text2);font-size:11px;font-weight:600;cursor:pointer;transition:all .12s;font-family:inherit;font-variant-numeric:tabular-nums}
.ed-variant-chip:hover{border-color:var(--text3);color:var(--text)}
.ed-variant-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.ed-count-control{align-self:flex-start;width:auto}
.ed-layer-head{display:flex;align-items:center;gap:10px;padding:10px}
.ed-layer-thumb{width:40px;height:40px;border-radius:6px;object-fit:cover;flex-shrink:0;background:#222;border:1px solid var(--border)}
.ed-layer-info{flex:1;min-width:0}
.ed-layer-name{font-weight:600;color:var(--text);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.005em}
.ed-layer-prompt{color:var(--text3);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.ed-layer-actions{display:flex;gap:2px;flex-shrink:0}
.ed-layer-btn{width:28px;height:28px;border:none;background:transparent;color:var(--text3);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;padding:0;transition:background .12s,color .12s}
.ed-layer-btn:hover{background:var(--bg-card);color:var(--text)}
.ed-layer-btn.danger:hover{color:var(--danger)}
.ed-layer-controls{border-top:1px solid var(--border);padding:10px;display:flex;flex-direction:column;gap:8px;background:color-mix(in srgb,var(--bg-card) 50%,transparent)}
.ed-layer-ctrl{display:grid;grid-template-columns:14px 1fr 38px;align-items:center;gap:10px}
.ed-layer-ctrl-icon{color:var(--text3);display:flex;align-items:center;justify-content:center}
.ed-layer-ctrl input[type=range]{width:100%;accent-color:var(--accent);cursor:pointer;height:3px}
.ed-layer-ctrl b{font-size:11px;text-align:right;color:var(--text);font-weight:600;font-variant-numeric:tabular-nums}
.ed-layers-empty{color:var(--text3);font-size:12px;text-align:center;padding:16px 4px;border:1px dashed var(--border);border-radius:8px}
.ed-layer-base{background:color-mix(in srgb,var(--text3) 6%,var(--bg-input))}
.ed-layer-base .ed-layer-name{font-style:italic;color:var(--text2)}

/* Edge-respect checkbox — compact, single-line */
.ed-checkbox{display:inline-flex;align-items:center;gap:10px;cursor:pointer;font-size:13px;color:var(--text2);margin-top:6px;user-select:none;white-space:nowrap}
.ed-checkbox span{font-weight:500;transition:color .15s}
.ed-checkbox:hover span{color:var(--text)}

/* Warning banner when refs not supported by selected model */
.ed-refs-warning{font-size:11px;color:#92400e;background:#fef3c7;border:1px solid #fcd34d;border-radius:6px;padding:8px 10px;line-height:1.4;margin-bottom:8px}
[data-theme="dark"] .ed-refs-warning{color:#fbbf24;background:rgba(251,191,36,.12);border-color:rgba(251,191,36,.3)}
.ed-refs-warning[hidden]{display:none !important}

/* Save modal */
.ed-save-modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}
.ed-save-modal[hidden]{display:none !important}
.ed-save-overlay{position:absolute;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(2px)}
.ed-save-box{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:20px 22px 22px;max-width:480px;width:100%;box-shadow:0 16px 48px rgba(0,0,0,.18)}
[data-theme="dark"] .ed-save-box{box-shadow:0 16px 48px rgba(0,0,0,.55)}
.ed-save-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.ed-save-head h3{font-size:15px;font-weight:600;letter-spacing:-.01em;margin:0}
.ed-save-step[hidden]{display:none !important}
.ed-save-step-desc{font-size:12px;color:var(--text3);margin:0 0 10px}
.ed-save-formats{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ed-save-format-btn{display:flex;flex-direction:column;gap:8px;padding:14px 16px;background:var(--bg-input);border:1.5px solid var(--border);border-radius:10px;cursor:pointer;text-align:left;transition:border-color .12s,background .12s,transform .08s;font-family:inherit;color:var(--text);width:100%}
.ed-save-format-btn:hover{border-color:var(--accent);background:var(--accent-light)}
.ed-save-format-btn:active{transform:scale(.98)}
.ed-save-format-head{display:flex;justify-content:space-between;align-items:baseline}
.ed-save-format-head h4{font-size:14px;font-weight:700;letter-spacing:.02em;margin:0;color:var(--text)}
.ed-save-size{font-size:11px;font-weight:600;color:var(--accent);font-variant-numeric:tabular-nums}
.ed-save-format-btn p{font-size:12px;color:var(--text3);line-height:1.45;margin:0}
.ed-save-back{background:none;border:none;color:var(--text3);font-size:12px;cursor:pointer;padding:2px 0;margin-bottom:14px;display:inline-flex;align-items:center;gap:4px;font-family:inherit}
.ed-save-back:hover{color:var(--accent)}
.ed-save-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.ed-save-field label{font-size:11px;color:var(--text2);font-weight:600;text-transform:uppercase;letter-spacing:.04em;display:flex;align-items:center;gap:6px}
.ed-save-field label b{color:var(--text);font-weight:700;font-variant-numeric:tabular-nums;text-transform:none;letter-spacing:0}
.ed-save-field .ed-save-dim{margin-left:auto;color:var(--text3);font-weight:500;text-transform:none;letter-spacing:0;font-variant-numeric:tabular-nums}
.ed-save-field input[type=range]{accent-color:var(--accent);height:3px;cursor:pointer;width:100%}
.ed-save-actions{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:4px}
.ed-save-size-final{font-size:12px;color:var(--text3);font-variant-numeric:tabular-nums}
.ed-save-size-final b{color:var(--text);font-weight:600}
.ed-save-actions .btn-main{flex-shrink:0}
@media(max-width:520px){.ed-save-formats{grid-template-columns:1fr}}

@media(max-width:1400px){
  .ed-main{grid-template-columns:1fr 300px}
}
@media(max-width:1200px){
  .ed-main{grid-template-columns:1fr 260px;gap:10px}
  .ed-workspace{height:calc(100vh - 200px)}
}
@media(max-width:1050px){
  .ed-workspace{height:auto}
  .ed-main{grid-template-columns:1fr}
  .ed-stage{min-height:400px}
  .ed-right{max-height:600px}
}

/* Tools tab */
.tools-lead{color:var(--text3);font-size:13px;margin:-12px 0 20px;max-width:640px;line-height:1.5}
.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}
.tool-card{display:flex;align-items:stretch;gap:14px;padding:18px;background:transparent;border:1.5px solid var(--border);border-radius:14px;text-decoration:none;color:inherit;transition:border-color .12s;position:relative}
.tool-card:hover{border-color:var(--accent)}
.tool-card:hover .tool-arrow{color:var(--accent)}
.tool-icon{flex:0 0 44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--tc,#dc2626) 12%,transparent);color:var(--tc,#dc2626);align-self:flex-start;transition:color .12s}
.tool-body{flex:1;min-width:0;display:flex;flex-direction:column}
.tool-title{font-size:15px;font-weight:600;margin:0 0 6px;color:var(--text);letter-spacing:-.005em;transition:color .12s}
.tool-desc{font-size:13px;color:var(--text2);line-height:1.5;margin:0 0 10px;transition:color .12s}
.tool-meta{font-size:11px;font-weight:500;color:var(--text3);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;letter-spacing:.01em;margin-top:auto;padding-top:6px;transition:color .12s}
.tool-arrow{flex:0 0 16px;color:var(--text3);transition:color .12s,transform .12s;align-self:flex-start;margin-top:4px}
.tool-card:hover .tool-arrow{transform:translate(2px,-2px)}

/* Mobile header */
.mobile-header{display:none;max-width:860px;margin-left:auto;margin-right:auto}

/* Balance bar */
.balance-bar{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:#1a1a1a;border-radius:var(--r);margin-bottom:16px;font-size:13px;color:#fff}
.balance-bar svg{stroke:#fff}
.balance-value{font-weight:700;color:#fff}

/* Provider bar */
.provider-bar{display:flex;align-items:center;gap:6px;margin-bottom:4px}
.prov-btn{padding:8px 20px;border-radius:20px;border:1.5px solid var(--border);background:var(--bg-card);color:var(--text2);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}
.prov-btn:hover{border-color:var(--accent);color:var(--accent)}
.prov-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Prompt */
.prompt-box{margin-bottom:16px}
.prompt-box textarea{width:100%;padding:14px 16px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--r);font-size:14px;resize:vertical;min-height:120px;color:var(--text);outline:none;transition:border .15s,box-shadow .15s;font-family:inherit}
.prompt-box textarea:focus{border-color:var(--accent)}
.prompt-box textarea::placeholder{color:var(--text3)}
.prompt-actions{display:flex;gap:6px;margin-bottom:6px;align-items:center;justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;overscroll-behavior-x:contain}
.prompt-actions.has-overflow{-webkit-mask-image:linear-gradient(to right,#000 80%,transparent 100%);mask-image:linear-gradient(to right,#000 80%,transparent 100%)}
.prompt-actions.at-end{-webkit-mask-image:none;mask-image:none}
.prompt-actions::-webkit-scrollbar{display:none}
.chip-badge{background:var(--accent);color:#fff;font-size:10px;padding:1px 6px;border-radius:10px;margin-left:4px}
.styles-list{display:flex;flex-direction:column;gap:6px;overflow-y:auto;max-height:60vh}
.style-row{display:flex;align-items:center;gap:12px;padding:8px;border:2px solid var(--border);border-radius:10px;cursor:pointer;transition:all .15s;background:var(--bg-card);position:relative}
.style-row:hover{border-color:var(--accent);background:var(--accent-light)}
.style-row.active{border-color:var(--accent);box-shadow:0 0 0 2px rgba(230,57,70,.2);background:var(--accent-light)}
.style-row-img{width:56px;height:56px;border-radius:8px;overflow:hidden;flex-shrink:0;background:var(--bg-input)}
.style-row-img img{width:100%;height:100%;object-fit:cover;display:block}
.style-row-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:24px;background:var(--bg-input)}
.style-row-info{flex:1;min-width:0}
.style-row-name{font-size:13px;font-weight:600;color:var(--text)}
.style-row-desc{font-size:11px;color:var(--text3);margin-top:2px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.style-row-prompt{font-style:italic}
.style-row-del{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.08);color:var(--text3);border:none;border-radius:50%;width:22px;height:22px;font-size:15px;line-height:1;cursor:pointer;display:none;align-items:center;justify-content:center}
.style-row:hover .style-row-del{display:flex}
.style-row-del:hover{background:var(--danger);color:#fff}
.templates-list{display:flex;flex-direction:column;gap:6px;max-height:40vh;overflow-y:auto}
.tpl-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s;font-size:13px;color:var(--text2)}
.tpl-item:hover{border-color:var(--accent)}
.tpl-item.active{border-color:var(--accent);background:var(--accent-light);color:var(--accent)}
.tpl-item .tpl-del{margin-left:auto;color:var(--text3);cursor:pointer;font-size:16px;opacity:0;transition:opacity .15s}
.tpl-item:hover .tpl-del{opacity:1}
.chip{display:inline-flex;align-items:center;height:30px;padding:0 12px;border-radius:15px;border:1px solid var(--border);background:var(--bg-card);color:var(--text3);font-size:12px;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}
.chip:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}
.chip-circle{width:30px;height:30px;min-width:30px;min-height:30px;padding:0;border-radius:50%;justify-content:center;flex-shrink:0;box-sizing:border-box;aspect-ratio:1}
.chip-accent{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}
.chip-accent:hover{background:var(--accent);color:#fff}
.chip-accent.loading{opacity:.6;pointer-events:none}

/* Model selector (dropdown) */
.model-selector{margin-bottom:16px}
.ctrl-label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}
.model-dd{position:relative}
.model-dd-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--r);cursor:pointer;text-align:left;font-family:inherit;font-size:14px;color:var(--text);transition:border .15s}
.model-dd-btn:hover{border-color:var(--text3)}
.model-dd.open .model-dd-btn{border-color:var(--text3);border-bottom-left-radius:0;border-bottom-right-radius:0}
.mdd-left{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}
.mdd-name{font-weight:600;font-size:14px}
.mdd-hint{font-size:11px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mdd-arrow{transition:transform .2s;color:var(--text3);flex-shrink:0;margin-left:12px}
.model-dd.open .mdd-arrow{transform:rotate(180deg)}
.model-dd-list{display:none;position:absolute;top:100%;left:0;right:0;background:var(--bg-card);border:1.5px solid var(--text3);border-top:1px solid var(--border);border-bottom-left-radius:var(--r);border-bottom-right-radius:var(--r);box-shadow:var(--shadow-lg);z-index:30;max-height:228px;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.model-dd-list::-webkit-scrollbar{width:6px}
.model-dd-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.model-dd.open .model-dd-list{display:block}
.model-option{padding:10px 14px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}
.model-option:last-child{border-bottom:none}
.model-option:hover{background:var(--bg-hover)}
.model-option.active{background:var(--accent-light)}
.mo-top{display:flex;align-items:center;gap:8px}
.mo-name{font-size:13px;font-weight:600;color:var(--text)}
.mo-cost{font-size:11px;color:var(--accent);font-weight:600}
.mo-desc{font-size:11px;color:var(--text3);margin-top:2px;line-height:1.3}

/* Controls */
.controls-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px;align-items:flex-end}
.ctrl-group{min-width:100px}
.gs-desc{font-size:12px;color:var(--text2);font-weight:400}
.ctrl-group label{display:block;font-size:12px;font-weight:500;color:var(--text2);margin-bottom:4px}
.ctrl-group select{width:100%;height:38px;padding:0 28px 0 12px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--r-sm);color:var(--text);font-size:13px;outline:none;cursor:pointer;appearance:none;box-sizing:border-box;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%23999' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}
.ctrl-group select:focus{border-color:var(--accent)}
.ctrl-group select option{background:var(--bg-card)}

/* Count control */
.count-control{display:flex;align-items:center;gap:0;border:1.5px solid var(--border);border-radius:var(--r-sm);overflow:hidden;background:var(--bg-card);height:38px}
.count-btn{width:38px;height:100%;border:none;background:transparent;color:var(--text);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s}
.count-btn:hover{background:var(--bg-hover)}
.count-btn:active{background:var(--accent-light)}
.count-value{width:32px;text-align:center;font-size:14px;font-weight:600;color:var(--text);border-left:1px solid var(--border);border-right:1px solid var(--border)}

.pill-group{display:flex;gap:4px;flex-wrap:wrap}
.pill{padding:4px 16px;border-radius:6px;border:1.5px solid var(--border);background:var(--bg-card);color:var(--text2);font-size:13px;font-weight:500;cursor:pointer;transition:all .12s;height:30px;display:flex;align-items:center;box-sizing:border-box}
.pill:hover{border-color:var(--accent);color:var(--accent)}
.pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}
/* Resolution / quality pills with inline price */
.pill-res{flex-direction:column;align-items:center;justify-content:center;height:auto;min-height:30px;padding:4px 12px;line-height:1.15;gap:1px}
.pill-res .pr-label{font-size:13px;font-weight:600}
.pill-res .pr-cost{font-size:11px;font-weight:500;opacity:.75;font-variant-numeric:tabular-nums}
.pill-res:not(.active) .pr-cost{color:var(--text3)}

.check-label{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text2);cursor:pointer;user-select:none;transition:color .15s}
.check-label:hover{color:var(--text)}

/* Modern minimalist toggle switch — applied to both .check-label and .ed-checkbox checkboxes */
.check-label input[type="checkbox"],
.ed-checkbox input[type="checkbox"]{
  appearance:none;-webkit-appearance:none;
  position:relative;flex-shrink:0;
  width:32px;height:18px;margin:0;padding:0;
  background:var(--border);
  border-radius:999px;border:none;cursor:pointer;
  transition:background .18s ease;
}
.check-label input[type="checkbox"]::before,
.ed-checkbox input[type="checkbox"]::before{
  content:"";position:absolute;top:2px;left:2px;
  width:14px;height:14px;border-radius:50%;
  background:#fff;
  box-shadow:0 1px 2px rgba(0,0,0,.15), 0 1px 3px rgba(0,0,0,.06);
  transition:transform .2s cubic-bezier(.4,.0,.2,1);
}
.check-label input[type="checkbox"]:checked,
.ed-checkbox input[type="checkbox"]:checked{background:var(--accent)}
.check-label input[type="checkbox"]:checked::before,
.ed-checkbox input[type="checkbox"]:checked::before{transform:translateX(14px)}
.check-label input[type="checkbox"]:focus-visible,
.ed-checkbox input[type="checkbox"]:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
[data-theme="dark"] .check-label input[type="checkbox"],
[data-theme="dark"] .ed-checkbox input[type="checkbox"]{background:rgba(255,255,255,.18)}
[data-theme="dark"] .check-label input[type="checkbox"]:checked,
[data-theme="dark"] .ed-checkbox input[type="checkbox"]:checked{background:var(--accent)}

/* Refs */
.refs-block{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.refs-row{display:flex}
.ref-add{display:flex;align-items:center;gap:6px;padding:12px 16px;border:2px dashed var(--border);border-radius:var(--r);color:var(--text3);font-size:12px;cursor:pointer;transition:all .15s;width:100%;justify-content:center;flex-wrap:wrap;text-align:center;background:var(--bg-card)}
.ref-add:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}
.ref-formats{display:block;font-size:11px;color:var(--text3);margin-top:2px;font-weight:400}
.ref-list{display:flex;gap:8px;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;padding-right:1px}
.ref-list::-webkit-scrollbar{display:none}
.ref-list:empty{display:none}
/* Edge fade — applied via JS when content overflows */
.ref-list.has-overflow{-webkit-mask-image:linear-gradient(to right,#000 80%,transparent 100%);mask-image:linear-gradient(to right,#000 80%,transparent 100%)}
.ref-list.at-end{-webkit-mask-image:none;mask-image:none}
/* When refs are present: compact upload zone so the picker doesn't dominate */
.refs-block:has(.ref-list:not(:empty)) .ref-add{padding:8px 14px;font-size:12px;gap:6px}
.refs-block:has(.ref-list:not(:empty)) .ref-add svg{width:14px;height:14px}
.refs-block:has(.ref-list:not(:empty)) .ref-formats{display:none}
.ref-item{position:relative;width:64px;min-width:64px;height:64px;border-radius:var(--r);overflow:hidden;border:1px solid var(--border)}
.ref-item img{width:100%;height:100%;object-fit:cover;cursor:zoom-in;transition:transform .15s}
.ref-item img:hover{transform:scale(1.04)}
/* Ref preview overlay */
.ref-lb{position:fixed;inset:0;z-index:250;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.85);padding:24px}
.ref-lb.hidden{display:none}
.ref-lb img{max-width:95%;max-height:95vh;object-fit:contain;border-radius:8px;box-shadow:0 10px 40px rgba(0,0,0,.4);user-select:none}
.ref-lb-close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.95);border:none;font-size:22px;color:#0a0a0a;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}
.ref-lb-close:hover{background:#fff}
.ref-num{position:absolute;bottom:3px;right:3px;min-width:18px;height:18px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;border-radius:9px;display:flex;align-items:center;justify-content:center;line-height:1;padding:0 4px;pointer-events:none;z-index:1;box-shadow:0 1px 3px rgba(0,0,0,.3)}
.ref-x{position:absolute;top:3px;right:3px;width:20px;height:20px;background:rgba(0,0,0,.6);border:none;border-radius:50%;color:#fff;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}
.ref-x:hover{background:var(--danger)}
.refs-dragover{background:var(--accent-light);border-radius:var(--r)}
.refs-dragover .ref-add{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}
.page-dragover #app{opacity:0}
.page-dragover::after{content:'Перетащите изображения сюда';position:fixed;inset:0;background:#fff;border:3px dashed var(--accent);border-radius:16px;margin:12px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600;color:var(--accent);z-index:9999;pointer-events:none}
.ref-uploading{opacity:1}
.ref-progress{position:absolute;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center}
.ref-progress span{color:#fff;font-size:13px;font-weight:700}
.ref-error{border-color:var(--danger)}
.btn-uploading{opacity:.5;cursor:not-allowed!important}

/* Two-column generate layout */
.gen-layout{display:grid;grid-template-columns:340px 1fr;gap:24px;align-items:stretch;height:calc(100vh - 56px - 28px);min-width:0}
.gen-left{background:var(--bg-card);border:none;border-radius:16px;padding:18px;box-shadow:none;display:flex;flex-direction:column;min-height:0;overflow-y:auto;overflow-x:hidden}
.gen-left .prompt-box{display:flex;flex-direction:column;margin-bottom:0;min-height:0;flex:0 0 auto}
.gen-left .prompt-box textarea{min-height:60px;flex:0 0 auto;background:var(--bg-card);resize:none;border-color:var(--border)}
.gen-left .prompt-box textarea:focus{border-color:var(--accent)}
.gen-left .prompt-actions{margin:0 0 12px;padding:0;overflow-x:auto;flex-shrink:0;flex-wrap:nowrap;scrollbar-width:none}
.gen-left .prompt-actions::-webkit-scrollbar{display:none}
.gen-left .prompt-actions .chip{flex:0 0 auto;justify-content:center;padding:0 10px}
.gen-left .prompt-actions .chip-circle{flex:0 0 30px}
/* Symmetric spacing around ref-list: equal gap above (flex gap inside refs-block)
   and below (margin-bottom of refs-block + model-selector top margin). */
.gen-left .refs-block{margin-top:12px;margin-bottom:14px;flex-shrink:0;gap:14px}
.gen-left .refs-block .ref-list:not(:empty){margin-bottom:0}
.gen-left .model-selector{margin:0 0 12px;flex-shrink:0}
.gen-left .model-dd-btn{background:var(--bg-card);border-color:var(--border)}
.gen-left .model-dd-list{background:var(--bg-card)}
.gen-left .ctrl-group select{background:var(--bg-card);border-color:var(--border)}
.gen-left .count-control{background:var(--bg-card);border-color:var(--border)}
.gen-left .chip{background:var(--bg-card);border-color:var(--border)}
.gen-left .chip:hover{border-color:var(--accent);background:var(--accent-light)}
.gen-left .chip-accent{background:var(--accent-light);border-color:var(--accent)}
.gen-left .chip-accent:hover{background:var(--accent);color:#fff}
.gen-left .balance-bar{margin-bottom:12px;flex-shrink:0}
.gen-left .controls-row{margin-bottom:12px;flex-shrink:0}
.gen-left #grp-gsearch{flex-shrink:0;margin-top:0}
.gen-left .btn-gen{border-radius:var(--r);margin-top:auto;flex-shrink:0;padding-top:14px;padding-bottom:14px}
.gen-right{display:flex;flex-direction:column;min-height:0;overflow-y:auto;overflow-x:hidden;background:var(--bg-card);border:none;border-radius:16px;padding:16px;box-shadow:none;clip-path:inset(0 round 16px)}
.gen-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px 16px;color:var(--text3);border:2px dashed var(--border);border-radius:var(--r);text-align:center;flex:1}
.gen-empty-state svg{opacity:.4;width:40px;height:40px}
.gen-empty-state p{font-size:13px;margin:0}

/* Storage notice */
.storage-notice{font-size:11px;color:var(--text3);text-align:center;margin-top:auto;padding-top:8px}

/* Generations */
.gens-area{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;min-width:0}
.gens-area:empty{display:none}
.gens-area[data-count="1"]{grid-template-columns:minmax(0,300px);justify-content:start}
.gens-area[data-count="3"] .gen-card:first-child{grid-column:1/-1}

.gen-card{background:var(--bg-input);border:none;border-radius:var(--r);overflow:hidden;width:100%;box-shadow:none}

.gen-img-wrap{width:100%;aspect-ratio:1;background:var(--bg-input);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;cursor:pointer;clip-path:inset(0)}
.gen-img-wrap img{width:100%;height:100%;object-fit:cover}

.gen-actions{position:absolute;bottom:0;left:0;right:0;display:flex;gap:6px;padding:8px;background:linear-gradient(transparent, rgba(0,0,0,.6));opacity:0;transition:opacity .15s;justify-content:flex-end}
.gen-card:hover .gen-actions{opacity:1}
.gen-act-btn{
  width:34px;height:34px;flex:0 0 34px;
  padding:0;border:none;border-radius:50%;
  background:rgba(255,255,255,.92);color:#1a1a1a;
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;text-decoration:none;
  transition:background .12s,transform .12s,color .12s;
  box-shadow:0 2px 8px rgba(0,0,0,.25);
}
.gen-act-btn svg{width:16px;height:16px;display:block}
.gen-act-btn:hover{background:#fff;transform:translateY(-1px)}
.gen-act-edit:hover{background:var(--accent);color:#fff}
.gen-act-upscale:hover{background:var(--accent);color:#fff}
.gen-act-dl:hover{background:#000;color:#fff}
.gen-act-del:hover{background:var(--danger);color:#fff}
/* Touch screens — always visible (no hover), still icon-only */
@media (hover:none){
  .gen-actions{opacity:1;background:linear-gradient(transparent, rgba(0,0,0,.55))}
}

.gen-bottom{padding:10px 12px}
.gen-model-name{font-size:13px;font-weight:600;color:var(--text)}
.gen-prompt-text{font-size:11px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.gen-state{font-size:11px;margin-top:4px}
.gen-state.st-proc{color:var(--accent)}
.gen-state.st-ok{color:var(--success)}
.gen-state.st-fail{color:var(--danger)}

.gen-fail-box{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px}
.gen-fail-icon{color:var(--danger);font-size:28px;font-weight:700;line-height:1}
.gen-retry-btn{padding:5px 16px;border:none;border-radius:20px;background:var(--accent);color:#fff;font-size:12px;font-weight:600;cursor:pointer}
.gen-retry-btn:hover{opacity:.85}
.gen-dismiss-btn{padding:3px 12px;border:none;border-radius:20px;background:var(--bg-hover);color:var(--text3);font-size:11px;cursor:pointer}
.gen-dismiss-btn:hover{color:var(--text)}

.gen-progress{width:100%;height:3px;background:var(--bg-input);border-radius:2px;margin-top:6px;overflow:hidden}
.gen-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}

@keyframes spin{to{transform:rotate(360deg)}}
.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}

/* Gallery */
.gal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:10px}
.gal-header .tab-title{margin-bottom:0}
.gal-size-control{display:flex;align-items:center;gap:8px;color:var(--text3)}
.gal-slider{-webkit-appearance:none;appearance:none;width:80px;height:2px;background:var(--border);border-radius:1px;outline:none;cursor:pointer}
.gal-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--text3);cursor:pointer;border:none;box-shadow:none;transition:background .15s}
.gal-slider::-webkit-slider-thumb:hover{background:var(--text)}
.gal-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--text3);cursor:pointer;border:none;box-shadow:none}
.gal-slider::-moz-range-thumb:hover{background:var(--text)}
.gal-cols-val{font-size:12px;font-weight:500;color:var(--text3);min-width:14px;text-align:center}

.gal-grid{display:grid;grid-template-columns:repeat(var(--gal-cols), 1fr);gap:12px;padding-bottom:40px}
.gal-item{aspect-ratio:1;border-radius:var(--r);overflow:hidden;position:relative;cursor:pointer;clip-path:inset(0 round var(--r))}
.gal-item::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,0);transition:background .2s;pointer-events:none}
.gal-item:hover::after{background:rgba(0,0,0,.35)}
.gal-item img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:1}
.gal-hover-actions{position:absolute;top:6px;right:6px;display:flex;gap:4px;opacity:0;transition:opacity .2s;z-index:2}
.gal-item:hover .gal-hover-actions{opacity:1}
.gal-hover-btn{width:28px;height:28px;border-radius:50%;background:rgba(0,0,0,.5);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;padding:0;text-decoration:none}
.gal-hover-btn:hover{background:rgba(0,0,0,.7)}
.gal-hover-btn svg{width:14px;height:14px}
.gal-hover-btn.del-btn:hover{background:var(--danger)}
.btn-dl{display:inline-flex;align-items:center;justify-content:center;padding:7px 16px;background:#1a1a1a;color:#fff;border:none;border-radius:var(--r);font-size:13px;font-weight:600;cursor:pointer;text-decoration:none;transition:background .15s}
.btn-dl:hover{background:#333}
.empty{text-align:center;color:var(--text3);padding:60px 20px;font-size:14px}
.empty.hidden{display:none}

/* Settings */
.settings-card{background:var(--bg-card);border:none;border-radius:var(--r);padding:20px;margin-bottom:16px;box-shadow:none}
.settings-card h3{font-size:15px;font-weight:600;margin-bottom:12px}
.key-status{font-size:12px;margin-left:8px}
.key-status.ok{color:var(--success)}
.key-status.no{color:var(--text3)}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center}
.lightbox.hidden{display:none}
.lb-overlay{position:absolute;inset:0;background:rgba(0,0,0,.75)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.9);border:none;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;box-shadow:0 2px 8px rgba(0,0,0,.2);transition:background .15s}
.lb-nav:hover{background:#fff}
.lb-nav-prev{left:12px}
.lb-nav-next{right:12px}
.lb-inner{position:relative;display:flex;flex-direction:row;width:80vw;height:85vh;max-width:1200px;border-radius:16px;overflow:hidden;box-shadow:0 8px 40px rgba(0,0,0,.4)}
.lb-image-wrap{flex:1;min-width:0;display:flex;align-items:center;justify-content:center;background:#ffffff;padding:40px;overflow:hidden}
.lb-image-wrap img{max-width:100%;max-height:100%;object-fit:contain;width:100%;height:100%}
.lb-panel{width:320px;flex-shrink:0;background:#f5f5f7;display:flex;flex-direction:column;padding:56px 24px 24px 24px;gap:16px;overflow-y:auto;position:relative}
.lb-close-btn{position:absolute;top:12px;right:12px;background:none;border:none;font-size:24px;color:var(--text3);cursor:pointer;padding:0 4px;line-height:1}
.lb-close-btn:hover{color:var(--text)}
.lb-meta{display:flex;flex-direction:column;gap:10px}
.lb-meta-row{display:flex;justify-content:space-between;align-items:center}
.lb-label{font-size:12px;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.lb-value{font-size:13px;color:var(--text);font-weight:500}
.lb-prompt-section{display:flex;flex-direction:column;gap:6px}
.lb-prompt-text{font-size:13px;color:var(--text2);line-height:1.5;max-height:120px;overflow-y:auto;word-break:break-word;background:var(--bg-input);border-radius:8px;padding:10px 12px}
.lb-copy-btn{background:none;border:none;color:var(--text3);cursor:pointer;padding:4px;border-radius:6px;transition:all .15s;display:flex;align-items:center}
.lb-copy-btn:hover{color:var(--accent);background:var(--accent-light)}
.lb-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto !important;padding-top:16px;border-top:1px solid rgba(0,0,0,.06)}
[data-theme="dark"] .lb-actions{border-top-color:rgba(255,255,255,.08)}
.lb-actions .btn-ghost,.lb-actions .lb-btn-download,.lb-actions .btn-del{flex:1 1 45%;min-width:0}
.lb-act-btn{width:100%;text-align:center;border-radius:10px;font-size:13px;display:inline-flex;align-items:center;justify-content:center;gap:6px}
.lb-btn-download{display:inline-flex;align-items:center;justify-content:center;padding:7px 16px;background:#2a2a2a;color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;text-decoration:none;transition:background .15s}
.lb-btn-download:hover{background:#3a3a3a}
@media(max-width:768px){
  .lb-inner{flex-direction:column;max-height:95vh;width:95vw}
  .lb-image-wrap{max-height:50vh}
  .lb-image-wrap img{max-height:50vh;width:100%;height:100%}
  .lb-panel{width:auto;max-height:45vh}
}

/* Modal */
.modal{position:fixed;inset:0;z-index:150;display:flex;align-items:center;justify-content:center}
.modal.hidden{display:none}
.modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,.3)}
.modal-box{position:relative;background:var(--bg-card);border-radius:16px;padding:24px;width:90%;max-width:440px;max-height:85vh;overflow-y:auto;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}
.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.modal-head h3{font-size:16px;font-weight:600}
.modal-head-actions{display:flex;align-items:center;gap:8px}
.modal-close{background:none;border:none;font-size:22px;color:var(--text3);cursor:pointer;padding:0 4px}
.modal-close:hover{color:var(--text)}
.ph-list{overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:6px}
.ph-item{padding:10px 12px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:13px;color:var(--text);transition:background .12s;display:flex;align-items:flex-start;gap:8px}
.ph-item:hover{background:var(--accent-light)}
.ph-text{cursor:pointer;flex:1;word-break:break-word;line-height:1.4}
.ph-copy{flex-shrink:0;background:none;border:1px solid var(--border);border-radius:var(--r-sm);cursor:pointer;padding:4px 8px;font-size:11px;color:var(--text3);transition:all .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:3px}
.ph-copy:hover{border-color:var(--accent);color:var(--accent)}
.rg-title{font-size:15px;font-weight:600;color:var(--text);margin:0 0 12px}
.rg-title.rg-title-compact{font-size:12px;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin:12px 0 6px}
.recent-gens{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:6px;padding:0;margin-top:0;min-width:0}
.recent-gens.rg-compact{grid-template-columns:repeat(auto-fill,minmax(38px,1fr));gap:3px;margin-top:6px}
.rg-item{aspect-ratio:1;border-radius:var(--r);overflow:hidden;cursor:pointer;position:relative;clip-path:inset(0 round var(--r))}
.rg-item::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,0);transition:background .2s;pointer-events:none}
.rg-item:hover::after{background:rgba(0,0,0,.35)}
.rg-item img{width:100%;height:100%;object-fit:cover;aspect-ratio:1}
.rg-actions{position:absolute;top:6px;right:6px;display:flex;gap:4px;opacity:0;transition:opacity .2s;z-index:2}
.rg-item:hover .rg-actions{opacity:1}
.rg-act{width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.9);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;padding:0}
.rg-act:hover{background:#fff}
.rg-act svg{width:12px;height:12px}
.rg-act-del:hover{background:var(--danger)}
.rg-act-del:hover svg{stroke:#fff}
.rg-more{aspect-ratio:1;border-radius:var(--r);background:var(--bg-card);border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;font-weight:600;color:var(--text3);transition:all .15s}
.rg-more:hover{border-color:var(--accent);color:var(--accent)}

/* Profile modal */
.profile-body{display:flex;flex-direction:column;gap:14px}
.profile-avatar-section{display:flex;align-items:center;gap:16px}
.profile-avatar-wrap{width:64px;height:64px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--accent-light)}
.profile-avatar-wrap img{width:100%;height:100%;object-fit:cover}
.profile-avatar-btn{margin:0!important;width:auto!important}

/* Medium screens */
@media(max-width:1500px){
  .content{padding:24px 28px 0}
  .gen-layout{grid-template-columns:300px 1fr;gap:20px}
}
@media(max-width:1300px){
  .content{padding:20px 20px 0}
  .gen-layout{grid-template-columns:280px 1fr;gap:16px}
  .tools-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
}
@media(max-width:1100px){
  .gen-layout{grid-template-columns:minmax(0,1fr);gap:16px;height:auto}
  .gen-left{position:static;background:none;border:none;padding:0;box-shadow:none;min-height:auto;display:block;overflow:visible}
  .gen-left .prompt-box{display:block}
  .gen-left .prompt-box textarea{min-height:120px;resize:vertical}
  .gen-right{overflow-y:visible}
  .gen-left .prompt-box textarea{background:var(--bg-card);border-color:var(--border)}
  .gen-left .model-dd-btn{background:var(--bg-card);border-color:var(--border)}
  .gen-left .ctrl-group select{background:var(--bg-card);border-color:var(--border)}
  .gen-left .count-control{background:var(--bg-card);border-color:var(--border)}
  .gen-left .chip{background:var(--bg-card);border-color:var(--border)}
  .gen-empty-state{min-height:200px}
}

/* Responsive */
@media(max-width:768px){
  .sidebar{display:none}
  .sidebar.open{display:flex;position:fixed;width:260px;box-shadow:var(--shadow-lg)}
  .content{margin-left:0;padding:16px}
  .mobile-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
  .mobile-brand{font-size:16px;font-weight:700}
  .mobile-tabs{display:flex;gap:4px;margin-left:auto;overflow-x:auto;flex-wrap:nowrap;max-width:100%;scrollbar-width:none;-ms-overflow-style:none}
  .mobile-tabs::-webkit-scrollbar{display:none}
  .mobile-tabs .m-tab{flex:0 0 auto}
  .m-tab{padding:5px 12px;border-radius:16px;border:1px solid var(--border);background:var(--bg-card);color:var(--text3);font-size:12px;cursor:pointer}
  .m-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}
  .gen-card{width:100%}
  .gens-area,.gens-area[data-count="1"],.gens-area[data-count="2"],.gens-area[data-count="3"],.gens-area[data-count="4"]{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:repeat(2,1fr)!important;gap:10px}
  .controls-row{flex-direction:column;gap:10px}
  .ctrl-group{min-width:100%}
  #tab-settings{max-width:none}
  .auth-card{padding:32px 24px;border-radius:16px;margin:0;max-width:100%}
  .auth-logo{width:48px;height:48px;border-radius:12px}
  .auth-title{font-size:20px}
  .auth-sub{font-size:13px;margin-bottom:20px}
  .code-cells{gap:6px;margin:12px 0 16px}
  .code-cell{width:40px;height:48px;font-size:22px}
  .style-row-img{width:48px;height:48px}
  .prompt-actions{gap:5px}
  .chip{height:28px;padding:0 10px;font-size:11px}
  .chip-circle{width:28px;height:28px;min-width:28px;min-height:28px}
  .balance-bar{padding:8px 12px;font-size:12px}
  .model-dd-btn{padding:8px 12px}
  .crop-container{width:220px;height:220px}
  #crop-canvas{width:220px;height:220px}
  .modal-box{padding:20px;max-height:85vh}
  .lb-nav{width:36px;height:36px}
  .lb-nav-prev{left:8px}
  .lb-nav-next{right:8px}
}

/* Editor: project chip + gallery — tablet/phone adaptations */
@media(max-width:900px){
  .ed-gallery-head{flex-direction:column;align-items:stretch;gap:10px}
  .ed-gallery-head > button{align-self:flex-start}
  .ed-gallery-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
  .ed-canvas-head-left{width:100%;min-width:0}
  .ed-head-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}
  .ed-current-project{max-width:100%}
  .ed-project-title{max-width:200px}
}
@media(max-width:560px){
  .ed-gallery-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .ed-pcard-info{padding:8px 10px 10px}
  .ed-pcard-name{font-size:13px}
  .ed-pcard-meta{font-size:10px}
  .ed-pcard.new{min-height:140px}
  .ed-gallery-empty{padding:40px 16px}
  .ed-current-project{padding:5px 10px;font-size:12px;gap:6px}
  .ed-project-title{max-width:140px;font-size:12px}
  .ed-project-rename svg{width:11px;height:11px}
  .ed-project-status{font-size:9px}
  .ed-head-actions .btn-main{padding:7px 12px;font-size:12px}
  .ed-head-actions .btn-main svg{width:12px;height:12px}
}
@media(max-width:380px){
  .ed-gallery-grid{grid-template-columns:1fr}
  .ed-head-actions .btn-main span,.ed-head-actions .btn-main{font-size:11px}
}

/* Profile views */
.pv-view{animation:pvFadeIn .15s ease}
@keyframes pvFadeIn{from{opacity:0}to{opacity:1}}
.pv-back{background:none;border:none;color:var(--text2);cursor:pointer;padding:2px;border-radius:6px;display:flex;align-items:center;transition:color .12s}
.pv-back:hover{color:var(--text)}

/* Crop editor */
.crop-area{display:flex;flex-direction:column;align-items:center}
#crop-canvas{display:block;max-width:100%;border-radius:var(--r);cursor:default;touch-action:none;background:#f0f0f3}

/* Toast */
.toast{position:fixed;top:16px;right:16px;background:#333;color:#fff;padding:7px 16px;border-radius:var(--r-sm);font-size:12px;font-weight:500;opacity:0;transform:translateY(-10px);transition:all .3s ease;pointer-events:none;z-index:300;white-space:nowrap;box-shadow:0 2px 10px rgba(0,0,0,.15)}
.toast.show{opacity:1;transform:translateY(0)}

/* Image loading animation — blur reveal */
@keyframes img-reveal{from{opacity:0;filter:blur(10px)}to{opacity:1;filter:blur(0)}}
.img-loading{opacity:0;filter:blur(10px)}
.img-loaded{animation:img-reveal .4s ease forwards;animation-delay:var(--reveal-delay,0s)}

/* Progressive image loading — blurry thumbnail → sharp full */
.progressive-img{transition:filter .4s ease}
.progressive-img{filter:blur(2px)}
.gen-img-wrap:has(.progressive-img)::after{content:'';position:absolute;top:50%;left:50%;width:24px;height:24px;margin:-12px 0 0 -12px;border:2.5px solid rgba(255,255,255,.2);border-top-color:rgba(255,255,255,.8);border-radius:50%;animation:progspin .8s linear infinite;z-index:2;pointer-events:none}
@keyframes progspin{to{transform:rotate(360deg)}}
.lb-image-wrap:has(.progressive-img){position:relative}
.lb-image-wrap:has(.progressive-img)::after{content:'';position:absolute;top:50%;left:50%;width:32px;height:32px;margin:-16px 0 0 -16px;border:3px solid rgba(0,0,0,.1);border-top-color:rgba(0,0,0,.5);border-radius:50%;animation:progspin .8s linear infinite;z-index:2;pointer-events:none}


/* Gallery link fix */
.gal-acts a{text-decoration:none}

/* Scrollbar */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--text3)}

/* Dark theme overrides for hardcoded colors */
[data-theme="dark"] .btn-close-lb{background:var(--bg-input);color:var(--text)}
[data-theme="dark"] .btn-close-lb:hover{background:var(--bg-hover)}
[data-theme="dark"] .balance-bar{background:#000}
[data-theme="dark"] .gen-act-btn{background:rgba(255,255,255,.88);color:#1a1a1a}
[data-theme="dark"] .btn-dl{background:var(--bg-input);color:var(--text)}
[data-theme="dark"] .btn-dl:hover{background:var(--bg-hover)}
[data-theme="dark"] .lb-nav{background:rgba(40,40,40,.9)}
[data-theme="dark"] .lb-nav:hover{background:var(--bg-hover)}
[data-theme="dark"] .lb-nav svg{stroke:var(--text)}
[data-theme="dark"] .lb-image-wrap{background:var(--bg)}
[data-theme="dark"] .lb-panel{background:var(--bg-card)}
[data-theme="dark"] .lb-btn-download{background:var(--bg-input);color:var(--text)}
[data-theme="dark"] .lb-btn-download:hover{background:var(--bg-hover)}
[data-theme="dark"] .rg-act{background:rgba(40,40,40,.9)}
[data-theme="dark"] .rg-act:hover{background:var(--bg-hover)}
[data-theme="dark"] .rg-act svg{stroke:var(--text)}
[data-theme="dark"] .toast{background:var(--bg-card);color:var(--text)}
[data-theme="dark"] .page-dragover::after{background:var(--bg);color:var(--accent)}
[data-theme="dark"] #crop-canvas{background:var(--bg-input)}
[data-theme="dark"] .gal-acts .btn-del{color:var(--text3);border-color:var(--border)}
[data-theme="dark"] .gal-acts .btn-del:hover{color:var(--danger);border-color:var(--danger)}
[data-theme="dark"] .auth-card{background:var(--bg-card);border-color:var(--border)}
[data-theme="dark"] .lb-overlay{background:rgba(0,0,0,.85)}
[data-theme="dark"] .modal-overlay{background:rgba(0,0,0,.5)}

/* Custom confirm/alert dialog */
.cdlg{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:16px}
.cdlg.hidden{display:none}
.cdlg-overlay{position:absolute;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(2px)}
.cdlg-box{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:24px;max-width:340px;width:100%;box-shadow:var(--shadow-lg);animation:cdlg-in .15s ease-out}
@keyframes cdlg-in{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
.cdlg-text{font-size:15px;font-weight:500;color:var(--text);text-align:center;line-height:1.4;margin-bottom:20px}
.cdlg-btns{display:flex;gap:8px}
.cdlg-btns button{flex:1;padding:10px 16px;border-radius:var(--r);font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all .15s}
.cdlg-btn-cancel{background:var(--bg-input);color:var(--text2)}
.cdlg-btn-cancel:hover{background:var(--bg-hover)}
.cdlg-btn-ok{background:var(--accent);color:#fff}
.cdlg-btn-ok:hover{background:var(--accent-hover)}
.cdlg-btn-danger{background:var(--danger);color:#fff}
.cdlg-btn-danger:hover{opacity:.9}

/* Upscaler tab */
.up-head{margin-bottom:14px}
.up-title{margin:0;font-size:18px;font-weight:600;color:var(--text);line-height:1.2}
.up-sub{margin:4px 0 0 0;font-size:13px;color:var(--text2);line-height:1.4}
/* Compact layout in upscaler — drop zone stays small, controls sit right under it */
#tab-upscale .gen-left{justify-content:flex-start}
#tab-upscale .prompt-box{flex:0 0 auto;margin-bottom:14px}
#tab-upscale .btn-gen{margin-top:auto}
#tab-upscale .ctrl-label{display:block;margin-bottom:6px;font-size:13px;color:var(--text2);font-weight:500}

/* Intensity slider (Натурально ↔ Максимум) */
.up-intensity{display:flex;flex-direction:column;gap:6px}
.up-intensity-head{display:flex;justify-content:space-between;align-items:baseline;gap:8px;flex-wrap:nowrap;min-width:0}
.up-intensity-head label{font-size:13px;color:var(--text2);font-weight:500;margin:0;flex:0 0 auto;white-space:nowrap}
.up-intensity-value{font-size:13px;color:var(--accent);font-weight:600;letter-spacing:.01em;white-space:nowrap;text-align:right;flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis}
.up-intensity-slider{
  -webkit-appearance:none;appearance:none;
  width:100%;height:6px;border-radius:3px;
  background:linear-gradient(to right,var(--accent) 0%,var(--accent) var(--fill,50%),var(--border) var(--fill,50%),var(--border) 100%);
  outline:none;margin:6px 0 2px;cursor:pointer;
}
.up-intensity-slider::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:18px;height:18px;border-radius:50%;
  background:#fff;border:2px solid var(--accent);
  cursor:grab;box-shadow:0 2px 6px rgba(0,0,0,.15);
  transition:transform .12s;
}
.up-intensity-slider::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.1)}
.up-intensity-slider::-moz-range-thumb{
  width:18px;height:18px;border-radius:50%;
  background:#fff;border:2px solid var(--accent);
  cursor:grab;box-shadow:0 2px 6px rgba(0,0,0,.15);
}
.up-intensity-ticks{display:flex;justify-content:space-between;font-size:11px;color:var(--text3);margin-top:2px}

/* Upscaler: large preview of the source image; drop zone disappears once an image is loaded. */
#up-refs-block{display:flex;flex-direction:column;gap:0}
#up-refs-block.has-image .refs-row{display:none}
#up-refs-block.has-image #up-ref-list{margin:0}
#up-ref-list{display:block;overflow:visible}
.up-ref-item{
  position:relative;width:100%;
  border:1px solid var(--border);border-radius:var(--r);
  background:var(--bg-input);overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  min-height:160px;max-height:360px;
}
.up-ref-item img{max-width:100%;max-height:360px;width:auto;height:auto;display:block;object-fit:contain}
.up-ref-item .ref-x{
  position:absolute;top:8px;right:8px;
  width:30px;height:30px;border-radius:50%;
  background:rgba(0,0,0,.6);color:#fff;border:none;
  font-size:18px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;line-height:1;
  z-index:2;transition:background .12s;
}
.up-ref-item .ref-x:hover{background:var(--danger)}
.up-ref-item.uploading .ref-progress{position:absolute;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center}
.up-ref-item.uploading .ref-progress span{color:#fff;font-weight:700;font-size:14px}
.up-ref-item.error{border-color:var(--danger)}

/* Upscaler — adaptive layout. */
@media (max-width:1100px){
  /* On tablets / phones the gen-layout already becomes single-column.
     Keep the upscaler panel sized to content (no fixed viewport height). */
  #tab-upscale .gen-left{min-height:auto;height:auto}
  #tab-upscale .gen-right{min-height:280px}
  #tab-upscale .btn-gen{margin-top:14px}
  .up-ref-item{max-height:50vh}
  .up-ref-item img{max-height:50vh}
}
@media (max-width:560px){
  #tab-upscale .up-head{margin-bottom:10px}
  #tab-upscale .up-title{font-size:17px}
  #tab-upscale .up-sub{font-size:12px}
  /* Single column for tiny screens — scale + resolution stack neatly. */
  #tab-upscale .controls-row{flex-direction:column;align-items:stretch;gap:10px}
  #tab-upscale .ctrl-group{width:100%}
  #tab-upscale .pill-group{flex-wrap:wrap}
  .up-intensity-head label{font-size:12px}
  .up-intensity-value{font-size:12px}
  .up-intensity-ticks{font-size:10px}
}
/* Generation tab — wrapper for textarea + clear button.
   Behaviour is identical to the Editor's ed-prompt: textarea grows with content
   (no internal scroll), and the whole .gen-left column scrolls if it exceeds
   the available viewport height. */
.input-prompt-wrap{position:relative}
#input-prompt{padding-right:34px;resize:none;overflow:hidden;background:var(--bg-input)}

/* Generation tab — keep the refs picker compact so it doesn't eat vertical space. */
.gen-left .refs-block .ref-add{padding:8px 14px;font-size:12px;gap:6px}
.gen-left .refs-block .ref-add svg{width:14px;height:14px}
.gen-left .refs-block .ref-formats{display:none}

/* Info tooltip (?) next to checkboxes etc. */
.info-tip{
  display:inline-flex;align-items:center;justify-content:center;
  width:16px;height:16px;border-radius:50%;
  background:var(--border);color:var(--text2);
  border:none;padding:0;margin-left:2px;
  font-size:11px;font-weight:700;line-height:1;cursor:help;
  position:relative;user-select:none;
  transition:background .15s,color .15s;
}
.info-tip:hover,.info-tip:focus-visible{background:var(--text3);color:var(--bg-card);outline:none}
.info-tip::after{
  content:attr(data-tip);
  position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);
  width:max-content;max-width:260px;
  padding:8px 10px;
  background:var(--text);color:var(--bg-card);
  border-radius:6px;
  font-size:11.5px;font-weight:400;line-height:1.45;
  white-space:normal;text-align:left;
  opacity:0;visibility:hidden;
  transition:opacity .15s ease;
  pointer-events:none;z-index:50;
  box-shadow:0 6px 18px rgba(0,0,0,.18);
}
.info-tip::before{
  content:"";
  position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:5px solid transparent;border-bottom-color:var(--text);
  margin-top:-2px;
  opacity:0;visibility:hidden;
  transition:opacity .15s ease;
  pointer-events:none;z-index:51;
}
.info-tip:hover::after,.info-tip:focus-visible::after,
.info-tip:hover::before,.info-tip:focus-visible::before{opacity:1;visibility:visible}
/* Compact toggle label — slightly smaller text now that we have the tip */
.check-label span,.ed-checkbox span{font-size:12.5px;font-weight:500}
