/* ============================================================
   Conversor de Coordenadas GPS · folha de estilo
   Tema: carta náutica (céu, oceano, nuvens, malha de meridianos)
   Cores por variáveis, com modo claro e modo escuro.
   Tudo prefixado sob .geo para não colidir com outros estilos.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700&family=Spectral:ital,wght@0,400;0,500;0,600;1,400&family=JetBrains+Mono:wght@400;500;600&display=swap');

.geo, .geo * { box-sizing: border-box; }
.geo { margin: 0; }

/* ----------------- MODO CLARO (predefinido) ----------------- */
.geo {
  --mar-raso:   #2f93b8;
  --mar:        #1f7fb0;
  --mar-fundo:  #0a3a55;
  --espuma:     #eef7fb;

  --papel:      #fbf6ea;   /* superfície principal / topo do conteúdo */
  --papel-fundo:#e7dcc2;   /* fundo do gradiente da página */
  --papel-alto: #fffdf8;   /* topo dos gradientes de painel e dos campos */
  --areia:      #e8dcc0;
  --areia-linha:#cdbc94;   /* linhas um pouco mais escuras, mais visíveis */

  --campo-bg:     #fffdf8;
  --campo-bg-foco:#ffffff;
  --leitura-a:  #eef6fb;
  --leitura-b:  #e4eff6;
  --leitura-linha:#c2d7e3;
  --branco:     #ffffff;

  /* texto, escurecido para boa leitura à luz do dia */
  --tinta:      #0a2733;
  --tinta-suave:#36505c;
  --tinta-fraca:#5a7682;

  --coral:      #cf6a30;
  --coral-escuro:#a44c1c;
  --verde:      #2c7a64;
  --erro:       #c0392b;

  --botao-bg:      #0c2f42;
  --botao-bg-hover:#1f7fb0;
  --botao-tinta:   #fdfaf2;

  /* hero sobre céu claro: texto escuro */
  --hero-titulo:  #08283c;
  --hero-sub:     #0a3548;
  --hero-tinta:   #06303f;
  --hero-pilula:  rgba(255,255,255,0.6);
  --hero-coral:   #a44c1c;

  /* gradiente do hero (céu que mergulha no oceano) */
  --hero-g1: #cfe9f4;
  --hero-g2: #9ed1e8;
  --hero-g3: #2f93b8;
  --hero-g4: #156a96;
  --hero-g5: #0a3a55;

  --grelha-linha: rgba(21,106,150,0.05);

  font-family: 'Spectral', Georgia, serif;
  color: var(--tinta);
  line-height: 1.6;
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
}

/* ----------------- MODO ESCURO ----------------- */
html.tema-escuro .geo {
  --mar-raso:   #4aa6d6;
  --mar:        #3f9bcf;
  --mar-fundo:  #06212e;
  --espuma:     #e7f1f6;

  --papel:      #142733;
  --papel-fundo:#0a161d;
  --papel-alto: #19323e;
  --areia:      #1b333d;
  --areia-linha:#314c57;

  --campo-bg:     #0f222b;
  --campo-bg-foco:#16303a;
  --leitura-a:  #102a33;
  --leitura-b:  #0d242c;
  --leitura-linha:#284850;
  --branco:     #1a3540;

  --tinta:      #e9f2f6;
  --tinta-suave:#b0c6d0;
  --tinta-fraca:#86a0ab;

  --coral:      #e8824a;
  --coral-escuro:#cf6a30;
  --verde:      #3a9b80;
  --erro:       #f08a72;

  --botao-bg:      #1f6f96;
  --botao-bg-hover:#2a86b0;
  --botao-tinta:   #f4fbff;

  --hero-titulo:  #eaf4f8;
  --hero-sub:     #bdd7e1;
  --hero-tinta:   #cfe6ee;
  --hero-pilula:  rgba(255,255,255,0.12);
  --hero-coral:   #f0915a;

  --hero-g1: #0e2a3a;
  --hero-g2: #0c3248;
  --hero-g3: #0a3a55;
  --hero-g4: #072c41;
  --hero-g5: #04141d;

  --grelha-linha: rgba(120,180,210,0.06);
}

.geo a { color: var(--mar); text-decoration: none; }
.geo a:hover { text-decoration: underline; }

