*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --base:#202020;--mantle:#191919;--crust:#121212;
  --surface0:#2a2a2a;--surface1:#363636;--surface2:#424242;
  --overlay0:#686868;--overlay1:#888888;--overlay2:#a8a8a8;
  --subtext0:#c0c0c0;--subtext1:#d8d8d8;--text:#efeff1;
  --lavender:#c8c8ca;--blue:#7a9fc0;--sapphire:#7a9fc0;
  --sky:#7a9fc0;--teal:#7a9fc0;--green:#6b9e78;
  --yellow:#b89060;--peach:#c8c8ca;--maroon:#c47878;
  --red:#b06060;--mauve:#efeff1;--pink:#c8c8ca;
  --flamingo:#d0d0d0;--rosewater:#e0e0e0;
}
html{scroll-behavior:smooth;overflow-y:auto;height:100%}
body{font-family:'JetBrains Mono',monospace;background:#121212;color:var(--text);min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:40px 16px 40px;overflow-x:hidden;overflow-y:auto}
body::before{display:none}
.wrap{position:relative;z-index:1;width:100%;max-width:800px}

/* ── Header ── */
header{text-align:center;margin-bottom:36px;animation:fadeUp .5s ease both;transition:margin-bottom .3s ease}
.logo{line-height:0}.logo svg{height:46px;width:auto;max-width:100%;display:block;margin:0 auto;transition:height .3s ease}
/* Logo rules — explicit to beat any cached overrides */
header .logo-editor{display:none !important}
header .logo-default{display:block !important}
/* editor-logo-mid: always hidden globally; desktop editor-active shows it */
.editor-logo-mid{display:none !important}
/* Editor-active header — desktop only */
@media(min-width:821px){
  body.editor-active{overflow:hidden;height:100dvh}
  body.editor-active header{display:none !important}
  body.editor-active .author{display:none !important}
  /* Editor logo in mid column — desktop only */
  body.editor-active .editor-logo-mid{display:block !important;margin-bottom:6px}
  .editor-logo-mid .logo-default{display:none !important}
  body.editor-active .editor-logo-mid .logo-editor{display:block !important}
  body.editor-active .editor-logo-mid .logo-editor svg{height:26px !important;width:auto !important;display:block;margin:0}
  body.editor-active .gif-col-left,
  body.editor-active .gif-col-mid,
  body.editor-active .gif-col-right{max-height:calc(100dvh - 60px);min-height:0}
}


.author{font-size:11px;color:var(--overlay1);margin-top:12px;letter-spacing:.04em}
.author span{color:var(--lavender)}
.author .brand-link{background:linear-gradient(90deg,var(--text),var(--overlay2),var(--subtext1),var(--text));background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 3s linear infinite;text-decoration:none;font-weight:800}
.author .coffee-link{background:linear-gradient(90deg,var(--text),var(--overlay2),var(--subtext1),var(--text));background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 3s linear infinite;text-decoration:none;font-weight:800}
@keyframes gradientShift{to{background-position:200% center}}

/* Loading overlay */
.loading-overlay{position:fixed;inset:0;background:rgba(18,18,18,0.82);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;gap:16px}
.loading-overlay.hidden{display:none}
.loading-spinner{width:44px;height:44px;border:3px solid var(--surface1);border-top-color:var(--mauve);border-radius:50%;animation:spin 0.8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-msg{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--overlay1)}

/* ── Cards ── */
.card{background:var(--mantle);border:1px solid var(--surface0);border-radius:14px;padding:20px;margin-bottom:10px;animation:fadeUp .4s ease both;min-height:0;flex-shrink:1}
.card+.card{animation-delay:.05s}

/* ── Section label ── */
.lbl{font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:var(--overlay0);margin-bottom:10px;display:flex;align-items:center;gap:8px}
.lbl::after{content:'';flex:1;height:1px;background:var(--surface0)}
.lbl .accent{color:var(--mauve);letter-spacing:0;text-transform:none;font-size:11px}

/* ── Inputs ── */
input[type=text],input[type=number],select,textarea{background:var(--base);border:1px solid var(--surface1);border-radius:8px;color:var(--text);font-family:'JetBrains Mono',monospace;font-size:12px;outline:none;transition:border-color .2s,box-shadow .2s;width:100%;padding:8px 11px}
input[type=text]::placeholder,textarea::placeholder{color:var(--overlay0)}
input[type=text]:focus,input[type=number]:focus,select:focus{border-color:var(--mauve);box-shadow:0 0 0 2px rgba(239,239,241,.15)}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 5 5-5' stroke='%23888888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px;appearance:none;cursor:pointer}
select option{background:var(--base)}
input[type=range]{width:100%;accent-color:var(--mauve);cursor:pointer;height:4px}
input[type=color]{width:36px;height:28px;border:1px solid var(--surface1);border-radius:6px;cursor:pointer;padding:2px;background:var(--base)}
input[type=checkbox]{accent-color:var(--mauve);width:14px;height:14px;cursor:pointer}

