/**
 * Designeo Lite — global.css
 * Sistema baseado em tokens. Nunca usa valores fixos — tudo referencia theme.json.
 * Para mudar o tema, edita theme.json. Este ficheiro não deve ser modificado por projecto.
 */

/* ─────────────────────────────────────────────────────────────────────────────
   TOKENS LOCAIS
   Variáveis que estendem o theme.json para uso interno neste CSS.
   ───────────────────────────────────────────────────────────────────────────── */

:root {
  /* Layout */
  --dl-header-height:    64px;
  --dl-content-narrow:   640px;
  --dl-content-default:  var(--wp--style--global--content-size, 720px);
  --dl-content-wide:     var(--wp--style--global--wide-size, 1160px);

  /* Bordas */
  --dl-border-thin:      0.5px solid var(--wp--preset--color--border);
  --dl-border-base:      1px solid var(--wp--preset--color--border);
  --dl-border-medium:    2px solid var(--wp--preset--color--border);

  /* Raios */
  --dl-radius-sm:        2px;
  --dl-radius-md:        4px;
  --dl-radius-lg:        8px;
  --dl-radius-xl:        12px;
  --dl-radius-full:      9999px;

  /* Transições */
  --dl-transition-fast:  0.12s ease;
  --dl-transition-base:  0.20s ease;
  --dl-transition-slow:  0.35s ease;

  /* Sombras */
  --dl-shadow-sm:        0 1px 3px rgba(0,0,0,0.08);
  --dl-shadow-md:        0 4px 16px rgba(0,0,0,0.08);
  --dl-shadow-lg:        0 8px 32px rgba(0,0,0,0.10);
}


/* ─────────────────────────────────────────────────────────────────────────────
   RESET MÍNIMO
   ───────────────────────────────────────────────────────────────────────────── */

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

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body { margin: 0; }

img, video, svg { display: block; max-width: 100%; height: auto; }

p:last-child { margin-bottom: 0; }

::selection {
  background: var(--wp--preset--color--on-surface);
  color: var(--wp--preset--color--surface);
}


/* ─────────────────────────────────────────────────────────────────────────────
   ACESSIBILIDADE
   ───────────────────────────────────────────────────────────────────────────── */

/* Skip link — invisível, aparece com Tab */
.dl-skip-link {
  position: absolute;
  top: -200%;
  left: var(--wp--preset--spacing--3);
  z-index: 9999;
  padding: var(--wp--preset--spacing--2) var(--wp--preset--spacing--3);
  background: var(--wp--preset--color--on-surface);
  color: var(--wp--preset--color--surface);
  font-family: var(--wp--preset--font-family--body);
  font-size: var(--wp--preset--font-size--sm);
  font-weight: 500;
  text-decoration: none;
  border-radius: 0 0 var(--dl-radius-md) var(--dl-radius-md);
  transition: top var(--dl-transition-fast);
}
.dl-skip-link:focus { top: 0; outline: 2px solid var(--wp--preset--color--surface); outline-offset: 2px; }

/* Focus visível — teclado */
:focus-visible {
  outline: 2px solid var(--wp--preset--color--on-surface);
  outline-offset: 3px;
  border-radius: var(--dl-radius-sm);
}
:focus:not(:focus-visible) { outline: none; }
#main-content:focus { outline: none; }


/* ─────────────────────────────────────────────────────────────────────────────
   HEADER
   ───────────────────────────────────────────────────────────────────────────── */

.dl-site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  height: var(--dl-header-height);
  display: flex;
  align-items: center;

  /* Vidro fosco — funciona sobre qualquer fundo */
  background-color: rgba(255, 255, 255, 0.88) !important;
  backdrop-filter: blur(12px) saturate(1.4);
  -webkit-backdrop-filter: blur(12px) saturate(1.4);

  border-bottom: var(--dl-border-thin);
  transition: box-shadow var(--dl-transition-base);
}

/* Sombra quando há scroll */
.dl-site-header.is-scrolled {
  box-shadow: var(--dl-shadow-sm);
  border-bottom-color: transparent;
}

/* Nav links */
.dl-site-header .wp-block-navigation a {
  text-decoration: none;
  transition: color var(--dl-transition-fast);
}
.dl-site-header .wp-block-navigation a:hover {
  color: var(--wp--preset--color--on-surface-muted);
}

/* Hamburger mobile */
.dl-site-header .wp-block-navigation__responsive-container-open,
.dl-site-header .wp-block-navigation__responsive-container-close {
  background: none;
  border: none;
  padding: var(--wp--preset--spacing--1);
  cursor: pointer;
  color: var(--wp--preset--color--on-surface);
}

/* Menu mobile overlay */
.wp-block-navigation__responsive-container.is-menu-open {
  background: var(--wp--preset--color--surface);
  padding: var(--wp--preset--spacing--6) var(--wp--preset--spacing--4);
}


