/**
 * BeatIRS — site-specific overrides only.
 *
 * Do not paste approved mock CSS here. Keep `approved-homepage.css` verbatim;
 * add WordPress-only or client-requested tweaks in this file so layers stay separate.
 */

/* --------------------------------------------------------------------------
   Card backgrounds — palette from approved `approved-homepage.css` :root
   Use utilities on wrappers, e.g. <article class="team-card card-bg card-bg--navy-aurora">…
   -------------------------------------------------------------------------- */

:root {
  /* Solids (plain fills) */
  --card-fill-cream: var(--color-surface);
  --card-fill-cream-2: var(--color-surface-2);
  --card-fill-navy-soft: var(--navy-50);
  --card-fill-crimson-soft: var(--crimson-50);
  --card-fill-navy-deep: var(--navy-800);

  /* Gradients — navy / cream / crimson / practice accents */
  --card-grad-navy-aurora: linear-gradient(
    135deg,
    var(--navy-900) 0%,
    var(--navy-800) 38%,
    var(--navy-700) 100%
  );
  --card-grad-navy-veil: linear-gradient(
    160deg,
    rgba(13, 27, 46, 0.92) 0%,
    rgba(27, 42, 74, 0.88) 45%,
    rgba(46, 66, 112, 0.82) 100%
  );
  --card-grad-warm-cream: linear-gradient(
    180deg,
    var(--color-bg) 0%,
    var(--color-surface) 45%,
    var(--color-surface-2) 100%
  );
  --card-grad-crimson-mist: linear-gradient(
    125deg,
    var(--crimson-50) 0%,
    var(--color-surface) 40%,
    var(--navy-50) 100%
  );
  --card-grad-crimson-edge: linear-gradient(
    90deg,
    var(--crimson-600) 0%,
    var(--crimson-500) 50%,
    var(--crimson-700) 100%
  );
  --card-grad-criminal: linear-gradient(
    145deg,
    var(--criminal-color) 0%,
    var(--navy-900) 55%,
    #0f1a2e 100%
  );
  --card-grad-civil: linear-gradient(
    145deg,
    var(--civil-color) 0%,
    #12261f 55%,
    #0d1f18 100%
  );
  --card-grad-comprehensive: linear-gradient(
    145deg,
    var(--comp-color) 0%,
    #1a2810 55%,
    #111c0c 100%
  );
}

.card-bg {
  background-repeat: no-repeat;
  background-size: cover;
}

/* Plain surfaces */
.card-bg--cream {
  background-color: var(--card-fill-cream);
}
.card-bg--cream-2 {
  background-color: var(--card-fill-cream-2);
}
.card-bg--navy-soft {
  background-color: var(--card-fill-navy-soft);
}
.card-bg--crimson-soft {
  background-color: var(--card-fill-crimson-soft);
}
.card-bg--navy-solid {
  background-color: var(--card-fill-navy-deep);
  color: var(--color-text-on-dark);
}

/* Gradients */
.card-bg--navy-aurora {
  background-image: var(--card-grad-navy-aurora);
  color: var(--color-text-on-dark);
}
.card-bg--navy-veil {
  background-image: var(--card-grad-navy-veil);
  color: var(--color-text-on-dark);
}
.card-bg--warm-cream {
  background-image: var(--card-grad-warm-cream);
  color: var(--color-text);
}
.card-bg--crimson-mist {
  background-image: var(--card-grad-crimson-mist);
  color: var(--color-text);
}
.card-bg--crimson-edge {
  background-image: var(--card-grad-crimson-edge);
  color: #fff;
}
.card-bg--criminal {
  background-image: var(--card-grad-criminal);
  color: var(--color-text-on-dark);
}
.card-bg--civil {
  background-image: var(--card-grad-civil);
  color: var(--color-text-on-dark);
}
.card-bg--comprehensive {
  background-image: var(--card-grad-comprehensive);
  color: var(--color-text-on-dark);
}
.nav-dropdown {
  min-width: 290px;
}
.btn-secondary,
.btn-form-submit,
.btn-primary {
  justify-content: center;
}
p,.footer-legal {
  max-width: 100%;
}

/* Practice cards: equal row height (grid) vs. inner only as tall as content — fill the
   article so `.practice-card-inner` / `.practice-card-content` reach the bottom with no
   cream “sliver” under the navy panel; buttons line up across columns. */
