/* ================================================================
   JRLG KIOSK - LAYOUT
   Portrait 4K (2160x3840). App shell: header / screen / footer.
   ================================================================ */

#app {
  position: fixed;
  inset: 0;
  display: grid;
  grid-template-rows: auto 1fr auto;
}

/* ---- IDLE MODE ------------------------------------------------- */

#idle-layer {
  position: fixed;
  inset: 0;
  background: var(--bg);
  display: grid;
  place-items: center;
  z-index: 100;
  transition: opacity var(--t-slow) var(--ease-in-out);
}
#idle-layer.hidden { opacity: 0; pointer-events: none; }

#idle-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  background: var(--bg);
}

#attract-overlay {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: end center;
  padding-bottom: 80px;
  pointer-events: none;
  background: linear-gradient(to top, rgba(0,0,0,0.55) 0%, transparent 30%);
}

#attract-overlay .cta {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 64px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg);
  padding: 36px 96px;
  border: 3px solid var(--fg);
  border-radius: 999px;
  animation: attract-pulse 2.4s ease-in-out infinite;
  text-shadow: 0 4px 24px rgba(0,0,0,0.8);
}

@keyframes attract-pulse {
  0%, 100% { opacity: 0.75; transform: scale(1); }
  50%      { opacity: 1;    transform: scale(1.04); }
}

/* ---- INTERACTIVE MODE ----------------------------------------- */

#header {
  height: 220px;
  padding: 40px var(--screen-padding);
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}
#header .logo { height: 140px; width: auto; }
#header .reset-btn {
  font-size: var(--fs-caption);
  color: var(--fg-muted);
  padding: 20px 36px;
  border: 1px solid var(--border-strong);
  border-radius: 999px;
}

#screen {
  position: relative;
  overflow-y: auto;
  background: var(--bg);
}

/* ---- FOOTER (Call CTA + Tabs) --------------------------------- */

#footer {
  background: var(--bg-elev-1);
  border-top: 1px solid var(--border);
}

#call-cta {
  padding: 32px var(--screen-padding);
  text-align: center;
  font-size: 44px;
  font-family: var(--font-serif);
  letter-spacing: 0.02em;
  color: var(--fg);
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}
#call-cta .label { color: var(--fg-muted); margin-right: 24px; }
#call-cta .number { font-weight: 600; letter-spacing: 0.04em; }

#tabs {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  height: 260px;
}
#tabs .tab {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 18px;
  color: var(--fg-muted);
  font-size: var(--fs-nav);
  font-weight: 500;
  letter-spacing: 0.04em;
  border-right: 1px solid var(--border);
  transition: background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}
#tabs .tab:last-child { border-right: none; }
#tabs .tab:active,
#tabs .tab.active { background: var(--bg-elev-2); color: var(--fg); }
#tabs .tab .icon { font-size: 72px; line-height: 1; }
#tabs .tab .label { text-transform: uppercase; }

/* ---- SCREEN TRANSITIONS --------------------------------------- */

