/* ==========================================================================
   Equalza — Image Compressor / Converter Tool CSS
   Extracted from CompressKit source. Only tool-specific rules.
   Core layout (body, html, fonts) handled by equalza-core.
   Tab classes renamed: ck- → eq-
   ========================================================================== */

/* ---------- CSS Variables ---------- */
:root{
  --bg:#f5f6f8;--surface:#fff;--border:#e2e5ea;--border2:#c8cdd6;
  --accent:#2563eb;--accent-h:#1d4ed8;--accent-light:#eff6ff;--accent-mid:#bfdbfe;
  --text:#111827;--text2:#4b5563;--text3:#9ca3af;
  --green:#059669;--green-bg:#ecfdf5;
  --red:#dc2626;--red-bg:#fef2f2;
  --sh:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.05);
  --r:8px;--rl:12px;--rxl:16px;
}

/* ==========================================================================
   Tool Card Shell
   ========================================================================== */

.tool-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rxl);box-shadow:var(--sh);overflow:hidden}
.tool-card-tabbed{overflow:visible;border-radius:0 var(--rxl) var(--rxl) var(--rxl)!important}

/* ==========================================================================
   Top Bar (after files loaded)
   ========================================================================== */

.top-bar{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;border-bottom:1px solid var(--border);background:var(--bg)}
.btn-add{display:inline-flex;align-items:center;gap:7px;background:var(--accent);color:#fff;font-weight:600;font-size:13px;font-family:inherit;padding:8px 16px;border-radius:var(--r);border:none;cursor:pointer;box-shadow:0 2px 6px rgba(37,99,235,.25);transition:all .15s}
.btn-add:hover{background:var(--accent-h)}
.btn-add svg,.btn-clear svg,.btn-primary svg,.btn-ghost svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.btn-clear{display:inline-flex;align-items:center;gap:7px;background:var(--red-bg);color:var(--red);font-weight:600;font-size:13px;font-family:inherit;padding:8px 16px;border-radius:var(--r);border:1px solid #fecaca;cursor:pointer;transition:all .15s}
.btn-clear:hover{background:var(--red);color:#fff}

/* ==========================================================================
   Drop Zone
   ========================================================================== */

.drop-zone{border:2px dashed var(--border2);border-radius:var(--rl);margin:20px;padding:48px 24px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg)}
.drop-zone:hover,.drop-zone.drag-over{border-color:var(--accent);background:var(--accent-light)}
.dz-icon{width:52px;height:52px;background:var(--accent-light);border:1px solid var(--accent-mid);border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.dz-icon svg{width:22px;height:22px;stroke:var(--accent);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.dz-title{font-size:16px;font-weight:700;margin-bottom:6px}
.dz-sub{font-size:13px;color:var(--text2);margin-bottom:14px}
.btn-dz{display:inline-flex;align-items:center;gap:7px;background:var(--accent);color:#fff;font-weight:600;font-size:13px;font-family:inherit;padding:9px 20px;border-radius:var(--r);border:none;cursor:pointer}
.fmt-pills{display:flex;gap:5px;justify-content:center;margin-top:14px;flex-wrap:wrap}
.fmt-pill{padding:2px 9px;border:1px solid var(--border);border-radius:4px;font-size:10px;font-weight:700;color:var(--text3);letter-spacing:.05em;text-transform:uppercase;background:var(--surface)}

/* ==========================================================================
   Thumbnail Strip
   ========================================================================== */

.strip-section{padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg)}
.strip-wrap{display:flex;align-items:center;gap:8px}
.strip{display:flex;gap:10px;overflow-x:auto;padding:2px;scroll-behavior:smooth;scrollbar-width:none;flex:1}
.strip::-webkit-scrollbar{display:none}
.arrow-btn{width:28px;height:28px;border-radius:50%;background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .15s;box-shadow:var(--sh)}
.arrow-btn:hover{background:var(--accent);border-color:var(--accent)}
.arrow-btn:hover svg{stroke:#fff}
.arrow-btn svg{width:12px;height:12px;stroke:var(--text2);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}

/* ==========================================================================
   Thumb Card
   ========================================================================== */

.thumb{position:relative;flex-shrink:0;width:110px;border-radius:var(--r);border:2px solid var(--border);background:var(--surface);cursor:pointer;overflow:hidden;transition:border-color .15s}
.thumb.active{border-color:var(--accent)}
.thumb:hover:not(.active){border-color:var(--accent-mid)}
.thumb-img{width:110px;height:74px;object-fit:cover;display:block;background:#f0f0f0}
.thumb-overlay{position:absolute;inset:0;background:rgba(255,255,255,.75);display:flex;align-items:center;justify-content:center}
.thumb-badge{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);background:rgba(5,150,105,.92);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:4px;white-space:nowrap;pointer-events:none}
.thumb-badge.blue{background:rgba(37,99,235,.9)}
.thumb-badge.red{background:rgba(220,38,38,.85)}
.thumb-foot{padding:4px 6px;display:flex;align-items:center;gap:4px;border-top:1px solid var(--border)}
.thumb-name{font-size:9px;font-weight:600;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}
.thumb-save{display:inline-flex;align-items:center;gap:2px;background:var(--green);color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:3px;text-decoration:none;white-space:nowrap;flex-shrink:0}
.thumb-save.blue{background:var(--accent)}
.thumb-x{position:absolute;top:2px;right:2px;width:16px;height:16px;background:rgba(0,0,0,.45);border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff}
.thumb-x:hover{background:var(--red)}
.thumb-x svg{width:8px;height:8px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round}

/* ==========================================================================
   Action Row
   ========================================================================== */

.action-row{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;border-bottom:1px solid var(--border)}
.btn-primary{display:inline-flex;align-items:center;gap:7px;background:var(--green);color:#fff;font-weight:600;font-size:13px;font-family:inherit;padding:8px 18px;border-radius:var(--r);border:none;cursor:pointer;transition:all .15s}
.btn-primary:hover{opacity:.88}
.btn-ghost{display:inline-flex;align-items:center;gap:7px;background:var(--bg);color:var(--text2);font-weight:600;font-size:13px;font-family:inherit;padding:8px 18px;border-radius:var(--r);border:1px solid var(--border2);cursor:pointer;transition:all .15s}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);background:var(--surface)}
.badge-circle{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;background:rgba(255,255,255,.9);color:var(--green);font-size:10px;font-weight:700;border-radius:9px;padding:0 4px}
.badge-circle.blue{color:var(--accent)}

/* ==========================================================================
   Format Selector (converter)
   ========================================================================== */

.fmt-bar{display:flex;align-items:center;gap:8px;padding:12px 20px;border-bottom:1px solid var(--border);flex-wrap:wrap;background:var(--bg)}
.fmt-label{font-size:12px;font-weight:600;color:var(--text2);white-space:nowrap}
.fmt-opt{padding:6px 14px;border-radius:var(--r);border:1px solid var(--border2);background:var(--surface);font-size:12px;font-weight:700;color:var(--text2);cursor:pointer;transition:all .15s;font-family:inherit}
.fmt-opt:hover{border-color:var(--accent);color:var(--accent)}
.fmt-opt.active{background:var(--accent);border-color:var(--accent);color:#fff}

/* ==========================================================================
   Main Preview Area
   ========================================================================== */

.preview-area{padding:20px 20px 24px}
.prev-filename{font-size:15px;font-weight:700;text-align:center;margin-bottom:6px}
.prev-sizes{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;font-size:13px;padding:0 4px}
.sz-orig{color:var(--text2)}.sz-orig b{color:var(--text);font-weight:700}
.sz-new{font-weight:700;color:var(--green)}

/* ==========================================================================
   Split Compare
   ========================================================================== */

.compare-wrap{display:flex;gap:16px;align-items:stretch}
.quality-col{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--rl);flex-shrink:0;width:74px}
.q-label{font-size:10px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.06em}
.q-num{width:50px;height:34px;border:1px solid var(--border2);border-radius:var(--r);text-align:center;font-size:16px;font-weight:700;color:var(--text);font-family:inherit;background:var(--surface)}
.q-num:focus{outline:none;border-color:var(--accent)}
input[type=range].vr{-webkit-appearance:none;writing-mode:vertical-lr;direction:rtl;width:4px;height:110px;background:#e2e5ea;border-radius:2px;outline:none;cursor:pointer}
input[type=range].vr::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--accent);border:2px solid #fff;box-shadow:0 1px 4px rgba(37,99,235,.3)}
.btn-apply{width:100%;padding:7px 0;background:var(--accent);color:#fff;font-weight:700;font-size:11px;font-family:inherit;border:none;border-radius:var(--r);cursor:pointer}
.btn-apply:hover{background:var(--accent-h)}

/* ==========================================================================
   Split Box (canvas-based)
   ========================================================================== */

.split-box{
  position:relative;overflow:hidden;
  border-radius:var(--rl);border:1px solid var(--border);
  background:#f0f0f0;cursor:col-resize;user-select:none;
}
#split-canvas{
  display:block;width:100%;
  image-rendering:auto;
  min-height:260px;
}
.split-line{
  position:absolute;top:0;left:50%;height:100%;
  width:2px;background:#fff;
  box-shadow:0 0 8px rgba(0,0,0,.4);
  transform:translateX(-50%);
  z-index:4;pointer-events:none;
}
.split-handle-circle{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:36px;height:36px;background:#fff;
  border-radius:50%;box-shadow:0 2px 10px rgba(0,0,0,.28);
  display:flex;align-items:center;justify-content:center;
}
.split-handle-circle svg{
  width:16px;height:16px;stroke:var(--text2);fill:none;
  stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;
}
.split-lbl{
  position:absolute;top:10px;padding:3px 9px;border-radius:4px;
  font-size:11px;font-weight:700;pointer-events:none;z-index:5;
}
.split-lbl.L{left:10px;background:rgba(0,0,0,.52);color:#fff}
.split-lbl.R{right:10px;background:rgba(5,150,105,.9);color:#fff}
.split-spinner-overlay{
  position:absolute;inset:0;background:rgba(255,255,255,.75);
  display:flex;align-items:center;justify-content:center;
  z-index:10;border-radius:var(--rl);
}

/* ==========================================================================
   Converter Preview
   ========================================================================== */

.conv-preview{border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;background:#fff;min-height:180px;display:flex;align-items:center;justify-content:center}
.conv-preview img{max-width:100%;max-height:380px;object-fit:contain;display:block}
.conv-fmt-badge{display:inline-flex;align-items:center;gap:5px;background:var(--accent-light);color:var(--accent);border:1px solid var(--accent-mid);font-size:12px;font-weight:700;padding:4px 12px;border-radius:5px;margin:0 auto 12px;width:fit-content}

/* ==========================================================================
   Spinner
   ========================================================================== */

.spin{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:rot .7s linear infinite}
@keyframes rot{to{transform:rotate(360deg)}}

/* ==========================================================================
   Utility
   ========================================================================== */

.hidden{display:none!important}

/* ==========================================================================
   Responsive (mobile)
   ========================================================================== */

@media(max-width:640px){
  .compare-wrap{flex-direction:column}
  .quality-col{flex-direction:row;width:100%;justify-content:center}
  input[type=range].vr{writing-mode:unset;direction:unset;width:120px;height:5px}
}

/* ==========================================================================
   Tool Tabs  (ck- renamed to eq-)
   ========================================================================== */

/* suppress legacy tab elements */
.main-tabs{display:none!important}
.main-tab{display:none!important}
.exif-toggle{display:none!important}

/* -- outer shell -- */
.tool-card-tabbed{
  background:transparent;
  border:none;
  border-radius:0;
  box-shadow:none;
  overflow:visible;
}

/* -- tab bar row -- */
.eq-tabs-row{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  padding:0 16px 0 12px;
  background:transparent;
  gap:8px;
  min-height:44px;
  position:relative;
  z-index:3;
  margin-bottom:-1px;
}

/* -- tab nav -- */
.eq-tabs-nav{
  display:flex;
  align-items:flex-end;
  gap:3px;
}

/* -- single tab -- */
.eq-tab{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:0 16px;
  height:40px;
  background:#ebebeb;
  border:1px solid var(--border);
  border-bottom-color:var(--border);
  color:var(--text2);
  font-size:13px;
  font-weight:600;
  font-family:inherit;
  cursor:pointer;
  border-radius:8px 8px 0 0;
  white-space:nowrap;
  user-select:none;
  position:relative;
  top:1px;
  z-index:2;
  transition:background .12s, color .12s;
}
.eq-tab svg{
  width:15px;height:15px;
  flex-shrink:0;
  opacity:.6;
}
.eq-tab:hover{
  background:#e0e0e0;
  color:var(--text);
}
.eq-tab:hover svg{opacity:.85}

/* active tab: white, merges into panel */
.eq-tab.active{
  background:var(--surface);
  color:var(--accent);
  border-color:var(--border);
  border-bottom-color:var(--surface);
  z-index:5;
  top:1px;
}
.eq-tab.active svg{opacity:1}

/* thin accent line on top of active tab */
.eq-tab.active::before{
  content:'';
  position:absolute;
  top:0; left:0; right:0;
  height:2px;
  background:var(--accent);
  border-radius:8px 8px 0 0;
}

/* cover any 1px seam at bottom of active tab */
.eq-tab.active::after{
  content:'';
  position:absolute;
  bottom:-1px; left:0; right:0;
  height:2px;
  background:var(--surface);
}

/* -- EXIF toggle (same height as tabs) -- */
.eq-exif-toggle{
  display:inline-flex;
  align-items:center;
  gap:7px;
  height:38px;
  padding:0 14px;
  background:#ebebeb;
  border:1px solid var(--border);
  border-radius:8px 8px 0 0;
  color:var(--text2);
  font-size:12px;
  font-weight:600;
  cursor:pointer;
  user-select:none;
  white-space:nowrap;
  position:relative;
  top:1px;
  z-index:2;
  transition:background .12s, color .12s;
}
.eq-exif-toggle:hover{background:#e0e0e0; color:var(--text)}
.eq-exif-toggle input[type=checkbox]{display:none}

.eq-exif-box{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:16px;height:16px;
  border-radius:4px;
  border:1.5px solid #c5c5c5;
  background:#fff;
  flex-shrink:0;
  transition:background .12s, border-color .12s;
  color:transparent;
}
.eq-exif-box svg{width:10px;height:10px;stroke-width:2}
.eq-exif-toggle.is-checked .eq-exif-box{
  background:var(--accent);
  border-color:var(--accent);
  color:#fff;
}
.eq-exif-toggle.is-checked{color:var(--text)}
.eq-exif-text{font-size:12px}

/* -- panel (shared by compressor + converter) -- */
.tool-pane{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:0 var(--rxl) var(--rxl) var(--rxl);
  overflow:hidden;
  position:relative;
  z-index:1;
  box-shadow:var(--sh);
}

/* -- responsive tabs -- */
@media(max-width:520px){
  .eq-tab{padding:0 11px;font-size:12px;gap:4px}
  .eq-tab svg{display:none}
  .eq-exif-text{display:none}
  .eq-exif-toggle{padding:0 10px}
  .eq-tabs-row{padding:0 10px 0 8px}
}
