/* ===== CONVERTER WIDGET ===== */
#qc-converter-widget,
.qc-widget-container {
    background: var(--qc-white);
    border: var(--qc-widget-border);
    border-radius: var(--qc-radius-xl);
    overflow: hidden;
    box-shadow: var(--qc-shadow-widget);
    margin: var(--qc-sp-6) auto;
    max-width: 600px;
    width: 100%;
}

/* Header */
.qc-widget-header {
    background: var(--qc-white);
    padding: var(--qc-sp-8) var(--qc-sp-6);
    text-align: center;
    border-bottom: 1px solid var(--qc-gray-100);
}
.qc-header-content { display: flex; flex-direction: column; align-items: center; gap: var(--qc-sp-4); }
.qc-header-logo { max-width: 140px; height: auto; }
.qc-header-title {
    font-family: var(--qc-font-heading);
    font-size: var(--qc-text-2xl);
    font-weight: 700;
    color: var(--qc-gray-900);
    display: flex;
    align-items: center;
    gap: var(--qc-sp-3);
    flex-wrap: wrap;
    justify-content: center;
}

/* Tier badges */
.qc-tier-badge {
    font-size: var(--qc-text-xs);
    font-weight: 700;
    padding: .2rem .6rem;
    border-radius: 999px;
    letter-spacing: .05em;
}
.qc-tier-pro     { background: var(--qc-primary); color: var(--qc-dark); }
.qc-tier-trial   { background: #8b5cf6; color: #fff; }
.qc-tier-warning { background: var(--qc-error); color: #fff; }

/* Daily counter */
.qc-daily-counter { padding: var(--qc-sp-4) var(--qc-sp-6); background: var(--qc-gray-50); border-bottom: 1px solid var(--qc-gray-100); }
.qc-counter-inner { max-width: 420px; margin-inline: auto; }
.qc-counter-text { font-size: var(--qc-text-sm); color: var(--qc-gray-600); margin-bottom: var(--qc-sp-2); }
.qc-counter-progress { height: 6px; background: var(--qc-gray-200); border-radius: 999px; overflow: hidden; margin-bottom: var(--qc-sp-2); }
.qc-counter-progress-bar { height: 100%; background: var(--qc-primary); border-radius: 999px; transition: width .3s; }
.qc-counter-warning { font-size: var(--qc-text-xs); color: var(--qc-error); }
.qc-counter-warning a { color: var(--qc-error); text-decoration: underline; }

/* Body */
.qc-widget-body { padding: var(--qc-sp-8); background: var(--qc-white); }

/* Drop zone */
.qc-drop-zone {
    border: 2px dashed var(--qc-gray-300);
    background: var(--qc-gray-50);
    border-radius: var(--qc-radius-lg);
    padding: var(--qc-sp-10) var(--qc-sp-6);
    text-align: center;
    cursor: pointer;
    transition: border-color .2s, background .2s;
}
.qc-drop-zone:hover, .qc-drop-zone.qc-drag-over {
    border-color: var(--qc-primary);
    background: var(--qc-primary-light);
}
.qc-drop-title { font-family: var(--qc-font-heading); font-weight: 600; font-size: var(--qc-text-lg); color: var(--qc-gray-800); margin-bottom: var(--qc-sp-2); }
.qc-drop-sub   { font-size: var(--qc-text-sm); color: var(--qc-gray-500); }

/* Queue items */
.qc-queue-item {
    display: flex;
    align-items: center;
    gap: var(--qc-sp-3);
    padding: var(--qc-sp-3) var(--qc-sp-4);
    background: var(--qc-gray-50);
    border-radius: var(--qc-radius);
    margin-bottom: var(--qc-sp-2);
}
.qc-queue-name { flex: 1; font-size: var(--qc-text-sm); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.qc-queue-size { font-size: var(--qc-text-xs); color: var(--qc-gray-500); white-space: nowrap; }
.qc-queue-remove {
    font-size: var(--qc-text-xs);
    color: var(--qc-gray-400);
    cursor: pointer;
    padding: .2rem .4rem;
    border-radius: var(--qc-radius-sm);
    transition: color .2s;
}
.qc-queue-remove:hover { color: var(--qc-error); }

/* Form sections */
.qc-form-section { margin-bottom: var(--qc-sp-6); }
.qc-label { display: block; font-size: var(--qc-text-sm); font-weight: 500; color: var(--qc-gray-700); margin-bottom: var(--qc-sp-3); }
.qc-file-input {
    width: 100%;
    padding: .625rem .875rem;
    border: 1px solid var(--qc-gray-300);
    border-radius: var(--qc-radius);
    font-size: var(--qc-text-sm);
    background: var(--qc-white);
    cursor: pointer;
}
.qc-file-input:focus { outline: none; border-color: var(--qc-primary); }
.qc-help-text { font-size: var(--qc-text-xs); color: var(--qc-gray-500); margin-top: var(--qc-sp-2); }

/* Format grid */
.qc-format-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--qc-sp-2);
}
.qc-format-radio { display: none; }
.qc-format-radio input { position: absolute; opacity: 0; width: 0; height: 0; }
.qc-format-radio input:checked ~ .qc-format-name { display: none; }

/* CSS-only radio card */
.qc-format-radio {
    display: block;
    cursor: pointer;
}
.qc-format-radio label {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--qc-sp-3) var(--qc-sp-2);
    border: 2px solid var(--qc-gray-200);
    border-radius: var(--qc-radius);
    text-align: center;
    cursor: pointer;
    transition: border-color .15s, background .15s;
}
.qc-format-radio input:checked + label,
.qc-format-radio label:has(input:checked) {
    border-color: var(--qc-primary-dark);
    background: var(--qc-primary);
}
.qc-format-radio input:checked + label .qc-format-name,
.qc-format-radio label:has(input:checked) .qc-format-name { color: var(--qc-dark); }
.qc-format-radio input:checked + label .qc-format-desc,
.qc-format-radio label:has(input:checked) .qc-format-desc { color: var(--qc-dark); }
.qc-format-radio label:hover { border-color: var(--qc-dark); }
.qc-format-name { font-family: var(--qc-font-heading); font-weight: 700; font-size: var(--qc-text-sm); color: var(--qc-gray-800); }
.qc-format-desc { font-size: var(--qc-text-xs); color: var(--qc-gray-500); margin-top: 2px; }

