:root{
  /* Meeters design tokens — meeters.org */
  --primary:#FF601A;
  --primary-dark:#F54900;
  --primary-light:#FF7E47;
  --primary-bg:#FFF1EB;
  --secondary:#25C9BA;
  --secondary-dark:#20ACA1;
  --secondary-bg:#E5F9F7;
  --ink:#1A202C;
  --body:#2D3748;
  --muted:#718096;
  --muted-dark:#4A5568;
  --success:#20ACA1;
  --success-bg:#E9F7F6;
  --error:#CD3753;
  --error-bg:#FAEBEE;
  --wa:#25D366;
  --wa-dark:#128C7E;
  --card:#FFFFFF;
  --line:#E2E8F0;
  --shadow:0 18px 50px -20px rgba(255,96,26,.22);
  --shadow-soft:0 10px 30px -16px rgba(26,32,44,.10);
  --brand-gradient:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);
  --radius:26px;
  --font-body:"DM Sans",system-ui,sans-serif;
  --font-display:"Libre Bodoni",Georgia,"Times New Roman",serif;
  --font-hand:"Pacifico",cursive;
  /* Tipografia adulta 45–65: corpo grande, buon contrasto */
  --text-xs:13px;
  --text-sm:15px;
  --text-base:17px;
  --text-md:18px;
  --text-lg:20px;
  --text-xl:24px;
  --text-2xl:28px;
  --text-3xl:34px;
  /* Ritmo tipografico */
  --leading-tight:1.22;
  --leading-snug:1.38;
  --leading-normal:1.55;
  --leading-relaxed:1.68;
  --measure:40ch;
  --measure-narrow:34ch;
  --measure-wide:46ch;
}

*{box-sizing:border-box}
html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
  overflow-x:hidden;
}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--primary-bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:var(--leading-relaxed);
  overflow-x:hidden;
  min-height:100vh;
  min-height:100dvh;
  font-size:var(--text-base);
}
img,svg,video{max-width:100%;height:auto}
button,input,textarea,select{font:inherit;color:inherit}
button{cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
h1,h2,h3{font-family:var(--font-body);line-height:var(--leading-tight);letter-spacing:-.01em;margin:0;font-weight:700;text-wrap:balance}
p{margin:0;line-height:var(--leading-relaxed)}
a{color:inherit}

/* App-like centered column — mobile first */
.shell{
  max-width:560px;margin:0 auto;
  padding-left:max(18px, env(safe-area-inset-left));
  padding-right:max(18px, env(safe-area-inset-right));
  padding-bottom:calc(120px + env(safe-area-inset-bottom));
  position:relative;
}

/* ── Sticky reassurance bar ── */
.topbar{
  position:sticky;top:0;z-index:40;
  background:var(--primary);color:#fff;
  text-align:center;font-size:var(--text-sm);font-weight:500;
  line-height:var(--leading-snug);
  padding:calc(10px + env(safe-area-inset-top)) 20px 10px;
  letter-spacing:.01em;
}
.topbar-inner{max-width:var(--measure-wide);margin:0 auto}
.topbar b{font-weight:700}

/* ── Brand row ── */
.brand{
  margin:0;padding:24px 0 8px;
  display:grid;place-items:center;width:100%;
}
.brand svg{
  display:block;width:min(160px, 56vw);height:auto;
  transform:translateX(-6px);
}

/* ── Hero ── */
.hero{text-align:center;padding:20px 8px 12px}
.hero .eyebrow{
  display:inline-flex;align-items:center;gap:5px;
  background:var(--primary-bg);color:var(--primary);
  border:1px solid rgba(255,96,26,.18);
  font-weight:700;font-size:var(--text-xs);letter-spacing:.04em;text-transform:uppercase;
  padding:5px 11px;border-radius:999px;margin-bottom:14px;
}
.hero h1{font-size:clamp(34px,9vw,46px);font-weight:700;color:var(--ink);max-width:14ch;margin:0 auto;line-height:var(--leading-tight)}
.hand{
  font-family:var(--font-hand);font-weight:400;font-style:normal;color:var(--primary);
  letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;
}
h1 .hand{
  font-size:1.4em;line-height:.9;
  position:relative;top:.05em;
}
h2 .hand{
  font-size:1.44em;line-height:.92;
  position:relative;top:.04em;
}
h1 .hand,h2 .hand{display:inline}
.hero .sub{
  color:var(--muted-dark);font-size:var(--text-md);
  line-height:var(--leading-relaxed);text-wrap:pretty;
}
.hero-lead{
  display:flex;flex-direction:column;gap:10px;
  margin:20px auto 0;max-width:var(--measure-wide);text-align:center;
}
.sub--lead{
  color:var(--ink);font-size:var(--text-md);font-weight:500;
}
.sub--cta{font-size:var(--text-base)}
.sub--cta .scroll-cue{
  display:inline-block;font-style:normal;
  animation:scrollCue 1.4s ease-in-out infinite;
}
@keyframes scrollCue{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(4px)}
}
.sub--note{
  font-size:var(--text-xs);color:var(--muted);font-weight:500;
  padding-top:10px;margin-top:2px;border-top:1px solid var(--line);
  line-height:var(--leading-snug);max-width:38ch;margin-left:auto;margin-right:auto;
}
.sub--lead b,.sub--cta b{color:var(--ink);font-weight:700}

