/* ==========================================================================
   IMMOBILART 2.0 — Design System premium, mobile-first
   Palette: bianco / antracite / oro-beige
   Tipografia: Plus Jakarta Sans (titoli) + Inter (corpo)
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@500;600;700&family=Cormorant+Garamond:ital,wght@0,500;0,600;1,500;1,600&family=Plus+Jakarta+Sans:ital,wght@0,500;0,600;0,700;0,800;1,600&family=Inter:wght@400;500;600;700;800&display=swap');

:root{
  /* Palette derivata direttamente dal logo ImmobilArt (blu + grigio) */
  --white:#FFFFFF;
  --paper:#123A5C;
  --beige:#E7F1FA;
  --beige-deep:#CFE3F3;
  --anthracite:#0B2C46;
  --anthracite-soft:#173F60;
  --ink-soft:#5B6B7A;
  --gold:#3D8FCE;
  --gold-deep:#2C6E9E;
  --gold-light:#DCEEFB;
  --line:#DEE6EC;
  --success:#3E6B4F;

  --display:'Plus Jakarta Sans', sans-serif;
  --serif:'Cormorant Garamond', serif;
  --vogue:'Cinzel', serif;
  --body:'Inter', sans-serif;

  --radius-s:2px;
  --radius-m:3px;
  --radius-l:4px;
  --shadow:0 24px 60px -30px rgba(28,26,23,.35);
  --shadow-soft:0 10px 30px -20px rgba(28,26,23,.3);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;font-family:var(--body);color:rgba(255,255,255,.86);background:var(--paper);
  -webkit-font-smoothing:antialiased;font-size:16px;line-height:1.6;
}
img{max-width:100%;display:block;}
.card-photo img,.post-photo img,.territory-card img,.person-photo img,.hero-float-badge img{filter:saturate(1.06) contrast(1.03);}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.1;margin:0 0 .45em;color:#fff;letter-spacing:-.015em;}
h1{font-weight:800;letter-spacing:-.02em;}
h2{font-weight:800;}
p{line-height:1.7;color:rgba(255,255,255,.72);margin:0 0 1em;}
ul{margin:0;padding:0;list-style:none;}

/* Testo scuro dove serve leggibilità su sfondi bianchi/chiari (card, form, filtri) */
.feature-card,.card-listing .card-body,.form-card,.post-card .post-body,.location-card .location-info,
.audience-card:not(.dark),.filter-bar,.section-beige,.band-beige,.chat-msg.bot{color:var(--anthracite);}
.feature-card h3,.card-listing h3,.form-card h3,.post-card h3,.location-card h3,
.audience-card:not(.dark) h2,.audience-card:not(.dark) h3,.section-beige h2,.section-beige h3,.chat-msg.bot{color:var(--anthracite);}
.feature-card p,.form-card > p,.post-card p,.section-beige p,.band-beige p,.audience-card:not(.dark) p{color:var(--ink-soft);}
.field label{color:var(--anthracite);}
.tab{color:var(--anthracite);}
input,select,textarea{color:var(--anthracite);background:var(--white);}
.chat-quick button{color:var(--anthracite);}
button{font-family:var(--body);}
:focus-visible{outline:3px solid var(--gold);outline-offset:3px;}

.container{max-width:1220px;margin:0 auto;padding:0 20px;}
@media(min-width:900px){.container{padding:0 40px;}}

.gold-rule{width:64px;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-deep));border:none;margin:0 0 20px;border-radius:2px;}
.gold-rule.center{margin-left:auto;margin-right:auto;}
.eyebrow{font-family:var(--body);font-size:12px;font-weight:800;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-light);display:inline-block;margin-bottom:12px;}

.section{padding:64px 0;}
.section-tight{padding:40px 0;}
@media(min-width:900px){.section{padding:104px 0;}}
.section-header{max-width:600px;margin-bottom:36px;}
@media(min-width:900px){.section-header{margin-bottom:52px;}}
.section-header.center{margin-left:auto;margin-right:auto;text-align:center;}
.section-dark{background:var(--anthracite);color:var(--white);}
.section-dark h2,.section-dark h3,.section-dark h4{color:var(--white);}
.section-dark p{color:rgba(255,255,255,.68);}
.section-beige{background:var(--beige);}

