/**
 * Craft Breeze — Landing page institucional [craftbreeze_home]
 *
 * Estilos namespaced em .cb-home para não colidir com o tema do site nem
 * com os restantes módulos do CB Suite. Cores e animações derivadas
 * directamente do design original do Claude Designer.
 *
 * Paleta:
 *   #f4eee0  creme base       #221c12  tinta escura
 *   #93701c  dourado          #7a5c14  dourado escuro
 *   #d6b46c  dourado claro    #ebe2d0  creme manifesto
 */

/* ── Reset escopado ─────────────────────────────────────────── */
.cb-home,
.cb-home * {
    box-sizing: border-box;
}
.cb-home {
    /* Full-bleed: ocupa toda a largura da viewport mesmo quando o tema
       envolve o conteúdo num container estreito (entry-content, .container,
       Gutenberg, etc). Escopado a .cb-home — não afecta mais nada.
       O JS (craftbreeze-home.js) mede a largura real e ajusta as margens
       com precisão, eliminando o problema da barra de scroll. Estes valores
       CSS são o fallback inicial antes do JS correr. */
    --cb-bleed: 50vw;
    width: 100vw;
    max-width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: calc(-1 * var(--cb-bleed));
    margin-right: calc(-1 * var(--cb-bleed));

    background: #f4eee0;
    color: #221c12;
    font-family: 'Inter', sans-serif;
    font-weight: 300;
    line-height: 1.6;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
}
.cb-home img {
    display: block;
    max-width: 100%;
}
.cb-home ::selection {
    background: #93701c;
    color: #f6f1e6;
}

/* O tema do site pode injectar margens/paddings em containers. Forçar
   o reset apenas dentro do nosso namespace para a página ficar full-bleed. */
.cb-home section,
.cb-home nav,
.cb-home footer,
.cb-home form,
.cb-home div,
.cb-home p,
.cb-home h1,
.cb-home h2,
.cb-home h3 {
    margin: 0;
}

/* ── Animações ──────────────────────────────────────────────── */
@keyframes cb-marquee { to { transform: translateX(-50%); } }
@keyframes cb-seal    { to { transform: rotate(360deg); } }
@keyframes cb-fadeup  { from { opacity: 0; transform: translateY(26px); } to { opacity: 1; transform: translateY(0); } }
@keyframes cb-fade    { from { opacity: 0; } to { opacity: 1; } }

/* ── Progressive enhancement das animações de entrada ────────
   Os elementos com data-cb-anim ficam VISÍVEIS por defeito. Só quando o
   JavaScript adiciona a classe .cb-home--anim é que a animação fade-in
   corre (revelando-os a partir de opacity:0). Assim, se o JS ou o CSS
   falharem, o conteúdo continua sempre visível — nunca uma página em
   branco. As animações contínuas (marquee, seal) não dependem disto. */
.cb-home.cb-home--anim [data-cb-anim] {
    opacity: 0;
}
.cb-home.cb-home--anim [data-cb-anim="cb-fadeup .9s .15s both cubic-bezier(.7,0,.3,1)"] { animation: cb-fadeup .9s .15s both cubic-bezier(.7,0,.3,1); }
.cb-home.cb-home--anim [data-cb-anim="cb-fadeup 1s .3s both cubic-bezier(.7,0,.3,1)"]   { animation: cb-fadeup 1s .3s both cubic-bezier(.7,0,.3,1); }
.cb-home.cb-home--anim [data-cb-anim="cb-fadeup 1s .42s both cubic-bezier(.7,0,.3,1)"]  { animation: cb-fadeup 1s .42s both cubic-bezier(.7,0,.3,1); }
.cb-home.cb-home--anim [data-cb-anim="cb-fadeup 1s .54s both cubic-bezier(.7,0,.3,1)"]  { animation: cb-fadeup 1s .54s both cubic-bezier(.7,0,.3,1); }
.cb-home.cb-home--anim [data-cb-anim="cb-fade 1.1s .9s both"]   { animation: cb-fade 1.1s .9s both; }
.cb-home.cb-home--anim [data-cb-anim="cb-fade 1.1s 1.05s both"] { animation: cb-fade 1.1s 1.05s both; }
.cb-home.cb-home--anim [data-cb-anim="cb-fade 1.2s 1.3s both"]  { animation: cb-fade 1.2s 1.3s both; }
.cb-home.cb-home--anim [data-cb-anim="cb-fade 1.4s .5s both"]   { animation: cb-fade 1.4s .5s both; }

/* Animações contínuas — correm sempre, independentes do fade-in de entrada.
   Não escondem conteúdo (só movem/rodam), por isso são seguras sem JS. */
.cb-home [data-cb-anim="cb-marquee 48s linear infinite"] { animation: cb-marquee 48s linear infinite; }
.cb-home [data-cb-anim="cb-seal 90s linear infinite"]    { animation: cb-seal 90s linear infinite; }

/* ── Acessibilidade: respeitar prefers-reduced-motion ───────── */
@media (prefers-reduced-motion: reduce) {
    .cb-home *,
    .cb-home *::before,
    .cb-home *::after {
        animation-duration: 0.001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.001ms !important;
        scroll-behavior: auto !important;
    }
    /* Garantir que elementos com fade-in ficam visíveis sem animação */
    .cb-home [style*="opacity:0"] {
        opacity: 1 !important;
    }
}

/* ── Foco visível para navegação por teclado ────────────────── */
.cb-home button:focus-visible,
.cb-home a:focus-visible,
.cb-home input:focus-visible,
.cb-home select:focus-visible,
.cb-home textarea:focus-visible {
    outline: 2px solid #93701c;
    outline-offset: 3px;
}

/* ── Responsivo ─────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .cb-home nav {
        padding: 22px 28px !important;
    }
    /* Esconder menu central em tablet/mobile — manter logo + CTA */
    .cb-home nav > div > div:first-child {
        display: none !important;
    }
}

@media (max-width: 820px) {
    /* Grelhas de 2 colunas passam a 1 coluna */
    .cb-home section > div[style*="grid-template-columns"] {
        grid-template-columns: 1fr !important;
        gap: 48px !important;
    }
    /* Hero: emblema abaixo do texto */
    .cb-home section:first-of-type > div {
        padding: 120px 0 70px !important;
    }
    /* Contacto e Sobre: stack */
    .cb-home #sobre > div,
    .cb-home #contacto > div {
        gap: 56px !important;
    }
    /* Reduzir padding lateral das secções */
    .cb-home section {
        padding-left: 28px !important;
        padding-right: 28px !important;
    }
    .cb-home nav {
        padding: 18px 20px !important;
    }
    .cb-home footer {
        padding-left: 24px !important;
        padding-right: 24px !important;
    }
}

@media (max-width: 560px) {
    /* Botões do hero em coluna */
    .cb-home section:first-of-type div[style*="flex-wrap:wrap"] {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 18px !important;
    }
    /* Estatísticas do "sobre" em coluna */
    .cb-home #sobre div[style*="repeat(3"] {
        grid-template-columns: 1fr 1fr !important;
        gap: 24px !important;
    }
    /* Linhas de divisão (cards) com padding menor */
    .cb-home #divisoes [data-cb-row] {
        padding: 28px 0 !important;
    }
    /* Footer: empilhar a linha inferior */
    .cb-home footer > div:last-child {
        flex-direction: column !important;
        text-align: center !important;
    }
}
