/* Global Styles */ * {
   margin: 0;
   padding: 0;
   box-sizing: border-box;
 }
 body {
   font-family: "Helvetica Neue", Helvetica, Arial, "Segoe UI", sans-serif;
   background: #000;
 /* Fundo 100% preto */   color: #fff;
   line-height: 1.8;
 /* Aumentado para melhorar legibilidade */   position: relative;
 }
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}
body[data-page="index"],
body[data-page="index"] *,
body[data-page="couple-gallery"],
body[data-page="couple-gallery"] * {
  text-shadow:     0 0 12px rgba(0, 0, 0, 0.98),     0 0 24px rgba(0, 0, 0, 0.92),     0 0 36px rgba(0, 0, 0, 0.88);
}
button,
button *,
input,
input *,
select,
select *,
textarea,
textarea *,
[class*="btn"],
[class*="btn"] *,
[class*="button"],
[class*="button"] *,
.faq-toggle,
.faq-toggle *,
.faq-category-button,
.faq-category-button *,
.future-letter-button,
.future-letter-button *,
.modal-letter-trigger,
.modal-letter-trigger *,
.hero-cta-button,
.hero-cta-button *,
.gift-modal-close,
.gift-modal-close *,
.hero-swiper-nav,
.hero-swiper-nav *,
.modal-letter-close,
.modal-letter-close *,
.gift-modal-item-header button,
.gift-modal-item-header button * {
  text-shadow: none !important;
}
 h1, h2, h3, h4, h5, h6 {
   margin-top: 0;
   margin-bottom: 0.28em;
 }
 p {
   margin-top: 0;
   margin-bottom: 1em;
 }
 body.modal-open {
   overflow: hidden;
 }
 body.modal-open .main-content {
   overflow: hidden;
 }
 #secret-proposal-overlay {
   position: fixed;
   left: 0;
   right: 0;
   top: 50px;
   padding: 18px 18px;
   display: none;
   justify-content: center;
   background: transparent;
   z-index: 9997;
   pointer-events: none;
 }
 #secret-proposal-overlay.is-active {
   display: flex;
 }
 .secret-proposal-content {
   pointer-events: auto;
   width: min(800px, 92%);
   text-align: center;
   position: relative;
 }
 .secret-proposal-content::before {
   content: "";
   position: absolute;
   inset: -28px;
   border-radius: 40px;
   background: radial-gradient(ellipse at center, rgba(255, 124, 0, 0.55) 0%, rgba(255, 124, 0, 0.18) 55%, transparent 100%);
   filter: blur(22px);
   opacity: 0.88;
   z-index: 0;
   pointer-events: none;
 }
 .secret-proposal-content > * {
   position: relative;
   z-index: 1;
 }
 .secret-proposal-time, .secret-proposal-message {
   display: none;
   margin: 6px auto;
   padding: 12px 32px;
   font-weight: 600;
   color: #fff;
   text-shadow: 3px 3px 8px rgba(0, 0, 0, 0.88);
   background: rgba(5, 5, 5, 0.92);
   border-radius: 14px;
   border: 2px solid rgba(255, 162, 0, 0.95);
   box-shadow:     0 0 0 2px rgba(255, 132, 0, 0.7),     0 0 22px rgba(255, 150, 0, 0.85),     0 0 46px rgba(255, 120, 0, 0.7);
   position: relative;
   z-index: 1;
   word-break: break-word;
 }
 .secret-proposal-time::before, .secret-proposal-message::before {
   content: "";
   position: absolute;
   inset: -18px;
   border-radius: inherit;
   background: radial-gradient(ellipse at center, rgba(255, 162, 0, 0.75) 0%, rgba(255, 132, 0, 0.18) 55%, transparent 100%);
   filter: blur(8px);
   opacity: 0.4;
   z-index: -1;
   pointer-events: none;
 }
 .secret-proposal-time.is-visible, .secret-proposal-message.is-visible {
   display: inline-flex;
   align-items: center;
   justify-content: center;
 }
 .secret-proposal-time {
   font-size: clamp(35px, 4.8vw, 48px);
   letter-spacing: 0.12em;
   font-variant-numeric: tabular-nums;
 }
 .secret-proposal-message {
   font-size: clamp(34px, 4.6vw, 48px);
   flex-direction: column;
   line-height: 1;
 }
 .proposal-message-line {
   display: block;
   text-shadow: inherit;
 }
 .proposal-message-primary {
   font-size: 1em;
   line-height: 1;
 }
 .proposal-message-secondary {
   margin-top: 0.15em;
   font-size: 0.5em;
   line-height: 1;
   letter-spacing: 0.08em;
 }
 .container {
   width: 90%;
   max-width: 1200px;
   margin: auto;
 }
  /* Fundo de Emojis */ #global-background {
   position: fixed;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   pointer-events: none;
   z-index: 0;
   --emoji-size: 6rem;
 }
 #global-background .emoji {
   position: absolute;
   font-size: var(--emoji-size, 6rem);
   opacity: 0.5;
   text-shadow: 0 0 20px rgba(255, 255, 255, 0.8);
 }
  /* Conteúdo Principal */ .main-content {
   position: relative;
   z-index: 1;
   background: transparent;
 }
  /* Header sem fundo e sem sombra */ header {
   background: transparent;
   padding: clamp(12px, 4vw, 20px) 0;
   position: fixed;
   width: 100%;
   top: 0;
   z-index: 1000;
   box-shadow: none;
 }
 header .container {
   position: relative;
   display: flex;
   justify-content: center;
 /* Centraliza o conteúdo principal */   align-items: center;
 }
 header .home-link img {
   height: clamp(20px, 6vw, 50px);
 /* Responsive sizing */ }
 header nav {
   position: absolute;
   right: clamp(6px, 3vw, 16px);
   top: clamp(4px, 2vw, 14px);
   transform: none;
 }
 header nav .login-btn {
   background: #e63946;
   color: #fff;
   padding: clamp(4px, 2vw, 10px) clamp(8px, 4vw, 20px);
   text-decoration: none;
   border-radius: 4px;
   transition: background 0.3s ease;
   font-size: clamp(11px, 3.5vw, 18px);
   line-height: 1.2;
 }
 header nav .login-btn:hover {
   background: #d62828;
 }
  header .home-link {
   display: inline-flex;
   align-items: center;
   justify-content: center;
   margin-top: 0;
 }
  /* Seções Transparentes */ .hero, .steps, .social-proof, .social-links, footer {
   background: transparent;
 }
  /* Hero */ .hero {
   display: flex;
   flex-direction: column;
   align-items: center;
   justify-content: center;
   padding: 80px 20px 80px;
   text-align: center;
 }
 body[data-page="couple-gallery"] .hero {
   padding-bottom: 0;
 }
 .hero-slide {
   display: flex;
   flex-direction: column;
 /* Empilha o texto acima da imagem */   align-items: center;
 /* Centraliza os itens horizontalmente */   justify-content: center;
 }
.hero-content {
  text-align: center;
  max-width: 800px;
  margin-bottom: 10px;
}
body[data-page="index"] #panel-how .hero-content {
  max-width: 100%;
  width: 100%;
}
 .hero-title {
   font-size: 22px;
 /* Aumentado de 48px */   color: #ff8c00;
   margin-bottom: 10px;
   text-shadow: 3px 3px 6px #000;
 /* Sombra mais forte */ }
