/* Flytree Compress Tool styles — full width, responsive, branded */
:root{
  --ft-primary:#2563eb; /* Flytree blue */
  --ft-accent:#10b981;  /* green */
  --ft-warn:#e11d48;    /* red */
  --ft-dark:#0f172a;    /* slate-900 */
  --ft-border:#e2e8f0;  /* slate-200 */
  --ft-muted:#64748b;   /* slate-500 */
}
.compress-tool-container{width:100%!important;max-width:100%!important;margin:0 auto;padding:20px;box-sizing:border-box;font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;color:var(--ft-dark)}
.ft-stepper{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}
.ft-step{display:flex;align-items:center;gap:8px;border:1px solid var(--ft-border);border-radius:14px;padding:10px 12px;font-weight:700;opacity:.7;background:#fff;transition:border-color .2s,box-shadow .2s,transform .2s}
.ft-step span{display:inline-grid;place-items:center;width:26px;height:26px;border-radius:50%;border:1px solid #cbd5e1;font-size:12px}
.ft-step.ft-active{opacity:1;border-color:var(--ft-primary);box-shadow:0 2px 10px rgba(37,99,235,.1)}
.ft-panel{border:1px solid var(--ft-border);border-radius:16px;padding:16px;background:#fff}
.ft-upload input[type=file]{display:block;width:100%;padding:14px;border:1px dashed #94a3b8;border-radius:12px;background:#f8fafc}
.ft-hint{margin:.5rem 0 0;color:var(--ft-muted);font-size:.9rem}
.ft-filelist{margin-top:12px;display:grid;gap:8px}
.ft-file{display:flex;justify-content:space-between;align-items:center;border:1px solid var(--ft-border);border-radius:12px;padding:10px;background:#fff}
.ft-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:14px}
.ft-btn{border:1px solid var(--ft-primary);background:var(--ft-primary);color:#fff;padding:10px 14px;border-radius:12px;font-weight:700;cursor:pointer;text-decoration:none;display:inline-block;transition:transform .15s ease, box-shadow .15s ease, background-color .15s ease}
.ft-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(37,99,235,.25)}
.ft-btn:active{transform:translateY(0);box-shadow:0 2px 8px rgba(0,0,0,.15)}
.ft-btn.secondary{background:#fff;color:var(--ft-primary)}
.ft-btn[disabled]{opacity:.5;cursor:not-allowed;box-shadow:none}
.ft-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.ft-field{display:flex;flex-direction:column;gap:6px}
.ft-checkbox{display:flex;align-items:center;gap:8px}
.ft-progress-wrap{height:10px;border:1px solid var(--ft-border);border-radius:999px;margin-bottom:12px;overflow:hidden;background:#f1f5f9}
.ft-progress-bar{height:100%;background:linear-gradient(90deg,var(--ft-primary),var(--ft-accent));transition:width .25s}
.ft-results{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}
.ft-card{border:1px solid var(--ft-border);border-radius:12px;padding:10px;display:flex;flex-direction:column;gap:8px;background:#fff}
.ft-mini{font-size:.85rem;color:#475569}
.ft-badge{font-size:.75rem;border:1px solid #cbd5e1;border-radius:999px;padding:2px 8px;color:#334155;background:#f8fafc}
@media (max-width:480px){.ft-actions{flex-direction:column;align-items:stretch}}

/* Drag & Drop zone */
.ft-dropzone{
  display:flex;align-items:center;justify-content:center;text-align:center;
  width:100%;padding:26px;border:2px dashed var(--ft-border);border-radius:14px;
  background:#f8fafc;margin-bottom:12px;user-select:none;outline:none;transition:border-color .2s, background .2s, box-shadow .2s
}
.ft-dropzone:hover{border-color:var(--ft-primary);box-shadow:0 4px 18px rgba(37,99,235,.12)}
.ft-dropzone.ft-dragover{border-color:var(--ft-accent);background:#ecfeff;box-shadow:0 6px 22px rgba(16,185,129,.18)}

/* Preview grid */
.ft-previews{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-top:10px}
.ft-thumb{position:relative;border:1px solid var(--ft-border);border-radius:12px;overflow:hidden;background:#fff}
.ft-thumb img{display:block;width:100%;height:90px;object-fit:cover}
.ft-thumb .ft-thumb-meta{padding:6px 8px;font-size:.78rem;color:#475569;display:flex;justify-content:space-between;gap:6px;align-items:center}
.ft-x{position:absolute;top:6px;right:6px;background:rgba(0,0,0,.6);color:#fff;border:none;border-radius:8px;padding:2px 6px;font-size:.75rem;cursor:pointer}
.ft-x:hover{background:rgba(0,0,0,.75)}
.ft-fileicon{display:grid;place-items:center;width:100%;height:90px;font-weight:800;color:#475569;background:#f1f5f9}

/* Drag reorder styles */
.ft-thumb.dragging{opacity:.5;border:2px dashed var(--ft-primary)}
.ft-thumb.drop-target{box-shadow:inset 0 0 0 2px var(--ft-accent)}

/* Drag reorder states */
.ft-draggable{cursor:grab}
.ft-draggable:active{cursor:grabbing}
.ft-drag-target{outline:2px dashed var(--ft-accent); outline-offset:2px}

/* Full-bleed thumbnail fixes */
:root{ --ft-thumb-ratio: 1; } /* 1 = square; set 16/9 or 4/3 if you like */
.ft-thumb{position:relative;border:1px solid var(--ft-border);border-radius:12px;overflow:hidden;background:#fff}
.ft-thumb-media{position:relative;width:100%;aspect-ratio:var(--ft-thumb-ratio);background:#f1f5f9}
.ft-thumb-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.ft-fileicon{position:absolute;inset:0;display:grid;place-items:center;font-weight:800;color:#475569;background:#f1f5f9}

/* tighten old rules to not conflict */
.ft-thumb img{height:auto}

/* Overall tool border + background */
.compress-tool-container{
  border:2px solid var(--ft-border);
  border-radius:18px;
  background:#f9fafb; /* light gray background */
  box-shadow:0 2px 12px rgba(0,0,0,.04);
}

/* Make all buttons larger */
.ft-btn{
  font-size:1rem;
  padding:14px 20px;
}

/* Style file input choose button */
.ft-upload input[type=file]::file-selector-button{
  background:var(--ft-primary);
  color:#fff;
  border:none;
  border-radius:12px;
  padding:12px 18px;
  margin-right:12px;
  font-weight:600;
  cursor:pointer;
  transition:all .2s;
}
.ft-upload input[type=file]::file-selector-button:hover{
  background:#1d4ed8; /* darker blue */
  transform:translateY(-1px);
  box-shadow:0 4px 12px rgba(37,99,235,.25);
}
.ft-upload input[type=file]::file-selector-button:active{
  transform:translateY(0);
  box-shadow:0 2px 6px rgba(0,0,0,.2);
}

/* ===== v1.3.3 UI polish ===== */
.compress-tool-wrap{position:relative;padding:18px;background:transparent}
.compress-tool-container{border:2px solid var(--ft-border);border-radius:18px;box-shadow:0 8px 28px rgba(2,6,23,.06);background:#fff}

/* Light background BELOW tool */
.ft-underlay{margin-top:14px;height:120px;border-radius:16px;background:linear-gradient(180deg,#f8fafc, #eef2ff);}

/* Larger, colorful "Choose files" button */
.ft-upload input[type=file]{
  font-size:0.95rem;
}
.ft-upload input[type=file]::file-selector-button{
  background:var(--ft-accent);
  color:#fff;
  border:1px solid var(--ft-accent);
  padding:12px 18px;
  margin-right:12px;
  border-radius:12px;
  font-weight:800;
  cursor:pointer;
  transition:transform .15s, box-shadow .15s, background .15s;
}
.ft-upload input[type=file]::file-selector-button:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 24px rgba(16,185,129,.25);
}
.ft-upload input[type=file]::file-selector-button:active{
  transform:translateY(0);
  box-shadow:0 4px 14px rgba(0,0,0,.12);
}

/* Bigger action buttons overall */
.ft-btn{padding:12px 18px;font-size:1rem;border-radius:14px}
.ft-actions{margin-top:16px}
