/* ==========================================================================
Pazzi per Asado — FULL CSS (Home + Servizi + Gallery + Contatti)
========================================================================== */
:root{
  --ppa-bg-dark:#0f171b;--ppa-peach:#f6dac0;--ppa-ink:#1a1a1a;--ppa-text:#eaeaea;
  --ppa-accent:#d3aa75;--ppa-white:#ffffff;--ppa-shadow:rgba(0,0,0,.35);
  --ppa-radius:16px;--ppa-radius-lg:20px;--ppa-maxw:1200px;--ppa-gap:28px;
  --ppa-green:#16a34a;
}

/* Reset */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,Arial,Helvetica,sans-serif;color:#1c1f23}

/* Utilities */
.ppa-container{max-width:var(--ppa-maxw);margin:0 auto;padding:0 20px}
.center{text-align:center}
.ppa-small{font-size:.9rem;color:#94a1ad}
.ppa-text-white{color:#fff!important}
.ppa-text-gold{color:var(--ppa-accent)!important}

/* Buttons */
.ppa-btn{display:inline-block;background:#111;color:#fff;border-radius:999px;padding:12px 22px;text-decoration:none;font-weight:700;border:2px solid transparent;transition:.2s;line-height:1}
.ppa-btn:hover{transform:translateY(-1px)}
.ppa-btn--outline{background:transparent;color:#111;border-color:#111}
.ppa-btn--light{background:#fff;color:#111}
.ppa-btn--gold{background:var(--ppa-accent);color:#111}
.ppa-btn--green{background:var(--ppa-green);color:#fff}

/* Section titles */
.ppa-sec-title{font-size:clamp(28px,4vw,44px);margin:0 0 16px}

/* Lead text (ALIGNMENT FIX) */
.ppa-lead{
  max-width:900px;
  margin:0 auto 12px;
  font-size:1.1rem;
  color:#cfd7de;
  text-align:center; /* ensure both requested blocks are centered consistently */
}

/* Full-bleed wrappers */
.ppa-section,.ppa-hero,.ppa-footer,.ppa-header{width:100vw;max-width:100vw;margin-left:calc(-50vw + 50%);margin-right:calc(-50vw + 50%)}
.ppa-section .ppa-container,.ppa-hero .ppa-container,.ppa-footer .ppa-container,.ppa-header .ppa-container{max-width:var(--ppa-maxw);margin:0 auto;padding-left:20px;padding-right:20px}

/* Header */
.ppa-header{position:sticky;top:0;background:rgba(255,255,255,.9);backdrop-filter:blur(6px);border-bottom:1px solid rgba(0,0,0,.06);z-index:1000;transition:.25s;overflow:visible}
.ppa-header .ppa-container{display:flex;align-items:center;justify-content:space-between;height:68px}
.ppa-header.is-scrolled{box-shadow:0 8px 24px rgba(0,0,0,.08)}

/* Logo */
.ppa-logo{display:inline-flex;align-items:center;gap:10px;text-decoration:none}
.ppa-logo img{height:54px;width:auto;display:block}

/* Nav (underline aligned & consistent) */
.ppa-nav ul{list-style:none;display:flex;gap:28px;margin:0;padding:0}
.ppa-nav a{
  color:#111;text-decoration:none;font-weight:600;position:relative;
  padding-bottom:14px;
}
.ppa-nav a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:0;
  height:2px;
  width:100%;
  background:#b48a56;
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .2s ease;
}
.ppa-nav a:hover{color:#b48a56}
.ppa-nav a:hover::after,.ppa-nav a.is-active::after{ transform:scaleX(1); }

/* Burger */
.ppa-burger{display:none;background:transparent;border:0;padding:8px;cursor:pointer}
.ppa-burger span{display:block;width:26px;height:2px;background:#111;margin:6px 0;transition:.2s}

/* ===== Mega menu (Servizi) — desktop ===== */
.ppa-nav > ul > li.has-mega{ position:static }
.ppa-nav__link{ display:inline-flex; align-items:center; gap:6px; }
.ppa-nav > ul > li.has-mega > .ppa-nav__link::before{
  content:"▾"; font-size:.7em; line-height:1; margin-left:6px; transition:transform .2s ease;
}
.ppa-nav > ul > li.has-mega.is-open > .ppa-nav__link::before{ transform:rotate(180deg) }
.ppa-nav > ul > li.has-mega.is-open > .ppa-nav__link::after{ transform:scaleX(1); }

.ppa-mega{
  position:absolute; top:calc(100% + 8px); left:50%; transform:translateX(-50%);
  width:min(var(--ppa-maxw), calc(100vw - 32px));
  background:#fff; color:#111; border-radius:14px;
  box-shadow:0 18px 40px rgba(0,0,0,.12);
  padding:16px 18px; display:grid; grid-template-columns:1fr 1fr; gap:24px; z-index:1100;
}
.ppa-mega::before{content:""; position:absolute; left:0; right:0; top:-14px; height:14px;}
.ppa-mega[hidden]{ display:none !important; } /* JS toggles this; when removed, it shows */

.ppa-mega__col h5{ margin:6px 0 8px; font-weight:800; color:#b48a56; font-size:1rem; }
.ppa-mega__col ul{ list-style:none; margin:0; padding:0; display:grid; grid-auto-rows:64px; gap:0; }
.ppa-mega__col a{
  display:flex; align-items:center; height:100%; padding:0 6px; border-radius:0; color:#111; text-decoration:none; font-weight:600; border-bottom:2px solid rgba(211,170,117,.45);
}
.ppa-mega__col a:hover{ background:rgba(0,0,0,.05); color:#b48a56; }
.ppa-mega__all{ font-weight:800; }
.ppa-mega__col li:last-child a{ border-bottom-color:transparent; }

/* ===== MOBILE: hide mega entirely ===== */
@media (max-width:992px){
  .ppa-mega{ display:none !important; } /* mobile stays hidden as design */
  .ppa-nav > ul > li.has-mega > .ppa-nav__link::before{ display:none; }
}

/* Hero */
.ppa-hero{position:relative;min-height:56vh;display:flex;align-items:center;overflow:hidden;z-index:0}
.ppa-hero__bg{ position:absolute;inset:0; background:linear-gradient(0deg,rgba(0,0,0,.4),rgba(0,0,0,.4)),url('../images/home1.jpg') center/cover no-repeat }
.ppa-hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.35),rgba(0,0,0,.15) 35%,rgba(0,0,0,.55))}
.ppa-hero__content{position:relative;z-index:1;color:#fff;padding:6vh 0}
.ppa-hero__title{font-size:clamp(34px,6vw,64px);margin:0 0 14px;color:#fff}
.ppa-hero__title--upper{text-transform:uppercase;letter-spacing:.02em;font-weight:900}
.ppa-hero__subtitle{max-width:900px;font-size:1.15rem;margin:0 0 22px;color:#e8e8e8}
.ppa-hero__contact-link{color:#fff;opacity:.85;text-decoration:underline;text-underline-offset:2px}
.ppa-hero__contact-link:hover{opacity:1}

/* Sections */
.ppa-section{padding:56px 0}
.ppa-section--dark{background:var(--ppa-bg-dark);color:var(--ppa-text)}
.ppa-section--peach{background:var(--ppa-peach)}
.ppa-grid-2{display:grid;grid-template-columns:1.1fr .9fr;gap:42px;align-items:center}

/* Services photos */
.ppa-photo-asado{
  min-height:360px;border-radius:18px;background:url('../images/home2.jpg') center/cover no-repeat;
  box-shadow:0 16px 36px rgba(0,0,0,.26)
}

/* Read-more */
.ppa-readmore__content[hidden]{display:none}
.ppa-readmore__toggle{
  appearance:none;border:0;border-radius:999px;padding:10px 16px;font-weight:800;
  background:#fff;color:#111;cursor:pointer;box-shadow:0 8px 18px rgba(0,0,0,.18)
}
.ppa-readmore__toggle:hover{transform:translateY(-1px)}

/* Services tiles */
.ppa-services{width:100%;margin:40px 0}
.ppa-services-track{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ppa-services-item{display:flex;flex-direction:column;align-items:center;text-align:center}
.ppa-services-img{width:100%;height:320px;border-radius:18px;background-size:cover;background-position:center;box-shadow:0 10px 25px rgba(0,0,0,.25);transition:transform .25s}
.ppa-services-img:hover{transform:scale(1.03)}
.ppa-services-caption{margin-top:14px;font-size:1.15rem;font-weight:700;color:#111}

/* Horizontal scroll frames */
.ppa-scroll-frame{overflow-x:auto;padding:6px 0 16px;margin:8px 0}
.ppa-scroll-frame::-webkit-scrollbar{height:8px}
.ppa-scroll-frame::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}
.ppa-scroll-track{display:flex;gap:18px;scroll-snap-type:x mandatory}
.ppa-scroll-track>*{scroll-snap-align:start}
.ppa-scroll-item{
  flex:0 0 auto;width:clamp(220px,30vw,360px);aspect-ratio:4/3;border-radius:18px;
  background-size:cover;background-position:center;box-shadow:0 12px 28px rgba(0,0,0,.28);position:relative;overflow:hidden
}
.ppa-scroll-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 60%,rgba(0,0,0,.25) 100%);pointer-events:none}

/* Footer */
.ppa-footer{background:var(--ppa-bg-dark);color:var(--ppa-text);padding:60px 0 34px}
.ppa-footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:28px}
.ppa-foot-title{margin:0 0 10px;color:#fff}
.ppa-footer a{color:#fff}
.ppa-logo--footer{display:inline-flex;align-items:center;justify-content:center}
.ppa-logo--footer img{height:80px;width:auto;display:block;filter:invert(1) brightness(2)}
.ppa-socials{display:flex;gap:14px}
.ppa-social{width:40px;height:40px;border-radius:999px;background:#fff;color:#111;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;overflow:hidden}
.ppa-social img{width:22px;height:22px;object-fit:contain}

/* Reveal */
.will-reveal{opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s ease}
.will-reveal.in-view{opacity:1;transform:translateY(0)}

/* Back-to-top */
.ppa-to-top{position:fixed;right:18px;bottom:18px;width:44px;height:44px;border-radius:999px;border:0;background:var(--ppa-accent);color:#111;font-size:18px;font-weight:800;cursor:pointer;box-shadow:0 10px 24px rgba(0,0,0,.25);opacity:0;pointer-events:none;transform:translateY(10px);transition:.25s;z-index:60}
.ppa-to-top.show{opacity:1;pointer-events:auto;transform:translateY(0)}

/* Contact (CF7) */
.ppa-contact-hero{position:relative;min-height:70vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;width:100vw;max-width:100vw;margin-left:calc(-50vw + 50%);margin-right:calc(-50vw + 50%);padding-top:48px;padding-bottom:120px}
.ppa-contact-hero__bg{position:absolute;inset:0;background-size:cover;background-position:center}
.ppa-contact-hero .ppa-hero__title{color:#fff!important}
.ppa-contact-hero__headline{margin:8px 0 18px;color:#eaeaea;font-size:clamp(16px,2vw,18px)}
.ppa-contact-hero__content{position:relative;z-index:1;max-width:760px;width:100%;background:rgba(255,255,255,.94);border-radius:14px;padding:22px 20px;color:#111;box-shadow:0 16px 36px rgba(0,0,0,.28)}
.ppa-form-modern .ppa-form-title{margin:0 0 10px;font-weight:700;font-size:clamp(18px,2.2vw,22px);color:#2e3136}
.ppa-form-modern .wpcf7-form{display:grid;grid-template-columns:1fr;gap:14px;justify-items:stretch;align-items:start}
@media (min-width:900px){
  .ppa-form-modern .wpcf7-form{grid-template-columns:1fr 1fr}
  .ppa-form-modern .wpcf7-form p:where(:has(textarea),.textarea),.ppa-form-modern .wpcf7-form p:nth-of-type(3){grid-column:1 / -1}
}
.ppa-form-modern .wpcf7-form p{margin:0}
.ppa-form-modern .wpcf7-form p>label{display:block;margin:0 0 6px;font-weight:600;color:#2a2f36;font-size:clamp(13px,1.3vw,14px)}
.ppa-form-modern .wpcf7-form input[type="text"],.ppa-form-modern .wpcf7-form input[type="email"],.ppa-form-modern .wpcf7-form input[type="tel"],.ppa-form-modern .wpcf7-form input[type="number"],.ppa-form-modern .wpcf7-form textarea{width:100%;background:#fff;border:1px solid rgba(0,0,0,.12);border-radius:10px;height:44px;padding:0 12px;outline:none;color:#202225;font-size:clamp(15px,1.7vw,16px);transition:border-color .15s ease,box-shadow .15s ease}
.ppa-form-modern .wpcf7-form textarea{min-height:130px;height:auto;padding:10px 12px;line-height:1.45;resize:vertical}
.ppa-form-modern .wpcf7-form input:focus,.ppa-form-modern .wpcf7-form textarea:focus{border-color:var(--ppa-accent);box-shadow:0 0 0 3px rgba(211,170,117,.2)}
.ppa-form-modern .wpcf7-form ::placeholder{color:#8d96a0;opacity:1}
.ppa-form-modern .wpcf7-form .wpcf7-submit{appearance:none;border:0;border-radius:999px;padding:12px 28px;font-weight:800;font-size:clamp(14px,1.6vw,16px);background:var(--ppa-accent);color:#111;cursor:pointer;box-shadow:0 10px 22px rgba(0,0,0,.18);transition:transform .12s ease,box-shadow .2s ease,background .2s ease;display:inline-flex;align-items:center;float:none!important}
.ppa-form-modern .wpcf7-form .wpcf7-submit:hover{transform:translateY(-1px);box-shadow:0 14px 28px rgba(0,0,0,.22)}
.ppa-form-modern .wpcf7-form .ppa-submit-row{grid-column:1 / -1 !important;display:grid !important;place-items:center !important;width:100% !important;text-align:center !important;position:relative !important}
.ppa-form-modern .wpcf7-form .wpcf7-spinner{position:absolute !important;left:50% !important;top:50% !important;transform:translate(-50%,-50%) !important;margin:0 !important}
.ppa-form-modern .wpcf7-not-valid{border-color:#c62828!important;box-shadow:0 0 0 3px rgba(198,40,40,.12)!important}
.ppa-form-modern .wpcf7-not-valid-tip{display:block;margin-top:6px;font-size:.85rem;color:#c62828}
.ppa-form-modern .wpcf7 form .wpcf7-response-output{margin:10px 0 0;border-radius:10px;padding:10px 12px;border:1px solid transparent;font-size:.95rem}
.ppa-form-modern .wpcf7 form.invalid .wpcf7-response-output{border-color:#c62828;color:#c62828;background:#ffe9e9}
.ppa-form-modern .wpcf7 form.sent .wpcf7-response-output{border-color:#2e7d32;color:#2e7d32;background:#ecf7ed}

/* Menu hero bg */
.ppa-hero--menu .ppa-hero__bg{background:linear-gradient(0deg,rgba(0,0,0,.45),rgba(0,0,0,.45)),url('../images/home4.jpg') center/cover no-repeat}

/* Menu cards (flip) */
.ppa-cards-carousel{margin-top:8px}
.ppa-cards-carousel .ppa-scroll-track{padding:6px 2px 10px}
.ppa-card{
  flex:0 0 auto;min-width:clamp(260px,70vw,360px);height:460px;background:#fff;border-radius:18px;
  box-shadow:0 10px 24px rgba(0,0,0,.08);border:1px solid rgba(0,0,0,.06);position:relative;overflow:hidden;
  perspective:1000px; /* add perspective so 3D flip reads correctly */
}
@media (min-width:768px){.ppa-card{min-width:clamp(300px,36vw,360px);height:450px}}
@media (min-width:1100px){.ppa-card{min-width:360px;height:450px}}

.ppa-card__inner{height:100%;width:100%;position:relative;transform-style:preserve-3d;transition:transform .55s cubic-bezier(.2,.7,.2,1)}
.ppa-card__face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;display:flex;flex-direction:column}
.ppa-card__front{background:#fff}
.ppa-card__back{background:#111;color:#fff;transform:rotateY(180deg)}
.ppa-card--flip.is-flipped .ppa-card__inner{transform:rotateY(180deg)}

.ppa-card__media{position:relative;flex:0 0 auto;aspect-ratio:3/2;background:#000;overflow:hidden}
.ppa-card__media img{width:100%;height:100%;object-fit:cover;display:block}
.ppa-badge{position:absolute;left:10px;top:10px;background:rgba(0,0,0,.6);color:#fff;padding:6px 10px;border-radius:999px;font-size:.85rem;font-weight:700}
.ppa-card__body{flex:1 1 auto;padding:12px 14px 14px;color:#111;display:flex;flex-direction:column}
.ppa-card__title{margin:2px 0 6px;font-weight:800;letter-spacing:.2px;color:#111;line-height:1.2;font-size:clamp(18px,2.2vw,20px)}
.ppa-card__desc{margin:0 0 10px;color:#4a4f56;font-size:.98rem}
.ppa-card__action{margin-top:auto}
.ppa-card__back-inner{height:100%;overflow:auto;padding:14px 16px 16px}
.ppa-card__back-title{margin:0 0 8px;color:#fff;font-size:1.05rem;font-weight:800}
.ppa-card__back h5{margin:10px 0 6px;font-size:.98rem;color:#f4f4f4}
.ppa-card__back ul{margin:0 0 8px 18px}
.ppa-card__back li{margin:4px 0}

/* Single-image carousel */
.ppa-carousel{position:relative;width:100%;max-width:100%;margin-inline:auto;border-radius:var(--ppa-radius-lg);overflow:hidden;box-shadow:0 14px 34px rgba(0,0,0,.18);background:#000;aspect-ratio:16/10;z-index:0}
@supports not (aspect-ratio:1/1){.ppa-carousel{height:48vw;max-height:520px}}
.ppa-carousel-track{position:relative;width:100%;height:100%}
.ppa-carousel-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;visibility:hidden;transition:opacity .35s ease,visibility .35s ease}
.ppa-carousel-img.active{opacity:1;visibility:visible}
.ppa-carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:999px;border:0;background:#fff;color:#111;font-weight:800;display:grid;place-items:center;cursor:pointer;box-shadow:0 10px 20px rgba(0,0,0,.25);line-height:1;z-index:2}
.ppa-carousel-arrow.prev{left:12px}
.ppa-carousel-arrow.next{right:12px}
.ppa-carousel-arrow:focus{outline:2px solid var(--ppa-accent);outline-offset:2px}
@media (min-width:768px){.ppa-carousel{width:80%}.ppa-carousel-arrow{width:44px;height:44px;font-size:1.2rem}}
@media (max-width:480px){.ppa-carousel-arrow{width:36px;height:36px}}

/* Typography normalization (flip cards) */
.ppa-card__front,.ppa-card__back,.ppa-card__front *,.ppa-card__back *{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,Arial,Helvetica,sans-serif!important;font-style:normal!important;text-transform:none!important;letter-spacing:0!important
}
.ppa-card__title,.ppa-card__back-title,.ppa-card__back h5{font-family:inherit!important;font-weight:800;letter-spacing:0}
.ppa-card__desc,.ppa-card__back p,.ppa-card__back li{font-family:inherit!important;font-weight:400}

/* Services headings */
.ppa-wrap .ppa-service-title, .ppa-wrap .ppa-service-title *{
  color: var(--ppa-accent) !important;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,Arial,Helvetica,sans-serif!important;
  font-weight:800 !important; font-style:normal !important; text-transform:none !important; letter-spacing:0 !important;
  font-size:clamp(24px,3vw,34px) !important; line-height:1.2 !important;
}
.ppa-wrap h3.ppa-sec-title{ text-transform:none !important; }

/* Responsive nav */
@media (max-width:992px){
  .ppa-grid-2{grid-template-columns:1fr}
  .ppa-footer__grid{grid-template-columns:1fr 1fr}
  .ppa-nav{display:none;position:absolute;top:68px;left:0;right:0;background:#fff;padding:14px 20px;border-bottom:1px solid rgba(0,0,0,.06)}
  .ppa-nav ul{flex-direction:column;gap:14px}
  .ppa-burger{display:block}
  .ppa-header--open .ppa-burger span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .ppa-header--open .ppa-burger span:nth-child(2){opacity:0}
  .ppa-header--open .ppa-burger span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  .ppa-header--open .ppa-nav{display:block}
}
@media (max-width:640px){.ppa-footer__grid{grid-template-columns:1fr}}

/* Mobile reorder: eventi-aziendali */
@media (max-width:992px){
  #eventi-aziendali{display:grid;grid-template-columns:1fr}
  #eventi-aziendali > figure{grid-row:1;margin-bottom:16px}
  #eventi-aziendali > div{grid-row:2}
}

/* ==========================================================================
GALLERY — Unified IG-style feed (no filters, no split)
========================================================================== */
#ppaGalleryFixed{ display:grid; gap:18px; grid-template-columns:repeat(3, 1fr); }
@media (max-width:1100px){ #ppaGalleryFixed{ grid-template-columns:repeat(2, 1fr); } }
@media (max-width:640px){ #ppaGalleryFixed{ grid-template-columns:1fr; } }

.ppa-g-card{ border-radius:18px; box-shadow:0 12px 28px rgba(0,0,0,.16); background:transparent; position:relative; overflow:hidden; transition:opacity .28s ease, transform .28s ease; }
.ppa-g-link{ display:block; line-height:0; position:relative; }
.ppa-g-card img{ display:block; width:100%; height:auto; vertical-align:middle; transition:transform .5s ease, opacity .35s ease; }
.ppa-g-card:hover img{ transform:scale(1.02); }
.ppa-g-cap{ position:absolute; inset:auto 10px 10px 10px; display:flex; justify-content:flex-end; pointer-events:none; }
.ppa-g-chip{ background:rgba(0,0,0,.6); color:#fff; font-weight:800; border:2px solid rgba(255,255,255,.2); padding:6px 10px; border-radius:999px; backdrop-filter:blur(4px); }

/* Reveal for gallery items */
.ppa-g-card.will-reveal{ opacity:0; transform:translateY(12px); }
.ppa-g-card.in-view{ opacity:1; transform:none; transition:opacity .45s ease, transform .45s ease; }

/* === GALLERY LIGHTBOX === */
.ppa-lightbox[aria-hidden="true"]{ display:none; }
.ppa-lightbox{ position:fixed; inset:0; z-index:9999; display:flex; align-items:center; justify-content:center; }
.ppa-lightbox__backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.86); backdrop-filter:saturate(1.1) blur(2px); }
.ppa-lightbox__frame{ position:relative; z-index:2; max-width:min(1200px,96vw); max-height:90vh; display:flex; align-items:center; justify-content:center; }
#ppaLightboxImg{ max-width:100%; max-height:100%; width:auto; height:auto; object-fit:contain; border-radius:14px; box-shadow:0 24px 60px rgba(0,0,0,.45); background:#000; }
#ppaLightboxCap{ position:absolute; left:0; right:0; bottom:-36px; text-align:center; color:#fff; }
.ppa-lightbox__nav, .ppa-lightbox__close{
  appearance:none; border:0; cursor:pointer; user-select:none; width:44px; height:44px; border-radius:999px; display:grid; place-items:center; font-weight:800; line-height:1; box-shadow:0 12px 24px rgba(0,0,0,.35); background:#fff; color:#111;
}
.ppa-lightbox__nav.prev{ position:absolute; left:10px; top:50%; transform:translateY(-50%); }
.ppa-lightbox__nav.next{ position:absolute; right:10px; top:50%; transform:translateY(-50%); }
.ppa-lightbox__close{ position:absolute; right:-10px; top:-10px; }
@media (max-width:640px){
  .ppa-lightbox__nav{ width:38px; height:38px; }
  .ppa-lightbox__close{ width:38px; height:38px; right:-6px; top:-6px; }
}

/* Put this at the very end of your CSS */
.ppa-cards-carousel .ppa-card__action{
  background: var(--ppa-accent) !important; /* gold */
  color: #111 !important;
  border-color: transparent !important;
}

/* ===== Overrides / Fixes ===== */
/* Chi siamo — left-align heading and paragraphs under it */
#chi-siamo h2.center, #chi-siamo .ppa-lead, #chi-siamo p.center{
  text-align:left !important; margin-left:0 !important; margin-right:auto !important;
}

/* Contattaci — center the white form box */
.ppa-contact-hero__content{ margin-left:auto !important; margin-right:auto !important; }

/* Mobile: prevent sticky hover */
@media (hover: none) {
  .ppa-nav a:hover { color: inherit; }
  .ppa-nav a:hover::after { transform: none; }
}

/* Mobile: remove iOS tap highlight + default dotted focus ring */
.ppa-nav a, .ppa-burger { -webkit-tap-highlight-color: transparent; }
.ppa-nav a:focus, .ppa-burger:focus { outline: none; }

/* Keep accessible keyboard focus on desktop */
@media (hover: hover) and (pointer: fine) {
  .ppa-nav a:focus-visible, .ppa-burger:focus-visible { outline: 2px solid var(--ppa-accent); outline-offset: 4px; }
}

/* Make underline show only on the active page on mobile */
@media (hover: none) { .ppa-nav a.is-active::after { transform: scaleX(1); } }

/* Gallery lightbox — hide the filename/caption under the image */
#ppaLightboxCap { display: none !important; }
.ppa-g-cap { display: none !important; }
/* 1) Left-align the two specific lead paragraphs (Intro + Menu) */
.ppa-section--dark > .ppa-container > .ppa-lead {
  text-align: left;
  margin-left: 0;
  margin-right: auto;
}

#menu .ppa-lead {
  text-align: left;
  margin-left: 0;
  margin-right: auto;
}

/* 2) Flip cards: add perspective so the 3D rotate is visible */
.ppa-card {
  perspective: 1000px; /* add if not present */
}
/* Left-align intro, menu, and requisiti tecnici paragraphs */
.ppa-section--dark > .ppa-container > .ppa-lead,
#menu .ppa-lead,
#cosa-facciamo .ppa-lead {
  text-align: left;
  margin-left: 0;
  margin-right: auto;
}
/* Keep the whole-page dark and footer pinned (no white band at bottom) */
html, body {
  background-color: var(--ppa-bg-dark) !important;
  min-height: 100%;
}
.ppa-wrap {
  min-height: 100dvh;   /* dynamic VH so mobile toolbars don't leave gaps */
  display: flex;
  flex-direction: column;
}
.ppa-footer { margin-top: auto; }

/* Make sure Astra's mobile drawer appears and sits above our header */
.ast-mobile-popup-drawer,
.ast-mobile-header-wrap,
.ast-mobile-popup-overlay {
  z-index: 999999 !important;
}

/* When the drawer is open, let Astra control page scroll */
body.ast-mobile-popup-active {
  overflow: hidden !important;
}

/* Ensure our custom header never blocks taps on the Astra drawer */
.ppa-header { z-index: 1000; }                 /* our normal layer */
.ast-mobile-popup-active .ppa-header { z-index: 1; }  /* push it below the drawer while open */

/* If your theme wraps content with its own background, keep it transparent so the dark body shows through */
#page, .site, .page, .content, .entry-content {
  background: transparent !important;
}
/* FAQ */
.ppa-faq-list { display:grid; gap:14px; margin-top:18px; }
.ppa-faq {
  background:#111; color:var(--ppa-text);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px; overflow:hidden;
}
.ppa-faq summary {
  cursor:pointer; list-style:none; outline:none;
  padding:16px 18px; margin:0;
  font-weight:800; color:#fff; display:flex; align-items:center; gap:12px;
}
.ppa-faq summary::-webkit-details-marker{ display:none; }
.ppa-faq summary::after{
  content:"▾"; margin-left:auto; transition:transform .2s ease;
}
.ppa-faq[open] summary::after{ transform:rotate(180deg); }
.ppa-faq__body{ padding:0 18px 18px; }
.ppa-faq__body p{ margin:10px 0; }
.ppa-faq__body ul{ margin:8px 0 0 18px; }
.ppa-faq[open]{
  border-color:var(--ppa-accent);
  box-shadow:0 12px 28px rgba(0,0,0,.22);
}
img[src*="logo2.png"]{
  filter: brightness(0) invert(1);
}
/* ================================
   Contact form — compact overrides
   Add to your main CSS after the defaults
==================================*/

/* Compact hero spacing */
.ppa-contact-hero{
  min-height: auto;                 /* override 70vh */
  padding-top: 42px;
  padding-bottom: 64px;
}
.ppa-contact-hero .ppa-hero__title{
  font-size: clamp(28px,4vw,40px);
  margin: 0 0 6px;
}
.ppa-contact-hero .ppa-contact-hero__headline{
  max-width: 820px;
  margin: 6px auto 16px;
  line-height: 1.45;
  font-size: clamp(14px,1.7vw,16px);
  color: #eaeaea;
}

/* Tighter form card */
.ppa-contact-hero__content{
  max-width: 640px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 16px 16px !important;
  border-radius: 12px !important;
  background: rgba(255,255,255,.96) !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.22) !important;
}

/* Grid + gaps */
.ppa-form-modern .wpcf7-form{ gap: 10px !important; }
@media (min-width: 900px){
  .ppa-form-modern .wpcf7-form{ grid-template-columns: 1fr 1fr !important; }
  .ppa-form-modern .wpcf7-form p:where(:has(textarea), .textarea){ grid-column: 1 / -1 !important; }
}

/* Labels smaller, tighter */
.ppa-form-modern .wpcf7-form p{ margin: 0 !important; }
.ppa-form-modern .wpcf7-form p>label{
  margin: 0 0 4px !important;
  font-size: clamp(12px,1.3vw,13px) !important;
  color: #2a2f36 !important;
}

/* Inputs/textarea more compact */
.ppa-form-modern .wpcf7-form input[type="text"],
.ppa-form-modern .wpcf7-form input[type="email"],
.ppa-form-modern .wpcf7-form input[type="tel"],
.ppa-form-modern .wpcf7-form input[type="number"]{
  height: 40px !important;              /* was 44px */
  padding: 0 10px !important;
  font-size: clamp(14px,1.6vw,15px) !important;
  border-radius: 10px !important;
}
.ppa-form-modern .wpcf7-form textarea{
  min-height: 110px !important;         /* was 130px */
  padding: 8px 10px !important;
  font-size: clamp(14px,1.6vw,15px) !important;
}

/* Submit row + button */
.ppa-form-modern .wpcf7-form .ppa-submit-row{ margin-top: 2px !important; }
.ppa-form-modern .wpcf7-form .wpcf7-submit{
  padding: 10px 22px !important;
  font-size: 14px !important;
  border-radius: 999px !important;
  box-shadow: 0 8px 18px rgba(0,0,0,.18) !important;
}

/* Optional: shrink CF7 messages a bit */
.ppa-form-modern .wpcf7 form .wpcf7-response-output{
  margin-top: 8px !important;
  padding: 8px 10px !important;
  font-size: .9rem !important;
}