/* ==========================================================================
   Camila Cakes — Ateliê e Confeitaria
   Design System & Reset
   ========================================================================== */

/* --- Reset básico --- */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  /* compensa o header fixo ao pular para uma âncora */
  scroll-padding-top: 88px;
  -webkit-text-size-adjust: 100%;
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}

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

a {
  color: inherit;
  text-decoration: none;
}

ul,
ol {
  list-style: none;
}

button,
input,
textarea,
select {
  font: inherit;
  color: inherit;
}

/* Fallback global de foco de teclado: garante indicador visível em
   qualquer elemento interativo que não tenha regra :focus-visible própria
   (ex.: links do rodapé sobre fundo escuro). As regras mais específicas
   por componente continuam prevalecendo. */
:focus-visible {
  outline: 2px solid var(--celeste);
  outline-offset: 2px;
}

/* --- Design tokens --- */
:root {
  /* Cores */
  --celeste: #4FB8E0;
  --celeste-claro: #8FD4EE;
  --rosa: #EC5E88;
  --rosa-escuro: #D84372;
  --cinza: #5A5A5A;
  --carvao: #2E2A2B;
  --creme: #FBF7F4;
  --creme-fatias: #F6EFE6;
  --branco: #FFFFFF;
  --vinho: #6E2235;

  /* Tipografia */
  --fonte-display: 'Cormorant Garamond', Georgia, serif;
  --fonte-corpo: 'Jost', system-ui, sans-serif;

  /* Espaçamentos (escala) */
  --esp-1: 0.5rem;   /*  8px */
  --esp-2: 1rem;     /* 16px */
  --esp-3: 1.5rem;   /* 24px */
  --esp-4: 2.5rem;   /* 40px */
  --esp-5: 4rem;     /* 64px */
  --esp-6: 6rem;     /* 96px */

  /* Forma */
  --radius: 16px;
  --sombra: 0 12px 32px rgba(46, 42, 43, 0.10);
}

/* --- Base --- */
body {
  background-color: var(--creme);
  color: var(--carvao);
  font-family: var(--fonte-corpo);
  font-weight: 400;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1,
h2,
h3 {
  font-family: var(--fonte-display);
  font-weight: 600;
  color: var(--carvao);
}

/* Cormorant é mais fina/alta que a Fraunces: pede mais tamanho e peso */
h1,
.hero__titulo {
  font-family: var(--fonte-display);
  font-weight: 600;
  font-size: clamp(2.75rem, 7vw, 4.5rem);
  line-height: 1.05;
  letter-spacing: -0.01em;
}

h2,
.secao-titulo {
  font-family: var(--fonte-display);
  font-weight: 600;
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.1;
}

h3 {
  font-family: var(--fonte-display);
  font-weight: 600;
  font-size: 1.35rem;
}

/* ==========================================================================
   Header fixo + navegação
   ========================================================================== */

.cabecalho {
  position: sticky;
  top: 0;
  z-index: 100;
  background-color: var(--creme);
  transition: box-shadow 0.3s ease;
}

/* sombra sutil ativada via JS depois do scroll */
.cabecalho.rolado {
  box-shadow: 0 4px 20px rgba(46, 42, 43, 0.08);
}

.cabecalho__interno {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--esp-3);
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--esp-2) var(--esp-3);
}

.cabecalho__logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.cabecalho__logo img {
  height: 48px;
  width: auto;
}

/* --- Navegação --- */
.nav {
  display: flex;
  align-items: center;
  gap: var(--esp-4);
}

.nav__lista {
  display: flex;
  align-items: center;
  gap: var(--esp-3);
}

.nav__link {
  position: relative;
  font-family: var(--fonte-corpo);
  font-weight: 500;
  color: var(--carvao);
  padding: var(--esp-1) 0;
  transition: color 0.2s ease;
}

/* underline animado */
.nav__link::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2px;
  background-color: var(--celeste);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.25s ease;
}

.nav__link:hover,
.nav__link:focus-visible {
  color: var(--celeste);
}

.nav__link:hover::after,
.nav__link:focus-visible::after {
  transform: scaleX(1);
}

/* --- CTA WhatsApp --- */
.cta-whatsapp {
  display: inline-block;
  background-color: var(--rosa);
  color: var(--branco);
  font-family: var(--fonte-corpo);
  font-weight: 500;
  padding: var(--esp-1) var(--esp-3);
  border-radius: var(--radius);
  transition: background-color 0.2s ease, transform 0.2s ease;
}

.cta-whatsapp:hover {
  background-color: var(--rosa-escuro);
}

