:root {
  --color-primary: #22c55e;
  --color-primary-dark: #16a34a;
  --color-bg: #f8fafc;
  --color-card: #ffffff;
  --color-text: #1e293b;
  --color-text-light: #64748b;
  --color-border: #e2e8f0;
  --color-red: #ef4444;
  --color-blue: #3b82f6;
  --color-purple: #8b5cf6;
  --color-yellow: #f59e0b;
}
.tq-card { background: var(--color-card); border: 1px solid var(--color-border); border-radius: 14px; padding: 16px; margin-bottom: 12px; box-shadow: 0 1px 6px rgba(0,0,0,0.05); }
.tq-section-label { font-size: 12px; font-weight: 700; color: var(--color-text-light); margin-bottom: 8px; letter-spacing: 0.5px; }
.tq-section-head { font-size: 13px; font-weight: 900; color: var(--color-text); margin-bottom: 10px; display: flex; align-items: center; gap: 6px; }
.tq-pills { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 4px; }
.tq-pill { padding: 9px 16px; border: 2px solid var(--color-border); border-radius: 99px; background: var(--color-card); font-size: 13px; font-weight: 700; color: var(--color-text); cursor: pointer; transition: all 0.15s; white-space: nowrap; }
.tq-pill:hover { border-color: var(--color-primary); color: var(--color-primary); }
.tq-pill.selected { border-color: var(--color-primary); background: #f0fdf4; color: var(--color-primary-dark); }
.tq-count-pill { padding: 7px 14px; border: 2px solid var(--color-border); border-radius: 99px; background: var(--color-card); font-size: 13px; font-weight: 700; color: var(--color-text-light); cursor: pointer; transition: all 0.15s; }
.tq-count-pill.selected { border-color: var(--color-blue); background: #eff6ff; color: var(--color-blue); }
.tq-btn-primary { width: 100%; padding: 14px; background: var(--color-primary); color: #fff; border: none; border-radius: 12px; font-size: 15px; font-weight: 900; cursor: pointer; transition: all 0.15s; margin-top: 4px; }
.tq-btn-primary:hover { background: var(--color-primary-dark); }
.tq-btn-primary:disabled { opacity: 0.4; cursor: not-allowed; }
.tq-btn-outline { width: 100%; padding: 12px; background: var(--color-card); color: var(--color-text); border: 2px solid var(--color-border); border-radius: 12px; font-size: 14px; font-weight: 700; cursor: pointer; transition: all 0.15s; margin-top: 8px; }
.tq-btn-outline:hover { border-color: var(--color-primary); color: var(--color-primary); }
.tq-dist-row { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.tq-dist-label { width: 20px; font-size: 12px; font-weight: 900; color: var(--color-text-light); text-align: right; flex-shrink: 0; }
.tq-dist-bar-wrap { flex: 1; height: 10px; background: #f1f5f9; border-radius: 99px; overflow: hidden; }
.tq-dist-bar { height: 100%; border-radius: 99px; transition: width 0.6s ease; }
.tq-dist-pct { width: 34px; font-size: 11px; font-weight: 700; color: var(--color-text-light); text-align: right; flex-shrink: 0; }
.tq-quiz-meta { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.tq-progress-text { font-size: 13px; font-weight: 700; color: var(--color-text-light); }
.tq-progress-text strong { color: var(--color-primary-dark); font-size: 16px; }
.tq-genre-tag { font-size: 11px; font-weight: 700; background: #f0fdf4; color: var(--color-primary-dark); padding: 3px 10px; border-radius: 99px; border: 1px solid #bbf7d0; }
.tq-bar-track { height: 5px; background: var(--color-border); border-radius: 99px; margin-bottom: 16px; overflow: hidden; }
.tq-bar-fill { height: 100%; background: var(--color-primary); border-radius: 99px; transition: width 0.3s; }
.tq-timer-row { margin-bottom: 12px; }
.tq-timer-bar-wrap { position: relative; height: 8px; background: #f1f5f9; border-radius: 99px; overflow: hidden; margin-bottom: 4px; }
.tq-timer-bar { height: 100%; border-radius: 99px; background: var(--color-primary); transition: width 1s linear, background 0.5s; }
.tq-timer-bar.warn   { background: var(--color-yellow); }
.tq-timer-bar.danger { background: var(--color-red); animation: tq-pulse-bar 0.5s infinite; }
.tq-timer-label { display: flex; justify-content: space-between; align-items: center; }
.tq-timer-text { font-size: 11px; font-weight: 700; color: var(--color-text-light); }
.tq-timer-num  { font-size: 13px; font-weight: 900; color: var(--color-text-light); transition: color 0.3s; }
.tq-timer-num.warn   { color: var(--color-yellow); }
.tq-timer-num.danger { color: var(--color-red); }
@keyframes tq-pulse-bar { 0%,100%{opacity:1} 50%{opacity:0.5} }
@keyframes tq-pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.1)} }
.tq-q-num { font-size: 12px; font-weight: 900; color: var(--color-primary-dark); background: #dcfce7; padding: 3px 10px; border-radius: 6px; display: inline-block; }
.tq-q-text { font-size: 16px; font-weight: 700; line-height: 1.65; }
.tq-options { display: flex; flex-direction: column; gap: 9px; }
.tq-opt { width: 100%; padding: 14px 18px; background: var(--color-card); border: 2px solid var(--color-border); border-radius: 12px; font-size: 15px; font-weight: 700; color: var(--color-text); cursor: pointer; text-align: left; transition: all 0.15s; display: flex; align-items: center; }
.tq-opt:hover:not(:disabled) { border-color: var(--color-primary); background: #f0fdf4; transform: translateY(-1px); }
.tq-opt-txt { flex: 1; }
.tq-opt.correct { border-color: var(--color-primary); background: #f0fdf4; color: var(--color-primary-dark); }
.tq-opt.wrong   { border-color: var(--color-red); background: #fef2f2; color: var(--color-red); }
.tq-opt.dimmed  { opacity: 0.45; }
.tq-opt:disabled { cursor: not-allowed; }
.tq-feedback { border-radius: 10px; padding: 12px 14px; margin-top: 14px; font-weight: 700; font-size: 14px; display: none; align-items: center; gap: 8px; }
.tq-feedback.show { display: flex; }
.tq-feedback.ok { background: #f0fdf4; color: var(--color-primary-dark); border: 1px solid #bbf7d0; }
.tq-feedback.ng { background: #fef2f2; color: var(--color-red); border: 1px solid #fecaca; }
.tq-feedback-pt { margin-left: auto; font-size: 12px; opacity: 0.85; }
.tq-next { width: 100%; margin-top: 12px; padding: 13px; background: var(--color-text); color: #fff; border: none; border-radius: 12px; font-size: 15px; font-weight: 700; cursor: pointer; display: none; transition: opacity 0.15s; }
.tq-next.show { display: block; }
.tq-next:hover { opacity: 0.85; }
.tq-result-hero { text-align: center; padding: 24px 0 18px; }
.tq-result-emoji { font-size: 56px; margin-bottom: 10px; }
.tq-result-title { font-size: 22px; font-weight: 900; margin-bottom: 4px; }
.tq-result-sub   { font-size: 12px; color: var(--color-text-light); }
.tq-stat-row { display: flex; gap: 10px; margin-bottom: 12px; }
.tq-stat { flex: 1; background: var(--color-card); border: 1px solid var(--color-border); border-radius: 12px; padding: 12px 8px; text-align: center; }
.tq-stat-lbl  { font-size: 10px; font-weight: 700; color: var(--color-text-light); margin-bottom: 4px; }
.tq-stat-val  { font-size: 24px; font-weight: 900; color: var(--color-primary-dark); }
.tq-stat-unit { font-size: 11px; color: var(--color-text-light); }
.tq-rank-table { width: 100%; border-collapse: collapse; }
.tq-rank-table th { font-size: 11px; font-weight: 700; color: #fff; padding: 8px; text-align: left; background: var(--color-primary-dark); }
.tq-rank-table th:first-child { border-radius: 8px 0 0 0; }
.tq-rank-table th:last-child  { border-radius: 0 8px 0 0; }
.tq-rank-table td { padding: 10px 8px; font-size: 13px; font-weight: 700; border-bottom: 1px solid var(--color-border); vertical-align: middle; }
.tq-rank-table tr:last-child td { border-bottom: none; }
.tq-rank-medal { font-size: 16px; }
.tq-rank-num   { color: var(--color-text-light); font-size: 12px; }
.tq-rank-you   { font-size: 10px; background: var(--color-primary); color: #fff; padding: 1px 6px; border-radius: 99px; margin-left: 4px; vertical-align: middle; }
.tq-rank-score { color: var(--color-primary-dark); }
.tq-rank-acc   { color: var(--color-blue); }
.tq-rank-time  { color: var(--color-text-light); font-size: 12px; }
.tq-modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:9999; display:flex; align-items:center; justify-content:center; }
.tq-modal { background:#fff; border-radius:20px; padding:24px 20px 32px; width:90%; max-width:480px; max-height:90vh; overflow-y:auto; animation:tq-slide-up 0.25s ease; }
@keyframes tq-slide-up { from{transform:translateY(30px);opacity:0} to{transform:translateY(0);opacity:1} }
.tq-modal-title { font-size:18px; font-weight:900; margin-bottom:4px; }
.tq-modal-sub   { font-size:13px; color:var(--color-text-light); margin-bottom:16px; }
.tq-modal-input { width:100%; padding:13px 16px; border:2px solid var(--color-border); border-radius:12px; font-size:15px; font-weight:700; outline:none; margin-bottom:10px; box-sizing:border-box; }
.tq-modal-input:focus { border-color:var(--color-primary); }
.tq-modal-divider { display:flex; align-items:center; gap:10px; margin:14px 0; }
.tq-modal-divider span { font-size:12px; color:var(--color-text-light); font-weight:700; white-space:nowrap; }
.tq-modal-divider:before,.tq-modal-divider:after { content:''; flex:1; height:1px; background:var(--color-border); }
.tq-modal-signup { width:100%; padding:13px; background:#f8fafc; border:2px solid var(--color-border); border-radius:12px; font-size:14px; font-weight:700; color:var(--color-text); cursor:pointer; text-align:center; transition:all 0.15s; }
.tq-modal-signup:hover { border-color:var(--color-purple); color:var(--color-purple); }
.tq-modal-skip { width:100%; padding:10px; background:none; border:none; font-size:13px; color:var(--color-text-light); cursor:pointer; margin-top:6px; }
.tq-loading { text-align: center; padding: 30px 0; color: var(--color-text-light); font-size: 13px; font-weight: 700; }
.tq-spinner { width: 28px; height: 28px; border: 3px solid var(--color-border); border-top-color: var(--color-primary); border-radius: 50%; animation: tq-spin 0.8s linear infinite; margin: 0 auto 8px; }
@keyframes tq-spin { to { transform: rotate(360deg); } }
.tq-acc-badge { background: #f0fdf4; border: 1px solid #bbf7d0; padding: 5px 12px; border-radius: 10px; text-align: center; flex-shrink: 0; }
.tq-acc-badge-lbl { font-size: 10px; font-weight: 700; color: var(--color-text-light); }
.tq-acc-badge-val { font-size: 15px; font-weight: 900; color: var(--color-primary-dark); line-height: 1.2; }
.tq-acc-badge-cnt { font-size: 9px; color: var(--color-text-light); font-weight: 600; }
.tq-diff-badge { font-size: 10px; font-weight: 900; color: #fff; padding: 2px 8px; border-radius: 20px; }