/* =============================================================================
   King Locksmith Reviews — widget.css
   All colour / spacing / shape values consumed from CSS custom properties
   set inline on .klr-widget by the PHP renderer. Nothing here is hardcoded.
   ============================================================================= */

/* ── Root ──────────────────────────────────────────────────────────────────── */
.klr-widget {
  /* Inherits container width from Elementor column — never override width */
  box-sizing: border-box;
  width: 100%;

  background: var(--klr-bg);
  border-radius: var(--klr-radius-w);
  padding: var(--klr-pad-v) var(--klr-pad-h);
  color: var(--klr-text-hi);
  font-family: var(--klr-font);
  font-size: var(--klr-font-base);
  line-height: 1.55;
  position: relative;
  overflow: hidden;
}

.klr-widget *,
.klr-widget *::before,
.klr-widget *::after {
  box-sizing: border-box;
}

/* ── Header ────────────────────────────────────────────────────────────────── */
.klr-header {
  text-align: center;
  margin-bottom: 32px;
  position: relative;
}

.klr-badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--klr-accent);
  background: var(--klr-accent-dim);
  border: 1px solid color-mix(in srgb, var(--klr-accent) 30%, transparent);
  padding: 4px 14px;
  border-radius: 20px;
  margin-bottom: 12px;
}

.klr-title {
  margin: 0 0 8px;
  font-size: var(--klr-font-title);
  font-weight: 700;
  color: var(--klr-text-hi);
  line-height: 1.2;
}

.klr-subtitle {
  margin: 0;
  font-size: calc(var(--klr-font-base) - 1px);
  color: var(--klr-text-mid);
  font-weight: 300;
}

/* ── Platform summary bar ──────────────────────────────────────────────────── */
.klr-platforms {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  background: var(--klr-surface);
  border: 1px solid var(--klr-border);
  border-radius: var(--klr-radius-c);
  overflow: hidden;
  margin-top: 22px;
}

.klr-plat-item {
  flex: 1;
  min-width: 120px;
  padding: 14px 16px;
  text-align: center;
  border-right: 1px solid var(--klr-border);
  transition: background .2s ease;
}
.klr-plat-item:last-child { border-right: none; }
.klr-plat-item:hover { background: var(--klr-card-hover); }

.klr-plat-name {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 5px;
}

.klr-plat-meta {
  font-size: 11px;
  color: var(--klr-text-mid);
  margin-top: 4px;
}
.klr-plat-meta strong {
  color: var(--klr-text-hi);
  font-weight: 600;
  margin-right: 2px;
}

/* ── Total row ─────────────────────────────────────────────────────────────── */
.klr-total {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-top: 12px;
  font-size: var(--klr-font-total, 13px);
  color: var(--klr-total-text);
}

/* ── Stars ─────────────────────────────────────────────────────────────────── */
.klr-stars { display: flex; align-items: center; gap: 2px; }
.klr-star  { font-size: 14px; line-height: 1; transition: color .15s; }

/* ── Filter tabs ───────────────────────────────────────────────────────────── */
.klr-filters {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 7px;
  margin-bottom: 20px;
}

.klr-filter {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 15px;
  border-radius: 20px;
  border: 1px solid var(--klr-border);
  background: var(--klr-filter-bg);
  color: var(--klr-filter-text);
  font-family: var(--klr-font);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: background .18s, border-color .18s, color .18s;
  line-height: 1;
}
.klr-filter:hover {
  border-color: color-mix(in srgb, var(--klr-filter-active-text) 25%, transparent);
  color: var(--klr-filter-active-text);
}
.klr-filter.active {
  background: var(--klr-filter-active-bg);
  border-color: color-mix(in srgb, var(--klr-filter-active-text) 20%, transparent);
  color: var(--klr-filter-active-text);
}

/* ── Carousel ──────────────────────────────────────────────────────────────── */
.klr-carousel { position: relative; }

.klr-track-wrap { overflow: hidden; border-radius: var(--klr-radius-c); padding: 20px 0; }

.klr-track {
  display: flex;
  gap: var(--klr-gap);
  transition: transform var(--klr-speed) cubic-bezier(.4,0,.2,1);
  will-change: transform;
  align-items: stretch;
}