/* ── Buttons ── */
.btn{padding:8px 16px;border-radius:8px;border:none;font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:5px;white-space:nowrap;letter-spacing:.02em}
.btn:active{transform:scale(.97)}
.btn:disabled{opacity:.3;cursor:not-allowed}
.btn-mauve{background:var(--mauve);color:var(--crust);box-shadow:0 3px 12px rgba(239,239,241,.25)}
.btn-mauve:hover:not(:disabled){filter:brightness(1.1);box-shadow:0 5px 18px rgba(239,239,241,.38);transform:translateY(-1px)}
.btn-green{background:#efeff1;color:#121212;font-weight:700;box-shadow:0 3px 12px rgba(239,239,241,.12)}
.btn-green:hover:not(:disabled){filter:brightness(.95);box-shadow:0 5px 18px rgba(239,239,241,.2);transform:translateY(-1px)}
.btn-blue{background:var(--blue);color:var(--crust);box-shadow:0 3px 12px rgba(122,159,192,.2)}
.btn-blue:hover:not(:disabled){filter:brightness(1.08);transform:translateY(-1px)}
.btn-ghost{background:transparent;border:1px solid var(--surface1);color:var(--subtext0)}
.btn-ghost.active{border-color:var(--mauve);color:var(--mauve);background:rgba(239,239,241,.12)}
.btn-ghost:hover:not(:disabled){border-color:var(--mauve);color:var(--mauve)}
.btn-red{background:transparent;border:1px solid rgba(176,96,96,.3);color:var(--red)}
.btn-red:hover:not(:disabled){background:rgba(176,96,96,.08)}

/* ── Grid ── */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}

/* ── Field ── */
.field label{display:block;font-size:10px;color:var(--overlay1);margin-bottom:5px;letter-spacing:.04em}

/* ── Divider ── */
.hr{height:1px;background:var(--surface0);margin:14px 0}

/* ── Alerts ── */
.err{padding:8px 12px;border-radius:8px;font-size:11px;line-height:1.5;margin-top:8px;background:rgba(176,96,96,.09);border:1px solid rgba(176,96,96,.35);color:var(--subtext1)}
.info{padding:8px 12px;border-radius:8px;font-size:11px;line-height:1.5;margin-top:8px;background:rgba(122,159,192,.09);border:1px solid rgba(122,159,192,.35);color:var(--subtext1)}
.warn{padding:8px 12px;border-radius:8px;font-size:11px;line-height:1.5;margin-top:8px;background:rgba(184,144,96,.09);border:1px solid rgba(184,144,96,.35);color:var(--subtext1)}

/* ── URL row ── */
.url-row{display:flex;gap:8px}
.url-row input{flex:1}

/* ── Source quality ── */
.sq-wrap{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.sq-btn{padding:3px 9px;border-radius:6px;border:1px solid var(--surface1);background:var(--base);font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--overlay1);cursor:pointer;transition:all .15s}
.sq-btn:hover{border-color:var(--mauve);color:var(--mauve)}
.sq-btn.active{border-color:var(--mauve);color:var(--mauve);background:rgba(239,239,241,.1)}