.hero-subtitle {
  font-size: 18px;
 /* Aumentado de 20px */   color: #ccc;
  text-shadow: 2px 2px 4px #000;
  line-height: 1.45;
}
 body[data-page="index"] #panel-hero .hero-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  margin-bottom: 6px;
 }
  body[data-page="index"] #panel-hero .hero-title, body[data-page="index"] #panel-hero .hero-subtitle {
   margin: 0;
 }
body[data-page="index"] #panel-hero .hero-image {
  margin-top: 0;
}
.hero,
.hero * {
  text-shadow: none !important;
}
.portrait-hero-break {
  display: none;
}
.hero-image img {
  width: var(--panel-dynamic-image-max-width, 100%);
  height: auto;
  max-width: none;
  max-height: var(--panel-dynamic-image-max-height, none);
  border-radius: 8px;
  transform-origin: center center;
  overflow: visible;
  position: relative;
  z-index: 2;
}
 .hero-swiper-nav {
   position: absolute;
   top: 50%;
   transform: translateY(-50%);
   width: 42px;
   height: 42px;
   border-radius: 999px;
   border: 1px solid rgba(255, 140, 0, 0.7);
   background: rgba(0, 0, 0, 0.65);
   color: rgba(255, 205, 140, 0.95);
   font-size: 26px;
   line-height: 1;
   display: flex;
   align-items: center;
   justify-content: center;
   cursor: pointer;
   z-index: 5;
   transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease;
 }
 .hero-swiper-nav:hover, .hero-swiper-nav:focus-visible {
   background: rgba(255, 140, 0, 0.8);
   color: #fff;
   border-color: rgba(255, 200, 120, 0.9);
   outline: none;
 }
.hero-swiper-prev {
  left: 18px;
}
.hero-swiper-next {
  right: 18px;
}
body[data-page="index"] #panel-how .hero-swiper-prev,
body[data-page="index"] #panel-how .hero-swiper-next {
  right: auto;
}
body[data-page="index"] #panel-how .hero-swiper-prev {
  left: calc(50% - (var(--panel-dynamic-image-max-width, 320px) / 2) - 57px);
}
body[data-page="index"] #panel-how .hero-swiper-next {
  left: calc(50% + (var(--panel-dynamic-image-max-width, 320px) / 2) + 15px);
}
  .legal-page {
   padding: 140px 20px 80px;
   max-width: 960px;
   margin: 0 auto;
   text-align: left;
   color: #f2f2f2;
 }
 .legal-header {
   text-align: center;
   margin-bottom: 30px;
 }
 .legal-header h1 {
   font-size: clamp(34px, 5vw, 52px);
   color: #ff8c00;
   text-shadow: 3px 3px 6px #000;
   margin-bottom: 12px;
 }
 .legal-header p {
   font-size: 16px;
   color: #ccc;
 }
 .legal-content {
   background: rgba(0, 0, 0, 0.55);
   border: 1px solid rgba(255, 140, 0, 0.35);
   border-radius: 10px;
   padding: clamp(20px, 4vw, 36px);
   line-height: 1.8;
   font-size: 16px;
   white-space: pre-line;
   box-shadow: 0 12px 40px rgba(0, 0, 0, 0.45);
 }
 .legal-content a {
   color: #ff8c00;
   font-weight: 600;
   text-decoration: underline;
 }
 .legal-actions {
   margin-top: 32px;
   text-align: center;
 }
 .legal-button {
   display: inline-block;
   padding: 12px 28px;
   border-radius: 6px;
   background: #ff8c00;
   color: #fff;
   font-size: 18px;
   text-decoration: none;
   transition: background 0.3s ease;
   border: none;
 }
 .legal-button:hover, .legal-button:focus {
   background: #e67e22;
 }
 .legal-footer {
   margin: 40px auto 0;
   padding: 20px;
   max-width: 420px;
   text-align: center;
   line-height: 1.6;
   font-size: 15px;
   color: #ccc;
   background: rgba(0, 0, 0, 0.45);
   border: 1px solid rgba(255, 140, 0, 0.35);
   border-radius: 8px;
 }
 .legal-footer p {
   margin: 6px 0;
 }
 .legal-footer a {
   color: #ff8c00;
   font-weight: 600;
   text-decoration: none;
 }
 .legal-footer a:hover, .legal-footer a:focus {
   text-decoration: underline;
 }
  /* Steps - Layout Desktop (intercalado) */ .steps {
   padding: 80px 20px;
 /* Aumentado */ }
 .steps .section-title {
   text-align: center;
   font-size: 48px;
 /* Aumentado de 36px */   color: #ff8c00;
   margin-bottom: 24px;
   text-shadow: 2px 2px 4px #000;
 }
 .step {
   display: flex;
   flex-wrap: nowrap;
   align-items: center;
   margin-bottom: 60px;
 /* Aumentado */ }
 /* Steps pares invertem a ordem do texto no desktop */ .step:nth-child(even) .step-text {
   order: 2;
 }
 .step-text, .step-image {
   flex: 1 1 300px;
   padding: 20px;
 }
 .step-text h3 {
   font-size: 36px;
 /* Aumentado de 28px */   color: #ff8c00;
   margin-bottom: 6px;
   text-shadow: 2px 2px 4px #000;
 }
 .step-text p {
   font-size: 20px;
 /* Aumentado de 16px */   color: #ccc;
   text-shadow: 2px 2px 4px #000;
 }
 .step-image img {
   width: 100%;
   border-radius: 8px;
   box-shadow: 0 1px 32px rgba(226, 12, 12, 0.74);
   display: block;
   position: relative;
 }
  /* Social Proof (Carousel) */ .social-proof {
   padding: 1px 1px;
   text-align: center;
 }
 .social-proof .section-title {
   font-size: 48px;
 /* Aumentado de 36px */   color: #ff8c00;
   margin-bottom: 18px;
   text-shadow: 2px 2px 4px #000;
 }
 /* Container do carousel */ .swiper-container {
   width: 90%;
   max-width: 600px;
   margin: 0 auto;
   position: relative;
   padding-bottom: 25px;
 }
 .swiper-slide {
   background: transparent;
   border-radius: 8px;
   overflow: visible;
   display: flex;
   justify-content: center;
   align-items: center;
 }
