/* =====================================================================
   Maria Grazia Aruta — Make-up Artist Napoli
   Design: cipria + oro · couture · mobile-first · app-like
   ===================================================================== */

:root{
  --cipria:#F7E6E3;        /* powder pink (brand bg) */
  --cipria-2:#F2D9D5;
  --avorio:#FBF5F2;        /* ivory */
  --vinaccia:#4E2730;      /* deep wine — dark luxe sections */
  --vinaccia-2:#3A1C24;
  --bordeaux:#8E2A2A;      /* script red accent */
  --oro:#C6A15B;           /* gold */
  --oro-chiaro:#E7CE96;
  --oro-scuro:#9B7733;
  --ink:#1A1411;          /* near-black text */
  --ink-soft:#5b524d;
  --su-scuro:#F4E7E2;     /* text on dark */
  --linea:rgba(26,20,17,.10);
  --grad-oro:linear-gradient(105deg,#9B7733 0%,#E7CE96 28%,#C6A15B 52%,#F1DEAE 70%,#9B7733 100%);
  --shadow-s:0 2px 10px rgba(78,39,48,.08);
  --shadow-m:0 14px 40px -18px rgba(78,39,48,.35);
  --shadow-l:0 30px 70px -30px rgba(58,28,36,.55);
  --r:18px; --r-s:12px; --r-l:28px;
  --maxw:1200px;
  --ff-display:"Cormorant Garamond",Georgia,serif;
  --ff-body:"Poppins",system-ui,-apple-system,sans-serif;
  --ff-script:"Pinyon Script",cursive;
  --appbar-h:64px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--ff-body);color:var(--ink);
  background:var(--avorio);line-height:1.62;font-size:16px;
  overflow-x:hidden;-webkit-font-smoothing:antialiased;
  padding-bottom:env(safe-area-inset-bottom);
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:600;line-height:1.06;letter-spacing:.005em;margin:0 0 .4em}
h1{font-size:clamp(2.5rem,8.5vw,5rem)}
h2{font-size:clamp(2rem,5.5vw,3.3rem)}
h3{font-size:clamp(1.3rem,3.4vw,1.7rem)}
p{margin:0 0 1rem}
.script{font-family:var(--ff-script);color:var(--bordeaux);font-weight:400}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(20px,5vw,40px)}
.section{padding-block:clamp(56px,9vw,110px)}
.eyebrow{
  font-family:var(--ff-body);font-size:.72rem;font-weight:600;letter-spacing:.34em;
  text-transform:uppercase;color:var(--oro-scuro);display:inline-flex;align-items:center;gap:.6em;margin-bottom:1rem;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--oro)}
.lede{font-size:clamp(1.05rem,2.4vw,1.25rem);color:var(--ink-soft);max-width:60ch}
.center{text-align:center}
.center .lede{margin-inline:auto}
.center .eyebrow::after{content:"";width:26px;height:1px;background:var(--oro)}