.practices-grid > .practice-card {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.practices-grid > .practice-card .practice-card-inner {
  flex: 1 1 auto;
  min-height: 0;
}

.practices-grid > .practice-card .practice-card-content {
  flex: 1 1 auto;
  margin-top: 0;
  justify-content: space-between;
  background: var(--card-grad-navy-aurora);
}

/* Primary menu (wp_nav_menu): chevron on parent links — mobile only (desktop uses hover submenu, no chevron) */
@media (max-width: 1000px) {
  .main-nav .menu-item-has-children > a.nav-link.nav-dropdown-trigger::after {
    content: "";
    width: 0.5rem;
    height: 0.5rem;
    border-right: 2.5px solid currentColor;
    border-bottom: 2.5px solid currentColor;
    transform: rotate(-45deg);
    margin-left: var(--space-1);
    opacity: 0.85;
    flex-shrink: 0;
    transition: transform var(--transition, 0.2s ease);
  }

  .main-nav .has-dropdown.open > a.nav-link.nav-dropdown-trigger::after {
    transform: rotate(45deg) translateY(-2px);
  }
}

.main-nav .nav-dropdown > li:nth-child(1) > a.dropdown-item::before,
.main-nav .nav-dropdown > li:nth-child(2) > a.dropdown-item::before,
.main-nav .nav-dropdown > li:nth-child(3) > a.dropdown-item::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  background: var(--navy-600);
}

.main-nav .nav-dropdown > li:nth-child(1) > a.dropdown-item::before {
  background: var(--criminal-color);
}
.main-nav .nav-dropdown > li:nth-child(2) > a.dropdown-item::before {
  background: var(--civil-color);
}
.main-nav .nav-dropdown > li:nth-child(3) > a.dropdown-item::before {
  background: var(--comp-color);
}

.header-inner .custom-logo-link {
  display: flex;
  align-items: center;
}
.header-inner .custom-logo-link img {
  display: block;
  width: auto;
}

/*
 * Header Contact CTA — primary menu strips nav-cta from <li> in PHP so only <a> carries it.
 * Merge approved `approved-homepage.css` .nav-link + .nav-cta (+ hover) on the anchor.
 */
.site-header .main-nav a.nav-link.nav-cta {
  font-size: var(--text-sm);
  font-weight: 600;
  color: #fff !important;
  padding: var(--space-2) var(--space-5);
  border-radius: var(--radius-md);
  transition:
    color var(--transition),
    background var(--transition);
  display: flex;
  align-items: center;
  gap: var(--space-1);
  white-space: nowrap;
  text-decoration: none;
  background: var(--color-accent);
  border: none;
  box-shadow: none;
}

.site-header .main-nav a.nav-link.nav-cta:hover,
.site-header .main-nav a.nav-link.nav-cta:focus-visible {
  color: #fff;
  background: var(--color-accent-hover) !important;
}

