@import url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,500;1,500&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Arimo:ital,wght@0,400..700;1,400..700&family=Montserrat:ital,wght@0,900;1,900&display=swap");
@import url("https://use.typekit.net/gax3rfa.css");

/* ===== Reset ===== */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  height: 100%;
}

:root {
  --clr: #000000;
  --footer-h: 80px;
}

/* ===== Loader ===== */
#loading {
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  background: #000000;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
  opacity: 1;
  transition: opacity 0.5s ease;
}

#loading .loading-container {
  position: relative;
  width: 200px;
  height: 200px;
  display: flex;
  justify-content: center;
  align-items: center;
}

#loading .loading-ring {
  width: 200px;
  height: 200px;
  border: 0 solid #000;
  border-radius: 50%;
  position: absolute;
}

#loading .ring1 {
  border-bottom-width: 8px;
  border-color: rgb(158, 0, 158);
  animation: rotate1 2s linear infinite;
}

#loading .ring2 {
  border-bottom-width: 8px;
  border-color: rgb(0, 255, 255);
  animation: rotate2 2s linear infinite;
}

#loading .ring3 {
  border-bottom-width: 8px;
  border-color: rgb(255, 255, 255);
  animation: rotate3 2s linear infinite;
}

#loading .loading {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  font-family: "pragmatica", "Arimo", sans-serif;
}

@keyframes rotate1 {
  0% { transform: rotateX(35deg) rotateY(-45deg) rotateZ(0deg); }
  100% { transform: rotateX(35deg) rotateY(-45deg) rotateZ(360deg); }
}

@keyframes rotate2 {
  0% { transform: rotateX(50deg) rotateY(10deg) rotateZ(0deg); }
  100% { transform: rotateX(50deg) rotateY(10deg) rotateZ(360deg); }
}

@keyframes rotate3 {
  0% { transform: rotateX(35deg) rotateY(55deg) rotateZ(0deg); }
  100% { transform: rotateX(35deg) rotateY(55deg) rotateZ(360deg); }
}

/* ===== Base ===== */
body {
  margin: 0;
  font-family: "Arimo", Arial, Helvetica, sans-serif;
  color: #000000;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  padding-bottom: var(--footer-h);
}

/* ================= Navbar ================= */
nav {
  font-family: "pragmatica", sans-serif;
  width: 100%;
  padding: 1rem 5%;
  background: #000000;
  border-bottom: 1px solid #000000;
  backdrop-filter: blur(15px);
  margin-bottom: 0;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* Navbar e dropdowns acima do slider */
header,
nav {
  position: relative;
  z-index: 3000;
}

.logo {
  font-size: 1.8rem;
  font-weight: 700;
  color: #ffffff;
  letter-spacing: 1px;
}

.nav-links {
  list-style: none;
  display: flex;
  gap: -5px;
  margin-left: auto;
  align-items: center;
  background: #000000;
}

.nav-links li {
  display: inline-block;
  position: relative;
}

.nav-links li a {
  position: relative;
  font-size: 1.05rem;
  font-weight: 500;
  color: #ffffff;
  transition: 0.3s;
  display: block;
  padding: 20px 50px;
  text-decoration: none;
  text-align: center;
}

.nav-links li ul.dropdown li {
  display: block;
  align-items: center;
}

.nav-links li ul.dropdown li a {
  align-items: center;
  text-align: center;
}

.nav-links li ul.dropdown {
  width: 100%;
  background: #000000;
  position: absolute;
  display: none;
}

/* Dropdown acima do slider */
nav .nav-links li > ul.dropdown {
  position: absolute;
  z-index: 4000;
}

.nav-links li a:hover {
  background: #ffffff3d;
  color: #800091;
  text-shadow: 0 0 10px #800091;
  border-radius: 6px;
}

.nav-links li:hover > ul.dropdown {
  display: block;
}

/* ======== Correção de layout header ======== */
nav.main-nav > .logo-link {
  order: 1;
}

nav.main-nav > .nav {
  order: 2;
}

/* === FULL FIXES APPEND === */
header nav,
nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: 8px;
}

nav .logo {
  flex: 0 0 auto;
}

nav .nav-links {
  display: flex;
  gap: 12px;
  margin-left: auto;
  justify-content: flex-end;
  align-items: center;
  padding: 0;
  background: transparent !important;
}

