/* Estate Planning Page Responsive Styles */
/* Enhanced CSS specificity using main element scoping to prevent navbar interference */

/* Mobile First - Base Styles */
@media screen and (max-width: 991px) {

  /* Hero Section */
  main #Hero.inner-hero {
    min-height: 60vh !important;
    padding: 40px 20px !important;
    background-size: cover !important;
    background-position: center !important;
  }

  main #Hero.inner-hero .content-wrapper {
    padding: 0 15px !important;
  }

  main #Hero .inner-hero-text {
    text-align: center !important;
    max-width: 100% !important;
  }

  main #Hero .title-white {
    font-size: 14px !important;
    margin-bottom: 10px !important;
  }

  main #Hero .h1-title.large {
    font-size: 28px !important;
    line-height: 1.2 !important;
    margin-bottom: 20px !important;
  }

  main #Hero .subtitle-white {
    font-size: 16px !important;
    line-height: 1.4 !important;
    margin-bottom: 25px !important;
  }

  /* Content Sections */
  main .content-section,
  main .content-section-green,
  main ._2-content-section {
    padding: 40px 20px !important;
  }

  main .content-wrapper {
    padding: 0 15px !important;
    max-width: 100% !important;
  }

  /* Flex Layouts */
  main .flex,
  main .split-column {
    flex-direction: column !important;
    gap: 30px !important;
  }

  main ._2-40-column,
  main ._2-60-column,
  main ._50-column-center,
  main ._50-column {
    width: 100% !important;
    padding: 0 !important;
    margin-bottom: 30px !important;
  }

  main ._2-40-column.right-padding {
    padding-right: 0 !important;
  }

  /* Typography */
  main .h2-title,
  main .h2-title-green {
    font-size: 24px !important;
    line-height: 1.3 !important;
    margin-bottom: 20px !important;
  }

  main .h3-title {
    font-size: 20px !important;
    line-height: 1.3 !important;
  }

  main .paragraph,
  main .split-paragraph-green {
    font-size: 16px !important;
    line-height: 1.6 !important;
    margin-bottom: 20px !important;
  }

  main .italicized {
    font-size: 14px !important;
    margin-top: 15px !important;
  }

  /* Buttons */
  main .button,
  main .button-4,
  main .button-5 {
    width: 100% !important;
    margin-bottom: 15px !important;
    padding: 15px 20px !important;
    font-size: 16px !important;
    text-align: center !important;
    display: block !important;
  }

  main .top-border {
    flex-direction: column !important;
    gap: 15px !important;
    margin-top: 30px !important;
  }

  /* Feature Cards/Boxes */
  main .blocks,
  main .circles {
    flex-direction: column !important;
    gap: 20px !important;
    margin-top: 30px !important;
  }

  main .rounded-box,
  main .circle-item {
    width: 100% !important;
    margin-bottom: 20px !important;
    padding: 25px 20px !important;
    text-align: center !important;
  }

  main .rounded-box img,
  main .circle-item img {
    width: 40px !important;
    height: 40px !important;
    margin-bottom: 15px !important;
  }

  main .title.small-regular {
    font-size: 16px !important;
    line-height: 1.3 !important;
  }

  /* Testimonials */
  main .flex-space {
    flex-direction: column !important;
    gap: 25px !important;
  }

  main ._2-intro-feature {
    width: 100% !important;
    padding: 25px 20px !important;
    margin-bottom: 20px !important;
    background: #f8f9fa !important;
    border-radius: 8px !important;
  }

  main .intro-feature-icon {
    margin-bottom: 20px !important;
  }

  main ._3-feature-icon {
    width: 50px !important;
    height: 50px !important;
    margin: 0 auto 15px !important;
  }

  main .paragraph.medium {
    font-size: 15px !important;
    line-height: 1.6 !important;
    text-align: center !important;
  }

  /* Lists */
  main .nm-planning-tabs--content-list {
    padding-left: 20px !important;
    margin-bottom: 20px !important;
  }

  main .list-item {
    font-size: 15px !important;
    line-height: 1.5 !important;
    margin-bottom: 8px !important;
    color: #10222F !important;
  }

  /* Estate Planning specific elements */
  main .estate-documents {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 20px !important;
    margin: 30px 0 !important;
  }

  main .document-card {
    padding: 25px 20px !important;
    text-align: center !important;
    background: #f8f9fa !important;
    border-radius: 8px !important;
    border: 1px solid #e9ecef !important;
  }

  main .document-icon {
    width: 50px !important;
    height: 50px !important;
    margin: 0 auto 15px !important;
    background: #10222F !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  main .document-title {
    font-size: 18px !important;
    font-weight: 600 !important;
    color: #10222F !important;
    margin-bottom: 10px !important;
  }

  main .document-description {
    font-size: 14px !important;
    line-height: 1.5 !important;
    color: #666 !important;
  }

  main .estate-steps {
    flex-direction: column !important;
    gap: 25px !important;
  }

  main .estate-step {
    width: 100% !important;
    margin-bottom: 25px !important;
    padding: 25px 20px !important;
    text-align: center !important;
    background: #ffffff !important;
    border: 2px solid #10222F !important;
    border-radius: 8px !important;
  }

  main .step-number {
    width: 40px !important;
    height: 40px !important;
    border-radius: 50% !important;
    background: #10222F !important;
    color: white !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 auto 15px !important;
    font-size: 18px !important;
    font-weight: 700 !important;
  }

  main .estate-calculator {
    padding: 30px 20px !important;
    margin: 20px 0 !important;
    background: #f8f9fa !important;
    border-radius: 8px !important;
  }

  main .estate-input {
    width: 100% !important;
    margin-bottom: 15px !important;
    padding: 12px 15px !important;
    font-size: 16px !important;
    border: 1px solid #ddd !important;
    border-radius: 4px !important;
  }

  /* Planning Steps Section */
  main .row {
    padding: 30px 20px !important;
    text-align: center !important;
  }

  main .row .h2-title {
    margin-bottom: 20px !important;
  }

  main .row p {
    font-size: 16px !important;
    line-height: 1.6 !important;
    margin-bottom: 15px !important;
    text-align: center !important;
  }

  /* Borders and Lines */
  main .bottom-border,
  main .top-border {
    border-width: 1px !important;
  }

  main ._2-red-line,
  main .red-line,
  main .green-line {
    height: 2px !important;
    width: 60px !important;
    margin: 15px auto !important;
    background-color: #10222F !important;
  }

  main .full-line {
    margin: 40px 0 !important;
  }

  /* Center alignment for mobile */
  main .center,
  main .mobile-center {
    text-align: center !important;
  }

  main .heading-container,
  main .heading-box {
    text-align: center !important;
    margin-bottom: 30px !important;
  }

  main .center-icon {
    margin-bottom: 20px !important;
  }

  main .center-icon img {
    width: 30px !important;
    height: 30px !important;
  }

  /* Header Flex */
  main .flex-header {
    flex-direction: column !important;
    gap: 15px !important;
    align-items: center !important;
  }

  main .line {
    display: none !important;
  }

  /* Inner Wrapper */
  main .inner-wrapper {
    padding: 0 !important;
  }

  /* Footer adjustments */
  main+.footer-section {
    margin-top: 0 !important;
  }
}

