/* =====================================================================
   LOGICHE DINAMICHE — Pagine interne + pagina Soluzioni (matrice + prezzi)
   Usa i design-token di styles.css. Caricato solo dove serve.
   ===================================================================== */

/* a11y: testo solo per screen reader */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ----------  Hero pagine interne  ---------- */
.page-hero { padding-top: clamp(120px, 17vh, 180px); padding-bottom: clamp(32px, 5vw, 56px); }
.page-hero .breadcrumb { margin-bottom: 1.2rem; }
.page-hero h1 {
  font-family: var(--font-display); font-weight: 600;
  font-size: clamp(2.2rem, 6vw, 4rem); line-height: 1.02; letter-spacing: -.03em;
  margin: 1rem 0 0;
}
.page-hero .lead { margin-top: 1.2rem; font-size: clamp(1.05rem, 1.6vw, 1.25rem); max-width: 58ch; }
.page-hero__actions { display: flex; flex-wrap: wrap; gap: .9rem; margin-top: 2rem; }

/* breadcrumb (replica da blog.css, così pages.css è autonomo) */
.breadcrumb { font-family: var(--font-mono); font-size: .74rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-faint); display: flex; gap: .6em; flex-wrap: wrap; }
.breadcrumb a { color: var(--ink-soft); }
.breadcrumb a:hover { color: var(--accent); }
.breadcrumb span[aria-current] { color: var(--accent); }

/* ----------  Sezione generica + intestazione  ---------- */
.psec { padding-block: clamp(56px, 9vw, 110px); }
.psec--alt { background: linear-gradient(180deg, transparent, var(--bg-2) 45%, transparent); }

/* ----------  Banda "incluso in ogni piano"  ---------- */
.included {
  border: 1px solid var(--border); border-radius: var(--r-xl);
  background: linear-gradient(155deg, var(--surface-2), var(--bg-2));
  padding: clamp(24px, 4vw, 40px); position: relative; overflow: hidden;
}
.included__h { font-family: var(--font-mono); font-size: .72rem; letter-spacing: .18em; text-transform: uppercase; color: var(--accent); margin-bottom: 1.3rem; display: inline-flex; align-items: center; gap: .6em; }
.included__h::before { content: ""; width: 24px; height: 1px; background: var(--accent); }
.included__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: .8rem 1.6rem; }
@media (max-width: 860px){ .included__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px){ .included__grid { grid-template-columns: 1fr; } }
.included__grid li { list-style: none; display: flex; gap: .6rem; align-items: flex-start; color: var(--ink-soft); font-size: .94rem; }
.included__grid svg { width: 18px; height: 18px; color: var(--accent); flex: none; margin-top: .15em; }

/* ----------  Toggle Mensile / Annuale  ---------- */
.bill-toggle { display: inline-flex; align-items: center; gap: .3rem; padding: .35rem; border: 1px solid var(--border); border-radius: var(--r-pill); background: var(--surface); }
.bill-toggle button {
  font-family: var(--font-mono); font-size: .76rem; letter-spacing: .06em; text-transform: uppercase;
  color: var(--ink-soft); padding: .55em 1.1em; border-radius: var(--r-pill); transition: background .3s, color .3s;
}
.bill-toggle button.on { background: var(--accent); color: var(--accent-ink); font-weight: 600; }
.bill-toggle__save { font-family: var(--font-mono); font-size: .72rem; letter-spacing: .04em; color: var(--accent); margin-left: .9rem; }

/* mostra/nascondi prezzi in base alla modalità (default markup: is-annual) */
.pricing .price--m { display: none; }
.pricing .price--y { display: inline-flex; }
.pricing.is-monthly .price--m { display: inline-flex; }
.pricing.is-monthly .price--y { display: none; }

