/*
  941 Appliance Repair – custom theme override
  Loads last to fully retheme the existing template.
*/

:root {
  /* Red / black palette with subtle orange + gray accents */
  --brand-primary: #ef4444;        /* red */
  --brand-primary-dark: #b91c1c;   /* deeper red */
  --brand-bg: #f8fafc;            /* light gray */
  --brand-ink: #0b0b0f;           /* near-black ink */

  /* Keep legacy variable names, but retheme values */
  --ar-navy: #0b0b0f;             /* near-black */
  --ar-navy-2: #2b0b0b;           /* deep red-black */
  --ar-sky: #ef4444;              /* repurposed (avoid blue) */
  --ar-gray: #f1f5f9;
  --ar-red: #ef4444;
  --ar-red-dark: #991b1b;

  --ar-accent: #f97316;           /* orange accent */
  --ar-accent-dark: #ea580c;

  --ar-surface: #ffffff;
  --ar-border: rgba(15, 23, 42, 0.10);
  --ar-shadow: 0 18px 45px rgba(2, 6, 23, 0.18);
  --ar-shadow-soft: 0 10px 30px rgba(2, 6, 23, 0.10);

  --ar-radius: 16px;
  --ar-radius-sm: 12px;
}

html, body {
  background: var(--brand-bg);
}

body {
  color: var(--brand-ink);
}

/* Links */
a {
  color: var(--brand-primary);
}
a:hover {
  color: var(--brand-primary-dark);
}

/* Navbar: glass + sharper look */
#navbar .navbar {
  /* Keep navbar clean/basic (no color-scheme changes) */
  background: rgba(248, 250, 252, 0.92) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--ar-border);
  border-radius: 0;
  width: 100%;
  box-shadow: var(--ar-shadow-soft);
}

#navbar .navbar .navbar-brand,
#navbar .navbar .nav-link,
#navbar .navbar .navbar-toggler {
  color: var(--brand-ink) !important;
}

/* Navbar menu typography: cleaner + less heavy */
#navbar .navbar-nav .nav-link {
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 0;
}

#navbar .navbar-nav .nav-link:not(.ar-nav-cta):hover,
#navbar .navbar-nav .nav-link:not(.ar-nav-cta):focus {
  color: var(--brand-primary) !important;
}

/* Keep active links readable; underline handles emphasis */
#navbar .navbar-nav .nav-link.active {
  color: var(--brand-ink) !important;
}

/* Navbar CTA buttons: one red, one black */
#navbar .ar-nav-cta {
  font-weight: 800;
  letter-spacing: 0;
  border-radius: 12px !important;
}

#navbar .ar-nav-cta--call {
  background: var(--brand-primary) !important;
  border-color: var(--brand-primary) !important;
  color: #fff !important;
}

#navbar .ar-nav-cta--call:hover,
#navbar .ar-nav-cta--call:focus {
  background: var(--brand-primary-dark) !important;
  border-color: var(--brand-primary-dark) !important;
}

#navbar .ar-nav-cta--quote {
  background: var(--ar-navy) !important;
  border-color: var(--ar-navy) !important;
  color: #fff !important;
}

#navbar .ar-nav-cta--quote:hover,
#navbar .ar-nav-cta--quote:focus {
  background: #111118 !important;
  border-color: #111118 !important;
}

/* Dropdown menu: cleaner */
.navbar-nav .dropdown-menu {
  border-radius: var(--ar-radius) !important;
  border: 1px solid rgba(148, 163, 184, 0.18) !important;
  box-shadow: var(--ar-shadow-soft) !important;
}

#navbar .navbar-nav .dropdown-menu {
  background: #ffffff !important;
}

#navbar .navbar-nav .dropdown-item {
  color: var(--brand-ink) !important;
}

#navbar .navbar-nav .dropdown-item:hover,
#navbar .navbar-nav .dropdown-item:focus {
  background: rgba(15, 23, 42, 0.06) !important;
  color: var(--brand-ink) !important;
}

/* Fix 'View All Services' hover readability */
#navbar .navbar-nav .dropdown-item.all-services:hover,
#navbar .navbar-nav .dropdown-item.all-services:focus {
  color: #000 !important;
}

/* Buttons: make them feel different */
.btn,
button,
input[type="submit"] {
  border-radius: var(--ar-radius-sm) !important;
}

