/* ============================================================
   HOME PAGE STYLES — Oil City Ready Mix Ltd.
   Page-specific only. Global styles in global/base.css
   ============================================================ */


/* ════════════════════════════════════════════
   1. HERO — Full-bleed video background, centered text
════════════════════════════════════════════ */
.hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: var(--header-h);
    overflow: hidden;
}

/* ── Video background ── */
.hero-video-wrap {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.hero-video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: var(--hero-pos, center 10%);
    display: block;
}

/* Dark overlay so text stays readable */
.hero-video-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
    to bottom,
    rgba(10, 15, 28, 0.45) 0%,
    rgba(10, 15, 28, 0.55) 50%,
    rgba(10, 15, 28, 0.65) 100%
  );
}

/* ── Centered content container ── */
.hero-container {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding-top: var(--space-16);
    padding-bottom: var(--space-20);
    max-width: 1400px;
    margin-inline: auto;
    width: 100%;
}

/* Badge / pill overline */
.hero-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-3);
    font-size: var(--text-xs);
    font-weight: var(--weight-semibold);
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-primary);
    margin-bottom: var(--space-6);
    background: var(--color-primary-glow);
    border: 1px solid rgba(201, 169, 98, 0.35);
    padding: 0.4rem 1rem 0.4rem 0.75rem;
    border-radius: var(--radius-full);
    width: fit-content;
}

.hero-badge__dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--color-primary);
    flex-shrink: 0;
    animation: pulse-dot 2.2s ease-in-out infinite;
}

@keyframes pulse-dot {
    0%, 100% {
        box-shadow: 0 0 0 0 rgba(201, 169, 98, 0.7);
    }

    50% {
        box-shadow: 0 0 0 6px rgba(201, 169, 98, 0);
    }
}

/* Hero title */
.hero-title {
    font-size: clamp(3rem, 6vw, 5.5rem);
    font-weight: 900;
    line-height: 0.95;
    letter-spacing: -0.04em;
    color: #ffffff;
    margin-bottom: var(--space-8);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.1em;
}

@media (max-width: 640px) {
    .hero-title {
        font-size: clamp(2rem, 6vw, 5.5rem);
    }
}

.hero-line {
    display: block;
    width: 100%;
}

.hero-line--gold {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 55%, var(--color-primary) 100%);
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    animation: shimmer 4s linear infinite;
    display: inline;
}

@keyframes shimmer {
    0% {
        background-position: 200% center;
    }

    100% {
        background-position: -200% center;
    }
}

/* Subtitle grid — two columns side by side */
.hero-sub-grid {
    display: flex;
              /* change from grid → flex */
    flex-direction: column;
     /* stack them */
    align-items: center;
        /* center horizontally */
    text-align: center;
         /* center text */
    gap: var(--space-5);
    margin-bottom: var(--space-10);
}

.hero-sub {
    font-size: clamp(1.2rem, 1.3vw, 1.05rem);
    font-weight: var(--weight-regular);
    color: rgba(255, 255, 255, 0.72);
    line-height: 1.78;
    max-width: 100%;
    margin-bottom: 0;
}

@media (max-width: 640px) {
    .hero-sub-grid {
        grid-template-columns: 1fr;
        gap: var(--space-5);
    }

    .hero-sub--bordered {
        padding-left: 0;
        border-left: none;
        padding-top: var(--space-5);
    /* border-top: 1px solid rgba(201, 169, 98, 0.3); */
    }
}

/* CTAs */
.hero-ctas {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-4);
    flex-wrap: wrap;
}

/* ── Override btn-ghost so it's visible on dark bg ── */
.hero .btn-ghost {
  color: #ffffff;
  border: 2px solid rgba(255, 255, 255, 0.45);
  background: transparent;
}

.hero .btn-ghost:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background: var(--color-primary-glow);
}

/* ── Override btn-primary for hero ── */
.hero .btn-primary {
  background: var(--color-primary);
  color: var(--color-navy);
  border: 2px solid var(--color-primary);
  font-weight: var(--weight-bold);
}

.hero .btn-primary:hover {
  background: var(--color-accent);
  border-color: var(--color-accent);
}

