/* =====================================================================
   THREE PUNTO ZERO — Design System
   Fonts: Visby (UI), The Seasons (display), Cormorant Garamond (accent)
   Palette: off-white / cream / warm taupe / grey / black  (neutral B&W brand)
   All colours are CSS variables — adjust here to retune the whole site.
   ===================================================================== */

/* ----- Brand fonts -------------------------------------------------- */
/* Cormorant Garamond + Poppins (Visby fallback) loaded from Google.
   Visby + The Seasons are licensed fonts: drop the files into /fonts and
   the @font-face rules below will pick them up automatically.            */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Poppins:wght@200;300;400;500;600&display=swap');

@font-face{
  font-family:'Visby';
  src:url('../fonts/VisbyCF-Medium.woff2') format('woff2'),
      url('../fonts/VisbyCF-Medium.woff')  format('woff');
  font-weight:500; font-style:normal; font-display:swap;
}
@font-face{
  font-family:'Visby';
  src:url('../fonts/VisbyCF-DemiBold.woff2') format('woff2'),
      url('../fonts/VisbyCF-DemiBold.woff')  format('woff');
  font-weight:600; font-style:normal; font-display:swap;
}
@font-face{
  font-family:'Visby';
  src:url('../fonts/VisbyCF-Light.woff2') format('woff2'),
      url('../fonts/VisbyCF-Light.woff')  format('woff');
  font-weight:300; font-style:normal; font-display:swap;
}
@font-face{
  font-family:'The Seasons';
  src:url('../fonts/TheSeasons-Regular.woff2') format('woff2'),
      url('../fonts/TheSeasons-Regular.woff')  format('woff');
  font-weight:400; font-style:normal; font-display:swap;
}
@font-face{
  font-family:'The Seasons';
  src:url('../fonts/TheSeasons-Light.woff2') format('woff2'),
      url('../fonts/TheSeasons-Light.woff')  format('woff');
  font-weight:300; font-style:normal; font-display:swap;
}

/* ----- Variables ---------------------------------------------------- */
:root{
  /* palette — neutral B&W editorial
     #f1f0ec off-white · #ede6db cream · #d8cfc2 taupe · #9b9b9b grey · #000 black */
  --ink:#000000;          /* black — text / dark navbar / dark sections */
  --ink-soft:#1a1a1a;     /* near-black (subtle hover variation) */
  --cream:#f1f0ec;        /* main light background / text on dark */
  --cream-2:#ede6db;      /* alt section background */
  --sand:#d8cfc2;         /* warm taupe — brand neutral */
  --gold:#000000;         /* primary accent on LIGHT backgrounds = black */
  --gold-deep:#000000;    /* accent (kept = black) */
  --gold-soft:#d8cfc2;    /* accent on DARK backgrounds = warm taupe */
  --sage:#161616;         /* secondary dark section (near-black) */
  --sage-soft:#9b9b9b;    /* grey */
  --text:#000000;         /* body text */
  --muted:#9b9b9b;        /* muted text = grey */
  --line:rgba(0,0,0,.14);
  --white:#ffffff;

  /* type */
  --font-sans:'Visby','Poppins',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-display:'The Seasons','Cormorant Garamond',Georgia,serif;
  --font-serif:'Cormorant Garamond',Georgia,serif;

  /* layout */
  --maxw:1240px;
  --gut:clamp(20px,5vw,80px);
  --radius:14px;
  --radius-lg:26px;
  --shadow:0 18px 50px -22px rgba(0,0,0,.32);
  --shadow-soft:0 12px 40px -18px rgba(0,0,0,.20);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ----- Reset -------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-sans);
  font-weight:300;
  color:var(--text);
  background:var(--cream);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}

/* ----- Typography --------------------------------------------------- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:400;line-height:1.08;letter-spacing:.005em}
.display{font-size:clamp(2.6rem,6.5vw,5.6rem);font-weight:300;line-height:1.02}
h2.section-title{font-size:clamp(2rem,4.4vw,3.5rem)}
h3{font-size:clamp(1.4rem,2.3vw,2rem)}
p{max-width:68ch}
em,.italic{font-family:var(--font-serif);font-style:italic;font-size:1.06em}

.eyebrow{
  font-family:var(--font-sans);font-weight:500;text-transform:uppercase;
  letter-spacing:.32em;font-size:.72rem;color:var(--ink);
  display:inline-flex;align-items:center;gap:.7em;margin-bottom:1.1rem;
}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--ink)}
.eyebrow.center::after{content:"";width:34px;height:1px;background:var(--ink)}
/* eyebrows on dark backgrounds use the warm taupe accent */
.bg-ink .eyebrow,.bg-sage .eyebrow,.hero .eyebrow,.page-hero .eyebrow,
.mission .eyebrow,.form-side .eyebrow,.three-band .eyebrow{color:var(--gold-soft)}
.bg-ink .eyebrow::before,.bg-ink .eyebrow::after,
.bg-sage .eyebrow::before,.bg-sage .eyebrow::after,
.hero .eyebrow::before,.hero .eyebrow::after,
.page-hero .eyebrow::before,.page-hero .eyebrow::after,
.mission .eyebrow::before,.mission .eyebrow::after,
.form-side .eyebrow::before,.form-side .eyebrow::after,
.three-band .eyebrow::before,.three-band .eyebrow::after{background:var(--gold-soft)}
.lead{font-size:clamp(1.05rem,1.5vw,1.28rem);color:var(--muted);font-weight:300}