.swiper-slide img {
  width: 100%;
  height: auto;
  display: block;
}
  .photo-upload-row {
   display: flex;
   align-items: center;
   margin-top: 12px;
 }
  .photo-upload-row button[disabled] {
   opacity: 0.6;
   cursor: not-allowed;
 }
  .photo-preview-grid .photo-item {
   position: relative;
 }
  .photo-item .photo-delete-btn {
   position: absolute;
   top: 6px;
   right: 6px;
   background: rgba(0, 0, 0, 0.7);
   border: none;
   color: #ff6b6b;
   width: 26px;
   height: 26px;
   border-radius: 50%;
   display: flex;
   align-items: center;
   justify-content: center;
   font-size: 16px;
   font-weight: bold;
   cursor: pointer;
   transition: background 0.2s, transform 0.2s;
 }
  .photo-item .photo-delete-btn:hover {
   background: rgba(0, 0, 0, 0.85);
   transform: scale(1.05);
 }
  .photo-item .photo-delete-btn:focus {
   outline: 2px solid #ff6b6b;
   outline-offset: 2px;
 }
  body[data-page="couple-gallery"] .swiper-container {
   width: 100%;
   max-width: 95vw;
   margin-left: auto;
   margin-right: auto;
   padding-bottom: 25px;
 }
  body[data-page="couple-gallery"] .swiper-slide {
   background: transparent;
   box-shadow: none;
 }
  body[data-page="couple-gallery"] .hero-image {
   display: flex;
   justify-content: center;
   align-items: center;
   width: auto;
   max-width: 100%;
 }
  body[data-page="couple-gallery"] .hero-image img, body[data-page="couple-gallery"] .swiper-slide img {
   width: auto;
   height: auto;
   max-width: 95vw;
   max-height: 85vh;
   object-fit: contain;
 }
 body[data-page="couple-gallery"] .couple-section {
   margin: 40px auto;
 }
 body[data-page="couple-gallery"] .counter-extra-anchor {
   width: 90%;
   max-width: 1200px;
   margin: 0 auto;
   display: flex;
   justify-content: center;
 }
 body[data-page="couple-gallery"] .counter-extra-anchor.is-empty {
   display: none;
 }
 body[data-page="couple-gallery"] .couple-layout__homage-slot {
   width: 90%;
   max-width: 1200px;
   margin: clamp(32px, 8vh, 48px) auto 20px;
   display: flex;
   justify-content: center;
 }
 body[data-page="couple-gallery"] .couple-layout__homage-slot.is-empty {
   display: none;
 }
 body[data-page="couple-gallery"] .counter-extra-anchor #counter-extra, body[data-page="couple-gallery"] .couple-layout__homage-slot #counter-extra {
   width: 100%;
 }
 body[data-page="couple-gallery"] .couple-layout__scroll-controls {
   display: none;
 }
 body[data-page="couple-gallery"] .couple-layout__scroll-controls button {
   width: 44px;
   height: 44px;
   display: flex;
   align-items: center;
   justify-content: center;
   border-radius: 50%;
   border: none;
   background: rgba(255, 140, 0, 0.85);
   color: #fff;
   font-size: 20px;
   font-weight: 600;
   cursor: pointer;
   box-shadow: 0 6px 20px rgba(0, 0, 0, 0.35);
   transition: transform 0.3s cubic-bezier(0.33, 1, 0.68, 1), box-shadow 0.3s ease, background 0.3s ease;
 }
 body[data-page="couple-gallery"] .couple-layout__scroll-controls button:hover {
   background: rgba(255, 160, 40, 0.9);
   box-shadow: 0 10px 24px rgba(0, 0, 0, 0.45);
   transform: translateY(-2px);
 }
 body[data-page="couple-gallery"] .couple-layout__scroll-controls button:active {
   transform: translateY(0);
 }
 body[data-page="couple-gallery"] .couple-layout__scroll-controls button:focus-visible {
   outline: 2px solid rgba(255, 255, 255, 0.9);
   outline-offset: 3px;
 }
 /* Landscape two-column layout for couple pages */ @media (orientation: landscape) and (min-width: 1072px) {
   body[data-page="couple-gallery"] header .container {
     width: 100%;
     max-width: none;
     margin: 0;
     padding-inline: clamp(16px, 3vw, 48px);
   }
   body[data-page="couple-gallery"] header nav {
     right: clamp(16px, 3vw, 48px);
     top: clamp(12px, 2.4vw, 28px);
   }
   body[data-page="couple-gallery"] .couple-layout {
     display: grid;
     grid-template-columns: minmax(360px, 40vw) minmax(360px, 1fr);
     column-gap: clamp(24px, 4vw, 64px);
     align-items: stretch;
     justify-content: stretch;
     min-height: 100vh;
     width: 100%;
     padding-inline: clamp(12px, 3vw, 48px);
     box-sizing: border-box;
   }
   body[data-page="couple-gallery"] .couple-layout__left {
     position: sticky;
     top: 0;
     height: 100vh;
     display: flex;
     flex-direction: column;
     justify-content: flex-start;
     gap: 0;
     padding: clamp(36px, 5.5vh, 64px) clamp(20px, 3vw, 40px) clamp(6px, 1.2vh, 12px) clamp(12px, 2vw, 24px);
     box-sizing: border-box;
   }
   body[data-page="couple-gallery"] .couple-layout__left .hero {
     flex: 0 0 auto;
     width: 100%;
     padding: 0;
     margin: 0;
     display: flex;
     align-items: center;
   }
   body[data-page="couple-gallery"] .couple-layout__left .hero .swiper-container {
     flex: 1 1 auto;
     width: 100%;
     max-width: none;
     padding-bottom: 2px;
 /*    transform: translateY(-10%);
*/   }
   body[data-page="couple-gallery"] .couple-layout__left .hero .swiper-wrapper,   body[data-page="couple-gallery"] .couple-layout__left .hero .swiper-slide {
     height: 100%;
   }
   body[data-page="couple-gallery"] .couple-layout__left .hero .swiper-slide {
     display: flex;
     align-items: center;
     justify-content: center;
   }
   body[data-page="couple-gallery"] .couple-layout__left .hero .swiper-slide img {
     width: 100%;
     height: auto;
     max-height: 81vh;
     object-fit: contain;
   }
   body[data-page="couple-gallery"] .couple-layout__left #secret-or-counter-section {
     margin: 5px auto clamp(6px, 1.4vh, 12px);
     width: 100%;
     padding-inline: clamp(8px, 2vw, 24px);
   }
   body[data-page="couple-gallery"] .couple-layout__right {
     min-height: 100vh;
     max-height: 100vh;
     overflow-y: auto;
     padding: clamp(88px, 12vh, 128px) clamp(20px, 3vw, 48px) clamp(48px, 9vh, 96px) clamp(20px, 3vw, 48px);
     box-sizing: border-box;
     scroll-padding-top: clamp(88px, 12vh, 128px);
   }
   body[data-page="couple-gallery"] .couple-layout__right .couple-section {
     margin: clamp(32px, 4vh, 56px) auto;
     width: 100%;
   }
   body[data-page="couple-gallery"] .couple-layout__right .legal-footer {
     margin: clamp(15px, 9vh, 112px) auto 0;
     max-width: 640px;
   }
   body[data-page="couple-gallery"] .couple-layout__right .legal-footer p {
     text-align: center;
   }
   body[data-page="couple-gallery"] .couple-layout__homage-slot {
     margin: clamp(32px, 5vh, 60px) auto 20px;
     width: 100%;
     padding: 0 clamp(12px, 2.5vw, 32px);
     box-sizing: border-box;
   }
   body[data-page="couple-gallery"] .counter-extra-anchor #counter-extra {
     margin-top: clamp(4px, 0.9vh, 12px);
   }
 body[data-page="couple-gallery"] .couple-layout__homage-slot #counter-extra {
     margin: 0 auto 0;
     max-width: 100%;
     font-size: 22px;
     line-height: 1.85;
   }
   body[data-page="couple-gallery"] .couple-layout__right::-webkit-scrollbar {
     width: 10px;
   }
   body[data-page="couple-gallery"] .couple-layout__right::-webkit-scrollbar-track {
     background: rgba(255, 255, 255, 0.06);
   }
   body[data-page="couple-gallery"] .couple-layout__right::-webkit-scrollbar-thumb {
     background: rgba(255, 140, 0, 0.55);
     border-radius: 999px;
   }
   body[data-page="couple-gallery"] .couple-layout__right::-webkit-scrollbar-thumb:hover {
     background: rgba(255, 160, 40, 0.75);
   }
   body[data-page="couple-gallery"] .couple-layout__scroll-controls {
     position: fixed;
     bottom: clamp(16px, 4vh, 40px);
     right: calc(clamp(20px, 3vw, 48px) + 12px);
     display: flex;
     flex-direction: column;
     gap: 12px;
     z-index: 1001;
   }
   body[data-page="couple-gallery"] #guests-section .hero-subtitle {
     font-size: calc(18px * 1.2);
     line-height: 1.85;
   }
 }
 /* Paginação (bolinhas) - Maior e posicionada logo abaixo das imagens */ .swiper-pagination {
   position: absolute;
   bottom: 10px;
   left: 0;
   width: 100%;
   text-align: center;
 }
 .swiper-pagination-bullet {
   width: 12px;
 /* Aumentado de 16px */   height: 12px;
 /* Aumentado de 16px */   background: #fff;
   opacity: 0.8;
   margin: 0 8px !important;
 }
 .swiper-pagination-bullet-active {
   background: #ff8c00;
   opacity: 1;
 }
  /* Couple counter responsive typography */ #secret-or-counter-section {
   padding-inline: clamp(1rem, 6vw, 3rem);
   width: 100%;
   margin: 1px auto 1px;
 }
 #secret-or-counter-section .section-title {
   font-size: 18px;
   line-height: 1.25;
   margin-bottom: clamp(0.75rem, 3vw, 1.5rem);
   overflow-wrap: anywhere;
   word-break: break-word;
   text-wrap: balance;
   hyphens: auto;
 }
 #secret-or-counter-section .hero-subtitle {
   font-size: 18px;
   line-height: 1.5;
   margin-bottom: clamp(0.5rem, 2.5vw, 1.25rem);
   margin-left: auto;
   margin-right: auto;
   max-width: min(100%, 70ch);
   overflow-wrap: anywhere;
   word-break: break-word;
   text-wrap: balance;
   white-space: pre-line;
   hyphens: auto;
 }
 #secret-or-counter-section #couple-name-display {
   font-size: 18px;
 }
 #secret-or-counter-section #counter-title {
   font-size: 18px;
 }