/* ── Cards ─────────────────────────────────────────────────────────────────── */
.klr-card {
  flex: 0 0 calc(33.333% - var(--klr-gap) * 2 / 3);
  background: var(--klr-card);
  border: 1px solid var(--klr-border);
  border-radius: var(--klr-radius-c);
  padding: var(--klr-card-pad);
  box-shadow: var(--klr-card-shadow, none);
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: background .2s ease, transform .25s ease, border-color .2s ease, box-shadow .2s ease;
}
.klr-card:hover {
  background: var(--klr-card-hover);
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--klr-text-hi) 12%, transparent);
}

/* Responsive overrides driven by data attributes on the JS side */
.klr-widget[data-desktop="2"] .klr-card { flex: 0 0 calc(50% - var(--klr-gap) / 2); }
.klr-widget[data-desktop="1"] .klr-card { flex: 0 0 100%; }

.klr-card-top {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

/* Avatar */
.klr-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 700;
  flex-shrink: 0;
  color: #fff;
  flex-shrink: 0;
  letter-spacing: -.5px;
}
.klr-avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.klr-avatar-initials {
  line-height: 1;
  user-select: none;
}


.klr-reviewer { flex: 1; min-width: 0; }
.klr-reviewer-name {
  font-size: calc(var(--klr-font-base) - 1px);
  font-weight: 600;
  color: var(--klr-text-hi);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.klr-reviewer-date {
  font-size: 11px;
  color: var(--klr-text-lo);
  margin-top: 2px;
}

.klr-card-platform { opacity: .65; flex-shrink: 0; }

/* Review text */
.klr-card-text {
  font-size: calc(var(--klr-font-base) - 2px);
  color: var(--klr-text-mid);
  line-height: 1.65;
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: var(--klr-clamp, 5);
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin: 0;
}

/* Card footer */
.klr-card-footer {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  color: var(--klr-text-lo);
  padding-top: 10px;
  border-top: 1px solid var(--klr-border);
  margin-top: auto;
}

.klr-verified {
  display: flex;
  align-items: center;
  gap: 3px;
  color: #00b67a;
  margin-left: auto;
  font-size: 11px;
}

/* shared icon sizing */
.klr-icon { display: inline-block; vertical-align: middle; flex-shrink: 0; }

/* ── Navigation wrapper ─────────────────────────────────────────────────────── */
/* ── Navigation — single horizontal row: [← ] [• • • •] [ →] ──────────────────
   All items sit on one line. Dots stay uniform 8×8 px circles — active dot
   uses accent colour only (no width expansion). Arrows are accent-filled
   circles with bold, clearly-visible chevrons.                                */
.klr-nav {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: nowrap !important;
  margin-top: 24px !important;
  padding: 0 !important;
  gap: 0 !important;
}

/* Both arrows sit together on the right */
.klr-nav-arrows {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 10px !important;
  flex-shrink: 0 !important;
}

/* ── Arrow buttons ────────────────────────────────────────────────────────────
   Full !important coverage so theme button resets (padding, min-height, etc.)
   cannot distort the circles.                                                  */
.klr-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 42px !important;
  height: 42px !important;
  min-width: 42px !important;
  min-height: 42px !important;
  max-width: 42px !important;
  max-height: 42px !important;
  border-radius: 50% !important;
  border: none !important;
  outline: none;
  background: var(--klr-nav-bg) !important;
  color: var(--klr-nav-icon) !important;
  cursor: pointer !important;
  padding: 0 !important;
  margin: 0 !important;
  flex-shrink: 0 !important;
  line-height: 1 !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
  transition: filter .18s ease, transform .14s ease, opacity .2s ease;
  text-decoration: none !important;
  font-size: 0 !important;
}
.klr-btn svg {
  display: block !important;
  flex-shrink: 0 !important;
  width: 20px !important;
  height: 20px !important;
  pointer-events: none;
  /* Force stroke color — theme SVG overrides cannot win against this */
  stroke: var(--klr-nav-icon) !important;
  fill: none !important;
  color: var(--klr-nav-icon) !important;
}
.klr-btn svg path,
.klr-btn svg line,
.klr-btn svg polyline {
  stroke: var(--klr-nav-icon) !important;
  fill: none !important;
}
.klr-btn:hover:not(:disabled) {
  filter: brightness(1.1);
  transform: scale(1.06);
}
.klr-btn:active:not(:disabled) { transform: scale(.93); }
.klr-btn:disabled {
  opacity: .3 !important;
  cursor: not-allowed !important;
  pointer-events: none;
}
.klr-btn:focus-visible {
  outline: 2px solid var(--klr-accent) !important;
  outline-offset: 4px;
}

