/* ============================================================
   RIBULLY · Pasta e Pizza — Imperia
   Hoja de estilos compartida para todas las páginas
   ============================================================ */
*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --green-900:#10271a; --green-800:#163220; --green-700:#1d4329; --green-600:#266038;
  --green-500:#338049; --leaf:#4ea65d; --lime:#9ccb4a; --lime-soft:#bcd97a;
  --cream:#F6F3E6; --cream-2:#EFEAD6; --card:#FBF9EF;
  --orange:#E67A1E; --orange-d:#cf6a12; --wheat:#D9B24A;
  --ink:#1a2a1f; --ink-soft:#3c4d40; --muted:#6c7a6a;
  --eo:cubic-bezier(.22,1,.36,1); --eio:cubic-bezier(.76,0,.24,1);
  --maxw:1200px;
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{font-family:'Mulish',sans-serif;color:var(--ink);background:var(--cream);
  -webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden;-webkit-tap-highlight-color:transparent;}
h1,h2,h3,h4{font-family:'Fraunces',serif;font-weight:600;line-height:1.04;letter-spacing:-.01em;text-wrap:balance;color:var(--green-800);}
p{text-wrap:pretty;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
section{position:relative;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
::selection{background:var(--lime);color:var(--green-900);}

/* film grain */
.grain{position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.04;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* reveal */
[data-rev]{opacity:0;transform:translateY(26px);filter:blur(5px);transition:opacity .9s var(--eo),transform .9s var(--eo),filter .9s ease;}
[data-rev].seen{opacity:1;transform:none;filter:none;}
[data-d1]{transition-delay:.09s;}[data-d2]{transition-delay:.18s;}[data-d3]{transition-delay:.27s;}[data-d4]{transition-delay:.36s;}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:15px;letter-spacing:.02em;
  padding:14px 26px;border-radius:999px;cursor:pointer;border:none;transition:transform .25s var(--eo),box-shadow .35s var(--eo),background-color .25s ease;}
.btn:active{transform:scale(.97);}
.btn-pri{background:var(--orange);color:#fff;box-shadow:0 12px 28px rgba(230,122,30,.34);}
@media(hover:hover){.btn-pri:hover{transform:translateY(-3px);background:var(--orange-d);box-shadow:0 18px 38px rgba(230,122,30,.42);}}
.btn-ghost{background:rgba(255,255,255,.1);color:#fff;border:1.5px solid rgba(255,255,255,.55);backdrop-filter:blur(4px);}
@media(hover:hover){.btn-ghost:hover{background:rgba(255,255,255,.2);transform:translateY(-3px);}}
.btn-dark{background:var(--green-700);color:#fff;box-shadow:0 12px 26px rgba(16,39,26,.25);}
@media(hover:hover){.btn-dark:hover{transform:translateY(-3px);background:var(--green-600);}}
.btn-wa{background:#1FA855;color:#fff;box-shadow:0 12px 28px rgba(31,168,85,.32);}
@media(hover:hover){.btn-wa:hover{transform:translateY(-3px);background:#188f47;}}
.btn .ico{transition:transform .3s var(--eo);}
@media(hover:hover){.btn:hover .ico{transform:translateX(4px);}}
:focus-visible{outline:none;box-shadow:0 0 0 3px var(--cream),0 0 0 6px var(--leaf);border-radius:6px;}

.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'Mulish',sans-serif;font-size:12px;font-weight:800;
  letter-spacing:.28em;text-transform:uppercase;color:var(--leaf);}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--lime);border-radius:2px;}
.eyebrow.center{justify-content:center;}
.eyebrow.center::after{content:"";width:26px;height:2px;background:var(--lime);border-radius:2px;}
.eyebrow.light{color:var(--lime);}

/* ===== NAV ===== */
header{position:sticky;top:0;z-index:100;background:rgba(18,40,26,.82);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(156,203,74,.2);transition:background .3s ease;}
nav{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:11px 28px;max-width:var(--maxw);margin:0 auto;}
.brand{display:flex;align-items:center;gap:12px;cursor:pointer;}
.brand-logo{height:58px;width:auto;display:block;transition:transform .3s var(--eo),filter .3s var(--eo);
  filter:drop-shadow(0 4px 12px rgba(0,0,0,.3));}
@media(hover:hover){.brand:hover .brand-logo{transform:translateY(-1px) scale(1.03);}}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
.brand .badge{width:52px;height:52px;border-radius:50%;background:#bfe09a;display:flex;align-items:center;justify-content:center;
  overflow:hidden;box-shadow:0 6px 16px rgba(0,0,0,.25);border:2px solid rgba(255,255,255,.4);flex:0 0 auto;}
.brand .badge img{width:100%;height:100%;object-fit:cover;object-position:center 44%;}
.brand .name{font-family:'Fraunces',serif;font-weight:700;font-size:23px;color:#fff;line-height:1;}
.brand .name span{display:block;font-family:'Mulish',sans-serif;font-weight:700;font-size:9.5px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--lime);margin-top:4px;}
.nav-links{display:flex;align-items:center;gap:2px;}
.nav-links a{padding:9px 13px;font-size:14.5px;font-weight:600;color:#e9f0e2;border-radius:8px;position:relative;transition:color .25s;}
.nav-links a::after{content:"";position:absolute;left:13px;right:13px;bottom:4px;height:2px;background:var(--lime);
  transform:scaleX(0);transform-origin:left;transition:transform .4s var(--eo);}
@media(hover:hover){.nav-links a:hover{color:#fff;}.nav-links a:hover::after{transform:scaleX(1);}}
.nav-links a.active{color:#fff;}
.nav-links a.active::after{transform:scaleX(1);background:var(--orange);}
.nav-cta{margin-left:6px;padding:10px 20px;background:var(--orange);color:#fff;border-radius:999px;font-weight:700;font-size:14px;
  box-shadow:0 6px 16px rgba(230,122,30,.3);transition:transform .25s var(--eo),background .25s;}
@media(hover:hover){.nav-cta:hover{transform:translateY(-2px);background:var(--orange-d);}}
.burger{display:none;flex-direction:column;gap:4px;width:40px;height:40px;align-items:center;justify-content:center;
  background:var(--orange);border-radius:10px;cursor:pointer;border:none;box-shadow:0 6px 16px rgba(230,122,30,.3);
  position:relative;z-index:85;flex:0 0 auto;}
.burger span{width:17px;height:2px;background:#fff;border-radius:2px;transition:transform .35s var(--eo),opacity .25s ease;}
.burger.open span:nth-child(1){transform:translateY(6px) rotate(45deg);}
.burger.open span:nth-child(2){opacity:0;}
.burger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg);}
.mobile-menu{display:none;}

/* ===== HERO (home) ===== */
.hero{min-height:100svh;display:flex;align-items:flex-end;position:relative;overflow:hidden;background:var(--green-900);}
.hero .bg{position:absolute;inset:0;background:url('hero-garden.webp') center/cover;animation:zoom 2s var(--eo) both;}
@media(max-width:760px){.hero .bg{background-image:url('hero-garden-v.webp');}}
@keyframes zoom{from{transform:scale(1.1);}to{transform:scale(1);}}
.hero .veil{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(16,39,26,.55) 0%,rgba(16,39,26,.12) 30%,rgba(16,39,26,.5) 70%,rgba(10,26,17,.92) 100%),
  radial-gradient(120% 80% at 18% 100%,rgba(10,26,17,.6),transparent 60%);}
.hero .inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 28px 9vh;width:100%;}
.hero .hero-logo{margin-bottom:18px;}
.hero .hero-logo img{width:clamp(260px,40vw,460px);height:auto;filter:drop-shadow(0 18px 40px rgba(0,0,0,.5));}
.hero h1{font-size:clamp(58px,11vw,150px);color:#fff;font-weight:700;letter-spacing:-.02em;line-height:.86;
  text-shadow:0 4px 40px rgba(0,0,0,.35);}
.hero .tag{display:flex;align-items:center;gap:14px;margin:14px 0 22px;}
.hero .tag span{width:42px;height:2px;background:var(--lime);}
.hero .tag em{font-family:'Fraunces',serif;font-style:italic;font-size:clamp(19px,2.6vw,27px);color:#dcebcf;}
.hero p{max-width:540px;color:#e7efdf;font-size:clamp(16px,2vw,19px);font-weight:300;margin-bottom:32px;}
.hero .cta-row{display:flex;gap:13px;flex-wrap:wrap;}
.hero .cues{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;
  align-items:center;gap:7px;color:#cfe0c0;font-size:11px;letter-spacing:.25em;text-transform:uppercase;animation:float 2.6s ease-in-out infinite;}
@keyframes float{0%,100%{transform:translateX(-50%) translateY(0);}50%{transform:translateX(-50%) translateY(7px);}}

/* ===== PAGE HERO (inner pages) ===== */
.phero{position:relative;min-height:56vh;display:flex;align-items:flex-end;overflow:hidden;background:var(--green-900);}
.phero .bg{position:absolute;inset:0;background-position:center;background-size:cover;animation:zoom 2.4s var(--eo) both;}
.phero .veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,39,26,.5),rgba(10,26,17,.86));}
.phero .inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;width:100%;padding:120px 28px 56px;}
.phero h1{color:#fff;font-size:clamp(40px,7vw,84px);font-weight:700;line-height:.9;text-shadow:0 4px 40px rgba(0,0,0,.35);}
.phero p{color:#dcebcf;max-width:560px;margin-top:16px;font-size:clamp(15px,2vw,18px);font-weight:300;}
.crumb{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--lime);margin-bottom:18px;}
.crumb a{color:#cfe0c0;}
.crumb a:hover{color:#fff;}

/* ===== STRIP marquee ===== */
.strip{background:var(--lime);color:var(--green-900);overflow:hidden;padding:13px 0;border-top:3px solid var(--green-800);border-bottom:3px solid var(--green-800);}
.strip .track{display:flex;gap:40px;white-space:nowrap;width:max-content;animation:marquee 28s linear infinite;font-family:'Fraunces',serif;font-weight:600;font-size:19px;font-style:italic;}
.strip .track span{display:inline-flex;align-items:center;gap:40px;}
.strip .track span::after{content:"✦";font-style:normal;color:var(--green-700);}
@keyframes marquee{to{transform:translateX(-50%);}}

/* ===== ABOUT / split ===== */
.about{padding:110px 0;background:var(--cream);}
.about .grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;}
.about h2{font-size:clamp(34px,5vw,56px);margin:18px 0 22px;}
.about p{font-size:17px;color:var(--ink-soft);margin-bottom:18px;font-weight:300;}
.about .stats{display:flex;gap:34px;flex-wrap:wrap;border-top:1px solid #d8d0b8;padding-top:26px;margin-top:30px;}
.about .stats b{font-family:'Fraunces',serif;font-size:34px;color:var(--green-600);display:block;line-height:1;}
.about .stats small{font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:6px;display:block;}
.about .photo{position:relative;border-radius:22px;overflow:hidden;box-shadow:0 40px 70px rgba(20,40,25,.22);aspect-ratio:4/5;}
.about .photo img{width:100%;height:100%;object-fit:cover;}
.about .photo .tagpill{position:absolute;left:18px;bottom:18px;background:var(--orange);color:#fff;padding:9px 18px;border-radius:999px;font-weight:700;font-size:13px;box-shadow:0 10px 24px rgba(0,0,0,.3);}
.about .photo.flip{aspect-ratio:4/5;}

/* section heading block */
.sec-head{text-align:center;max-width:680px;margin:0 auto 46px;}
.sec-head h2{font-size:clamp(34px,5vw,56px);margin-top:14px;}
.sec-head .sub{color:var(--muted);font-style:italic;font-family:'Fraunces',serif;margin-top:10px;font-size:18px;}
.sec-head.light h2{color:#fff;}
.sec-head.light .sub{color:#bcd0b0;}

/* ===== FEATURE CARDS ===== */
.features{padding:104px 0;background:var(--cream);}
.fgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.fcard{background:var(--card);border:1px solid #e6dfc7;border-radius:18px;padding:30px 24px;transition:transform .4s var(--eo),box-shadow .4s var(--eo);}
@media(hover:hover){.fcard:hover{transform:translateY(-6px);box-shadow:0 26px 50px rgba(20,40,25,.14);}}
.fcard .ic{width:52px;height:52px;border-radius:14px;background:rgba(78,166,93,.14);display:flex;align-items:center;justify-content:center;color:var(--green-600);margin-bottom:18px;}
.fcard h3{font-size:22px;margin-bottom:8px;color:var(--green-800);}
.fcard p{font-size:14.5px;color:var(--ink-soft);font-weight:300;}

/* ===== MENU lists (dark) ===== */
.menu{padding:104px 0 110px;background:linear-gradient(180deg,var(--green-800),var(--green-900));color:#eef3e7;position:relative;}
.menu .head{text-align:center;margin-bottom:42px;}
.menu .eyebrow{color:var(--lime);}
.menu h2{color:#fff;font-size:clamp(34px,5vw,56px);margin-top:14px;}
.menu .sub{color:#bcd0b0;font-style:italic;font-family:'Fraunces',serif;margin-top:8px;}
.tabs{display:flex;flex-wrap:wrap;justify-content:center;gap:9px;margin-bottom:46px;}
.tab{padding:10px 20px;border-radius:999px;border:1.5px solid rgba(156,203,74,.35);background:transparent;color:#dce7d0;
  font-family:'Mulish',sans-serif;font-weight:700;font-size:14px;cursor:pointer;transition:all .28s var(--eo);}
.tab:active{transform:scale(.95);}
@media(hover:hover){.tab:hover{border-color:var(--lime);color:#fff;transform:translateY(-2px);}}
.tab.active{background:var(--lime);color:var(--green-900);border-color:var(--lime);box-shadow:0 8px 20px rgba(156,203,74,.28);}
.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 54px;max-width:1020px;margin:0 auto;}
.item{display:flex;align-items:baseline;gap:12px;padding:15px 8px;border-bottom:1px dotted rgba(156,203,74,.28);transition:background .3s,padding-left .3s var(--eo);}
@media(hover:hover){.item:hover{background:rgba(156,203,74,.07);padding-left:14px;}}
.item .info{flex:1;min-width:0;}
.item .nm{font-family:'Fraunces',serif;font-weight:600;font-size:19px;color:#fff;}
.item .ds{font-size:13px;color:#aabfa0;font-weight:300;margin-top:3px;line-height:1.45;}
.item .pr{font-family:'Fraunces',serif;font-weight:600;font-size:18px;color:var(--lime);white-space:nowrap;}
.item .pr small{font-size:11px;color:#9fb594;font-weight:400;}
.menu .note{text-align:center;margin-top:46px;font-size:13px;color:#9fb594;line-height:1.7;}

/* ===== GALLERY ===== */
.gallery{padding:104px 0;background:var(--cream);}
.gallery .head{text-align:center;margin-bottom:44px;}
.gallery h2{font-size:clamp(34px,5vw,56px);margin-top:14px;}
.ggrid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:230px;gap:14px;}
.gcell{position:relative;border-radius:16px;overflow:hidden;}
.gcell img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--eo),filter .6s;}
.gcell::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(16,39,26,.4));opacity:0;transition:opacity .5s;}
@media(hover:hover){.gcell:hover img{transform:scale(1.07);filter:saturate(1.08);}.gcell:hover::after{opacity:1;}}
.gcell.wide{grid-column:span 2;}
.gcell.tall{grid-row:span 2;}

/* ===== PACKAGES / cards (Eventi) ===== */
.cards{padding:104px 0;background:var(--cream);}
.pkgs{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch;}
.pkg{background:var(--card);border:1px solid #e6dfc7;border-radius:20px;padding:32px 28px;display:flex;flex-direction:column;transition:transform .4s var(--eo),box-shadow .4s var(--eo);}
@media(hover:hover){.pkg:hover{transform:translateY(-6px);box-shadow:0 28px 54px rgba(20,40,25,.15);}}
.pkg.feat{background:linear-gradient(180deg,var(--green-700),var(--green-800));border-color:transparent;color:#eef3e7;}
.pkg .kick{font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;font-weight:800;color:var(--leaf);margin-bottom:10px;}
.pkg.feat .kick{color:var(--lime);}
.pkg h3{font-size:27px;margin-bottom:6px;}
.pkg.feat h3{color:#fff;}
.pkg .price{font-family:'Fraunces',serif;font-size:30px;color:var(--green-600);margin:6px 0 18px;}
.pkg.feat .price{color:var(--lime);}
.pkg .price small{font-size:13px;color:var(--muted);font-weight:400;font-family:'Mulish',sans-serif;}
.pkg.feat .price small{color:#bcd0b0;}
.pkg ul{list-style:none;margin:0 0 24px;display:flex;flex-direction:column;gap:11px;}
.pkg li{display:flex;gap:10px;align-items:flex-start;font-size:14.5px;color:var(--ink-soft);font-weight:300;}
.pkg.feat li{color:#dcebcf;}
.pkg li svg{flex:0 0 auto;margin-top:3px;color:var(--green-500);}
.pkg.feat li svg{color:var(--lime);}
.pkg .btn{margin-top:auto;justify-content:center;}

/* ===== STEPS (Brace) ===== */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.step{position:relative;padding:30px 26px;border-radius:18px;background:rgba(156,203,74,.06);border:1px solid rgba(156,203,74,.18);}
.step .n{font-family:'Fraunces',serif;font-size:46px;color:var(--lime);line-height:1;opacity:.65;}
.step h3{color:#fff;font-size:21px;margin:10px 0 8px;}
.step p{font-size:14px;color:#bcd0b0;font-weight:300;}

/* ===== CTA BAND ===== */
.ctaband{padding:84px 0;background:var(--green-700);color:#eef3e7;text-align:center;position:relative;overflow:hidden;}
.ctaband::after{content:"";position:absolute;inset:0;background:radial-gradient(70% 120% at 50% 0%,rgba(156,203,74,.14),transparent 60%);}
.ctaband .inner{position:relative;z-index:2;max-width:680px;margin:0 auto;padding:0 28px;}
.ctaband h2{color:#fff;font-size:clamp(30px,4.6vw,50px);}
.ctaband p{color:#cfe0c0;font-weight:300;margin:14px auto 26px;max-width:520px;}
.ctaband .row{display:flex;gap:13px;justify-content:center;flex-wrap:wrap;}

/* ===== CONTACT ===== */
.contact{padding:104px 0;background:linear-gradient(180deg,var(--green-900),var(--green-800));color:#eef3e7;}
.contact .grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:stretch;}
.contact h2{color:#fff;font-size:clamp(32px,4.6vw,50px);margin-top:14px;margin-bottom:18px;}
.contact .lead{color:#c4d6b8;font-weight:300;margin-bottom:30px;max-width:440px;}
.info-row{display:flex;gap:15px;align-items:flex-start;padding:17px 0;border-top:1px solid rgba(156,203,74,.2);}
.info-row .ic{width:42px;height:42px;flex:0 0 auto;border-radius:12px;background:rgba(156,203,74,.16);display:flex;align-items:center;justify-content:center;color:var(--lime);}
.info-row .lbl{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--lime);font-weight:700;margin-bottom:3px;}
.info-row .val{font-size:16.5px;color:#eef3e7;}
.info-row a.val{transition:color .25s;}
@media(hover:hover){.info-row a.val:hover{color:var(--lime);}}
.contact .card{background:var(--card);border-radius:22px;padding:8px;box-shadow:0 30px 60px rgba(0,0,0,.3);overflow:hidden;}
.contact .card iframe{width:100%;height:100%;min-height:340px;border:0;border-radius:16px;display:block;}
.resv{margin-top:26px;display:flex;gap:12px;flex-wrap:wrap;}

/* ===== FOOTER ===== */
footer{background:var(--green-900);color:#9fb594;padding:54px 0 30px;border-top:1px solid rgba(156,203,74,.16);}
footer .grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;}
footer .name{font-family:'Fraunces',serif;font-size:25px;color:#fff;}
footer .foot-logo{width:208px;height:auto;margin-bottom:6px;filter:drop-shadow(0 6px 14px rgba(0,0,0,.35));}
footer h4{font-family:'Mulish',sans-serif;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--lime);margin-bottom:14px;font-weight:800;}
footer a{display:block;padding:5px 0;color:#c4d6b8;transition:color .25s,transform .25s var(--eo);}
@media(hover:hover){footer a:hover{color:#fff;transform:translateX(4px);}}
footer .bottom{max-width:var(--maxw);margin:38px auto 0;padding:22px 28px 0;border-top:1px solid rgba(156,203,74,.16);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:12.5px;color:#7d9276;}

@media(prefers-reduced-motion:reduce){
  [data-rev]{opacity:1!important;transform:none!important;filter:none!important;}
  .hero .bg,.phero .bg,.hero .cues,.strip .track{animation:none!important;}
}

/* ===== RESPONSIVE ===== */
@media(max-width:1080px){
  .fgrid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:980px){
  .about .grid{grid-template-columns:1fr;gap:40px;}
  .about .photo,.about .photo.flip{aspect-ratio:16/11;}
  .contact .grid{grid-template-columns:1fr;gap:32px;}
  .ggrid{grid-template-columns:repeat(2,1fr);grid-auto-rows:190px;}
  .pkgs{grid-template-columns:1fr;max-width:480px;margin:0 auto;}
  .steps{grid-template-columns:1fr;}
}
@media(max-width:760px){
  .nav-links,.nav-cta{display:none;}
  .burger{display:flex;}
  .brand-logo{height:48px;}
  .menu-grid{grid-template-columns:1fr;gap:0;}
  footer .grid{grid-template-columns:1fr;gap:28px;}
  .fgrid{grid-template-columns:1fr;}
  .gcell.wide{grid-column:span 1;}.gcell.tall{grid-row:span 1;}
  .ggrid{grid-template-columns:1fr 1fr;grid-auto-rows:150px;}
  /* ===== MENÚ MÓVIL — overlay a pantalla completa (estilo Portego) ===== */
  .mobile-menu{display:flex;flex-direction:column;align-items:center;justify-content:center;
    position:fixed;inset:0;z-index:80;max-height:none;overflow:hidden;padding:96px 28px 48px;
    background:var(--green-900);transform:translateY(-100%);transition:transform .55s var(--eio);border:0;}
  .mobile-menu.open{transform:none;}
  .mobile-menu::before{content:"";position:absolute;inset:-8%;z-index:0;
    background:url('bg-olive-dark.webp') center/cover no-repeat;transform:scale(1.06);
    animation:mmKen 24s ease-in-out infinite alternate;}
  .mobile-menu::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
    background:
      linear-gradient(120deg,transparent 38%,rgba(156,203,74,.10) 50%,transparent 62%),
      radial-gradient(60% 40% at 50% -6%,rgba(156,203,74,.22),transparent 62%),
      radial-gradient(50% 32% at 88% 82%,rgba(230,122,30,.16),transparent 60%),
      linear-gradient(rgba(10,26,17,.62),rgba(8,20,12,.84));
    background-size:260% 260%,100% 100%,100% 100%,100% 100%;background-position:0% 0%,center,center,center;
    animation:mmSweep 15s linear infinite;}
  @keyframes mmKen{0%{transform:scale(1.06) translate(0,0);}100%{transform:scale(1.14) translate(-2%,-2%);}}
  @keyframes mmSweep{0%{background-position:0% 0%,center,center,center;}100%{background-position:100% 100%,center,center,center;}}
  @media(prefers-reduced-motion:reduce){.mobile-menu::before,.mobile-menu::after{animation:none;}}
  .mobile-menu .mm-in{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:4px;padding:0;width:100%;max-width:360px;}
  .mobile-menu a:not(.btn){font-family:'Fraunces',serif;font-size:30px;font-weight:600;color:#eef3e7;padding:11px 2px;
    letter-spacing:.01em;text-shadow:0 2px 16px rgba(0,0,0,.45);}
  .mobile-menu a:not(.btn).active{color:var(--lime);}
  .mobile-menu a{opacity:0;transform:translateY(16px);}
  .mobile-menu.open a{opacity:1;transform:none;transition:opacity .5s var(--eo),transform .5s var(--eo),color .3s ease;}
  .mobile-menu.open a:nth-child(1){transition-delay:.12s;}.mobile-menu.open a:nth-child(2){transition-delay:.17s;}
  .mobile-menu.open a:nth-child(3){transition-delay:.22s;}.mobile-menu.open a:nth-child(4){transition-delay:.27s;}
  .mobile-menu.open a:nth-child(5){transition-delay:.32s;}.mobile-menu.open a:nth-child(6){transition-delay:.37s;}
  .mobile-menu.open a:nth-child(7){transition-delay:.44s;}
  .mobile-menu .btn-pri{margin-top:24px;justify-content:center;font-size:16px;padding:15px 32px;}
}
@media(max-width:430px){ .wrap,nav{padding-left:18px;padding-right:18px;} .hero .inner{padding-left:18px;padding-right:18px;} .phero .inner{padding-left:18px;padding-right:18px;} }

/* ============================================================
   ANIMACIONES (portadas de Portego De Ma', adaptadas al verde)
   ============================================================ */

/* A. Barra de progreso de lectura (arriba del todo) */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:1200;
  background:linear-gradient(90deg,var(--green-600),var(--leaf),var(--orange));
  box-shadow:0 0 10px rgba(78,166,93,.5);transition:width .1s linear;pointer-events:none;}

/* C. Partículas flotantes del hero (motas de luz verde/lima/crema) */
.hero-particles{position:absolute;inset:0;z-index:1;pointer-events:none;}

/* D. Título del hero — entrada deslizada + rebote por letra */
.hero-title{white-space:pre-wrap;}
.hero-title .ti-char{display:inline-block;will-change:transform;backface-visibility:hidden;}

/* G. Barrido de imágenes al aparecer (revela desde la izquierda) */
.img-wipe{clip-path:inset(0 100% 0 0);transition:clip-path 1s var(--eo);will-change:clip-path;}
.img-wipe.in-view{clip-path:inset(0 0 0 0);}

/* F. Tarjetas con inclinación 3D (tilt) */
.tilt-card{transition:transform .12s ease-out,box-shadow .55s ease;transform-style:preserve-3d;}

/* H. Transición de telón entre páginas (barrido continuo, tono verde).
   Salida y entrada comparten el mismo fondo y brillo central = sin saltos. */
:root{--rb-curtain:
  radial-gradient(58% 46% at 50% 50%,rgba(156,203,74,.16) 0%,transparent 64%),
  linear-gradient(165deg,#143a23 0%,var(--green-900) 55%,#0a1f11 100%);}
.page-curtain{position:fixed;inset:0;z-index:2000;
  background:url('logo-full.webp') center center/clamp(200px,55vw,300px) no-repeat,var(--rb-curtain);
  transform:translateY(100%);pointer-events:none;will-change:transform;}
.page-curtain.cover{transform:translateY(0);transition:transform .72s cubic-bezier(.4,0,.2,1);}
@media (prefers-reduced-motion:no-preference){
  html.rb-entering::before{content:'';position:fixed;inset:0;z-index:2001;pointer-events:none;
    background:url('logo-full.webp') center center/clamp(200px,55vw,300px) no-repeat,var(--rb-curtain);transform:translateY(0);
    animation:rbReveal .95s cubic-bezier(.4,0,.2,1) .02s forwards;}
}
@keyframes rbReveal{0%{transform:translateY(0);opacity:1;}62%{opacity:1;}100%{transform:translateY(-100%);opacity:0;}}
@media (prefers-reduced-motion:reduce){
  .img-wipe{clip-path:none;transition:none;}
  .page-curtain{display:none;}
  html.rb-entering::before{display:none;}
}

/* ============================================================
   FONDO DE MARCA — ondas verdes (RIBULLY)
   Secciones crema = paneles "sticker" flotando sobre el verde
   ============================================================ */
html{background:var(--green-500);}
body{background:transparent;}
body::before{content:"";position:fixed;inset:0;z-index:-2;
  background:url('bg-wave.webp') center center/cover no-repeat;}
@media(max-width:760px){ body::before{background-image:url('bg-wave-v.webp');} }

.about,.features,.gallery,.cards{background:transparent;padding-top:70px;padding-bottom:70px;}
.about>.wrap,.features>.wrap,.gallery>.wrap,.cards>.wrap{
  background:var(--cream);
  max-width:1140px;
  border-radius:32px;
  padding:64px 48px;
  box-shadow:0 34px 80px rgba(13,32,20,.22);
}
@media(max-width:760px){
  .about,.features,.gallery,.cards{padding-top:32px;padding-bottom:32px;}
  .about>.wrap,.features>.wrap,.gallery>.wrap,.cards>.wrap{border-radius:22px;padding:38px 22px;}
}

/* ============================================================
   FONDOS TEMÁTICOS POR PÁGINA (verde + naranja)
   ============================================================ */
/* La Brace — brasa y chispas */
.pg-brace .menu{background:linear-gradient(rgba(13,28,18,.72),rgba(8,20,12,.84)),url('bg-embers.webp') center/cover;background-attachment:scroll;}
/* Menù — food-art verde (basilico, olio, brace) */
.pg-menu .menu{background:linear-gradient(rgba(13,28,18,.68),rgba(10,26,17,.80)),url('bg-cucina.webp') center/cover;}
/* Cantina — rami d'ulivo scuri */
.pg-cantina .menu{background:linear-gradient(rgba(13,28,18,.74),rgba(8,20,12,.84)),url('bg-olive-dark.webp') center/cover;}
/* Contatti — rami d'ulivo scuri */
.pg-contatti .contact{background:linear-gradient(rgba(13,28,18,.80),rgba(8,20,12,.90)),url('bg-olive-dark.webp') center/cover;}
/* Eventi — intonaco crema con ulivo nei pannelli */
.pg-eventi .about>.wrap,.pg-eventi .cards>.wrap{background:linear-gradient(rgba(246,243,230,.55),rgba(246,243,230,.55)),url('bg-eventi.webp') center/cover;}

/* ============================================================
   HEADER FLOTANTE tipo "Dynamic Island" al hacer scroll
   ============================================================ */
header{transition:background .4s ease,backdrop-filter .4s ease,border-color .4s ease,padding .5s var(--eo);}
nav{border:1px solid transparent;border-radius:0;
  transition:max-width .5s var(--eo),padding .5s var(--eo),background .4s ease,
    border-radius .5s var(--eo),box-shadow .5s var(--eo),border-color .4s ease;}
header.scrolled{background:transparent;backdrop-filter:none;border-bottom-color:transparent;padding:10px 14px 0;}
header.scrolled nav{max-width:1060px;margin:0 auto;padding:7px 12px 7px 18px;border-radius:999px;
  background:rgba(16,34,22,.92);backdrop-filter:blur(16px) saturate(1.25);
  border:1px solid rgba(156,203,74,.32);box-shadow:0 16px 40px rgba(0,0,0,.42);}
header.scrolled .brand-logo{height:46px;}
@media(max-width:760px){
  header.scrolled{padding:8px 26px 0;}
  header.scrolled nav{padding:6px 17px 6px 25px;}
  header.scrolled .brand-logo{height:42px;}
}
@media(prefers-reduced-motion:reduce){header,nav{transition:none;}}

/* ============================================================
   ISLA: estado "Aperto" + botón llamar (sólo móvil)
   ============================================================ */
.open-pill{display:none;}
.call-btn{display:none;}
.nav-actions{display:contents;}
.open-pill i{width:8px;height:8px;border-radius:50%;background:var(--wheat);flex:0 0 auto;}
.open-pill.is-open i{background:#5ed957;animation:dotpulse 2.2s ease-out infinite;}
@keyframes dotpulse{0%{box-shadow:0 0 0 0 rgba(94,217,87,.55);}70%{box-shadow:0 0 0 7px rgba(94,217,87,0);}100%{box-shadow:0 0 0 0 rgba(94,217,87,0);}}
@media(max-width:760px){
  .open-pill{display:inline-flex;align-items:center;gap:7px;font-family:'Mulish',sans-serif;
    font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#e2ecd6;white-space:nowrap;}
  .call-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;
    background:rgba(156,203,74,.16);color:var(--lime);border:1px solid rgba(156,203,74,.32);
    transition:transform .25s var(--eo),background .25s;flex:0 0 auto;}
  .call-btn:active{transform:scale(.92);background:rgba(156,203,74,.28);}
  .nav-actions{display:flex;align-items:center;gap:10px;}
}
@media(prefers-reduced-motion:reduce){.open-pill.is-open i{animation:none;}}

/* ============================================================
   FORMULARIO DE RESERVA + REDES (contatti)
   ============================================================ */
.resv-form{max-width:760px;margin:0 auto;}
.rf-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 18px;}
.resv-form label{display:flex;flex-direction:column;gap:7px;font-family:'Mulish',sans-serif;font-size:12px;
  font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);}
.resv-form .opt{font-weight:600;letter-spacing:.01em;text-transform:none;color:var(--muted);}
.resv-form input,.resv-form textarea{font-family:'Mulish',sans-serif;font-size:15px;font-weight:500;letter-spacing:0;
  text-transform:none;color:var(--ink);background:#fff;border:1.5px solid #e0d9c2;border-radius:12px;padding:13px 15px;
  width:100%;transition:border-color .2s,box-shadow .2s;}
.resv-form input:focus,.resv-form textarea:focus{outline:none;border-color:var(--leaf);box-shadow:0 0 0 3px rgba(78,166,93,.18);}
.resv-form .rf-full{margin-top:16px;}
.resv-form textarea{resize:vertical;min-height:86px;}
.rf-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px;}
.rf-msg{margin-top:18px;padding:13px 16px;border-radius:12px;font-weight:600;font-size:14.5px;}
.rf-msg.ok{background:rgba(78,166,93,.14);color:#27632f;border:1px solid rgba(78,166,93,.4);}
.rf-msg.err{background:rgba(207,80,40,.12);color:#9a3412;border:1px solid rgba(207,80,40,.35);}
@media(max-width:620px){.rf-grid{grid-template-columns:1fr;}}
.socials{display:flex;gap:12px;margin-top:20px;}
.socials a{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(156,203,74,.16);color:var(--lime);border:1px solid rgba(156,203,74,.32);
  transition:transform .25s var(--eo),background .25s;}
@media(hover:hover){.socials a:hover{transform:translateY(-2px);background:rgba(156,203,74,.28);}}

/* ============================================================
   BANNER DE COOKIES
   ============================================================ */
.cookie-bar{position:fixed;left:16px;right:16px;bottom:16px;z-index:3000;max-width:680px;margin:0 auto;
  background:rgba(16,34,22,.97);backdrop-filter:blur(10px);border:1px solid rgba(156,203,74,.3);
  border-radius:18px;padding:18px 20px;box-shadow:0 18px 50px rgba(0,0,0,.45);
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;transform:translateY(140%);transition:transform .5s var(--eo);}
.cookie-bar.show{transform:none;}
.cookie-bar p{color:#e2ecd6;font-size:13.5px;font-weight:400;flex:1 1 280px;margin:0;}
.cookie-bar a{color:var(--lime);text-decoration:underline;}
.cookie-bar .ck-btns{display:flex;gap:10px;flex:0 0 auto;}
.cookie-bar .btn{padding:10px 20px;font-size:13.5px;}
.ck-reject{background:transparent;border:1.5px solid rgba(255,255,255,.4);color:#fff;}
@media(max-width:520px){.cookie-bar{flex-direction:column;align-items:stretch;text-align:center;}.cookie-bar .ck-btns{justify-content:center;}}

/* Página legal (privacy) */
.legal{padding:120px 0 70px;}
.legal .wrap{max-width:820px;background:var(--cream);border-radius:28px;padding:54px 46px;box-shadow:0 30px 70px rgba(13,32,20,.2);}
.legal h1{font-size:clamp(34px,5vw,52px);margin-bottom:8px;}
.legal h2{font-size:22px;margin:30px 0 10px;}
.legal p,.legal li{color:var(--ink-soft);font-size:15.5px;margin-bottom:10px;}
.legal ul{padding-left:20px;}
.legal a{color:var(--green-600);text-decoration:underline;}
.legal .upd{color:var(--muted);font-size:13px;margin-bottom:24px;}
@media(max-width:620px){.legal .wrap{padding:40px 22px;}}