#counterDisplay {
  --counter-font-size: 18px;
  display: block;
  margin-left: auto;
  margin-right: auto;
  max-width: min(100%, 70ch);
  line-height: 1.5;
  font-size: var(--counter-font-size, 18px);
}

#secret-or-counter-section #counterDisplay {
  overflow-wrap: normal;
  word-break: normal;
}

#secret-or-counter-section #counterDisplay .duration-segment,
#secret-or-counter-section #counterDisplay .duration-connector {
  white-space: nowrap;
}
 #counterDisplay [data-role='counter-text'] {
   display: block;
   margin: 0 auto;
   max-width: 100%;
   white-space: pre-line;
   overflow-wrap: anywhere;
 }
 #counterDisplay [data-role='counter-duration'] {
   display: inline-flex;
   flex-wrap: nowrap;
   justify-content: center;
   gap: clamp(0.25em, 2vw, 0.45em);
   max-width: 100%;
 }
 #counterDisplay .duration-prefix {
   display: inline-flex;
   align-items: baseline;
   margin-right: 0.35em;
 }
 #counterDisplay .duration-segment, #counterDisplay .duration-connector {
   display: inline-flex;
   align-items: baseline;
   gap: 0.3em;
   flex: 0 1 auto;
   min-width: 0;
 }
 #counterDisplay .duration-label {
   display: inline-flex;
   gap: 0.2em;
 }
#counterDisplay .duration-value {
  font-weight: 600;
  font-size: 1em;
}
 #counterDisplay .duration-connector-comma, #counterDisplay .duration-connector-and {
   white-space: pre-wrap;
 }
 #counter-extra {
   margin-top: clamp(0.35rem, 1.5vw, 1rem);
   margin-left: auto;
   margin-right: auto;
   max-width: min(70ch, 100%);
   display: inline-block;
   width: min(70ch, 100%);
   text-align: center;
   white-space: pre-line;
   overflow-wrap: anywhere;
   word-break: break-word;
   text-wrap: balance;
   font-size: 18px;
   margin-bottom: 0;
   text-shadow: 0 12px 32px rgba(0, 0, 0, 0.85), 0 0 24px rgba(255, 140, 0, 0.5);
 }
 #counter-extra.is-empty {
   display: none;
 }
 @media (max-width: 600px) {
   #counterDisplay [data-role='counter-duration'] {
     gap: clamp(0.2em, 2.5vw, 0.35em);
   }
 }
 /* Divide counter into two rows (Y/M/D on top, H/M/S below) on very narrow screens */
@media (max-width: 480px) {
  #counterDisplay [data-role='counter-duration'] {
    flex-wrap: wrap;
    justify-content: center;
    gap: clamp(0.25em, 3.5vw, 0.45em);
    row-gap: clamp(0.35em, 4vw, 0.6em);
  }

  #counterDisplay .duration-prefix {
    flex-basis: 100%;
    text-align: center;
    margin-bottom: 0.1em;
  }

  #counterDisplay .duration-segment {
    justify-content: center;
  }

  #counterDisplay .duration-connector[data-after-unit='days'] {
    flex-basis: 100%;
    width: 100%;
    height: 0;
    margin: 0;
    padding: 0;
  }

  #counterDisplay .duration-connector[data-after-unit='days'] > * {
    display: none !important;
  }
}
  /* Future Letters (public view) */ #letters-list {
   margin: 0;
   padding: 0;
   list-style: none;
   display: flex;
   flex-direction: column;
   gap: 18px;
   align-items: center;
 }
 body[data-page="couple-gallery"] #letters-section {
   margin: 0 auto 20px;
 }
 body[data-page="couple-gallery"] #guests-section {
   margin: 0 auto 20px;
 }
 body[data-page="couple-gallery"] #gifts-section {
   margin: 0 auto;
 }
 body[data-page="couple-gallery"] #guests-section .hero-subtitle {
   padding: 5px;
   border-radius: 14px;
   background: rgba(10, 10, 10, 0.78);
   box-shadow: 0 22px 60px rgba(0, 0, 0, 0.65);
   border: 1px solid rgba(255, 140, 0, 0.35);
 }
.input-hint,
#letter-coverage-hint {
  font-size: 0.9rem;
  color: #d0d0d0;
  margin: 4px 0 10px;
  display: block;
}

.future-letter-item {
   display: flex;
   flex-direction: column;
   align-items: center;
   gap: 12px;
   padding: 20px 24px;
   border-radius: 12px;
   border: 1px solid rgba(255, 140, 0, 0.4);
   background: rgba(0, 0, 0, 0.55);
   box-shadow: 0 16px 30px rgba(0, 0, 0, 0.45);
   width: min(100%, 440px);
 }
