/* ============================================================
   SELF-HOSTED FONTS (GDPR-compliant, no external CDN)
   Source: @fontsource packages, latin subset only, WOFF2
   ============================================================ */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-display: swap;
  font-weight: 100 900;
  src: url('../fonts/fraunces-latin-opsz-normal.woff2') format('woff2-variations');
}
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-display: swap;
  font-weight: 100 900;
  src: url('../fonts/fraunces-latin-opsz-italic.woff2') format('woff2-variations');
}
@font-face {
  font-family: 'Albert Sans';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url('../fonts/albert-sans-latin-400-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'Albert Sans';
  font-style: normal;
  font-display: swap;
  font-weight: 500;
  src: url('../fonts/albert-sans-latin-500-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'Albert Sans';
  font-style: normal;
  font-display: swap;
  font-weight: 600;
  src: url('../fonts/albert-sans-latin-600-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'Albert Sans';
  font-style: normal;
  font-display: swap;
  font-weight: 700;
  src: url('../fonts/albert-sans-latin-700-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'Spline Sans Mono';
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url('../fonts/spline-sans-mono-latin-400-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'Spline Sans Mono';
  font-style: normal;
  font-display: swap;
  font-weight: 500;
  src: url('../fonts/spline-sans-mono-latin-500-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'Spline Sans Mono';
  font-style: normal;
  font-display: swap;
  font-weight: 600;
  src: url('../fonts/spline-sans-mono-latin-600-normal.woff2') format('woff2');
}

/* ============================================================
   SITE HERO (above the calculator)
   ============================================================ */
.site-hero {
  background: radial-gradient(ellipse 80% 60% at 50% 0%, #14191f 0%, var(--ink) 70%);
  border-bottom: 1px solid var(--line);
  padding: 84px 22px 64px;
  margin-bottom: 36px;
  position: relative;
}
.site-hero::after {
  content: "";
  position: absolute;
  left: 50%; bottom: -1px;
  transform: translateX(-50%);
  width: 60%;
  max-width: 380px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold) 50%, transparent);
  opacity: .55;
}
.site-hero .hero-inner {
  max-width: 920px;
  margin: 0 auto;
}
.site-hero .hero-eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 12px;
}
.site-hero .hero-eyebrow::before {
  content: "";
  display: inline-block;
  width: 28px; height: 1px;
  background: var(--gold);
  opacity: .7;
}
.site-hero h1.hero-title {
  font-family: var(--serif);
  font-weight: 600;
  font-size: clamp(34px, 5.6vw, 60px);
  line-height: 1.04;
  letter-spacing: -.015em;
  margin: 22px 0 24px;
  color: var(--txt);
  max-width: 16ch;
}
.site-hero h1.hero-title em {
  font-style: italic;
  color: var(--gold-soft);
  font-variation-settings: 'opsz' 80;
}
.site-hero .hero-lede {
  font-family: var(--sans);
  font-size: clamp(15px, 1.4vw, 17.5px);
  line-height: 1.6;
  color: var(--muted);
  max-width: 60ch;
  margin: 0 0 32px;
}
.site-hero .hero-lede strong {
  color: var(--txt);
  font-weight: 500;
}
.site-hero .hero-cta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--mono);
  font-size: 12.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--gold-soft);
  text-decoration: none;
  padding: 13px 22px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel);
  transition: border-color .25s ease, color .25s ease, background .25s ease;
}
.site-hero .hero-cta:hover,
.site-hero .hero-cta:focus-visible {
  border-color: var(--gold);
  color: var(--gold);
  outline: none;
}
.site-hero .hero-cta .arrow {
  display: inline-block;
  transition: transform .25s ease;
}
.site-hero .hero-cta:hover .arrow {
  transform: translateY(2px);
}
@media (max-width: 680px) {
  .site-hero { padding: 56px 18px 44px; margin-bottom: 24px; }
  .site-hero h1.hero-title { font-size: clamp(30px, 8vw, 42px); max-width: 100%; }
  .site-hero .hero-eyebrow { font-size: 10px; letter-spacing: .28em; }
}

/* ============================================================
   SITE FOOTER
   ============================================================ */
.site-footer {
  border-top: 1px solid var(--line);
  margin-top: 72px;
  padding: 44px 22px 36px;
  background: linear-gradient(180deg, var(--ink), #0a0c10);
}
.site-footer-inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.site-footer-disclaimer {
  border-left: 3px solid var(--gold);
  padding: 14px 18px;
  background: var(--panel);
  border-radius: 8px;
  font-size: 12.5px;
  line-height: 1.6;
  color: var(--muted);
  max-width: 820px;
}
.site-footer-disclaimer strong { color: var(--txt); font-weight: 600; }
.site-footer-meta {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}
.site-footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 22px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.site-footer-links a {
  color: var(--muted);
  text-decoration: none;
  transition: color .2s;
}
.site-footer-links a:hover { color: var(--gold-soft); }
.site-footer-copy {
  font-size: 11.5px;
  color: var(--faint);
  font-family: var(--mono);
  letter-spacing: .06em;
}

/* ============================================================
   SKIP LINK (accessibility)
   ============================================================ */
.skip-link {
  position: absolute;
  left: -9999px;
  top: auto;
  width: 1px; height: 1px;
  overflow: hidden;
}
.skip-link:focus {
  position: fixed;
  left: 12px; top: 12px;
  width: auto; height: auto;
  z-index: 9999;
  padding: 12px 18px;
  background: var(--gold);
  color: var(--ink);
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 600;
  text-decoration: none;
  border-radius: 6px;
}

/* ============================================================
   ORIGINAL STYLES BELOW
   ============================================================ */
:root{
  --ink:#0d1014; --panel:#161b22; --panel2:#1c222c; --line:#262d39;
  --txt:#e9e7e1; --muted:#8b93a1; --faint:#5d6573;
  --gold:#d8a64e; --gold-soft:#e7c489;
  --pos:#5cc6a6; --neg:#e2795f;
  --c1:#d8a64e; --c2:#6e93c4; --c3:#5cc6a6; --c4:#b07ba8; --c5:#c9b79c; --c6:#7d8aa0;
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --ui:'Albert Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --mono:'Spline Sans Mono','SFMono-Regular',ui-monospace,'Cascadia Mono',Menlo,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  background:var(--ink); color:var(--txt); font-family:var(--ui);
  background-image:radial-gradient(1100px 500px at 85% -8%,rgba(216,166,78,.08),transparent 60%),
                   radial-gradient(900px 500px at 0% 100%,rgba(110,147,196,.06),transparent 55%);
  min-height:100vh; padding:28px clamp(14px,4vw,56px) 64px;
}
.wrap{max-width:1280px;margin:0 auto}
header{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:18px;
  padding-bottom:22px;border-bottom:1px solid var(--line);margin-bottom:28px}
.brand .eyebrow{font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);font-weight:600}
.brand h1{font-family:var(--serif);font-weight:600;font-size:clamp(28px,4.4vw,46px);line-height:1.02;
  letter-spacing:-.01em;margin-top:8px}
.brand h1 em{font-style:italic;color:var(--gold-soft)}
.privacy{font-size:12.5px;color:var(--muted);margin-top:10px;max-width:430px}
.privacy b{color:var(--txt);font-weight:600}
.controls{display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.yearbox{display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--line);
  padding:6px;border-radius:12px}
.yearbtn{font-family:var(--mono);font-size:13px;color:var(--muted);background:transparent;border:none;
  padding:7px 11px;border-radius:8px;cursor:pointer;transition:.18s;font-weight:500}
