/* ==========================================================
   SSMC — Commercial Section Styles
   ss- prefix · new components only · 2026 Design System
   Hero/overlay use existing site global classes (.intro,.overlay)
   ========================================================== */

:root {
  --ss-green:     #1b463c;
  --ss-orange:    #f68b1e;
  --ss-lt-green:  #A5D6A7;
  --ss-warm-gray: #f7f6f3;
  --ss-r-card:    20px;
  --ss-r-pill:    50px;
  --ss-font:      'Lato', sans-serif;
  --ss-shadow-sm: 0 4px 20px rgba(0,0,0,.08);
  --ss-shadow-md: 0 12px 40px rgba(0,0,0,.12);
  --ss-shadow-lg: 0 24px 64px rgba(0,0,0,.16);
}

.ss-section { padding: 80px 0; }
.ss-section--gray { background: var(--ss-warm-gray); }

.ss-container { max-width: 1200px; margin: 0 auto; padding: 0 28px; }

.ss-eyebrow {
  display: inline-block;
  font-family: var(--ss-font);
  font-size: 11px; font-weight: 700;
  letter-spacing: 4px; text-transform: uppercase;
  color: var(--ss-orange); margin-bottom: 14px;
}
.ss-section-title {
  font-family: var(--ss-font);
  font-size: clamp(26px, 3.4vw, 44px);
  font-weight: 900; color: var(--ss-green);
  line-height: 1.1; letter-spacing: -1px; margin: 0 0 14px;
}
.ss-section-sub {
  font-family: var(--ss-font);
  font-size: 17px; color: #5a5a5a;
  line-height: 1.75; max-width: 620px; margin: 0 0 52px;
}

