/* Moamba d'Angola - styles.css
   Cores principais:
   - marrom: #74694c
   - dourado: #c2b179
*/

:root{
  --brown:#74694c;
  --gold:#c2b179;
  --bg:#faf7f1;
  --muted:#777;
  --container:1200px;
  --radius:12px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:"Open Sans",system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  background:var(--bg);
  color:#222;
  -webkit-font-smoothing:antialiased;
}

.container{max-width:var(--container);margin:0 auto;padding:0 20px}

/* NAVBAR */
.nav-wrap{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .35s ease, border-bottom .35s ease, box-shadow .35s ease}

/* estado por omissão: transparente quando sobre o hero (subentendido) */
.nav-wrap:not(.scrolled){background:transparent;border-bottom:0}

/* quando estiver em modo scrolled — aparece o fundo e separação elegante */
.nav-wrap.scrolled{background:linear-gradient(rgba(255,255,255,0.95), rgba(255,255,255,0.88));backdrop-filter:blur(6px);border-bottom:1px solid rgba(0,0,0,0.04);box-shadow:0 6px 18px rgba(0,0,0,0.04)}
.navbar{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand .logo{display:flex;align-items:center;gap:10px;text-decoration:none}
/* Logo: remover caixa de fundo e aumentar tamanho para melhor visibilidade */
.logo-icon{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:0;overflow:visible;background:transparent;padding:0}
.logo-img{width:auto;max-width:72px;height:100%;object-fit:contain;display:block}

/* reduzir ligeiramente em ecrãs pequenos */
@media (max-width:680px){
  .logo-icon{width:56px;height:56px}
}
.logo-text{font-family:"Playfair Display",serif;font-weight:700}

.nav-links{list-style:none;display:flex;gap:18px;margin:0;padding:0}
/* tornar os labels do menu mais elegantes usando Playfair Display */
.nav-links a{color:var(--brown);text-decoration:none;padding:6px 8px;border-radius:6px;transition:all .25s ease;font-weight:600;font-family:"Playfair Display", serif;letter-spacing:0.4px}
.nav-links a:hover{color:var(--gold);transform:translateY(-2px);box-shadow:0 6px 18px rgba(116,105,76,0.08)}

/* cores diferentes quando estiver sobre o hero (não scrolled): links claros */
.nav-wrap:not(.scrolled) .nav-links a{color:rgba(255,255,255,0.95)}
.nav-wrap:not(.scrolled) .logo-text{color:rgba(255,255,255,0.95)}
.nav-wrap:not(.scrolled) .logo-icon{background:transparent;color:var(--gold)}

.nav-wrap.scrolled .nav-links a{color:var(--brown)}
.nav-wrap.scrolled .logo-text{color:var(--brown)}
.nav-wrap.scrolled .logo-icon{background:transparent;color:var(--gold)}

/* active link */
.nav-links a.active{background:linear-gradient(90deg,var(--gold),rgba(194,177,121,0.85));color:var(--brown);box-shadow:0 8px 30px rgba(116,105,76,0.08)}

/* Se a navbar estiver sobre o hero (transparente), não mostrar o background/borda do link activo
  — mantém o link activo com cor clara para não distrair do hero */
.nav-wrap:not(.scrolled) .nav-links a.active{background:transparent;box-shadow:none;color:rgba(255,255,255,0.95)}

.nav-toggle{display:none;background:none;border:none}
.nav-toggle .hamburger{width:28px;height:2px;background:var(--brown);display:block;position:relative;transition:background .25s}
.nav-toggle .hamburger::after,.nav-toggle .hamburger::before{content:"";position:absolute;left:0;width:28px;height:2px;background:var(--brown);transition:transform .25s,background .25s}
.nav-toggle .hamburger::before{top:-8px}
.nav-toggle .hamburger::after{top:8px}

/* adaptar a cor do hamburger quando a navbar estiver sobre o hero */
.nav-wrap:not(.scrolled) .nav-toggle .hamburger,
.nav-wrap:not(.scrolled) .nav-toggle .hamburger::before,
.nav-wrap:not(.scrolled) .nav-toggle .hamburger::after{background:#fff}
.nav-wrap.scrolled .nav-toggle .hamburger,
.nav-wrap.scrolled .nav-toggle .hamburger::before,
.nav-wrap.scrolled .nav-toggle .hamburger::after{background:var(--brown)}

/* PRELOADER */
.preloader{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#fff;z-index:9999}
.preloader-inner{display:flex;align-items:center;justify-content:center;gap:14px}
.logo-spin{width:92px;height:92px;border-radius:12px;background:transparent;display:flex;align-items:center;justify-content:center;box-shadow:none}
.logo-spin img.preloader-logo{max-width:80px;height:auto;display:block}
.logo-letter{font-family:"Playfair Display",serif;color:var(--gold);font-size:48px}
.preloader-text{margin:0;color:var(--muted);font-weight:700;font-size:16px}

/* Animação sutil do preloader */
@keyframes preloader-pulse{0%{transform:scale(1)}50%{transform:scale(1.06)}100%{transform:scale(1)}}
@keyframes preloader-fade{0%{opacity:0.85}50%{opacity:1}100%{opacity:0.85}}
.logo-spin img.preloader-logo{animation:preloader-pulse 1.6s ease-in-out infinite}
.preloader-text{animation:preloader-fade 1.6s ease-in-out infinite}

/* Pausar animação quando o preloader é escondido */
.preloader.hide .logo-spin img.preloader-logo,
.preloader.hide .preloader-text{animation-play-state:paused}

.preloader.hide{opacity:0;pointer-events:none;transition:opacity .6s}

/* HERO */
.hero{height:100vh;position:relative;display:flex;align-items:center}
.hero-bg{position:absolute;inset:0;background-image:url('../assets/img/espaco.jpg');background-size:cover;background-position:center;background-attachment:fixed;filter:contrast(0.95) brightness(0.6);z-index:0}
.hero-content{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;height:100%}
.hero-logo{text-align:center;color:#fff;padding:30px}
.brand-title{font-family:"Playfair Display",serif;font-size:48px;margin:0;color:var(--gold);text-shadow:0 6px 18px rgba(0,0,0,0.35)}
.brand-sub{margin-top:8px;color:rgba(255,255,255,0.9);font-family:'Libre Baskerville', serif;font-size:18px;letter-spacing:0.2px}
.hero-cta{margin-top:18px;display:flex;gap:12px;justify-content:center}
  .hero-cta{margin-bottom:8px}
.btn{padding:10px 18px;border-radius:8px;border:2px solid transparent;cursor:pointer;font-weight:700}
.btn{padding:10px 18px;border-radius:8px;border:2px solid transparent;cursor:pointer;font-weight:700}
/* Tornar botões visualmente mais elegantes usando Playfair Display */
.btn{font-family:"Playfair Display", serif;letter-spacing:0.6px;font-size:16px}
.btn.primary{background:var(--gold);color:var(--brown);transition:all .25s}
.btn.primary.white{color:#fff}
.btn.primary:hover{background:var(--brown);color:var(--gold);transform:translateY(-3px)}
.btn.ghost{background:transparent;border:2px solid rgba(255,255,255,0.18);color:#fff;padding:8px 16px}
.btn.ghost:hover{background:rgba(255,255,255,0.06);transform:translateY(-2px)}
.btn.ghost{background:transparent;border:2px solid rgba(255,255,255,0.18);color:#fff}

/* ABOUT */
.about{padding:80px 0}
.about-grid{display:grid;grid-template-columns:1fr 420px;gap:40px;align-items:center}
.about h2{color:var(--brown);font-family:"Playfair Display",serif;text-align:center}
.about h2::after{content:"";display:block;width:72px;height:3px;margin:12px auto 0;border-radius:4px;background:linear-gradient(90deg,var(--gold),rgba(116,105,76,0.12))}
.about-text p{color:var(--muted);line-height:1.6}
.about-image img{width:100%;border-radius:12px;box-shadow:0 14px 40px rgba(116,105,76,0.06)}

/* About page extras */
.about-text h2{font-size:32px;margin-bottom:12px;text-align:center}
.about-lead{font-family:'Libre Baskerville',serif;color:var(--muted);font-size:18px;margin-bottom:18px}
.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:18px;margin-top:20px}
.value-card{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.00));border:1px solid rgba(194,177,121,0.08);padding:16px;border-radius:12px;display:flex;gap:12px;align-items:flex-start}
.value-card i{color:var(--gold);font-size:20px;margin-top:4px}
.value-card h4{margin:0;font-size:16px;color:var(--gold);font-family:"Playfair Display",serif}
.value-card p{margin:6px 0 0;color:var(--muted);font-size:14px;line-height:1.5}

/* Services grid (elegant cards for events and takeaway) */
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;margin-top:24px;margin-bottom:32px}
.service-card{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.00));border:1px solid rgba(194,177,121,0.12);padding:22px;border-radius:12px;display:flex;gap:14px;align-items:flex-start;transition:all .3s ease}
.service-card:hover{background:linear-gradient(180deg, rgba(194,177,121,0.06), rgba(194,177,121,0.02));border-color:rgba(194,177,121,0.2);transform:translateY(-4px);box-shadow:0 8px 24px rgba(116,105,76,0.08)}
.service-card i{color:var(--gold);font-size:24px;margin-top:2px;flex-shrink:0}
.service-card h4{margin:0;font-size:16px;color:var(--brown);font-family:"Playfair Display",serif;font-weight:700}
.service-card p{margin:6px 0 0;color:var(--muted);font-size:14px;line-height:1.6}

.chef{display:flex;gap:20px;align-items:center;margin-top:32px}
.chef img{width:140px;height:140px;object-fit:cover;border-radius:12px;border:3px solid rgba(194,177,121,0.12)}
.chef-bio h3{margin:0 0 6px;font-family:"Playfair Display",serif;color:var(--brown)}
.chef-bio p{margin:0;color:var(--muted)}

.stats-row{display:flex;gap:12px;margin-top:28px}
.stat{flex:1;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.03);padding:14px;border-radius:10px;text-align:center}
.stat h3{margin:0;color:var(--gold);font-size:20px}
.stat p{margin:6px 0 0;color:var(--muted)}