.btn-primary {
  background-color: var(--ar-accent) !important;
  border-color: var(--ar-accent) !important;
  color: #fff !important;
}

.btn-primary:hover,
.btn-primary:focus {
  background-color: var(--ar-accent-dark) !important;
  border-color: var(--ar-accent-dark) !important;
}

.btn-outline-primary {
  border-color: var(--brand-primary) !important;
  color: var(--brand-primary) !important;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
  background: rgba(239, 68, 68, 0.10) !important;
  border-color: var(--brand-primary) !important;
  color: var(--brand-primary-dark) !important;
}

/* Cards / sections */
.card,
.service-box,
.service-card {
  border-radius: var(--ar-radius) !important;
  border-color: var(--ar-border) !important;
}

/* Headings */
h1, h2, h3, h4 {
  color: var(--brand-ink);
  letter-spacing: -0.015em;
}

/* Dark mode: keep it coherent */
body.dark-mode {
  background: #0b1220;
  color: #e2e8f0;
}

body.dark-mode a {
  color: #fb7185;
}

body.dark-mode #navbar .navbar {
  background: rgba(15, 23, 42, 0.80) !important;
  border-color: rgba(148, 163, 184, 0.18) !important;
}

/* Footer */
.ar-footer {
  margin-top: 0;
}

.ar-footer-cta {
  background: linear-gradient(135deg, var(--ar-navy) 0%, var(--ar-navy-2) 55%, rgba(239,68,68,0.30) 100%);
  padding: 26px 0;
}

.ar-footer-cta-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.ar-footer-cta-title {
  margin: 0;
  color: #fff;
  font-weight: 900;
  letter-spacing: -0.02em;
}

.ar-footer-cta-sub {
  margin: 6px 0 0;
  color: rgba(255,255,255,0.82);
}

.ar-footer-cta-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.ar-footer-cta .btn {
  border-radius: 14px !important;
  font-weight: 800;
}

/* Footer CTA buttons: red + black (no orange/white) */
.ar-footer-cta .btn-primary {
  background: var(--brand-primary) !important;
  border-color: var(--brand-primary) !important;
  color: #fff !important;
}

.ar-footer-cta .btn-primary:hover,
.ar-footer-cta .btn-primary:focus {
  background: var(--brand-primary-dark) !important;
  border-color: var(--brand-primary-dark) !important;
}

.ar-footer-cta .btn-outline-light {
  background: var(--ar-navy) !important;
  border-color: var(--brand-primary) !important;
  color: #fff !important;
}

.ar-footer-cta .btn-outline-light:hover,
.ar-footer-cta .btn-outline-light:focus {
  background: #111118 !important;
  border-color: var(--brand-primary-dark) !important;
  color: #fff !important;
}

.ar-footer-main {
  background: var(--ar-navy);
  color: rgba(255,255,255,0.82);
  padding: 56px 0;
}

.ar-footer-brand img {
  filter: drop-shadow(0 10px 28px rgba(0,0,0,0.35));
}

.ar-footer-about {
  margin: 14px 0 16px;
  max-width: 420px;
  color: rgba(255,255,255,0.78);
}

.ar-footer-heading {
  color: #fff;
  font-weight: 900;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 14px;
}

.ar-footer-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.ar-footer-list li {
  margin: 0 0 10px;
}

.ar-footer-main a {
  color: rgba(255,255,255,0.80);
  text-decoration: none;
}

.ar-footer-main a:hover {
  color: #fb7185;
}

.ar-footer-social {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.ar-social {
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.06);
}

.ar-social:hover {
  border-color: rgba(239,68,68,0.40);
  background: rgba(239,68,68,0.10);
}

.ar-footer-muted {
  color: rgba(255,255,255,0.70);
}

.ar-footer-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 18px;
}

.ar-chip {
  display: inline-flex;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.06);
  font-weight: 700;
  font-size: 12px;
  color: rgba(255,255,255,0.78);
}

.ar-footer-contact {
  border-top: 1px solid rgba(255,255,255,0.10);
  padding-top: 14px;
}

.ar-footer-contact-row {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding: 6px 0;
}

.ar-footer-contact-k {
  font-weight: 900;
  color: rgba(255,255,255,0.88);
}

.ar-footer-bottom {
  background: #070d18;
  color: rgba(255,255,255,0.70);
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: 14px 0;
}

