/*
Theme Name:  Roberta Abramo Ginecologia
Theme URI:   https://robertaabramoginecologia.com.br
Description: Tema filho do Astra — design elegante inspirado no Verra com paleta quente
Author:      Claude Code
Template:    astra
Version:     1.0.0
Text Domain: roberta-abramo
*/

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300;1,400&family=Jost:wght@300;400;500&display=swap');

/* =============================================
   VARIÁVEIS
   ============================================= */
:root {
  --creme:            #F9F3EE;
  --creme-mid:        #EDE0D4;
  --creme-dark:       #d8c4b0;
  --terracota:        #8D6E63;
  --terracota-light:  #c4a898;
  --marrom:           #3E2C22;
  --texto:            #6B5A4E;
  --muted:            #9b8070;
  --borda:            #e0d6cc;
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'Jost', sans-serif;
}

/* =============================================
   RESET / BASE
   ============================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: var(--sans);
  font-weight: 300;
  background: var(--creme);
  color: var(--marrom);
  -webkit-font-smoothing: antialiased;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
  image-rendering: -webkit-optimize-contrast;
  -ms-interpolation-mode: bicubic;
}
a { text-decoration: none; color: inherit; }

h1,h2,h3,h4 { font-family: var(--serif); font-weight: 300; line-height: 1.2; }

.eyebrow {
  display: block;
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--terracota);
  font-weight: 400;
  margin-bottom: 16px;
}

/* =============================================
   BOTÕES
   ============================================= */
.btn-primary {
  display: inline-block;
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--creme);
  background: var(--terracota);
  padding: 14px 28px;
  font-weight: 400;
  border: none;
  cursor: pointer;
  transition: background .2s;
  text-decoration: none;
}
.btn-primary:hover { background: #7a5c53; color: var(--creme); }

.btn-ghost {
  display: inline-block;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  border-bottom: 0.5px solid var(--terracota-light);
  padding-bottom: 2px;
  background: none;
  border-top: none; border-left: none; border-right: none;
  cursor: pointer;
  transition: color .2s;
}
.btn-ghost:hover { color: var(--terracota); }

/* =============================================
   HEADER
   ============================================= */
#masthead, .site-header {
  display: flex !important;
  justify-content: space-between;
  align-items: center;
  padding: 20px 48px !important;
  border-bottom: 0.5px solid var(--borda);
  background: var(--creme) !important;
  position: sticky;
  top: 0;
  z-index: 100;
}
.site-branding .site-title {
  font-family: var(--sans);
  font-size: 13px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--marrom);
  font-weight: 300;
}
.site-branding .site-description {
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 2px;
  text-transform: uppercase;
}
.main-header-menu .menu-item a {
  font-size: 12px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--muted) !important;
  font-weight: 300;
  padding: 0 16px !important;
}
.main-header-menu .menu-item a:hover { color: var(--terracota) !important; }
.menu-item.menu-cta a {
  color: var(--creme) !important;
  background: var(--terracota);
  padding: 10px 22px !important;
}
.menu-item.menu-cta a:hover { background: #7a5c53 !important; }

/* =============================================
   STRIP
   ============================================= */
.ra-strip {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  border-top: 0.5px solid var(--borda);
  border-bottom: 0.5px solid var(--borda);
  background: var(--creme);
}
.ra-strip-item {
  padding: 18px 36px;
  font-size: 10px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 300;
  border-right: 0.5px solid var(--borda);
}
.ra-strip-item:last-child { border-right: none; }

/* =============================================
   HERO
   ============================================= */
.ra-hero { display: grid; grid-template-columns: 1fr 1fr; min-height: 520px; }

.ra-hero-left {
  padding: 80px 56px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-right: 0.5px solid var(--borda);
  background: var(--creme);
}
.ra-hero-title {
  font-size: 50px;
  font-weight: 300;
  line-height: 1.15;
  color: var(--marrom);
  margin-bottom: 28px;
  font-family: var(--serif);
}
.ra-hero-title em { font-style: italic; color: var(--terracota); }
.ra-hero-sub {
  font-size: 13px;
  color: var(--texto);
  line-height: 1.9;
  margin-bottom: 40px;
  font-weight: 300;
  max-width: 360px;
}
.ra-hero-actions { display: flex; align-items: center; gap: 24px; }

.ra-hero-right {
  background: var(--creme-mid);
  overflow: hidden;
  position: relative;
}
.ra-hero-right img {
  width: 100%;
  height: 100%;
  min-height: 520px;
  object-fit: cover;
  object-position: center 10%;
  image-rendering: auto;
  will-change: transform;
}
.ra-hero-stat {
  position: absolute;
  bottom: 28px;
  left: 28px;
  background: rgba(249,243,238,0.92);
  padding: 14px 20px;
}
.ra-hero-stat-num {
  font-size: 32px;
  font-family: var(--serif);
  font-weight: 300;
  color: var(--terracota);
  line-height: 1;
}
.ra-hero-stat-label {
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 4px;
}

/* =============================================
   SEÇÕES GENÉRICAS
   ============================================= */
.ra-section { padding: 80px 56px; background: var(--creme); }
.ra-section-header { margin-bottom: 48px; }
.ra-sec-title {
  font-size: 36px;
  font-family: var(--serif);
  font-weight: 300;
  color: var(--marrom);
  line-height: 1.2;
}
.ra-sec-title em { font-style: italic; color: var(--terracota); }

/* =============================================
   SINTOMAS
   ============================================= */
.ra-sintomas-list { display: flex; flex-direction: column; }
.ra-sintoma-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 0;
  border-bottom: 0.5px solid var(--borda);
}
.ra-sintoma-row:first-child { border-top: 0.5px solid var(--borda); }
.ra-sintoma-num {
  font-size: 12px;
  color: var(--terracota-light);
  font-family: var(--serif);
  width: 32px;
  flex-shrink: 0;
}
.ra-sintoma-text {
  font-size: 14px;
  color: var(--texto);
  font-weight: 300;
  flex: 1;
  padding: 0 24px;
}
.ra-sintoma-arrow { font-size: 14px; color: var(--terracota-light); }

