html[data-theme="dark"] {
--bg-primary: var(--color-gray-950);
--bg-secondary: var(--color-gray-900);
--bg-tertiary: var(--color-gray-800);
--bg-elevated: var(--color-gray-800);
--text-primary: var(--color-gray-50);
--text-secondary: var(--color-gray-400);
--text-tertiary: var(--color-gray-500);
--text-inverse: var(--color-gray-900);
--accent: var(--color-accent-400);
--accent-hover: var(--color-accent-300);
--accent-light: var(--color-accent-900);
--accent-bg: rgba(139, 92, 246, 0.1);
--accent-text: var(--color-accent-300);
--border: var(--color-gray-700);
--border-light: var(--color-gray-800);
--shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
--shadow-md: 0 4px 6px rgba(0, 0, 0, 0.25);
--shadow-lg: 0 10px 25px rgba(0, 0, 0, 0.3);
--shadow-accent: 0 4px 20px rgba(139, 92, 246, 0.3);
--success-bg: rgba(16, 185, 129, 0.1);
--warning-bg: rgba(245, 158, 11, 0.1);
--error-bg: rgba(239, 68, 68, 0.1);
--info-bg: rgba(59, 130, 246, 0.1);
}
[data-theme="light"], :root {
--bg-primary: var(--color-white);
--bg-secondary: var(--color-gray-50);
--bg-tertiary: var(--color-gray-100);
--bg-elevated: var(--color-white);
--text-primary: var(--color-gray-900);
--text-secondary: var(--color-gray-500);
--text-tertiary: var(--color-gray-500);
--text-inverse: var(--color-white);
--accent: var(--color-accent-600);
--accent-hover: var(--color-accent-700);
--accent-light: var(--color-accent-100);
--accent-bg: var(--color-accent-50);
--accent-text: var(--color-accent-700);
--accent-text-on-white: var(--color-accent-600);
--border: var(--color-gray-200);
--border-light: var(--color-gray-100);
--shadow-accent: 0 4px 20px rgba(124, 58, 237, 0.2);
--success: var(--color-success-600);
--success-bg: #ECFDF5;
--warning: var(--color-warning-600);
--warning-bg: #FFFBEB;
--error: var(--color-error-600);
--error-bg: #FEF2F2;
--info: var(--color-info-600);
--info-bg: #EFF6FF;
}
.qt-skip-link {
position: fixed;
top: -100px;
left: 50%;
transform: translateX(-50%);
z-index: 100000;
background: var(--accent, #8B5CF6);
color: #fff;
padding: 12px 24px;
border-radius: 0 0 var(--radius-md, 10px) var(--radius-md, 10px);
font-size: var(--font-size-sm, 14px);
font-weight: 600;
text-decoration: none;
transition: top 0.2s ease;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}
.qt-skip-link:focus {
top: 0;
outline: none;
}
.qt-a11y-focus *:focus-visible {
outline: 3px solid var(--accent, #8B5CF6) !important;
outline-offset: 2px !important;
border-radius: 4px;
}
.qt-a11y-focus button:focus-visible,
.qt-a11y-focus a:focus-visible,
.qt-a11y-focus input:focus-visible,
.qt-a11y-focus select:focus-visible,
.qt-a11y-focus textarea:focus-visible {
outline: 3px solid var(--accent, #8B5CF6) !important;
outline-offset: 2px !important;
box-shadow: 0 0 0 6px rgba(139, 92, 246, 0.15) !important;
}
.qt-high-contrast {
--text-primary: #000000 !important;
--text-secondary: #1a1a1a !important;
--text-tertiary: #333333 !important;
--bg-primary: #ffffff !important;
--bg-secondary: #f5f5f5 !important;
--bg-tertiary: #e8e8e8 !important;
--border: #000000 !important;
--border-light: #666666 !important;
--accent: #5B21B6 !important;
--accent-hover: #4C1D95 !important;
}
[data-theme="dark"].qt-high-contrast {
--text-primary: #ffffff !important;
--text-secondary: #e0e0e0 !important;
--text-tertiary: #cccccc !important;
--bg-primary: #000000 !important;
--bg-secondary: #0a0a0a !important;
--bg-tertiary: #1a1a1a !important;
--border: #ffffff !important;
--border-light: #999999 !important;
--accent: #A78BFA !important;
}
.qt-high-contrast .card,
.qt-high-contrast .tool-card,
.qt-high-contrast .tool-form,
.qt-high-contrast .tool-result {
border: 2px solid var(--border) !important;
}
.qt-high-contrast .btn {
border: 2px solid currentColor !important;
font-weight: 700 !important;
}
.qt-high-contrast a {
text-decoration: underline !important;
}
.qt-a11y-toggle {
position: fixed;
bottom: 80px;
right: 16px;
z-index: 9990;
width: 44px;
height: 44px;
border-radius: 50%;
border: 2px solid var(--border, #e5e7eb);
background: var(--bg-elevated, #fff);
color: var(--text-primary, #111);
font-size: 20px;
cursor: pointer;
display: flex;
align-items: center;
justify-content: center;
box-shadow: 0 2px 10px rgba(0, 0, 0, 0.15);
transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
line-height: 1;
}
.qt-a11y-toggle:hover {
transform: scale(1.1);
box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
}
.qt-a11y-toggle--active {
background: var(--accent, #8B5CF6);
color: #fff;
border-color: var(--accent, #8B5CF6);
}
.qt-a11y-panel {
position: fixed;
bottom: 130px;
right: 16px;
z-index: 9991;
background: var(--bg-elevated, #fff);
border: 1px solid var(--border, #e5e7eb);
border-radius: var(--radius-lg, 14px);
padding: 16px;
box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15);
width: 240px;
display: none;
animation: qtA11yPanelIn 0.2s ease;
}
.qt-a11y-panel.open {
display: block;
}
@keyframes qtA11yPanelIn {
from { opacity: 0; transform: translateY(8px); }
to { opacity: 1; transform: translateY(0); }
}
.qt-a11y-panel__title {
font-size: var(--font-size-sm, 14px);
font-weight: 700;
color: var(--text-primary, #111);
margin-bottom: 12px;
display: flex;
align-items: center;
gap: 6px;
}
.qt-a11y-option {
display: flex;
align-items: center;
justify-content: space-between;
padding: 8px 0;
border-bottom: 1px solid var(--border-light, #f3f4f6);
font-size: var(--font-size-sm, 14px);
color: var(--text-primary, #111);
}
.qt-a11y-option:last-child {
border-bottom: none;
}
.qt-a11y-option__label {
display: flex;
align-items: center;
gap: 8px;
}
.qt-toggle {
position: relative;
width: 40px;
height: 22px;
flex-shrink: 0;
}
.qt-toggle input {
opacity: 0;
width: 0;
height: 0;
position: absolute;
}
.qt-toggle__track {
position: absolute;
inset: 0;
background: var(--bg-tertiary, #e5e7eb);
border-radius: 11px;
cursor: pointer;
transition: background 0.2s;
}
.qt-toggle__track::after {
content: '';
position: absolute;
top: 2px;
left: 2px;
width: 18px;
height: 18px;
background: #fff;
border-radius: 50%;
transition: transform 0.2s;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
}
.qt-toggle input:checked + .qt-toggle__track {
background: var(--accent, #8B5CF6);
}
.qt-toggle input:checked + .qt-toggle__track::after {
transform: translateX(18px);
}
.qt-toggle input:focus-visible + .qt-toggle__track {
outline: 3px solid var(--accent, #8B5CF6);
outline-offset: 2px;
}
@media (prefers-reduced-motion: reduce) {
.qt-a11y-reduced-motion *,
.qt-a11y-reduced-motion *::before,
.qt-a11y-reduced-motion *::after {
animation-duration: 0.01ms !important;
animation-iteration-count: 1 !important;
transition-duration: 0.01ms !important;
}
}
.qt-a11y-reduced-motion *,
.qt-a11y-reduced-motion *::before,
.qt-a11y-reduced-motion *::after {
animation-duration: 0.01ms !important;
animation-iteration-count: 1 !important;
transition-duration: 0.01ms !important;
}
.qt-a11y-large-text {
font-size: 118% !important;
}
.qt-a11y-large-text .tool-form,
.qt-a11y-large-text .tool-result {
font-size: 110% !important;
}
.sr-only {
position: absolute !important;
width: 1px !important;
height: 1px !important;
padding: 0 !important;
margin: -1px !important;
overflow: hidden !important;
clip: rect(0, 0, 0, 0) !important;
white-space: nowrap !important;
border: 0 !important;
}
[dir="rtl"] .qt-a11y-toggle {
left: 16px;
right: auto;
}
[dir="rtl"] .qt-a11y-panel {
left: 16px;
right: auto;
}
[dir="rtl"] .qt-skip-link {
left: 50%;
right: auto;
}
.cp-overlay {
position: fixed;
inset: 0;
z-index: 9999;
background: rgba(0, 0, 0, 0.5);
backdrop-filter: blur(4px);
-webkit-backdrop-filter: blur(4px);
display: flex;
align-items: flex-start;
justify-content: center;
padding-top: 15vh;
opacity: 0;
pointer-events: none;
visibility: hidden;
transition: opacity 150ms ease;
}
.cp-overlay.cp-open {
opacity: 1;
pointer-events: auto;
visibility: visible;
}
.cp-modal {
width: 90%;
max-width: 640px;
max-height: 70vh;
background: var(--bg-primary, #fff);
border: 1px solid var(--border, #e5e7eb);
border-radius: var(--radius-xl, 20px);
box-shadow: var(--shadow-xl, 0 20px 50px -5px rgba(0,0,0,0.1));
display: flex;
flex-direction: column;
overflow: hidden;
transform: scale(0.96) translateY(-8px);
transition: transform 150ms ease;
}
.cp-overlay.cp-open .cp-modal {
transform: scale(1) translateY(0);
}
.cp-search {
display: flex;
align-items: center;
gap: 12px;
padding: 16px 20px;
border-bottom: 1px solid var(--border-light, #f3f4f6);
}
.cp-search__icon {
flex-shrink: 0;
width: 20px;
height: 20px;
color: var(--text-tertiary, #9ca3af);
}
.cp-search__input {
flex: 1;
border: none;
outline: none;
background: transparent;
font-size: 16px;
font-family: var(--font-sans, 'Inter', sans-serif);
color: var(--text-primary, #111827);
caret-color: var(--accent, #7c3aed);
}
.cp-search__input::placeholder {
color: var(--text-tertiary, #9ca3af);
}
.cp-search__kbd {
flex-shrink: 0;
display: inline-flex;
align-items: center;
gap: 4px;
font-size: 11px;
font-family: var(--font-sans, 'Inter', sans-serif);
color: var(--text-tertiary, #9ca3af);
background: var(--bg-tertiary, #f3f4f6);
border: 1px solid var(--border, #e5e7eb);
border-radius: 6px;
padding: 2px 6px;
line-height: 1.4;
}
.cp-results {
flex: 1;
overflow-y: auto;
padding: 8px;
overscroll-behavior: contain;
}
.cp-results::-webkit-scrollbar { width: 6px; }
.cp-results::-webkit-scrollbar-thumb {
background: var(--border, #e5e7eb);
border-radius: 3px;
}
.cp-section {
padding: 6px 12px 4px;
font-size: 11px;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.05em;
color: var(--text-tertiary, #9ca3af);
}
.cp-item {
display: flex;
align-items: center;
gap: 12px;
padding: 10px 12px;
border-radius: var(--radius-md, 10px);
cursor: pointer;
transition: background 80ms ease;
text-decoration: none;
color: inherit;
}
.cp-item:hover,
.cp-item.cp-active {
background: var(--accent-bg, rgba(139,92,246,0.06));
}
.cp-item.cp-active {
background: var(--accent-bg, rgba(139,92,246,0.1));
}
.cp-item__icon {
flex-shrink: 0;
width: 36px;
height: 36px;
display: flex;
align-items: center;
justify-content: center;
font-size: 18px;
border-radius: var(--radius-sm, 6px);
background: var(--bg-tertiary, #f3f4f6);
}
.cp-item__text {
flex: 1;
min-width: 0;
}
.cp-item__name {
font-size: 14px;
font-weight: 500;
color: var(--text-primary, #111827);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.cp-item__name mark {
background: none;
color: var(--accent, #7c3aed);
font-weight: 700;
}
.cp-item__desc {
font-size: 12px;
color: var(--text-secondary, #6b7280);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.cp-item__badge {
flex-shrink: 0;
font-size: 10px;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.04em;
padding: 2px 8px;
border-radius: var(--radius-full, 9999px);
color: #fff;
}
.cp-item__badge--social   { background: #8B5CF6; }
.cp-item__badge--ai       { background: #06B6D4; }
.cp-item__badge--calculator { background: #EF4444; }
.cp-item__badge--generator { background: #F59E0B; color: #111; }
.cp-item__badge--utility  { background: #3B82F6; }
.cp-item__badge--page     { background: var(--text-tertiary, #9ca3af); }
.cp-item__badge--action   { background: var(--accent, #7c3aed); }
.cp-item__enter {
flex-shrink: 0;
font-size: 11px;
color: var(--text-tertiary, #9ca3af);
opacity: 0;
transition: opacity 80ms ease;
}
.cp-item.cp-active .cp-item__enter {
opacity: 1;
}
.cp-empty {
padding: 32px 16px;
text-align: center;
color: var(--text-tertiary, #9ca3af);
font-size: 14px;
}
.cp-empty__icon {
font-size: 32px;
margin-bottom: 8px;
opacity: 0.5;
}
.cp-footer {
display: flex;
align-items: center;
gap: 16px;
padding: 10px 20px;
border-top: 1px solid var(--border-light, #f3f4f6);
font-size: 11px;
color: var(--text-tertiary, #9ca3af);
}
.cp-footer__hint {
display: flex;
align-items: center;
gap: 4px;
}
.cp-footer kbd {
display: inline-flex;
align-items: center;
justify-content: center;
min-width: 20px;
height: 20px;
padding: 0 4px;
font-size: 10px;
font-family: var(--font-sans, 'Inter', sans-serif);
background: var(--bg-tertiary, #f3f4f6);
border: 1px solid var(--border, #e5e7eb);
border-radius: 4px;
}
.cp-trigger-btn {
display: inline-flex;
align-items: center;
justify-content: center;
width: 36px;
height: 36px;
border: none;
background: transparent;
color: var(--text-secondary, #6b7280);
border-radius: var(--radius-sm, 6px);
cursor: pointer;
transition: background 150ms ease, color 150ms ease;
padding: 0;
}
.cp-trigger-btn:hover {
background: var(--bg-tertiary, #f3f4f6);
color: var(--text-primary, #111827);
}
.cp-trigger-btn svg {
width: 18px;
height: 18px;
}
.cp-item__remove {
flex-shrink: 0;
width: 24px;
height: 24px;
display: flex;
align-items: center;
justify-content: center;
border: none;
background: transparent;
color: var(--text-tertiary, #9ca3af);
border-radius: var(--radius-sm, 6px);
cursor: pointer;
font-size: 14px;
opacity: 0;
transition: opacity 80ms ease;
}
.cp-item:hover .cp-item__remove {
opacity: 1;
}
.cp-item__remove:hover {
background: var(--error-bg, #fef2f2);
color: var(--error, #dc2626);
}
[dir="rtl"] .cp-search { flex-direction: row-reverse; }
[dir="rtl"] .cp-item { flex-direction: row-reverse; }
[dir="rtl"] .cp-item__text { text-align: right; }
[dir="rtl"] .cp-footer { flex-direction: row-reverse; }
@media (max-width: 640px) {
.cp-overlay { padding-top: 8vh; }
.cp-modal { width: 95%; max-height: 80vh; }
.cp-search__kbd { display: none; }
.cp-footer { display: none; }
.cp-item__enter { display: none; }
}
.qt-deeplink-prefilled {
display: flex;
align-items: center;
gap: var(--space-2, 8px);
padding: var(--space-2, 8px) var(--space-4, 16px);
margin-bottom: var(--space-4, 16px);
background: var(--accent-bg, rgba(139, 92, 246, 0.08));
border: 1px solid var(--accent-light, #EDE9FE);
border-radius: var(--radius-md, 10px);
color: var(--accent-text, #7C3AED);
font-size: var(--font-size-sm, 0.875rem);
font-weight: 500;
animation: qt-dl-slide-in 0.3s ease-out;
transition: opacity 0.5s ease;
}
.qt-deeplink-prefilled--fade {
opacity: 0;
}
.qt-deeplink-prefilled__icon {
font-size: 1.1em;
flex-shrink: 0;
}
@keyframes qt-dl-slide-in {
from { opacity: 0; transform: translateY(-8px); }
to   { opacity: 1; transform: translateY(0); }
}
.qt-deeplink-toast {
position: fixed;
top: 20px;
left: 50%;
transform: translateX(-50%) translateY(-20px);
padding: 10px 24px;
background: var(--bg-elevated, #fff);
color: var(--text-primary, #111);
border: 1px solid var(--border, #E5E7EB);
border-radius: var(--radius-lg, 14px);
box-shadow: var(--shadow-lg, 0 10px 25px rgba(0,0,0,0.1));
font-size: var(--font-size-sm, 0.875rem);
font-weight: 500;
z-index: 10000;
opacity: 0;
transition: opacity 0.3s ease, transform 0.3s ease;
pointer-events: none;
max-width: 90vw;
text-align: center;
}
.qt-deeplink-toast--visible {
opacity: 1;
transform: translateX(-50%) translateY(0);
}
[data-deeplink-btn] {
position: relative;
white-space: nowrap;
}
[data-deeplink-btn]:hover {
color: var(--accent, #8B5CF6);
}
.qt-deeplink-display {
display: flex;
align-items: center;
gap: var(--space-2, 8px);
margin-top: var(--space-3, 12px);
padding: var(--space-2, 8px);
background: var(--bg-secondary, #F9FAFB);
border: 1px solid var(--border-light, #F3F4F6);
border-radius: var(--radius-md, 10px);
}
.qt-deeplink-display__url {
flex: 1;
font-family: var(--font-mono, 'JetBrains Mono', monospace);
font-size: var(--font-size-xs, 0.75rem);
color: var(--text-secondary, #6B7280);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
padding: var(--space-1, 4px) var(--space-2, 8px);
background: transparent;
border: none;
width: 100%;
cursor: text;
}
.qt-deeplink-display__copy {
flex-shrink: 0;
padding: var(--space-1, 4px) var(--space-3, 12px);
background: var(--accent, #8B5CF6);
color: #fff;
border: none;
border-radius: var(--radius-sm, 6px);
font-size: var(--font-size-xs, 0.75rem);
font-weight: 600;
cursor: pointer;
transition: background var(--transition-fast, 150ms ease);
}
.qt-deeplink-display__copy:hover {
background: var(--accent-hover, #7C3AED);
}
[dir="rtl"] .qt-deeplink-prefilled {
flex-direction: row-reverse;
}
[dir="rtl"] .qt-deeplink-display {
flex-direction: row-reverse;
}
@media (max-width: 640px) {
.qt-deeplink-prefilled {
font-size: var(--font-size-xs, 0.75rem);
padding: var(--space-2, 8px) var(--space-3, 12px);
}
.qt-deeplink-toast {
top: 10px;
padding: 8px 16px;
font-size: var(--font-size-xs, 0.75rem);
}
.qt-deeplink-display {
flex-direction: column;
}
.qt-deeplink-display__copy {
width: 100%;
text-align: center;
}
}
[data-theme="dark"] .qt-deeplink-toast {
background: var(--bg-elevated, #1F2937);
border-color: var(--border, #374151);
}
.sr-only {
position: absolute;
width: 1px;
height: 1px;
overflow: hidden;
clip: rect(0, 0, 0, 0);
white-space: nowrap;
border: 0;
}
.vc-topbar-mic {
position: relative;
display: flex;
align-items: center;
justify-content: center;
width: 36px;
height: 36px;
border: none;
background: transparent;
color: var(--text-secondary, #6B7280);
cursor: pointer;
border-radius: var(--radius-full, 9999px);
transition: color 0.2s, background 0.2s, transform 0.15s;
-webkit-tap-highlight-color: transparent;
flex-shrink: 0;
padding: 0;
}
.vc-topbar-mic:hover {
color: var(--accent, #8B5CF6);
background: var(--accent-bg, rgba(139,92,246,0.08));
}
.vc-topbar-mic:active { transform: scale(0.92); }
.vc-topbar-mic:focus-visible {
outline: 2px solid var(--accent, #8B5CF6);
outline-offset: 2px;
}
.vc-topbar-mic__svg { width: 24px; height: 24px; }
.vc-topbar-mic--listening {
color: var(--accent, #8B5CF6);
animation: vc-pulse-ring 1.6s ease-in-out infinite;
}
.vc-topbar-mic--dictating {
color: var(--success, #10B981);
animation: vc-pulse-ring 1.2s ease-in-out infinite;
}
.vc-topbar-mic--confirm {
color: var(--warning, #F59E0B);
animation: vc-blink 0.6s ease-in-out infinite;
}
.vc-mic--active {
color: var(--accent, #8B5CF6) !important;
background: var(--accent-bg, rgba(139,92,246,0.12)) !important;
}
.vc-mic--active::after {
content: '';
position: absolute;
top: 2px;
right: 2px;
width: 7px;
height: 7px;
background: var(--accent, #8B5CF6);
border-radius: 50%;
border: 1.5px solid var(--bg-primary, #fff);
}
.vc-mic--wake::after {
background: var(--success, #10B981) !important;
}
.vc-progress-ring {
transition: stroke-dashoffset 0.1s linear;
}
.vc-topbar-mic--listening .vc-progress-ring {
stroke: var(--accent, #8B5CF6);
}
.vc-topbar-mic--dictating .vc-progress-ring {
stroke: var(--success, #10B981);
}
.vc-topbar-mic--floating {
position: fixed;
bottom: 80px;
right: 16px;
z-index: 9998;
width: 44px;
height: 44px;
background: var(--bg-elevated, #fff);
box-shadow: var(--shadow-lg, 0 10px 25px rgba(0,0,0,0.12));
}
@keyframes vc-pulse-ring {
0%, 100% { box-shadow: 0 0 0 0 rgba(139,92,246,0.3); }
50%      { box-shadow: 0 0 0 6px rgba(139,92,246,0); }
}
@keyframes vc-blink {
0%, 100% { opacity: 1; }
50%      { opacity: 0.4; }
}
.vc-bar {
position: fixed;
bottom: 16px;
left: 50%;
transform: translateX(-50%) translateY(120px);
z-index: 10000;
display: flex;
align-items: center;
gap: 8px;
min-width: 280px;
max-width: min(520px, calc(100vw - 32px));
padding: 10px 16px;
background: var(--bg-elevated, #fff);
border: 1px solid var(--border, rgba(0,0,0,0.08));
border-radius: 50px;
box-shadow: 0 8px 32px rgba(0,0,0,0.12), 0 2px 8px rgba(0,0,0,0.06);
opacity: 0;
pointer-events: none;
transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1),
opacity 0.25s ease;
backdrop-filter: blur(16px);
-webkit-backdrop-filter: blur(16px);
}
[data-theme="dark"] .vc-bar {
background: rgba(31,41,55,0.92);
border-color: rgba(255,255,255,0.08);
box-shadow: 0 8px 32px rgba(0,0,0,0.35);
}
.vc-bar--visible {
transform: translateX(-50%) translateY(0);
opacity: 1;
pointer-events: auto;
}
.has-bottom-nav .vc-bar { bottom: 76px; }
.vc-bar__mic {
flex-shrink: 0;
width: 32px;
height: 32px;
display: flex;
align-items: center;
justify-content: center;
border-radius: 50%;
background: var(--accent, #8B5CF6);
color: #fff;
position: relative;
}
.vc-bar__mic svg { width: 16px; height: 16px; }
.vc-bar__mic--listening::after {
content: '';
position: absolute;
inset: -3px;
border-radius: 50%;
border: 2px solid var(--accent, #8B5CF6);
animation: vc-mic-ripple 1.4s ease-out infinite;
}
@keyframes vc-mic-ripple {
0%   { transform: scale(1); opacity: 0.6; }
100% { transform: scale(1.5); opacity: 0; }
}
.vc-bar__mic--dictating { background: var(--success, #10B981); }
.vc-bar__mic--dictating::after { border-color: var(--success, #10B981); }
.vc-bar__mic--confirm { background: var(--warning, #F59E0B); }
.vc-waveform {
flex-shrink: 0;
width: 80px;
height: 24px;
border-radius: 4px;
opacity: 0.85;
transition: opacity 0.2s;
}
.vc-bar:not(.vc-bar--visible) .vc-waveform { opacity: 0; }
.vc-bar__text {
flex: 1;
min-width: 0;
font-size: 14px;
font-weight: 500;
color: var(--text-primary, #111);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
line-height: 1.3;
}
.vc-bar__text--interim { color: var(--text-tertiary, #9CA3AF); font-style: italic; }
.vc-bar__text--success { color: var(--success, #10B981); }
.vc-bar__text--error   { color: var(--error, #EF4444); }
.vc-bar__text--warning { color: var(--warning, #F59E0B); }
.vc-bar__close {
flex-shrink: 0;
width: 24px;
height: 24px;
display: flex;
align-items: center;
justify-content: center;
border: none;
background: var(--bg-tertiary, #F3F4F6);
color: var(--text-secondary, #6B7280);
border-radius: 50%;
cursor: pointer;
font-size: 14px;
line-height: 1;
padding: 0;
transition: background 0.15s, color 0.15s;
}
.vc-bar__close:hover {
background: var(--error-bg, #FEF2F2);
color: var(--error, #EF4444);
}
.vc-hint-layer {
position: fixed;
inset: 0;
z-index: 9999;
pointer-events: none;
opacity: 0;
transition: opacity 0.3s ease;
}
.vc-hint-layer--active { opacity: 1; }
.vc-hint {
position: absolute;
display: inline-flex;
align-items: center;
gap: 4px;
padding: 3px 10px;
font-size: 11px;
font-weight: 600;
font-family: var(--font-sans, 'Inter', sans-serif);
color: #fff;
background: var(--accent, #8B5CF6);
border-radius: 20px;
white-space: nowrap;
box-shadow: 0 2px 8px rgba(139,92,246,0.35);
transform: translateY(-100%) translateY(-6px);
animation: vc-hint-in 0.3s cubic-bezier(0.34, 1.56, 0.64, 1) both;
letter-spacing: 0.02em;
text-transform: lowercase;
pointer-events: none;
z-index: 10001;
}
.vc-hint::before { content: '🎤'; font-size: 10px; }
.vc-hint--action {
background: var(--success, #10B981);
box-shadow: 0 2px 8px rgba(16,185,129,0.35);
}
.vc-hint--nav {
background: var(--info, #3B82F6);
box-shadow: 0 2px 8px rgba(59,130,246,0.35);
}
.vc-hint--input {
background: var(--warning, #F59E0B);
color: #1a1a1a;
box-shadow: 0 2px 8px rgba(245,158,11,0.35);
}
.vc-hint--input::before { content: '✏️'; }
@keyframes vc-hint-in {
0%   { opacity: 0; transform: translateY(-100%) translateY(-6px) scale(0.7); }
100% { opacity: 1; transform: translateY(-100%) translateY(-6px) scale(1); }
}
.vc-highlighted {
outline: 2px solid var(--accent, #8B5CF6) !important;
outline-offset: 3px;
border-radius: 8px;
transition: outline-color 0.3s;
animation: vc-highlight-pulse 2s ease-in-out infinite;
}
.vc-highlighted--action { outline-color: var(--success, #10B981) !important; }
.vc-highlighted--input  { outline-color: var(--warning, #F59E0B) !important; }
@keyframes vc-highlight-pulse {
0%, 100% { outline-offset: 3px; }
50%      { outline-offset: 5px; }
}
.vc-suggestions {
position: fixed;
bottom: 68px;
left: 50%;
transform: translateX(-50%) translateY(30px);
z-index: 9999;
display: flex;
flex-wrap: wrap;
justify-content: center;
gap: 6px;
max-width: min(560px, calc(100vw - 32px));
opacity: 0;
pointer-events: none;
transition: transform 0.3s ease, opacity 0.25s ease;
}
.has-bottom-nav .vc-suggestions { bottom: 128px; }
.vc-suggestions--visible {
transform: translateX(-50%) translateY(0);
opacity: 1;
pointer-events: auto;
}
.vc-suggestions__chip {
display: inline-flex;
align-items: center;
gap: 4px;
padding: 5px 12px;
font-size: 12px;
font-weight: 500;
font-family: var(--font-sans, 'Inter', sans-serif);
color: var(--text-secondary, #6B7280);
background: var(--bg-elevated, #fff);
border: 1px solid var(--border, #E5E7EB);
border-radius: 20px;
cursor: pointer;
white-space: nowrap;
transition: all 0.15s;
box-shadow: 0 1px 3px rgba(0,0,0,0.06);
-webkit-tap-highlight-color: transparent;
}
.vc-suggestions__chip:hover {
border-color: var(--accent, #8B5CF6);
color: var(--accent, #8B5CF6);
background: var(--accent-bg, rgba(139,92,246,0.06));
}
.vc-suggestions__chip:focus-visible {
outline: 2px solid var(--accent, #8B5CF6);
outline-offset: 1px;
}
[data-theme="dark"] .vc-suggestions__chip {
background: rgba(31,41,55,0.85);
border-color: rgba(255,255,255,0.1);
}
.vc-suggestions__chip::before { content: '"'; opacity: 0.4; }
.vc-suggestions__chip::after  { content: '"'; opacity: 0.4; }
.vc-help {
position: fixed;
bottom: 0;
left: 0;
right: 0;
z-index: 10002;
max-height: 65vh;
overflow-y: auto;
background: var(--bg-primary, #fff);
border-top: 1px solid var(--border, #E5E7EB);
border-radius: 20px 20px 0 0;
box-shadow: 0 -8px 32px rgba(0,0,0,0.1);
transform: translateY(100%);
transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
padding: 0;
}
[data-theme="dark"] .vc-help { background: var(--bg-secondary, #111827); }
.vc-help--visible { transform: translateY(0); }
.vc-help__inner { padding: 20px 20px 28px; }
.vc-help__header {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 16px;
}
.vc-help__header h3 {
font-size: 16px;
font-weight: 700;
color: var(--text-primary, #111);
margin: 0;
}
.vc-help__close {
width: 32px;
height: 32px;
display: flex;
align-items: center;
justify-content: center;
border: none;
background: var(--bg-tertiary, #F3F4F6);
color: var(--text-secondary, #6B7280);
border-radius: 50%;
cursor: pointer;
font-size: 18px;
transition: background 0.15s;
}
.vc-help__close:hover {
background: var(--error-bg, #FEF2F2);
color: var(--error, #EF4444);
}
.vc-help__grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
gap: 16px;
}
.vc-help__section h4 {
font-size: 13px;
font-weight: 600;
color: var(--text-primary, #111);
margin: 0 0 8px;
}
.vc-help__section ul { list-style: none; margin: 0; padding: 0; }
.vc-help__section li {
font-size: 12px;
color: var(--text-secondary, #6B7280);
padding: 3px 0;
line-height: 1.4;
}
.vc-help__section li code,
.vc-help__section li strong {
font-size: 12px;
font-weight: 600;
color: var(--accent, #8B5CF6);
background: var(--accent-bg, rgba(139,92,246,0.08));
padding: 1px 5px;
border-radius: 4px;
}
.vc-help__tip {
margin-top: 14px;
font-size: 11px;
color: var(--text-tertiary, #9CA3AF);
text-align: center;
line-height: 1.6;
}
.vc-help__tip small { opacity: 0.7; }
.vc-help__handle {
display: block;
width: 36px;
height: 4px;
margin: 10px auto 6px;
background: var(--border, #E5E7EB);
border-radius: 2px;
}
.vc-onboarding {
position: fixed;
inset: 0;
z-index: 10003;
display: flex;
align-items: center;
justify-content: center;
opacity: 0;
transition: opacity 0.35s ease;
pointer-events: none;
}
.vc-onboarding--visible {
opacity: 1;
pointer-events: auto;
}
.vc-onboarding__backdrop {
position: absolute;
inset: 0;
background: rgba(0,0,0,0.4);
backdrop-filter: blur(4px);
-webkit-backdrop-filter: blur(4px);
}
.vc-onboarding__card {
position: relative;
z-index: 1;
background: var(--bg-primary, #fff);
border-radius: 20px;
padding: 32px 28px 24px;
max-width: 360px;
width: calc(100vw - 48px);
text-align: center;
box-shadow: 0 20px 60px rgba(0,0,0,0.15);
transform: translateY(20px) scale(0.95);
transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.vc-onboarding--visible .vc-onboarding__card {
transform: translateY(0) scale(1);
}
[data-theme="dark"] .vc-onboarding__card {
background: var(--bg-secondary, #1F2937);
}
.vc-onboarding__icon {
font-size: 48px;
margin-bottom: 12px;
line-height: 1;
}
.vc-onboarding__title {
font-size: 20px;
font-weight: 700;
color: var(--text-primary, #111);
margin: 0 0 8px;
}
.vc-onboarding__text {
font-size: 14px;
color: var(--text-secondary, #6B7280);
line-height: 1.5;
margin: 0 0 16px;
}
.vc-onboarding__text kbd {
display: inline-block;
padding: 2px 6px;
font-size: 11px;
font-family: var(--font-mono, monospace);
background: var(--bg-tertiary, #F3F4F6);
border: 1px solid var(--border, #E5E7EB);
border-radius: 4px;
color: var(--text-primary, #111);
}
.vc-onboarding__features {
display: flex;
flex-wrap: wrap;
gap: 8px;
justify-content: center;
margin-bottom: 20px;
}
.vc-onboarding__features span {
display: inline-block;
padding: 4px 10px;
font-size: 12px;
font-weight: 500;
color: var(--accent-text, #7C3AED);
background: var(--accent-bg, rgba(139,92,246,0.08));
border-radius: 20px;
}
.vc-onboarding__actions {
display: flex;
gap: 10px;
justify-content: center;
}
.vc-onboarding__skip {
padding: 8px 20px;
font-size: 14px;
font-weight: 500;
color: var(--text-secondary, #6B7280);
background: transparent;
border: 1px solid var(--border, #E5E7EB);
border-radius: 50px;
cursor: pointer;
transition: all 0.15s;
}
.vc-onboarding__skip:hover {
background: var(--bg-tertiary, #F3F4F6);
}
.vc-onboarding__try {
padding: 8px 24px;
font-size: 14px;
font-weight: 600;
color: #fff;
background: var(--accent, #8B5CF6);
border: none;
border-radius: 50px;
cursor: pointer;
transition: all 0.15s;
box-shadow: 0 2px 12px rgba(139,92,246,0.3);
}
.vc-onboarding__try:hover {
background: var(--accent-hover, #7C3AED);
transform: translateY(-1px);
box-shadow: 0 4px 16px rgba(139,92,246,0.4);
}
.no-voice .vc-topbar-mic,
.no-voice .vc-bar,
.no-voice .vc-suggestions,
.no-voice .vc-hint-layer,
.no-voice .vc-onboarding {
display: none !important;
}
@media (max-width: 480px) {
.vc-bar {
min-width: 0;
max-width: calc(100vw - 24px);
left: 12px;
right: 12px;
transform: translateX(0) translateY(120px);
bottom: 12px;
}
.vc-bar--visible {
transform: translateX(0) translateY(0);
}
.has-bottom-nav .vc-bar { bottom: 72px; }
.vc-waveform { width: 56px; }
.vc-suggestions {
left: 12px;
right: 12px;
transform: translateX(0) translateY(30px);
bottom: 64px;
}
.has-bottom-nav .vc-suggestions { bottom: 124px; }
.vc-suggestions--visible {
transform: translateX(0) translateY(0);
}
.vc-help__grid { grid-template-columns: 1fr 1fr; }
.vc-onboarding__card { padding: 24px 20px 20px; }
.vc-onboarding__features { gap: 6px; }
.vc-onboarding__features span { font-size: 11px; padding: 3px 8px; }
}
@media (max-width: 360px) {
.vc-help__grid { grid-template-columns: 1fr; }
.vc-waveform { display: none; }
}
[dir="rtl"] .vc-bar { direction: rtl; }
[dir="rtl"] .vc-hint { transform: translateY(-100%) translateY(-6px); }
[dir="rtl"] .vc-mic--active::after { right: auto; left: 2px; }
[dir="rtl"] .vc-onboarding__card { direction: rtl; }
.qt-bg-overlay {
position: fixed;
inset: 0;
background: rgba(0, 0, 0, 0);
z-index: 9998;
pointer-events: none;
transition: background 0.3s ease;
}
.qt-bg-overlay.open {
background: rgba(0, 0, 0, 0.4);
backdrop-filter: blur(2px);
pointer-events: auto;
}
.qt-bg-panel {
position: fixed;
top: 0;
right: 0;
width: min(400px, 94vw);
height: 100vh;
background: var(--bg-elevated, #fff);
border-left: 1px solid var(--border, rgba(0,0,0,0.08));
z-index: 9999;
overflow-y: auto;
transform: translateX(100%);
transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
box-shadow: -10px 0 40px rgba(0, 0, 0, 0.15);
padding: 24px;
}
.qt-bg-panel.open { transform: translateX(0); }
[data-theme="dark"] .qt-bg-panel {
background: rgba(15, 15, 25, 0.97);
backdrop-filter: blur(20px);
border-color: rgba(255, 255, 255, 0.08);
}
.qt-bg-panel__header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 24px;
}
.qt-bg-panel__header h3 {
font-size: 18px;
font-weight: 700;
margin: 0;
letter-spacing: -0.02em;
}
.qt-bg-panel__close {
background: none;
border: none;
color: var(--text-secondary, #6B7280);
cursor: pointer;
font-size: 20px;
padding: 4px;
line-height: 1;
border-radius: 6px;
transition: background 0.2s;
}
.qt-bg-panel__close:hover { background: var(--bg-tertiary, rgba(0,0,0,0.05)); }
.qt-bg-toggle {
display: flex;
background: var(--bg-tertiary, rgba(0,0,0,0.04));
border-radius: 12px;
padding: 4px;
margin-bottom: 20px;
}
.qt-bg-toggle__btn {
flex: 1;
padding: 10px 0;
border-radius: 9px;
border: none;
cursor: pointer;
font-size: 12px;
font-weight: 600;
transition: all 0.2s ease;
background: transparent;
color: var(--text-secondary, #6B7280);
white-space: nowrap;
}
.qt-bg-toggle__btn.active {
background: var(--color-accent-500, #8B5CF6);
color: #fff;
box-shadow: 0 2px 12px rgba(139, 92, 246, 0.3);
}
.qt-bg-tabs {
display: flex;
gap: 0;
margin-bottom: 20px;
border-bottom: 1px solid var(--border-light, rgba(0,0,0,0.06));
}
.qt-bg-tabs__btn {
flex: 1;
padding: 10px 0;
background: none;
border: none;
border-bottom: 2px solid transparent;
color: var(--text-secondary, #6B7280);
cursor: pointer;
font-size: 13px;
font-weight: 600;
transition: all 0.2s ease;
}
.qt-bg-tabs__btn.active {
border-bottom-color: var(--color-accent-500, #8B5CF6);
color: var(--color-accent-500, #8B5CF6);
}
.qt-bg-img-tabs {
display: flex;
gap: 0;
margin-bottom: 16px;
border-bottom: 1px solid var(--border-light, rgba(0,0,0,0.06));
}
.qt-bg-img-tabs__btn {
flex: 1;
padding: 10px 0;
background: none;
border: none;
border-bottom: 2px solid transparent;
color: var(--text-secondary, #6B7280);
cursor: pointer;
font-size: 13px;
font-weight: 600;
transition: all 0.2s ease;
}
.qt-bg-img-tabs__btn.active {
border-bottom-color: var(--color-accent-500, #8B5CF6);
color: var(--color-accent-500, #8B5CF6);
}
.qt-bg-presets {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 10px;
}
.qt-bg-preset {
position: relative;
border: 2px solid var(--border-light, rgba(0,0,0,0.08));
border-radius: 12px;
padding: 28px 14px 14px;
cursor: pointer;
text-align: left;
transition: all 0.2s ease;
overflow: hidden;
}
.qt-bg-preset:hover { transform: scale(1.03); }
.qt-bg-preset.active {
border-color: var(--color-accent-500, #8B5CF6);
box-shadow: 0 0 0 1px var(--color-accent-500, #8B5CF6);
}
.qt-bg-preset__name {
display: block;
color: #f1f1f1;
font-size: 12px;
font-weight: 600;
letter-spacing: 0.02em;
text-shadow: 0 1px 3px rgba(0,0,0,0.5);
}
.qt-bg-preset--light .qt-bg-preset__name { color: #374151; text-shadow: none; }
.qt-bg-preset--light { border-color: rgba(0, 0, 0, 0.1) !important; }
.qt-bg-preset--light.active { border-color: var(--color-accent-500, #8B5CF6) !important; }
.qt-bg-preset__check {
position: absolute;
top: 6px;
right: 8px;
color: var(--color-accent-400, #A78BFA);
font-size: 14px;
font-weight: 700;
}
.qt-bg-label {
display: flex;
justify-content: space-between;
font-size: 11px;
font-weight: 600;
color: var(--text-secondary, #6B7280);
text-transform: uppercase;
letter-spacing: 0.06em;
margin-bottom: 8px;
margin-top: 16px;
}
.qt-bg-label:first-child { margin-top: 0; }
.qt-bg-color-row { display: flex; gap: 12px; align-items: center; }
.qt-bg-color-input {
width: 48px; height: 48px; border: none; border-radius: 10px;
cursor: pointer; background: none; padding: 0; flex-shrink: 0;
}
.qt-bg-color-input::-webkit-color-swatch-wrapper { padding: 2px; }
.qt-bg-color-input::-webkit-color-swatch { border: none; border-radius: 8px; }
.qt-bg-color-input::-moz-color-swatch { border: none; border-radius: 8px; }
.qt-bg-hex-input {
flex: 1; padding: 10px 12px; border-radius: 10px;
border: 1px solid var(--border, rgba(0,0,0,0.1));
background: var(--bg-tertiary, rgba(0,0,0,0.03));
color: var(--text-primary, #111);
font-family: var(--font-mono, monospace); font-size: 13px;
outline: none; transition: border-color 0.2s;
}
.qt-bg-hex-input:focus { border-color: var(--color-accent-500, #8B5CF6); }
.qt-bg-swap {
display: block; margin: 12px auto;
background: rgba(139, 92, 246, 0.1);
border: 1px solid rgba(139, 92, 246, 0.2);
color: var(--color-accent-400, #A78BFA);
padding: 6px 16px; border-radius: 50px; cursor: pointer;
font-size: 12px; font-weight: 600; transition: all 0.2s;
}
.qt-bg-swap:hover { background: rgba(139, 92, 246, 0.2); }
.qt-bg-range { width: 100%; accent-color: var(--color-accent-500, #8B5CF6); margin: 4px 0; }
.qt-bg-angle-presets { display: flex; justify-content: space-between; margin-top: 8px; gap: 4px; }
.qt-bg-angle-btn {
background: var(--bg-tertiary, rgba(0,0,0,0.04));
color: var(--text-secondary, #6B7280);
border: none; border-radius: 6px; padding: 4px 8px;
font-size: 11px; font-weight: 600; cursor: pointer;
font-family: var(--font-mono, monospace); transition: all 0.15s;
}
.qt-bg-angle-btn:hover { background: var(--color-accent-500, #8B5CF6); color: #fff; }
.qt-bg-preview {
height: 48px; border-radius: 12px;
border: 1px solid var(--border-light, rgba(0,0,0,0.06));
transition: background 0.3s ease;
}
.qt-bg-gallery-cats {
display: flex;
gap: 6px;
overflow-x: auto;
padding-bottom: 12px;
margin-bottom: 12px;
scrollbar-width: none;
-ms-overflow-style: none;
}
.qt-bg-gallery-cats::-webkit-scrollbar { display: none; }
.qt-bg-gallery-cat {
flex-shrink: 0;
padding: 6px 14px;
border-radius: 50px;
border: 1px solid var(--border, rgba(0,0,0,0.1));
background: var(--bg-tertiary, rgba(0,0,0,0.03));
color: var(--text-secondary, #6B7280);
font-size: 12px;
font-weight: 600;
cursor: pointer;
transition: all 0.2s;
white-space: nowrap;
}
.qt-bg-gallery-cat:hover {
border-color: var(--color-accent-400, #A78BFA);
color: var(--color-accent-400, #A78BFA);
}
.qt-bg-gallery-cat.active {
background: var(--color-accent-500, #8B5CF6);
color: #fff;
border-color: var(--color-accent-500, #8B5CF6);
box-shadow: 0 2px 8px rgba(139, 92, 246, 0.25);
}
.qt-bg-gallery-grid {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 8px;
margin-bottom: 16px;
}
.qt-bg-gallery-item {
position: relative;
border: 2px solid transparent;
border-radius: 12px;
overflow: hidden;
cursor: pointer;
transition: all 0.2s ease;
background: var(--bg-tertiary, #f3f4f6);
padding: 0;
}
.qt-bg-gallery-item:hover {
transform: scale(1.03);
box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
}
.qt-bg-gallery-item.active {
border-color: var(--color-accent-500, #8B5CF6);
box-shadow: 0 0 0 1px var(--color-accent-500, #8B5CF6), 0 4px 16px rgba(139, 92, 246, 0.25);
}
.qt-bg-gallery-item img {
display: block;
width: 100%;
height: 90px;
object-fit: cover;
transition: transform 0.3s;
}
.qt-bg-gallery-item:hover img { transform: scale(1.08); }
.qt-bg-gallery-item__name {
display: block;
padding: 6px 10px;
font-size: 11px;
font-weight: 600;
color: var(--text-secondary, #6B7280);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.qt-bg-gallery-item__check {
position: absolute;
top: 6px;
right: 6px;
width: 22px;
height: 22px;
background: var(--color-accent-500, #8B5CF6);
color: #fff;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
font-size: 12px;
font-weight: 700;
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}
.qt-bg-gallery-item--fallback {
min-height: 90px;
background: linear-gradient(135deg, var(--color-accent-500, #8B5CF6) 0%, #06B6D4 100%);
}
.qt-bg-gallery-item--fallback .qt-bg-gallery-item__name {
position: absolute;
bottom: 0;
left: 0;
right: 0;
color: #fff;
text-shadow: 0 1px 3px rgba(0,0,0,0.5);
background: linear-gradient(transparent, rgba(0,0,0,0.4));
padding: 20px 10px 6px;
}
.qt-bg-dropzone {
border: 2px dashed var(--border, rgba(139, 92, 246, 0.25));
border-radius: 16px;
padding: 32px 20px;
text-align: center;
transition: all 0.3s ease;
cursor: pointer;
background: rgba(139, 92, 246, 0.03);
}
.qt-bg-dropzone--hidden { display: none; }
.qt-bg-dropzone--active,
.qt-bg-dropzone:hover {
border-color: var(--color-accent-500, #8B5CF6);
background: rgba(139, 92, 246, 0.08);
}
.qt-bg-dropzone__icon { font-size: 36px; margin-bottom: 10px; opacity: 0.8; }
.qt-bg-dropzone__text { font-size: 14px; font-weight: 600; color: var(--text-primary, #111); margin-bottom: 4px; }
.qt-bg-dropzone__or { font-size: 12px; color: var(--text-secondary, #6B7280); margin: 8px 0; }
.qt-bg-dropzone__btn {
display: inline-block;
background: var(--color-accent-500, #8B5CF6);
color: #fff; border: none; border-radius: 50px;
padding: 8px 24px; font-size: 13px; font-weight: 600;
cursor: pointer; transition: all 0.2s;
}
.qt-bg-dropzone__btn:hover { background: var(--color-accent-600, #7C3AED); transform: scale(1.03); }
.qt-bg-dropzone__hint { font-size: 11px; color: var(--text-tertiary, #9CA3AF); margin-top: 10px; }
.qt-bg-img-preview {
position: relative;
border-radius: 14px;
overflow: hidden;
margin-bottom: 16px;
border: 2px solid var(--color-accent-500, #8B5CF6);
box-shadow: 0 4px 20px rgba(139, 92, 246, 0.15);
}
.qt-bg-img-preview img { display: block; width: 100%; height: 120px; object-fit: cover; }
.qt-bg-img-change {
position: absolute; bottom: 8px; right: 8px;
background: rgba(0, 0, 0, 0.7); color: #fff;
border: none; border-radius: 50px; padding: 6px 14px;
font-size: 12px; font-weight: 600; cursor: pointer;
backdrop-filter: blur(4px); transition: all 0.2s;
}
.qt-bg-img-change:hover { background: var(--color-accent-500, #8B5CF6); }
.qt-bg-img-options--hidden { display: none; }
.qt-bg-fit-btns { display: flex; gap: 6px; }
.qt-bg-fit-btn {
flex: 1; padding: 8px 0; border-radius: 8px;
border: 1px solid var(--border, rgba(0,0,0,0.1));
background: var(--bg-tertiary, rgba(0,0,0,0.03));
color: var(--text-secondary, #6B7280);
font-size: 12px; font-weight: 600; cursor: pointer; transition: all 0.2s;
}
.qt-bg-fit-btn.active {
background: var(--color-accent-500, #8B5CF6);
color: #fff; border-color: var(--color-accent-500, #8B5CF6);
box-shadow: 0 2px 8px rgba(139, 92, 246, 0.25);
}
.qt-bg-fit-btn:hover:not(.active) {
border-color: var(--color-accent-400, #A78BFA);
color: var(--color-accent-400, #A78BFA);
}
.qt-bg-tip {
margin-top: 16px;
padding: 10px 14px;
background: rgba(245, 158, 11, 0.1);
border: 1px solid rgba(245, 158, 11, 0.2);
border-radius: 10px;
font-size: 12px;
color: var(--color-warning-500, #F59E0B);
line-height: 1.5;
}
.qt-bg-tip b {
color: var(--color-warning-600, #D97706);
}
.qt-bg-readability-tip {
position: fixed;
bottom: 24px;
left: 50%;
transform: translateX(-50%) translateY(100px);
max-width: min(500px, 90vw);
background: rgba(30, 30, 50, 0.92);
color: #fff;
padding: 12px 20px;
border-radius: 14px;
font-size: 13px;
font-weight: 500;
line-height: 1.5;
backdrop-filter: blur(12px);
border: 1px solid rgba(255, 255, 255, 0.1);
box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
z-index: 9997;
display: flex;
align-items: center;
gap: 12px;
transition: transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.qt-bg-readability-tip.show {
transform: translateX(-50%) translateY(0);
}
.qt-bg-readability-tip b {
color: var(--color-accent-300, #C4B5FD);
}
.qt-bg-readability-tip button {
flex-shrink: 0;
background: rgba(255, 255, 255, 0.15);
border: none;
color: #fff;
width: 28px;
height: 28px;
border-radius: 50%;
cursor: pointer;
font-size: 14px;
display: flex;
align-items: center;
justify-content: center;
transition: background 0.2s;
}
.qt-bg-readability-tip button:hover {
background: rgba(255, 255, 255, 0.25);
}
.qt-bg-reset {
width: 100%; margin-top: 24px; padding: 12px;
background: none;
border: 1px solid var(--border, rgba(0,0,0,0.08));
color: var(--text-secondary, #6B7280);
border-radius: 10px; cursor: pointer;
font-size: 13px; font-weight: 600; transition: all 0.2s;
}
.qt-bg-reset:hover { border-color: var(--color-error-500, #EF4444); color: var(--color-error-500, #EF4444); }
.qt-bg-info {
margin-top: 16px; padding: 12px 14px;
background: rgba(139, 92, 246, 0.06);
border-radius: 10px;
border: 1px solid rgba(139, 92, 246, 0.12);
font-size: 12px;
color: var(--color-accent-400, #A78BFA);
text-align: center;
}
.qt-bg-toast {
position: fixed; top: 20px; left: 50%;
transform: translateX(-50%) translateY(-80px);
background: rgba(139, 92, 246, 0.95);
color: #fff; padding: 10px 24px;
border-radius: 50px; font-size: 14px; font-weight: 600;
backdrop-filter: blur(10px); z-index: 10000;
box-shadow: 0 8px 32px rgba(139, 92, 246, 0.3);
letter-spacing: 0.02em;
transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
pointer-events: none;
}
.qt-bg-toast.show { transform: translateX(-50%) translateY(0); }
.qt-bg-trigger {
display: inline-flex; align-items: center; gap: 6px;
background: rgba(139, 92, 246, 0.08);
border: 1px solid rgba(139, 92, 246, 0.15);
color: var(--color-accent-400, #A78BFA);
padding: 6px 14px; border-radius: 50px; cursor: pointer;
font-size: 13px; font-weight: 600; transition: all 0.2s;
}
.qt-bg-trigger:hover {
background: rgba(139, 92, 246, 0.15);
border-color: rgba(139, 92, 246, 0.3);
}
body.qt-bg-active .card,
body.qt-bg-active .tool-form,
body.qt-bg-active .tool-result { backdrop-filter: blur(10px); }
#qtBgImageOverlay { position: fixed; inset: 0; z-index: -1; pointer-events: none; }
@media (max-width: 640px) {
.qt-bg-panel { width: 100vw; }
.qt-bg-presets { grid-template-columns: repeat(2, 1fr); gap: 8px; }
.qt-bg-preset { padding: 24px 12px 12px; }
.qt-bg-trigger span.qt-bg-trigger__text { display: none; }
.qt-bg-toggle__btn { font-size: 11px; padding: 8px 0; }
.qt-bg-dropzone { padding: 24px 16px; }
.qt-bg-gallery-grid { grid-template-columns: repeat(2, 1fr); gap: 6px; }
.qt-bg-gallery-item img { height: 75px; }
.qt-bg-readability-tip { bottom: 12px; font-size: 12px; padding: 10px 14px; }
}
:root {
--coin-gold: #F59E0B;
--coin-gold-light: #FCD34D;
--coin-gold-dark: #D97706;
--coin-glow: rgba(245, 158, 11, 0.3);
--mine-gradient: linear-gradient(135deg, #F59E0B 0%, #D97706 50%, #B45309 100%);
--mine-bg: rgba(245, 158, 11, 0.06);
--mine-border: rgba(245, 158, 11, 0.2);
}
[data-theme="dark"] {
--mine-bg: rgba(245, 158, 11, 0.08);
--mine-border: rgba(245, 158, 11, 0.25);
--coin-glow: rgba(245, 158, 11, 0.4);
}
.qc-balance {
display: inline-flex;
align-items: center;
gap: 6px;
padding: 4px 12px;
border-radius: var(--radius-full);
background: var(--mine-bg);
border: 1px solid var(--mine-border);
font-weight: 600;
font-size: var(--font-size-sm);
color: var(--coin-gold-dark);
cursor: default;
transition: all var(--transition-base);
position: relative;
overflow: hidden;
}
[data-theme="dark"] .qc-balance {
color: var(--coin-gold-light);
}
.qc-balance:hover {
border-color: var(--coin-gold);
box-shadow: 0 0 12px var(--coin-glow);
}
.qc-balance__icon {
width: 18px;
height: 18px;
display: flex;
align-items: center;
justify-content: center;
font-size: 14px;
filter: drop-shadow(0 0 3px var(--coin-glow));
}
.qc-balance__amount {
font-family: var(--font-mono);
font-weight: 700;
font-size: var(--font-size-sm);
letter-spacing: -0.02em;
min-width: 32px;
}
.qc-balance__label {
font-weight: 500;
font-size: var(--font-size-xs);
opacity: 0.8;
}
.qc-balance--earned {
animation: coinPulse 0.6s ease;
border-color: var(--coin-gold);
box-shadow: 0 0 20px var(--coin-glow);
}
@keyframes coinPulse {
0% { transform: scale(1); }
30% { transform: scale(1.12); }
60% { transform: scale(0.96); }
100% { transform: scale(1); }
}
.qc-mine-section {
margin-top: var(--space-5);
padding: var(--space-5);
border-radius: var(--radius-lg);
background: var(--mine-bg);
border: 1px dashed var(--mine-border);
text-align: center;
position: relative;
overflow: hidden;
}
.qc-mine-section::before {
content: '';
position: absolute;
top: 0; left: -100%;
width: 50%;
height: 100%;
background: linear-gradient(90deg, transparent, rgba(245, 158, 11, 0.05), transparent);
animation: mineSweep 3s ease-in-out infinite;
}
@keyframes mineSweep {
0% { left: -50%; }
100% { left: 150%; }
}
.qc-mine-header {
display: flex;
align-items: center;
justify-content: center;
gap: 8px;
margin-bottom: var(--space-3);
font-size: var(--font-size-sm);
color: var(--text-secondary);
font-weight: 500;
}
.qc-mine-header__icon {
font-size: 16px;
}
.qc-mine-btn {
display: inline-flex;
align-items: center;
gap: 10px;
padding: 12px 28px;
border: none;
border-radius: var(--radius-full);
background: var(--mine-gradient);
color: #FFFFFF;
font-weight: 700;
font-size: var(--font-size-base);
cursor: pointer;
transition: all var(--transition-base);
position: relative;
overflow: hidden;
box-shadow: 0 4px 16px rgba(245, 158, 11, 0.3);
letter-spacing: 0.02em;
}
.qc-mine-btn:hover {
transform: translateY(-2px) scale(1.02);
box-shadow: 0 6px 24px rgba(245, 158, 11, 0.4);
}
.qc-mine-btn:active {
transform: translateY(0) scale(0.98);
}
.qc-mine-btn:disabled {
opacity: 0.5;
cursor: not-allowed;
transform: none;
box-shadow: none;
}
.qc-mine-btn__pickaxe {
font-size: 18px;
display: inline-block;
}
.qc-mine-btn:hover .qc-mine-btn__pickaxe {
animation: pickaxeSwing 0.4s ease;
}
@keyframes pickaxeSwing {
0% { transform: rotate(0deg); }
25% { transform: rotate(-20deg); }
75% { transform: rotate(10deg); }
100% { transform: rotate(0deg); }
}
.qc-mine-btn__amount {
font-family: var(--font-mono);
font-weight: 800;
}
.qc-mine-btn::after {
content: '';
position: absolute;
top: 0; left: -100%;
width: 60%;
height: 100%;
background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
transition: left 0.5s ease;
}
.qc-mine-btn:hover::after {
left: 120%;
}
.qc-mine-sub {
margin-top: var(--space-2);
font-size: var(--font-size-xs);
color: var(--text-tertiary);
}
.qc-mine-sub a {
color: var(--coin-gold-dark);
text-decoration: underline;
text-underline-offset: 2px;
}
[data-theme="dark"] .qc-mine-sub a {
color: var(--coin-gold-light);
}
.qc-mine-remaining {
display: inline-flex;
align-items: center;
gap: 4px;
margin-top: var(--space-2);
font-size: var(--font-size-xs);
color: var(--text-tertiary);
font-family: var(--font-mono);
}
.qc-coin-fly {
position: fixed;
pointer-events: none;
z-index: 10000;
font-size: 24px;
animation: coinFlyUp 1.2s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
filter: drop-shadow(0 0 6px var(--coin-glow));
}
@keyframes coinFlyUp {
0% {
opacity: 1;
transform: translateY(0) scale(1) rotate(0deg);
}
50% {
opacity: 1;
transform: translateY(-60px) scale(1.3) rotate(180deg);
}
100% {
opacity: 0;
transform: translateY(-140px) scale(0.5) rotate(360deg);
}
}
.qc-coin-fly--1 { animation-duration: 1.0s; }
.qc-coin-fly--2 { animation-duration: 1.1s; animation-delay: 0.05s; }
.qc-coin-fly--3 { animation-duration: 1.2s; animation-delay: 0.1s; }
.qc-coin-fly--4 { animation-duration: 0.9s; animation-delay: 0.15s; }
.qc-coin-fly--5 { animation-duration: 1.3s; animation-delay: 0.08s; }
.qc-toast {
display: flex;
align-items: center;
gap: 10px;
padding: 12px 20px;
border-radius: var(--radius-lg);
background: linear-gradient(135deg, #92400E, #78350F);
color: var(--coin-gold-light);
font-weight: 600;
font-size: var(--font-size-sm);
box-shadow: 0 8px 32px rgba(120, 53, 15, 0.4);
border: 1px solid rgba(245, 158, 11, 0.3);
}
.qc-toast__icon { font-size: 20px; }
.qc-toast__amount {
font-family: var(--font-mono);
font-weight: 800;
color: #FCD34D;
}
.qc-hashrate {
display: flex;
align-items: baseline;
gap: 6px;
font-family: var(--font-mono);
}
.qc-hashrate__value {
font-size: var(--font-size-2xl);
font-weight: 800;
color: var(--coin-gold);
}
.qc-hashrate__unit {
font-size: var(--font-size-xs);
color: var(--text-tertiary);
text-transform: uppercase;
letter-spacing: 0.1em;
}
.qc-stats {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: var(--space-3);
padding: var(--space-4);
background: var(--mine-bg);
border-radius: var(--radius-lg);
border: 1px solid var(--mine-border);
}
@media (max-width: 480px) {
.qc-stats { grid-template-columns: 1fr; }
}
.qc-stats__item {
text-align: center;
padding: var(--space-3);
}
.qc-stats__value {
font-family: var(--font-mono);
font-size: var(--font-size-xl);
font-weight: 800;
color: var(--coin-gold);
}
.qc-stats__label {
font-size: var(--font-size-xs);
color: var(--text-tertiary);
margin-top: 2px;
text-transform: uppercase;
letter-spacing: 0.05em;
}
.qc-progress {
margin-top: var(--space-3);
}
.qc-progress__bar {
height: 6px;
background: var(--bg-tertiary);
border-radius: var(--radius-full);
overflow: hidden;
position: relative;
}
.qc-progress__fill {
height: 100%;
background: var(--mine-gradient);
border-radius: var(--radius-full);
transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1);
position: relative;
}
.qc-progress__fill::after {
content: '';
position: absolute;
top: 0; right: 0;
width: 20px;
height: 100%;
background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4));
border-radius: var(--radius-full);
}
.qc-progress__text {
display: flex;
justify-content: space-between;
margin-top: 4px;
font-size: var(--font-size-xs);
color: var(--text-tertiary);
font-family: var(--font-mono);
}
.qc-withdraw {
padding: var(--space-5);
border-radius: var(--radius-lg);
background: var(--bg-secondary);
border: 1px solid var(--border);
text-align: center;
opacity: 0.6;
position: relative;
}
.qc-withdraw__badge {
position: absolute;
top: -10px;
right: 16px;
padding: 2px 10px;
border-radius: var(--radius-full);
background: var(--accent);
color: white;
font-size: var(--font-size-xs);
font-weight: 700;
letter-spacing: 0.05em;
}
.qc-withdraw__title {
font-weight: 700;
font-size: var(--font-size-lg);
margin-bottom: var(--space-2);
}
.qc-withdraw__text {
font-size: var(--font-size-sm);
color: var(--text-secondary);
}
.qc-leaderboard-row {
display: flex;
align-items: center;
gap: var(--space-3);
padding: var(--space-3) var(--space-4);
border-radius: var(--radius-md);
transition: background var(--transition-fast);
}
.qc-leaderboard-row:hover {
background: var(--mine-bg);
}
.qc-leaderboard-row__rank {
font-family: var(--font-mono);
font-weight: 800;
min-width: 28px;
color: var(--text-tertiary);
}
.qc-leaderboard-row__rank--1 { color: #F59E0B; }
.qc-leaderboard-row__rank--2 { color: #9CA3AF; }
.qc-leaderboard-row__rank--3 { color: #D97706; }
.qc-leaderboard-row__coins {
margin-left: auto;
font-family: var(--font-mono);
font-weight: 700;
color: var(--coin-gold);
}
.qc-inline {
display: inline-flex;
align-items: center;
gap: 3px;
font-weight: 600;
}
.qc-inline__coin {
font-size: 0.9em;
filter: drop-shadow(0 0 2px var(--coin-glow));
}
.qc-mine-section--mined {
border-color: var(--coin-gold);
background: rgba(245, 158, 11, 0.1);
}
.qc-mine-section--mined .qc-mine-btn {
background: var(--bg-tertiary);
color: var(--text-secondary);
box-shadow: none;
cursor: default;
}
@media (max-width: 640px) {
.qc-mine-btn {
padding: 10px 22px;
font-size: var(--font-size-sm);
}
.qc-stats {
grid-template-columns: repeat(3, 1fr);
gap: var(--space-2);
padding: var(--space-3);
}
.qc-stats__value { font-size: var(--font-size-lg); }
}
.ss-modal {
position: fixed;
inset: 0;
z-index: 10000;
display: flex;
align-items: center;
justify-content: center;
opacity: 0;
visibility: hidden;
transition: opacity 0.25s ease, visibility 0.25s ease;
}
.ss-modal--open {
opacity: 1;
visibility: visible;
}
.ss-modal__backdrop {
position: absolute;
inset: 0;
background: rgba(0, 0, 0, 0.6);
backdrop-filter: blur(8px);
-webkit-backdrop-filter: blur(8px);
}
.ss-modal__content {
position: relative;
z-index: 1;
background: var(--bg-elevated, #fff);
border-radius: 20px;
padding: 24px;
max-width: 420px;
width: 92%;
max-height: 90vh;
overflow-y: auto;
box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
transform: scale(0.95) translateY(10px);
transition: transform 0.25s ease;
}
.ss-modal--open .ss-modal__content {
transform: scale(1) translateY(0);
}
.ss-modal__close {
position: absolute;
top: 12px;
right: 12px;
width: 36px;
height: 36px;
border: none;
background: var(--bg-tertiary, #f3f4f6);
border-radius: 50%;
font-size: 20px;
cursor: pointer;
display: flex;
align-items: center;
justify-content: center;
color: var(--text-secondary, #6b7280);
transition: background 0.15s;
}
.ss-modal__close:hover {
background: var(--bg-secondary, #e5e7eb);
}
.ss-modal__preview {
display: flex;
align-items: center;
justify-content: center;
min-height: 200px;
margin-bottom: 16px;
border-radius: 12px;
overflow: hidden;
}
.ss-modal__loading {
font-size: 48px;
animation: ss-pulse 1s ease infinite alternate;
}
@keyframes ss-pulse {
from { opacity: 0.4; transform: scale(0.95); }
to   { opacity: 1;   transform: scale(1.05); }
}
.ss-modal__formats {
display: flex;
gap: 8px;
margin-bottom: 16px;
}
.ss-fmt {
flex: 1;
display: flex;
flex-direction: column;
align-items: center;
gap: 2px;
padding: 10px 8px;
border: 2px solid var(--border, #e5e7eb);
border-radius: 12px;
background: var(--bg-secondary, #f9fafb);
cursor: pointer;
font-size: 14px;
font-weight: 600;
color: var(--text-primary, #1f2937);
transition: all 0.15s ease;
}
.ss-fmt small {
font-size: 11px;
font-weight: 400;
color: var(--text-secondary, #6b7280);
}
.ss-fmt:hover {
border-color: var(--accent, #8B5CF6);
background: var(--accent-bg, #f5f3ff);
}
.ss-fmt--active {
border-color: var(--accent, #8B5CF6);
background: var(--accent-bg, #f5f3ff);
color: var(--accent, #8B5CF6);
box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.15);
}
.ss-modal__actions {
display: flex;
gap: 10px;
}
.ss-modal__dl {
flex: 2;
min-height: 48px;
font-size: 16px;
font-weight: 600;
border-radius: 12px;
}
.ss-modal__share {
flex: 1;
min-height: 48px;
font-size: 16px;
border-radius: 12px;
}
[data-theme="dark"] .ss-modal__content {
background: var(--bg-elevated, #1f2937);
}
[data-theme="dark"] .ss-fmt {
background: var(--bg-tertiary, #374151);
border-color: var(--border, #4b5563);
}
[data-theme="dark"] .ss-fmt--active,
[data-theme="dark"] .ss-fmt:hover {
background: rgba(139, 92, 246, 0.15);
border-color: var(--accent, #a78bfa);
}
@media (max-width: 640px) {
.ss-modal__content {
max-width: 100%;
width: 100%;
border-radius: 20px 20px 0 0;
position: absolute;
bottom: 0;
max-height: 85vh;
padding: 20px 16px;
}
.ss-modal__preview canvas {
max-height: 45vh !important;
}
}
.qt-compete-banner {
display: flex;
align-items: center;
gap: 16px;
margin-top: var(--space-6, 24px);
padding: 16px 20px;
background: linear-gradient(135deg, rgba(139,92,246,0.08), rgba(6,182,212,0.06));
border: 1px solid rgba(139,92,246,0.2);
border-radius: var(--radius-lg, 14px);
font-family: var(--font-sans, 'Inter', sans-serif);
}
.qt-compete-banner--challenge {
background: linear-gradient(135deg, rgba(245,158,11,0.1), rgba(239,68,68,0.06));
border-color: rgba(245,158,11,0.3);
flex-direction: column;
text-align: center;
}
.qt-compete-banner__icon { font-size: 32px; flex-shrink: 0; }
.qt-compete-banner__content { flex: 1; min-width: 0; }
.qt-compete-banner__title {
font-weight: 600;
font-size: 15px;
color: var(--text-primary, #111827);
margin-bottom: 2px;
}
.qt-compete-banner__desc {
font-size: 13px;
color: var(--text-secondary, #6B7280);
}
.qt-compete-btn {
white-space: nowrap;
flex-shrink: 0;
display: inline-flex;
align-items: center;
gap: 8px;
padding: 10px 20px;
font-size: 14px;
font-weight: 600;
}
.qt-compete-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.qt-compete-score-badge {
display: inline-flex;
align-items: center;
padding: 2px 8px;
background: rgba(255,255,255,0.2);
border-radius: 20px;
font-size: 12px;
font-weight: 700;
}
.qt-compete-panel { margin-top: var(--space-4, 16px); }
.qt-compete-created {
text-align: center;
padding: 24px;
background: var(--bg-primary, #fff);
border: 1px solid var(--border, #E5E7EB);
border-radius: var(--radius-lg, 14px);
box-shadow: var(--shadow-md, 0 4px 6px rgba(0,0,0,0.07));
}
.qt-compete-created__badge {
font-size: 16px;
font-weight: 700;
color: var(--accent, #8B5CF6);
margin-bottom: 12px;
}
.qt-compete-created__score {
display: flex;
align-items: baseline;
justify-content: center;
gap: 6px;
margin-bottom: 20px;
}
.qt-compete-score-big {
font-size: 48px;
font-weight: 800;
color: var(--text-primary, #111827);
line-height: 1;
}
.qt-compete-score-unit {
font-size: 18px;
font-weight: 600;
color: var(--text-secondary, #6B7280);
}
.qt-compete-share-label {
font-size: 13px;
color: var(--text-secondary, #6B7280);
margin-bottom: 8px;
}
.qt-compete-link-row {
display: flex;
gap: 8px;
margin-bottom: 16px;
}
.qt-compete-link-input {
flex: 1;
padding: 10px 12px;
border: 1px solid var(--border, #E5E7EB);
border-radius: var(--radius-sm, 6px);
font-size: 13px;
font-family: var(--font-mono, monospace);
background: var(--bg-secondary, #F9FAFB);
color: var(--text-primary, #111827);
min-width: 0;
}
.qt-compete-link-input:focus {
outline: 2px solid var(--accent, #8B5CF6);
outline-offset: 1px;
}
.qt-compete-share-buttons {
display: flex;
gap: 8px;
justify-content: center;
flex-wrap: wrap;
margin-bottom: 16px;
}
.qt-compete-share-btn {
display: inline-flex;
align-items: center;
gap: 6px;
padding: 8px 16px;
border-radius: var(--radius-full, 9999px);
font-size: 13px;
font-weight: 500;
text-decoration: none;
color: #fff;
transition: transform 0.15s ease, opacity 0.15s ease;
}
.qt-compete-share-btn:hover { transform: scale(1.05); opacity: 0.9; }
.qt-compete-share--wa { background: #25D366; }
.qt-compete-share--tg { background: #0088CC; }
.qt-compete-share--tw { background: #1DA1F2; }
.qt-compete-waiting {
font-size: 13px;
color: var(--text-secondary, #6B7280);
font-style: italic;
}
.qt-compete-challenger {
display: flex;
align-items: center;
gap: 12px;
justify-content: center;
margin-bottom: 12px;
}
.qt-compete-challenger__avatar { font-size: 40px; }
.qt-compete-challenger__info {
font-size: 15px;
color: var(--text-primary, #111827);
}
.qt-compete-target { margin-top: 8px; }
.qt-compete-target__label {
font-size: 14px;
color: var(--text-secondary, #6B7280);
margin-bottom: 4px;
}
.qt-compete-target__score {
display: flex;
align-items: baseline;
justify-content: center;
gap: 6px;
}
.qt-compete-result {
text-align: center;
padding: 24px;
border-radius: var(--radius-lg, 14px);
border: 2px solid var(--border, #E5E7EB);
}
.qt-compete-result--won {
background: linear-gradient(135deg, rgba(16,185,129,0.08), rgba(245,158,11,0.06));
border-color: #10B981;
}
.qt-compete-result--lost {
background: linear-gradient(135deg, rgba(239,68,68,0.06), rgba(245,158,11,0.04));
border-color: #EF4444;
}
.qt-compete-result--tied {
background: linear-gradient(135deg, rgba(59,130,246,0.06), rgba(139,92,246,0.04));
border-color: #3B82F6;
}
.qt-compete-result__msg {
font-size: 24px;
font-weight: 800;
margin-bottom: 20px;
}
.qt-compete-versus {
display: flex;
align-items: center;
justify-content: center;
gap: 20px;
margin-bottom: 20px;
}
.qt-compete-versus__side {
flex: 1;
max-width: 160px;
padding: 16px;
border-radius: var(--radius-md, 10px);
background: var(--bg-primary, #fff);
border: 1px solid var(--border, #E5E7EB);
}
.qt-compete-versus--me { border-color: var(--accent, #8B5CF6); }
.qt-compete-versus--them { opacity: 0.7; }
.qt-compete-versus__label {
font-size: 11px;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.5px;
color: var(--text-secondary, #6B7280);
margin-bottom: 4px;
}
.qt-compete-versus__score {
font-size: 36px;
font-weight: 800;
color: var(--text-primary, #111827);
line-height: 1.1;
}
.qt-compete-versus__unit {
font-size: 13px;
color: var(--text-secondary, #6B7280);
}
.qt-compete-versus__vs {
font-size: 16px;
font-weight: 700;
color: var(--text-secondary, #6B7280);
flex-shrink: 0;
}
.qt-compete-expired {
text-align: center;
padding: 16px;
margin-bottom: var(--space-4, 16px);
background: rgba(245,158,11,0.1);
border: 1px solid rgba(245,158,11,0.3);
border-radius: var(--radius-md, 10px);
color: #92400E;
font-size: 14px;
}
@media (max-width: 640px) {
.qt-compete-banner {
flex-direction: column;
text-align: center;
gap: 12px;
padding: 16px;
}
.qt-compete-btn { width: 100%; justify-content: center; }
.qt-compete-link-row { flex-direction: column; }
.qt-compete-link-input { font-size: 12px; }
.qt-compete-versus { gap: 10px; }
.qt-compete-versus__side { padding: 12px; }
.qt-compete-versus__score { font-size: 28px; }
.qt-compete-score-big { font-size: 36px; }
.qt-compete-share-buttons { flex-direction: column; }
.qt-compete-share-btn { justify-content: center; }
}
[data-theme="dark"] .qt-compete-banner {
background: linear-gradient(135deg, rgba(139,92,246,0.12), rgba(6,182,212,0.08));
border-color: rgba(139,92,246,0.3);
}
[data-theme="dark"] .qt-compete-banner--challenge {
background: linear-gradient(135deg, rgba(245,158,11,0.12), rgba(239,68,68,0.08));
border-color: rgba(245,158,11,0.4);
}
[data-theme="dark"] .qt-compete-created { background: var(--bg-secondary, #111827); }
[data-theme="dark"] .qt-compete-link-input { background: var(--bg-tertiary, #1F2937); }
[data-theme="dark"] .qt-compete-versus__side { background: var(--bg-tertiary, #1F2937); }
[data-theme="dark"] .qt-compete-expired { background: rgba(245,158,11,0.15); color: #FCD34D; }
[dir="rtl"] .qt-compete-banner { flex-direction: row-reverse; }
[dir="rtl"] .qt-compete-banner--challenge { flex-direction: column; }
@media (prefers-reduced-motion: reduce) {
.qt-compete-share-btn { transition: none; }
}
@media print {
.qt-compete-banner,
.qt-compete-panel,
.qt-compete-share-buttons { display: none !important; }
}
.qt-share {
margin-top: var(--space-8, 32px);
padding: var(--space-5, 20px) var(--space-4, 16px);
border-radius: var(--radius-lg, 14px);
background: var(--bg-secondary, #F9FAFB);
border: 1px solid var(--border-light, #F3F4F6);
text-align: center;
}
.qt-share__label {
font-size: var(--font-size-xs, 0.75rem);
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.1em;
color: var(--text-tertiary, #9CA3AF);
margin: 0 0 var(--space-3, 12px) 0;
}
.qt-share__grid {
display: flex;
flex-wrap: wrap;
justify-content: center;
gap: var(--space-2, 8px);
}
.qt-share__btn {
display: inline-flex;
align-items: center;
gap: 6px;
padding: 8px 14px;
border-radius: var(--radius-md, 10px);
font-size: var(--font-size-sm, 0.875rem);
font-weight: 500;
font-family: var(--font-sans, 'Inter', sans-serif);
text-decoration: none;
border: 1px solid var(--border, #E5E7EB);
background: var(--bg-primary, #FFFFFF);
color: var(--text-secondary, #6B7280);
cursor: pointer;
transition: all var(--transition-fast, 150ms) ease;
line-height: 1;
-webkit-tap-highlight-color: transparent;
}
.qt-share__btn:hover {
transform: translateY(-2px);
box-shadow: var(--shadow-md, 0 4px 6px -1px rgba(0,0,0,0.07));
}
.qt-share__btn:active {
transform: translateY(0);
}
.qt-share__btn svg {
flex-shrink: 0;
}
.qt-share__btn--whatsapp:hover {
background: #25D366; color: #fff; border-color: #25D366;
}
.qt-share__btn--telegram:hover {
background: #0088cc; color: #fff; border-color: #0088cc;
}
.qt-share__btn--x:hover {
background: #000; color: #fff; border-color: #000;
}
.qt-share__btn--facebook:hover {
background: #1877F2; color: #fff; border-color: #1877F2;
}
.qt-share__btn--linkedin:hover {
background: #0A66C2; color: #fff; border-color: #0A66C2;
}
.qt-share__btn--email:hover {
background: #EA4335; color: #fff; border-color: #EA4335;
}
.qt-share__btn--copy:hover {
background: var(--accent, #7C3AED); color: #fff; border-color: var(--accent, #7C3AED);
}
.qt-share__btn--native:hover {
background: var(--accent, #7C3AED); color: #fff; border-color: var(--accent, #7C3AED);
}
.qt-share__btn--copied {
background: var(--color-success-500, #10B981) !important;
color: #fff !important;
border-color: var(--color-success-500, #10B981) !important;
}
[data-theme="dark"] .qt-share {
background: var(--bg-secondary, #111827);
border-color: var(--border, #374151);
}
[data-theme="dark"] .qt-share__btn {
background: var(--bg-tertiary, #1F2937);
border-color: var(--border, #374151);
color: var(--text-secondary, #9CA3AF);
}
[data-theme="dark"] .qt-share__btn--x:hover {
background: #e7e9ea; color: #000; border-color: #e7e9ea;
}
@media (max-width: 480px) {
.qt-share__btn span { display: none; }
.qt-share__btn { padding: 10px; }
.qt-share__btn--native span { display: inline; }
.qt-share__grid { gap: 6px; }
}
@media (min-width: 481px) and (max-width: 768px) {
.qt-share__btn { padding: 8px 12px; font-size: 0.8rem; }
}
.seo-content {
margin-top: var(--space-8);
border-top: 1px solid var(--border-light);
}
.seo-content__toggle {
display: flex;
align-items: center;
justify-content: space-between;
width: 100%;
padding: var(--space-4) 0;
background: none;
border: none;
cursor: pointer;
color: var(--text-tertiary);
font-size: var(--font-size-sm);
font-family: var(--font-sans);
transition: color var(--transition-fast);
}
.seo-content__toggle:hover {
color: var(--text-secondary);
}
.seo-content__toggle-icon {
transition: transform var(--transition-base);
font-size: 12px;
}
.seo-content[open] .seo-content__toggle-icon {
transform: rotate(180deg);
}
.seo-content__body {
padding: 0 0 var(--space-6);
color: var(--text-secondary);
font-size: var(--font-size-sm);
line-height: 1.7;
animation: seoFadeIn 0.3s ease;
}
@keyframes seoFadeIn {
from { opacity: 0; transform: translateY(-8px); }
to   { opacity: 1; transform: translateY(0); }
}
.seo-content__body h2 {
font-size: var(--font-size-lg);
color: var(--text-primary);
margin-bottom: var(--space-3);
}
.seo-content__body h3 {
font-size: var(--font-size-base);
color: var(--text-primary);
margin: var(--space-5) 0 var(--space-2);
}
.seo-content__body p {
margin-bottom: var(--space-3);
}
.seo-faq {
margin-top: var(--space-5);
}
.seo-faq__item {
margin-bottom: var(--space-3);
padding: var(--space-3);
background: var(--bg-secondary);
border-radius: var(--radius-md);
border: 1px solid var(--border-light);
}
.seo-faq__item h4 {
font-size: var(--font-size-sm);
color: var(--text-primary);
margin-bottom: var(--space-1);
}
.seo-faq__item p {
margin: 0;
font-size: var(--font-size-xs);
color: var(--text-tertiary);
}