/* gold text accent */
.gold{
  background:var(--grad-oro);-webkit-background-clip:text;background-clip:text;color:transparent;
  background-size:200% auto;
}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--ink);--fg:#fff;
  display:inline-flex;align-items:center;gap:.6em;justify-content:center;
  padding:.95em 1.7em;border-radius:100px;font-weight:600;font-size:.95rem;letter-spacing:.01em;
  background:var(--bg);color:var(--fg);border:1px solid transparent;cursor:pointer;
  transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s,filter .25s;
  box-shadow:var(--shadow-s);will-change:transform;
}
.btn .ico{width:1.15em;height:1.15em}
.btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-m)}
.btn:active{transform:translateY(-1px)}
.btn-gold{--bg:transparent;color:var(--ink);position:relative;background:var(--grad-oro);background-size:200% auto;animation:shimmer 6s linear infinite}
.btn-ghost{--bg:transparent;color:var(--ink);border-color:var(--linea);box-shadow:none}
.btn-ghost:hover{border-color:var(--oro)}
.btn-wa{--bg:#1FAE5A;--fg:#fff}
.btn-light{--bg:#fff;--fg:var(--ink)}
.btn-block{display:flex;width:100%}
@keyframes shimmer{to{background-position:200% center}}

/* ---------- header ---------- */
.site-head{
  position:sticky;top:0;z-index:60;
  background:color-mix(in srgb,var(--avorio) 82%,transparent);
  backdrop-filter:blur(14px) saturate(1.2);-webkit-backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s;
}
.site-head.scrolled{border-color:var(--linea)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px;gap:1rem}
.brand{display:flex;align-items:center;gap:.7rem;min-width:0}
.brand img{height:30px;width:auto}
.brand b{font-family:var(--ff-display);font-weight:600;font-size:1.18rem;letter-spacing:.01em;white-space:nowrap}
.brand small{display:block;font-family:var(--ff-body);font-size:.56rem;letter-spacing:.32em;text-transform:uppercase;color:var(--oro-scuro);margin-top:-2px}
.nav-links{display:flex;align-items:center;gap:.3rem}
.nav-links a{padding:.5em .9em;border-radius:100px;font-size:.92rem;font-weight:500;color:var(--ink-soft);transition:color .2s,background .2s}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--ink);background:color-mix(in srgb,var(--cipria) 70%,transparent)}
.nav-cta{margin-left:.4rem}
.nav-toggle{display:none;width:44px;height:44px;border:1px solid var(--linea);border-radius:12px;background:#fff;align-items:center;justify-content:center;flex-direction:column;gap:4px}
.nav-toggle span{width:18px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

@media(max-width:880px){
  .nav-links{
    position:fixed;inset:72px 0 auto 0;flex-direction:column;align-items:stretch;
    background:var(--avorio);padding:1rem clamp(20px,5vw,40px) 2rem;gap:.2rem;
    border-bottom:1px solid var(--linea);box-shadow:var(--shadow-m);
    transform:translateY(-12px);opacity:0;pointer-events:none;transition:.28s;
  }
  .nav-links.open{transform:none;opacity:1;pointer-events:auto}
  .nav-links a{padding:.85em 1em;font-size:1.05rem;border-radius:12px}
  .nav-cta{margin:.5rem 0 0}
  .nav-toggle{display:flex}
  .nav-toggle.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
}
@media(max-width:560px){
  .nav{height:64px}
  .brand img{height:22px}
  .brand b{font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .brand small{display:none}
  .nav-links{inset:64px 0 auto 0}
}

/* ---------- hero ---------- */
.hero{
  position:relative;text-align:center;overflow:hidden;
  background:
    radial-gradient(120% 90% at 50% -10%, #fff 0%, var(--cipria) 42%, var(--cipria-2) 100%);
  padding-block:clamp(40px,7vw,72px) clamp(60px,10vw,120px);
}
.hero::after{ /* subtle gold grain */
  content:"";position:absolute;inset:0;pointer-events:none;mix-blend-mode:overlay;opacity:.5;
  background-image:radial-gradient(circle at 20% 30%,rgba(198,161,91,.18),transparent 25%),
                   radial-gradient(circle at 80% 60%,rgba(198,161,91,.14),transparent 22%);
}
.hero-logo{width:min(380px,72vw);margin:0 auto 1.4rem;filter:drop-shadow(0 18px 30px rgba(78,39,48,.18))}
.hero h1{margin:0 0 .25em}
.hero h1 .ln2{display:block;font-style:italic;color:var(--vinaccia)}
.hero .lede{margin:1.2rem auto 0;font-size:clamp(1.05rem,2.6vw,1.3rem)}
.hero-cta{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap;margin-top:1.9rem}
.hero-badges{display:flex;gap:1.4rem;justify-content:center;flex-wrap:wrap;margin-top:2.4rem;
  font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--oro-scuro);font-weight:600}
.hero-badges span{display:inline-flex;align-items:center;gap:.5em}
.hero-badges span+span::before{content:"·";color:var(--oro);margin-right:1.4rem}

/* floating gold particles */
.sparkles{position:absolute;inset:0;pointer-events:none;z-index:0}
.sparkles i{position:absolute;width:7px;height:7px;color:var(--oro);opacity:0;animation:float 7s ease-in-out infinite}
.sparkles i svg{width:100%;height:100%}
@keyframes float{0%{opacity:0;transform:translateY(14px) scale(.6)}30%{opacity:.9}70%{opacity:.6}100%{opacity:0;transform:translateY(-26px) scale(1.05)}}

/* ---------- winged divider (signature) ---------- */
.wing-div{display:flex;align-items:center;justify-content:center;gap:1rem;color:var(--oro);margin:0 auto;max-width:340px}
.wing-div svg{width:130px;height:auto}
.wing-div::before,.wing-div::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--oro))}
.wing-div::after{background:linear-gradient(90deg,var(--oro),transparent)}

