/* ===== Meu Escritório - Espaço Criativo | Estilo do site ===== */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700&family=Manrope:wght@400;500;600;700;800&display=swap');

:root{
  --bg:#ffffff;
  --card:#ffffff;
  --card-border:#eceaf1;
  --text:#2b2b2b;
  --muted:#75727f;
  --teal:#3fb6b0;
  --green:#3fae5a;
  --orange:#e8963c;
  --pink:#e1467c;
  --blue:#4f8fe0;
  --purple:#8e6fd8;
  --yellow:#e8c53c;
  --red:#d94f4f;
  --max:1080px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Manrope', Arial, sans-serif;
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;}
img{max-width:100%; display:block;}
.wrap{
  width:100%;
  max-width:var(--max);
  margin:0 auto;
  padding:0 24px;
}

/* ---- HEADER / NAV ---- */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--card-border);
}
.header-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:10px 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  position:relative;
}
.search-toggle{
  background:none;
  border:none;
  cursor:pointer;
  color:var(--text);
  display:flex;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  border-radius:50%;
  flex-shrink:0;
  transition:background .15s ease, color .15s ease;
}
.search-toggle:hover{background:#f2f0f5; color:var(--teal);}
.search-toggle svg{width:19px; height:19px;}
.search-box{
  display:none;
  position:absolute;
  top:100%;
  right:24px;
  margin-top:10px;
  background:#fff;
  border:1px solid var(--card-border);
  border-radius:14px;
  box-shadow:0 8px 24px rgba(43,43,43,.12);
  padding:10px;
  z-index:60;
}
.search-box.open{display:flex; gap:8px;}
.search-box input[type=search]{
  border:1px solid var(--card-border);
  border-radius:10px;
  padding:9px 12px;
  font-size:14px;
  font-family:inherit;
  width:220px;
  outline:none;
  color:var(--text);
}
.search-box input[type=search]:focus{border-color:var(--teal);}
.search-box button{
  background:var(--teal);
  color:#fff;
  border:none;
  border-radius:10px;
  padding:0 14px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.search-box button svg{width:16px; height:16px;}
@media (max-width:480px){
  .search-box{right:12px; left:12px;}
  .search-box input[type=search]{width:100%;}
}
.brand{
  display:flex;
  align-items:center;
  text-decoration:none;
}
.brand-logo{
  height:44px;
  width:auto;
}
.main-nav{
  display:flex;
  align-items:center;
  gap:28px;
}
.main-nav a{
  text-decoration:none;
  color:var(--text);
  font-weight:600;
  font-size:14.5px;
  padding:6px 2px;
  border-bottom:2px solid transparent;
  transition:color .15s ease, border-color .15s ease;
}
.main-nav a:hover{color:var(--teal);}
.main-nav a.active{color:var(--teal); border-color:var(--teal);}
.nav-toggle{
  display:none;
  background:none;
  border:none;
  font-size:24px;
  cursor:pointer;
  color:var(--text);
  padding:4px 8px;
}
@media (max-width:760px){
  .main-nav{
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:#fff;
    flex-direction:column;
    gap:0;
    border-bottom:1px solid var(--card-border);
    box-shadow:0 8px 16px rgba(43,43,43,.06);
    max-height:0;
    overflow:hidden;
    transition:max-height .25s ease;
  }
  .main-nav.open{max-height:280px;}
  .main-nav a{
    padding:14px 24px;
    border-bottom:1px solid var(--card-border);
    border-left:3px solid transparent;
  }
  .main-nav a.active{border-left-color:var(--teal); border-bottom-color:var(--card-border);}
  .nav-toggle{display:block;}
}

/* ---- HERO ---- */
.hero{
  text-align:center;
  padding:64px 20px 30px;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 12% -15%, rgba(63,182,176,.14), transparent 42%),
    radial-gradient(circle at 88% -5%, rgba(225,70,124,.12), transparent 40%),
    radial-gradient(circle at 50% 110%, rgba(232,150,60,.08), transparent 45%);
}
.hero .logo-img{
  width:170px;
  max-width:55%;
  margin:0 auto 18px;
}
.hero .eyebrow{
  display:inline-block;
  font-size:12px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--teal);
  background:rgba(63,182,176,.1);
  padding:6px 16px;
  border-radius:20px;
  margin-bottom:18px;
}
.hero h1{
  font-family:'Playfair Display', serif;
  font-weight:700;
  font-size:clamp(24px, 4.5vw, 44px);
  color:var(--text);
  margin:0 0 18px;
  line-height:1.2;
  max-width:640px;
  margin-left:auto;
  margin-right:auto;
  min-height:2.4em;
  word-break:keep-all;
}
.hero h1 em{
  font-style:normal;
  color:var(--teal);
}
.hero h1 .type-cycle{
  color:var(--teal);
  border-bottom:3px solid rgba(63,182,176,.35);
  padding-bottom:2px;
  display:inline-block;
  white-space:nowrap;
}
.type-cursor{
  display:inline-block;
  width:2px;
  height:0.85em;
  background:var(--teal);
  margin-left:3px;
  vertical-align:-0.08em;
  animation:blink-cursor 1s steps(1) infinite;
}
@keyframes blink-cursor{50%{opacity:0;}}
.hero p{
  color:var(--muted);
  font-size:16px;
  max-width:540px;
  margin:0 auto 30px;
  line-height:1.65;
}
.hero-actions{
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
  margin-bottom:10px;
}