/* ----- Layout ------------------------------------------------------- */
.container{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
section{position:relative}
.section{padding:clamp(72px,11vw,150px) 0}
.section.tight{padding:clamp(54px,7vw,90px) 0}
.bg-cream{background:var(--cream)}
.bg-cream2{background:var(--cream-2)}
.bg-ink{background:var(--ink);color:var(--cream)}
.bg-sage{background:var(--sage);color:var(--cream)}
.center{text-align:center}
.center .eyebrow{justify-content:center}
.grid{display:grid;gap:clamp(20px,3vw,40px)}
.muted{color:var(--muted)}

/* ----- Buttons ------------------------------------------------------ */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-sans);font-weight:500;font-size:.82rem;
  letter-spacing:.16em;text-transform:uppercase;
  padding:1.05em 2.1em;border-radius:100px;
  transition:all .45s var(--ease);position:relative;overflow:hidden;
}
.btn svg{width:16px;height:16px;transition:transform .45s var(--ease)}
/* primary button: black on light backgrounds, inverts to taupe on hover */
.btn-gold{background:var(--ink);color:var(--cream)}
.btn-gold:hover{background:var(--gold-soft);color:var(--ink);transform:translateY(-2px);box-shadow:0 14px 30px -14px rgba(0,0,0,.45)}
.btn-gold:hover svg{transform:translateX(4px)}
/* on dark sections the primary button is taupe with black text */
.hero .btn-gold,.page-hero .btn-gold,.bg-ink .btn-gold,.bg-sage .btn-gold,
.mission .btn-gold,.form-side .btn-gold,.three-band .btn-gold{background:var(--gold-soft);color:var(--ink)}
.hero .btn-gold:hover,.page-hero .btn-gold:hover,.bg-ink .btn-gold:hover,.bg-sage .btn-gold:hover,
.mission .btn-gold:hover,.form-side .btn-gold:hover,.three-band .btn-gold:hover{background:var(--cream);color:var(--ink)}
.btn-outline{border:1px solid currentColor;color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--cream);transform:translateY(-2px)}
.bg-ink .btn-outline,.bg-sage .btn-outline{color:var(--cream)}
.bg-ink .btn-outline:hover,.bg-sage .btn-outline:hover{background:var(--cream);color:var(--ink)}
.btn-light{background:var(--cream);color:var(--ink)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft)}

/* ----- Navbar ------------------------------------------------------- */
/* The scrolled bar is a deep brand tone (never white), so the
   light brand logo stays perfectly legible at all times.               */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:18px var(--gut);
  transition:background .5s var(--ease),padding .5s var(--ease),box-shadow .5s var(--ease);
}
.site-header::after{
  content:"";position:absolute;inset:0;z-index:-1;opacity:0;
  background:linear-gradient(180deg,rgba(0,0,0,.55),transparent);
  transition:opacity .5s var(--ease);
}
.site-header[data-state="top"]::after{opacity:1}
.site-header[data-state="scrolled"]{
  background:rgba(0,0,0,.92);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  padding-top:12px;padding-bottom:12px;
  box-shadow:0 10px 40px -20px rgba(0,0,0,.6);
}
.brand{display:flex;align-items:center;gap:12px;z-index:2}
.brand img{height:54px;width:auto;transition:height .5s var(--ease)}
.site-header[data-state="scrolled"] .brand img{height:44px}
.nav{display:flex;align-items:center;gap:38px}
.nav a{
  font-family:var(--font-sans);font-weight:400;font-size:.82rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--cream);
  position:relative;padding:6px 0;opacity:.9;transition:opacity .3s;
}
.nav a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold-soft);transition:width .4s var(--ease)}
.nav a:hover{opacity:1}.nav a:hover::after,.nav a.active::after{width:100%}
/* dropdown */
.nav .has-sub{position:relative}
.nav .submenu{
  position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(10px);
  background:rgba(0,0,0,.97);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  border:1px solid rgba(241,240,236,.14);border-radius:14px;padding:14px;min-width:240px;
  display:flex;flex-direction:column;gap:2px;opacity:0;pointer-events:none;transition:all .35s var(--ease);box-shadow:var(--shadow)}