.screen-view {
  position: absolute;
  inset: 0;
  padding: var(--screen-padding);
  opacity: 0;
  pointer-events: none;
  transform: translateY(24px);
  transition: opacity var(--t-med) var(--ease-out), transform var(--t-med) var(--ease-out);
}
.screen-view.active {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.hidden { display: none !important; }
.stack > * + * { margin-top: 48px; }


/* ================================================================
   MAP SCREEN
   ================================================================ */
.screen.partners-screen,
.screen.events-screen,
.screen.about-screen,
.screen.why-screen,
.screen.results-screen {
  padding: var(--screen-padding);
  height: 100%;
  overflow: auto;
}

/* Map screen: vertical flex — hero on top, map fills the middle, stats as a compact strip at the bottom. No blank void under stats. */
.screen.map-screen {
  padding: var(--screen-padding);
  height: 100%;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.screen.map-screen .map-hero { flex: 0 0 auto; }
.screen.map-screen .map-subtitle { margin-top: 16px; }
.screen.map-screen .map-container { flex: 1 1 auto; margin-top: 0; aspect-ratio: auto; min-height: 0; }
.screen.map-screen #map-stats { flex: 0 0 auto; margin-top: 0; }

.map-eyebrow,
.partners-eyebrow { font-family: var(--font-sans); font-size: var(--fs-caption); text-transform: uppercase; letter-spacing: 0.16em; color: var(--fg-dim); }
.map-title,
.partners-title { margin-top: 16px; }
.map-subtitle,
.partners-subtitle { margin-top: 24px; color: var(--fg-muted); font-size: var(--fs-h3); max-width: 1800px; }

.map-container {
  position: relative;
  margin-top: 48px;
  width: 100%;
  aspect-ratio: 16/9;
  background: #050505;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
#map.map,
.map-container > .map { position: absolute !important; inset: 0 !important; width: 100% !important; height: 100% !important; }

/* Reset View button — floats over the map, top-right corner */
.map-reset-btn {
  position: absolute;
  top: 24px;
  right: 24px;
  z-index: 10;
  padding: 18px 32px;
  background: rgba(15,15,15,0.85);
  color: var(--fg);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  font-family: var(--font-sans);
  font-size: 24px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 4px 24px rgba(0,0,0,0.6);
}
.map-reset-btn:active { background: rgba(30,30,30,0.95); }


#map-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 48px;
}
#map-stats .stat {
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 28px 36px;
  text-align: left;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
#map-stats .stat-num { font-family: var(--font-serif); font-size: 96px; line-height: 1; color: var(--fg); }
#map-stats .stat-lbl { margin-top: 10px; font-size: var(--fs-caption); letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-muted); }

.office-marker { display: flex; flex-direction: column; align-items: center; pointer-events: none; }
.office-pin { width: 22px; height: 22px; border-radius: 50%; background: var(--fg); border: 3px solid var(--accent-contrast); box-shadow: 0 0 0 2px var(--fg), 0 0 16px rgba(255,255,255,0.6); }
.office-marker--planned .office-pin { background: transparent; border-color: var(--fg); }
.office-label { margin-top: 8px; text-align: center; }
.office-city { font-family: var(--font-sans); font-weight: 700; font-size: 20px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg); text-shadow: 0 2px 6px rgba(0,0,0,0.9); }
.office-badge { margin-top: 2px; font-size: 14px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-muted); }

