/*
Theme Name: Dra. Karina Mello — Oftalmologia
Theme URI: https://karinamello.com.br
Author: Dra. Karina Mello
Description: Tema institucional one-page para a Dra. Karina Mello, oftalmologista em Campo Grande/MS. Paleta creme/dourado com tipografia serifada.
Version: 1.0.0
License: GPL-2.0-or-later
Text Domain: karina-mello
*/

/* =========================
   Design tokens
========================= */
:root{
  --background:#fbf8f1;
  --foreground:#2a2620;
  --card:#fdfbf5;
  --muted:#f1ece1;
  --muted-foreground:#7a705f;
  --border:#e6dfcd;
  --gold:#b8924a;
  --gold-soft:#d9bf86;
  --gold-strong:#9c7a36;
  --primary-foreground:#fdfbf5;
  --cream:#f7f1e3;
  --sand:#ece2c8;
  --gradient-gold:linear-gradient(135deg,#d9bf86,#b8924a);
  --gradient-cream:linear-gradient(180deg,#fdfbf5,#f1ece1);
  --shadow-elegant:0 30px 60px -30px rgba(120,90,40,.25);
  --shadow-soft:0 8px 30px -10px rgba(120,90,40,.15);
  --radius:18px;

  --font-serif:"Cormorant Garamond","Playfair Display",Georgia,serif;
  --font-sans:"Jost","Inter",system-ui,sans-serif;
  --font-script:"Dancing Script",cursive;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--background);
  color:var(--foreground);
  font-family:var(--font-sans);
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-serif);font-weight:500;letter-spacing:-.01em;margin:0}
em{font-style:normal;color:var(--gold)}
.container{max-width:1180px;margin:0 auto;padding:0 24px}
.eyebrow{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold)}
.muted{color:var(--muted-foreground)}
.gold{color:var(--gold)}
.font-script{font-family:var(--font-script)}

.btn{
  display:inline-flex;align-items:center;gap:8px;
  border-radius:999px;padding:14px 28px;
  background:var(--gradient-gold);color:var(--primary-foreground);
  box-shadow:var(--shadow-elegant);
  font-size:14px;letter-spacing:.02em;
  transition:opacity .2s,transform .2s;
}
.btn:hover{opacity:.92}
.btn-ghost{
  display:inline-block;color:var(--foreground);font-size:14px;
  border-bottom:1px solid transparent;padding:6px 2px;
}
.btn-ghost:hover{color:var(--gold);border-color:var(--gold)}

.gold-divider{
  height:1px;max-width:280px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  margin:30px 0;
}

/* =========================
   Header / Navbar
========================= */
.site-header{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(10px);
  background:rgba(251,248,241,.85);
  border-bottom:1px solid var(--border);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  height:78px;
}
.brand{display:flex;flex-direction:column;line-height:1}
.brand-name{font-family:var(--font-serif);font-size:22px;color:var(--foreground)}
.brand-tag{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-top:4px}
.nav-links{display:none;align-items:center;gap:32px}
.nav-links a{font-size:14px;color:var(--muted-foreground);transition:color .2s}
.nav-links a:hover{color:var(--gold)}
.nav-toggle{
  background:none;border:0;font-size:24px;cursor:pointer;color:var(--foreground);
  display:block;padding:8px;
}
.mobile-nav{display:none;border-top:1px solid var(--border);background:var(--background);padding:16px 24px}
.mobile-nav.open{display:flex;flex-direction:column;gap:14px}
.mobile-nav a{color:var(--foreground);font-size:15px}
@media(min-width:1024px){
  .nav-links{display:flex}
  .nav-toggle{display:none}
  .mobile-nav{display:none!important}
}