/* Scroll indicator */
.scroll-indicator {
  position: absolute;
  bottom: var(--space-6);
  left: 50%;
  transform: translateX(-50%);
  z-index: 4;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  color: rgba(255, 255, 255, 0.45);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  text-decoration: none;
  transition: color var(--dur-base) var(--ease-out);
  animation: bob 2.8s ease-in-out infinite;
}

.scroll-indicator:hover { color: var(--color-primary); }

@keyframes bob {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(8px); }
}

/* ── Responsive ── */
@media (max-width: 640px) {
  .hero-ctas {
    flex-direction: column;
    width: 100%;
  }
  .hero-ctas .btn {
    width: 100%;
    justify-content: center;
  }
  .scroll-indicator { display: none; }
}

/* ════════════════════════════════════════════
   2. MISSION STRIP
════════════════════════════════════════════ */
.mission-strip {
  background: #0A0F1C;
  padding-block: var(--space-16);
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

.mission-inner {
  max-width: 820px;
  margin-inline: auto;
  text-align: center;
}

.mission-label {
  display: inline-block;
  font-size: var(--text-lg);
  font-weight: var(--weight-semibold);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: var(--space-5);
}

.mission-quote {
   font-size: clamp(1.2rem, 2.5vw, 1.65rem);
  font-weight: var(--weight-medium);
  font-style: italic;
  color: rgba(255,255,255,0.88);
  line-height: 1.65;
  letter-spacing: -0.01em;

  /* CHANGE THESE 👇 */
  border-left: none;
  padding-left: 0;
  text-align: center;

  margin: 0 auto;
  max-width: 700px;
}

/* ════════════════════════════════════════════
   2b. STATS STRIP (kept for reference, unused)
════════════════════════════════════════════ */
.stats-strip {
  background: #0A0F1C;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  padding-block: var(--space-12);
}

.stats-grid {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.stat-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  flex: 1;
  min-width: 130px;
  gap: var(--space-1);
}

.stat-number {
  font-size: clamp(2.25rem, 4.5vw, 3.5rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  color: var(--color-primary);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

.stat-unit {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.5);
  margin-top: var(--space-1);
}

.stat-label {
  font-size: var(--text-xs);
  color: rgba(255, 255, 255, 0.3);
  letter-spacing: 0.05em;
  margin-top: 2px;
}

.stat-divider {
  width: 1px;
  height: 56px;
  background: rgba(255, 255, 255, 0.08);
  flex-shrink: 0;
}

@media (max-width: 700px) {
  .stat-divider { display: none; }
  .stats-grid { justify-content: center; gap: var(--space-8); }
}


/* ════════════════════════════════════════════
   3. ABOUT — Split layout + image stack
════════════════════════════════════════════ */
.about-section { background: var(--color-bg); }

.about-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(var(--space-12), 6vw, var(--space-24));
  align-items: center;
}

.about-heading {
  color: var(--color-primary);
  font-size: clamp(1.6rem, 2.8vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.4;
  margin-bottom: var(--space-6);
}

.about-body {
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  line-height: 1.75;
  margin-bottom: var(--space-4);
  text-align: justify;
}

.about-quote {
  border-left: 2px solid var(--color-primary);
  padding-left: var(--space-5);
  margin-block: var(--space-8);
}

.about-quote p {
  font-size: var(--text-xl);
  font-weight: var(--weight-medium);
  font-style: italic;
  color: var(--color-text);
  letter-spacing: -0.01em;
}

/* Image stack (right column) */
.about-images {
  position: relative;
  padding-bottom: var(--space-12);
}

.about-img-main {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-xl);
}

.about-img-main img {
  width: 100%;
  height: 500px;
  object-fit: cover;
  display: block;
  transition: transform 0.8s var(--ease-out);
}

.about-img-main:hover img { transform: scale(1.04); }

.about-img-accent {
  position: absolute;
  bottom: 0;
  left: -var(--space-8);
  left: -2rem;
  width: 55%;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-xl);
  border: 3px solid var(--color-bg);
}

.about-img-accent img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  display: block;
}

.about-img-badge {
  position: absolute;
  top: var(--space-6);
  right: -var(--space-4);
  right: -1rem;
  background: var(--color-primary);
  color: var(--color-black);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-5);
  text-align: center;
  box-shadow: var(--shadow-gold);
  animation: float-up 4s ease-in-out infinite;
}