/* City pins on Service Areas Map — sized by case count, top 10 get labels */
.city-marker { display: flex; flex-direction: column; align-items: center; pointer-events: none; }
.city-dot { border-radius: 50%; background: rgba(255, 77, 77, 0.85); border: 2px solid rgba(255, 200, 200, 0.7); box-shadow: 0 0 12px rgba(255, 77, 77, 0.6); }
.city-marker--labeled .city-dot { background: rgba(255, 77, 77, 0.95); border-color: #fff; box-shadow: 0 0 18px rgba(255, 77, 77, 0.8); }
.city-label { margin-top: 6px; font-family: var(--font-sans); font-weight: 600; font-size: 16px; letter-spacing: 0.04em; color: var(--fg); text-shadow: 0 2px 6px rgba(0,0,0,0.95); white-space: nowrap; }
.city-count { color: var(--fg-muted); font-weight: 400; }


/* ================================================================
   REVIEWS SCREEN
   ================================================================ */
.reviews-hero { margin-bottom: 56px; }

.reviews-aggregate {
  display: flex;
  align-items: center;
  gap: 32px;
  margin-top: 40px;
  padding: 32px 40px;
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  max-width: 1200px;
}
.reviews-aggregate .agg-stars { display: inline-flex; gap: 4px; font-size: 56px; line-height: 1; }
.reviews-aggregate .star--full { color: #FFC700; }
.reviews-aggregate .star--half { color: #FFC700; opacity: 0.65; }
.reviews-aggregate .star--empty { color: var(--border-strong); }
.reviews-aggregate .agg-score { font-family: var(--font-serif); font-size: 100px; line-height: 1; color: var(--fg); margin-left: 8px; }
.reviews-aggregate .agg-meta { display: flex; flex-direction: column; gap: 4px; }
.reviews-aggregate .agg-total { font-size: var(--fs-h3); font-weight: 600; color: var(--fg); }
.reviews-aggregate .agg-source { font-size: var(--fs-caption); letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-muted); }

.reviews-stage {
  position: relative;
  margin-top: 64px;
  min-height: 1400px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.reviews-loading, .reviews-empty, .reviews-error {
  color: var(--fg-dim);
  font-size: var(--fs-h3);
  font-style: italic;
}

.review-card {
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  border-left: 8px solid #FF4D4D;
  border-radius: var(--radius-lg);
  padding: 96px 96px 72px;
  width: 100%;
  max-width: 1900px;
  position: relative;
  box-shadow: var(--shadow-2);
  transition: opacity 400ms ease, transform 400ms ease;
  opacity: 1;
  transform: translateY(0);
}
.review-card--entering { opacity: 0; transform: translateY(24px); }

.review-quote-mark {
  position: absolute;
  top: -40px;
  left: 48px;
  font-family: var(--font-serif);
  font-size: 260px;
  line-height: 1;
  color: #FF4D4D;
  opacity: 0.25;
  pointer-events: none;
}

.review-stars { font-size: 72px; line-height: 1; display: flex; gap: 8px; margin-bottom: 48px; color: #FFC700; }
.review-stars .star--full { color: #FFC700; }
.review-stars .star--empty { color: var(--border-strong); }

.review-text {
  font-family: var(--font-serif);
  line-height: 1.35;
  color: var(--fg);
  margin: 0 0 56px;
  quotes: none;
}
.review-text::before, .review-text::after { content: none; }
.review-text--lg { font-size: 88px; }
.review-text--md { font-size: 68px; }
.review-text--sm { font-size: 52px; line-height: 1.4; }

.review-footer { display: flex; align-items: center; gap: 32px; padding-top: 40px; border-top: 1px solid var(--border); }
.review-avatar {
  width: 96px; height: 96px; border-radius: 50%;
  background: linear-gradient(135deg, #FF4D4D, #c23a3a);
  color: #fff;
  display: grid; place-items: center;
  font-family: var(--font-serif); font-size: 56px; font-weight: 600;
}
.review-attribution { display: flex; flex-direction: column; gap: 4px; }
.review-author { font-family: var(--font-sans); font-size: 44px; font-weight: 700; color: var(--fg); }
.review-when { font-size: var(--fs-caption); letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-muted); }

.reviews-dots { display: flex; justify-content: center; gap: 20px; margin-top: 48px; }
.reviews-dot {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--border-strong);
  transition: background 300ms ease, transform 300ms ease;
}
.reviews-dot.active { background: #FF4D4D; transform: scale(1.3); }


/* ================================================================
   PARTNERS SCREEN
   ================================================================ */
.partners-hero { margin-bottom: 64px; }

.partners-featured {
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 72px;
  margin-bottom: 80px;
  min-height: 520px;
  display: flex;
  align-items: center;
}
.partners-featured__placeholder {
  width: 100%;
  text-align: center;
  color: var(--fg-dim);
  font-size: var(--fs-h3);
  font-style: italic;
}
.featured-card { display: grid; grid-template-columns: 360px 1fr; gap: 64px; align-items: center; width: 100%; }
.featured-logo { width: 360px; height: 360px; object-fit: contain; background: var(--bg-elev-2); border-radius: var(--radius-md); padding: 40px; }
.featured-logo--placeholder { display: grid; place-items: center; font-family: var(--font-serif); font-size: 140px; color: var(--fg-dim); }
.featured-name { font-family: var(--font-serif); font-size: 96px; line-height: 1; color: var(--fg); }
.featured-tagline { margin-top: 24px; font-size: var(--fs-h3); color: var(--fg-muted); line-height: 1.4; max-width: 1200px; }
.featured-chips { margin-top: 40px; display: flex; flex-wrap: wrap; gap: 16px; }
.featured-chip { padding: 16px 32px; border: 1px solid var(--border-strong); border-radius: 999px; font-size: var(--fs-caption); letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-muted); }


.partners-categories-heading { margin-bottom: 40px; }
.partners-categories-heading h3 { font-size: var(--fs-h2); margin-bottom: 16px; }
.partners-categories-heading p { color: var(--fg-muted); font-size: var(--fs-h3); }

.partners-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.partner-tile {
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 56px;
  min-height: 360px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.partner-tile__icon { font-size: 96px; color: var(--accent); line-height: 1; }
.partner-tile__label { font-family: var(--font-serif); font-size: 64px; color: var(--fg); }
.partner-tile__desc { font-size: var(--fs-caption); color: var(--fg-muted); line-height: 1.5; }
.partners-empty { grid-column: 1 / -1; text-align: center; padding: 80px; color: var(--fg-dim); font-style: italic; }

.partners-footer { margin-top: 96px; text-align: center; padding-top: 64px; border-top: 1px solid var(--border); }
.partners-markets-label { font-size: var(--fs-caption); color: var(--fg-dim); letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 24px; }
.partners-markets { font-family: var(--font-serif); font-size: var(--fs-h2); color: var(--fg); }
.market-chip { padding: 0 16px; }
.market-sep { color: var(--fg-dim); padding: 0 4px; }
.partners-cta { margin-top: 40px; font-size: var(--fs-h3); color: var(--fg-muted); }
.partners-cta strong { color: var(--fg); font-weight: 600; }


/* ================================================================
   ABOUT SCREEN — Meet the Founder
   Timeline + community + mission
   ================================================================ */
.about-hero {
  display: grid;
  grid-template-columns: 520px 1fr;
  gap: 64px;
  align-items: center;
}
.about-hero .jr-portrait {
  width: 100%;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: var(--bg-elev-1);
  aspect-ratio: 4/5;
  object-fit: cover;
}
.about-eyebrow { font-family: var(--font-sans); font-size: var(--fs-caption); text-transform: uppercase; letter-spacing: 0.16em; color: var(--fg-dim); }
.about-title { margin-top: 16px; }
.about-subtitle { margin-top: 24px; color: var(--fg-muted); font-size: var(--fs-h3); font-style: italic; font-family: var(--font-serif); }
.about-subtitle em { color: var(--fg); font-style: italic; }

.about-timeline {
  margin-top: 96px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.tl-item {
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 56px 48px;
  display: flex;
  flex-direction: column;
  gap: 32px;
  position: relative;
  overflow: hidden;
}
.tl-item::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 6px; height: 100%;
  background: var(--fg);
  opacity: 0.85;
}
.tl-year {
  font-family: var(--font-serif);
  font-size: 96px;
  line-height: 1;
  color: var(--fg);
  letter-spacing: -0.02em;
}
.tl-body h3 {
  font-size: var(--fs-h3);
  margin-bottom: 16px;
}
.tl-body p {
  color: var(--fg-muted);
  font-size: var(--fs-body);
  line-height: 1.45;
}

.about-community {
  margin-top: 80px;
  background: var(--bg-elev-2);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
  padding: 64px;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 48px;
  align-items: center;
}
.community-tag {
  font-family: var(--font-sans);
  font-size: var(--fs-caption);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--accent-contrast);
  background: var(--fg);
  padding: 14px 28px;
  border-radius: 999px;
  font-weight: 700;
  align-self: start;
}
.about-community h3 { font-size: var(--fs-h2); margin-bottom: 16px; }
.about-community p { color: var(--fg-muted); font-size: var(--fs-body); line-height: 1.45; }

.about-mission {
  margin-top: 64px;
  border-left: 8px solid var(--fg);
  padding: 40px 56px;
  background: transparent;
}
.mission-label {
  font-family: var(--font-sans);
  font-size: var(--fs-caption);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--fg-dim);
  margin-bottom: 24px;
}
.about-mission p {
  font-family: var(--font-serif);
  font-size: 56px;
  line-height: 1.25;
  color: var(--fg);
  font-style: italic;
}
.about-mission strong { font-style: normal; font-weight: 500; }


/* ================================================================
   RESULTS SCREEN — Recent Wins + Client Voices
   ================================================================ */
.results-eyebrow { font-family: var(--font-sans); font-size: var(--fs-caption); text-transform: uppercase; letter-spacing: 0.16em; color: var(--fg-dim); }
.results-title { margin-top: 16px; }
.results-subtitle { margin-top: 24px; color: var(--fg-muted); font-size: var(--fs-h3); }

.results-layout {
  margin-top: 72px;
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 56px;
  align-items: start;
}

.block-label {
  font-family: var(--font-sans);
  font-size: var(--fs-caption);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--fg-dim);
  margin-bottom: 32px;
  font-weight: 600;
}

.wins-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
.win-card {
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 40px 48px;
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 40px;
  align-items: center;
}
.win-duration {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  border-right: 1px solid var(--border-strong);
  padding-right: 32px;
}
.win-num {
  font-family: var(--font-serif);
  font-size: 128px;
  line-height: 1;
  color: var(--fg);
  letter-spacing: -0.02em;
}
.win-unit {
  font-family: var(--font-sans);
  font-size: var(--fs-caption);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--fg-muted);
  margin-top: 8px;
}
.win-type {
  font-family: var(--font-serif);
  font-size: var(--fs-h3);
  color: var(--fg);
  line-height: 1.2;
}
.win-county {
  margin-top: 12px;
  font-size: var(--fs-caption);
  color: var(--fg-muted);
  letter-spacing: 0.04em;
}

.testimonial-rotator {
  background: var(--bg-elev-2);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
  padding: 56px;
  min-height: 560px;
  display: flex;
  align-items: center;
}
.testimonial-card {
  display: flex;
  flex-direction: column;
  gap: 40px;
  width: 100%;
}
.testimonial-card blockquote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 44px;
  line-height: 1.3;
  color: var(--fg);
  position: relative;
  padding-left: 48px;
}
.testimonial-card blockquote::before {
  content: "\201C";
  font-family: var(--font-serif);
  font-size: 180px;
  line-height: 1;
  color: var(--fg-dim);
  position: absolute;
  left: -8px; top: -56px;
}
.testimonial-card figcaption {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: 32px;
  border-top: 1px solid var(--border);
}
.t-author { font-family: var(--font-sans); font-weight: 700; font-size: 32px; letter-spacing: 0.04em; color: var(--fg); }
.t-source { font-size: var(--fs-caption); color: var(--fg-dim); letter-spacing: 0.08em; text-transform: uppercase; }

