/**
 * 123TinyTools Word Counter — Styles
 * All selectors scoped under .tia-wc-wrap (frontend) or .tia-wc-gate-overlay.
 * Brand tokens as CSS custom properties — scoped, never override theme globals.
 *
 * Dark mode architecture:
 *   Light tokens are always the default. Dark mode ONLY activates when the
 *   WordPress theme adds a class to <body>: .kt-dark-mode (Kadence),
 *   .dark-mode (generic), body[data-theme="dark"], or .is-dark (Divi/Astra).
 *   NO @media (prefers-color-scheme: dark) — OS preference alone would make
 *   plugin surfaces dark while the WP page stays light = broken mixed look.
 *   Wrap background is TRANSPARENT so the page background shows through.
 *
 * WCAG AA compliance:
 *   Muted text uses #64748B (5.9:1 on white) not #94A3B8 (2.92:1 fails).
 *
 * Version: 2.1.2
 */

/* ──────────────────────────────────────────────────────────
   LIGHT TOKENS  (scoped — never pollute global :root)
────────────────────────────────────────────────────────── */
.tia-wc-wrap,
.tia-wc-gate-overlay {
  isolation: isolate;
  --tia-blue-50:  #EFF4FF;
  --tia-blue-100: #DBE8FF;
  --tia-blue-200: #B8D0FF;
  --tia-blue-400: #5B8DEF;
  --tia-blue-500: #4B7CF3;
  --tia-blue-600: #3461E8;

  --tia-slate-50:  #F8FAFD;
  --tia-slate-100: #F1F5F9;
  --tia-slate-200: #E4EAF4;
  --tia-slate-300: #CBD5E1;
  --tia-slate-400: #94A3B8;
  --tia-slate-500: #64748B;
  --tia-slate-600: #475569;
  --tia-slate-700: #334155;
  --tia-slate-800: #1E293B;
  --tia-slate-900: #0F172A;

  --tia-success:       #22C55E;
  --tia-success-light: #DCFCE7;
  --tia-warning:       #F59E0B;
  --tia-warning-light: #FEF3C7;
  --tia-error:         #EF4444;
  --tia-error-light:   #FEE2E2;
  --tia-info:          #0EA5E9;
  --tia-info-light:    #E0F2FE;

  --tia-bg:           #F8FAFD;
  --tia-surface:      #FFFFFF;
  --tia-border:       #E4EAF4;
  --tia-border-s:     #CBD5E1;

  --tia-text:         #1E293B;
  --tia-text-body:    #475569;
  --tia-text-muted:   #64748B;  /* 5.9:1 on white — WCAG AA pass */

  --tia-shadow-sm: 0 1px 2px rgba(74,124,243,.04), 0 1px 3px rgba(0,0,0,.06);
  --tia-shadow-md: 0 4px 6px rgba(74,124,243,.06), 0 2px 4px rgba(0,0,0,.06);
  --tia-shadow-lg: 0 10px 20px rgba(74,124,243,.08), 0 4px 6px rgba(0,0,0,.05);
  --tia-shadow-xl: 0 20px 40px rgba(74,124,243,.12), 0 8px 16px rgba(0,0,0,.06);

  --tia-r-sm:   6px;
  --tia-r-md:   10px;
  --tia-r-lg:   16px;
  --tia-r-xl:   24px;
  --tia-r-full: 9999px;

  --tia-font-h: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --tia-font-b: 'Inter', system-ui, -apple-system, sans-serif;
  --tia-font-m: 'JetBrains Mono', 'Fira Code', 'Cascadia Code', monospace;

  box-sizing: border-box;
  font-family: var(--tia-font-b);
  color: var(--tia-text);
  line-height: 1.6;
}

/* Inherit box-sizing inside */
.tia-wc-wrap *,
.tia-wc-wrap *::before,
.tia-wc-wrap *::after,
.tia-wc-gate-overlay *,
.tia-wc-gate-overlay *::before,
.tia-wc-gate-overlay *::after {
  box-sizing: border-box;
}

/* ──────────────────────────────────────────────────────────
   WRAP — transparent so the page background shows through.
   Tokens drive every surface; no hardcoded hex here.
────────────────────────────────────────────────────────── */
.tia-wc-wrap {
  background: transparent;
  color: var(--tia-text);
}

/* Theme-bleed protection — use CSS vars so dark mode works */
.tia-wc-wrap .tia-wc-editor-card  { background-color: var(--tia-surface); }
.tia-wc-wrap .tia-wc-toolbar      { background-color: var(--tia-slate-50); color: var(--tia-text-body); }
.tia-wc-wrap .tia-wc-char-bar     { background-color: var(--tia-slate-50); }
.tia-wc-wrap .tia-wc-textarea     { background-color: var(--tia-slate-50); color: var(--tia-text); }
.tia-wc-wrap .tia-stat-card       { background-color: var(--tia-surface); color: var(--tia-text); }
.tia-wc-wrap .tia-stat-featured   { background-color: var(--tia-blue-50); }
.tia-wc-wrap .tia-stat-value      { color: var(--tia-text); }
.tia-wc-wrap .tia-stat-featured .tia-stat-value { color: var(--tia-blue-600); }
.tia-wc-wrap .tia-wc-reading-row  { background-color: var(--tia-surface); color: var(--tia-text); }
.tia-wc-wrap .tia-stat-row-card   { background-color: var(--tia-surface); color: var(--tia-text); }
.tia-wc-wrap .tia-wc-freq-card    { background-color: var(--tia-surface); }
.tia-wc-wrap .tia-card-header     { background-color: var(--tia-surface); color: var(--tia-text); }
.tia-wc-wrap .tia-card-body       { background-color: var(--tia-surface); }
.tia-wc-wrap .tia-wc-export-row   { background-color: var(--tia-surface); color: var(--tia-text-body); }
.tia-wc-wrap .tia-wc-upload-zone  { background-color: var(--tia-surface); }
.tia-wc-wrap .tia-freq-word       { color: var(--tia-text); }
.tia-wc-wrap .tia-stat-label      { color: var(--tia-text-muted); }
.tia-wc-wrap .tia-stat-row-label  { color: var(--tia-text-body); }
.tia-wc-wrap .tia-card-title      { color: var(--tia-text); }
.tia-wc-wrap .tia-reading-label   { color: var(--tia-text-muted); }
.tia-wc-wrap .tia-reading-time-display { color: var(--tia-blue-500); }
.tia-wc-wrap .tia-upload-title    { color: var(--tia-text); }
.tia-wc-wrap .tia-upload-sub      { color: var(--tia-text-muted); }
.tia-wc-wrap .tia-wc-empty-title  { color: var(--tia-text-muted); }
.tia-wc-wrap .tia-wc-empty p      { color: var(--tia-text-muted); }
.tia-wc-wrap .tia-export-label    { color: var(--tia-text-body); }