.pills{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin:22px 0 4px}
.pill{
  background:var(--card);border:1px solid var(--line);
  padding:10px 15px;border-radius:999px;font-size:var(--text-sm);font-weight:500;
  display:inline-flex;align-items:center;gap:6px;box-shadow:var(--shadow-soft);
}
.pill .free{color:var(--success);font-weight:700}

/* ── Swipe card (signature) ── */
.swipe-wrap{
  --stack-inset:24px;
  --card-gutter:22px;
  --card-tags:118px;
  --photo-ratio:4 / 3;
  --card-max:420px;
  position:relative;width:min(100%,var(--card-max));margin:32px auto 12px;
  padding:var(--stack-inset) 18px 12px var(--card-gutter);
  overflow:visible;
}
.swipe-wrap::after{
  content:"";
  display:block;
  width:calc(100% - var(--card-gutter) * 2);
  margin-left:var(--card-gutter);
  aspect-ratio:var(--photo-ratio);
  padding-bottom:var(--card-tags);
  box-sizing:content-box;
  pointer-events:none;
  visibility:hidden;
}
.hint{
  text-align:center;color:var(--muted);font-size:var(--text-sm);font-weight:500;
  margin:8px auto 20px;padding:0 10px;max-width:40ch;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  line-height:var(--leading-snug);
}
.hint__row{display:flex;align-items:center;justify-content:center;gap:7px}
.hint .dot{width:6px;height:6px;border-radius:50%;background:var(--primary);animation:pulse 1.6s infinite;flex:none}
.hint__step{font-weight:700;color:var(--ink)}
.hint__action{text-wrap:pretty;font-size:var(--text-xs);opacity:.92}
.hint b{color:var(--ink);font-weight:700}
@keyframes pulse{0%,100%{opacity:.35;transform:scale(.8)}50%{opacity:1;transform:scale(1.3)}}

@keyframes stackFlutterNext{
  0%,100%{transform:translateY(-14px) translateX(10px) scale(.965) rotate(1.6deg)}
  50%{transform:translateY(-18px) translateX(16px) scale(.965) rotate(2.4deg)}
}
@keyframes stackFlutterDeep{
  0%,100%{transform:translateY(-28px) translateX(18px) scale(.93) rotate(2.6deg)}
  50%{transform:translateY(-34px) translateX(24px) scale(.93) rotate(3.4deg)}
}
@keyframes stackFlutterNextDesktop{
  0%,100%{transform:translateY(-15px) translateX(11px) scale(.965) rotate(1.4deg)}
  50%{transform:translateY(-19px) translateX(15px) scale(.965) rotate(2deg)}
}
@keyframes stackFlutterDeepDesktop{
  0%,100%{transform:translateY(-30px) translateX(20px) scale(.93) rotate(2.4deg)}
  50%{transform:translateY(-36px) translateX(24px) scale(.93) rotate(3deg)}
}

.card{
  position:absolute;left:var(--card-gutter);right:var(--card-gutter);top:0;bottom:auto;z-index:2;
  border-radius:var(--radius);overflow:hidden;
  background:var(--card);box-shadow:var(--shadow);
  touch-action:none;cursor:grab;
  -webkit-user-select:none;user-select:none;
  display:flex;flex-direction:column;
  transition:transform .32s cubic-bezier(.25,.8,.25,1), opacity .32s ease, filter .32s ease, box-shadow .32s ease;
  will-change:transform;
  transform-origin:left top;
  backface-visibility:hidden;
}
.card--stack{pointer-events:none}
.card--stack.card--active{
  pointer-events:auto;z-index:4;
  transform:translateY(0) translateX(0) scale(1) rotate(0deg);
  box-shadow:0 18px 44px -22px rgba(30,38,38,.28);
}
.card--stack.card--next{
  z-index:3;
  transform:translateY(-16px) translateX(12px) scale(.965) rotate(2deg);
  opacity:1;
  filter:brightness(.98);
  box-shadow:0 10px 28px -16px rgba(30,38,38,.2);
}
.card--stack.card--deep{
  z-index:2;
  transform:translateY(-32px) translateX(22px) scale(.93) rotate(3deg);
  opacity:1;
  filter:brightness(.95);
  box-shadow:0 6px 20px -12px rgba(30,38,38,.16);
}
.swipe-wrap:not(.is-dragging) .card--stack.card--next{
  animation:stackFlutterNext 2.8s ease-in-out infinite;
}
.swipe-wrap:not(.is-dragging) .card--stack.card--deep{
  animation:stackFlutterDeep 2.8s ease-in-out infinite;
  animation-delay:.45s;
}
.card--stack.card--hidden{
  visibility:hidden;pointer-events:none;opacity:0;
}
.swipe-wrap .stamp{z-index:5}
.card.dragging{transition:none;cursor:grabbing}
.card.gone-right{transition:transform .5s cubic-bezier(.2,.7,.3,1),opacity .5s;transform:translate(160%,-30px) rotate(22deg)!important;opacity:0;pointer-events:none}
.card.gone-left{transition:transform .5s cubic-bezier(.2,.7,.3,1),opacity .5s;transform:translate(-160%,-30px) rotate(-22deg)!important;opacity:0;pointer-events:none}