.future-letter-button {
  background: linear-gradient(135deg, #ff8c00, #ff7600);
  color: #fff;
  border: none;
  border-radius: 6px;
   padding: 18px 36px;
   font-size: 18px;
   font-weight: 600;
   cursor: pointer;
   transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
  box-shadow: 0 18px 36px rgba(255, 140, 0, 0.45);
  width: 100%;
  max-width: 360px;
  text-align: center;
}
.future-letter-item-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 360px;
  padding: 18px 36px;
  border-radius: 6px;
  font-size: 18px;
  font-weight: 600;
  text-align: center;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.85);
}
.future-letter-item-label-locked {
  opacity: 0.65;
}
.future-letter-button:hover {
  transform: translateY(-1px);
  background: linear-gradient(135deg, #ffa53b, #ff8c00);
  box-shadow: 0 24px 40px rgba(255, 165, 60, 0.5);
}
 .future-letter-button:disabled {
   background: rgba(255, 255, 255, 0.08);
   color: rgba(255, 255, 255, 0.55);
   cursor: not-allowed;
   box-shadow: none;
 }
 .future-letter-status {
   font-size: 14px;
   color: #d0d0d0;
   letter-spacing: 0.2px;
   text-align: center;
 }
  .modal-letter {
   display: none;
   position: fixed;
   inset: 0;
   padding: clamp(24px, 4vw, 60px);
   background: rgba(0, 0, 0, 0.82);
   backdrop-filter: blur(2px);
   z-index: 9999;
   justify-content: center;
   align-items: center;
 }
 .modal-letter-content {
   position: relative;
   width: min(92%, 640px);
   max-height: 90vh;
   background: rgba(10, 10, 10, 0.96);
   border: 2px solid #ff8c00;
   border-radius: 14px;
   padding: clamp(20px, 4vw, 32px);
   color: #fff;
   box-shadow: 0 30px 60px rgba(0, 0, 0, 0.6);
   display: flex;
   flex-direction: column;
   gap: clamp(14px, 3vw, 20px);
 }
 .modal-letter-content .section-title {
   margin: 0;
   font-size: clamp(20px, 3vw, 26px);
   color: #ff8c00;
   text-align: left;
 }
 .modal-letter-meta {
   font-size: 15px;
   color: rgba(255, 255, 255, 0.7);
   margin: 0;
   text-align: left;
 }
 .modal-letter-close {
   position: absolute;
   top: 14px;
   right: 16px;
   background: transparent;
   border: none;
   color: #ff8c00;
   font-size: 28px;
   font-weight: 600;
   line-height: 1;
   cursor: pointer;
   transition: color 0.2s ease;
 }
 .modal-letter-close:hover, .modal-letter-close:focus-visible {
   color: #ffab3f;
 }
 .modal-letter-body {
   max-height: min(60vh, 480px);
   overflow-y: auto;
   padding-right: 11px;
   margin-right: -5px;
   display: flex;
   flex-direction: column;
   gap: 12px;
   font-size: 17px;
   line-height: 1.7;
 }
 .modal-letter-body p {
   margin: 0;
 }
 .modal-letter-body::-webkit-scrollbar {
   width: 8px;
 }
 .modal-letter-body::-webkit-scrollbar-track {
   background: rgba(255, 255, 255, 0.08);
   border-radius: 999px;
 }
 .modal-letter-body::-webkit-scrollbar-thumb {
   background: rgba(255, 140, 0, 0.65);
   border-radius: 999px;
 }
 .modal-letter-body::-webkit-scrollbar-thumb:hover {
   background: rgba(255, 160, 40, 0.75);
 }
  @media (max-width: 600px) {
   .modal-letter-content {
     padding: 22px 18px 28px;
   }
   .modal-letter-body {
     max-height: 65vh;
   }
   .future-letter-item {
     width: 100%;
     padding-inline: 18px;
   }
 }
.modal-letter-trigger,
.hero-cta-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #ff8c00;
  color: #fff;
  padding: 12px 28px;
  border: none;
  border-radius: 6px;
  font-size: 18px;
  cursor: pointer;
  letter-spacing: 0.05em;
  text-transform: none;
   transition: background 0.3s ease, transform 0.2s ease;
 }
 .modal-letter-trigger:hover, .modal-letter-trigger:focus-visible,
.hero-cta-button:hover,
.hero-cta-button:focus-visible {
   background: #e67e22;
   transform: translateY(-1px);
 }
 .modal-letter-trigger:disabled {
   opacity: 0.5;
   cursor: not-allowed;
   transform: none;
 }
 .gift-modal-item {
   list-style: none;
   margin: 14px 0;
   padding: 0;
   text-align: left;
 }
 .gift-modal-list {
   list-style: none;
   margin: 0;
   padding: 0;
   display: flex;
   flex-direction: column;
   gap: 6px;
   word-break: break-word;
 }
 .gift-modal-group {
   list-style: none;
   margin: 18px 0 8px;
   padding: 0;
   color: #ff8c00;
   text-transform: uppercase;
   letter-spacing: 0.08em;
   font-size: 1.5em;
 }
 .gift-modal-group strong {
   font-size: 0.95em;
 }
 .gift-modal-item {
   font-size: 18px;
   line-height: 1.0;
 }
 .gift-modal-item-header {
   display: flex;
   flex-wrap: nowrap;
   align-items: center;
   gap: 8px;
   justify-content: space-between;
 }
 .gift-modal-item-header strong {
   font-size: 1em;
   color: #ffce8a;
 }
 .gift-modal-flag {
   padding: 2px 10px;
   border-radius: 999px;
   border: 1px solid rgba(255, 140, 0, 0.6);
   background: rgba(255, 140, 0, 0.16);
   color: #ff8c00;
   font-size: 0.75em;
   letter-spacing: 0.08em;
   text-transform: uppercase;
 }
 .gift-modal-meta {
   display: block;
   margin-top: 4px;
   font-size: 0.95em;
   color: #ffddaa;
 }
 .gift-modal-description {
   margin-top: 6px;
   font-size: 0.95em;
   color: #ddd;
   line-height: 1.45;
 }