.nav .has-sub:hover .submenu{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.nav .submenu a{padding:11px 14px;border-radius:9px;letter-spacing:.1em;font-size:.78rem;white-space:nowrap;transition:background .3s}
.nav .submenu a::after{display:none}
.nav .submenu a:hover{background:rgba(216,207,194,.18);opacity:1}
.nav .has-sub>a::before{content:"";position:absolute;left:0;right:0;top:100%;height:18px}
.nav-cta{display:flex;align-items:center;gap:18px}
.nav-social{display:flex;gap:12px}
.nav-social a{display:grid;place-items:center;width:34px;height:34px;border:1px solid rgba(241,240,236,.35);border-radius:50%;color:var(--cream);transition:all .35s}
.nav-social a:hover{background:var(--gold-soft);border-color:var(--gold-soft);color:var(--ink)}
.nav-social svg{width:15px;height:15px}
.nav-phone{
  display:inline-flex;align-items:center;gap:.55em;color:var(--cream);
  font-weight:500;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;
  border:1px solid var(--gold-soft);padding:.7em 1.3em;border-radius:100px;transition:all .35s;
}
.nav-phone:hover{background:var(--gold-soft);color:var(--ink)}
.burger{display:none;flex-direction:column;gap:5px;width:30px;z-index:5}
.burger span{height:2px;width:100%;background:var(--cream);transition:.4s var(--ease)}
.nav-overlay{display:none}

/* ----- Hero --------------------------------------------------------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;color:var(--cream);overflow:hidden}
.hero-media{position:absolute;inset:0;z-index:-2}
.hero-media img,.hero-media video{width:100%;height:100%;object-fit:cover}
.hero::before{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(105deg,rgba(0,0,0,.78) 0%,rgba(0,0,0,.45) 45%,rgba(0,0,0,.18) 100%)}
.hero-inner{padding-top:120px;max-width:880px}
.hero .display em{color:var(--gold-soft)}
.hero p{font-size:clamp(1.05rem,1.6vw,1.3rem);margin:1.6rem 0 2.4rem;color:rgba(241,240,236,.9)}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.scroll-cue{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;opacity:.7}
.scroll-cue span{width:1px;height:48px;background:linear-gradient(var(--gold-soft),transparent);animation:cue 2.4s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ----- 3D canvas band ----------------------------------------------- */
.three-band{position:relative;min-height:78vh;display:flex;align-items:center;background:var(--ink);color:var(--cream);overflow:hidden}
#three-canvas{position:absolute;inset:0;width:100%;height:100%;display:block}
.three-band .container{position:relative;z-index:2;pointer-events:none}
.three-band .quote{font-family:var(--font-display);font-weight:300;font-size:clamp(1.6rem,3.4vw,3rem);line-height:1.2;max-width:18ch}

/* ----- Service cards ------------------------------------------------ */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,28px)}
.svc{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;min-height:520px;
  display:flex;flex-direction:column;justify-content:flex-end;padding:34px;color:var(--cream);isolation:isolate;
}
.svc img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform 1.1s var(--ease)}
.svc::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(0,0,0,.05) 30%,rgba(0,0,0,.85) 100%)}
.svc:hover img{transform:scale(1.07)}
.svc .num{font-family:var(--font-serif);font-style:italic;font-size:1.1rem;color:var(--gold-soft);margin-bottom:auto}
.svc h3{font-size:1.7rem;margin-bottom:.5rem}
.svc p{font-size:.95rem;color:rgba(241,240,236,.82);margin-bottom:1.3rem}
.svc .go{display:inline-flex;align-items:center;gap:.6em;font-family:var(--font-sans);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cream)}
.svc .go svg{width:30px;height:30px;padding:7px;border:1px solid rgba(241,240,236,.5);border-radius:50%;transition:all .4s var(--ease)}
.svc:hover .go svg{background:var(--gold-soft);border-color:var(--gold-soft);color:var(--ink);transform:translateX(5px)}

/* ----- Split / image+text ------------------------------------------ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:center}
.split.reverse .split-media{order:2}
.split-media{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);position:relative}
.split-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.split-media.wide img{aspect-ratio:5/4}
.split-body h2{margin-bottom:1.2rem}
.split-body p+p{margin-top:1.1rem}
.split-body .btn{margin-top:1.8rem}

/* ----- Stats -------------------------------------------------------- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;text-align:center}
.stat .n{font-family:var(--font-display);font-size:clamp(2.6rem,5vw,4.2rem);color:var(--ink);line-height:1}
.bg-ink .stat .n,.bg-sage .stat .n{color:var(--gold-soft)}
.stat .l{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-top:.7rem}
.bg-ink .stat .l,.bg-sage .stat .l{color:rgba(241,240,236,.7)}

/* ----- Audience chips ----------------------------------------------- */
.chips{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:2rem}
.chip{border:1px solid var(--line);border-radius:100px;padding:.7em 1.5em;font-size:.82rem;letter-spacing:.08em;background:rgba(255,255,255,.4);transition:all .4s var(--ease)}
.chip:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);transform:translateY(-3px)}

/* ----- Mission band ------------------------------------------------- */
.mission{position:relative;min-height:80vh;display:flex;align-items:center;color:var(--cream);overflow:hidden}
.mission video,.mission img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.mission::after{content:"";position:absolute;inset:0;z-index:-1;background:rgba(0,0,0,.55)}
.mission blockquote{font-family:var(--font-display);font-weight:300;font-size:clamp(1.5rem,3.2vw,2.7rem);line-height:1.28;max-width:24ch}
.mission .mark{font-family:var(--font-serif);font-size:5rem;color:var(--gold-soft);line-height:.4;display:block;height:.5em}

/* ----- Testimonials marquee ----------------------------------------- */
.marquee{display:flex;gap:22px;width:max-content;animation:scrollx 60s linear infinite}
.marquee-wrap{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee img{height:210px;width:auto;border-radius:var(--radius);box-shadow:var(--shadow-soft);object-fit:cover}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ----- Instagram feed ----------------------------------------------- */
.ig-head{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:2.6rem}
.ig-handle{display:inline-flex;align-items:center;gap:.6em;font-weight:500;letter-spacing:.04em}
.ig-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.ig-cell{position:relative;aspect-ratio:1;border-radius:var(--radius);overflow:hidden;display:block;background:var(--cream-2)}
.ig-cell img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.ig-cell::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,0);transition:background .4s;display:grid;place-items:center}
.ig-cell:hover img{transform:scale(1.08)}
.ig-cell:hover::after{background:rgba(0,0,0,.35)}
.ig-cell .ig-ico{position:absolute;inset:0;display:grid;place-items:center;opacity:0;transition:opacity .4s;z-index:2;color:var(--cream)}
.ig-cell:hover .ig-ico{opacity:1}
.ig-embed-slot{margin-top:10px}

/* ----- Il Ricettivo ------------------------------------------------- */
.ricettivo-head{display:flex;align-items:center;gap:22px;flex-wrap:wrap;margin-bottom:2.4rem}
.ricettivo-head img.logo{height:74px;width:auto}
.articles{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.article{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-soft);transition:transform .5s var(--ease),box-shadow .5s var(--ease);display:flex;flex-direction:column}
.article:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.article-img{aspect-ratio:16/10;overflow:hidden}
.article-img img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.article:hover .article-img img{transform:scale(1.07)}
.article-body{padding:24px 26px 28px;display:flex;flex-direction:column;gap:.6rem;flex:1}
.article .tag{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink)}
.article h3{font-size:1.35rem}
.article .date{font-size:.76rem;color:var(--muted);margin-top:auto}