/* ---------- bottoni ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:16px 30px;border-radius:var(--radius-s);font-weight:700;font-size:13.5px;
  letter-spacing:.06em;text-transform:uppercase;border:1.5px solid transparent;cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
  white-space:nowrap;
}
.btn-primary{background:var(--anthracite);color:var(--white);}
.btn-primary:hover{background:var(--gold-deep);transform:translateY(-2px);box-shadow:0 16px 30px -14px rgba(35,42,51,.5);}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:var(--white);box-shadow:0 16px 34px -14px rgba(61,143,206,.55);}
.btn-gold:hover{background:linear-gradient(135deg,var(--gold-deep),var(--gold-deep));transform:translateY(-2px);box-shadow:0 20px 38px -14px rgba(61,143,206,.65);}
.btn-outline{background:transparent;border-color:var(--anthracite);color:var(--anthracite);}
.btn-outline:hover{background:var(--anthracite);color:var(--white);}
.btn-outline-light{background:transparent;border-color:rgba(255,255,255,.5);color:var(--white);}
.btn-outline-light:hover{background:rgba(255,255,255,.12);border-color:#fff;}
.btn-block{width:100%;}
.btn-sm{padding:11px 18px;font-size:13.5px;}
.btn-wa{background:#25D366;color:#fff;}
.btn-wa:hover{background:#1DA851;transform:translateY(-2px);}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:80;background:rgba(11,44,70,.95);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.1);}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;gap:14px;}
@media(min-width:900px){.header-inner{padding:16px 40px;}}
.brand img{height:34px;width:auto;filter:brightness(0) invert(1);}
@media(min-width:900px){.brand img{height:40px;}}
.main-nav{
  position:fixed;inset:64px 0 0 0;background:var(--white);z-index:70;
  padding:20px 24px 100px;overflow-y:auto;transform:translateX(100%);transition:transform .28s ease;
}
.main-nav.open{transform:translateX(0);}
.main-nav a{display:block;padding:14px 4px;font-size:18px;font-weight:600;border-bottom:1px solid var(--line);color:var(--anthracite);}
.main-nav a.active{color:var(--gold-deep);}
.nav-cta{margin-top:22px;display:flex;flex-direction:column;gap:12px;}
@media(min-width:1080px){
  .main-nav{position:static;inset:auto;background:none;transform:none;padding:0;display:flex;align-items:center;gap:26px;overflow:visible;}
  .main-nav a{display:inline-block;padding:6px 2px;font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border-bottom:2px solid transparent;color:rgba(255,255,255,.88);}
  .main-nav a:hover,.main-nav a.active{border-color:var(--gold);color:#fff;}
  .nav-cta{flex-direction:row;margin-top:0;}
}
.header-actions{display:flex;align-items:center;gap:10px;}
.nav-toggle{display:flex;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;padding:8px;cursor:pointer;z-index:90;}
.nav-toggle span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:transform .2s ease, opacity .2s ease;}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0;}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
@media(min-width:1080px){.nav-toggle{display:none;}}
.header-phone{display:none;align-items:center;gap:8px;font-weight:700;font-size:14px;}
@media(min-width:1080px){.header-phone{display:flex;}}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--anthracite);color:var(--white);overflow:hidden;min-height:min(640px,92vh);display:flex;}
@media(min-width:900px){.hero{min-height:640px;}}
.hero-media{position:absolute;inset:0;z-index:0;}
.hero-media img{width:100%;height:100%;object-fit:cover;opacity:1;filter:saturate(1.08) contrast(1.04);}
.hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,25,38,.12) 40%,rgba(11,25,38,.94) 100%);}
@media(min-width:900px){.hero-media::after{background:linear-gradient(100deg,rgba(11,25,38,.93) 24%,rgba(11,25,38,.22) 100%);}}
.hero-content{position:relative;z-index:1;width:100%;display:flex;align-items:center;padding:96px 20px 36px;}
@media(min-width:900px){.hero-content{padding:0 40px;}}
.hero-inner{max-width:620px;}
.hero .eyebrow{color:var(--gold-light);}
.hero h1{font-family:var(--vogue);font-weight:600;font-size:clamp(28px,5.2vw,52px);color:#fff;letter-spacing:.03em;line-height:1.3;text-transform:uppercase;}
.hero h1 em{font-style:italic;color:var(--gold-light);font-weight:500;}
.hero-lead{font-size:17px;color:rgba(255,255,255,.78);max-width:480px;}
.hero-actions{display:flex;flex-direction:column;gap:12px;margin-top:20px;}
@media(min-width:560px){.hero-actions{flex-direction:row;flex-wrap:wrap;}}
.hero-stats{display:flex;gap:28px;margin-top:40px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.18);padding-top:26px;}
.hero-stats div strong{display:block;font-family:var(--serif);font-weight:600;font-size:38px;color:#fff;letter-spacing:-.01em;}
.hero-stats div span{font-size:12.5px;color:rgba(255,255,255,.6);letter-spacing:.03em;}

/* ---------- grid / card ---------- */
.grid{display:grid;gap:22px;}
@media(min-width:700px){.grid-2{grid-template-columns:1fr 1fr;}.grid-3{grid-template-columns:repeat(2,1fr);}.grid-4{grid-template-columns:repeat(2,1fr);}}
@media(min-width:1000px){.grid-3{grid-template-columns:repeat(3,1fr);}.grid-4{grid-template-columns:repeat(4,1fr);}}

