.ministry-card {
      text-align: center;
    }

    .ministry-leader-photo {
      width: 88px;
      height: 88px;
      margin: 0 auto 18px;
      border-radius: 50%;
      position: relative;
      display: grid;
      place-items: center;
      overflow: hidden;
      background: radial-gradient(circle at 30% 20%, #8f4b20, #2a1208 72%);
      box-shadow: 0 16px 34px rgba(27, 12, 5, .18);
      flex: 0 0 auto;
      box-sizing: border-box;
    }

    .ministry-leader-photo::before {
      content: attr(data-initials);
      position: absolute;
      inset: 0;
      border-radius: 50%;
      display: grid;
      place-items: center;
      background: radial-gradient(circle at 30% 20%, #8f4b20, #2a1208 72%);
      color: #fff5df;
      font-weight: 800;
      font-size: 1.1rem;
      letter-spacing: .04em;
      z-index: 0;
    }

    .ministry-leader-photo::after {
      content: "";
      position: absolute;
      inset: 0;
      border: 5px solid rgba(214, 166, 86, .95);
      border-radius: 50%;
      box-shadow: inset 0 0 0 2px rgba(255, 255, 255, .88);
      pointer-events: none;
      z-index: 2;
      box-sizing: border-box;
    }

    .ministry-leader-photo img {
      position: absolute;
      inset: 0;
      z-index: 1;
      width: 100%;
      height: 100%;
      border-radius: 50%;
      object-fit: cover;
      object-position: center;
      display: block;
      background: #2a1208;
    }
    .ministry-featured-card {
      position: relative;
      margin: 34px 0 26px;
      padding: clamp(24px, 3vw, 34px);
      border-radius: 34px;
      display: grid;
      grid-template-columns: 132px minmax(0, 1fr);
      align-items: center;
      gap: 26px;
      background:
        radial-gradient(circle at 12% 18%, rgba(214, 166, 86, .18), transparent 34%),
        radial-gradient(circle at 92% 14%, rgba(255, 245, 223, .08), transparent 30%),
        linear-gradient(135deg, rgba(255,255,255,.10), rgba(255,255,255,.045)),
        #173c2f;
      border: 1px solid rgba(214, 166, 86, .34);
      box-shadow: 0 28px 68px rgba(7, 29, 35, .18);
      overflow: hidden;
      isolation: isolate;
    }

    .ministry-featured-card::before {
      content: "";
      position: absolute;
      inset: 0 0 auto 0;
      height: 5px;
      background: linear-gradient(90deg, #d6a656, #5f6f2f, transparent);
      z-index: 0;
    }

    .ministry-featured-photo {
      position: relative;
      width: 118px;
      height: 118px;
      border-radius: 50%;
      display: grid;
      place-items: center;
      overflow: hidden;
      background: radial-gradient(circle at 30% 20%, #8f4b20, #2a1208 72%);
      box-shadow: 0 18px 38px rgba(0, 0, 0, .22);
      color: #fff5df;
      font-weight: 950;
      letter-spacing: .06em;
      box-sizing: border-box;
      justify-self: center;
      z-index: 1;
    }

    .ministry-featured-photo::after {
      content: "";
      position: absolute;
      inset: 0;
      border: 6px solid rgba(214, 166, 86, .95);
      border-radius: 50%;
      box-shadow: inset 0 0 0 2px rgba(255, 255, 255, .88);
      pointer-events: none;
      z-index: 2;
      box-sizing: border-box;
    }

    .ministry-featured-photo span {
      position: relative;
      z-index: 0;
      font-size: 1.25rem;
    }

    .ministry-featured-photo img {
      position: absolute;
      inset: 0;
      z-index: 1;
      width: 100%;
      height: 100%;
      border-radius: 50%;
      object-fit: cover;
      object-position: center;
      display: block;
      background: #2a1208;
      cursor: zoom-in;
    }

    .ministry-featured-copy {
      position: relative;
      z-index: 1;
      min-width: 0;
    }

    .ministry-featured-kicker {
      display: inline-flex;
      width: fit-content;
      margin-bottom: 10px;
      padding: 7px 12px;
      border-radius: 999px;
      background: rgba(214, 166, 86, .16);
      border: 1px solid rgba(214, 166, 86, .34);
      color: #fff5df;
      font-size: .76rem;
      font-weight: 950;
      letter-spacing: .1em;
      text-transform: uppercase;
    }

    .ministry-featured-card h3 {
      margin: 0;
      color: #fff5df;
      font-size: clamp(1.55rem, 3vw, 2.15rem);
      line-height: 1.05;
      letter-spacing: -.045em;
    }

    .ministry-featured-card p {
      max-width: 780px;
      margin: 12px 0 0;
      color: rgba(255, 245, 223, .82);
      font-size: 1rem;
      line-height: 1.62;
    }


    .ministry-featured-role {
      display: block;
      margin-top: 8px;
      color: #d6a656;
      font-size: .98rem;
      font-weight: 950;
      letter-spacing: .02em;
    }

    .ministry-featured-tags {
      display: flex;
      flex-wrap: wrap;
      gap: 9px;
      margin-top: 18px;
    }

    .ministry-featured-tags span {
      display: inline-flex;
      align-items: center;
      min-height: 30px;
      padding: 7px 12px;
      border-radius: 999px;
      background: rgba(255, 245, 223, .10);
      color: rgba(255, 245, 223, .92);
      border: 1px solid rgba(255, 245, 223, .16);
      font-size: .82rem;
      font-weight: 900;
    }





    .latest-devotionals {
      align-items: stretch;
    }

    .devotional-card {
      position: relative;
      display: flex;
      flex-direction: column;
      gap: 12px;
      padding-top: 72px;
    }

    .devotional-card .devotional-kicker {
      color: rgba(255, 245, 223, .72);
      font-size: .78rem;
      font-weight: 800;
      letter-spacing: .12em;
      text-transform: uppercase;
    }

    .devotional-card .devotional-author {
      color: rgba(255, 245, 223, .86);
      font-size: .92rem;
      font-weight: 800;
      margin-top: -4px;
    }


    .devotional-card .devotional-number {
      width: 46px;
      height: 46px;
      border-radius: 50%;
      display: inline-grid;
      place-items: center;
      color: #fff5df;
      font-weight: 900;
      background: rgba(255, 255, 255, .10);
      border: 1px solid rgba(214, 166, 86, .55);
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .10);
    }

    .devotional-card time {
      color: rgba(255, 245, 223, .68);
      font-size: .88rem;
    }

    .empty-devotionals {
      padding: 28px;
      border-radius: 24px;
      background: rgba(27, 12, 5, .08);
      border: 1px solid rgba(27, 12, 5, .10);
    }

    .devotional-read-link {
      position: absolute;
      top: 24px;
      right: 26px;
      display: inline-flex;
      align-items: center;
      gap: 9px;
      width: fit-content;
      padding: 9px 12px;
      border-radius: 999px;
      background: rgba(255, 245, 223, .08);
      border: 1px solid rgba(255, 245, 223, .20);
      color: rgba(255, 245, 223, .94);
      font-size: .88rem;
      font-weight: 900;
      letter-spacing: -.01em;
      text-decoration: none;
      box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
      transition: transform .18s ease, color .18s ease, background .18s ease, border-color .18s ease;
    }

    .devotional-read-link:hover,
    .devotional-read-link:focus-visible {
      color: #fff7e7;
      background: rgba(214, 166, 86, .18);
      border-color: rgba(214, 166, 86, .46);
      transform: translateY(-1px);
      outline: none;
    }

    .devotional-read-link .devotional-read-icon {
      width: 28px;
      height: 28px;
      border-radius: 999px;
      display: inline-grid;
      place-items: center;
      background: rgba(214, 166, 86, .20);
      border: 1px solid rgba(214, 166, 86, .42);
      box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
      color: currentColor;
      flex: 0 0 auto;
    }

    .devotional-read-link .devotional-read-icon svg {
      width: 16px;
      height: 16px;
      display: block;
    }


    @media (orientation: portrait) and (max-width: 1000px) {
      .pastoral-grid {
        grid-template-columns: 1fr;
      }

      .pastor-card {
        width: 100%;
        max-width: 560px;
        margin-inline: auto;
      }
    }

    @media (max-width: 640px) {

      .ministry-featured-card {
        grid-template-columns: 1fr;
        text-align: center;
        justify-items: center;
        gap: 18px;
      }

      .ministry-featured-tags {
        justify-content: center;
      }
      .devotional-card {
        padding-top: 82px;
      }

      .devotional-read-link {
        top: 22px;
        right: 20px;
        font-size: .82rem;
      }
    }


    .birthday-section {
      position: relative;
      overflow: hidden;
    }

    .birthday-section::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 12% 20%, rgba(214, 166, 86, .20), transparent 28%),
        radial-gradient(circle at 88% 72%, rgba(7, 29, 35, .10), transparent 30%);
      pointer-events: none;
    }

    .birthday-section .container {
      position: relative;
      z-index: 1;
    }

    .birthdays-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 22px;
      margin-top: 34px;
      align-items: stretch;
    }

    .birthday-card {
      position: relative;
      min-height: 100%;
      padding: 34px 28px 30px;
      border-radius: 30px;
      background:
        radial-gradient(circle at 16% 10%, rgba(214, 166, 86, .16), transparent 34%),
        radial-gradient(circle at 88% 18%, rgba(255, 245, 223, .06), transparent 30%),
        linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.045)),
        #173c2f;
      border: 1px solid rgba(214, 166, 86, .32);
      box-shadow: 0 24px 56px rgba(7, 29, 35, .18);
      color: #fff5df;
      text-align: center;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 14px;
      overflow: hidden;
      isolation: isolate;
    }

    .birthday-card::before {
      content: "";
      position: absolute;
      inset: 0 0 auto 0;
      height: 5px;
      background: linear-gradient(90deg, #d6a656, #5f6f2f, transparent);
      z-index: 0;
    }

    .birthday-card.is-today {
      border-color: rgba(214, 166, 86, .74);
      background:
        radial-gradient(circle at 18% 8%, rgba(214, 166, 86, .30), transparent 30%),
        radial-gradient(circle at 88% 16%, rgba(24, 209, 88, .13), transparent 30%),
        linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,247,226,.96)),
        #fbf7ef;
      color: #071d23;
      box-shadow: 0 28px 64px rgba(143, 75, 32, .20);
      animation: birthdayGlow 2.6s ease-in-out infinite;
    }

    .birthday-card.is-today::before {
      height: 6px;
      background: linear-gradient(90deg, #d6a656, #ffd36d, #18d158, #d6a656);
      background-size: 240% 100%;
      animation: birthdayShimmer 3s linear infinite;
    }

    .birthday-card.is-today::after {
      content: "✦";
      position: absolute;
      right: 18px;
      top: 18px;
      width: 32px;
      height: 32px;
      border-radius: 50%;
      display: grid;
      place-items: center;
      color: #8f4b20;
      background: rgba(214, 166, 86, .22);
      box-shadow: 0 10px 24px rgba(143, 75, 32, .15);
      animation: birthdayFloat 1.8s ease-in-out infinite;
      z-index: 2;
    }

    @keyframes birthdayGlow {
      0%, 100% { transform: translateY(0); }
      50% { transform: translateY(-4px); }
    }

    @keyframes birthdayShimmer {
      from { background-position: 0% 50%; }
      to { background-position: 240% 50%; }
    }

    @keyframes birthdayFloat {
      0%, 100% { transform: translateY(0) rotate(0deg); opacity: .78; }
      50% { transform: translateY(-5px) rotate(10deg); opacity: 1; }
    }

    .birthday-card-top {
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 14px;
    }

    .birthday-identity {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 12px;
      min-width: 0;
      width: 100%;
    }

    .birthday-avatar {
      position: relative;
      width: 88px;
      height: 88px;
      margin: 0 auto;
      border-radius: 50%;
      display: grid;
      place-items: center;
      overflow: hidden;
      background: radial-gradient(circle at 30% 20%, #8f4b20, #2a1208 72%);
      color: #fff5df;
      box-shadow: 0 16px 34px rgba(27, 12, 5, .18);
      flex: 0 0 auto;
      box-sizing: border-box;
      font: inherit;
      font-weight: 950;
      letter-spacing: .04em;
      border: 0;
    }

    .birthday-avatar::before {
      content: "";
      position: absolute;
      inset: 0;
      border-radius: 50%;
      background: radial-gradient(circle at 30% 20%, #8f4b20, #2a1208 72%);
      z-index: 0;
    }

    .birthday-avatar::after {
      content: "";
      position: absolute;
      inset: 0;
      border: 5px solid rgba(214, 166, 86, .95);
      border-radius: 50%;
      box-shadow: inset 0 0 0 2px rgba(255, 255, 255, .88);
      pointer-events: none;
      z-index: 2;
      box-sizing: border-box;
    }

    button.birthday-avatar {
      cursor: zoom-in;
      padding: 0;
      transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
    }

    button.birthday-avatar:hover,
    button.birthday-avatar:focus-visible {
      transform: translateY(-2px) scale(1.03);
      filter: brightness(1.04);
      outline: none;
    }

    .birthday-avatar img {
      position: absolute;
      inset: 0;
      z-index: 1;
      width: 100%;
      height: 100%;
      border-radius: 50%;
      object-fit: cover;
      object-position: center;
      display: block;
      background: #2a1208;
    }

    .birthday-avatar span {
      position: relative;
      z-index: 1;
      font-size: 1.08rem;
    }

    .birthday-card.is-today .birthday-avatar {
      background: radial-gradient(circle at 30% 20%, #d6a656, #2a1208 72%);
      box-shadow: 0 18px 38px rgba(143, 75, 32, .24);
    }

    .birthday-card.is-today .birthday-avatar::after {
      border-color: rgba(255, 211, 109, .98);
    }

    .birthday-tag {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: fit-content;
      min-height: 30px;
      padding: 7px 13px;
      border-radius: 999px;
      background: rgba(255, 245, 223, .10);
      color: #fff5df;
      font-size: .76rem;
      font-weight: 950;
      letter-spacing: .08em;
      text-transform: uppercase;
      white-space: nowrap;
      border: 1px solid rgba(214, 166, 86, .28);
    }

    .birthday-card.is-today .birthday-tag {
      background: rgba(24, 209, 88, .16);
      color: #0d4f2a;
      border-color: rgba(24, 209, 88, .28);
    }

    .birthday-card h3 {
      margin: 2px 0 0;
      color: #fff5df;
      font-size: clamp(1.22rem, 1.75vw, 1.48rem);
      line-height: 1.08;
      letter-spacing: -.035em;
      overflow-wrap: anywhere;
      text-align: center;
    }

    .birthday-card.is-today h3 {
      color: #071d23;
    }

    .birthday-card-meta {
      display: grid;
      gap: 9px;
      width: 100%;
      margin-top: 2px;
      justify-items: center;
    }

    .birthday-info-line {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      color: rgba(255, 245, 223, .82);
      font-size: .96rem;
      line-height: 1.4;
      text-align: center;
      max-width: 100%;
    }

    .birthday-info-line svg {
      width: 17px;
      height: 17px;
      fill: #e1b96d;
      flex: 0 0 auto;
    }

    .birthday-info-line strong {
      color: #fff5df;
      font-weight: 900;
    }

    .birthday-card.is-today .birthday-info-line {
      color: #52605c;
    }

    .birthday-card.is-today .birthday-info-line svg {
      fill: #8f4b20;
    }

    .birthday-card.is-today .birthday-info-line strong {
      color: #071d23;
    }

    .birthday-actions {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      width: 100%;
      margin-top: 6px;
    }

    .birthday-whatsapp {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      width: 100%;
      min-height: 42px;
      padding: 10px 14px;
      border-radius: 999px;
      background: #18d158;
      color: #061f25;
      font-weight: 950;
      font-size: .9rem;
      box-shadow: 0 16px 28px rgba(24, 209, 88, .20);
      transition: transform .2s ease, filter .2s ease, box-shadow .2s ease;
    }

    .birthday-whatsapp:hover,
    .birthday-whatsapp:focus-visible {
      transform: translateY(-2px);
      filter: brightness(1.03);
      outline: none;
      box-shadow: 0 20px 34px rgba(24, 209, 88, .26);
    }

    .birthday-whatsapp svg {
      width: 18px;
      height: 18px;
      fill: currentColor;
      flex: 0 0 auto;
    }

    .photo-modal {
      position: fixed;
      inset: 0;
      z-index: 9999;
      display: grid;
      place-items: center;
      padding: 24px;
      background: rgba(7, 29, 35, .78);
      backdrop-filter: blur(12px);
      opacity: 0;
      pointer-events: none;
      transition: opacity .22s ease;
    }

    .photo-modal.is-open {
      opacity: 1;
      pointer-events: auto;
    }

    .photo-modal[hidden] {
      display: none;
    }

    .photo-modal-card {
      position: relative;
      width: min(420px, calc(100vw - 38px));
      border-radius: 34px;
      padding: 18px;
      background: linear-gradient(180deg, #fffaf0, #fbf7ef);
      border: 1px solid rgba(214, 166, 86, .56);
      box-shadow: 0 30px 80px rgba(0, 0, 0, .35);
      transform: translateY(10px) scale(.98);
      transition: transform .22s ease;
    }

    .photo-modal.is-open .photo-modal-card {
      transform: translateY(0) scale(1);
    }

    .photo-modal-card img {
      width: 100%;
      max-height: min(72vh, 620px);
      object-fit: contain;
      display: block;
      border-radius: 24px;
      background: #fff;
    }

    .photo-modal-caption {
      margin: 12px 48px 2px 4px;
      color: #071d23;
      font-weight: 950;
      line-height: 1.25;
    }

    .photo-modal-close {
      position: absolute;
      right: 16px;
      top: 16px;
      width: 38px;
      height: 38px;
      border: 0;
      border-radius: 50%;
      display: grid;
      place-items: center;
      background: rgba(7, 29, 35, .86);
      color: #fff5df;
      font-size: 1.25rem;
      font-weight: 950;
      cursor: pointer;
      box-shadow: 0 12px 26px rgba(0, 0, 0, .18);
    }

    [data-photo-modal-trigger]:not(button) {
      cursor: zoom-in;
      transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
    }

    [data-photo-modal-trigger]:not(button):hover,
    [data-photo-modal-trigger]:not(button):focus-visible {
      transform: translateY(-1px) scale(1.02);
      filter: brightness(1.02);
      outline: 2px solid rgba(214, 166, 86, .55);
      outline-offset: 2px;
    }

    body.photo-modal-open {
      overflow: hidden;
    }

    .birthday-empty {
      margin-top: 28px;
      padding: 26px;
      border: 1px dashed rgba(214, 166, 86, .58);
      border-radius: 26px;
      background: rgba(251, 247, 239, .80);
      color: #40504c;
      text-align: center;
    }



    .top-page-float {
      position: fixed !important;
      right: 22px !important;
      bottom: calc(168px + env(safe-area-inset-bottom, 0px)) !important;
      z-index: 10000 !important;
      display: inline-grid;
      place-items: center;
      width: 56px;
      height: 56px;
      min-height: 56px;
      padding: 0;
      border: 1px solid rgba(214, 166, 86, .72);
      border-radius: 50%;
      background: linear-gradient(135deg, #071d23, #173c2f);
      color: #d6a656;
      font: inherit;
      box-shadow: 0 18px 42px rgba(0, 0, 0, .24), inset 0 1px 0 rgba(255, 255, 255, .18);
      cursor: pointer;
      transition: transform .22s ease, box-shadow .22s ease, filter .22s ease;
    }

    .top-page-float:hover,
    .top-page-float:focus-visible {
      transform: translateY(-3px);
      filter: brightness(1.08);
      box-shadow: 0 22px 50px rgba(0, 0, 0, .30), inset 0 1px 0 rgba(255, 255, 255, .24);
      outline: none;
    }

    .top-page-float svg {
      width: 22px;
      height: 22px;
      fill: currentColor;
    }

    .top-page-float span {
      position: absolute;
      width: 1px;
      height: 1px;
      overflow: hidden;
      clip: rect(0 0 0 0);
      white-space: nowrap;
    }

    .share-page-float {
      position: fixed !important;
      right: 22px !important;
      bottom: calc(96px + env(safe-area-inset-bottom, 0px)) !important;
      z-index: 9999 !important;
      display: inline-grid;
      place-items: center;
      width: 56px;
      height: 56px;
      min-height: 56px;
      padding: 0;
      border: 1px solid rgba(214, 166, 86, .72);
      border-radius: 50%;
      background: linear-gradient(135deg, #d6a656, #b97827);
      color: #061f25;
      font: inherit;
      box-shadow: 0 18px 42px rgba(0, 0, 0, .24), inset 0 1px 0 rgba(255, 255, 255, .34);
      cursor: pointer;
      transition: transform .22s ease, box-shadow .22s ease, filter .22s ease;
    }

    .share-page-float:hover,
    .share-page-float:focus-visible {
      transform: translateY(-3px);
      filter: brightness(1.04);
      box-shadow: 0 22px 50px rgba(0, 0, 0, .30), inset 0 1px 0 rgba(255, 255, 255, .38);
      outline: none;
    }

    .share-page-float svg {
      width: 22px;
      height: 22px;
      fill: currentColor;
    }

    .share-page-float span {
      position: absolute;
      width: 1px;
      height: 1px;
      overflow: hidden;
      clip: rect(0 0 0 0);
      white-space: nowrap;
    }



    .whatsapp-float {
      position: fixed !important;
      right: 22px !important;
      bottom: calc(24px + env(safe-area-inset-bottom, 0px)) !important;
      z-index: 9998 !important;
      width: 56px !important;
      height: 56px !important;
      border-radius: 50% !important;
      display: inline-flex !important;
      align-items: center !important;
      justify-content: center !important;
      background: #18d158 !important;
      color: #061f25 !important;
      box-shadow: 0 18px 42px rgba(0, 0, 0, .24) !important;
    }

    .whatsapp-float svg {
      width: 25px !important;
      height: 25px !important;
      fill: currentColor !important;
    }

    .share-page-toast {
      position: fixed;
      right: 22px;
      bottom: calc(236px + env(safe-area-inset-bottom, 0px));
      z-index: 71;
      max-width: min(280px, calc(100vw - 40px));
      padding: 10px 14px;
      border-radius: 999px;
      background: rgba(6, 31, 37, .94);
      color: #fff5df;
      font-size: .86rem;
      font-weight: 800;
      box-shadow: 0 16px 34px rgba(0, 0, 0, .24);
      opacity: 0;
      transform: translateY(8px);
      pointer-events: none;
      transition: opacity .22s ease, transform .22s ease;
    }

    .share-page-toast.is-visible {
      opacity: 1;
      transform: translateY(0);
    }


    /* Ajuste do card "Prepare sua visita" */
    .visit-card {
      overflow: hidden;
    }

    .visit-card h2 {
      max-width: 12ch;
      line-height: .98;
      letter-spacing: -.055em;
    }

    .visit-card .steps {
      margin: 34px 0 0 !important;
      padding: 0 !important;
      list-style: none !important;
      display: grid !important;
      gap: 14px !important;
      counter-reset: visit-steps;
    }

    .visit-card .steps li {
      counter-increment: visit-steps;
      display: grid !important;
      grid-template-columns: 48px minmax(0, 1fr) !important;
      grid-template-areas:
        "numero titulo"
        "numero texto" !important;
      column-gap: 18px !important;
      row-gap: 6px !important;
      align-items: start !important;
      min-width: 0;
      margin: 0 !important;
      padding: 18px !important;
      border: 1px solid rgba(7, 29, 35, .08) !important;
      border-radius: 22px !important;
      background: rgba(251, 247, 239, .72) !important;
      box-shadow: 0 12px 30px rgba(7, 29, 35, .06) !important;
    }

    .visit-card .steps li::before {
      content: counter(visit-steps) !important;
      grid-area: numero !important;
      width: 42px !important;
      height: 42px !important;
      border-radius: 50% !important;
      display: grid !important;
      place-items: center !important;
      background: #071d23 !important;
      color: #d6a656 !important;
      font-weight: 950 !important;
      line-height: 1 !important;
      box-shadow: 0 12px 24px rgba(7, 29, 35, .16) !important;
    }

    .visit-card .steps li::after {
      display: none !important;
      content: none !important;
    }

    .visit-card .steps li strong {
      grid-area: titulo !important;
      display: block !important;
      width: auto !important;
      max-width: none !important;
      margin: 0 !important;
      padding: 0 !important;
      justify-self: stretch !important;
      text-align: left !important;
      color: #071d23 !important;
      font-size: clamp(1rem, 1.7vw, 1.16rem) !important;
      line-height: 1.15 !important;
      letter-spacing: -.02em !important;
    }

    .visit-card .steps li span {
      grid-area: texto !important;
      display: block !important;
      width: auto !important;
      max-width: none !important;
      margin: 0 !important;
      padding: 0 !important;
      color: #5c6a71 !important;
      font-size: clamp(.98rem, 1.5vw, 1.05rem) !important;
      line-height: 1.55 !important;
    }


    /* Seção Pastores */
    .pastoral-section {
      position: relative;
      overflow: hidden;
    }

    .pastoral-section::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 12% 14%, rgba(214, 166, 86, .18), transparent 28%),
        radial-gradient(circle at 88% 78%, rgba(7, 29, 35, .08), transparent 30%);
      pointer-events: none;
    }

    .pastoral-section .container {
      position: relative;
      z-index: 1;
    }

    .pastoral-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 22px;
      margin-top: 34px;
    }

    .pastor-card {
      position: relative;
      min-height: 100%;
      padding: 34px 28px 30px;
      border-radius: 30px;
      background:
        linear-gradient(180deg, rgba(255,255,255,.92), rgba(251,247,239,.96)),
        #fbf7ef;
      border: 1px solid rgba(214, 166, 86, .34);
      box-shadow: 0 22px 52px rgba(7, 29, 35, .11);
      text-align: center;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 14px;
      overflow: hidden;
    }

    .pastor-card::before {
      content: "";
      position: absolute;
      inset: 0 0 auto 0;
      height: 5px;
      background: linear-gradient(90deg, #d6a656, #173c2f, transparent);
    }

    .pastor-photo {
      width: 136px;
      height: 136px;
      border-radius: 50%;
      position: relative;
      display: grid;
      place-items: center;
      overflow: hidden;
      background: radial-gradient(circle at 30% 20%, #8f4b20, #2a1208 72%);
      border: 4px solid rgba(214, 166, 86, .86);
      box-shadow: 0 18px 38px rgba(7, 29, 35, .18), inset 0 0 0 3px rgba(255, 255, 255, .82);
      flex: 0 0 auto;
      box-sizing: border-box;
    }

    .pastor-photo::before {
      content: attr(data-initials);
      position: absolute;
      inset: 0;
      display: grid;
      place-items: center;
      color: #fff5df;
      font-weight: 900;
      font-size: 1.45rem;
      letter-spacing: .05em;
      z-index: 0;
    }

    .pastor-photo img {
      position: absolute;
      inset: 0;
      z-index: 1;
      width: 100%;
      height: 100%;
      border-radius: 50%;
      object-fit: cover;
      object-position: center;
      display: block;
      background: #2a1208;
    }

    .pastor-role {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: fit-content;
      padding: 7px 12px;
      border-radius: 999px;
      background: rgba(214, 166, 86, .18);
      color: #173c2f;
      font-size: .78rem;
      font-weight: 900;
      letter-spacing: .08em;
      text-transform: uppercase;
    }

    .pastor-card h3 {
      margin: 2px 0 0;
      color: #071d23;
      font-size: clamp(1.35rem, 2vw, 1.72rem);
      line-height: 1.08;
      letter-spacing: -.035em;
    }

    .pastor-card p {
      margin: 0;
      color: #5c6a71;
      font-size: 1rem;
      line-height: 1.58;
      max-width: 31ch;
    }

    /* Seção Experiências Peniel */
    .experiences-section {
      position: relative;
      overflow: hidden;
      background:
        radial-gradient(circle at 8% 18%, rgba(214, 166, 86, .20), transparent 28%),
        radial-gradient(circle at 90% 70%, rgba(255, 245, 223, .10), transparent 32%),
        linear-gradient(135deg, #071d23 0%, #0c2b2f 48%, #173c2f 100%);
      color: #fff5df;
    }

    .experiences-section::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px),
        linear-gradient(0deg, rgba(255,255,255,.035) 1px, transparent 1px);
      background-size: 72px 72px;
      opacity: .32;
      pointer-events: none;
      mask-image: linear-gradient(180deg, transparent, #000 18%, #000 82%, transparent);
    }

    .experiences-section .container {
      position: relative;
      z-index: 1;
    }

    .experiences-section .section-head .eyebrow,
    .experiences-section .experience-kicker {
      color: #d6a656;
    }

    .experiences-section .section-head h2 {
      color: #fff5df;
    }

    .experiences-section .section-head p {
      color: rgba(255, 245, 223, .78);
    }

    .experiences-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 18px;
      margin-top: 34px;
    }

    .experience-card {
      position: relative;
      min-height: 100%;
      padding: 26px;
      border-radius: 28px;
      background:
        linear-gradient(180deg, rgba(255,255,255,.86), rgba(251,247,239,.94)),
        #fbf7ef;
      color: #071d23;
      border: 1px solid rgba(214, 166, 86, .36);
      box-shadow: 0 24px 56px rgba(0, 0, 0, .24);
      display: flex;
      flex-direction: column;
      gap: 16px;
      overflow: hidden;
    }

    .experience-card::before {
      content: "";
      position: absolute;
      inset: 0 0 auto 0;
      height: 5px;
      background: linear-gradient(90deg, #d6a656, #173c2f, transparent);
    }

    .experience-icon {
      width: 56px;
      height: 56px;
      border-radius: 18px;
      display: grid;
      place-items: center;
      background: rgba(214, 166, 86, .18);
      border: 1px solid rgba(214, 166, 86, .36);
      font-size: 1.6rem;
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, .68);
    }

    .experience-kicker {
      display: block;
      font-size: .76rem;
      font-weight: 900;
      letter-spacing: .12em;
      text-transform: uppercase;
      margin-bottom: -8px;
    }

    .experience-card h3 {
      margin: 0;
      color: #071d23;
      font-size: clamp(1.42rem, 2vw, 1.82rem);
      line-height: 1.02;
      letter-spacing: -.04em;
    }

    .experience-card p {
      margin: 0;
      color: #4f5f61;
      font-size: .98rem;
      line-height: 1.58;
    }

    .experience-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin: 2px 0;
    }

    .experience-meta span {
      display: inline-flex;
      align-items: center;
      width: fit-content;
      padding: 7px 10px;
      border-radius: 999px;
      background: rgba(7, 29, 35, .07);
      color: #173c2f;
      font-size: .76rem;
      font-weight: 900;
      letter-spacing: .04em;
      text-transform: uppercase;
    }

    .experience-status {
      margin-top: auto;
      padding-top: 2px;
      color: #8f4b20;
      font-size: .88rem;
      font-weight: 900;
    }

    .experience-card .text-link {
      width: fit-content;
      margin-top: 0;
    }


    /* Versículo do dia */
    .daily-verse-section {
      position: relative;
      overflow: hidden;
      padding: 52px 0;
      background:
        radial-gradient(circle at 12% 18%, rgba(214, 166, 86, .20), transparent 28%),
        radial-gradient(circle at 88% 74%, rgba(7, 29, 35, .08), transparent 30%),
        #fbf7ef;
    }

    .daily-verse-section::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(90deg, rgba(7, 29, 35, .045) 1px, transparent 1px),
        linear-gradient(0deg, rgba(7, 29, 35, .035) 1px, transparent 1px);
      background-size: 72px 72px;
      opacity: .36;
      pointer-events: none;
      mask-image: linear-gradient(180deg, transparent, #000 20%, #000 80%, transparent);
    }

    .daily-verse-section .container {
      position: relative;
      z-index: 1;
    }

    .daily-verse-card {
      position: relative;
      display: grid;
      grid-template-columns: minmax(220px, 270px) minmax(0, 1fr) minmax(280px, 380px);
      gap: 24px;
      align-items: center;
      padding: clamp(26px, 4vw, 44px);
      border-radius: 34px;
      background:
        linear-gradient(135deg, rgba(7, 29, 35, .98), rgba(23, 60, 47, .96)),
        #071d23;
      color: #fff5df;
      border: 1px solid rgba(214, 166, 86, .44);
      box-shadow: 0 28px 70px rgba(7, 29, 35, .22);
      overflow: hidden;
    }

    .daily-verse-card::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 88% 18%, rgba(214, 166, 86, .24), transparent 26%),
        radial-gradient(circle at 8% 82%, rgba(255, 245, 223, .08), transparent 30%);
      pointer-events: none;
    }

    .daily-verse-media,
    .daily-verse-copy,
    .daily-verse-devotional {
      position: relative;
      z-index: 1;
    }

    .daily-verse-media {
      display: grid;
      grid-template-columns: 78px minmax(0, 1fr);
      gap: 14px;
      justify-items: start;
      align-items: center;
      align-content: center;
      align-self: center;
      min-width: 0;
    }

    .daily-verse-logo {
      width: 78px;
      height: 78px;
      border-radius: 26px;
      display: grid;
      place-items: center;
      background: rgba(214, 166, 86, .18);
      border: 1px solid rgba(214, 166, 86, .46);
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, .18);
      overflow: hidden;
    }

    .daily-verse-logo img {
      width: 56px;
      height: 56px;
      object-fit: contain;
      display: block;
    }

    .daily-verse-brand-text {
      display: grid;
      gap: 5px;
      min-width: 0;
    }

    .daily-verse-brand-text strong {
      color: #fff5df;
      font-size: .92rem;
      font-weight: 950;
      line-height: 1.15;
      letter-spacing: -.015em;
    }

    .daily-verse-brand-text span {
      color: rgba(214, 166, 86, .92);
      font-size: .8rem;
      font-weight: 900;
      letter-spacing: .04em;
      text-transform: lowercase;
    }

    .daily-verse-pastor {
      display: grid;
      justify-items: center;
      gap: 5px;
      color: rgba(255, 245, 223, .84);
      text-align: center;
      font-size: .76rem;
      line-height: 1.15;
      font-weight: 800;
    }

    .daily-verse-pastor img {
      width: 70px;
      height: 70px;
      border-radius: 50%;
      object-fit: cover;
      object-position: center;
      display: block;
      border: 2px solid rgba(214, 166, 86, .82);
      box-shadow: 0 12px 26px rgba(0, 0, 0, .22), inset 0 0 0 2px rgba(255, 255, 255, .62);
      background: #fff;
    }

    .daily-verse-pastor small {
      display: block;
      color: #d6a656;
      font-size: .68rem;
      font-weight: 950;
      letter-spacing: .06em;
      text-transform: uppercase;
    }

    .daily-verse-card .eyebrow {
      color: #d6a656;
    }

    .daily-verse-copy h2 {
      margin: 8px 0 14px;
      color: #fff5df;
      font-size: clamp(1.45rem, 3vw, 2.65rem);
      line-height: 1.02;
      letter-spacing: -.045em;
    }

    .daily-verse-copy blockquote {
      margin: 0;
      color: rgba(255, 245, 223, .90);
      font-size: clamp(1.06rem, 1.85vw, 1.32rem);
      line-height: 1.62;
      max-width: 760px;
    }

    .daily-verse-reference {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      align-items: center;
      margin-top: 18px;
      color: #fff5df;
      font-weight: 900;
    }

    .daily-verse-reference span {
      display: inline-flex;
      align-items: center;
      width: fit-content;
      padding: 7px 10px;
      border-radius: 999px;
      background: rgba(214, 166, 86, .18);
      color: #d6a656;
      font-size: .76rem;
      font-weight: 950;
      letter-spacing: .08em;
      text-transform: uppercase;
    }

    .daily-verse-origin {
      display: inline-flex;
      align-items: center;
      width: fit-content;
      gap: 6px;
      margin-top: 10px;
      padding: 0;
      background: transparent;
      border: 0;
      color: rgba(255, 245, 223, .48);
      font-size: .68rem;
      font-weight: 750;
      letter-spacing: .025em;
    }

    .daily-verse-origin::before {
      content: "";
      width: 5px;
      height: 5px;
      border-radius: 50%;
      background: rgba(214, 166, 86, .64);
      flex: 0 0 auto;
    }

    .daily-verse-devotional {
      justify-self: end;
      display: grid;
      gap: 12px;
      padding: 18px;
      border-radius: 24px;
      background: rgba(255, 255, 255, .08);
      border: 1px solid rgba(255, 255, 255, .14);
      color: rgba(255, 245, 223, .84);
      font-size: .92rem;
      line-height: 1.55;
      text-align: left;
    }

    .daily-verse-devotional-head {
      display: flex;
      align-items: center;
      gap: 12px;
      min-width: 0;
    }

    .daily-verse-devotional-head div {
      display: grid;
      gap: 4px;
      min-width: 0;
    }

    .daily-verse-devotional-photo {
      width: 58px;
      height: 58px;
      border-radius: 50%;
      object-fit: cover;
      object-position: center;
      display: block;
      flex: 0 0 auto;
      border: 2px solid rgba(214, 166, 86, .86);
      box-shadow: 0 12px 24px rgba(0, 0, 0, .24), inset 0 0 0 2px rgba(255, 255, 255, .62);
      background: #fff;
    }

    .daily-verse-devotional-head span {
      color: #d6a656;
      font-size: .78rem;
      font-weight: 900;
      letter-spacing: .035em;
      line-height: 1.15;
    }

    .daily-verse-devotional strong {
      color: #fff5df;
      font-size: 1rem;
      letter-spacing: -.015em;
    }

    .daily-verse-devotional p {
      margin: 0;
      color: rgba(255, 245, 223, .84);
    }

    .daily-verse-share {
      margin-top: 2px;
      width: 100%;
      border: 1px solid rgba(214, 166, 86, .62);
      border-radius: 999px;
      background: linear-gradient(135deg, #d6a656, #b97827);
      color: #061f25;
      font: inherit;
      font-weight: 950;
      font-size: .88rem;
      line-height: 1;
      padding: 12px 14px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      cursor: pointer;
      box-shadow: 0 14px 30px rgba(0, 0, 0, .18), inset 0 1px 0 rgba(255, 255, 255, .32);
      transition: transform .2s ease, filter .2s ease, box-shadow .2s ease;
    }

    .daily-verse-share:hover,
    .daily-verse-share:focus-visible {
      transform: translateY(-2px);
      filter: brightness(1.04);
      outline: none;
      box-shadow: 0 18px 36px rgba(0, 0, 0, .24), inset 0 1px 0 rgba(255, 255, 255, .36);
    }

    .daily-verse-share:disabled {
      opacity: .72;
      cursor: wait;
      transform: none;
    }

    .daily-verse-share svg {
      width: 18px;
      height: 18px;
      fill: currentColor;
    }



    /* Troca de posição: Versículo do dia no destaque principal e Próxima programação abaixo */
    .hero-daily-verse-card {
      display: grid;
      gap: 16px;
      align-content: start;
      color: #fff5df;
      overflow: hidden;
    }

    .hero-daily-verse-card .daily-verse-media {
      grid-template-columns: 58px minmax(0, 1fr);
      gap: 12px;
      justify-items: start;
      align-items: center;
    }

    .hero-daily-verse-card .daily-verse-logo {
      width: 58px;
      height: 58px;
      border-radius: 20px;
    }

    .hero-daily-verse-card .daily-verse-logo img {
      width: 42px;
      height: 42px;
    }

    .hero-daily-verse-card .daily-verse-brand-text strong {
      font-size: .86rem;
      line-height: 1.15;
    }

    .hero-daily-verse-card .daily-verse-brand-text span {
      font-size: .74rem;
    }

    .hero-daily-verse-card .daily-verse-copy h2 {
      margin: 8px 0 12px;
      font-size: clamp(1.55rem, 2.3vw, 2.25rem);
    }

    .hero-daily-verse-card .daily-verse-copy blockquote {
      font-size: clamp(1rem, 1.45vw, 1.18rem);
      line-height: 1.55;
    }

    .hero-daily-verse-card .daily-verse-reference {
      margin-top: 14px;
      font-size: .98rem;
    }

    .hero-daily-verse-card .daily-verse-devotional {
      width: 100%;
      justify-self: stretch;
      padding: 16px;
      border-radius: 22px;
    }

    .hero-daily-verse-card .daily-verse-devotional-photo {
      width: 52px;
      height: 52px;
    }

    .hero-daily-verse-card .daily-verse-share {
      margin-top: 2px;
    }

    .program-highlight-section {
      position: relative;
      overflow: hidden;
      padding: 52px 0;
      background:
        radial-gradient(circle at 12% 18%, rgba(214, 166, 86, .20), transparent 28%),
        radial-gradient(circle at 88% 74%, rgba(7, 29, 35, .08), transparent 30%),
        #fbf7ef;
    }

    .program-highlight-section::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(90deg, rgba(7, 29, 35, .045) 1px, transparent 1px),
        linear-gradient(0deg, rgba(7, 29, 35, .035) 1px, transparent 1px);
      background-size: 72px 72px;
      opacity: .36;
      pointer-events: none;
      mask-image: linear-gradient(180deg, transparent, #000 20%, #000 80%, transparent);
    }

    .program-highlight-section .container {
      position: relative;
      z-index: 1;
    }

    .program-highlight-layout {
      display: grid;
      place-items: center;
    }

    .program-highlight-card {
      width: min(100%, 760px);
      justify-self: center;
      color: #071d23;
      background:
        radial-gradient(circle at 88% 12%, rgba(214, 166, 86, .26), transparent 30%),
        linear-gradient(135deg, rgba(255, 255, 255, .97), rgba(251, 247, 239, .98));
      border: 1px solid rgba(214, 166, 86, .44);
      box-shadow: 0 28px 70px rgba(7, 29, 35, .16);
    }

    .program-highlight-card .hero-brand-mark {
      opacity: .10;
      filter: none;
    }

    .program-highlight-card .hero-card-header strong,
    .program-highlight-card h2,
    .program-highlight-card .countdown strong,
    .program-highlight-card .hero-week strong {
      color: #071d23 !important;
      text-shadow: none !important;
    }

    .program-highlight-card .live-badge {
      color: #173c2f !important;
      background: rgba(23, 60, 47, .13) !important;
      border: 1px solid rgba(23, 60, 47, .18) !important;
      box-shadow: none !important;
      text-shadow: none !important;
    }

    .program-highlight-card .live-badge span {
      background: #173c2f !important;
      box-shadow: 0 0 0 6px rgba(23, 60, 47, .12) !important;
    }

    .program-highlight-card p,
    .program-highlight-card #next-event-text,
    .program-highlight-card .countdown span,
    .program-highlight-card .hero-week span,
    .program-highlight-card .hero-card-header strong {
      text-shadow: none !important;
    }

    .program-highlight-card #next-event-text {
      color: #40504c !important;
      font-weight: 850;
    }

    .program-highlight-card .countdown {
      background: rgba(255, 255, 255, .72) !important;
      border: 1px solid rgba(214, 166, 86, .26) !important;
      box-shadow: 0 16px 34px rgba(7, 29, 35, .08) !important;
    }

    .program-highlight-card .countdown span {
      color: #6d5b3d !important;
      font-weight: 900 !important;
      letter-spacing: .12em;
    }

    .program-highlight-card .hero-week a {
      background: rgba(7, 29, 35, .055) !important;
      border: 1px solid rgba(7, 29, 35, .08) !important;
      color: #071d23 !important;
      text-shadow: none !important;
    }

    .program-highlight-card .hero-week span {
      color: #40504c !important;
      font-weight: 750;
    }

    .program-highlight-card .btn-light {
      background: #071d23 !important;
      color: #fff5df !important;
      box-shadow: 0 16px 34px rgba(7, 29, 35, .18) !important;
    }


    @media (max-width: 1000px) {


      .daily-verse-card {
        grid-template-columns: minmax(220px, 270px) minmax(0, 1fr);
      }

      .daily-verse-devotional {
        grid-column: 1 / -1;
        justify-self: stretch;
      }

      .pastoral-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .birthdays-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .experiences-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
    }

    @media (max-width: 640px) {

      .program-highlight-section {
        padding: 34px 0;
      }

      .hero-daily-verse-card {
        gap: 14px;
      }

      .hero-daily-verse-card .daily-verse-devotional {
        padding: 14px;
      }



      .daily-verse-section {
        padding: 34px 0;
      }

      .daily-verse-card {
        grid-template-columns: 1fr;
        gap: 18px;
        padding: 24px;
        border-radius: 28px;
      }

      .daily-verse-media {
        grid-template-columns: 58px minmax(0, 1fr);
        gap: 12px;
        justify-items: start;
        align-items: center;
      }

      .daily-verse-brand-text strong {
        font-size: .86rem;
        line-height: 1.16;
      }

      .daily-verse-brand-text span {
        font-size: .75rem;
      }

      .daily-verse-logo {
        width: 58px;
        height: 58px;
        border-radius: 20px;
      }

      .daily-verse-logo img {
        width: 42px;
        height: 42px;
      }

      .daily-verse-pastor {
        grid-template-columns: 52px minmax(0, 1fr);
        justify-items: start;
        text-align: left;
        column-gap: 10px;
      }

      .daily-verse-pastor img {
        grid-row: 1 / span 2;
        width: 52px;
        height: 52px;
      }

      .daily-verse-pastor span {
        align-self: end;
      }

      .daily-verse-pastor small {
        align-self: start;
      }

      .daily-verse-copy h2 {
        margin-top: 8px;
      }

      .daily-verse-devotional {
        width: 100%;
        justify-self: stretch;
        text-align: left;
      }

      .daily-verse-devotional-photo {
        width: 52px;
        height: 52px;
      }

      .visit-card h2 {
        max-width: 11ch;
        font-size: clamp(2.55rem, 11vw, 3.55rem);
      }

      .visit-card .steps {
        margin-top: 26px !important;
        gap: 12px !important;
      }

      .visit-card .steps li {
        grid-template-columns: 44px minmax(0, 1fr) !important;
        column-gap: 14px !important;
        padding: 16px !important;
        border-radius: 20px !important;
      }

      .visit-card .steps li::before {
        width: 38px !important;
        height: 38px !important;
      }

      .visit-card .steps li strong {
        font-size: 1.04rem !important;
      }

      .visit-card .steps li span {
        font-size: .96rem !important;
        line-height: 1.5 !important;
      }

      .ministry-leader-photo {
        width: 76px;
        height: 76px;
        margin-bottom: 14px;
      }

      .ministry-leader-photo::after {
        border-width: 4px;
      }


      .birthdays-grid {
        grid-template-columns: 1fr;
      }

      .experiences-grid {
        grid-template-columns: 1fr;
        gap: 14px;
      }

      .experience-card {
        padding: 22px;
        border-radius: 24px;
      }

      .experience-icon {
        width: 50px;
        height: 50px;
        border-radius: 16px;
        font-size: 1.38rem;
      }


      .whatsapp-float {
        right: 18px !important;
        bottom: calc(24px + env(safe-area-inset-bottom, 0px)) !important;
      }

      .share-page-float {
        right: 18px !important;
        bottom: calc(98px + env(safe-area-inset-bottom, 0px)) !important;
        width: 56px;
        height: 56px;
        min-height: 56px;
        padding: 0;
        border-radius: 50%;
      }

      .top-page-float {
        right: 18px !important;
        bottom: calc(172px + env(safe-area-inset-bottom, 0px)) !important;
        width: 56px;
        height: 56px;
        min-height: 56px;
        padding: 0;
        border-radius: 50%;
      }

      .share-page-float span {
        position: absolute;
        width: 1px;
        height: 1px;
        overflow: hidden;
        clip: rect(0 0 0 0);
        white-space: nowrap;
      }

      .share-page-toast {
        right: 18px;
        bottom: calc(162px + env(safe-area-inset-bottom, 0px));
      }

    }


/* Correção iPhone/visualização vertical: pastores sempre 1 card por linha */
@media (orientation: portrait) {
  .pastoral-grid {
    grid-template-columns: 1fr !important;
  }

  .pastor-card {
    width: 100%;
    max-width: 560px;
    margin-left: auto;
    margin-right: auto;
  }
}

/* Fallback para navegadores iOS que tratem orientation de forma inconsistente */
@media (max-width: 700px) {
  .pastoral-grid {
    grid-template-columns: 1fr !important;
  }
}


/* Clãs: layout final sem repetição, com perfis em horizontal e vertical */
#clas .clans-board.has-clean-cards {
  display: none !important;
}

