
:root{
  --cream:#fbf5ea;
  --paper:#fffaf2;
  --ink:#2b1d18;
  --muted:#6d5c4c;
  --line:#eadcc8;
  --red:#9f2f25;
  --red-dark:#7f261e;
  --red-soft:#f3dfd8;
  --blue:#153f62;
  --olive:#6f7550;
  --gold:#d6a341;
  --white:#ffffff;
  --shadow:0 24px 70px rgba(44, 28, 18, .12);
  --shadow-sm:0 16px 40px rgba(44, 28, 18, .10);
  --radius:28px;
  --radius-sm:18px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--cream);color:var(--ink);font-family:Arial, Helvetica, sans-serif;line-height:1.55;font-size:16px}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{width:min(var(--max), calc(100% - 40px));margin:0 auto}
.eyebrow{letter-spacing:.18em;text-transform:uppercase;font-weight:800;color:var(--red);font-size:.78rem;margin:0 0 12px}
h1,h2,h3{font-family:Georgia, 'Times New Roman', serif;line-height:1.04;color:var(--ink);margin:0}
h1{font-size:clamp(2.45rem, 6vw, 5.8rem);letter-spacing:-.05em}
h2{font-size:clamp(2rem, 4vw, 4rem);letter-spacing:-.045em}
h3{font-size:clamp(1.25rem, 2vw, 1.9rem);letter-spacing:-.02em}
p{margin:0;color:var(--muted)}
.lead{font-size:clamp(1.05rem, 1.8vw, 1.35rem);line-height:1.65;color:#4f4036}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border-radius:999px;padding:16px 24px;font-weight:800;border:1px solid transparent;transition:.2s ease;cursor:pointer;text-align:center;min-height:52px}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 16px 38px rgba(159,47,37,.22)}
.btn-primary:hover{background:var(--red-dark)}
.btn-secondary{background:#fff;color:var(--red);border-color:#e3cabc;box-shadow:var(--shadow-sm)}
.btn-ghost{background:transparent;color:var(--red);border-color:#d9b7a8}
.section{padding:96px 0}
.section-tight{padding:68px 0}
.section-head{max-width:820px;margin:0 auto 42px;text-align:center}
.section-head p{margin-top:18px;font-size:1.12rem}
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,245,234,.94);backdrop-filter:blur(16px);border-bottom:1px solid rgba(105,82,64,.12)}
.header-inner{height:92px;display:flex;align-items:center;gap:24px}
.brand{display:inline-flex;align-items:center;flex:0 0 auto}
.brand img{width:220px;height:auto;border-radius:16px;box-shadow:0 8px 30px rgba(44,28,18,.06)}
.desktop-nav{display:flex;align-items:center;gap:22px;margin-left:auto;font-weight:800;color:#2c211b}
.desktop-nav a{position:relative;white-space:nowrap;font-size:.98rem}
.desktop-nav a.active,.desktop-nav a:hover{color:var(--red)}
.desktop-nav a.active:after{content:"";position:absolute;left:0;right:0;bottom:-10px;height:3px;background:var(--red);border-radius:10px}
.header-cta{padding:13px 20px;min-height:46px;white-space:nowrap}
.menu-toggle{display:none;width:48px;height:48px;border:0;background:transparent;margin-left:auto;cursor:pointer}
.menu-toggle span{display:block;width:28px;height:3px;background:var(--ink);margin:6px auto;border-radius:5px;transition:.2s}
.mobile-panel{position:absolute;left:20px;right:20px;top:100px;background:#fff;border:1px solid var(--line);border-radius:28px;padding:18px;box-shadow:var(--shadow)}
.mobile-panel nav{display:grid;gap:8px}
.mobile-panel a{font-weight:800;padding:14px 16px;border-radius:16px}
.mobile-panel a.active{background:var(--cream);color:var(--red)}
.mobile-cta{margin-top:10px;color:#fff!important;padding:16px!important}
.hero{position:relative;overflow:hidden;background:
  radial-gradient(circle at 10% 20%, rgba(214,163,65,.22), transparent 28%),
  linear-gradient(180deg, #fff7ed 0%, #f8ecdc 100%);
}
.hero:before{content:"";position:absolute;inset:auto 0 0 0;height:62px;background:linear-gradient(90deg, var(--red) 0 18%, #e6cc83 18% 31%, var(--blue) 31% 44%, var(--olive) 44% 58%, #d9b191 58% 72%, var(--red) 72% 100%);opacity:.18}
.hero-grid{display:grid;grid-template-columns:1fr .95fr;gap:56px;align-items:center;min-height:calc(100vh - 92px);padding:72px 0 96px}
.hero-copy{position:relative;z-index:2}
.hero-copy .lead{margin:24px 0 30px;max-width:690px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:34px}
.hero-note{display:flex;gap:10px;align-items:flex-start;color:#5c4b3f;font-weight:700;max-width:600px;background:rgba(255,255,255,.7);border:1px solid var(--line);padding:14px 16px;border-radius:18px}
.hero-note svg{width:22px;height:22px;flex:0 0 auto;fill:var(--red)}
.hero-media{position:relative;z-index:1}
.hero-photo-card{border-radius:36px;overflow:hidden;box-shadow:var(--shadow);background:#fff;padding:12px;transform:rotate(.4deg)}
.hero-photo-card img{height:620px;width:100%;object-fit:cover;border-radius:26px}
.hero-badge{position:absolute;left:-24px;bottom:38px;background:#fff;border:1px solid var(--line);border-radius:24px;padding:18px 20px;box-shadow:var(--shadow-sm);display:grid;gap:2px;min-width:210px}
.hero-badge strong{font-family:Georgia, serif;font-size:2rem;color:var(--red);line-height:1}
.hero-badge span{font-size:.92rem;color:var(--muted);font-weight:700}
.stats-band{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:0}
.stat-card{padding:28px 18px;border-right:1px solid var(--line);min-height:136px;display:flex;flex-direction:column;justify-content:center}
.stat-card:first-child{border-left:1px solid var(--line)}
.stat-card strong{font-family:Georgia, serif;font-size:clamp(1.35rem,2vw,2.1rem);color:var(--red);line-height:1.05}
.stat-card span{display:block;color:var(--muted);font-weight:700;margin-top:8px;font-size:.94rem}
.intro-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:50px;align-items:center}
.intro-gallery{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.intro-gallery img{width:100%;height:280px;object-fit:cover;border-radius:24px;box-shadow:var(--shadow-sm)}
.intro-gallery img:nth-child(2){margin-top:44px}
.intro-copy p{margin-top:18px;font-size:1.08rem}
.intro-copy .btn{margin-top:28px}
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.service-card{background:#fff;border:1px solid var(--line);border-radius:30px;overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;min-height:100%}
.service-card img{height:255px;width:100%;object-fit:cover}
.service-card-body{padding:28px;display:flex;flex-direction:column;gap:14px;flex:1}
.service-card-body p{flex:1}
.service-pill{display:inline-flex;align-self:flex-start;background:var(--cream);border:1px solid var(--line);color:var(--red);font-weight:800;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;padding:8px 12px;border-radius:999px}
.compare{background:#f7ebdb;border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.compare:before{content:"";position:absolute;width:420px;height:420px;border-radius:50%;background:rgba(21,63,98,.07);right:-120px;top:-180px}
.compare-layout{display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:stretch;margin-top:42px}
.compare-card{border-radius:34px;padding:34px;border:1px solid var(--line);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.compare-card.light{background:#fff}
.compare-card.highlight{background:linear-gradient(145deg,var(--red),#7d241d);color:#fff;border-color:rgba(255,255,255,.15)}
.compare-card.highlight h3,.compare-card.highlight p{color:#fff}
.compare-card h3{margin-bottom:22px}
.feature-list{list-style:none;margin:0;padding:0;display:grid;gap:16px}
.feature-list li{display:flex;gap:12px;align-items:flex-start;color:#42362f;font-weight:700}
.compare-card.highlight .feature-list li{color:#fff}
.icon-dot{width:26px;height:26px;flex:0 0 auto;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:900;font-size:.85rem}
.icon-bad{background:#f2dfd5;color:var(--red)}
.icon-good{background:#fff;color:var(--red)}
.compare-closing{margin:30px auto 0;max-width:880px;background:#fff;border:1px solid var(--line);border-radius:28px;padding:26px;display:flex;gap:24px;align-items:center;justify-content:space-between;box-shadow:var(--shadow-sm)}
.compare-closing p{font-size:1.02rem}
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.step-card{background:#fff;border:1px solid var(--line);border-radius:26px;padding:28px;box-shadow:var(--shadow-sm)}
.step-number{display:inline-flex;width:48px;height:48px;border-radius:16px;align-items:center;justify-content:center;background:var(--red);color:#fff;font-weight:900;margin-bottom:18px}
.step-card h3{font-size:1.35rem;margin-bottom:10px}
.story-section{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.story-section h2,.story-section h3{color:#fff}
.story-section p{color:#e8ddd2}
.story-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:46px;align-items:center}
.story-image{background:#fff;padding:12px;border-radius:28px;box-shadow:0 28px 80px rgba(0,0,0,.28);transform:rotate(-1deg)}
.story-image img{border-radius:18px;max-height:640px;width:100%;object-fit:cover;object-position:top}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gallery-item{position:relative;overflow:hidden;border-radius:24px;box-shadow:var(--shadow-sm);background:#fff;min-height:230px}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:.35s ease}
.gallery-item:hover img{transform:scale(1.04)}
.gallery-label{position:absolute;left:12px;right:12px;bottom:12px;background:rgba(255,255,255,.9);border:1px solid rgba(255,255,255,.5);border-radius:16px;padding:10px 12px;font-weight:900;color:var(--ink)}
.pastilhas-band{background:#fff}
.pastilhas-grid{display:grid;grid-template-columns:1fr 1fr;gap:42px;align-items:center}
.pastilhas-images{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.pastilhas-images img{height:270px;width:100%;object-fit:cover;border-radius:26px;box-shadow:var(--shadow-sm)}
.check-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:24px 0 28px}
.check-item{background:var(--cream);border:1px solid var(--line);border-radius:18px;padding:14px;font-weight:800;color:#3e3027}
.cta-section{padding:86px 0;background:linear-gradient(135deg,var(--red),#75231c);color:#fff;position:relative;overflow:hidden}
.cta-section:before{content:"";position:absolute;inset:0;background-image:url('../img/painel-azulejos-portugueses-azuis.webp');background-size:cover;background-position:center;opacity:.12;mix-blend-mode:screen}
.cta-box{position:relative;display:grid;grid-template-columns:1fr auto;gap:28px;align-items:center}
.cta-box h2,.cta-box p{color:#fff}
.cta-box p{margin-top:16px;max-width:720px;color:#fff2e8;font-size:1.12rem}
.location-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:26px;align-items:stretch}
.location-card{background:#fff;border:1px solid var(--line);border-radius:30px;padding:32px;box-shadow:var(--shadow-sm)}
.location-card p{margin-top:12px}
.hours{margin-top:22px;display:grid;gap:12px}
.hours div{padding:14px;border-radius:18px;background:var(--cream);border:1px solid var(--line)}
.map-wrap{overflow:hidden;border-radius:30px;border:1px solid var(--line);box-shadow:var(--shadow-sm);min-height:420px;background:#fff}
.map-wrap iframe{width:100%;height:100%;min-height:420px;border:0;display:block}
.page-hero{padding:82px 0 70px;background:linear-gradient(135deg,#fff8ed,#f4e3cf);border-bottom:1px solid var(--line)}
.page-hero-grid{display:grid;grid-template-columns:1fr .8fr;gap:44px;align-items:center}
.page-hero img{height:430px;width:100%;object-fit:cover;border-radius:32px;box-shadow:var(--shadow)}
.content-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.info-card{background:#fff;border:1px solid var(--line);border-radius:28px;padding:30px;box-shadow:var(--shadow-sm)}
.info-card h3{margin-bottom:12px}
.info-card ul{margin:16px 0 0;padding-left:20px;color:var(--muted);font-weight:700}
.text-page{max-width:900px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:30px;padding:38px;box-shadow:var(--shadow-sm)}
.text-page h2{font-size:2rem;margin:30px 0 12px}.text-page h2:first-child{margin-top:0}.text-page p,.text-page li{color:#5c4b3f}.text-page ul{margin:10px 0 0}.text-page a{color:var(--red);font-weight:800}
.footer{background:#231611;color:#f8ecdc;padding:70px 0 22px}.footer p,.footer a{color:#d8c9bb}.footer h3{color:#fff;font-size:1.25rem;margin-bottom:14px}.footer-grid{display:grid;grid-template-columns:1.2fr 1fr .75fr;gap:42px}.footer-logo{width:210px;border-radius:16px;margin-bottom:18px}.footer-links{list-style:none;margin:0;padding:0;display:grid;gap:8px}.footer-links a:hover,.footer a:hover{color:#fff}.social-links{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}.social-links a{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:999px;background:rgba(255,255,255,.08);font-weight:800}.social-links svg{width:20px;height:20px;fill:currentColor}.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:44px;padding-top:22px;display:flex;justify-content:space-between;gap:20px;color:#c9b7a8;font-size:.94rem}
.whatsapp-float{position:fixed;left:22px;bottom:22px;z-index:60;background:#1faf62;color:#fff;display:inline-flex;align-items:center;gap:10px;padding:14px 18px;border-radius:999px;font-weight:900;box-shadow:0 18px 44px rgba(12,128,66,.34)}.whatsapp-float svg{width:25px;height:25px;fill:#fff}.whatsapp-float:hover{transform:translateY(-2px)}
@media (max-width:1080px){.desktop-nav,.header-cta{display:none}.menu-toggle{display:block}.hero-grid,.intro-grid,.story-grid,.pastilhas-grid,.location-grid,.page-hero-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(3,1fr)}.service-grid,.steps-grid{grid-template-columns:repeat(2,1fr)}.gallery-grid{grid-template-columns:repeat(3,1fr)}.hero-photo-card img{height:460px}.hero-badge{left:18px}.compare-layout{grid-template-columns:1fr}.cta-box{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:720px){.container{width:min(100% - 28px,var(--max))}.header-inner{height:78px}.brand img{width:205px;box-shadow:none}.mobile-panel{top:86px;left:14px;right:14px}.hero-grid{padding:46px 0 78px;min-height:auto;gap:30px}.hero-photo-card{border-radius:26px;padding:8px}.hero-photo-card img{height:360px;border-radius:20px}.hero-badge{position:static;margin:14px 8px 0;min-width:0}.hero-actions .btn,.compare-closing .btn,.cta-box .btn{width:100%}.stats-grid{grid-template-columns:1fr 1fr}.stat-card{border-left:0!important;min-height:112px}.section{padding:68px 0}.section-tight{padding:50px 0}.intro-gallery,.service-grid,.steps-grid,.pastilhas-images,.content-grid{grid-template-columns:1fr}.intro-gallery img,.intro-gallery img:nth-child(2){margin-top:0;height:245px}.service-card img{height:230px}.gallery-grid{grid-template-columns:1fr 1fr}.gallery-item{min-height:190px}.compare-closing{display:grid}.compare-card{padding:26px}.check-grid{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column}.page-hero{padding:58px 0}.page-hero img{height:300px}.whatsapp-float{left:14px;right:14px;justify-content:center;bottom:14px}.footer{padding-bottom:90px}h1{font-size:clamp(2.25rem,12vw,3.9rem)}h2{font-size:clamp(1.9rem,9vw,3rem)}}
@media (max-width:420px){.brand img{width:185px}.stats-grid,.gallery-grid{grid-template-columns:1fr}.pastilhas-images img{height:230px}}

/* ==============================
   V3 MOBILE FIRST REFINEMENT
   Correção focada em celular: hero mais premium, cards sólidos e WhatsApp sem tampar a tela
   ============================== */
@media (max-width: 720px) {
  body {
    font-size: 15.5px;
    background: #fff8ee;
  }

  .container {
    width: min(100% - 28px, var(--max));
  }

  .site-header {
    background: rgba(255, 250, 242, .98);
    border-bottom: 1px solid rgba(70, 45, 32, .10);
  }

  .header-inner {
    height: 72px;
  }

  .brand img {
    width: 176px;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
  }

  .menu-toggle {
    width: 46px;
    height: 46px;
    border-radius: 14px;
    background: #fff;
    border: 1px solid var(--line);
    box-shadow: 0 8px 22px rgba(44, 28, 18, .08);
  }

  .menu-toggle span {
    width: 24px;
    height: 2.5px;
    margin: 5px auto;
  }

  .mobile-panel {
    position: fixed;
    top: 82px;
    left: 14px;
    right: 14px;
    max-height: calc(100vh - 104px);
    overflow: auto;
    border-radius: 24px;
    padding: 12px;
    background: rgba(255, 255, 255, .98);
    box-shadow: 0 26px 70px rgba(31, 19, 13, .22);
  }

  .mobile-panel nav {
    gap: 4px;
  }

  .mobile-panel a {
    padding: 13px 14px;
    border-radius: 14px;
    font-size: 1rem;
  }

  .mobile-panel a.active {
    background: #f7ecde;
  }

  .mobile-cta {
    margin-top: 8px;
    min-height: 50px;
  }

  .hero {
    background: #fff8ee;
  }

  .hero:before {
    display: none;
  }

  .hero-grid {
    display: flex;
    flex-direction: column;
    padding: 0 0 42px;
    gap: 0;
    min-height: auto;
  }

  .hero-media {
    order: 1;
    width: calc(100% + 28px);
    margin-left: -14px;
    margin-right: -14px;
  }

  .hero-photo-card {
    padding: 0;
    border-radius: 0 0 30px 30px;
    box-shadow: none;
    transform: none;
    background: transparent;
  }

  .hero-photo-card img {
    width: 100%;
    height: 255px;
    border-radius: 0 0 30px 30px;
    object-fit: cover;
    object-position: center;
    filter: saturate(.96) contrast(.98);
  }

  .hero-badge {
    position: absolute;
    left: 14px;
    right: 14px;
    bottom: 14px;
    min-width: 0;
    margin: 0;
    padding: 14px 16px;
    border-radius: 18px;
    background: rgba(255, 255, 255, .94);
    box-shadow: 0 14px 34px rgba(44, 28, 18, .18);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
  }

  .hero-badge strong {
    font-size: 1.28rem;
    letter-spacing: -.02em;
    white-space: nowrap;
  }

  .hero-badge span {
    font-size: .82rem;
    line-height: 1.25;
    text-align: right;
  }

  .hero-copy {
    order: 2;
    position: relative;
    z-index: 2;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 28px;
    padding: 24px 20px 22px;
    margin-top: -24px;
    box-shadow: 0 20px 55px rgba(44, 28, 18, .12);
  }

  .hero-copy .eyebrow {
    font-size: .68rem;
    letter-spacing: .14em;
    margin-bottom: 10px;
  }

  h1 {
    font-size: clamp(2rem, 10vw, 2.75rem);
    line-height: 1.02;
    letter-spacing: -.045em;
  }

  h2 {
    font-size: clamp(1.72rem, 8vw, 2.35rem);
    line-height: 1.08;
    letter-spacing: -.04em;
  }

  h3 {
    line-height: 1.12;
  }

  .hero-copy .lead {
    margin: 16px 0 18px;
    font-size: 1rem;
    line-height: 1.55;
  }

  .hero-actions {
    display: grid;
    gap: 10px;
    margin-bottom: 14px;
  }

  .hero-actions .btn {
    width: 100%;
    min-height: 50px;
    padding: 13px 16px;
  }

  .hero-note {
    border-radius: 16px;
    padding: 12px;
    font-size: .9rem;
    background: #fff8ee;
    line-height: 1.38;
  }

  .hero-note svg {
    width: 19px;
    height: 19px;
  }

  .stats-band {
    background: transparent;
    border: 0;
    padding: 10px 0 0;
  }

  .stats-grid {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .stat-card {
    min-height: 105px;
    padding: 18px 14px;
    border: 1px solid var(--line) !important;
    border-radius: 20px;
    background: #fff;
    box-shadow: 0 12px 30px rgba(44, 28, 18, .06);
  }

  .stat-card strong {
    font-size: 1.18rem;
  }

  .stat-card span {
    font-size: .82rem;
    line-height: 1.25;
  }

  .section {
    padding: 54px 0;
  }

  .section-tight {
    padding: 46px 0;
  }

  .section-head {
    margin-bottom: 24px;
    text-align: left;
  }

  .section-head p {
    margin-top: 12px;
    font-size: 1rem;
  }

  .intro-grid {
    gap: 24px;
  }

  .intro-gallery {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .intro-gallery img,
  .intro-gallery img:nth-child(2) {
    height: 190px;
    margin: 0;
    border-radius: 20px;
  }

  .intro-copy {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 24px;
    padding: 22px;
    box-shadow: 0 14px 38px rgba(44, 28, 18, .07);
  }

  .intro-copy p {
    font-size: .98rem;
  }

  .intro-copy .btn {
    width: 100%;
    margin-top: 20px;
  }

  .service-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .service-card {
    border-radius: 24px;
  }

  .service-card img {
    height: 190px;
  }

  .service-card-body {
    padding: 20px;
    gap: 10px;
  }

  .service-card-body .btn {
    width: 100%;
    margin-top: 4px;
  }

  .compare {
    background: #f7ecde;
  }

  .compare:before {
    display: none;
  }

  .compare-layout {
    grid-template-columns: 1fr;
    gap: 14px;
    margin-top: 22px;
  }

  .compare-card {
    border-radius: 24px;
    padding: 22px 18px;
  }

  .compare-card.highlight {
    order: -1;
    box-shadow: 0 20px 50px rgba(127, 38, 30, .20);
  }

  .compare-card h3 {
    font-size: 1.45rem;
    margin-bottom: 16px;
  }

  .feature-list {
    gap: 12px;
  }

  .feature-list li {
    font-size: .94rem;
    line-height: 1.35;
  }

  .icon-dot {
    width: 23px;
    height: 23px;
    font-size: .78rem;
  }

  .compare-closing {
    margin-top: 16px;
    border-radius: 22px;
    padding: 18px;
    display: grid;
    gap: 14px;
  }

  .compare-closing p {
    font-size: .96rem;
  }

  .compare-closing .btn {
    width: 100%;
  }

  .steps-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .step-card {
    display: grid;
    grid-template-columns: 46px 1fr;
    column-gap: 14px;
    padding: 18px;
    border-radius: 22px;
  }

  .step-number {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    margin: 0;
    grid-row: span 2;
  }

  .step-card h3 {
    font-size: 1.18rem;
    margin: 0 0 6px;
  }

  .step-card p {
    font-size: .92rem;
  }

  .story-grid {
    gap: 24px;
  }

  .story-image {
    padding: 8px;
    border-radius: 22px;
    transform: none;
  }

  .story-image img {
    max-height: 380px;
    border-radius: 16px;
  }

  .story-section .lead {
    font-size: 1rem;
  }

  .gallery-grid {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .gallery-item {
    min-height: 168px;
    border-radius: 20px;
  }

  .gallery-label {
    left: 8px;
    right: 8px;
    bottom: 8px;
    border-radius: 13px;
    padding: 8px 9px;
    font-size: .82rem;
    line-height: 1.18;
  }

  .pastilhas-grid {
    gap: 24px;
  }

  .pastilhas-band {
    background: #fff8ee;
  }

  .pastilhas-band .lead {
    font-size: 1rem;
  }

  .check-grid {
    grid-template-columns: 1fr;
    gap: 9px;
    margin: 18px 0 20px;
  }

  .check-item {
    padding: 12px 14px;
    border-radius: 15px;
    font-size: .92rem;
  }

  .pastilhas-images {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .pastilhas-images img {
    height: 210px;
    border-radius: 20px;
  }

  .cta-section {
    padding: 52px 0;
  }

  .cta-box {
    display: grid;
    gap: 18px;
  }

  .cta-box p {
    font-size: 1rem;
  }

  .cta-box .btn {
    width: 100%;
  }

  .location-grid {
    gap: 18px;
  }

  .location-card {
    border-radius: 24px;
    padding: 22px;
  }

  .hours div {
    border-radius: 16px;
  }

  .map-wrap {
    border-radius: 24px;
    min-height: 300px;
  }

  .map-wrap iframe {
    min-height: 300px;
  }

  .page-hero {
    padding: 42px 0;
  }

  .page-hero-grid {
    gap: 22px;
  }

  .page-hero img {
    height: 230px;
    border-radius: 24px;
  }

  .content-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .info-card {
    border-radius: 22px;
    padding: 20px;
  }

  .text-page {
    border-radius: 22px;
    padding: 22px;
  }

  .footer {
    padding: 48px 0 84px;
  }

  .footer-grid {
    gap: 28px;
  }

  .footer-logo {
    width: 180px;
  }

  .footer-bottom {
    margin-top: 30px;
  }

  .whatsapp-float {
    left: 14px;
    right: auto;
    bottom: 14px;
    padding: 12px 14px;
    font-size: .92rem;
    box-shadow: 0 14px 34px rgba(12,128,66,.32);
  }

  .whatsapp-float svg {
    width: 22px;
    height: 22px;
  }
}

@media (max-width: 380px) {
  .brand img {
    width: 158px;
  }

  .hero-photo-card img {
    height: 230px;
  }

  .hero-copy {
    padding: 22px 18px;
  }

  h1 {
    font-size: 1.92rem;
  }

  .stat-card {
    min-height: 96px;
  }

  .pastilhas-images,
  .gallery-grid,
  .intro-gallery,
  .stats-grid {
    grid-template-columns: 1fr;
  }

  .gallery-item {
    min-height: 210px;
  }
}


/* =========================================================
   V4 MOBILE REAL: muda o arquivo CSS e força cache-busting.
   Objetivo: mobile com cara de landing page premium, sem hero gigante e sem botão verde ocupando a tela.
   ========================================================= */
@media (max-width: 720px) {
  html { scroll-padding-top: 74px; }
  body { background: #fff7ec !important; color: #241813; overflow-x: hidden; }

  .container { width: min(100% - 30px, var(--max)) !important; }

  .site-header {
    position: sticky !important;
    top: 0 !important;
    background: rgba(255, 248, 238, .98) !important;
    backdrop-filter: blur(12px);
    box-shadow: 0 10px 30px rgba(45, 30, 19, .08) !important;
  }
  .header-inner { height: 68px !important; }
  .brand img { width: 166px !important; background: transparent !important; box-shadow: none !important; border-radius: 0 !important; }
  .menu-toggle {
    width: 44px !important; height: 44px !important;
    border-radius: 16px !important;
    background: #fff !important;
    border: 1px solid rgba(91, 57, 38, .16) !important;
    box-shadow: 0 10px 25px rgba(45, 30, 19, .08) !important;
  }
  .menu-toggle span { width: 23px !important; height: 2.5px !important; margin: 5px auto !important; }

  .mobile-panel {
    top: 78px !important; left: 12px !important; right: 12px !important;
    border-radius: 24px !important;
    padding: 10px !important;
    background: #fff !important;
    box-shadow: 0 28px 70px rgba(31, 19, 13, .25) !important;
    border: 1px solid rgba(91, 57, 38, .10) !important;
    max-height: calc(100vh - 98px) !important;
    overflow: auto !important;
  }
  .mobile-panel a { font-size: .98rem !important; padding: 13px 14px !important; border-radius: 15px !important; }
  .mobile-panel a.active { background: #f3e8d8 !important; color: #8f2b21 !important; }
  .mobile-cta { min-height: 50px !important; margin-top: 8px !important; }

  .hero { background: #fff7ec !important; padding: 0 0 34px !important; overflow: visible !important; }
  .hero:before { display: none !important; }
  .hero-grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    min-height: 0 !important;
    padding: 0 0 0 !important;
  }
  .hero-media {
    order: 1 !important;
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    position: relative !important;
  }
  .hero-photo-card {
    padding: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    transform: none !important;
  }
  .hero-photo-card:after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.38));
    pointer-events: none;
  }
  .hero-photo-card img {
    height: 215px !important;
    width: 100% !important;
    border-radius: 0 !important;
    object-fit: cover !important;
    object-position: center !important;
    display: block !important;
  }
  .hero-badge { display: none !important; }

  .hero-copy {
    order: 2 !important;
    background: #fff !important;
    border: 1px solid rgba(91, 57, 38, .12) !important;
    border-radius: 26px !important;
    padding: 22px 18px 20px !important;
    margin: -32px 0 0 !important;
    box-shadow: 0 22px 55px rgba(45, 30, 19, .16) !important;
    position: relative !important;
    z-index: 3 !important;
  }
  .hero-copy .eyebrow { font-size: .68rem !important; letter-spacing: .14em !important; color: #a72c22 !important; margin-bottom: 10px !important; }
  .hero-copy h1 {
    font-size: 2rem !important;
    line-height: 1.03 !important;
    letter-spacing: -.045em !important;
    margin: 0 !important;
  }
  .hero-copy .lead {
    font-size: .99rem !important;
    line-height: 1.55 !important;
    margin: 15px 0 17px !important;
    color: #5b4739 !important;
  }
  .hero-actions { display: grid !important; gap: 10px !important; margin: 0 0 12px !important; }
  .hero-actions .btn { width: 100% !important; min-height: 52px !important; padding: 14px 16px !important; font-size: .98rem !important; }
  .hero-note { padding: 12px 12px !important; border-radius: 16px !important; background: #fff7ec !important; font-size: .86rem !important; line-height: 1.35 !important; }
  .hero-note svg { width: 18px !important; min-width: 18px !important; }

  .stats-band { padding: 22px 0 16px !important; background: #fff7ec !important; }
  .stats-grid { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
  .stat-card {
    min-height: auto !important;
    padding: 16px 13px !important;
    border-radius: 20px !important;
    background: #fff !important;
    border: 1px solid rgba(91, 57, 38, .12) !important;
    box-shadow: 0 12px 30px rgba(45, 30, 19, .06) !important;
  }
  .stat-card strong { font-size: 1.12rem !important; letter-spacing: -.03em !important; color: #9d2f24 !important; }
  .stat-card span { font-size: .84rem !important; line-height: 1.3 !important; }

  .section { padding: 54px 0 !important; }
  .section-tight { padding: 44px 0 !important; }
  .section-head { margin-bottom: 24px !important; }
  .section-head h2, h2 { font-size: 1.9rem !important; line-height: 1.08 !important; letter-spacing: -.04em !important; }
  .section-head p { font-size: .98rem !important; line-height: 1.55 !important; }

  .intro-grid, .story-grid, .pastilhas-grid, .location-grid, .page-hero-grid, .content-grid { grid-template-columns: 1fr !important; gap: 24px !important; }
  .intro-gallery { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
  .intro-gallery img, .intro-gallery img:nth-child(2) { height: 170px !important; border-radius: 18px !important; margin-top: 0 !important; }
  .intro-copy { padding: 0 !important; }

  .service-grid { grid-template-columns: 1fr !important; gap: 16px !important; }
  .service-card { border-radius: 24px !important; box-shadow: 0 16px 40px rgba(45,30,19,.08) !important; }
  .service-card img { height: 170px !important; }
  .service-card-body { padding: 18px !important; }
  .service-card h3 { font-size: 1.32rem !important; }
  .service-card p { font-size: .95rem !important; }
  .service-card .btn { width: 100% !important; min-height: 48px !important; }

  .compare { background: #fff !important; padding: 54px 0 !important; }
  .compare .section-head { text-align: left !important; }
  .compare-layout { display: flex !important; flex-direction: column !important; gap: 14px !important; }
  .compare-card { border-radius: 24px !important; padding: 20px 17px !important; }
  .compare-card.highlight { order: 1 !important; box-shadow: 0 20px 50px rgba(141, 39, 29, .20) !important; }
  .compare-card.light { order: 2 !important; background: #fff8ee !important; }
  .compare-card h3 { font-size: 1.38rem !important; margin-bottom: 14px !important; }
  .feature-list { gap: 10px !important; }
  .feature-list li { font-size: .94rem !important; line-height: 1.42 !important; align-items: flex-start !important; }
  .icon-dot { width: 23px !important; height: 23px !important; min-width: 23px !important; margin-top: -1px !important; }
  .compare-closing { display: grid !important; gap: 14px !important; margin-top: 16px !important; padding: 18px !important; border-radius: 22px !important; }
  .compare-closing p { font-size: .95rem !important; line-height: 1.5 !important; }
  .compare-closing .btn { width: 100% !important; }

  .steps-grid { grid-template-columns: 1fr !important; gap: 12px !important; }
  .step-card { padding: 18px !important; border-radius: 22px !important; }
  .step-card h3 { font-size: 1.18rem !important; }

  .story-image img { max-height: 350px !important; object-fit: cover !important; border-radius: 24px !important; }
  .gallery-grid { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
  .gallery-item { min-height: 160px !important; border-radius: 18px !important; }
  .gallery-item span { font-size: .78rem !important; padding: 8px 10px !important; }

  .pastilhas-images { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
  .pastilhas-images img { height: 170px !important; border-radius: 18px !important; }
  .check-grid { grid-template-columns: 1fr !important; }

  .cta-box { display: grid !important; grid-template-columns: 1fr !important; gap: 18px !important; padding: 24px 18px !important; border-radius: 28px !important; }
  .cta-box h2 { font-size: 1.85rem !important; }
  .cta-box .btn { width: 100% !important; }

  .page-hero { padding: 34px 0 44px !important; }
  .page-hero img { height: 220px !important; border-radius: 22px !important; }
  .page-hero h1 { font-size: 2.05rem !important; }

  .footer { padding-bottom: 82px !important; }
  .footer-grid { grid-template-columns: 1fr !important; gap: 24px !important; }
  .footer-bottom { flex-direction: column !important; align-items: flex-start !important; gap: 10px !important; }

  .whatsapp-float {
    left: 14px !important;
    right: auto !important;
    bottom: 14px !important;
    width: auto !important;
    max-width: calc(100vw - 28px) !important;
    padding: 11px 14px !important;
    border-radius: 999px !important;
    font-size: .9rem !important;
    gap: 8px !important;
    box-shadow: 0 14px 34px rgba(12,128,66,.30) !important;
  }
  .whatsapp-float svg { width: 22px !important; height: 22px !important; }
}

@media (max-width: 380px) {
  .hero-copy h1 { font-size: 1.82rem !important; }
  .section-head h2, h2 { font-size: 1.72rem !important; }
  .stats-grid { grid-template-columns: 1fr !important; }
  .whatsapp-float { font-size: .84rem !important; }
}


/* Blog V5 */
.blog-hero .page-hero-grid img,
.article-hero .page-hero-grid img {
  object-position: center;
}
.blog-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}
.blog-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 30px;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  min-height: 100%;
}
.blog-card-image img {
  width: 100%;
  height: 230px;
  object-fit: cover;
  display: block;
}
.blog-card-body {
  padding: 26px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  flex: 1;
}
.blog-card-body p { flex: 1; }
.soon-card { opacity: .94; }
.soon-card .service-pill { background: #f4ece1; color: #6e6258; }
.blog-guidance { background: #fff7ed; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.article-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 34px;
  align-items: start;
}
.article-content {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 32px;
  padding: 42px;
  box-shadow: var(--shadow-sm);
}
.article-content p { margin: 0 0 20px; font-size: 1.08rem; }
.article-content h2 { margin: 34px 0 16px; font-size: clamp(1.65rem, 3vw, 2.35rem); }
.article-content h3 { margin-bottom: 10px; }
.article-meta { margin-top: 20px; color: var(--muted); font-weight: 800; }
.article-callout {
  margin: 34px 0;
  background: linear-gradient(135deg, #fff7ed, #f1dfca);
  border: 1px solid var(--line);
  border-radius: 26px;
  padding: 28px;
}
.article-callout .btn { margin-top: 8px; }
.article-sidebar { position: sticky; top: 112px; }
.article-sidebar .info-card ul { padding-left: 18px; }
.article-sidebar a { color: var(--red); font-weight: 800; }
@media (max-width: 1080px) {
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
  .article-layout { grid-template-columns: 1fr; }
  .article-sidebar { position: static; }
}
@media (max-width: 720px) {
  .blog-grid { grid-template-columns: 1fr !important; gap: 16px !important; }
  .blog-card { border-radius: 24px !important; }
  .blog-card-image img { height: 210px !important; }
  .blog-card-body { padding: 22px !important; }
  .article-content { padding: 24px 18px !important; border-radius: 24px !important; }
  .article-content p { font-size: 1rem !important; }
  .article-callout { padding: 22px 18px !important; border-radius: 22px !important; }
  .article-callout .btn { width: 100% !important; }
}