/* Gate modal — CSS var based */
.tia-gate-modal      { background-color: var(--tia-surface); }
.tia-gate-title      { color: var(--tia-text); }
.tia-gate-sub        { color: var(--tia-text-body); }
.tia-gate-modal-header { background-color: var(--tia-surface); }
.tia-gate-modal-body   { background-color: var(--tia-surface); }

/* Buttons — CSS var based (always override theme resets) */
.tia-wc-wrap .tia-btn {
  background-color: var(--tia-surface);
  color: var(--tia-text-body);
  border-color: var(--tia-border);
}
.tia-wc-wrap .tia-btn-primary {
  background-color: var(--tia-blue-400) !important;
  color: #fff !important;
  border-color: var(--tia-blue-400) !important;
}
.tia-wc-wrap .tia-btn-primary:hover {
  background-color: var(--tia-blue-500) !important;
  border-color: var(--tia-blue-500) !important;
}
.tia-wc-wrap .tia-chip {
  background-color: transparent;
  color: var(--tia-text-muted);
  border-color: transparent;
  border-bottom-color: transparent;
}
.tia-wc-wrap .tia-chip.tia-chip-active {
  background-color: var(--tia-surface) !important;
  color: var(--tia-blue-400) !important;
  border-color: transparent !important;
  border-bottom-color: var(--tia-blue-400) !important;
}
.tia-wc-wrap .tia-chip:hover:not(.tia-chip-active) {
  background-color: var(--tia-slate-100) !important;
  color: var(--tia-text-body) !important;
  border-color: transparent !important;
  border-bottom-color: var(--tia-blue-200) !important;
}
.tia-gate-btn-primary {
  background-color: var(--tia-blue-400) !important;
  color: #fff !important;
}
.tia-gate-btn-primary:hover { background-color: var(--tia-blue-500) !important; }
.tia-gate-btn-outline       { background-color: transparent; color: var(--tia-text-body); }

/* ──────────────────────────────────────────────────────────
   DARK MODE — THEME-CLASS ONLY
   NO @media (prefers-color-scheme: dark) — that fires from
   the OS alone and makes plugin surfaces dark while the WP
   theme page stays light, creating a broken mixed appearance.
   Dark mode only activates when the WP theme explicitly adds
   a dark-mode class to <body> (Kadence, generic, data-attr).
────────────────────────────────────────────────────────── */

/* Kadence dark mode */
.kt-dark-mode .tia-wc-wrap,
.kt-dark-mode .tia-wc-gate-overlay {
  --tia-blue-50:   #172340;
  --tia-blue-100:  #1E2F55;
  --tia-blue-200:  #2A4480;
  --tia-surface:   #1E293B;
  --tia-slate-50:  #162032;
  --tia-slate-100: #1E293B;
  --tia-slate-200: #334155;
  --tia-border:    #334155;
  --tia-border-s:  #475569;
  --tia-text:      #F1F5F9;
  --tia-text-body: #94A3B8;
  --tia-text-muted:#64748B;
  --tia-shadow-sm: 0 1px 2px rgba(0,0,0,.2), 0 1px 3px rgba(0,0,0,.3);
  --tia-shadow-md: 0 4px 6px rgba(0,0,0,.25), 0 2px 4px rgba(0,0,0,.2);
  --tia-shadow-lg: 0 10px 20px rgba(0,0,0,.3), 0 4px 6px rgba(0,0,0,.2);
  --tia-shadow-xl: 0 20px 40px rgba(0,0,0,.4), 0 8px 16px rgba(0,0,0,.25);
  --tia-warning-light: #451a03;
  --tia-error-light:   #450a0a;
  --tia-info-light:    #082f49;
  --tia-success-light: #052e16;
}

/* WPPOOL WP Dark Mode plugin */
html.wp-dark-mode-active .tia-wc-wrap,
html.wp-dark-mode-active .tia-wc-gate-overlay,
body.wp-dark-mode-active .tia-wc-wrap,
body.wp-dark-mode-active .tia-wc-gate-overlay {
  --tia-blue-50:   #172340;
  --tia-blue-100:  #1E2F55;
  --tia-blue-200:  #2A4480;
  --tia-surface:   #1E293B;
  --tia-slate-50:  #162032;
  --tia-slate-100: #1E293B;
  --tia-slate-200: #334155;
  --tia-border:    #334155;
  --tia-border-s:  #475569;
  --tia-text:      #F1F5F9;
  --tia-text-body: #94A3B8;
  --tia-text-muted:#64748B;
  --tia-shadow-sm: 0 1px 2px rgba(0,0,0,.2), 0 1px 3px rgba(0,0,0,.3);
  --tia-shadow-md: 0 4px 6px rgba(0,0,0,.25), 0 2px 4px rgba(0,0,0,.2);
  --tia-shadow-lg: 0 10px 20px rgba(0,0,0,.3), 0 4px 6px rgba(0,0,0,.2);
  --tia-shadow-xl: 0 20px 40px rgba(0,0,0,.4), 0 8px 16px rgba(0,0,0,.25);
  --tia-warning-light: #451a03;
  --tia-error-light:   #450a0a;
  --tia-info-light:    #082f49;
  --tia-success-light: #052e16;
}