.about-img-badge__num {
  display: block;
  font-size: 2rem;
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1;
}

.about-img-badge__text {
  font-size: 0.65rem;
  font-weight: var(--weight-semibold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  line-height: 1.4;
  opacity: 0.8;
}

.why-intro-section { background: var(--color-bg-secondary); }

@media (max-width: 960px) {
  .about-layout { grid-template-columns: 1fr; }
  .about-images { padding-bottom: var(--space-16); }
  .about-img-badge { right: var(--space-4); }
  .about-img-accent { display: none; }

  .why-intro-section .about-text   { order: 1; }
  .why-intro-section .about-images { order: 2; }
}


/* ════════════════════════════════════════════
   4. SERVICES — Cards with top images
════════════════════════════════════════════ */
.services-section{ background: var(--color-bg);}
/* Full-width stacked header */
.services-header {
  margin-bottom: var(--space-14);
  
}

.services-header h2 {
  font-size: clamp(1.6rem, 2.8vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  margin-bottom: var(--space-6);
  color: var(--color-primary);
}

.services-header__intro {
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  line-height: 1.75;
   max-width: 100ch;
}

/* Open text specs — no card borders */
.services-specs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  padding-block: var(--space-12);
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-14);
}

.services-spec__title {
  font-size: clamp(1.1rem, 2vw, 1.35rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--color-text);
  margin-bottom: var(--space-4);
}

.services-spec__body {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  line-height: 1.75;
  text-align: justify;
}

/* Types of Offerings label */
.services-offerings-title {
  font-size: clamp(1.1rem, 2vw, 1.35rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--color-text);
  margin-bottom: var(--space-8);
}

.services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  margin-bottom: var(--space-12);
}

.services-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  transition:
    border-color var(--dur-base) var(--ease-out),
    transform    var(--dur-base) var(--ease-out),
    box-shadow   var(--dur-base) var(--ease-out);
}

.services-card:hover {
  border-color: var(--color-border-hover);
  transform: translateY(-8px);
  box-shadow: var(--shadow-lg), var(--shadow-gold);
}

/* Card image */
.services-card__img {
  position: relative;
  height: 220px;
  overflow: hidden;
}

.services-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.7s var(--ease-out);
}

.services-card:hover .services-card__img img { transform: scale(1.07); }

.services-card__img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 40%, rgba(8,8,8,0.6) 100%);
}

/* Card body */
.services-card__body {
  padding: var(--space-8);
}

/* Gold bar — full width inside card body */
.services-card .gold-bar {
  display: block;
  width: 100%;
  border-radius: 0;
}

.services-card h3 {
  font-size: clamp(1.25rem, 2vw, 1.6rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-bottom: var(--space-3);
  color: var(--color-text);
}

.services-card p {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  margin-bottom: var(--space-6);
  line-height: 1.7;
}

.services-card__features {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  border-top: 1px solid var(--color-border-subtle);
  padding-top: var(--space-5);
}

.services-card__features li {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  padding-left: var(--space-5);
  position: relative;
}

.services-card__features li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 9px;
  width: 12px;
  height: 1.5px;
  background: var(--color-primary);
  border-radius: var(--radius-full);
}

/* Order callout banner */
.services-callout {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-8) var(--space-10);
}

.services-callout__body {
  display: block;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.6;
}

.services-callout-cta {
  margin-top: var(--space-6);
}

@media (max-width: 900px) {
  .services-specs  { grid-template-columns: 1fr; }
  .services-grid   { grid-template-columns: 1fr; }
}
@media (max-width: 540px) {
  .services-callout-cta .btn {
    width: 100%;
    white-space: normal;
    text-align: center;
  }
}


/* ════════════════════════════════════════════
   5. CORPORATE STRUCTURE
════════════════════════════════════════════ */
.corporate-section { background: var(--color-bg-secondary); }

.corporate-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(var(--space-12), 6vw, var(--space-24));
  align-items: center;
}

.corporate-heading {
  font-size: clamp(1.6rem, 2.8vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.1;
  color: var(--color-primary);
  margin-bottom: var(--space-6);
}

.corporate-body {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  line-height: 1.78;
  text-align: justify;
}

/* ── Hierarchy chart (right column) ── */
.corporate-chart {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-10);
  box-shadow: var(--shadow-md);
}

