/* ════════════════════════════════════════════════════
   CASA MARGARIDA — Loja · Minha Conta · Institucionais
   ════════════════════════════════════════════════════ */

/* ─── LOJA: 2ª foto no hover (efeito galeria) ───────── */
.woocommerce ul.products li.product > a { position: relative; display: block; }
.woocommerce ul.products li.product .cm-loop-2nd {
  position: absolute; top: 0; left: 0; width: 100% !important;
  aspect-ratio: 4/5; object-fit: cover;
  opacity: 0; transition: opacity .7s var(--ease); pointer-events: none; margin: 0 !important;
}
.woocommerce ul.products li.product:hover .cm-loop-2nd { opacity: 1; }
.woocommerce ul.products li.product:hover a img:first-child { filter: saturate(1.03); }

/* ─── LOJA: estado vazio elegante ───────────────────── */
.woocommerce-shop .woocommerce-info,
.woocommerce-info.woocommerce-no-products-found,
.woocommerce ul.products.columns-4:empty + .woocommerce-info {
  background: transparent !important; border: none !important;
  font-family: var(--serif) !important; font-style: italic; font-size: 1.15rem !important;
  color: var(--mid) !important; text-align: center; padding: 3rem 1rem !important;
}
.woocommerce-shop .woocommerce-info::before { display: none !important; }

/* ════════════════════════════════════════════════════
   MINHA CONTA
   ════════════════════════════════════════════════════ */
.woocommerce-account .woocommerce {
  display: grid;
  grid-template-columns: 250px 1fr;
  gap: 3rem;
  align-items: start;
}
/* login/registro (deslogado) ocupa coluna única centralizada */
.woocommerce-account:not(.logged-in) .woocommerce { display: block; max-width: 460px; margin: 0 auto; }

.woocommerce-MyAccount-navigation ul { list-style: none; margin: 0; padding: 0; border-top: 1px solid rgba(154,77,46,.12); }
.woocommerce-MyAccount-navigation li { border-bottom: 1px solid rgba(154,77,46,.12); }
.woocommerce-MyAccount-navigation li a {
  display: block; padding: .95rem .2rem;
  font-family: var(--sans); font-size: .62rem; letter-spacing: .25em; text-transform: uppercase;
  color: var(--mid); text-decoration: none; transition: color .3s var(--ease), padding-left .3s var(--ease);
}
.woocommerce-MyAccount-navigation li a:hover { color: var(--terra); padding-left: .5rem; }
.woocommerce-MyAccount-navigation li.is-active a { color: var(--terra); font-weight: 600; }

.woocommerce-MyAccount-content p,
.woocommerce-MyAccount-content { font-family: var(--sans); color: var(--txt); }
.woocommerce-MyAccount-content a:not(.button) { color: var(--terra); }
.woocommerce-account .woocommerce-MyAccount-content table.shop_table {
  border: none !important; width: 100% !important;
}
.woocommerce-account table.shop_table th {
  font-family: var(--sans) !important; font-size: .58rem !important; letter-spacing: .25em !important;
  text-transform: uppercase !important; color: var(--mid) !important; border: none !important;
  border-bottom: 1px solid rgba(154,77,46,.16) !important; padding: 0 0 .9rem !important;
}
.woocommerce-account table.shop_table td {
  border: none !important; border-top: 1px solid rgba(154,77,46,.1) !important; padding: 1rem 0 !important;
  font-family: var(--serif) !important; color: var(--ink) !important;
}

/* formulários (login, endereço, dados) */
.woocommerce-account form .woocommerce-form-row label,
.woocommerce form .form-row label {
  font-family: var(--sans) !important; font-size: .58rem !important; letter-spacing: .26em !important;
  text-transform: uppercase !important; color: var(--mid) !important; font-weight: 600 !important;
}
.woocommerce-account input.input-text,
.woocommerce-account input[type="text"],
.woocommerce-account input[type="email"],
.woocommerce-account input[type="password"] {
  width: 100% !important; border: 1px solid rgba(154,77,46,.22) !important; border-radius: 0 !important;
  background: var(--bone) !important; padding: .9rem 1rem !important; font-family: var(--sans) !important;
}
.woocommerce-account .woocommerce-form-login__submit,
.woocommerce-account .button {
  background: var(--terra) !important; color: var(--cream) !important; border: none !important; border-radius: 0 !important;
  font-family: var(--sans) !important; font-size: .6rem !important; letter-spacing: .3em !important;
  text-transform: uppercase !important; font-weight: 500 !important; padding: .95rem 1.8rem !important;
}
.woocommerce-account h2 {
  font-family: var(--serif) !important; font-weight: 300 !important; font-size: 1.5rem !important;
  color: var(--ink) !important;
}

