/*
Theme Name: LIV Pro
Theme URI: https://agenziaserviziliv.it
Author: Agenzia Servizi LIV
Description: Tema premium per Agenzia Servizi LIV + Roma Digital Hub. Stile istituzionale-tech, mobile-first, accessibile. Palette navy-deep + blu elettrico + oro caldo.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 8.0
License: GPL v2 or later
Text Domain: liv-pro
*/

/* =================================================================
   LIV PRO — Design system v2 (premium digital)
================================================================= */

:root{
  /* === COLORI === */
  --color-navy-deep: #06172E;
  --color-navy:      #081B33;
  --color-navy-700:  #0F2A4A;
  --color-navy-600:  #163357;
  --color-blue:      #2563EB;
  --color-blue-soft: #3B82F6;
  --color-blue-glow: rgba(37,99,235,.22);
  --color-gold:      #D8AD63;
  --color-gold-soft: #EAC78F;
  --color-bordeaux:  #8C1F2C;
  --color-bordeaux-dark:#6F1722;

  --color-whatsapp:      #25D366;
  --color-whatsapp-dark: #1FB458;

  --color-surface:     #ffffff;
  --color-surface-alt: #F5F7FA;
  --color-surface-2:   #EEF2F8;

  --color-ink:        #0F172A;
  --color-text:       #1E293B;
  --color-muted:      #64748B;
  --color-muted-soft: #94A3B8;
  --color-line:       #E2E8F0;
  --color-line-soft:  #F1F5F9;

  /* glass per blocchi dark */
  --glass-bg:     rgba(255,255,255,.06);
  --glass-border: rgba(255,255,255,.12);

  /* === FORME === */
  --radius-xl:  22px;
  --radius-lg:  18px;
  --radius:     14px;
  --radius-sm:  10px;
  --radius-pill:999px;

  /* === SHADOWS === */
  --shadow-soft:   0 1px 2px rgba(15,23,42,.04), 0 1px 1px rgba(15,23,42,.04);
  --shadow-card:   0 1px 3px rgba(15,23,42,.06), 0 8px 24px rgba(15,23,42,.06);
  --shadow-card-hover:0 4px 6px rgba(15,23,42,.08), 0 16px 40px rgba(15,23,42,.12);
  --shadow-lg:     0 24px 60px rgba(6,23,46,.18);
  --shadow-glow:   0 0 0 1px rgba(37,99,235,.18), 0 18px 50px rgba(37,99,235,.18);

  /* === LAYOUT === */
  --container-width:1240px;
  --container-narrow:880px;
  --header-h:96px;

  /* === FONT === */
  --font-sans:'Inter','Plus Jakarta Sans','Manrope','Sora',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;

  /* === ALIAS retro-compatibili (per template precedenti) === */
  --liv-navy:        var(--color-navy-deep);
  --liv-navy-700:    var(--color-navy-700);
  --liv-blue:        var(--color-blue);
  --liv-gold:        var(--color-gold);
  --liv-bordeaux:    var(--color-bordeaux);
  --liv-surface:     var(--color-surface);
  --liv-surface-alt: var(--color-surface-alt);
  --liv-ink:         var(--color-ink);
  --liv-text:        var(--color-text);
  --liv-muted:       var(--color-muted);
  --liv-line:        var(--color-line);
  --liv-header-h:    var(--header-h);
  --liv-radius:      var(--radius);
  --liv-radius-lg:   var(--radius-lg);
  --liv-shadow:      var(--shadow-card);
  --liv-shadow-lg:   var(--shadow-card-hover);
  --liv-font-sans:   var(--font-sans);
}

/* === RESET / BASE === */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font-sans);
  font-size:17px;
  line-height:1.65;
  color:var(--color-text);
  background:var(--color-surface);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"cv11","ss01";
}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:var(--color-navy-700);text-decoration:none;transition:color .18s ease}
a:hover{color:var(--color-blue)}
::selection{background:var(--color-navy);color:#fff}
:focus-visible{outline:2px solid var(--color-blue);outline-offset:3px;border-radius:6px}

/* === TIPOGRAFIA === */
h1,h2,h3,h4{
  font-family:var(--font-sans);
  font-weight:800;
  color:var(--color-ink);
  line-height:1.15;
  letter-spacing:-.022em;
  margin:0 0 .55em;
}
h1{font-size:clamp(2.3rem,5vw,3.8rem);font-weight:800;letter-spacing:-.028em}
h2{font-size:clamp(1.9rem,3.4vw,2.6rem);font-weight:800}
h3{font-size:clamp(1.2rem,1.6vw,1.4rem);font-weight:700;letter-spacing:-.015em}
h4{font-size:1.05rem;font-weight:700;letter-spacing:0}
p{margin:0 0 1.1em;font-size:1.05rem;line-height:1.7;color:var(--color-text)}
ul{padding-left:1.15em;margin:0 0 1.1em}
li{margin:.3em 0}
strong{font-weight:700;color:var(--color-ink)}
.lead{
  font-size:clamp(1.08rem,1.5vw,1.28rem);
  line-height:1.65;
  color:var(--color-muted);
  max-width:64ch;
  font-weight:400;
}
small,.small{font-size:.9rem;color:var(--color-muted)}

/* === LAYOUT === */
.container{max-width:var(--container-width);margin:0 auto;padding:0 24px}
.container--narrow{max-width:var(--container-narrow);margin:0 auto;padding:0 24px}
.section{padding:104px 0}
.section--tight{padding:60px 0}
.section--alt{background:var(--color-surface-alt)}
.section--navy{
  background:linear-gradient(160deg,var(--color-navy-deep) 0%,var(--color-navy-700) 100%);
  color:#fff;
}
.section--navy h1,.section--navy h2,.section--navy h3,.section--navy h4{color:#fff}
.section--navy .lead,.section--navy p{color:rgba(255,255,255,.82)}

/* Kicker / badge */
.kicker{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.78rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--color-blue);
  padding:6px 14px;border-radius:var(--radius-pill);
  background:rgba(37,99,235,.10);
  margin-bottom:18px;
}
.kicker--gold{color:var(--color-gold);background:rgba(216,173,99,.12)}
.kicker--light{color:var(--color-gold-soft);background:rgba(234,199,143,.14)}
.kicker--bordeaux{color:var(--color-bordeaux);background:rgba(140,31,44,.08)}
.section--navy .kicker{background:rgba(234,199,143,.14);color:var(--color-gold-soft)}

.section-head{text-align:center;max-width:760px;margin:0 auto 60px}
.section-head .lead{margin:0 auto}

/* === BUTTONS === */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  padding:15px 26px;border-radius:12px;
  font-family:var(--font-sans);
  font-weight:700;font-size:1rem;letter-spacing:-.005em;
  border:2px solid transparent;cursor:pointer;text-align:center;
  transition:transform .18s ease, background-color .18s ease, border-color .18s ease, box-shadow .18s ease, color .18s ease;
  line-height:1;white-space:nowrap;
  min-height:52px;
}
.btn .ico{width:1.15em;height:1.15em}

.btn--primary{
  background:var(--color-blue);color:#fff;border-color:var(--color-blue);
  box-shadow:0 6px 18px rgba(37,99,235,.28);
}
.btn--primary:hover{
  background:#1d4fd1;border-color:#1d4fd1;color:#fff;
  transform:translateY(-2px);box-shadow:0 10px 24px rgba(37,99,235,.36);
}
.btn--navy{background:var(--color-navy-deep);color:#fff;border-color:var(--color-navy-deep)}
.btn--navy:hover{background:var(--color-navy-700);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-card-hover)}