/* Generic dark-mode class + data attribute (html[data-theme] = Kadence primary signal) */
html[data-theme="dark"] .tia-wc-wrap,
html[data-theme="dark"] .tia-wc-gate-overlay,
.dark-mode .tia-wc-wrap,
.dark-mode .tia-wc-gate-overlay,
body[data-theme="dark"] .tia-wc-wrap,
body[data-theme="dark"] .tia-wc-gate-overlay,
.is-dark .tia-wc-wrap,
.is-dark .tia-wc-gate-overlay {
  --tia-blue-50:   #172340;
  --tia-blue-100:  #1E2F55;
  --tia-blue-200:  #2A4480;
  --tia-surface:   #1E293B;
  --tia-slate-50:  #162032;
  --tia-slate-100: #1E293B;
  --tia-slate-200: #334155;
  --tia-border:    #334155;
  --tia-border-s:  #475569;
  --tia-text:      #F1F5F9;
  --tia-text-body: #94A3B8;
  --tia-text-muted:#64748B;
  --tia-shadow-sm: 0 1px 2px rgba(0,0,0,.2), 0 1px 3px rgba(0,0,0,.3);
  --tia-shadow-md: 0 4px 6px rgba(0,0,0,.25), 0 2px 4px rgba(0,0,0,.2);
  --tia-shadow-lg: 0 10px 20px rgba(0,0,0,.3), 0 4px 6px rgba(0,0,0,.2);
  --tia-shadow-xl: 0 20px 40px rgba(0,0,0,.4), 0 8px 16px rgba(0,0,0,.25);
  --tia-warning-light: #451a03;
  --tia-error-light:   #450a0a;
  --tia-info-light:    #082f49;
  --tia-success-light: #052e16;
}

/* ──────────────────────────────────────────────────────────
   INTRO TEXT
────────────────────────────────────────────────────────── */
.tia-wc-wrap .tia-wc-intro {
  margin-bottom: 20px;
  color: var(--tia-text-body);
  font-size: 15px;
  line-height: 1.65;
}

/* ──────────────────────────────────────────────────────────
   TOOL HEADER
────────────────────────────────────────────────────────── */
.tia-wc-wrap .tia-wc-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 20px;
}

.tia-wc-wrap .tia-wc-title {
  font-family: var(--tia-font-h);
  font-size: clamp(20px, 3vw, 26px);
  font-weight: 800;
  color: var(--tia-text);
  line-height: 1.2;
  letter-spacing: -0.4px;
  margin: 0 0 4px;
  padding: 0;
  border: none;
}

.tia-wc-wrap .tia-wc-title span { color: var(--tia-blue-400); }

.tia-wc-wrap .tia-wc-subtitle {
  color: var(--tia-text-body);
  font-size: 14px;
  line-height: 1.5;
  margin: 0;
}

.tia-wc-wrap .tia-wc-badge {
  flex-shrink: 0;
  background: var(--tia-blue-50);
  border: 1px solid var(--tia-blue-200);
  color: var(--tia-blue-600);
  font-size: 11px;
  font-weight: 700;
  font-family: var(--tia-font-h);
  padding: 4px 10px;
  border-radius: var(--tia-r-full);
  letter-spacing: .5px;
  text-transform: uppercase;
  white-space: nowrap;
  margin-top: 4px;
  line-height: 1;
}

/* ──────────────────────────────────────────────────────────
   ALERT BANNERS
────────────────────────────────────────────────────────── */
.tia-wc-wrap .tia-wc-alert {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 16px;
  border-radius: var(--tia-r-md);
  font-size: 13.5px;
  line-height: 1.5;
  margin-bottom: 16px;
  border: 1px solid transparent;
}

.tia-wc-wrap .tia-wc-alert-warn {
  background: var(--tia-warning-light);
  border-color: #FDE68A;
  color: #92400E;
}

.tia-wc-wrap .tia-wc-alert-error {
  background: var(--tia-error-light);
  border-color: #FECACA;
  color: #7F1D1D;
}

.tia-wc-wrap .tia-wc-alert-info {
  background: var(--tia-info-light);
  border-color: #BAE6FD;
  color: #0C4A6E;
}

.tia-wc-wrap .tia-wc-alert svg {
  flex-shrink: 0;
  margin-top: 1px;
}

/* ──────────────────────────────────────────────────────────
   SVG ICON BASE
────────────────────────────────────────────────────────── */
.tia-wc-wrap .tia-ic,
.tia-wc-gate-overlay .tia-ic {
  width: 16px;
  height: 16px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  display: inline-block;
  vertical-align: middle;
  flex-shrink: 0;
}

/* ──────────────────────────────────────────────────────────
   BUTTONS
────────────────────────────────────────────────────────── */
.tia-wc-wrap .tia-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--tia-font-b);
  font-size: 12.5px;
  font-weight: 500;
  padding: 6px 12px;
  border-radius: var(--tia-r-md);
  border: 1px solid var(--tia-border);
  background: var(--tia-surface);
  color: var(--tia-text-body);
  cursor: pointer;
  transition: background .15s, border-color .15s, color .15s, box-shadow .15s;
  line-height: 1;
  white-space: nowrap;
  text-decoration: none;
  -webkit-appearance: none;
  appearance: none;
  outline: none;
}

.tia-wc-wrap .tia-btn:hover {
  background: var(--tia-blue-50);
  border-color: var(--tia-blue-200);
  color: var(--tia-blue-500);
}

.tia-wc-wrap .tia-btn:focus-visible {
  box-shadow: 0 0 0 3px rgba(91,141,239,.25);
  border-color: var(--tia-blue-400);
}

.tia-wc-wrap .tia-btn-primary {
  background: var(--tia-blue-400);
  border-color: var(--tia-blue-400);
  color: #fff;
  font-weight: 600;
  border-radius: var(--tia-r-full);
  padding: 9px 22px;
  font-size: 13.5px;
  box-shadow: 0 2px 12px rgba(91,141,239,.35);
}
.tia-wc-wrap .tia-btn-primary:hover {
  background: var(--tia-blue-500);
  border-color: var(--tia-blue-500);
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 4px 18px rgba(91,141,239,.45);
}

.tia-wc-wrap .tia-btn-danger-ghost {
  background: transparent;
  border-color: transparent;
  color: var(--tia-text-muted);
}
.tia-wc-wrap .tia-btn-danger-ghost:hover {
  background: var(--tia-error-light);
  border-color: transparent;
  color: var(--tia-error);
}