.card-listing{background:var(--white);border-radius:var(--radius-m);overflow:hidden;box-shadow:var(--shadow-soft);border:1px solid var(--line);border-top:3px solid transparent;transition:transform .25s cubic-bezier(.2,.7,.3,1), box-shadow .25s ease, border-color .25s ease;}
.card-listing:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-top-color:var(--gold);}
.card-listing{background:var(--white);padding:10px;}
.card-photo{position:relative;aspect-ratio:4/3;background:var(--beige);}
.card-photo img{width:100%;height:100%;object-fit:cover;}
.card-tag{position:absolute;top:14px;left:14px;background:rgba(255,255,255,.95);backdrop-filter:blur(6px);color:var(--anthracite);font-size:11px;font-weight:800;padding:7px 13px;border-radius:2px;text-transform:uppercase;letter-spacing:.1em;}
.card-tag.gold{background:var(--gold);color:#fff;}
.card-price{position:absolute;bottom:14px;left:14px;background:var(--anthracite);color:#fff;font-family:var(--serif);font-weight:600;padding:9px 19px;border-radius:1px;font-size:21px;letter-spacing:-.005em;box-shadow:0 10px 24px -10px rgba(0,0,0,.5);}
.card-fav{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.9);display:flex;align-items:center;justify-content:center;}
.card-body{padding:20px;}
.card-body h3{font-size:18px;margin-bottom:6px;}
.card-loc{display:flex;gap:6px;align-items:center;font-size:13px;color:var(--ink-soft);margin-bottom:14px;}
.card-meta{display:flex;gap:14px;font-size:13px;color:var(--ink-soft);border-top:1px solid var(--line);padding-top:14px;flex-wrap:wrap;}
.card-meta strong{color:var(--anthracite);}

/* ---------- servizi/feature card ---------- */
.feature-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-m);padding:28px;transition:transform .2s ease,box-shadow .2s ease;}
.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft);}
.feature-icon{width:48px;height:48px;border-radius:var(--radius-s);background:var(--beige);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--gold-deep);}
.feature-card h3{font-size:18px;margin-bottom:8px;}
.feature-card p{font-size:14.5px;margin-bottom:0;}