/* ── Drop zone ── */
.drop-zone{border:2px dashed var(--surface1);border-radius:12px;padding:28px 16px;text-align:center;cursor:pointer;transition:all .2s;background:var(--base);position:relative}
.drop-zone:hover,.drop-zone.over{border-color:var(--mauve);background:rgba(239,239,241,.04)}
.drop-zone.has-file{border-color:var(--green);background:rgba(107,158,120,.04)}
.drop-zone .di{font-size:28px;margin-bottom:8px}
.drop-zone .dt{font-size:11px;color:var(--overlay0)}
.drop-zone .dn{font-size:11px;color:var(--green);margin-top:6px;font-weight:600}

/* ── Canvas editor ── */
.editor-wrap{position:relative;border-radius:10px;overflow:hidden;background:var(--crust);line-height:0;user-select:none}
#previewCanvas{display:block;width:100%;cursor:crosshair}
#overlayCanvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}
.editor-wrap.drag-active #overlayCanvas{pointer-events:auto;cursor:none}

/* ── Timeline ── */
.timeline{position:relative;height:48px;background:var(--base);border-radius:8px;margin:10px 0;user-select:none;overflow:visible}
.tl-bg{position:absolute;inset:0;border-radius:8px}
.tl-fill{position:absolute;top:0;bottom:0;background:rgba(239,239,241,.15);border-left:2px solid var(--mauve);border-right:2px solid var(--mauve)}
.tl-handle{position:absolute;top:50%;transform:translate(-50%,-50%);width:12px;height:28px;background:var(--mauve);border-radius:4px;cursor:ew-resize;z-index:4;transition:filter .15s}
.tl-handle:hover{filter:brightness(1.2)}
.tl-playhead{position:absolute;top:0;bottom:0;width:2px;background:var(--blue);z-index:3;pointer-events:none;transform:translateX(-50%)}
.tl-playhead::before{content:'';position:absolute;top:-4px;left:50%;transform:translateX(-50%);width:8px;height:8px;background:var(--blue);border-radius:50%}
.kf-dot{position:absolute;top:50%;transform:translate(-50%,-50%);width:10px;height:10px;border-radius:50%;background:#7a9fc0;border:2px solid var(--mantle);cursor:pointer;z-index:5;transition:all .15s}
.kf-dot.selected{background:#7a9fc0;transform:translate(-50%,-50%) scale(1.3)}
.kf-dot:hover{filter:brightness(1.2)}
.tl-times{display:flex;justify-content:space-between;font-size:9px;color:var(--overlay0);margin-top:4px}
.tl-ticks{position:absolute;inset:0;pointer-events:none;border-radius:8px;overflow:hidden}
.tl-trim-overlay{position:absolute;top:0;bottom:0;background:var(--base);opacity:.75;pointer-events:none;z-index:1}

/* ── Edit tabs ── */
.edit-tabs{display:flex;gap:4px;margin-bottom:14px;border-bottom:1px solid var(--surface0);padding-bottom:12px}
.edit-tab{padding:5px 12px;border-radius:6px;border:1px solid transparent;background:transparent;color:var(--subtext1);font-weight:600;font-family:'JetBrains Mono',monospace;font-size:10px;cursor:pointer;transition:all .15s;letter-spacing:.03em}
.edit-tab:hover{color:var(--text);border-color:var(--surface1)}
.edit-tab.active{border-color:var(--mauve);color:var(--mauve);background:rgba(239,239,241,.1)}
.tab-panel{display:none}
.tab-panel.active{display:block}

/* ── Keyframe list ── */
.kf-list{display:flex;flex-direction:column;gap:4px;margin-bottom:12px;max-height:260px;overflow-y:auto}
.kf-item{background:var(--base);border:1px solid var(--surface0);border-radius:8px;padding:10px 12px;transition:border-color .15s;position:relative}
.kf-item:hover{border-color:var(--surface1)}
.kf-item.selected{border-color:var(--mauve);background:rgba(239,239,241,.05)}
.kf-item-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.kf-time{font-size:11px;color:var(--peach);font-weight:600}
.kf-del{margin-left:auto;padding:2px 7px;border-radius:5px;border:1px solid rgba(176,96,96,.2);background:transparent;color:var(--red);font-size:9px;cursor:pointer;font-family:'JetBrains Mono',monospace;transition:all .15s}
.kf-del:hover{background:rgba(176,96,96,.1)}
.kf-values{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.kf-val{display:flex;flex-direction:column;gap:3px}
.kf-val label{font-size:9px;color:var(--overlay0);text-transform:uppercase;letter-spacing:.1em;display:flex;align-items:center;gap:3px}
.kf-val input{background:var(--surface0);border:1px solid var(--surface1);border-radius:5px;color:var(--text);font-family:'JetBrains Mono',monospace;font-size:11px;padding:4px 7px;width:100%;outline:none;transition:border-color .15s}
.kf-val input:focus{border-color:var(--mauve)}
.kf-diamond{background:none;border:none;cursor:pointer;font-size:13px;color:var(--surface2);padding:0;line-height:1;transition:color .12s;flex-shrink:0;vertical-align:middle}
.kf-diamond:hover{color:var(--overlay2)}
.kf-diamond-active{color:#7a9fc0}
.kf-chevron{background:none;border:1px solid var(--surface1);border-radius:4px;cursor:pointer;font-size:11px;color:var(--overlay1);padding:1px 5px;line-height:1.4;transition:all .12s;flex-shrink:0;font-family:'JetBrains Mono',monospace;margin-left:4px}
.kf-chevron:hover{border-color:var(--mauve);color:var(--mauve)}
.ov-layer-card{border:1px solid var(--surface0);border-radius:8px;overflow:hidden;margin-bottom:6px;transition:border-color .15s,box-shadow .15s}
.ov-layer-card.active{border-color:var(--mauve);box-shadow:0 0 0 1px rgba(239,239,241,.15)}

/* ── Chroma ── */
.chroma-pick{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.chroma-pick span{font-size:11px;color:var(--overlay1)}
#chromaCanvas{width:100%;border-radius:8px;display:none;background:repeating-conic-gradient(var(--surface0) 0% 25%,var(--base) 0% 50%) 0 0/14px 14px;margin-top:10px}

/* ── Quality slider ── */
.quality-track{position:relative;padding-bottom:18px;margin-bottom:4px}
.quality-labels{display:flex;justify-content:space-between;font-size:9px;color:var(--overlay0);margin-top:4px}
.quality-val{font-size:13px;color:var(--mauve);font-weight:600;text-align:center;margin-top:6px}

/* ── Stats ── */
.stats{display:flex;gap:0;background:var(--base);border:1px solid var(--surface0);border-radius:10px;overflow:hidden;margin:12px 0}
.stat{flex:1;padding:10px;border-right:1px solid var(--surface0)}
.stat:last-child{border-right:none}
.stat-l{font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:var(--overlay0);margin-bottom:4px}
.stat-v{font-family:'Nunito',sans-serif;font-size:18px;font-weight:800;line-height:1}
.stat-s{font-size:9px;color:var(--overlay0);margin-top:2px}
.c-green{color:var(--green)}.c-yellow{color:var(--yellow)}.c-red{color:var(--red)}.c-blue{color:var(--blue)}.c-mauve{color:var(--mauve)}

/* ── Progress ── */
.prog-wrap{margin-top:14px}
.prog-track{height:3px;background:var(--surface0);border-radius:99px;overflow:hidden}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--mauve),var(--blue),var(--teal));border-radius:99px;transition:width .3s ease;width:0}
.prog-steps{display:flex;justify-content:space-between;margin-top:8px}
.prog-step{font-size:9px;color:var(--overlay0);display:flex;align-items:center;gap:4px;letter-spacing:.03em}
.prog-step .dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}
.prog-step.active{color:var(--mauve)}.prog-step.done{color:var(--green)}
.prog-detail{font-size:10px;color:var(--overlay0);text-align:center;margin-top:8px;font-style:italic}

/* ── Presets ── */
.presets{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:14px}


/* ── Result ── */
.gif-wrap{border-radius:10px;overflow:hidden;background:repeating-conic-gradient(var(--surface0) 0% 25%,var(--base) 0% 50%) 0 0/16px 16px;line-height:0;width:fit-content;max-width:100%;margin:0 auto}
#resultGif,#gifResultImg{display:block;max-width:100%;height:auto}
.result-badges{display:flex;gap:5px;flex-wrap:wrap;justify-content:center;margin:12px 0}
.badge{padding:3px 9px;border-radius:20px;font-size:9px;letter-spacing:.04em}
.badge-green{background:rgba(107,158,120,.12);border:1px solid rgba(107,158,120,.3);color:var(--green)}
.badge-red{background:rgba(176,96,96,.1);border:1px solid rgba(176,96,96,.25);color:var(--red)}
.badge-yellow{background:rgba(184,144,96,.1);border:1px solid rgba(184,144,96,.25);color:var(--yellow)}
.badge-blue{background:rgba(122,159,192,.1);border:1px solid rgba(122,159,192,.25);color:var(--blue)}
.badge-mauve{background:rgba(239,239,241,.1);border:1px solid rgba(239,239,241,.25);color:var(--mauve)}

/* ── Misc ── */
.hidden{display:none!important}
.row{display:flex;gap:8px;align-items:center}
.hint{font-size:10px;color:var(--overlay2);line-height:1.6;margin-bottom:10px;font-style:italic}
.spinner{width:12px;height:12px;border:2px solid rgba(255,255,255,.15);border-top-color:currentColor;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes chatCursor{0%,100%{opacity:1}50%{opacity:0}}
@media(max-width:520px){.g3{grid-template-columns:1fr 1fr}.g4{grid-template-columns:1fr 1fr}}

/* ── Effects / Overlay tab helpers ── */
.eff-row{display:flex;align-items:center;gap:6px;margin-bottom:5px;flex-wrap:wrap}
.eff-num{width:52px!important;padding:4px 6px!important;font-size:11px!important;background:var(--base);border:1px solid var(--surface1);border-radius:5px;color:var(--text);font-family:'JetBrains Mono',monospace;outline:none;box-sizing:border-box}
.eff-num:focus{border-color:var(--mauve)}
.eff-col-lbl{font-size:9px;text-transform:uppercase;letter-spacing:.12em;color:var(--overlay0);margin-bottom:6px;display:flex;align-items:center;gap:6px}
.eff-col-lbl::after{content:'';flex:1;height:1px;background:var(--surface0)}
.eff-col-lbl.ov-section{color:var(--text);font-weight:700;font-size:10px}
.eff-btn-col{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}
.eff-btn-col .btn{justify-content:flex-start;text-align:left}
.eff-btn-item{display:flex;flex-direction:column;gap:3px;margin-bottom:6px;margin-top:2px}
.eff-btn-item input[type=range]{width:100%;margin:2px 0 0}
.eff-btn-item .btn{justify-content:center;text-align:center}
.export-seq-status{padding:8px 10px;border-radius:8px;font-size:10px;margin-top:8px;background:rgba(107,158,120,.07);border:1px solid rgba(107,158,120,.2);color:var(--green)}
.export-seq-status.err{background:rgba(176,96,96,.07);border-color:rgba(176,96,96,.2);color:var(--red)}


/* ── GIF editor ── */
.frame-timeline{position:relative;overflow-x:auto;overflow-y:hidden;background:var(--base);border:1px solid var(--surface0);border-radius:10px;margin:10px 0;padding:6px;min-height:72px;user-select:none;-webkit-user-select:none}
.frame-strip{display:flex;gap:3px;align-items:center;min-width:max-content}
.frame-thumb{position:relative;flex-shrink:0;border-radius:4px;overflow:hidden;border:2px solid transparent;cursor:pointer;transition:border-color .12s}
.frame-thumb.selected{border-color:var(--mauve)}
.frame-thumb.selected::after{content:'';position:absolute;inset:0;background:rgba(239,239,241,.25)}
.frame-thumb canvas{display:block}
.frame-num{position:absolute;bottom:1px;left:2px;font-size:8px;font-family:'JetBrains Mono',monospace;color:rgba(255,255,255,.75);line-height:1;text-shadow:0 0 3px #000}
.frame-playhead{position:absolute;top:0;bottom:0;width:2px;background:var(--blue);pointer-events:none;z-index:3;transform:translateX(-50%)}
.frame-playhead::before{content:'';position:absolute;top:-3px;left:50%;transform:translateX(-50%);width:7px;height:7px;background:var(--blue);border-radius:50%}
.sel-range{position:absolute;top:0;bottom:0;background:rgba(239,239,241,.12);pointer-events:none;z-index:2}
.frame-reorder-indicator{position:absolute;top:0;bottom:0;width:3px;background:var(--blue);pointer-events:none;z-index:6;border-radius:2px;transform:translateX(-50%)}
.frame-thumb.dragging-source{opacity:.45;outline:2px dashed var(--blue)}


/* ── Scrub bar (secondary proportional timeline) ── */
.scrub-bar-wrap{position:relative;height:14px;background:var(--base);border-radius:6px;margin:6px 0 2px;cursor:pointer;user-select:none;border:1px solid var(--surface0);overflow:visible}
.scrub-bar-ph{position:absolute;top:-2px;bottom:-2px;width:2px;background:var(--blue);transform:translateX(-50%);pointer-events:none;border-radius:2px;z-index:5}
.scrub-bar-ph::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;background:var(--blue);border-radius:50%}
.scrub-frame-line{position:absolute;top:3px;bottom:3px;width:1px;background:var(--surface1);opacity:.5;pointer-events:none;transform:translateX(-50%);z-index:1}
.scrub-kf-tick{position:absolute;top:2px;bottom:2px;width:3px;background:var(--peach);opacity:.9;pointer-events:auto;transform:translateX(-50%);border-radius:2px;z-index:4;cursor:grab;transition:opacity .1s,transform .1s}
.scrub-kf-tick:hover{opacity:1;transform:translateX(-50%) scaleY(1.2)}
.scrub-kf-tick-nondrag{cursor:default;pointer-events:none}
.scrub-kf-napolitan{position:absolute;top:2px;bottom:2px;width:4px;border-radius:2px;z-index:4;cursor:grab;overflow:hidden;transform:translateX(-50%)}
.scrub-kf-tick-overlay{background:var(--green)}

/* ── Playback controls ── */
.playback-controls{display:flex;align-items:center;gap:5px;margin:4px 0 6px;flex-wrap:wrap}
.pb-btn{width:26px;height:26px;border-radius:6px;border:1px solid var(--surface1);background:var(--base);color:var(--text);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0;padding:0;font-family:'JetBrains Mono',monospace}
.pb-btn:hover{border-color:var(--mauve);color:var(--mauve)}
.pb-btn.active{border-color:var(--mauve);background:rgba(239,239,241,.1);color:var(--mauve)}
.pb-time{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--overlay1)}

/* ── Video decode panel ── */
.video-decode-panel{background:var(--base);border:1px solid var(--surface0);border-radius:8px;padding:12px;margin-top:10px}
.vd-preview-wrap{background:repeating-conic-gradient(var(--surface0) 0% 25%,var(--base) 0% 50%) 0 0/14px 14px;border-radius:8px;overflow:hidden;margin-bottom:10px;line-height:0;display:flex;align-items:center;justify-content:center;max-height:200px}
#vdPreviewVid{width:100%;max-height:200px;display:block;object-fit:contain}

/* ── Twitch emote preset ── */
.emote-sizes{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.emote-size{padding:6px 12px;border-radius:8px;border:1px solid var(--surface1);background:var(--base);font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--overlay1);cursor:pointer;transition:all .15s;text-align:center}
.emote-size:hover{border-color:var(--mauve);color:var(--mauve)}
.emote-size.active{border-color:var(--mauve);background:rgba(239,239,241,.1);color:var(--mauve)}
.emote-size .es-px{font-size:13px;font-family:'Nunito',sans-serif;font-weight:700;color:var(--text);display:block;line-height:1.2}
/* ── Blank canvas presets ── */
.bc-presets{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px}
.bc-chip{padding:5px 10px;border-radius:7px;border:1px solid var(--surface1);background:var(--base);font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--overlay1);cursor:pointer;transition:all .15s;text-align:center;line-height:1.35}
.bc-chip:hover{border-color:var(--mauve);color:var(--mauve)}
.bc-chip.active{border-color:var(--mauve);background:rgba(239,239,241,.1);color:var(--mauve)}
.bc-chip .bc-label{font-size:9px;color:var(--overlay0);display:block}
/* ── Toast notification ── */
#fgToast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(12px);background:var(--surface0);border:1px solid var(--surface1);color:var(--text);font-family:'JetBrains Mono',monospace;font-size:11px;padding:8px 18px;border-radius:20px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s,transform .2s;z-index:9999}
#fgToast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── 3-column GIF editor layout ── */

