/* Home Page — isolated brand theme (green #0f3d2e, white, gray) */
.home-page {
  --brand: #0f3d2e;
  --gray-900: #212529;
  --gray-700: #6c757d;
  --gray-500: #adb5bd;
  --gray-300: #dee2e6;
  --gray-200: #e9ecef;
  --gray-100: #f8f9fa;
  /* Accent palette for multi-step UI */
  --accent-green: #198754;
  --accent-amber: #d97706;
  --accent-indigo: #4f46e5;
  --accent-cyan: #0891b2;
}

.home-page { color: var(--gray-900); }

/* Utilities override (scoped) */
.home-page .text-primary,
.home-page .text-accent { color: var(--brand) !important; }
.home-page .bg-primary,
.home-page .bg-accent { background-color: var(--brand) !important; }
.home-page a.link-primary { color: var(--brand) !important; }
.home-page a.link-primary:hover { color: #0c2f25 !important; }

/* Buttons */
.home-page .btn-brand,
.home-page .btn-primary,
.home-page .btn-accent { background-color: var(--brand) !important; border-color: var(--brand) !important; color: #fff !important; }
.home-page .btn-brand:hover,
.home-page .btn-primary:hover,
.home-page .btn-accent:hover { background-color: #0c2f25 !important; border-color: #0c2f25 !important; }
.home-page .btn-outline-secondary { color: var(--gray-700) !important; border-color: var(--gray-300) !important; }
.home-page .btn-outline-secondary:hover { color: #fff !important; background-color: var(--brand) !important; border-color: var(--brand) !important; }
.home-page .btn-soft { color: var(--brand); background-color: rgba(15,61,46,.08); border-color: rgba(15,61,46,.12); }
.home-page .btn-soft:hover { background-color: rgba(15,61,46,.14); }

/* Hero */
.home-page .hero { border-radius: 1rem; overflow: hidden; background: linear-gradient(135deg, #0f3d2e, #14533f); }
.home-page .hero .overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02)); }
.home-page .hero-content { position: relative; z-index: 2; }
.home-page .hero-title { color: #fff; letter-spacing: .4px; }
.home-page .hero-subtitle { color: #e9ecef; }
.home-page .hero-cta .btn { box-shadow: 0 10px 20px rgba(0,0,0,.16); }
.home-page .hero-cta .btn-primary { background-color: #fff !important; color: var(--brand) !important; border-color: var(--brand) !important; }
.home-page .hero-cta .btn-primary:hover { background-color: #f8f9fa !important; }
.home-page .hero-cta .btn { padding: .5rem 1rem; font-size: .95rem; box-shadow: 0 6px 14px rgba(0,0,0,.14); }

/* Sections */
.home-page .section-title { color: var(--gray-900); }
.home-page .section-subtitle { color: var(--gray-700); }
.home-page .section-divider { width: 80px; height: 4px; border-radius: 999px; background-color: var(--brand); margin: .5rem auto 0; }

/* Service cards */
.home-page #services-overview .service-card { position: relative; border-radius: 1rem; background: #fff; border: 1px solid var(--gray-200); box-shadow: 0 10px 24px rgba(0,0,0,.08); overflow: hidden; }
.home-page #services-overview .service-card::before { content: ""; position: absolute; inset-inline: 0; top: 0; height: 4px; background: var(--accent, var(--brand)); }
.home-page #services-overview .service-card .card-body { padding: 1rem 1rem; }
.home-page #services-overview .service-card h5 { font-weight: 700; }
.home-page #services-overview .service-card .icon { width: 64px; height: 64px; border-radius: 12px; display: inline-flex; align-items: center; justify-content: center; background: var(--accent, var(--brand)); color: #fff; box-shadow: 0 8px 18px rgba(0,0,0,.10); }
.home-page #services-overview .service-card .icon i { color: #fff; }
.home-page #services-overview .service-card .text-muted { color: var(--gray-700) !important; }
.home-page #services-overview .service-card .link-primary { color: var(--accent, var(--brand)) !important; }
.home-page #services-overview .service-card:hover { transform: translateY(-3px); box-shadow: 0 16px 34px rgba(0,0,0,.12); border-color: rgba(0,0,0,.06); }

/* Accent cycling per card to avoid monotony */
.home-page #services-overview .row > [class*="col"]:nth-child(4n+1) .service-card { --accent: var(--accent-green); }
.home-page #services-overview .row > [class*="col"]:nth-child(4n+2) .service-card { --accent: var(--accent-amber); }
.home-page #services-overview .row > [class*="col"]:nth-child(4n+3) .service-card { --accent: var(--accent-indigo); }
.home-page #services-overview .row > [class*="col"]:nth-child(4n+4) .service-card { --accent: var(--accent-cyan); }

/* Timeline */
.home-page .timeline { position: relative; }
.home-page .timeline::before { content: ""; position: absolute; inset-inline-start: 50%; transform: translateX(-50%); top: 0; bottom: 0; width: 3px; background: linear-gradient(180deg, rgba(15,61,46,.35), rgba(15,61,46,.12)); border-radius: 8px; }
/* Step card UI */
.home-page .timeline-step { border: 1px solid var(--gray-200); border-radius: .75rem; padding: .75rem; text-align: center; background: #fff; }
.home-page .timeline .row { align-items: stretch; }
.home-page .timeline .row > [class*="col"] { display: flex; }
.home-page .timeline .row > [class*="col"] > .timeline-step { flex: 1 1 auto; height: 100%; display: flex; flex-direction: column; }
.home-page .timeline-step .icon { width: 42px; height: 42px; display: inline-flex; align-items: center; justify-content: center; border-radius: .6rem; margin-top: .15rem; }
.home-page .timeline-step h6 { margin-top: .5rem; }
.home-page .timeline-step .dot { width: 18px; height: 18px; border-radius: 50%; border: 3px solid #fff; box-shadow: 0 0 0 6px rgba(15,61,46,.10); }
/* Per-step colors (break monotony) */
.home-page .timeline-step.step-1 { background: rgba(25,135,84,.06); border-color: rgba(25,135,84,.18); }
.home-page .timeline-step.step-1 .icon { background: rgba(25,135,84,.15); color: var(--accent-green); }
.home-page .timeline-step.step-1 .dot { background: var(--accent-green); box-shadow: 0 0 0 6px rgba(25,135,84,.14); }

.home-page .timeline-step.step-2 { background: rgba(217,119,6,.06); border-color: rgba(217,119,6,.20); }
.home-page .timeline-step.step-2 .icon { background: rgba(217,119,6,.15); color: var(--accent-amber); }
.home-page .timeline-step.step-2 .dot { background: var(--accent-amber); box-shadow: 0 0 0 6px rgba(217,119,6,.14); }

.home-page .timeline-step.step-3 { background: rgba(79,70,229,.06); border-color: rgba(79,70,229,.20); }
.home-page .timeline-step.step-3 .icon { background: rgba(79,70,229,.15); color: var(--accent-indigo); }
.home-page .timeline-step.step-3 .dot { background: var(--accent-indigo); box-shadow: 0 0 0 6px rgba(79,70,229,.14); }

.home-page .timeline-step.step-4 { background: rgba(8,145,178,.06); border-color: rgba(8,145,178,.20); }
.home-page .timeline-step.step-4 .icon { background: rgba(8,145,178,.15); color: var(--accent-cyan); }
.home-page .timeline-step.step-4 .dot { background: var(--accent-cyan); box-shadow: 0 0 0 6px rgba(8,145,178,.14); }

/* Testimonials */
.home-page .testimonial-card .stars { color: var(--brand); }
.home-page .testimonial-avatar { background: var(--gray-100); }

/* Brand strip */
.home-page .brand-strip .badge { background: var(--gray-100); border: 1px solid var(--gray-200); color: var(--brand); }

/* Footer */
.home-page .site-footer { background-color: var(--brand); color: #fff; }
.home-page .site-footer a { color: #e6e6e6; }
.home-page .site-footer a:hover { color: #fff; }

/* Tables and badges */
.home-page .table thead th { border-bottom-color: var(--gray-300); }
.home-page .border-primary { border-color: var(--brand) !important; }
.home-page .badge.bg-info,
.home-page .badge.bg-primary { background-color: var(--brand) !important; color: #fff !important; }

/* Fine-tuning */
.home-page .text-muted { color: var(--gray-700) !important; }
.home-page .soft-sep { background-color: var(--gray-200); }

/* Responsive (mobile) — smaller titles & compact spacing */
@media (max-width: 576px) {
  .home-page .hero-content { padding: 0.9rem 0.75rem; }
  .home-page .hero { border-radius: 0.75rem; }
  .home-page .hero-title { font-size: calc(1.15rem + 1vw); line-height: 1.35; }
  .home-page .hero-subtitle { font-size: calc(0.9rem + 0.35vw); line-height: 1.6; }
  .home-page .section-title { font-size: calc(1rem + 0.7vw); }
  .home-page .section-subtitle { font-size: calc(0.85rem + 0.35vw); }
  .home-page .hero-cta .btn { padding: .45rem .85rem; font-size: .9rem; }
}

/* Search input-group: add breathing room and clean radii */
.home-page .input-group { gap: 0.5rem; align-items: stretch; }
.home-page .card .input-group { max-width: 640px; margin-inline: auto; }
.home-page .input-group .form-control { border-radius: 0.6rem !important; flex: 1 1 auto; min-width: 0; }
.home-page .input-group .form-control::placeholder { font-size: 0.9rem; }
.home-page .input-group .btn { border-radius: 0.6rem !important; flex: 0 0 auto; }
.home-page .input-group .btn.btn-sm { padding: 0.35rem 0.6rem; font-size: 0.875rem; }

/* Assistant Modal (chat UI) */
.assistant-modal .modal-content { border-radius: 1rem; }
.assistant-modal .modal-header { display: flex; align-items: center; justify-content: space-between; gap: 0.75rem; }
.assistant-modal .modal-header .btn-close { margin-inline-start: 0.75rem; }
.assistant-modal .modal-header .modal-title { color: var(--brand); }
.assistant-modal .chat-window { height: 380px; overflow-y: auto; background: #fff; border: 1px solid var(--gray-200); border-radius: 0.75rem; padding: 0.75rem; }
.assistant-modal .message { display: flex; margin: 0.4rem 0; }
.assistant-modal .message.user { justify-content: flex-end; }
.assistant-modal .message.assistant { justify-content: flex-start; }
.assistant-modal .bubble { max-width: 75%; padding: 0.5rem 0.75rem; border-radius: 0.75rem; font-size: 0.95rem; line-height: 1.6; box-shadow: 0 6px 14px rgba(0,0,0,.08); }
.assistant-modal .message.user .bubble { background: rgba(15,61,46,.10); color: var(--gray-900); border: 1px solid rgba(15,61,46,.18); }
.assistant-modal .message.assistant .bubble { background: var(--brand); color: #fff; }
.assistant-modal #assistantForm .form-control { border-radius: 0.75rem; }
.assistant-modal #assistantForm .btn { border-radius: 0.75rem; }
.assistant-modal #assistantForm .btn.btn-sm { padding: 0.375rem; min-width: 40px; display: inline-flex; align-items: center; justify-content: center; }
/* Fix Bootstrap join rules when adding gap (restore borders in RTL/LTR) */
.home-page .input-group > .form-control:not(:last-child),
.home-page .input-group > .form-select:not(:last-child),
.home-page .input-group > .input-group-text:not(:last-child) { border-right-width: 1px !important; }
.home-page .input-group > .form-control:not(:first-child),
.home-page .input-group > .form-select:not(:first-child),
.home-page .input-group > .input-group-text:not(:first-child) { border-left-width: 1px !important; }

/* Case-request buttons: ensure spacing on mobile */
.home-page #case-request .btn { min-width: 220px; }
@media (max-width: 576px) {
  .home-page #case-request .btn { width: 100%; }
}

/* Timeline — mobile: remove center line and condense spacing */
@media (max-width: 576px) {
  .home-page .timeline::before { display: none; }
  .home-page .timeline .row { --bs-gutter-y: 0.75rem; --bs-gutter-x: 0.75rem; }
  .home-page .timeline-step { padding: 0.6rem 0.6rem; gap: 0.5rem; }
  /* Equal heights also on mobile */
  .home-page .timeline .row > [class*="col"] > .timeline-step { min-height: 190px; }
}

/* CTA — align to brand green and improve contrast */
.home-page .cta { border-radius: 1rem; background: linear-gradient(135deg, #0f3d2e, #14533f); color: #fff; }
.home-page .cta h3, .home-page .cta p { color: #fff; }
.home-page .cta .btn-primary { background-color: #fff !important; color: #0f3d2e !important; border-color: #0f3d2e !important; }
.home-page .cta .btn-outline-secondary { color: #fff !important; border-color: rgba(255,255,255,0.6) !important; }
.home-page .cta .btn-outline-secondary:hover { background-color: rgba(255,255,255,0.18) !important; }

/* Footer — height = 2 × navbar, with comfortable paddings */
.home-page .site-footer {
  /* Estimate navbar height; adjust per breakpoint */
  --nav-h: 56px;
  min-height: calc(var(--nav-h) * 2);
}
.home-page .site-footer .container { padding-top: 1rem !important; padding-bottom: 1rem !important; }
@media (min-width: 576px) {
  .home-page .site-footer { --nav-h: 64px; }
  .home-page .site-footer .container { padding-top: 1.25rem !important; padding-bottom: 1.25rem !important; }
}

/* Lawyer gallery — uniform image sizes across devices */
.home-page #lawyer-gallery .card-img-top {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}
.home-page .site-footer h6 { font-size: 0.95rem; margin-bottom: 0.3rem; }
.home-page .site-footer p, .home-page .site-footer li, .home-page .site-footer small { font-size: 0.85rem; }