.yearbtn:hover{color:var(--txt)}
.yearbtn.active{background:var(--gold);color:#1a1205;font-weight:600}
.yearbtn.proj{font-style:italic}
.yearbtn.proj.active{background:var(--gold-soft)}
.btns{display:flex;gap:8px}
.btn{font-family:var(--ui);font-size:12.5px;font-weight:600;color:var(--txt);background:var(--panel);
  border:1px solid var(--line);padding:8px 14px;border-radius:9px;cursor:pointer;transition:.18s}
.btn:hover{border-color:var(--gold);color:var(--gold-soft)}
.tag{display:inline-block;font-size:10.5px;font-weight:600;letter-spacing:.05em;padding:3px 9px;border-radius:20px;
  text-transform:uppercase;vertical-align:middle;margin-left:10px}
.tag.stor{background:rgba(110,147,196,.16);color:#9bb6dc}
.tag.corr{background:rgba(92,198,166,.16);color:var(--pos)}
.tag.prev{background:rgba(216,166,78,.16);color:var(--gold-soft)}

/* KPI */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:14px}
.kpis-5{grid-template-columns:repeat(5,1fr)}
.kpi-section{margin-bottom:22px}
.kpi-sec-head{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--gold-soft);
  margin:4px 0 12px;letter-spacing:.01em}
.kpi-sec-head span{font-family:var(--mono);font-size:12px;color:var(--faint);font-weight:400;margin-left:8px}
.kpi.empty{background:transparent;border:none;box-shadow:none}
.kpi.empty::before{display:none}
.kpi{background:linear-gradient(160deg,var(--panel2),var(--panel));border:1px solid var(--line);
  border-radius:16px;padding:18px 18px 16px;position:relative;overflow:hidden;
  opacity:0;transform:translateY(10px);animation:rise .55s cubic-bezier(.2,.7,.2,1) forwards}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold);opacity:.85}
.kpi .k-l{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:600}
.kpi .k-v{font-family:var(--mono);font-size:clamp(20px,2.2vw,27px);font-weight:600;margin-top:10px;letter-spacing:-.02em}
.kpi .k-s{font-family:var(--mono);font-size:12.5px;margin-top:5px;color:var(--faint)}
.k-v.pos,.k-s.pos{color:var(--pos)} .k-v.neg,.k-s.neg{color:var(--neg)}
@keyframes rise{to{opacity:1;transform:none}}

/* panels */
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-top:14px}
.grid-alloc{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}
@media(max-width:760px){.grid-alloc{grid-template-columns:1fr}}
.legend .dl{margin-left:8px;font-family:var(--mono);font-size:11px;font-weight:500}
.legend .dl.up{color:var(--pos)}
.legend .dl.dn{color:var(--neg)}
.legend .dl.eq{color:var(--faint)}
.legend .bm{margin-left:6px;font-family:var(--mono);font-size:11px;color:var(--faint)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}
.ov-filter{padding:14px 20px;margin-bottom:14px}
.ov-filter .dfilter label{display:block;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:9px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:18px 20px}
.card h3{font-family:var(--ui);font-size:13px;font-weight:700;letter-spacing:.02em;color:var(--txt);
  display:flex;align-items:center;justify-content:space-between}
.card h3 span{font-family:var(--mono);font-size:11.5px;color:var(--faint);font-weight:500}
.donut-wrap{display:flex;align-items:center;gap:16px;margin-top:14px}
.legend{display:flex;flex-direction:column;gap:7px;flex:1;min-width:0}
.legend .li{display:flex;align-items:center;gap:8px;font-size:12.5px}
.legend .sw{width:10px;height:10px;border-radius:3px;flex:none}
.legend .nm{color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.legend .vl{margin-left:auto;font-family:var(--mono);font-size:12px;color:var(--txt);font-weight:500}
.center-num{font-family:var(--mono);text-anchor:middle;fill:var(--txt)}
.bars{margin-top:16px;display:flex;flex-direction:column;gap:13px}
.bar-row{display:grid;grid-template-columns:96px 1fr auto;align-items:center;gap:12px;font-size:12.5px}
.bar-row .bl{color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bar-track{height:9px;background:var(--panel2);border-radius:6px;overflow:hidden}
.bar-fill{height:100%;border-radius:6px;width:0;transition:width .7s cubic-bezier(.2,.7,.2,1)}
.bar-row .bv{font-family:var(--mono);font-size:12px;color:var(--txt)}
.foot{margin-top:30px;padding-top:18px;border-top:1px solid var(--line);font-size:11.5px;color:var(--faint);
  display:flex;flex-wrap:wrap;gap:6px 18px;align-items:center}
.data-card{margin-top:14px}
.data-head{display:flex;align-items:center;justify-content:space-between;cursor:pointer}
.tbl-scroll{max-height:300px;overflow:auto;margin-top:14px;border:1px solid var(--line);border-radius:10px;display:none}
table{width:100%;border-collapse:collapse;font-size:12px}
th{position:sticky;top:0;background:var(--panel2);color:var(--muted);font-weight:600;text-align:right;
  padding:8px 10px;white-space:nowrap;font-size:11px;letter-spacing:.03em}
th:first-child,td:first-child,th:nth-child(2),td:nth-child(2),th:nth-child(3),td:nth-child(3),
th:nth-child(4),td:nth-child(4){text-align:left}
td{padding:7px 10px;border-top:1px solid var(--line);font-family:var(--mono);text-align:right;color:var(--txt);white-space:nowrap}
td.txt{font-family:var(--ui);color:var(--muted)}
svg text{font-family:var(--mono)}
.chart-legend{display:flex;gap:18px;margin-top:6px;flex-wrap:wrap}
.chart-legend .ci{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--muted)}
.chart-legend .cl{width:18px;height:3px;border-radius:2px}
.assumptions{display:flex;gap:10px;flex-wrap:wrap}
.field{display:flex;align-items:center;gap:7px;background:var(--panel);border:1px solid var(--line);
  padding:6px 11px;border-radius:11px}
.field label{font-size:11px;color:var(--muted);font-weight:600;letter-spacing:.03em;text-transform:uppercase}
.field input{width:62px;background:var(--panel2);border:1px solid var(--line);color:var(--gold-soft);
  font-family:var(--mono);font-size:13px;font-weight:600;padding:4px 7px;border-radius:7px;text-align:right}
.field input:focus{outline:none;border-color:var(--gold)}
.field .u{font-family:var(--mono);font-size:12px;color:var(--faint)}
.kpi.net::before{background:var(--pos)} .kpi.bench::before{background:var(--gold)}
/* simulazione */
.sim{margin-top:28px}
.sim-grid{display:grid;grid-template-columns:300px 1fr;gap:14px;margin-top:14px}
.sim-inputs{display:flex;flex-direction:column;gap:14px}
.sim-field label{display:block;font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;
  letter-spacing:.04em;margin-bottom:7px}
.sim-field .inrow{display:flex;align-items:center;gap:8px}
.sim-field input[type=number]{flex:1;background:var(--panel2);border:1px solid var(--line);color:var(--txt);
  font-family:var(--mono);font-size:15px;font-weight:600;padding:9px 11px;border-radius:9px;width:100%}
.sim-field input:focus{outline:none;border-color:var(--gold)}
.sim-field input[type=range]{width:100%;accent-color:var(--gold);margin-top:8px}
.sim-field .u{font-family:var(--mono);color:var(--faint);font-size:13px}
.horizons{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:14px}
.horizon{background:linear-gradient(160deg,var(--panel2),var(--panel));border:1px solid var(--line);
  border-radius:14px;padding:15px 16px;position:relative;overflow:hidden}
.horizon::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold)}
.horizon .h-l{font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--gold-soft);font-weight:700}
.horizon .h-v{font-family:var(--mono);font-size:clamp(17px,2vw,22px);font-weight:600;margin-top:8px;letter-spacing:-.02em}
.horizon .h-s{font-family:var(--mono);font-size:11.5px;margin-top:5px;color:var(--pos)}
.horizon .h-x{font-family:var(--mono);font-size:11px;margin-top:3px;color:var(--faint)}
/* tabs */
.tabs{display:flex;gap:6px;margin-bottom:22px;border-bottom:1px solid var(--line)}
.tab{font-family:var(--ui);font-size:14px;font-weight:600;color:var(--muted);background:transparent;
  border:none;border-bottom:2px solid transparent;padding:11px 18px;cursor:pointer;transition:.18s;margin-bottom:-1px}
