/**
 * elementor-sections.css (Batch 19)
 *
 * Visual styling for the QooKey Elementor section widgets
 * (class-qk-hero-widget.php, class-qk-feature-grid-widget.php,
 * class-qk-testimonial-widget.php, class-qk-cta-section-widget.php,
 * class-qk-region-banner-widget.php, class-qk-news-list-widget.php).
 * Loads after design-tokens.css + responsive-base.css.
 *
 * Kept in ONE small file (not per-widget) per performance governance —
 * these widgets only render `.qk-*` classes (no inline styles, no
 * per-widget CSS files), and this file is the single stylesheet that gives
 * those classes their appearance. Registered always-on alongside
 * responsive-base.css: it is small (~1.5KB) and every QooKey marketing page
 * (qookey.com) uses at least one of these section widgets, so conditional
 * enqueueing would add complexity without a meaningful payload saving.
 */

/* Hero (class-qk-hero-widget.php) */
.qk-hero {
  padding-block: var(--qk-space-7);
  text-align: center;
}

.qk-hero h1 {
  font-size: var(--qk-font-size-2xl);
  line-height: var(--qk-line-height-tight);
  color: var(--qk-color-neutral-900);
  margin: 0 0 var(--qk-space-3);
}

.qk-hero p {
  font-size: var(--qk-font-size-lg);
  color: var(--qk-color-neutral-700);
  margin: 0 0 var(--qk-space-5);
}

.qk-hero__cta {
  display: inline-flex;
  padding-inline: var(--qk-space-5);
  border-radius: var(--qk-radius-md);
  background: var(--qk-color-primary-500);
  color: var(--qk-color-neutral-0);
  font-weight: 600;
  text-decoration: none;
  transition: background var(--qk-motion-duration-fast) var(--qk-motion-ease-standard);
}

.qk-hero__cta:hover,
.qk-hero__cta:focus-visible {
  background: var(--qk-color-primary-700);
}

/* Secondary hero CTA (Batch 23, item #80) — outline style, sits next to the
   primary filled CTA (e.g. "How it works" beside "Browse cars"). */
.qk-hero__cta--secondary {
  background: transparent;
  border: 1px solid var(--qk-color-primary-500);
  color: var(--qk-color-primary-500);
  margin-inline-start: var(--qk-space-2);
}

.qk-hero__cta--secondary:hover,
.qk-hero__cta--secondary:focus-visible {
  background: var(--qk-color-primary-50);
  color: var(--qk-color-primary-700);
  border-color: var(--qk-color-primary-700);
}

/* Feature grid (class-qk-feature-grid-widget.php) */
.qk-feature-card {
  background: var(--qk-color-neutral-0);
  border: 1px solid var(--qk-color-neutral-100);
  border-radius: var(--qk-radius-lg);
  padding: var(--qk-space-5);
}

.qk-feature-card .dashicons {
  font-size: var(--qk-font-size-xl);
  width: var(--qk-font-size-xl);
  height: var(--qk-font-size-xl);
  color: var(--qk-color-primary-500);
  margin-bottom: var(--qk-space-3);
}

.qk-feature-card h3 {
  font-size: var(--qk-font-size-lg);
  margin: 0 0 var(--qk-space-2);
  color: var(--qk-color-neutral-900);
}

.qk-feature-card p {
  margin: 0;
  color: var(--qk-color-neutral-700);
}

/* Testimonials (class-qk-testimonial-widget.php) */
.qk-testimonial-card {
  background: var(--qk-color-primary-50);
  border-radius: var(--qk-radius-lg);
  padding: var(--qk-space-5);
  margin: 0;
}

.qk-testimonial-card p {
  font-size: var(--qk-font-size-base);
  color: var(--qk-color-neutral-900);
  margin: 0 0 var(--qk-space-3);
}

.qk-testimonial-card footer {
  font-size: var(--qk-font-size-sm);
  color: var(--qk-color-neutral-700);
}

/* CTA section (class-qk-cta-section-widget.php) */
.qk-cta-section {
  padding-block: var(--qk-space-6);
  text-align: center;
  background: var(--qk-color-primary-900);
  border-radius: var(--qk-radius-lg);
}

.qk-cta-section h2 {
  color: var(--qk-color-neutral-0);
  font-size: var(--qk-font-size-xl);
  margin: 0 0 var(--qk-space-2);
}

.qk-cta-section p {
  color: var(--qk-color-primary-100);
  margin: 0 0 var(--qk-space-4);
}