/* ─────────────────────────────────────────────────────────────────────────────
   LAYOUT PRINCIPAL
   ───────────────────────────────────────────────────────────────────────────── */

.dl-main {
  /* Compensa o header sticky — evita conteúdo escondido atrás do header */
  scroll-margin-top: var(--dl-header-height);
}

/* A primeira secção da página não precisa de padding-top extra */
.dl-main > .wp-block-post-content > .wp-block-group:first-child,
.dl-main > .wp-block-group:first-child {
  padding-top: 0 !important;
}


/* ─────────────────────────────────────────────────────────────────────────────
   SECÇÕES — sistema de padding consistente
   ───────────────────────────────────────────────────────────────────────────── */

/*
  Usa classes utilitárias nos grupos do Gutenberg:
  dl-section-sm  →  padding vertical 48px  (secções de suporte)
  dl-section     →  padding vertical 80px  (secções standard)
  dl-section-lg  →  padding vertical 120px (secções de destaque)
  dl-section-hero→  padding vertical 160px (hero)
*/

.dl-section-sm  { padding-top: var(--wp--preset--spacing--6) !important; padding-bottom: var(--wp--preset--spacing--6) !important; }
.dl-section     { padding-top: var(--wp--preset--spacing--10) !important; padding-bottom: var(--wp--preset--spacing--10) !important; }
.dl-section-lg  { padding-top: var(--wp--preset--spacing--12) !important; padding-bottom: var(--wp--preset--spacing--12) !important; }
.dl-section-hero {
  padding-top: calc(var(--wp--preset--spacing--16) + var(--dl-header-height)) !important;
  padding-bottom: var(--wp--preset--spacing--16) !important;
}

/* Bordas entre secções */
.dl-border-top    { border-top:    var(--dl-border-thin) !important; }
.dl-border-bottom { border-bottom: var(--dl-border-thin) !important; }


/* ─────────────────────────────────────────────────────────────────────────────
   TIPOGRAFIA UTILITÁRIA
   ───────────────────────────────────────────────────────────────────────────── */

/* Overline — label pequeno acima de títulos */
.dl-overline {
  display: block;
  font-family: var(--wp--preset--font-family--body);
  font-size: var(--wp--preset--font-size--xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--wp--preset--color--on-surface-muted);
  margin-bottom: var(--wp--preset--spacing--2);
}

/* Lead — parágrafo de introdução maior */
.dl-lead {
  font-size: var(--wp--preset--font-size--lg) !important;
  line-height: 1.65 !important;
  color: var(--wp--preset--color--on-surface-muted);
  font-weight: 300;
}

/* Número de serviço */
.dl-service-number {
  display: block;
  font-family: var(--wp--preset--font-family--body);
  font-size: var(--wp--preset--font-size--xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  color: var(--wp--preset--color--on-surface-muted);
  margin-bottom: var(--wp--preset--spacing--2);
}


/* ─────────────────────────────────────────────────────────────────────────────
   BOTÕES
   ───────────────────────────────────────────────────────────────────────────── */

.wp-block-button__link {
  transition: opacity var(--dl-transition-fast), background-color var(--dl-transition-fast);
  cursor: pointer;
}
.wp-block-button__link:hover { opacity: 0.82; }

/* Outline */
.wp-block-button.is-style-outline .wp-block-button__link {
  background: transparent !important;
  color: var(--wp--preset--color--on-surface) !important;
  border: 1.5px solid currentColor !important;
}
.wp-block-button.is-style-outline .wp-block-button__link:hover {
  background: var(--wp--preset--color--on-surface) !important;
  color: var(--wp--preset--color--surface) !important;
  opacity: 1;
}

/* Ghost / texto */
.wp-block-button.is-style-ghost .wp-block-button__link {
  background: transparent !important;
  color: var(--wp--preset--color--on-surface) !important;
  border: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 1px;
  letter-spacing: 0.04em;
}
.wp-block-button.is-style-ghost .wp-block-button__link:hover {
  color: var(--wp--preset--color--on-surface-muted) !important;
  opacity: 1;
}

/* Botão sobre fundo escuro */
.dl-btn-inverse .wp-block-button__link {
  background: var(--wp--preset--color--surface) !important;
  color: var(--wp--preset--color--on-surface) !important;
  border-color: var(--wp--preset--color--surface) !important;
}


/* ─────────────────────────────────────────────────────────────────────────────
   CARDS
   ───────────────────────────────────────────────────────────────────────────── */

.dl-card {
  background: var(--wp--preset--color--surface);
  border: var(--dl-border-thin);
  border-radius: var(--dl-radius-md);
  padding: var(--wp--preset--spacing--5);
}

.dl-card-surface {
  background: var(--wp--preset--color--surface-alt);
  border-radius: var(--dl-radius-md);
  padding: var(--wp--preset--spacing--5);
}

.dl-card-shadow {
  background: var(--wp--preset--color--surface);
  border-radius: var(--dl-radius-lg);
  box-shadow: var(--dl-shadow-md);
  padding: var(--wp--preset--spacing--5);
}


/* ─────────────────────────────────────────────────────────────────────────────
   SEPARADOR
   ───────────────────────────────────────────────────────────────────────────── */

.wp-block-separator {
  border: none;
  border-top: var(--dl-border-thin);
  margin-top: 0;
  margin-bottom: 0;
}


/* ─────────────────────────────────────────────────────────────────────────────
   FAQ — details/summary nativo (zero JavaScript)
   ───────────────────────────────────────────────────────────────────────────── */

details.dl-faq {
  border-bottom: var(--dl-border-thin);
  padding: var(--wp--preset--spacing--4) 0;
}
details.dl-faq:first-of-type { border-top: var(--dl-border-thin); }

details.dl-faq summary {
  cursor: pointer;
  list-style: none;
  font-family: var(--wp--preset--font-family--body);
  font-size: var(--wp--preset--font-size--base);
  font-weight: 500;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--wp--preset--spacing--4);
  user-select: none;
}
details.dl-faq summary::-webkit-details-marker { display: none; }
details.dl-faq summary::after {
  content: '+';
  font-size: 1.5rem;
  font-weight: 200;
  flex-shrink: 0;
  transition: transform var(--dl-transition-base);
  line-height: 1;
}
details.dl-faq[open] summary::after { transform: rotate(45deg); }