#giftsModal {
  align-items: flex-start;
  padding-top: var(--gifts-modal-top, 50px);
  padding-bottom: clamp(24px, 5vh, 64px);
  padding-inline: clamp(20px, 3vw, 48px);
  overflow-y: auto;
}
.gift-modal-container {
  width: min(760px, 92vw);
  max-height: min(92vh, 760px);
  display: flex;
  flex-direction: column;
}
.gift-modal-body {
  margin-top: 18px;
  flex: 1 1 auto;
  max-height: clamp(280px, calc(92vh - 180px), 620px);
  overflow-y: auto;
  padding-right: 6px;
}
 .gift-modal-body::-webkit-scrollbar {
   width: 8px;
 }
 .gift-modal-body::-webkit-scrollbar-track {
   background: rgba(255, 255, 255, 0.1);
   border-radius: 999px;
 }
 .gift-modal-body::-webkit-scrollbar-thumb {
   background: rgba(255, 140, 0, 0.65);
   border-radius: 999px;
 }
 .gift-modal-body::-webkit-scrollbar-thumb:hover {
   background: rgba(255, 160, 40, 0.75);
 }
 .gift-modal-close {
   padding: 10px 14px;
   border-radius: 8px;
   background: rgba(255, 140, 0, 0.1);
   display: flex;
   align-items: center;
   justify-content: center;
   min-width: 44px;
   min-height: 44px;
   border: none;
 }
 .gift-modal-close:hover, .gift-modal-close:focus-visible {
   background: rgba(255, 140, 0, 0.22);
 }
  .faq-section {
   padding: 40px 0 24px;
 }
 .faq-section .container {
   max-width: 960px;
   margin: 0 auto;
   padding: 0 clamp(12px, 4vw, 24px);
   display: flex;
   flex-direction: column;
   align-items: center;
 }
 .faq-toggle {
   width: min(65%, 520px);
   padding: clamp(16px, 3vw, 22px);
   border-radius: 12px;
   border: 1px solid rgba(255, 140, 0, 0.66);
   background: linear-gradient(135deg, rgba(255, 140, 0, 0.9), rgba(255, 140, 0, 0.65));
   color: #fff;
   font-size: clamp(18px, 2.2vw, 22px);
   letter-spacing: 0.04em;
   text-transform: uppercase;
   font-weight: 600;
   cursor: pointer;
   display: inline-flex;
   justify-content: center;
   align-items: center;
   gap: 12px;
   box-shadow: 0 18px 36px rgba(255, 140, 0, 0.22);
   transition: transform 0.35s ease, box-shadow 0.35s ease, background 0.35s ease;
 }
 .faq-section .faq-toggle + .faq-categories {
   width: 100%;
 }
 .faq-toggle:hover, .faq-toggle:focus-visible {
   transform: translateY(-4px);
   box-shadow: 0 24px 42px rgba(255, 140, 0, 0.32);
   background: linear-gradient(135deg, rgba(255, 165, 64, 0.95), rgba(255, 140, 0, 0.78));
 }
 .faq-section.is-open .faq-toggle {
   background: linear-gradient(135deg, rgba(230, 126, 34, 0.95), rgba(255, 140, 0, 0.88));
 }
 .faq-categories {
   margin-top: clamp(24px, 5vw, 36px);
   display: grid;
   gap: clamp(12px, 3vw, 18px);
   overflow: hidden;
   max-height: 0;
   opacity: 0;
   transform: translateY(-12px);
   transition: max-height 0.5s ease, opacity 0.35s ease, transform 0.5s ease;
 }
 .faq-categories.is-open {
   opacity: 1;
   transform: translateY(0);
 }
 .faq-category-item {
   border-radius: 14px;
   background: rgba(10, 10, 10, 0.88);
   border: 1px solid rgba(255, 140, 0, 0.4);
   box-shadow: 0 12px 30px rgba(0, 0, 0, 0.55);
   overflow: hidden;
 }
 .faq-category-button {
   width: 100%;
   border: none;
   background: transparent;
   padding: clamp(18px, 3vw, 22px);
   display: flex;
   align-items: center;
   justify-content: space-between;
   gap: 16px;
   color: #ffce8a;
   font-size: clamp(18px, 2.2vw, 22px);
   font-weight: 600;
   letter-spacing: 0.04em;
   text-transform: uppercase;
   cursor: pointer;
   position: relative;
   transition: background 0.3s ease, color 0.3s ease, padding 0.3s ease;
 }
 .faq-category-button::before {
   content: '';
   position: absolute;
   inset: 0;
   background: linear-gradient(90deg, rgba(255, 140, 0, 0.28), rgba(255, 140, 0, 0));
   opacity: 0.65;
   pointer-events: none;
   transition: opacity 0.3s ease;
 }
 .faq-category-button:hover::before, .faq-category-button:focus-visible::before {
   opacity: 1;
 }
 .faq-category-button:hover, .faq-category-button:focus-visible {
   color: #fff;
   background: rgba(255, 140, 0, 0.12);
 }
 .faq-category-button span {
   pointer-events: none;
 }
 .faq-category-icon {
   width: 26px;
   height: 26px;
   border-radius: 50%;
   border: 2px solid rgba(255, 140, 0, 0.7);
   display: inline-flex;
   align-items: center;
   justify-content: center;
   position: relative;
   flex-shrink: 0;
   transition: transform 0.35s ease, border-color 0.35s ease;
 }
 .faq-category-icon::before, .faq-category-icon::after {
   content: '';
   position: absolute;
   background: #ff8c00;
   border-radius: 999px;
   transition: transform 0.35s ease, background 0.35s ease;
 }
 .faq-category-icon::before {
   width: 12px;
   height: 2px;
 }
 .faq-category-icon::after {
   width: 2px;
   height: 12px;
 }
 .faq-category-button[aria-expanded="true"] .faq-category-icon {
   transform: rotate(180deg);
   border-color: rgba(255, 153, 51, 0.85);
 }
 .faq-category-button[aria-expanded="true"] .faq-category-icon::after {
   transform: scaleY(0);
 }
 .faq-question-list {
   padding: 0 clamp(18px, 3vw, 22px) clamp(18px, 4vw, 26px);
   display: grid;
   gap: clamp(16px, 3.2vw, 22px);
   border-top: 1px solid rgba(255, 140, 0, 0.28);
   max-height: 0;
   overflow: hidden;
   opacity: 0;
   transform: translateY(-14px);
   transition: max-height 0.45s ease, opacity 0.35s ease, transform 0.45s ease;
 }
 .faq-question-list.is-open {
   opacity: 1;
   transform: translateY(0);
 }
 .faq-question {
   padding: clamp(14px, 3vw, 18px) clamp(16px, 3vw, 24px);
   background: linear-gradient(135deg, rgba(255, 140, 0, 0.12), rgba(255, 140, 0, 0.05));
   border-left: 3px solid rgba(255, 140, 0, 0.6);
   border-radius: 12px;
   box-shadow: inset 0 0 0 1px rgba(255, 140, 0, 0.08);
 }
 .faq-question-title {
   font-size: clamp(17px, 2vw, 20px);
   font-weight: 600;
   color: #fff;
   letter-spacing: 0.03em;
 }
 .faq-question-answer {
   margin-top: 8px;
   color: #e6e6e6;
   font-size: clamp(15px, 1.8vw, 18px);
   line-height: 1.6;
 }
 .faq-question-answer ol, .faq-question-answer ul {
   margin: 12px 0 0 18px;
   padding: 0;
 }
 .faq-question-answer li {
   margin-bottom: 6px;
   padding-left: 4px;
 }
  @media (max-width: 720px) {
   .faq-toggle {
     width: 100%;
     font-size: 16px;
     letter-spacing: 0.02em;
     padding: 16px;
   }
   .faq-category-button {
     font-size: 17px;
   }
   .faq-question-title {
     font-size: 16px;
   }
   .faq-question-answer {
     font-size: 15px;
   }
 }
  /* Connect With Us */ .social-links {
   padding: 60px 20px;
 /* Aumentado */   text-align: center;
   margin: 0 auto;
 }
 .social-links .section-title {
   font-size: 36px;
 /* Aumentado de 28px */   color: #ff8c00;
   margin-bottom: 12px;
   text-shadow: 2px 2px 4px #000;
 }
 .social-icons {
   display: flex;
   justify-content: center;
   align-items: center;
 }
 .social-icons a {
   display: inline-block;
   margin: 0 10px;
   transition: transform 0.3s ease;
 }
 .social-icons a:hover {
   transform: scale(1.1);
 }
 .social-icons img {
   width: 60px;
   height: 60px;
   object-fit: cover;
   border-radius: 50%;
   border: 2px solid #e63946;
 }
  /* Footer */ footer {
   padding: 30px 10px;
 /* Aumentado */   font-size: 18px;
 /* Aumentado de 14px */   text-align: center;
   color: #ccc;
   text-shadow: 2px 2px 4px #000;
 }
  /* Responsividade (max-width: 768px) */ @media (max-width: 768px) {
   .step {
     flex-direction: column !important;
     display: block;
     position: relative;
     margin-bottom: 40px;
   }
   .step-text,   .step-image {
     width: 100%;
     order: initial;
     padding: 10px 0;
     position: static;
     transform: none;
     background: transparent;
     text-align: center;
   }
   .step-text h3 {
     font-size: 28px;
 /* Aumentado de 24px */     margin-bottom: 10px;
   }
   .step-text p {
     font-size: 18px;
 /* Aumentado de 14px */   }
   .swiper-container {
     max-width: 90%;
   }
 }
  /* Botão CTA para Planos */ .cta-plans {
   text-align: center;
   margin-top: 10px;
 }
 .btn-plans {
   display: inline-flex;
   align-items: center;
   justify-content: center;
   background: #ff8c00;
   color: #fff;
   padding: 12px 28px;
   font-size: 18px;
   font-weight: 600;
   line-height: 1.25;
   letter-spacing: 0.05em;
   text-decoration: none;
   text-transform: none;
   border: none;
   border-radius: 6px;
   cursor: pointer;
   transition: background 0.3s ease, transform 0.2s ease;
 }
 .btn-plans:hover,
 .btn-plans:focus-visible {
   background: #e67e22;
   transform: translateY(-1px);
 }
 .neon-trail {
   background-color: rgba(255, 0, 0, 0.5);
   filter: blur(4px);
   border-radius: 4px;
   pointer-events: none;
   width: 3em;
 /* aumenta a largura */   height: 2em;
 /* aumenta a altura */ }
 .line-emoji {
   color: red;
   text-shadow: 0 0 20px rgba(255, 0, 0, 0.822);
   /* Outras propriedades já definidas via JS */ }
  :root {
   --header-offset: 72px;
 }
  body[data-page="index"] {
   height: 100vh;
   overflow: hidden;
 }