@media (max-width: 820px) {
  .woocommerce-account .woocommerce { grid-template-columns: 1fr; gap: 2rem; }
}

/* ════════════════════════════════════════════════════
   PÁGINAS INSTITUCIONAIS (Sobre, Como é Feito, FAQ, Políticas)
   ════════════════════════════════════════════════════ */
/* esconde o título padrão do tema (usamos o hero do conteúdo) */
.cm-inner.page .entry-header,
.cm-inner.page .page-header,
.cm-inner.page header.entry-header { display: none !important; }

.cm-page { max-width: 1100px; margin: 0 auto; }
.cm-page-hero { text-align: center; max-width: 680px; margin: 0 auto 3.5rem; }
.cm-page-hero .cm-eyebrow { justify-content: center; }
.cm-page-hero h1 {
  font-family: var(--serif); font-weight: 300; font-size: clamp(2.2rem, 5vw, 3.4rem);
  color: var(--ink); margin: .5rem 0 1rem; letter-spacing: -.01em; line-height: 1.05;
}
.cm-page-hero p {
  font-family: var(--serif); font-style: italic; font-weight: 300; font-size: 1.1rem;
  color: var(--txt); line-height: 1.7; margin: 0;
}

/* seções de conteúdo (alternância imagem/texto) */
.cm-page-section {
  display: grid; grid-template-columns: 1fr 1fr; gap: 3.5rem; align-items: center;
  margin: 0 auto 4rem; max-width: 1000px;
}
.cm-page-section.cm-rev { direction: rtl; }
.cm-page-section.cm-rev > * { direction: ltr; }
.cm-page-section .cm-ps-media {
  aspect-ratio: 4/5; background: var(--bone) center/cover no-repeat;
  border: 1px solid rgba(154,77,46,.1);
}
.cm-page-section h2 {
  font-family: var(--serif); font-weight: 300; font-size: clamp(1.6rem, 3vw, 2.2rem);
  color: var(--ink); margin: 0 0 1rem; letter-spacing: -.01em;
}
.cm-page-section h2::before {
  content: ''; display: block; width: 34px; height: 2px; background: var(--terra); opacity: .85; margin-bottom: 1rem;
}
.cm-page-section p {
  font-family: var(--serif); font-weight: 300; font-size: 1.05rem; line-height: 1.8; color: var(--txt); margin: 0 0 1rem;
}

/* faixa de processo (Como é Feito) — passos */
.cm-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; margin: 3rem auto; max-width: 1000px; }
.cm-step { text-align: center; }
.cm-step-n {
  font-family: var(--script); font-size: 2.6rem; color: var(--terra); line-height: 1; display: block; margin-bottom: .5rem;
}
.cm-step h3 {
  font-family: var(--sans); font-size: .62rem; letter-spacing: .3em; text-transform: uppercase;
  color: var(--ink); margin: 0 0 .5rem; font-weight: 600;
}
.cm-step p { font-family: var(--serif); font-style: italic; font-weight: 300; font-size: .92rem; color: var(--txt); line-height: 1.6; margin: 0; }

/* FAQ / Políticas (texto longo) */
.cm-page-prose { max-width: 760px; margin: 0 auto; }
.cm-page-prose h2 {
  font-family: var(--serif); font-weight: 300; font-size: 1.5rem; color: var(--ink); margin: 2.5rem 0 1rem;
}
.cm-page-prose h3 {
  font-family: var(--sans); font-size: .62rem; letter-spacing: .3em; text-transform: uppercase;
  color: var(--terra); margin: 2rem 0 .8rem; font-weight: 600;
}
.cm-page-prose p, .cm-page-prose li {
  font-family: var(--serif); font-weight: 300; font-size: 1.02rem; line-height: 1.85; color: var(--txt);
}
.cm-page-prose ul { padding-left: 1.2rem; }