.fade-in { animation: fadeIn 0.6s var(--ease-out); }
@keyframes fadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }


/* ================================================================
   WHY JR LAW GROUP SCREEN
   4-card grid + services strip (tone down giant "We Handle")
   ================================================================ */
.why-eyebrow { font-family: var(--font-sans); font-size: var(--fs-caption); text-transform: uppercase; letter-spacing: 0.16em; color: var(--fg-dim); }
.why-title { margin-top: 16px; }
.why-subtitle { margin-top: 24px; color: var(--fg-muted); font-size: var(--fs-h3); font-style: italic; font-family: var(--font-serif); }

.why-grid {
  margin-top: 80px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
}
.why-card {
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 56px 56px 56px 72px;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 24px;
  overflow: hidden;
}
.why-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 4px;
  background: linear-gradient(90deg, var(--fg), transparent 60%);
  opacity: 0.6;
}
.why-num {
  font-family: var(--font-serif);
  font-size: 88px;
  line-height: 1;
  color: var(--fg-dim);
  letter-spacing: -0.02em;
}
.why-card h3 {
  font-size: var(--fs-h2);
  line-height: 1.1;
}
.why-card p {
  color: var(--fg-muted);
  font-size: var(--fs-body);
  line-height: 1.45;
}

.services-strip {
  margin-top: 80px;
  background: var(--bg-elev-2);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
  padding: 48px 56px;
}
.services-label {
  /* Toned down per Ashton — no more giant yellow block */
  font-family: var(--font-sans);
  font-size: var(--fs-caption);
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--fg-dim);
  font-weight: 600;
  margin-bottom: 32px;
}
.services-tiles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.service-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  padding: 32px;
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  text-align: center;
}
.service-tile img {
  width: 140px;
  height: 140px;
  object-fit: contain;
  filter: invert(1) brightness(1.1);
}
.service-tile span {
  font-family: var(--font-sans);
  font-size: 32px;
  font-weight: 600;
  color: var(--fg);
  letter-spacing: 0.02em;
}