/* Parent card */
.corp-parent {
  background: #0A0F1C;
  border-radius: var(--radius-lg);
  padding: var(--space-6) var(--space-8);
  text-align: center;
  position: relative;
  box-shadow: var(--shadow-lg);
}

.corp-parent__badge {
  display: inline-block;
  font-size: 0.6rem;
  font-weight: var(--weight-semibold);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-primary);
  background: rgba(201,169,98,0.12);
  border: 1px solid rgba(201,169,98,0.22);
  border-radius: var(--radius-full);
  padding: 0.2rem 0.75rem;
  margin-bottom: var(--space-3);
}

.corp-parent__name {
  font-size: clamp(1rem, 2vw, 1.2rem);
  font-weight: 700;
  color: #ffffff;
  letter-spacing: -0.02em;
  line-height: 1.3;
}

.corp-parent__abbr {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: 0.18em;
  color: var(--color-primary);
  margin-top: var(--space-1);
}

/* Connector */
.corp-connector {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-block: var(--space-3);
  gap: 0;
}

.corp-connector__line {
  width: 1px;
  height: 20px;
  background: var(--color-primary);
  opacity: 0.4;
}

.corp-connector__branches {
  display: flex;
  justify-content: space-between;
  width: 60%;
  position: relative;
}

.corp-connector__branches::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--color-primary);
  opacity: 0.3;
}

.corp-connector__branches span {
  display: block;
  width: 1px;
  height: 14px;
  background: var(--color-primary);
  opacity: 0.35;
}

/* Group header box */
.corp-group-header {
  background: #0A0F1C;
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-8);
  text-align: center;
  box-shadow: var(--shadow-lg);
}

.corp-group-label {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-primary);
}

/* Flow connector — vertical line + arrowhead */
.corp-flow-connector {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}

.corp-flow-line {
  width: 1.5px;
  height: 18px;
  background: var(--color-primary);
  opacity: 0.45;
}

.corp-flow-arrowhead {
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 7px solid rgba(201, 169, 98, 0.5);
}

/* Numbered prefix inside each row */
.corp-sub__num {
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  color: var(--color-primary);
  letter-spacing: 0.06em;
  flex-shrink: 0;
}

/* Subsidiary rows */
.corp-subs {
  display: flex;
  flex-direction: column;
  gap: var(--space-10);
  margin-top: var(--space-10);
}

.corp-sub {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  transition:
    border-color var(--dur-base) var(--ease-out),
    box-shadow   var(--dur-base) var(--ease-out);
}

.corp-sub:hover {
  border-color: rgba(201,169,98,0.3);
  box-shadow: 0 2px 16px rgba(201,169,98,0.08);
}

/* Active sub (OCRM — current company) */
.corp-sub--active {
  border-color: rgba(201,169,98,0.35);
  background: rgba(201,169,98,0.04);
}

.corp-sub__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(201,169,98,0.2);
  flex-shrink: 0;
  animation: pulse-dot 2.2s ease-in-out infinite;
}

.corp-sub__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 2px;
  min-width: 0;
}

.corp-sub__abbr {
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  letter-spacing: 0.12em;
  color: var(--color-primary);
  text-transform: uppercase;
}

.corp-sub__name {
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
  letter-spacing: -0.01em;
}

.corp-sub__tag {
  font-size: var(--text-xs);
  color: var(--color-text-subtle);
  letter-spacing: 0.02em;
  width: 100%;
}


@media (max-width: 960px) {
  .corporate-layout { grid-template-columns: 1fr; }
}


/* ════════════════════════════════════════════
   6. WHY CHOOSE US — Full-bleed contrast
════════════════════════════════════════════ */
.why-section {
  position: relative;
  overflow: hidden;
  padding-block: var(--section-py);
}

/* Background image */
.why-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.why-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Dark overlay */
.why-overlay {
  position: absolute;
  inset: 0;
  background: rgba(6, 14, 8, 0.88);
  z-index: 1;
}

/* Diagonal stripe pattern */
.why-pattern {
  position: absolute;
  inset: 0;
  z-index: 2;
  background-image: repeating-linear-gradient(
    -45deg,
    transparent,
    transparent 60px,
    rgba(201,162,39,0.03) 60px,
    rgba(201,162,39,0.03) 61px
  );
  pointer-events: none;
}