/* Break gifEditorWrap out of the 800px wrap constraint — full viewport width */
#gifEditorWrap{
  width:100vw;
  position:relative;
  left:50%;
  transform:translateX(-50%);
  padding:0 20px;
  box-sizing:border-box;
}

.gif-editor-cols{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:12px;
  align-items:start;
  width:100%;
}
.gif-col-left{ order:1; min-width:0; min-height:0; display:flex; flex-direction:column; gap:10px; max-height:calc(100dvh - 120px); overflow:hidden; }
.gif-col-mid{ order:2; min-width:0; min-height:0; display:flex; flex-direction:column; max-height:calc(100dvh - 120px); }
.gif-col-right{ order:3; min-width:0; min-height:0; display:flex; flex-direction:column; gap:10px; max-height:calc(100dvh - 120px); overflow:hidden; }

/* Collapse to single column on narrow screens */
@media(max-width:820px){
  #gifEditorWrap{ width:100%; left:0; transform:none; padding:0; }
  .gif-editor-cols{ grid-template-columns:1fr; }
  .gif-col-left,.gif-col-mid,.gif-col-right{ order:unset; max-height:none; overflow:visible; min-height:0; height:auto; }
  .gif-col-left > .card,.gif-col-right > .card{ flex:none; min-height:auto; overflow:visible; }
  .tab-panel.active{ max-height:none !important; overflow:visible; }
  #gifEditorToolsCard{ max-height:none !important; }
}