/* ----- Forms -------------------------------------------------------- */
.form-band{display:grid;grid-template-columns:1.05fr .95fr;gap:0;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.form-media{position:relative;min-height:100%}
.form-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.form-side{background:var(--ink);color:var(--cream);padding:clamp(34px,5vw,64px)}
.form-side .eyebrow{color:var(--gold-soft)}
.form-side h2{color:var(--cream);margin-bottom:1rem}
.quote-form{display:grid;gap:18px;margin-top:2rem}
.quote-form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{position:relative}
.field label{display:block;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(241,240,236,.6);margin-bottom:.5rem}
.field input,.field textarea{
  width:100%;background:transparent;border:none;border-bottom:1px solid rgba(241,240,236,.28);
  color:var(--cream);font-family:var(--font-sans);font-weight:300;font-size:1rem;padding:.6em 0;transition:border-color .4s;
}
.field textarea{resize:vertical;min-height:90px}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold-soft)}
.field input::placeholder,.field textarea::placeholder{color:rgba(241,240,236,.35)}
.quote-form .btn-gold{justify-self:start;margin-top:.5rem}
.form-note{font-size:.8rem;color:rgba(241,240,236,.55);margin-top:1rem}
.form-ok{display:none;background:rgba(216,207,194,.16);border:1px solid var(--gold-soft);border-radius:var(--radius);padding:1em 1.2em;color:var(--cream);font-size:.92rem}

/* ----- Page hero (interior) ----------------------------------------- */
.page-hero{position:relative;min-height:74vh;display:flex;align-items:flex-end;color:var(--cream);overflow:hidden}
.page-hero img.bg,.page-hero video.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.page-hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(0,0,0,.35),rgba(0,0,0,.8))}
.page-hero .container{padding-bottom:clamp(48px,7vw,90px);padding-top:140px}
.page-hero h1{font-size:clamp(2.6rem,6vw,5rem);font-weight:300}
.breadcrumb{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:1rem}

/* ----- Feature list ------------------------------------------------- */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:1rem}
.feature{background:rgba(255,255,255,.55);border:1px solid var(--line);border-radius:var(--radius-lg);padding:34px 30px;transition:transform .5s var(--ease),background .5s}
.bg-ink .feature,.bg-sage .feature{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.14)}
.feature:hover{transform:translateY(-6px);background:var(--white)}
.bg-ink .feature:hover,.bg-sage .feature:hover{background:rgba(255,255,255,.1)}
.feature .ico{width:52px;height:52px;display:grid;place-items:center;border-radius:50%;background:var(--ink);color:var(--cream);margin-bottom:1.2rem}
.bg-ink .feature .ico,.bg-sage .feature .ico{background:var(--gold-soft);color:var(--ink)}
.feature .ico svg{width:24px;height:24px}
.feature h3{font-size:1.3rem;margin-bottom:.5rem}
.feature p{font-size:.95rem;color:var(--muted)}
.bg-ink .feature p,.bg-sage .feature p{color:rgba(241,240,236,.72)}

/* ----- Steps -------------------------------------------------------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;counter-reset:s}
.step{position:relative;padding-top:54px}
.step::before{counter-increment:s;content:"0" counter(s);position:absolute;top:0;left:0;font-family:var(--font-display);font-size:2.4rem;color:var(--gold-soft)}
.step h3{font-size:1.25rem;margin-bottom:.5rem}
.step p{font-size:.95rem;color:var(--muted)}

/* ----- Footer ------------------------------------------------------- */
.site-footer{background:var(--ink);color:var(--cream);padding:clamp(60px,8vw,110px) 0 40px}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(30px,5vw,70px);padding-bottom:60px;border-bottom:1px solid rgba(241,240,236,.14)}
.footer-brand img{height:60px;margin-bottom:1.4rem}
.footer-brand p{color:rgba(241,240,236,.66);font-size:.95rem;max-width:36ch}
.footer-col h4{font-family:var(--font-sans);font-weight:500;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:1.3rem}
.footer-col a,.footer-col p{display:block;color:rgba(241,240,236,.78);font-size:.95rem;padding:.32em 0;transition:color .3s}
.footer-col a:hover{color:var(--gold-soft)}
.footer-partners{padding:46px 0;border-bottom:1px solid rgba(241,240,236,.14)}
.footer-partners .lab{text-align:center;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(241,240,236,.5);margin-bottom:26px}
.partner-row{display:flex;align-items:center;justify-content:center;gap:clamp(28px,5vw,70px);flex-wrap:wrap}
.partner-row a{display:grid;place-items:center}
.partner-row img{height:64px;width:auto;opacity:.85;filter:grayscale(.2);transition:all .4s var(--ease)}
.partner-row img:hover{opacity:1;filter:none;transform:translateY(-3px)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;padding-top:30px;font-size:.82rem;color:rgba(241,240,236,.55)}
.footer-bottom a:hover{color:var(--gold-soft)}