.about-cta{margin-top:28px;text-align:center}
.about-cta .btn{padding:12px 22px}

@media (max-width:980px){
  .about-grid{grid-template-columns:1fr}
  .chef{flex-direction:row}
  .chef img{width:120px;height:120px}
  .stats-row{flex-direction:column}
  .services-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
  .service-card{padding:18px}
}

/* Make CTA buttons stack on small screens for better tap targets */
@media (max-width:680px){
  .about-cta .btn{display:block;width:100%;margin:8px 0}
  .about-cta .btn.ghost{margin-left:0}
  .services-grid{grid-template-columns:1fr;gap:12px}
  .service-card{padding:16px;gap:12px}
  .service-card i{font-size:20px}
  .service-card h4{font-size:15px}
  .service-card p{font-size:13px}
}

/* Ghost buttons on light sections (About / Contact) */
.about .btn.ghost,
.contact .btn.ghost{
  color:var(--brown);
  border:2px solid rgba(116,105,76,0.14);
  background:transparent;
}
.about .btn.ghost:hover,
.contact .btn.ghost:hover{
  background:rgba(116,105,76,0.06);
  color:var(--brown);
  transform:translateY(-2px);
}

/* MENU */
.menu{padding:84px 0}
.menu h2{color:var(--brown);font-family:"Playfair Display", serif;font-size:40px;letter-spacing:0.6px;text-align:center;margin:0 0 10px;position:relative}
.menu-cta{text-align:center;margin-top:40px}
.menu-cta .btn{padding:12px 24px;font-size:18px;text-decoration:none;color:#fff}
.menu-cta .btn i{margin-left:8px;transition:transform .25s ease}
.menu-cta .btn:hover i{transform:translateX(4px)}
.menu h2::after{content:"";display:block;width:72px;height:3px;margin:12px auto 0;border-radius:4px;background:linear-gradient(90deg,var(--gold),rgba(116,105,76,0.12))}
.menu .section-sub{color:var(--muted);margin:0 auto 28px;max-width:760px;text-align:center;font-family:'Libre Baskerville', serif;font-size:18px;font-style:italic}
.menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:28px;margin-top:28px;max-width:1100px;margin-left:auto;margin-right:auto}
.dish-card{background:linear-gradient(180deg, #fff, #fbf9f4);border-radius:14px;border:1px solid rgba(116,105,76,0.06);overflow:hidden;display:flex;flex-direction:column;transition:transform .28s,box-shadow .28s;padding-bottom:6px}
.dish-card:hover{transform:translateY(-10px);box-shadow:0 24px 48px rgba(116,105,76,0.10)}
.dish-media img{width:100%;height:220px;object-fit:cover}
.dish-body{padding:18px 16px}
.dish-body h3{margin:0 0 8px 0;font-family:"Playfair Display",serif;color:var(--brown);font-size:18px}
.badge{background:var(--gold);color:var(--brown);padding:4px 8px;border-radius:8px;font-size:12px;margin-left:8px;font-weight:700}
.dish-body p{color:var(--muted);margin:0 0 12px}
.dish-footer{display:flex;justify-content:space-between;align-items:center}
.price{font-weight:800;color:var(--brown)}
.tag{background:rgba(116,105,76,0.06);padding:4px 8px;border-radius:6px;font-size:12px}

/* GALLERY Masonry */
.gallery{padding:80px 0}
.masonry{column-count:3;column-gap:16px}
.m-item{break-inside:avoid;margin-bottom:16px;border-radius:8px;overflow:hidden}
.m-item img{width:100%;display:block;transition:transform .25s;cursor:pointer}
.m-item img:hover{transform:scale(1.03);filter:brightness(1.03)}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.8);opacity:0;pointer-events:none;transition:opacity .25s;z-index:200}
.lightbox[aria-hidden="false"]{opacity:1;pointer-events:auto}
.lightbox-img{max-width:90%;max-height:80%;border-radius:8px;box-shadow:0 18px 60px rgba(0,0,0,0.6)}
.lightbox-close{position:absolute;top:28px;right:32px;background:transparent;color:#fff;border:0;font-size:34px}

/* Hero Section */
.page-hero{
  background:linear-gradient(180deg,rgba(116,105,76,0.06),transparent);
  padding:72px 0;
  text-align:center;
  margin-bottom:40px;
}
.page-hero h1{
  font-family:"Playfair Display",serif;
  color:var(--brown);
  font-size:48px;
  margin:0;
  position:relative;
  display:inline-block;
}
.page-hero h1::after{
  content:"";
  display:block;
  width:80%;
  height:3px;
  margin:12px auto 0;
  border-radius:4px;
  background:linear-gradient(90deg,var(--gold),rgba(116,105,76,0.12));
}

/* Contact Section */
.contact{
  padding:0 0 40px;
}
.contact h2{
  color:var(--brown);
  font-family:"Playfair Display",serif;
  font-size:32px;
  letter-spacing:0.6px;
  text-align:center;
  margin:0 0 10px;
  position:relative;
}
.contact h2::after{
  content:"";
  display:block;
  width:72px;
  height:3px;
  margin:12px auto 0;
  border-radius:4px;
  background:linear-gradient(90deg,var(--gold),rgba(116,105,76,0.12));
}
.contact .section-sub{color:var(--muted);margin:0 auto 28px;max-width:760px;text-align:center;font-family:'Libre Baskerville',serif;font-size:18px;font-style:italic}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:center;margin-top:28px}

