/* ==========================================================================
   Equalza — Image Cropper Tool CSS
   Matches CompressKit / Compressor design system.
   ========================================================================== */

/* ---------- CSS Variables (same as compressor) ---------- */
: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}

/* ---------- Hidden utility ---------- */
.hidden{display:none!important}

/* ---------- 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}
.btn-dz:hover{background:var(--accent-h)}
.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)}

/* ---------- Cropper Layout ---------- */
.crop-canvas-wrap{position:relative;border-radius:var(--rl);border:1px solid var(--border);overflow:hidden;background:#1a1a2e;user-select:none;touch-action:none;cursor:default}
.crop-canvas-wrap img{display:block;width:100%;height:auto;min-height:220px;object-fit:contain;transition:none}

/* ---------- Dark Overlay ---------- */
.crop-overlay{position:absolute;inset:0;pointer-events:none;background:rgba(0,0,0,.5)}

/* ---------- Crop Frame ---------- */
.crop-frame{position:absolute;border:2px solid var(--accent);box-shadow:0 0 0 1px rgba(0,0,0,.25),inset 0 0 0 1px rgba(255,255,255,.08);cursor:move;touch-action:none;z-index:5}

/* Rule-of-thirds grid */
.crop-grid-h,.crop-grid-v{position:absolute;background:rgba(255,255,255,.18);pointer-events:none}
.crop-grid-h{left:0;right:0;height:1px}
.crop-grid-v{top:0;bottom:0;width:1px}

/* ---------- Corner & Edge Handles ---------- */
.crop-handle{position:absolute;width:12px;height:12px;background:#fff;border:2px solid var(--accent);border-radius:2px;transform:translate(-50%,-50%);z-index:10;box-shadow:0 1px 3px rgba(0,0,0,.3);touch-action:none}

/* ---------- Info Row ---------- */
.crop-info-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:13px;padding:0 2px}
.crop-info-row .info-source{color:var(--text2)}
.crop-info-row .info-source b{color:var(--text)}
.crop-info-row .info-crop{font-weight:700;color:var(--accent)}

/* ---------- Preset Bar ---------- */
.crop-preset-bar{display:flex;align-items:center;gap:8px;padding:12px 20px;border-bottom:1px solid var(--border);background:var(--bg);flex-wrap:wrap}
.crop-preset-bar .preset-label{font-size:12px;font-weight:600;color:var(--text2);white-space:nowrap}
.crop-preset-btn{padding:6px 14px;border-radius:var(--r);border:1px solid var(--border2);background:var(--surface);color:var(--text2);font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap}
.crop-preset-btn:hover{border-color:var(--accent);color:var(--accent)}
.crop-preset-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Social preset separator */
.crop-preset-sep{width:1px;height:24px;background:var(--border2);margin:0 2px;flex-shrink:0}

/* ---------- Transform Row ---------- */
.crop-transform-row{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-bottom:1px solid var(--border);background:var(--bg);flex-wrap:wrap}
.crop-transform-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:var(--r);border:1px solid var(--border2);background:var(--surface);color:var(--text2);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}
.crop-transform-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}
.crop-transform-btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ---------- Action Row ---------- */
.action-row{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;border-top: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-primary svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.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)}
.btn-ghost svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}

/* ---------- Export Row ---------- */
.crop-export-row{display:flex;align-items:center;gap:12px;padding:12px 20px;border-top:1px solid var(--border);flex-wrap:wrap}
.crop-export-row .fmt-group{display:flex;align-items:center;gap:6px}
.crop-export-row .quality-group{display:flex;align-items:center;gap:8px;flex:1;min-width:160px}
.crop-export-row .quality-group input[type=range]{flex:1;accent-color:var(--accent);min-width:80px}
.crop-export-row .q-val{font-weight:700;color:var(--accent);font-size:14px;min-width:32px;text-align:center}
.crop-export-row .est-size{font-size:12px;color:var(--text2);margin-inline-start:auto;white-space:nowrap}
.crop-export-row .est-size b{color:var(--text)}

/* ---------- Privacy Banner ---------- */
.crop-privacy{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 20px;background:var(--green-bg);border-top:1px solid #bbf7d0;font-size:12px;color:var(--green);font-weight:600}
.crop-privacy svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ---------- Responsive ---------- */
@media(max-width:680px){
  .crop-preset-bar{gap:5px;padding:10px 14px}
  .crop-preset-btn{padding:5px 10px;font-size:11px}
  .crop-transform-row{gap:4px;padding:8px 14px}
  .crop-transform-btn{padding:5px 8px;font-size:11px}
  .crop-export-row{flex-direction:column;gap:8px;align-items:stretch}
  .crop-export-row .est-size{margin-inline-start:0;text-align:center}
}