.btn--bordeaux{background:var(--color-bordeaux);color:#fff;border-color:var(--color-bordeaux)}
.btn--bordeaux:hover{background:var(--color-bordeaux-dark);color:#fff;transform:translateY(-2px)}

.btn--ghost{background:transparent;color:var(--color-navy-deep);border-color:var(--color-navy-deep)}
.btn--ghost:hover{background:var(--color-navy-deep);color:#fff;transform:translateY(-2px)}

.btn--ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn--ghost-light:hover{background:#fff;color:var(--color-navy-deep);transform:translateY(-2px)}

.btn--gold{
  background:var(--color-gold);color:#1A1305;border-color:var(--color-gold);
  box-shadow:0 6px 18px rgba(216,173,99,.32);
}
.btn--gold:hover{background:#c39750;border-color:#c39750;color:#1A1305;transform:translateY(-2px);box-shadow:0 10px 26px rgba(216,173,99,.4)}

.btn--wa{
  background:var(--color-whatsapp);color:#fff;border-color:var(--color-whatsapp);
  box-shadow:0 6px 18px rgba(37,211,102,.32);
}
.btn--wa:hover{background:var(--color-whatsapp-dark);border-color:var(--color-whatsapp-dark);color:#fff;transform:translateY(-2px);box-shadow:0 10px 26px rgba(37,211,102,.42)}

.btn--light{background:#fff;color:var(--color-navy-deep);border-color:#fff}
.btn--light:hover{background:var(--color-surface-alt);color:var(--color-navy-deep);transform:translateY(-2px)}

.btn--lg{padding:19px 32px;font-size:1.06rem;min-height:60px;border-radius:14px}
.btn--sm{padding:10px 16px;font-size:.9rem;min-height:42px;border-radius:10px}
.btn--block{display:flex;width:100%}

.cta-group{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px}
.cta-group--center{justify-content:center;margin-top:40px}
.cta-group--start{margin-top:0}

/* === ICON === */
.ico{width:1.1em;height:1.1em;flex-shrink:0;stroke-width:1.8;stroke:currentColor;fill:none;stroke-linecap:round;stroke-linejoin:round}

/* === HEADER === */
.site-header{
  position:sticky;top:0;z-index:100;
  background:var(--color-navy-deep);
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  min-height:var(--header-h);
}
.site-brand{display:flex;align-items:center;gap:14px;text-decoration:none;color:#fff;min-width:0;flex:1 1 auto}
.site-brand:hover{color:#fff}

.site-brand--logo{
  display:inline-flex;align-items:center;
  line-height:0;min-width:0;
  transition:opacity .18s ease, transform .18s ease;
}
.site-brand--logo:hover{opacity:.92;transform:translateY(-1px)}
.site-brand--logo img,
.site-header .custom-logo{
  display:block;
  height:auto;width:auto;
  max-height:62px;max-width:380px;
  object-fit:contain;
}
@media (max-width:1080px){
  .site-brand--logo img,.site-header .custom-logo{max-height:54px;max-width:340px}
}
@media (max-width:980px){
  .site-brand--logo img,.site-header .custom-logo{max-height:50px;max-width:260px}
}
@media (max-width:520px){
  .site-brand--logo img,.site-header .custom-logo{max-height:44px;max-width:220px}
}
@media (max-width:380px){
  .site-brand--logo img,.site-header .custom-logo{max-height:38px;max-width:180px}
}
@media (max-width:1080px){:root{--header-h:90px}}
@media (max-width:980px){:root{--header-h:84px}}
@media (max-width:520px){:root{--header-h:78px}}

/* fallback brand text (se manca custom logo) */
.brand-mark{
  width:46px;height:46px;border-radius:11px;
  background:#fff;color:var(--color-navy-deep);
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:1.05rem;letter-spacing:-.02em;
  box-shadow:inset 0 -3px 0 var(--color-gold);
}
.brand-text{display:flex;flex-direction:column;line-height:1.1;color:#fff}
.brand-name{font-weight:800;color:#fff;font-size:1.06rem;letter-spacing:-.01em}
.brand-tag{font-size:.72rem;color:rgba(255,255,255,.65);letter-spacing:.06em;text-transform:uppercase;margin-top:3px}

/* === NAV === */
.main-nav{display:flex;align-items:center}
.main-nav ul.menu{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:2px}
.main-nav li{margin:0;position:relative}
.main-nav a{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 14px;border-radius:10px;
  font-weight:600;font-size:.94rem;color:rgba(255,255,255,.88);
  white-space:nowrap;
  transition:background-color .15s ease, color .15s ease;
}
/* breakpoint medi: ulteriore compattazione voci per stare sempre su una riga */
@media (max-width:1180px){
  .main-nav ul.menu{gap:0}
  .main-nav a{padding:10px 11px;font-size:.9rem;letter-spacing:-.005em}
}
.main-nav a:hover,
.main-nav .current-menu-item>a,
.main-nav .current_page_item>a,
.main-nav .current-menu-ancestor>a,
.main-nav .current-menu-parent>a{
  background:rgba(255,255,255,.08);color:#fff;
}
.main-nav .menu-item-has-children>a::after{
  content:"";width:6px;height:6px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;
  transform:rotate(45deg);margin-left:4px;margin-top:-2px;opacity:.7;
}

/* Dropdown desktop */
.main-nav .sub-menu{
  position:absolute;top:100%;left:0;
  margin-top:8px;
  list-style:none;padding:8px;
  background:var(--color-navy-deep);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  min-width:240px;
  box-shadow:0 18px 40px rgba(0,0,0,.4);
  opacity:0;visibility:hidden;pointer-events:none;
  transform:translateY(-4px);
  transition:opacity .15s ease, transform .15s ease, visibility .15s;
  z-index:120;
}
/* Ponte invisibile che copre il gap tra link parent e dropdown:
   mantiene l'hover continuo quando si sposta il mouse verso le voci */
.main-nav .sub-menu::before{
  content:"";position:absolute;
  top:-12px;left:0;right:0;height:12px;
  background:transparent;
}
.main-nav .menu-item-has-children:hover>.sub-menu,
.main-nav .menu-item-has-children:focus-within>.sub-menu{
  opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0);
}
.main-nav .sub-menu a{
  display:block;padding:11px 14px;border-radius:8px;
  color:rgba(255,255,255,.86);font-weight:500;font-size:.94rem;
  white-space:nowrap;
}
.main-nav .sub-menu a:hover{background:rgba(255,255,255,.08);color:#fff}

.header-cta{display:flex;align-items:center;gap:10px;margin-left:8px;flex-shrink:0}

.nav-toggle{
  display:none;background:transparent;border:0;padding:10px;
  color:#fff;cursor:pointer;border-radius:10px;flex-shrink:0;
}
.nav-toggle:hover{background:rgba(255,255,255,.08)}
.nav-toggle .ico{width:28px;height:28px;stroke-width:2.2}

@media (max-width:1080px){
  .header-cta .btn--ghost-light{display:none}
}
@media (max-width:980px){
  .container{padding:0 16px}
  .header-inner{gap:12px}
  .site-brand{gap:10px}
  .nav-toggle{
    display:inline-flex;align-items:center;justify-content:center;
    width:42px;height:42px;padding:0;border-radius:50%;
    background:rgba(255,255,255,.08);
  }
  .nav-toggle:hover{background:rgba(255,255,255,.16)}
  .nav-toggle .ico{width:22px;height:22px}
  .header-cta{gap:8px;margin-left:0}
  /* WhatsApp diventa icona tonda su mobile, mantiene area cliccabile generosa */
  .header-cta .btn--wa{
    width:42px;height:42px;min-height:42px;
    padding:0;border-radius:50%;
    font-size:0;line-height:0;flex-shrink:0;
    gap:0;
  }
  .header-cta .btn--wa .ico{width:22px;height:22px;font-size:initial}
  /* Drawer mobile fullscreen sotto l'header */
  .main-nav{
    position:fixed;top:var(--header-h);left:0;right:0;bottom:0;
    background:var(--color-navy-deep);padding:16px 18px 80px;
    display:block;
    transform:translateX(100%);transition:transform .25s ease;
    overflow-y:auto;-webkit-overflow-scrolling:touch;
    border-top:1px solid rgba(255,255,255,.08);
    z-index:110;
  }
  .main-nav.is-open{transform:translateX(0)}
  .main-nav ul.menu{
    list-style:none;margin:0;padding:0;
    display:block;width:100%;
  }
  .main-nav li{
    margin:0;padding:0;width:100%;display:block;position:relative;
  }
  .main-nav a{
    display:block;width:100%;box-sizing:border-box;
    padding:12px 14px;border-radius:10px;
    font-weight:600;font-size:1rem;line-height:1.25;
    color:rgba(255,255,255,.92);
    border:1px solid transparent;background:transparent;
    text-decoration:none;
  }
  .main-nav a:hover,.main-nav a:focus,
  .main-nav .current-menu-item>a{
    background:rgba(255,255,255,.08);
    border-color:rgba(255,255,255,.08);
    color:#fff;
  }
  /* Voce parent con sotto-menu: layout con chevron a destra */
  .main-nav .menu-item-has-children>a{
    display:flex;align-items:center;justify-content:space-between;
    padding-right:18px;gap:12px;
  }
  .main-nav .menu-item-has-children>a::after{
    content:"";
    width:9px;height:9px;
    border-right:2px solid currentColor;border-bottom:2px solid currentColor;
    transform:rotate(45deg);
    margin:-3px 0 0 0;opacity:.85;flex-shrink:0;display:block;
    transition:transform .2s ease;
  }
  .main-nav .menu-item-has-children.is-open>a::after{
    transform:rotate(225deg);margin-top:3px;
  }
  /* Sub-menu accordion: nascosto di default, visibile su .is-open */
  .main-nav .menu-item-has-children .sub-menu{
    position:static;background:transparent;border:0;
    padding:2px 0 6px 16px;margin:4px 0 4px 6px;
    box-shadow:none;min-width:0;
    transform:none;
    border-left:2px solid rgba(216,173,99,.35);
    display:none;
    opacity:1;visibility:visible;pointer-events:auto;
  }
  .main-nav .menu-item-has-children.is-open .sub-menu{display:block}
  .main-nav .sub-menu::before{display:none}
  .main-nav .sub-menu li{margin:0}
  .main-nav .sub-menu a{
    padding:10px 12px;font-size:.94rem;white-space:normal;
    color:rgba(255,255,255,.78);font-weight:500;
  }
  .main-nav .sub-menu a:hover{color:#fff}
}
@media (max-width:520px){
  .brand-text{display:none}
  .header-cta .btn--ghost{display:none}
}

/* === HERO scenografica === */
.hero{
  position:relative;overflow:hidden;isolation:isolate;
  background:
    radial-gradient(1100px 600px at 85% -15%, rgba(216,173,99,.20), transparent 60%),
    radial-gradient(900px 700px at -15% 115%, rgba(37,99,235,.36), transparent 60%),
    linear-gradient(160deg,#04111F 0%,var(--color-navy-deep) 45%,var(--color-navy-700) 100%);
  color:#fff;
  padding:140px 0 140px;
  text-align:center;
}
/* Grid pattern digitale discreto */
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 75% 70% at 50% 45%, #000 25%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 75% 70% at 50% 45%, #000 25%, transparent 80%);
}
/* Glow blu in alto a destra */
.hero::after{
  content:"";position:absolute;width:720px;height:720px;border-radius:50%;
  background:radial-gradient(circle, var(--color-blue) 0%, transparent 65%);
  opacity:.22;top:-280px;right:-220px;pointer-events:none;filter:blur(50px);z-index:0;
}
/* Glow oro in basso a sinistra (accento premium) */
.hero-glow{
  position:absolute;width:560px;height:560px;border-radius:50%;
  background:radial-gradient(circle, var(--color-gold) 0%, transparent 60%);
  opacity:.16;bottom:-260px;left:-180px;pointer-events:none;filter:blur(60px);z-index:0;
}
.hero > .container{position:relative;z-index:2;max-width:980px}
.hero .kicker{
  background:rgba(216,173,99,.16);color:var(--color-gold-soft);
  border:1px solid rgba(216,173,99,.30);
  font-size:.8rem;padding:8px 18px;
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.hero h1{
  color:#fff;margin-bottom:24px;
  font-size:clamp(2.5rem,5.4vw,4.2rem);
  font-weight:800;letter-spacing:-.03em;line-height:1.08;
}
.hero .lead{
  color:rgba(255,255,255,.86);
  font-size:clamp(1.12rem,1.7vw,1.36rem);
  margin:0 auto 8px;max-width:62ch;line-height:1.55;
}
.hero .cta-group{justify-content:center;margin-top:44px}
.hero .cta-group .btn{min-width:220px}

/* Hero badges trust (sotto le CTA, con più respiro) */
.hero-trust{
  margin-top:56px;display:flex;flex-wrap:wrap;gap:14px 28px;justify-content:center;
  color:rgba(255,255,255,.72);font-size:.92rem;
}
.hero-trust span{display:inline-flex;align-items:center;gap:8px}
.hero-trust .ico{color:var(--color-gold-soft);width:18px;height:18px;stroke-width:2.4}

@media (max-width:980px){
  .hero{padding:96px 0 110px}
}
@media (max-width:680px){
  .hero{padding:56px 0 80px}
  .hero h1{font-size:2.15rem;margin-bottom:16px;letter-spacing:-.025em}
  .hero .lead{font-size:1.06rem}
  .hero .cta-group{margin-top:32px;flex-direction:column;align-items:stretch;width:100%}
  .hero .cta-group .btn{width:100%;min-width:0}
  .hero-trust{margin-top:36px;font-size:.86rem;gap:10px 20px}
}

/* === HERO BENEFITS (3 micro-vantaggi con respiro) === */
.hero-benefits{margin-top:-68px;position:relative;z-index:3;padding-bottom:40px}
.hero-benefits .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.hero-benefit{
  background:#fff;border:1px solid var(--color-line);
  border-radius:var(--radius-lg);
  padding:26px 26px;display:flex;gap:16px;align-items:flex-start;
  box-shadow:var(--shadow-card);
  transition:transform .18s ease, box-shadow .18s ease;
}
.hero-benefit:hover{transform:translateY(-3px);box-shadow:var(--shadow-card-hover)}
.hero-benefit .b-ico{
  width:48px;height:48px;border-radius:14px;flex-shrink:0;
  background:linear-gradient(140deg,var(--color-blue),#1d4fd1);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 14px rgba(37,99,235,.28);
}
.hero-benefit .b-ico .ico{width:22px;height:22px;stroke-width:2.1}
.hero-benefit h4{margin:0 0 4px;font-size:1rem;color:var(--color-ink)}
.hero-benefit p{margin:0;font-size:.93rem;color:var(--color-muted);line-height:1.55}

@media (max-width:880px){
  .hero-benefits .grid{grid-template-columns:1fr;gap:14px}
  .hero-benefits{margin-top:-44px;padding-bottom:24px}
}

/* === DUAL BLOCKS (Le due anime del brand) === */
.dual{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.dual-card{
  background:#fff;border:1px solid var(--color-line);border-radius:var(--radius-xl);
  padding:46px 40px 40px;box-shadow:var(--shadow-card);
  display:flex;flex-direction:column;position:relative;overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.dual-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-card-hover);border-color:#cdd6e3}
/* LIV: variante chiara istituzionale con barra navy */
.dual-card::before{
  content:"";position:absolute;left:0;top:0;right:0;height:5px;
  background:var(--color-navy-deep);
}
/* Hub: variante tech scura con barra gradient blu→oro */
.dual-card.dual--digital{
  background:
    radial-gradient(700px 350px at 100% 0%, rgba(37,99,235,.26), transparent 60%),
    radial-gradient(550px 320px at 0% 100%, rgba(216,173,99,.22), transparent 60%),
    linear-gradient(160deg,#04111F 0%,var(--color-navy-deep) 50%,var(--color-navy-700) 100%);
  color:#fff;border:1px solid rgba(255,255,255,.08);
  box-shadow:0 24px 56px rgba(6,23,46,.28);
}
.dual-card.dual--digital h3,
.dual-card.dual--digital h4{color:#fff}
.dual-card.dual--digital p{color:rgba(255,255,255,.86)}
.dual-card.dual--digital::before{
  background:linear-gradient(90deg,var(--color-blue),var(--color-gold));
  height:4px;
}
/* Pattern grid digitale solo sulla card Hub */
.dual-card.dual--digital::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:36px 36px;
  mask-image:radial-gradient(ellipse 90% 80% at 70% 30%, #000 25%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 90% 80% at 70% 30%, #000 25%, transparent 80%);
  opacity:.7;
}
.dual-card.dual--digital > *{position:relative;z-index:1}

.dual-card .d-head{display:flex;align-items:center;gap:16px;margin-bottom:16px}
.dual-card .d-ico{
  width:64px;height:64px;border-radius:16px;flex-shrink:0;
  background:var(--color-navy-deep);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 18px rgba(6,23,46,.22);
}
.dual-card.dual--digital .d-ico{
  background:linear-gradient(140deg,var(--color-blue),#0F2A4A);color:#fff;
  box-shadow:0 10px 24px rgba(37,99,235,.46), inset 0 0 0 1px rgba(255,255,255,.10);
}
.dual-card .d-ico .ico{width:28px;height:28px;stroke-width:2.1}
.dual-card .dual-tag{
  font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.16em;
  color:var(--color-navy-deep);
  padding:5px 10px;border-radius:999px;background:rgba(6,23,46,.06);
}
.dual-card.dual--digital .dual-tag{
  color:var(--color-gold-soft);
  background:rgba(216,173,99,.14);border:1px solid rgba(216,173,99,.28);
}
.dual-card h3{font-size:clamp(1.45rem,2.3vw,1.75rem);margin:8px 0 14px;font-weight:800;letter-spacing:-.022em;line-height:1.2}
.dual-card p{font-size:1.04rem;flex-grow:1;line-height:1.65}
.dual-card .dual-points{
  list-style:none;padding:0;margin:18px 0 28px;
  display:grid;grid-template-columns:1fr 1fr;gap:10px 18px;
}
.dual-card .dual-points li{
  font-size:.93rem;color:var(--color-muted);
  display:flex;gap:8px;align-items:flex-start;margin:0;
}
.dual-card .dual-points li .ico{color:var(--color-blue);width:18px;height:18px;flex-shrink:0;margin-top:3px}
.dual-card.dual--digital .dual-points li{color:rgba(255,255,255,.85)}
.dual-card.dual--digital .dual-points li .ico{color:var(--color-gold-soft)}
.dual-card .btn{align-self:flex-start;margin-top:auto}
@media (max-width:880px){
  .dual{grid-template-columns:1fr;gap:22px}
  .dual-card{padding:34px 24px 30px}
  .dual-card .dual-points{grid-template-columns:1fr;margin:14px 0 22px}
  .dual-card .btn{width:100%;align-self:stretch}
}

/* === TIMELINE (Come funziona) === */
.timeline{
  position:relative;
  display:grid;grid-template-columns:repeat(5,1fr);gap:22px;
  counter-reset:liv-step;
}
.timeline::before{
  content:"";position:absolute;top:24px;left:9%;right:9%;
  height:2px;background:linear-gradient(90deg,var(--color-blue),var(--color-gold));
  opacity:.4;z-index:0;
}
.t-step{
  position:relative;text-align:center;
  background:#fff;border-radius:var(--radius);
  padding:64px 18px 22px;
  border:1px solid var(--color-line);
  box-shadow:var(--shadow-soft);
  z-index:1;
  transition:transform .18s ease, box-shadow .18s ease;
}
.t-step:hover{transform:translateY(-3px);box-shadow:var(--shadow-card)}
.t-step::before{
  counter-increment:liv-step;content:counter(liv-step);
  position:absolute;top:-2px;left:50%;transform:translate(-50%,-50%);
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(140deg,var(--color-blue),#1d4fd1);color:#fff;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 20px rgba(37,99,235,.35);font-size:1.06rem;
  border:4px solid #fff;
}
.t-step h4{margin:8px 0 6px;color:var(--color-ink);font-size:1rem;line-height:1.35}
.t-step p{color:var(--color-muted);font-size:.92rem;margin:0;line-height:1.55}
@media (max-width:980px){
  .timeline{grid-template-columns:1fr;gap:14px}
  .timeline::before{
    top:0;bottom:0;left:24px;right:auto;width:2px;height:auto;
    background:linear-gradient(180deg,var(--color-blue),var(--color-gold));
  }
  .t-step{
    text-align:left;padding:22px 22px 22px 86px;
  }
  .t-step::before{
    top:50%;left:24px;transform:translate(-50%,-50%);
  }
}

/* === GRID / CARD === */
.grid{display:grid;gap:24px}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
@media (max-width:980px){.grid--3{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.grid--3,.grid--2{grid-template-columns:1fr;gap:18px}}

.card{
  background:#fff;border:1px solid var(--color-line);border-radius:var(--radius-lg);
  padding:32px 28px;transition:all .2s ease;
  display:flex;flex-direction:column;
  position:relative;color:inherit;text-decoration:none;
  overflow:hidden;
}
.card::after{
  content:"";position:absolute;left:0;right:0;top:0;height:3px;
  background:linear-gradient(90deg,var(--color-blue),var(--color-gold));
  transform:scaleX(0);transform-origin:left;transition:transform .25s ease;
}
.card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-card-hover);
  border-color:#cdd6e3;color:inherit;
}
.card:hover::after{transform:scaleX(1)}
.card-ico{
  width:56px;height:56px;border-radius:14px;
  background:var(--color-surface-2);
  border:1px solid var(--color-line-soft);
  display:flex;align-items:center;justify-content:center;
  color:var(--color-blue);margin-bottom:20px;
  transition:background .2s ease, color .2s ease;
}
.card:hover .card-ico{background:var(--color-blue);color:#fff;border-color:var(--color-blue)}
.card-ico .ico{width:26px;height:26px;stroke-width:1.9}
.card h3{font-size:1.18rem;margin-bottom:10px}
.card p{color:var(--color-muted);font-size:.98rem;margin-bottom:18px;flex-grow:1;line-height:1.6}
.card .card-link{
  font-weight:700;color:var(--color-blue);font-size:.94rem;
  display:inline-flex;align-items:center;gap:6px;margin-top:auto;
}
.card .card-link .ico{width:1em;height:1em;transition:transform .15s ease}
.card:hover .card-link .ico{transform:translateX(4px)}

/* Audience cards */
.audience-card{
  background:#fff;border:1px solid var(--color-line);border-radius:var(--radius-lg);
  padding:32px 24px;text-align:center;transition:all .2s ease;
}
.audience-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover);border-color:#cdd6e3}
.audience-card .card-ico{
  margin:0 auto 18px;width:64px;height:64px;
  background:linear-gradient(140deg,var(--color-navy-deep),var(--color-navy-700));
  color:var(--color-gold-soft);border-color:var(--color-navy-deep);
}
.audience-card .card-ico .ico{width:28px;height:28px}
.audience-card h3{font-size:1.1rem;margin-bottom:6px}
.audience-card p{font-size:.92rem;color:var(--color-muted);margin:0;line-height:1.55}

/* === SERVICE BLOCK === */
.service-block{
  background:#fff;border:1px solid var(--color-line);border-radius:var(--radius-lg);
  padding:32px;margin-bottom:20px;
  display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:center;
  transition:box-shadow .2s ease, border-color .2s ease, transform .2s ease;
}
.service-block:hover{box-shadow:var(--shadow-card-hover);border-color:#cdd6e3;transform:translateY(-2px)}
.service-block .card-ico{margin-bottom:0;width:64px;height:64px}
.service-block .card-ico .ico{width:30px;height:30px}
.service-block h3{margin:0 0 8px;font-size:1.35rem}
.service-block ul{margin:8px 0 0;padding-left:20px;color:var(--color-muted);columns:2;column-gap:36px}
.service-block ul li{break-inside:avoid;font-size:.95rem}
.service-block .btn{white-space:nowrap}
@media (max-width:880px){
  .service-block{grid-template-columns:1fr;text-align:left;padding:24px;gap:18px}
  .service-block ul{columns:1}
  .service-block .btn{width:100%;justify-self:stretch}
}

/* === FEATURE LIST === */
.feature-list{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px;
}
.feature-list li{
  display:flex;gap:12px;align-items:flex-start;
  background:#fff;padding:16px 18px;border-radius:var(--radius);
  border:1px solid var(--color-line);font-size:.97rem;
}
.feature-list .ico{color:var(--color-blue);margin-top:.15em;flex-shrink:0;stroke-width:2.4;width:1em;height:1em}
.feature-list--1{grid-template-columns:1fr}
.feature-list--2{grid-template-columns:repeat(2,1fr)}
.feature-list--3{grid-template-columns:repeat(3,1fr)}
@media (max-width:980px){.feature-list--3{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.feature-list,.feature-list--2,.feature-list--3{grid-template-columns:1fr}}

/* === ROMA DIGITAL HUB — sezione full-bleed scenografica === */
.section--hub{
  background:
    radial-gradient(900px 450px at 90% -10%, rgba(37,99,235,.32), transparent 60%),
    radial-gradient(700px 450px at -10% 110%, rgba(216,173,99,.22), transparent 60%),
    linear-gradient(160deg,#04111F 0%,var(--color-navy-deep) 50%,var(--color-navy-700) 100%);
  color:#fff;position:relative;overflow:hidden;
  padding:120px 0;
}
.section--hub::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size:46px 46px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 40%, #000 25%, transparent 85%);
  -webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 40%, #000 25%, transparent 85%);
  opacity:.65;
}
.section--hub > .container{position:relative;z-index:2}
.section--hub h2,.section--hub h3,.section--hub h4{color:#fff}
.section--hub .lead{color:rgba(255,255,255,.84);max-width:62ch}
.section--hub .section-head .kicker{
  background:rgba(216,173,99,.16);color:var(--color-gold-soft);
  border:1px solid rgba(216,173,99,.32);
}

.hub-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:48px;
}
.hub-pill{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--radius-lg);padding:28px 26px;
  display:flex;flex-direction:column;gap:14px;
  position:relative;overflow:hidden;
  transition:background .25s ease, border-color .25s ease, transform .25s ease, box-shadow .25s ease;
}
.hub-pill::after{
  content:"";position:absolute;left:0;right:0;top:0;height:2px;
  background:linear-gradient(90deg,var(--color-blue),var(--color-gold));
  transform:scaleX(0);transform-origin:left;transition:transform .3s ease;
}
.hub-pill:hover{
  background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.22);
  transform:translateY(-4px);
  box-shadow:0 18px 40px rgba(0,0,0,.32);
}
.hub-pill:hover::after{transform:scaleX(1)}
.hub-pill .p-ico{
  width:54px;height:54px;border-radius:14px;flex-shrink:0;
  background:linear-gradient(140deg,var(--color-blue),#1d4fd1);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 20px rgba(37,99,235,.42), inset 0 0 0 1px rgba(255,255,255,.10);
}
.hub-pill .p-ico .ico{width:24px;height:24px;stroke-width:2}
.hub-pill h4{margin:0 0 6px;font-size:1.06rem;color:#fff;letter-spacing:-.01em}
.hub-pill p{margin:0;font-size:.92rem;color:rgba(255,255,255,.74);line-height:1.55}

.section--hub .cta-group{justify-content:center;margin-top:0}

@media (max-width:980px){
  .section--hub{padding:80px 0}
  .hub-grid{grid-template-columns:repeat(2,1fr);gap:16px}
}
@media (max-width:680px){
  .section--hub{padding:64px 0}
  .hub-grid{grid-template-columns:1fr;gap:14px;margin-bottom:32px}
  .hub-pill{padding:22px 22px}
  .section--hub .cta-group{flex-direction:column;align-items:stretch}
  .section--hub .cta-group .btn{width:100%;white-space:normal;line-height:1.25;min-height:54px}
}

/* === Vecchio .hub-feature: alias che ridirige al nuovo stile, mantenuto per altre pagine === */
.hub-feature{
  background:
    radial-gradient(700px 350px at 90% 0%, rgba(37,99,235,.30), transparent 60%),
    radial-gradient(500px 350px at -10% 110%, rgba(216,173,99,.20), transparent 60%),
    linear-gradient(160deg,var(--color-navy-deep) 0%,var(--color-navy) 100%);
  color:#fff;border-radius:var(--radius-xl);
  padding:72px 60px;position:relative;overflow:hidden;
  border:1px solid rgba(255,255,255,.06);
}
.hub-feature::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:40px 40px;
  mask-image:radial-gradient(ellipse 100% 100% at 60% 40%, #000 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 100% 100% at 60% 40%, #000 30%, transparent 80%);
  opacity:.6;
}
.hub-feature > *{position:relative;z-index:2}
.hub-feature .kicker{background:rgba(234,199,143,.14);color:var(--color-gold-soft)}
.hub-feature h2{color:#fff;max-width:20ch;margin-bottom:14px}
.hub-feature .lead{color:rgba(255,255,255,.85);max-width:62ch;margin-bottom:40px}
.hub-feature .hub-grid{margin-bottom:40px}
@media (max-width:680px){
  .hub-feature{padding:44px 24px}
  .hub-feature .cta-group{flex-direction:column;align-items:stretch}
  .hub-feature .cta-group .btn{width:100%;white-space:normal;line-height:1.25;min-height:54px}
}

/* === FIDUCIA (4 vantaggi premium) === */
.benefits-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.benefit-card{
  background:#fff;border:1px solid var(--color-line);border-radius:var(--radius-lg);
  padding:30px 26px;text-align:left;transition:all .2s ease;
  position:relative;overflow:hidden;
}
.benefit-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover)}
.benefit-card .b-ico{
  width:54px;height:54px;border-radius:14px;
  background:linear-gradient(140deg,var(--color-blue),var(--color-blue-soft));color:#fff;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;box-shadow:0 6px 16px rgba(37,99,235,.32);
}
.benefit-card .b-ico .ico{width:26px;height:26px;stroke-width:2}
.benefit-card h3{font-size:1.05rem;margin-bottom:8px}
.benefit-card p{color:var(--color-muted);font-size:.94rem;margin:0;line-height:1.6}
@media (max-width:1080px){.benefits-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.benefits-grid{grid-template-columns:1fr}}

/* === TRUST (CTA finale premium) === */
.trust{
  background:
    radial-gradient(700px 360px at 90% 0%, rgba(37,99,235,.32), transparent 60%),
    radial-gradient(600px 360px at -10% 110%, rgba(216,173,99,.22), transparent 60%),
    linear-gradient(160deg,#04111F 0%,var(--color-navy-deep) 50%,var(--color-navy-700) 100%);
  color:#fff;border-radius:var(--radius-xl);padding:72px 60px;
  position:relative;overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 24px 70px rgba(6,23,46,.22);
  text-align:center;
}
.trust::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size:42px 42px;
  mask-image:radial-gradient(ellipse 80% 100% at 50% 50%, #000 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 100% at 50% 50%, #000 30%, transparent 80%);
  opacity:.6;
}
/* Bordo gradient sottile sopra */
.trust--premium::after{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--color-blue),var(--color-gold),transparent);
  opacity:.7;
}
.trust > *{position:relative;z-index:2}
.trust .kicker{
  background:rgba(216,173,99,.16);color:var(--color-gold-soft);
  border:1px solid rgba(216,173,99,.30);
}
.trust h2{
  color:#fff;max-width:24ch;margin-left:auto;margin-right:auto;
  font-size:clamp(1.9rem,3.4vw,2.6rem);
}
.trust p{color:rgba(255,255,255,.86);max-width:62ch;margin:0 auto 10px;font-size:1.06rem}
.trust .cta-group{justify-content:center;margin-top:34px}
@media (max-width:680px){
  .trust{padding:48px 24px}
  .trust .cta-group{flex-direction:column;align-items:stretch}
  .trust .cta-group .btn{width:100%;white-space:normal;line-height:1.25;min-height:54px}
}

/* === FAQ === */
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq{
  background:#fff;border:1px solid var(--color-line);border-radius:var(--radius);
  padding:0;overflow:hidden;
}
.faq summary{
  list-style:none;cursor:pointer;padding:22px 26px;
  font-weight:700;color:var(--color-ink);font-size:1.02rem;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-size:1.6rem;line-height:1;color:var(--color-blue);
  transition:transform .2s ease;flex-shrink:0;
}
.faq[open] summary::after{content:"−"}
.faq[open] summary{border-bottom:1px solid var(--color-line)}
.faq-body{padding:20px 26px;color:var(--color-muted);font-size:.98rem;line-height:1.65}
.faq-body p:last-child{margin-bottom:0}

/* === CONTACT === */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:start}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr;gap:28px}}
.contact-info{
  background:#fff;border:1px solid var(--color-line);border-radius:var(--radius-lg);
  padding:32px;display:flex;flex-direction:column;gap:22px;
}
.contact-row{display:flex;gap:16px;align-items:flex-start}
.contact-row .card-ico{margin:0;flex-shrink:0;width:48px;height:48px}
.contact-row .card-ico .ico{width:22px;height:22px}
.contact-row strong{display:block;color:var(--color-ink);font-size:.95rem;margin-bottom:4px}
.contact-row span,.contact-row a{color:var(--color-muted);font-size:.98rem;line-height:1.5}

.form-card{
  background:#fff;border:1px solid var(--color-line);border-radius:var(--radius-lg);
  padding:32px;
}
.form-row{margin-bottom:16px;display:flex;flex-direction:column;gap:8px}
.form-row label{font-weight:600;font-size:.92rem;color:var(--color-ink)}
.form-row label .req{color:var(--color-bordeaux);margin-left:2px}
.form-row input,.form-row select,.form-row textarea{
  width:100%;padding:14px 16px;border:1.5px solid var(--color-line);
  border-radius:12px;font:inherit;color:var(--color-ink);
  background:#fff;transition:border-color .15s ease, box-shadow .15s ease;
  font-size:1rem;
}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{
  outline:none;border-color:var(--color-blue);box-shadow:0 0 0 4px rgba(37,99,235,.16);
}
.form-row textarea{min-height:140px;resize:vertical}
.form-checkbox{display:flex;gap:12px;align-items:flex-start;font-size:.9rem;color:var(--color-muted);line-height:1.55}
.form-checkbox input{width:auto;margin-top:3px;flex-shrink:0}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:520px){.form-grid{grid-template-columns:1fr}}
.form-feedback{padding:16px;border-radius:12px;margin-bottom:18px;font-weight:600}
.form-feedback.success{background:rgba(31,138,77,.1);color:#1f8a4d;border:1px solid rgba(31,138,77,.3)}
.form-feedback.error{background:rgba(140,31,44,.08);color:var(--color-bordeaux);border:1px solid rgba(140,31,44,.25)}
.map-embed{
  border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-line);
  margin-top:24px;
}
.map-embed iframe{display:block;width:100%;height:340px;border:0}

/* === PAGE HEADER === */
.page-header{
  background:
    radial-gradient(700px 350px at 90% -10%, rgba(37,99,235,.26), transparent 60%),
    radial-gradient(500px 350px at -10% 110%, rgba(216,173,99,.18), transparent 60%),
    linear-gradient(160deg,var(--color-navy-deep) 0%,var(--color-navy-700) 100%);
  color:#fff;padding:84px 0 96px;position:relative;overflow:hidden;
}
.page-header::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:40px 40px;
  mask-image:radial-gradient(ellipse 60% 80% at 50% 40%, #000 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 60% 80% at 50% 40%, #000 30%, transparent 80%);
  opacity:.55;
}
.page-header > .container{position:relative;z-index:2}
.page-header h1{color:#fff;margin-bottom:14px;max-width:24ch}
.page-header-row{display:flex;gap:22px;align-items:flex-start;flex-wrap:wrap}
.page-header-ico{
  width:64px;height:64px;border-radius:14px;flex-shrink:0;
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);
  color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 20px rgba(0,0,0,.18);
}
.page-header-ico .ico{width:30px;height:30px;stroke-width:2}
.page-header-text{flex:1;min-width:260px}
.page-header-text h1{margin-top:6px}
.page-header .lead{color:rgba(255,255,255,.88);max-width:65ch}
.page-header .cta-group{margin-top:32px}
.breadcrumbs{font-size:.86rem;color:rgba(255,255,255,.68);margin-bottom:20px}
.breadcrumbs a{color:rgba(255,255,255,.88);text-decoration:underline;text-underline-offset:3px}
@media (max-width:680px){
  .page-header{padding:54px 0 64px}
  .page-header .cta-group{flex-direction:column;align-items:stretch}
  .page-header .cta-group .btn{width:100%}
}

/* === SINGLE SERVICE PAGE === */
.service-layout{display:grid;grid-template-columns:1fr 340px;gap:40px;align-items:start}
@media (max-width:980px){.service-layout{grid-template-columns:1fr}}
.service-content{
  background:#fff;padding:40px;border-radius:var(--radius-lg);
  border:1px solid var(--color-line);
}
.service-content > :first-child{margin-top:0}
.service-content h2{font-size:1.5rem;margin-top:1.6em}
.service-content h2:first-child{margin-top:0}
.service-content ul li{margin:.45em 0}
.service-aside{
  background:#fff;padding:28px;border-radius:var(--radius-lg);
  border:1px solid var(--color-line);
  position:sticky;top:calc(var(--header-h) + 16px);
  display:flex;flex-direction:column;gap:14px;
}
.service-aside h3{font-size:1.1rem;margin:0}
.service-aside p{font-size:.94rem;color:var(--color-muted);margin:0}
.service-aside .btn{width:100%}
@media (max-width:680px){.service-content{padding:28px 22px}}

/* === FOOTER PREMIUM === */
.site-footer{
  background:linear-gradient(180deg,var(--color-navy-deep) 0%,#040E1C 100%);
  color:rgba(255,255,255,.78);padding:80px 0 24px;margin-top:0;
  border-top:1px solid rgba(255,255,255,.06);
  position:relative;overflow:hidden;
}
.site-footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--color-blue),var(--color-gold),transparent);
  opacity:.4;
}
.site-footer a{color:rgba(255,255,255,.85)}
.site-footer a:hover{color:var(--color-gold-soft)}

.footer-cta{
  background:
    radial-gradient(500px 240px at 90% 0%, rgba(37,99,235,.32), transparent 60%),
    radial-gradient(400px 240px at 0% 100%, rgba(216,173,99,.20), transparent 60%),
    linear-gradient(140deg,var(--color-navy-700) 0%,var(--color-navy-deep) 100%);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-xl);padding:36px 40px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  margin-bottom:60px;
}
.footer-cta h3{color:#fff;margin:0 0 6px;font-size:1.3rem}
.footer-cta p{color:rgba(255,255,255,.78);margin:0;font-size:.96rem}
.footer-cta .cta-group{margin-top:0}
@media (max-width:780px){
  .footer-cta{flex-direction:column;align-items:flex-start;padding:28px 24px}
  .footer-cta .cta-group{width:100%}
  .footer-cta .cta-group .btn{flex:1}
}

.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr;gap:0}}
.footer-col h4{
  color:#fff;font-size:.9rem;letter-spacing:.1em;text-transform:uppercase;
  margin:0 0 18px;font-weight:700;
  position:relative;padding-bottom:8px;display:inline-block;
}
.footer-col h4::after{
  content:"";position:absolute;left:0;bottom:0;width:32px;height:2px;
  background:var(--color-gold);border-radius:2px;
}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin:.6em 0;font-size:.93rem}
.footer-col li .ico{width:.95em;height:.95em;color:var(--color-gold-soft);margin-right:6px}
.footer-brand p{margin-top:18px;font-size:.95rem;line-height:1.7;max-width:42ch;color:rgba(255,255,255,.7)}
.footer-contact-list{margin-top:20px}
.footer-contact-list li{margin:.5em 0;font-size:.95rem}

/* Accordion footer (open by default on desktop) */
.footer-acc{padding:0;background:transparent;border:0}
.footer-acc > summary{
  list-style:none;cursor:default;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.footer-acc > summary::-webkit-details-marker{display:none}
.footer-acc > summary > h4{margin:0}
.footer-acc[open] > summary{margin-bottom:6px}

@media (min-width:881px){
  /* su desktop: sempre aperto via JS, niente toggle interattivo */
  .footer-acc{display:block}
  .footer-acc > summary{pointer-events:none}
  .footer-acc ul{display:block!important}
}

@media (max-width:880px){
  .footer-grid{margin-bottom:36px}
  .footer-col{padding:18px 0;border-top:1px solid rgba(255,255,255,.10)}
  .footer-col.footer-brand{padding-top:0;border-top:0}
  .footer-acc > summary{cursor:pointer;padding:6px 0}
  .footer-acc > summary > h4{margin:0;display:inline-block}
  .footer-acc > summary::after{
    content:"+";font-size:1.4rem;line-height:1;
    color:var(--color-gold-soft);transition:transform .2s ease;flex-shrink:0;
  }
  .footer-acc[open] > summary::after{content:"−"}
  .footer-acc[open]{padding-bottom:22px}
  .footer-acc ul{padding-top:8px}
}
.footer-logo{
  display:inline-flex;align-items:center;
  line-height:0;margin-bottom:6px;
  transition:opacity .18s ease;
}
.footer-logo:hover{opacity:.92}
.footer-logo img{height:64px;width:auto;display:block}
@media (max-width:520px){.footer-logo img{height:54px}}

.footer-bottom{
  border-top:1px solid rgba(255,255,255,.10);padding-top:22px;
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;
  font-size:.86rem;color:rgba(255,255,255,.58);
}

/* === WHATSAPP FLOAT === */
.wa-float{
  position:fixed;right:20px;bottom:20px;z-index:999;
  width:64px;height:64px;border-radius:50%;
  background:var(--color-whatsapp);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 14px 32px rgba(37,211,102,.45);
  transition:transform .2s ease, box-shadow .2s ease;
}
.wa-float:hover{transform:scale(1.06);color:#fff;box-shadow:0 18px 40px rgba(37,211,102,.55)}
.wa-float svg{width:32px;height:32px;fill:#fff;stroke:none}
.wa-float::after{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  border:2px solid var(--color-whatsapp);opacity:.45;
  animation:waPulse 2.2s infinite;
}
@keyframes waPulse{0%{transform:scale(.85);opacity:.55}100%{transform:scale(1.5);opacity:0}}
.wa-float-label{
  position:absolute;right:76px;top:50%;transform:translateY(-50%);
  background:var(--color-navy-deep);color:#fff;padding:9px 14px;border-radius:10px;
  font-size:.84rem;font-weight:600;white-space:nowrap;
  box-shadow:var(--shadow-card);opacity:0;pointer-events:none;
  transition:opacity .2s ease;
}
.wa-float:hover .wa-float-label{opacity:1}
@media (max-width:520px){
  .wa-float{width:58px;height:58px;right:16px;bottom:16px}
  .wa-float svg{width:28px;height:28px}
  .wa-float-label{display:none}
}

/* === UTILITIES === */
.text-center{text-align:center}
.mt-0{margin-top:0!important}.mt-1{margin-top:10px}.mt-2{margin-top:18px}.mt-3{margin-top:28px}.mt-4{margin-top:40px}
.mb-0{margin-bottom:0!important}.mb-2{margin-bottom:18px}.mb-3{margin-bottom:28px}.mb-4{margin-bottom:40px}
.alignleft{float:left;margin:0 1.2em .8em 0}
.alignright{float:right;margin:0 0 .8em 1.2em}
.aligncenter{display:block;margin-left:auto;margin-right:auto}
.screen-reader-text{position:absolute;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}

/* admin bar offset */
body.admin-bar .site-header{top:32px}
@media (max-width:782px){body.admin-bar .site-header{top:46px}}

/* Section mobile padding */
@media (max-width:680px){
  .section{padding:64px 0}
  .section--tight{padding:40px 0}
  .section-head{margin-bottom:36px}
}

/* Touch: disable hover lift */
@media (hover:none){
  .card:hover,.audience-card:hover,.dual-card:hover,.service-block:hover,
  .hero-benefit:hover,.t-step:hover,.benefit-card:hover,.hub-pill:hover{transform:none;box-shadow:var(--shadow-soft)}
  .btn:hover{transform:none}
}

/* =================================================================
   LIV POPUP PROMO
================================================================= */
.liv-popup{
  position:fixed;inset:0;z-index:1000;
  display:none;align-items:center;justify-content:center;
  padding:20px;opacity:0;transition:opacity .25s ease;
}
.liv-popup.is-open{display:flex;opacity:1}
.liv-popup__overlay{
  position:absolute;inset:0;
  background:rgba(6,23,46,.66);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.liv-popup__dialog{
  position:relative;z-index:2;
  width:100%;max-width:560px;
  background:#fff;border-radius:22px;
  box-shadow:0 30px 80px rgba(6,23,46,.45);
  overflow:hidden;display:flex;flex-direction:column;
  transform:translateY(20px) scale(.97);
  transition:transform .35s cubic-bezier(.22,.97,.4,1.05);
  max-height:calc(100vh - 40px);
}
.liv-popup.is-open .liv-popup__dialog{transform:translateY(0) scale(1)}
.liv-popup__close{
  position:absolute;top:14px;right:14px;z-index:3;
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.92);color:var(--color-navy-deep);
  border:0;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 12px rgba(6,23,46,.18);
  transition:transform .15s ease, background .15s ease;
}
.liv-popup__close:hover{background:#fff;transform:scale(1.06)}
.liv-popup__close .ico{width:18px;height:18px;stroke-width:2.4}
.liv-popup__visual{
  position:relative;overflow:hidden;
  background:
    radial-gradient(600px 280px at 80% -20%, rgba(216,173,99,.32), transparent 60%),
    radial-gradient(500px 280px at -10% 110%, rgba(37,99,235,.40), transparent 60%),
    linear-gradient(160deg,var(--color-navy-deep) 0%,var(--color-navy-700) 100%);
  color:#fff;
  padding:44px 36px 32px;
  display:flex;align-items:center;justify-content:center;
}
.liv-popup__icon{
  width:88px;height:88px;border-radius:22px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);
  display:flex;align-items:center;justify-content:center;
  color:var(--color-gold-soft);position:relative;z-index:2;
  box-shadow:0 12px 28px rgba(0,0,0,.28);
}
.liv-popup__icon .ico{width:44px;height:44px;stroke-width:2}
.liv-popup__deco{
  position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,.07) 0 1px, transparent 1px),
    radial-gradient(circle at 75% 70%, rgba(255,255,255,.07) 0 1px, transparent 1px);
  background-size:22px 22px;opacity:.8;
}
.liv-popup__body{padding:30px 36px 32px;display:flex;flex-direction:column;overflow-y:auto}
.liv-popup__eyebrow{
  display:inline-flex;align-items:center;align-self:flex-start;
  font-size:.74rem;font-weight:800;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--color-blue);
  padding:6px 12px;border-radius:999px;
  background:rgba(37,99,235,.10);
  margin-bottom:14px;
}
.liv-popup__title{
  font-size:clamp(1.55rem,3vw,1.95rem);font-weight:800;
  color:var(--color-ink);letter-spacing:-.02em;line-height:1.2;
  margin:0 0 10px;
}
.liv-popup__subtitle{margin:0 0 18px;color:var(--color-muted);font-size:1.02rem;line-height:1.55}
.liv-popup__bullets{
  list-style:none;padding:0;margin:0 0 24px;
  display:flex;flex-direction:column;gap:10px;
}
.liv-popup__bullets li{display:flex;align-items:flex-start;gap:10px;font-size:.96rem;color:var(--color-text);margin:0}
.liv-popup__bullets .ico{color:var(--color-blue);width:20px;height:20px;flex-shrink:0;margin-top:.15em;stroke-width:2.4}
.liv-popup__cta{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.liv-popup__cta .btn{justify-content:center}
.liv-popup__foot{margin:0;text-align:center;font-size:.82rem;color:var(--color-muted)}
@media (max-width:560px){
  .liv-popup{padding:0;align-items:flex-end}
  .liv-popup__dialog{max-width:100%;border-radius:22px 22px 0 0;max-height:92vh}
  .liv-popup__visual{padding:34px 24px 26px}
  .liv-popup__icon{width:74px;height:74px;border-radius:18px}
  .liv-popup__icon .ico{width:36px;height:36px}
  .liv-popup__body{padding:24px 22px 26px}
  .liv-popup__title{font-size:1.45rem}
}
body.liv-popup-open{overflow:hidden}
@media (prefers-reduced-motion:reduce){
  .liv-popup,.liv-popup__dialog{transition:none!important;animation:none!important}
}

/* =========================================================
   SERVIZI ONLINE PAGE  (scoped: .so-*)
   Pagina autonoma /servizi-online/ — non tocca altre regole.
   Palette: navy #06172E · blu #0F2A4A · oro #D8AD63
            verde WA #25D366 · bianco · grigio #F5F7FA
            testo #172033 · muted #667487
   ========================================================= */
:root{
  --so-navy:#06172E;
  --so-blue:#0F2A4A;
  --so-gold:#D8AD63;
  --so-wa:#25D366;
  --so-bg:#F5F7FA;
  --so-text:#172033;
  --so-muted:#667487;
  --so-line:rgba(7,23,46,.08);
}

/* HERO --------------------------------------------------- */
.so-hero{
  background:
    radial-gradient(900px 420px at 80% 8%, rgba(216,173,99,.18), transparent 60%),
    radial-gradient(700px 380px at 12% 92%, rgba(64,123,255,.20), transparent 60%),
    linear-gradient(160deg, var(--so-navy) 0%, var(--so-blue) 60%, #0A1F3C 100%);
}
.so-hero h1{color:#fff}
.so-hero .lead{color:rgba(255,255,255,.86)}
.so-hero .kicker{
  background:rgba(216,173,99,.18);
  color:var(--so-gold);
  border:1px solid rgba(216,173,99,.35);
}

/* SECTION WRAPPER --------------------------------------- */
.so-section{position:relative}
.so-section .section-head h2{letter-spacing:-.01em}

/* === SCEGLI IL SERVIZIO (4 PICK CARD) ================== */
.so-pick-grid{
  display:grid;gap:20px;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
}
@media (min-width:900px){
  .so-pick-grid{grid-template-columns:repeat(4, 1fr)}
}
.so-pick{
  position:relative;
  background:#fff;
  border:1px solid var(--so-line);
  border-radius:22px;
  padding:26px 22px 22px;
  display:flex;flex-direction:column;gap:12px;
  box-shadow:0 2px 10px rgba(6,23,46,.05);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  overflow:hidden;
}
.so-pick::after{
  content:"";position:absolute;inset:0;border-radius:22px;pointer-events:none;
  border:1px solid transparent;transition:border-color .22s ease;
}
.so-pick:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 40px rgba(6,23,46,.12);
  border-color:rgba(15,42,74,.18);
}
.so-pick:hover::after{border-color:rgba(216,173,99,.35)}
.so-pick__ico{
  width:54px;height:54px;border-radius:14px;
  display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, rgba(15,42,74,.10), rgba(216,173,99,.10));
  color:var(--so-navy);
  margin-bottom:4px;
}
.so-pick__ico .ico{width:26px;height:26px;stroke-width:2}
.so-pick h3{margin:0;font-size:1.18rem;color:var(--so-navy);letter-spacing:-.005em}
.so-pick p{margin:0;color:var(--so-muted);font-size:.96rem;line-height:1.55;flex:1}
.so-pick .btn{margin-top:6px;justify-content:space-between;gap:10px}
.so-pick .btn .ico{transition:transform .15s ease}
.so-pick:hover .btn .ico{transform:translateX(3px)}

/* === GRID GRATUITI / A PAGAMENTO ======================= */
.so-grid{display:grid;gap:18px;grid-template-columns:1fr}
@media (min-width:640px){
  .so-grid--3{grid-template-columns:repeat(2,1fr)}
}
@media (min-width:980px){
  .so-grid--3{grid-template-columns:repeat(3,1fr)}
}

.so-card{
  position:relative;background:#fff;
  border:1px solid var(--so-line);border-radius:20px;
  padding:24px 22px 22px;
  display:flex;flex-direction:column;gap:10px;
  box-shadow:0 2px 8px rgba(6,23,46,.04);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.so-card:hover{
  transform:translateY(-3px);
  box-shadow:0 16px 36px rgba(6,23,46,.10);
}
.so-card h3{margin:.2em 0 0;font-size:1.08rem;color:var(--so-navy)}
.so-card p{margin:0;color:var(--so-muted);font-size:.94rem;line-height:1.55;flex:1}
.so-card .card-ico{
  width:50px;height:50px;border-radius:12px;
  background:rgba(15,42,74,.06);color:var(--so-navy);border:none;
  margin-bottom:4px;
}
.so-card .card-ico .ico{width:24px;height:24px;stroke-width:2}
.so-card .card-link{
  margin-top:auto;color:var(--so-navy);font-weight:600;
  display:inline-flex;align-items:center;gap:6px;
  text-decoration:none;font-size:.95rem;
}
.so-card .card-link:hover{color:var(--so-gold)}
.so-card .card-link .ico{width:1em;height:1em;transition:transform .15s ease}
.so-card .card-link:hover .ico{transform:translateX(3px)}

/* Tag badges */
.so-tag{
  position:absolute;top:14px;right:14px;
  display:inline-flex;align-items:center;
  padding:4px 10px;border-radius:999px;
  font-size:.72rem;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;
}
.so-tag--free{background:rgba(37,211,102,.12);color:#0f8a40;border:1px solid rgba(37,211,102,.35)}
.so-tag--paid{background:rgba(216,173,99,.16);color:#7a5a1f;border:1px solid rgba(216,173,99,.40)}

/* Variante gratuita: leggera enfasi verde sull'icona */
.so-card--free:hover{border-color:rgba(37,211,102,.28)}
.so-card--free .card-ico{background:rgba(37,211,102,.10);color:#0f8a40}

/* Variante a pagamento: enfasi oro */
.so-card--paid:hover{border-color:rgba(216,173,99,.45)}
.so-card--paid .card-ico{
  background:linear-gradient(135deg, rgba(216,173,99,.18), rgba(216,173,99,.06));
  color:#7a5a1f;
}
.so-card--paid .btn--ghost{border-color:rgba(15,42,74,.35);color:var(--so-navy)}
.so-card--paid .btn--ghost:hover{background:var(--so-navy);color:#fff;border-color:var(--so-navy)}

.so-paid-note{
  margin-top:18px;text-align:center;color:var(--so-muted);
}

/* === FORM PLACEHOLDER (fallback) ======================= */
.so-form-wrap{margin-top:8px}
.so-form-placeholder{
  background:#fff;border:1px solid var(--so-line);border-radius:20px;
  padding:24px;box-shadow:0 6px 24px rgba(6,23,46,.06);
}
.so-form-placeholder .req{color:#c0392b}
.so-form-placeholder input,
.so-form-placeholder select,
.so-form-placeholder textarea{
  width:100%;padding:12px 14px;border:1px solid var(--so-line);
  border-radius:12px;font:inherit;color:var(--so-text);
  background:#fff;transition:border-color .15s ease, box-shadow .15s ease;
}
.so-form-placeholder input:focus,
.so-form-placeholder select:focus,
.so-form-placeholder textarea:focus{
  outline:none;border-color:var(--so-blue);
  box-shadow:0 0 0 4px rgba(15,42,74,.10);
}
.so-form-placeholder label{
  display:block;margin-bottom:6px;font-weight:600;color:var(--so-navy);font-size:.92rem;
}
.so-form-placeholder .form-grid{
  display:grid;gap:14px;grid-template-columns:1fr;
}
@media (min-width:720px){
  .so-form-placeholder .form-grid{grid-template-columns:1fr 1fr}
}
.so-form-placeholder .form-row{margin-bottom:14px}
.so-form-placeholder .form-checkbox{
  display:flex;align-items:flex-start;gap:10px;margin:8px 0 4px;font-size:.92rem;color:var(--so-muted);
}
.so-form-placeholder .mt-2{margin-top:14px}

/* === RESPONSIVE FINE-TUNE ============================== */
@media (max-width:680px){
  .so-pick{padding:22px 18px 18px;border-radius:18px}
  .so-pick__ico{width:48px;height:48px;border-radius:12px}
  .so-pick h3{font-size:1.08rem}
  .so-card{padding:22px 18px 18px;border-radius:18px}
  .so-tag{top:12px;right:12px;font-size:.68rem;padding:3px 8px}
  .so-section .section-head h2{font-size:1.55rem;line-height:1.2}
  .so-form-placeholder{padding:20px;border-radius:18px}
  .so-pick .btn,
  .so-card .btn{width:100%}
}

/* =========================================================
   HOME — banda "Inizia online" (.so-home)
   Sezione di richiamo dalla front-page verso /servizi-online/
   ========================================================= */
.so-home{
  padding:64px 0;
  position:relative;
}
.so-home__card{
  position:relative;
  border-radius:28px;
  padding:48px;
  overflow:hidden;
  color:#fff;
  background:
    radial-gradient(700px 320px at 85% 15%, rgba(216,173,99,.22), transparent 60%),
    radial-gradient(600px 320px at 10% 90%, rgba(64,123,255,.22), transparent 60%),
    linear-gradient(135deg, var(--so-navy) 0%, var(--so-blue) 70%, #0A1F3C 100%);
  box-shadow:0 24px 60px rgba(6,23,46,.20);
  display:grid;
  grid-template-columns:minmax(0,1.25fr) minmax(0,1fr);
  gap:42px;
  align-items:center;
}
.so-home__card::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(circle at 70% 50%, #000 0%, transparent 75%);
  opacity:.6;
}
.so-home__copy{position:relative;z-index:1}
.so-home__copy h2{
  color:#fff;margin:.4em 0 .35em;
  font-size:clamp(1.6rem, 2.4vw, 2.1rem);
  line-height:1.18;letter-spacing:-.01em;
}
.so-home__copy > p{
  color:rgba(255,255,255,.85);margin:0 0 18px;
  font-size:1.02rem;line-height:1.6;
}
.so-home__copy .kicker{
  background:rgba(216,173,99,.18);
  color:var(--so-gold);
  border:1px solid rgba(216,173,99,.35);
}
.so-home__bullets{
  list-style:none;padding:0;margin:0 0 24px;
  display:grid;gap:10px;
  grid-template-columns:1fr 1fr;
}
.so-home__bullets li{
  display:flex;align-items:center;gap:10px;
  color:rgba(255,255,255,.92);font-size:.95rem;font-weight:500;
}
.so-home__bullets .ico{
  color:var(--so-gold);width:18px;height:18px;flex-shrink:0;stroke-width:2.4;
}

/* Deco a destra: 4 tile tech */
.so-home__deco{position:relative;z-index:1}
.so-home__tiles{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
}
.so-home__tiles .t-tile{
  display:flex;flex-direction:column;align-items:flex-start;gap:10px;
  padding:18px 16px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  color:#fff;font-size:.92rem;
  backdrop-filter:blur(8px);
  transition:transform .25s ease, background .25s ease, border-color .25s ease;
}
.so-home__tiles .t-tile:hover{
  transform:translateY(-3px);
  background:rgba(255,255,255,.10);
  border-color:rgba(216,173,99,.45);
}
.so-home__tiles .t-tile .ico{
  width:26px;height:26px;color:var(--so-gold);stroke-width:2;
}
.so-home__tiles .t-tile b{font-weight:600;letter-spacing:.01em}

/* Responsive — tablet */
@media (max-width:980px){
  .so-home{padding:48px 0}
  .so-home__card{
    grid-template-columns:1fr;
    padding:36px 28px;
    gap:28px;
  }
  .so-home__deco{order:2}
}

/* Responsive — mobile */
@media (max-width:680px){
  .so-home{padding:36px 0}
  .so-home__card{
    padding:28px 22px;
    border-radius:22px;
  }
  .so-home__bullets{grid-template-columns:1fr;gap:8px}
  .so-home__tiles{grid-template-columns:1fr 1fr;gap:10px}
  .so-home__tiles .t-tile{padding:14px 12px;font-size:.85rem;border-radius:14px}
  .so-home .cta-group{flex-direction:column;align-items:stretch}
  .so-home .cta-group .btn{width:100%;justify-content:center;white-space:normal}
}

/* =========================================================
   UPLOAD DOCUMENTI (campo file nel form contatti)
   ========================================================= */
.liv-upload-row .opt{color:var(--so-muted,#667487);font-weight:400;font-size:.82em;margin-left:6px}
.liv-upload-row input[type="file"]{
  display:block;width:100%;padding:14px;
  background:#fff;border:1.5px dashed rgba(15,42,74,.30);border-radius:12px;
  font-size:.95rem;color:var(--so-text,#172033);cursor:pointer;
  transition:border-color .15s ease, background .15s ease;
}
.liv-upload-row input[type="file"]:hover{border-color:var(--so-blue,#0F2A4A);background:#fafbfd}
.liv-upload-row input[type="file"]:focus{outline:none;border-color:var(--so-blue,#0F2A4A);box-shadow:0 0 0 4px rgba(15,42,74,.10)}
.liv-upload-row .upload-hint{margin:8px 0 0;color:var(--so-muted,#667487)}

/* =========================================================
   AREA CLIENTE (.liv-ac-*)
   ========================================================= */
.liv-ac{display:flex;flex-direction:column;gap:22px}
.liv-ac-hello{padding:0 4px}
.liv-ac-actions{
  display:flex;flex-wrap:wrap;gap:10px;padding:0 4px;
}
.liv-ac-actions .btn{flex:0 0 auto}
.liv-ac-empty{text-align:center;color:var(--so-muted,#667487)}

.liv-ac-list{display:grid;gap:14px}
.liv-ac-item{
  background:#fff;border:1px solid rgba(7,23,46,.08);
  border-radius:18px;padding:22px;
  box-shadow:0 2px 8px rgba(6,23,46,.04);
  transition:box-shadow .2s ease, transform .2s ease;
}
.liv-ac-item:hover{box-shadow:0 12px 30px rgba(6,23,46,.08);transform:translateY(-2px)}
.liv-ac-item__head{
  display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:10px;
}
.liv-ac-id{
  display:inline-block;font-size:.72rem;color:var(--so-muted,#667487);
  font-weight:700;letter-spacing:.05em;text-transform:uppercase;
}
.liv-ac-title{margin:4px 0 2px;font-size:1.05rem;color:var(--so-navy,#06172E)}
.liv-ac-meta{margin:0;font-size:.84rem;color:var(--so-muted,#667487)}
.liv-ac-status{
  flex-shrink:0;color:#fff;padding:6px 12px;border-radius:999px;
  font-size:.76rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
}
.liv-ac-item__body p{margin:0 0 8px;color:var(--so-text,#172033);font-size:.95rem;line-height:1.55}
.liv-ac-files{margin-top:8px;font-size:.88rem;color:var(--so-muted,#667487)}
.liv-ac-files summary{cursor:pointer;color:var(--so-navy,#06172E);font-weight:600}
.liv-ac-files ul{margin:8px 0 0;padding-left:18px}
.liv-ac-files a{color:var(--so-blue,#0F2A4A)}

.liv-ac-login{max-width:480px;margin:0 auto}
.liv-ac-login .login-username,
.liv-ac-login .login-password{margin-bottom:14px}
.liv-ac-login label{display:block;margin-bottom:6px;font-weight:600;color:var(--so-navy,#06172E);font-size:.92rem}
.liv-ac-login input[type="text"],
.liv-ac-login input[type="email"],
.liv-ac-login input[type="password"]{
  width:100%;padding:12px 14px;border:1px solid rgba(7,23,46,.10);
  border-radius:12px;font:inherit;background:#fff;
}
.liv-ac-login .login-submit{margin-top:12px}
.liv-ac-login .button-primary{
  width:100%;padding:12px 18px;background:var(--so-navy,#06172E);color:#fff;
  border:none;border-radius:12px;font-weight:700;cursor:pointer;
}
.liv-ac-login .button-primary:hover{background:var(--so-blue,#0F2A4A)}

@media (max-width:680px){
  .liv-ac-item{padding:18px;border-radius:14px}
  .liv-ac-item__head{flex-direction:column;gap:8px}
  .liv-ac-status{align-self:flex-start}
  .liv-ac-actions{flex-direction:column}
  .liv-ac-actions .btn{width:100%;justify-content:center}
}

/* ============================================================
 * IMMOBILI — Archivio, card, scheda single, gallery
 * (palette LIV navy/gold, coerente con resto del tema)
 * ========================================================== */

/* ---- Header pagina dedicato (eredita il navy scuro di .page-header) ----
 * NB: non sovrascriviamo il background del .page-header base (navy/gradient)
 * per evitare testo bianco su sfondo chiaro. Aggiungiamo solo un accento
 * dorato in alto a destra per identificare la sezione immobili.
 * ---------------------------------------------------------------------- */
.page-header--immobili{
	background:
		radial-gradient(900px 320px at 85% -10%, rgba(216,173,99,.22), transparent 60%),
		radial-gradient(700px 350px at 90% -10%, rgba(37,99,235,.26), transparent 60%),
		radial-gradient(500px 350px at -10% 110%, rgba(216,173,99,.18), transparent 60%),
		linear-gradient(160deg, var(--color-navy-deep) 0%, var(--color-navy-700) 100%);
}
.page-header--immobili .kicker{background:rgba(234,199,143,.14);color:var(--color-gold-soft)}

/* ---- Filtri (archive) — base + avanzati ---- */
.immobili-filters{
	display:flex;flex-direction:column;gap:14px;
	margin:0 0 24px;padding:16px;
	background:#fff;border:1px solid var(--liv-line);
	border-radius:var(--liv-radius);box-shadow:var(--liv-shadow);
}
.immobili-filters__row{
	display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;
}
.immobili-filters__row--main{align-items:center}
.immobili-filters__row--advanced{
	display:none;
	border-top:1px dashed var(--liv-line);padding-top:14px;
}
.immobili-filters__row--advanced.is-open{display:flex}

.immobili-filter{
	display:flex;flex-direction:column;gap:4px;flex:1 1 170px;min-width:0;
}
.immobili-filter__label{
	font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
	color:var(--liv-muted);
}
.immobili-filters__row--main .immobili-filter__label{
	position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);
}
.immobili-filters select,
.immobili-filter input[type="search"],
.immobili-filter input[type="number"]{
	width:100%;min-width:0;padding:10px 12px;
	border:1px solid var(--liv-line);border-radius:8px;
	background:#fff;color:var(--liv-ink);font-weight:600;
	font-family:inherit;font-size:.95rem;line-height:1.2;
}
.immobili-filter input::placeholder{color:#9aa0a6;font-weight:500}
.immobili-filters select:focus,
.immobili-filter input:focus{outline:2px solid var(--liv-gold);outline-offset:1px;border-color:var(--liv-gold)}

.immobili-filter--search{flex:2 1 280px}
.immobili-filter--range{flex:1 1 220px}
.immobili-range{display:flex;align-items:center;gap:6px}
.immobili-range > span{color:var(--liv-muted);font-weight:700}
.immobili-range input{flex:1 1 0;min-width:0}
.immobili-range input::-webkit-outer-spin-button,
.immobili-range input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.immobili-range input{-moz-appearance:textfield;appearance:textfield}

.immobili-filters__toggle{
	display:inline-flex;align-items:center;gap:6px;
	padding:10px 14px;border:1px solid var(--liv-line);border-radius:8px;
	background:#fff;color:var(--liv-navy);font-family:inherit;font-weight:700;
	font-size:.9rem;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease;
	margin-left:auto;
}
.immobili-filters__toggle .ico{width:16px;height:16px}
.immobili-filters__toggle:hover{background:var(--liv-paper);border-color:var(--liv-gold);color:var(--liv-navy)}
.immobili-filters__toggle .t-hide{display:none}
.immobili-filters__toggle.is-open{background:var(--liv-navy);color:#fff;border-color:var(--liv-navy)}
.immobili-filters__toggle.is-open .t-show{display:none}
.immobili-filters__toggle.is-open .t-hide{display:inline}

.immobili-filters__actions{
	display:flex;gap:8px;align-items:center;flex:0 0 auto;margin-left:auto;align-self:flex-end;
}
.immobili-filters__actions .btn{white-space:nowrap}

/* ---- Filtri attivi (chip) ---- */
.immobili-active-filters{
	display:flex;flex-wrap:wrap;align-items:center;gap:10px;
	margin:0 0 20px;padding:12px 14px;
	background:rgba(216,173,99,.10);border:1px solid rgba(216,173,99,.35);
	border-radius:var(--liv-radius);
}
.immobili-active-filters__count{color:var(--liv-navy);font-size:.92rem}
.immobili-active-filters__count strong{color:var(--liv-ink);font-size:1rem}
.immobili-active-filters__list{
	list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:6px;flex:1 1 auto;
}
.immobili-chip{
	display:inline-flex;align-items:center;gap:6px;
	padding:5px 10px;border-radius:999px;
	background:#fff;border:1px solid var(--liv-line);
	color:var(--liv-ink);font-weight:600;font-size:.82rem;line-height:1;
	text-decoration:none;transition:background .15s ease,border-color .15s ease,color .15s ease;
}
.immobili-chip:hover{background:var(--liv-navy);border-color:var(--liv-navy);color:#fff}
.immobili-chip__x{font-size:1.05rem;line-height:1;font-weight:700;opacity:.7}
.immobili-chip:hover .immobili-chip__x{opacity:1}
.immobili-active-filters__reset{
	color:var(--liv-navy);font-weight:700;text-decoration:underline;font-size:.85rem;white-space:nowrap;
}
.immobili-active-filters__reset:hover{color:var(--liv-gold)}

/* ---- Toggle Lista/Mappa ---- */
.immobili-view__toolbar{
	display:flex;justify-content:flex-end;margin:0 0 16px;
}
.immobili-view__toggle{
	display:inline-flex;border:1px solid var(--liv-line);border-radius:10px;overflow:hidden;
	background:#fff;box-shadow:var(--liv-shadow);
}
.immobili-view__toggle button{
	display:inline-flex;align-items:center;gap:6px;
	padding:9px 14px;border:0;background:transparent;cursor:pointer;
	font-family:inherit;font-weight:700;font-size:.88rem;color:var(--liv-navy);
	transition:background .15s ease,color .15s ease;
}
.immobili-view__toggle button + button{border-left:1px solid var(--liv-line)}
.immobili-view__toggle button .ico{width:16px;height:16px}
.immobili-view__toggle button.is-active{background:var(--liv-navy);color:#fff}
.immobili-view__toggle button:hover:not(.is-active){background:var(--liv-paper)}

.immobili-view__map{display:none}
.immobili-view[data-active-view="map"] .immobili-view__list{display:none}
.immobili-view[data-active-view="map"] .immobili-view__map{display:block}

/* ---- Mappa (single + archivio) ---- */
.immobile-map{
	height:380px;border-radius:var(--liv-radius);overflow:hidden;
	border:1px solid var(--liv-line);box-shadow:var(--liv-shadow);
	background:#eef1f5;margin:12px 0 8px;
	position:relative;
}
.immobili-map--archive{height:560px;margin:0}
.immobili-map__empty,
.immobili-map.is-empty::after{
	position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
	background:rgba(255,255,255,.86);color:var(--liv-muted);font-weight:600;text-align:center;padding:24px;
	z-index:600;
}
.immobile-map__hint,
.immobili-map__hint{color:var(--liv-muted);font-size:.82rem;margin:8px 0 0}

@media (max-width:640px){
	.immobile-map{height:320px}
	.immobili-map--archive{height:480px}
}

/* ---- Popup Leaflet styling (override morbido) ---- */
.leaflet-popup-content-wrapper{
	border-radius:12px;box-shadow:0 12px 28px rgba(7,12,28,.18);
	border:1px solid var(--liv-line);
}
.leaflet-popup-content{margin:0;width:240px !important;font-family:inherit;line-height:1.4}
.leaflet-popup-tip{box-shadow:none}
.livmap-popup__thumb{display:block;border-radius:12px 12px 0 0;overflow:hidden;background:#eee}
.livmap-popup__thumb img{display:block;width:100%;height:120px;object-fit:cover}
.livmap-popup__body{padding:10px 12px 12px}
.livmap-popup__badges{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px}
.livmap-popup__badge{
	display:inline-block;padding:2px 7px;border-radius:999px;
	font-size:.7rem;font-weight:700;background:#eef1f5;color:var(--liv-navy);border:1px solid var(--liv-line);
	letter-spacing:.02em;
}
.livmap-popup__badge--sell{background:#fde2e2;color:#7a1c1c;border-color:#e8b3b3}
.livmap-popup__badge--rent{background:#dff2ff;color:#0b3a66;border-color:#9bd2ff}
.livmap-popup__badge--gold{background:var(--liv-gold);color:#000;border-color:var(--liv-gold)}
.livmap-popup__title{
	display:block;font-weight:800;font-size:1rem;color:var(--liv-navy);
	text-decoration:none;margin:4px 0 4px;line-height:1.25;
}
.livmap-popup__title:hover{color:var(--liv-gold)}
.livmap-popup__price{font-weight:800;color:var(--liv-ink);margin-bottom:4px}
.livmap-popup__meta{color:var(--liv-muted);font-size:.82rem;margin-bottom:8px}
.livmap-popup__cta{
	display:inline-block;padding:6px 10px;border-radius:8px;
	background:var(--liv-navy);color:#fff;font-weight:700;font-size:.82rem;
	text-decoration:none;
}
.livmap-popup__cta:hover{background:var(--liv-gold);color:#000}

/* Leaflet attribution discreta */
.leaflet-control-attribution{
	background:rgba(255,255,255,.85) !important;color:var(--liv-muted) !important;
	font-size:11px !important;
}
.leaflet-control-attribution a{color:var(--liv-navy) !important}

@media (max-width:780px){
	.immobili-filters__row--main{align-items:stretch}
	.immobili-filters__row--main .immobili-filter,
	.immobili-filters__row--advanced .immobili-filter{flex:1 1 calc(50% - 5px)}
	.immobili-filter--search{flex:1 1 100%}
	.immobili-filters__toggle{flex:1 1 100%;justify-content:center;margin-left:0}
	.immobili-filters__row--main .immobili-filter__label{
		position:static;width:auto;height:auto;clip:auto;clip-path:none;overflow:visible;
	}
	.immobili-filters__actions{flex:1 1 100%;margin-left:0}
	.immobili-filters__actions .btn{flex:1 1 0}
	.immobili-active-filters{flex-direction:column;align-items:flex-start}
	.immobili-active-filters__reset{align-self:flex-end}
}

/* ---- Grid ---- */
.immobili-grid{
	display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
	gap:28px;
}
@media (max-width:980px){.immobili-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.immobili-grid{grid-template-columns:1fr;gap:20px}}

/* ---- Card immobile ---- */
.immobile-card{
	background:#fff;border:1px solid var(--liv-line);
	border-radius:var(--liv-radius-lg);overflow:hidden;
	display:flex;flex-direction:column;
	box-shadow:var(--liv-shadow);
	transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;
}
.immobile-card:hover{
	transform:translateY(-4px);box-shadow:var(--liv-shadow-lg);
	border-color:rgba(216,173,99,.5);
}
.immobile-card__media{
	display:block;position:relative;aspect-ratio:16/10;background:#eee;
	overflow:hidden;text-decoration:none;
}
.immobile-card__img{
	width:100%;height:100%;object-fit:cover;display:block;
	transition:transform .35s ease;
}
.immobile-card:hover .immobile-card__img{transform:scale(1.04)}
.immobile-card__noimg{
	display:flex;align-items:center;justify-content:center;
	width:100%;height:100%;
	background:linear-gradient(135deg,#f2f3f5 0%, #e5e8ec 100%);
	color:var(--liv-muted);
}
.immobile-card__noimg .ico{width:48px;height:48px}

/* badges */
.immobile-badge{
	position:absolute;display:inline-flex;align-items:center;
	padding:6px 10px;border-radius:999px;
	font-size:.75rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;
	border:1px solid transparent;backdrop-filter:blur(6px);
}
.immobile-card__media .immobile-badge{top:12px}
.immobile-badge--sell{background:rgba(140,31,44,.92);color:#fff;left:12px}
.immobile-badge--rent{background:rgba(11,67,121,.92);color:#fff;left:12px}
.immobile-badge--gold{background:rgba(216,173,99,.95);color:#1f1305;right:12px}
.immobile-badge--light{background:rgba(255,255,255,.92);color:var(--liv-navy);border-color:rgba(0,0,0,.06)}
.immobile-badge--ref{background:rgba(255,255,255,.92);color:var(--liv-muted);border-color:rgba(0,0,0,.06);font-weight:700}

/* Quando i badge stanno nell'hero (sfondo navy) vogliamo contrasto chiaro */
.immobile-hero__badges .immobile-badge--light{background:rgba(255,255,255,.95);color:var(--liv-navy);border-color:transparent}
.immobile-hero__badges .immobile-badge--ref{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.28)}

.immobile-card__body{padding:18px 18px 16px;display:flex;flex-direction:column;gap:10px;flex:1}
.immobile-card__price{
	font-size:1.35rem;font-weight:900;color:var(--liv-navy);
	letter-spacing:.01em;font-variant-numeric:tabular-nums;
}
.immobile-card__title{
	margin:0;font-size:1.05rem;line-height:1.3;font-weight:800;
}
.immobile-card__title a{color:var(--liv-ink);text-decoration:none}
.immobile-card__title a:hover{color:var(--liv-navy)}

.immobile-card__meta{
	list-style:none;margin:0;padding:0;
	display:flex;flex-wrap:wrap;gap:6px 14px;
	font-size:.85rem;color:var(--liv-muted);
}
.immobile-card__meta li{display:inline-flex;align-items:center;gap:5px}
.immobile-card__meta .ico{width:14px;height:14px;color:var(--liv-gold)}
.immobile-card__specs{font-weight:700;color:var(--liv-ink)}

.immobile-card__excerpt{
	margin:0;color:var(--liv-muted);font-size:.9rem;line-height:1.5;
	display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}

.immobile-card__foot{
	display:flex;justify-content:space-between;align-items:center;gap:10px;
	margin-top:auto;padding-top:12px;border-top:1px dashed var(--liv-line);
}
.immobile-card__agency{
	display:inline-flex;align-items:center;gap:8px;
	font-size:.78rem;color:var(--liv-muted);font-weight:700;text-transform:uppercase;
	letter-spacing:.04em;max-width:55%;
}
.immobile-card__agency img{
	width:28px;height:28px;border-radius:6px;border:1px solid var(--liv-line);
	background:#fff;object-fit:contain;padding:2px;
}
.immobile-card__agency--empty{color:var(--liv-muted)}

/* archive empty */
.immobili-empty{
	background:#fff;border:1px dashed var(--liv-line);border-radius:var(--liv-radius-lg);
	padding:40px 24px;text-align:center;
}
.immobili-empty h2{margin:0 0 8px;color:var(--liv-navy)}

/* pagination */
.immobili-pagination{margin-top:40px;text-align:center}
.immobili-pagination .page-numbers{
	display:inline-flex;align-items:center;justify-content:center;
	min-width:42px;height:42px;padding:0 12px;margin:0 4px;
	border:1px solid var(--liv-line);border-radius:10px;
	background:#fff;color:var(--liv-ink);text-decoration:none;font-weight:700;
}
.immobili-pagination .page-numbers.current{
	background:var(--liv-navy);color:#fff;border-color:var(--liv-navy);
}
.immobili-pagination .page-numbers:hover:not(.current){
	border-color:var(--liv-gold);color:var(--liv-navy);
}

/* ============================================================
 * SCHEDA SINGOLA IMMOBILE
 * ========================================================== */

.page-header--single-immobile{padding-bottom:30px}
.immobile-hero{
	display:flex;justify-content:space-between;align-items:flex-end;
	gap:24px;flex-wrap:wrap;margin-top:18px;
}
.immobile-hero__head{flex:1 1 60%;min-width:280px}
.immobile-hero__badges{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 12px}
.immobile-hero__badges .immobile-badge{position:static}
.immobile-hero h1{margin:0 0 6px;font-size:clamp(1.6rem,3vw,2.4rem);line-height:1.15;color:#fff}
.immobile-hero__loc{
	margin:6px 0 0;display:inline-flex;align-items:center;gap:8px;
	color:rgba(255,255,255,.85);font-weight:600;
}
.immobile-hero__loc .ico{width:16px;height:16px;color:var(--liv-gold)}
.immobile-hero__price{
	background:var(--liv-gold);color:var(--liv-navy);
	padding:18px 24px;border-radius:14px;
	display:flex;flex-direction:column;align-items:flex-end;gap:4px;
	box-shadow:0 16px 40px rgba(216,173,99,.35);min-width:240px;
}
.immobile-hero__price-label{
	font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;
	color:rgba(26,19,5,.7);font-weight:800;
}
.immobile-hero__price-amount{
	font-size:2rem;font-weight:900;color:var(--liv-navy);
	font-variant-numeric:tabular-nums;letter-spacing:.005em;
}
@media (max-width:680px){
	.immobile-hero{flex-direction:column;align-items:stretch}
	.immobile-hero__price{align-items:flex-start;min-width:0}
}

/* ---- Gallery ---- */
.immobile-gallery-wrap{padding:24px 0}
.immobile-gallery{display:grid;gap:12px}
.immobile-gallery__cover{
	display:block;overflow:hidden;border-radius:var(--liv-radius-lg);
	background:#eee;aspect-ratio:16/9;
}
.immobile-gallery__cover-img{
	width:100%;height:100%;object-fit:cover;display:block;
	transition:transform .4s ease;
}
.immobile-gallery__cover:hover .immobile-gallery__cover-img{transform:scale(1.02)}
.immobile-gallery__thumbs{
	display:grid;grid-template-columns:repeat(6,1fr);gap:8px;
	list-style:none;margin:0;padding:0;
}
@media (max-width:780px){.immobile-gallery__thumbs{grid-template-columns:repeat(4,1fr)}}
@media (max-width:480px){.immobile-gallery__thumbs{grid-template-columns:repeat(3,1fr)}}
.immobile-gallery__thumbs li{aspect-ratio:1/1;overflow:hidden;border-radius:8px;background:#eee}
.immobile-gallery__thumb-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s ease}
.immobile-gallery__thumbs a:hover .immobile-gallery__thumb-img{transform:scale(1.08)}

/* ---- Layout dettaglio (main + aside) ---- */
.immobile-layout{
	display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:32px;
}
@media (max-width:980px){.immobile-layout{grid-template-columns:1fr}}

.immobile-block{
	background:#fff;border:1px solid var(--liv-line);border-radius:var(--liv-radius-lg);
	padding:24px 28px;margin-bottom:20px;box-shadow:var(--liv-shadow);
}
.immobile-block__title{
	margin:0 0 18px;font-size:1.15rem;font-weight:900;color:var(--liv-navy);
	padding-bottom:10px;border-bottom:2px solid var(--liv-gold);display:inline-block;
}

.immobile-specs{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media (max-width:680px){.immobile-specs{grid-template-columns:repeat(2,1fr)}}
.immobile-specs .spec{
	background:var(--liv-surface-alt);border:1px solid var(--liv-line);
	border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:2px;
}
.spec__k{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--liv-muted);font-weight:700}
.spec__v{font-size:1.05rem;font-weight:800;color:var(--liv-ink)}

.immobile-desc{color:var(--liv-text);line-height:1.7}
.immobile-desc p{margin:0 0 1em}
.immobile-loc-text{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--liv-navy)}
.immobile-loc-text .ico{width:16px;height:16px;color:var(--liv-gold)}

/* ---- Aside (agenzia + quick contatti) ---- */
.immobile-aside{display:flex;flex-direction:column;gap:18px}
.immobile-aside__card{
	background:#fff;border:1px solid var(--liv-line);
	border-radius:var(--liv-radius-lg);padding:22px 22px 20px;
	box-shadow:var(--liv-shadow);
}

.immobile-agency__head{
	display:flex;align-items:center;gap:14px;margin-bottom:12px;
	padding-bottom:14px;border-bottom:1px dashed var(--liv-line);
}
.immobile-agency__logo{
	width:64px;height:64px;border-radius:10px;background:#fff;
	object-fit:contain;padding:6px;border:1px solid var(--liv-line);
}
.immobile-agency__name{font-weight:900;color:var(--liv-navy);font-size:1.05rem;line-height:1.2}
.immobile-agency__ref{color:var(--liv-muted);font-size:.85rem;margin-top:2px}
.immobile-agency__desc{margin:0 0 12px;color:var(--liv-text);font-size:.92rem;line-height:1.5}
.immobile-agency__contacts{
	list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;
}
.immobile-agency__contacts li{
	display:inline-flex;align-items:center;gap:8px;font-size:.92rem;color:var(--liv-text);
}
.immobile-agency__contacts .ico{width:16px;height:16px;color:var(--liv-gold);flex-shrink:0}
.immobile-agency__contacts a{color:var(--liv-ink);text-decoration:none;font-weight:600}
.immobile-agency__contacts a:hover{color:var(--liv-navy);text-decoration:underline}

.immobile-quick h3{margin:0 0 14px;font-size:1.05rem;color:var(--liv-navy);font-weight:900}
.cta-group--stacked{flex-direction:column;align-items:stretch}
.cta-group--stacked .btn{justify-content:center}
.immobile-quick__ref{margin:14px 0 0;padding-top:12px;border-top:1px dashed var(--liv-line);color:var(--liv-muted);font-size:.85rem;text-align:center}

/* ---- Form richiesta info (scheda immobile) ---- */
.immobile-form-wrap{
	max-width:720px;margin:0 auto;
	background:#fff;border:1px solid var(--liv-line);border-radius:var(--liv-radius-lg);
	padding:32px;box-shadow:var(--liv-shadow);
}
.immobile-form-head{text-align:center;margin-bottom:24px}
.immobile-form-head h2{margin:8px 0 12px;color:var(--liv-navy)}
.immobile-form-head p{margin:0;color:var(--liv-muted)}

/* Precompilato box dentro form */
.liv-immobile-prefill__box{
	display:flex;align-items:center;gap:12px;
	padding:14px 16px;border:1px solid rgba(216,173,99,.45);
	background:rgba(255,247,225,.55);border-radius:10px;margin-top:6px;
}
.liv-immobile-prefill__icon{
	display:flex;align-items:center;justify-content:center;
	width:38px;height:38px;border-radius:9px;background:var(--liv-navy);color:var(--liv-gold);
	flex-shrink:0;
}
.liv-immobile-prefill__icon .ico{width:18px;height:18px}
.liv-immobile-prefill__box strong{color:var(--liv-ink);font-weight:800}

/* Topic locked (immobile) */
#liv-topic[readonly]{background:#f7f4ec;border-color:rgba(216,173,99,.4);color:var(--liv-navy);font-weight:700;cursor:not-allowed}