@media (max-width:980px){
  .contact-grid{grid-template-columns:1fr}
}

@media (max-width:680px){
  .contact-grid{gap:16px;margin-top:20px}
}
.map-frame{position:relative;border-radius:12px;overflow:hidden;border:1px solid rgba(0,0,0,0.06)}
.map-frame iframe{width:100%;height:160px;border:0;display:block}
.map-marker{position:absolute;left:50%;top:50%;transform:translate(-50%,-100%);pointer-events:none}
.map-marker span{display:block;width:26px;height:34px;background:var(--brown);border-radius:6px;position:relative;box-shadow:0 6px 18px rgba(0,0,0,0.2)}
.map-marker span::after{content:"";position:absolute;left:50%;transform:translateX(-50%);bottom:-8px;width:10px;height:10px;background:var(--gold);border-radius:50%;animation:marker-bounce 1.6s infinite}
@keyframes marker-bounce{0%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-8px)}100%{transform:translateX(-50%) translateY(0)}}

.socials{margin-top:12px;display:flex;gap:8px}
.social{display:inline-flex;width:40px;height:40px;border-radius:8px;align-items:center;justify-content:center;background:var(--brown);color:#fff;text-decoration:none;position:relative;font-size:18px;transition:transform .25s ease, background-color .25s ease}
.social:hover{background:var(--gold);color:var(--brown);transform:translateY(-3px)}
.site-footer{background:var(--brown);color:#fff;padding:40px 0 20px;margin-top:0}
.social::after{content:attr(data-tooltip);position:absolute;left:50%;transform:translateX(-50%) translateY(8px);opacity:0;pointer-events:none;background:#222;color:#fff;padding:6px 8px;border-radius:6px;font-size:12px;transition:all .18s}
.social:hover::after{opacity:1;transform:translateX(-50%) translateY(-40px)}

/* Horário */
.schedule{
  font-family:"Open Sans",sans-serif;
  font-size:14px;
  margin:0;
  padding:16px;
  background:rgba(255,255,255,0.08);
  border-radius:12px;
  width:340px;
}
.schedule-title{
  font-family:"Playfair Display",serif;
  color:var(--gold);
  margin-bottom:12px;
  font-size:18px;
  display:flex;
  align-items:center;
  gap:8px;
  justify-content:center;
  letter-spacing:0.4px;
}
.schedule-title i{font-size:18px}
.schedule-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:12px 24px;
  align-items:baseline;
  text-align:center;
}
.schedule-row{
  display:contents;
}
.day{
  color:rgba(255,255,255,0.95);
  font-weight:600;
  text-align:right;
  padding-right:12px;
  border-right:1px solid rgba(255,255,255,0.1);
}
.hours{
  color:var(--gold);
  text-align:left;
  padding-left:12px;
}

/* Versão para a página de contacto */
.contact .schedule{
  background:rgba(116,105,76,0.04);
  border:1px solid rgba(116,105,76,0.1);
  margin:28px 0;
  padding:24px 32px;
  max-width:400px;
}
.contact .schedule-title{
  color:var(--brown);
  font-size:22px;
  margin-bottom:20px;
}
.contact .day{
  color:var(--brown);
  border-right-color:rgba(116,105,76,0.1);
}
.contact .hours{color:var(--gold)}

/* FOOTER */
.footer-inner{display:grid;grid-template-columns:1.2fr auto 1fr;gap:48px;align-items:start}
.footer-col{max-width:360px}
.footer-title{font-family:"Playfair Display",serif;color:var(--gold);font-size:20px;margin:0 0 16px;display:flex;align-items:center;gap:8px}
.footer-title i{font-size:18px}
.footer-text{color:rgba(255,255,255,0.9);font-size:14px;line-height:1.6;margin:12px 0}
.footer-contact{list-style:none;padding:0;margin:16px 0}
.footer-contact li{display:flex;align-items:center;gap:8px;margin-bottom:12px;color:rgba(255,255,255,0.9)}
.footer-contact i{color:var(--gold);width:20px}
.copyright{color:rgba(255,255,255,0.8);font-size:14px;border-top:1px solid rgba(255,255,255,0.1);margin-top:24px;padding-top:16px}
.copyright span{color:var(--gold)}
.footer-links{display:grid;grid-template-columns:repeat(2, 1fr);gap:16px 24px;margin-top:4px}
.footer-links-group{display:flex;flex-direction:column;gap:12px}
.footer-links-group h4{color:var(--gold);font-family:"Playfair Display",serif;font-size:16px;margin:0 0 4px}
.footer-links a{color:rgba(255,255,255,0.9);text-decoration:none;display:flex;align-items:center;gap:8px;transition:all 0.2s ease;font-size:14px;padding:4px 0}
.footer-links a i{color:var(--gold);font-size:15px;width:18px;text-align:center;opacity:0.9}
.footer-links a:hover{color:var(--gold);transform:translateX(4px)}
.footer-links a:hover i{opacity:1}
.schedule{min-width:320px}

@media (max-width:980px){
  .footer-inner{grid-template-columns:1fr;gap:32px;text-align:center}
  .footer-links{align-items:center}
  .schedule{margin:16px auto}
  .copyright p{margin:8px 0}
  .footer-links a{justify-content:center}
  .footer-links a:hover{transform:translateY(-2px)}
  .services-highlight{justify-content:center}
  .footer-col{max-width:100%;text-align:center}
}

@media (max-width:680px){
  .site-footer{padding:28px 0 20px}
  .footer-inner{gap:24px;padding:0 16px}
  .footer-title{font-size:18px;margin:0 0 12px}
  .footer-text{font-size:13px;margin:8px 0}
  .footer-contact{margin:12px 0}
  .footer-contact li{font-size:13px;justify-content:center;margin-bottom:8px}
  .footer-contact i{width:16px;font-size:14px}
  .copyright{font-size:12px;margin-top:16px;padding-top:12px}
  .schedule-title{font-size:16px;margin:0 0 12px}
  .schedule-grid{gap:8px 12px}
  .schedule-row{font-size:12px}
  .schedule-row .day,.schedule-row .hours{font-size:12px}
  .footer-links-group h4{font-size:14px;margin:0 0 8px}
  .footer-links a{font-size:12px;padding:2px 0}
  .footer-links a i{font-size:13px}
  .services-highlight{gap:6px;flex-wrap:wrap;justify-content:center}
  .map-frame iframe{height:240px}
}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}

/* Responsive */

/* Desktop grande */
@media (min-width: 1400px) {
  .container {
    max-width: 1320px;
  }
  
  .menu-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  
  .masonry {
    column-count: 4;
  }
}

/* Tablets e desktops pequenos */
@media (max-width:980px){
  .menu-grid{grid-template-columns:repeat(2,1fr)}
  .about-grid{grid-template-columns:1fr}
  .masonry{column-count:2}
  .logo-icon{width:64px;height:64px}
  .logo-img{max-width:64px}
  
  .container {
    padding: 0 32px;
  }
  
  .hero {
    height: 60vh;
  }
}

/* Mobile */
@media (max-width:680px){
  /* Navegação mobile */
  .nav-links{
    display:none;
    position:absolute;
    right:20px;
    top:64px;
    background:#fff;
    padding:14px;
    border-radius:10px;
    box-shadow:0 10px 40px rgba(0,0,0,0.08);
    flex-direction:column
  }
  .nav-links.open{display:flex}
  /* When the mobile menu is open, links must be dark so they are readable on the white background
     (this overrides the transparent/white link style used when navbar is over the hero).
     Use a more specific selector so rules take effect immediately when the menu opens. */
  .nav-wrap .nav-links.open a,
  .nav-wrap:not(.scrolled) .nav-links.open a{
    color:var(--brown);
    opacity:1;
  }
  .nav-wrap .nav-links.open a:hover,
  .nav-wrap:not(.scrolled) .nav-links.open a:hover{
    color:var(--gold);
  }
  /* Also ensure focus is visible for keyboard/touch users */
  .nav-wrap .nav-links.open a:focus{color:var(--gold)}
  .nav-toggle{display:block}
  
  /* Layout responsivo */
  .menu-grid{grid-template-columns:1fr}
  .masonry{column-count:1}
  .brand-title{font-size:34px}
  .hero-bg{background-attachment:scroll}
  .logo-icon{width:48px;height:48px}
  .logo-img{max-width:48px}
  
  /* Melhorar área de toque */
  .nav-links a,
  .btn,
  .social {
    padding: 12px 16px;
    min-height: 44px;
  }
  
  /* Otimizar performance */
  .dish-card:hover {
    transform: none;
  }
  
  /* Ajustar espaçamentos */
  .section {
    padding: 40px 0;
  }

  /* Aumentar espaço antes da secção de contactos no mobile para evitar proximidade com o hero */
  .contact{padding-top:40px}
  
  /* Melhorar legibilidade */
  body {
    font-size: 16px;
  }
  
  /* Preloader em mobile */
  .preloader-inner{
    flex-direction:column;
    gap:8px
  }
}

/* Touch events */
@media (hover: hover) {
  .dish-card:hover {
    transform: translateY(-4px);
  }
  .nav-links a:hover {
    color: var(--gold);
    transform: translateY(-2px);
  }
  .social:hover {
    transform: translateY(-3px);
  }
}

/* Accessibility: high-contrast focus */
a:focus,button:focus{outline:3px solid rgba(194,177,121,0.35);outline-offset:2px}

/* =======================
   TESTIMONIALS
   ======================= */
.testimonials{width:100%;padding:24px 20px;background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.00));border:1px solid rgba(194,177,121,0.04);border-radius:12px;margin:20px 0 60px;box-sizing:border-box}
.testimonials h2{font-family:"Playfair Display",serif;color:var(--brown);text-align:center;margin:0 0 14px;font-size:26px}
.testimonials h2::after{content:"";display:block;width:72px;height:3px;margin:12px auto 0;border-radius:4px;background:linear-gradient(90deg,var(--gold),rgba(116,105,76,0.12))}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,minmax(300px,1fr));gap:28px;max-width:1100px;margin:0 auto;align-items:stretch;justify-items:stretch}