.geo .pagina {
  min-height: 100vh;
  background: linear-gradient(180deg, var(--papel) 0%, var(--papel-fundo) 100%);
  position: relative;
  transition: background .3s;
}

/* malha de coordenadas muito ténue no fundo de toda a página */
.geo .pagina::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(var(--grelha-linha) 1px, transparent 1px),
    linear-gradient(90deg, var(--grelha-linha) 1px, transparent 1px);
  background-size: 46px 46px;
  z-index: 0;
}

.geo .interior {
  position: relative;
  z-index: 1;
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 18px 64px;
}

/* ============================================================
   CABEÇALHO / HERO
   ============================================================ */
.geo .mar-hero {
  position: relative;
  margin: 0 -18px 40px;
  padding: 0 18px;
  overflow: hidden;
  background: linear-gradient(180deg,
      var(--hero-g1) 0%, var(--hero-g2) 34%, var(--hero-g3) 62%,
      var(--hero-g4) 84%, var(--hero-g5) 100%);
  transition: background .3s;
}

.geo .nuvem {
  position: absolute;
  background: #ffffff;
  border-radius: 50%;
  opacity: 0.85;
  filter: blur(0.3px);
  box-shadow: 36px 8px 0 -4px #ffffff, 74px 14px 0 -8px #ffffff, -34px 10px 0 -6px #ffffff;
}
.geo .nuvem.n1 { width: 60px; height: 60px; top: 26px; left: 8%;  opacity: 0.9; }
.geo .nuvem.n2 { width: 44px; height: 44px; top: 58px; left: 64%; opacity: 0.7; transform: scale(1.2); }
.geo .nuvem.n3 { width: 38px; height: 38px; top: 18px; left: 42%; opacity: 0.55; }
html.tema-escuro .geo .nuvem { opacity: 0.28 !important; }

.geo .malha-mar { position: absolute; inset: 0; pointer-events: none; opacity: 0.4; }

.geo .hero-conteudo {
  position: relative;
  z-index: 2;
  max-width: 1000px;
  margin: 0 auto;
  padding: 30px 0 40px;
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}

.geo .hero-logo { width: 76px; height: 76px; flex-shrink: 0; filter: drop-shadow(0 6px 14px rgba(8,40,60,0.35)); }
.geo .hero-texto { min-width: 0; }

.geo .hero-eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--hero-titulo);
  background: var(--hero-pilula);
  display: inline-block; padding: 4px 10px; border-radius: 20px; margin-bottom: 12px;
}

.geo h1 {
  font-family: 'Fraunces', serif;
  font-weight: 600;
  font-size: clamp(26px, 6vw, 44px);
  line-height: 1.04; letter-spacing: -0.02em;
  color: var(--hero-titulo);
  margin: 0;
}
.geo h1 em { font-style: italic; font-weight: 500; color: var(--hero-coral); }

.geo .hero-sub {
  margin-top: 10px; color: var(--hero-sub);
  font-size: clamp(14px, 3.4vw, 17px); max-width: 52ch;
}

.geo .hero-coord {
  margin-left: auto;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; color: var(--hero-tinta);
  background: var(--hero-pilula);
  border-radius: 10px; padding: 10px 14px; line-height: 1.7;
  text-align: right; align-self: flex-start;
}
.geo .hero-coord .ponto {
  display: inline-block; width: 7px; height: 7px; border-radius: 50%;
  background: var(--coral); margin-right: 6px; vertical-align: middle;
}

.geo .onda { display: block; width: 100%; height: 28px; position: relative; z-index: 2; margin-bottom: -1px; }
.geo .onda-fill { fill: var(--papel); transition: fill .3s; }

/* botão "Acessar offline" (na versão online) e faixa de ligação (na versão offline) */
.geo .btn-offline {
  display: inline-flex; align-items: center; gap: 8px;
  margin-top: 16px; padding: 10px 18px; border-radius: 24px;
  background: var(--coral); color: #fff; border: none;
  font-family: 'Fraunces', serif; font-weight: 600; font-size: 14px;
  text-decoration: none; cursor: pointer;
  transition: background .15s, transform .08s;
}
.geo .btn-offline:hover { background: var(--coral-escuro); text-decoration: none; }
.geo .btn-offline:active { transform: translateY(1px); }
.geo .btn-offline svg { width: 17px; height: 17px; }