nav .nav-links li {
  display: inline-flex;
}

nav .nav-links li a {
  padding: 8px 14px !important;
  font-size: 0.95rem;
  line-height: 1.2;
  text-align: left;
}

nav .nav-links li ul.dropdown {
  right: 0;
  left: auto;
}

.nav-links {
  gap: 12px !important;
}

.nav-links li a {
  padding: 8px 14px !important;
}

/* Dropdown centrado por baixo do item */
nav .nav-links li {
  position: relative;
}

nav .nav-links li > ul.dropdown {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  display: none;
  min-width: 220px;
  max-width: 80vw;
  padding: 8px 0;
  background: #000000;
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
  text-align: center;
  z-index: 1000;
}

nav .nav-links li:hover > ul.dropdown {
  display: block;
}

nav .nav-links li ul.dropdown li {
  display: block;
}

nav .nav-links li ul.dropdown a {
  display: block;
  padding: 10px 16px;
  white-space: nowrap;
  line-height: 1.2;
  text-align: center;
}

/* neutralizar heranças antigas */
.nav-links li ul.dropdown {
  left: 50% !important;
  right: auto !important;
  width: auto !important;
}

.nav-links li ul.dropdown li a {
  text-align: center !important;
}

/* ===== Contact Section ===== */
.contact {
  position: relative;
  min-height: calc(100vh - var(--footer-h) - 2rem);
  padding: 50px 100px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: stretch;
  gap: 24px;
}

/* Frosted glass panel atrás do conteúdo */
.contact::before {
  content: "";
  position: absolute;
  top: clamp(40px, 8vh, 100px);
  bottom: clamp(40px, 8vh, 100px);
  left: clamp(40px, 4vw, 111px);
  right: clamp(40px, 4vw, 111px);
  background: rgba(255, 255, 255, 0.6);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  border-radius: 16px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.2);
  z-index: 0;
}

/* Conteúdo por cima do painel */
.contact .content,
.contact .container {
  position: relative;
  z-index: 1;
}

/* Títulos e subtítulo */
.contact .content {
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}

.contact .content h2 {
  font-family: "pragmatica", "pragmatica-condensed", Montserrat, Arial, sans-serif;
  font-size: clamp(28px, 2.4vw + 8px, 48px);
  font-weight: 900;
  color: #000000;
  margin: 0 0 8px 0;
}

.contact .content p {
  font-family: "pragmatica", "Arimo", sans-serif;
  font-size: clamp(16px, 1.4vw + 6px, 24px);
  font-weight: 300;
  color: #000000;
  margin: 0 0 8px 0;
  text-align: left !important; /* respeita o teu inline style do <head> */
}

/* Cards de contacto */
.container {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: stretch;
  margin-top: 10px;
}

.container .contactInfo {
  width: min(900px, 100%);
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin: 0 auto 24px auto;
  padding: 0 24px;
}

.container .contactInfo .box {
  position: relative;
  padding: 16px 18px;
  display: grid;
  grid-template-columns: 60px 1fr;
  align-items: center;
  gap: 16px;
  background: rgba(255, 255, 255, 0.75);
  border-radius: 12px;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
}

.container .contactInfo .box .icon {
  width: 60px;
  height: 60px;
  background: #ffffff;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 22px;
  color: #111111;
}

.container .contactInfo .box .text {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 16px;
  color: #000000;
  font-weight: 300;
}

.container .contactInfo .box .text h3 {
  margin: 0;
  font-weight: 700;
  color: #c600f8;
  font-family: "pragmatica", "Arimo", sans-serif;
}

.container .contactInfo .box .text p {
  margin: 0;
  line-height: 1.5;
}

/* ===== Footer (fixo) ===== */
footer,
#footer,
footer#contacts,
.footer,
[role="contentinfo"],
[class*="footer"] {
  position: fixed !important;
  left: 0;
  right: 0;
  bottom: 0;
  height: var(--footer-h);
  background: #111111;
  color: #ffffff;
  border-top: 1px solid #e9e9ee;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 20px;
  z-index: 4000;
  font-size: 14px;
}

footer :is(p, ul, ol),
#footer :is(p, ul, ol),
footer#contacts :is(p, ul, ol) {
  margin: 0;
}