/* ──────────────────────────────────────────────────────────
   EDITOR CARD
────────────────────────────────────────────────────────── */
.tia-wc-wrap .tia-wc-editor-card {
  background: var(--tia-surface);
  border: none;
  border-radius: var(--tia-r-xl);
  box-shadow: 0 2px 20px rgba(0,0,0,.07), 0 1px 4px rgba(0,0,0,.04);
  overflow: hidden;
  margin-bottom: 20px;
}

/* ── Toolbar ── */
.tia-wc-wrap .tia-wc-toolbar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 14px;
  border-bottom: none;
  background: var(--tia-slate-50);
  flex-wrap: wrap;
}

.tia-wc-wrap .tia-wc-toolbar-left  { display: flex; gap: 6px; flex: 1; flex-wrap: wrap; }
.tia-wc-wrap .tia-wc-toolbar-right { display: flex; gap: 6px; align-items: center; }

/* Live indicator */
.tia-wc-wrap .tia-wc-live-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--tia-success);
  flex-shrink: 0;
  animation: tia-pulse-dot 2s ease infinite;
}

@keyframes tia-pulse-dot {
  0%, 100% { box-shadow: 0 0 0 0 rgba(34,197,94,.4); }
  50%       { box-shadow: 0 0 0 4px rgba(34,197,94,0); }
}

.tia-wc-wrap .tia-wc-live-label {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--tia-success);
}

/* ── Textarea ── */
.tia-wc-wrap .tia-wc-textarea {
  display: block;
  width: 100%;
  min-height: 220px;
  max-height: 520px;
  padding: 18px 20px;
  resize: none;
  border: none;
  outline: none;
  font-family: var(--tia-font-b);
  font-size: 15px;
  line-height: 1.75;
  color: var(--tia-text);
  background: var(--tia-slate-50);
  -webkit-font-smoothing: antialiased;
}

.tia-wc-wrap .tia-wc-textarea::placeholder { color: var(--tia-text-muted); }

/* Char meter bar */
.tia-wc-wrap .tia-wc-char-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 16px;
  border-top: none;
  background: var(--tia-slate-50);
}

.tia-wc-wrap .tia-wc-char-meter {
  flex: 1;
  height: 4px;
  background: var(--tia-slate-200);
  border-radius: var(--tia-r-full);
  overflow: hidden;
}

.tia-wc-wrap .tia-wc-char-meter-fill {
  height: 100%;
  width: 0%;
  border-radius: var(--tia-r-full);
  background: linear-gradient(90deg, var(--tia-blue-400), var(--tia-blue-500));
  transition: width .3s ease, background .3s ease;
}
.tia-wc-wrap .tia-wc-char-meter-fill.tia-meter-warn  {
  background: linear-gradient(90deg, var(--tia-warning), #D97706);
}
.tia-wc-wrap .tia-wc-char-meter-fill.tia-meter-limit {
  background: linear-gradient(90deg, var(--tia-error), #DC2626);
}

.tia-wc-wrap .tia-wc-char-label {
  font-size: 12px;
  color: var(--tia-text-muted);
  font-family: var(--tia-font-m);
  white-space: nowrap;
}

/* ──────────────────────────────────────────────────────────
   PRIMARY STAT CARDS
────────────────────────────────────────────────────────── */
.tia-wc-wrap .tia-wc-stats-primary {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin-bottom: 16px;
}

.tia-wc-wrap .tia-stat-card {
  background: var(--tia-surface);
  border: none;
  border-radius: var(--tia-r-lg);
  padding: 16px 18px;
  box-shadow: 0 2px 12px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.04);
  position: relative;
  overflow: hidden;
  transition: box-shadow .2s, transform .2s;
}

.tia-wc-wrap .tia-stat-card:hover {
  box-shadow: var(--tia-shadow-md);
  transform: translateY(-1px);
}

.tia-wc-wrap .tia-stat-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--tia-blue-400), var(--tia-blue-200));
  opacity: 0;
  transition: opacity .2s;
}

.tia-wc-wrap .tia-stat-card:hover::before { opacity: 1; }

.tia-wc-wrap .tia-stat-featured {
  border-color: var(--tia-blue-200);
  background: linear-gradient(135deg, var(--tia-blue-50) 0%, var(--tia-surface) 60%);
}

.tia-wc-wrap .tia-stat-featured::before { opacity: 1; }

.tia-wc-wrap .tia-stat-icon {
  width: 32px;
  height: 32px;
  border-radius: var(--tia-r-md);
  background: var(--tia-blue-50);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 10px;
  color: var(--tia-blue-400);
}

.tia-wc-wrap .tia-stat-featured .tia-stat-icon { background: var(--tia-blue-100); }

.tia-wc-wrap .tia-stat-value {
  font-family: var(--tia-font-h);
  font-size: clamp(22px, 3.5vw, 30px);
  font-weight: 800;
  color: var(--tia-text);
  line-height: 1;
  margin-bottom: 4px;
  letter-spacing: -1px;
}

.tia-wc-wrap .tia-stat-featured .tia-stat-value { color: var(--tia-blue-600); }

.tia-wc-wrap .tia-stat-label {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--tia-text-muted);
  text-transform: uppercase;
  letter-spacing: .5px;
}

/* Empty state */
.tia-wc-wrap .tia-wc-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 48px 20px;
}

.tia-wc-wrap .tia-wc-empty-title {
  font-family: var(--tia-font-h);
  font-size: 16px;
  font-weight: 700;
  color: var(--tia-text-muted);
  margin-bottom: 6px;
}

.tia-wc-wrap .tia-wc-empty p {
  font-size: 13px;
  color: var(--tia-text-muted);
  margin: 0;
}

/* ──────────────────────────────────────────────────────────
   READING TIME ROW
────────────────────────────────────────────────────────── */
.tia-wc-wrap .tia-wc-reading-row {
  background: var(--tia-surface);
  border: none;
  border-radius: var(--tia-r-lg);
  padding: 14px 20px;
  box-shadow: 0 2px 12px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.04);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.tia-wc-wrap .tia-reading-label {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--tia-text-muted);
  text-transform: uppercase;
  letter-spacing: .5px;
  white-space: nowrap;
  display: flex;
  align-items: center;
  gap: 6px;
}

.tia-wc-wrap .tia-reading-label .tia-ic { color: var(--tia-blue-400); }

.tia-wc-wrap .tia-reading-chips {
  display: flex;
  gap: 0;
  flex: 1;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--tia-border);
}