.ar-footer-bottom-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}

.ar-footer-bottom-links {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}

.ar-footer-bottom a {
  color: rgba(255,255,255,0.70);
}

.ar-footer-bottom a:hover {
  color: #fb7185;
}

@media (max-width: 768px) {
  .ar-footer-cta-inner {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* Keep footer readable in forced dark-mode pages */
body.dark-mode .ar-footer-main {
  background: #0b1220;
}

/* Homepage content blocks */
.ar-hero {
  /* Matte metallic red (less glossy / less pink) */
  background: linear-gradient(
    135deg,
    #140203 0%,
    #2b0508 26%,
    #5a0d13 58%,
    #7f121a 78%,
    #250406 100%
  );
  color: rgba(255,255,255,0.90);
  position: relative;
  overflow: hidden;
}

.ar-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  /* Subtle "brushed" texture + soft vignettes */
  background:
    radial-gradient(900px 520px at 16% 22%, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0) 62%),
    radial-gradient(760px 460px at 90% 8%, rgba(0,0,0,0.22) 0%, rgba(0,0,0,0) 58%),
    repeating-linear-gradient(
      115deg,
      rgba(255,255,255,0.035) 0px,
      rgba(255,255,255,0.035) 2px,
      rgba(0,0,0,0) 2px,
      rgba(0,0,0,0) 12px
    ),
    linear-gradient(135deg, rgba(0,0,0,0.22) 0%, rgba(0,0,0,0.42) 55%, rgba(0,0,0,0.18) 100%);
  pointer-events: none;
}

.ar-hero > .container {
  position: relative;
  z-index: 1;
}

/* Hero: inline quote form card */
.ar-hero-quote-card {
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(255,255,255,0.28);
  border-radius: 18px;
  box-shadow: 0 28px 70px rgba(2,6,23,0.40);
  padding: 22px;
}

/* Same card, but for non-hero (light) pages */
.ar-quote-card {
  background: #ffffff;
  border-color: rgba(15, 23, 42, 0.10);
  box-shadow: 0 18px 45px rgba(2, 6, 23, 0.12);
}

.ar-hero-quote-title {
  margin: 0;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: -0.02em;
  color: var(--brand-ink);
}

.ar-hero-quote-sub {
  margin: 6px 0 0;
  color: rgba(15, 23, 42, 0.72);
  font-weight: 600;
  line-height: 1.5;
}

.ar-hero-quote-form {
  margin-top: 14px;
}

.ar-hero-form-label {
  display: block;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  margin: 0 0 6px;
  color: rgba(15, 23, 42, 0.70);
}

.ar-hero-quote-card .form-control {
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  background: rgba(255,255,255,0.95);
  padding: 11px 12px;
}

.ar-hero-quote-card .form-control:focus {
  border-color: rgba(239, 68, 68, 0.55);
  box-shadow: 0 0 0 0.18rem rgba(239, 68, 68, 0.12);
}

.ar-hero-quote-actions {
  display: grid;
  gap: 10px;
}

.ar-hero-quote-actions .btn {
  border-radius: 14px !important;
  font-weight: 800;
  padding: 12px 14px;
}

/* Force hero form buttons to match red/black scheme (not orange) */
.ar-hero-quote-actions .btn.btn-primary {
  background: var(--brand-primary) !important;
  border-color: var(--brand-primary) !important;
}

.ar-hero-quote-actions .btn.btn-primary:hover,
.ar-hero-quote-actions .btn.btn-primary:focus {
  background: var(--brand-primary-dark) !important;
  border-color: var(--brand-primary-dark) !important;
}

.ar-hero-quote-actions .btn.btn-outline-primary {
  background: var(--ar-navy) !important;
  border-color: var(--ar-navy) !important;
  color: #fff !important;
}

.ar-hero-quote-actions .btn.btn-outline-primary:hover,
.ar-hero-quote-actions .btn.btn-outline-primary:focus {
  background: #111118 !important;
  border-color: #111118 !important;
}

/* Contact + FAQ pages: force red/black accents (avoid legacy orange/blue) */
.ar-page--contact .btn-primary,
.ar-page--faqs .btn-primary {
  background: var(--brand-primary) !important;
  border-color: var(--brand-primary) !important;
  color: #fff !important;
}