/* ----- Reveal animations ------------------------------------------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.12s}.reveal.d2{transition-delay:.24s}.reveal.d3{transition-delay:.36s}.reveal.d4{transition-delay:.48s}
.reveal-img{clip-path:inset(0 0 100% 0);transition:clip-path 1.2s var(--ease)}
.reveal-img.in{clip-path:inset(0 0 0 0)}
@media (prefers-reduced-motion:reduce){
  .reveal,.reveal-img{opacity:1;transform:none;clip-path:none;transition:none}
  .marquee,.scroll-cue span{animation:none}
}

/* ----- Responsive --------------------------------------------------- */
@media(max-width:1024px){
  .services{grid-template-columns:1fr 1fr}
  .articles{grid-template-columns:1fr 1fr}
  .ig-grid{grid-template-columns:repeat(3,1fr)}
  .features,.steps{grid-template-columns:1fr 1fr}
}
@media(max-width:820px){
  .nav,.nav-cta .nav-social{display:none}
  .burger{display:flex}
  .nav-overlay{display:flex;position:fixed;inset:0;z-index:999;background:rgba(0,0,0,.98);flex-direction:column;align-items:center;justify-content:center;gap:30px;opacity:0;pointer-events:none;transition:opacity .5s var(--ease)}
  .nav-overlay.open{opacity:1;pointer-events:auto}
  .nav-overlay a{font-family:var(--font-display);font-size:2rem;color:var(--cream)}
  .nav-overlay .nav-social{display:flex;gap:18px}
  .split,.form-band{grid-template-columns:1fr}
  .split.reverse .split-media{order:0}
  .form-media{min-height:280px}
  .services,.stats,.features,.steps,.articles{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr;gap:40px}
  .quote-form .row{grid-template-columns:1fr}
  .ig-grid{grid-template-columns:1fr 1fr}
  .three-band{min-height:60vh}
  .hero-inner{padding-bottom:150px}
  .scroll-cue{bottom:24px}
}
@media(max-width:480px){
  .marquee img{height:140px}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{justify-content:center}
}


/* ----- Skip link (accessibilità tastiera) ---------------------------- */
.skip-link{position:fixed;top:-100px;left:16px;z-index:2000;background:var(--ink);color:var(--cream);padding:.8em 1.4em;border-radius:100px;font-family:var(--font-sans);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;transition:top .3s var(--ease)}
.skip-link:focus{top:16px}

/* ----- Honeypot anti-spam (invisibile agli utenti) ------------------- */
.hp-field{position:absolute !important;left:-9999px !important;top:auto;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}

/* ----- WhatsApp flottante -------------------------------------------- */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:900;display:inline-flex;align-items:center;gap:10px;background:var(--ink);color:var(--cream);border:1px solid rgba(216,207,194,.55);border-radius:100px;padding:13px 22px 13px 16px;font-family:var(--font-sans);font-weight:500;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;box-shadow:0 18px 44px -18px rgba(0,0,0,.55);transition:all .4s var(--ease)}
.wa-float svg{width:20px;height:20px;color:var(--gold-soft);transition:color .4s var(--ease)}
.wa-float:hover{background:var(--gold-soft);color:var(--ink);border-color:var(--gold-soft);transform:translateY(-3px)}
.wa-float:hover svg{color:var(--ink)}
@media(max-width:640px){
  .wa-float{right:16px;bottom:16px;padding:15px}
  .wa-float .wa-txt{display:none}
}


/* ----- Scarpetta Rossa (distinta dai partner) ------------------------- */
.footer-impegno{display:flex;flex-direction:column;align-items:center;gap:14px;padding:30px 0;border-bottom:1px solid rgba(241,240,236,.14);text-align:center}
.footer-impegno img{height:64px;width:auto;opacity:.95;transition:opacity .4s var(--ease),transform .4s var(--ease)}
.footer-impegno a:hover img{opacity:1;transform:translateY(-3px)}
.footer-impegno p{color:rgba(241,240,236,.5);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase}

/* ----- Confronto due servizi ----------------------------------------- */
.grid.duo{grid-template-columns:1fr 1fr}
@media(max-width:820px){.grid.duo{grid-template-columns:1fr}}


/* ----- Prodotti: materioteca (card 3D) -------------------------------- */
.mat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.6vw,30px);perspective:1100px}
.mat-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(28px,3.5vw,44px) clamp(24px,3vw,36px);transition:box-shadow .5s var(--ease),transform .25s ease-out;will-change:transform;transform-style:preserve-3d}
.mat-card:hover{box-shadow:var(--shadow)}
.mat-card .mat-tag{font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;font-weight:500;color:var(--muted)}
.mat-card .mat-n{font-family:var(--font-display);font-size:clamp(2.8rem,5vw,4.2rem);line-height:1;color:var(--ink);margin-top:.6rem}
.mat-card .mat-n small{font-family:var(--font-serif);font-style:italic;font-size:.38em;color:var(--muted)}
.mat-card h3{font-size:1.25rem;margin:.9rem 0 .5rem}
.mat-card p{font-size:.93rem;color:var(--muted)}
@media(max-width:820px){
  .mat-grid{grid-template-columns:1fr;gap:18px;perspective:none}
  .mat-card{transform:none !important;transform-style:flat;background:#fff;border:1px solid rgba(0,0,0,.16);border-radius:20px;box-shadow:var(--shadow-soft);padding:28px 24px}
}


/* ----- Strumenti del Ricettivo (calcolatori) -------------------------- */
.rt-tools{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2.6vw,30px);align-items:start}
.tool-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(26px,3vw,40px)}
.tool-card h3{font-size:1.35rem;margin-bottom:.3rem}
.tool-card .tool-hint{font-size:.85rem;color:var(--muted);margin-bottom:1.2rem}
.tool-card label{display:block;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;color:var(--muted);margin-top:1.1rem}
.tool-card input,.tool-card select{display:block;width:100%;margin-top:.45rem;background:transparent;border:none;border-bottom:1px solid rgba(0,0,0,.25);font-family:var(--font-sans);font-weight:300;font-size:1.05rem;color:var(--text);padding:.45em 0;border-radius:0;-webkit-appearance:none;appearance:none}
.tool-card input:focus,.tool-card select:focus{outline:none;border-color:var(--ink)}
.tool-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.tool-extra{margin-top:1.3rem;border:1px dashed rgba(0,0,0,.2);border-radius:12px;padding:.9em 1.1em}
.tool-extra summary{cursor:pointer;font-size:.8rem;letter-spacing:.06em}
.tool-res{margin-top:1.5rem;background:var(--cream-2);border-radius:12px;padding:1em 1.2em;font-size:.98rem;line-height:1.7}
.tool-res strong{font-family:var(--font-display);font-weight:400;font-size:1.25em}
.tool-note{font-size:.76rem;color:var(--muted);margin-top:.9rem}
@media(max-width:820px){.rt-tools{grid-template-columns:1fr}.tool-row{grid-template-columns:1fr}}