/* ----------  Card tier (3 piani)  ---------- */
.tiers { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; align-items: stretch; margin-top: 2.2rem; }
@media (max-width: 980px){ .tiers { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; } }
.tier {
  display: flex; flex-direction: column;
  border: 1px solid var(--border); border-radius: var(--r-xl);
  padding: 1.9rem 1.7rem; background: var(--surface); position: relative; overflow: hidden;
  transition: transform .4s var(--ease-out), border-color .4s;
}
.tier:hover { transform: translateY(-5px); border-color: var(--accent); }
.tier--featured { background: linear-gradient(180deg, var(--surface-2), var(--surface)); }
.tier--featured::before {
  content: ""; position: absolute; inset: 0; border-radius: inherit; padding: 1px; pointer-events: none;
  background: linear-gradient(160deg, var(--accent-soft), transparent 45%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
}
.tier__badge { position: absolute; top: 1.3rem; right: 1.3rem; font-family: var(--font-mono); font-size: .64rem; letter-spacing: .14em; text-transform: uppercase; color: var(--accent-ink); background: var(--accent); border-radius: var(--r-pill); padding: .35em .8em; font-weight: 600; }
.tier__name { font-family: var(--font-display); font-weight: 600; font-size: 1.5rem; letter-spacing: -.015em; }
.tier__tagline { color: var(--ink-soft); font-size: .9rem; margin-top: .3rem; min-height: 2.6em; }
.tier__price { display: flex; flex-direction: column; margin: 1.2rem 0 .2rem; min-height: 4.4rem; }
.tier__price .price { align-items: baseline; gap: .35rem; flex-wrap: wrap; }
.tier__price .amt { font-family: var(--font-display); font-weight: 600; font-size: 2.6rem; letter-spacing: -.02em; line-height: 1; }
.tier__price .per { color: var(--ink-soft); font-size: .9rem; }
.tier__price .eff { width: 100%; color: var(--accent); font-family: var(--font-mono); font-size: .74rem; letter-spacing: .02em; margin-top: .4rem; }
.tier__list { list-style: none; padding: 0; display: grid; gap: .65rem; margin: 1.4rem 0 1.7rem; }
.tier__list li { display: flex; gap: .6rem; align-items: flex-start; font-size: .92rem; color: var(--ink-soft); }
.tier__list li > span { flex: 1; min-width: 0; } /* testo come singolo blocco: wrappa allineato dopo l'icona */
.tier__list li b { color: var(--ink); font-weight: 600; }
.tier__list svg { width: 17px; height: 17px; color: var(--accent); flex: none; margin-top: .15em; }
.tier .btn { margin-top: auto; justify-content: center; }

/* ----------  Matrice di confronto completa  ---------- */
.matrix-scroll { overflow-x: auto; margin-top: 2.4rem; border-radius: var(--r-lg); -webkit-overflow-scrolling: touch; }
.matrix { width: 100%; border-collapse: collapse; min-width: 640px; }
.matrix caption { text-align: left; color: var(--ink-faint); font-family: var(--font-mono); font-size: .74rem; letter-spacing: .1em; text-transform: uppercase; padding-bottom: 1rem; }
.matrix th, .matrix td { padding: 1rem 1.1rem; text-align: left; border-bottom: 1px solid var(--border-soft); vertical-align: top; }
.matrix thead th { background: var(--bg-2); text-align: center; vertical-align: bottom; }
.matrix thead th:first-child { text-align: left; }
.matrix thead .tname { font-family: var(--font-display); font-weight: 600; font-size: 1.15rem; }
.matrix thead .tprice { display: block; color: var(--accent); font-family: var(--font-mono); font-size: .8rem; margin-top: .25rem; font-weight: 600; }
.matrix thead .tprice .price--m, .matrix thead .tprice .price--y { gap: .25rem; }
.matrix tbody th { font-weight: 500; color: var(--ink); width: 38%; }
.matrix tbody td { color: var(--ink-soft); text-align: center; }
.matrix tbody th[scope="row"] { text-align: left; }
.matrix col.col-feat { width: 34%; }
.matrix .yes svg { width: 19px; height: 19px; color: var(--accent); display: inline-block; }
.matrix .no { color: var(--ink-faint); }
.matrix tbody tr:hover td, .matrix tbody tr:hover th { background: rgba(255,255,255,.015); }
.matrix .row-price th, .matrix .row-price td { border-top: 1px solid var(--border); font-weight: 600; }
.matrix .row-price td { color: var(--ink); }

/* asterisco + nota a piè di matrice */
.ast { color: var(--accent); font-weight: 700; }
.matrix-note { margin-top: 1rem; color: var(--ink-faint); font-size: .82rem; line-height: 1.5; max-width: 70ch; }
.matrix-note .ast { margin-right: .2em; }

/* tooltip "in sovraimpressione" (su hover/focus) */
.tip { position: relative; color: var(--accent); font-weight: 700; cursor: help; }
.tip:focus { outline: none; }
.tip__box {
  position: absolute; top: 150%; left: 50%; transform: translate(-50%, 4px); z-index: 20;
  width: max-content; max-width: 240px;
  background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--r-sm);
  padding: .7em .85em; font-size: .8rem; font-weight: 400; color: var(--ink-soft); line-height: 1.5;
  box-shadow: var(--shadow-card);
  opacity: 0; visibility: hidden; transition: opacity .2s var(--ease), transform .2s var(--ease), visibility .2s;
}
.tip__box::before {
  content: ""; position: absolute; bottom: 100%; left: 50%; transform: translateX(-50%);
  border: 6px solid transparent; border-bottom-color: var(--border);
}
.tip:hover .tip__box, .tip:focus .tip__box, .tip:focus-within .tip__box { opacity: 1; visibility: visible; transform: translate(-50%, 0); }