.card .photo{
  position:relative;flex:none;width:100%;aspect-ratio:var(--photo-ratio, 1 / 1);overflow:hidden;
}
.card .photo picture{display:block;width:100%;height:100%}
.card .photo img{
  width:100%;height:100%;max-width:none;object-fit:cover;object-position:center center;display:block;
}
.card .veil{
  position:absolute;left:0;right:0;bottom:0;padding:54px 20px 18px;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.62));color:#fff;
}
.card .veil .title{font-family:var(--font-body);font-weight:700;font-size:clamp(20px,5.5vw,26px);line-height:var(--leading-snug);text-wrap:balance}
.card .veil .title .yrs{font-size:var(--text-base);font-weight:500;opacity:.9}
.card .veil .meta{display:flex;align-items:center;gap:7px;font-size:var(--text-sm);margin-top:6px;opacity:.95}
.card .tags{display:flex;flex-wrap:wrap;gap:8px;padding:16px 18px 18px;background:#fff;flex:none}
.card .tag{font-size:var(--text-sm);font-weight:500;color:var(--ink);background:var(--primary-bg);border:1px solid var(--line);padding:8px 13px;border-radius:999px}
.card .tag--soft{font-size:var(--text-xs);color:var(--muted);background:transparent;border-color:var(--line);font-weight:500;opacity:.92}
.card .tag.free{color:var(--success);background:var(--success-bg);border-color:rgba(32,172,161,.25)}

.stamp{
  position:absolute;top:24px;font-family:var(--font-body);font-weight:700;font-size:clamp(18px,5vw,28px);
  padding:6px 16px;border:4px solid;border-radius:12px;opacity:0;pointer-events:none;
  text-transform:uppercase;letter-spacing:.04em;
  transition:opacity .18s ease;
}
.stamp.like{left:20px;color:var(--primary);border-color:var(--primary);transform:rotate(-16deg)}
.stamp.nope{right:20px;color:var(--error);border-color:var(--error);transform:rotate(16deg)}

/* swipe buttons */
.swipe-actions{
  position:relative;z-index:10;
  display:flex;justify-content:center;align-items:center;gap:22px;
  margin:52px 0 36px;padding:0 8px;
}
.sbtn{
  width:62px;height:62px;border-radius:50%;border:none;background:#fff;
  box-shadow:var(--shadow-soft);font-size:25px;cursor:pointer;display:grid;place-items:center;
  transition:transform .12s ease, box-shadow .12s ease;
  -webkit-tap-highlight-color:transparent;touch-action:manipulation;
}
.sbtn:hover{transform:translateY(-3px)}
.sbtn:active{transform:scale(.92)}
.sbtn.nope{color:var(--error)}
.sbtn.like{
  color:#fff;background:var(--primary);width:72px;height:72px;font-size:28px;
  position:relative;overflow:visible;isolation:isolate;
  box-shadow:0 14px 34px -18px rgba(255,96,26,.42);
}
.sbtn.like.is-cta{animation:swipeBreath 2.6s cubic-bezier(.45,0,.55,1) infinite}
.sbtn.like.is-cta::before{
  content:"";position:absolute;inset:-10px;border-radius:50%;z-index:-1;
  background:radial-gradient(circle,rgba(255,96,26,.28) 0%,rgba(255,96,26,0) 68%);
  animation:swipeHalo 2.6s cubic-bezier(.45,0,.55,1) infinite;
  pointer-events:none;
}
.sbtn.like.is-cta::after{
  content:"";position:absolute;inset:0;border-radius:50%;
  box-shadow:0 0 0 0 rgba(255,255,255,.35);
  animation:swipeRipple 2.6s cubic-bezier(.45,0,.55,1) infinite;
  pointer-events:none;
}
.sbtn__icon{
  display:inline-block;line-height:1;font-weight:800;font-size:1.15em;
  transition:transform .35s cubic-bezier(.34,1.3,.64,1);
}
.sbtn.like.is-cta:hover{
  animation:none;transform:translateY(-2px) scale(1.07);
  box-shadow:0 22px 44px -14px rgba(255,96,26,.58);
}
.sbtn.like.is-cta:hover::before,.sbtn.like.is-cta:hover::after{animation:none;opacity:0}
.sbtn.like.is-cta:hover .sbtn__icon{transform:scale(1.08)}
.sbtn.like:active .sbtn__icon{transform:scale(.94)}
@keyframes swipeBreath{
  0%,100%{transform:scale(1);box-shadow:0 14px 34px -18px rgba(255,96,26,.38)}
  50%{transform:scale(1.055);box-shadow:0 22px 42px -14px rgba(255,96,26,.52)}
}
@keyframes swipeHalo{
  0%,100%{opacity:.45;transform:scale(.96)}
  50%{opacity:.9;transform:scale(1.06)}
}
@keyframes swipeRipple{
  0%,100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}
  45%,55%{box-shadow:0 0 0 7px rgba(255,255,255,.14)}
}
.sbtn .lbl{display:none}

.swipe-note{
  text-align:center;color:var(--muted-dark);font-size:var(--text-sm);
  line-height:var(--leading-relaxed);max-width:42ch;margin:-24px auto 0;padding:0 12px;
  text-wrap:pretty;
}
.swipe-note b{color:var(--ink);font-weight:700}

/* striscia testimonianza alta */
.quote-strip{
  margin-top:8px;padding:20px 22px;text-align:center;
  background:var(--card);border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow-soft);
}
.quote-strip p{
  margin:0 auto;font-size:var(--text-base);font-style:italic;color:var(--body);
  line-height:var(--leading-relaxed);max-width:var(--measure);text-wrap:pretty;
}
.quote-strip .who{
  margin-top:12px;font-size:var(--text-sm);font-weight:600;color:var(--muted);font-style:normal;
}