/* eff-btn-item for effects sliders */
.eff-btn-item{display:flex;flex-direction:column;gap:3px;margin-bottom:6px;margin-top:2px}
.eff-btn-item input[type=range]{width:100%;margin:2px 0 0}
.eff-btn-item .btn{justify-content:center;text-align:center}

/* ── Preview zoom/pan ── */
.preview-zoom-bar{display:flex;align-items:center;gap:6px;margin-bottom:4px}
.preview-zoom-label{font-size:9px;color:var(--overlay1);flex:1}
.preview-wrap{border-radius:8px;overflow:hidden;background:repeating-conic-gradient(var(--surface0) 0% 25%,var(--base) 0% 50%) 0 0/14px 14px;cursor:default;user-select:none;flex-shrink:0;margin:0 auto;display:block;max-width:100%;position:relative}
.preview-wrap.zoom-active{cursor:grab}
.preview-wrap.zoom-panning{cursor:grabbing}
.preview-canvas{display:block;transform-origin:top left;touch-action:none}

/* ── Export result card ── */
.gif-result-wrap{
  width:100%;
  max-height:40vh;
  overflow:hidden;
  border-radius:6px;
  background:repeating-conic-gradient(var(--surface0) 0% 25%,var(--base) 0% 50%) 0 0/14px 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:8px;
}
.gif-result-img{
  max-width:100%;
  max-height:40vh;
  object-fit:contain;
  display:block;
  border-radius:4px;
}