/* Tablet Styles */
@media screen and (min-width: 768px) and (max-width: 991px) {
  main #Hero .h1-title.large {
    font-size: 32px !important;
  }

  main .h2-title,
  main .h2-title-green {
    font-size: 26px !important;
  }

  main .flex-space {
    flex-direction: row !important;
    flex-wrap: wrap !important;
  }

  main ._2-intro-feature {
    width: calc(50% - 15px) !important;
  }

  main .blocks {
    flex-direction: row !important;
    flex-wrap: wrap !important;
  }

  main .rounded-box {
    width: calc(33.333% - 15px) !important;
  }

  main .estate-documents {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  main .estate-steps {
    flex-direction: row !important;
    flex-wrap: wrap !important;
  }

  main .estate-step {
    width: calc(50% - 15px) !important;
  }
}

/* Small Mobile Styles */
@media screen and (max-width: 480px) {
  main #Hero .h1-title.large {
    font-size: 24px !important;
  }

  main .h2-title,
  main .h2-title-green {
    font-size: 22px !important;
  }

  main .content-section,
  main .content-section-green,
  main ._2-content-section {
    padding: 30px 15px !important;
  }

  main .rounded-box,
  main .circle-item,
  main .document-card,
  main .estate-step {
    padding: 20px 15px !important;
  }

  main .document-title {
    font-size: 16px !important;
  }

  main .step-number {
    width: 35px !important;
    height: 35px !important;
    font-size: 16px !important;
  }
}