/* JS format buttons */
.qc-js-format-btn {
    padding: var(--qc-sp-2) var(--qc-sp-4);
    border: 2px solid var(--qc-gray-200);
    border-radius: var(--qc-radius);
    background: var(--qc-white);
    font-family: var(--qc-font-heading);
    font-weight: 600;
    font-size: var(--qc-text-sm);
    color: var(--qc-gray-700);
    cursor: pointer;
    transition: all .15s;
}
.qc-js-format-btn:hover { border-color: var(--qc-dark); }
.qc-js-format-btn.qc-format-active { border-color: var(--qc-primary-dark); background: var(--qc-primary); color: var(--qc-dark); font-weight: 700; }

/* Quality row */
.qc-quality-row { display: flex; align-items: center; gap: var(--qc-sp-4); }
.qc-quality-row input[type=range] { flex: 1; accent-color: var(--qc-primary); }
.qc-js-quality-val { font-weight: 700; min-width: 30px; text-align: right; }
.qc-input-number {
    width: 100%;
    max-width: 100px;
    padding: .5rem .75rem;
    border: 1px solid var(--qc-gray-300);
    border-radius: var(--qc-radius);
    font-size: var(--qc-text-sm);
}

/* Submit */
.qc-submit-wrapper { margin-top: var(--qc-sp-2); }

/* Progress */
.qc-spinner {
    width: 40px;
    height: 40px;
    border: 3px solid var(--qc-gray-200);
    border-top-color: var(--qc-primary);
    border-radius: 50%;
    animation: qc-spin .8s linear infinite;
    margin: 0 auto var(--qc-sp-4);
}
@keyframes qc-spin { to { transform: rotate(360deg); } }
.qc-progress-track { background: var(--qc-gray-100); border-radius: 999px; height: 8px; overflow: hidden; margin-top: var(--qc-sp-4); }
.qc-js-progress-bar { height: 100%; background: var(--qc-primary); border-radius: 999px; width: 0; transition: width .3s; }

/* Result state */
.qc-result { text-align: center; padding: var(--qc-sp-4) 0; }
.qc-result-icon {
    width: 56px; height: 56px;
    background: var(--qc-success-light);
    color: var(--qc-success);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.5rem;
    margin: 0 auto var(--qc-sp-4);
}
.qc-result-title { font-family: var(--qc-font-heading); font-weight: 700; font-size: var(--qc-text-xl); margin-bottom: var(--qc-sp-4); }
.qc-result-stats { display: flex; justify-content: center; gap: var(--qc-sp-8); flex-wrap: wrap; margin-bottom: var(--qc-sp-6); }
.qc-stat-item { text-align: center; }
.qc-stat-label { display: block; font-size: var(--qc-text-xs); color: var(--qc-gray-500); text-transform: uppercase; letter-spacing: .05em; }
.qc-stat-value { display: block; font-family: var(--qc-font-heading); font-size: var(--qc-text-xl); font-weight: 700; color: var(--qc-dark); }
.qc-result-buttons { display: flex; gap: var(--qc-sp-3); justify-content: center; flex-wrap: wrap; }
.qc-expiry-notice { font-size: var(--qc-text-xs); color: var(--qc-gray-400); margin-top: var(--qc-sp-4); }

/* Error state */
.qc-error-state { text-align: center; padding: var(--qc-sp-4) 0; }
.qc-error-icon-circle {
    width: 56px; height: 56px;
    background: var(--qc-error-light);
    color: var(--qc-error);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.5rem;
    margin: 0 auto var(--qc-sp-4);
}
.qc-error-heading { font-family: var(--qc-font-heading); font-weight: 700; font-size: var(--qc-text-xl); margin-bottom: var(--qc-sp-3); }
.qc-error-detail { color: var(--qc-gray-600); font-size: var(--qc-text-sm); margin-bottom: var(--qc-sp-6); }