.cta-whatsapp:focus-visible {
  outline: 3px solid var(--rosa-escuro);
  outline-offset: 2px;
}

/* --- Botão hambúrguer (só mobile) --- */
.menu-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  padding: 10px;
  background: transparent;
  border: none;
  cursor: pointer;
}

.menu-toggle__barra {
  display: block;
  width: 100%;
  height: 2px;
  background-color: var(--carvao);
  border-radius: 2px;
  transition: transform 0.25s ease, opacity 0.25s ease;
}

.menu-toggle:focus-visible {
  outline: 3px solid var(--celeste);
  outline-offset: 2px;
}

/* hambúrguer vira "X" quando o menu está aberto */
.menu-toggle[aria-expanded="true"] .menu-toggle__barra:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.menu-toggle[aria-expanded="true"] .menu-toggle__barra:nth-child(2) {
  opacity: 0;
}
.menu-toggle[aria-expanded="true"] .menu-toggle__barra:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* ==========================================================================
   Mobile (até 768px)
   ========================================================================== */
@media (max-width: 768px) {
  .menu-toggle {
    display: flex;
  }

  /* nav vira painel dropdown abaixo do header */
  .nav {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    flex-direction: column;
    align-items: stretch;
    gap: var(--esp-2);
    padding: var(--esp-3);
    background-color: var(--creme);
    box-shadow: 0 12px 20px rgba(46, 42, 43, 0.10);

    /* fechado por padrão */
    transform: translateY(-12px);
    opacity: 0;
    visibility: hidden;
    transition: transform 0.25s ease, opacity 0.25s ease, visibility 0.25s;
  }

  .nav.aberto {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }

  .nav__lista {
    flex-direction: column;
    align-items: stretch;
    gap: var(--esp-2);
  }

  .nav__link {
    display: block;
    padding: var(--esp-1) 0;
  }

  /* underline não faz sentido empilhado: realça com cor */
  .nav__link::after {
    display: none;
  }

  .nav__cta {
    text-align: center;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cabecalho,
  .nav,
  .nav__link,
  .nav__link::after,
  .cta-whatsapp,
  .menu-toggle__barra {
    transition: none;
  }
}

/* ==========================================================================
   Hero / Vitrine (#inicio)
   ========================================================================== */

.hero {
  padding: var(--esp-4) 0;
  overflow: hidden; /* contém a forma orgânica de fundo */
}

.hero__interno {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: var(--esp-6);
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--esp-3);
}

/* --- Coluna de texto --- */
.hero__eyebrow {
  font-family: 'Caveat', cursive;
  font-size: 1.6rem;
  font-weight: 600;
  color: var(--rosa);
  text-transform: none;
  letter-spacing: normal;
  display: inline-block;
  transform: rotate(-3deg);
  transform-origin: left center;
  margin-bottom: var(--esp-2);
  line-height: 1;
}

.hero__titulo {
  margin-bottom: var(--esp-3);
  max-width: 14ch;
}

.hero__apoio {
  font-size: 1.125rem;
  color: var(--cinza);
  max-width: 46ch;
  margin-bottom: var(--esp-4);
}

.hero__acoes {
  display: flex;
  flex-wrap: wrap;
  gap: var(--esp-2);
}

/* botão secundário (ghost com borda celeste) */
.cta-secundario {
  display: inline-block;
  background-color: transparent;
  color: var(--celeste);
  font-family: var(--fonte-corpo);
  font-weight: 500;
  padding: var(--esp-1) var(--esp-3);
  border: 2px solid var(--celeste);
  border-radius: var(--radius);
  transition: background-color 0.2s ease, color 0.2s ease;
}

.cta-secundario:hover {
  background-color: var(--celeste);
  color: var(--branco);
}

.cta-secundario:focus-visible {
  outline: 3px solid var(--celeste);
  outline-offset: 2px;
}

/* --- Coluna da foto --- */
.hero__foto {
  position: relative;
}

/* detalhe orgânico de marca atrás da foto */
.hero__foto::before {
  content: "";
  position: absolute;
  z-index: 0;
  width: 70%;
  height: 70%;
  right: -6%;
  top: -8%;
  background-color: var(--celeste-claro);
  opacity: 0.35;
  border-radius: 42% 58% 63% 37% / 43% 38% 62% 57%;
}

.hero__foto img {
  position: relative;
  z-index: 1;
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: var(--radius);
  box-shadow: var(--sombra);
}

/* ==========================================================================
   Hero — responsivo
   ========================================================================== */