#clas .clans-clean-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 26px;
  width: 100%;
}

.clan-clean-card {
  width: 100%;
  border-radius: 28px;
  padding: 22px;
  background:
    radial-gradient(circle at 90% 10%, rgba(214, 166, 86, .12), transparent 36%),
    #fffaf2;
  border: 1px solid rgba(214, 166, 86, .28);
  box-shadow: 0 18px 38px rgba(7, 29, 35, .08);
  display: grid;
  gap: 16px;
  overflow: hidden;
}

.clan-clean-card-top {
  display: grid;
  grid-template-columns: 86px minmax(0, 1fr);
  gap: 15px;
  align-items: center;
}

.clan-clean-photo {
  width: 82px;
  height: 82px;
  border-radius: 50%;
  position: relative;
  display: grid;
  place-items: center;
  overflow: hidden;
  background: radial-gradient(circle at 30% 20%, #8f4b20, #2a1208 72%);
  color: #fff5df;
  font-size: .78rem;
  font-weight: 950;
  box-shadow: 0 14px 30px rgba(27, 12, 5, .16);
}

.clan-clean-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  border: 4px solid rgba(214, 166, 86, .95);
  border-radius: 50%;
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, .88);
  pointer-events: none;
  z-index: 2;
}

.clan-clean-photo img {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
  object-position: center;
  display: block;
  cursor: zoom-in;
}