/* ---- PAGE HEADER (non-home pages) ---- */
.page-head{
  text-align:center;
  padding:48px 20px 16px;
  background:
    radial-gradient(circle at 15% -10%, rgba(63,182,176,.07), transparent 45%),
    radial-gradient(circle at 85% 0%, rgba(225,70,124,.06), transparent 40%);
}
.page-head h1{
  font-family:'Playfair Display', serif;
  font-size:30px;
  color:var(--teal);
  margin:0 0 12px;
}
.page-head p{
  color:var(--muted);
  font-size:15px;
  max-width:560px;
  margin:0 auto;
  line-height:1.6;
}

/* ---- BUTTONS ---- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  text-decoration:none;
  font-weight:700;
  font-size:14px;
  padding:12px 22px;
  border-radius:30px;
  transition:transform .15s ease, filter .15s ease, background .15s ease;
  border:1px solid transparent;
}
.btn:hover{transform:translateY(-2px);}
.btn-primary{background:var(--teal); color:#fff;}
.btn-primary:hover{filter:brightness(1.06);}
.btn-outline{background:#fff; color:var(--teal); border-color:var(--teal);}
.btn-whats{background:#25d366; color:#fff;}
.btn svg{width:16px; height:16px; flex-shrink:0;}

/* ---- SECTIONS ---- */
section{padding:44px 0;}
.section-title{
  text-align:center;
  margin-bottom:8px;
}
.section-title h2{
  font-family:'Playfair Display', serif;
  font-size:26px;
  color:var(--text);
  margin:0 0 10px;
}
.section-title p{
  color:var(--muted);
  font-size:14.5px;
  max-width:560px;
  margin:0 auto;
  line-height:1.6;
}

