/* ============================================================
   homepage.css — Homepage-specific styles
   jonsinghlaw.ca

   Load on index.html only. Complements the global framework
   for page-specific layout and section styling.
   ============================================================ */


/* ============================
   Hero Section
   ============================ */

.hero {
  position: relative;
  min-height: 560px;
  display: flex;
  align-items: center;
  background-color: var(--color-navy);
  background-image: linear-gradient(
    145deg,
    #020F1E 0%,
    var(--color-navy) 50%,
    var(--color-navy-light) 100%
  );
  overflow: hidden;
  padding: var(--spacing-4xl) 0;
}

/*
  ── Hero Background Image (enable in production) ──────────────────────────
  When the hero photo is ready:
  1. Place optimised images at /images/hero-main.webp and /images/hero-main.jpg
  2. Add class "has-image" to the <section class="hero"> element
  ──────────────────────────────────────────────────────────────────────────
*/
.hero.has-image {
  background-image:
    linear-gradient(
      to right,
      rgba(2, 15, 30, 0.88) 35%,
      rgba(4, 44, 83, 0.55) 100%
    ),
    url('/images/Banner.jpg');
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

/* Decorative circle accent — CSS only, no image dependency */
.hero::before {
  content: '';
  position: absolute;
  top: -120px;
  right: -120px;
  width: 560px;
  height: 560px;
  border-radius: var(--radius-full);
  background: rgba(24, 95, 165, 0.08);
  pointer-events: none;
}

.hero::after {
  content: '';
  position: absolute;
  bottom: -160px;
  right: 15%;
  width: 320px;
  height: 320px;
  border-radius: var(--radius-full);
  background: rgba(15, 110, 86, 0.06);
  pointer-events: none;
}

.hero-inner {
  position: relative;
  z-index: 1;
}

.hero-eyebrow {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
  margin-bottom: var(--spacing-md);
}

.hero-headline {
  font-family: var(--font-family-heading);
  font-size: var(--font-size-3xl);
  font-weight: 700;
  color: var(--color-white);
  line-height: var(--line-height-tight);
  letter-spacing: -0.01em;
  margin-bottom: var(--spacing-lg);
}

.hero-subheading {
  font-size: var(--font-size-md);
  color: rgba(250, 250, 248, 0.78);
  line-height: var(--line-height-relaxed);
  max-width: 500px;
  margin-bottom: var(--spacing-xl);
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-md);
  margin-bottom: var(--spacing-lg);
}

.hero-trust {
  font-size: var(--font-size-sm);
  color: rgba(250, 250, 248, 0.4);
  margin: 0;
}


/* ============================
   Practice Areas Section
   ============================ */

.practice-areas-section {
  background-color: var(--color-white);
}

/* Icon placeholder above card title */
.card-practice-icon {
  width: 48px;
  height: 48px;
  background-color: rgba(24, 95, 165, 0.1);
  border-radius: var(--radius-md);
  border: 1px solid rgba(24, 95, 165, 0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  margin-bottom: var(--spacing-md);
  flex-shrink: 0;
  transition: background-color var(--transition-normal), border-color var(--transition-normal);
}

.card-practice:hover .card-practice-icon {
  background-color: rgba(24, 95, 165, 0.16);
  border-color: rgba(24, 95, 165, 0.25);
}


/* ============================
   Value Proposition Section
   ============================ */

.value-prop-section {
  background-color: var(--color-light-gray);
}

.value-prop-layout {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2xl);
}

.value-prop-heading-col {}

.value-prop-heading-col h2 {
  font-size: var(--font-size-2xl);
  line-height: var(--line-height-snug);
  margin-bottom: var(--spacing-md);
}

.value-prop-heading-col .lead {
  color: var(--color-primary);
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-base);
}

.value-prop-content-col {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

.value-prop-content-col p {
  color: var(--color-text-muted);
  line-height: var(--line-height-relaxed);
}


/* ============================
   Goals Section
   ============================ */

.goals-section {
  background-color: var(--color-white);
}

.goals-intro {
  max-width: 680px;
  margin: 0 auto var(--spacing-3xl);
  text-align: center;
}

.goals-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--spacing-xl);
}

.goal-item {
  display: flex;
  gap: var(--spacing-lg);
  align-items: flex-start;
  padding: var(--spacing-xl);
  background-color: var(--color-off-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  transition: box-shadow var(--transition-normal), border-color var(--transition-normal), transform var(--transition-normal);
}

.goal-item:hover {
  box-shadow: var(--shadow-medium);
  border-color: rgba(24, 95, 165, 0.25);
  transform: translateY(-2px);
}

.goal-number {
  width: 44px;
  height: 44px;
  flex-shrink: 0;
  background-color: var(--color-primary);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-white);
  line-height: 1;
}

.goal-text h3 {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-navy);
  margin-bottom: var(--spacing-xs);
}

.goal-text p {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  line-height: var(--line-height-relaxed);
  margin: 0;
}


/* ============================
   Testimonials Section
   ============================ */

.testimonials-section {
  background-color: var(--color-light-gray);
}

.testimonials-footer {
  text-align: center;
  margin-top: var(--spacing-2xl);
}


/* ============================
   Lead Magnet Section
   ============================ */

.lead-magnet-section {
  background-color: var(--color-primary);
}

.lead-magnet-inner {
  max-width: 600px;
  margin: 0 auto;
  text-align: center;
}

.lead-magnet-inner .eyebrow {
  color: rgba(255, 255, 255, 0.6);
}

.lead-magnet-inner h2 {
  color: var(--color-white);
  font-size: var(--font-size-2xl);
  margin-bottom: var(--spacing-md);
}

.lead-magnet-inner .lead {
  color: rgba(250, 250, 248, 0.82);
  margin-bottom: var(--spacing-xl);
}


/* ============================
   Educational Section
   ============================ */

.educational-section {
  background-color: var(--color-off-white);
}

/* Numbered badge on educational cards */
.card-edu-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background-color: var(--color-primary);
  color: var(--color-white);
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--spacing-md);
  line-height: 1;
}


/* ============================
   CTA & Contact Section
   ============================ */

.cta-contact-section {
  background-color: var(--color-white);
}

.contact-methods {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--spacing-xl);
  margin-top: var(--spacing-2xl);
}

.contact-method {
  text-align: center;
  padding: var(--spacing-2xl) var(--spacing-xl);
  background-color: var(--color-light-gray);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  transition: box-shadow var(--transition-normal), border-color var(--transition-normal), transform var(--transition-normal);
}

.contact-method:hover {
  box-shadow: var(--shadow-medium);
  border-color: rgba(24, 95, 165, 0.2);
  transform: translateY(-2px);
}

.contact-method-icon {
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--spacing-md);
  font-size: 24px;
  color: var(--color-white);
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(24, 95, 165, 0.3);
}

.contact-method h3 {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-navy);
  margin-bottom: var(--spacing-sm);
}

.contact-method p {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--spacing-lg);
}

/* Direct contact links row at bottom of CTA section */
.contact-direct {
  margin-top: var(--spacing-3xl);
  padding-top: var(--spacing-3xl);
  border-top: 1px solid var(--color-border);
  text-align: center;
}

.contact-direct-links {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-md);
  margin-top: var(--spacing-md);
}

.contact-direct-link {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary);
  transition: color var(--transition-fast);
}

.contact-direct-link:hover {
  color: var(--color-primary-dark);
  text-decoration: none;
}


/* Homepage responsive handled in responsive.css */