/* ================================================================
   EVENTS SCREEN — Upcoming events as rich cards
   ================================================================ */
.events-eyebrow { font-family: var(--font-sans); font-size: var(--fs-caption); text-transform: uppercase; letter-spacing: 0.16em; color: var(--fg-dim); }
.events-title { margin-top: 16px; }
.events-subtitle { margin-top: 24px; color: var(--fg-muted); font-size: var(--fs-h3); max-width: 1800px; }

.events-list {
  margin-top: 96px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  padding-top: 8px;
}
.event-card {
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: grid;
  grid-template-columns: 560px 1fr;
  gap: 0;
  min-height: 360px;
}
.event-img {
  background-color: var(--bg-elev-2);
  background-size: cover;
  background-position: center;
}
.event-img--placeholder {
  background: linear-gradient(135deg, var(--bg-elev-2), var(--bg-elev-1));
  position: relative;
}
.event-img--placeholder::after {
  content: "JRLG";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-serif);
  font-size: 96px;
  color: var(--fg-dim);
  letter-spacing: 0.1em;
}
.event-body {
  padding: 64px 56px 56px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  min-width: 0;
}
.event-meta {
  display: flex;
  gap: 24px;
  align-items: center;
  flex-wrap: wrap;
  font-family: var(--font-sans);
  font-size: var(--fs-caption);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--fg-muted);
}
.event-date {
  color: var(--fg);
  font-weight: 700;
  padding: 10px 20px;
  background: var(--bg-elev-2);
  border: 1px solid var(--border-strong);
  border-radius: 999px;
}
.event-time { color: var(--fg-muted); }
.event-title {
  font-size: var(--fs-h2);
  line-height: 1.1;
  margin-top: 8px;
}
.event-tagline {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--fg-muted);
  font-size: 36px;
  line-height: 1.3;
}
.event-venue {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
  margin-top: 4px;
}
.event-venue strong { font-size: 32px; color: var(--fg); font-family: var(--font-sans); font-weight: 700; letter-spacing: 0.02em; }
.event-venue span { font-size: var(--fs-caption); color: var(--fg-muted); }
.event-highlights {
  list-style: none;
  padding: 0;
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.event-highlights li {
  font-size: var(--fs-caption);
  padding: 10px 20px;
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--fg-muted);
}
.event-dress {
  margin-top: 8px;
  font-size: var(--fs-caption);
  color: var(--fg-dim);
  font-style: italic;
}
.events-empty, .empty {
  padding: 96px;
  text-align: center;
  color: var(--fg-muted);
  font-size: var(--fs-h3);
  background: var(--bg-elev-1);
  border: 1px dashed var(--border-strong);
  border-radius: var(--radius-lg);
}
.events-footer {
  margin-top: 64px;
  padding: 32px 48px;
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  text-align: center;
  font-size: var(--fs-caption);
  color: var(--fg-muted);
  letter-spacing: 0.08em;
}
.events-footer strong { color: var(--fg); font-weight: 700; }