/* =========================
   Hero
========================= */
.hero{position:relative;overflow:hidden;background:var(--gradient-cream)}
.hero::before,.hero::after{
  content:"";position:absolute;width:380px;height:380px;border-radius:50%;
  filter:blur(80px);opacity:.4;background:var(--gold-soft);pointer-events:none;
}
.hero::before{top:-120px;right:-120px}
.hero::after{bottom:-160px;left:-120px;opacity:.25}
.hero-inner{
  position:relative;display:grid;gap:48px;align-items:center;
  padding:80px 0 120px;
}
.hero h1{font-size:clamp(40px,6vw,72px);line-height:1.05;margin-top:24px}
.hero p.lead{font-size:18px;color:var(--muted-foreground);max-width:520px;margin-top:20px}
.hero-cta{margin-top:36px;display:flex;flex-wrap:wrap;gap:18px;align-items:center}
.hero-stats{margin-top:48px;display:flex;gap:32px;align-items:center;color:var(--muted-foreground);font-size:13px}
.hero-stats .stat-num{font-family:var(--font-serif);font-size:30px;color:var(--foreground);line-height:1}
.hero-stats .stat-lab{font-size:11px;letter-spacing:.2em;text-transform:uppercase;margin-top:6px}
.hero-divider{width:1px;height:42px;background:var(--border)}
.tag-pill{
  display:inline-flex;align-items:center;gap:8px;
  border:1px solid rgba(184,146,74,.3);background:rgba(253,251,245,.6);
  padding:6px 16px;border-radius:999px;
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);
}
.hero-image{position:relative}
.hero-image .glow{
  position:absolute;inset:-24px;background:var(--gradient-gold);
  opacity:.18;filter:blur(40px);border-radius:48px;
}
.hero-image .frame{
  position:relative;aspect-ratio:4/5;overflow:hidden;
  border-radius:32px;border:1px solid rgba(184,146,74,.2);
  box-shadow:var(--shadow-elegant);
}
.hero-image img{width:100%;height:100%;object-fit:cover}
.hero-caption{
  position:absolute;left:24px;right:24px;bottom:-24px;
  background:rgba(253,251,245,.95);backdrop-filter:blur(8px);
  border:1px solid rgba(184,146,74,.2);border-radius:18px;
  padding:18px 24px;box-shadow:var(--shadow-soft);
}
.hero-caption .script{font-family:var(--font-script);font-size:24px;color:var(--gold);line-height:1}
.hero-caption .serif{font-family:var(--font-serif);font-size:18px;margin-top:4px}
@media(min-width:1024px){
  .hero-inner{grid-template-columns:1fr 1fr;padding:120px 0 140px}
}

/* =========================
   Sections (About, Experience)
========================= */
.section{padding:96px 0}
.section.alt{background:var(--gradient-cream)}
.split{display:grid;gap:56px;align-items:center}
@media(min-width:1024px){
  .split{grid-template-columns:2fr 3fr}
  .split.reverse{grid-template-columns:3fr 2fr}
}
.section h2{font-size:clamp(32px,4.5vw,52px);margin-top:12px}
.figure{
  position:relative;aspect-ratio:4/5;overflow:hidden;
  border-radius:32px;border:1px solid rgba(184,146,74,.18);
  box-shadow:var(--shadow-elegant);
}
.figure img{width:100%;height:100%;object-fit:cover}
.figure-glow{position:relative}
.figure-glow::before{
  content:"";position:absolute;inset:-16px;border-radius:48px;
  background:var(--gradient-gold);opacity:.15;filter:blur(36px);
}
.section .copy p{color:var(--muted-foreground);margin:0 0 16px}
.quote{font-family:var(--font-serif);font-style:italic;font-size:20px;color:var(--foreground)}

.feature-grid{margin-top:36px;display:grid;gap:16px}
@media(min-width:640px){.feature-grid{grid-template-columns:repeat(3,1fr)}}
.feature-card{
  border:1px solid rgba(184,146,74,.2);background:var(--card);
  border-radius:18px;padding:20px;box-shadow:var(--shadow-soft);
}
.feature-card .t{font-family:var(--font-serif);color:var(--gold);font-size:15px}
.feature-card .d{font-size:13px;color:var(--muted-foreground);margin-top:4px}

/* Experience items */
.exp-items{margin-top:36px;display:grid;gap:20px}
@media(min-width:640px){.exp-items{grid-template-columns:1fr 1fr}}
.exp-item{display:flex;gap:16px}
.exp-icon{
  width:44px;height:44px;border-radius:50%;flex-shrink:0;
  border:1px solid rgba(184,146,74,.3);background:var(--card);
  display:flex;align-items:center;justify-content:center;color:var(--gold);
  font-size:18px;
}
.exp-item .t{font-family:var(--font-serif);font-size:18px}
.exp-item .d{font-size:14px;color:var(--muted-foreground);margin-top:2px}

