/* ========== HerbiSaúde Central v3 (clean, responsive, no effects) ========== */
:root{
  --bg:#f6f8f7;
  --panel:#ffffff;
  --ink:#0e2a21;
  --muted:#6a7e77;
  --border:#d7e1dd;
  --brand:#14795f;
  --brand-2:#0b3f31;
  --danger:#c9363b;
  --radius:16px;
  --radius-sm:12px;
  --space:clamp(16px, 2vw, 24px);
  --container: min(1200px, 100% - 2*var(--space));
  --fs-1: clamp(18px, 1.6vw, 20px);
  --fs-2: clamp(20px, 1.9vw, 24px);
  --fs-3: clamp(26px, 2.6vw, 34px);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Inter, Arial, sans-serif;
  color:var(--ink);
  background: var(--bg);
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

.view{display:none; min-height:100dvh}
.view.visible{display:block}

.brand, .brand-sm{font-weight:800; letter-spacing:.2px; margin:0}
.brand span, .brand-sm span{color:var(--brand)}

.topbar{
  position:sticky; top:0;
  display:flex; align-items:center; justify-content:space-between;
  padding: var(--space);
  background: var(--panel);
  border-bottom:1px solid var(--border);
}
.topbar-left{display:flex; align-items:center; gap:12px; min-width:0}
.heading{margin:0; font-weight:700; font-size:var(--fs-1); white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.sep{width:1px; height:22px; background:var(--border)}

.topbar-right{display:flex; gap:10px; flex-wrap:wrap}

.container{width: var(--container); margin-inline:auto; padding-block: calc(var(--space) * .75)}

.intro h4{margin:0 0 6px; font-size:var(--fs-1); font-weight:700}
.muted{color:var(--muted)}

.grid{
  display:grid; gap:16px;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  margin-top: var(--space);
}

.card{
  background: var(--panel);
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px;
  display:flex; flex-direction:column; gap:10px;
}
.card h5{margin:0; font-size:var(--fs-1)}
.card p{margin:0; color:var(--muted); word-break:break-all}
.card .controls{display:flex; gap:8px; flex-wrap:wrap; margin-top:4px}

.btn{
  appearance:none; border:1px solid transparent; border-radius:10px;
  padding:10px 14px; font-weight:700; cursor:pointer; background:transparent; color:var(--ink);
}
.btn:focus{outline:2px solid var(--brand); outline-offset:2px}
.btn-solid{background: var(--brand); color:white; border-color:var(--brand)}
.btn-outline{border-color:var(--border); background:#fff}
.btn-danger{background: var(--danger); color:white; border-color:var(--danger)}

.file{position:relative; overflow:hidden}
.file input{position:absolute; inset:0; opacity:0; cursor:pointer}

.footer{
  padding: var(--space); text-align:center; color:var(--muted);
  border-top:1px solid var(--border); background:var(--panel);
}

.auth{
  width: var(--container);
  margin-inline:auto;
  padding: clamp(32px, 6vw, 64px) var(--space);
  display:grid; gap:12px;
  max-width:520px;
  background: var(--panel);
  border:1px solid var(--border);
  border-radius: var(--radius);
  margin-top: min(12vh, 10rem);
}
.subtitle{margin:0 0 8px; color:var(--muted)}
.label{font-size:.95rem; color:var(--muted)}
input{
  padding:12px 14px; border-radius:10px; border:1px solid var(--border);
  width:100%; font-size:1rem;
}

/* Dialog */
dialog{border:0; padding:0; background:transparent}
.dialog-card{
  width:min(520px, 96vw);
  background: var(--panel); border:1px solid var(--border); border-radius: var(--radius);
  padding:18px;
}
.dialog-card h3{margin:0 0 12px}
.row{display:grid; gap:6px; margin-bottom:12px}
.actions{display:flex; justify-content:flex-end; gap:8px}


/* === Botões pill idênticos ao PixFlex === */
:root{
  --px-card: #141823;
  --px-text: #9aa5b1;
  --px-muted: #9aa5b1;
  --px-ring: #22d3ee; /* default fallback */
  --px-bradesco: #CC092F;
  --px-caixa: #0C79C1;
  --px-bb: #FFCC00;
  --px-bb-accent: #1A3C8A;
  --px-nu: #820AD1;
  --px-pags: #00C34E;
}

/* base do pill */
.btn-hero{
  position:relative;
  isolation:isolate;
  display:flex; align-items:center; justify-content:center;
  gap:10px;
  height:84px;
  border-radius:999px;
  text-decoration:none;
  background: var(--px-card);
  border:1px solid rgba(255,255,255,.06);
  color: var(--px-text);
  overflow:hidden;
  padding:0 18px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  box-shadow: 0 10px 24px rgba(0,0,0,.25);
}
.btn-hero__label{display:flex; flex-direction:column; align-items:center; text-align:center}
.btn-hero strong{font-size:18px; letter-spacing:.2px}
.btn-hero small{color:var(--px-muted)}
.btn-hero:hover{ transform: translateY(-2px); border-color: rgba(255,255,255,.14) }

/* pulse ring (hover) */
.pulse .btn-hero__ring{
  position:absolute; inset:0;
  border-radius:inherit;
  z-index:-1;
  background: radial-gradient(60% 60% at 50% 50%, var(--ring, var(--px-ring)) 0%, transparent 70%);
  opacity:.0;
  transform: scale(.9);
  transition: opacity .25s ease, transform .25s ease;
  filter: blur(12px);
}
.pulse::after, .pulse::before{
  content:""; position:absolute; inset:-2px; border-radius:inherit; z-index:-2;
  background: conic-gradient(from 180deg, transparent, var(--ring, var(--px-ring)), transparent 60%);
  opacity:.0; transform: rotate(0deg);
  transition: opacity .25s ease;
}
.pulse:hover .btn-hero__ring{ opacity:.8; transform: scale(1) }
.pulse:hover::after{ animation: spin 1.8s linear infinite; opacity:.25 }
.pulse:hover::before{ animation: spin 2.4s linear infinite reverse; opacity:.15 }
@keyframes spin { to { transform: rotate(360deg) } }

/* variações (exatamente como no modelo) */
.btn-hero--bradesco{ --ring: var(--px-bradesco); background:
  linear-gradient(180deg, rgba(204,9,47,.18), rgba(204,9,47,.04)) , var(--px-card);
}
.btn-hero--caixa{ --ring: var(--px-caixa); background:
  linear-gradient(180deg, rgba(12,121,193,.18), rgba(12,121,193,.04)) , var(--px-card);
}
.btn-hero--bb{ --ring: var(--px-bb); background:
  linear-gradient(180deg, rgba(255,204,0,.22), rgba(26,60,138,.05)) , var(--px-card);
}
.btn-hero--nubank{ --ring: var(--px-nu); background:
  linear-gradient(180deg, rgba(130,10,209,.22), rgba(130,10,209,.05)) , var(--px-card);
}
.btn-hero--pagseguro{ --ring: var(--px-pags); background:
  linear-gradient(180deg, rgba(0,195,78,.22), rgba(0,195,78,.05)) , var(--px-card);
}

/* responsivo */
@media (max-width:560px){
  .btn-hero{ height:72px }
  .btn-hero strong{ font-size:17px }
}