/* ── Dots — uniform circles, active = accent colour only (no size change) ──────
   Fixed 8×8 px. Active dot changes colour, NOT size, so the row never shifts. */
.klr-dots {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 7px !important;
  flex-shrink: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
}
.klr-dot {
  display: block !important;
  width: 8px !important;
  height: 8px !important;
  min-width: 8px !important;
  min-height: 8px !important;
  max-width: 8px !important;
  max-height: 8px !important;
  border-radius: 50% !important;
  background: var(--klr-dot) !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  cursor: pointer !important;
  flex-shrink: 0 !important;
  box-sizing: border-box !important;
  font-size: 0 !important;
  transition: background .25s ease, opacity .25s ease, transform .2s ease;
}
.klr-dot.active {
  background: var(--klr-dot-active) !important;
  transform: scale(1.25);
}
.klr-dot.near  { opacity: .55 !important; }
.klr-dot.far   { opacity: .3 !important; }
.klr-dot:hover:not(.active) {
  background: var(--klr-dot-active) !important;
  opacity: .7 !important;
  opacity: 1 !important;
}
.klr-dot:focus-visible {
  outline: 2px solid var(--klr-accent);
  outline-offset: 3px;
}

/* ── Page counter (mobile only) ─────────────────────────────────────────────── */
.klr-page-count {
  display: none;
  font-size: 12px;
  font-weight: 600;
  color: var(--klr-text-mid);
  min-width: 38px;
  text-align: center;
  letter-spacing: .02em;
  flex-shrink: 0;
}

/* ── Empty state ───────────────────────────────────────────────────────────── */
.klr-empty {
  text-align: center;
  padding: 48px 20px;
  color: var(--klr-text-mid);
  font-size: var(--klr-font-base);
  line-height: 1.7;
}

/* ── Responsive ────────────────────────────────────────────────────────────── */
@media (max-width: 600px) {
  .klr-widget { padding: var(--klr-pad-v) calc(var(--klr-pad-h) * .6); }
  .klr-card   { flex: 0 0 100% !important; max-width: 100% !important; }
  .klr-plat-item { min-width: 90px; padding: 10px 10px; }
  .klr-plat-name span { display: none; }

  /* Dots stay same shape on mobile, just slightly smaller */
  .klr-dot            { width: 7px !important; height: 7px !important; min-width: 7px !important; min-height: 7px !important; max-width: 7px !important; max-height: 7px !important; }
  .klr-dots           { gap: 6px !important; }

  /* Arrows slightly smaller on mobile */
  .klr-btn            { width: 36px !important; height: 36px !important; min-width: 36px !important; min-height: 36px !important; max-width: 36px !important; max-height: 36px !important; }
  .klr-btn svg        { width: 17px !important; height: 17px !important; }
  .klr-nav-arrows     { gap: 8px !important; }
}

@media (min-width: 601px) and (max-width: 820px) {
  .klr-card { flex: 0 0 calc(50% - var(--klr-gap) / 2) !important; }
  .klr-btn  { width: 40px !important; height: 40px !important; min-width: 40px !important; min-height: 40px !important; max-width: 40px !important; max-height: 40px !important; }
}

/* ── Accessibility: reduced motion ─────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .klr-track   { transition: none; }
  .klr-card    { transition: none; }
  .klr-dot     { transition: none; }
}

/* ── Test mode banner ──────────────────────────────────────────────────────── */
.klr-test-banner {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(251, 191, 36, 0.12);
  border: 1px solid rgba(251, 191, 36, 0.4);
  color: #fbbf24;
  font-size: 12px;
  font-weight: 500;
  padding: 9px 14px;
  border-radius: 8px;
  margin-bottom: 24px;
  line-height: 1.4;
}
.klr-test-banner strong { font-weight: 700; }
.klr-test-banner em     { font-style: normal; opacity: .8; }
