
/* Garantir que hidden sempre funcione */
[hidden]{
  display:none !important;
}

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700&family=Poppins:wght@300;400;500;600;700&display=swap');

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: 'Poppins', sans-serif;
  background: #fff8f6;
  color: #3b2f2f;
}

/* TOP BAR FIXA */
/* BLOQUEAR SCROLL QUANDO MENU ESTIVER ABERTO */

body.menu-open {
  overflow: hidden;
  height: 100vh;
}
.top-bar {
  background: #131313;
  padding: 10px 8%;
  display: flex;
  justify-content: center;
  gap: 35px;
  flex-wrap: wrap;

  position: fixed;
  top: 0;
  left: 0;
  width: 100%;

  z-index: 1002;
}

.top-bar a {
  color: #fff;
  text-decoration: none;
  font-size: 14px;
}

.top-bar i {
  margin-right: 6px;
}

/* HEADER FIXO */

.header {
  width: 100%;
  padding: 16px 2%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: fixed;
  top: 35px;
  left: 0;
  z-index: 1001;

  transition:
    background 0.4s ease,
    backdrop-filter 0.4s ease,
    box-shadow 0.4s ease,
    padding 0.4s ease;
}
.header.scrolled {
  background: #131313;
  backdrop-filter: blur(12px);
}
.header.scrolled .bi-list{
  color: white;
}

/* MENU BUTTON */

.menu-toggle {
  width: 48px;
  height: 58px;
  border: none;
  border-radius: 50%;
  background: transparent;
  color: #C5A367;
  font-size: 28px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: 0.3s;
  position: relative;
  z-index: 1004;
}

.menu-toggle i {
  font-size: 40px;
}

.menu-toggle:hover {
  transform: scale(1.05);
}

/* NAV LATERAL */

nav {
  position: fixed;
  top: 0;
  left: -320px;
  width: 320px;
  height: 100vh;

  background: #0f0f0f;
  border-right: 1px solid rgba(197,163,103,0.25);

  padding: 120px 25px 30px;

  transition: 0.4s ease;

  z-index: 1003;
}

nav.active {
  left: 0;
}

/* OVERLAY ESCURO */

.overlay {
  position: fixed;
  inset: 0;

  background: rgba(0,0,0,0.55);

  opacity: 0;
  visibility: hidden;

  transition: 0.3s ease;

  z-index: 1000;
}

.overlay.active {
  opacity: 1;
  visibility: visible;
}

/* NAV UL */

nav ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

/* LI COM ÍCONE NO FINAL */

nav ul li {
  font-size: 15px;
  font-weight: 500;
  cursor: pointer;
  color: #fff;
  transition: 0.3s;

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;

  border-bottom: 1px solid rgba(255,255,255,0.08);
  padding-bottom: 10px;
}

/* LINKS MENU LATERAL */

nav ul li a {
  width: 100%;

  color: #fff;

  display: flex;
  align-items: center;
  justify-content: space-between;

  gap: 14px;

  text-decoration: none;

  transition: 0.3s;
}

nav ul li a i {
  color: #C5A367;
}

nav ul li a:hover {
  color: #C5A367;
}
nav ul li:last-child {
  border-bottom: none;
}

nav ul li i {
  font-size: 17px;
  color: #C5A367;
}

nav ul li:hover {
  color: #C5A367;
  transform: translateX(4px);
}

/* BUTTONS */

.buttons {
  display: flex;
  gap: 12px;
}

.buttons a {
  text-decoration: none;
  padding: 10px 18px;
  border-radius: 30px;
  font-size: 14px;
  font-weight: 600;
  transition: 0.3s;
}

.login {
  color: #ffffff;
  border: 1px solid #ffffff;
}

.cadastro {
  background: linear-gradient(135deg, #131313, #131313);
  color: #fff;
}

.buttons a:hover {
  transform: translateY(-2px);
}
/* =========================================================
   LOCATION SELECT
========================================================= */

.services-location-selector {
  height: 58px;

  padding: 0 18px;

  background: transparent;

  border-radius: 18px;

  display: flex;
  align-items: center;
  gap: 14px;

  transition: 0.3s ease;
}



/* ICON */

.services-location-selector i {
  color: #C5A367;

  font-size: 22px;
}

/* CONTENT */

.services-location-content {
  display: flex;
  flex-direction: column;
}

.services-location-content span {
  color: rgba(255,255,255,0.58);

  font-size: 11px;
  font-weight: 500;

  text-transform: uppercase;

  letter-spacing: 1px;
}

/* SELECT */

.services-location-content select {
  background: transparent;
  border: none;
  outline: none;

  color: #fff;

  font-size: 14px;
  font-weight: 700;

  cursor: pointer;

  appearance: none;

  padding-right: 15px;
}

/* OPTION */

.services-location-content select option {
  background: #131313;
  color: #fff;
}

/* RESPONSIVO */

@media (max-width: 1100px) {

  .services-location-selector {
    display: none;
  }
}
/* =========================================================
   SERVICES HEADER
========================================================= */
/* BUTTONS */

.services-buttons {
  display: flex;
  align-items: center;
  gap: 14px;
}

/* LOGIN */

.services-login {
  color: #fff;

  border: 1px solid #fff;

  padding: 10px 18px;

  border-radius: 30px;

  font-size: 14px;
  font-weight: 600;

  transition: 0.3s ease;
}

.services-login:hover {
  transform: translateY(-2px);
}

/* REGISTER */

.services-register {
  background: #131313;
  color: #fff;

  padding: 10px 18px;

  border-radius: 30px;

  font-size: 14px;
  font-weight: 600;

  display: flex;
  align-items: center;
  gap: 10px;

  transition: 0.3s ease;
}

.services-register i {
  color: #C5A367;
}

.services-register:hover {
  transform: translateY(-2px);
}

/* DIVIDER */

.services-divider {
  width: 1px;
  height: 34px;

  background: rgba(255,255,255,0.18);
}

/* CART */

.services-cart {
  display: flex;
  align-items: center;
  gap: 10px;

  color: #fff;

  font-size: 15px;
  font-weight: 700;

  transition: 0.3s ease;
}

.services-cart i {
  color: #C5A367;
  font-size: 24px;
}

.services-cart:hover {
  transform: translateY(-2px);
}

.services-cart:hover i {
  transform: scale(1.08);
}

/* RESPONSIVO */

@media (max-width: 850px) {

  .services-divider,
  .services-cart span {
    display: none;
  }

  .services-cart i {
    font-size: 22px;
  }
}

@media (max-width: 700px) {

  .services-buttons {
    gap: 8px;
  }

  .services-login,
  .services-register {
    padding: 9px 12px;
    font-size: 12px;
  }

  .services-register i {
    display: none;
  }
}
/* HEADER */

.services-header {
  width: 100%;
  padding: 16px 2%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: fixed;
  top: 30px;
  left: 0;
  z-index: 1001;
  background: rgba(19,19,19,0.92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255,255,255,0.05);
  transition: 0.4s ease;
}

/* MENU BUTTON */

.services-menu-toggle {
  width: 48px;
  height: 58px;

  border: none;
  border-radius: 50%;

  background: transparent;

  color: #C5A367;

  cursor: pointer;

  display: flex;
  align-items: center;
  justify-content: center;

  position: relative;

  z-index: 1005;

  transition: 0.3s;
}

.services-menu-toggle i {
  font-size: 40px;
}

.services-menu-toggle:hover {
  transform: scale(1.05);
}

/* NAV */

.services-nav-menu {
  width: 320px;
  height: 100vh;

  position: fixed;
  top: 0;
  left: -320px;

  background: #0f0f0f;

  border-right: 1px solid rgba(197,163,103,0.25);

  padding: 120px 25px 30px;

  transition: 0.4s ease;

  z-index: 1004;
}

.services-nav-menu.active {
  left: 0;
}

.services-nav-menu ul {
  list-style: none;

  display: flex;
  flex-direction: column;

  gap: 18px;
}

.services-nav-menu ul li {
  border-bottom: 1px solid rgba(255,255,255,0.08);

  padding-bottom: 10px;

  transition: 0.3s;
}

.services-nav-menu ul li:last-child {
  border-bottom: none;
}

.services-nav-menu ul li:hover {
  transform: translateX(4px);
}

.services-nav-menu ul li a {
  width: 100%;

  color: #fff;

  display: flex;
  align-items: center;
  justify-content: space-between;

  gap: 14px;

  text-decoration: none;

  font-size: 15px;
  font-weight: 500;

  transition: 0.3s;
}

.services-nav-menu ul li a:hover {
  color: #C5A367;
}

.services-nav-menu ul li a i {
  color: #C5A367;
  font-size: 17px;
}

/* OVERLAY */

.services-overlay {
  position: fixed;
  inset: 0;

  background: rgba(0,0,0,0.65);

  opacity: 0;
  visibility: hidden;

  pointer-events: none;

  transition:
    opacity 0.3s ease,
    visibility 0.3s ease;

  z-index: 1000;
}

.services-overlay.active {
  opacity: 1;
  visibility: visible;

  pointer-events: auto;
}

/* SEARCH */

.services-search {
  width: 100%;
  max-width: 540px;
  height: 54px;

  background: rgba(255,255,255,0.08);

  border: 1px solid rgba(255,255,255,0.12);

  border-radius: 50px;

  padding: 0 22px;

  display: flex;
  align-items: center;
  gap: 14px;

  backdrop-filter: blur(10px);

  transition: 0.3s ease;
}

.services-search:hover {
  border-color: rgba(197,163,103,0.45);
}


.services-search i {
  color: #C5A367;
  font-size: 18px;
}

.services-search input {
  width: 100%;
  height: 100%;

  background: transparent;
  border: none;
  outline: none;

  color: #fff;

  font-size: 15px;
  font-family: 'Poppins', sans-serif;
}

.services-search input::placeholder {
  color: rgba(255,255,255,0.65);
}

/* BUTTONS */

.services-buttons {
  display: flex;
  gap: 12px;
}

.services-buttons a {
  padding: 10px 18px;

  border-radius: 30px;

  text-decoration: none;

  font-size: 14px;
  font-weight: 600;

  transition: 0.3s;
}

.services-login {
  color: #fff;
  border: 1px solid #fff;
}

.services-register {
  background: #131313;
  color: #fff;
}
.services-register .bi-box-arrow-up-right{
  color: white;
}

.services-buttons a:hover {
  transform: translateY(-2px);
}

/* BODY */

body.services-page {
  padding-top: 95px;
}

/* RESPONSIVO */

@media (max-width: 1100px) {

  .services-search {
    max-width: 380px;
  }
}

@media (max-width: 850px) {

  .services-search {
    display: none;
  }
}

@media (max-width: 700px) {

  .services-header {
    padding: 14px 5%;
  }

  .services-menu-toggle {
    width: 44px;
    height: 44px;
  }

  .services-menu-toggle i {
    font-size: 34px;
  }

  .services-nav-menu {
    width: 280px;
    left: -280px;

    padding-top: 110px;
  }

  .services-nav-menu.active {
    left: 0;
  }

  .services-nav-menu ul li a {
    font-size: 14px;
  }

  .services-buttons {
    gap: 8px;
  }

  .services-buttons a {
    padding: 9px 12px;
    font-size: 12px;
  }

  body.services-page {
    padding-top: 82px;
  }
}
/* =========================================================
   USER PROFILE
========================================================= */

.services-user-profile {
  display: flex;
  align-items: center;
  gap: 12px;

  cursor: pointer;

  transition: 0.3s ease;
}

.services-user-profile:hover {
  transform: translateY(-2px);
}

/* FOTO */

.services-user-profile img {
  width: 46px;
  height: 46px;

  border-radius: 50%;

  object-fit: cover;

  border: 2px solid rgba(197,163,103,0.45);

  box-shadow:
    0 4px 12px rgba(0,0,0,0.18);
}

/* INFO */

.services-user-info {
  display: flex;
  flex-direction: column;
}

.services-user-info span {
  color: rgba(255,255,255,0.55);

  font-size: 11px;
  font-weight: 500;

  letter-spacing: 1px;

  text-transform: uppercase;
}

.services-user-info strong {
  color: #fff;

  font-size: 14px;
  font-weight: 700;
}

/* RESPONSIVO */

@media (max-width: 950px) {

  .services-user-info {
    display: none;
  }
}

@media (max-width: 700px) {

  .services-user-profile img {
    width: 40px;
    height: 40px;
  }
}
/* BANNER */

.banner {
  min-height: 100vh;
  background: url(/frontend/assets/image/banner.png);
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  overflow: hidden;
  background-size: cover;
  background-position: center;
}

/* PARCERIAS DENTRO DO BANNER */

.parcerias {
  width: 100%;
  background: #050505;
  padding: 15px 0;
  top: 25px;
  overflow: hidden;
  position: relative;
  z-index: 2;
}

.parcerias-slider {
  width: 100%;
  overflow: hidden;
  position: relative;
}

.parcerias-track {
  display: flex;
  align-items: center;
  gap: 45px;
  width: max-content;
  animation: parceriasMove 22s linear infinite;
}

.parceria-logo {
  min-width: 90px;
  height: 30px;

  display: flex;
  align-items: center;
  justify-content: center;

  padding: 15px 25px;
}

.parceria-logo img {
  max-width: 100%;
  max-height: 55px;
  object-fit: contain;

  filter: grayscale(100%);
  opacity: 0.55;

  transition: 0.4s ease;
}

.parceria-logo:hover img {
  filter: grayscale(0%);
  opacity: 1;
}

@keyframes parceriasMove {
  from {
    transform: translateX(-50%);
  }

  to {
    transform: translateX(0);
  }
}

@media (max-width: 700px) {
  .parcerias {
    padding: 18px 0;
  }

  .parcerias-track {
    gap: 30px;
    animation-duration: 18s;
  }

  .parceria-logo {
    min-width: 130px;
    height: 65px;
    padding: 12px 18px;
  }

  .parceria-logo img {
    max-height: 45px;
  }
}

/* SOBRE */

.sobre {
  width: 100%;
  padding: 120px 8%;
  background: #fff;
}

.sobre-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 70px;
}