@media (max-width: 768px) {
  .hero {
    padding: var(--esp-4) 0;
  }

  .hero__interno {
    grid-template-columns: 1fr;
    gap: var(--esp-4);
  }

  /* texto em cima, foto embaixo */
  .hero__texto {
    order: 1;
  }
  .hero__foto {
    order: 2;
  }

  .hero__titulo {
    max-width: 20ch;
  }
}

@media (max-width: 400px) {
  .hero__acoes .cta-whatsapp,
  .hero__acoes .cta-secundario {
    flex: 1 1 100%;
    text-align: center;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cta-secundario {
    transition: none;
  }
}

/* ==========================================================================
   Encomendas (#encomendas)
   ========================================================================== */

.encomendas {
  padding: var(--esp-4) 0;
}

.encomendas__interno {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--esp-3);
}

/* --- Cabeçalho de seção (reutilizável) --- */
.secao-cabecalho {
  margin-bottom: var(--esp-4);
}

/* separa o cabeçalho dos docinhos do carrossel de bolos acima */
.secao-cabecalho--docinhos {
  margin-top: var(--esp-5);
}

.secao-eyebrow {
  font-family: 'Caveat', cursive;
  font-size: 1.6rem;
  font-weight: 600;
  color: var(--rosa);
  text-transform: none;       /* remove o uppercase anterior */
  letter-spacing: normal;     /* remove o espaçamento de versalete */
  display: inline-block;
  transform: rotate(-3deg);
  transform-origin: left center;
  margin-bottom: var(--esp-1);
  line-height: 1;
}

.secao-titulo {
  margin-bottom: var(--esp-2);
}

.secao-apoio {
  font-size: 1.125rem;
  color: var(--cinza);
  max-width: 48ch;
}

/* --- Carrossel automático de bolos --- */
.carrossel-viewport {
  width: 100%;
  overflow: hidden;
  -webkit-mask-image: linear-gradient(to right, transparent, #000 5%, #000 95%, transparent);
  mask-image: linear-gradient(to right, transparent, #000 5%, #000 95%, transparent);
}

.carrossel-track {
  display: flex;
  gap: 18px;
  width: max-content;
  animation: carrossel-scroll 36s linear infinite;
}

.carrossel-viewport:hover .carrossel-track {
  animation-play-state: paused;
}

.carrossel-track figure {
  margin: 0;
  flex: 0 0 260px;
}

.carrossel-track img {
  width: 100%;
  height: 320px;
  object-fit: cover;
  display: block;
  border-radius: var(--radius);
  box-shadow: var(--sombra);
}

@keyframes carrossel-scroll {
  from { transform: translateX(calc(-50% - 9px)); }
  to { transform: translateX(0); }
}

/* Docinhos: 3 passadas, desliza 1/3 da pista */
.carrossel-track--docinhos {
  animation-name: carrossel-scroll-docinhos;
}

@keyframes carrossel-scroll-docinhos {
  from { transform: translateX(0); }
  to { transform: translateX(calc(-33.333% - 12px)); }
}

@media (prefers-reduced-motion: reduce) {
  .carrossel-track { animation: none; }
  .carrossel-viewport { overflow-x: auto; }
}

/* --- Fatias do dia (faixa full-bleed com textura) --- */
.fatias {
  background-color: var(--creme-fatias);
  background-image: repeating-linear-gradient(
    45deg,
    rgba(110, 34, 53, 0.04) 0,
    rgba(110, 34, 53, 0.04) 1px,
    transparent 1px,
    transparent 12px
  );
  padding: var(--esp-5) 0;
  margin: var(--esp-4) 0;
}

.fatias__interno {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--esp-3);
}

/* --- Fatias do dia (lista alternada) --- */
.fatias-lista {
  display: flex;
  flex-direction: column;
  gap: var(--esp-5);
  margin-top: var(--esp-4);
}

.fatia-item {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: var(--esp-4);
  align-items: center;
}

.fatia-item--invertido .fatia-foto {
  order: 2;
}

.fatia-foto {
  aspect-ratio: 4 / 3;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--sombra);
}

.fatia-foto img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .5s ease;
}

.fatia-item:hover .fatia-foto img {
  transform: scale(1.04);
}

.fatia-texto p {
  color: var(--cinza);
  line-height: 1.6;
  margin: var(--esp-1) 0 var(--esp-3);
}

@media (max-width: 768px) {
  .fatia-item,
  .fatia-item--invertido {
    grid-template-columns: 1fr;
    gap: var(--esp-2);
  }
  .fatia-item--invertido .fatia-foto {
    order: 0;  /* no mobile, foto sempre em cima */
  }
}

@media (prefers-reduced-motion: reduce) {
  .fatia-foto img { transition: none; }
}