.ar-page--contact .btn-primary:hover,
.ar-page--contact .btn-primary:focus,
.ar-page--faqs .btn-primary:hover,
.ar-page--faqs .btn-primary:focus {
  background: var(--brand-primary-dark) !important;
  border-color: var(--brand-primary-dark) !important;
}

.ar-page--faqs .accordion .btn-link {
  color: var(--brand-ink) !important;
}

.ar-page--faqs .accordion .btn-link:hover,
.ar-page--faqs .accordion .btn-link:focus {
  color: var(--brand-primary) !important;
  text-decoration: none;
}

/* Contact page: layout + premium panel */
.ar-page--contact .ar-contact-panel {
  height: 100%;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 18px;
  box-shadow: 0 26px 65px rgba(2,6,23,0.35);
  padding: 28px;
  color: rgba(255,255,255,0.86);
}

.ar-page--contact .ar-contact-panel-title {
  margin: 0;
  color: #ffffff;
  font-weight: 950;
  font-size: 22px;
  letter-spacing: -0.01em;
}

.ar-page--contact .ar-contact-panel-sub {
  margin: 10px 0 18px;
  color: rgba(255,255,255,0.82);
  line-height: 1.6;
  font-weight: 600;
}

.ar-page--contact .ar-contact-kv {
  margin: 0 0 14px;
}

.ar-page--contact .ar-contact-k {
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(255,255,255,0.70);
  margin-bottom: 4px;
}

.ar-page--contact .ar-contact-v {
  color: #ffffff;
  font-weight: 850;
  text-decoration: none;
}

.ar-page--contact a.ar-contact-v:hover,
.ar-page--contact a.ar-contact-v:focus {
  color: #ffffff;
  text-decoration: underline;
  text-decoration-color: rgba(239, 68, 68, 0.65);
}

.ar-page--contact .ar-contact-hours {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.14);
}

.ar-page--contact .ar-contact-hours-list {
  list-style: none;
  padding: 0;
  margin: 10px 0 0;
}

.ar-page--contact .ar-contact-hours-list li {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding: 6px 0;
  color: rgba(255,255,255,0.84);
  font-weight: 650;
}

.ar-page--contact .ar-contact-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 18px;
}

.ar-page--contact .btn-outline-primary {
  background: var(--ar-navy) !important;
  border-color: var(--ar-navy) !important;
  color: #fff !important;
}

.ar-page--contact .btn-outline-primary:hover,
.ar-page--contact .btn-outline-primary:focus {
  background: #111118 !important;
  border-color: #111118 !important;
  color: #fff !important;
}

.ar-page--contact .ar-contact-note {
  margin-top: 16px;
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(239, 68, 68, 0.12);
  border: 1px solid rgba(239, 68, 68, 0.24);
  color: rgba(255,255,255,0.92);
  font-weight: 650;
  line-height: 1.5;
}

.ar-page--contact .ar-contact-form-card .form-control {
  height: auto;
}

.ar-page--contact .ar-contact-form-fineprint {
  margin-top: 10px;
  font-size: 12px;
  color: rgba(15, 23, 42, 0.60);
  line-height: 1.4;
}
.ar-form-fineprint {
  margin-top: 10px;
  font-size: 12px;
  color: rgba(15, 23, 42, 0.62);
  line-height: 1.45;
}
.ar-page--contact .ar-contact-map {
  width: 100%;
  height: 420px;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 14px 40px rgba(2,6,23,0.12);
  border: 1px solid rgba(15,23,42,0.10);
}

@media (max-width: 768px) {
  .ar-page--contact .ar-contact-actions .btn {
    flex: 1 1 0;
    min-width: 0;
    text-align: center;
  }
}

@media (max-width: 768px) {
  .ar-hero-quote-card {
    padding: 18px;
  }
}

.ar-home-block {
  padding: 90px 0;
}

.ar-home-block--light {
  background: var(--ar-gray);
}

.ar-home-block--tint {
  background: #f8fafc;
}

.ar-eyebrow {
  display: inline-flex;
  gap: 10px;
  align-items: center;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(15, 23, 42, 0.70);
  margin-bottom: 10px;
}

.ar-home-title {
  font-weight: 900;
  letter-spacing: -0.02em;
  margin: 0 0 12px;
}