.sobre-image {
  position: relative;
}

.sobre-image img {
  width: 100%;
  max-width: 520px;
  display: block;
  border-radius: 30px;
}

.sobre-subtitle {
  color: #C5A367;
  font-weight: 600;
  letter-spacing: 4px;
  font-size: 14px;
}

.sobre-content h2 {
  font-size: 48px;
  line-height: 1.2;
  margin: 18px 0 25px;
  color: #111;
  font-family: 'Playfair Display', serif;
}

.sobre-content h2 span {
  color: #C5A367;
}

.sobre-content p {
  font-size: 16px;
  line-height: 1.9;
  color: #555;
  margin-bottom: 35px;
}

.sobre-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-bottom: 35px;
}

.sobre-card {
  padding: 25px 20px;
  border-radius: 22px;
  transition: 0.3s;
}

.sobre-card i {
  font-size: 28px;
  color: #C5A367;
  margin-bottom: 15px;
}

.sobre-card h3 {
  font-size: 17px;
  margin-bottom: 10px;
  color: #111;
}

.sobre-card p {
  font-size: 14px;
  line-height: 1.6;
  margin: 0;
}

.sobre-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 28px;
  border-radius: 40px;
  background: linear-gradient(135deg, #111, #2b2b2b);
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  transition: 0.3s;
}

.sobre-btn:hover {
  transform: translateY(-3px);
}

.sobre-btn i {
  font-size: 18px;
}

/* TABLET */

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

  .header {
    top: 0;
  }

  .container {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .gold-line {
    display: none;
  }

  .line {
    margin: 25px auto;
  }


  .cta,
  .location {
    margin-left: 0;
  }

  .right {
    min-height: auto;
  }

  .model {
    height: 560px;
    border-radius: 40px;
    box-shadow: 0 0 0 6px #C5A367;
  }

  .card {
    position: relative;
    right: auto;
    bottom: auto;
    margin: -80px auto 0;
  }

  .sobre-container {
    grid-template-columns: 1fr;
  }

  .sobre-content {
    text-align: center;
  }

  .sobre-image img {
    margin: 0 auto;
  }

  .sobre-content h2 {
    font-size: 38px;
  }

  .sobre-cards {
    grid-template-columns: 1fr;
  }

  .sobre-btn {
    justify-content: center;
  }
}

/* MOBILE */

@media (max-width: 700px) {
  .header {
    top: 0;
    padding: 14px 5%;
  }

  nav {
    width: 280px;
    left: -280px;
    padding-top: 110px;
  }

  nav.active {
    left: 0;
  }

  nav ul li {
    font-size: 14px;
  }

  .buttons {
    gap: 8px;
  }

  .buttons a {
    padding: 9px 12px;
    font-size: 12px;
  }

  .menu-toggle {
    width: 44px;
    height: 44px;
    font-size: 26px;
  }

  .container {
    padding: 30px 20px;
  }

  .logo p {
    letter-spacing: 10px;
  }


  .cta {
    width: 100%;
    justify-content: center;
    padding: 16px 20px;
    font-size: 18px;
  }

  .model {
    height: 420px;
  }

  .card {
    width: 100%;
    padding: 22px;
  }

  .card-items {
    grid-template-columns: 1fr;
  }

  .footer {
    justify-content: center;
    text-align: center;
  }

  .socials {
    flex-direction: column;
    gap: 12px;
  }

  .sobre {
    padding: 80px 5%;
  }

  .sobre-content h2 {
    font-size: 30px;
  }

  .sobre-content p {
    font-size: 15px;
  }

  .sobre-image img {
    border-radius: 25px;
  }
}
/* SECTION TRATAMENTOS */

.tratamentos {
  width: 100%;
  padding: 120px 8%;

  background: #131313;
}

/* TITULO */

.tratamentos-title {
  text-align: center;
  margin-bottom: 70px;
}

.tratamentos-title span {
  color: #C5A367;
  font-size: 14px;
  letter-spacing: 4px;
  font-weight: 600;
}

.tratamentos-title h2 {
  color: white;

  font-size: 48px;

  margin-top: 15px;

  font-family: 'Playfair Display', serif;
}

.tratamentos-title h2 strong {
  color: #C5A367;
  font-weight: 700;
}

/* CONTAINER */