body[data-page="index"] .main-content {
  height: 100vh;
  overflow-y: auto;
  overflow-x: hidden;
  scroll-snap-type: y mandatory;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scroll-padding-top: calc(var(--header-offset, 72px) + var(--scroll-snap-extra, 0px));
  overscroll-behavior: contain;
}
  body[data-page="index"] .page-panels {
   display: flex;
   flex-direction: column;
   min-height: 100%;
 }
body[data-page="index"] .page-panel {
  width: 100%;
  box-sizing: border-box;
  scroll-snap-align: start;
  scroll-snap-stop: always;
  min-height: 100vh;
  padding: calc(var(--header-offset, 72px) + clamp(16px, 4vh, 32px)) clamp(16px, 6vw, 48px) clamp(32px, 6vh, 64px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(24px, 5vh, 48px);
}
.page-panel.dynamic-panel--overflowing {
  overflow-y: auto;
  justify-content: flex-start;
}
@media (max-height: 780px) {
  body[data-page="index"] .page-panel {
    padding: calc(var(--header-offset, 72px) + clamp(10px, 2vh, 18px)) clamp(12px, 5vw, 32px) clamp(20px, 4vh, 36px);
    gap: clamp(16px, 4vh, 28px);
  }
  body[data-page="index"] .hero {
    padding: clamp(12px, 4vw, 24px) clamp(10px, 4vw, 24px);
    gap: clamp(8px, 3vh, 16px);
  }
  body[data-page="index"] .hero-content {
    gap: 4px;
  }
  body[data-page="index"] .hero-title {
    font-size: clamp(20px, 5vw, 30px);
    line-height: 1.2;
  }
  body[data-page="index"] .hero-subtitle {
    font-size: clamp(15px, 4.2vw, 18px);
    line-height: 1.35;
  }
}
@media (max-height: 640px) {
  body[data-page="index"] .page-panel {
    padding: calc(var(--header-offset, 72px) + clamp(6px, 1.5vh, 14px)) clamp(10px, 4vw, 24px) clamp(16px, 3vh, 28px);
    gap: clamp(12px, 3vh, 20px);
  }
  body[data-page="index"] .hero {
    gap: clamp(6px, 2vh, 12px);
  }
  body[data-page="index"] .hero-title {
    font-size: clamp(18px, 4.8vw, 26px);
  }
  body[data-page="index"] .hero-subtitle {
    font-size: clamp(14px, 4vw, 17px);
    line-height: 1.3;
  }
}
  @media (max-height: 680px) {
   body[data-page="index"] .page-panel {
     justify-content: flex-start;
   }
 }
  body[data-page="index"] .page-panel--faq {
   justify-content: flex-start;
   gap: clamp(24px, 5vh, 48px);
 }
  body[data-page="index"] .page-panel--faq > :is(.faq-section, .social-links, .legal-footer) {
   width: min(100%, 880px);
   margin-left: auto;
   margin-right: auto;
 }
body[data-page="index"] .hero {
  width: 100%;
  padding: clamp(16px, 4vw, 32px) clamp(12px, 5vw, 40px);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
   gap: clamp(12px, 3vh, 20px);
 }
  body[data-page="index"] .hero--steps {
   gap: clamp(18px, 4vh, 28px);
 }
  body[data-page="index"] .hero-slide {
   flex-direction: column;
   gap: clamp(10px, 2vh, 16px);
 }
body[data-page="index"] .hero-image img {
  width: var(--panel-dynamic-image-max-width, 100%);
  max-width: none;
  max-height: var(--panel-dynamic-image-max-height, none);
  object-fit: contain;
}
  body[data-page="index"] .social-proof {
   width: min(100%, 960px);
   margin: 0 auto;
   text-align: center;
   display: flex;
   flex-direction: column;
   align-items: center;
   gap: 6px;
   background: transparent;
 }
  body[data-page="index"] .social-proof .hero-image img {
   box-shadow: none;
 }
  body[data-page="index"] #more-info-button {
   align-self: center;
   margin-top: 10px;
 }
  body[data-page="index"] #panel-showcase {
   padding-top: calc(var(--header-offset, 72px) + 10px);
   padding-bottom: clamp(16px, 4vh, 32px);
 }
  body[data-page="index"] #panel-showcase .section-title {
   margin-top: 0;
   margin-bottom: 0;
 }