.qk-cta-section__button {
  display: inline-flex;
  padding-inline: var(--qk-space-5);
  border-radius: var(--qk-radius-md);
  background: var(--qk-color-accent-500);
  color: var(--qk-color-neutral-900);
  font-weight: 600;
  text-decoration: none;
  transition: background var(--qk-motion-duration-fast) var(--qk-motion-ease-standard);
}

.qk-cta-section__button:hover,
.qk-cta-section__button:focus-visible {
  background: var(--qk-color-primary-300);
}

/* Region banner (class-qk-region-banner-widget.php) */
.qk-region-banner {
  padding-block: var(--qk-space-6) var(--qk-space-5);
}

.qk-region-banner__badge {
  display: inline-flex;
  padding-inline: var(--qk-space-3);
  padding-block: var(--qk-space-1);
  border-radius: var(--qk-radius-sm);
  background: var(--qk-color-primary-50);
  color: var(--qk-color-primary-700);
  font-size: var(--qk-font-size-xs);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-bottom: var(--qk-space-3);
}

.qk-region-banner h1 {
  font-size: var(--qk-font-size-2xl);
  line-height: var(--qk-line-height-tight);
  color: var(--qk-color-neutral-900);
  margin: 0 0 var(--qk-space-2);
}

.qk-region-banner p {
  font-size: var(--qk-font-size-lg);
  color: var(--qk-color-neutral-700);
  margin: 0;
}

/* Region visual governance (Batch 20, item #19) — mirrors
   regionAccentColorValue() in
   lib/features/regions/presentation/region_badge.dart 1:1 by hex value, so
   a region's color is identical in WP-rendered and Flutter-rendered UI.
   Apply alongside .qk-region-banner__badge (e.g.
   class="qk-region-banner__badge qk-region-badge--goa") to recolor the
   badge per region; default badge color (primary) is used if no
   .qk-region-badge--* class is present. */
.qk-region-badge--goa {
  background: rgba(31, 122, 240, 0.12); /* --qk-color-primary-500 */
  color: var(--qk-color-primary-700);
}

.qk-region-badge--ka {
  background: rgba(255, 138, 31, 0.12); /* --qk-color-accent-500 */
  color: #b35e00;
}

.qk-region-badge--mh {
  background: rgba(31, 157, 85, 0.12); /* --qk-color-success-500 */
  color: var(--qk-color-success-500);
}

.qk-region-badge--kl {
  background: rgba(224, 168, 0, 0.12); /* --qk-color-warning-500 */
  color: #8a6800;
}

/* News list (class-qk-news-list-widget.php, Batch 21) */
.qk-news-list {
  padding-block: var(--qk-space-6);
}

.qk-news-list__empty {
  color: var(--qk-color-neutral-700);
}

.qk-news-card {
  background: var(--qk-color-neutral-0);
  border: 1px solid var(--qk-color-neutral-100);
  border-radius: var(--qk-radius-lg);
  padding: var(--qk-space-5);
}

.qk-news-card__thumb {
  display: block;
  margin: calc(var(--qk-space-5) * -1) calc(var(--qk-space-5) * -1) var(--qk-space-3);
  border-radius: var(--qk-radius-lg) var(--qk-radius-lg) 0 0;
  overflow: hidden;
}

.qk-news-card__thumb img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.qk-news-card h3 {
  font-size: var(--qk-font-size-lg);
  margin: 0 0 var(--qk-space-1);
}

.qk-news-card h3 a {
  color: var(--qk-color-neutral-900);
  text-decoration: none;
}

.qk-news-card h3 a:hover,
.qk-news-card h3 a:focus-visible {
  color: var(--qk-color-primary-500);
}

.qk-news-card__date {
  display: block;
  font-size: var(--qk-font-size-xs);
  color: var(--qk-color-neutral-500);
  margin-bottom: var(--qk-space-2);
}

.qk-news-card p {
  color: var(--qk-color-neutral-700);
  margin: 0 0 var(--qk-space-2);
}

.qk-news-card__video {
  font-size: var(--qk-font-size-sm);
  font-weight: 600;
  color: var(--qk-color-primary-500);
  text-decoration: none;
}

.qk-news-card__video:hover,
.qk-news-card__video:focus-visible {
  color: var(--qk-color-primary-700);
}

/* Operational coordination layer (item #87) — shared state badge colors.
   Mirrors operationalStateColorValue() in
   lib/features/vehicle_listings/presentation/operational_state_badge.dart
   1:1 by hex value, so a listing's operational state reads as the same
   color in WP-rendered and Flutter-rendered UI. Apply alongside a generic
   badge class (e.g. class="qk-op-state qk-op-state--available"). */