/* ----------  Box riscatto  ---------- */
.buyout {
  margin-top: 2.6rem; display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(24px, 4vw, 48px);
  border: 1px solid var(--border); border-radius: var(--r-xl);
  background: linear-gradient(155deg, var(--surface-2), var(--bg-2));
  padding: clamp(24px, 4vw, 44px); position: relative; overflow: hidden;
}
@media (max-width: 760px){ .buyout { grid-template-columns: 1fr; } }
.buyout::before { content: ""; position: absolute; width: 340px; height: 340px; right: -120px; top: -130px; background: radial-gradient(circle, var(--accent-glow), transparent 65%); opacity: .2; pointer-events: none; }
.buyout h3 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.4rem, 3vw, 1.9rem); letter-spacing: -.02em; position: relative; }
.buyout p { color: var(--ink-soft); margin-top: .9rem; position: relative; }
.buyout__example { border: 1px solid var(--border); border-radius: var(--r); background: rgba(0,0,0,.22); padding: 1.3rem 1.4rem; position: relative; }
.buyout__example .k { font-family: var(--font-mono); font-size: .7rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-faint); }
.buyout__row { display: flex; justify-content: space-between; gap: 1rem; padding: .55rem 0; border-bottom: 1px solid var(--border-soft); font-size: .92rem; color: var(--ink-soft); }
.buyout__row:last-child { border-bottom: none; }
.buyout__row b { color: var(--ink); }
.buyout__row.tot b { color: var(--accent); font-family: var(--font-display); font-size: 1.15rem; }

/* ----------  Card "oltre la membership" (Enterprise / Custom)  ---------- */
.beyond { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; margin-top: 2.2rem; }
@media (max-width: 820px){ .beyond { grid-template-columns: 1fr; } }
.beyond__card {
  border: 1px solid var(--border); border-radius: var(--r-xl); padding: 2rem 1.8rem;
  background: linear-gradient(180deg, var(--surface-2), var(--surface)); position: relative; overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .4s var(--ease-out), border-color .4s;
}
.beyond__card:hover { transform: translateY(-5px); border-color: var(--accent); }
.beyond__card .plan__k { font-family: var(--font-mono); font-size: .74rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-faint); }
.beyond__card h3 { font-family: var(--font-display); font-weight: 600; font-size: 1.6rem; margin: .5rem 0 .3rem; letter-spacing: -.015em; }
.beyond__card .price-tag { font-family: var(--font-display); font-weight: 600; font-size: 1.4rem; color: var(--ink); margin: .6rem 0 1rem; }
.beyond__card p { color: var(--ink-soft); font-size: .95rem; margin-bottom: 1.2rem; }
.beyond__card ul { list-style: none; padding: 0; display: grid; gap: .6rem; margin-bottom: 1.6rem; }
.beyond__card li { display: flex; gap: .6rem; align-items: flex-start; font-size: .92rem; color: var(--ink-soft); }
.beyond__card svg.chk { width: 17px; height: 17px; color: var(--accent); flex: none; margin-top: .15em; }
.beyond__card .btn { margin-top: auto; }

/* ----------  Liste feature generiche (pagine interne)  ---------- */
.feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.1rem; }
@media (max-width: 900px){ .feature-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px){ .feature-grid { grid-template-columns: 1fr; } }
.feature-card { border: 1px solid var(--border); border-radius: var(--r-lg); padding: 1.6rem 1.5rem; background: linear-gradient(180deg, var(--surface), var(--bg-2)); transition: transform .4s var(--ease-out), border-color .4s; }
.feature-card:hover { transform: translateY(-4px); border-color: var(--accent); }
.feature-card__ico { width: 38px; height: 38px; color: var(--accent); margin-bottom: 1rem; }
.feature-card h3 { font-family: var(--font-display); font-weight: 600; font-size: 1.15rem; margin-bottom: .5rem; letter-spacing: -.01em; }
.feature-card p { color: var(--ink-soft); font-size: .93rem; }

/* prose generica per pagine di contenuto */
.page-prose { max-width: 70ch; }
.page-prose p { color: var(--ink-soft); margin-bottom: 1.1em; font-size: 1.03rem; line-height: 1.7; }
.page-prose p b, .page-prose strong { color: var(--ink); font-weight: 600; }

/* CTA band riusabile a fine pagina */
.cta-band {
  border: 1px solid var(--border); border-radius: var(--r-xl);
  background: linear-gradient(155deg, var(--surface-2), var(--bg-2));
  padding: clamp(28px, 5vw, 56px); text-align: center; position: relative; overflow: hidden;
}
.cta-band::before { content: ""; position: absolute; width: 360px; height: 360px; left: 50%; top: -160px; transform: translateX(-50%); background: radial-gradient(circle, var(--accent-glow), transparent 65%); opacity: .2; pointer-events: none; }
.cta-band h2 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.7rem, 4vw, 2.6rem); letter-spacing: -.02em; position: relative; }
.cta-band p { color: var(--ink-soft); max-width: 50ch; margin: 1rem auto 1.8rem; position: relative; }
.cta-band .page-hero__actions, .cta-band__actions { justify-content: center; display: flex; flex-wrap: wrap; gap: .9rem; position: relative; }