/* =============================================
   ESPECIALIDADES
   ============================================= */
.ra-espec-section { background: var(--creme-mid); }
.ra-espec-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: #d4c0ad;
  margin-top: 48px;
}
.ra-espec-card {
  padding: 48px 40px;
  background: var(--creme-mid);
  transition: background .2s;
}
.ra-espec-card:hover { background: #e4d4c0; }
.ra-espec-n {
  display: block;
  font-size: 11px;
  color: #b09080;
  letter-spacing: 2px;
  font-family: var(--serif);
  margin-bottom: 20px;
}
.ra-espec-title {
  font-size: 26px;
  font-family: var(--serif);
  font-weight: 300;
  color: var(--marrom);
  margin-bottom: 14px;
}
.ra-espec-desc {
  font-size: 13px;
  color: var(--texto);
  line-height: 1.8;
  font-weight: 300;
}
.ra-espec-link {
  display: inline-block;
  margin-top: 24px;
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--terracota);
  border-bottom: 0.5px solid rgba(141,110,99,0.4);
  padding-bottom: 2px;
}

/* =============================================
   SOBRE
   ============================================= */
.ra-sobre { display: grid; grid-template-columns: 1fr 1fr; }
.ra-sobre-img { overflow: hidden; min-height: 500px; }
.ra-sobre-img img {
  width: 100%;
  height: 100%;
  min-height: 500px;
  object-fit: cover;
  object-position: center 15%;
  image-rendering: auto;
  will-change: transform;
}
.ra-sobre-content {
  padding: 80px 56px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: var(--creme);
  border-left: 0.5px solid var(--borda);
}
.ra-sobre-quote {
  font-size: 24px;
  font-family: var(--serif);
  font-style: italic;
  color: var(--terracota);
  line-height: 1.5;
  margin-bottom: 32px;
}
.ra-sobre-text {
  font-size: 13px;
  color: var(--texto);
  line-height: 1.9;
  font-weight: 300;
  margin-bottom: 12px;
}
.ra-credenciais { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 32px; }
.ra-cred {
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--terracota);
  padding: 6px 14px;
  border: 0.5px solid rgba(141,110,99,0.35);
}