@media (max-width: 820px) {
  .cm-page-section { grid-template-columns: 1fr; gap: 1.6rem; }
  .cm-page-section.cm-rev { direction: ltr; }
  .cm-steps { grid-template-columns: 1fr; gap: 2rem; }
}

/* ════════════════════════════════════════════════════
   PÁGINA DE CONTATO — layout 2 col + canais + form
   ════════════════════════════════════════════════════ */
.cm-contact-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 3.5rem; align-items: start;
  max-width: 1000px; margin: 0 auto;
}
.cm-contact-media {
  aspect-ratio: 4/5; background: var(--bone) center/cover no-repeat;
  border: 1px solid rgba(154,77,46,.1); position: sticky; top: 94px;
}

/* canais */
.cm-contact-side h3 {
  font-family: var(--sans); font-size: .58rem; letter-spacing: .38em; text-transform: uppercase;
  color: var(--terra); margin: 0 0 1.2rem; font-weight: 600;
}
.cm-contact-channels { margin-bottom: 2.6rem; }
.cm-channel {
  display: flex; align-items: baseline; justify-content: space-between; gap: 1rem;
  padding: 1rem 0; border-bottom: 1px solid rgba(154,77,46,.12);
  text-decoration: none; color: var(--ink); transition: padding-left .3s var(--ease);
}
.cm-channel:hover { padding-left: .5rem; }
.cm-channel-static { cursor: default; }
.cm-channel-static:hover { padding-left: 0; }
.cm-channel-lb {
  font-family: var(--sans); font-size: .58rem; letter-spacing: .3em; text-transform: uppercase;
  color: var(--mid); flex: 0 0 auto;
}
.cm-channel-val { font-family: var(--serif); font-size: 1.02rem; color: var(--ink); text-align: right; }
.cm-channel:hover .cm-channel-val { color: var(--terra); }

/* form (placeholder + também serve pro Fluent Forms quando trocar) */
.cm-contact-form h3 { margin-top: 0; }
.cm-form-placeholder,
.cm-contact-form .fluentform form,
.cm-contact-form .ff-form-loader form {
  display: flex; flex-direction: column; gap: 1rem;
}
.cm-contact-form label,
.cm-contact-form .ff-el-input--label label {
  display: flex; flex-direction: column; gap: .35rem;
  font-family: var(--sans); font-size: .55rem; letter-spacing: .3em; text-transform: uppercase;
  color: var(--mid); font-weight: 600;
}
.cm-contact-form input[type="text"],
.cm-contact-form input[type="email"],
.cm-contact-form textarea,
.cm-contact-form .ff-el-form-control {
  border: 1px solid rgba(154,77,46,.22) !important; border-radius: 0 !important;
  background: var(--bone) !important; color: var(--ink) !important;
  font-family: var(--sans) !important; font-size: .95rem !important; padding: .9rem 1rem !important;
  font-weight: 400; box-shadow: none !important;
  transition: border-color .3s var(--ease), background .3s var(--ease);
}
.cm-contact-form input:focus,
.cm-contact-form textarea:focus,
.cm-contact-form .ff-el-form-control:focus {
  outline: none !important; border-color: var(--terra) !important; background: var(--white) !important;
}
.cm-contact-form textarea { resize: vertical; min-height: 110px; }
.cm-contact-form button[type="submit"],
.cm-contact-form .ff-btn-submit,
.cm-inner .cm-contact-form button[type="submit"] {
  background: var(--terra) !important; color: var(--cream) !important;
  border: none !important; border-radius: 0 !important; cursor: pointer;
  font-family: var(--sans) !important; font-size: .62rem !important; letter-spacing: .38em !important;
  text-transform: uppercase !important; font-weight: 600 !important; padding: 1rem 2rem !important;
  align-self: flex-start; box-shadow: none !important;
  transition: background .3s var(--ease);
}
.cm-contact-form button[type="submit"]:hover,
.cm-contact-form .ff-btn-submit:hover { background: var(--terra-warm) !important; }
.cm-form-note {
  font-family: var(--serif); font-style: italic; font-size: .9rem; color: var(--terra);
  margin: .5rem 0 0; background: rgba(154,77,46,.06); padding: .8rem 1rem; border-left: 2px solid var(--terra);
}

@media (max-width: 820px) {
  .cm-contact-grid { grid-template-columns: 1fr; gap: 2rem; }
  .cm-contact-media { position: static; }
}