.clan-clean-photo.is-empty {
  background: linear-gradient(135deg, #173c2f, #071d23);
}

.clan-clean-title {
  min-width: 0;
}

.clan-clean-title span,
.clan-clean-field span {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 6px;
  padding: 5px 9px;
  border-radius: 999px;
  background: rgba(214, 166, 86, .14);
  color: #0f7b64;
  font-size: .72rem;
  font-weight: 950;
  letter-spacing: .09em;
  text-transform: uppercase;
}

.clan-clean-title h3 {
  margin: 0;
  color: #071d23;
  font-size: 1.22rem;
  line-height: 1.12;
  letter-spacing: -.025em;
}

.clan-clean-fields {
  display: grid;
  gap: 10px;
}

.clan-clean-field {
  padding: 12px 14px;
  border-radius: 18px;
  background: rgba(255, 255, 255, .72);
  border: 1px solid rgba(7, 29, 35, .06);
}

.clan-clean-field strong {
  display: block;
  color: #071d23;
  font-size: 1.02rem;
  line-height: 1.24;
}

.clan-clean-actions {
  display: flex;
}

.clan-clean-whatsapp {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  width: 100%;
  border-radius: 999px;
  background: #18d158;
  color: #061f25;
  font-weight: 950;
  text-decoration: none;
  box-shadow: 0 14px 28px rgba(24, 209, 88, .20);
}

@media (max-width: 1100px) {
  #clas .clans-clean-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (orientation: portrait), (max-width: 700px) {
  #clas .clans-clean-cards {
    grid-template-columns: 1fr !important;
    gap: 14px;
    margin-top: 24px;
  }

  .clan-clean-card {
    border-radius: 26px;
    padding: 18px;
  }

  .clan-clean-card-top {
    grid-template-columns: 78px minmax(0, 1fr);
    gap: 14px;
  }

  .clan-clean-photo {
    width: 76px;
    height: 76px;
  }
}