/* ── Match reveal ── */
.match{
  position:absolute;left:var(--card-gutter, 16px);right:var(--card-gutter, 16px);
  top:0;bottom:0;height:auto;
  z-index:6;border-radius:var(--radius);overflow:hidden;
  background:var(--brand-gradient);color:#fff;display:none;
  flex-direction:column;align-items:center;justify-content:flex-start;text-align:center;
  padding:clamp(22px,5.5vw,34px) clamp(18px,4.5vw,28px) clamp(26px,6vw,38px);
  box-shadow:var(--shadow);
}
.match.show{display:flex;animation:pop .45s cubic-bezier(.2,.9,.3,1.2)}
@keyframes pop{from{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}
.match h2{
  font-size:clamp(20px,5.2vw,28px);font-weight:700;line-height:var(--leading-tight);
  margin:clamp(8px,2vw,12px) 0 0;
}
.match .big{
  font-family:var(--font-display);font-weight:700;font-style:italic;
  font-size:clamp(30px,8vw,46px);line-height:1.05;margin:0;
}
.match p{
  margin:clamp(10px,2.5vw,14px) 0 0;font-size:clamp(14px,3.6vw,17px);
  max-width:32ch;opacity:.95;line-height:var(--leading-snug);text-wrap:pretty;
}
.match .wa{
  margin-top:auto;padding-top:clamp(14px,3.5vw,22px);
  width:100%;display:flex;justify-content:center;
}
.match .wa-btn{
  width:auto;max-width:100%;padding:13px 22px;
  font-size:clamp(14px,3.5vw,17px);white-space:nowrap;gap:9px;
}
.match .wa-btn svg{width:20px;height:20px;flex:none}

.heart-burst{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.heart-burst span{position:absolute;bottom:30%;font-size:26px;animation:floatUp 1.1s ease-out forwards}
@keyframes floatUp{to{transform:translateY(-260px) rotate(40deg);opacity:0}}

/* ── Section scaffolding ── */
.section{margin-top:48px;scroll-margin-top:72px}
.section > .kicker{
  text-align:center;color:var(--primary);font-weight:700;font-size:var(--text-sm);
  text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;line-height:var(--leading-snug);
}
.section > h2{
  text-align:center;font-size:clamp(26px,7vw,34px);font-weight:700;
  margin:0 auto 10px;padding:0 12px;color:var(--ink);
  max-width:28ch;line-height:var(--leading-tight);
}
.section > .lead{
  text-align:center;color:var(--muted-dark);font-size:var(--text-base);
  max-width:var(--measure);margin:0 auto 24px;
  line-height:var(--leading-relaxed);text-wrap:pretty;
}
.section-block{margin-top:20px}

/* steps */
.steps{display:grid;gap:12px}
.step{
  background:var(--card);border:1px solid var(--line);border-radius:18px;
  padding:16px 18px;display:flex;gap:14px;align-items:flex-start;box-shadow:var(--shadow-soft);
}
.step .n{
  flex:none;width:38px;height:38px;border-radius:50%;background:var(--primary);color:#fff;
  font-family:var(--font-body);font-weight:700;display:grid;place-items:center;font-size:var(--text-base);
}
.step .t{font-weight:700;font-family:var(--font-body);font-size:var(--text-md);line-height:var(--leading-snug)}
.step .d{color:var(--muted);font-size:var(--text-base);margin-top:5px;line-height:var(--leading-relaxed)}

/* story */
.story{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:26px 24px;box-shadow:var(--shadow-soft)}
.story h2{font-size:var(--text-xl);margin-bottom:16px;color:var(--ink);line-height:var(--leading-tight);text-wrap:balance}
.story p{color:var(--body);font-size:var(--text-base);margin-bottom:16px;line-height:var(--leading-relaxed);text-wrap:pretty}
.story p:last-child{margin-bottom:0}
.story .punch{
  font-family:var(--font-display);font-weight:700;font-style:italic;font-size:var(--text-xl);
  color:var(--primary);display:block;line-height:var(--leading-snug);text-wrap:balance;
}
.story-photo{border-radius:18px;overflow:hidden;margin-bottom:18px;box-shadow:var(--shadow-soft)}
.story-photo picture{display:block}
.story-photo img{width:100%;height:auto;display:block;aspect-ratio:16/10;object-fit:cover}
.story-duo{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:18px 0}
.story-duo--triple{grid-template-columns:repeat(3,1fr)}
.story-duo picture{display:block;overflow:hidden;border-radius:14px}
.story-duo img{width:100%;height:140px;object-fit:cover;border-radius:14px;display:block}

/* map */
.map-card{
  background:var(--card);border:1px solid var(--line);border-radius:22px;
  padding:18px;box-shadow:var(--shadow-soft);overflow:hidden;
}
.map-embed{
  position:relative;border-radius:16px;overflow:hidden;
  border:1px solid var(--line);background:var(--secondary-bg);
  aspect-ratio:16/11;
  min-height:200px;
}
.map-embed::before{
  content:"";display:block;padding-top:68.75%;
}
.map-embed iframe{
  position:absolute;inset:0;width:100%;height:100%;border:0;display:block;
}
@supports (aspect-ratio:16/11){
  .map-embed::before{display:none}
  .map-embed{min-height:0}
}
.map-link{
  display:inline-flex;align-items:center;gap:4px;margin:12px 0 18px;
  font-size:var(--text-sm);font-weight:600;color:var(--primary);text-decoration:none;
}
.map-link:hover{text-decoration:underline}
.map-route{
  list-style:none;margin:0;padding:0;display:grid;gap:10px;
  counter-reset:map-stop;
}
.map-stop{
  display:flex;gap:14px;align-items:flex-start;
  background:var(--primary-bg);border:1px solid var(--line);border-radius:16px;
  padding:14px 16px;
}
.map-stop--highlight{
  border-color:rgba(255,96,26,.28);
  box-shadow:0 0 0 3px rgba(255,96,26,.08);
}
.map-stop__icon{
  flex:none;width:40px;height:40px;border-radius:12px;
  background:var(--card);display:grid;place-items:center;font-size:20px;
  box-shadow:var(--shadow-soft);
}
.map-stop__day{
  display:block;font-size:var(--text-xs);font-weight:700;text-transform:uppercase;
  letter-spacing:.05em;color:var(--primary);margin-bottom:3px;
}
.map-stop__title{
  display:block;font-family:var(--font-body);font-weight:700;font-size:var(--text-base);
  color:var(--ink);margin-bottom:3px;
}
.map-stop__desc{display:block;font-size:var(--text-sm);color:var(--muted);line-height:var(--leading-relaxed)}

.section--reels .lead{margin-bottom:28px}
.reels-stage{
  display:flex;justify-content:center;
  padding:0 8px;
}
.reels-wrap{
  width:min(100%,300px);
  aspect-ratio:9/16;
  border-radius:28px;overflow:hidden;
  background:#0a1628;
  box-shadow:0 24px 48px -16px rgba(10,22,40,.35),0 0 0 1px var(--line);
  position:relative;
}
.reels-wrap::after{
  content:"";position:absolute;inset:0;border-radius:inherit;
  pointer-events:none;z-index:4;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);
}
.reels-video{
  width:100%;height:100%;
  display:block;object-fit:cover;object-position:center;
}
.reels-ui{
  position:absolute;left:0;right:0;bottom:0;z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:28px 14px 12px;
  pointer-events:none;
}
.reels-wrap.is-ui-open .reels-ui,
.reels-wrap:hover .reels-ui,
.reels-wrap.is-paused .reels-ui{
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.55));
}
.reels-progress{
  width:100%;pointer-events:none;
}
.reels-progress__bar{
  display:block;height:3px;border-radius:999px;
  background:rgba(255,255,255,.35);overflow:hidden;
}
.reels-progress__fill{
  display:block;height:100%;width:0;
  background:#fff;border-radius:inherit;
}
.reels-btn{
  pointer-events:auto;
  display:flex;align-items:center;justify-content:center;
  border:0;padding:0;cursor:pointer;
  background:rgba(255,255,255,.18);color:#fff;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  transition:opacity .2s,visibility .2s,transform .15s,background .15s;
  -webkit-tap-highlight-color:transparent;
  opacity:0;visibility:hidden;
}
.reels-wrap:hover .reels-btn,
.reels-wrap.is-ui-open .reels-btn,
.reels-wrap.is-paused .reels-btn{
  opacity:1;visibility:visible;
}
.reels-btn:focus-visible{opacity:1;visibility:visible;outline:2px solid #fff;outline-offset:2px}
.reels-btn:active{transform:scale(.92)}
.reels-btn--play{
  width:48px;height:48px;border-radius:50%;
  box-shadow:0 4px 16px rgba(0,0,0,.25);
}
.reels-icon{width:22px;height:22px;fill:currentColor;display:block}
.reels-icon--play{display:none}
.reels-wrap.is-paused .reels-icon--pause{display:none}
.reels-wrap.is-paused .reels-icon--play{display:block}

/* momenti — layout editoriale foto grandi */
.momenti-layout{
  display:flex;flex-direction:column;gap:14px;
  margin:4px -8px 0;
}
.momenti-layout picture{
  display:block;overflow:hidden;
  border-radius:22px;box-shadow:var(--shadow-soft);
}
.momenti-layout img{
  width:100%;display:block;object-fit:cover;
}
.momenti-layout__hero img{
  aspect-ratio:16/10;min-height:240px;
}
.momenti-layout__duo{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start;
}
.momenti-layout__duo img{
  aspect-ratio:4/5;min-height:220px;
}
.momenti-layout__duo picture:last-child{margin-top:28px}

.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.gallery picture{display:block;overflow:hidden;border-radius:16px;box-shadow:var(--shadow-soft)}
.gallery img{
  width:100%;height:130px;max-width:none;object-fit:cover;display:block;
}
.gallery picture.wide{grid-column:span 2}
.gallery picture.wide img{height:170px}
.gallery--story{margin:18px 0 14px}

.group-photo{border-radius:18px;overflow:hidden;margin-bottom:16px;box-shadow:var(--shadow-soft)}
.group-photo picture{display:block}
.group-photo img{width:100%;height:auto;display:block;aspect-ratio:16/9;object-fit:cover}

/* dates */
.price-banner{
  text-align:center;background:var(--secondary-bg);border:1px solid rgba(37,201,186,.28);
  border-radius:16px;padding:16px 20px;font-size:var(--text-base);color:var(--secondary-dark);
  font-weight:500;margin-bottom:18px;line-height:var(--leading-relaxed);text-wrap:pretty;
}
.price-banner b{color:var(--ink);font-weight:700}
.dates{display:grid;gap:10px}
.date{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:var(--card);border:1.5px solid var(--line);border-radius:16px;
  padding:13px 16px;cursor:pointer;text-align:left;width:100%;font:inherit;
  transition:border-color .15s,box-shadow .15s,transform .1s;
  -webkit-tap-highlight-color:transparent;touch-action:manipulation;
}
.date .left{min-width:0;flex:1}
.date:hover{transform:translateY(-2px)}
.date[aria-pressed="true"]{border-color:var(--primary);box-shadow:0 0 0 3px rgba(255,96,26,.14)}
.date .when{font-weight:500;font-size:var(--text-base);color:var(--ink)}
.date .nights{color:var(--muted);font-size:var(--text-sm);margin-top:2px}
.date .right{text-align:right;flex:none}
.date .price{font-family:var(--font-body);font-weight:700;font-size:var(--text-lg);color:var(--primary)}
.date .best{display:inline-block;font-size:var(--text-xs);font-weight:700;color:var(--success);
  background:var(--success-bg);padding:2px 8px;border-radius:999px;margin-top:3px}

/* testimonials as chat bubbles */
.chat{display:grid;gap:14px}
.bubble{background:var(--card);border:1px solid var(--line);border-radius:18px 18px 18px 6px;
  padding:14px 16px;box-shadow:var(--shadow-soft);max-width:92%}
.bubble .stars{color:#E5B12B;font-size:var(--text-base);letter-spacing:2px}
.bubble .txt{font-size:var(--text-base);margin:8px 0 10px;color:var(--body);line-height:var(--leading-relaxed);text-wrap:pretty}
.bubble .who{font-size:var(--text-sm);color:var(--muted);font-weight:500}
.bubble--right{margin-left:auto;border-radius:18px 18px 6px 18px}
.reviews-lead{margin:-8px auto 20px;text-align:center}
.reviews-lead a{color:var(--primary);font-weight:600;text-decoration:none}
.reviews-lead a:hover{text-decoration:underline;text-underline-offset:2px}

/* social proof */
.proof{text-align:center;background:var(--primary);color:#fff;border-radius:22px;padding:28px 22px;box-shadow:var(--shadow)}
.proof .num{font-family:var(--font-body);font-weight:700;font-size:44px;line-height:1}
.proof .lbl{font-size:var(--text-base);opacity:.95;margin-top:8px;line-height:var(--leading-snug)}
.proof .sub{
  font-family:var(--font-display);font-weight:700;font-style:italic;font-size:var(--text-xl);
  margin-top:12px;line-height:var(--leading-snug);max-width:var(--measure-narrow);margin-left:auto;margin-right:auto;
  text-wrap:balance;
}

/* final CTA */
.final{text-align:center;background:var(--card);border:1px solid var(--line);border-radius:24px;
  padding:28px 22px;box-shadow:var(--shadow-soft)}
.final-closer{
  font-family:var(--font-display);font-weight:700;font-style:italic;
  font-size:clamp(19px,5vw,22px);color:var(--primary);
  margin:0 auto 16px;max-width:var(--measure);line-height:var(--leading-snug);text-wrap:balance;
}
.final h2{font-size:var(--text-2xl);margin-bottom:12px;color:var(--ink);line-height:var(--leading-tight)}
.final-sub{
  color:var(--muted);font-size:var(--text-base);max-width:var(--measure-narrow);
  margin:0 auto;line-height:var(--leading-relaxed);text-wrap:pretty;
}
.final .resure{display:flex;flex-wrap:wrap;justify-content:center;gap:16px;color:var(--muted);font-size:var(--text-sm);font-weight:500;margin:18px 0 24px;line-height:var(--leading-snug)}
.final .resure span{display:inline-flex;align-items:center;gap:6px}

/* WhatsApp button */
.wa-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  background:var(--wa);color:#fff;font-family:var(--font-body);font-weight:700;font-size:var(--text-md);
  padding:18px 28px;border-radius:999px;text-decoration:none;
  box-shadow:0 12px 26px -10px rgba(37,211,102,.7);transition:transform .12s,box-shadow .12s;width:100%;max-width:340px;
}
.wa-btn:hover{transform:translateY(-2px);box-shadow:0 16px 30px -10px rgba(37,211,102,.8)}
.wa-btn:active{transform:scale(.98)}
.wa-btn svg{width:22px;height:22px;fill:#fff}
.match .wa-btn{background:#fff;color:var(--ink)}
.match .wa-btn svg{fill:var(--wa-dark)}

/* sticky bottom bar (mobile) */
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:50;
  background:rgba(255,241,235,.96);
  -webkit-backdrop-filter:blur(10px);
  backdrop-filter:blur(10px);
  border-top:1px solid var(--line);
  padding:10px max(16px, env(safe-area-inset-right)) calc(10px + env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-left));
  display:flex;justify-content:center;
  transform:translateY(120%);transition:transform .3s ease;
  pointer-events:none;
}
@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  .sticky-cta{background:rgba(255,241,235,.98)}
}
.sticky-cta.show{transform:translateY(0);pointer-events:auto}

/* footer */
.site-footer{
  margin-top:46px;
  padding:32px max(18px, env(safe-area-inset-right)) calc(32px + env(safe-area-inset-bottom)) max(18px, env(safe-area-inset-left));
  background:var(--card);border-top:1px solid var(--line);
  color:var(--muted);font-size:12px;line-height:1.5;
  scroll-margin-bottom:96px;
}
.site-footer__inner{max-width:960px;margin:0 auto}
.site-footer__top{
  display:flex;align-items:center;justify-content:flex-end;
  margin-bottom:20px;
}
.site-footer__links{
  display:flex;flex-wrap:wrap;align-items:center;gap:10px 22px;
  margin:0 0 18px;font-size:13px;line-height:1.4;
}
.site-footer__links a{
  color:var(--muted);text-decoration:none;white-space:nowrap;
  transition:color .15s;
}
.site-footer__links a:hover{color:var(--primary)}
.site-footer__nav{
  display:flex;flex-wrap:wrap;align-items:center;gap:6px;
  font-size:12px;color:var(--muted);
}
.site-footer__nav a{
  color:var(--muted);text-decoration:none;transition:color .15s;
}
.site-footer__nav a:hover{color:var(--primary)}
.site-footer__dot{
  width:2px;height:2px;border-radius:50%;background:var(--muted);flex:none;
}
.site-footer__manifesto{
  display:block;height:53px;width:auto;max-width:100%;
  border-radius:4px;box-shadow:1px 1px 2px rgba(0,0,0,.06);
}
.site-footer__legal{
  margin:0;font-size:12px;line-height:1.55;color:var(--muted);text-wrap:pretty;
}
.site-footer__legal a{color:inherit;text-decoration:underline;text-underline-offset:2px}
.site-footer__legal a:hover{color:var(--primary)}
.site-footer__payments{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:12px;margin-top:40px;padding-bottom:8px;
  text-align:center;color:var(--muted);font-size:12px;
}
.site-footer__payments img{display:block;height:29px;width:auto;max-width:100%}

@media (min-width:768px){
  .site-footer{padding:32px 24px calc(48px + env(safe-area-inset-bottom))}
  .site-footer__links{font-size:14px;gap:12px 28px;margin-bottom:22px}
  .site-footer__payments{
    flex-direction:row;gap:16px;font-size:14px;
  }
  .site-footer__payments img{height:20px}
}

/* date status + rate + interest */
.date .right{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex:none}
.date.sold{opacity:.5;cursor:not-allowed}
.date.sold:hover{transform:none}
.date .rate{color:var(--muted);font-size:var(--text-xs)}
.date .interest{display:flex;align-items:center;gap:5px;color:var(--primary);font-size:var(--text-sm);font-weight:700;margin-top:5px}
.status{font-size:var(--text-xs);font-weight:700;padding:3px 10px;border-radius:999px}
.status.avail{color:var(--secondary-dark);background:var(--secondary-bg)}
.status.confirmed{color:var(--success);background:var(--success-bg)}
.status.sold{color:var(--error);background:var(--error-bg)}

/* host / accompagnatore */
.host{display:flex;gap:16px;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:22px;padding:18px 20px;box-shadow:var(--shadow-soft)}
.host .avatar{flex:none;width:88px;height:88px;border-radius:50%;overflow:hidden;background:var(--primary-bg);box-shadow:var(--shadow-soft)}
.host .avatar img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.host .role{color:var(--primary);font-size:var(--text-sm);font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.host .name{font-family:var(--font-body);font-weight:700;font-size:var(--text-lg);margin:2px 0 10px;color:var(--ink)}
.host-bio{margin:0 0 12px;font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--body);text-wrap:pretty}
.host-location{font-size:var(--text-sm);font-weight:600;color:var(--muted-dark);margin-bottom:10px;line-height:var(--leading-snug)}
.host .motto{font-family:var(--font-display);font-weight:700;font-style:italic;font-size:var(--text-md);color:var(--ink);margin-top:6px;line-height:var(--leading-snug)}
.host-note{text-align:center;color:var(--muted);font-size:var(--text-sm);margin-top:14px;line-height:var(--leading-relaxed);max-width:var(--measure-narrow);margin-left:auto;margin-right:auto}

/* group block */
.group{background:var(--primary);color:#fff;border-radius:22px;padding:26px 24px;box-shadow:var(--shadow)}
.group--spaced{margin-top:20px}
.group .row{display:flex;gap:14px;align-items:flex-start;margin-bottom:16px;font-size:var(--text-base);line-height:var(--leading-relaxed)}
.group .row:last-child{margin-bottom:0}
.group .row span:last-child{text-wrap:pretty}
.group .ico{flex:none;font-size:24px;line-height:1.35;margin-top:2px}

/* risk reversal */
.risk{display:grid;gap:12px}
.risk .item{display:flex;gap:14px;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:17px 19px;box-shadow:var(--shadow-soft)}
.risk .ico{flex:none;width:44px;height:44px;border-radius:13px;background:var(--success-bg);display:grid;place-items:center;font-size:22px}
.risk .t{font-weight:700;font-family:var(--font-body);font-size:var(--text-base);color:var(--ink);line-height:var(--leading-snug)}
.risk .d{color:var(--muted);font-size:var(--text-sm);margin-top:5px;line-height:var(--leading-relaxed)}

:focus-visible{outline:3px solid var(--primary);outline-offset:2px;border-radius:8px}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto}
  .card{will-change:auto}
  .sbtn.like.is-cta{box-shadow:0 0 0 3px rgba(255,96,26,.28),0 14px 34px -18px rgba(255,96,26,.38)}
}