/* ----- Strumenti del Ricettivo 2.0 (calcolatori brandizzati) ----------- */
.rt2-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,34px);align-items:start}
.rt2-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(28px,3.4vw,46px);box-shadow:var(--shadow-soft)}
.rt2-badge{display:inline-flex;align-items:center;gap:.55em;font-family:var(--font-sans);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;font-weight:500;color:var(--muted);border:1px solid var(--line);border-radius:100px;padding:.55em 1.1em;margin-bottom:1.4rem}
.rt2-badge b{color:var(--ink);font-weight:600}
.rt2-card h3{font-size:clamp(1.35rem,2vw,1.65rem);margin-bottom:.4rem}
.rt2-sub{font-size:.92rem;color:var(--muted);margin-bottom:1.7rem}
.rt2-field{margin-bottom:1.3rem}
.rt2-field>label{display:block;font-family:var(--font-sans);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;color:var(--ink);margin-bottom:.45rem}
.rt2-field input[type=number]{width:100%;background:transparent;border:0;border-bottom:1px solid rgba(0,0,0,.28);border-radius:0;padding:.3em 0;font-family:var(--font-display);font-size:1.55rem;color:var(--ink);transition:border-color .3s;-moz-appearance:textfield}
.rt2-field input[type=number]::-webkit-outer-spin-button,.rt2-field input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.rt2-field input[type=number]:focus{outline:none;border-color:var(--ink)}
.rt2-field input::placeholder{color:rgba(0,0,0,.25)}
.rt2-help{font-size:.74rem;color:var(--muted);margin-top:.5rem;line-height:1.55}
.rt2-pills{display:flex;flex-wrap:wrap;gap:8px}
.rt2-pill{font-family:var(--font-sans);font-weight:400;font-size:.78rem;letter-spacing:.03em;border:1px solid rgba(0,0,0,.2);border-radius:100px;padding:.62em 1.15em;background:transparent;color:var(--ink);cursor:pointer;transition:all .3s var(--ease)}
.rt2-pill small{color:inherit;opacity:.6;font-size:.86em}
.rt2-pill:hover{transform:translateY(-1px)}
.rt2-pill.on{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.rt2-switch{display:flex;align-items:center;gap:12px;cursor:pointer;user-select:none;margin:1.5rem 0 1rem;position:relative}
.rt2-switch input{position:absolute;opacity:0;pointer-events:none}
.rt2-switch .tr{width:42px;height:24px;border-radius:100px;background:rgba(0,0,0,.16);position:relative;transition:background .3s;flex-shrink:0}
.rt2-switch .tr::after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.25);transition:transform .3s var(--ease)}
.rt2-switch input:checked+.tr{background:var(--ink)}
.rt2-switch input:checked+.tr::after{transform:translateX(18px)}
.rt2-switch .lb{font-size:.88rem;color:var(--ink)}
.rt2-cmp{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.rt2-cmp.open{max-height:420px}
.rt2-out{margin-top:1.6rem;background:var(--ink);color:var(--cream);border-radius:16px;padding:1.25em 1.4em}
.rt2-out .lab{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft)}
.rt2-out .val{font-family:var(--font-display);font-size:clamp(1.9rem,3vw,2.5rem);line-height:1.15;margin-top:.15em}
.rt2-out .row2{display:flex;justify-content:space-between;align-items:baseline;gap:14px;border-top:1px solid rgba(241,240,236,.16);margin-top:.9em;padding-top:.9em;font-size:.88rem;color:rgba(241,240,236,.75)}
.rt2-out .row2 b{font-family:var(--font-display);font-weight:400;font-size:1.15rem;color:var(--cream)}
.rt2-out .verd{font-family:var(--font-serif);font-style:italic;color:var(--gold-soft);margin-top:.7em;font-size:1.04rem;line-height:1.5}
.rt2-note{font-size:.75rem;color:var(--muted);margin-top:1.15rem;line-height:1.65}
.rt2-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:900px){.rt2-grid{grid-template-columns:1fr}}
@media(max-width:560px){.rt2-row{grid-template-columns:1fr}}