.geo .online-strip {
  background: var(--mar-fundo); color: var(--espuma);
  text-align: center; font-size: 13.5px; line-height: 1.5;
  padding: 10px 16px;
}
.geo .online-strip a { color: #9ed7ef; text-decoration: underline; font-weight: 600; }
.geo .selo-offline {
  display: inline-block; margin-left: 8px;
  font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--verde);
  border: 1px solid var(--verde); border-radius: 20px; padding: 2px 8px;
  vertical-align: middle;
}

/* ============================================================
   PAINÉIS DE CONVERSÃO
   ============================================================ */
.geo .grelha { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }

.geo .painel {
  background: linear-gradient(180deg, var(--papel) 0%, var(--papel-alto) 100%);
  border: 1px solid var(--areia-linha);
  border-radius: 16px;
  padding: 26px 24px 28px;
  position: relative;
  box-shadow: 0 1px 0 rgba(255,255,255,0.4) inset, 0 14px 30px -22px rgba(10,58,85,0.55);
  transition: background .3s, border-color .3s;
}
.geo .painel::before {
  content: ''; position: absolute; top: 0; left: 26px;
  width: 58px; height: 4px; border-radius: 0 0 4px 4px;
  background: linear-gradient(90deg, var(--mar-raso), var(--mar));
}
.geo .painel.modo-b::before { background: linear-gradient(90deg, var(--coral), var(--coral-escuro)); }

.geo .painel-topo { margin-bottom: 20px; }
.geo .painel-modo {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--tinta-fraca); margin-bottom: 6px;
}
.geo .painel-titulo {
  font-family: 'Fraunces', serif; font-weight: 600; font-size: 19px;
  line-height: 1.2; letter-spacing: -0.01em; color: var(--tinta);
}
.geo .painel-titulo .seta { color: var(--coral); margin: 0 5px; }

.geo .campo { margin-bottom: 15px; }
.geo .rotulo {
  display: block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--tinta-suave); margin-bottom: 7px;
}

.geo input[type="text"],
.geo input[type="number"],
.geo input[type="password"],
.geo input[type="email"],
.geo select {
  width: 100%;
  padding: 11px 12px;
  border: 1px solid var(--areia-linha);
  border-radius: 9px;
  background: var(--campo-bg);
  color: var(--tinta);
  font-family: 'JetBrains Mono', monospace;
  font-size: 15px;
  transition: border-color .15s, box-shadow .15s, background .15s;
}
.geo input:focus, .geo select:focus {
  outline: none;
  border-color: var(--mar-raso);
  box-shadow: 0 0 0 3px rgba(47,147,184,0.2);
  background: var(--campo-bg-foco);
}
.geo input::placeholder { color: var(--tinta-fraca); opacity: 0.85; }

.geo input.invalido,
.geo input.invalido:focus {
  border-color: var(--erro);
  box-shadow: 0 0 0 3px rgba(192,57,43,0.16);
}
.geo .aviso-campo {
  display: none;
  margin-top: 6px;
  font-family: 'Spectral', serif;
  font-size: 12.5px;
  line-height: 1.4;
  color: var(--erro);
}
.geo .aviso-campo.visivel { display: block; }
.geo .aviso-campo.visivel::before { content: '\26A0\00A0'; }

.geo .gms { display: grid; grid-template-columns: 1fr 1fr 1.25fr 0.95fr; gap: 7px; }
.geo .gms .unidade { position: relative; }
.geo .gms .unidade::after {
  content: attr(data-u);
  position: absolute; right: 9px; top: 50%; transform: translateY(-50%);
  font-family: 'JetBrains Mono', monospace; font-size: 13px;
  color: var(--tinta-fraca); pointer-events: none;
}
.geo .gms .unidade input { padding-right: 22px; }

.geo .botao {
  width: 100%; margin-top: 8px;
  padding: 13px 16px; border: none; border-radius: 10px;
  background: var(--botao-bg); color: var(--botao-tinta);
  font-family: 'Fraunces', serif; font-size: 15px; font-weight: 600; letter-spacing: 0.01em;
  cursor: pointer; transition: background .15s, transform .08s;
}
.geo .botao:hover { background: var(--botao-bg-hover); }
.geo .painel.modo-b .botao:hover { background: var(--coral-escuro); }
.geo .botao:active { transform: translateY(1px); }