/* ── Mobile & small screens ── */
@media (max-width:479px){
  .swipe-wrap{--card-tags:148px}
  .card .tags{padding:14px 16px 16px;gap:7px}
  .card .veil{padding:48px 16px 16px}
  .card .veil .meta{flex-wrap:wrap}
  .swipe-actions{gap:18px;margin-top:44px}
  .sbtn{width:58px;height:58px;font-size:24px}
  .sbtn.like{width:68px;height:68px;font-size:28px}
  .story-duo img{height:120px}
  .story-duo--triple img{height:110px}
  .gallery img{height:115px}
  .gallery picture.wide img{height:150px}
  .momenti-layout__hero img{min-height:200px}
  .momenti-layout__duo img{min-height:180px}
  .momenti-layout__duo picture:last-child{margin-top:20px}
  .final{padding:26px 20px}
  .proof .num{font-size:40px}
  .host .avatar{width:80px;height:80px}
}

@media (max-width:380px){
  .date{
    flex-direction:column;align-items:flex-start;gap:10px;
  }
  .date .right{
    width:100%;flex-direction:row;flex-wrap:wrap;align-items:center;
    justify-content:space-between;text-align:left;
  }
  .story-duo{grid-template-columns:1fr}
  .story-duo--triple{grid-template-columns:1fr}
  .story-duo img{height:auto;aspect-ratio:16/10}
  .map-stop{gap:10px;padding:12px 14px}
}

