

body .menu-top{position:sticky;top:0;z-index:90;background:linear-gradient(90deg,rgba(43,22,13,.97),rgba(84,43,24,.95),rgba(43,22,13,.97));border-bottom:1px solid rgba(213,177,128,.24);box-shadow:0 12px 34px rgba(17,8,4,.18)}
body .menu-top-wrap{min-height:90px;display:flex;align-items:center;justify-content:space-between;gap:20px}
body .menu-brand{font-family:"Playfair Display",serif;font-size:2.4rem;font-weight:800;color:#fff4e8}
body .menu-nav{display:flex;gap:8px;flex-wrap:wrap}
body .menu-nav a{color:#f6ead8;font-weight:700;padding:12px 16px;border-radius:999px}
body .menu-nav a.active,body .menu-nav a:hover{background:rgba(255,255,255,.08)}
body .menu-hero{position:relative;overflow:hidden;padding:72px 0 44px;background:#2f170f}
body .menu-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(28,13,8,.56), rgba(28,13,8,.34) 36%, rgba(28,13,8,.72)), url("../img/hero-bg.webp") center/cover no-repeat}
body .menu-hero .container{position:relative;z-index:2}
body .menu-eyebrow{display:inline-block;margin-bottom:18px;padding:9px 16px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);font-size:.82rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#fff7ec}
body .menu-hero h1{margin:0 0 14px;font-family:"Playfair Display",serif;font-size:clamp(2.3rem,5vw,4.4rem);line-height:1.05;color:#fff8ee;text-shadow:0 8px 24px rgba(0,0,0,.24)}
body .menu-hero p{margin:0;max-width:820px;font-size:clamp(1rem,2vw,1.16rem);line-height:1.75;color:#f2e3d4}
body .menu-main{padding:60px 0 72px}
body .menu-section{margin-bottom:44px}
body .menu-title-wrap{display:flex;gap:18px;align-items:center;margin-bottom:18px;background:rgba(255,250,244,.94);border:1px solid var(--line);padding:18px;border-radius:26px;box-shadow:var(--shadow)}
body .menu-cat-icon{width:84px;height:84px;border-radius:22px;background:#efe2d4;border:1px solid var(--line);object-fit:cover}
body .menu-section h2{margin:0 0 6px;font-family:"Playfair Display",serif;font-size:clamp(2rem,3vw,3rem)}
body .menu-section p{margin:0;color:var(--muted);line-height:1.8}
body .product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
body .product-card{background:rgba(255,250,244,.95);border:1px solid var(--line);border-radius:28px;overflow:hidden;box-shadow:var(--shadow)}
body .product-media{padding:18px 18px 0;background:transparent}
body .product-media img{width:100%;aspect-ratio:1.28/1;object-fit:cover;border-radius:22px}
body .product-body{padding:18px 20px 22px}
body .product-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px}
body .product-top h3{margin:0;font-family:"Playfair Display",serif;font-size:clamp(1.55rem,2vw,2rem);line-height:1.1;color:var(--brown)}
body .product-top strong{font-size:1.45rem;color:var(--accent-dark);white-space:nowrap}
body .product-body p{margin:0;color:var(--muted);line-height:1.75}
body .menu-contact{background:linear-gradient(180deg,#34190f,#23110b);color:#f5e3d1;padding:34px 0 26px}
body .menu-contact-grid{display:grid;grid-template-columns:1fr .9fr;gap:24px;align-items:start}
body .menu-contact h2{margin:0 0 12px;font-family:"Playfair Display",serif;font-size:2.4rem;color:#fff2e6}
body .menu-contact p{margin:0 0 8px;color:#edd7c2}
body .menu-contact-box{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);border-radius:26px;padding:24px}
body .menu-contact-box strong{display:block;font-family:"Playfair Display",serif;font-size:2rem;margin-bottom:8px}
body .menu-contact-box span{color:#edd7c2}
body .menu-contact-link{color:#fff2e6;text-decoration:none;font-weight:800;border-bottom:1px solid rgba(216,191,146,.55)}
body .menu-contact-link:hover{color:#f2dfbf}
body .menu-whatsapp-inline{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 16px;margin-top:10px;border-radius:999px;background:#2b8a57;color:#fff;text-decoration:none;font-weight:800;box-shadow:0 12px 24px rgba(0,0,0,.14)}

@media (max-width: 1100px){
  .cards-two,.cards-quad,.gallery-grid,.price-panels,body .product-grid,.footer-grid{grid-template-columns:repeat(2, minmax(0,1fr))}
  .feature-card{grid-template-columns:1fr}
}
@media (max-width: 860px){
  .strip-inner{min-height:auto;padding:10px 0;align-items:flex-start;flex-direction:column}
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center}
  .nav{position:fixed;right:16px;top:94px;width:min(320px, calc(100vw - 32px));padding:16px;background:rgba(36,18,11,.98);border:1px solid rgba(213,177,128,.24);border-radius:24px;box-shadow:0 20px 40px rgba(0,0,0,.28);display:none;flex-direction:column;align-items:stretch;backdrop-filter:blur(16px)}
  .nav.open{display:flex}
  .nav a{padding:14px 16px}
  .hero-home .hero-inner{padding:58px 0 34px}
  .hero-stage{min-height:200px}
  .float-coffee{width:min(42vw,280px)}
  .float-gelato{width:min(34vw,220px)}
  .float-grill{width:min(36vw,230px)}
  .split,.cta-grid,body .menu-contact-grid{grid-template-columns:1fr}
  .masonry-grid .wide,.masonry-grid .tall{grid-column:auto;grid-row:auto}
}
@media (max-width: 640px){
  body{padding-bottom:78px}
  .top-contact-strip{display:none}
  .container{width:min(100% - 20px, 1180px)}
  .nav-wrap{min-height:84px}
  .brand img{height:48px}
  .hero-copy h1{font-size:clamp(2rem,10vw,3rem)}
  .hero-copy p{font-size:1rem}
  .hero-actions,.left-actions{justify-content:flex-start}
  .hero-home .hero-copy{ text-align:left }
  .hero-stage{display:none}
  .cards-two,.cards-quad,.gallery-grid,.masonry-grid,.price-panels,.footer-grid,.mixed-visual,body .product-grid{grid-template-columns:1fr}
  .feature-cards{margin-top:0;padding-top:58px}
  .section{padding:58px 0}
  .copy-panel,.visual-panel,.cta-banner,.map-card{padding:22px}
  .cta-grid .btn{width:100%}
  .footer-bottom-inner{flex-direction:column;justify-content:center;padding:12px 0}
  .whatsapp-float{display:none}
  .mobile-contact-bar{display:grid;grid-template-columns:1fr 1fr;position:fixed;left:0;right:0;bottom:0;z-index:999;background:#24150f;border-top:1px solid rgba(255,255,255,.12);box-shadow:0 -12px 24px rgba(0,0,0,.18)}
  .mobile-contact-bar a{min-height:62px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800}
  .mobile-contact-bar .call-action{background:#5a3723}
  .mobile-contact-bar .wa-action{background:#2b8a57}
  body .menu-top-wrap{min-height:80px}
  body .menu-brand{font-size:1.8rem}
  body .menu-title-wrap{align-items:flex-start;flex-direction:column}
}


/* Mobile polish v2 */
body{overflow-x:hidden}
@media (max-width:860px){
  body .menu-top{backdrop-filter:blur(18px)}
  body .menu-top-wrap{min-height:80px;align-items:flex-start;flex-direction:column;justify-content:center;padding:14px 0}
  body .menu-brand{font-size:1.85rem}
  body .menu-nav{width:100%;overflow:auto;flex-wrap:nowrap;padding-bottom:4px}
  body .menu-nav a{white-space:nowrap;padding:10px 14px;font-size:.95rem}
  body .menu-hero{padding:46px 0 28px}
  body .menu-hero h1{font-size:clamp(2rem,9vw,3.2rem)}
  body .menu-hero p{font-size:1rem;line-height:1.65}
  body .menu-main{padding:36px 0 60px}
  body .menu-title-wrap{padding:16px;border-radius:20px;align-items:flex-start;flex-direction:column}
  body .menu-cat-icon{width:62px;height:62px;border-radius:16px}
  body .product-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  body .product-card{border-radius:22px}
  body .product-media{padding:14px 14px 0}
  body .product-media img{border-radius:16px;aspect-ratio:1.2/1}
  body .product-body{padding:16px 16px 18px}
}
@media (max-width:640px){
  body{padding-bottom:78px}
  body .menu-brand{font-size:1.58rem}
  body .menu-top-wrap{gap:10px}
  body .menu-nav{gap:8px}
  body .menu-nav a{font-size:.92rem}
  body .menu-hero{padding:38px 0 22px}
  body .menu-hero h1{font-size:clamp(1.9rem,10vw,2.7rem)}
  body .menu-hero p{font-size:.98rem}
  body .product-grid{grid-template-columns:1fr}
  body .menu-contact-grid{grid-template-columns:1fr}
  body .menu-contact h2{font-size:2rem}
  body .menu-contact-box{padding:18px;border-radius:20px}
  .whatsapp-float{display:none}
  .mobile-contact-bar{display:grid;grid-template-columns:1fr 1fr;position:fixed;left:0;right:0;bottom:0;z-index:999;background:#24150f;border-top:1px solid rgba(255,255,255,.12);box-shadow:0 -12px 24px rgba(0,0,0,.18)}
  .mobile-contact-bar a{min-height:60px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;text-decoration:none}
  .mobile-contact-bar .call-action{background:#5a3723}
  .mobile-contact-bar .wa-action{background:#2b8a57}
}