.ar-home-lead {
  color: #475569;
  font-size: 18px;
  line-height: 1.7;
  margin: 0;
}

.ar-home-media img {
  width: 100%;
  height: auto;
  border-radius: 18px;
  box-shadow: var(--ar-shadow-soft);
  border: 1px solid var(--ar-border);
}

.ar-checklist {
  list-style: none;
  padding: 0;
  margin: 18px 0 0;
}

.ar-checklist li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  margin: 0 0 10px;
  color: #334155;
  font-weight: 700;
}

.ar-checklist i {
  color: var(--brand-primary);
  font-size: 18px;
  line-height: 1;
  margin-top: 2px;
}

.ar-home-actions {
  margin-top: 18px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

/* Homepage 'Why homeowners choose' CTAs: red + black */
.ar-home-actions .btn-primary {
  background: var(--brand-primary) !important;
  border-color: var(--brand-primary) !important;
  color: #fff !important;
}

.ar-home-actions .btn-primary:hover,
.ar-home-actions .btn-primary:focus {
  background: var(--brand-primary-dark) !important;
  border-color: var(--brand-primary-dark) !important;
}

.ar-home-actions .btn-outline-primary {
  background: var(--ar-navy) !important;
  border-color: var(--ar-navy) !important;
  color: #fff !important;
}

.ar-home-actions .btn-outline-primary:hover,
.ar-home-actions .btn-outline-primary:focus {
  background: #111118 !important;
  border-color: #111118 !important;
  color: #fff !important;
}

.ar-step-card {
  background: #fff;
  border: 1px solid var(--ar-border);
  border-radius: 18px;
  padding: 26px;
  height: 100%;
  box-shadow: var(--ar-shadow-soft);
}

.ar-step-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}

.ar-step-head .ar-step-icon {
  margin-bottom: 0;
  flex: 0 0 auto;
}

.ar-step-head h3 {
  margin: 0;
}

.ar-step-icon {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(239, 68, 68, 0.10);
  color: var(--brand-primary-dark);
  margin-bottom: 12px;
  font-size: 18px;
}

.ar-step-card h3 {
  font-weight: 900;
  font-size: 18px;
  margin: 0 0 8px;
}

.ar-step-card p {
  margin: 0;
  color: #475569;
  line-height: 1.65;
}

.ar-chip-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.ar-chip-light {
  display: inline-flex;
  padding: 10px 14px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--ar-border);
  box-shadow: 0 8px 22px rgba(2, 6, 23, 0.06);
  font-weight: 900;
  color: #0f172a;
}

.ar-home-note {
  margin-top: 14px;
  padding: 14px 16px;
  border-radius: 16px;
  background: rgba(239, 68, 68, 0.10);
  border: 1px solid rgba(239, 68, 68, 0.22);
  color: #7f1d1d;
  font-weight: 800;
}

.ar-home-note a {
  color: #7f1d1d;
  text-decoration: underline;
}

.ar-price-note {
  margin-top: 16px;
  padding: 14px 16px;
  border-radius: 16px;
  background: rgba(249, 115, 22, 0.10);
  border: 1px solid rgba(249, 115, 22, 0.22);
  color: #0f172a;
  font-weight: 800;
  line-height: 1.6;
}

@media (max-width: 768px) {
  .ar-home-block {
    padding: 70px 0;
  }

  /* Center homepage CTA buttons on mobile; prefer side-by-side */
  .ar-home-actions {
    justify-content: center;
    flex-wrap: nowrap;
  }

  .ar-home-actions .btn {
    flex: 1 1 0;
    min-width: 0;
    text-align: center;
  }

  /* Slightly tighter buttons on mobile so two can fit */
  .ar-home-actions .btn.btn-lg {
    padding: 12px 14px;
  }

  /* If screen is extremely narrow, allow stacking instead of overflow */
  @media (max-width: 389px) {
    .ar-home-actions {
      flex-wrap: wrap;
    }

    .ar-home-actions .btn {
      flex: 0 1 auto;
      min-width: auto;
    }
  }

  /* Home hero: center text + CTAs on mobile */
  .ar-hero {
    text-align: center;
  }
  .ar-hero h1,
  .ar-hero p {
    margin-left: auto;
    margin-right: auto;
  }
  .ar-hero .ar-hero-actions {
    justify-content: center !important;
  }
}