/* Buttons */
.ss-btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--ss-font);
  font-size: 12px; font-weight: 700;
  letter-spacing: 2.5px; text-transform: uppercase;
  padding: 15px 34px; border-radius: var(--ss-r-pill);
  border: none; cursor: pointer; text-decoration: none; line-height: 1;
  transition: background .2s, box-shadow .2s, transform .2s, color .2s;
}
.ss-btn svg { width: 14px; height: 14px; flex-shrink: 0; transition: transform .2s; }
.ss-btn:hover svg { transform: translateX(3px); }
.ss-btn--orange { background: var(--ss-orange); color: #fff; }
.ss-btn--orange:hover { background: #df7c10; color: #fff; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(246,139,30,.35); }
.ss-btn--green { background: var(--ss-green); color: #fff; }
.ss-btn--green:hover { background: #133028; color: #fff; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(27,70,60,.35); }
.ss-btn--outline-white { background: transparent; color: #fff; border: 2px solid rgba(255,255,255,.7); }
.ss-btn--outline-white:hover { background: #fff; color: var(--ss-green); border-color: #fff; }

/* Trust bar */
.ss-trust-bar { background: var(--ss-green); padding: 22px 24px; text-align: center; }
.ss-trust-bar p { font-family: var(--ss-font); font-size: clamp(15px, 1.7vw, 19px); font-weight: 600; color: #fff; margin: 0; }
.ss-trust-bar span { color: var(--ss-orange); }

/* Segment cards */
.ss-segments { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.ss-segment-card { position: relative; border-radius: var(--ss-r-card); overflow: hidden; height: 500px; display: block; text-decoration: none; }
.ss-segment-card img { width: 100%; height: 100%; object-fit: cover; object-position: center; transition: transform .65s ease; display: block; }
.ss-segment-card:hover img { transform: scale(1.05); }
.ss-segment-card__grad { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(to bottom, rgba(0,0,0,.02) 25%, rgba(0,0,0,.82) 100%); transition: background .4s; }
.ss-segment-card:hover .ss-segment-card__grad { background: linear-gradient(to bottom, rgba(27,70,60,.2) 0%, rgba(27,70,60,.88) 100%); }
.ss-segment-card__body { position: absolute; bottom: 0; left: 0; right: 0; padding: 34px 30px; z-index: 2; }
.ss-segment-card__label { font-family: var(--ss-font); font-size: 10px; font-weight: 700; letter-spacing: 3.5px; text-transform: uppercase; color: var(--ss-orange); display: block; margin-bottom: 7px; }
.ss-segment-card__title { font-family: var(--ss-font); font-size: clamp(20px, 2.2vw, 30px); font-weight: 900; color: #fff; line-height: 1.12; margin: 0 0 18px; }
.ss-segment-card__cta { display: inline-flex; align-items: center; gap: 7px; font-family: var(--ss-font); font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: #fff; background: var(--ss-orange); padding: 9px 20px; border-radius: var(--ss-r-pill); opacity: 0; transform: translateY(8px); transition: opacity .25s, transform .25s; text-decoration: none; }
.ss-segment-card:hover .ss-segment-card__cta { opacity: 1; transform: translateY(0); }
.ss-segment-card__cta svg { width: 12px; height: 12px; }

/* How It Works */
.ss-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 50px 36px; }
.ss-step { text-align: center; }
.ss-step__img { width: 100%; height: 180px; object-fit: contain; display: block; margin: 0 auto 24px; }
.ss-step__num { width: 54px; height: 54px; border-radius: 50%; background: var(--ss-orange); color: #fff; font-family: var(--ss-font); font-size: 20px; font-weight: 900; display: flex; align-items: center; justify-content: center; margin: 0 auto 18px; }
.ss-step__title { font-family: var(--ss-font); font-size: 18px; font-weight: 700; color: var(--ss-green); margin: 0 0 10px; }
.ss-step__body { font-family: var(--ss-font); font-size: 15px; color: #5a5a5a; line-height: 1.78; margin: 0; }

/* Split layout */
.ss-split { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
.ss-split__img { border-radius: var(--ss-r-card); overflow: hidden; height: 500px; box-shadow: var(--ss-shadow-md); }
.ss-split__img img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Feature list */
.ss-feature-list { list-style: none; padding: 0; margin: 0 0 32px; display: flex; flex-direction: column; gap: 16px; }
.ss-feature-list li { display: flex; gap: 12px; align-items: flex-start; font-family: var(--ss-font); font-size: 16px; color: #333; line-height: 1.6; }
.ss-feature-list li::before { content: ''; display: block; width: 22px; height: 22px; min-width: 22px; border-radius: 50%; background: var(--ss-lt-green) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231b463c' stroke-width='2.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center / 13px no-repeat; margin-top: 2px; flex-shrink: 0; }

/* Benefit cards */
.ss-benefits { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
.ss-benefit-card { background: #fff; border-radius: var(--ss-r-card); padding: 38px 30px; box-shadow: var(--ss-shadow-sm); transition: transform .22s, box-shadow .22s; }
.ss-benefit-card:hover { transform: translateY(-5px); box-shadow: var(--ss-shadow-md); }
.ss-benefit-card__icon { width: 52px; height: 52px; border-radius: 14px; background: var(--ss-lt-green); display: flex; align-items: center; justify-content: center; margin-bottom: 20px; }
.ss-benefit-card__icon svg { width: 24px; height: 24px; stroke: var(--ss-green); fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.ss-benefit-card__title { font-family: var(--ss-font); font-size: 17px; font-weight: 700; color: var(--ss-green); margin: 0 0 9px; }
.ss-benefit-card__body { font-family: var(--ss-font); font-size: 15px; color: #666; line-height: 1.75; margin: 0; }

/* Green CTA band */
.ss-green-band { background: var(--ss-green); padding: 90px 24px; text-align: center; }
.ss-green-band__title { font-family: var(--ss-font); font-size: clamp(22px, 3vw, 38px); font-weight: 900; color: #fff; line-height: 1.18; margin: 0 0 16px; }
.ss-green-band__sub { font-family: var(--ss-font); font-size: 17px; color: rgba(255,255,255,.82); line-height: 1.7; max-width: 680px; margin: 0 auto 32px; }
.ss-green-band__btns { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* Quote form */
.ss-form-wrap { max-width: 800px; margin: 0 auto; background: #fff; border-radius: var(--ss-r-card); padding: 56px 64px; box-shadow: var(--ss-shadow-lg); }
.ss-form-title { font-family: var(--ss-font); font-size: 26px; font-weight: 900; color: var(--ss-green); margin: 0 0 5px; }
.ss-form-note { font-family: var(--ss-font); font-size: 14px; color: #888; margin: 0 0 32px; }
.ss-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.ss-field { display: flex; flex-direction: column; }
.ss-field label { font-family: var(--ss-font); font-size: 11px; font-weight: 700; letter-spacing: 1.8px; text-transform: uppercase; color: #999; margin-bottom: 6px; }
.ss-field input, .ss-field textarea { font-family: var(--ss-font); font-size: 15px; color: #222; padding: 12px 16px; border: 1.5px solid #e2e2e2; border-radius: 10px; background: #fafafa; width: 100%; transition: border-color .2s, background .2s; box-sizing: border-box; }
.ss-field input:focus, .ss-field textarea:focus { outline: none; border-color: var(--ss-green); background: #fff; }
.ss-field input::placeholder, .ss-field textarea::placeholder { color: #bbb; }
.ss-form-grid .cf-turnstile { grid-column: 1 / -1; margin-top: 4px; }
.ss-form-submit { margin-top: 22px; text-align: center; }

/* Bottom dark bar */
.ss-cta-bar { background: #111; padding: 60px 24px; text-align: center; }
.ss-cta-bar__title { font-family: var(--ss-font); font-size: clamp(18px, 2.3vw, 28px); font-weight: 700; color: #fff; margin: 0 0 9px; }
.ss-cta-bar__sub { font-family: var(--ss-font); font-size: 15px; color: rgba(255,255,255,.55); margin: 0; }
.ss-cta-bar__sub a { color: var(--ss-orange); text-decoration: none; font-weight: 600; }
.ss-cta-bar__sub a:hover { text-decoration: underline; }

/* Responsive */
@media (max-width: 1024px) {
  .ss-split { gap: 48px; } .ss-split__img { height: 400px; }
  .ss-form-wrap { padding: 44px; }
}
@media (max-width: 768px) {
  .ss-section { padding: 52px 0; }
  .ss-segments { grid-template-columns: 1fr; }
  .ss-segment-card { height: 340px; }
  .ss-segment-card__cta { opacity: 1; transform: none; }
  .ss-steps { grid-template-columns: 1fr; gap: 40px; max-width: 460px; margin: 0 auto; }
  .ss-split { grid-template-columns: 1fr; gap: 28px; }
  .ss-split__img { height: 260px; order: -1; }
  .ss-benefits { grid-template-columns: 1fr; }
  .ss-form-wrap { padding: 28px 20px; }
  .ss-form-grid { grid-template-columns: 1fr; }
  .ss-green-band { padding: 60px 20px; }
}
@media (max-width: 480px) {
  .ss-segment-card { height: 280px; }
  .ss-btn { font-size: 11px; padding: 12px 24px; }
}
