:root{
  --primary:#2b8cee;
  --bg:#f6f7f8;
  --card:#ffffff;
  --text:#111418;
  --muted:#617589;
  --border:#e8edf2;
  --shadow: 0 10px 30px rgba(17,20,24,.08);
}

.theme-dark{
  --bg:#101922;
  --card:#1a2632;
  --text:#ffffff;
  --muted:#a6b3c2;
  --border:#2a3642;
  --shadow: 0 14px 40px rgba(0,0,0,.25);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:var(--bg);
  color:var(--text);
  transition: background .2s ease, color .2s ease;
}

.container{
  width:min(1100px, 92%);
  margin:0 auto;
}

.hide-mobile{ display:none; }
@media (min-width:640px){ .hide-mobile{ display:inline; } }

/* NAV */
.nav{
  position:sticky; top:0; z-index:50;
  background:var(--card);
  border-bottom:1px solid var(--border);
}
.nav__inner{
  height: 64px;          /* volta ao normal */
  padding: 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
}

.logo{
  display:flex;
  align-items:center;
  gap:12px;
}

.logo__image{
  height: 42px;          /* header logo */
  width:auto;
  display:block;
  object-fit:contain;
}
.hero__logo{
  height: 168px;
  width:auto;
  object-fit:contain;
  display:block;
  margin: 0 auto 10px;
}


/* opcional: ajustar em mobile */
@media (max-width: 480px) {
  .logo__image {
    height: 34px;
  }
}

.logo__icon{
  width:40px; height:40px;
  border-radius:12px;
  background: color-mix(in srgb, var(--primary) 12%, transparent);
  display:grid; place-items:center;
  color:var(--primary);
}
.logo__text{ font-weight:800; letter-spacing:-.02em; }

.nav__actions{ display:flex; align-items:center; gap:12px; }
.lang{
  display:flex; align-items:center; gap:10px;
  font-weight:600;
  color:var(--muted);
}
.lang__btn{
  border:0; background:transparent;
  font:inherit; color:inherit;
  cursor:pointer;
  padding:8px 6px;
}
.lang__btn:hover{ color:var(--primary); }
.lang__btn.is-active{ color:var(--primary); font-weight:900; }
.lang__sep{ opacity:.35; }

.theme{
  width:42px; height:42px;
  border-radius:12px;
  border:1px solid var(--border);
  background:transparent;
  color:var(--text);
  cursor:pointer;
}

/* HERO */
.hero{
  background:var(--card);
  border-bottom:1px solid var(--border);
  padding:80px 0;
  text-align:center;
}
.hero__inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:18px;
}
.badge{
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 12px;
  border-radius:999px;
  background: color-mix(in srgb, var(--primary) 12%, transparent);
  color:var(--primary);
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:12px;
}
.badge__dot{
  width:8px; height:8px; border-radius:999px;
  background:var(--primary);
  animation:pulse 1.2s infinite;
}
@keyframes pulse{
  0%{ transform:scale(1); opacity:.6; }
  50%{ transform:scale(1.35); opacity:1; }
  100%{ transform:scale(1); opacity:.6; }
}
.hero__title{
  margin:0;
  font-size: clamp(34px, 5vw, 62px);
  font-weight:900;
  letter-spacing:-.03em;
}
.hero__subtitle{
  margin:0;
  color:var(--muted);
  font-size: clamp(16px, 2vw, 20px);
  line-height:1.6;
  max-width: 780px;
}
.scroll{
  margin-top:22px;
  color: color-mix(in srgb, var(--primary) 55%, transparent);
  animation:bounce 1.2s infinite;
}
@keyframes bounce{
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(8px); }
}

/* GRID */
.grid{ padding:56px 0 72px; }
.cards{
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
}
@media (min-width:800px){
  .cards{ grid-template-columns:repeat(3, 1fr); gap:22px; }
}