.tia-wc-wrap .tia-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 8px 14px;
  border-radius: 0;
  font-size: 12.5px;
  font-weight: 500;
  font-family: var(--tia-font-b);
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  background: transparent;
  color: var(--tia-text-muted);
  cursor: pointer;
  transition: background .15s, border-color .15s, color .15s;
  -webkit-appearance: none;
  appearance: none;
  outline: none;
  white-space: nowrap;
}

.tia-wc-wrap .tia-chip:hover:not(.tia-chip-active) {
  background: var(--tia-slate-100);
  color: var(--tia-text-body);
  border-bottom-color: var(--tia-blue-200);
}

.tia-wc-wrap .tia-chip.tia-chip-active {
  background: var(--tia-surface);
  color: var(--tia-blue-400);
  font-weight: 600;
  border-bottom-color: var(--tia-blue-400);
}

.tia-wc-wrap .tia-chip:focus-visible {
  box-shadow: inset 0 0 0 2px rgba(91,141,239,.3);
}

.tia-wc-wrap .tia-chip-wpm {
  font-family: var(--tia-font-m);
  font-size: 10.5px;
  opacity: .75;
}

.tia-wc-wrap .tia-reading-time-display {
  font-family: var(--tia-font-h);
  font-size: clamp(18px, 3vw, 22px);
  font-weight: 800;
  color: var(--tia-blue-500);
  letter-spacing: -0.5px;
  white-space: nowrap;
}

.tia-wc-wrap .tia-reading-time-display span {
  font-size: 12px;
  font-weight: 500;
  color: var(--tia-text-muted);
  font-family: var(--tia-font-b);
  letter-spacing: 0;
  margin-left: 2px;
}

/* ──────────────────────────────────────────────────────────
   SECONDARY STATS
────────────────────────────────────────────────────────── */
.tia-wc-wrap .tia-wc-stats-secondary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px;
  margin-bottom: 20px;
}

.tia-wc-wrap .tia-stat-row-card {
  background: var(--tia-surface);
  border: none;
  border-radius: var(--tia-r-lg);
  padding: 14px 18px;
  box-shadow: 0 2px 12px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.04);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  transition: box-shadow .2s;
}

.tia-wc-wrap .tia-stat-row-card:hover { box-shadow: var(--tia-shadow-md); }

.tia-wc-wrap .tia-stat-row-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--tia-text-body);
  display: flex;
  align-items: center;
  gap: 7px;
}

.tia-wc-wrap .tia-stat-row-label .tia-ic { color: var(--tia-blue-400); }

.tia-wc-wrap .tia-stat-row-value {
  font-family: var(--tia-font-h);
  font-size: 18px;
  font-weight: 700;
  color: var(--tia-text);
  white-space: nowrap;
}

/* ──────────────────────────────────────────────────────────
   FREQUENCY CARD
────────────────────────────────────────────────────────── */
.tia-wc-wrap .tia-wc-freq-card {
  background: var(--tia-surface);
  border: none;
  border-radius: var(--tia-r-xl);
  box-shadow: 0 2px 20px rgba(0,0,0,.07), 0 1px 4px rgba(0,0,0,.04);
  overflow: hidden;
  margin-bottom: 20px;
}

.tia-wc-wrap .tia-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px 8px;
  border-bottom: none;
}

.tia-wc-wrap .tia-card-title {
  font-family: var(--tia-font-h);
  font-size: 14.5px;
  font-weight: 700;
  color: var(--tia-text);
  display: flex;
  align-items: center;
  gap: 8px;
}

.tia-wc-wrap .tia-card-title .tia-ic { color: var(--tia-blue-400); }

.tia-wc-wrap .tia-card-meta {
  font-size: 12px;
  color: var(--tia-text-muted);
}

.tia-wc-wrap .tia-card-body {
  padding: 16px 20px;
}

/* Frequency rows */
.tia-wc-wrap .tia-freq-row {
  display: grid;
  grid-template-columns: 24px 1fr 36px;
  align-items: center;
  gap: 10px;
  padding: 7px 0;
  border-bottom: 1px solid var(--tia-slate-100);
}

.tia-wc-wrap .tia-freq-row:last-child { border-bottom: none; }

.tia-wc-wrap .tia-freq-rank {
  font-family: var(--tia-font-m);
  font-size: 11px;
  color: var(--tia-text-muted);
  text-align: right;
}

.tia-wc-wrap .tia-freq-word-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.tia-wc-wrap .tia-freq-word {
  font-size: 13.5px;
  font-weight: 500;
  color: var(--tia-text);
  white-space: nowrap;
  min-width: 60px;
}

.tia-wc-wrap .tia-freq-bar {
  flex: 1;
  height: 6px;
  background: var(--tia-slate-100);
  border-radius: var(--tia-r-full);
  overflow: hidden;
}

.tia-wc-wrap .tia-freq-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--tia-blue-400), var(--tia-blue-500));
  border-radius: var(--tia-r-full);
  transition: width .4s ease;
}

.tia-wc-wrap .tia-freq-count {
  font-family: var(--tia-font-m);
  font-size: 11.5px;
  font-weight: 500;
  color: var(--tia-text-muted);
  text-align: right;
}

/* ──────────────────────────────────────────────────────────
   EXPORT ROW
────────────────────────────────────────────────────────── */
.tia-wc-wrap .tia-wc-export-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  background: var(--tia-surface);
  border: none;
  border-radius: var(--tia-r-lg);
  padding: 12px 18px;
  box-shadow: 0 2px 12px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.04);
  margin-bottom: 20px;
}

.tia-wc-wrap .tia-export-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--tia-text-body);
  display: flex;
  align-items: center;
  gap: 6px;
}

.tia-wc-wrap .tia-export-label .tia-ic { color: var(--tia-blue-400); }

