/* Sandra do Leite - Site institucional (HTML) */
/* Tema claro + feminino (paleta: #C2185B, #F8BBD0, #E91E63, #FFFFFF) */

:root{
  --bg:#ffffff;
  --panel:#ffffff;
  --panel2:#fff3f8;

  --fg:#0b0d10;
  --muted:#334155;
  --muted2:#64748b;

  --brand:#E91E63;
  --brand2:#C2185B;
  --brandSoft:#F8BBD0;

  --success:#16a34a;
  --danger:#e11d48;

  --border:rgba(15, 23, 42, .12);
  --shadow: 0 18px 50px rgba(2, 6, 23, .10);

  --radius: 18px;
  --radius2: 26px;
  --max: 1120px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  color:var(--fg);
  background:
    radial-gradient(900px 520px at 18% 0%, rgba(248,187,208,.55), transparent 55%),
    radial-gradient(760px 520px at 90% 10%, rgba(233,30,99,.12), transparent 55%),
    radial-gradient(760px 520px at 70% 85%, rgba(194,24,91,.10), transparent 60%),
    linear-gradient(180deg, #ffffff 0%, #fff7fb 100%);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
  line-height:1.55;
}

a{color:inherit; text-decoration:none}
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible{
  outline:3px solid rgba(233,30,99,.35);
  outline-offset:2px;
  border-radius:12px;
}

.container{
  max-width:var(--max);
  margin:0 auto;
  padding: 0 18px;
}

.skip-link{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip-link:focus{
  left:18px; top:14px; width:auto; height:auto;
  padding:10px 12px;
  background:rgba(255,255,255,.92);
  border:1px solid var(--border);
  border-radius:12px;
  z-index:9999;
}

/* Header */
.header{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(10px);
  background:rgba(255,255,255,.78);
  border-bottom:1px solid var(--border);
}
.header-inner{
  display:grid;
  grid-template-columns: auto 1fr auto;
  align-items:center;
  padding: 14px 0;
  gap:14px;
}

/* Brand */
.brand{
  display:flex; align-items:center; gap:10px;
  min-width: 210px;
}
.brand-mark{
  width:38px; height:38px;
  border-radius:14px;
  background:
    radial-gradient(14px 14px at 30% 30%, rgba(255,255,255,.65), transparent 55%),
    linear-gradient(135deg, rgba(233,30,99,1) 0%, rgba(194,24,91,1) 60%, rgba(248,187,208,1) 100%);
  box-shadow: 0 10px 26px rgba(233,30,99,.16);
  border:1px solid rgba(233,30,99,.18);
}
.brand-text strong{display:block; font-size:14px; letter-spacing:.2px}
.brand-text span{display:block; font-size:12px; color:var(--muted2); margin-top:-2px}

/* Nav */
.nav{
  display:flex; align-items:center;
  gap:10px;
  flex-wrap:nowrap;
  justify-content:center;
  overflow:hidden;
}
.nav a{white-space:nowrap}
.nav a{
  padding:8px 9px;
  border-radius:999px;
  color:var(--muted);
  border:1px solid transparent;
  font-size:12.5px;
}
.nav a:hover{
  color:var(--fg);
  background:rgba(233,30,99,.08);
  border-color:rgba(233,30,99,.18);
}
.nav a.active{
  color:var(--brand2);
  background:rgba(248,187,208,.45);
  border-color:rgba(233,30,99,.22);
}

/* Buttons */
.header-cta{
  display:flex; align-items:center; gap:10px;
  justify-content:flex-end;
}
.btn{
  display:inline-flex;
  align-items:center; justify-content:center;
  gap:10px;
  padding: 11px 14px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.85);
  color:var(--fg);
  font-weight:800;
  font-size:13px;
  letter-spacing:.2px;
  cursor:pointer;
  transition: transform .12s ease, background .12s ease, border-color .12s ease, box-shadow .12s ease;
}
.btn:hover{
  transform: translateY(-1px);
  background:rgba(248,187,208,.28);
  border-color:rgba(233,30,99,.22);
  box-shadow: 0 10px 26px rgba(233,30,99,.10);
}
.btn.primary{
  background:linear-gradient(135deg, rgba(233,30,99,1) 0%, rgba(194,24,91,1) 100%);
  border-color:rgba(194,24,91,.35);
  color:#fff;
}
.btn.primary:hover{
  background:linear-gradient(135deg, rgba(233,30,99,1) 0%, rgba(194,24,91,1) 100%);
  box-shadow: 0 14px 30px rgba(233,30,99,.22);
}
.btn.ghost{background:transparent;}
.btn.small{padding:8px 12px; font-size:12px}
.btn.whatsapp{
  background:#25D366;
  border-color: rgba(0,0,0,.08);
  color:#0b0d10;
}
.btn.whatsapp:hover{
  background:#22c55e;
  border-color: rgba(0,0,0,.10);
  box-shadow: 0 14px 30px rgba(34,197,94,.20);
}

/* Mobile */
.mobile-toggle{display:none}
@media (max-width: 920px){
  .brand{min-width:auto}
  .nav{display:none}
  .mobile-toggle{display:inline-flex}
  .header-inner{padding: 12px 0}
}
.mobile-panel{
  display:none;
  border-top:1px solid var(--border);
}
.mobile-panel.open{display:block}
.mobile-panel .nav{
  display:flex;
  justify-content:flex-start;
  padding: 10px 0 16px;
}
.mobile-panel .nav a{padding:10px 12px}

/* Hero */
.hero{padding: 56px 0 26px;}
.hero-grid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:22px;
  align-items:stretch;
}
@media (max-width: 920px){
  .hero{padding: 34px 0 18px}
  .hero-grid{grid-template-columns: 1fr}
}
.kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 10px;
  background:rgba(248,187,208,.45);
  border:1px solid rgba(233,30,99,.22);
  border-radius:999px;
  color:var(--brand2);
  font-size:12px;
  font-weight:900;
}
.h1{
  font-size:44px;
  line-height:1.08;
  margin:14px 0 10px;
  letter-spacing:-.8px;
}
@media (max-width: 520px){.h1{font-size:34px}}
.lead{
  color:var(--muted);
  font-size:16px;
  margin: 0 0 18px;
  max-width: 64ch;
}
.hero-actions{display:flex; gap:12px; flex-wrap:wrap; margin: 16px 0 14px;}
.hero-meta{display:flex; gap:14px; flex-wrap:wrap; color:var(--muted2); font-size:12px; margin-top: 10px;}
.badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 10px;
  border:1px solid var(--border);
  border-radius:999px;
  background:rgba(255,255,255,.75);
}

