/* SVG Optimizer — sv- prefixed. */
.sv-app { display: flex; flex-direction: column; gap: 16px; }
.sv-app .panel { padding: 22px; }   /* global section{padding:30px 0} would crush the panels */

/* hero (split: text | upload) */
.sv-hero.split-hero { align-items: center; }
.sv-hero h2 { margin: 0 0 2px; font-size: 22px; font-weight: 800; }
.sv-sub { margin: 0 0 8px; font-size: 14px; font-weight: 700; color: #475569; }
.sv-sub .accent { color: #7c3aed; }
.sv-note { margin: 0 0 12px; font-size: 13px; line-height: 1.55; color: #5b6577; }
.sv-badges { display: flex; flex-wrap: wrap; gap: 7px; }
.sv-badges span { font-size: 11.5px; font-weight: 700; color: #6d4bf0; background: #f1ecfe; border: 1px solid #ddd3fb; border-radius: 20px; padding: 4px 10px; }
.sv-badges i { margin-right: 5px; }

/* upload-zone accent (matches the per-tool modifier the other tools use: icon + drag colour) */
.sv-upload .upload-icon { color: #7c3aed; }
.sv-upload.drag { border-color: #7c3aed; background: #f7f4ff; }

/* controls */
.sv-controls-h { display: flex; align-items: center; gap: 8px; margin: 0 0 14px; font-size: 14px; font-weight: 800; color: #27314a; }
.sv-controls-h i { color: #7c3aed; }
.sv-prec-row { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.sv-prec-row label { font-size: 12.5px; font-weight: 700; color: #475569; white-space: nowrap; }
.sv-prec-row input[type=range] { flex: 1; max-width: 260px; accent-color: #7c3aed; }
.sv-prec-out { font-size: 13px; font-weight: 800; color: #6d4bf0; min-width: 14px; text-align: center; }
.sv-prec-hint { font-size: 11.5px; color: #94a3b8; }
.sv-toggles { display: flex; flex-wrap: wrap; gap: 9px; }
.sv-toggle { display: inline-flex; align-items: center; gap: 7px; font-size: 12.5px; font-weight: 700; color: #475569; background: #f7f8fc; border: 1px solid #e8eaf2; border-radius: 9px; padding: 8px 12px; cursor: pointer; }
.sv-toggle input { accent-color: #7c3aed; width: 15px; height: 15px; }
.sv-toggle:hover { border-color: #ddd3fb; }

/* results */
.sv-res-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; flex-wrap: wrap; margin-bottom: 16px; }
.sv-summary { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; }
.sv-sum-big { display: flex; flex-direction: column; line-height: 1; }
.sv-sum-big strong { font-size: 30px; font-weight: 800; color: #059669; }
.sv-sum-big span { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: #94a3b8; margin-top: 3px; }
.sv-sum-rows { font-size: 12.5px; color: #64748b; }
.sv-sum-rows div { margin: 2px 0; }
.sv-sum-rows b { color: #1f2937; margin-left: 6px; }
.sv-sum-save { color: #059669 !important; }
.sv-res-actions { display: flex; gap: 8px; }

.sv-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; }
.sv-card { border: 1px solid #eef1f6; border-radius: 12px; overflow: hidden; background: #fff; display: flex; flex-direction: column; }
.sv-thumb { height: 120px; background-color: #fff; background-image:
  linear-gradient(45deg, #eef1f6 25%, transparent 25%), linear-gradient(-45deg, #eef1f6 25%, transparent 25%),
  linear-gradient(45deg, transparent 75%, #eef1f6 75%), linear-gradient(-45deg, transparent 75%, #eef1f6 75%);
  background-size: 16px 16px; background-position: 0 0, 0 8px, 8px -8px, -8px 0; }
.sv-card[style] .sv-thumb, .sv-thumb[style] { background-repeat: no-repeat; background-position: center; background-size: contain; }
.sv-thumb[style*="url"] { background-size: contain; background-repeat: no-repeat; background-position: center; }
.sv-card-body { padding: 11px 12px; }
.sv-card-name { font-size: 12.5px; font-weight: 700; color: #27314a; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sv-card-stats { display: flex; align-items: center; gap: 6px; margin: 6px 0 9px; font-size: 12px; }
.sv-card-stats i { color: #cbd5e1; font-size: 10px; }
.sv-was { color: #94a3b8; }
.sv-now { font-weight: 800; color: #059669; }
.sv-kept { color: #94a3b8; }
.sv-saved { margin-left: auto; font-weight: 800; color: #7c3aed; background: #f1ecfe; border-radius: 20px; padding: 1px 8px; font-size: 11px; }
.sv-row-prec { display: flex; align-items: center; gap: 8px; margin: 0 0 9px; }
.sv-row-cap { font-size: 11px; font-weight: 700; color: #94a3b8; white-space: nowrap; }
.sv-row-slider { flex: 1; min-width: 0; accent-color: #7c3aed; height: 4px; }
.sv-row-out { font-size: 12px; font-weight: 800; color: #6d4bf0; min-width: 12px; text-align: center; }
.sv-card-actions { display: flex; gap: 6px; }
.sv-btn { flex: 1; font-size: 11.5px; font-weight: 700; color: #334155; background: #f4f6fa; border: 1px solid #e3e8f0; border-radius: 8px; padding: 7px 8px; cursor: pointer; white-space: nowrap; }
.sv-btn:hover { border-color: #ddd3fb; color: #6d4bf0; }
.sv-btn.sv-x { flex: none; width: 32px; color: #94a3b8; }
.sv-btn.sv-x:hover { color: #e11d48; border-color: #f3b4bd; }

.sv-res-actions .btn-outline, .sv-res-actions .btn-indigo { font-size: 13px; }
.sv-plan-note { display: flex; align-items: flex-start; gap: 7px; margin-top: 14px; font-size: 12px; color: #64748b; line-height: 1.5; }
.sv-plan-note i { color: #7c3aed; margin-top: 2px; }
.sv-plan-link { border: 0; background: none; color: #6d4bf0; font-weight: 800; cursor: pointer; text-decoration: underline; padding: 0; font: inherit; }
.sv-free-pill { background: rgba(255, 255, 255, .25); border-radius: 20px; padding: 1px 7px; margin-left: 4px; font-size: 10.5px; }
