/* ============================================================
   DailyDesk — Image Compressor & Resizer
   image-compressor.css — tool-specific styles.
   Reuses the design tokens + chrome from styles.css.
   ============================================================ */

/* A touch of soft, on-brand colour just for positive "saved" feedback and the
   drag-over hint — everything else stays in the greyscale system. */
:root {
  --ic-saved-bg:   #e9f3ec;   /* mint, matches --tl-work */
  --ic-saved-text: #2f7d57;
  --ic-drop-blue:  rgba(70, 110, 200, 0.06);
  --ic-drop-blue-border: #b9c6e6;
}

/* ── Value badges ── */
.ic-badges { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 18px; }
.ic-badge { display: inline-flex; align-items: center; gap: 6px; padding: 5px 11px; border: 1px solid var(--color-border); border-radius: var(--radius-pill); background: var(--color-card); font-size: 0.78rem; font-weight: 500; color: var(--color-muted); }
.ic-badge svg { width: 13px; height: 13px; color: var(--color-text); flex-shrink: 0; }

/* ── Drop zone ── */
.ic-drop { display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 40px 24px; border: 2px dashed var(--color-border); box-shadow: none; cursor: pointer; transition: border-color .15s, background .15s; margin-bottom: 22px; }
.ic-drop:hover { border-color: var(--color-border-hover); background: var(--color-bg); }
.ic-drop.is-dragover { border-color: var(--ic-drop-blue-border); background: var(--ic-drop-blue); }
.ic-drop-icon { width: 38px; height: 38px; color: var(--color-light); margin-bottom: 10px; }
.ic-drop-title { font-size: 1.02rem; font-weight: 700; letter-spacing: -0.01em; }
.ic-drop-sub { font-size: 0.86rem; color: var(--color-muted); margin-top: 4px; }
.ic-drop-browse { background: none; border: none; padding: 0; font: inherit; color: var(--color-text); font-weight: 600; text-decoration: underline; }
.ic-drop-browse:hover { color: var(--color-muted); }
.ic-drop-formats { font-size: 0.72rem; color: var(--color-light); margin-top: 10px; letter-spacing: .02em; }

