/* ============================================
   INNER PAGES CSS
   ============================================ */

.cards-grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; }
.cards-grid-2 { display: grid; grid-template-columns: repeat(2,1fr); gap: 2px; }

.sec-intro { font-size: 16px; color: #666; max-width: 720px; line-height: 1.85; margin-bottom: 0; }

/* Steps */
.steps-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: #e8e8e8; margin-top: 48px; }
.step { background: #fff; padding: 44px 32px; }
.step-n { font-family: var(--font-display); font-size: 64px; font-weight: 900; color: #f0f0f0; line-height: 1; margin-bottom: 16px; }
.step-title { font-family: var(--font-display); font-size: 20px; font-weight: 800; color: #111; margin-bottom: 10px; }
.step-desc { font-size: 14px; color: #888; line-height: 1.7; }

/* Brand boxes */
.brand-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 2px; margin-top: 48px; }
.brand-box {
  background: #1a1a1a; padding: 36px 28px;
  border-bottom: 3px solid rgba(255,255,255,0.07);
  transition: border-color .25s;
}
.brand-box:hover { border-bottom-color: #fff; }
.brand-name { font-family: var(--font-display); font-size: 28px; font-weight: 900; color: #fff; margin-bottom: 8px; letter-spacing: .04em; }
.brand-desc { font-size: 13px; color: rgba(255,255,255,0.35); line-height: 1.5; }

/* Series cards */
.series-grid { display: flex; flex-direction: column; gap: 2px; }
.series-card {
  background: #1a1a1a; padding: 28px 24px;
  border-left: 3px solid rgba(255,255,255,0.08);
  transition: all .3s; cursor: pointer;
}
.series-card:hover { background: #222; border-left-color: #fff; }
.series-tag { font-family: var(--font-display); font-size: 11px; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: rgba(255,255,255,0.3); margin-bottom: 6px; }
.series-name { font-family: var(--font-display); font-size: 26px; font-weight: 900; color: #fff; margin-bottom: 4px; }
.series-desc { font-size: 13px; color: rgba(255,255,255,0.4); }
.series-size { font-family: var(--font-display); font-size: 13px; font-weight: 700; color: rgba(255,255,255,0.25); letter-spacing: .08em; margin-top: 8px; }

/* Dealer badge */
.dealer-badge-section {
  display: flex; align-items: center; gap: 48px; flex-wrap: wrap;
  margin-bottom: 56px; padding-bottom: 48px; border-bottom: 2px solid #f0f0f0;
}
.dealer-badge-img {
  flex-shrink: 0; background: #f7f7f7;
  padding: 28px 36px; border: 1px solid #e8e8e8;
  display: flex; flex-direction: column; align-items: center;
}
.dealer-badge-img img { height: 56px; width: auto; display: block; }
.dealer-badge-img .dealer-label {
  font-family: var(--font-display); font-size: 11px; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase; color: #aaa;
  margin-top: 10px; text-align: center;
}
.dealer-text h3 {
  font-family: var(--font-display); font-size: 28px; font-weight: 900;
  color: #111; line-height: 1.1; margin-bottom: 12px;
}
.dealer-text p { font-size: 15px; color: #888; max-width: 440px; line-height: 1.7; }

/* Contact form */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }
.contact-details { display: flex; flex-direction: column; gap: 0; }
.contact-item { display: flex; gap: 16px; padding: 20px 0; border-bottom: 1px solid #e8e8e8; align-items: flex-start; }
.contact-item:first-child { border-top: 1px solid #e8e8e8; }
.contact-icon { font-size: 20px; flex-shrink: 0; margin-top: 2px; }
.contact-label { font-family: var(--font-display); font-size: 15px; font-weight: 800; color: #111; margin-bottom: 4px; }
.contact-val { font-size: 14px; color: #888; line-height: 1.6; }
.contact-val a { color: #111; font-weight: 600; }

.contact-form { background: #f7f7f7; padding: 48px 40px; }
.form-title { font-family: var(--font-display); font-size: 28px; font-weight: 900; color: #111; line-height: 1; margin-bottom: 8px; }
.form-sub { font-size: 14px; color: #888; line-height: 1.7; margin-bottom: 32px; }
.form-group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.form-label { font-family: var(--font-display); font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: #999; }
.form-input, .form-select, .form-textarea {
  width: 100%; padding: 13px 16px;
  border: 1px solid #e8e8e8; background: #fff;
  font-family: var(--font-body); font-size: 14px; color: #111;
  outline: none; transition: border-color .2s;
  appearance: none;
}
.form-input:focus, .form-select:focus, .form-textarea:focus { border-color: #111; }
.form-textarea { resize: vertical; min-height: 100px; }
.form-submit {
  width: 100%; background: #111; color: #fff;
  font-family: var(--font-display); font-weight: 800;
  font-size: 15px; letter-spacing: .08em; text-transform: uppercase;
  padding: 17px 36px; border: 2px solid #111;
  cursor: pointer; transition: all .2s; margin-top: 8px;
}
.form-submit:hover { background: #fff; color: #111; }
.form-note { font-size: 12px; color: #aaa; text-align: center; margin-top: 10px; }

/* Service area */
.service-area-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 2px; margin-top: 48px; }
.area-box {
  background: #1a1a1a; padding: 32px 24px;
  border-bottom: 3px solid rgba(255,255,255,0.07);
}
.area-region { font-family: var(--font-display); font-size: 22px; font-weight: 900; color: #fff; margin-bottom: 8px; }
.area-cities { font-size: 13px; color: rgba(255,255,255,0.35); line-height: 1.6; }

/* About page */
.about-story { font-size: 17px; color: #555; line-height: 1.9; margin-bottom: 24px; }
.about-story strong { color: #111; font-weight: 600; }

/* ============================================
   INNER RESPONSIVE
   ============================================ */
@media(max-width: 1024px) {
  .cards-grid-3 { grid-template-columns: 1fr 1fr; }
  .steps-grid { grid-template-columns: 1fr 1fr; }
  .brand-grid { grid-template-columns: 1fr 1fr; }
  .service-area-grid { grid-template-columns: 1fr 1fr; }
  .contact-grid { grid-template-columns: 1fr; gap: 48px; }
}

@media(max-width: 768px) {
  .cards-grid-3, .cards-grid-2 { grid-template-columns: 1fr; }
  .steps-grid { grid-template-columns: 1fr; }
  .brand-grid { grid-template-columns: 1fr 1fr; }
  .service-area-grid { grid-template-columns: 1fr 1fr; }
  .dealer-badge-section { flex-direction: column; gap: 24px; }
  .contact-form { padding: 32px 24px; }
  .photo-strip { grid-template-columns: 1fr; }
}

/* ============================================
   PAGE HERO BACKGROUND PHOTO
   ============================================ */
.page-hero-bg {
  position: absolute; inset: 0; z-index: 0; overflow: hidden;
}
.page-hero-bg img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center 40%;
  opacity: 0.28;
}
.page-hero::before { z-index: 1; }
.page-hero-content { z-index: 2; }

/* ============================================
   PHOTO STRIP (process phases)
   ============================================ */
.photo-strip {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 3px; margin-top: 56px;
}
.photo-strip-item { position: relative; overflow: hidden; aspect-ratio: 4/3; }
.photo-strip-item img {
  width: 100%; height: 100%; object-fit: cover;
  filter: brightness(0.82) contrast(1.05);
  transition: transform .5s cubic-bezier(.25,.46,.45,.94);
}
.photo-strip-item:hover img { transform: scale(1.04); }
.photo-strip-label {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 12px 16px;
  background: linear-gradient(to top, rgba(0,0,0,0.75) 0%, transparent 100%);
  font-family: var(--font-display); font-size: 12px; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,0.85);
}

/* ============================================
   INLINE PHOTO (beside body content)
   ============================================ */
.inline-photo { width: 100%; aspect-ratio: 4/3; overflow: hidden; }
.inline-photo img {
  width: 100%; height: 100%; object-fit: cover; filter: brightness(0.88);
}
