/* ===== ESPIRITAMARIA.PT — CSS PRINCIPAL ===== */
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@300;400;500;700&family=Roboto:ital,wght@0,300;0,400;0,700;1,400&family=Playfair+Display:ital,wght@0,400;0,700;1,400&display=swap');

:root {
  --roxo:        #663366;
  --roxo-escuro: #3d1e3e;
  --roxo-claro:  #8a4a8b;
  --roxo-med:    #7a3d7b;
  --dourado:     #b48c3c;
  --dourado-cl:  #d4aa5a;
  --preto:       #0a050a;
  --preto-soft:  #110d11;
  --cinza-esc:   #1a141a;
  --cinza:       #888;
  --cinza-clr:   #c0b0c0;
  --branco:      #fff;
  --creme:       #f5f0f5;
  --verde-wa:    #25D366;
  --verde-wa-dk: #1da851;
  --sombra:      rgba(99,50,100,.3);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; overflow-x:hidden; }
body {
  background:var(--preto);
  color:var(--creme);
  font-family:'Roboto',Arial,sans-serif;
  font-size:16px; line-height:1.85;
}

/* TIPOGRAFIA */
h1,h2,h3,h4 { font-family:'Oswald',sans-serif; font-weight:500; line-height:1.2; }
.playfair { font-family:'Playfair Display',serif; }
a { color:var(--roxo-claro); transition:color .2s; }
a:hover { color:var(--dourado); }

/* HEADER */
header {
  background:var(--preto-soft);
  border-bottom:2px solid var(--roxo);
  position:sticky; top:0; z-index:1000;
  padding:0 30px;
  display:flex; align-items:center; justify-content:space-between;
  min-height:70px;
  box-shadow:0 2px 15px var(--sombra);
  overflow:visible;
}
.logo { display:flex; align-items:center; gap:12px; text-decoration:none; }
.logo img { height:48px; }
.logo-txt { font-family:'Oswald',sans-serif; font-size:18px; color:var(--creme); letter-spacing:2px; line-height:1.2; }
.logo-txt span { color:var(--roxo-claro); display:block; font-size:11px; letter-spacing:3px; }

nav { display:flex; gap:2px; align-items:center; flex-wrap:nowrap; }
nav > a, nav > .nav-dropdown > .nav-drop-btn {
  font-family:'Oswald',sans-serif; font-size:13px; letter-spacing:1.5px;
  text-transform:uppercase; color:var(--cinza-clr); text-decoration:none;
  padding:6px 11px; border-radius:2px; transition:all .2s;
  white-space:nowrap;
}
nav > a:hover, nav > a.active { color:var(--branco); background:var(--roxo); }

/* DROPDOWN */
.nav-dropdown { position:relative; }
.nav-drop-btn {
  display:inline-flex; align-items:center; gap:5px;
  cursor:pointer; background:none; border:none;
  font-family:'Oswald',sans-serif; font-size:13px; letter-spacing:1.5px;
  text-transform:uppercase; color:var(--cinza-clr);
  padding:6px 11px; border-radius:2px; transition:all .2s;
  white-space:nowrap;
}
.nav-drop-btn svg { width:10px; height:10px; fill:currentColor; transition:transform .2s; flex-shrink:0; }
.nav-dropdown:hover .nav-drop-btn,
.nav-dropdown.open .nav-drop-btn { color:var(--branco); background:var(--roxo); }
.nav-dropdown.open .nav-drop-btn svg { transform:rotate(180deg); }

.nav-drop-menu {
  position:absolute; top:calc(100% + 6px); left:0;
  background:var(--preto-soft); border:1px solid rgba(102,51,153,.35);
  border-radius:4px; min-width:210px;
  box-shadow:0 8px 28px rgba(0,0,0,.55);
  opacity:0; visibility:hidden; transform:translateY(-6px);
  transition:all .2s; z-index:300;
}
.nav-dropdown:hover .nav-drop-menu,
.nav-dropdown.open .nav-drop-menu { opacity:1; visibility:visible; transform:translateY(0); }
.nav-drop-menu a {
  display:block; font-family:'Oswald',sans-serif; font-size:12px; letter-spacing:1.5px;
  text-transform:uppercase; color:var(--cinza-clr); text-decoration:none;
  padding:10px 16px; border-bottom:1px solid rgba(102,51,153,.12); transition:all .15s;
}
.nav-drop-menu a:last-child { border-bottom:none; }
.nav-drop-menu a:hover { color:var(--branco); background:var(--roxo); padding-left:22px; }