.tratamentos-container {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

/* CARD */

.tratamento-card {
  position: relative;

  height: 620px;

  overflow: hidden;

  border-radius: 30px;

  cursor: pointer;
}

/* IMG */

.tratamento-card img {
  width: 100%;
  height: 100%;

  object-fit: cover;

  filter: grayscale(100%);

  transition:
    transform 0.6s ease,
    filter 0.6s ease;
}

/* HOVER */

.tratamento-card:hover img {
  filter: grayscale(0%);
  transform: scale(1.05);
}

/* OVERLAY */

.tratamento-overlay {
  position: absolute;

  inset: 0;

  background: linear-gradient(
    to top,
    rgba(0,0,0,0.92),
    rgba(0,0,0,0.15)
  );

  display: flex;
  flex-direction: column;
  justify-content: flex-end;

  padding: 40px 30px;

  transition: 0.4s ease;
}

/* TITULO CARD */

.tratamento-overlay h3 {
  color: #C5A367;

  font-size: 30px;

  margin-bottom: 14px;

  font-family: 'Playfair Display', serif;
}

/* TEXTO */

.tratamento-overlay p {
  color: rgba(255,255,255,0.85);

  line-height: 1.8;

  font-size: 15px;
}

/* RESPONSIVO */

@media (max-width: 1100px) {

  .tratamentos-container {
    grid-template-columns: 1fr;
  }

  .tratamento-card {
    height: 550px;
  }
}

@media (max-width: 700px) {

  .tratamentos {
    padding: 80px 5%;
  }

  .tratamentos-title h2 {
    font-size: 34px;
  }

  .tratamento-card {
    height: 480px;
  }

  .tratamento-overlay {
    padding: 30px 22px;
  }

  .tratamento-overlay h3 {
    font-size: 24px;
  }

  .tratamento-overlay p {
    font-size: 14px;
  }
}
/* SERVIÇOS */

.servicos {
  width: 100%;
  padding: 120px 8%;
  background: #ffffff;
}

/* HEADER */

.servicos-header {
  text-align: center;
  max-width: 850px;
  margin: 0 auto 70px;
}

.servicos-header span {
  color: #C5A367;
  font-size: 14px;
  letter-spacing: 4px;
  font-weight: 600;
}

.servicos-header h2 {
  font-size: 48px;
  color: #111;
  margin: 18px 0 20px;
  line-height: 1.2;
  font-family: 'Playfair Display', serif;
}

.servicos-header h2 strong {
  color: #C5A367;
}

.servicos-header p {
  color: #666;
  font-size: 16px;
  line-height: 1.8;
}

/* GRID */

.servicos-container {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

/* CARD */

.servico-box {
  background: #fff;
  border-radius: 30px;

  padding: 40px 35px;

  border: 1px solid rgba(0,0,0,0.06);

  transition: 0.4s ease;

  position: relative;

  overflow: hidden;
}

.servico-box::before {
  content: "";

  position: absolute;

  top: 0;
  left: 0;

  width: 100%;
  height: 4px;

  background: #C5A367;

  transform: scaleX(0);

  transition: 0.4s ease;
}

.servico-box:hover::before {
  transform: scaleX(1);
}

.servico-box:hover {
  transform: translateY(-8px);

  box-shadow: 0 15px 40px rgba(0,0,0,0.08);
}

/* CARD DESTAQUE */

.servico-box.destaque {
  background: #111;
}

.servico-box.destaque h3,
.servico-box.destaque p,
.servico-box.destaque a {
  color: white;
}

/* ICON */

.servico-icon {
  width: 70px;
  height: 70px;

  border-radius: 20px;

  background: rgba(197,163,103,0.12);

  display: flex;
  align-items: center;
  justify-content: center;

  margin-bottom: 28px;
}

.servico-icon i {
  font-size: 30px;
  color: #C5A367;
}

/* TEXT */

.servico-box h3 {
  font-size: 24px;
  margin-bottom: 18px;
  color: #111;
  font-family: 'Playfair Display', serif;
}

.servico-box p {
  color: #666;
  line-height: 1.8;
  margin-bottom: 28px;
  font-size: 15px;
}

/* LINK */

.servico-box a {
  display: inline-flex;
  align-items: center;
  gap: 10px;

  color: #111;
  text-decoration: none;

  font-weight: 600;

  transition: 0.3s;
}

.servico-box a:hover {
  gap: 16px;
}

.servico-box a i {
  color: #C5A367;
}

/* RESPONSIVO */

@media (max-width: 1100px) {

  .servicos-container {
    grid-template-columns: repeat(2, 1fr);
  }

  .servicos-header h2 {
    font-size: 40px;
  }
}

@media (max-width: 700px) {

  .servicos {
    padding: 80px 5%;
  }

  .servicos-container {
    grid-template-columns: 1fr;
  }

  .servicos-header {
    margin-bottom: 50px;
  }

  .servicos-header h2 {
    font-size: 30px;
  }

  .servicos-header p {
    font-size: 15px;
  }

  .servico-box {
    padding: 35px 28px;
  }

  .servico-box h3 {
    font-size: 22px;
  }
}
/* AVALIAÇÕES */

.avaliacoes {
  width: 100%;
  padding: 120px 8%;
  background: #131313;
}

/* HEADER */

.avaliacoes-header {
  text-align: center;
  margin-bottom: 70px;
}

.avaliacoes-header span {
  color: #C5A367;
  font-size: 14px;
  letter-spacing: 4px;
  font-weight: 600;
}

.avaliacoes-header h2 {
  color: white;
  font-size: 48px;
  margin-top: 16px;
  line-height: 1.2;
  font-family: 'Playfair Display', serif;
}

.avaliacoes-header h2 strong {
  color: #C5A367;
}

/* CONTAINER */

.avaliacoes-container {
  display: grid;
  grid-template-columns: 1.3fr 0.9fr;
  gap: 45px;
  align-items: center;
}

/* LEFT */

.avaliacoes-content {
  display: flex;
  flex-direction: column;
  gap: 25px;
}

/* CARD */

.avaliacao-card {
  background: rgba(255,255,255,0.03);

  border: 1px solid rgba(255,255,255,0.06);

  border-radius: 28px;

  padding: 35px;

  transition: 0.4s ease;
}

.avaliacao-card:hover {
  transform: translateY(-6px);

  border-color: rgba(197,163,103,0.35);

  box-shadow: 0 15px 40px rgba(0,0,0,0.18);
}

/* STARS */

.avaliacao-stars {
  display: flex;
  gap: 6px;
  margin-bottom: 18px;
}

.avaliacao-stars i {
  color: #C5A367;
  font-size: 18px;
}

/* TEXT */

.avaliacao-card p {
  color: rgba(255,255,255,0.82);

  line-height: 1.9;

  font-size: 15px;

  margin-bottom: 28px;
}

/* USER */

.avaliacao-user {
  display: flex;
  align-items: center;
  gap: 15px;
}

.avaliacao-user img {
  width: 60px;
  height: 60px;

  border-radius: 50%;

  object-fit: cover;

  border: 2px solid #C5A367;
}

.avaliacao-user h4 {
  color: white;
  font-size: 17px;
  margin-bottom: 5px;
}

.avaliacao-user span {
  color: rgba(255,255,255,0.55);
  font-size: 14px;
}

/* RIGHT */

.avaliacoes-admin {
  position: sticky;
  top: 130px;
}

/* IMAGE */

.admin-image {
  position: relative;
  margin-bottom: 30px;
}

.admin-image img {
  width: 100%;
  border-radius: 35px;
  object-fit: cover;
}

/* SELO */

.admin-selo {
  position: absolute;

  bottom: 25px;
  left: 25px;

  background: linear-gradient(
    135deg,
    #C5A367,
    #e9cf9d
  );

  color: #111;

  display: flex;
  align-items: center;
  gap: 10px;

  padding: 14px 22px;

  border-radius: 50px;

  font-weight: 700;

  box-shadow: 0 10px 30px rgba(0,0,0,0.18);
}

.admin-selo i {
  font-size: 18px;
}

/* TEXT */

.admin-text span {
  color: #C5A367;
  font-size: 13px;
  letter-spacing: 3px;
  font-weight: 600;
}

.admin-text h3 {
  color: white;

  font-size: 42px;

  line-height: 1.2;

  margin: 18px 0 22px;

  font-family: 'Playfair Display', serif;
}

.admin-text p {
  color: rgba(255,255,255,0.75);

  line-height: 1.9;

  font-size: 15px;
}

/* RESPONSIVO */

@media (max-width: 1100px) {

  .avaliacoes-container {
    grid-template-columns: 1fr;
  }

  .avaliacoes-admin {
    position: relative;
    top: 0;
  }

  .admin-text {
    text-align: center;
  }
}

@media (max-width: 700px) {

  .avaliacoes {
    padding: 80px 5%;
  }

  .avaliacoes-header h2 {
    font-size: 32px;
  }

  .avaliacao-card {
    padding: 28px;
  }

  .admin-text h3 {
    font-size: 30px;
  }

  .admin-selo {
    left: 50%;
    transform: translateX(-50%);
    bottom: 18px;

    width: max-content;
  }
} /* FOOTER */

.footer {
  width: 100%;

  background: #fff;

  border-top: 1px solid rgba(0,0,0,0.06);
}

/* TOP */

.footer-top {
  padding: 70px 8%;

  display: grid;
  grid-template-columns: 1.3fr 1fr 1fr 1.2fr;

  gap: 55px;
}

/* BRAND */

.footer-logo {
  width: 120px;
  margin-bottom: 22px;
}

.footer-brand p {
  color: #666;
  line-height: 1.9;
  font-size: 15px;
  margin-bottom: 28px;
}

/* SOCIAL */

.footer-socials {
  display: flex;
  gap: 14px;
}

.footer-socials a {
  width: 42px;
  height: 42px;

  border-radius: 50%;

  background: #111;

  color: #C5A367;

  display: flex;
  align-items: center;
  justify-content: center;

  text-decoration: none;

  transition: 0.3s;
}

.footer-socials a:hover {
  background: #C5A367;
  color: #111;

  transform: translateY(-4px);
}

/* COLUMN */

.footer-column h3 {
  color: #111;

  font-size: 22px;

  margin-bottom: 24px;

  font-family: 'Playfair Display', serif;
}

/* LINKS */

.footer-column a {
  display: flex;
  align-items: center;
  gap: 8px;

  margin-bottom: 16px;

  color: #666;

  text-decoration: none;

  transition: 0.3s;
}

.footer-column a i {
  color: #C5A367;
}

.footer-column a:hover {
  color: #C5A367;
  transform: translateX(5px);
}

/* CONTACT */

.footer-contact-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;

  margin-bottom: 18px;
}

.footer-contact-item i {
  color: #C5A367;
  font-size: 18px;
}

.footer-contact-item span {
  color: #666;
  line-height: 1.7;
  font-size: 15px;
}

/* SECURITY */

.footer-security-card {
  background: transparent;
  border-radius: 24px;
  padding: 20px;
  display: flex;
  align-items: center;
  gap: 18px;
  transition: 0.3s ease;
}
.footer-security-card img{
  width: 90px;
}

/* BOTTOM */
/* BOTTOM */

.footer-bottom {
  border-top: 1px solid rgba(0,0,0,0.06);

  padding: 24px 8%;

  position: relative;

  display: flex;
  align-items: center;
  justify-content: space-between;

  min-height: 90px;
}

/* LEFT */

.footer-bottom-left {
  display: flex;
  align-items: center;

  position: absolute;
  left: 8%;
}

.footer-mini-logo {
  width: 42px;
  height: 42px;
  object-fit: contain;
}

/* COPYRIGHT CENTRAL */

.footer-copy {
  position: absolute;

  left: 50%;
  transform: translateX(-50%);

  color: #666;

  font-size: 14px;
  font-weight: 500;

  white-space: nowrap;
}

/* RIGHT */

.footer-bottom-right {
  display: flex;
  align-items: center;
  gap: 12px;

  margin-left: auto;
}

.footer-bottom-right span {
  color: #666;
  font-size: 14px;
}

.footer-bottom-selo {
  height: 48px;
  object-fit: contain;
}

/* RESPONSIVO */

@media (max-width: 700px) {

  .footer-bottom {
    padding: 30px 5%;

    flex-direction: column;

    gap: 20px;

    text-align: center;
  }

  .footer-bottom-left,
  .footer-copy,
  .footer-bottom-right {
    position: relative;

    left: auto;

    transform: none;

    margin: 0 auto;
  }

  .footer-copy {
    order: 2;
  }
}
/* =========================================================
   BANNER DIA DAS MÃES FULLSCREEN
========================================================= */

.maes-banner {
  width: 100%;
  height: 100vh;

  background: #ffffff;

  position: relative;

  overflow: hidden;
}

/* CONTAINER DA IMAGEM */

.maes-banner-image {
  width: 100%;
  height: 100%;
}

/* IMAGEM */

.maes-banner-image img {
  width: 100%;
  height: 100%;

  object-fit: cover;
  object-position: center;

  display: block;
}

/* OVERLAY SUAVE */

.maes-banner::before {
  content: "";

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      to top,
      rgba(0,0,0,0.35),
      rgba(0,0,0,0.08)
    );

  z-index: 1;
}

/* RESPONSIVO */

@media (max-width: 700px) {

  .maes-banner {
    height: 75vh;
  }

  .maes-banner-image img {
    object-position: center;
  }
}
.d3-services-catalog {
  width: 100%;
  padding: 100px 8%;
  background: #f4f1ec;
}

.d3-services-heading {
  text-align: center;
  max-width: 760px;
  margin: 0 auto 55px;
}

.d3-services-heading span {
  color: #C5A367;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 5px;
}

.d3-services-heading h2 {
  font-family: 'Playfair Display', serif;
  font-size: 46px;
  color: #2b1d1a;
  margin: 14px 0;
}

.d3-services-heading p {
  color: #666;
  font-size: 16px;
  line-height: 1.7;
}

.d3-services-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}

.d3-service-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,0.12);
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  transition: 0.3s ease;
}

.d3-service-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 14px 28px rgba(0,0,0,0.12);
}