.dl-faq-body {
  margin-top: var(--wp--preset--spacing--3);
  font-size: var(--wp--preset--font-size--base);
  color: var(--wp--preset--color--on-surface-muted);
  line-height: 1.75;
  padding-right: var(--wp--preset--spacing--6);
}


/* ─────────────────────────────────────────────────────────────────────────────
   TESTEMUNHO
   ───────────────────────────────────────────────────────────────────────────── */

.dl-testimonial {
  background: var(--wp--preset--color--surface-alt);
  border-radius: var(--dl-radius-md);
  padding: var(--wp--preset--spacing--6);
}
.dl-testimonial-quote {
  font-family: var(--wp--preset--font-family--display);
  font-size: var(--wp--preset--font-size--xl);
  font-style: italic;
  line-height: 1.45;
  margin-bottom: var(--wp--preset--spacing--4);
}
.dl-testimonial-author {
  font-size: var(--wp--preset--font-size--xs);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--wp--preset--color--on-surface-muted);
}


/* ─────────────────────────────────────────────────────────────────────────────
   FORMULÁRIO DE CONTACTO
   ───────────────────────────────────────────────────────────────────────────── */

.dl-contact-form input,
.dl-contact-form textarea,
.dl-contact-form select {
  width: 100%;
  padding: var(--wp--preset--spacing--2) 0;
  font-size: var(--wp--preset--font-size--base);
  font-family: var(--wp--preset--font-family--body);
  font-weight: 300;
  background: transparent;
  border: none;
  border-bottom: var(--dl-border-thin);
  border-radius: 0;
  color: var(--wp--preset--color--on-surface);
  outline: none;
  transition: border-color var(--dl-transition-fast);
  -webkit-appearance: none;
}
.dl-contact-form input::placeholder,
.dl-contact-form textarea::placeholder {
  color: var(--wp--preset--color--on-surface-subtle);
}
.dl-contact-form input:focus,
.dl-contact-form textarea:focus {
  border-bottom-color: var(--wp--preset--color--on-surface);
}
.dl-contact-form textarea { resize: vertical; min-height: 100px; }

.dl-contact-label {
  display: block;
  font-size: var(--wp--preset--font-size--xs);
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--wp--preset--color--on-surface-muted);
  margin-bottom: var(--wp--preset--spacing--1);
}


/* ─────────────────────────────────────────────────────────────────────────────
   FOOTER
   ───────────────────────────────────────────────────────────────────────────── */

.dl-site-footer {
  background: var(--wp--preset--color--surface-inverse);
  color: var(--wp--preset--color--on-inverse);
}
.dl-site-footer a {
  color: var(--wp--preset--color--on-inverse-muted);
  text-decoration: none;
  transition: color var(--dl-transition-fast);
}
.dl-site-footer a:hover { color: var(--wp--preset--color--on-inverse); }


/* ─────────────────────────────────────────────────────────────────────────────
   IMAGENS
   ───────────────────────────────────────────────────────────────────────────── */

.wp-block-image img { border-radius: var(--dl-radius-md); }
.wp-block-image.is-style-rounded img { border-radius: var(--dl-radius-full); }

