.ctrl-group { display:flex;flex-direction:column;gap:0.4rem; } .ctrl-group label { font-size:0.72rem;font-weight:600;color:var(--sub);display:flex;justify-content:space-between;align-items:center; } .lval { font-size:0.75rem;color:var(--accent);font-weight:700; } .ctrl-input { width:100%;background:#fff;border:1.5px solid var(--border2); color:var(--text);padding:9px 11px;border-radius:9px; font-size:0.84rem;outline:none; transition:border-color 0.18s,box-shadow 0.18s; cursor:default; } .ctrl-input:focus { border-color:var(--accent);box-shadow:0 0 0 3px rgba(79,70,229,0.1); } .ctrl-input.clickable { cursor:pointer; } .ctrl-input.clickable:hover { border-color:var(--accent); } .compress-btn { width:100%;padding:11px 0; background:linear-gradient(135deg,var(--accent) 0%,#7c3aed 100%); color:#fff;border:none;border-radius:10px; font-size:0.88rem;font-weight:700; cursor:pointer;transition:all 0.2s; box-shadow:0 3px 12px rgba(79,70,229,0.35);letter-spacing:0.2px; } .compress-btn:hover { opacity:0.92;transform:translateY(-1px); } .compress-btn:disabled { opacity:0.4;cursor:not-allowed;transform:none;box-shadow:none; } /* ── Canvas / Picker Area (replaces queue-section) ── */ .queue-section { padding:0 2rem 1.5rem;display:none; } .queue-header { display:flex;align-items:center;justify-content:space-between;padding:1.2rem 0 0.8rem;border-top:1px solid var(--border); } .queue-title { font-size:0.75rem;font-weight:700;color:var(--sub);text-transform:uppercase;letter-spacing:1px; } .queue-actions { display:flex;gap:8px;align-items:center; } .add-more-btn { display:inline-flex;align-items:center;gap:5px;padding:6px 14px; background:#f0f1ff;border:1px solid #c4c9e8;color:var(--accent); border-radius:8px;font-size:0.78rem;font-weight:600;cursor:pointer; transition:all 0.18s; } .add-more-btn:hover { background:var(--accent-lt); } .clear-btn { font-size:0.78rem;color:var(--red);background:var(--red-lt); border:none;cursor:pointer;font-weight:600; padding:6px 14px;border-radius:8px;transition:all 0.18s; } .clear-btn:hover { background:#fca5a5; } /* ── Canvas wrapper ── */ .canvas-wrapper { position:relative;border-radius:12px;overflow:hidden; border:1px solid var(--border);background:#f8f9ff; cursor:crosshair;margin-bottom:1.2rem; max-height:460px;display:flex;align-items:center;justify-content:center; } #imageCanvas { display:block;max-width:100%;max-height:460px;object-fit:contain; } /* Magnifier */ .magnifier { position:absolute;width:110px;height:110px;border-radius:50%; border:2.5px solid var(--accent);pointer-events:none;overflow:hidden; display:none;box-shadow:0 4px 20px rgba(79,70,229,0.25);z-index:10; background:#fff; } #magCanvas { position:absolute;top:0;left:0; } .crosshair-line { position:absolute;top:50%;left:50%;transform:translate(-50%,-50%); pointer-events:none;z-index:11; } .crosshair-line::before,.crosshair-line::after { content:'';position:absolute;background:rgba(255,255,255,0.9); } .crosshair-line::before { width:1px;height:14px;top:-7px;left:0; } .crosshair-line::after { width:14px;height:1px;top:0;left:-7px; } /* ── Color Info Row (replaces file-list) ── */ .file-list { display:flex;flex-direction:column;gap:8px; } .file-card { background:#f8f9ff;border:1px solid var(--border); border-radius:12px;padding:11px 14px; display:grid;grid-template-columns:52px 1fr auto auto; align-items:center;gap:12px;animation:fadeSlide 0.2s ease; } @keyframes fadeSlide { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} } .file-card.done { border-color:#6ee7b7;background:#f0fdf8; } .thumb { width:52px;height:52px;border-radius:8px; background:#e4e7f4;border:1px solid var(--border);flex-shrink:0; display:block; } .file-info .fname { font-size:0.84rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:320px; } .file-meta { font-size:0.7rem;color:var(--muted);margin-top:3px;display:flex;gap:8px;flex-wrap:wrap; } .saving-badge { font-size:0.7rem;padding:3px 10px;border-radius:99px;background:var(--green-lt);color:#065f46;border:1px solid #a7f3d0;white-space:nowrap;font-weight:700; } .dl-btn { display:inline-flex;align-items:center;gap:5px;padding:7px 13px; background:var(--accent-lt);border:1px solid #c4b5fd;color:var(--accent); border-radius:8px;font-size:0.78rem;font-weight:600; cursor:pointer;text-decoration:none;transition:all 0.18s;white-space:nowrap; } .dl-btn:hover { background:#ddd6fe; } /* ── Summary Bar ── */ .summary-bar { background:linear-gradient(135deg,#f0eeff 0%,#e0f2fe 100%); border:1px solid #c4b5fd;border-radius:var(--radius); padding:1.4rem 2rem;margin:0 2rem 1.5rem; display:none;grid-template-columns:repeat(4,1fr);gap:1rem;text-align:center; } .summary-bar.visible { display:grid; } .stat-val {font-size:1.35rem;font-weight:700;color:var(--accent); } .stat-label { font-size:0.7rem;color:var(--sub);margin-top:2px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px; } /* ── Palette Download Bar ── */ .dl-all-btn { display:none;width:calc(100% - 4rem);margin:0 2rem 2rem; padding:12px 0;background:#fff;border:2px solid var(--accent); color:var(--accent);border-radius:12px; font-size:0.9rem;font-weight:700;cursor:pointer;transition:all 0.2s; } .dl-all-btn.visible { display:block; } .dl-all-btn:hover { background:var(--accent-lt); } /* ── Palette Grid ── */ .palette-grid { display:flex;flex-wrap:wrap;gap:8px; padding:0 2rem 1.5rem; } .palette-grid.hidden { display:none; } .palette-title { font-size:0.7rem;font-weight:700;color:var(--muted); text-transform:uppercase;letter-spacing:1px; padding:0 2rem;margin-bottom:0.6rem;display:none; } .palette-title.visible { display:block; } .swatch-item { width:40px;height:40px;border-radius:9px; border:1.5px solid var(--border);cursor:pointer; position:relative;transition:transform 0.15s,border-color 0.15s; flex-shrink:0; } .swatch-item:hover { transform:scale(1.18);border-color:var(--accent);z-index:2; } .swatch-item .swatch-tip { position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%); background:var(--text);color:#fff;border-radius:6px;padding:4px 8px; font-size:0.65rem;white-space:nowrap; opacity:0;pointer-events:none;transition:opacity 0.15s;z-index:99; } .swatch-item:hover .swatch-tip { opacity:1; } /* ── Toast ── */ .toast { position:fixed;bottom:2rem;right:2rem;background:var(--text);color:#fff; border-radius:12px;padding:12px 20px;font-size:0.85rem;font-weight:500; box-shadow:0 8px 24px rgba(0,0,0,0.18);transform:translateY(80px);opacity:0; transition:all 0.28s ease;z-index:99;max-width:300px; } .toast.show { transform:translateY(0);opacity:1; } /* ── Zoom toggle btn ── */ .zoom-toggle { display:inline-flex;align-items:center;gap:5px;padding:6px 14px; background:#f0f1ff;border:1px solid #c4c9e8;color:var(--accent); border-radius:8px;font-size:0.78rem;font-weight:600;cursor:pointer; transition:all 0.18s; } .zoom-toggle.active { background:var(--accent-lt);border-color:var(--accent); } .zoom-toggle:hover { background:var(--accent-lt); } @media (max-width:780px) { .ctrl-input.clickable { margin-bottom: 0; cursor: pointer; } .queue-header { display: block; } }