body[data-page="index"] #panel-showcase .hero {
  gap: 6px;
  padding: 0;
}
 body[data-page="index"] #panel-showcase .hero-slide {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1px;
  margin: 0;
}
 body[data-page="index"] #panel-showcase .hero-image {
  margin-top: 0;
}
body[data-page="index"] #panel-showcase .swiper-container {
  position: relative;
  padding-bottom: 0;
  overflow: hidden;
}
body[data-page="index"] #panel-showcase .hero-pagination {
  position: absolute;
  left: 0;
  right: 0;
  bottom: clamp(12px, 3vw, 24px);
  transform: none;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(8px, 2vw, 12px);
  padding: 0;
  background: transparent;
  backdrop-filter: none;
  z-index: 3;
  pointer-events: auto;
}
body[data-page="index"] #panel-showcase .hero-pagination .swiper-pagination-bullet {
  margin: 0 !important;
  opacity: 0.8;
}
body[data-page="index"] #panel-showcase .hero-pagination .swiper-pagination-bullet-active {
  opacity: 1;
  background: #ff8c00;
}
 body[data-page="index"] #panel-showcase .hero-cta-actions {
  margin-top: 1px;
  display: flex;
  justify-content: center;
  align-items: stretch;
  gap: 10px;
  flex-wrap: nowrap;
}
body[data-page="index"] #panel-showcase .hero-cta-actions > * {
 flex: 0 0 80px;
 min-width: 160px;
}
body[data-page="index"] #panel-showcase .hero-cta-actions .modal-letter-trigger,
body[data-page="index"] #panel-showcase .hero-cta-actions .btn-plans,
body[data-page="index"] #panel-showcase .hero-cta-actions .hero-cta-button {
  margin-top: 0;
  width: 80px;
  font-size: clamp(12px, 3.2vw, 14px);
  padding: 8px 0;
  line-height: 1.2;
  text-align: center;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #ff8c00;
  color: #fff;
  border-radius: 6px;
  border: none;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-decoration: none;
}
body[data-page="index"] #panel-showcase .hero-cta-actions .modal-letter-trigger:hover,
body[data-page="index"] #panel-showcase .hero-cta-actions .modal-letter-trigger:focus-visible,
body[data-page="index"] #panel-showcase .hero-cta-actions .btn-plans:hover,
body[data-page="index"] #panel-showcase .hero-cta-actions .btn-plans:focus-visible,
body[data-page="index"] #panel-showcase .hero-cta-actions .hero-cta-button:hover,
body[data-page="index"] #panel-showcase .hero-cta-actions .hero-cta-button:focus-visible {
  background: #e67e22;
}
  @media (max-aspect-ratio: 100/115) {
   body[data-page="index"] .social-proof .hero {
     gap: 6px;
   }
   body[data-page="index"] .social-proof .swiper-container {
     padding-bottom: 30px;
   }
   body[data-page="index"] .social-proof .swiper-pagination {
     bottom: 10px;
   }
 }
  body[data-page="index"] .faq-section .container {
   padding: 0 clamp(12px, 4vw, 24px);
 }
  body[data-page="index"] .legal-footer {
   margin-top: clamp(16px, 4vh, 40px);
 }
  @media (max-aspect-ratio: 100/115) {
   body[data-page="index"] .main-content {
     scroll-padding-top: calc(var(--header-offset, 72px) + clamp(-48px, -8vh, -20px) + 30px);
   }
   body[data-page="index"] .page-panel {
     padding-top: calc(var(--header-offset, 72px) + clamp(-48px, -8vh, -20px) + 30px);
     padding-left: clamp(4px, 3vw, 14px);
     padding-right: clamp(4px, 3vw, 14px);
     gap: clamp(12px, 3vh, 24px);
     justify-content: flex-start;
   }
   body[data-page="index"] .container {
     width: 100%;
     max-width: none;
     padding-left: 0;
     padding-right: 0;
   }
   body[data-page="index"] :is(h1, h2, h3, h4, h5, h6, p) {
     width: 100%;
     max-width: none;
     margin-left: 10px;
     margin-right: 10px;
     line-height: 1;
   }
   body[data-page="index"] .hero,   body[data-page="index"] .hero-content,   body[data-page="index"] .step-text,   body[data-page="index"] .faq-section .container,   body[data-page="index"] #secret-or-counter-section,   body[data-page="index"] #counterDisplay,   body[data-page="index"] #counter-extra,   body[data-page="index"] .social-proof,   body[data-page="index"] .cta-plans,   body[data-page="index"] .cta-plans .btn-plans {
     width: 100%;
     max-width: none;
   }
   body[data-page="index"] .hero {
     width: 100%;
     max-width: none;
     padding-left: clamp(4px, 3vw, 16px);
     padding-right: clamp(4px, 3vw, 16px);
     align-items: stretch;
   }
   body[data-page="index"] .hero .swiper-container,   body[data-page="index"] .hero .swiper-wrapper,   body[data-page="index"] .hero .swiper-slide {
     width: 100%;
     max-width: none;
   }
   body[data-page="index"] .hero-slide {
     align-items: stretch;
   }
   body[data-page="index"] .hero-content {
     align-self: stretch;
     max-width: none;
     width: 100%;
     padding-left: clamp(4px, 3vw, 16px);
     padding-right: clamp(4px, 3vw, 16px);
   }
   body[data-page="index"] .hero-content :is(h1, h2, h3, h4, h5, h6, p) {
     width: 100%;
     max-width: none;
     line-height: 1;
   }
   body[data-page="index"] .hero-image {
     align-self: center;
   }
   body[data-page="index"] .social-proof .section-title {
     font-size: 24px;
   }
   body[data-page="index"] #panel-hero .portrait-hero-break {
     display: block;
     margin: 0;
   }
   body[data-page="index"] #panel-how .hero-slide {
     align-items: center;
   }
   body[data-page="index"] #panel-how .hero-image {
     align-self: center;
   }
   body[data-page="index"] #panel-how .hero-image img {
     margin-left: auto;
     margin-right: auto;
   }
   body[data-page="index"] #panel-how .hero-swiper-nav {
     position: fixed;
     top: 50%;
     transform: translateY(-50%);
     opacity: 0;
     pointer-events: none;
     transition: opacity 0.25s ease;
     z-index: 1200;
   }
  body[data-page="index"] #panel-how .hero-swiper-prev {
     left: 0;
     left: calc(env(safe-area-inset-left, 0px));
     right: auto;
   }
   body[data-page="index"] #panel-how .hero-swiper-next {
     left: auto;
     right: 0;
     right: calc(env(safe-area-inset-right, 0px));
   }
   body[data-page="index"].is-panel-how-visible #panel-how .hero-swiper-nav {
     opacity: 1;
     pointer-events: auto;
   }
   body[data-page="index"] #more-info-button,
   body[data-page="index"] .cta-plans .btn-plans {
     width: 240px;
     max-width: 240px;
     height: 36px;
     padding: 0;
     font-size: 20px;
     line-height: 36px;
     letter-spacing: 0.05em;
     display: inline-flex;
     align-items: center;
     justify-content: center;
   }
   body[data-page="index"] #more-info-button {
     margin-top: 10px;
   }
   body[data-page="index"] .cta-plans {
     margin-top: 10px;
   }
   body[data-page="index"] .cta-plans .btn-plans {
     margin-top: 0;
   }
   body[data-page="index"] #moreInfoModal .modal-letter-content {
     width: 100%;
     max-width: 100%;
     padding: clamp(16px, 4vw, 32px);
     max-height: calc(100vh - 32px);
     box-sizing: border-box;
     margin: 0;
     overflow-x: hidden;
     border-radius: 14px;
   }
   body[data-page="index"] #moreInfoModal .modal-letter-body {
     width: 100%;
     overflow-wrap: anywhere;
     word-break: break-word;
     overflow-x: hidden;
     box-sizing: border-box;
     padding-right: 16px;
     margin-right: -5px;
   }
   body[data-page="index"] #moreInfoModal .modal-letter-body p {
     overflow-wrap: anywhere;
     word-break: break-word;
     white-space: normal;
   }
   body[data-page="index"] #moreInfoModal {
     overflow-x: hidden;
   }
   body[data-page="index"] #moreInfoModal.modal-letter {
     padding: clamp(12px, 4vw, 24px);
   }
}
 .gtranslate_wrapper, .gtranslate_wrapper * {
   text-shadow: none !important;
 }
 .gtranslate_wrapper .gt_float_switcher {
   font-size: 15px !important;
   line-height: 15px !important;
   border-radius: 1.5px !important;
   box-shadow: rgba(0, 0, 0, 0.15) 0 3.75px 11.25px !important;
 }
 .gtranslate_wrapper .gt_float_switcher img {
   width: 24.75px !important;
   margin: 0 3.75px 0 0 !important;
   border-radius: 2.25px !important;
 }
 .gtranslate_wrapper .gt_float_switcher .gt-selected .gt-current-lang,
 .gtranslate_wrapper .gt_float_switcher .gt_options a {
   padding: 4.5px 11.25px !important;
 }
 .gtranslate_wrapper .gt_float_switcher .gt-selected .gt-current-lang span.gt_float_switcher-arrow {
   height: 18px !important;
   width: 11.25px !important;
   background-size: 8.25px !important;
 }