/* ----- Pagine strumento (calcolatori) --------------------------------- */
.calc-hero{background:var(--ink);color:var(--cream);padding:clamp(140px,20vh,190px) 0 clamp(40px,6vw,64px)}
.calc-hero h1{font-size:clamp(2.2rem,5.4vw,4rem);font-weight:300;color:var(--cream);line-height:1.05}
.calc-hero h1 em{color:var(--gold-soft)}
.calc-hero p{margin-top:1.2rem;max-width:56ch;color:rgba(241,240,236,.85);font-size:1.08rem}
.calcx{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);padding:clamp(28px,4vw,52px);max-width:880px;margin-inline:auto}
.calcx .cx-lab{display:block;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500;color:var(--muted);margin:1.7rem 0 .8rem}
.calcx > .cx-lab:first-child,.cx-field .cx-lab{margin-top:0}
.cx-pills{display:flex;flex-wrap:wrap;gap:10px}
.cx-pill{font-family:var(--font-sans);font-weight:400;font-size:.84rem;letter-spacing:.03em;border:1px solid rgba(0,0,0,.16);border-radius:100px;padding:.7em 1.35em;background:transparent;cursor:pointer;transition:all .3s var(--ease);color:var(--ink)}
.cx-pill:hover{transform:translateY(-2px)}
.cx-pill.on{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.cx-num{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,26px);margin-top:.4rem}
.cx-field input{width:100%;background:transparent;border:none;border-bottom:1px solid rgba(0,0,0,.3);font-family:var(--font-display);font-size:clamp(1.7rem,3vw,2.3rem);color:var(--ink);padding:.1em 0}
.cx-field input:focus{outline:none;border-bottom:2px solid var(--ink)}
.cx-help{font-size:.78rem;color:var(--muted);margin-top:.5rem}
.cx-result{margin-top:2.2rem;background:var(--ink);color:var(--cream);border-radius:18px;padding:clamp(20px,3vw,32px);display:flex;flex-direction:column;gap:16px}
.cx-result .lab{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-soft)}
.cx-result .big{font-family:var(--font-display);font-size:clamp(2.4rem,5.6vw,3.6rem);line-height:1.05;margin-top:.2rem}
.cx-detail{border-top:1px solid rgba(241,240,236,.16);padding-top:14px;display:grid;gap:7px}
.cx-detail div{display:flex;justify-content:space-between;gap:16px;font-size:.88rem;color:rgba(241,240,236,.75)}
.cx-note{font-size:.78rem;color:var(--muted);margin-top:1.2rem;line-height:1.7;max-width:76ch}
.cx-note a{text-decoration:underline}
.ratex{width:100%;border-collapse:collapse;background:var(--white);box-shadow:var(--shadow-soft);border-radius:var(--radius);overflow:hidden}
.ratex th,.ratex td{padding:15px 20px;text-align:left;border-bottom:1px solid var(--line);font-size:.95rem}
.ratex th{font-family:var(--font-sans);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:500}
.ratex td:last-child,.ratex th:last-child{text-align:right}
.ratex td:last-child{font-family:var(--font-display);font-size:1.25rem;white-space:nowrap}
.ratex tr:last-child td{border-bottom:none}
.faqx{max-width:880px;margin-inline:auto;display:grid;gap:12px}
.faqx details{background:var(--white);border:1px solid var(--line);border-radius:14px;padding:18px 22px}
.faqx summary{cursor:pointer;font-family:var(--font-display);font-size:1.12rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faqx summary::-webkit-details-marker{display:none}
.faqx summary::after{content:"+";font-family:var(--font-serif);font-size:1.5rem;color:var(--muted);flex-shrink:0}
.faqx details[open] summary::after{content:"–"}
.faqx details p{margin-top:.8rem;color:var(--muted);font-size:.95rem;line-height:1.7;max-width:none}
.tools-duo{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2.6vw,30px)}
.tool-link{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(28px,3.5vw,44px);display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.tool-link:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.tool-link .tl-k{font-family:var(--font-serif);font-style:italic;color:var(--muted);font-size:1rem}
.tool-link h3{font-size:1.5rem;margin:.5rem 0 .5rem}
.tool-link p{color:var(--muted);font-size:.95rem;margin-bottom:1.4rem}
.tool-link .tl-go{margin-top:auto;display:inline-flex;align-items:center;gap:.6em;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500}
.tool-link .tl-go svg{width:28px;height:28px;padding:6px;border:1px solid rgba(0,0,0,.25);border-radius:50%;transition:all .4s var(--ease)}
.tool-link:hover .tl-go svg{background:var(--ink);border-color:var(--ink);color:var(--cream);transform:translateX(4px)}
@media(max-width:820px){
  .cx-num{grid-template-columns:1fr}
  .tools-duo{grid-template-columns:1fr}
  .calc-hero{padding-top:120px}
}


/* ----- Strumenti nel blocco Ricettivo (home) --------------------------- */
.ric-tools{margin-top:clamp(30px,4vw,48px);border:1px solid rgba(241,240,236,.16);border-radius:var(--radius-lg);padding:clamp(22px,3vw,34px);display:flex;align-items:center;justify-content:space-between;gap:clamp(20px,3vw,40px);flex-wrap:wrap;background:rgba(255,255,255,.03)}
.ric-tools .lab{font-family:var(--font-serif);font-style:italic;color:var(--gold-soft);font-size:1.08rem;display:block;margin-bottom:.4rem}
.ric-tools p{color:rgba(241,240,236,.72);font-size:.95rem;max-width:48ch;margin:0}
.ric-tools-links{display:flex;gap:12px;flex-wrap:wrap}
.ric-tools-links a{display:inline-flex;align-items:center;gap:.6em;border:1px solid rgba(216,207,194,.45);border-radius:100px;padding:.85em 1.5em;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;color:var(--cream);transition:all .35s var(--ease)}
.ric-tools-links a:hover{background:var(--gold-soft);border-color:var(--gold-soft);color:var(--ink);transform:translateY(-2px)}
.ric-tools-links a svg{width:15px;height:15px;transition:transform .35s var(--ease)}
.ric-tools-links a:hover svg{transform:translateX(3px)}
@media(max-width:820px){.ric-tools{flex-direction:column;align-items:flex-start}}


/* ----- Mini strumenti in home (sezione Il Ricettivo) ------------------ */
.tools-mini{display:grid;grid-template-columns:1.1fr 1fr 1fr;gap:clamp(16px,2vw,24px);align-items:stretch}
.tools-mini .tm-head{display:flex;flex-direction:column;justify-content:center;padding-right:8px}
.tools-mini .tm-head p{color:rgba(241,240,236,.7);font-size:.92rem;max-width:34ch}
.tool-mini{position:relative;display:flex;flex-direction:column;gap:.45rem;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-lg);padding:24px 26px;transition:background .45s var(--ease),transform .45s var(--ease)}
.tool-mini:hover{background:rgba(255,255,255,.1);transform:translateY(-4px)}
.tool-mini .tm-k{font-family:var(--font-serif);font-style:italic;color:var(--gold-soft);font-size:.95rem}
.tool-mini h3{color:var(--cream);font-size:1.22rem;line-height:1.22}
.tool-mini .tm-go{margin-top:auto;display:inline-flex;align-items:center;gap:.6em;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500;color:var(--cream);padding-top:.9rem}
.tool-mini .tm-go svg{width:26px;height:26px;padding:6px;border:1px solid rgba(241,240,236,.5);border-radius:50%;transition:all .4s var(--ease)}
.tool-mini:hover .tm-go svg{background:var(--gold-soft);border-color:var(--gold-soft);color:var(--ink);transform:translateX(4px)}
@media(max-width:820px){.tools-mini{grid-template-columns:1fr}.tools-mini .tm-head{padding-right:0}}