/* ---- CARD GRID ---- */
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(230px,1fr));
  gap:20px;
  margin-top:30px;
}
.card{
  background:var(--card);
  border:1px solid var(--card-border);
  box-shadow:0 4px 18px rgba(43,43,43,.05);
  border-radius:18px;
  padding:26px 22px;
  display:flex;
  flex-direction:column;
  height:100%;
  text-decoration:none;
  color:inherit;
  cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease;
}
.card:hover{transform:translateY(-3px); box-shadow:0 8px 20px rgba(43,43,43,.08);}
.card .emoji{
  width:52px;
  height:52px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:14px;
}
.card .emoji svg{width:26px; height:26px;}
.card h3{
  margin:0 0 8px;
  font-size:17px;
  font-weight:800;
}
.card p{
  color:var(--muted);
  font-size:13.8px;
  line-height:1.55;
  margin:0;
  flex:1;
}
.tone-teal .emoji{background:rgba(63,182,176,.14); color:var(--teal);}
.tone-green .emoji{background:rgba(63,174,90,.14); color:var(--green);}
.tone-orange .emoji{background:rgba(232,150,60,.16); color:#b56a1c;}
.tone-pink .emoji{background:rgba(225,70,124,.14); color:var(--pink);}
.tone-blue .emoji{background:rgba(79,143,224,.14); color:var(--blue);}
.tone-purple .emoji{background:rgba(142,111,216,.14); color:var(--purple);}

/* ---- CARD CTA (soft link, not an obvious WhatsApp button) ---- */
.card-cta{
  margin-top:16px;
  display:inline-flex;
  align-items:center;
  gap:6px;
  align-self:flex-start;
  background:none;
  color:var(--teal);
  text-decoration:none;
  font-weight:700;
  font-size:13px;
  padding:0;
  border-radius:0;
  transition:gap .15s ease;
}
.card:hover .card-cta{gap:10px;}
.card:hover .cta-arrow{transform:translateX(2px);}
.card-cta svg.cta-arrow{width:14px; height:14px; flex-shrink:0; transition:transform .15s ease;}
.tone-teal .card-cta{color:var(--teal);}
.tone-green .card-cta{color:var(--green);}
.tone-orange .card-cta{color:#b56a1c;}
.tone-pink .card-cta{color:var(--pink);}
.tone-blue .card-cta{color:var(--blue);}
.tone-purple .card-cta{color:var(--purple);}

/* ---- CHIP LIST (canecas) ---- */
.chip-list{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:16px;
}
.chip-list span{
  background:#f7f6fa;
  border:1px solid var(--card-border);
  border-radius:20px;
  padding:8px 14px;
  font-size:13px;
  font-weight:600;
  color:var(--text);
}
.card .chip-list{margin-bottom:14px;}
.card .chip-list span{padding:5px 10px; font-size:11.5px;}

/* ---- STORE / CONTACT CARDS ---- */
.stores{
  display:grid;
  grid-template-columns:1fr;
  gap:20px;
  margin-top:30px;
}
@media (min-width:640px){
  .stores{grid-template-columns:1fr 1fr;}
}
.store{
  background:var(--card);
  border:1px solid var(--card-border);
  box-shadow:0 4px 18px rgba(43,43,43,.06);
  border-radius:20px;
  padding:22px 20px 20px;
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.store::before{
  content:"";
  position:absolute;
  top:0; left:0; right:0;
  height:4px;
}
.store.s1::before{background:linear-gradient(90deg,var(--teal),var(--blue));}
.store.s2::before{background:linear-gradient(90deg,var(--pink),var(--orange));}
.store h3{margin:6px 0 2px; font-size:17px; font-weight:800;}
.store .badge{
  display:inline-block;
  font-size:10.5px;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:3px 9px;
  border-radius:20px;
  font-weight:700;
}
.store.s1 .badge{background:rgba(63,182,176,.18); color:var(--teal);}
.store.s2 .badge{background:rgba(225,70,124,.18); color:var(--pink);}
.store address{
  font-style:normal;
  color:var(--muted);
  font-size:13px;
  line-height:1.5;
  margin:10px 0 16px;
  flex:1;
}
.store .map-embed{
  display:block;
  position:relative;
  border-radius:12px;
  overflow:hidden;
  border:1px solid var(--card-border);
  margin-bottom:16px;
  height:150px;
  cursor:pointer;
  transition:filter .15s ease;
}
.store .map-embed:hover{filter:brightness(.94);}
.store .map-embed iframe{
  width:100%;
  height:100%;
  border:0;
  display:block;
  pointer-events:none;
}
.store .actions{
  display:flex;
  flex-direction:column;
  gap:10px;
}
a.pill{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  text-decoration:none;
  font-weight:700;
  font-size:13.5px;
  padding:11px 14px;
  border-radius:12px;
  transition:transform .15s ease, filter .15s ease;
}
a.pill:hover{transform:translateY(-2px); filter:brightness(1.05);}
a.pill.whats{background:#25d366; color:#fff;}
a.pill.map{background:rgba(63,182,176,.1); color:var(--teal); border:1px solid rgba(63,182,176,.3);}
a.pill.rate{background:rgba(232,150,60,.12); color:#b56a1c; border:1px solid rgba(232,150,60,.35);}
a.pill.call{background:rgba(79,143,224,.1); color:var(--blue); border:1px solid rgba(79,143,224,.3);}
a.pill svg{width:15px; height:15px; flex-shrink:0;}

.contact-row{
  margin-top:30px;
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:12px;
}
a.chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  text-decoration:none;
  color:var(--text);
  background:#f7f6fa;
  border:1px solid var(--card-border);
  padding:10px 16px;
  border-radius:30px;
  font-size:13.5px;
  font-weight:600;
  transition:transform .15s ease, background .15s ease;
}
a.chip:hover{transform:translateY(-2px); background:#efedf4;}
a.icon-circle{
  width:42px; height:42px;
  display:flex; align-items:center; justify-content:center;
  border-radius:50%;
  text-decoration:none;
  border:1px solid var(--card-border);
  box-shadow:0 2px 8px rgba(43,43,43,.08);
  transition:transform .15s ease;
}
a.icon-circle:hover{transform:translateY(-2px) scale(1.05);}
a.icon-circle svg{width:19px; height:19px;}
.ig{background:linear-gradient(135deg,#f9ce34,#ee2a7b,#6228d7);}
.fb{background:#3b5998;}

/* ---- CTA BAND ---- */
.cta-band{
  background:linear-gradient(120deg, rgba(63,182,176,.08), rgba(225,70,124,.07));
  border-radius:24px;
  text-align:center;
  padding:40px 24px;
  margin:10px 0 0;
}
.cta-band h2{
  font-family:'Playfair Display', serif;
  font-size:24px;
  margin:0 0 10px;
  color:var(--text);
}
.cta-band p{
  color:var(--muted);
  font-size:14.5px;
  margin:0 0 20px;
}

/* ---- CANECAS CATALOG ---- */
.mug-section{
  margin-bottom:32px;
  border:1px solid var(--card-border);
  border-radius:20px;
  padding:24px 22px 26px;
  background:#fff;
  box-shadow:0 4px 18px rgba(43,43,43,.04);
  position:relative;
  overflow:hidden;
}
.mug-section::before{
  content:"";
  position:absolute;
  top:0; left:0; right:0;
  height:4px;
}
.mug-section-head{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:22px;
}
.mug-section-icon{
  width:42px;
  height:42px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.mug-section-icon svg{width:22px; height:22px;}
.mug-section h2{
  font-family:'Playfair Display', serif;
  font-size:18.5px;
  margin:0;
  padding:0;
  border:0;
  color:var(--text);
}
.mug-section-sub{
  color:var(--muted);
  font-size:12px;
  margin:2px 0 0;
}
.mug-section.tone-teal::before{background:var(--teal);}
.mug-section.tone-teal .mug-section-icon{background:rgba(63,182,176,.14); color:var(--teal);}
.mug-section.tone-pink::before{background:var(--pink);}
.mug-section.tone-pink .mug-section-icon{background:rgba(225,70,124,.14); color:var(--pink);}
.mug-section.tone-purple::before{background:var(--purple);}
.mug-section.tone-purple .mug-section-icon{background:rgba(142,111,216,.14); color:var(--purple);}
.mug-section.tone-orange::before{background:var(--orange);}
.mug-section.tone-orange .mug-section-icon{background:rgba(232,150,60,.16); color:#b56a1c;}
.mug-section.tone-blue::before{background:var(--blue);}
.mug-section.tone-blue .mug-section-icon{background:rgba(79,143,224,.14); color:var(--blue);}
.mug-section.tone-yellow::before{background:var(--yellow);}
.mug-section.tone-yellow .mug-section-icon{background:rgba(232,197,60,.22); color:#a3811d;}
.mug-section.tone-green::before{background:var(--green);}
.mug-section.tone-green .mug-section-icon{background:rgba(63,174,90,.14); color:var(--green);}
.mug-section.tone-red::before{background:var(--red);}
.mug-section.tone-red .mug-section-icon{background:rgba(217,79,79,.14); color:var(--red);}

.mug-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(200px,1fr));
  gap:14px;
}
.mug-item{
  display:flex;
  flex-direction:column;
  background:#fbfaFC;
  border:1px solid var(--card-border);
  border-radius:14px;
  padding:14px 14px 12px;
  text-decoration:none;
  color:inherit;
  cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease;
}
.mug-item:hover{transform:translateY(-3px); box-shadow:0 8px 20px rgba(43,43,43,.08);}
.mug-swatch{
  width:100%;
  height:170px;
  border-radius:10px;
  margin-bottom:12px;
  flex-shrink:0;
  background-image:linear-gradient(135deg, rgba(255,255,255,.55), rgba(255,255,255,0) 55%);
  border:1px solid rgba(0,0,0,.08);
  position:relative;
  overflow:hidden;
}
.mug-swatch img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.mug-info{margin-bottom:12px;}
.mug-name{
  display:block;
  font-size:12.2px;
  font-weight:700;
  line-height:1.35;
  margin-bottom:4px;
}
.mug-meta{display:block; font-size:11.6px; color:var(--muted);}
.mug-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:5px;
  background:#25d366;
  color:#fff;
  text-decoration:none;
  font-weight:700;
  font-size:12px;
  padding:9px 12px;
  border-radius:20px;
  white-space:nowrap;
  transition:transform .15s ease, filter .15s ease;
  margin-top:auto;
}
.mug-cta:hover{transform:translateY(-1px); filter:brightness(1.05);}

/* ---- PRODUCT DETAIL (caneca individual) ---- */
.product-wrap{
  display:grid;
  grid-template-columns:1fr;
  gap:32px;
  margin-top:18px;
}
@media (min-width:680px){
  .product-wrap{grid-template-columns:1fr 1fr; align-items:start;}
}
.product-visual{
  border-radius:20px;
  overflow:hidden;
  border:1px solid var(--card-border);
  background:#fff;
  box-shadow:0 4px 18px rgba(43,43,43,.06);
}
.product-swatch{
  position:relative;
  width:100%;
  aspect-ratio:1/1;
}
.product-swatch img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.product-thumbs{
  display:flex;
  gap:10px;
  padding:12px;
  flex-wrap:wrap;
}
.product-thumb{
  width:56px;
  height:56px;
  padding:0;
  border-radius:8px;
  border:2px solid transparent;
  overflow:hidden;
  cursor:pointer;
  background:#f1f0f4;
  flex-shrink:0;
}
.product-thumb img{width:100%; height:100%; object-fit:cover; display:block;}
.product-thumb.active{border-color:var(--teal);}
.product-info .badge-cat{
  display:inline-block;
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  padding:5px 12px;
  border-radius:20px;
  margin-bottom:14px;
}
.product-info h1{
  font-family:'Playfair Display', serif;
  font-size:24px;
  margin:0 0 8px;
  line-height:1.25;
}
.product-price{
  font-size:22px;
  font-weight:800;
  color:var(--text);
  margin:0 0 4px;
}
.product-code{
  color:var(--muted);
  font-size:13px;
  margin:0 0 22px;
}
.product-block{margin-bottom:20px;}
.product-block h4{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--muted);
  margin:0 0 8px;
}
.product-block p{
  font-size:14.5px;
  line-height:1.6;
  margin:0;
  color:var(--text);
}
.product-cta{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:#25d366;
  color:#fff;
  text-decoration:none;
  font-weight:700;
  font-size:14.5px;
  padding:13px 24px;
  border-radius:30px;
  margin-top:6px;
  transition:transform .15s ease, filter .15s ease;
}
.product-cta:hover{transform:translateY(-2px); filter:brightness(1.05);}
.product-cta svg{width:17px; height:17px;}
.product-notfound{text-align:center; padding:60px 20px;}
.product-notfound h1{font-family:'Playfair Display', serif; font-size:24px; margin-bottom:10px;}
.product-notfound p{color:var(--muted); margin-bottom:22px;}
.back-link{
  display:inline-flex;
  align-items:center;
  gap:6px;
  color:var(--muted);
  text-decoration:none;
  font-size:13.5px;
  font-weight:600;
  margin:20px 0 0;
}
.back-link:hover{color:var(--teal);}
.back-link svg{width:14px; height:14px;}

/* ---- GENERIC CATEGORY ICON SWATCH (categoria.html / item.html) ---- */
.product-swatch.icon-swatch{display:flex; align-items:center; justify-content:center;}
.product-swatch.icon-swatch img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block;}
.product-swatch.icon-swatch .icon-wrap{position:relative; z-index:1; display:flex; align-items:center; justify-content:center; width:100%; height:100%;}
.product-swatch.icon-swatch .icon-wrap svg{width:34%; height:34%;}
.product-swatch.icon-swatch.tone-teal{background:rgba(63,182,176,.12);} .product-swatch.icon-swatch.tone-teal svg{color:var(--teal);}
.product-swatch.icon-swatch.tone-green{background:rgba(63,174,90,.12);} .product-swatch.icon-swatch.tone-green svg{color:var(--green);}
.product-swatch.icon-swatch.tone-orange{background:rgba(232,150,60,.14);} .product-swatch.icon-swatch.tone-orange svg{color:#b56a1c;}
.product-swatch.icon-swatch.tone-pink{background:rgba(225,70,124,.12);} .product-swatch.icon-swatch.tone-pink svg{color:var(--pink);}
.product-swatch.icon-swatch.tone-blue{background:rgba(79,143,224,.12);} .product-swatch.icon-swatch.tone-blue svg{color:var(--blue);}
.product-swatch.icon-swatch.tone-purple{background:rgba(142,111,216,.12);} .product-swatch.icon-swatch.tone-purple svg{color:var(--purple);}
.cat-page-head{margin-bottom:8px;}
.cat-page-head p{max-width:640px;}

/* ---- FOOTER ---- */
.site-footer{
  border-top:1px solid var(--card-border);
  margin-top:60px;
  padding-top:46px;
  background:#faf9fc;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.3fr 1fr 1fr;
  gap:36px;
  padding-bottom:34px;
}
@media (max-width:700px){
  .footer-grid{grid-template-columns:1fr; gap:30px; text-align:left;}
}
.footer-logo{
  height:30px;
  width:auto;
  margin-bottom:14px;
}
.footer-brand p{
  color:var(--muted);
  font-size:13.3px;
  line-height:1.65;
  margin:0 0 18px;
  max-width:320px;
}
.footer-social{
  display:flex;
  gap:10px;
}
.footer-social a.icon-circle{width:36px; height:36px;}
.footer-social a.icon-circle svg{width:16px; height:16px;}
.footer-col h4{
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:#a29db3;
  margin:0 0 16px;
}
.footer-col a, .footer-col span{
  display:flex;
  align-items:center;
  gap:8px;
  color:var(--text);
  text-decoration:none;
  font-size:13.8px;
  margin-bottom:12px;
  line-height:1.4;
}
.footer-col a svg, .footer-col span svg{width:14px; height:14px; flex-shrink:0; color:var(--teal);}
.footer-col a:hover{color:var(--teal);}
.footer-bottom{
  border-top:1px solid var(--card-border);
  padding:16px 0;
}
.footer-bottom .wrap{
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  gap:10px;
}
.footer-bottom p{
  color:#a09db0;
  font-size:12px;
  margin:0;
}

/* ---- TESTIMONIALS ---- */
.rating-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:#fff;
  border:1px solid var(--card-border);
  border-radius:30px;
  padding:8px 18px;
  margin:0 0 8px;
}
.rating-badge .stars{color:#e8963c; font-size:15px; letter-spacing:1px;}
.rating-badge strong{font-size:14px;}
.rating-badge span{color:var(--muted); font-size:13px;}
.testimonials-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  gap:20px;
}
.testimonial-card{
  background:#fff;
  border:1px solid var(--card-border);
  border-radius:16px;
  padding:22px 20px;
  box-shadow:0 4px 14px rgba(43,43,43,.05);
}
.testimonial-card .stars{
  color:#e8963c;
  font-size:14px;
  letter-spacing:2px;
  margin-bottom:10px;
}
.testimonial-card p{
  font-size:14.5px;
  line-height:1.55;
  color:var(--text);
  margin:0 0 14px;
}
.testimonial-author{
  display:block;
  font-size:12.8px;
  font-weight:700;
  color:var(--muted);
}
.testimonial-author span{
  display:block;
  font-weight:400;
  font-size:12px;
  color:#a29db3;
  margin-top:2px;
}

/* ---- PHOTO CARDS (Produtos/Serviços) ---- */
.card-photo{
  display:block;
  width:calc(100% + 44px);
  margin:-26px -22px 16px -22px;
  height:150px;
  object-fit:cover;
  border-radius:17px 17px 0 0;
}