/* Cards */
.hero-card{
  border:1px solid var(--border);
  border-radius:var(--radius2);
  background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,243,248,.92));
  box-shadow: var(--shadow);
  overflow:hidden;
  display:flex; flex-direction:column;
}
.hero-card .photo{
  height: 260px;
  background:
    radial-gradient(120px 120px at 18% 20%, rgba(233,30,99,.10), transparent 55%),
    radial-gradient(180px 180px at 80% 40%, rgba(194,24,91,.10), transparent 60%),
    linear-gradient(135deg, rgba(248,187,208,.55), rgba(255,255,255,.70));
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:flex-end;
  padding: 18px;
}
.photo .photo-tag{
  font-size:12px;
  color:var(--muted);
  background:rgba(255,255,255,.75);
  border:1px solid var(--border);
  padding:8px 10px;
  border-radius:999px;
}
.hero-card .card-body{padding:18px}
.card-title{font-weight:900; letter-spacing:-.2px; margin:0 0 10px; font-size:16px}
.card-text{margin:0; color:var(--muted); font-size:14px}
.card-list{margin:14px 0 0; padding:0; list-style:none; display:grid; gap:10px;}
.card-list li{
  display:flex; gap:10px; align-items:flex-start;
  padding:10px 12px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.70);
  border-radius:14px;
}
.dot{
  width:10px; height:10px;
  border-radius:999px;
  background:var(--brand);
  margin-top:5px;
  flex:0 0 auto;
}
.card-list strong{display:block; font-size:13px}
.card-list span{display:block; color:var(--muted2); font-size:12px; margin-top:2px}

/* Sections */
.section{padding: 34px 0;}
.section-head{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:16px; flex-wrap:wrap;
  margin-bottom:16px;
}
.h2{margin:0; font-size:22px; letter-spacing:-.2px;}
.sub{margin:6px 0 0; color:var(--muted); max-width: 70ch; font-size:14px;}
.grid-3{display:grid; grid-template-columns: repeat(3, 1fr); gap:14px;}
@media (max-width: 920px){.grid-3{grid-template-columns: 1fr}}

.card{
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:rgba(255,255,255,.85);
  box-shadow: 0 10px 30px rgba(2,6,23,.06);
  padding: 16px;
}
.card h3{margin: 0 0 8px; font-size:15px; letter-spacing:-.2px;}
.card p{margin:0; color:var(--muted); font-size:14px;}

.pillrow{display:flex; gap:10px; flex-wrap:wrap; margin-top: 12px;}
.pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(233,30,99,.18);
  color:var(--muted);
  background:rgba(248,187,208,.25);
  font-size:12px;
}
.pill b{color:var(--brand2)}

/* Highlights */
.highlights{display:grid; grid-template-columns: 1.3fr .7fr; gap:14px;}
@media (max-width: 920px){.highlights{grid-template-columns:1fr}}
.panel{
  border:1px solid var(--border);
  border-radius:var(--radius2);
  background:rgba(255,255,255,.85);
  padding: 18px;
  box-shadow: 0 10px 30px rgba(2,6,23,.06);
}
.panel h3{margin:0 0 10px; font-size:16px}
.panel p{margin:0; color:var(--muted)}