.tab:hover{color:var(--txt)}
.tab.active{color:var(--gold-soft);border-bottom-color:var(--gold)}
/* === Pagina Budget e spese === */
.budget-header{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.budget-header .field{margin-right:0}
.budget-header select{background:var(--panel2);border:1px solid var(--line);color:var(--gold-soft);
  font-family:var(--mono);font-size:13px;font-weight:600;padding:5px 9px;border-radius:7px;cursor:pointer}
.budget-header select:focus{outline:none;border-color:var(--gold)}
.budget-empty{padding:42px 24px;text-align:center;color:var(--muted)}
.budget-empty .e-title{font-family:var(--serif);font-size:22px;color:var(--gold-soft);margin-bottom:8px}
.budget-empty .e-sub{font-size:13px;color:var(--faint);margin-bottom:18px}
.budget-empty .btn{display:inline-block;margin:0 4px}
.bud-tbl{width:100%;border-collapse:collapse;font-size:12px;margin-top:8px}
.bud-tbl th{position:sticky;top:0;background:var(--panel2);color:var(--muted);font-weight:600;
  text-align:right;padding:9px 10px;font-size:11px;letter-spacing:.03em;border-bottom:1px solid var(--line)}
.bud-tbl th:first-child{text-align:left}
.bud-tbl td{padding:7px 10px;border-top:1px solid var(--line);font-family:var(--mono);
  text-align:right;color:var(--txt);white-space:nowrap}
.bud-tbl td:first-child{font-family:var(--ui);text-align:left}
.bud-tbl tr.macro td{background:rgba(110,147,196,.06);font-weight:700;color:var(--gold-soft)}
.bud-tbl tr.macro td:first-child{padding-left:10px}
.bud-tbl tr.sub td:first-child{padding-left:30px;color:var(--muted);font-weight:400}
/* Expand/collapse a 3 livelli */
.bud-tbl tr.sub, .bud-tbl tr.mov { display:none; }
.bud-tbl tr.sub.shown, .bud-tbl tr.mov.shown { display:table-row; }
.bud-tbl tr.macro, .bud-tbl tr.sub.has-mov { cursor:pointer; }
.bud-tbl tr.macro:hover td, .bud-tbl tr.sub.has-mov:hover td { background:rgba(216,166,78,.06); }
.bud-tbl .chev { display:inline-block; width:11px; color:var(--gold); margin-right:8px;
  font-size:10px; transition:transform .15s ease-out; opacity:.7; user-select:none; }
.bud-tbl .chev-empty { display:inline-block; width:11px; margin-right:8px; }
.bud-tbl tr.is-open > td:first-child > .chev { transform:rotate(90deg); opacity:1; }
.bud-tbl tr.mov td { background:rgba(0,0,0,.18); font-size:11px; color:#a8aebc;
  padding:5px 10px; border-top:1px dotted #1a2028; }
.bud-tbl tr.mov td:first-child { padding-left:54px; }
.bud-tbl tr.mov td:nth-child(3) { font-family:var(--mono); }
.bud-tbl tr.mov td.mov-cat { color:var(--faint); font-style:italic; font-size:10.5px; }
.bud-tbl tr.mov-empty td { padding-left:54px; font-style:italic; color:var(--faint); font-size:10.5px; }
.bud-tbl tr.sub td:first-child::before { content:none; }
.bud-tbl tr.sub.has-mov .sub-count { color:var(--faint); font-size:10.5px; margin-left:6px; }
.bud-tbl input.bud-edit{background:var(--panel2);border:1px solid var(--line);color:var(--gold-soft);
  font-family:var(--mono);font-size:12px;font-weight:600;padding:3px 7px;border-radius:6px;
  width:80px;text-align:right}
.bud-tbl input.bud-edit:focus{outline:none;border-color:var(--gold)}
.bar-wrap{display:inline-flex;width:140px;height:12px;background:#0f1419;
  border:1px solid var(--line);border-radius:7px;overflow:hidden;vertical-align:middle;margin-left:6px}
.bar-fill{height:12px;border-radius:6px;transition:width .3s;display:block}
/* Scala graduale a 7 livelli: 1=ottimo, 7=critico */
.bar-fill.lvl-1 {background:#2fa67e}
.bar-fill.lvl-2 {background:#5cc6a6}
.bar-fill.lvl-3 {background:#a4ca5a}
.bar-fill.lvl-4 {background:#e8c853}
.bar-fill.lvl-5 {background:#e8a04a}
.bar-fill.lvl-6 {background:#dc7d50}
.bar-fill.lvl-7 {background:#c8553a}
/* Colore della cella percentuale, coerente con la barra */
.bud-tbl td.lvl-1 {color:#2fa67e;font-weight:600}
.bud-tbl td.lvl-2 {color:#5cc6a6;font-weight:600}
.bud-tbl td.lvl-3 {color:#a4ca5a;font-weight:600}
.bud-tbl td.lvl-4 {color:#e8c853;font-weight:600}
.bud-tbl td.lvl-5 {color:#e8a04a;font-weight:600}
.bud-tbl td.lvl-6 {color:#dc7d50;font-weight:600}
.bud-tbl td.lvl-7 {color:#c8553a;font-weight:600}
.bud-tbl tr.macro td.lvl-1, .bud-tbl tr.macro td.lvl-2, .bud-tbl tr.macro td.lvl-3,
.bud-tbl tr.macro td.lvl-4, .bud-tbl tr.macro td.lvl-5, .bud-tbl tr.macro td.lvl-6,
.bud-tbl tr.macro td.lvl-7 {font-weight:700}
/* Delta in € accanto alla percentuale (più piccolo) */
.bud-tbl .pct-delta {font-size:10.5px;opacity:.72;margin-left:5px;font-weight:500}
.bud-tbl tr.tot td{border-top:2px solid var(--line);font-weight:700;color:var(--gold-soft);padding-top:11px}
.bridge-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:14px}
@media(max-width:760px){.bridge-grid{grid-template-columns:1fr}}
/* Banner di verifica integrità */
.integrity{display:flex;align-items:flex-start;gap:12px;padding:10px 16px;border-radius:8px;
  font-size:12.5px;margin:14px 0;border:1px solid;background:var(--panel2)}
.integrity .badge{display:inline-block;width:22px;height:22px;border-radius:50%;
  text-align:center;line-height:22px;font-weight:700;flex-shrink:0;margin-top:1px}
.integrity .body{flex:1;line-height:1.6}
.integrity .head{font-weight:600;font-size:13px;margin-bottom:2px}
.integrity .det{color:var(--muted);font-size:12px}
.integrity .det b{color:var(--gold-soft);font-weight:600;background:rgba(216,166,78,.08);
  padding:1px 5px;border-radius:4px;font-family:var(--mono);font-size:11.5px}
.integrity.ok{border-color:rgba(92,198,166,.4);color:var(--pos)}
.integrity.ok .badge{background:var(--pos);color:#0d1014}
.integrity.warn{border-color:rgba(226,121,95,.5);color:var(--neg)}
.integrity.warn .badge{background:var(--neg);color:#0d1014}
.integrity.warn .det{color:#d4d4cf}
/* fine pagina Budget e spese */
/* filtri dettaglio */
.detail-filters{display:flex;flex-wrap:wrap;gap:22px;align-items:flex-start;padding:18px 20px}
.dfilter label{display:block;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);
  font-weight:600;margin-bottom:9px}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{font-family:var(--ui);font-size:12.5px;font-weight:500;color:var(--muted);background:var(--panel2);
  border:1px solid var(--line);padding:6px 12px;border-radius:20px;cursor:pointer;transition:.16s}
.chip:hover{color:var(--txt);border-color:var(--faint)}
.chip.active{background:var(--gold);color:#1a1205;border-color:var(--gold);font-weight:600}
#assetSelect{font-family:var(--ui);font-size:13.5px;font-weight:500;color:var(--txt);background:var(--panel2);
  border:1px solid var(--line);padding:8px 12px;border-radius:9px;min-width:230px;cursor:pointer}
#assetSelect:focus{outline:none;border-color:var(--gold)}
.seg{display:inline-flex;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:4px;gap:3px}
.seg-b{font-family:var(--ui);font-size:12.5px;font-weight:500;color:var(--muted);background:transparent;
  border:none;padding:7px 13px;border-radius:7px;cursor:pointer;transition:.16s}
.seg-b:hover{color:var(--txt)}
.seg-b.active{background:var(--gold);color:#1a1205;font-weight:600}
.detail-head{margin-top:14px;display:flex;flex-wrap:wrap;align-items:baseline;gap:8px 16px;padding:16px 20px}
.detail-head .dh-name{font-family:var(--serif);font-size:24px;font-weight:600;color:var(--txt)}
.detail-head .dh-isin{font-family:var(--mono);font-size:12px;color:var(--faint)}
.detail-head .dh-meta{font-size:12.5px;color:var(--muted);margin-left:auto;display:flex;gap:8px;flex-wrap:wrap}
.detail-head .pill{background:var(--panel2);border:1px solid var(--line);border-radius:20px;padding:3px 11px;font-weight:500}
.kpis-detail{grid-template-columns:repeat(4,1fr)}
/* card panoramica "All Assets" nella vista Dettaglio */
.all-assets-card{margin-top:14px;padding:18px 20px}
.all-assets-card h3 .aa-hint{font-size:11.5px;color:var(--faint);font-weight:500;margin-left:8px}
.aa-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:14px}
.aa-panel{background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:14px}
.aa-panel-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.aa-panel-head h4{font-family:var(--ui);font-size:11.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.seg-mini{display:inline-flex;background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:3px}
.seg-mini button{font-family:var(--ui);font-size:11px;font-weight:600;color:var(--muted);background:transparent;border:none;padding:5px 10px;border-radius:6px;cursor:pointer;transition:.15s}
.seg-mini button:hover{color:var(--txt)}
.seg-mini button.active{background:var(--gold);color:#1a1205}
.aa-bars{display:flex;flex-direction:column;gap:5px}
.aa-bar{display:grid;grid-template-columns:minmax(120px,150px) 1fr 84px;align-items:center;gap:10px;font-size:12px;cursor:pointer;padding:4px 6px;border-radius:6px;transition:background .15s}
.aa-bar:hover{background:rgba(216,166,78,.07)}
.aa-bar.active{background:rgba(216,166,78,.15);box-shadow:inset 0 0 0 1px rgba(216,166,78,.35)}
.aa-bar .aa-name{color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}
.aa-bar.active .aa-name{color:var(--gold-soft)}
.aa-bar .aa-track{height:13px;background:var(--panel);border:1px solid var(--line);border-radius:3px;position:relative;overflow:hidden}
.aa-bar .aa-fill{position:absolute;top:0;bottom:0;left:0;border-radius:3px;transition:width .25s}
.aa-bar .aa-val{font-family:var(--mono);text-align:right;font-size:11.5px;font-weight:600}
@media(max-width:920px){.kpis{grid-template-columns:repeat(2,1fr)}.kpis-5{grid-template-columns:repeat(2,1fr)}.kpis-detail{grid-template-columns:repeat(2,1fr)}
  .grid3{grid-template-columns:1fr}.grid2{grid-template-columns:1fr}
  header{flex-direction:column;align-items:flex-start}.controls{align-items:flex-start}.sim-grid{grid-template-columns:1fr}
  .detail-head .dh-meta{margin-left:0;width:100%}
  .aa-grid{grid-template-columns:1fr}
  .aa-bar{grid-template-columns:minmax(100px,130px) 1fr 70px}}

/* ===== Modulo CASA ===== */
.house-cfg{padding:20px 22px}
.house-cfg h3{margin-bottom:14px}
.house-cfg .hc-sub{font-family:var(--mono);font-size:11.5px;color:var(--faint);font-weight:500;margin-left:8px}

/* === Sticky summary bar (solo mobile) === */
.h-sticky-bar{
  display:none;
  position:sticky;top:8px;z-index:50;
  margin-bottom:14px;
  padding:9px 12px;
  background:rgba(22,27,34,0.92);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  border:1px solid var(--line);
  border-left:3px solid var(--gold);
  border-radius:11px;
  box-shadow:0 8px 24px rgba(0,0,0,0.4), 0 2px 6px rgba(0,0,0,0.3);
}
.h-sticky-bar.is-hidden{display:none !important}
.h-sticky-bar .h-sb-grid{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px 10px;align-items:center;
}
.h-sticky-bar .h-sb-cell{
  display:flex;flex-direction:column;gap:2px;min-width:0;
  padding:0 6px;border-left:1px solid var(--line);
}
.h-sticky-bar .h-sb-cell:first-child{border-left:none;padding-left:2px}
.h-sticky-bar .h-sb-lbl{
  font-family:var(--ui);font-size:9px;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.h-sticky-bar .h-sb-val{
  font-family:var(--mono);font-size:14px;font-weight:600;letter-spacing:-.02em;
  color:var(--txt);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.h-sticky-bar .h-sb-val.pos{color:var(--pos)}
.h-sticky-bar .h-sb-val.neg{color:var(--neg)}
.h-sticky-bar .h-sb-val.muted{color:var(--faint)}
@media(max-width:760px){
  .h-sticky-bar{display:block}
}

/* === Modalità configurazione: Essenziale / Avanzata === */
.h-cfg-head{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  flex-wrap:wrap;margin-bottom:18px;
}
.h-cfg-head h3{margin-bottom:0;flex:1;min-width:240px}
.h-cfg-head #hCfgModeSeg{width:auto;flex:none}
.h-cfg-head #hCfgModeSeg button{padding:7px 18px;font-size:12.5px;flex:none}
.house-cfg[data-mode="ess"] .h-adv{display:none !important}
/* Hint in fondo a ogni gruppo quando ci sono campi nascosti */
.h-adv-hint{
  display:none;
  margin-top:auto;padding:9px 11px;
  font-size:11px;font-style:italic;color:var(--faint);
  text-align:center;
  background:rgba(216,166,78,0.035);
  border:1px dashed rgba(216,166,78,0.18);border-radius:7px;
  cursor:pointer;transition:.18s;
  user-select:none;
}
.h-adv-hint:hover{
  color:var(--gold-soft);
  border-color:rgba(216,166,78,0.45);
  background:rgba(216,166,78,0.08);
}
.h-adv-hint .n{font-family:var(--mono);font-style:normal;font-weight:600;color:var(--gold-soft)}
.house-cfg[data-mode="ess"] .house-group .h-adv-hint{display:block}
.house-cfg[data-mode="ess"] .house-group{justify-content:flex-start}
.house-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px 22px;margin-top:6px}
.house-group{display:flex;flex-direction:column;gap:11px;min-width:0}
.house-group .hg-title{font-family:var(--serif);font-size:14.5px;color:var(--gold-soft);font-weight:600;
  padding-bottom:6px;border-bottom:1px dashed var(--line);margin-bottom:2px}
.h-field label{display:block;font-size:10.5px;color:var(--muted);font-weight:600;text-transform:uppercase;
  letter-spacing:.05em;margin-bottom:5px}
.h-field .inrow{display:flex;align-items:center;gap:7px}
.h-field input[type=number]{flex:1;min-width:0;background:var(--panel2);border:1px solid var(--line);color:var(--txt);
  border-radius:8px;padding:8px 10px;font-family:var(--mono);font-size:13px;font-weight:500}
.h-field input[type=number]:focus{outline:none;border-color:var(--gold)}
.h-field .u{font-family:var(--mono);color:var(--faint);font-size:12px;flex:none}
.h-field .help{font-family:var(--mono);font-size:10.5px;color:var(--faint);margin-top:4px;font-weight:400;line-height:1.4}
.h-field.toggle{display:flex;align-items:center;gap:10px}
.h-field.toggle label{margin:0;text-transform:none;letter-spacing:0;font-size:12.5px;font-weight:500;color:var(--txt);cursor:pointer}
.h-field input[type=checkbox]{accent-color:var(--gold);width:15px;height:15px;cursor:pointer}
.h-seg{display:inline-flex;background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:3px;width:100%}
.h-seg button{flex:1;font-family:var(--ui);font-size:12px;font-weight:500;color:var(--muted);background:transparent;
  border:none;padding:6px 8px;border-radius:6px;cursor:pointer;transition:.15s;white-space:nowrap}
.h-seg button:hover{color:var(--txt)}
.h-seg button.active{background:var(--gold);color:#1a1205;font-weight:600}
.h-derived{font-family:var(--mono);font-size:12px;color:var(--gold-soft);padding:8px 10px;background:rgba(216,166,78,.08);
  border-radius:6px;border-left:2px solid var(--gold);margin-top:4px}
.h-derived b{color:var(--txt)}

/* Tabella dettaglio cassa rogito */
.h-det-tbl{width:100%;border-collapse:collapse;font-size:13px;margin-top:8px}
.h-det-tbl th,.h-det-tbl td{padding:9px 12px;text-align:left;border-bottom:1px solid var(--line)}
.h-det-tbl th{font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:600;background:rgba(0,0,0,.15)}
.h-det-tbl td.num{font-family:var(--mono);text-align:right;font-weight:500;white-space:nowrap}
.h-det-tbl td.base{font-family:var(--mono);text-align:right;color:var(--faint);font-size:11.5px;white-space:nowrap}
.h-det-tbl td.note{color:var(--faint);font-size:11.5px}
.h-det-tbl tr.section td{background:rgba(216,166,78,.04);font-family:var(--serif);font-weight:600;color:var(--gold-soft);
  font-size:12.5px;padding-top:11px;padding-bottom:9px}
.h-det-tbl tr.total td{background:rgba(216,166,78,.08);font-weight:700;font-size:14px;border-top:1px solid var(--gold)}
.h-det-tbl tr.total td.num{color:var(--gold-soft)}
.h-det-tbl tr.sub td{padding-left:28px;color:var(--muted)}
.h-det-tbl tr.sub td.num{color:var(--txt)}

.house-empty{text-align:center;padding:40px;color:var(--muted)}
.house-empty .e-title{font-family:var(--serif);font-size:18px;color:var(--gold-soft);margin-bottom:6px}

@media(max-width:1100px){.house-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.house-grid{grid-template-columns:1fr}}

/* Grafico ammortamento mutuo */
.h-amm-chart{margin-top:14px}
.h-chart-legend{display:flex;gap:18px;margin-top:10px;flex-wrap:wrap;font-size:11.5px;color:var(--muted)}
.h-chart-legend .ci{display:flex;align-items:center;gap:6px}
.h-chart-legend .cl{width:12px;height:12px;border-radius:3px;display:inline-block}

/* Tabella ammortamento */
.h-amm-tbl{width:100%;border-collapse:collapse;font-size:12.5px;margin-top:8px;font-family:var(--mono)}
.h-amm-tbl th,.h-amm-tbl td{padding:7px 12px;text-align:right;border-bottom:1px solid var(--line);white-space:nowrap}
.h-amm-tbl th{font-family:var(--ui);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);
  font-weight:600;background:rgba(0,0,0,.15)}
.h-amm-tbl th:first-child,.h-amm-tbl td:first-child{text-align:left}
.h-amm-tbl tr:hover td{background:rgba(216,166,78,.04)}
.h-amm-tbl td.year{font-weight:600;color:var(--gold-soft)}
.h-amm-tbl td.cap{color:var(--gold-soft)}
.h-amm-tbl td.int{color:var(--neg)}
.h-amm-tbl tr.total td{border-top:1px solid var(--gold);background:rgba(216,166,78,.08);font-weight:700;font-size:13px}
.h-amm-tbl tr.total td.year{color:var(--txt)}

.h-amm-head{display:flex;align-items:center;justify-content:space-between;cursor:pointer}
.h-amm-head .toggle-ic{font-size:11px;color:var(--muted);font-family:var(--mono);font-weight:600;letter-spacing:.06em}
.h-amm-body{margin-top:10px;display:none}
.h-amm-body.open{display:block}

/* Tabella BvR dettaglio anno su anno */
.bvr-tbl-wrap{overflow-x:auto;margin-top:10px;border:1px solid var(--line);border-radius:10px}

/* Pulsante toggle visualizzazione portafoglio liquido nel grafico BvR */
.bvr-tgl-btn{background:var(--panel2);color:var(--muted);border:1px solid var(--line);
  border-radius:8px;padding:6px 12px;font-size:11px;font-family:var(--mono);font-weight:600;
  letter-spacing:.04em;cursor:pointer;display:inline-flex;align-items:center;gap:8px;
  transition:all .15s ease;white-space:nowrap}
.bvr-tgl-btn:hover{border-color:var(--gold-soft);color:var(--txt)}
.bvr-tgl-btn .dot{width:9px;height:9px;border-radius:50%;background:var(--line);
  border:1.5px solid var(--muted);transition:all .15s ease}
.bvr-tgl-btn.active{background:rgba(216,166,78,.08);border-color:var(--gold-soft);color:var(--gold-soft)}
.bvr-tgl-btn.active .dot{background:var(--gold);border-color:var(--gold)}
.bvr-tbl{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:11.5px;min-width:1280px}
.bvr-tbl thead th{position:sticky;top:0;background:var(--panel2);color:var(--muted);font-weight:600;
  text-transform:uppercase;letter-spacing:.04em;font-size:10px;padding:8px 9px;border-bottom:1px solid var(--line);
  text-align:right;white-space:nowrap;z-index:1}
.bvr-tbl thead th.grp{text-align:center;border-bottom:1px solid var(--line);color:var(--gold-soft);
  font-family:var(--serif);font-size:12px;letter-spacing:.02em;text-transform:none;font-style:italic}
.bvr-tbl thead th.grp.buy{background:rgba(216,166,78,.08)}
.bvr-tbl thead th.grp.rent{background:rgba(110,147,196,.08)}
.bvr-tbl thead th.grp.delta{background:rgba(176,123,168,.08)}
.bvr-tbl tbody td{padding:6px 9px;text-align:right;border-bottom:1px solid rgba(38,45,57,.5);white-space:nowrap}
.bvr-tbl tbody td.year{text-align:left;color:var(--gold-soft);font-weight:600;font-family:var(--serif);font-size:13px}
.bvr-tbl tbody td.tot{background:rgba(216,166,78,.05);color:var(--txt);font-weight:600}
.bvr-tbl tbody td.tot-rent{background:rgba(110,147,196,.05);color:var(--txt);font-weight:600}
.bvr-tbl tbody td.tot-delta{background:rgba(176,123,168,.05);font-weight:600}
.bvr-tbl tbody td.tot-delta.pos{color:var(--pos)}
.bvr-tbl tbody td.tot-delta.neg{color:var(--neg)}
.bvr-tbl tbody td.faint{color:var(--faint)}
.bvr-tbl tbody td.neg-val{color:var(--neg)}
.bvr-tbl tbody tr.rogito td{background:rgba(216,166,78,.04);border-bottom:2px solid var(--line)}
.bvr-tbl tbody tr.rogito td.tot{background:rgba(216,166,78,.10)}
.bvr-tbl tbody tr.rogito td.tot-rent{background:rgba(110,147,196,.10)}
.bvr-tbl tbody tr.rogito td.tot-delta{background:rgba(176,123,168,.10)}
.bvr-tbl tbody tr:hover td{background:rgba(216,166,78,.03)}
.bvr-tbl-note{padding:10px 14px;font-size:11.5px;color:var(--muted);background:var(--panel2);
  border-top:1px solid var(--line);line-height:1.55}
.bvr-tbl-note b{color:var(--txt);font-weight:600}
.bvr-tbl-note code{font-family:var(--mono);background:rgba(216,166,78,.08);padding:1px 5px;border-radius:3px;
  color:var(--gold-soft);font-size:11px}

/* Buy vs Rent grid - 5 colonne */
.bvr-grid{grid-template-columns:repeat(5,1fr) !important}
@media(max-width:1100px){.bvr-grid{grid-template-columns:repeat(2,1fr) !important}}
@media(max-width:680px){.bvr-grid{grid-template-columns:1fr !important}}

/* === Verdetto Buy vs Rent: blocco "decisione" === */
.bvr-verdict{
  position:relative;
  background:
    radial-gradient(720px 200px at 8% 0%, rgba(216,166,78,0.16), transparent 65%),
    linear-gradient(180deg, rgba(216,166,78,0.07), rgba(216,166,78,0.02));
  border:1px solid rgba(216,166,78,0.32);
  border-radius:18px;
  padding:24px 28px 22px;
  margin-bottom:14px;
  overflow:hidden;
  opacity:0;transform:translateY(8px);
  animation:rise .55s cubic-bezier(.2,.7,.2,1) forwards;
}
.bvr-verdict::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(180deg,var(--gold),var(--gold-soft));
}
.bvr-verdict-eyebrow{
  font-family:var(--ui);font-size:10.5px;font-weight:700;
  letter-spacing:.28em;text-transform:uppercase;color:var(--gold);
  margin-bottom:14px;
  display:flex;flex-wrap:wrap;align-items:center;gap:0 10px;
}
.bvr-verdict-eyebrow .sep{color:var(--faint);font-weight:400;letter-spacing:.1em}
.bvr-verdict-eyebrow .yr{color:var(--gold-soft);font-family:var(--mono);font-weight:600;letter-spacing:.04em;white-space:nowrap}
.bvr-verdict-headline{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(28px,3.8vw,42px);line-height:1.05;letter-spacing:-.018em;
  color:var(--txt);
}
.bvr-verdict-headline .winner{font-style:italic;color:var(--gold-soft);font-weight:600}
.bvr-verdict-headline .winner.rent{color:#9bb6dc}
.bvr-verdict-headline .delta{
  font-family:var(--mono);font-style:normal;font-weight:600;color:var(--gold-soft);
  font-size:.92em;letter-spacing:-.025em;
}
.bvr-verdict-headline .delta.neg{color:var(--neg)}
.bvr-verdict-meta{
  margin-top:14px;font-family:var(--ui);font-size:13.5px;color:var(--muted);
  line-height:1.55;max-width:780px;
}
.bvr-verdict-meta .be{
  display:inline-flex;align-items:baseline;gap:6px;
  background:rgba(176,123,168,0.14);
  border:1px solid rgba(176,123,168,0.32);
  border-radius:6px;padding:2px 9px;margin:0 2px;
  color:#d6b3cd;
}
.bvr-verdict-meta .be .be-num{font-family:var(--mono);font-weight:700;color:#e8c7df;font-size:13px}
.bvr-verdict-meta .be .be-u{font-family:var(--mono);font-size:11px;color:#b890ad;font-weight:500}
.bvr-verdict-meta b{color:var(--txt);font-weight:600}
.bvr-verdict-meta b.mono{font-family:var(--mono);color:var(--gold-soft)}
.bvr-verdict.is-tie .bvr-verdict-headline .winner{color:var(--gold-soft);font-style:normal}
@media(max-width:680px){
  .bvr-verdict{padding:20px 18px 18px;border-radius:14px}
  .bvr-verdict-eyebrow{font-size:9.5px;letter-spacing:.18em;margin-bottom:12px;gap:0 7px}
  .bvr-verdict-headline{font-size:clamp(24px,7vw,32px)}
  .bvr-verdict-meta{font-size:12.5px}
}

/* Parametri fiscali grid - 3 colonne */
.h-fiscal-grid{grid-template-columns:repeat(3,1fr) !important;gap:14px 22px}
@media(max-width:920px){.h-fiscal-grid{grid-template-columns:repeat(2,1fr) !important}}
@media(max-width:680px){.h-fiscal-grid{grid-template-columns:1fr !important}}

.h-btn-reset{background:transparent;border:1px solid var(--line);color:var(--muted);
  padding:7px 14px;border-radius:7px;cursor:pointer;font-family:var(--ui);font-size:12px;
  font-weight:500;letter-spacing:.03em;transition:.15s}
.h-btn-reset:hover{border-color:var(--gold);color:var(--gold-soft)}

/* Heatmap sensitività */
.h-sens-toolbar{display:flex;justify-content:space-between;align-items:center;margin-top:10px;flex-wrap:wrap;gap:12px}
.h-sens-toolbar .h-seg{width:auto;display:inline-flex}
.h-sens-toolbar .h-seg button{padding:6px 14px}
.h-sens-legend{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);font-family:var(--mono)}
.h-sens-legend .gr{width:140px;height:10px;border-radius:3px}
.h-sens-tbl{width:100%;border-collapse:separate;border-spacing:2px;margin-top:14px;font-family:var(--mono);font-size:11.5px}
.h-sens-tbl th,.h-sens-tbl td{padding:6px 4px;text-align:center;border-radius:4px;min-width:50px}
.h-sens-tbl th{background:transparent;color:var(--muted);font-weight:600;font-size:10.5px;letter-spacing:.04em}
.h-sens-tbl th.corner{font-size:9.5px;text-align:right;padding-right:8px;line-height:1.25}
.h-sens-tbl th.corner span{color:var(--gold-soft);font-weight:700}
.h-sens-tbl th.axis-y{text-align:right;padding-right:8px;background:transparent}
.h-sens-tbl td.cell{color:#0a0a0a;font-weight:600;cursor:pointer;transition:transform .12s, box-shadow .12s}
.h-sens-tbl td.cell:hover{transform:scale(1.06);box-shadow:0 0 0 1px var(--gold), 0 2px 8px rgba(0,0,0,0.4);z-index:2;position:relative}
.h-sens-tbl td.cell.current{box-shadow:0 0 0 2px var(--gold), 0 0 8px rgba(216,166,78,.4);font-weight:800}
.h-sens-tbl td.cell.empty{background:rgba(255,255,255,.04);color:var(--faint);font-weight:400}
.h-sens-info{font-size:11.5px;color:var(--muted);margin-top:10px;font-family:var(--mono);line-height:1.5}
.h-sens-info b{color:var(--gold-soft)}

/* Scenari salvati */
.h-scn-toolbar{display:flex;align-items:center;gap:10px;margin-top:6px;flex-wrap:wrap}
.h-scn-toolbar input[type=text]{background:var(--panel2);border:1px solid var(--line);color:var(--txt);
  border-radius:8px;padding:8px 12px;font-family:var(--ui);font-size:13px;min-width:200px;flex:1;max-width:280px}
.h-scn-toolbar input[type=text]:focus{outline:none;border-color:var(--gold)}
.h-scn-btn{background:transparent;border:1px solid var(--line);color:var(--muted);
  padding:7px 13px;border-radius:7px;cursor:pointer;font-family:var(--ui);font-size:12px;
  font-weight:500;letter-spacing:.02em;transition:.15s;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}
.h-scn-btn:hover{border-color:var(--gold);color:var(--gold-soft)}
.h-scn-btn.primary{background:var(--gold);color:#1a1205;border-color:var(--gold);font-weight:600}
.h-scn-btn.primary:hover{background:var(--gold-soft);color:#1a1205}
.h-scn-btn.danger:hover{border-color:var(--neg);color:var(--neg)}

.h-scn-empty{padding:30px;text-align:center;color:var(--faint);font-size:13px;font-style:italic;
  background:rgba(255,255,255,.02);border-radius:8px;margin-top:12px}

.h-scn-list{display:flex;flex-direction:column;gap:8px;margin-top:14px}
.h-scn-row{background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:11px 14px;
  display:grid;grid-template-columns:minmax(140px,1.3fr) repeat(4, 1fr) auto;gap:14px;align-items:center}
.h-scn-row .scn-name{font-family:var(--serif);font-size:14px;font-weight:600;color:var(--gold-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.h-scn-row .scn-name .scn-date{display:block;font-family:var(--mono);font-size:10px;color:var(--faint);font-weight:400}
.h-scn-row .scn-kpi{font-family:var(--mono);font-size:11.5px;line-height:1.4}
.h-scn-row .scn-kpi .l{display:block;color:var(--muted);font-size:9.5px;text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.h-scn-row .scn-kpi .v{color:var(--txt);font-weight:600;font-size:13px}
.h-scn-row .scn-kpi .v.pos{color:var(--pos)}
.h-scn-row .scn-kpi .v.neg{color:var(--neg)}
.h-scn-row .scn-actions{display:flex;gap:6px;flex-wrap:nowrap}
.h-scn-row .scn-actions .h-scn-btn{padding:5px 9px;font-size:11px}

/* Tabella confronto */
.h-cmp-tbl{width:100%;border-collapse:collapse;font-size:12.5px;margin-top:16px;font-family:var(--mono)}
.h-cmp-tbl th,.h-cmp-tbl td{padding:8px 12px;text-align:right;border-bottom:1px solid var(--line);white-space:nowrap}
.h-cmp-tbl th{font-family:var(--ui);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--gold-soft);
  font-weight:600;background:rgba(0,0,0,.15);text-align:right}
.h-cmp-tbl th:first-child,.h-cmp-tbl td:first-child{text-align:left;font-family:var(--ui);font-weight:500;color:var(--muted);font-size:12px}
.h-cmp-tbl th.cur,.h-cmp-tbl td.cur{background:rgba(216,166,78,.08)}
.h-cmp-tbl th.cur{color:var(--gold)}
.h-cmp-tbl tr.section td{background:rgba(216,166,78,.04);font-family:var(--serif);font-weight:600;color:var(--gold-soft);
  font-size:12.5px;text-align:left;padding-top:11px;padding-bottom:9px}
.h-cmp-tbl td.best{color:var(--gold-soft);font-weight:700}
@media(max-width:920px){
  .h-scn-row{grid-template-columns:1fr 1fr; row-gap:8px}
  .h-scn-row .scn-name{grid-column:span 2}
  .h-scn-row .scn-actions{grid-column:span 2;justify-content:flex-end}
}

/* ===== Switch modalità Casa (Acquisto / Gestione esistente) ===== */
.h-mode-card{padding:14px 18px;margin-bottom:18px;background:linear-gradient(180deg,rgba(216,166,78,.06) 0%,transparent 100%)}
.h-mode-card .h-mode-head{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.h-mode-card .h-mode-title{font-family:var(--serif);font-size:14px;color:var(--gold-soft);font-weight:600;letter-spacing:.02em}
.h-mode-card .h-mode-title em{font-style:normal;color:var(--muted);font-family:var(--mono);font-size:11.5px;font-weight:400;display:block;margin-top:2px}
.h-mode-card .h-seg{width:auto;min-width:340px}
.h-mode-card .h-seg button{padding:8px 18px;font-size:12.5px}
.h-mode-card .h-mode-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.h-export-btn{
  font-family:var(--ui);font-size:12.5px;font-weight:600;color:var(--gold-soft);
  background:var(--panel2);border:1px solid rgba(216,166,78,0.32);
  padding:8px 14px;border-radius:9px;cursor:pointer;
  display:inline-flex;align-items:center;gap:7px;transition:.18s;
  white-space:nowrap;
}
.h-export-btn:hover{
  border-color:var(--gold);background:rgba(216,166,78,0.08);color:var(--gold);
}
.h-export-btn:active{transform:translateY(1px)}
.h-export-btn .ico{font-size:15px;line-height:1}
.h-export-btn:disabled{opacity:.5;cursor:not-allowed}
@media(max-width:680px){
  .h-export-btn{flex:1;justify-content:center}
}

/* ===== Gestione: grid e gruppi ===== */
.hm-scn-card{padding:18px 22px}
.hm-scn-card h3{margin-bottom:6px}
.hm-scn-card .hm-scn-tag{display:inline-block;padding:3px 10px;border-radius:10px;font-family:var(--mono);font-size:10.5px;
  font-weight:600;letter-spacing:.06em;margin-right:10px;text-transform:uppercase;vertical-align:1px}
.hm-scn-card .tag-vendo{background:rgba(216,166,78,.18);color:var(--gold-soft);border:1px solid rgba(216,166,78,.4)}
.hm-scn-card .tag-affitto{background:rgba(110,147,196,.18);color:var(--c2);border:1px solid rgba(110,147,196,.4)}
.hm-scn-card .tag-tengo{background:rgba(176,123,168,.18);color:var(--c4);border:1px solid rgba(176,123,168,.4)}

/* ===================== PRINT VIEW (schermo: nascosto; stampa: visibile) ===================== */
#house-print-view{display:none}

@media print{
  /* Nascondi tutto a livello body tranne il print view */
  body > *:not(#house-print-view){display:none !important}
  body{
    background:#ffffff !important;
    color:#1a1a1a !important;
    padding:0 !important;
    margin:0 !important;
    background-image:none !important;
  }
  #house-print-view{
    display:block !important;
    color:#1a1a1a;
    font-family:'Albert Sans',-apple-system,sans-serif;
    font-size:10.5pt;
    line-height:1.5;
    padding:0;
  }
  @page{size:A4 portrait;margin:14mm 14mm 16mm 14mm}

  /* Header */
  .pv-header{
    border-bottom:1.5pt solid #1a1a1a;
    padding-bottom:10pt;margin-bottom:16pt;
  }
  .pv-eyebrow{
    font-size:8.5pt;letter-spacing:.22em;text-transform:uppercase;
    color:#a37b1a;font-weight:700;margin-bottom:6pt;
  }
  .pv-title{
    font-family:'Fraunces',Georgia,serif;font-size:26pt;font-weight:600;
    margin:0 0 5pt;line-height:1.05;letter-spacing:-.015em;color:#1a1a1a;
  }
  .pv-title-acc{color:#a37b1a;font-style:italic;font-weight:600;font-size:.7em;letter-spacing:0}
  .pv-meta{font-size:9pt;color:#666}
  .pv-meta span{font-family:'Spline Sans Mono',monospace;color:#333}

  /* Verdetto */
  .pv-verdict{
    background:#faf3df;
    border-left:3pt solid #a37b1a;
    padding:14pt 16pt;margin-bottom:14pt;
    page-break-inside:avoid;
  }
  .pv-verdict-eyebrow{
    font-size:8.5pt;letter-spacing:.18em;text-transform:uppercase;
    color:#a37b1a;font-weight:700;margin-bottom:7pt;
  }
  .pv-verdict-eyebrow span{font-family:'Spline Sans Mono',monospace;color:#1a1a1a;font-weight:700;letter-spacing:.04em}
  .pv-verdict-headline{
    font-family:'Fraunces',Georgia,serif;font-size:21pt;font-weight:600;
    line-height:1.1;color:#1a1a1a;margin-bottom:8pt;letter-spacing:-.015em;
  }
  .pv-verdict-headline .winner{font-style:italic;color:#a37b1a;font-weight:600}
  .pv-verdict-headline .winner.rent{color:#3e6592}
  .pv-verdict-headline .delta{
    font-family:'Spline Sans Mono',monospace;font-style:normal;font-weight:600;
    color:#a37b1a;font-size:.92em;letter-spacing:-.025em;
  }
  .pv-verdict-meta{font-size:10pt;color:#3a3a3a;line-height:1.5}
  .pv-verdict-meta b{color:#1a1a1a;font-weight:600}
  .pv-verdict-meta b.mono{font-family:'Spline Sans Mono',monospace;color:#1a1a1a}

  /* KPI */
  .pv-kpis{
    display:grid;grid-template-columns:1fr 1fr 1fr;gap:9pt;
    margin-bottom:14pt;page-break-inside:avoid;
  }
  .pv-kpi{
    border:0.75pt solid #cfcfcf;border-left:2.5pt solid #a37b1a;
    padding:9pt 12pt;background:#fff;
  }
  .pv-kpi .lbl{
    font-size:8pt;letter-spacing:.1em;text-transform:uppercase;
    color:#666;font-weight:700;margin-bottom:3pt;
  }
  .pv-kpi .val{
    font-family:'Spline Sans Mono',monospace;font-size:16pt;font-weight:600;
    color:#1a1a1a;margin:0;letter-spacing:-.02em;line-height:1.1;
  }
  .pv-kpi .val.pos{color:#1d7a52}
  .pv-kpi .val.neg{color:#b8453a}
  .pv-kpi .val.tie{color:#666}
  .pv-kpi .sub{
    font-family:'Spline Sans Mono',monospace;font-size:7.5pt;
    color:#888;margin-top:3pt;
  }

  /* Scenario */
  .pv-scenario{margin-bottom:14pt;page-break-inside:avoid}
  .pv-scenario h2,.pv-chart h2{
    font-family:'Fraunces',Georgia,serif;font-size:13pt;font-weight:600;
    color:#a37b1a;margin:0 0 8pt;
    border-bottom:0.5pt solid #cfcfcf;padding-bottom:4pt;
  }
  /* Reset di stili globali ereditati da th/td della dashboard */
  #house-print-view table,
  #house-print-view table th,
  #house-print-view table td,
  #house-print-view table tr{
    background:transparent !important;
    position:static !important;
    border-collapse:collapse;
  }
  .pv-scen-grid{display:grid;grid-template-columns:1fr 1fr;gap:18pt}
  .pv-scen-col h3{
    font-size:9pt;font-weight:700;color:#555;margin:0 0 5pt;
    text-transform:uppercase;letter-spacing:.08em;
  }
  .pv-scen-col table{width:100%;border-collapse:collapse;font-size:9.5pt}
  .pv-scen-col table th{
    text-align:left;font-weight:400;color:#555;
    padding:3.5pt 0;border-bottom:0.4pt dashed #d4d4d4;width:60%;
  }
  .pv-scen-col table td{
    font-family:'Spline Sans Mono',monospace;text-align:right;
    color:#1a1a1a;font-weight:500;
    padding:3.5pt 0;border-bottom:0.4pt dashed #d4d4d4;
  }

  /* Chart */
  .pv-chart{page-break-inside:avoid}
  #pv-chart{margin:6pt 0;width:100%}
  #pv-chart svg{width:100%;height:auto;display:block;max-height:90mm}
  .pv-chart-legend{
    display:flex;flex-direction:column;gap:2.5pt;
    font-size:9pt;color:#3a3a3a;margin-top:6pt;
  }
  .pv-chart-legend .dot{
    display:inline-block;width:14pt;height:2.5pt;
    margin-right:6pt;vertical-align:middle;border-radius:1pt;
  }
  .pv-chart-legend .dot.buy{background:#a37b1a}
  .pv-chart-legend .dot.rent{background:#4a6f9e}
  .pv-chart-legend .dot.be{background:#9a5b8e}

  /* Footer */
  .pv-footer{
    margin-top:18pt;padding-top:7pt;
    border-top:0.5pt solid #cfcfcf;
    font-size:8.5pt;color:#777;font-style:italic;line-height:1.4;
  }
}

/* ============================================================
   LEGAL PAGES (privacy, termini, disclaimer)
   Layout long-read editoriale, sobrio e leggibile.
   ============================================================ */
.legal-header {
  border-bottom: 1px solid var(--line);
  padding: 18px 22px;
  background: var(--ink);
}
.legal-header-inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}
.legal-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: var(--txt);
}
.legal-brand-mark {
  width: 32px; height: 32px;
  display: inline-grid; place-items: center;
  background: var(--ink);
  border: 1px solid var(--gold);
  border-radius: 7px;
  color: var(--gold);
  font-family: var(--serif);
  font-weight: 600;
  font-size: 18px;
  line-height: 1;
}
.legal-brand-name {
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -.01em;
}
.legal-back {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
  transition: color .2s;
}
.legal-back:hover { color: var(--gold-soft); }

.legal-page {
  max-width: 760px;
  margin: 0 auto;
  padding: 60px 22px 40px;
}
.legal-article .legal-eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 600;
}
.legal-article .legal-title {
  font-family: var(--serif);
  font-weight: 600;
  font-size: clamp(34px, 5vw, 52px);
  line-height: 1.05;
  letter-spacing: -.015em;
  color: var(--txt);
  margin: 18px 0 22px;
}
.legal-article .legal-title em {
  font-style: italic;
  color: var(--gold-soft);
}
.legal-article .legal-lead {
  font-size: 18px;
  line-height: 1.6;
  color: var(--txt);
  font-weight: 400;
  margin: 0 0 32px;
  padding-bottom: 26px;
  border-bottom: 1px solid var(--line);
}
.legal-article h2 {
  font-family: var(--serif);
  font-weight: 600;
  font-size: 24px;
  line-height: 1.2;
  letter-spacing: -.01em;
  color: var(--gold-soft);
  margin: 40px 0 12px;
}
.legal-article h3 {
  font-family: var(--sans);
  font-weight: 600;
  font-size: 16px;
  color: var(--txt);
  margin: 24px 0 8px;
}
.legal-article p,
.legal-article li {
  font-size: 15px;
  line-height: 1.7;
  color: var(--txt);
  margin: 0 0 14px;
}
.legal-article p strong { color: var(--gold-soft); font-weight: 600; }
.legal-article ul, .legal-article ol {
  margin: 0 0 18px 0;
  padding-left: 22px;
}
.legal-article li { margin-bottom: 6px; }
.legal-article a {
  color: var(--gold-soft);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: rgba(216,166,78,.4);
  transition: text-decoration-color .2s;
}
.legal-article a:hover { text-decoration-color: var(--gold); }
.legal-article .legal-callout {
  border-left: 3px solid var(--gold);
  padding: 14px 18px;
  background: var(--panel);
  border-radius: 8px;
  margin: 24px 0;
  font-size: 14px;
  line-height: 1.6;
  color: var(--muted);
}
.legal-article .legal-callout strong { color: var(--txt); font-weight: 600; }
.legal-article .legal-meta {
  margin-top: 48px;
  padding-top: 22px;
  border-top: 1px solid var(--line);
  font-family: var(--mono);
  font-size: 12px;
  color: var(--faint);
  letter-spacing: .04em;
}
.legal-article .legal-todo {
  background: rgba(216,166,78,.07);
  border: 1px dashed rgba(216,166,78,.4);
  padding: 10px 14px;
  border-radius: 6px;
  margin: 0 0 16px;
  font-size: 13px;
  color: var(--gold-soft);
  font-family: var(--mono);
}
.legal-article .legal-todo strong { color: var(--gold); }