.why-container {
  position: relative;
  z-index: 3;
}

.why-header {
  max-width: 640px;
  margin-bottom: var(--space-16);
}

.why-header h2 {
  font-size: clamp(2rem, 4.5vw, 3.5rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.1;
  margin-bottom: var(--space-4);
  color: rgba(240, 237, 232, 0.95);
}

.why-header h2 em {
  font-style: italic;
  color: var(--color-primary);
  -webkit-text-fill-color: var(--color-primary);
}

.why-sub {
  font-size: var(--text-lg);
  color: rgba(240,237,232,0.65);
  max-width: 50ch;
}

.why-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  margin-bottom: var(--space-16);
  border: 1px solid rgba(201,162,39,0.1);
}

.why-item {
  padding: var(--space-10);
  border: 1px solid rgba(201,162,39,0.08);
  background: rgba(0,0,0,0.2);
  transition:
    background var(--dur-base) var(--ease-out),
    border-color var(--dur-base) var(--ease-out);
  backdrop-filter: blur(4px);
}

.why-item:hover {
  background: rgba(201,162,39,0.06);
  border-color: rgba(201,162,39,0.2);
}

.why-item__number {
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 900;
  letter-spacing: -0.04em;
  color: var(--color-primary);
  opacity: 0.22;
  line-height: 1;
  margin-bottom: var(--space-4);
  transition: opacity var(--dur-base) var(--ease-out);
}

.why-item:hover .why-item__number { opacity: 0.5; }

.why-item__title {
  font-size: clamp(1.1rem, 2vw, 1.4rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: rgba(240, 237, 232, 0.92);
  margin-bottom: var(--space-3);
}

.why-item__text {
  font-size: var(--text-base);
  color: rgba(240,237,232,0.6);
  max-width: 40ch;
  line-height: 1.72;
}

.why-cta { text-align: center; }

@media (max-width: 768px) {
  .why-grid { grid-template-columns: 1fr; }
  .why-item { padding: var(--space-8) var(--space-6); }
}


/* ════════════════════════════════════════════
   6. CALCULATOR — Full-width two-card layout
════════════════════════════════════════════ */

/* Section header */
.calculator-section{background:var(--color-bg);}
.calc-header {
  
  margin-bottom: var(--space-12);
}

.calc-header h2 {
  font-size: clamp(1.6rem, 2.8vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  margin-bottom: 0;
  color: var(--color-primary);
}

/* Two calculator cards side by side */
.calc-cards-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
  margin-bottom: var(--space-8);
}

.calc-card {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.calc-card__header {
  border-bottom: 1px solid var(--color-border);
  padding: var(--space-6) var(--space-8);
}

.calc-card__title {
  font-size: clamp(1rem, 1.8vw, 1.2rem);
  font-weight: var(--weight-bold);
  letter-spacing: -0.02em;
  color: var(--color-text);
  margin-bottom: var(--space-1);
}

.calc-note {
  font-size: var(--text-xs);
  color: var(--color-text-subtle);
  margin-bottom: 0;
}

.calc-form {
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: var(--space-5);
}

/* Stacked fields inside each card */
.calc-fields-stack {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.calc-result {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--space-6);
  background: var(--color-bg-tertiary);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  text-align: center;
  gap: var(--space-1);
  margin-top: auto;
}

.calc-result__label {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.calc-result__value {
  font-size: clamp(2.25rem, 5vw, 3.5rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  color: var(--color-primary);
  line-height: 1;
  transition: all var(--dur-base) var(--ease-spring);
}

/* Disclaimer accordion */
.calc-disclaimer-block {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.calc-disclaimer-toggle {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-5) var(--space-6);
  background: var(--color-bg-secondary);
  border: none;
  cursor: pointer;
  touch-action: manipulation;
  text-align: left;
  transition: color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
}

.calc-disclaimer-toggle:hover {
  color: var(--color-text);
  background: var(--color-bg-tertiary);
}

.calc-disclaimer-icon {
  flex-shrink: 0;
  transition: transform var(--dur-base) var(--ease-out);
}

.calc-disclaimer-toggle[aria-expanded="true"] .calc-disclaimer-icon {
  transform: rotate(180deg);
}

.calc-disclaimer-body {
  display: none;
  padding: var(--space-6);
  border-top: 1px solid var(--color-border);
  background: var(--color-bg-elevated);
}

.calc-disclaimer-body.open {
  display: block;
}

.calc-disclaimer-body p {
  font-size: var(--text-sm);
  color: var(--color-text-subtle);
  line-height: 1.7;
  text-align: center;
  max-width: 100%;
}

.calc-disclaimer-body p:not(:last-child) {
  margin-bottom: var(--space-3);
}

@media (max-width: 768px) {
  .calc-cards-grid { grid-template-columns: 1fr; }
}


/* ════════════════════════════════════════════
   7. QUOTE FORM
════════════════════════════════════════════ */
.quote-section { background: var(--color-bg-secondary); }

.quote-layout {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: clamp(var(--space-12), 6vw, var(--space-20));
  align-items: stretch;
}

.quote-text {
  display: flex;
  flex-direction: column;
}

.quote-text h2 {
  font-size: clamp(1.6rem, 2.8vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  margin-bottom: var(--space-4);
  color: var(--color-primary);
}

.quote-text > p {
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  margin-bottom: var(--space-8);
  max-width: 40ch;
  line-height: 1.7;
}

.quote-contact-strip {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin-bottom: var(--space-8);
}

.quote-contact-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-text-muted);
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease-out);
}

.quote-contact-link:hover { color: var(--color-primary); opacity: 1; }
.quote-contact-sep { color: var(--color-text-subtle); }

/* Quote image */
.quote-img {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  flex: none;
  min-height: 330px;
  max-height: 400px;
  position: relative;
}

.quote-img img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.7s var(--ease-out);
}

.quote-img:hover img { transform: scale(1.04); }

/* Form */
.quote-form-wrap {
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-10);
}