/* ==========================================================================
   Sobre (#sobre)
   ========================================================================== */

.sobre {
  padding: var(--esp-4) 0;
}

.sobre__interno {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--esp-3);
}

.sobre-bloco {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--esp-5);
  align-items: center;
}

.sobre-foto img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: var(--radius);
  box-shadow: var(--sombra);
  display: block;
}

/* Título manuscrito animado ("escrito à mão") */
.sobre-titulo-mao {
  display: inline-block;
  overflow: hidden;
  margin-bottom: var(--esp-3);
  padding-right: 0.3em;   /* respiro pra cauda das letras manuscritas não cortar */
}

.sobre-titulo-mao__texto {
  font-family: 'Caveat', cursive;
  font-size: clamp(2.5rem, 6vw, 4rem);
  font-weight: 700;
  color: var(--vinho, #6E2235);
  white-space: nowrap;
  display: inline-block;
  padding-right: 0.15em;  /* folga extra dentro do texto */
  -webkit-mask-image: linear-gradient(to right, #000 0%, #000 100%);
  mask-image: linear-gradient(to right, #000 0%, #000 100%);
  -webkit-mask-size: 0% 100%;
  mask-size: 0% 100%;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
}

.sobre-titulo-mao.escrever .sobre-titulo-mao__texto {
  animation: escrever-mao 2.2s steps(40) forwards;
}

@keyframes escrever-mao {
  to {
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
  }
}

@media (prefers-reduced-motion: reduce) {
  .sobre-titulo-mao__texto {
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
    animation: none;
  }
}

.sobre-texto p:not(.secao-eyebrow):not(.secao-titulo) {
  color: var(--cinza);
  line-height: 1.7;
  margin-bottom: var(--esp-3);
}

@media (max-width: 768px) {
  .sobre-bloco {
    grid-template-columns: 1fr;
    gap: var(--esp-4);
  }
  /* dissolve o wrapper para reordenar cabeçalho/foto/corpo no mobile */
  .sobre-texto {
    display: contents;
  }
  .sobre-cabecalho {
    order: 1;
  }
  .sobre-foto {
    order: 2;
    max-width: 420px;
    margin: 0 auto;
  }
  .sobre-corpo {
    order: 3;
  }
}

/* ==========================================================================
   Localização (#localizacao)
   ========================================================================== */

.localizacao {
  padding: var(--esp-4) 0;
}

.localizacao__interno {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--esp-3);
}

.local-bloco {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--esp-5);
  align-items: center;
}

.local-item {
  margin-bottom: var(--esp-4);
}

.local-item h3 {
  font-size: 1rem;
  color: var(--carvao);
  margin-bottom: var(--esp-1);
}

.local-item p {
  color: var(--cinza);
  line-height: 1.6;
}

.local-mapa {
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--sombra);
  line-height: 0;
}

.local-mapa iframe {
  width: 100%;
  height: 420px;
  border: 0;
  display: block;
}

@media (max-width: 768px) {
  .local-bloco {
    grid-template-columns: 1fr;
    gap: var(--esp-4);
  }
  .local-mapa iframe {
    height: 300px;
  }
}

/* ==========================================================================
   Rodapé (paleta invertida: fundo escuro)
   ========================================================================== */

.rodape {
  background: var(--carvao);
  color: var(--creme);
  padding: var(--esp-5) 0 var(--esp-3);
  margin-top: var(--esp-6);
}

.rodape__interno {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--esp-3);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--esp-4);
  flex-wrap: wrap;
}

.rodape-logo {
  height: 56px;
  width: auto;
  display: block;
  margin-bottom: var(--esp-2);
}

.rodape-tagline {
  color: var(--creme);
  opacity: .75;
  font-size: .95rem;
  max-width: 32ch;
  line-height: 1.5;
}

.rodape-contato {
  display: flex;
  flex-direction: column;
  gap: var(--esp-1);
}

.rodape-contato a {
  color: var(--creme);
  text-decoration: none;
  transition: opacity .2s ease;
}

.rodape-contato a:hover {
  opacity: .7;
}

.rodape__base {
  max-width: 1200px;
  margin: var(--esp-4) auto 0;
  padding: var(--esp-3) var(--esp-3) 0;
  border-top: 1px solid rgba(245,241,232,.15);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--esp-2);
  flex-wrap: wrap;
  font-size: .85rem;
  opacity: .7;
}

.rodape-credito a {
  color: var(--creme);
  text-decoration: underline;
}

@media (max-width: 600px) {
  .rodape__interno,
  .rodape__base {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (prefers-reduced-motion: reduce) {
  .rodape-contato a {
    transition: none;
  }
}
