/* Farmácia Boa Vista — landing page (static)
   Palette: dominant red, neutral grays, accessible contrast.
*/
:root{
  --bg: #ffffff;
  --text: #111827;
  --muted: #6b7280;
  --border: #e5e7eb;
  --card: #ffffff;
  --shadow: 0 12px 30px rgba(17,24,39,.08);

  --red: #d7262b;
  --red-600: #b91c1c;
  --red-50: #fff1f2;

  --radius: 18px;
  --radius-sm: 12px;
  --max: 1100px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--text);
  background:var(--bg);
  line-height:1.5;
}

a{color:inherit; text-decoration:none}
a:hover{opacity:.9}
code{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}

.container{
  width:min(var(--max), calc(100% - 2rem));
  margin-inline:auto;
}

.skip-link{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip-link:focus{
  left:1rem; top:1rem; width:auto; height:auto; padding:.5rem .75rem;
  background:var(--bg); border:1px solid var(--border); border-radius:10px; z-index:9999;
}

/* Header */
.header{
  position:sticky; top:0; z-index:100;
  background:rgba(255,255,255,.85);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--border);
}
.header__inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:.9rem 0;
  gap:1rem;
}
.brand{display:flex; align-items:center; gap:.75rem; padding:.35rem .55rem; border-radius:16px; background:rgba(255,255,255,.75); border:1px solid var(--border)}
.brand__logo{width:68px; height:68px}
.brand__name{font-weight:800; letter-spacing:-.02em}
.brand__meta{font-size:.9rem; color:var(--muted)}
.nav{
  display:flex; gap:1rem;
  font-size:.95rem;
  color:#374151;
}
.nav a{padding:.4rem .5rem; border-radius:10px}
.nav a:hover{background:#f3f4f6}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  border:1px solid var(--border);
  padding:.65rem .9rem;
  border-radius:999px;
  font-weight:700;
  background:var(--bg);
  transition: transform .06s ease, background .15s ease, border-color .15s ease;
}
.btn:active{transform: translateY(1px)}
.btn--primary{
  background:var(--red);
  border-color:var(--red);
  color:white;
}
.btn--primary:hover{background:var(--red-600); border-color:var(--red-600)}
.btn--ghost{
  background:transparent;
}
.btn--lg{padding:.85rem 1.1rem; font-size:1rem}

.header__cta{display:flex; gap:.5rem}