/* ── Full-size result modal ── */
.result-modal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.85);
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px;
  box-sizing:border-box;
}
.result-modal.hidden{ display:none; }
.result-modal-inner{
  background:var(--mantle);
  border:1px solid var(--surface0);
  border-radius:10px;
  max-width:min(95vw, 1200px);
  max-height:92vh;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.result-modal-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 14px;
  border-bottom:1px solid var(--surface0);
  flex-shrink:0;
}
.result-modal-body{
  overflow:hidden;
  padding:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex:1;
  min-height:0;
  background:repeating-conic-gradient(var(--surface0) 0% 25%,var(--base) 0% 50%) 0 0/14px 14px;
}
.result-modal-body img{
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  display:block;
  border-radius:4px;
}
.result-modal-footer{
  padding:12px 14px;
  border-top:1px solid var(--surface0);
  flex-shrink:0;
  background:var(--mantle);
}

/* ── Result card inline image ── */
.gif-result-card-wrap{
  width:100%;
  margin-bottom:8px;
  border-radius:6px;
  background:repeating-conic-gradient(var(--surface0) 0% 25%,var(--base) 0% 50%) 0 0/14px 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.gif-result-card-img{
  max-width:100%;
  max-height:30vh;
  object-fit:contain;
  display:block;
  cursor:pointer;
}

/* ── SVG gizmo overlay ── */
.gizmo-svg{
  position:absolute;
  top:0;left:0;
  overflow:visible;
  pointer-events:none;
  transform-origin:top left;
}

/* ── Paint tool modal ── */
.paint-modal{
  position:fixed;inset:0;background:rgba(0,0,0,0.85);z-index:9998;
  display:flex;align-items:center;justify-content:center;padding:16px;box-sizing:border-box;
}
.paint-modal.hidden{display:none}
.paint-modal-inner{
  background:var(--mantle);border:1px solid var(--surface0);border-radius:10px;
  display:flex;flex-direction:column;
  width:min(95vw,1100px);max-height:92vh;overflow:hidden;
}
.paint-modal-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;border-bottom:1px solid var(--surface0);flex-shrink:0;
}
.paint-modal-body{
  display:flex;flex:1;min-height:0;gap:0;
}
.paint-modal-controls{
  width:320px;flex-shrink:0;padding:14px;border-right:1px solid var(--surface0);
  overflow-y:auto;overflow-x:hidden;
}
.paint-modal-canvas-wrap{
  flex:1;min-width:0;padding:14px;display:flex;align-items:stretch;
}
@media(max-width:600px){
  .paint-modal-body{flex-direction:column}
  .paint-modal-controls{width:100%;border-right:none;border-bottom:1px solid var(--surface0)}
}

