/* Core theme (mantém seu visual original) */
:root{
  --bg:#0f1115;
  --panel:#151923;
  --gold:#fcf81e;
  --muted:#9aa3b2;
  --white:#f3f4f6;
  --accent:#f5e61a;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:Montserrat,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu;background:var(--bg);color:var(--white)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1200px,92%);margin:0 auto}
.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:10px;top:10px;width:auto;height:auto;background:#000;color:#fff;padding:8px;border-radius:6px;z-index:999}

.site-header{position:sticky;top:0;z-index:10;background:rgba(15,17,21,.75);backdrop-filter:blur(10px);border-bottom:1px solid #232633}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand-logo{height:100px;border-radius:8px;border:1px solid #232633}
.title{font-family:"Bebas Neue";letter-spacing:1px;font-size:28px}
.nav a.btn{padding:10px 16px;border:1px solid var(--gold);border-radius:999px;transition:.25s;display:inline-flex;align-items:center;gap:8px}
.nav a.btn:hover,.nav a.btn:focus-visible{background:var(--gold);color:#111;outline:none}

.hero{position:relative;overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:center;padding:48px 0}
.badge{display:inline-flex;align-items:center;gap:8px;background:#1b2130;border:1px solid #2a3142;color:var(--accent);padding:6px 10px;border-radius:999px;font-size:12px}
h1{font-family:"Bebas Neue";font-weight:700;font-size:clamp(36px,6vw,64px);line-height:1;letter-spacing:1px;margin:14px 0}
.lead{color:var(--muted);font-size:16px;max-width:56ch}
.cta{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap}
.cta .primary{background:var(--gold);color:#111;padding:12px 18px;border-radius:10px;border:1px solid var(--gold);font-weight:700}
.cta .ghost{border:1px solid #2a3142;padding:12px 18px;border-radius:10px;color:var(--white)}

.barber-stripes{height:8px;background:repeating-linear-gradient(135deg,#c01d2e 0 16px,#ffffff 16px 32px,#1b4bd8 32px 48px)}

section{padding:48px 0}
.section-title{font-family:"Bebas Neue";font-size:40px;margin:0 0 18px}
.grid{display:grid;gap:18px}
.services{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.card {
  background: var(--panel);
  border: 1px solid #232633;
  border-radius: 16px;
  padding: 18px;
  transition: transform .2s ease;
}

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

.card h3 {
  margin: 6px 0 8px;
  font-family: "Bebas Neue";
  font-size: 28px;
  color: var(--accent);
}
.price{color:var(--muted);font-size:14px}

.filters{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.chip{border:1px solid #2a3142;background:transparent;color:var(--white);padding:8px 12px;border-radius:999px;cursor:pointer;transition:.2s}
.chip.active,.chip:hover,.chip:focus-visible{border-color:var(--gold);outline:none}

/* --- Galeria em grid uniforme --- */
.gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(410px, 1fr));
  gap: 16px;
}

.shot {
  border-radius: 17px;
  border: 1px solid #232633;
  overflow: hidden;
  background: #0d0f14;
  display: flex;
  flex-direction: column;
}

.shot img {
  width: 100%;
  aspect-ratio: 1 / 1;     /* padrão mobile → quadrado */
  object-fit: cover;
  cursor: zoom-in;
  transition: transform .4s ease, opacity .3s ease;
}

.shot .meta {
  padding: 10px;
  color: #c7cfdb;
  font-size: 12px;
  border-top: 1px solid #232633;
}

/* 👉 A partir de 768px, muda para retangular 4:3 */
@media (min-width: 768px) {
  .shot img {
    aspect-ratio: 4 / 3;
  }
}

/* Breakpoints da galeria */
@media (max-width: 768px) {
  .gallery {
    grid-template-columns: 1fr 1fr; /* duas colunas no tablet */
  }
}

@media (max-width: 480px) {
  .gallery {
    grid-template-columns: 1fr; /* apenas uma coluna no celular */
  }
  .shot img {
    aspect-ratio: 3 / 2; /* formato mais retangular em celulares */
  }
  .shot .meta {
    font-size: 14px;
    text-align: center;
  }
}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.85);display:none;align-items:center;justify-content:center;flex-direction:column;padding:20px;z-index:30}
.lightbox img{max-width:96vw;max-height:80vh;border-radius:12px;border:1px solid #333;margin-bottom:8px}
.lightbox-cap{color:#c7cfdb;font-size:14px}
.lightbox.show{display:flex}
.lightbox-close{position:absolute;top:14px;right:18px;font-size:36px;background:transparent;border:none;color:#fff;cursor:pointer;line-height:1}

footer{padding:24px 0;color:#8e98aa;border-top:1px solid #232633}
.footer-flex{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}

.whatsapp-fab {
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  cursor: pointer;
  transition: transform 0.2s;
}

.whatsapp-fab:hover {
  transform: scale(1.1);
}

:focus-visible{outline:2px dashed var(--gold);outline-offset:2px}
@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important}
}

/* Ajustes de responsividade */
@media (max-width: 768px) {
  .hero .wrap {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .info-cards {
    margin-top: 20px;
  }
  .card {
    font-size: 15px;
    padding: 16px;
  }
}

/* Estilo para mapa */
.map-container {
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid #232633;
  margin-top: 16px;
}

/* Ajuste de navegação no mobile */
@media (max-width: 600px) {
  .nav {
    flex-direction: column;
    align-items: center;
    gap: 12px;
  }
  .nav a.btn {
    width: 100%;
    justify-content: center;
    text-align: center;
  }
}

/* Melhorar navegação mobile */
@media (max-width: 600px) {
  .nav {
    flex-direction: column;
    align-items: center;
    gap: 10px;
  }
  .nav a.btn {
    width: auto;
    min-width: 140px;
    text-align: center;
    justify-content: center;
    padding: 10px 20px;
  }
}

.services .card {
  box-shadow: 0 4px 12px rgba(68, 65, 50, 0.6); /* sombra amarela */
  border-radius: 12px; /* opcional, deixa arredondado */
  transition: transform 0.2s, box-shadow 0.2s;
}

/* Efeito no hover */
.services .card:hover {
  transform: translateY(-4px);
  box-shadow: 0 6px 18px rgba(255, 215, 0, 0.9);
}

.card {
  background: var(--panel);
  border-radius: 16px;
  padding: 18px;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  box-shadow: 0 4px 12px rgba(68, 65, 50, 0.6); /* sombra suave */
}

.card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(255, 215, 0, 0.85); /* brilho mais forte */
}