/* Hero */
.hero{
  background:
    url('assets/pattern-crosses.svg') center/cover no-repeat,
    radial-gradient(900px 340px at 18% 12%, var(--red-50), transparent 60%),
    radial-gradient(800px 360px at 92% 14%, #f3f4f6, transparent 55%);
  border-bottom:1px solid var(--border);
}
.hero__inner{
  padding:3rem 0 2.5rem;
  display:grid;
  grid-template-columns: 1.2fr .9fr;
  gap:2rem;
  align-items:start;
}
.badge{
  display:inline-block;
  background: #111827;
  color:#fff;
  padding:.35rem .6rem;
  border-radius:999px;
  font-size:.85rem;
  margin:0 0 1rem 0;
}
.hero h1{
  margin:.2rem 0 1rem 0;
  font-size: clamp(1.8rem, 3.6vw, 3rem);
  line-height:1.1;
  letter-spacing:-.03em;
}
.lead{
  margin:0 0 1.25rem 0;
  font-size:1.1rem;
  color:#374151;
  max-width: 58ch;
}
.hero__actions{display:flex; gap:.75rem; flex-wrap:wrap; margin: 0 0 1.1rem 0}

.hero__trust{
  display:flex; gap:1rem; flex-wrap:wrap;
  margin: 1rem 0 0 0;
}
.trust-item{
  border:1px solid var(--border);
  background: rgba(255,255,255,.7);
  padding:.7rem .8rem;
  border-radius: var(--radius-sm);
  min-width: 170px;
}
.trust-item__title{font-size:.85rem; color:var(--muted)}
.trust-item__value{font-weight:800}

.micro{font-size:.88rem}
.muted{color:var(--muted)}

.hero__card{
  background: var(--card);
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding:1.2rem 1.2rem 1.1rem;
  box-shadow: var(--shadow);
}
.hero__card h2{margin:.2rem 0 1rem 0; font-size:1.1rem}
.steps{margin:0 0 1rem 1.1rem; padding:0}
.steps li{margin:.4rem 0}

/* Sections */
.section{padding:3rem 0}
.section--alt{background:#fafafa; border-top:1px solid var(--border); border-bottom:1px solid var(--border)}
.section__head{margin:0 0 1.3rem 0}
.section__head h2{margin:0 0 .35rem 0; font-size:1.6rem; letter-spacing:-.02em}

.grid{display:grid; gap:1rem}
.cards{grid-template-columns: repeat(4, 1fr)}
.card{
  border:1px solid var(--border);
  border-radius: var(--radius);
  background: var(--card);
  padding:1.1rem;
  box-shadow: 0 1px 0 rgba(17,24,39,.02);
}
.card h3{margin:.1rem 0 .5rem 0}
.card p{margin:.2rem 0 0 0; color:#374151}

.inline-cta{
  margin-top:1.3rem;
  display:flex; align-items:center; gap:1rem; flex-wrap:wrap;
}

.howto{grid-template-columns: repeat(3, 1fr)}
.howto__item{
  border:1px solid var(--border);
  border-radius: var(--radius);
  background:white;
  padding:1.1rem;
}
.howto__num{
  width:36px; height:36px;
  border-radius:999px;
  background:var(--red);
  color:white;
  display:grid; place-items:center;
  font-weight:900;
  margin-bottom:.6rem;
}

.delivery{grid-template-columns: repeat(3, 1fr)}

.contact{
  display:grid;
  grid-template-columns: 1.3fr .7fr;
  gap:1rem;
  align-items:start;
}
.contact__main{display:grid; grid-template-columns: 1fr 1fr; gap:1rem}
.contact__card{
  border:1px solid var(--border);
  border-radius: var(--radius);
  background:white;
  padding:1.1rem;
}
.contact__value{font-size:1.2rem; font-weight:900; margin:.2rem 0 .8rem 0}
.contact__actions{display:flex; gap:.6rem; flex-wrap:wrap}
.link{color:var(--red); font-weight:800}
.list{list-style:none; padding:0; margin:.6rem 0 0 0}
.list li{display:flex; justify-content:space-between; padding:.45rem 0; border-bottom:1px dashed #e5e7eb}
.list li:last-child{border-bottom:none}

.final-cta{
  text-align:center;
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding:2rem 1.5rem;
  background: linear-gradient(180deg, #fff, #fff7f8);
}
.final-cta h2{margin:0 0 .5rem 0}
.final-cta p{margin:0 0 1rem 0}

/* Footer */
.footer{
  border-top:1px solid var(--border);
  padding:1.8rem 0 1.2rem;
}
.footer__inner{
  display:flex; justify-content:space-between; align-items:center;
  gap:1rem; flex-wrap:wrap;
}
.footer__brand{display:flex; align-items:center; gap:.75rem}
.footer__logo{width:40px; height:40px}
.footer__name{font-weight:900}
.footer__links{display:flex; gap:.9rem; flex-wrap:wrap; color:#374151}
.footer__links a:hover{color:var(--red)}
.footer__legal{margin-top:1rem}
.footer__legal p{margin:.25rem 0}

/* Responsive */
@media (max-width: 980px){
  .hero__inner{grid-template-columns: 1fr; }
  .visual__logo img{height:58px}

  .cards{grid-template-columns: repeat(2, 1fr)}
  .howto{grid-template-columns: 1fr}
  .delivery{grid-template-columns: 1fr}
  .contact{grid-template-columns: 1fr}
  .contact__main{grid-template-columns: 1fr}
  .nav{display:none}
}


/* Hero visual (illustration + highlighted logo) */
.hero__visual{display:flex; flex-direction:column; gap:1rem}
.visual{
  margin:0;
  background: rgba(255,255,255,.78);
  border:1px solid var(--border);
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: var(--shadow);
  position:relative;
}
.visual__img{display:block; width:100%; height:auto}
.visual__logo{
  position:absolute;
  left:18px; top:18px;
  background:#ffffff;
  border:1px solid var(--border);
  border-radius: 16px;
  padding:.55rem .65rem;
  box-shadow: 0 10px 24px rgba(17,24,39,.10);
}
.visual__logo img{display:block; height:68px; width:auto}
.section__img{
  width:100%;
  height:auto;
  border:1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 10px 24px rgba(17,24,39,.08);
  margin: 0 0 1.1rem 0;
}


/* Offers */
.offers{grid-template-columns: repeat(4, 1fr)}
.offer{
  border:1px solid var(--border);
  border-radius: var(--radius);
  background:#ffffff;
  padding:1.1rem;
  box-shadow: 0 10px 24px rgba(17,24,39,.06);
  position:relative;
  overflow:hidden;
}
.offer:before{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(500px 160px at 0% 0%, var(--red-50), transparent 60%);
  pointer-events:none;
}
.offer__tag{
  display:inline-block;
  font-size:.78rem;
  font-weight:800;
  color: #7f1d1d;
  background: #fff1f2;
  border:1px solid #fecdd3;
  padding:.25rem .5rem;
  border-radius:999px;
  margin-bottom:.6rem;
  position:relative;
}
.offer h3{margin:.2rem 0 .4rem 0; position:relative}
.offer p{margin:0 0 .65rem 0; color:#374151; position:relative}
.offer--highlight{
  background: linear-gradient(180deg, #fff, #fff7f8);
}
.offer--highlight .btn{position:relative}

/* Testimonials */
.testimonials{grid-template-columns: repeat(3, 1fr)}
.testimonial{
  border:1px solid var(--border);
  border-radius: var(--radius);
  background:#ffffff;
  padding:1.2rem;
  box-shadow: 0 10px 24px rgba(17,24,39,.06);
}
.stars{color: var(--red); font-weight:900; letter-spacing:.08em; margin-bottom:.5rem}
.quote{margin:.2rem 0 .8rem 0; color:#374151}
.who{margin:0; font-weight:800; color:#111827}
.reviews-cta{
  margin-top:1.2rem;
  display:flex; gap:.75rem; flex-wrap:wrap; align-items:center;
}

/* Responsive additions */
@media (max-width: 980px){
  .offers{grid-template-columns: 1fr}
  .testimonials{grid-template-columns: 1fr}
}


/* Promo cards (Ofertas da semana) */
.offers{grid-template-columns: repeat(4, 1fr); align-items:stretch}
.promo{
  border:1px solid var(--border);
  border-radius: var(--radius);
  background:#ffffff;
  padding:1.1rem 1.1rem 1rem;
  box-shadow: 0 14px 30px rgba(17,24,39,.08);
  position:relative;
  overflow:hidden;
}
.promo:before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(520px 170px at 0% 0%, var(--red-50), transparent 62%),
    radial-gradient(540px 180px at 100% 0%, #f3f4f6, transparent 55%);
  pointer-events:none;
}
.promo__top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:.75rem;
  position:relative;
}
.promo__cat{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  font-weight:900;
  color:#111827;
  background:rgba(255,255,255,.85);
  border:1px solid var(--border);
  padding:.35rem .6rem;
  border-radius:999px;
  font-size:.85rem;
}
.promo__icon{font-size:1.05rem}
.promo__badge{
  font-weight:1000;
  letter-spacing:.02em;
  color:#7f1d1d;
  background:#fff1f2;
  border:1px solid #fecdd3;
  padding:.35rem .55rem;
  border-radius:999px;
  font-size:.9rem;
  position:relative;
}
.promo__badge--solid{
  background: var(--red);
  border-color: var(--red);
  color:#fff;
}
.promo__title{
  margin:.8rem 0 .35rem 0;
  font-size:1.06rem;
  letter-spacing:-.01em;
  position:relative;
}
.promo__desc{margin:0 0 .75rem 0; color:#374151; position:relative}
.promo__price{
  display:flex;
  align-items:baseline;
  gap:.65rem;
  margin: 0 0 .85rem 0;
  position:relative;
}
.promo__old{
  color: var(--muted);
  text-decoration: line-through;
  font-weight:800;
}
.promo__new{
  color:#111827;
  font-weight:1000;
  font-size:1.25rem;
}
.promo__price--note .promo__new{font-size:1.1rem}
.promo__cta{width:100%; position:relative}
.promo__fine{margin:.65rem 0 0 0; position:relative}

/* Optional subtle accent by category */
.promo--vit:after, .promo--hig:after, .promo--dor:after, .promo--delivery:after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:0;
  height:6px;
  background: var(--red);
  opacity:.9;
}


/* Stores list */
.stores{display:grid; gap:.9rem; margin-top:.5rem}
.store{
  border:1px solid #f1f5f9;
  border-radius: 14px;
  padding:.75rem .8rem;
  background: #ffffff;
}
.store__title{font-weight:900; margin-bottom:.25rem}
.store__addr{color:#374151; font-size:.95rem; margin-bottom:.35rem}


/* Hero with photo */
.hero--photo{
  position: relative;
  padding: 0;
  overflow: hidden;
  border-bottom: 1px solid var(--border);
}
.hero__photo-wrap{
  position:absolute;
  inset:0;
  z-index:0;
}
.hero__photo{
  width:100%;
  height:100%;
  object-fit:cover;
}
.hero__overlay{
  position:absolute;
  inset:0;
  background: linear-gradient(
    180deg,
    rgba(185,28,28,.55) 0%,
    rgba(185,28,28,.65) 40%,
    rgba(255,255,255,.92) 100%
  );
}
.hero__inner--overlay{
  position: relative;
  z-index: 1;
  padding: 3.5rem 0 3rem;
}
.hero--photo h1,
.hero--photo .lead{
  color: #111827;
}
@media (max-width: 980px){
  .hero__overlay{
    background: linear-gradient(
      180deg,
      rgba(185,28,28,.65) 0%,
      rgba(255,255,255,.96) 100%
    );
  }
}


/* Farmácia Popular highlight */
.popular{
  margin: 1rem 0 1.1rem 0;
  display:flex;
  align-items:center;
  gap: .9rem;
  flex-wrap:wrap;
  background: rgba(255,255,255,.82);
  border:1px solid var(--border);
  border-radius: 18px;
  padding: .75rem .85rem;
  box-shadow: 0 10px 24px rgba(17,24,39,.08);
}
.popular__logo{
  height: 44px;
  width: auto;
  border-radius: 12px;
}
.popular__title{font-weight: 1000; letter-spacing:-.01em}
.popular__desc{color: #374151; font-size: .95rem}
.popular__cta{white-space:nowrap}

/* Farmácia Popular section */
.popular-section{
  display:grid;
  grid-template-columns: 260px 1fr;
  gap: 1.2rem;
  align-items:start;
}
.popular-section__logo{
  width: 100%;
  height: auto;
  border-radius: 18px;
  border:1px solid var(--border);
  box-shadow: 0 14px 30px rgba(17,24,39,.08);
}
.popular-section__list li{
  border-bottom: 1px dashed #e5e7eb;
}
@media (max-width: 980px){
  .popular-section{grid-template-columns: 1fr}
  .popular__logo{height: 40px}
  .popular__cta{width:100%}
}