.kpis{display:grid; grid-template-columns: repeat(2, 1fr); gap:12px;}
@media (max-width: 520px){.kpis{grid-template-columns:1fr}}
.kpi{
  padding: 14px 14px;
  border-radius:18px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.80);
}
.kpi .num{font-size:20px; font-weight:900; letter-spacing:-.4px; color: var(--brand2);}
.kpi .lbl{margin-top:2px; color:var(--muted2); font-size:12px;}

/* Lists */
.list{margin: 10px 0 0; padding: 0; list-style:none; display:grid; gap:10px;}
.item{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding: 14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.85);
  border-radius:18px;
  box-shadow: 0 10px 26px rgba(2,6,23,.05);
}
.item .icon{
  width:38px; height:38px; border-radius:16px;
  background:rgba(248,187,208,.55);
  border:1px solid rgba(233,30,99,.18);
  display:flex; align-items:center; justify-content:center;
  font-weight:900;
  color: var(--brand2);
}
.item h4{margin:0; font-size:14px}
.item p{margin:4px 0 0; color:var(--muted); font-size:13px}

/* CTA band */
.cta{padding: 28px 0 44px;}
.cta-wrap{
  border:1px solid rgba(233,30,99,.16);
  border-radius:var(--radius2);
  background:
    radial-gradient(500px 280px at 20% 10%, rgba(248,187,208,.60), transparent 65%),
    radial-gradient(420px 260px at 90% 50%, rgba(233,30,99,.14), transparent 65%),
    linear-gradient(180deg, rgba(255,255,255,.90), rgba(255,255,255,.75));
  padding: 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
  box-shadow: 0 18px 50px rgba(233,30,99,.08);
}
.cta-wrap h3{margin:0; font-size:18px}
.cta-wrap p{margin:6px 0 0; color:var(--muted); max-width:70ch}
.cta-actions{display:flex; gap:10px; flex-wrap:wrap}

/* Footer */
.footer{
  border-top:1px solid var(--border);
  padding: 26px 0 40px;
  color:var(--muted2);
  font-size:12px;
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:14px;
  align-items:start;
}
@media (max-width: 920px){.footer-grid{grid-template-columns:1fr}}
.footer a{color:var(--muted)}
.footer a:hover{color:var(--brand2)}
.footer small{display:block; margin-top:8px}
.footer .links{display:flex; flex-wrap:wrap; gap:10px; margin-top:10px;}

/* Forms */
.form{display:grid; gap:12px; margin-top: 12px;}
.field{display:grid; gap:6px;}
label{font-size:12px; color:var(--muted2)}
input, textarea, select{
  padding: 12px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.92);
  color:var(--fg);
  font-size:14px;
}
textarea{min-height: 120px; resize:vertical}
.hint{font-size:12px; color:var(--muted2)}
.checkbox{display:flex; gap:10px; align-items:flex-start;}
.checkbox input{margin-top:4px}

/* Utility */
.hr{height:1px; background:rgba(15, 23, 42, .10); margin:16px 0}
.note{
  border:1px solid rgba(233,30,99,.18);
  background:rgba(248,187,208,.25);
  border-radius:16px;
  padding: 12px 14px;
  color:var(--muted);
  font-size:13px;
}

/* Hero banner lateral (mantido por compatibilidade, caso use em outra pagina) */
.hero-banner{
  border:1px solid var(--border);
  border-radius:var(--radius2);
  background:
    radial-gradient(180px 180px at 20% 20%, rgba(233,30,99,.12), transparent 60%),
    radial-gradient(260px 260px at 80% 30%, rgba(248,187,208,.65), transparent 62%),
    radial-gradient(260px 260px at 70% 85%, rgba(194,24,91,.10), transparent 60%),
    linear-gradient(135deg, rgba(255,255,255,.88), rgba(255,243,248,.92));
  box-shadow: var(--shadow);
  overflow:hidden;
  height: clamp(280px, 28vw, 380px);
  position: relative;
}
.hero-banner-inner{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 18px;
}
.hero-banner-tag{
  font-size:12px;
  color:var(--muted);
  background:rgba(255,255,255,.82);
  border:1px solid var(--border);
  padding:10px 12px;
  border-radius:999px;
}
@media (max-width: 920px){
  .hero-banner{height: 260px;}
}

.section.tight{padding-top: 14px;}

/* Hero com imagem como background (sem degrade no topo) */
.hero.hero-bg{
  position: relative;
  min-height: 360px;
  background-image: var(--hero-img, url('/assets/img/hero-sandra.jpg'));
  background-size: cover;
  background-position: right center;
  background-repeat: no-repeat;
  border-bottom: 1px solid var(--border);
}

/* Garante que nenhuma camada extra crie degrade */
.hero.hero-bg::before,
.hero.hero-bg::after{
  content: none !important;
  display: none !important;
}

.hero.hero-bg .hero-content{
  position: relative;
  z-index: 1;
  max-width: 680px;
}

@media (max-width: 920px){
  .hero.hero-bg{
    min-height: unset;
    background-image: var(--hero-img-mobile, var(--hero-img, url('/assets/img/hero-sandra.jpg')));
    background-position: center top;
  }
  .hero.hero-bg .hero-content{
    max-width: none;
  }
}