/* ----- Selettore comune (pagine tassa di soggiorno) ------------------- */
.cx-com{position:relative;max-width:380px;margin-top:1.8rem}
.cx-com label{display:block;font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;font-weight:500;color:var(--gold-soft);margin-bottom:.5rem}
.cx-com input{width:100%;background:transparent;border:none;border-bottom:1px solid rgba(241,240,236,.4);color:var(--cream);font-family:var(--font-display);font-size:1.35rem;padding:.3em 0}
.cx-com input::placeholder{color:rgba(241,240,236,.4);font-family:var(--font-sans);font-size:1rem}
.cx-com input:focus{outline:none;border-bottom-color:var(--gold-soft)}
.cx-com ul{position:absolute;top:100%;left:0;right:0;background:#111;border:1px solid rgba(241,240,236,.16);border-radius:12px;margin-top:8px;padding:6px;list-style:none;z-index:60;display:none;max-height:264px;overflow:auto;box-shadow:var(--shadow)}
.cx-com ul.open{display:block}
.cx-com li{padding:10px 14px;border-radius:8px;color:var(--cream);cursor:pointer;font-size:.95rem;transition:background .25s}
.cx-com li:hover{background:rgba(216,207,194,.16)}

/* ----- Griglia comuni -------------------------------------------------- */
.comuni-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:clamp(14px,2vw,22px)}
.comune-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;display:flex;flex-direction:column;gap:.35rem;transition:transform .45s var(--ease),box-shadow .45s var(--ease)}
.comune-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.comune-card .cc-n{font-family:var(--font-display);font-size:1.3rem;line-height:1.15}
.comune-card .cc-t{font-size:.82rem;color:var(--muted)}
.comune-card .cc-go{margin-top:.5rem;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500}


/* ----- Pacchetti Studio 3.0 (siti web) -------------------------------- */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.4vw,28px);align-items:stretch}
.plan{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(28px,3.4vw,42px);display:flex;flex-direction:column;position:relative;transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.plan:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.plan.hot{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.plan .pl-k{font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;font-weight:500;color:var(--muted)}
.plan.hot .pl-k{color:var(--gold-soft)}
.plan h3{font-size:1.6rem;margin:.5rem 0 .1rem}
.plan.hot h3{color:var(--cream)}
.plan .pl-price{font-family:var(--font-display);font-size:clamp(2rem,3.2vw,2.7rem);line-height:1;margin:.6rem 0 .15rem}
.plan .pl-price small{font-family:var(--font-serif);font-style:italic;font-size:.42em;color:var(--muted)}
.plan.hot .pl-price small{color:rgba(241,240,236,.6)}
.plan .pl-sub{font-size:.8rem;color:var(--muted);margin-bottom:1.3rem;letter-spacing:.04em}
.plan.hot .pl-sub{color:rgba(241,240,236,.6)}
.plan ul{margin:0 0 1.8rem;display:grid;gap:.6rem;list-style:none;padding:0}
.plan li{font-size:.92rem;color:var(--muted);padding-left:1.4em;position:relative;line-height:1.55}
.plan.hot li{color:rgba(241,240,236,.78)}
.plan li::before{content:"—";position:absolute;left:0;color:var(--gold-soft)}
.plan .btn{margin-top:auto;justify-content:center}
.plan .pl-badge{position:absolute;top:-13px;right:22px;background:var(--gold-soft);color:var(--ink);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;padding:.55em 1.2em;border-radius:100px}
@media(max-width:900px){.plans{grid-template-columns:1fr}.plan.hot{order:-1}}

/* ----- Testimonianze: card recensioni Airbnb ritagliate --------------- */
.marquee-rev{animation-duration:340s}
.marquee-rev img{height:130px;background:#fff}
@media(max-width:480px){.marquee-rev img{height:96px}}

/* ----- Filtro fotografico di brand (tono caldo uniforme) -------------- */
.hero-media img,img.bg,.svc img,.split-media img,.form-media img,.articles img{filter:sepia(.14) saturate(.82) contrast(.97) brightness(1.03)}

/* ----- Card manutenzioni: zoom per nascondere il bordo della foto storica */
.svc-zoom img{transform:scale(1.22);transform-origin:50% 62%}
.svc-zoom:hover img{transform:scale(1.3)}