/* ===== Responsivo ===== */
@media (max-width: 900px) {
  .contact {
    padding: 40px 24px;
  }
  .contact::before {
    left: 24px;
    right: 24px;
  }
}

@media (max-width: 600px) {
  nav {
    padding: 0.75rem 4%;
    margin-bottom: 1rem;
  }
  .nav-links li a {
    padding: 10px 14px;
  }
  .container .contactInfo .box {
    grid-template-columns: 48px 1fr;
    gap: 12px;
  }
  .container .contactInfo .box .icon {
    width: 48px;
    height: 48px;
    font-size: 20px;
  }
}

/* === Full-page background image (controlada no HTML) === */
.bg-cover{
  position: fixed;
  inset: 0;
  z-index: -1;            /* fica por trás de tudo */
}

.bg-cover img{
  width: 100%;
  height: 100%;
  object-fit: cover;      /* cobre a viewport */
  display: block;
}

/* Usa a variável inline --panel-alpha vinda do HTML */
.contact::before{
  background: rgba(255, 255, 255, var(--panel-alpha, 0.6)) !important;
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
}

/* (Opcional) em mobile, performance melhor sem parallax nativo */
@media (max-width: 900px){
  .bg-cover{ position: absolute; }
}

/* === PATCH: painel mais acima + margens top/bottom e conteúdo dentro === */

/* Espaçamento interno da secção para o conteúdo não colar nas bordas do painel */
.contact{
  /* respiro vertical confortável */
  padding-block: clamp(28px, 5vh, 64px);
}

/* Permite ajustares INSETs do painel a partir do HTML, com bons defaults */
.contact::before{
  /* 
    Ajustes:
    - Subi o painel (menos top)
    - Dei mais margem em baixo (mais bottom)
    - Mantive margens laterais
    Podes alterar via HTML: style="--panel-inset-top: 16px; --panel-inset-bottom: 96px; --panel-inset-inline: 56px"
  */
  top: var(--panel-inset-top, clamp(10px, 3vh, 40px));
  bottom: var(--panel-inset-bottom, clamp(36px, 7vh, 120px));
  left: var(--panel-inset-inline, clamp(40px, 4vw, 111px));
  right: var(--panel-inset-inline, clamp(40px, 4vw, 111px));
  /* já está com a tua opacidade/blur noutro bloco; mantemos */
}

/* Garante que o conteúdo fica naturalmente “dentro” do painel */
.contact .content,
.contact .container{
  /* alinha com as laterais do painel (acompanha os clamps) */
  margin-inline: calc(var(--panel-inset-inline, 56px) - 16px);
  /* e não deixa encostar “lá em cima” se o título for grande */
  margin-top: max(0px, calc(var(--panel-inset-top, 24px) - 16px));
  margin-bottom: max(0px, calc(var(--panel-inset-bottom, 64px) - 24px));
}

/* Título totalmente dentro do painel e bem legível em imagem escura */
.contact .content h2{
  margin-top: 0;
  position: relative;
  z-index: 1;               /* por cima do vidro, caso o browser não suporte blur */
}

/* Opcional: se quiseres centralizar o bloco de texto/cards dentro do painel */
.contact .content{
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}
.container .contactInfo{
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}

/* === Language flags dropdown (separate in navbar) === */
.nav-links {
  display: flex;
  align-items: center;
}

.nav-links > li.lang-switch {
  position: relative;
  margin-right: auto; /* empurra os outros itens para a direita, bandeiras ficam mais à esquerda */
}

.nav-links > li.lang-switch > a.lang-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 14px;
}

.flag-icon {
  width: 22px;
  height: 22px;
  border-radius: 2px;
  display: block;
  object-fit: cover;
}

/* dropdown de bandeiras */
.nav-links li.lang-switch > ul.dropdown-lang {
  position: absolute;
  top: 100%;
  left: 0;
  margin: 0;
  padding: 6px 8px;
  list-style: none;
  background: #000000;
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
  display: none;
  z-index: 2000;
}

.nav-links li.lang-switch:hover > ul.dropdown-lang {
  display: block;
}

.nav-links li.lang-switch ul.dropdown-lang li a {
  display: block;
  padding: 4px;
}

.nav-links li.lang-switch ul.dropdown-lang li a .flag-icon {
  width: 20px;
  height: 20px;
}