.tia-wc-wrap .tia-export-btns {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

/* ──────────────────────────────────────────────────────────
   UPLOAD ZONE
────────────────────────────────────────────────────────── */
.tia-wc-wrap .tia-wc-upload-zone {
  position: relative;
  border: 2px dashed var(--tia-border-s);
  border-radius: var(--tia-r-xl);
  padding: 32px 20px;
  text-align: center;
  cursor: pointer;
  transition: border-color .2s, background .2s;
  background: var(--tia-surface);
  margin-bottom: 20px;
  outline: none;
}

.tia-wc-wrap .tia-wc-upload-zone:hover,
.tia-wc-wrap .tia-wc-upload-zone.tia-drag-over,
.tia-wc-wrap .tia-wc-upload-zone:focus-visible {
  border-color: var(--tia-blue-400);
  background: var(--tia-blue-50);
}

.tia-wc-wrap .tia-wc-upload-icon {
  width: 52px;
  height: 52px;
  border-radius: var(--tia-r-lg);
  background: var(--tia-blue-50);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 12px;
  color: var(--tia-blue-400);
  transition: background .2s;
}

.tia-wc-wrap .tia-wc-upload-zone:hover .tia-wc-upload-icon,
.tia-wc-wrap .tia-wc-upload-zone.tia-drag-over .tia-wc-upload-icon {
  background: var(--tia-blue-100);
}

.tia-wc-wrap .tia-upload-title {
  font-family: var(--tia-font-h);
  font-size: 14px;
  font-weight: 700;
  color: var(--tia-text);
  margin-bottom: 4px;
}

.tia-wc-wrap .tia-upload-sub {
  font-size: 12.5px;
  color: var(--tia-text-muted);
  line-height: 1.5;
}

.tia-wc-wrap .tia-upload-sub strong { color: var(--tia-text-body); }

.tia-wc-wrap .tia-upload-types {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-top: 12px;
}

.tia-wc-wrap .tia-type-badge {
  font-family: var(--tia-font-m);
  font-size: 10.5px;
  font-weight: 500;
  padding: 3px 8px;
  border-radius: var(--tia-r-sm);
  background: var(--tia-slate-100);
  color: var(--tia-slate-500);
  border: 1px solid var(--tia-border);
}

/* ──────────────────────────────────────────────────────────
   RELATED TOOLS
────────────────────────────────────────────────────────── */
.tia-wc-wrap .tia-wc-related {
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid var(--tia-border);
}

.tia-wc-wrap .tia-related-title {
  font-family: var(--tia-font-h);
  font-size: 12px;
  font-weight: 700;
  color: var(--tia-text-muted);
  text-transform: uppercase;
  letter-spacing: .7px;
  margin-bottom: 10px;
}

.tia-wc-wrap .tia-related-list {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.tia-wc-wrap .tia-related-tool {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: var(--tia-r-full);
  font-size: 12.5px;
  font-weight: 500;
  color: var(--tia-blue-500);
  background: var(--tia-blue-50);
  border: 1px solid var(--tia-blue-200);
  text-decoration: none;
  transition: background .15s, color .15s;
}

.tia-wc-wrap .tia-related-tool:hover {
  background: var(--tia-blue-100);
  color: var(--tia-blue-600);
}

/* ──────────────────────────────────────────────────────────
   GATE OVERLAY
────────────────────────────────────────────────────────── */
.tia-wc-gate-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, .5);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 9990;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  opacity: 0;
  transition: opacity .25s ease;
}

.tia-wc-gate-overlay.tia-gate-show {
  opacity: 1;
}

.tia-gate-modal {
  background: var(--tia-surface);
  border-radius: var(--tia-r-xl);
  box-shadow: var(--tia-shadow-xl);
  width: 100%;
  max-width: 420px;
  overflow: hidden;
  position: relative;
  transform: translateY(16px) scale(.97);
  transition: transform .25s ease;
}

.tia-wc-gate-overlay.tia-gate-show .tia-gate-modal {
  transform: none;
}

.tia-gate-modal-header {
  padding: 28px 28px 20px;
  text-align: center;
  border-bottom: none;
}

.tia-gate-icon {
  width: 56px;
  height: 56px;
  border-radius: var(--tia-r-xl);
  background: var(--tia-blue-50);
  border: 2px solid var(--tia-blue-200);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
  color: var(--tia-blue-400);
}

.tia-gate-title {
  font-family: var(--tia-font-h);
  font-size: 19px;
  font-weight: 800;
  color: var(--tia-text);
  margin-bottom: 6px;
  letter-spacing: -.3px;
}

.tia-gate-sub {
  font-size: 13.5px;
  color: var(--tia-text-body);
  line-height: 1.5;
}

.tia-gate-modal-body {
  padding: 22px 28px 26px;
}

/* Gate close button */
.tia-gate-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--tia-slate-100);
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--tia-text-muted);
  transition: background .15s, color .15s;
  padding: 0;
  outline: none;
}

.tia-gate-close:hover { background: var(--tia-slate-200); color: var(--tia-text-body); }
.tia-gate-close:focus-visible { box-shadow: 0 0 0 3px rgba(91,141,239,.25); }

/* Gate actions */
.tia-gate-actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.tia-gate-btn {
  width: 100%;
  padding: 12px 20px;
  border-radius: var(--tia-r-md);
  font-family: var(--tia-font-h);
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  border: none;
  transition: background .15s, color .15s, box-shadow .15s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-decoration: none;
  outline: none;
  -webkit-appearance: none;
  appearance: none;
}

.tia-gate-btn-primary {
  background: var(--tia-blue-400);
  color: #fff;
}
.tia-gate-btn-primary:hover { background: var(--tia-blue-500); }
.tia-gate-btn-primary:focus-visible { box-shadow: 0 0 0 3px rgba(91,141,239,.3); }

.tia-gate-btn-outline {
  background: transparent;
  color: var(--tia-text-body);
  border: 1.5px solid var(--tia-border-s);
}
.tia-gate-btn-outline:hover { background: var(--tia-slate-50); color: var(--tia-text); }

/* Divider */
.tia-gate-divider {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--tia-text-muted);
  font-size: 12px;
  margin: 4px 0;
}
.tia-gate-divider::before,
.tia-gate-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--tia-border);
}

/* Social login wrapper */
.tia-gate-social-login {
  margin-bottom: 12px;
}
.tia-gate-social-login > * {
  max-width: 100%;
}

/* WP login link */
.tia-gate-login-link {
  margin-bottom: 8px;
}