/* Viewport scrollbar — navy thumb on warm track (Firefox + WebKit/Blink) */
html {
  scrollbar-color: var(--navy-800)
    var(--color-surface-2, var(--surface, #ede9e2));
  scrollbar-width: thin;
}

html::-webkit-scrollbar {
  width: 11px;
  height: 11px;
}

html::-webkit-scrollbar-track {
  background: var(--color-surface-2, var(--surface, #ede9e2));
}

html::-webkit-scrollbar-thumb {
  background-color: var(--navy-700, var(--navy-800));
  border-radius: var(--radius-md);
  border: 3px solid var(--color-surface-2, var(--surface, #ede9e2));
}

html::-webkit-scrollbar-thumb:hover {
  background-color: var(--navy-800);
}

html::-webkit-scrollbar-corner {
  background: var(--color-surface-2, var(--surface, #ede9e2));
}

.form-disclaimer {
  margin-top: 10px;
}

/* Header branding wrapper — Customizer selective refresh target + custom logo sizing */
.site-header-branding {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  line-height: 0;
}

.site-header-branding .custom-logo-link {
  display: flex;
  align-items: center;
}

.site-header-branding .custom-logo-link img {
  display: block;
  width: 200px;
  max-width: 200px;
  height: auto;
  max-height: none;
}

@media (max-width: 600px) {
  .site-header-branding .custom-logo-link img {
    max-width: 140px;
  }
}

.header-inner {
  height: auto;
  min-height: 88px;
  justify-content: space-between;
}

.header-phone svg {
  flex-shrink: 0;
}

#site-footer-branding-logo .custom-logo-link img.custom-logo {
  display: block;
  width: auto;
  height: auto;
  max-height: 57px;
}

@media (max-width: 600px) {
  #site-footer-branding-logo .custom-logo-link img.custom-logo {
    max-height: 50px;
  }
}

/* Header — mobile: spread branding vs actions */
@media (max-width: 600px) {
  .header-inner {
    justify-content: space-between;
    height: auto;
    min-height: 64px;
  }
}

/*
 * Primary nav — mobile panel (approved hides .main-nav <1000px; JS toggles body.nav-open).
 * Do NOT use position:fixed on .main-nav here: .site-header has backdrop-filter, which makes
 * fixed descendants position against the header box (~88px tall), so top:88px + bottom:0
 * collapsed the panel to zero height (invisible) while body overflow:hidden still “stuck” scroll.
 * Use absolute + top:100% against the sticky header so the panel anchors below the bar (height from content; overflow-y auto for long lists).
 */
@media (max-width: 1000px) {
  body.nav-open {
    overflow: hidden;
  }

  body.nav-open .site-header {
    overflow: visible;
    z-index: 200;
  }

  body.nav-open .main-nav {
    display: flex !important;
    flex-direction: column;
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    width: 100%;
    z-index: 101;
    flex: none;
    margin: 0;
    box-sizing: border-box;
    padding: var(--space-4, 1rem) clamp(var(--space-5), 5vw, var(--space-16));
    border-radius: 0 0 var(--radius-lg, 12px) var(--radius-lg, 12px);
    background: rgba(250, 249, 246, 0.98);
    backdrop-filter: blur(10px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    justify-content: flex-start;
    border-top: 1px solid var(--color-divider, rgba(0, 0, 0, 0.08));
    opacity: 1;
    visibility: visible;
  }

  body.nav-open .main-nav > ul {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    width: 100%;
    opacity: 1;
    visibility: visible;
  }

  body.nav-open .main-nav .nav-link {
    white-space: normal;
  }

  body.nav-open .main-nav .has-dropdown:not(.open) .nav-dropdown {
    display: none;
  }

  body.nav-open .main-nav .has-dropdown.open .nav-dropdown {
    display: flex;
    flex-direction: column;
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    border: none;
    padding: var(--space-2, 0.5rem) 0 var(--space-2, 0.5rem) var(--space-4, 1rem);
    margin: 0;
    min-width: 0;
  }
}

/* Numbers section — mobile: horizontal dividers use bottom edge instead of right */
@media (max-width: 768px) {
   .numbers-grid {
      gap: 20px;
   }
  .number-tile {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  }
}

/*
 * Video placeholder — mobile: avoid clipping the play icon (no flex vertical center when inner is tall)
 * and keep everything in the 16:9 frame without a scrollbar — tighter spacing + smaller type/icon.
 */
@media (max-width: 768px) {
  .video-placeholder {
    align-items: flex-start;
    justify-content: flex-start;
  }

  .video-placeholder-inner {
    padding: var(--space-4, 1rem) var(--space-5, 1.25rem);
    gap: var(--space-2, 0.5rem);
    box-sizing: border-box;
    width: 100%;
    overflow: hidden;
    min-height: 0;
  }

  .video-play-icon {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
  }

  .video-placeholder-label {
    font-size: 0.6875rem;
    line-height: 1.45;
  }
}

/* Footer widget columns — stack multiple widgets inside a column */
.footer-nav .footer-widget + .footer-widget {
  margin-top: var(--space-4, 1rem);
}

.footer-nav-title {
  margin-bottom: 20px;
}

/*
 * Bottom CTA — approved `.bottom-cta-inner` uses `grid-template-columns: 1fr 1fr` (and `1fr` below 800px).
 * Plain `1fr` implies a minimum track size of `auto`, so wide min-content (long words, form controls)
 * can force the grid wider than the padded viewport → horizontal scroll and the white card looks
 * shifted with uneven side margins. `minmax(0, 1fr)` keeps tracks within the container.
 * `align-items: center` overrides approved `start` so the headline column and form card align on the cross axis.
 */
.bottom-cta-inner {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  align-items: center;
}

@media (max-width: 800px) {
  .bottom-cta-inner {
    grid-template-columns: minmax(0, 1fr);
  }
}

.bottom-cta .cta-text,
.bottom-cta .contact-form-wrap {
  min-width: 0;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

/*
 * Contact form — homepage loads `approved-homepage.css` + `custom.css` only (`main.css` is skipped),
 * so honeypot positioning from `main.css` was missing and the situation `<textarea>` could sit
 * narrower than `.form-input` rows (replaced-element / flex min-width behavior).
 */
.beatirs-hp-wrap {
  position: absolute !important;
  left: -10000px !important;
  top: auto !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
}

.contact-form .form-field {
  min-width: 0;
  width: 100%;
}

.contact-form textarea.form-textarea {
  display: block;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

/* Site-wide: no :focus-visible ring (overrides approved-homepage.css and similar) */
:focus-visible {
  outline: none !important;
  outline-offset: 0 !important;
  box-shadow: none !important;
}

.form-input,
.form-textarea {
  border-width: 2px;
}

/* Hero: full-bleed background photo (replaces gradient placeholder) */
.hero-bg-image {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.hero-bg .hero-overlay {
  z-index: 1;
}

/* Reviews CPT testimonial cards (free-text practice area; neutral top accent) */
.testimonial.beatirs-review-testimonial {
  border-top-color: var(--navy-800);
}

/* Team grid: square photo frame (overrides approved-homepage.css 3:4) */
.team-photo {
  aspect-ratio: 1 / 1;
}

.team-photo .team-headshot {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Homepage: reviews CPT carousel */
.beatirs-reviews-carousel {
  margin-bottom: var(--space-12, 3rem);
}

.beatirs-rc-row {
  display: flex;
  align-items: stretch;
  gap: 0.5rem;
}

.beatirs-rc-arrow {
  flex: 0 0 auto;
  align-self: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 999px;
  border: 1px solid var(--color-divider, #e5e7eb);
  background: var(--color-bg, #fff);
  color: inherit;
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
  padding: 0;
}

.beatirs-rc-arrow:hover {
  border-color: var(--navy-800, #1e3a5f);
}

/* Swiper adds swiper-button-* to our arrows; undo default absolute placement */
.beatirs-reviews-carousel .beatirs-rc-arrow.swiper-button-prev,
.beatirs-reviews-carousel .beatirs-rc-arrow.swiper-button-next {
  position: relative;
  top: auto;
  left: auto;
  right: auto;
  margin-top: 0;
  width: 2.5rem;
  height: 2.5rem;
  color: inherit;
}

.beatirs-reviews-carousel .beatirs-rc-arrow.swiper-button-prev::after,
.beatirs-reviews-carousel .beatirs-rc-arrow.swiper-button-next::after {
  content: none;
}

.beatirs-rc-viewport {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
}

/* Swiper (homepage reviews); same row + arrows + dot look as before */
.beatirs-rc-swiper {
  width: 100%;
  max-width: 100%;
  margin: 0;
  overflow: hidden;
}

.beatirs-rc-swiper .swiper-wrapper {
  align-items: stretch;
}

.beatirs-rc-swiper .swiper-slide {
  height: auto;
  box-sizing: border-box;
  padding-bottom: 2px;
}

.beatirs-rc-slide .testimonial {
  height: 100%;
}

.beatirs-rc-slide:nth-child(3n + 1) .testimonial {
  border-top-color: var(--criminal-color, #8b2942);
}

.beatirs-rc-slide:nth-child(3n + 2) .testimonial {
  border-top-color: var(--civil-color, #1e5a8a);
}

.beatirs-rc-slide:nth-child(3n + 3) .testimonial {
  border-top-color: var(--comp-color, #2d6a4f);
}

.beatirs-reviews-carousel .beatirs-rc-dots.swiper-pagination {
  position: static;
  bottom: auto;
  top: auto;
  left: auto;
  width: 100%;
  transform: none;
  transition: none;
  text-align: center;
}

.beatirs-rc-dots {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem;
  margin-top: 0.75rem;
  width: 100%;
}

.beatirs-rc-dots.swiper-pagination-bullets .swiper-pagination-bullet {
  width: 0.55rem;
  height: 0.55rem;
  margin: 0 !important;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: var(--color-text-faint, #9ca3af);
  opacity: 1;
  cursor: pointer;
}

.beatirs-rc-dots.swiper-pagination-bullets .swiper-pagination-bullet-active {
  background: var(--navy-800, #1e3a5f);
  transform: scale(1.25);
}

.beatirs-rc-arrow.swiper-button-disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

.beatirs-reviews-carousel[data-arrows="0"] .beatirs-rc-arrow {
  display: none !important;
}

.beatirs-reviews-carousel[data-dots="0"] .beatirs-rc-dots {
  display: none !important;
}