/* ── Custom thin scrollbar (Catppuccin) ── */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--surface1);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--overlay0)}
* { scrollbar-width:thin; scrollbar-color:var(--surface1) transparent; }

/* Tab panel content scrolls internally, not the column */
.tab-panel.active{overflow-y:auto;max-height:calc(100dvh - 230px)}
body.editor-active .tab-panel.active{max-height:calc(100dvh - 210px)}

/* gifInfoCard: flex column, preview wrap is normal block — JS controls its size */
#gifInfoCard{flex:1 1 auto;min-height:0;overflow:hidden}
.card-preview-region{overflow:hidden}

/* Cards in left/right cols share height proportionally */
.gif-col-left > .card,.gif-col-right > .card{flex:0 1 auto;min-height:0;overflow:hidden}
.gif-col-left > .card:last-child,.gif-col-right > .card:last-child{flex:0 1 auto}

/* Prevent horizontal scroll everywhere in cards */
.card{overflow-x:hidden}
.card *{min-width:0}
.btn{min-width:0;max-width:100%;flex-shrink:1;overflow:hidden;white-space:normal;word-break:break-word;height:auto;line-height:1.3}
.eff-btn-row,.eff-row,.g2,.eff-col,.eff-btn-col{overflow:hidden}
[style*="display:flex"]{min-width:0}