/* =========================
   Services
========================= */
.services-grid{margin-top:56px;display:grid;gap:24px}
@media(min-width:768px){.services-grid{grid-template-columns:repeat(3,1fr)}}
.service-card{
  background:var(--card);border:1px solid rgba(184,146,74,.2);
  border-radius:24px;padding:32px;box-shadow:var(--shadow-soft);
  transition:transform .25s,box-shadow .25s;
}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-elegant)}
.service-icon{
  width:56px;height:56px;border-radius:50%;
  background:rgba(217,191,134,.15);border:1px solid rgba(184,146,74,.3);
  display:flex;align-items:center;justify-content:center;color:var(--gold);
  font-size:24px;
}
.service-card h3{font-size:24px;margin-top:24px}
.service-card .desc{font-size:14px;color:var(--muted-foreground);margin-top:12px;line-height:1.6}
.service-card ul{list-style:none;padding:0;margin:24px 0 0;display:flex;flex-direction:column;gap:8px}
.service-card li{font-size:14px;display:flex;gap:10px;align-items:flex-start;color:#3d3829}
.service-card li::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--gold);
  margin-top:8px;flex-shrink:0;
}

/* =========================
   FAQ
========================= */
.faq{max-width:760px;margin:0 auto;text-align:center}
.faq-list{margin-top:48px;display:flex;flex-direction:column;gap:12px;text-align:left}
.faq-item{
  border:1px solid rgba(184,146,74,.2);background:var(--card);
  border-radius:18px;box-shadow:var(--shadow-soft);
  padding:6px 24px;
}
.faq-item summary{
  list-style:none;cursor:pointer;font-family:var(--font-serif);
  font-size:18px;padding:18px 0;display:flex;justify-content:space-between;align-items:center;gap:16px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:var(--gold);font-size:22px;transition:transform .2s}
.faq-item[open] summary::after{content:"–"}
.faq-item summary:hover{color:var(--gold)}
.faq-item .answer{padding:0 0 20px;color:var(--muted-foreground);line-height:1.7}

/* =========================
   Contact
========================= */
.contact-card{
  position:relative;overflow:hidden;
  border:1px solid rgba(184,146,74,.25);background:var(--card);
  border-radius:40px;box-shadow:var(--shadow-elegant);
}
.contact-card::before{
  content:"";position:absolute;inset:0;background:var(--gradient-cream);opacity:.8;
}
.contact-card::after{
  content:"";position:absolute;top:-100px;right:-100px;width:280px;height:280px;
  border-radius:50%;background:var(--gold-soft);opacity:.4;filter:blur(80px);
}
.contact-inner{
  position:relative;padding:64px 48px;display:grid;gap:48px;align-items:center;
}
@media(min-width:1024px){.contact-inner{grid-template-columns:1fr 1fr;padding:80px 64px}}
.contact-rows{display:flex;flex-direction:column;gap:18px}
.contact-row{
  display:flex;align-items:center;gap:16px;
  border:1px solid rgba(184,146,74,.2);background:rgba(253,251,245,.8);
  backdrop-filter:blur(6px);border-radius:18px;padding:18px 20px;
  transition:border-color .2s;
}
.contact-row:hover{border-color:rgba(184,146,74,.5)}
.contact-row .ic{
  width:48px;height:48px;border-radius:50%;flex-shrink:0;
  background:rgba(217,191,134,.15);border:1px solid rgba(184,146,74,.3);
  color:var(--gold);display:flex;align-items:center;justify-content:center;font-size:20px;
}
.contact-row .lab{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-foreground)}
.contact-row .val{font-family:var(--font-serif);font-size:18px;margin-top:2px}

/* =========================
   Footer & FAB
========================= */
.site-footer{border-top:1px solid var(--border);background:var(--background)}
.footer-inner{
  display:flex;flex-direction:column;align-items:center;gap:18px;
  padding:48px 0;text-align:center;
}
@media(min-width:768px){.footer-inner{flex-direction:row;justify-content:space-between;text-align:left}}
.footer-script{font-family:var(--font-script);color:var(--gold);font-size:24px}
.footer-meta{font-size:12px;color:var(--muted-foreground)}

.fab{
  position:fixed;bottom:24px;right:24px;z-index:40;
  width:58px;height:58px;border-radius:50%;
  background:var(--gradient-gold);color:var(--primary-foreground);
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-elegant);font-size:26px;
  transition:transform .2s;
}
.fab:hover{transform:scale(1.07)}

/* WP-specific niceties */
.alignwide,.alignfull{max-width:100%}
.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}