/* Make cards wider from right -> left (leftmost largest) on desktop */
@media (min-width:981px){
  .testimonials{margin-top:36px}
  /* Force 4 cards in one row on desktop; use smaller min width so 4 fit comfortably */
  .testimonials-grid{grid-template-columns:repeat(4,minmax(220px,1fr));max-width:1200px;gap:32px;align-items:stretch}
}
.testimonial-card{background:#fff;padding:28px;border-radius:12px;box-shadow:0 16px 40px rgba(116,105,76,0.06);border:1px solid rgba(116,105,76,0.04);color:var(--brown);display:flex;flex-direction:column;justify-content:space-between;min-height:260px;height:100%}
.testimonial-card .quote{font-style:italic;color:var(--muted);margin:0 0 16px;line-height:1.75;font-size:16px}
.testimonial-card .author{display:flex;align-items:center;gap:14px;margin-top:12px}
/* hide author image when present (we will remove images from HTML too) */
.testimonial-card .author img{display:none}
.testimonial-card .author-meta strong{display:block;color:var(--brown);font-size:15px}
.testimonial-card .author-meta span{display:block;color:var(--muted);font-size:13px}

@media (max-width:980px){
  .testimonials-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:680px){
  .testimonials-grid{grid-template-columns:1fr}
  .testimonial-card{padding:14px}
}

/* Footer services highlight - elegant badges for special services */
.services-highlight{display:flex;gap:10px;margin:16px 0 24px;flex-wrap:wrap}
.service-item{display:flex;align-items:center;gap:6px;font-size:13px;color:rgba(255,255,255,0.85);background:rgba(194,177,121,0.12);border:1px solid rgba(194,177,121,0.2);padding:8px 12px;border-radius:6px;transition:all 0.2s ease}
.service-item i{color:var(--gold);font-size:14px}
.service-item:hover{background:rgba(194,177,121,0.18);border-color:rgba(194,177,121,0.35)}