.btn-wa-hdr {
  display:inline-flex; align-items:center; gap:7px;
  background:var(--verde-wa); color:#fff;
  padding:9px 16px; border-radius:3px;
  font-family:'Oswald',sans-serif; font-size:12px; letter-spacing:1.5px;
  text-decoration:none; font-weight:600; transition:all .2s; white-space:nowrap;
}
.btn-wa-hdr:hover { background:var(--verde-wa-dk); color:#fff; transform:translateY(-1px); }

/* HAMBURGER */
.hamburger {
  display:none; flex-direction:column; gap:5px;
  cursor:pointer; padding:8px; background:none; border:none; z-index:200;
}
.hamburger span { display:block; width:26px; height:2px; background:var(--dourado); border-radius:2px; transition:all .3s; }
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* HERO */
.hero {
  background:linear-gradient(135deg, var(--roxo-escuro), var(--preto) 65%);
  padding:80px 30px; text-align:center; position:relative; overflow:hidden;
}
.hero::before {
  content:''; position:absolute; inset:0;
  background:url('images/rosa.jpg') center/cover no-repeat; opacity:.1;
}
.hero-inner { position:relative; z-index:1; max-width:820px; margin:0 auto; }
.hero-eyebrow { font-family:'Oswald',sans-serif; font-size:12px; letter-spacing:4px; color:var(--dourado); text-transform:uppercase; margin-bottom:20px; opacity:.9; }
.hero h1 { color:var(--branco); margin-bottom:18px; font-weight:700; font-size:clamp(30px,5vw,56px); }
.hero h1 span { color:var(--roxo-claro); }
.hero p { font-size:17px; color:var(--cinza-clr); margin-bottom:34px; line-height:1.95; }
.hero-ctas { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* SUBHEADER */
.subheader { background-size:cover; background-position:center; padding:70px 30px; text-align:center; position:relative; }
.subheader::before { content:''; position:absolute; inset:0; background:rgba(61,30,62,.78); }
.subheader-inner { position:relative; z-index:1; }
.subheader h1 { color:var(--branco); margin-bottom:10px; font-size:clamp(26px,4vw,42px); }
.subheader p  { color:var(--cinza-clr); max-width:600px; margin:0 auto; }

/* BOTÕES */
.btn-primario {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--roxo); color:var(--branco); padding:13px 28px;
  border-radius:3px; text-decoration:none; font-family:'Oswald',sans-serif;
  font-size:13px; letter-spacing:2px; font-weight:600; transition:all .3s;
  box-shadow:0 4px 15px var(--sombra);
}
.btn-primario:hover { background:var(--roxo-claro); color:#fff; transform:translateY(-2px); }
.btn-wa {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--verde-wa); color:#fff; padding:13px 28px;
  border-radius:3px; text-decoration:none; font-family:'Oswald',sans-serif;
  font-size:13px; letter-spacing:2px; font-weight:600; transition:all .3s;
  box-shadow:0 4px 15px rgba(37,211,102,.35);
}
.btn-wa:hover { background:var(--verde-wa-dk); color:#fff; transform:translateY(-2px); }
.btn-outline {
  display:inline-flex; align-items:center; gap:8px;
  border:2px solid var(--roxo); color:var(--creme); padding:11px 26px;
  border-radius:3px; text-decoration:none; font-family:'Oswald',sans-serif;
  font-size:13px; letter-spacing:2px; transition:all .3s;
}
.btn-outline:hover { background:var(--roxo); color:#fff; }

/* SECÇÕES */
.section { padding:60px 30px; }
.section-dark   { background:var(--preto-soft); }
.section-roxo   { background:var(--roxo-escuro); }
.section-light  { background:#f5f0f5; color:var(--preto); }
.section-light h2, .section-light h3, .section-light h4 { color:var(--roxo-escuro); }
.section-light p { color:#333; }
.section-light .section-subtitle { color:#666; }
.container { max-width:1100px; margin:0 auto; }
.text-center { text-align:center; }
.section-title { font-size:clamp(24px,3vw,36px); color:var(--branco); margin-bottom:12px; font-weight:700; }
.section-title.dark { color:var(--roxo-escuro); }
.section-subtitle { color:var(--cinza-clr); margin-bottom:40px; font-size:17px; }

/* CARDS */
.cards-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:20px; margin-top:36px; }
.card {
  background:var(--cinza-esc); border:1px solid rgba(102,51,102,.3);
  border-radius:4px; padding:28px 22px; transition:all .3s;
}
.card:hover { border-color:var(--roxo); transform:translateY(-4px); box-shadow:0 8px 25px var(--sombra); }
.card h4 { color:var(--creme); margin-bottom:10px; font-size:17px; }
.card p  { color:var(--cinza); font-size:15px; line-height:1.7; }
.card-icon { font-size:32px; margin-bottom:14px; display:block; }
.card-link { display:inline-block; margin-top:14px; font-family:'Oswald',sans-serif; font-size:12px; letter-spacing:2px; color:var(--roxo-claro); text-decoration:none; text-transform:uppercase; border-bottom:1px solid transparent; transition:border-color .2s; }
.card-link:hover { border-color:var(--roxo-claro); color:var(--roxo-claro); }

/* 2 COLUNAS */
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center; }
.two-col img { width:100%; border-radius:4px; border:3px solid var(--roxo); }
.two-col p { color:var(--cinza-clr); margin-bottom:16px; }
.two-col h2, .two-col h3 { color:var(--creme); margin-bottom:18px; }

/* QUOTE */
.quote-box {
  border-left:4px solid var(--roxo); padding:22px 28px;
  background:rgba(102,51,102,.1); margin:28px 0;
  font-family:'Playfair Display',serif; font-style:italic;
  font-size:19px; color:var(--creme); line-height:1.75;
}

/* TESTEMUNHOS */
.dep-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:22px; margin-top:36px; }
.dep-card {
  background:var(--cinza-esc); border:1px solid rgba(102,51,102,.2);
  border-radius:4px; padding:28px 24px; position:relative;
}
.dep-card::before { content:'"'; position:absolute; top:10px; left:16px; font-family:'Playfair Display',serif; font-size:56px; color:rgba(102,51,102,.25); line-height:1; }
.dep-stars { color:var(--dourado); font-size:15px; margin-bottom:12px; }
.dep-texto { color:var(--cinza-clr); font-style:italic; font-size:16px; line-height:1.75; margin-bottom:18px; }
.dep-autor { font-family:'Oswald',sans-serif; font-size:12px; letter-spacing:2px; color:var(--dourado); }
.dep-cidade { font-size:12px; color:var(--cinza); margin-top:3px; }
.dep-resultado { display:inline-block; margin-top:12px; background:rgba(102,51,102,.2); border:1px solid rgba(102,51,102,.4); color:var(--roxo-claro); font-family:'Oswald',sans-serif; font-size:10px; letter-spacing:2px; padding:4px 10px; border-radius:2px; }

/* LISTA SERVIÇOS */
.servicos-lista { list-style:none; }
.servicos-lista li { padding:10px 0 10px 26px; position:relative; color:var(--cinza-clr); border-bottom:1px solid rgba(102,51,102,.12); font-size:16px; }
.servicos-lista li::before { content:'✦'; position:absolute; left:0; color:var(--roxo-claro); font-size:10px; top:14px; }

/* CONTACTO */
.contact-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:28px; margin-top:36px; }
.contact-item { text-align:center; }
.contact-item .icon { font-size:34px; margin-bottom:10px; display:block; }
.contact-item h4 { color:var(--creme); margin-bottom:6px; font-size:15px; }
.contact-item a, .contact-item p { color:var(--cinza-clr); font-size:15px; text-decoration:none; }
.contact-item a:hover { color:var(--dourado); }

/* FORM */
.form-group { margin-bottom:16px; }
.form-group input, .form-group textarea, .form-group select {
  width:100%; padding:11px 14px; background:var(--cinza-esc);
  border:1px solid rgba(102,51,102,.35); border-radius:3px;
  color:var(--creme); font-size:15px; font-family:'Roboto',sans-serif; transition:border-color .2s;
}
.form-group input:focus, .form-group textarea:focus { outline:none; border-color:var(--roxo); }
.form-group textarea { min-height:130px; resize:vertical; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }

/* NÚMEROS */
.numeros { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:1px; background:rgba(102,51,102,.2); border-top:1px solid rgba(102,51,102,.2); border-bottom:1px solid rgba(102,51,102,.2); }
.numero-item { background:var(--preto); padding:36px 20px; text-align:center; }
.numero-item .num { font-family:'Oswald',sans-serif; font-size:40px; color:var(--dourado); margin-bottom:8px; }
.numero-item .lbl { font-family:'Oswald',sans-serif; font-size:11px; letter-spacing:2px; color:var(--cinza); text-transform:uppercase; }

/* WA FLUTUANTE */
.wa-float { position:fixed; bottom:25px; right:25px; z-index:1000; width:56px; height:56px; border-radius:50%; background:var(--verde-wa); display:flex; align-items:center; justify-content:center; box-shadow:0 4px 18px rgba(37,211,102,.5); text-decoration:none; animation:waPulse 2.5s infinite; transition:transform .2s; }
.wa-float:hover { transform:scale(1.1); }
.wa-float svg { width:28px; height:28px; fill:#fff; }
@keyframes waPulse { 0%,100% { box-shadow:0 4px 18px rgba(37,211,102,.5),0 0 0 0 rgba(37,211,102,.4); } 50% { box-shadow:0 4px 18px rgba(37,211,102,.5),0 0 0 12px rgba(37,211,102,0); } }
.tel-float { position:fixed; bottom:91px; right:25px; z-index:1000; width:56px; height:56px; border-radius:50%; background:var(--roxo); display:flex; align-items:center; justify-content:center; box-shadow:0 4px 18px var(--sombra); text-decoration:none; transition:transform .2s; }
.tel-float:hover { transform:scale(1.1); }
.tel-float svg { width:24px; height:24px; fill:#fff; }

/* FOOTER */
footer { background:var(--preto-soft); border-top:2px solid var(--roxo); padding:50px 30px 25px; }
.footer-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:38px; max-width:1100px; margin:0 auto 36px; }
.footer-col h4 { font-family:'Oswald',sans-serif; font-size:13px; letter-spacing:2px; text-transform:uppercase; color:var(--creme); margin-bottom:18px; padding-bottom:10px; border-bottom:1px solid rgba(102,51,102,.35); }
.footer-col p, .footer-col a { color:var(--cinza); font-size:14px; line-height:1.85; text-decoration:none; }
.footer-col a:hover { color:var(--dourado); }
.footer-social { display:flex; gap:10px; margin-top:10px; }
.footer-social a { width:34px; height:34px; border-radius:50%; background:rgba(102,51,102,.3); display:flex; align-items:center; justify-content:center; color:var(--cinza-clr); font-size:15px; text-decoration:none; transition:all .2s; border:1px solid rgba(102,51,102,.4); }
.footer-social a:hover { background:var(--roxo); color:#fff; }
.footer-copy { text-align:center; padding-top:22px; border-top:1px solid rgba(102,51,102,.18); color:rgba(180,170,180,.45); font-size:12px; line-height:1.7; max-width:1100px; margin:0 auto; }

/* CTA BOX */
.cta-box { background:linear-gradient(135deg,rgba(102,51,102,.2),rgba(0,0,0,.8)); border:1px solid rgba(102,51,102,.35); border-radius:4px; padding:50px 36px; text-align:center; margin:44px 0; position:relative; overflow:hidden; }
.cta-box::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,transparent,var(--roxo),transparent); }
.cta-box h3 { font-family:'Oswald',sans-serif; font-size:26px; color:var(--branco); margin-bottom:14px; }
.cta-box p { color:var(--cinza-clr); margin-bottom:28px; max-width:500px; margin-left:auto; margin-right:auto; }

/* RESPONSIVO */
@media (max-width:900px) {
  header { flex-wrap:wrap; padding:12px 20px; gap:10px; }
  .hamburger { display:flex; }
  nav {
    display:none; width:100%; flex-direction:column; gap:0;
    background:var(--preto-soft); border-top:1px solid rgba(102,51,153,.25);
    padding:8px 0 16px; order:3; max-height:80vh; overflow-y:auto;
  }
  nav.open { display:flex; }
  nav > a {
    font-size:13px; padding:12px 20px;
    border-bottom:1px solid rgba(102,51,153,.1); border-radius:0;
    letter-spacing:1.5px;
  }
  .nav-dropdown { width:100%; }
  .nav-drop-btn {
    width:100%; justify-content:space-between;
    font-size:13px; padding:12px 20px; border-radius:0;
    border-bottom:1px solid rgba(102,51,153,.1);
  }
  .nav-drop-menu {
    position:static; opacity:1; visibility:hidden; transform:none;
    max-height:0; overflow:hidden; box-shadow:none; border:none; border-radius:0;
    background:rgba(102,51,153,.08); transition:max-height .3s ease;
  }
  .nav-dropdown.open .nav-drop-menu { visibility:visible; max-height:600px; }
  .nav-drop-menu a { font-size:12px; padding:10px 20px 10px 34px; border-bottom:1px solid rgba(102,51,153,.08); }
  .nav-drop-menu a:hover { padding-left:40px; }
  .btn-wa-hdr { font-size:11px; padding:8px 12px; }
}
@media (max-width:700px) {
  .two-col { grid-template-columns:1fr; }
  .form-grid { grid-template-columns:1fr; }
  .hero { padding:55px 20px; }
  .section { padding:44px 20px; }
  .wa-float { bottom:15px; right:15px; }
  .tel-float { bottom:81px; right:15px; }
  .cta-box { padding:36px 20px; }
}
@media (max-width:480px) { .btn-wa-hdr { display:none; } }