/* ---------- band / cta ---------- */
.band{border-radius:var(--radius-l);padding:44px 24px;border:1px solid rgba(255,255,255,.08);}
@media(min-width:900px){.band{padding:72px 68px;}}
.band-anthracite{background:var(--anthracite);color:#fff;border-top:3px solid var(--gold);box-shadow:0 30px 60px -30px rgba(0,0,0,.5);}
.band-gold{background:linear-gradient(135deg,var(--gold-deep),var(--gold));color:#fff;}
.band-gold h2{color:#fff;}
.band-gold p{color:rgba(255,255,255,.88);}
.band-anthracite h2{color:#fff;}
.band-anthracite p{color:rgba(255,255,255,.7);}
.band-beige{background:var(--beige);}

/* ---------- split venditori/acquirenti ---------- */
.split{display:grid;gap:24px;}
@media(min-width:900px){.split{grid-template-columns:1fr 1fr;gap:32px;align-items:center;}}
.audience-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-l);padding:32px 26px;position:relative;}
.audience-card.dark{background:var(--anthracite);color:#fff;}
.audience-card.dark h2,.audience-card.dark h3{color:#fff;}
.audience-card.dark p{color:rgba(255,255,255,.72);}
.audience-list{margin:20px 0 26px;}
.audience-list li{display:flex;gap:10px;padding:8px 0;font-size:14.5px;color:var(--ink-soft);}
.audience-card.dark .audience-list li{color:rgba(255,255,255,.8);}
.audience-list li svg{flex:none;color:var(--gold);margin-top:2px;}

/* ---------- steps ---------- */
.steps{counter-reset:step;display:grid;gap:24px;}
@media(min-width:700px){.steps{grid-template-columns:repeat(2,1fr);}}
@media(min-width:1000px){.steps{grid-template-columns:repeat(4,1fr);}}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);font-family:var(--serif);font-weight:600;font-size:44px;color:var(--gold);display:block;margin-bottom:10px;}
.step h4{font-size:16px;margin-bottom:6px;}
.step p{font-size:13.5px;}

/* ---------- persone ---------- */
.person{text-align:center;}
.person-photo{border-radius:var(--radius-m);aspect-ratio:3/4;overflow:hidden;margin-bottom:16px;box-shadow:var(--shadow-soft);border-bottom:3px solid var(--gold);}
.person-photo img{width:100%;height:100%;object-fit:cover;}
.person h4{font-size:16.5px;margin-bottom:2px;}
.person span{font-size:13px;color:var(--gold-deep);font-weight:700;}

/* ---------- recensioni ---------- */
.review-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-m);padding:26px;height:100%;}
.review-stars{color:var(--gold);letter-spacing:2px;margin-bottom:12px;font-size:15px;}
.review-card p{font-style:italic;color:var(--anthracite);}
.review-name{font-weight:700;font-size:13.5px;color:var(--ink-soft);font-style:normal;margin-top:14px;}

/* ---------- sedi ---------- */
.location-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-m);overflow:hidden;}
.location-map{aspect-ratio:16/10;border:none;width:100%;display:block;filter:grayscale(.4) contrast(1.05);}
.location-info{padding:22px;}
.location-info h3{font-size:18px;margin-bottom:10px;}
.location-row{display:flex;gap:10px;align-items:flex-start;font-size:13.5px;color:var(--ink-soft);margin-bottom:8px;}
.location-row svg{flex:none;margin-top:3px;color:var(--gold-deep);}

/* ---------- form ---------- */
.form-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-l);padding:26px 22px;box-shadow:var(--shadow-soft);}
@media(min-width:900px){.form-card{padding:44px 40px;}}
.form-row{display:grid;gap:16px;}
@media(min-width:640px){.form-row{grid-template-columns:1fr 1fr;}}
.field{margin-bottom:16px;}
.field label{display:block;font-size:13px;font-weight:700;margin-bottom:7px;}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border-radius:var(--radius-s);border:1.5px solid var(--line);background:var(--white);font-family:var(--body);font-size:14.5px;color:var(--anthracite);}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold);outline:none;}
.field textarea{resize:vertical;min-height:110px;}
.form-note{font-size:12.5px;color:var(--ink-soft);margin-top:6px;}
.form-success{display:none;background:var(--gold-light);border-radius:var(--radius-m);padding:18px;margin-top:16px;color:var(--gold-deep);font-weight:700;}

/* ---------- filtri ricerca ---------- */
.filter-bar{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-l);padding:18px;display:grid;gap:12px;margin-bottom:32px;box-shadow:var(--shadow-soft);}
@media(min-width:800px){.filter-bar{grid-template-columns:repeat(4,1fr) auto;align-items:end;}}
.filter-bar .field{margin-bottom:0;}
.tabs{display:flex;gap:10px;margin-bottom:28px;flex-wrap:wrap;}
.tab{padding:10px 18px;border-radius:999px;border:1.5px solid var(--line);background:var(--white);font-weight:700;font-size:13.5px;cursor:pointer;}
.tab.active{background:var(--anthracite);color:#fff;border-color:var(--anthracite);}
.results-count{font-size:13.5px;color:rgba(255,255,255,.65);margin-bottom:18px;}

/* ---------- pagina interna hero ---------- */
.page-hero{padding:40px 0 32px;}
@media(min-width:900px){.page-hero{padding:64px 0 48px;}}
.page-hero h1{font-size:clamp(30px,5vw,46px);}
.breadcrumb{font-size:13px;color:rgba(255,255,255,.55);margin-bottom:16px;}
.breadcrumb a{color:var(--gold-light);font-weight:700;}

/* ---------- footer ---------- */
.site-footer{background:var(--anthracite);color:rgba(255,255,255,.68);padding:56px 0 26px;margin-top:36px;}
.footer-grid{display:grid;gap:32px;margin-bottom:44px;}
@media(min-width:700px){.footer-grid{grid-template-columns:1.3fr 1fr 1fr 1fr;}}
.footer-brand img{height:32px;filter:brightness(0) invert(1);margin-bottom:14px;}
.footer-brand p{color:rgba(255,255,255,.55);font-size:13.5px;max-width:280px;}
.site-footer h5{color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px;}
.site-footer a{display:block;padding:5px 0;font-size:14px;color:rgba(255,255,255,.68);}
.site-footer a:hover{color:var(--gold-light);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.14);padding-top:22px;display:flex;flex-direction:column;gap:8px;font-size:12.5px;color:rgba(255,255,255,.45);}
@media(min-width:700px){.footer-bottom{flex-direction:row;justify-content:space-between;}}