/* leitura do resultado */
.geo .leitura {
  margin-top: 20px; padding: 18px;
  background: repeating-linear-gradient(180deg, var(--leitura-a) 0 26px, var(--leitura-b) 26px 27px);
  border: 1px solid var(--leitura-linha);
  border-radius: 12px; min-height: 92px;
  transition: background .3s, border-color .3s;
}
.geo .leitura-topo { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.geo .leitura-rotulo {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--mar);
}
.geo .copiar {
  border: 1px solid var(--mar-raso); background: var(--branco); color: var(--mar);
  font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.04em;
  padding: 6px 11px; border-radius: 7px; cursor: pointer;
  display: none; align-items: center; gap: 6px; transition: background .15s, color .15s;
}
.geo .copiar.visivel { display: inline-flex; }
.geo .copiar:hover { background: var(--mar); color: #fff; }
.geo .copiar.feito { background: var(--verde); border-color: var(--verde); color: #fff; }
.geo .copiar svg { width: 13px; height: 13px; }

.geo .valor {
  font-family: 'JetBrains Mono', monospace;
  font-size: 16px; font-weight: 500; color: var(--tinta);
  line-height: 1.9; word-break: break-word;
}
.geo .valor .et { display: inline-block; width: 34px; color: var(--tinta-fraca); font-size: 12px; }
.geo .valor .vazio { font-family: 'Spectral', serif; font-style: italic; font-size: 14px; color: var(--tinta-fraca); }
.geo .valor .erro { font-family: 'Spectral', serif; font-size: 14px; color: var(--coral-escuro); }

/* botão para abrir no Google Maps */
.geo .abrir-mapa {
  display: inline-flex; align-items: center; gap: 8px;
  margin-top: 14px; padding: 11px 16px;
  background: var(--coral); color: #fff;
  border-radius: 10px;
  font-family: 'Fraunces', serif; font-weight: 600; font-size: 14px;
  text-decoration: none; transition: background .15s, transform .08s;
}
.geo .abrir-mapa:hover { background: var(--coral-escuro); text-decoration: none; }
.geo .abrir-mapa:active { transform: translateY(1px); }
.geo .abrir-mapa svg { width: 16px; height: 16px; }
.geo .abrir-mapa[hidden] { display: none; }

/* ============================================================
   NOTA DE CONVENÇÃO
   ============================================================ */
.geo .notas { margin-top: 34px; }
.geo .nota {
  background: var(--areia);
  border: 1px solid var(--areia-linha);
  border-radius: 11px;
  padding: 14px 16px;
  font-size: 13.5px; color: var(--tinta-suave);
  transition: background .3s, border-color .3s;
}
.geo .nota b { color: var(--tinta); font-family: 'Fraunces', serif; }

.geo .rodape {
  margin-top: 34px; padding-top: 22px;
  border-top: 1px solid var(--areia-linha);
  display: flex; justify-content: space-between; align-items: center;
  gap: 14px; flex-wrap: wrap; font-size: 13px; color: var(--tinta-fraca);
}
.geo .rodape a { color: var(--tinta-suave); }
.geo .rodape .assinatura { font-family: 'Fraunces', serif; }
.geo .rodape .assinatura a { color: var(--tinta-suave); }

/* ============================================================
   SELECTOR DE TEMA (claro / escuro)
   ============================================================ */
.geo .tema-barra {
  margin-top: 22px; padding-top: 18px;
  border-top: 1px solid var(--areia-linha);
  display: flex; align-items: center; justify-content: center; gap: 14px; flex-wrap: wrap;
}
.geo .tema-rotulo {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--tinta-fraca);
}
.geo .tema-toggle {
  display: inline-flex;
  background: var(--areia);
  border: 1px solid var(--areia-linha);
  border-radius: 24px; padding: 3px;
}
.geo .tema-op {
  border: none; background: transparent; cursor: pointer;
  font-family: 'Spectral', serif; font-size: 13.5px; color: var(--tinta-suave);
  padding: 7px 16px; border-radius: 20px;
  display: inline-flex; align-items: center; gap: 6px;
  transition: background .15s, color .15s;
}
.geo .tema-op:hover { color: var(--tinta); }
.geo .tema-op.activo { background: var(--botao-bg); color: var(--botao-tinta); }

/* ============================================================
   BANNER DE COOKIES
   ============================================================ */
.geo .cookies {
  position: fixed; left: 14px; right: 14px; bottom: 14px; z-index: 50;
  background: var(--mar-fundo); color: var(--espuma);
  border-radius: 14px; padding: 16px 18px;
  box-shadow: 0 18px 40px -16px rgba(6,40,60,0.7);
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  max-width: 720px; margin: 0 auto;
}
.geo .cookies p { margin: 0; font-size: 13.5px; line-height: 1.55; flex: 1 1 240px; }
.geo .cookies a { color: #9ed7ef; text-decoration: underline; }
.geo .cookies .ck-acoes { display: flex; gap: 9px; flex-shrink: 0; }
.geo .cookies button {
  border: none; border-radius: 9px; padding: 10px 16px;
  font-family: 'Fraunces', serif; font-weight: 600; font-size: 13.5px; cursor: pointer;
}
.geo .ck-aceitar { background: var(--coral); color: #fff; }
.geo .ck-aceitar:hover { background: var(--coral-escuro); }
.geo .ck-recusar { background: transparent; color: var(--espuma); border: 1px solid rgba(255,255,255,0.35); }
.geo .ck-recusar:hover { background: rgba(255,255,255,0.1); }

/* ============================================================
   PÁGINA DE TEXTO (política de privacidade)
   ============================================================ */
.geo .documento {
  background: var(--papel);
  border: 1px solid var(--areia-linha);
  border-radius: 16px;
  padding: clamp(22px, 5vw, 44px);
  box-shadow: 0 14px 30px -24px rgba(10,58,85,0.5);
}
.geo .documento h2 {
  font-family: 'Fraunces', serif; font-weight: 600;
  font-size: clamp(20px, 4vw, 26px); color: var(--tinta);
  margin: 26px 0 10px; letter-spacing: -0.01em;
}
.geo .documento h2:first-child { margin-top: 0; }
.geo .documento p { margin: 0 0 14px; color: var(--tinta-suave); }
.geo .documento ul { margin: 0 0 16px; padding-left: 20px; }
.geo .documento li { margin-bottom: 7px; color: var(--tinta-suave); }
.geo .documento .voltar {
  display: inline-flex; align-items: center; gap: 7px; margin-bottom: 4px;
  font-family: 'JetBrains Mono', monospace; font-size: 12px; letter-spacing: 0.04em;
}
.geo .documento .data {
  font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--tinta-fraca); margin-bottom: 24px;
}

/* ============================================================
   RESPONSIVO  ·  a partir de telas de ~4 polegadas (320px)
   ============================================================ */
@media (max-width: 820px) {
  .geo .grelha { grid-template-columns: 1fr; }
  .geo .hero-coord { margin-left: 0; }
}

@media (max-width: 520px) {
  .geo .interior { padding: 0 14px 80px; }
  .geo .mar-hero { margin: 0 -14px 30px; padding: 0 14px; }
  .geo .hero-conteudo { padding: 22px 0 30px; gap: 14px; }
  .geo .hero-logo { width: 60px; height: 60px; }
  .geo .painel { padding: 22px 17px 24px; }
  .geo .painel::before { left: 17px; }
  .geo .gms { grid-template-columns: 1fr 1fr 1.2fr 0.85fr; gap: 5px; }
  .geo input[type="text"], .geo input[type="number"], .geo input[type="password"], .geo input[type="email"], .geo select { font-size: 14px; padding: 10px 9px; }
  .geo .gms .unidade input { padding-right: 18px; }
  .geo .gms .unidade::after { right: 6px; font-size: 12px; }
  .geo .cookies { flex-direction: column; align-items: stretch; left: 10px; right: 10px; bottom: 10px; }
  .geo .cookies .ck-acoes { justify-content: stretch; }
  .geo .cookies button { flex: 1; }
}

@media (max-width: 360px) {
  .geo { font-size: 15px; }
  .geo .gms { grid-template-columns: 1fr 1fr; }
  .geo .gms .dir-wrap { grid-column: 1 / -1; }
  .geo .valor { font-size: 14px; }
  .geo .hero-coord { width: 100%; text-align: left; }
  .geo .abrir-mapa { width: 100%; justify-content: center; }
}

@media (prefers-reduced-motion: reduce) {
  .geo * { animation: none !important; transition: none !important; }
}
