/*
 * GTA — Landing Pages
 * Folha de estilos partilhada para todas as landing pages de /landing/
 * Depende de: Bootstrap 5, Bootstrap Icons, fonte Montserrat (woff2 local)
 */

@font-face {
  font-family: 'Montserrat';
  src: url('../../css/fonts/Montserrat-VF.woff2') format('woff2-variations');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

:root {
  --deep: #033452;
  --baltic: #1E6285;
  --sky: #00AAE4;
  --sky-hover: #0095C8;
  --aqua: #3AC4EC;
  --mint: #10B981;
  --danger: #EF4444;
  --gold: #F59E0B;
  --white: #FFFFFF;
  --snow: #F7FAFC;
  --pearl: #EDF2F7;
  --mist: #E2E8F0;
  --slate: #94A3B8;
  --graphite: #64748B;
  --ink: #334155;
  --charcoal: #1E293B;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Montserrat', system-ui, sans-serif;
  background: var(--white);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* ── MICRO NAV ── */
.lp-topbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  padding: .7rem 0;
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(255,255,255,.04);
}
.lp-topbar .container { display: flex; align-items: center; justify-content: space-between; }
.lp-topbar-logo { height: 28px; opacity: .9; }
.lp-topbar-cta {
  display: inline-flex; align-items: center; gap: .4rem;
  background: var(--sky); color: var(--white);
  font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
  padding: .5rem 1.2rem; border-radius: 50px; text-decoration: none;
  transition: all .25s ease;
}
.lp-topbar-cta:hover { background: #0095C8; transform: translateY(-1px); box-shadow: 0 4px 20px rgba(0,170,228,.3); }

/* ── HERO ── */
.lp-hero::before {
  content: " "; width: 100%; height: 100%; position: absolute; top: 0; left: 0;
  z-index: 1;
  opacity: .82;
  background:
    radial-gradient(ellipse 70% 60% at 75% 35%, rgba(0,170,228,.65) 0%, transparent 70%),
    radial-gradient(ellipse 50% 50% at 15% 80%, rgba(255,107,53,.35) 0%, transparent 60%),
    linear-gradient(175deg, var(--ink) 0%, #081c30 45%, var(--deep) 100%);
}
.lp-hero {
  min-height: 100vh; display: flex; align-items: center; position: relative;
  padding: 6rem 0 4rem;
  background-repeat: no-repeat; background-size: cover;
}
/* replaces inline style="z-index:2" on hero containers */
.lp-hero > .container { position: relative; z-index: 2; }
.lp-hero::after {
  content: ''; position: absolute; inset: 0;
  background-image: radial-gradient(rgba(255,255,255,.012) 1px, transparent 1px);
  background-size: 24px 24px; pointer-events: none;
}

.lp-kicker {
  display: inline-flex; align-items: center; gap: .5rem;
  font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .14em;
  color: var(--sky); margin-bottom: 1.5rem;
}
.lp-kicker::before { content: ''; display: block; width: 28px; height: 2px; background: linear-gradient(90deg, var(--sky), transparent); }

.lp-h1 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(2.4rem, 6vw, 4.2rem);
  font-weight: 400; line-height: 1.08;
  color: var(--white); margin: 0 0 1.5rem;
  letter-spacing: -.02em;
  filter: drop-shadow(1px 1px 2px rgba(0,0,0,.4));
}
.lp-h1 em { font-style: normal; color: var(--sky); }
.lp-h1-sub {
  font-size: 1.05rem; line-height: 1.75;
  color: var(--pearl); max-width: 540px; margin-bottom: 2.5rem;
  filter: drop-shadow(1px 1px 2px rgba(0,0,0,.4));
}
.lp-h1-sub strong { color: var(--white); font-weight: 600; }

.lp-proof-strip {
  display: flex; gap: 2rem; flex-wrap: wrap;
  margin-top: 3rem; padding-top: 2rem;
  border-top: 1px solid rgba(255,255,255,.06);
}
.lp-proof-item { display: flex; align-items: center; gap: .6rem; }
.lp-proof-icon {
  width: 36px; height: 36px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center; font-size: .95rem;
}
.ic-gold-tx-c strong { color: var(--gold) !important; }
.lp-proof-icon.ic-gold { background: rgba(245,158,11,.1); color: var(--gold); }
.lp-proof-icon.ic-sky  { background: var(--sky-glow); color: var(--sky); }
.lp-proof-icon.ic-mint { background: rgba(16,185,129,.1); color: var(--mint); }
.lp-proof-text { font-size: .76rem; color: var(--muted); line-height: 1.35; }
.lp-proof-text strong { color: var(--white); display: block; font-size: .82rem; }

/* ── CTA BUTTONS ── */
.lp-cta-group { display: flex; gap: .8rem; flex-wrap: wrap;}
.lp-cta-group.center { justify-content: center!important;}

.lp-btn-primary {
  display: inline-flex; align-items: center; gap: .5rem;
  background: var(--sky); color: var(--white);
  font-size: .82rem; font-weight: 700;
  padding: .85rem 2rem; border-radius: 50px;
  text-decoration: none; border: 0; cursor: pointer;
  transition: all .3s cubic-bezier(.4,0,.2,1);
}
.lp-btn-primary:hover { background: var(--sky-hover); transform: translateY(-2px); box-shadow: 0 8px 32px rgba(0,170,228,.2); }

.lp-btn-secondary {
  display: inline-flex; align-items: center; gap: .5rem;
  background: transparent;
  font-size: .82rem; font-weight: 600;
  padding: .85rem 2rem; border-radius: 50px;
  text-decoration: none; transition: all .3s ease;
}
.lp-btn-secondary.on-dark  { color: var(--white); border: 1px solid rgba(255,255,255,.12); }
.lp-btn-secondary.on-dark:hover  { border-color: var(--sky); color: var(--sky); }
.lp-btn-secondary.on-light { color: var(--deep); border: 1px solid var(--mist); }
.lp-btn-secondary.on-light:hover { border-color: var(--sky); color: var(--sky); }

.lp-btn-wa {
  display: inline-flex; align-items: center; gap: .5rem;
  background: #25D366; color: var(--white);
  font-size: .82rem; font-weight: 700;
  padding: .85rem 2rem; border-radius: 50px;
  text-decoration: none; transition: all .3s ease;
}
.lp-btn-wa:hover { background: #1ebe5a; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(37,211,102,.15); }

/* ── HERO SCENARIO CARD ── */
.lp-hero-right { position: relative; }
.lp-scenario {
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.04);
  border-radius: 16px; padding: 2rem;
  backdrop-filter: blur(6px);
}
.lp-scenario-title {
  font-size: .8rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .12em; color: var(--sky); margin-bottom: 1.2rem;
}
.lp-scenario-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: .65rem 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
  font-size: .82rem;
  filter: drop-shadow(1px 1px 2px rgba(0,0,0,.4));
}
.lp-scenario-row .label { color: var(--pearl); }
.lp-scenario-row .val   { font-weight: 700; filter: drop-shadow(3px 1px 12px rgba(255,0,0,.7)); }
.lp-scenario-row .val.danger { color: var(--danger); }
.lp-scenario-row .val.mint   { color: var(--mint); }
.lp-scenario-total {
  margin-top: 1rem; padding: 1rem 0;
  display: flex; justify-content: space-between;
  font-size: .9rem; font-weight: 700; color: var(--pearl);
  filter: drop-shadow(1px 1px 2px rgba(0,0,0,.5));
}
.lp-scenario-total .val { color: var(--mint); font-size: 1.1rem; }
.lp-scenario-note { margin-top: .8rem; font-size: .68rem; color: var(--slate); text-align: center; font-style: italic; }

/* ── URGENCY BAR ── */
.lp-urgency {
  background: linear-gradient(90deg, #1a0a0a 0%, #2a0f0f 50%, #1a0a0a 100%);
  border-top: 1px solid rgba(239,68,68,.15);
  border-bottom: 1px solid rgba(239,68,68,.15);
  padding: 1.8rem 0; text-align: center;
}
.lp-urgency-text {
  font-size: .88rem; color: rgba(255,255,255,.7);
  display: flex; align-items: center; justify-content: center; gap: .6rem; flex-wrap: wrap;
}
.lp-urgency-text i { color: var(--danger); font-size: 1.1rem; }
.lp-urgency-text strong { color: var(--white); }
.lp-urgency-text .lp-tag {
  display: inline-flex; padding: .2rem .7rem;
  background: rgba(239,68,68,.12); color: var(--danger);
  font-size: .7rem; font-weight: 700; border-radius: 50px;
  text-transform: uppercase; letter-spacing: .06em;
}

/* ── SECTIONS ── */
.lp-section { padding: 5.5rem 0; position: relative; }
.lp-section.bg-snow { background: var(--snow); }
.lp-section.bg-dark {
  background: linear-gradient(175deg, var(--deep) 0%, #0d2e48 50%, var(--baltic) 100%);
  color: var(--white);
}
.lp-label {
  font-size: .62rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .16em; color: var(--sky); margin-bottom: .6rem;
}
.lp-h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(1.6rem, 3.5vw, 2.6rem);
  font-weight: 400; line-height: 1.15;
  margin: 0 0 1rem; letter-spacing: -.01em; color: var(--deep);
}
.lp-section.bg-dark .lp-h2 { color: var(--white); }
.lp-h2 em { font-style: normal; color: var(--sky); }
.lp-subtitle { font-size: .92rem; color: var(--graphite); line-height: 1.7; max-width: 520px; }
.lp-section.bg-dark .lp-subtitle { color: rgba(255,255,255,.5); }

/* ── PILLS ── */
.lp-pills { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: 2rem; }
.lp-pill {
  display: inline-flex; align-items: center; gap: .45rem;
  padding: .55rem 1.1rem;
  background: var(--white); border: 1px solid var(--mist); border-radius: 50px;
  font-size: .78rem; font-weight: 600; color: var(--ink);
  transition: all .3s ease;
  box-shadow: 0 1px 3px rgba(3,52,82,.04);
}
.lp-pill:hover { border-color: var(--sky); color: var(--sky); box-shadow: 0 4px 16px rgba(0,170,228,.1); }
.lp-pill i { color: var(--sky); font-size: .9rem; }

/* ── PROCESS STEPS ── */
.lp-steps {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1rem; margin-top: 3rem; counter-reset: stepcount;
}
@media (max-width: 767.98px) { .lp-steps { grid-template-columns: 1fr; } }
.lp-step-card {
  padding: 2rem 1.5rem;
  background: var(--white); border: 1px solid var(--pearl); border-radius: 14px;
  position: relative; counter-increment: stepcount;
  transition: all .3s ease;
}
.lp-step-card:hover { border-color: var(--sky); box-shadow: 0 8px 32px rgba(0,170,228,.08); transform: translateY(-3px); }
.lp-step-card::before {
  content: counter(stepcount, decimal-leading-zero);
  font-family: 'DM Serif Display', serif;
  font-size: 2.5rem; font-weight: 400;
  color: rgba(0,170,228,.12); line-height: 1;
  margin-bottom: .6rem; display: block;
}
.lp-step-card h4 { font-size: .88rem; font-weight: 700; margin: 0 0 .3rem; color: var(--deep); }
.lp-step-card p  { font-size: .78rem; color: var(--graphite); line-height: 1.6; margin: 0; }

/* ── COMPARE COLUMNS ── */
.lp-compare-col { padding: 2.5rem; border-radius: 16px; height: 100%; }
.lp-compare-col.col-bad  { background: #FEF2F2; border: 1px solid rgba(239,68,68,.12); }
.lp-compare-col.col-good { background: #ECFDF5; border: 1px solid rgba(16,185,129,.12); }
.lp-compare-col h3 { font-family: 'DM Serif Display', serif; font-size: 1.3rem; margin: 0 0 1.5rem; }
.lp-compare-col.col-bad  h3 { color: var(--danger); }
.lp-compare-col.col-good h3 { color: var(--mint); }
.lp-compare-line { display: flex; align-items: flex-start; gap: .6rem; padding: .6rem 0; font-size: .82rem; color: var(--ink); }
.lp-compare-line i { margin-top: .15rem; flex-shrink: 0; font-size: .85rem; }
.lp-compare-col.col-bad  .lp-compare-line i { color: var(--danger); }
.lp-compare-col.col-good .lp-compare-line i { color: var(--mint); }

/* ── DIFFERENTIATORS (dark) ── */
.lp-diff-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 14px; padding: 2rem;
  transition: all .35s ease; height: 100%;
}
.lp-diff-card:hover { border-color: rgba(0,170,228,.25); background: rgba(0,170,228,.06); transform: translateY(-4px); }
.lp-diff-card .ic {
  width: 44px; height: 44px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.15rem; margin-bottom: 1rem;
  background: rgba(0,170,228,.12); color: var(--sky);
}
.lp-diff-card h4 { font-size: .9rem; font-weight: 700; margin: 0 0 .35rem; color: var(--white); }
.lp-diff-card p  { font-size: .78rem; color: rgba(255,255,255,.45); line-height: 1.6; margin: 0; }

/* ── FINAL CTA ── */
.lp-final-cta {
  padding: 6rem 0;
  background:
    radial-gradient(ellipse 60% 50% at 50% 50%, rgba(0,170,228,.06) 0%, transparent 70%),
    linear-gradient(175deg, var(--deep) 0%, #060d18 100%);
  text-align: center; color: var(--white);
}
.lp-final-cta h2 { font-family: 'DM Serif Display', serif; font-size: clamp(1.8rem, 4vw, 3rem); margin: 0 0 .8rem; color: var(--white); }
.lp-final-cta h2 em { font-style: normal; color: var(--sky); }
.lp-final-cta p  { font-size: 1rem; color: rgba(255,255,255,.45); max-width: 480px; margin: 0 auto 2.5rem; line-height: 1.7; }
.lp-final-trust { display: flex; align-items: center; justify-content: center; gap: 1.5rem; margin-top: 2.5rem; flex-wrap: wrap; }
.lp-trust-badge { display: flex; align-items: center; gap: .4rem; font-size: .7rem; font-weight: 600; color: rgba(255,255,255,.35); }
.lp-trust-badge i { color: var(--sky); font-size: .85rem; }

/* ── BLOG LINK ── */
.lp-blog-link { padding: 2rem 0; background: var(--snow); text-align: center; border-top: 1px solid var(--pearl); }
.lp-blog-link a { color: var(--sky); text-decoration: none; font-size: .82rem; font-weight: 600; transition: color .2s; }
.lp-blog-link a:hover { color: var(--baltic); }

/* ── MINI FOOTER ── */
.lp-footer { padding: 2rem 0; background: var(--snow); border-top: 1px solid var(--pearl); }
.lp-footer-inner { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; }
.lp-footer-copy { font-size: .7rem; color: var(--slate); }
.lp-footer-links a { font-size: .7rem; color: var(--slate); text-decoration: none; margin-left: 1rem; transition: color .2s; }
.lp-footer-links a:hover { color: var(--sky); }

/* ── ANIMATIONS ── */
@keyframes fadeUp { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }
.fade-in { animation: fadeUp .7s cubic-bezier(.4,0,.2,1) both; }
.d1 { animation-delay: .1s; }
.d2 { animation-delay: .2s; }
.d3 { animation-delay: .3s; }
.d4 { animation-delay: .4s; }

/* ── COUNTRY CARDS ── */
.lp-country-card {
  background: var(--snow); border: 1px solid var(--pearl);
  border-radius: 14px; padding: 1.5rem 1rem; text-align: center;
  transition: all .25s ease;
}
.lp-country-card:hover { border-color: var(--sky); box-shadow: 0 4px 20px rgba(0,170,228,.08); transform: translateY(-3px); }
.lp-country-flag { font-size: 2rem; margin-bottom: .5rem; }
.lp-country-name { font-size: .78rem; font-weight: 700; color: var(--deep); margin-bottom: .35rem; }
.lp-country-tag { display: inline-block; font-size: .6rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; padding: .2rem .5rem; border-radius: 50px; }
.lp-country-tag.eu  { background: rgba(0,170,228,.1); color: var(--sky); }
.lp-country-tag.ext { background: rgba(245,158,11,.1); color: var(--gold); }

/* ── FAQ ── */
.lp-faq { display: flex; flex-direction: column; gap: 0; }
.lp-faq-item { border-bottom: 1px solid var(--pearl); padding: 1.25rem 0; }
.lp-faq-item:first-child { border-top: 1px solid var(--pearl); }
.lp-faq-q { display: flex; align-items: center; gap: .6rem; font-size: .9rem; font-weight: 700; color: var(--deep); margin-bottom: .5rem; }
.lp-faq-q i { color: var(--sky); flex-shrink: 0; }
.lp-faq-a { font-size: .82rem; color: var(--graphite); line-height: 1.7; padding-left: 1.6rem; }

/* ── RESPONSIVE ── */
@media (max-width: 991.98px) {
  .lp-hero { min-height: auto; padding: 7rem 0 3rem; }
  .lp-proof-strip { gap: 1.2rem; }
}
@media (max-width: 575.98px) {
  .lp-proof-strip  { flex-direction: column; gap: .8rem; }
  .lp-cta-group    { flex-direction: column; }
  .lp-cta-group a  { text-align: center; justify-content: center; }
  .lp-pills        { gap: .4rem; }
  .lp-pill         { font-size: .72rem; padding: .45rem .85rem; }
}

/* ── CONSOLIDATED: replaces common inline styles ── */
.lp-accordion-item {
  border: 0 !important;
  border-radius: 12px !important;
  overflow: hidden;
  box-shadow: 0 1px 4px rgba(3,52,82,.06);
  margin-bottom: .5rem;
}
.lp-accordion-body {
  font-size: .88rem;
  color: var(--graphite);
  line-height: 1.75;
}