/* ---------- whatsapp float ---------- */
.wa-float{position:fixed;right:18px;bottom:18px;z-index:95;width:58px;height:58px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 28px -8px rgba(0,0,0,.4);transition:transform .2s ease;}
.wa-float:hover{transform:scale(1.07);}

/* ---------- chatbot ---------- */
.chat-toggle{position:fixed;right:18px;bottom:86px;z-index:95;width:58px;height:58px;border-radius:50%;background:var(--anthracite);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 28px -8px rgba(0,0,0,.4);border:none;cursor:pointer;transition:transform .2s ease;}
.chat-toggle:hover{transform:scale(1.07);}
.chat-window{position:fixed;right:18px;bottom:154px;z-index:96;width:min(340px,calc(100vw - 36px));max-height:60vh;background:var(--white);border-radius:var(--radius-l);box-shadow:var(--shadow);display:none;flex-direction:column;overflow:hidden;border:1px solid var(--line);}
.chat-window.open{display:flex;}
.chat-head{background:var(--anthracite);color:#fff;padding:16px 18px;}
.chat-head strong{display:block;font-family:var(--display);font-size:16px;}
.chat-head span{font-size:12px;color:rgba(255,255,255,.65);}
.chat-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;}
.chat-msg{max-width:85%;padding:10px 14px;border-radius:14px;font-size:13.5px;line-height:1.5;}
.chat-msg.bot{background:var(--beige);align-self:flex-start;border-bottom-left-radius:4px;}
.chat-msg.user{background:var(--anthracite);color:#fff;align-self:flex-end;border-bottom-right-radius:4px;}
.chat-quick{display:flex;flex-wrap:wrap;gap:8px;padding:0 16px 16px;}
.chat-quick button{background:var(--white);border:1.5px solid var(--line);border-radius:999px;padding:7px 12px;font-size:12.5px;font-weight:600;cursor:pointer;}
.chat-quick button:hover{border-color:var(--gold);color:var(--gold-deep);}

/* ---------- blog ---------- */
.post-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-m);overflow:hidden;}
.post-photo{aspect-ratio:16/10;}
.post-photo img{width:100%;height:100%;object-fit:cover;}
.post-body{padding:20px;}
.post-meta{font-size:12px;color:var(--gold-deep);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;}
.post-body h3{font-size:18px;margin-bottom:8px;}
.post-body p{font-size:14px;}
article.prose{max-width:720px;margin:0 auto;}
article.prose h2{margin-top:1.4em;font-size:24px;}
article.prose p{font-size:16px;color:var(--anthracite-soft);}