.quote-form { display: flex; flex-direction: column; gap: var(--space-5); }

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
}

.quote-submit { width: 100%; margin-top: var(--space-2); }

@media (max-width: 960px) {
  .quote-layout { grid-template-columns: 1fr; }
}

@media (max-width: 540px) {
  .form-row { grid-template-columns: 1fr; }
  .quote-form-wrap { padding: var(--space-6); }
}


/* ════════════════════════════════════════════
   8. CONTACT & GOOGLE MAPS
════════════════════════════════════════════ */
.contact-section { background: var(--color-bg); }
.contact-layout {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: clamp(var(--space-12), 6vw, var(--space-20));
  align-items: start;
}

.contact-info h2 {
  font-size: clamp(1.6rem, 2.8vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  margin-bottom: var(--space-4);
  color: var(--color-primary);
}

.contact-info > p {
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  margin-bottom: var(--space-10);
  max-width: 42ch;
  line-height: 1.7;
}

.contact-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  margin-bottom: var(--space-10);
}

.contact-list__item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
}

.contact-list__icon {
  width: 20px;
  height: 20px;
  color: var(--color-primary);
  flex-shrink: 0;
  margin-top: 3px;
}

.contact-list__label {
  display: block;
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-subtle);
  margin-bottom: 3px;
}

.contact-list__value {
  display: block;
  font-size: var(--text-base);
  color: var(--color-text-muted);
}

a.contact-list__value { transition: color var(--dur-fast) var(--ease-out); }
a.contact-list__value:hover { color: var(--color-primary); opacity: 1; }

/* Hours grid — aligns times in a column */
.contact-hours {
  display: grid;
  grid-template-columns: max-content max-content max-content;
  column-gap: var(--space-2);
  row-gap: 2px;
  align-items: baseline;
}

.contact-hours__day,
.contact-hours__time {
  font-size: var(--text-base);
  color: var(--color-text-muted);
}

.contact-hours__sep {
  color: var(--color-text-subtle);
}

/* Google Maps iframe */
.contact-map {
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-lg);
  min-height: 500px;
  height: 100%;
}

.contact-map iframe {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 500px;
  border: none;
}

@media (max-width: 900px) {
  .contact-layout { grid-template-columns: 1fr; }
  .contact-map,
  .contact-map iframe { min-height: 360px; }
}