/* ================================================================
   REVIEWS SCREEN — Swipeable carousel + Leave-a-review QR panel
   ================================================================ */
.reviews-body {
  display: block;
}

.reviews-carousel {
  position: relative;
  display: grid;
  grid-template-columns: 96px 1fr 96px;
  gap: 24px;
  align-items: stretch;
}
.reviews-carousel .reviews-stage {
  min-height: 640px;
}

.rev-arrow {
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  color: var(--fg);
  font-size: 56px;
  line-height: 1;
  font-weight: 400;
  cursor: pointer;
  width: 96px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--t-fast), border-color var(--t-fast);
}
.rev-arrow:active { background: var(--bg-elev-2); border-color: var(--border-strong); }

.leave-review {
  background: var(--bg-elev-2);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
  padding: 48px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.leave-review__inner {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

/* --below: full-width banner under the carousel, text left + QR right */
.leave-review.leave-review--below {
  margin-top: 48px;
  padding: 56px 64px;
}
.leave-review.leave-review--below .leave-review__inner {
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 64px;
}
.leave-review.leave-review--below .leave-review__copy {
  flex: 1 1 auto;
  max-width: 1100px;
}
.leave-review.leave-review--below .leave-review__qr {
  flex: 0 0 auto;
  max-width: 360px;
  width: 360px;
  align-self: center;
}

/* ================================================================
   PARTNERS — Top Specialties card (under provider map stats)
   ================================================================ */
.top-specialties {
  margin-top: 56px;
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 48px 56px;
}
.top-specialties__heading h4 {
  font-family: var(--font-serif);
  font-size: 56px;
  line-height: 1.1;
  color: var(--fg);
  margin: 0;
}
.top-specialties__heading p {
  margin-top: 8px;
  color: var(--fg-muted);
  font-size: var(--fs-h3);
}
.top-specialties__list {
  margin-top: 36px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.spec-row {
  display: grid;
  grid-template-columns: 56px 28px 1fr 2fr 96px;
  gap: 24px;
  align-items: center;
}
.spec-rank {
  font-family: var(--font-serif);
  font-size: 40px;
  color: var(--fg-muted);
  text-align: center;
}
.spec-swatch {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.2);
}
.spec-name {
  font-family: var(--font-sans);
  font-size: 28px;
  color: var(--fg);
  font-weight: 600;
}
.spec-bar {
  position: relative;
  height: 14px;
  background: var(--bg-elev-2);
  border-radius: 999px;
  overflow: hidden;
}
.spec-bar-fill {
  position: absolute;
  inset: 0 auto 0 0;
  border-radius: 999px;
}
.spec-count {
  font-family: var(--font-sans);
  font-size: 28px;
  font-weight: 700;
  color: var(--fg);
  text-align: right;
  font-variant-numeric: tabular-nums;
}

/* Top Providers card — name-only rows, no swatch/bar/count */
.top-providers { margin-top: 0; margin-bottom: 24px; }
.spec-row--providers {
  grid-template-columns: 56px 1fr;
  gap: 24px;
}
.spec-name--provider {
  font-size: 32px;
  line-height: 1.2;
}
.leave-review__eyebrow {
  font-family: var(--font-sans);
  font-size: var(--fs-caption);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--fg-dim);
  font-weight: 600;
}
.leave-review__title {
  font-family: var(--font-serif);
  font-size: 72px;
  line-height: 1.1;
  color: var(--fg);
  margin-top: 16px;
}
.leave-review__sub {
  margin-top: 16px;
  color: var(--fg-muted);
  font-size: 28px;
  line-height: 1.4;
}
.leave-review__qr {
  background: #fff;
  border-radius: var(--radius-md);
  padding: 24px;
  align-self: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  width: 100%;
  max-width: 440px;
}
.leave-review__qr img {
  width: 100%;
  height: auto;
  display: block;
}
.leave-review__caption {
  color: #111;
  font-family: var(--font-sans);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-align: center;
  text-transform: uppercase;
}

/* Clicks on dots — make them obvious as controls */
.reviews-dot { cursor: pointer; }


/* ================================================================
   PARTNERS SCREEN — Provider map section
   ================================================================ */
.providers-map-section {
  margin-top: 64px;
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 48px;
}
.providers-map-heading {
  margin-bottom: 24px;
}
.providers-map-heading h3 {
  font-size: var(--fs-h2);
  line-height: 1.1;
}
.providers-map-heading p {
  margin-top: 12px;
  color: var(--fg-muted);
  font-size: var(--fs-h3);
}

.providers-map-legend {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px 32px;
  margin-bottom: 24px;
  padding: 20px 24px;
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
}
.prov-legend-item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 22px;
  line-height: 1.2;
}
.prov-legend-dot {
  width: 18px; height: 18px;
  border-radius: 50%;
  border: 1.5px solid #0a0a0a;
  box-shadow: 0 0 0 1px var(--border-strong);
  flex-shrink: 0;
}
.prov-legend-lbl {
  color: var(--fg);
  font-weight: 500;
  flex: 1;
}
.prov-legend-count {
  color: var(--fg-muted);
  font-family: var(--font-serif);
  font-size: 26px;
}