.qk-op-state {
  display: inline-flex;
  padding-inline: var(--qk-space-2);
  padding-block: calc(var(--qk-space-1) / 2);
  border-radius: var(--qk-radius-sm);
  font-size: var(--qk-font-size-xs);
  font-weight: 600;
  letter-spacing: 0.5px;
}

.qk-op-state--available {
  background: rgba(31, 157, 85, 0.12); /* --qk-color-success-500 */
  color: var(--qk-color-success-500);
}

.qk-op-state--discussing {
  background: rgba(224, 168, 0, 0.12); /* --qk-color-warning-500 */
  color: #8a6800;
}

.qk-op-state--occupied {
  background: rgba(209, 55, 63, 0.12); /* --qk-color-danger-500 */
  color: var(--qk-color-danger-500);
}

.qk-op-state--future_occupied {
  background: rgba(255, 138, 31, 0.12); /* --qk-color-accent-500 */
  color: #b35e00;
}

.qk-op-state--returning {
  background: rgba(124, 92, 255, 0.12); /* --qk-color-violet-500 */
  color: var(--qk-color-violet-500);
}

.qk-op-state--offline {
  background: rgba(138, 145, 155, 0.12); /* --qk-color-neutral-500 */
  color: var(--qk-color-neutral-700);
}

/* Help-connect indicator — additive, never replaces the availability color
   above (OPERATIONAL_COORDINATION_LAYER.md §8). */
.qk-op-state--help-connect {
  background: rgba(31, 122, 240, 0.12); /* --qk-color-primary-500 */
  color: var(--qk-color-primary-500);
  margin-inline-start: var(--qk-space-1);
}

/* How It Works (class-qk-how-it-works-widget.php, item #94) — numbered
   storytelling steps following the hero. Reuses .qk-grid; step cards get a
   large numbered badge instead of an icon. */
.qk-how-it-works {
  padding-block: var(--qk-space-7);
  text-align: center;
}

.qk-how-it-works h2 {
  font-size: var(--qk-font-size-xl);
  color: var(--qk-color-neutral-900);
  margin: 0 0 var(--qk-space-5);
}

.qk-how-it-works__grid {
  text-align: left;
}

@media (min-width: 1024px) {
  .qk-how-it-works__grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.qk-step-card {
  background: var(--qk-color-neutral-0);
  border: 1px solid var(--qk-color-neutral-100);
  border-radius: var(--qk-radius-lg);
  padding: var(--qk-space-5);
}

.qk-step-card__number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--qk-space-6);
  height: var(--qk-space-6);
  border-radius: var(--qk-radius-md);
  background: var(--qk-color-primary-50);
  color: var(--qk-color-primary-700);
  font-weight: 700;
  font-size: var(--qk-font-size-lg);
  margin-bottom: var(--qk-space-3);
}

.qk-step-card h3 {
  font-size: var(--qk-font-size-base);
  margin: 0 0 var(--qk-space-1);
  color: var(--qk-color-neutral-900);
}

.qk-step-card p {
  margin: 0;
  color: var(--qk-color-neutral-700);
  font-size: var(--qk-font-size-sm);
}

/* News article single page (class-qk-news-article-widget.php, item #100) —
   complements .qk-news-card (list/archive) above. */
.qk-news-article {
  padding-block: var(--qk-space-6);
  max-width: 720px;
}

.qk-news-article__category {
  display: inline-flex;
  padding-inline: var(--qk-space-3);
  padding-block: var(--qk-space-1);
  border-radius: var(--qk-radius-sm);
  background: var(--qk-color-primary-50);
  color: var(--qk-color-primary-700);
  font-size: var(--qk-font-size-xs);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-bottom: var(--qk-space-3);
}

.qk-news-article__title {
  font-size: var(--qk-font-size-2xl);
  line-height: var(--qk-line-height-tight);
  color: var(--qk-color-neutral-900);
  margin: 0 0 var(--qk-space-2);
}

.qk-news-article__date {
  display: block;
  font-size: var(--qk-font-size-sm);
  color: var(--qk-color-neutral-500);
  margin-bottom: var(--qk-space-4);
}

.qk-news-article__thumb {
  margin-bottom: var(--qk-space-4);
  border-radius: var(--qk-radius-lg);
  overflow: hidden;
}

.qk-news-article__thumb img {
  display: block;
  width: 100%;
  height: auto;
}

.qk-news-article__video {
  display: inline-block;
  margin-bottom: var(--qk-space-4);
}

.qk-news-article__body {
  font-size: var(--qk-font-size-base);
  line-height: var(--qk-line-height-base);
  color: var(--qk-color-neutral-700);
}

.qk-news-article__body p {
  margin: 0 0 var(--qk-space-4);
}