/* ---------- credibility marquee ---------- */
.cred{background:var(--vinaccia);color:var(--su-scuro);overflow:hidden;border-block:1px solid rgba(231,206,150,.18)}
.cred-track{display:flex;gap:3rem;padding-block:1.15rem;white-space:nowrap;animation:marq 26s linear infinite;width:max-content}
.cred-track span{font-family:var(--ff-display);font-size:1.35rem;letter-spacing:.04em;display:inline-flex;align-items:center;gap:1.2rem;font-style:italic}
.cred-track span::after{content:"✦";color:var(--oro);font-size:.7em;font-style:normal}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- manifesto ---------- */
.manifesto{background:var(--avorio)}
.manifesto .quote{font-family:var(--ff-display);font-style:italic;font-size:clamp(1.6rem,4.4vw,2.6rem);line-height:1.25;max-width:20ch;margin:0 auto 1.4rem;text-align:center}
.manifesto .quote em{color:var(--bordeaux);font-style:italic}
.manifesto-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.2rem;margin-top:2.6rem}
.mf-card{background:#fff;border:1px solid var(--linea);border-radius:var(--r);padding:1.6rem;box-shadow:var(--shadow-s)}
.mf-card .ico{width:30px;height:30px;color:var(--oro);margin-bottom:.7rem}
.mf-card h3{font-size:1.15rem;margin-bottom:.3rem}
.mf-card p{font-size:.95rem;color:var(--ink-soft);margin:0}

/* ---------- services ---------- */
.serv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.2rem}
.serv-card{
  position:relative;background:#fff;border:1px solid var(--linea);border-radius:var(--r);
  padding:1.7rem 1.5rem;overflow:hidden;transition:transform .3s,box-shadow .3s,border-color .3s;
}
.serv-card::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:var(--grad-oro);transform:scaleX(0);transform-origin:left;transition:transform .4s}
.serv-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-m);border-color:transparent}
.serv-card:hover::before{transform:scaleX(1)}
.serv-ico{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;background:var(--cipria);color:var(--oro-scuro);margin-bottom:1rem}
.serv-ico .ico{width:24px;height:24px}
.serv-card h3{font-size:1.3rem;margin-bottom:.3rem}
.serv-card .price{font-family:var(--ff-body);font-weight:600;color:var(--bordeaux);font-size:.95rem;margin-top:.2rem}
.serv-card p{font-size:.93rem;color:var(--ink-soft);margin:.5rem 0 0}

/* makeup-themed list (lipstick bullets) */
.mk-list{list-style:none;padding:0;margin:1rem 0 0;display:grid;gap:.55rem}
.mk-list li{display:flex;gap:.7rem;align-items:flex-start;font-size:.95rem}
.mk-list li .ico{width:18px;height:18px;color:var(--oro);flex:none;margin-top:.18rem}