/* ──────────────────────────────────────────────────────────
   BLURRED STATE (when gate fires, blur underlying stats)
────────────────────────────────────────────────────────── */
.tia-wc-blurred {
  filter: blur(6px);
  pointer-events: none;
  user-select: none;
  -webkit-user-select: none;
}

/* ──────────────────────────────────────────────────────────
   RESPONSIVE
────────────────────────────────────────────────────────── */
/* ── tablet: center heading, stat grid 3 cols ── */
@media (max-width: 768px) {
  .tia-wc-wrap .tia-wc-header {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 8px;
  }
  .tia-wc-wrap .tia-wc-badge { align-self: center; }
  .tia-wc-wrap .tia-wc-subtitle { text-align: center; }
  .tia-wc-wrap .tia-wc-stats-primary { grid-template-columns: repeat(3, 1fr); }
  .tia-wc-wrap .tia-wc-stats-secondary { grid-template-columns: repeat(2, 1fr); }
}

/* ── 2 cols on large phone ── */
@media (max-width: 640px) {
  .tia-wc-wrap .tia-wc-stats-primary { grid-template-columns: repeat(2, 1fr); }
  .tia-wc-wrap .tia-wc-stats-secondary { grid-template-columns: repeat(2, 1fr); }
  .tia-wc-wrap .tia-wc-reading-row { flex-direction: column; align-items: flex-start; gap: 10px; }
  .tia-wc-wrap .tia-wc-export-row { flex-direction: column; align-items: flex-start; }
  .tia-wc-wrap .tia-reading-time-display { font-size: 20px; }
  .tia-gate-modal-header { padding: 22px 20px 16px; }
  .tia-gate-modal-body { padding: 18px 20px 22px; }
  .tia-wc-wrap .tia-wc-toolbar { padding: 8px 10px; gap: 4px; }
  .tia-wc-wrap .tia-btn { font-size: 12px; padding: 5px 10px; }
}

/* ── 2 cols on small phone ── */
@media (max-width: 420px) {
  .tia-wc-wrap .tia-wc-stats-primary { grid-template-columns: 1fr 1fr; }
  .tia-wc-wrap .tia-wc-stats-secondary { grid-template-columns: 1fr 1fr; }
  .tia-wc-wrap .tia-reading-chips { gap: 0; }
  .tia-wc-wrap .tia-chip { font-size: 11px; padding: 7px 8px; }
  .tia-wc-wrap .tia-chip-wpm { display: none; }
  .tia-wc-wrap .tia-wc-upload-zone { padding: 22px 16px; }
  .tia-wc-wrap .tia-stat-value { font-size: 22px; }
}

/* ──────────────────────────────────────────────────────────
   PRINT (hide controls, show text stats cleanly)
────────────────────────────────────────────────────────── */
@media print {
  .tia-wc-wrap .tia-wc-editor-card,
  .tia-wc-wrap .tia-wc-upload-zone,
  .tia-wc-wrap .tia-wc-export-row,
  .tia-wc-wrap .tia-wc-toolbar,
  .tia-wc-wrap .tia-wc-char-bar,
  .tia-wc-gate-overlay {
    display: none !important;
  }
  .tia-wc-wrap .tia-stat-card,
  .tia-wc-wrap .tia-stat-row-card {
    box-shadow: none;
    border: 1px solid #ddd;
  }
}

/* ──────────────────────────────────────────────────────────
   SEO CONTENT SECTION
────────────────────────────────────────────────────────── */
.tia-wc-wrap .tia-wc-seo-content {
  background: var(--tia-surface);
  border: none;
  border-radius: var(--tia-r-xl);
  box-shadow: 0 2px 20px rgba(0,0,0,.07), 0 1px 4px rgba(0,0,0,.04);
  padding: 32px 36px;
  margin-bottom: 20px;
  color: var(--tia-text-body);
  font-size: 15px;
  line-height: 1.7;
}

/* Scoped heading styles inside the SEO content block */
.tia-wc-wrap .tia-wc-seo-content h2 {
  font-family: var(--tia-font-h);
  font-size: clamp(18px, 2.5vw, 22px);
  font-weight: 800;
  color: var(--tia-text);
  margin: 0 0 12px;
  padding: 0;
  border: none;
  letter-spacing: -0.3px;
  line-height: 1.2;
}

.tia-wc-wrap .tia-wc-seo-content h3 {
  font-family: var(--tia-font-h);
  font-size: clamp(15px, 2vw, 17px);
  font-weight: 700;
  color: var(--tia-text);
  margin: 24px 0 8px;
  padding: 0;
  border: none;
  line-height: 1.3;
}

.tia-wc-wrap .tia-wc-seo-content h3:first-child { margin-top: 0; }

.tia-wc-wrap .tia-wc-seo-content p {
  margin: 0 0 14px;
  color: var(--tia-text-body);
}

.tia-wc-wrap .tia-wc-seo-content p:last-child { margin-bottom: 0; }

.tia-wc-wrap .tia-wc-seo-content ul,
.tia-wc-wrap .tia-wc-seo-content ol {
  margin: 0 0 14px 0;
  padding-left: 0;
  list-style: none;
}

.tia-wc-wrap .tia-wc-seo-content ul li,
.tia-wc-wrap .tia-wc-seo-content ol li {
  position: relative;
  padding-left: 20px;
  margin-bottom: 7px;
  color: var(--tia-text-body);
  font-size: 14.5px;
}

.tia-wc-wrap .tia-wc-seo-content ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 9px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--tia-blue-400);
}

.tia-wc-wrap .tia-wc-seo-content ol {
  counter-reset: tia-ol;
}

.tia-wc-wrap .tia-wc-seo-content ol li {
  counter-increment: tia-ol;
}

.tia-wc-wrap .tia-wc-seo-content ol li::before {
  content: counter(tia-ol) '.';
  position: absolute;
  left: 0;
  color: var(--tia-blue-400);
  font-weight: 700;
  font-size: 13px;
}

.tia-wc-wrap .tia-wc-seo-content strong { color: var(--tia-text); font-weight: 600; }
.tia-wc-wrap .tia-wc-seo-content em     { font-style: italic; color: var(--tia-text-body); }

.tia-wc-wrap .tia-wc-seo-content a {
  color: var(--tia-blue-500);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color .15s;
}

.tia-wc-wrap .tia-wc-seo-content a:hover { color: var(--tia-blue-600); }