/* =============================================
   LOCALIZAÇÃO
   ============================================= */
.ra-local-section { padding: 80px 56px; background: var(--creme-mid); }
.ra-local-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
  margin-top: 48px;
}
.ra-local-info p {
  font-size: 13px;
  color: var(--texto);
  line-height: 1.9;
  font-weight: 300;
  margin-bottom: 20px;
}
.ra-local-info strong { color: var(--marrom); font-weight: 400; }
.ra-local-map iframe {
  width: 100%;
  height: 300px;
  border: 0.5px solid var(--terracota-light);
  display: block;
}
.ra-convenio {
  margin-top: 28px;
  padding-top: 28px;
  border-top: 0.5px solid #d4c0ad;
}
.ra-convenio p {
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 8px;
}
.ra-convenio strong {
  font-size: 14px;
  color: var(--marrom);
  font-weight: 300;
  letter-spacing: 1px;
}

/* =============================================
   CTA FINAL
   ============================================= */
.ra-cta {
  padding: 100px 56px;
  text-align: center;
  background: var(--marrom);
}
.ra-cta .eyebrow { color: #c9a98a; }
.ra-cta-title {
  font-size: 52px;
  font-family: var(--serif);
  font-weight: 300;
  color: var(--creme);
  line-height: 1.2;
  margin-bottom: 36px;
}
.ra-cta-title em { font-style: italic; color: #c9a98a; }
.ra-cta .btn-primary { font-size: 12px; padding: 16px 36px; letter-spacing: 2.5px; }
.ra-cta-phone {
  display: block;
  font-size: 18px;
  font-family: var(--serif);
  color: #c9a98a;
  margin-top: 28px;
  letter-spacing: 1px;
}

/* =============================================
   FOOTER
   ============================================= */
.site-footer, #colophon {
  display: flex !important;
  justify-content: space-between;
  align-items: center;
  padding: 24px 48px !important;
  border-top: 0.5px solid var(--borda) !important;
  background: var(--creme) !important;
}
.site-footer p, #colophon p {
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 1px;
  font-weight: 300;
}

/* =============================================
   ASTRA OVERRIDES
   ============================================= */
.ast-breadcrumbs-wrapper,
.ast-above-header-wrap,
.ast-below-header-wrap { display: none !important; }
.entry-title        { display: none; }
.site-content       { padding: 0 !important; }
.ast-container      { max-width: 100% !important; padding: 0 !important; }
.entry-content      { margin: 0 !important; padding: 0 !important; }

/* =============================================
   RESPONSIVO — TABLET (≤900px)
   ============================================= */
@media (max-width: 900px) {
  .ra-hero, .ra-sobre { grid-template-columns: 1fr; }
  .ra-hero-left       { padding: 56px 32px; }
  .ra-hero-title      { font-size: 36px; }
  .ra-hero-right img  { min-height: 360px; }
  .ra-espec-grid      { grid-template-columns: 1fr; }
  .ra-local-grid      { grid-template-columns: 1fr; gap: 40px; }
  .ra-sobre-content   { padding: 56px 32px; }
  .ra-section, .ra-local-section { padding: 56px 32px; }
  .ra-cta             { padding: 72px 32px; }
  .ra-cta-title       { font-size: 36px; }
  #masthead, .site-header { padding: 16px 24px !important; }
}

/* =============================================
   RESPONSIVO — MOBILE (≤600px)
   ============================================= */
@media (max-width: 600px) {
  .ra-hero-title     { font-size: 28px; }
  .ra-hero-actions   { flex-direction: column; align-items: flex-start; }
  .ra-cta-title      { font-size: 28px; }
  .ra-espec-card     { padding: 32px 24px; }
  .ra-sobre-quote    { font-size: 20px; }
  .site-footer, #colophon { flex-direction: column; gap: 8px; text-align: center; }
}