.providers-map-container {
  position: relative;
  width: 100%;
  height: 880px;           /* explicit pixel height — aspect-ratio collapses inside flex parents on the kiosk */
  min-height: 880px;
  background: #050505;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
}
#providers-map.providers-map,
.providers-map-container > .providers-map {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
}

.providers-map-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: 24px;
}
.prov-stat {
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 24px 32px;
  text-align: left;
}
.prov-stat-num {
  font-family: var(--font-serif);
  font-size: 72px;
  line-height: 1;
  color: var(--fg);
}
.prov-stat-lbl {
  margin-top: 8px;
  font-size: var(--fs-caption);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.providers-map-empty {
  padding: 96px;
  text-align: center;
  color: var(--fg-muted);
  font-size: var(--fs-h3);
}

/* ---------------------------------------------------------------------------
 * Why JRLG in-page tab toggle (merged with Recent Wins)
 * ------------------------------------------------------------------------- */

.why-screen {
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.why-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  background: var(--bg-elev-1, #101010);
  padding: 12px;
  border-radius: var(--radius-md, 14px);
  border: 1px solid var(--border, #222);
}

.why-tab {
  all: unset;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: center;
  justify-content: center;
  padding: 22px 16px;
  border-radius: calc(var(--radius-md, 14px) - 4px);
  background: transparent;
  color: var(--fg-muted, #aaa);
  text-align: center;
  transition: background 160ms ease, color 160ms ease;
}

.why-tab:hover {
  background: rgba(255, 207, 0, 0.08);
  color: var(--fg, #fff);
}

.why-tab.is-active {
  background: var(--brand, #FFCF00);
  color: #111;
}

.why-tab__eyebrow {
  font-size: 20px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0.75;
}

.why-tab__label {
  font-family: var(--font-serif, Georgia, serif);
  font-size: 44px;
  line-height: 1.1;
}

.why-tab.is-active .why-tab__eyebrow { opacity: 1; }

.why-panel {
  display: none;
  flex-direction: column;
  gap: 32px;
}

.why-panel.is-active {
  display: flex;
}

/* Wins panel inherits results-layout — make sure it fills available space */
.why-panel[data-why-panel="wins"] .results-layout {
  margin-top: 16px;
}
