
:root{--d3-cream:#f4efe8;--d3-card:#fffdf9;--d3-gold:#c5a367;--d3-gold-dark:#9b7641;--d3-brown:#5d3b27;--d3-muted:#7b6a5d;--d3-line:#eadfce}
.d3-services-catalog{background:var(--d3-cream)!important;padding:64px 8%!important}.d3-services-heading{text-align:center;margin-bottom:34px}.d3-services-heading h2{font-family:'Playfair Display',Georgia,serif!important;color:var(--d3-brown)!important;font-size:clamp(30px,4vw,46px)!important}.d3-services-grid{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(280px,360px))!important;gap:30px!important;justify-content:center!important}.d3-service-card{background:var(--d3-card)!important;border:1px solid var(--d3-line)!important;border-radius:26px!important;overflow:hidden!important;text-decoration:none!important;color:var(--d3-brown)!important;box-shadow:0 18px 50px rgba(73,47,30,.10)!important;transition:transform .22s ease,box-shadow .22s ease!important;max-width:360px!important}.d3-service-card:hover{transform:translateY(-7px)!important;box-shadow:0 25px 65px rgba(73,47,30,.16)!important}.d3-service-card,.d3-service-card *{text-decoration:none!important}.d3-service-image{height:230px!important;background:#fff!important;position:relative!important;overflow:hidden!important}.d3-service-image img{width:100%!important;height:100%!important;object-fit:cover!important;display:block!important}.bag-btn{background:linear-gradient(135deg,var(--d3-gold),var(--d3-gold-dark))!important;color:#fff!important}.d3-service-info{padding:24px 24px 28px!important}.d3-service-info h3{font-family:'Poppins',Arial,Helvetica,sans-serif!important;font-size:18px!important;line-height:1.25!important;color:#8f1616!important;font-weight:800!important;margin:0 0 12px!important}.d3-service-info p{color:var(--d3-muted)!important;line-height:1.65!important;margin:0 0 18px!important}.d3-service-info span{color:var(--d3-gold-dark)!important}.d3-service-info strong{color:var(--d3-brown)!important}.pending-cart-drawer{position:fixed!important;inset:0!important;background:rgba(44,33,26,.36)!important;z-index:9999!important;display:flex!important;justify-content:flex-end!important;backdrop-filter:blur(3px)}.pending-cart-card{width:min(440px,94vw)!important;height:100%!important;background:var(--d3-card)!important;padding:28px!important;box-shadow:-18px 0 55px rgba(60,42,28,.22)!important;overflow:auto!important;color:var(--d3-brown)!important;border-left:1px solid var(--d3-line)!important}.pending-cart-close{float:right;border:0;background:#f0e7d8;color:var(--d3-brown);border-radius:50%;width:36px;height:36px;font-size:22px;cursor:pointer}.drawer-kicker{color:var(--d3-gold-dark);font-weight:800;letter-spacing:.12em;text-transform:uppercase;font-size:12px}.pending-cart-card h2{font-family:'Playfair Display',Georgia,serif!important;font-size:32px!important;margin:8px 0 24px!important;color:var(--d3-brown)!important}.empty-pending,.pending-loading{background:#f7f0e6;border:1px solid var(--d3-line);border-radius:20px;padding:22px;text-align:center;color:var(--d3-muted)}.pending-item{display:flex;gap:15px;padding:15px;border:1px solid var(--d3-line);border-radius:22px;margin-bottom:14px;background:#fff;box-shadow:0 10px 26px rgba(73,47,30,.06)}.pending-item img{width:92px;height:92px;object-fit:cover;border-radius:18px;background:#faf6ef}.pending-info{display:grid;gap:6px;min-width:0}.pending-info strong{font-size:17px;color:var(--d3-brown)}.pending-info span{color:var(--d3-muted);font-size:13px}.pending-info b{font-size:18px;color:var(--d3-gold-dark)}.pending-info small{color:#6f8d5f;background:#edf8e9;border:1px solid #d9edd3;border-radius:999px;padding:5px 9px;width:max-content}

/* =========================================================
   CORREÇÃO RESPONSIVIDADE MOBILE + CARRINHO FECHADO
   ========================================================= */
.pending-cart-drawer[hidden],
#pendingCartDrawer[hidden] {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.services-buttons .auth-buttons[hidden],
.services-buttons [hidden] {
  display: none !important;
}

.services-buttons .auth-buttons:not([hidden]) {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  white-space: nowrap !important;
}

@media (max-width: 900px) {
  .top-bar {
    display: none !important;
  }

  .services-header {
    top: 0 !important;
    min-height: 64px !important;
    padding: 10px 12px !important;
    gap: 8px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
  }

  .menu-toggle,
  .services-menu-toggle {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    display: inline-flex !important;
  }

  .menu-toggle i,
  .services-menu-toggle i {
    font-size: 32px !important;
  }

  .services-search,
  .services-location-selector {
    display: none !important;
  }

  .services-buttons {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 6px !important;
    margin-left: auto !important;
    min-width: 0 !important;
    flex: 1 1 auto !important;
  }

  .services-login,
  .services-register {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 8px 10px !important;
    border-radius: 999px !important;
    font-size: 12px !important;
    line-height: 1 !important;
    min-height: 36px !important;
    max-width: 105px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  .services-register i {
    display: none !important;
  }

  .services-divider {
    display: none !important;
  }

  .services-cart {
    display: inline-flex !important;
    min-width: 42px !important;
    width: 42px !important;
    height: 42px !important;
    border-radius: 999px !important;
    justify-content: center !important;
    background: rgba(255,255,255,.08) !important;
    border: 1px solid rgba(197,163,103,.28) !important;
  }

  .services-cart span {
    display: none !important;
  }

  .services-cart i {
    font-size: 21px !important;
  }

  .services-user-profile {
    max-width: 145px !important;
    min-width: 0 !important;
    padding: 4px 6px !important;
  }

  .services-user-profile img {
    width: 32px !important;
    height: 32px !important;
  }

  .services-user-info span {
    display: none !important;
  }

  .services-user-info strong {
    font-size: 12px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    max-width: 82px !important;
    display: block !important;
  }

  .mini-logout {
    font-size: 12px !important;
    padding: 8px 9px !important;
  }

  body {
    overflow-x: hidden !important;
  }

  .d3-services-catalog {
    padding-top: 90px !important;
  }

  .d3-services-grid {
    grid-template-columns: 1fr !important;
    padding: 0 14px !important;
  }

  .d3-service-card {
    max-width: 100% !important;
  }

  .pending-cart-card {
    width: min(92vw, 390px) !important;
    padding: 22px !important;
  }
}

@media (max-width: 420px) {
  .services-login,
  .services-register {
    max-width: 88px !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }

  .services-buttons {
    gap: 5px !important;
  }

  .services-cart {
    width: 38px !important;
    min-width: 38px !important;
    height: 38px !important;
  }
}

/* Ajuste solicitado: cards de serviços sem borda arredondada e sem sombra */
.d3-services-page .d3-service-card,
.d3-services-page .d3-service-card:hover{
  border-radius:0!important;
  box-shadow:none!important;
  transform:none!important;
}
.d3-services-page .d3-service-image,
.d3-services-page .d3-service-image img{
  border-radius:0!important;
}
.d3-services-page .d3-service-card:hover .d3-service-image img{
  transform:none!important;
}
.d3-services-page .d3-service-info{
  border-radius:0!important;
}

/* Melhorias visuais no card de informação/detalhe do serviço */
.service-detail-card{
  background:#fffdf9!important;
  border:1px solid #e8dbc8!important;
  border-radius:0!important;
  box-shadow:none!important;
}
.service-top{
  gap:34px!important;
  padding:30px!important;
  align-items:stretch!important;
}
.service-top img{
  border-radius:0!important;
  border:1px solid #e8dbc8!important;
  box-shadow:none!important;
}
.service-desc{
  border-radius:0!important;
  border:1px solid #e8dbc8!important;
  background:linear-gradient(180deg,#fffdf9 0%,#fbf6ee 100%)!important;
  color:#6b4026!important;
  padding:24px!important;
  line-height:1.85!important;
  font-size:18px!important;
  box-shadow:inset 0 0 0 1px rgba(197,163,103,.08)!important;
  scrollbar-width:thin;
  scrollbar-color:#c5a367 #f1e8dc;
}
.service-desc::-webkit-scrollbar{width:8px}
.service-desc::-webkit-scrollbar-track{background:#f1e8dc}
.service-desc::-webkit-scrollbar-thumb{background:#c5a367}
.buy-area{
  background:linear-gradient(135deg,#fbf6ee 0%,#fffdf9 100%)!important;
  border-top:1px solid #e8dbc8!important;
}
.schedule{
  border-radius:0!important;
  box-shadow:none!important;
  border:1px solid #e8dbc8!important;
}
@media (max-width: 860px){
  .service-top{grid-template-columns:1fr!important;padding:18px!important;gap:18px!important}
  .service-desc{font-size:16px!important;max-height:none!important}
  .buy-area{grid-template-columns:1fr!important;text-align:left!important}
  .price-box{text-align:left!important}
}

/* Ajuste: imagens dos cards de serviços sempre ocupam o card sem quebrar layout. */
.d3-service-image img{width:100%;height:100%;object-fit:cover;display:block;background:#f5eee8;}
.d3-category-header a{color:var(--category-color,#5b371e)!important;}

/* Ajuste: título do card em uma linha sem reticências; descrição pode quebrar linha. */
.d3-services-page .d3-service-info h3{
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:clip!important;
  display:block!important;
}
.d3-services-page .d3-service-info p{
  white-space:normal!important;
  overflow:visible!important;
  text-overflow:clip!important;
  display:block!important;
}
.d3-services-page .d3-service-price,
.d3-services-page .d3-service-info strong{white-space:nowrap!important;}

/* =========================================================
   Correção final: imagem do card presa ao card + carregamento visual
   ========================================================= */
.d3-services-page .d3-services-row{
  align-items:stretch!important;
  -webkit-overflow-scrolling:touch!important;
}
.d3-services-page .d3-services-row .d3-service-card,
.d3-services-page .d3-service-card{
  position:relative!important;
  overflow:hidden!important;
  contain:paint!important;
  isolation:isolate!important;
  background:#fffdf9!important;
  flex-shrink:0!important;
}
.d3-services-page .d3-service-image{
  width:100%!important;
  height:230px!important;
  min-height:230px!important;
  position:relative!important;
  overflow:hidden!important;
  contain:paint!important;
  background:#f5eee8!important;
  flex:0 0 auto!important;
}
.d3-services-page .d3-service-image img{
  position:static!important;
  display:block!important;
  width:100%!important;
  max-width:none!important;
  height:100%!important;
  min-height:100%!important;
  object-fit:cover!important;
  object-position:center!important;
  transform:none!important;
  transition:none!important;
  opacity:1!important;
  filter:none!important;
  pointer-events:none!important;
  user-select:none!important;
}
.d3-services-page .d3-service-card:hover,
.d3-services-page .d3-service-card:hover .d3-service-image img{
  transform:none!important;
}
@media (max-width:768px){
  .d3-services-page .d3-services-row .d3-service-card{
    min-width:78vw!important;
    max-width:78vw!important;
    flex:0 0 78vw!important;
  }
  .d3-services-page .d3-service-image{
    height:235px!important;
    min-height:235px!important;
  }
}

/* =========================================================
   Correção final: banners mobile ocupando 100dvh
   ========================================================= */
@media (max-width:768px){
  body.d3-home-page .banner,
  body.d3-home-page section.banner,
  body.d3-home-page #inicio.banner{
    width:100%!important;
    min-height:100dvh!important;
    height:100dvh!important;
    max-height:none!important;
    background-image:url('/frontend/assets/image/banner-home-mobile.png')!important;
    background-size:cover!important;
    background-position:center center!important;
    background-repeat:no-repeat!important;
  }
  .maes-banner{
    width:100%!important;
    min-height:100dvh!important;
    height:100dvh!important;
    max-height:none!important;
    margin:0!important;
    padding:0!important;
    overflow:hidden!important;
    background:#0d0d0d!important;
  }
  .maes-banner-image,
  .maes-banner-image picture{
    display:block!important;
    width:100%!important;
    height:100%!important;
    min-height:100dvh!important;
    margin:0!important;
    padding:0!important;
    overflow:hidden!important;
  }
  .maes-banner-image img{
    display:block!important;
    width:100%!important;
    height:100%!important;
    min-height:100dvh!important;
    object-fit:cover!important;
    object-position:center center!important;
    margin:0!important;
    border-radius:0!important;
  }
}

.d3-service-info h3{white-space:normal!important;overflow:visible!important;text-overflow:unset!important;word-break:break-word!important}.d3-services-page .d3-service-card,.d3-services-row .d3-service-card{min-width:340px!important;max-width:340px!important}@media(max-width:768px){.d3-services-page .d3-service-card,.d3-services-row .d3-service-card{min-width:88vw!important;max-width:88vw!important}}


/* Cards de serviços compactos com título completo */
.d3-services-row{gap:14px!important}
.d3-services-row .d3-service-card,.d3-services-page .d3-services-row .d3-service-card,.d3-services-page .d3-service-card{min-width:300px!important;max-width:300px!important;flex:0 0 300px!important;border-radius:0!important;background:#fffdf9!important;border:1px solid #eadfcf!important;box-shadow:0 10px 28px rgba(73,47,30,.08)!important;overflow:hidden!important}
.d3-service-card:hover,.d3-services-page .d3-service-card:hover{transform:translateY(-3px)!important;box-shadow:0 16px 36px rgba(73,47,30,.12)!important}
.d3-service-image,.d3-services-page .d3-service-image{height:190px!important;border-radius:0!important}
.d3-service-image img,.d3-services-page .d3-service-image img{width:100%!important;height:100%!important;object-fit:cover!important}
.d3-service-info,.d3-services-page .d3-service-info{padding:22px 24px 24px!important;min-height:0!important;display:flex!important;flex-direction:column!important}
.d3-service-info h3,.d3-services-page .d3-service-info h3{font-family:'Poppins',Arial,Helvetica,sans-serif!important;color:#8f1616!important;font-size:18px!important;font-weight:800!important;line-height:1.12!important;margin:0 0 12px!important;white-space:normal!important;overflow:visible!important;text-overflow:unset!important;display:block!important;-webkit-line-clamp:unset!important;-webkit-box-orient:unset!important;word-break:normal!important;overflow-wrap:anywhere!important}
.d3-service-info p,.d3-services-page .d3-service-info p{font-size:15px!important;line-height:1.55!important;color:#6f5849!important;margin:0 0 20px!important;white-space:normal!important;overflow:visible!important;text-overflow:unset!important;display:block!important}
.d3-service-price{margin-top:auto!important;font-size:15px!important;color:#b0843f!important}
.d3-service-price strong{font-size:18px!important;color:#2f1f18!important;white-space:nowrap!important}
.d3-discount-pill{align-self:flex-start!important;margin:0 0 10px!important}.d3-popular-ribbon{height:38px!important;font-size:12px!important}
@media(max-width:768px){.d3-services-row .d3-service-card,.d3-services-page .d3-services-row .d3-service-card,.d3-services-page .d3-service-card{min-width:82vw!important;max-width:82vw!important;flex-basis:82vw!important}.d3-service-image,.d3-services-page .d3-service-image{height:180px!important}.d3-service-info h3,.d3-services-page .d3-service-info h3{font-size:18px!important}.d3-service-info,.d3-services-page .d3-service-info{padding:20px!important}}