/* CARD */
.card{
  text-decoration:none;
  color:inherit;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:18px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  min-height: 420px;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.card:hover{
  transform: translateY(-6px);
  box-shadow: var(--shadow);
  border-color: color-mix(in srgb, var(--primary) 35%, var(--border));
}
.card__media{
  position:relative;
  aspect-ratio: 4 / 3;
  background-size:cover;
  background-position:center;
  overflow:hidden;
}
.card__overlay{
  position:absolute; inset:0;
  background: linear-gradient(to bottom, rgba(0,0,0,0) 70%, rgba(0,0,0,.10) 100%);
  transition: background .25s ease;
}

.card:hover .card__overlay{ background:rgba(0,0,0,.10); }

.card__body{
  padding:18px 18px 16px;
  display:flex;
  flex-direction:column;
  gap:12px;
  flex:1;
}
.card__top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.card__title{
  margin:0;
  font-size:18px;
  font-weight:800;
  letter-spacing:-.02em;
}
.card:hover .card__title{ color:var(--primary); }
.card__sub{
  margin:6px 0 0;
  color:var(--muted);
  font-size:13px;
}
.card__arrow{
  color: color-mix(in srgb, var(--muted) 55%, transparent);
  transition: color .2s ease;
}
.card:hover .card__arrow{ color:var(--primary); }

.card__tags{
  margin-top:auto;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding-top:10px;
}
.tag{
  font-size:12px;
  font-weight:600;
  color: color-mix(in srgb, var(--text) 55%, transparent);
  background: color-mix(in srgb, var(--text) 8%, transparent);
  padding:7px 10px;
  border-radius:10px;
}

/* LIVE PREVIEW (iframe) */
.card__media{
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden; /* 🔒 ESSENCIAL */
}

.card__media--live{
  background: var(--bg);
}
.card__iframe{
  position:absolute;
  inset:0;

  width: 520%;
  height: 520%;
  transform: scale(0.1923);
  transform-origin: top left;

  border:0;
  background: var(--bg);

  /* 🔒 remove scroll totalmente */
  overflow: hidden;
  pointer-events: none;
}



/* CTA CARD */
.card--cta{
  background: color-mix(in srgb, var(--primary) 7%, var(--card));
  border-color: color-mix(in srgb, var(--primary) 25%, var(--border));
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:26px;
  gap:12px;
}
.ctaIcon{
  width:64px; height:64px;
  border-radius:999px;
  display:grid; place-items:center;
  background: color-mix(in srgb, var(--primary) 12%, transparent);
  color:var(--primary);
  font-size:28px;
}
.ctaTitle{ margin:6px 0 0; font-weight:900; letter-spacing:-.02em; }
.ctaText{ margin:0; color:var(--muted); max-width: 320px; line-height:1.6; }
.ctaBtn{
  margin-top:10px;
  border:0;
  background:var(--primary);
  color:#fff;
  font-weight:800;
  padding:12px 18px;
  border-radius:14px;
  cursor:pointer;
  transition: transform .2s ease, filter .2s ease;
}
.ctaBtn:hover{ transform: translateY(-2px); filter:brightness(.95); }

/* FOOTER */
.footer{
  background:var(--card);
  border-top:1px solid var(--border);
  padding:40px 0;
}
.footer__inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:18px;
  text-align:center;
}
.footer__links{
  display:flex; flex-wrap:wrap;
  gap:18px;
  color:var(--muted);
  font-weight:600;
}
.footer__links a{ color:inherit; text-decoration:none; }
.footer__links a:hover{ color:var(--primary); }

.footer__social{ display:flex; gap:12px; }
.footer__social a{
  width:40px; height:40px;
  border-radius:999px;
  border:1px solid var(--border);
  display:grid; place-items:center;
  color: color-mix(in srgb, var(--muted) 70%, transparent);
  text-decoration:none;
}
.footer__social a:hover{ color:var(--primary); border-color: color-mix(in srgb, var(--primary) 35%, var(--border)); }
.footer__copy{ margin:0; color: color-mix(in srgb, var(--muted) 70%, transparent); font-size:13px; }

/* MODAL */
.modal {
  position: fixed;
  inset: 0;
  display: none;
  z-index: 100;
}

.modal.is-open {
  display: block;
}

.modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(4px);
}

.modal__content {
  position: relative;
  max-width: 480px;
  margin: 8vh auto;
  background: var(--card);
  border-radius: 18px;
  padding: 26px;
  box-shadow: var(--shadow);
  animation: modalIn .25s ease;
}

@keyframes modalIn {
  from { transform: translateY(12px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}

.modal__close {
  position: absolute;
  top: 14px;
  right: 14px;
  border: 0;
  background: transparent;
  cursor: pointer;
  color: var(--muted);
}

.modal__title {
  margin: 0;
  font-size: 22px;
  font-weight: 900;
}

.modal__subtitle {
  margin: 6px 0 18px;
  color: var(--muted);
  font-size: 14px;
}

.modal__form {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.modal__form label {
  font-size: 13px;
  font-weight: 600;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.modal__form input,
.modal__form textarea {
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--bg);
  font-family: inherit;
  font-size: 14px;
  color: var(--text);
}

.modal__form textarea {
  resize: vertical;
}

.modal__submit {
  margin-top: 8px;
  background: var(--primary);
  color: #fff;
  border: 0;
  border-radius: 14px;
  padding: 14px;
  font-weight: 800;
  cursor: pointer;
}

.modal__submit:hover {
  filter: brightness(.95);
}

/* RESULT MODAL (success / error) */
.resultModal{
  position:fixed;
  inset:0;
  display:none;
  z-index:120; /* acima do modal de colaborar */
}

.resultModal.is-open{ display:block; }

.resultModal__overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.45);
  backdrop-filter: blur(4px);
}

.resultModal__content{
  position:relative;
  max-width: 420px;
  margin: 14vh auto;
  background: var(--card);
  border:1px solid var(--border);
  border-radius: 18px;
  padding: 22px;
  box-shadow: var(--shadow);
  text-align:center;
  animation: modalIn .25s ease;
}

.resultModal__icon{
  width:64px;
  height:64px;
  border-radius:999px;
  display:grid;
  place-items:center;
  margin:0 auto 10px;
  font-size:30px;
}

.resultModal__title{
  margin:0;
  font-size:20px;
  font-weight:900;
}

.resultModal__text{
  margin:8px 0 16px;
  color: var(--muted);
  line-height:1.55;
}

.resultModal__btn{
  border:0;
  background: var(--primary);
  color:#fff;
  font-weight:800;
  padding: 12px 18px;
  border-radius: 14px;
  cursor:pointer;
}

.resultModal__btn:hover{ filter:brightness(.95); }

/* variants */
.resultModal.success .resultModal__icon{
  background: color-mix(in srgb, #22c55e 14%, transparent);
  color:#16a34a;
}

.resultModal.error .resultModal__icon{
  background: color-mix(in srgb, #ef4444 14%, transparent);
  color:#dc2626;
}