/* ── Controls ── */
.ic-controls { padding: 18px 22px; }
.ic-ctrl-grid { display: flex; flex-wrap: wrap; gap: 22px 28px; align-items: flex-end; }
.ic-field { display: flex; flex-direction: column; gap: 7px; min-width: 0; }
.ic-field--check { justify-content: flex-end; }
.ic-label { font-size: 0.78rem; font-weight: 600; color: var(--color-muted); }
.ic-val { display: inline-block; min-width: 1.6em; padding: 0 5px; margin-left: 4px; border-radius: 5px; background: var(--color-bg); color: var(--color-text); font-variant-numeric: tabular-nums; text-align: center; }
.ic-inline { display: inline-flex; align-items: center; gap: 8px; }
.ic-times, .ic-unit { font-size: 0.82rem; color: var(--color-light); }
.ic-num { width: 84px; padding: 8px 10px; border: 1px solid var(--color-border); border-radius: var(--radius-input); background: var(--color-card); color: var(--color-text); font-family: inherit; font-size: 0.86rem; font-variant-numeric: tabular-nums; transition: border-color .15s, box-shadow .15s; }
.ic-num:hover { border-color: var(--color-border-hover); }
.ic-num:focus { outline: none; border-color: #aaa; box-shadow: 0 0 0 3px rgba(0,0,0,.06); }
.ic-color { width: 40px; height: 32px; padding: 2px; border: 1px solid var(--color-border); border-radius: var(--radius-input); background: var(--color-card); cursor: pointer; }
.ic-color:hover { border-color: var(--color-border-hover); }
.ic-check { display: inline-flex; align-items: center; gap: 8px; font-size: 0.84rem; color: var(--color-text); cursor: pointer; }
.ic-check input { width: 15px; height: 15px; accent-color: var(--color-text); cursor: pointer; }

/* Range slider — greyscale */
.ic-range { -webkit-appearance: none; appearance: none; width: 190px; max-width: 100%; height: 4px; border-radius: 3px; background: var(--color-border); outline: none; }
.ic-range::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 17px; height: 17px; border-radius: 50%; background: var(--color-text); border: 2px solid #fff; box-shadow: 0 1px 3px rgba(0,0,0,.25); cursor: pointer; }
.ic-range::-moz-range-thumb { width: 15px; height: 15px; border-radius: 50%; background: var(--color-text); border: 2px solid #fff; box-shadow: 0 1px 3px rgba(0,0,0,.25); cursor: pointer; }
.ic-range:focus-visible { box-shadow: 0 0 0 3px rgba(0,0,0,.10); }

/* ── Summary + bulk actions ── */
.ic-actions { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; margin: 4px 0 16px; }
.ic-summary { font-size: 0.88rem; color: var(--color-muted); }
.ic-summary strong { color: var(--color-text); font-weight: 700; }
.ic-summary .ic-saved-total { color: var(--ic-saved-text); font-weight: 700; }
.ic-action-btns { display: flex; align-items: center; gap: 8px; }
.ic-dl-all svg { width: 15px; height: 15px; }

/* ── Results grid ── */
.ic-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(252px, 1fr)); gap: 14px; margin-bottom: 30px; }
.ic-card { position: relative; display: flex; flex-direction: column; background: var(--color-card); border: 1px solid var(--color-border); border-radius: 14px; overflow: hidden; box-shadow: var(--shadow-card); }
.ic-thumb { position: relative; aspect-ratio: 16 / 10; background: repeating-conic-gradient(#f0f0f0 0% 25%, #fafafa 0% 50%) 50% / 18px 18px; display: flex; align-items: center; justify-content: center; }
.ic-thumb img { max-width: 100%; max-height: 100%; object-fit: contain; display: block; }
.ic-meta { padding: 11px 13px 4px; }
.ic-name { font-size: 0.82rem; font-weight: 600; color: var(--color-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ic-dims { font-size: 0.74rem; color: var(--color-light); margin-top: 2px; font-variant-numeric: tabular-nums; }
.ic-fmt { font-size: 0.7rem; color: var(--color-muted); font-weight: 700; letter-spacing: .03em; margin-top: 3px; }
.ic-sizes { display: flex; align-items: center; gap: 7px; flex-wrap: wrap; margin-top: 7px; font-size: 0.8rem; font-variant-numeric: tabular-nums; }
.ic-size-old { color: var(--color-light); text-decoration: line-through; }
.ic-arrow { color: var(--color-light); }
.ic-size-new { color: var(--color-text); font-weight: 700; }
.ic-saved { margin-left: auto; padding: 2px 8px; border-radius: var(--radius-pill); background: var(--ic-saved-bg); color: var(--ic-saved-text); font-size: 0.72rem; font-weight: 700; }
.ic-saved.is-bigger { background: var(--weekend-soft); color: var(--weekend); }
.ic-card-actions { display: flex; gap: 6px; padding: 8px 13px 12px; margin-top: auto; }
.ic-dl { flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 8px 10px; border: none; border-radius: 8px; background: var(--color-btn-primary-bg); color: #fff; font-size: 0.8rem; font-weight: 600; transition: background .15s; }
.ic-dl:hover { background: var(--color-btn-primary-hover); }
.ic-dl svg { width: 13px; height: 13px; }
.ic-remove { display: inline-flex; align-items: center; justify-content: center; width: 34px; flex-shrink: 0; border: 1px solid var(--color-border); border-radius: 8px; background: var(--color-card); color: var(--color-muted); transition: border-color .15s, color .15s, background .15s; }
.ic-remove:hover { border-color: var(--color-border-hover); color: var(--color-text); background: var(--color-bg); }
.ic-remove svg { width: 14px; height: 14px; }

/* Per-card status (working / error) */
.ic-status { padding: 0 13px; font-size: 0.74rem; }
.ic-card.is-working .ic-status { padding: 0 13px 10px; color: var(--color-muted); display: flex; align-items: center; gap: 7px; }
.ic-card.is-error .ic-status { padding: 0 13px 10px; color: var(--weekend); }
.ic-card.is-working .ic-card-actions, .ic-card.is-error .ic-card-actions { display: none; }
.ic-card.is-working .ic-sizes, .ic-card.is-working .ic-dims { opacity: .4; }
.ic-spinner { width: 13px; height: 13px; border: 2px solid var(--color-border); border-top-color: var(--color-text); border-radius: 50%; animation: ic-spin .7s linear infinite; flex-shrink: 0; }
.ic-note { font-size: 0.7rem; color: var(--color-light); padding: 0 13px 8px; margin-top: -2px; }
@keyframes ic-spin { to { transform: rotate(360deg); } }

/* Info / FAQ block */
.ic-info { max-width: 820px; }
.ic-info code { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: 5px; padding: 1px 5px; font-size: 0.85em; }

@media (prefers-reduced-motion: reduce) {
  .ic-spinner { animation: none; }
}

/* ── Mobile ── */
@media (max-width: 560px) {
  .ic-ctrl-grid { gap: 16px 18px; }
  .ic-range { width: 100%; }
  .ic-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; }
  .ic-actions { justify-content: stretch; }
  .ic-action-btns { width: 100%; }
  .ic-dl-all { flex: 1; }
}