/* ---------- misc ---------- */
.text-center{text-align:center;}
.mt-0{margin-top:0;}
.tag-pill{display:inline-block;background:var(--gold-light);color:var(--gold-deep);font-size:12px;font-weight:700;padding:5px 13px;border-radius:999px;margin-bottom:14px;}
.value-row{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--line);}
.value-row:last-child{border-bottom:none;}
.value-num{font-family:var(--serif);font-weight:600;font-size:32px;color:var(--gold-light);flex:none;width:52px;}
.territory-card{position:relative;border-radius:var(--radius-m);overflow:hidden;aspect-ratio:4/3;}
.territory-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.3,1);}
.territory-card:hover img{transform:scale(1.06);}
.territory-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(35,42,51,0) 40%,rgba(35,42,51,.85));}
.territory-card .territory-label{position:absolute;left:18px;bottom:16px;color:#fff;z-index:2;}
.territory-card .territory-label h3{color:#fff;margin-bottom:2px;}
.territory-card .territory-label span{font-size:12.5px;color:rgba(255,255,255,.7);}

/* ============================================================
   WOW LAYER — decorazioni, movimento, micro-interazioni
   ============================================================ */

/* zoom immagini card al passaggio del mouse */
.card-photo{overflow:hidden;}
.card-photo img{transition:transform .55s cubic-bezier(.2,.7,.3,1);}
.card-listing:hover .card-photo img{transform:scale(1.07);}
.post-photo{overflow:hidden;}
.post-photo img{transition:transform .55s cubic-bezier(.2,.7,.3,1);}
.post-card:hover .post-photo img{transform:scale(1.07);}

/* pulsanti con freccia che scorre */
.btn-arrow{position:relative;overflow:hidden;}
.btn-arrow .arrow{display:inline-block;transition:transform .25s ease;}
.btn-arrow:hover .arrow{transform:translateX(4px);}

/* header che si comprime allo scroll */
.site-header{transition:box-shadow .25s ease;}
.site-header.scrolled{box-shadow:0 8px 24px -18px rgba(35,42,51,.35);}
.site-header.scrolled .header-inner{padding-top:9px;padding-bottom:9px;}

/* blob decorativi sfocati, tono blu del brand */
.blob{position:absolute;border-radius:50%;filter:blur(70px);pointer-events:none;z-index:0;}
.hero{position:relative;}
.hero::before{
  content:"";position:absolute;z-index:0;top:-120px;right:-120px;width:420px;height:420px;
  border-radius:50%;background:radial-gradient(circle,rgba(61,143,206,.35),transparent 70%);filter:blur(10px);
}
.hero-content{z-index:1;}
.hero-media{z-index:0;}

/* divisore ondulato tra sezioni */
.wave-divider{display:block;width:100%;height:auto;margin-top:-2px;position:relative;z-index:2;}

/* badge fluttuante stile "glass" sopra l'hero */
.hero-float-badge{
  position:relative;z-index:2;margin-top:-54px;
  background:rgba(255,255,255,.94);backdrop-filter:blur(14px);
  border-radius:var(--radius-m);box-shadow:var(--shadow);
  padding:17px 22px;display:inline-flex;align-items:center;gap:12px;
  border:1px solid var(--gold-light);border-top:2px solid var(--gold);
}
@media(min-width:900px){.hero-float-badge{margin-top:-38px;}}
.hero-float-badge strong{font-family:var(--serif);font-weight:600;font-size:26px;display:block;color:var(--anthracite);}
.hero-float-badge span{font-size:12px;color:var(--ink-soft);}
.hero-float-badge .stars{color:var(--gold);letter-spacing:2px;font-size:14px;}

/* numeri animati in hero */
.stat-num{display:inline-block;}

/* scroll reveal — attivo solo con JS disponibile (classe aggiunta su <html>) */
html.js-anim .reveal-el{
  opacity:0;transform:translateY(28px);
  transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1);
}
html.js-anim .reveal-el.in-view{opacity:1;transform:translateY(0);}
@media (prefers-reduced-motion: reduce){
  html.js-anim .reveal-el{opacity:1!important;transform:none!important;transition:none!important;}
}

/* linea che si disegna sotto i titoli in vista */
.gold-rule{transform-origin:left center;}
html.js-anim .reveal-el .gold-rule{transform:scaleX(0);transition:transform .6s ease .15s;}
html.js-anim .reveal-el.in-view .gold-rule{transform:scaleX(1);}
.gold-rule.center{transform-origin:center;}

/* hover card più profondo con leggera rotazione */
.feature-card,.audience-card{transition:transform .3s cubic-bezier(.2,.7,.3,1),box-shadow .3s ease;}
.feature-card:hover{transform:translateY(-6px) rotate(-.3deg);}

/* pulsazione discreta sul pulsante whatsapp per farsi notare */
@keyframes wa-pulse{0%,100%{box-shadow:0 12px 28px -8px rgba(0,0,0,.4),0 0 0 0 rgba(37,211,102,.5);}50%{box-shadow:0 12px 28px -8px rgba(0,0,0,.4),0 0 0 10px rgba(37,211,102,0);}}
.wa-float{animation:wa-pulse 2.6s ease-in-out infinite;}
@media (prefers-reduced-motion: reduce){.wa-float{animation:none;}}