/* Aspect ratios utilitários */
.dl-aspect-square { aspect-ratio: 1/1; object-fit: cover; }
.dl-aspect-portrait { aspect-ratio: 3/4; object-fit: cover; }
.dl-aspect-landscape { aspect-ratio: 16/9; object-fit: cover; }
.dl-aspect-cinema { aspect-ratio: 21/9; object-fit: cover; }


/* ─────────────────────────────────────────────────────────────────────────────
   PAGINAÇÃO
   ───────────────────────────────────────────────────────────────────────────── */

.wp-block-query-pagination { margin-top: var(--wp--preset--spacing--8); }
.wp-block-query-pagination-numbers .page-numbers {
  padding: var(--wp--preset--spacing--1) var(--wp--preset--spacing--2);
  border: var(--dl-border-thin);
  border-radius: var(--dl-radius-sm);
  font-size: var(--wp--preset--font-size--xs);
  text-decoration: none;
  color: var(--wp--preset--color--on-surface);
  transition: background var(--dl-transition-fast);
}
.wp-block-query-pagination-numbers .page-numbers.current,
.wp-block-query-pagination-numbers .page-numbers:hover {
  background: var(--wp--preset--color--on-surface);
  color: var(--wp--preset--color--surface);
  border-color: var(--wp--preset--color--on-surface);
}


/* ─────────────────────────────────────────────────────────────────────────────
   404
   ───────────────────────────────────────────────────────────────────────────── */

.error404 .dl-main {
  min-height: calc(80vh - var(--dl-header-height));
  display: flex;
  flex-direction: column;
  justify-content: center;
}


/* ─────────────────────────────────────────────────────────────────────────────
   ANIMAÇÕES — respeita prefers-reduced-motion
   ───────────────────────────────────────────────────────────────────────────── */

@media (prefers-reduced-motion: no-preference) {
  .dl-fade-up {
    opacity: 0;
    transform: translateY(20px);
    animation: dl-fade-up 0.6s ease forwards;
  }
  @keyframes dl-fade-up {
    to { opacity: 1; transform: none; }
  }
}


/* ─────────────────────────────────────────────────────────────────────────────
   RESPONSIVO
   ───────────────────────────────────────────────────────────────────────────── */

@media (max-width: 781px) {
  .dl-section-sm  { padding-top: var(--wp--preset--spacing--6) !important; padding-bottom: var(--wp--preset--spacing--6) !important; }
  .dl-section     { padding-top: var(--wp--preset--spacing--8) !important; padding-bottom: var(--wp--preset--spacing--8) !important; }
  .dl-section-lg  { padding-top: var(--wp--preset--spacing--10) !important; padding-bottom: var(--wp--preset--spacing--10) !important; }
  .dl-section-hero {
    padding-top: calc(var(--wp--preset--spacing--12) + var(--dl-header-height)) !important;
    padding-bottom: var(--wp--preset--spacing--12) !important;
  }

  .wp-block-columns.is-not-stacked-on-mobile {
    flex-wrap: wrap !important;
  }
  .wp-block-columns.is-not-stacked-on-mobile > .wp-block-column {
    flex-basis: 100% !important;
    width: 100% !important;
  }
}


/* ─────────────────────────────────────────────────────────────────────────────
   PRINT
   ───────────────────────────────────────────────────────────────────────────── */

@media print {
  .dl-site-header,
  .dl-site-footer,
  .wp-block-buttons { display: none; }
  body { font-size: 12pt; line-height: 1.5; }
}


/* ─────────────────────────────────────────────────────────────────────────────
   CORRECÇÕES v2.0.1
   ───────────────────────────────────────────────────────────────────────────── */

/* Força títulos sem itálico em todos os contextos */
h1, h2, h3, h4, h5, h6,
.wp-block-post-title,
.wp-block-heading {
  font-style: normal !important;
}

/* Remove links azuis — herda a cor do contexto */
a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  transition: opacity var(--dl-transition-fast);
}
a:hover { opacity: 0.65; text-decoration: none; }

/* Dentro de parágrafos e corpo de texto */
.wp-block-paragraph a,
.wp-block-list a,
.entry-content a {
  color: var(--wp--preset--color--on-surface);
}

/* Espaço entre título da página e conteúdo */
.wp-block-post-title {
  margin-top: 0 !important;
  margin-bottom: var(--wp--preset--spacing--5) !important;
}

/* Remove espaço duplo quando a primeira secção do conteúdo já tem padding */
.wp-block-post-content > .wp-block-group:first-child {
  margin-top: 0 !important;
}

/* Páginas geradas pelo Studio — sem espaço extra no topo */
.page-template-page-no-title .dl-main,
.dl-main > .wp-block-post-content > *:first-child {
  margin-top: 0;
}

/* Separador entre secções mais limpo */
.wp-block-group + .wp-block-group {
  margin-top: 0;
}