/* Limit reached */
.qc-limit-reached { text-align: center; padding: var(--qc-sp-4) 0; }
.qc-limit-icon { font-size: 2rem; color: var(--qc-warning); margin-bottom: var(--qc-sp-4); }
.qc-limit-heading { font-family: var(--qc-font-heading); font-weight: 700; font-size: var(--qc-text-xl); margin-bottom: var(--qc-sp-3); }
.qc-limit-text { color: var(--qc-gray-600); font-size: var(--qc-text-sm); margin-bottom: var(--qc-sp-5); }
.qc-limit-reset { font-size: var(--qc-text-xs); color: var(--qc-gray-400); margin-top: var(--qc-sp-3); }

/* Results list (JS) */
.qc-result-item {
    display: flex; align-items: center; justify-content: space-between; gap: var(--qc-sp-4);
    padding: var(--qc-sp-3) var(--qc-sp-4);
    border-radius: var(--qc-radius);
    margin-bottom: var(--qc-sp-2);
}
.qc-result-success { background: var(--qc-success-light); }
.qc-result-fail    { background: var(--qc-error-light); }
.qc-result-info { flex: 1; overflow: hidden; }
.qc-result-name { display: block; font-weight: 500; font-size: var(--qc-text-sm); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.qc-result-meta { display: block; font-size: var(--qc-text-xs); color: var(--qc-gray-600); }
.qc-result-error-text { color: var(--qc-error); }
.qc-btn-sm { font-size: var(--qc-text-xs); padding: .4rem .75rem; }

/* Privacy footer */
.qc-privacy-footer {
    padding: var(--qc-sp-4) var(--qc-sp-6);
    background: var(--qc-gray-50);
    border-top: 1px solid var(--qc-gray-100);
    text-align: center;
    font-size: var(--qc-text-xs);
    color: var(--qc-gray-500);
}
.qc-privacy-footer a { color: var(--qc-gray-600); text-decoration: underline; }

/* Upgrade card */
.qc-upgrade-card { padding: var(--qc-sp-6); background: var(--qc-dark); border-top: 1px solid rgb(255 255 255 / .1); }
.qc-upgrade-card-inner { max-width: 400px; margin-inline: auto; }
.qc-upgrade-title { font-family: var(--qc-font-heading); font-weight: 700; color: var(--qc-white); font-size: var(--qc-text-lg); margin-bottom: var(--qc-sp-2); }
.qc-upgrade-price { font-family: var(--qc-font-heading); font-size: var(--qc-text-3xl); font-weight: 700; color: var(--qc-primary); margin-bottom: var(--qc-sp-5); }
.qc-upgrade-period { font-size: var(--qc-text-base); font-weight: 400; color: #a8b8cc; }
.qc-upgrade-features { display: flex; flex-direction: column; gap: var(--qc-sp-2); margin-bottom: var(--qc-sp-6); }
.qc-upgrade-features li { display: flex; align-items: center; gap: var(--qc-sp-3); font-size: var(--qc-text-sm); color: #a8b8cc; }
.qc-upgrade-features li::before { content: '\2713'; color: var(--qc-primary); font-weight: 700; }

/* Email magic link form */
.qc-email-link-form {
    margin-top: var(--qc-sp-6);
    padding: var(--qc-sp-5) var(--qc-sp-5);
    border-top: 1px solid var(--qc-gray-100);
    border-radius: var(--qc-radius-md);
    background: var(--qc-gray-50);
}
.qc-email-link-label {
    font-size: var(--qc-text-sm);
    font-weight: 600;
    color: var(--qc-dark);
    margin: 0 0 var(--qc-sp-3);
}
.qc-email-link-row {
    display: flex;
    gap: var(--qc-sp-2);
}
.qc-email-link-input {
    flex: 1;
    padding: 10px 14px;
    border: 1px solid var(--qc-gray-300);
    border-radius: var(--qc-radius-sm);
    font-size: var(--qc-text-sm);
    font-family: var(--qc-font-body);
    color: var(--qc-dark);
    background: var(--qc-white);
    outline: none;
    transition: border-color .15s;
}
.qc-email-link-input:focus { border-color: var(--qc-primary); }
.qc-email-link-note {
    margin: var(--qc-sp-2) 0 0;
    font-size: var(--qc-text-xs);
    color: var(--qc-gray-500);
}
.qc-email-sent {
    font-size: var(--qc-text-sm);
    color: #27ae60;
    font-weight: 600;
    margin: 0;
    padding: var(--qc-sp-2) 0;
}
/* Session expired inline message */
.qc-session-expired-msg {
    text-align: center;
    padding: var(--qc-sp-8) var(--qc-sp-4);
}
.qc-session-expired-msg p {
    color: var(--qc-gray-600);
    margin-bottom: var(--qc-sp-4);
    font-size: var(--qc-text-sm);
}