@media (max-width: 640px) {
  .tia-wc-wrap .tia-wc-seo-content { padding: 24px 20px; }
}

/* ──────────────────────────────────────────────────────────
   FAQ ACCORDION SECTION
────────────────────────────────────────────────────────── */
.tia-wc-wrap .tia-wc-faq-section {
  margin-bottom: 24px;
}

.tia-wc-wrap .tia-wc-faq-heading {
  font-family: var(--tia-font-h);
  font-size: clamp(16px, 2.2vw, 19px);
  font-weight: 800;
  color: var(--tia-text);
  margin: 0 0 14px;
  padding: 0;
  border: none;
  letter-spacing: -0.3px;
}

.tia-wc-wrap .tia-wc-faq-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* ── details / summary ── */
.tia-wc-wrap .tia-wc-faq-item {
  background: var(--tia-surface);
  border: none;
  border-radius: var(--tia-r-lg);
  box-shadow: 0 2px 12px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.04);
  overflow: hidden;
  transition: box-shadow .2s;
}

.tia-wc-wrap .tia-wc-faq-item[open] {
  box-shadow: 0 4px 20px rgba(91,141,239,.12), 0 1px 4px rgba(0,0,0,.05);
}

.tia-wc-wrap .tia-wc-faq-q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 16px 20px;
  font-family: var(--tia-font-h);
  font-size: 15px;
  font-weight: 700;
  color: var(--tia-text);
  cursor: pointer;
  list-style: none;
  -webkit-appearance: none;
  appearance: none;
  user-select: none;
  transition: background .15s, color .15s;
  line-height: 1.4;
}

/* Remove default browser disclosure triangle */
.tia-wc-wrap .tia-wc-faq-q::-webkit-details-marker { display: none; }
.tia-wc-wrap .tia-wc-faq-q::marker               { display: none; }

/* Custom chevron via ::after */
.tia-wc-wrap .tia-wc-faq-q::after {
  content: '';
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  background-color: var(--tia-blue-400);
  border-radius: 50%;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 13px 13px;
  transition: transform .25s ease, background-color .15s;
}

.tia-wc-wrap .tia-wc-faq-item[open] .tia-wc-faq-q::after {
  transform: rotate(180deg);
  background-color: var(--tia-blue-500);
}

.tia-wc-wrap .tia-wc-faq-q:hover {
  background: var(--tia-blue-50);
  color: var(--tia-blue-600);
}

.tia-wc-wrap .tia-wc-faq-item[open] .tia-wc-faq-q {
  background: var(--tia-blue-50);
  color: var(--tia-blue-600);
}

.tia-wc-wrap .tia-wc-faq-q:focus-visible {
  outline: none;
  box-shadow: inset 0 0 0 3px rgba(91,141,239,.3);
}

/* Answer panel */
.tia-wc-wrap .tia-wc-faq-a {
  padding: 14px 20px 18px;
  font-size: 14.5px;
  color: var(--tia-text-body);
  line-height: 1.65;
  border-top: 1px solid var(--tia-border);
  background: var(--tia-slate-50);
  animation: tia-wc-faq-open .2s ease forwards;
}

@keyframes tia-wc-faq-open {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.tia-wc-wrap .tia-wc-faq-a p { margin: 0 0 10px; }
.tia-wc-wrap .tia-wc-faq-a p:last-child { margin-bottom: 0; }

/* ── Dark mode element overrides (badge + FAQ — token-flip alone insufficient) ── */

/* Badge: --tia-blue-600 not flipped → medium blue on dark navy fails WCAG AA */
.kt-dark-mode .tia-wc-wrap .tia-wc-badge,
html.wp-dark-mode-active .tia-wc-wrap .tia-wc-badge,
body.wp-dark-mode-active .tia-wc-wrap .tia-wc-badge,
html[data-theme="dark"] .tia-wc-wrap .tia-wc-badge,
.dark-mode .tia-wc-wrap .tia-wc-badge,
body[data-theme="dark"] .tia-wc-wrap .tia-wc-badge,
.is-dark .tia-wc-wrap .tia-wc-badge {
  background: rgba(91,141,239,.15);
  border-color: rgba(91,141,239,.30);
  color: #93BBFD;
}

/* FAQ hover/open: dark blue text on dark navy bg fails AA */
.kt-dark-mode .tia-wc-wrap .tia-wc-faq-q:hover,
html.wp-dark-mode-active .tia-wc-wrap .tia-wc-faq-q:hover,
body.wp-dark-mode-active .tia-wc-wrap .tia-wc-faq-q:hover,
html[data-theme="dark"] .tia-wc-wrap .tia-wc-faq-q:hover,
.dark-mode .tia-wc-wrap .tia-wc-faq-q:hover,
body[data-theme="dark"] .tia-wc-wrap .tia-wc-faq-q:hover,
.is-dark .tia-wc-wrap .tia-wc-faq-q:hover,
.kt-dark-mode .tia-wc-wrap .tia-wc-faq-item[open] .tia-wc-faq-q,
html.wp-dark-mode-active .tia-wc-wrap .tia-wc-faq-item[open] .tia-wc-faq-q,
body.wp-dark-mode-active .tia-wc-wrap .tia-wc-faq-item[open] .tia-wc-faq-q,
html[data-theme="dark"] .tia-wc-wrap .tia-wc-faq-item[open] .tia-wc-faq-q,
.dark-mode .tia-wc-wrap .tia-wc-faq-item[open] .tia-wc-faq-q,
body[data-theme="dark"] .tia-wc-wrap .tia-wc-faq-item[open] .tia-wc-faq-q,
.is-dark .tia-wc-wrap .tia-wc-faq-item[open] .tia-wc-faq-q { background: rgba(91,141,239,.20) !important; color: #93BBFD !important; }

@media (max-width: 640px) {
  .tia-wc-wrap .tia-wc-faq-q  { padding: 14px 16px; font-size: 14px; }
  .tia-wc-wrap .tia-wc-faq-a  { padding: 12px 16px 16px; }
}

/* ──────────────────────────────────────────────────────────
   END OF FILE
   Dark mode: handled via CSS var overrides on @media and
   body-class selectors above. See architecture comment at top.
────────────────────────────────────────────────────────── */