@media (max-width:359px){
  .hero h1{font-size:32px}
  .pills{gap:8px}
  .topbar{font-size:var(--text-sm);padding-left:12px;padding-right:12px}
}

@media (min-width:560px){
  .swipe-wrap{
    --card-gutter:24px;
    --card-max:440px;
    padding-left:14px;padding-right:24px;
  }
  .swipe-wrap::after{padding-bottom:var(--card-tags, 124px)}
  .swipe-actions{margin-top:56px}
}

/* ── Desktop: tipografia più grande ── */
@media (min-width:768px){
  :root{
    --text-xs:14px;
    --text-sm:17px;
    --text-base:19px;
    --text-md:21px;
    --text-lg:24px;
    --text-xl:28px;
    --text-2xl:32px;
    --text-3xl:40px;
    --measure:44ch;
    --measure-narrow:38ch;
    --measure-wide:50ch;
  }

  .shell{max-width:720px;padding-left:28px;padding-right:28px}

  .swipe-wrap{--card-max:460px;padding-right:26px}

  .topbar{font-size:var(--text-base);padding-top:calc(11px + env(safe-area-inset-top));padding-bottom:11px}

  .hero h1{font-size:clamp(40px,4.2vw,52px);max-width:18ch}
  .hero-lead{max-width:42ch}
  .sub--note{max-width:36ch}

  .section > h2{font-size:clamp(30px,3.2vw,38px);max-width:36ch}
  .section > .lead{max-width:42ch}

  .story h2{font-size:var(--text-2xl)}
  .story .punch{font-size:var(--text-2xl)}

  .match{padding:clamp(26px,4vw,38px) clamp(22px,3.5vw,32px) clamp(30px,4.5vw,42px)}
  .match .big{font-size:clamp(36px,4.5vw,52px)}
  .match h2{font-size:clamp(22px,2.5vw,30px)}
  .match p{font-size:var(--text-base);max-width:36ch}
  .match .wa-btn{font-size:var(--text-base);padding:14px 24px}

  .card .veil .title{font-size:clamp(24px,2.5vw,30px)}

  .card{
    transition:transform .52s cubic-bezier(.22,1,.36,1), opacity .52s ease, filter .52s ease, box-shadow .52s ease;
  }
  .card.gone-right,
  .card.gone-left{
    transition:transform .65s cubic-bezier(.22,.68,.32,1), opacity .55s ease;
  }
  .swipe-wrap:not(.is-dragging) .card--stack.card--next{
    animation:stackFlutterNextDesktop 4s cubic-bezier(.45,0,.55,1) infinite;
  }
  .swipe-wrap:not(.is-dragging) .card--stack.card--deep{
    animation:stackFlutterDeepDesktop 4s cubic-bezier(.45,0,.55,1) infinite;
    animation-delay:.6s;
  }
  .stamp{transition:opacity .24s cubic-bezier(.22,1,.36,1)}

  .proof .num{font-size:52px}
  .proof .sub{font-size:var(--text-2xl)}

  .final h2{font-size:var(--text-3xl)}
  .final-closer{font-size:clamp(21px,2vw,24px);max-width:42ch}

  .wa-btn{font-size:var(--text-lg);padding:20px 32px;max-width:380px}
  .wa-btn svg{width:24px;height:24px}

  .date{padding:16px 20px}
  .date .price{font-size:var(--text-xl)}

  .host .avatar{width:96px;height:96px}

  .reels-wrap{width:min(100%,340px)}

  .momenti-layout{margin-left:0;margin-right:0;gap:16px}
  .momenti-layout__hero img{min-height:280px}
  .momenti-layout__duo{gap:16px}
  .momenti-layout__duo img{min-height:260px}
  .momenti-layout__duo picture:last-child{margin-top:36px}
  .host .name{font-size:var(--text-xl)}

  .step{padding:18px 22px}
  .bubble{padding:18px 20px;max-width:94%}

  .quote-strip{padding:20px 24px}
}

@media (min-width:1024px){
  :root{
    --measure:48ch;
    --measure-narrow:40ch;
    --measure-wide:54ch;
  }

  .shell{max-width:880px;padding-left:32px;padding-right:32px}
  .topbar-inner{max-width:880px}

  .hero h1{max-width:20ch}
  .hero-lead{max-width:46ch}
  .sub--note{max-width:40ch}

  .section > h2{max-width:40ch}
  .section > .lead{max-width:46ch}

  .story-duo img{height:180px}
  .story-duo--triple img{height:200px}
  .gallery img{height:160px}
  .gallery picture.wide img{height:220px}

  .momenti-layout__hero img{min-height:320px}
  .momenti-layout__duo img{min-height:280px}

  .reels-wrap{width:min(100%,380px)}

  .swipe-wrap{--card-max:480px;padding-right:28px}
}