/* package cards (self make-up) */
.pkg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.4rem}
.pkg{border-radius:var(--r-l);padding:2rem 1.8rem;position:relative;overflow:hidden;border:1px solid var(--linea)}
.pkg.pink{background:linear-gradient(160deg,#fff,var(--cipria))}
.pkg.gold{background:linear-gradient(160deg,#fff,#F3E7CC);border-color:rgba(155,119,51,.3)}
.pkg .tag{font-size:.66rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--oro-scuro)}
.pkg h3{font-size:1.7rem;margin:.4rem 0 .1rem}
.pkg .cost{font-family:var(--ff-display);font-size:2.6rem;font-weight:600;line-height:1}
.pkg .cost small{font-size:1rem;color:var(--ink-soft);font-family:var(--ff-body);font-weight:500}
.pkg .dur{font-size:.85rem;color:var(--ink-soft);margin-bottom:1rem}

/* ---------- gallery ---------- */
.filters{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:2rem}
.filters button{
  padding:.55em 1.1em;border-radius:100px;border:1px solid var(--linea);background:#fff;color:var(--ink-soft);
  font-weight:600;font-size:.85rem;cursor:pointer;transition:.25s;
}
.filters button.active,.filters button:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.gallery{columns:4 220px;column-gap:14px}
.gallery figure{margin:0 0 14px;break-inside:avoid;position:relative;border-radius:var(--r-s);overflow:hidden;box-shadow:var(--shadow-s);cursor:pointer;background:var(--cipria)}
.gallery img{width:100%;height:auto;transition:transform .6s cubic-bezier(.2,.7,.2,1);display:block}
.gallery figure:hover img{transform:scale(1.06)}
.gallery figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:1.4rem .9rem .8rem;color:#fff;font-size:.78rem;
  letter-spacing:.16em;text-transform:uppercase;font-weight:600;
  background:linear-gradient(transparent,rgba(26,20,17,.72));opacity:0;transform:translateY(8px);transition:.3s;
}
.gallery figure:hover figcaption{opacity:1;transform:none}
.gallery figure.hide{display:none}
/* uniform card variant (homepage teaser) */
.gallery.cards{columns:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}
.gallery.cards figure{aspect-ratio:4/5}
.gallery.cards img{height:100%;object-fit:cover;object-position:center 32%}

/* lightbox */
.lb{position:fixed;inset:0;z-index:90;background:rgba(26,20,17,.92);display:none;align-items:center;justify-content:center;padding:5vw}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:86vh;width:auto;border-radius:8px;box-shadow:var(--shadow-l)}
.lb button{position:absolute;top:18px;right:18px;width:46px;height:46px;border-radius:50%;border:none;background:#fff;font-size:1.4rem;cursor:pointer}

/* ---------- bridal banner ---------- */
.sposa{position:relative;color:var(--su-scuro);overflow:hidden;background:var(--vinaccia)}
.sposa::before{content:"";position:absolute;inset:0;background:url("../img/portfolio/sposa-01.jpg") center 28%/cover;opacity:.22}
.sposa::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--vinaccia-2) 8%,transparent)}
.sposa .wrap{position:relative;z-index:2}
.sposa h2{color:#fff}
.sposa .lede{color:var(--cipria)}
.sposa .free{display:inline-flex;align-items:center;gap:.5em;background:var(--grad-oro);color:var(--ink);font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;padding:.5em 1em;border-radius:100px;margin-bottom:1rem}

/* ---------- about ---------- */
.about{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.about-media{position:relative}
.about-media img{border-radius:var(--r-l);box-shadow:var(--shadow-l);width:100%;aspect-ratio:4/5;object-fit:cover}
.about-media .badge{
  position:absolute;left:-12px;bottom:24px;background:#fff;border-radius:var(--r);padding:1rem 1.2rem;box-shadow:var(--shadow-m);text-align:center;
}
.about-media .badge b{display:block;font-family:var(--ff-display);font-size:2rem;line-height:1;color:var(--oro-scuro)}
.about-media .badge span{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft)}
@media(max-width:760px){.about{grid-template-columns:1fr}.about-media{order:-1;max-width:420px;margin-inline:auto}}

/* ---------- FAQ (AEO) ---------- */
.faq{max-width:820px;margin-inline:auto}
.faq details{border:1px solid var(--linea);border-radius:var(--r);background:#fff;margin-bottom:.8rem;overflow:hidden}
.faq summary{list-style:none;cursor:pointer;padding:1.15rem 1.3rem;font-weight:600;font-size:1.02rem;display:flex;justify-content:space-between;gap:1rem;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--oro-scuro);transition:transform .3s;font-family:var(--ff-body)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 1.3rem 1.3rem;margin:0;color:var(--ink-soft);font-size:.96rem}

/* ---------- booking form ---------- */
.booking{background:var(--cipria)}
.form-card{background:#fff;border-radius:var(--r-l);box-shadow:var(--shadow-l);padding:clamp(1.6rem,4vw,2.6rem);max-width:760px;margin-inline:auto}
.field{margin-bottom:1.1rem}
.field label{display:block;font-weight:600;font-size:.85rem;margin-bottom:.4rem}
.field input,.field select,.field textarea{
  width:100%;padding:.85em 1em;border:1px solid var(--linea);border-radius:var(--r-s);font:inherit;background:var(--avorio);color:var(--ink);transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--oro);box-shadow:0 0 0 3px rgba(198,161,91,.18);background:#fff}
.field textarea{min-height:110px;resize:vertical}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
@media(max-width:540px){.grid-2{grid-template-columns:1fr;gap:0}}
.hp{position:absolute;left:-9999px}
.form-note{font-size:.82rem;color:var(--ink-soft);display:flex;gap:.5em;align-items:flex-start;margin-top:1rem}
.form-note .ico{width:16px;height:16px;color:var(--oro);flex:none;margin-top:.15rem}
.form-status{padding:1rem;border-radius:var(--r-s);font-size:.92rem;font-weight:500;margin-bottom:1rem;display:none}
.form-status.ok{display:block;background:#E9F6EE;color:#176b39;border:1px solid #b8e2c8}
.form-status.err{display:block;background:#FCEBEB;color:#9b2226;border:1px solid #f2c4c4}

/* ---------- footer ---------- */
.site-foot{background:var(--vinaccia-2);color:var(--su-scuro);padding-block:clamp(48px,7vw,72px) calc(96px + env(safe-area-inset-bottom))}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr;gap:1.8rem}}
.site-foot img{height:34px;margin-bottom:1rem}
.site-foot h4{font-family:var(--ff-body);font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--oro-chiaro);margin-bottom:1rem}
.site-foot a{color:var(--cipria);opacity:.85;transition:opacity .2s}
.site-foot a:hover{opacity:1;color:#fff}
.foot-links{display:grid;gap:.5rem}
.foot-contact{display:grid;gap:.7rem}
.foot-contact a{display:inline-flex;align-items:center;gap:.6em}
.foot-contact .ico{width:18px;height:18px;color:var(--oro)}
.socials{display:flex;gap:.6rem;margin-top:1rem}
.socials a{width:42px;height:42px;border:1px solid rgba(231,206,150,.3);border-radius:12px;display:grid;place-items:center;color:var(--oro-chiaro)}
.socials a:hover{background:var(--oro);color:var(--vinaccia-2);border-color:var(--oro)}
.foot-bottom{border-top:1px solid rgba(231,206,150,.16);margin-top:2.5rem;padding-top:1.4rem;font-size:.8rem;opacity:.7;display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between}

/* ---------- mobile app bar + WA float ---------- */
.appbar{
  position:fixed;left:0;right:0;bottom:0;z-index:70;height:calc(var(--appbar-h) + env(safe-area-inset-bottom));
  padding-bottom:env(safe-area-inset-bottom);
  background:color-mix(in srgb,#fff 88%,transparent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-top:1px solid var(--linea);display:none;grid-template-columns:repeat(5,1fr);box-shadow:0 -8px 30px -16px rgba(58,28,36,.4);
}
.appbar a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:.62rem;font-weight:600;color:var(--ink-soft);letter-spacing:.02em}
.appbar a .ico{width:22px;height:22px}
.appbar a[aria-current="page"]{color:var(--ink)}
.appbar .center-cta{position:relative}
.appbar .center-cta span.btnc{
  position:absolute;top:-22px;left:50%;transform:translateX(-50%);
  width:58px;height:58px;border-radius:50%;display:grid;place-items:center;color:var(--ink);
  background:var(--grad-oro);background-size:200% auto;box-shadow:var(--shadow-m);animation:shimmer 6s linear infinite;
}
.appbar .center-cta span.btnc .ico{width:26px;height:26px}
.appbar .center-cta b{margin-top:34px;font-size:.62rem;font-weight:700;color:var(--ink)}
.wa-float{
  position:fixed;right:16px;bottom:calc(var(--appbar-h) + 16px + env(safe-area-inset-bottom));z-index:65;
  width:58px;height:58px;border-radius:50%;background:#1FAE5A;color:#fff;display:grid;place-items:center;
  box-shadow:0 10px 26px -8px rgba(31,174,90,.6);transition:transform .25s;
}
.wa-float .ico{width:30px;height:30px}
.wa-float:hover{transform:scale(1.08)}
.wa-float::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid #1FAE5A;animation:pulse 2.4s ease-out infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.7);opacity:0}}

@media(max-width:880px){
  .appbar{display:grid}
  body{padding-bottom:calc(var(--appbar-h) + env(safe-area-inset-bottom))}
  .nav-cta{display:none} /* azione principale già nella appbar */
}
@media(min-width:881px){.wa-float{bottom:24px;right:24px}}

/* ---------- reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- article ---------- */
.article{max-width:740px;margin-inline:auto}
.article img{border-radius:var(--r);margin:1.6rem 0;box-shadow:var(--shadow-m)}
.article h2{margin-top:2.2rem}
.article p,.article li{font-size:1.05rem;color:#332a26}
.article ul{padding-left:0;list-style:none;display:grid;gap:.6rem;margin:1.2rem 0}
.article ul li{display:flex;gap:.7rem}
.article ul li .ico{width:20px;height:20px;color:var(--oro);flex:none;margin-top:.25rem}
.meta{font-size:.85rem;color:var(--ink-soft);letter-spacing:.04em}

/* utils */
.mt0{margin-top:0}.tc{text-align:center}
.skip{position:absolute;left:-999px;top:0;background:#fff;padding:.6em 1em;border-radius:0 0 10px 0;z-index:100}
.skip:focus{left:0}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* Fix icone footer troppo grandi */
.site-footer img,
.footer img {
    max-width: 140px;
    height: auto;
}

.site-footer .social img,
.footer .social img,
.site-footer svg,
.footer svg {
    width: 28px;
    height: 28px;
}

/* FIX DEFINITIVO icone footer enormi */
footer img[src*="logo-mark"] {
    width: 140px !important;
    max-width: 140px !important;
    height: auto !important;
}

footer img,
footer svg {
    max-width: 28px !important;
    max-height: 28px !important;
    width: 28px !important;
    height: 28px !important;
}

footer .brand img,
footer .footer-brand img,
footer .logo img {
    width: 140px !important;
    max-width: 140px !important;
    height: auto !important;
}

/* Fix form mobile */
@media (max-width: 768px) {
  .form-card,
  .field,
  form,
  input,
  select,
  textarea,
  button {
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  .form-card {
    padding: 22px 16px !important;
    overflow: hidden !important;
  }

  input,
  select,
  textarea {
    width: 100% !important;
    min-width: 0 !important;
  }
}

/* FIX MOBILE DEFINITIVO PRENOTA */
@media (max-width: 768px) {
  html, body {
    max-width: 100%;
    overflow-x: hidden;
  }

  .booking,
  .booking .wrap,
  .form-card {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  .form-card {
    padding: 24px 18px !important;
    border-radius: 28px !important;
  }

  .form-card .grid,
  .form-grid,
  .field-row {
    display: block !important;
    grid-template-columns: 1fr !important;
  }

  .field,
  input,
  select,
  textarea,
  button {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  .form-note {
    display: block !important;
    width: 100% !important;
    line-height: 1.45 !important;
    text-align: left !important;
    white-space: normal !important;
  }

  .form-note .ico {
    width: 18px !important;
    height: 18px !important;
    margin-right: 6px !important;
    vertical-align: middle;
  }

  .bottom-nav {
    max-width: 100vw !important;
  }
}

/* Fix menu hamburger mobile */
@media (max-width: 768px) {
  .nav-toggle {
    width: 56px !important;
    max-width: 56px !important;
    min-width: 56px !important;
    height: 56px !important;
    padding: 0 !important;
    flex: 0 0 56px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  .site-head button.nav-toggle {
    width: 56px !important;
  }
}

/* Fix Pacchetto Gold mobile */
@media (max-width: 768px) {
  .packages,
  .pricing,
  .cards,
  .service-grid {
    display: block !important;
  }

  .package,
  .price-card,
  .service-card,
  .card {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: auto !important;
    overflow: visible !important;
  }

  .mk-list,
  .mk-list li {
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    color: inherit !important;
    height: auto !important;
    overflow: visible !important;
  }

  .mk-list li {
    margin: 12px 0 !important;
    line-height: 1.4 !important;
  }
}

/* Fix reveal su mobile */
@media (max-width: 768px) {
  .reveal,
  .reveal.in,
  .pkg,
  .pkg.gold,
  .pkg.pink {
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    height: auto !important;
    min-height: auto !important;
    overflow: visible !important;
  }

  .pkg-grid {
    display: block !important;
  }

  .pkg {
    margin-bottom: 28px !important;
  }
}

/* Fix definitivo pacchetti self make-up */
.pkg-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 28px;
}

.pkg {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  overflow: visible !important;
  height: auto !important;
}

.pkg h3,
.pkg .cost,
.pkg .dur,
.pkg .mk-list,
.pkg .mk-list li,
.pkg .btn {
  opacity: 1 !important;
  visibility: visible !important;
  display: block !important;
}

@media (max-width: 768px) {
  .pkg-grid {
    display: block !important;
  }

  .pkg {
    width: 100% !important;
    margin-bottom: 28px !important;
    padding: 32px 24px !important;
    min-height: auto !important;
  }

  .pkg .mk-list li {
    display: flex !important;
    gap: 10px !important;
    align-items: flex-start !important;
  }
}

/* FIX FORZATO PACCHETTI */
#self-make-up .pkg,
#self-make-up .pkg * {
  color: #3b2420 !important;
  opacity: 1 !important;
  visibility: visible !important;
}

#self-make-up .pkg {
  background: #ffffff !important;
  display: block !important;
  position: relative !important;
  z-index: 2 !important;
}

#self-make-up .pkg.gold {
  background: #fff8e8 !important;
  border: 1px solid #c9a24a !important;
}

#self-make-up .pkg .tag,
#self-make-up .pkg .cost,
#self-make-up .pkg h3,
#self-make-up .pkg .dur,
#self-make-up .pkg li,
#self-make-up .pkg a {
  display: block !important;
}