.d3-service-image {
  position: relative;
  height: 210px;
  overflow: hidden;
}

.d3-service-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: 0.4s ease;
}

.d3-service-card:hover .d3-service-image img {
  transform: scale(1.05);
}

.d3-service-image button {
  position: absolute;
  right: 14px;
  bottom: 0px;
  width: 46px;
  height: 46px;
  border: none;
  border-radius: 50%;
  background: #8b0d13;
  color: #fff;
  font-size: 21px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

.d3-service-info {
  padding: 26px 22px 28px;
}

.d3-service-info h3 {
  color: #8b0d13;
  font-size: 21px;
  margin-bottom: 10px;
  font-weight: 700;
}

.d3-service-info p {
  color: #5f514d;
  font-size: 15px;
  line-height: 1.7;
  margin-bottom: 14px;
}

.d3-service-info span {
  color: #8b0d13;
  font-size: 15px;
}

.d3-service-info strong {
  font-weight: 800;
}

@media (max-width: 1100px) {
  .d3-services-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 700px) {
  .d3-services-catalog {
    padding: 75px 5%;
  }

  .d3-services-heading h2 {
    font-size: 32px;
  }

  .d3-services-grid {
    grid-template-columns: 1fr;
  }

  .d3-service-image {
    height: 230px;
  }
}
/* ===== Segurança/auth/admin/chat - implementação PHP ===== */
[hidden], .auth-buttons[hidden] { display: none !important; }
.header-user { margin-left: auto; }
.mini-logout { color: #c49a4a; font-weight: 700; text-decoration: none; margin-left: 10px; white-space: nowrap; }
.auth-page { min-height: 100vh; display: grid; place-items: center; background: #0d0d0d; padding: 24px; }
.auth-card { width: min(440px, 100%); background: #161616; color: #fff; border: 1px solid rgba(196,154,74,.35); border-radius: 24px; padding: 32px; box-shadow: 0 20px 60px rgba(0,0,0,.35); }
.auth-card img { width: 90px; display: block; margin: 0 auto 18px; }
.auth-card h1 { text-align: center; margin-bottom: 20px; }
.auth-card label, .admin-form label { display: grid; gap: 8px; margin-bottom: 14px; font-weight: 700; }
.auth-card input, .admin-form input, .admin-form textarea, .admin-form select, .admin-table input, .admin-table textarea, #adminChatInput, #userChatInput { width: 100%; border: 1px solid rgba(196,154,74,.35); background: #0f0f0f; color: #fff; border-radius: 12px; padding: 12px; outline: none; }
.auth-card button, .admin-form button, .admin-table button, #adminChatForm button, #userChatForm button { border: 0; border-radius: 12px; padding: 12px 16px; background: #c49a4a; color: #111; font-weight: 800; cursor: pointer; }
.auth-card a { color: #c49a4a; }
.form-error { background: rgba(220, 53, 69, .14); color: #ff9da8; border: 1px solid rgba(220,53,69,.35); padding: 12px; border-radius: 12px; }
.search-suggestions { position: absolute; top: calc(100% + 8px); left: 0; right: 0; background: #151515; border: 1px solid rgba(196,154,74,.35); border-radius: 16px; overflow: hidden; z-index: 40; box-shadow: 0 18px 40px rgba(0,0,0,.25); }
.services-search { position: relative; }
.search-suggestions a, .search-suggestions span { display: block; padding: 12px 16px; color: #fff; text-decoration: none; }
.search-suggestions a:hover { background: rgba(196,154,74,.18); }
.admin-page { background: #0d0d0d; color: #fff; min-height: 100vh; }
.admin-top { display: flex; justify-content: space-between; align-items: center; gap: 20px; padding: 22px 5%; background: #151515; border-bottom: 1px solid rgba(196,154,74,.25); }
.admin-top h1 { font-size: clamp(1.2rem, 2vw, 2rem); }
.admin-top a { color: #c49a4a; text-decoration: none; margin-left: 14px; font-weight: 700; }
.admin-layout { width: min(1200px, 92%); margin: 28px auto; display: grid; grid-template-columns: 360px 1fr; gap: 20px; }
.admin-card { background: #151515; border: 1px solid rgba(196,154,74,.25); border-radius: 22px; padding: 22px; }
.admin-card.wide { grid-column: span 2; }
.admin-alert { width: min(1200px,92%); margin: 20px auto 0; background: rgba(25,135,84,.15); color: #8ff0b5; padding: 12px 16px; border-radius: 12px; }
.admin-table-wrap { overflow-x: auto; }
.admin-table { width: 100%; border-collapse: collapse; min-width: 850px; }
.admin-table th, .admin-table td { border-bottom: 1px solid rgba(255,255,255,.1); padding: 12px; vertical-align: top; }
.admin-table textarea { min-height: 74px; margin-top: 8px; }
.admin-table .danger { background: #dc3545; color: white; margin-top: 8px; }
.check { display: flex !important; grid-template-columns: auto 1fr !important; align-items: center; }
.admin-chat { display: grid; grid-template-columns: 280px 1fr; gap: 16px; }
.admin-chat aside { display: grid; align-content: start; gap: 8px; }
.chat-session-btn { text-align: left; border: 1px solid rgba(196,154,74,.25); background: #101010; color: #fff; border-radius: 12px; padding: 12px; cursor: pointer; }
.chat-session-btn small { display: block; color: #c49a4a; }
.chat-messages { height: 320px; overflow-y: auto; background: #0f0f0f; border: 1px solid rgba(196,154,74,.2); border-radius: 16px; padding: 14px; }
.chat-line { margin: 8px 0; padding: 10px 12px; border-radius: 12px; background: #222; color: #fff; word-break: break-word; }
.chat-line.admin { background: rgba(196,154,74,.25); }
.chat-line.system { background: rgba(13,110,253,.2); }
#adminChatForm, #userChatForm { display: flex; gap: 8px; margin-top: 10px; }
.support-chat { position: fixed; right: 22px; bottom: 22px; z-index: 100; }
.support-chat-btn { width: 62px; height: 62px; border-radius: 50%; border: none; background: #c49a4a; color: #111; font-size: 1.6rem; box-shadow: 0 14px 35px rgba(0,0,0,.35); cursor: pointer; }
.support-chat-panel { position: absolute; right: 0; bottom: 76px; width: min(360px, calc(100vw - 44px)); background: #151515; color: white; border: 1px solid rgba(196,154,74,.35); border-radius: 20px; padding: 14px; box-shadow: 0 18px 50px rgba(0,0,0,.4); }
.support-chat-panel header { display: flex; justify-content: space-between; align-items: center; font-weight: 800; margin-bottom: 10px; }
.support-chat-panel header button { background: transparent; border: 0; color: white; font-size: 1.5rem; cursor: pointer; }
@media (max-width: 900px) { .admin-layout, .admin-card.wide, .admin-chat { grid-template-columns: 1fr; grid-column: span 1; } .admin-top { flex-direction: column; align-items: flex-start; } }

/* Painel admin preto e branco, estilo phpMyAdmin simples */
.phpmyadmin-style { background:#f4f4f4 !important; color:#111 !important; font-family: Arial, Helvetica, sans-serif; }
.admin-top-clean { background:#fff !important; color:#111 !important; border-bottom:1px solid #cfcfcf !important; box-shadow:0 2px 8px rgba(0,0,0,.06); }
.admin-top-clean h1 { color:#111; margin:0 0 4px; }
.admin-top-clean p { margin:0; color:#555; font-size:.92rem; }
.admin-top-clean a { color:#111 !important; border:1px solid #111; padding:8px 10px; border-radius:4px; background:#fff; display:inline-block; }
.admin-shell { width:min(1320px,96%); margin:22px auto; display:grid; grid-template-columns:240px 1fr; gap:16px; align-items:start; }
.admin-sidebar { background:#fff; border:1px solid #cfcfcf; border-radius:6px; padding:10px; position:sticky; top:12px; }
.admin-sidebar-title { display:block; padding:9px 10px; border-bottom:1px solid #ddd; margin-bottom:8px; }
.admin-tab { width:100%; display:flex; align-items:center; gap:8px; border:0; border-left:4px solid transparent; background:#fff; color:#111; padding:11px 10px; text-align:left; cursor:pointer; font-weight:700; }
.admin-tab:hover, .admin-tab.active { background:#111; color:#fff; border-left-color:#777; }
.admin-content { min-width:0; }
.admin-panel { display:none; background:#fff; border:1px solid #cfcfcf; border-radius:6px; padding:18px; }
.admin-panel.active { display:block; }
.admin-panel h2 { margin:0 0 16px; color:#111; border-bottom:1px solid #ddd; padding-bottom:10px; }
.admin-stats { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:12px; margin-bottom:14px; }
.admin-stats article { border:1px solid #cfcfcf; background:#fafafa; padding:18px; border-radius:6px; }
.admin-stats span { display:block; color:#555; margin-bottom:8px; }
.admin-stats strong { font-size:2rem; }
.admin-note, .admin-help { background:#f7f7f7; border:1px solid #ddd; padding:12px; border-radius:6px; color:#222; }
.admin-form-grid { display:grid; grid-template-columns:1fr 220px; gap:12px; }
.admin-form-grid .full { grid-column:1 / -1; }
.phpmyadmin-style .auth-card label, .phpmyadmin-style .admin-form label { color:#111; }
.phpmyadmin-style .admin-form input, .phpmyadmin-style .admin-form textarea, .phpmyadmin-style .admin-form select,
.phpmyadmin-style .admin-table input, .phpmyadmin-style .admin-table textarea,
.phpmyadmin-style #adminChatInput { background:#fff !important; color:#111 !important; border:1px solid #aaa !important; border-radius:4px !important; padding:9px !important; }
.phpmyadmin-style .admin-form button, .phpmyadmin-style .admin-table button, .phpmyadmin-style #adminChatForm button { background:#111 !important; color:#fff !important; border-radius:4px !important; border:1px solid #111 !important; }
.admin-table-clean { min-width:900px; background:#fff; color:#111; }
.admin-table-clean th { background:#111; color:#fff; font-weight:700; }
.admin-table-clean th, .admin-table-clean td { border:1px solid #d8d8d8 !important; padding:10px !important; }
.admin-table-clean tr:nth-child(even) td { background:#f8f8f8; }
.admin-table-clean textarea { min-height:70px; margin:6px 0; }
.admin-table-clean .danger { background:#fff !important; color:#111 !important; margin-top:8px; border:1px solid #111 !important; }
.admin-chat-clean { display:grid; grid-template-columns:300px 1fr; gap:14px; }
.admin-chat-clean aside { border:1px solid #cfcfcf; background:#fafafa; border-radius:6px; padding:12px; }
.admin-chat-clean aside h3 { color:#111; margin:0 0 10px; }
#adminChatSessions { display:grid; gap:8px; max-height:520px; overflow:auto; }
.chat-session-btn { width:100%; border:1px solid #bbb; background:#fff; color:#111; padding:10px; border-radius:4px; text-align:left; cursor:pointer; font-weight:700; }
.chat-session-btn:hover, .chat-session-btn.active { background:#111; color:#fff; }
.chat-session-btn small { display:block; opacity:.75; margin-top:3px; }
.admin-chat-window { border:1px solid #cfcfcf; border-radius:6px; padding:12px; background:#fff; }
.chat-messages { min-height:320px; max-height:520px; overflow:auto; border:1px solid #ddd; background:#fafafa; padding:12px; border-radius:4px; margin-bottom:10px; }
#adminChatForm { display:grid; grid-template-columns:1fr auto; gap:8px; }
.phpmyadmin-style .chat-line { background:#fff; color:#111; border:1px solid #ccc; border-radius:4px; }
.phpmyadmin-style .chat-line.admin { background:#111; color:#fff; }
.phpmyadmin-style .chat-line.system { background:#eee; color:#111; }
.admin-empty { color:#555; margin:0; }
.chat-status { display:block; min-height:16px; margin-top:6px; color:#ddd; }
@media (max-width: 900px) {
  .admin-shell, .admin-chat-clean, .admin-form-grid, .admin-stats { grid-template-columns:1fr; }
  .admin-sidebar { position:static; }
  .admin-top-clean nav a { margin:4px 4px 0 0; }
}

/* ===== Correção final: painel tipo phpMyAdmin + chat estilo WhatsApp ===== */
.phpmyadmin-style { background:#fff !important; color:#111 !important; font-family:Arial, Helvetica, sans-serif !important; }
.phpmyadmin-style .pma-top { background:#f3f3f3 !important; color:#111 !important; border-bottom:1px solid #aaa !important; padding:10px 14px !important; box-shadow:none !important; }
.phpmyadmin-style .pma-top h1 { font-size:18px !important; color:#111 !important; margin:0 !important; }
.phpmyadmin-style .pma-top p { margin:3px 0 0 !important; color:#333 !important; font-size:12px !important; }
.phpmyadmin-style .pma-top nav a { background:#fff !important; color:#111 !important; border:1px solid #aaa !important; border-radius:2px !important; padding:6px 10px !important; text-decoration:none !important; }
.phpmyadmin-style .admin-shell.phpmyadmin-simple-shell { display:block !important; max-width:none !important; width:auto !important; margin:10px !important; padding:0 !important; }
.phpmyadmin-style .phpmyadmin-simple-content { border:1px solid #aaa !important; background:#fff !important; padding:10px !important; border-radius:0 !important; box-shadow:none !important; }
.phpmyadmin-style .pma-selectbar { display:flex !important; align-items:center !important; gap:10px !important; background:#e6e6e6 !important; border:1px solid #aaa !important; padding:8px !important; margin-bottom:10px !important; }
.phpmyadmin-style .pma-selectbar select { border:1px solid #777 !important; background:#fff !important; color:#111 !important; padding:5px 8px !important; min-width:240px !important; border-radius:0 !important; }
.phpmyadmin-style .admin-panel { display:none !important; background:#fff !important; border:1px solid #aaa !important; padding:10px !important; border-radius:0 !important; box-shadow:none !important; }
.phpmyadmin-style .admin-panel.active { display:block !important; }
.phpmyadmin-style .admin-panel h2 { font-size:16px !important; color:#111 !important; border-bottom:1px solid #aaa !important; padding-bottom:6px !important; margin:0 0 10px !important; }
.phpmyadmin-style .admin-stats { display:grid !important; grid-template-columns:repeat(3, minmax(120px, 1fr)) !important; gap:8px !important; }
.phpmyadmin-style .admin-stats article, .phpmyadmin-style .admin-note { border:1px solid #aaa !important; background:#f8f8f8 !important; color:#111 !important; border-radius:0 !important; box-shadow:none !important; }
.phpmyadmin-style .admin-table-clean { border-collapse:collapse !important; width:100% !important; background:#fff !important; color:#111 !important; }
.phpmyadmin-style .admin-table-clean th { background:#e6e6e6 !important; color:#111 !important; border:1px solid #999 !important; padding:6px !important; }
.phpmyadmin-style .admin-table-clean td { border:1px solid #bbb !important; padding:6px !important; vertical-align:top !important; }
.phpmyadmin-style input, .phpmyadmin-style textarea, .phpmyadmin-style select { border:1px solid #888 !important; background:#fff !important; color:#111 !important; border-radius:0 !important; padding:6px !important; }
.phpmyadmin-style button { border:1px solid #777 !important; background:#f1f1f1 !important; color:#111 !important; border-radius:0 !important; padding:6px 10px !important; cursor:pointer !important; }
.phpmyadmin-style button:hover { background:#111 !important; color:#fff !important; }
.phpmyadmin-style button.danger { background:#fff !important; color:#900 !important; border-color:#900 !important; }
.phpmyadmin-style .admin-form-grid { display:grid !important; grid-template-columns:repeat(2,minmax(180px,1fr)) !important; gap:10px !important; }
.phpmyadmin-style .admin-form-grid .full { grid-column:1 / -1 !important; }

.support-chat.whatsapp-chat { position:fixed !important; right:18px !important; bottom:18px !important; z-index:9999 !important; font-family:Arial, Helvetica, sans-serif !important; }
.support-chat-btn { width:58px !important; height:58px !important; border-radius:50% !important; border:0 !important; background:#25d366 !important; color:#fff !important; font-size:24px !important; box-shadow:0 8px 24px rgba(0,0,0,.25) !important; }
.support-chat-panel { width:min(360px, calc(100vw - 28px)) !important; height:520px !important; background:#efeae2 !important; border:1px solid #cfcfcf !important; border-radius:10px !important; padding:0 !important; overflow:hidden !important; box-shadow:0 12px 35px rgba(0,0,0,.28) !important; }
.support-chat-header { height:54px !important; background:#f0f2f5 !important; color:#111 !important; display:flex !important; align-items:center !important; justify-content:space-between !important; padding:8px 12px !important; border-bottom:1px solid #ddd !important; margin:0 !important; }
.support-brand { display:flex !important; align-items:center !important; gap:7px !important; font-size:15px !important; }
.support-brand img { width:32px !important; height:32px !important; border-radius:50% !important; object-fit:cover !important; background:#fff !important; border:1px solid #ddd !important; }
.verified-icon { color:#0095f6 !important; font-size:16px !important; }
.support-chat-header button { background:transparent !important; border:0 !important; color:#111 !important; font-size:24px !important; cursor:pointer !important; padding:0 !important; }
.whatsapp-chat .chat-messages, .whatsapp-messages, .admin-chat-window .chat-messages { background:#efeae2 !important; border:0 !important; border-radius:0 !important; padding:12px !important; height:390px !important; min-height:390px !important; max-height:390px !important; overflow-y:auto !important; margin:0 !important; }
.chat-row { display:flex !important; margin:5px 0 !important; }
.chat-row.user { justify-content:flex-end !important; }
.chat-row.admin, .chat-row.system { justify-content:flex-start !important; }
.chat-bubble { max-width:78% !important; padding:7px 9px !important; border-radius:8px !important; background:#fff !important; color:#111 !important; box-shadow:0 1px 1px rgba(0,0,0,.08) !important; font-size:14px !important; line-height:1.3 !important; word-break:break-word !important; }
.chat-row.user .chat-bubble { background:#d9fdd3 !important; }
.chat-row.system .chat-bubble { background:#fff3cd !important; margin:auto !important; text-align:center !important; max-width:92% !important; }
.chat-who { display:block !important; font-weight:bold !important; font-size:11px !important; margin-bottom:2px !important; opacity:.7 !important; }
.chat-text { white-space:pre-wrap !important; }
.chat-form { display:flex !important; gap:8px !important; padding:10px !important; background:#f0f2f5 !important; border-top:1px solid #ddd !important; }
.chat-form input { flex:1 !important; border:1px solid #ddd !important; background:#fff !important; color:#111 !important; border-radius:18px !important; padding:10px 12px !important; outline:none !important; }
.chat-form button { border:0 !important; border-radius:18px !important; background:#25d366 !important; color:#fff !important; font-weight:bold !important; padding:8px 14px !important; }
.chat-status { color:#333 !important; background:#f0f2f5 !important; display:block !important; padding:0 12px 8px !important; }

.phpmyadmin-style .admin-chat-clean { display:grid !important; grid-template-columns:280px 1fr !important; gap:10px !important; }
.phpmyadmin-style .admin-chat-clean aside, .phpmyadmin-style .admin-chat-window { border:1px solid #aaa !important; border-radius:0 !important; background:#fff !important; padding:8px !important; }
.phpmyadmin-style .admin-chat-window { padding:0 !important; overflow:hidden !important; }
.phpmyadmin-style .admin-chat-head { border-bottom:1px solid #aaa !important; }
.phpmyadmin-style .chat-session-btn { border:1px solid #999 !important; background:#fff !important; color:#111 !important; border-radius:0 !important; margin-bottom:5px !important; text-align:left !important; }
.phpmyadmin-style .chat-session-btn.active, .phpmyadmin-style .chat-session-btn:hover { background:#111 !important; color:#fff !important; }
.phpmyadmin-style .admin-chat-window .chat-messages { height:430px !important; max-height:430px !important; min-height:430px !important; }

@media (max-width: 800px) {
  .phpmyadmin-style .admin-stats, .phpmyadmin-style .admin-form-grid, .phpmyadmin-style .admin-chat-clean { grid-template-columns:1fr !important; }
  .phpmyadmin-style .pma-selectbar { align-items:flex-start !important; flex-direction:column !important; }
  .phpmyadmin-style .pma-selectbar select { width:100% !important; min-width:0 !important; }
}

/* ===== D3 PAINEL ADMIN - ESTILO HOSTINGER / HPANEL ===== */
.hostinger-panel-page {
  margin: 0 !important;
  background: #f4f5ff !important;
  color: #1f1346 !important;
  font-family: Inter, Arial, Helvetica, sans-serif !important;
}
.hpanel-header {
  min-height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 14px 24px;
  background: linear-gradient(135deg, #2f1c6a, #673de6);
  color: #fff;
  box-shadow: 0 8px 28px rgba(47,28,106,.2);
}
.hpanel-brand { display:flex; align-items:center; gap:12px; }
.hpanel-brand img { width:42px; height:42px; object-fit:contain; background:#fff; border-radius:12px; padding:4px; }
.hpanel-brand strong { display:block; font-size:18px; line-height:1.1; }
.hpanel-brand span { display:block; font-size:12px; opacity:.86; margin-top:3px; }
.hpanel-header nav { display:flex; gap:10px; flex-wrap:wrap; }
.hpanel-header nav a { color:#fff !important; border:1px solid rgba(255,255,255,.28); text-decoration:none; border-radius:10px; padding:9px 12px; font-size:14px; background:rgba(255,255,255,.08); }
.hpanel-header nav a:hover { background:#fff; color:#2f1c6a !important; }
.hpanel-layout { display:grid; grid-template-columns:280px 1fr; gap:22px; padding:22px; align-items:start; }
.hpanel-sidebar { position:sticky; top:18px; background:#fff; border:1px solid #ebe7ff; border-radius:18px; padding:18px; box-shadow:0 10px 28px rgba(47,28,106,.08); }
.hpanel-sidebar h2 { margin:0 0 14px; font-size:18px; color:#2f1c6a; }
.hpanel-sidebar label { display:block; font-weight:800; font-size:13px; margin-bottom:8px; color:#2f1c6a; }
.hpanel-sidebar select, #adminSectionSelect { width:100%; border:1px solid #d7d1ff !important; background:#fff !important; color:#2f1c6a !important; border-radius:10px !important; padding:12px !important; font-weight:700; outline:none; }
.hpanel-sidebar select:focus, #adminSectionSelect:focus { border-color:#673de6 !important; box-shadow:0 0 0 3px rgba(103,61,230,.12); }
.hpanel-tip { margin-top:14px; font-size:12px; color:#6d628f; line-height:1.5; background:#f7f5ff; border-radius:12px; padding:12px; }
.hpanel-main { min-width:0; }
.hpanel-alert { background:#e8fff4; border:1px solid #9ee8c2; color:#10623d; border-radius:14px; padding:12px 14px; margin-bottom:16px; font-weight:800; }
.hpanel-card.admin-panel { display:none !important; background:#fff !important; border:1px solid #ebe7ff !important; border-radius:18px !important; padding:20px !important; box-shadow:0 10px 28px rgba(47,28,106,.08) !important; }
.hpanel-card.admin-panel.active { display:block !important; }
.hpanel-title { display:flex; justify-content:space-between; gap:16px; align-items:flex-start; margin-bottom:18px; border-bottom:1px solid #ebe7ff; padding-bottom:16px; }
.hpanel-title span { display:block; color:#673de6; font-weight:900; text-transform:uppercase; letter-spacing:.08em; font-size:11px; }
.hpanel-title h1 { margin:4px 0 0 !important; color:#2f1c6a !important; font-size:24px !important; line-height:1.1; }
.hpanel-title > i { font-size:28px; color:#673de6; background:#f2efff; border-radius:14px; padding:10px; }
.hpanel-stats { display:grid; grid-template-columns:repeat(3, minmax(150px, 1fr)); gap:14px; }
.hpanel-stats article { background:#f7f5ff; border:1px solid #ebe7ff; border-radius:16px; padding:18px; }
.hpanel-stats small { display:block; color:#6d628f; font-weight:800; }
.hpanel-stats strong { display:block; color:#2f1c6a; font-size:34px; margin-top:8px; }
.hpanel-muted { color:#6d628f; line-height:1.5; }
.hpanel-form { display:grid; grid-template-columns:repeat(2,minmax(220px,1fr)); gap:14px; }
.hpanel-form label, .hpanel-table label { color:#2f1c6a; font-weight:800; font-size:13px; }
.hpanel-form .full { grid-column:1/-1; }
.hpanel-form .check, .hpanel-table .check { display:flex; align-items:center; gap:8px; }
.hpanel-form input, .hpanel-form textarea, .hpanel-form select,
.hpanel-table input, .hpanel-table textarea, .hpanel-table select,
#adminChatInput {
  width:100%; border:1px solid #d7d1ff !important; background:#fff !important; color:#2f1c6a !important; border-radius:10px !important; padding:10px 12px !important; margin-top:6px; outline:none;
}
.hpanel-form textarea, .hpanel-table textarea { min-height:86px; resize:vertical; }
.hpanel-btn, .hpanel-chat button, #adminChatForm button { border:0 !important; background:#673de6 !important; color:#fff !important; border-radius:10px !important; padding:11px 14px !important; font-weight:900 !important; cursor:pointer !important; box-shadow:0 8px 18px rgba(103,61,230,.18); }
.hpanel-btn:hover, .hpanel-chat button:hover, #adminChatForm button:hover { background:#5025d1 !important; }
.hpanel-btn.small { display:block; width:100%; margin-bottom:8px; padding:8px 10px !important; }
.hpanel-btn.danger { background:#ffe8ed !important; color:#b0002a !important; box-shadow:none; }
.hpanel-btn.danger:hover { background:#b0002a !important; color:#fff !important; }
.hpanel-table-wrap { overflow:auto; border:1px solid #ebe7ff; border-radius:14px; }
.hpanel-table { width:100%; border-collapse:collapse; color:#2f1c6a; min-width:900px; }
.hpanel-table th { background:#f7f5ff; text-align:left; color:#2f1c6a; padding:12px; font-size:13px; border-bottom:1px solid #ebe7ff; }
.hpanel-table td { padding:12px; border-bottom:1px solid #f0edff; vertical-align:top; }
.hpanel-table tr:hover td { background:#fbfaff; }
.hpanel-chat { display:grid; grid-template-columns:310px 1fr; gap:16px; min-height:520px; }
.hpanel-chat-list, .hpanel-chat-window { border:1px solid #ebe7ff; border-radius:16px; overflow:hidden; background:#fff; }
.hpanel-chat-list { padding:12px; }
.hpanel-chat-list h3 { margin:0 0 10px; color:#2f1c6a; font-size:16px; }
.hpanel-chat-list .chat-session-btn { width:100%; display:block; text-align:left; background:#fff !important; color:#2f1c6a !important; border:1px solid #ebe7ff !important; border-radius:12px !important; padding:10px !important; margin-bottom:8px; box-shadow:none !important; }
.hpanel-chat-list .chat-session-btn strong { display:block; font-size:13px; }
.hpanel-chat-list .chat-session-btn small { display:block; color:#6d628f; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-top:4px; }
.hpanel-chat-list .chat-session-btn.active, .hpanel-chat-list .chat-session-btn:hover { background:#f2efff !important; border-color:#673de6 !important; }
.hpanel-chat-window { display:flex; flex-direction:column; min-height:520px; }
.hpanel-chat-window .support-chat-header { flex:0 0 auto !important; background:#f7f5ff !important; color:#2f1c6a !important; border-bottom:1px solid #ebe7ff !important; }
.hpanel-chat-window .chat-messages { flex:1 1 auto !important; height:390px !important; min-height:390px !important; max-height:none !important; overflow:auto !important; background:#efeae2 !important; padding:14px !important; }
.hpanel-chat-window .chat-form { flex:0 0 auto; display:grid !important; grid-template-columns:1fr auto; gap:10px; padding:12px; background:#fff; border-top:1px solid #ebe7ff; }
.hpanel-chat-window #adminChatInput { margin:0 !important; }
.support-brand { display:flex; align-items:center; gap:8px; }
.support-brand img { width:32px !important; height:32px !important; object-fit:contain; border-radius:8px; background:#fff; padding:2px; }
.verified-icon { color:#3897f0 !important; }
.whatsapp-messages .chat-row, .chat-messages .chat-row { display:flex !important; margin:8px 0 !important; }
.whatsapp-messages .chat-row.user, .chat-messages .chat-row.user { justify-content:flex-start !important; }
.whatsapp-messages .chat-row.admin, .chat-messages .chat-row.admin { justify-content:flex-end !important; }
.whatsapp-messages .chat-row.system, .chat-messages .chat-row.system { justify-content:center !important; }
.whatsapp-messages .chat-bubble, .chat-messages .chat-bubble { max-width:78%; border-radius:12px !important; padding:8px 10px !important; color:#111 !important; background:#fff !important; box-shadow:0 1px 2px rgba(0,0,0,.12); }
.whatsapp-messages .chat-row.admin .chat-bubble, .chat-messages .chat-row.admin .chat-bubble { background:#d9fdd3 !important; }
.whatsapp-messages .chat-row.system .chat-bubble, .chat-messages .chat-row.system .chat-bubble { background:#fff8c6 !important; font-size:12px; }
.chat-who { display:block; font-size:11px; font-weight:900; opacity:.65; margin-bottom:2px; }
.chat-text { display:block; white-space:pre-wrap; word-break:break-word; }
@media (max-width: 900px) {
  .hpanel-layout { grid-template-columns:1fr; padding:14px; }
  .hpanel-sidebar { position:static; }
  .hpanel-header { flex-direction:column; align-items:flex-start; }
  .hpanel-form, .hpanel-stats, .hpanel-chat { grid-template-columns:1fr; }
}
.service-card-link{display:block;color:inherit;text-decoration:none;cursor:pointer}.service-card-link:hover{transform:translateY(-4px)}.bag-btn{position:absolute;right:14px;bottom:14px;width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:#fff;color:#7d5431;box-shadow:0 8px 20px #0002}
.support-chat-header .support-brand strong::before{content:'Atendimento Online';font-weight:800}.support-chat-header .support-brand strong{font-size:0}.verified-icon{color:#3897f0!important}.whatsapp-chat .whatsapp-chat .chat-bubble{border-radius:16px;padding:10px 12px}.whatsapp-chat .chat-row.user{text-align:right}.whatsapp-chat .chat-row.user .chat-bubble{background:#dcf8c6}.whatsapp-chat .chat-row.admin .chat-bubble{background:#fff}.whatsapp-chat .chat-row.system .chat-bubble{background:#e7e7e7;text-align:center}

/* Chat Atendimento Online - suporte oficial */
.support-chat-header .support-brand strong { font-weight: 800; }
.verified-icon, .message-verified { color: #3897f0 !important; vertical-align: -1px; }
.chat-who .message-verified { font-size: .9em; margin-left: 3px; }


/* D3 FINAL - cards e carrinho pendente */
.d3-services-catalog{background:#f4efe8!important;padding:70px 8%!important}.d3-services-heading{text-align:center;margin-bottom:36px}.d3-services-heading span{color:#c5a367!important;letter-spacing:.18em;font-weight:700}.d3-services-heading h2{font-family:'Playfair Display',serif;color:#5d3b27;font-size:42px;margin:10px 0}.d3-services-heading p{color:#7b6a5d}.d3-services-grid{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:28px;align-items:stretch}.d3-service-card{display:block!important;background:#fffdf9!important;border:1px solid #eadfce!important;border-radius:26px!important;overflow:hidden!important;text-decoration:none!important;color:#5d3b27!important;box-shadow:0 18px 45px rgba(73,47,30,.08)!important;transition:.25s ease!important}.d3-service-card:hover{transform:translateY(-6px);box-shadow:0 24px 55px rgba(73,47,30,.14)!important}.d3-service-image{height:245px!important;position:relative!important;background:#fff!important;overflow:hidden!important}.d3-service-image img{width:100%!important;height:100%!important;object-fit:cover!important;transition:.35s ease!important}.d3-service-card:hover .d3-service-image img{transform:scale(1.04)}.bag-btn{position:absolute;right:16px;bottom:16px;width:48px;height:48px;border-radius:50%;display:grid;place-items:center;background:#c5a367!important;color:#fff!important;box-shadow:0 10px 22px rgba(197,163,103,.32)}.d3-service-info{padding:22px 24px 26px!important}.d3-service-info h3{font-family:'Playfair Display',serif!important;font-size:26px!important;color:#5d3b27!important;line-height:1.15!important;text-decoration:none!important;margin-bottom:12px!important}.d3-service-info p{color:#7b6a5d!important;line-height:1.6!important;text-decoration:none!important;margin-bottom:18px!important}.d3-service-info span{color:#9a7a4a!important;text-decoration:none!important}.d3-service-info strong{color:#5d3b27!important}.d3-service-card,.d3-service-card *{text-decoration:none!important}.pending-cart-drawer{position:fixed;inset:0;background:rgba(31,24,20,.38);z-index:2000;display:flex;justify-content:flex-end}.pending-cart-card{width:min(440px,94vw);height:100%;background:#fffdf9;box-shadow:-18px 0 45px rgba(60,42,28,.18);padding:28px;overflow:auto;color:#5d3b27}.pending-cart-close{float:right;border:0;background:#f0e7d8;color:#5d3b27;border-radius:50%;width:34px;height:34px;font-size:22px}.drawer-kicker{color:#c5a367;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.pending-cart-card h2{font-family:'Playfair Display',serif;font-size:30px;margin:8px 0 20px}.empty-pending{background:#f7f0e6;border:1px solid #eadfce;border-radius:18px;padding:20px;text-align:center}.pending-item{display:flex;gap:14px;padding:14px;border:1px solid #eadfce;border-radius:18px;margin-bottom:12px;background:#fff}.pending-item img{width:86px;height:86px;object-fit:cover;border-radius:14px}.pending-item div{display:grid;gap:3px}.pending-item strong{font-size:16px}.pending-item small,.pending-item span{color:#7b6a5d}.pending-item b{color:#c5a367}.pending-item em{font-style:normal;text-transform:capitalize;color:#5d3b27;font-weight:700}


/* Correção final Atendimento Online/chat */
.support-chat-header .support-brand strong{font-size:15px!important;}
.support-chat-header .support-brand strong::before{content:none!important;}
.support-chat-header .support-brand strong{color:#111!important;font-weight:800!important;}
.chat-who .message-verified{color:#3897f0!important;font-size:13px!important;vertical-align:-1px!important;margin-left:3px!important;}


/* Login/Cadastro Google */
.google-auth-btn{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    width:100%;
    margin-top:12px;
    padding:13px 16px;
    border:1px solid rgba(0,0,0,.14);
    border-radius:12px;
    background:#fff;
    color:#222;
    font-weight:700;
    text-decoration:none;
    box-shadow:0 6px 18px rgba(0,0,0,.06);
}
.google-auth-btn:hover{
    filter:brightness(.98);
    transform:translateY(-1px);
}
.google-auth-btn .bi-google{
    font-size:18px;
}

.prime-user-icon { color: #c79a24; margin-right: 5px; vertical-align: -1px; }

/* D3 mobile overflow emergency */
@media (max-width:768px){
  html,body{width:100%!important;max-width:100%!important;overflow-x:hidden!important;margin:0!important;padding:0!important}
  body{position:relative!important}
  main,.banner,.maes-banner,.maes-banner-image,.maes-banner-image img,.services-header,.header,.service-nav,.d3-services-catalog{max-width:100%!important;overflow-x:hidden!important}
}





/* Botão de menu mobile visível somente na página inicial */
@media (max-width:768px){

  body.d3-home-page .menu-toggle{
    position:fixed !important;
    top:18px !important;
    left:18px !important;
    width:54px !important;
    height:54px !important;
    border-radius:16px !important;
    background:rgba(0,0,0,.88) !important;
    border:2px solid rgba(212,175,96,.95) !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    z-index:10000 !important;
    box-shadow:0 12px 30px rgba(0,0,0,.35) !important;
  }

  body.d3-home-page .menu-toggle i{
    color:#d4af60 !important;
    font-size:30px !important;
  }

  body.d3-home-page

  body.d3-home-page .header{
    position:fixed !important;
    top:0 !important;
    left:0 !important;
    right:0 !important;
    width:100% !important;
    height:82px !important;
    z-index:9999 !important;
    pointer-events:none !important;
    background:transparent !important;
  }

  body.d3-home-page .header .menu-toggle,
  body.d3-home-page .header .buttons,
  body.d3-home-page .header .auth-buttons,
  body.d3-home-page .header .header-user{
    pointer-events:auto !important;
  }

  body.d3-home-page .buttons.auth-buttons{
    position:fixed !important;
    top:20px !important;
    right:12px !important;
    left:auto !important;
    display:flex !important;
    align-items:center !important;
    justify-content:flex-end !important;
    gap:6px !important;
    z-index:10001 !important;
    width:auto !important;
    max-width:calc(100vw - 92px) !important;
  }

  body.d3-home-page .buttons.auth-buttons a{
    white-space:nowrap !important;
    font-size:10px !important;
    padding:8px 10px !important;
    border-radius:999px !important;
    line-height:1 !important;
    box-shadow:0 8px 20px rgba(0,0,0,.25) !important;
  }

  body.d3-home-page .buttons.auth-buttons .login{
    background:rgba(255,255,255,.92) !important;
    color:#111 !important;
  }

  body.d3-home-page .buttons.auth-buttons .cadastro{
    background:#111 !important;
    color:#fff !important;
  }
}


/* D3 final mobile menu fix */
@media (max-width:768px){

  /* Somente a página inicial recebe botão destacado */
  body.d3-home-page .menu-toggle{
    position:fixed !important;
    top:18px !important;
    left:18px !important;
    width:54px !important;
    height:54px !important;
    border-radius:16px !important;
    background:rgba(0,0,0,.88) !important;
    border:2px solid rgba(212,175,96,.95) !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    z-index:10050 !important;
    box-shadow:0 12px 30px rgba(0,0,0,.35) !important;
    pointer-events:auto !important;
  }

  body.d3-home-page .menu-toggle i{
    color:#d4af60 !important;
    font-size:30px !important;
  }

  body.d3-home-page .menu-toggle::after{
    content:none !important;
    display:none !important;
  }

  /* Botões Entrar/Cadastrar sempre à direita na página inicial */
  body.d3-home-page .buttons.auth-buttons{
    position:fixed !important;
    top:22px !important;
    right:12px !important;
    left:auto !important;
    display:flex !important;
    align-items:center !important;
    justify-content:flex-end !important;
    gap:8px !important;
    z-index:10040 !important;
    width:auto !important;
    max-width:calc(100vw - 88px) !important;
    pointer-events:auto !important;
  }

  body.d3-home-page.menu-open .buttons.auth-buttons{
    display:none !important;
  }

  body.d3-home-page .buttons.auth-buttons a{
    white-space:nowrap !important;
    font-size:10px !important;
    padding:8px 11px !important;
    border-radius:999px !important;
    line-height:1 !important;
    box-shadow:0 8px 20px rgba(0,0,0,.25) !important;
  }

  body.d3-home-page .buttons.auth-buttons .login{
    background:rgba(255,255,255,.95) !important;
    color:#111 !important;
  }

  body.d3-home-page .buttons.auth-buttons .cadastro{
    background:#111 !important;
    color:#fff !important;
  }

  /* Menu lateral precisa aparecer em início e serviços */
  nav.nav-menu,
  .nav-menu{
    position:fixed !important;
    top:0 !important;
    left:-86vw !important;
    width:82vw !important;
    max-width:320px !important;
    height:100vh !important;
    background:#0f0f0f !important;
    z-index:10030 !important;
    opacity:1 !important;
    visibility:visible !important;
    display:block !important;
    padding:120px 25px 30px !important;
    transition:left .32s ease !important;
    overflow-y:auto !important;
  }

  nav.nav-menu.active,
  .nav-menu.active{
    left:0 !important;
    transform:none !important;
    opacity:1 !important;
    visibility:visible !important;
    display:block !important;
  }

  .overlay.active,
  .services-overlay.active{
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
    z-index:10020 !important;
  }

  /* Serviços volta ao botão padrão, mas clicável e acima do banner */
  body.d3-services-page .menu-toggle,
  .services-header .menu-toggle{
    position:fixed !important;
    top:18px !important;
    left:18px !important;
    z-index:10050 !important;
    pointer-events:auto !important;
  }

  body.d3-services-page .menu-toggle::after,
  .services-header .menu-toggle::after{
    content:none !important;
    display:none !important;
  }
}


/* D3 mobile auth/login fix */
@media (max-width:768px){

  body.d3-home-page .buttons.auth-buttons[hidden],
  body.d3-home-page .auth-buttons[hidden],
  .buttons.auth-buttons[hidden],
  .auth-buttons[hidden]{
    display:none !important;
    visibility:hidden !important;
    opacity:0 !important;
    pointer-events:none !important;
  }

  body.d3-home-page .header-user,
  body.d3-home-page .services-user-profile.header-user{
    position:fixed !important;
    top:14px !important;
    right:10px !important;
    left:auto !important;
    z-index:10045 !important;
    max-width:calc(100vw - 88px) !important;
    min-width:0 !important;
    display:flex !important;
    align-items:center !important;
    gap:7px !important;
    padding:7px 9px !important;
    border-radius:999px !important;
    background:rgba(0,0,0,.82) !important;
    color:#fff !important;
    box-shadow:0 8px 20px rgba(0,0,0,.25) !important;
  }

  body.d3-home-page .header-user img{
    width:28px !important;
    height:28px !important;
    border-radius:50% !important;
    object-fit:cover !important;
  }

  body.d3-home-page .header-user .services-user-info{
    min-width:0 !important;
    max-width:120px !important;
    overflow:hidden !important;
  }

  body.d3-home-page .header-user .services-user-info span{
    display:none !important;
  }

  body.d3-home-page .header-user .services-user-info strong{
    display:block !important;
    color:#fff !important;
    font-size:11px !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
    max-width:120px !important;
  }

  body.d3-home-page .header-user .mini-logout{
    font-size:10px !important;
    padding:6px 8px !important;
    border-radius:999px !important;
    background:#d4af60 !important;
    color:#000 !important;
    text-decoration:none !important;
    font-weight:900 !important;
  }
}


/* D3 correção final login/cadastro e menu mobile */
@media (max-width:768px){

  [hidden],
  .auth-buttons[hidden],
  .buttons.auth-buttons[hidden],
  .services-login[hidden],
  .services-register[hidden]{
    display:none!important;
    visibility:hidden!important;
    opacity:0!important;
    pointer-events:none!important;
  }

  /* Página inicial: botões só quando deslogado e sempre à direita */
  body.d3-home-page .buttons.auth-buttons{
    position:fixed!important;
    top:22px!important;
    right:12px!important;
    left:auto!important;
    display:flex!important;
    align-items:center!important;
    justify-content:flex-end!important;
    gap:8px!important;
    z-index:10040!important;
    width:auto!important;
    max-width:calc(100vw - 88px)!important;
    pointer-events:auto!important;
  }

  body.d3-home-page.menu-open .buttons.auth-buttons{
    display:none!important;
  }

  body.d3-home-page .buttons.auth-buttons a{
    white-space:nowrap!important;
    font-size:10px!important;
    padding:8px 11px!important;
    border-radius:999px!important;
    line-height:1!important;
  }

  body.d3-home-page .header-user,
  body.d3-home-page .services-user-profile.header-user{
    position:fixed!important;
    top:14px!important;
    right:10px!important;
    left:auto!important;
    z-index:10045!important;
    max-width:calc(100vw - 88px)!important;
    display:flex!important;
    align-items:center!important;
    gap:7px!important;
    padding:7px 9px!important;
    border-radius:999px!important;
    background:rgba(0,0,0,.82)!important;
    color:#fff!important;
  }

  body.d3-home-page .header-user img{
    width:28px!important;
    height:28px!important;
  }

  body.d3-home-page .header-user .services-user-info{
    display:flex!important;
    min-width:0!important;
    max-width:120px!important;
    overflow:hidden!important;
  }

  body.d3-home-page .header-user .services-user-info span{
    display:none!important;
  }

  body.d3-home-page .header-user .services-user-info strong{
    color:#fff!important;
    font-size:11px!important;
    max-width:120px!important;
    white-space:nowrap!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
  }

  /* Serviços: quando logado, mostrar foto + nome + sair */
  body.d3-services-page .services-buttons{
    display:flex!important;
    align-items:center!important;
    gap:8px!important;
    position:relative!important;
    z-index:10045!important;
  }

  body.d3-services-page .services-buttons .auth-buttons[hidden],
  body.d3-services-page .services-login[hidden],
  body.d3-services-page .services-register[hidden]{
    display:none!important;
  }

  body.d3-services-page .services-user-profile{
    display:flex!important;
    align-items:center!important;
    gap:7px!important;
    padding:6px 8px!important;
    border-radius:999px!important;
    background:rgba(0,0,0,.72)!important;
    max-width:150px!important;
  }

  body.d3-services-page .services-user-profile img{
    width:30px!important;
    height:30px!important;
    flex:0 0 30px!important;
  }

  body.d3-services-page .services-user-info{
    display:flex!important;
    flex-direction:column!important;
    min-width:0!important;
    max-width:95px!important;
    overflow:hidden!important;
  }

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

  body.d3-services-page .services-user-info strong{
    display:block!important;
    color:#fff!important;
    font-size:11px!important;
    line-height:1.1!important;
    white-space:nowrap!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
    max-width:95px!important;
  }

  body.d3-services-page .mini-logout{
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    padding:7px 9px!important;
    font-size:10px!important;
    border-radius:999px!important;
    background:#d4af60!important;
    color:#000!important;
    font-weight:900!important;
    text-decoration:none!important;
  }

  body.d3-services-page .services-divider,
  body.d3-services-page .services-cart span{
    display:none!important;
  }

  /* Menu de serviços: lateral igual início, não tela inteira */
  body.d3-services-page nav.nav-menu,
  body.d3-services-page .nav-menu{
    position:fixed!important;
    top:0!important;
    left:-84vw!important;
    width:78vw!important;
    max-width:310px!important;
    height:100vh!important;
    background:#0f0f0f!important;
    z-index:10030!important;
    opacity:1!important;
    visibility:visible!important;
    display:block!important;
    padding:120px 24px 30px!important;
    transition:left .32s ease!important;
    overflow-y:auto!important;
    transform:none!important;
  }

  body.d3-services-page nav.nav-menu.active,
  body.d3-services-page .nav-menu.active{
    left:0!important;
    transform:none!important;
  }

  body.d3-services-page .services-overlay.active,
  body.d3-services-page .overlay.active{
    opacity:1!important;
    visibility:visible!important;
    pointer-events:auto!important;
    z-index:10020!important;
  }

  body.d3-services-page .menu-toggle{
    position:fixed!important;
    top:18px!important;
    left:18px!important;
    z-index:10050!important;
    pointer-events:auto!important;
  }

  body.d3-services-page .menu-toggle::after{
    content:none!important;
    display:none!important;
  }
}


/* D3 correção menu mobile serviços + header início */
@media (max-width:768px){

  /* Header da página inicial não pode cortar o menu quando rolar */
  body.d3-home-page .header,
  body.d3-home-page .header.scrolled{
    height:auto !important;
    min-height:82px !important;
    overflow:visible !important;
    background:transparent !important;
    box-shadow:none !important;
    border:0 !important;
    backdrop-filter:none !important;
  }

  body.d3-home-page .nav-menu,
  body.d3-home-page nav.nav-menu{
    top:0 !important;
    padding-top:120px !important;
    height:100dvh !important;
    overflow-y:auto !important;
  }

  /* Serviços: o menu deve abrir como barra lateral, não no header */
  body.d3-services-page .services-header{
    overflow:visible !important;
    height:auto !important;
    min-height:72px !important;
  }

  body.d3-services-page .nav-menu,
  body.d3-services-page nav.nav-menu,
  body.d3-services-page .services-nav-menu{
    position:fixed !important;
    top:0 !important;
    left:-84vw !important;
    width:82vw !important;
    max-width:320px !important;
    height:100dvh !important;
    min-height:100dvh !important;
    background:#0f0f0f !important;
    border-right:1px solid rgba(197,163,103,.25) !important;
    padding:120px 25px 30px !important;
    z-index:10030 !important;
    opacity:1 !important;
    visibility:visible !important;
    display:block !important;
    transform:none !important;
    transition:left .32s ease !important;
    overflow-y:auto !important;
    overflow-x:hidden !important;
  }

  body.d3-services-page .nav-menu.active,
  body.d3-services-page nav.nav-menu.active,
  body.d3-services-page .services-nav-menu.active{
    left:0 !important;
    transform:none !important;
  }

  body.d3-services-page .nav-menu ul,
  body.d3-services-page nav.nav-menu ul,
  body.d3-services-page .services-nav-menu ul{
    display:flex !important;
    flex-direction:column !important;
    gap:18px !important;
    width:100% !important;
  }

  body.d3-services-page .nav-menu li,
  body.d3-services-page nav.nav-menu li,
  body.d3-services-page .services-nav-menu li{
    width:100% !important;
    border-bottom:1px solid rgba(255,255,255,.08) !important;
    padding-bottom:10px !important;
  }

  body.d3-services-page .nav-menu a,
  body.d3-services-page nav.nav-menu a,
  body.d3-services-page .services-nav-menu a{
    width:100% !important;
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    color:#fff !important;
    text-decoration:none !important;
    font-size:15px !important;
    font-weight:600 !important;
  }

  body.d3-services-page .services-overlay,
  body.d3-services-page .overlay{
    position:fixed !important;
    inset:0 !important;
    background:rgba(0,0,0,.58) !important;
    z-index:10020 !important;
  }

  body.d3-services-page .services-overlay.active,
  body.d3-services-page .overlay.active{
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
  }

  body.d3-services-page .menu-toggle{
    position:fixed !important;
    top:18px !important;
    left:18px !important;
    z-index:10050 !important;
  }
}


/* Mobile início: login/cadastro com altura do botão menu */
@media (max-width:768px){
  body.d3-home-page .buttons.auth-buttons{
    top:18px !important;
    right:12px !important;
    height:54px !important;
    gap:8px !important;
    max-width:calc(100vw - 86px) !important;
  }

  body.d3-home-page .buttons.auth-buttons a{
    height:54px !important;
    min-height:54px !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    border-radius:16px !important;
    font-size:11px !important;
    font-weight:900 !important;
    padding:0 13px !important;
    box-shadow:0 12px 30px rgba(0,0,0,.30) !important;
  }

  body.d3-home-page .buttons.auth-buttons .login{
    min-width:70px !important;
    background:rgba(255,255,255,.96) !important;
    color:#111 !important;
    border:2px solid rgba(255,255,255,.8) !important;
  }

  body.d3-home-page .buttons.auth-buttons .cadastro{
    min-width:112px !important;
    background:rgba(0,0,0,.88) !important;
    color:#fff !important;
    border:2px solid rgba(212,175,96,.75) !important;
  }

  body.d3-home-page .buttons.auth-buttons .cadastro i{
    color:#d4af60 !important;
    font-size:13px !important;
    margin-left:4px !important;
  }
}

@media (max-width:380px){
  body.d3-home-page .buttons.auth-buttons a{
    font-size:10px !important;
    padding:0 10px !important;
  }

  body.d3-home-page .buttons.auth-buttons .login{
    min-width:62px !important;
  }

  body.d3-home-page .buttons.auth-buttons .cadastro{
    min-width:102px !important;
  }
}


/* Mobile início: usuário aparece só após scroll */
@media (max-width:768px){
  body.d3-home-page .header-user,
  body.d3-home-page .services-user-profile.header-user{
    opacity:0 !important;
    visibility:hidden !important;
    transform:translateY(-12px) !important;
    pointer-events:none !important;
    transition:opacity .25s ease, transform .25s ease, visibility .25s ease !important;
  }

  body.d3-home-page.d3-show-mobile-user .header-user,
  body.d3-home-page.d3-show-mobile-user .services-user-profile.header-user{
    opacity:1 !important;
    visibility:visible !important;
    transform:translateY(0) !important;
    pointer-events:auto !important;
  }
}

/* Ajustes D3: WhatsApp no painel e remoção de arredondamento em informações do serviço */
.whatsapp-admin{display:inline-flex;align-items:center;gap:5px;color:#128c7e!important;font-weight:800;margin-top:4px}.whatsapp-admin .bi-whatsapp{color:#25d366}.service-detail-card,.service-desc{border-radius:0!important}

/* Botão PWA: abrir no app */
.d3-open-app-wrap{position:fixed;top:8px;right:12px;z-index:999999;display:flex;justify-content:flex-end;pointer-events:none}.d3-open-app-btn{pointer-events:auto;border:0;border-radius:999px;background:#0b74c9;color:#fff;font-weight:800;font-size:13px;line-height:1;display:inline-flex;align-items:center;gap:6px;padding:8px 12px;box-shadow:0 8px 22px rgba(0,0,0,.2);cursor:pointer}.d3-open-app-btn img{width:16px;height:16px;border-radius:3px;object-fit:cover;background:#fff}.d3-has-open-app-btn{padding-top:0}@media(max-width:768px){.d3-open-app-wrap{top:7px;right:10px}.d3-open-app-btn{font-size:12px;padding:7px 11px}}
