/* =================================================================
   Talenis · Stile editoriale, dark obsidian, mint accent
   Mobile-first. Vanilla CSS. Nessun build.
   ================================================================= */

/* ----- Design tokens --------------------------------------------- */
:root {
  /* Surfaces */
  --bg:               oklch(11% 0.014 275);
  --bg-elev:          oklch(14% 0.018 275);
  --bg-elev-2:        oklch(18% 0.02 275);
  --bg-inverse:       oklch(96% 0.03 85);

  /* Hairlines */
  --line:             oklch(28% 0.01 85);
  --line-strong:      oklch(36% 0.012 85);

  /* Ink (warm cream palette) */
  --ink:              oklch(96% 0.03 85);
  --ink-soft:         oklch(78% 0.025 85);
  --ink-mute:         oklch(58% 0.02 85);
  --ink-dim:          oklch(42% 0.018 85);

  /* Color accents */
  --brand:            oklch(70% 0.2 285);
  --brand-soft:       oklch(82% 0.16 285);
  --mint:             oklch(82% 0.14 165);
  --mint-strong:      oklch(76% 0.18 165);
  --warn:             oklch(82% 0.14 75);
  --danger:           oklch(72% 0.2 25);

  /* Typography */
  --font-display:     'Instrument Serif', 'Times New Roman', Georgia, serif;
  --font-body:        'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --font-mono:        'JetBrains Mono', ui-monospace, 'SFMono-Regular', Menlo, Consolas, monospace;

  /* Radii */
  --r-xs:             6px;
  --r-sm:             10px;
  --r:                14px;
  --r-lg:             22px;
  --r-xl:             28px;
  --r-pill:           999px;

  /* Shadows */
  --shadow-sm:        0 1px 2px rgb(0 0 0 / 0.4);
  --shadow:           0 18px 50px -22px rgb(0 0 0 / 0.65);
  --shadow-pill:      0 8px 24px -12px rgb(0 0 0 / 0.55), 0 2px 6px -2px rgb(0 0 0 / 0.4);
  --shadow-card:      0 40px 100px -40px rgb(0 0 0 / 0.85), 0 0 0 1px var(--line);
  --shadow-glow:      0 0 100px -10px oklch(70% 0.2 285 / 0.25);

  /* Layout */
  --content-w:        1180px;
  --reading-w:        70ch;

  /* Motion */
  --ease:             cubic-bezier(0.2, 0.8, 0.2, 1);
  --ease-soft:        cubic-bezier(0.32, 0.72, 0, 1);
  --t-fast:           160ms;
  --t:                280ms;
  --t-slow:           560ms;
}

/* ----- Reset & base --------------------------------------------- */
*,
*::before,
*::after { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }

button:focus:not(:focus-visible),
a:focus:not(:focus-visible),
input:focus:not(:focus-visible) {
    outline: none;
}

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-behavior: smooth;
  scroll-padding-top: 100px;
  /* Niente rubber-band/overscroll bounce ai limiti dello scroll (iOS/Android).
     L'effetto distorceva il layout quando si raggiungeva cima/fondo pagina. */
  overscroll-behavior: none;
}

body { overscroll-behavior: none; }

body {
  margin: 0;
  min-height: 100vh;
  width: 100%;
  max-width: 100vw;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: clip;
  background-image:
    radial-gradient(900px 600px at 10% -10%, oklch(70% 0.2 285 / 0.10), transparent 60%),
    radial-gradient(800px 500px at 95% 25%, oklch(82% 0.14 165 / 0.06), transparent 60%);
  background-attachment: fixed;
}

/* Safety: blocca scorrimenti orizzontali residui generati da elementi
   con white-space:nowrap o auroras che si estendono oltre i bordi. */
html { overflow-x: clip; }
main { overflow-x: clip; }

img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; }
ul { list-style: none; padding: 0; margin: 0; }
p { margin: 0; }

::selection {
  background: var(--brand);
  color: #0a0a10;
}

:focus-visible {
  outline: 2px solid var(--brand-soft);
  outline-offset: 3px;
  border-radius: 6px;
}

/* ----- Grain (subtle film texture) ------------------------------ */
.grain {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  opacity: 0.045;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 256 256'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  background-size: 256px;
}

/* ----- Utilities ------------------------------------------------ */
.container {
  width: 100%;
  max-width: var(--content-w);
  margin: 0 auto;
  padding: 0 20px;
}
@media (min-width: 760px) { .container { padding: 0 32px; } }

.mono {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
}

.muted { color: var(--ink-mute); }

/* ----- Typography primitives ----------------------------------- */
.display {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: normal;
  line-height: 1.02;
  letter-spacing: -0.025em;
  margin: 0;
  color: var(--ink);
}
.display em {
  font-style: italic;
  color: var(--brand-soft);
}
.display--xl {
  font-size: clamp(3rem, 8vw, 6rem);
  max-width: 18ch;
}
.display--lg {
  font-size: clamp(2.2rem, 5vw, 3.6rem);
  max-width: 22ch;
  margin: 14px 0 56px;
}
.display--md {
  font-size: clamp(1.7rem, 3.5vw, 2.4rem);
  max-width: 26ch;
}

/* Editorial section label */
.section-label {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 0 0 24px;
  font-family: var(--font-mono);
  font-size: 0.74rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.section-label__num {
  color: var(--brand-soft);
}
.section-label__rule {
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, var(--line-strong), transparent);
}
.section-label__date { color: var(--ink-dim); }
.section-label--center {
  justify-content: center;
  text-align: center;
}
.section-label--center .section-label__rule { display: none; }

/* legacy/utility eyebrow */
.eyebrow {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--brand-soft);
  margin: 0 0 14px;
  font-weight: 500;
}

/* ----- Buttons -------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 13px 20px;
  border-radius: var(--r);
  font-family: inherit;
  font-weight: 600;
  font-size: 0.95rem;
  letter-spacing: -0.005em;
  border: 1px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  transition:
    transform var(--t-fast) var(--ease),
    background var(--t) var(--ease),
    border-color var(--t) var(--ease),
    box-shadow var(--t) var(--ease),
    color var(--t) var(--ease);
  -webkit-tap-highlight-color: transparent;
  text-decoration: none;
}
.btn__icon { display: inline-flex; align-items: center; }
.btn__arrow {
  display: inline-block;
  transition: transform var(--t) var(--ease);
}
.btn:hover .btn__arrow { transform: translateX(4px); }

.btn--sm { padding: 8px 14px; font-size: 0.86rem; border-radius: var(--r-sm); }
.btn--lg { padding: 14px 22px; font-size: 1rem; }
.btn--block { width: 100%; }

.btn--primary {
  background: var(--ink);
  color: oklch(10% 0.01 280);
  border-color: var(--ink);
}
.btn--primary:hover {
  transform: translateY(-1px);
  background: #fff;
  border-color: #fff;
  box-shadow: 0 12px 32px -14px rgb(255 255 255 / 0.25);
}
.btn--primary:active { transform: translateY(0); }

.btn--ghost {
  background: transparent;
  border-color: var(--line-strong);
  color: var(--ink);
}
.btn--ghost:hover {
  background: oklch(96% 0.03 85 / 0.06);
  border-color: var(--ink-mute);
}

.btn--google {
  background: var(--ink);
  color: oklch(15% 0.01 280);
  border-color: var(--ink);
}
.btn--google:hover {
  background: #fff;
  transform: translateY(-1px);
}

.btn--danger {
  background: color-mix(in oklab, var(--danger) 18%, var(--bg-elev));
  color: var(--ink);
  border-color: color-mix(in oklab, var(--danger) 55%, var(--line-strong));
}
.btn--danger:hover {
  background: color-mix(in oklab, var(--danger) 32%, var(--bg-elev));
  border-color: var(--danger);
  color: var(--ink);
}
.btn--danger:active { transform: translateY(0); }

/* link with arrow (editorial) */
.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 500;
  color: var(--ink);
  border-bottom: 1px solid var(--line-strong);
  padding-bottom: 4px;
  transition: border-color var(--t), gap var(--t);
}
.link-arrow:hover {
  border-color: var(--ink);
  gap: 12px;
}

/* ----- Brand ---------------------------------------------------- */
.brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
}
.brand__name {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: -0.01em;
  line-height: 1;
  font-style: italic;
}
/* Puntino viola — parte ufficiale del logo. Reso via pseudo-elemento così
   non serve aggiornare il markup ovunque venga usato .brand__name. */
.brand__name::after {
  content: '.';
  color: var(--brand);
  margin-left: 1px;
}
/* ----- Header (pill nav) --------------------------------------- */
/* Fixed sopra il contenuto: in questo modo il <main> di ogni pagina
   parte da y=0 e l'aurora/sfondo della pagina riempie l'area dietro
   la pill — niente più fascia nera "vuota" sopra la navbar.
   Ogni sezione di pagina (.hero, .dashboard, .auth, ecc.) compensa
   con un padding-top dedicato per non finire sotto la pill. */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  display: flex;
  justify-content: center;
  padding: 12px 14px 8px;
  background: transparent;
  pointer-events: none; 
}
.site-header > * { pointer-events: auto; }
.site-header__pill {
  position: relative;
  width: 100%;
  max-width: calc(var(--content-w) - 40px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  height: 60px;
  padding: 6px 8px 6px 18px;
  /* Liquid glass: vetro con riflesso specolare in alto, blur/saturazione
     spinti per l'effetto "frosted" coerente con menu e bottom-nav. */
  background:
    linear-gradient(180deg, oklch(100% 0 0 / 0.07), oklch(100% 0 0 / 0) 60%),
    color-mix(in oklab, var(--bg-elev) 82%, transparent);
  backdrop-filter: blur(28px) saturate(180%);
  -webkit-backdrop-filter: blur(28px) saturate(180%);
  border: 1px solid color-mix(in oklab, oklch(100% 0 0) 10%, var(--line-strong));
  border-radius: var(--r-pill);
  box-shadow:
    var(--shadow-pill),
    inset 0 1px 0 oklch(100% 0 0 / 0.14),
    inset 0 -1px 0 oklch(0% 0 0 / 0.22);
}

/* Pulsanti dentro la pill: stadium-shape come la pill, mai angoli sharp.
   Forzati con !important per scavalcare eventuali override successivi
   da .btn--sm (border-radius: var(--r-sm)). */
.site-header__pill .btn,
.site-header__pill .btn--sm {
  border-radius: var(--r-pill) !important;
  padding: 8px 16px;
  font-size: 0.86rem;
  line-height: 1.15;
  white-space: nowrap;
}
.site-header__pill .btn__arrow { font-size: 0.95em; }
@media (max-width: 480px) {
  .site-header__pill .btn,
  .site-header__pill .btn--sm { padding: 7px 12px; font-size: 0.8rem; }
  .site-header__pill { gap: 8px; }
}
@media (max-width: 360px) {
  .site-header__pill .btn,
  .site-header__pill .btn--sm { padding: 6px 10px; font-size: 0.78rem; }
}

.site-nav {
  display: none;
  gap: 22px;
  align-items: center;
}
.nav-link {
  position: relative;
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  color: var(--ink-soft);
  font-size: 0.9rem;
  font-weight: 500;
  transition: color var(--t-fast);
}
.nav-link:hover { color: var(--ink); }
.nav-link__num {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  color: var(--ink-dim);
  letter-spacing: 0.05em;
}
.nav-link:hover .nav-link__num { color: var(--brand-soft); }

.auth-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

@media (max-width: 420px) {
  .auth-actions__login { display: none; }
  .site-header__pill { padding-left: 16px; }
}
@media (min-width: 980px) {
  .site-nav { display: flex; }
  .site-header__pill { padding-left: 22px; }
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative;
  padding: 140px 0 28px;
  isolation: isolate;
  overflow: hidden;
}
@media (max-width: 640px) {
  .hero { padding-top: 116px; }
}

.hero__aurora {
  position: absolute;
  inset: -25% -10% 30% -10%;
  z-index: -1;
  background:
    radial-gradient(50% 60% at 25% 30%, oklch(70% 0.2 285 / 0.40), transparent 70%),
    radial-gradient(40% 50% at 80% 20%, oklch(82% 0.14 165 / 0.18), transparent 72%),
    radial-gradient(60% 50% at 60% 80%, oklch(70% 0.2 320 / 0.10), transparent 72%);
  filter: blur(50px);
  pointer-events: none;
}

.hero__label { margin-bottom: 40px; }

.hero__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 36px;
  align-items: end;
}
@media (min-width: 980px) {
  .hero__grid {
    grid-template-columns: 1.4fr 1fr;
    gap: 56px;
  }
}

.hero__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(3rem, 9vw, 6.8rem);
  line-height: 0.94;
  letter-spacing: -0.03em;
  margin: 0;
}
.hero__title em {
  font-style: italic;
  color: var(--brand-soft);
}
.hero__title-mark {
  position: relative;
  display: inline-block;
}
.hero__title-mark::after {
  content: '';
  position: absolute;
  left: -2%;
  right: -2%;
  bottom: 0.08em;
  height: 0.18em;
  background: var(--mint);
  border-radius: 2px;
  opacity: 0.85;
  z-index: -1;
}

.hero__aside {
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.hero__lede {
  font-size: 1.05rem;
  color: var(--ink-soft);
  line-height: 1.6;
  max-width: 44ch;
}
.hero__lede strong { color: var(--ink); font-weight: 600; }

.hero__cta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.hero__micro {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  color: var(--ink-mute);
}
.hero__micro-star { color: var(--mint); }

.hero__about-link {
  margin: -4px 0 0;
  font-size: 0.92rem;
}
.hero__about-link .link-arrow {
  color: var(--ink-soft);
}
.hero__about-link .link-arrow:hover {
  color: var(--brand-soft);
}

@media (min-width: 760px) { .hero { padding: 88px 0 40px; } }

/* ============================================================
   MOCKUP DASHBOARD (faux preview)
   ============================================================ */
.mockup {
  margin: 64px 0 0;
  background: linear-gradient(180deg, var(--bg-elev), var(--bg-elev-2));
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}
@media (min-width: 760px) { .mockup { margin-top: 88px; } }

.mockup__chrome {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
  background: oklch(15% 0.012 280);
  border-bottom: 1px solid var(--line);
}
.mockup__dots {
  display: inline-flex;
  gap: 6px;
}
.mockup__dots span {
  display: block;
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: var(--line-strong);
}
.mockup__dots span:nth-child(1) { background: oklch(72% 0.2 25); }
.mockup__dots span:nth-child(2) { background: oklch(82% 0.14 75); }
.mockup__dots span:nth-child(3) { background: oklch(76% 0.18 145); }
.mockup__url {
  flex: 1;
  text-align: center;
  font-size: 0.78rem;
  color: var(--ink-mute);
  padding: 6px 14px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  max-width: 280px;
  margin: 0 auto;
  letter-spacing: -0.005em;
}
.mockup__url .mono { color: var(--ink-soft); }
.mockup__user {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--brand);
  color: oklch(12% 0.01 280);
  font-weight: 700;
  font-size: 0.82rem;
}

.mockup__body {
  padding: 22px 18px;
}
@media (min-width: 720px) { .mockup__body { padding: 28px 28px; } }

.mockup__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 20px;
  margin-bottom: 24px;
  padding-bottom: 20px;
  border-bottom: 1px dashed var(--line);
}
.mockup__eyebrow {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 6px;
}
.mockup__amount {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2.2rem, 5vw, 3.4rem);
  line-height: 1;
  letter-spacing: -0.02em;
  margin: 0;
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  color: var(--ink);
}
.mockup__amount small {
  font-family: var(--font-display);
  font-size: 0.55em;
  color: var(--ink-mute);
  vertical-align: top;
}
.mockup__amount .mono {
  font-family: var(--font-mono);
  font-size: 0.6em;
  color: var(--ink-mute);
  font-weight: 400;
  align-self: flex-end;
}
.mockup__delta {
  font-size: 0.82rem;
  color: var(--ink-soft);
  margin: 8px 0 0;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.mockup__delta-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--mint);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--mint) 28%, transparent);
}
.mockup__date {
  text-align: right;
  border-left: 1px solid var(--line);
  padding-left: 18px;
}
.mockup__date-day {
  font-size: 1.6rem;
  line-height: 1;
  color: var(--ink);
  margin: 0;
}
.mockup__date-mo {
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  color: var(--ink-mute);
  margin: 4px 0 8px;
}
.mockup__date-sub {
  font-size: 0.74rem;
  color: var(--ink-dim);
  margin: 0;
}

.mockup__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
@media (min-width: 880px) {
  .mockup__grid {
    grid-template-columns: 1.4fr 1fr;
    gap: 22px;
  }
}

.mockup__panel,
.mockup__goal,
.mockup__txns {
  background: oklch(16% 0.014 275);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 18px 18px;
}

.mockup__panel-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 14px;
}
.mockup__panel-title {
  font-size: 0.95rem;
  color: var(--ink);
  margin: 0;
  font-weight: 600;
  letter-spacing: -0.01em;
}
.mockup__panel-meta {
  font-size: 0.72rem;
  color: var(--ink-mute);
  letter-spacing: 0.06em;
  margin: 0;
}

.mockup__cats {
  display: grid;
  gap: 14px;
}
.mockup__cat {
  display: grid;
  grid-template-columns: 88px 1fr 84px;
  gap: 12px;
  align-items: center;
  font-size: 0.88rem;
}
.mockup__cat-name { color: var(--ink-soft); }
.mockup__cat-num { color: var(--ink); text-align: right; font-size: 0.78rem; }
.mockup__bar {
  position: relative;
  height: 6px;
  background: var(--line);
  border-radius: var(--r-pill);
  overflow: hidden;
}
.mockup__bar-fill {
  display: block;
  height: 100%;
  width: var(--p);
  max-width: 100%;
  background: var(--brand-soft);
  border-radius: var(--r-pill);
  transition: width 600ms var(--ease);
}
.mockup__bar-fill--warn   { background: var(--warn); }
.mockup__bar-fill--danger { background: var(--danger); }

.mockup__side {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.mockup__goal-body {
  display: flex;
  align-items: center;
  gap: 18px;
}
.mockup__ring {
  --p: 0;
  position: relative;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: conic-gradient(var(--mint) calc(var(--p) * 1%), var(--line) 0);
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.mockup__ring::before {
  content: '';
  position: absolute;
  inset: 6px;
  border-radius: 50%;
  background: oklch(16% 0.014 275);
}
.mockup__ring > span {
  position: relative;
  z-index: 1;
  font-size: 0.78rem;
  color: var(--ink);
}
.mockup__goal-name {
  margin: 0;
  font-size: 0.95rem;
  color: var(--ink);
  font-weight: 500;
}
.mockup__goal-num {
  margin: 4px 0 0;
  font-size: 0.78rem;
  color: var(--ink-mute);
}

.mockup__txns ul { display: grid; gap: 10px; }
.mockup__txn {
  display: grid;
  grid-template-columns: 28px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px dashed var(--line);
  font-size: 0.88rem;
}
.mockup__txn:last-child { border-bottom: 0; }
.mockup__txn-tag {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  font-weight: 700;
  font-size: 0.78rem;
  color: oklch(15% 0.01 280);
}
.mockup__txn-tag--abbo { background: oklch(82% 0.16 285); }
.mockup__txn-tag--food { background: oklch(82% 0.14 75); }
.mockup__txn-tag--in   { background: var(--mint); }
.mockup__txn-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.mockup__txn-text > span:first-child {
  color: var(--ink);
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.mockup__txn-sub {
  font-size: 0.7rem;
  color: var(--ink-dim);
  letter-spacing: 0.04em;
}
.mockup__txn-amt {
  font-size: 0.85rem;
  color: var(--ink);
  white-space: nowrap;
}
.mockup__txn-amt--pos { color: var(--mint); }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee {
  margin: 56px 0;
  padding: 22px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
  background: linear-gradient(180deg, transparent, oklch(13% 0.014 275));
}
.marquee__track {
  display: flex;
  width: max-content;
  animation: marquee 38s linear infinite;
}
.marquee__group {
  display: inline-flex;
  align-items: center;
  gap: 38px;
  padding-right: 38px;
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 4vw, 2.6rem);
  color: var(--ink);
}
.marquee__group em {
  font-style: italic;
  white-space: nowrap;
}
.marquee__star {
  font-style: normal;
  color: var(--brand-soft);
  font-size: 0.7em;
}
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .marquee__track { animation: none; }
}

/* ============================================================
   MANIFESTO
   ============================================================ */
.manifesto { padding: 64px 0; }
@media (min-width: 760px) { .manifesto { padding: 96px 0; } }

.manifesto__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border-top: 1px solid var(--line);
}
@media (min-width: 760px) {
  .manifesto__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.manifesto__item {
  padding: 28px 0;
  border-bottom: 1px solid var(--line);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
@media (min-width: 760px) {
  .manifesto__item {
    padding: 32px 28px;
  }
  .manifesto__item:nth-child(2n) {
    border-left: 1px solid var(--line);
  }
}

.manifesto__num {
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  color: var(--brand-soft);
  margin: 0;
}
.manifesto__item h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.4rem, 2.4vw, 1.8rem);
  letter-spacing: -0.015em;
  margin: 0;
  color: var(--ink);
}
.manifesto__item p {
  color: var(--ink-soft);
  font-size: 0.98rem;
  max-width: 50ch;
  margin-top: 6px;
}
.manifesto__item em {
  font-style: italic;
  color: var(--ink);
}

.manifesto__cta {
  margin-top: 40px;
  padding: 28px 26px;
  border: 1px dashed var(--line-strong);
  border-radius: var(--r-lg);
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: flex-start;
  background:
    radial-gradient(60% 100% at 0% 0%, oklch(70% 0.2 285 / 0.08), transparent 70%),
    transparent;
}
@media (min-width: 640px) {
  .manifesto__cta {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 28px;
    padding: 24px 30px;
  }
}
.manifesto__cta-text {
  font-family: var(--font-display);
  font-size: clamp(1.15rem, 2vw, 1.4rem);
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 0;
  line-height: 1.3;
}
.manifesto__cta-text em {
  font-style: italic;
  color: var(--brand-soft);
}
.manifesto__cta-btn { flex-shrink: 0; }

/* ============================================================
   FEATURES BENTO
   ============================================================ */
.features { padding: 64px 0; }
@media (min-width: 760px) { .features { padding: 96px 0; } }

.bento {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
@media (min-width: 720px) {
  .bento { grid-template-columns: repeat(2, 1fr); }
  .bento__card--feat { grid-column: span 2; }
  .bento__card--wide { grid-column: span 2; }
  .bento__card--edu  { grid-column: span 2; }
}
@media (min-width: 1080px) {
  .bento {
    grid-template-columns: repeat(3, 1fr);
    grid-auto-rows: minmax(220px, auto);
  }
  .bento__card--feat { grid-column: span 2; grid-row: span 2; }
  .bento__card--wide { grid-column: span 2; grid-row: span 1; }
  .bento__card--edu  { grid-column: span 2; grid-row: span 1; }
}

.bento__card {
  position: relative;
  padding: 24px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: border-color var(--t) var(--ease), background var(--t) var(--ease), transform var(--t) var(--ease);
  overflow: hidden;
}
.bento__card:hover {
  border-color: var(--line-strong);
  background: var(--bg-elev-2);
  transform: translateY(-2px);
}

.bento__num {
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0;
}

.bento__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.7rem, 2.6vw, 2.2rem);
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 0;
  color: var(--ink);
}
.bento__title em {
  font-style: italic;
  color: var(--brand-soft);
}
.bento__title-sm {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.25rem;
  letter-spacing: -0.01em;
  margin: 0;
  line-height: 1.15;
  color: var(--ink);
}

.bento__desc {
  color: var(--ink-soft);
  font-size: 0.94rem;
  line-height: 1.55;
  margin: 0;
}

.bento__card--feat .bento__copy {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.bento__visual {
  margin-top: auto;
  padding: 16px;
  background: oklch(16% 0.014 275);
  border: 1px solid var(--line);
  border-radius: var(--r);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.mini-cat {
  display: grid;
  grid-template-columns: 70px 1fr 70px;
  gap: 12px;
  align-items: center;
  font-size: 0.82rem;
}
.mini-cat__name { color: var(--ink-soft); }
.mini-cat__num  { color: var(--ink); text-align: right; font-size: 0.72rem; }
.mini-cat__bar {
  display: block;
  height: 6px;
  background: var(--line);
  border-radius: var(--r-pill);
  overflow: hidden;
  position: relative;
}
.mini-cat__bar > span {
  display: block;
  height: 100%;
  width: var(--p);
  max-width: 100%;
  background: var(--brand-soft);
  border-radius: var(--r-pill);
}
.mini-cat__bar > .mini-cat__bar--warn   { background: var(--warn); }
.mini-cat__bar > .mini-cat__bar--danger { background: var(--danger); }

.bento__icon {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  margin-top: auto;
  color: var(--ink);
  background: oklch(20% 0.018 275);
  box-shadow: inset 0 0 0 1px var(--line-strong);
}

.bento__chart {
  margin-top: auto;
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  align-items: end;
  gap: 6px;
  height: 70px;
}
.bento__chart span {
  display: block;
  height: var(--h);
  border-radius: 4px 4px 2px 2px;
  background: linear-gradient(180deg, var(--brand-soft), color-mix(in oklab, var(--brand) 60%, transparent));
}

.bento__ring {
  --p: 50;
  position: relative;
  width: 88px;
  height: 88px;
  margin-top: auto;
  border-radius: 50%;
  background: conic-gradient(var(--mint) calc(var(--p) * 1%), var(--line) 0);
  display: grid;
  place-items: center;
}
.bento__ring::before {
  content: '';
  position: absolute;
  inset: 8px;
  border-radius: 50%;
  background: var(--bg-elev);
}
.bento__ring > span {
  position: relative;
  z-index: 1;
  font-size: 0.9rem;
  color: var(--ink);
}

.bento__stat {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.bento__stat-num {
  font-family: var(--font-display);
  font-size: 1.6rem;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.bento__stat-sub {
  font-size: 0.74rem;
  color: var(--ink-mute);
  letter-spacing: 0.04em;
}

.bento__card--edu {
  background:
    linear-gradient(135deg, oklch(20% 0.05 285), oklch(15% 0.02 275));
}

/* ============================================================
   EDUCATION / ARTICLE CARD
   ============================================================ */
.education { padding: 64px 0; }
@media (min-width: 760px) { .education { padding: 96px 0; } }

.article-card {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  overflow: hidden;
}
@media (min-width: 880px) {
  .article-card {
    grid-template-columns: 1fr 1.3fr;
  }
}

.article-card__head {
  padding: 36px 32px 28px;
  border-bottom: 1px solid var(--line);
  background:
    radial-gradient(60% 100% at 0% 0%, oklch(72% 0.18 75 / 0.18), transparent 70%),
    var(--bg-elev);
}
@media (min-width: 880px) {
  .article-card__head {
    border-bottom: 0;
    border-right: 1px solid var(--line);
  }
}

.article-card__kicker {
  font-size: 0.74rem;
  letter-spacing: 0.16em;
  color: var(--warn);
  margin: 0 0 18px;
}
.article-card__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2rem, 3.5vw, 2.8rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: 0;
  color: var(--ink);
}
.article-card__title em {
  font-style: italic;
  color: var(--warn);
}

.article-card__body {
  padding: 36px 32px;
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.article-card__dropcap {
  color: var(--ink-soft);
  font-size: 1.02rem;
  line-height: 1.65;
  text-indent: 0;
  position: relative;
}
.article-card__dropcap::first-letter {
  font-family: var(--font-display);
  float: left;
  font-size: 3.2em;
  line-height: 0.8;
  margin: 0.08em 8px 0 0;
  color: var(--ink);
  font-style: italic;
}
.article-card__dropcap em {
  font-style: italic;
  color: var(--ink);
}

.article-card__points {
  display: grid;
  gap: 10px;
  padding: 18px 22px;
  background: oklch(16% 0.014 275);
  border-left: 2px solid var(--warn);
  border-radius: 6px 12px 12px 6px;
}
.article-card__points li {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 10px;
  color: var(--ink);
  font-size: 0.95rem;
  align-items: baseline;
}
.article-card__points .mono {
  color: var(--warn);
  font-size: 0.78rem;
  letter-spacing: 0.05em;
}

.article-card__cta { margin-top: 4px; }

/* ============================================================
   PRICING
   ============================================================ */
.pricing { padding: 64px 0; }
@media (min-width: 760px) { .pricing { padding: 96px 0; } }

.plans {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
@media (min-width: 760px) {
  .plans { grid-template-columns: repeat(2, 1fr); }
}

.plan {
  position: relative;
  padding: 32px 28px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.plan--featured {
  background:
    radial-gradient(80% 80% at 50% 0%, oklch(72% 0.2 285 / 0.20), transparent 70%),
    var(--bg-elev);
  border-color: oklch(45% 0.12 285);
  box-shadow: var(--shadow-glow);
}

.plan__tag {
  position: absolute;
  top: -12px;
  left: 24px;
  background: var(--ink);
  color: oklch(12% 0.01 280);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  padding: 5px 12px;
  border-radius: var(--r-pill);
}

.plan__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  color: var(--ink-mute);
  margin: 0;
}
.plan__name {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 2rem;
  letter-spacing: -0.02em;
  margin: 8px 0 8px;
  color: var(--ink);
}
.plan__price {
  font-family: var(--font-display);
  font-size: clamp(3rem, 6vw, 4rem);
  line-height: 0.95;
  margin: 0 0 6px;
  letter-spacing: -0.02em;
  display: flex;
  align-items: baseline;
  gap: 6px;
  color: var(--ink);
}
.plan__price .mono {
  font-size: 0.45em;
  color: var(--ink-mute);
  font-weight: 500;
}
.plan__price-soon {
  font-style: italic;
  color: var(--brand-soft);
  font-size: 0.65em;
}
.plan__per {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: var(--ink-mute);
  font-weight: 500;
  letter-spacing: 0.04em;
  margin-left: 2px;
}
.plan__sub {
  font-size: 0.92rem;
  color: var(--ink-soft);
  margin: 0;
}

.plan__features {
  display: grid;
  gap: 10px;
  list-style: none;
  padding: 0;
  margin: 0;
}
/* Bullet via pseudo-elemento posizionato in assoluto: il contenuto del
   <li> resta in flow inline, quindi <strong>, <em> e text node convivono
   senza che il layout li separi su righe diverse (succede con grid/flex
   sul contenitore, perché ogni nodo diretto diventa un item separato). */
.plan__features li {
  position: relative;
  padding-left: 30px;
  font-size: 0.95rem;
  color: var(--ink-soft);
  line-height: 1.5;
}
.plan__features li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.4em;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: color-mix(in oklab, var(--mint) 30%, transparent);
  box-shadow: inset 0 0 0 1px var(--mint);
}
.plan__features li strong { color: var(--ink); font-weight: 600; }

.plan__cta { margin-top: auto; }

/* ============================================================
   CTA FINAL
   ============================================================ */
.cta-final {
  padding: 56px 0 96px;
}
.cta-final__inner {
  text-align: center;
  padding: 64px 24px 72px;
  border-radius: var(--r-xl);
  border: 1px solid var(--line-strong);
  background:
    radial-gradient(70% 90% at 50% 0%, oklch(72% 0.2 285 / 0.24), transparent 70%),
    var(--bg-elev);
  position: relative;
  overflow: hidden;
}
.cta-final .display { margin: 14px auto 18px; max-width: 16ch; }
.cta-final__sub {
  color: var(--ink-soft);
  margin: 0 auto 28px;
  font-size: 1.02rem;
  max-width: 44ch;
}
.cta-final__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
}

/* ============================================================
   AUTH (login / register)
   ============================================================ */
.auth {
  position: relative;
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 130px 16px 80px;
  isolation: isolate;
}
.auth__background {
  position: absolute;
  inset: -10% -10% 0 -10%;
  z-index: -1;
  background:
    radial-gradient(50% 60% at 20% 20%, oklch(70% 0.2 285 / 0.30), transparent 70%),
    radial-gradient(40% 50% at 80% 10%, oklch(82% 0.14 165 / 0.18), transparent 72%);
  filter: blur(50px);
  pointer-events: none;
}

.auth__card {
  width: 100%;
  max-width: 460px;
  padding: 36px 28px 28px;
  background: var(--bg-elev);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-card);
}
@media (min-width: 540px) { .auth__card { padding: 44px 40px 32px; } }

.auth__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.8rem, 3.5vw, 2.2rem);
  letter-spacing: -0.02em;
  text-align: center;
  margin: 0 0 8px;
  line-height: 1.05;
}
.auth__subtitle {
  text-align: center;
  color: var(--ink-soft);
  font-size: 0.95rem;
  margin: 0 0 24px;
  max-width: 36ch;
  margin-left: auto;
  margin-right: auto;
}

.auth__alert {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  border-radius: var(--r);
  background: color-mix(in oklab, var(--danger) 14%, transparent);
  border: 1px solid color-mix(in oklab, var(--danger) 50%, var(--line-strong));
  color: var(--ink);
  font-size: 0.9rem;
  margin-bottom: 18px;
}
.auth__alert-icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--danger);
  color: oklch(15% 0.01 280);
  font-weight: 700;
  font-size: 0.85rem;
  line-height: 1;
}

.auth__notice {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  border-radius: var(--r);
  background: color-mix(in oklab, var(--mint) 12%, transparent);
  border: 1px solid color-mix(in oklab, var(--mint) 40%, var(--line-strong));
  color: var(--ink);
  font-size: 0.9rem;
  margin-bottom: 18px;
}
.auth__notice-icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--mint);
  color: oklch(15% 0.01 280);
  font-weight: 700;
  font-size: 0.85rem;
  line-height: 1;
}

.auth__inline-form { margin-top: 10px; }

.auth__form { display: grid; gap: 14px; }

.auth__switch {
  text-align: center;
  font-size: 0.92rem;
  color: var(--ink-soft);
  margin: 22px 0 0;
}
.auth__switch a { color: var(--ink); font-weight: 600; border-bottom: 1px solid var(--line-strong); }
.auth__switch a:hover { border-color: var(--ink); }

/* Form fields */
.field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.field__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.field__label {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.field__link {
  font-size: 0.78rem;
  color: var(--ink);
  border-bottom: 1px solid var(--line-strong);
  padding-bottom: 1px;
  transition: border-color var(--t-fast), color var(--t-fast);
}
.field__link:hover { border-color: var(--ink); }
.field__hint {
  font-size: 0.78rem;
  color: var(--ink-mute);
  margin: 4px 0 0;
}

.input {
  width: 100%;
  padding: 13px 14px;
  background: oklch(16% 0.014 275);
  border: 1px solid var(--line-strong);
  border-radius: var(--r);
  color: var(--ink);
  font-family: inherit;
  font-size: 16px;
  transition: border-color var(--t) var(--ease), background var(--t) var(--ease), box-shadow var(--t) var(--ease);
}
.input::placeholder { color: var(--ink-dim); }
.input:hover { border-color: var(--ink-mute); }
.input:focus {
  outline: none;
  border-color: var(--ink);
  background: var(--bg);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--ink) 10%, transparent);
}

.input-wrap { position: relative; }
.input-wrap .input { padding-right: 44px; }
.input-toggle {
  position: absolute;
  right: 6px;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  background: transparent;
  border: 0;
  border-radius: 10px;
  color: var(--ink-mute);
  cursor: pointer;
  transition: background var(--t-fast), color var(--t-fast);
}
.input-toggle:hover { background: oklch(96% 0.03 85 / 0.07); color: var(--ink); }

.field--checkbox { margin-top: 4px; }
.checkbox {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  cursor: pointer;
  user-select: none;
  font-size: 0.9rem;
  color: var(--ink-soft);
  position: relative;
}
.checkbox input { position: absolute; opacity: 0; pointer-events: none; }
.checkbox__box {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  border-radius: 6px;
  background: oklch(16% 0.014 275);
  border: 1px solid var(--line-strong);
  position: relative;
  transition: background var(--t-fast), border-color var(--t-fast);
  margin-top: 1px;
}
.checkbox input:checked + .checkbox__box {
  background: var(--ink);
  border-color: var(--ink);
}
.checkbox input:checked + .checkbox__box::after {
  content: '';
  position: absolute;
  left: 5px;
  top: 1px;
  width: 6px;
  height: 12px;
  border-right: 2px solid oklch(12% 0.01 280);
  border-bottom: 2px solid oklch(12% 0.01 280);
  transform: rotate(45deg);
}
.checkbox input:focus-visible + .checkbox__box {
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--ink) 10%, transparent);
}
.checkbox__label a {
  color: var(--ink);
  border-bottom: 1px solid var(--line-strong);
}
.checkbox__label a:hover { border-color: var(--ink); }

/* Divider OPPURE */
.divider {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 22px 0;
  color: var(--ink-mute);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.divider::before,
.divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--line-strong), transparent);
}

/* ============================================================
   LEGAL
   ============================================================ */
.legal-page { padding: 130px 0 96px; }

.legal-page__header { margin-bottom: 40px; max-width: var(--reading-w); }
.legal-page__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2.2rem, 5vw, 3.4rem);
  letter-spacing: -0.025em;
  line-height: 1.05;
  margin: 14px 0 10px;
  color: var(--ink);
}
.legal-page__date {
  color: var(--ink-mute);
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  margin: 0;
}

.legal-page__body {
  display: grid;
  gap: 36px;
  grid-template-columns: 1fr;
}
.legal-page__toc {
  padding: 22px 22px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  font-size: 0.9rem;
}
.legal-page__toc-title {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 14px;
}
.legal-page__toc ol {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: decimal inside;
  color: var(--ink-mute);
}
.legal-page__toc a {
  color: var(--ink-soft);
  transition: color var(--t-fast);
}
.legal-page__toc a:hover { color: var(--ink); }

.legal-page__content {
  max-width: var(--reading-w);
  color: var(--ink-soft);
}
.legal-page__content section + section { margin-top: 32px; }
.legal-page__content h2 {
  color: var(--ink);
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.5rem;
  letter-spacing: -0.015em;
  margin: 0 0 14px;
  line-height: 1.15;
}
.legal-page__content h3 {
  color: var(--ink);
  font-size: 1.02rem;
  font-weight: 600;
  margin: 24px 0 8px;
}
.legal-page__content p { margin: 0 0 14px; line-height: 1.7; }
.legal-page__content ul,
.legal-page__content ol {
  padding-left: 22px;
  margin: 0 0 14px;
  color: var(--ink-soft);
}
.legal-page__content ul { list-style: disc; }
.legal-page__content ol { list-style: decimal; }
.legal-page__content li { margin-bottom: 6px; line-height: 1.65; }
.legal-page__content strong { color: var(--ink); font-weight: 600; }
.legal-page__content em { color: var(--ink); }
.legal-page__content a {
  color: var(--ink);
  border-bottom: 1px solid var(--line-strong);
  padding-bottom: 1px;
  transition: border-color var(--t-fast);
}
.legal-page__content a:hover { border-color: var(--ink); }

.legal-page__disclaimer {
  padding: 22px 24px;
  margin: 0 0 32px;
  background: color-mix(in oklab, var(--warn) 12%, transparent);
  border: 1px solid color-mix(in oklab, var(--warn) 45%, var(--line-strong));
  border-radius: var(--r-lg);
  color: var(--ink);
  font-size: 0.96rem;
  line-height: 1.65;
}
.legal-page__disclaimer strong { color: var(--ink); }

@media (min-width: 980px) {
  .legal-page__body {
    grid-template-columns: 240px 1fr;
    gap: 56px;
    align-items: start;
  }
  .legal-page__toc {
    position: sticky;
    top: 100px;
    align-self: start;
  }
}

/* ============================================================
   ABOUT PAGE — Chi siamo
   Layout editoriale tipo lettera-rivista. Deliberatamente
   diverso dalla landing: nessun aurora hero, nessuna griglia
   di card numerate, nessun bento. Solo testo, ritmo,
   tipografia serif e molto bianco.
   ============================================================ */

.about-page {
  overflow-x: clip;
  padding-top: 96px; /* compensa la pill header fixed */
}

/* Container "narrow" — riservato a layout editoriali da lettura. */
.about-page .container--narrow {
  width: 100%;
  max-width: 780px;
  margin: 0 auto;
  padding: 0 22px;
}

/* Separatore verticale fra sezioni della pagina: hairline orizzontale
   solo sopra le sezioni 3/4/5, niente sotto la prima. */
.about-page > section + section {
  border-top: 1px solid var(--line);
}

/* ----- 1 · APERTURA / EPIGRAFE ---------------------------------- */
.about-epigraph {
  padding: 56px 0 72px;
  text-align: center;
}
@media (min-width: 760px) { .about-epigraph { padding: 96px 0 104px; } }

.about-epigraph__meta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 56px;
}
.about-epigraph__sep {
  color: var(--ink-dim);
  font-size: 0.7em;
}

.about-epigraph__quote {
  margin: 0 auto;
  padding: 0;
  max-width: 32ch;
}
@media (min-width: 760px) {
  .about-epigraph__quote { max-width: 36ch; }
}
.about-epigraph__quote p {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.8rem, 4.6vw, 3rem);
  line-height: 1.18;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin: 0;
}
.about-epigraph__quote em {
  font-style: italic;
  color: var(--brand-soft);
  position: relative;
}
.about-epigraph__open,
.about-epigraph__close {
  color: var(--brand-soft);
  font-style: italic;
  display: inline-block;
  line-height: 0;
  vertical-align: -0.18em;
  margin: 0 0.04em;
}
.about-epigraph__close { vertical-align: -0.32em; }

.about-epigraph__attrib {
  margin: 32px 0 0;
  font-size: 0.74rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

.about-epigraph__divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  margin: 64px auto 0;
  max-width: 320px;
  color: var(--mint);
}
.about-epigraph__divider span {
  flex: 1;
  height: 1px;
  background: var(--line-strong);
}
.about-epigraph__divider-glyph {
  flex: 0 0 auto;
  font-size: 0.9rem;
  color: var(--mint);
}

/* ----- 2 · LETTERA ----------------------------------------------- */
.about-letter {
  padding: 56px 0 72px;
}
@media (min-width: 760px) { .about-letter { padding: 88px 0 96px; } }

.letter__kicker {
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 28px;
}
.letter__kicker-rule {
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, var(--line-strong), transparent);
}

.letter__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2rem, 4.6vw, 3rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  color: var(--ink);
  margin: 0 0 44px;
  max-width: 18ch;
}
.letter__title em {
  font-style: italic;
  color: var(--brand-soft);
}
.letter__title-mark {
  position: relative;
  display: inline-block;
  font-style: italic;
}
.letter__title-mark::after {
  content: '';
  position: absolute;
  left: -2%;
  right: -2%;
  bottom: 0.06em;
  height: 0.16em;
  background: color-mix(in oklab, var(--mint) 80%, transparent);
  border-radius: 2px;
  z-index: -1;
}

.letter__body {
  font-family: var(--font-body);
  color: var(--ink-soft);
  font-size: 1.04rem;
  line-height: 1.75;
  max-width: 62ch;
}
.letter__body p {
  margin: 0 0 22px;
}
.letter__body strong {
  color: var(--ink);
  font-weight: 600;
}
.letter__body em {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.08em;
  color: var(--ink);
  letter-spacing: -0.005em;
}

/* Drop cap manuale (più controllabile di ::first-letter). */
.letter__lead { position: relative; }
.letter__dropcap {
  float: left;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 4.4rem;
  line-height: 0.78;
  padding: 8px 14px 0 0;
  color: var(--brand-soft);
  letter-spacing: -0.04em;
}
.letter__sr {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

.letter__pull {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.35rem, 2.6vw, 1.8rem);
  line-height: 1.25;
  color: var(--ink);
  margin: 36px 0 36px -22px;
  padding: 4px 0 4px 22px;
  border-left: 2px solid var(--brand-soft);
  max-width: 28ch;
}
.letter__pull em {
  font-family: inherit;
  font-style: italic;
  color: var(--brand-soft);
  font-size: 1em;
}

.letter__signoff {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-top: 52px;
  padding-top: 28px;
  border-top: 1px solid var(--line);
}
.letter__signoff-sign {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(2.2rem, 5vw, 3rem);
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--brand-soft);
}
.letter__signoff-meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-top: 6px;
  font-size: 0.78rem;
  color: var(--ink-mute);
  letter-spacing: 0.04em;
}
.letter__signoff-meta .mono {
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  color: var(--ink-soft);
}
.letter__signoff-role {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

/* ----- 2 · FONDATORE — prosa, niente dl/dt/dd -------------------- */
.about-founder {
  padding: 56px 0 64px;
}
@media (min-width: 760px) { .about-founder { padding: 88px 0 88px; } }

.about-founder__eyebrow {
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 36px;
}

.about-founder__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 36px;
  align-items: start;
}
@media (min-width: 760px) {
  .about-founder__layout {
    grid-template-columns: 220px 1fr;
    gap: 48px;
  }
}

.about-founder__portrait {
  position: relative;
  aspect-ratio: 1 / 1.18;
  max-width: 220px;
  background:
    linear-gradient(160deg, oklch(70% 0.2 285 / 0.18), transparent 60%),
    var(--bg-elev);
  border: 1px solid var(--line-strong);
  border-radius: 4px;
  display: grid;
  place-items: center;
  padding: 18px;
  box-shadow: var(--shadow);
  overflow: hidden;
}
.about-founder__portrait::before,
.about-founder__portrait::after {
  content: '';
  position: absolute;
  background: var(--line-strong);
}
.about-founder__portrait::before {
  top: 12px;
  left: 12px;
  right: 12px;
  height: 1px;
}
.about-founder__portrait::after {
  bottom: 12px;
  left: 12px;
  right: 12px;
  height: 1px;
}
.about-founder__monogram {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(4rem, 12vw, 6rem);
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--ink);
  text-align: center;
}
.about-founder__portrait-stamp {
  position: absolute;
  bottom: 22px;
  left: 0;
  right: 0;
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  text-align: center;
  line-height: 1.6;
}
.about-founder__portrait-stamp span {
  color: var(--ink-dim);
  letter-spacing: 0;
}

.about-founder__prose {
  font-family: var(--font-body);
  color: var(--ink-soft);
  font-size: 1.02rem;
  line-height: 1.7;
  max-width: 62ch;
}
.about-founder__prose p {
  margin: 0 0 18px;
}
.about-founder__prose p:last-child { margin-bottom: 0; }
.about-founder__prose strong {
  color: var(--ink);
  font-weight: 600;
}
.about-founder__prose em {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.06em;
  color: var(--ink);
  letter-spacing: -0.005em;
}

.about-founder__name {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2.2rem, 5vw, 3rem);
  line-height: 1;
  letter-spacing: -0.025em;
  color: var(--ink);
  margin: 0 0 22px;
}

.about-founder__cta {
  margin-top: 26px !important;
  padding-top: 18px;
  border-top: 1px solid var(--line);
  font-size: 0.92rem;
  color: var(--ink-mute);
}
.about-founder__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--ink);
  border-bottom: 1px solid var(--line-strong);
  padding-bottom: 1px;
  margin-left: 4px;
  transition: color var(--t-fast), border-color var(--t-fast);
}
.about-founder__link:hover {
  color: var(--brand-soft);
  border-color: var(--brand-soft);
}

/* ----- 4 · TENETS ------------------------------------------------ */
.about-tenets {
  padding: 64px 0 72px;
}
@media (min-width: 760px) { .about-tenets { padding: 88px 0 96px; } }

.about-tenets__eyebrow {
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 36px;
}

.tenets {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}
.tenets__item {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 18px;
  align-items: baseline;
  padding: 22px 0;
  border-top: 1px solid var(--line);
}
.tenets__item:last-child {
  border-bottom: 1px solid var(--line);
}
@media (min-width: 760px) {
  .tenets__item {
    grid-template-columns: 96px 1fr;
    gap: 28px;
    padding: 30px 0;
  }
}

.tenets__num {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.8rem, 4.5vw, 2.6rem);
  line-height: 1;
  color: var(--brand-soft);
  letter-spacing: -0.02em;
  text-align: left;
}
.tenets__text {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.25rem, 2.6vw, 1.7rem);
  line-height: 1.2;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: 0;
}
.tenets__text em {
  font-style: italic;
  color: var(--brand-soft);
}

/* ----- 5 · CHIUSURA ---------------------------------------------- */
.about-end {
  padding: 64px 0 96px;
  text-align: center;
}
@media (min-width: 760px) { .about-end { padding: 96px 0 128px; } }

.about-end__cta {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin: 0 0 36px;
}
.about-end__link {
  position: relative;
  display: inline-block;
  margin-left: 6px;
  font-style: italic;
  color: var(--brand-soft);
  transition: color var(--t-fast);
}
.about-end__link::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0.08em;
  height: 1px;
  background: var(--brand-soft);
  transform: scaleX(0.6);
  transform-origin: left center;
  transition: transform var(--t) var(--ease);
}
.about-end__link:hover {
  color: var(--ink);
}
.about-end__link:hover::after {
  transform: scaleX(1);
  background: var(--ink);
}

.about-end__meta {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 10px;
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0;
}
.about-end__meta a {
  color: var(--ink-soft);
  transition: color var(--t-fast);
}
.about-end__meta a:hover { color: var(--ink); }
.about-end__meta span[aria-hidden] {
  color: var(--ink-dim);
}

/* ============================================================
   ERROR PAGES
   ============================================================ */
.error-page {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 120px 20px 60px;
  text-align: center;
  position: relative;
  isolation: isolate;
  overflow: hidden;
}
.error-page::before {
  content: '';
  position: absolute;
  inset: -10% -10% 30% -10%;
  z-index: -1;
  background: radial-gradient(50% 60% at 50% 20%, oklch(70% 0.2 285 / 0.28), transparent 70%);
  filter: blur(50px);
  pointer-events: none;
}
.error-page__inner { max-width: 580px; }
.error-page__code {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(6rem, 24vw, 12rem);
  line-height: 1;
  margin: 0 0 6px;
  background: linear-gradient(120deg, var(--brand-soft) 10%, var(--mint) 90%);
  -webkit-background-clip: text;
          background-clip: text;
  color: transparent;
  letter-spacing: -0.05em;
}
.error-page__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  letter-spacing: -0.02em;
  margin: 0 0 14px;
  line-height: 1.1;
  color: var(--ink);
}
.error-page__desc {
  color: var(--ink-soft);
  margin: 0 auto 28px;
  font-size: 1.02rem;
  max-width: 50ch;
}
.error-page__actions {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

/* ============================================================
   FOOTER (rich + wordmark)
   ============================================================ */
.site-footer {
  border-top: 1px solid var(--line);
  padding: 0 0 28px;
  margin-top: 60px;
  position: relative;
}

.site-footer__wordmark {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(6rem, 22vw, 16rem);
  line-height: 0.85;
  letter-spacing: -0.05em;
  text-align: center;
  margin: 24px 0 36px;
  background: linear-gradient(180deg, oklch(96% 0.03 85 / 0.18), transparent);
  -webkit-background-clip: text;
          background-clip: text;
  color: transparent;
  user-select: none;
  position: relative;
}
.site-footer__wordmark span {
  color: var(--brand-soft);
  -webkit-text-fill-color: var(--brand-soft);
}

.site-footer__top {
  display: grid;
  gap: 36px;
  grid-template-columns: 1fr;
  margin: 0 0 36px;
}
@media (min-width: 760px) {
  .site-footer__top {
    grid-template-columns: 1.6fr 1fr 1fr 1fr;
    gap: 32px;
  }
}

.site-footer__brand-col {
  display: flex;
  flex-direction: column;
  gap: 14px;
  max-width: 360px;
}
.site-footer__tagline {
  color: var(--ink-soft);
  font-size: 0.92rem;
  margin: 0;
  line-height: 1.6;
}
.site-footer__meta {
  font-size: 0.75rem;
  color: var(--ink-mute);
  letter-spacing: 0.04em;
  margin: 4px 0 0;
}
.site-footer__meta .mono { color: var(--brand-soft); }

.site-footer__col-title {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 14px;
}
.site-footer__col ul {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.site-footer__col a {
  color: var(--ink-soft);
  font-size: 0.94rem;
  transition: color var(--t-fast);
}
.site-footer__col a:hover { color: var(--ink); }

.site-footer__bottom {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
  justify-content: space-between;
  align-items: flex-start;
}
.site-footer__small-links {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
}
.site-footer__small-links a {
  color: var(--ink-mute);
  font-size: 0.85rem;
  transition: color var(--t-fast);
}
.site-footer__small-links a:hover { color: var(--ink); }
@media (min-width: 640px) {
  .site-footer__bottom { flex-direction: row; align-items: center; }
}

/* ============================================================
   AREA PERSONALE (header desktop — dropdown con tutte le sezioni)
   ------------------------------------------------------------
   Visibile solo da >= 760px: su mobile le sezioni vivono tutte
   nella bottom-nav, quindi il dropdown sul profilo è nascosto per
   non duplicare la navigazione.
   ============================================================ */
.user-menu { position: relative; display: none; }
@media (min-width: 760px) {
  .user-menu { display: block; }
}
.user-menu__trigger {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 4px 12px 4px 4px;
  background: oklch(96% 0.03 85 / 0.05);
  border: 1px solid var(--line);
  border-radius: var(--r-pill);
  cursor: pointer;
  list-style: none;
  transition: background var(--t-fast), border-color var(--t-fast);
}
.user-menu__trigger::-webkit-details-marker { display: none; }
.user-menu__trigger:hover,
.user-menu[open] .user-menu__trigger {
  background: oklch(96% 0.03 85 / 0.09);
  border-color: var(--line-strong);
}
.user-menu__trigger.is-active { border-color: var(--line-strong); }

.user-pill__avatar {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--brand);
  color: oklch(12% 0.01 280);
  display: grid;
  place-items: center;
  font-weight: 700;
  font-size: 0.82rem;
  flex-shrink: 0;
  overflow: hidden;
}
.user-pill__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.user-menu__name {
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--ink);
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.user-menu__chevron {
  color: var(--ink-mute);
  flex-shrink: 0;
  transition: transform var(--t-fast), color var(--t-fast);
}
.user-menu[open] .user-menu__chevron { transform: rotate(180deg); color: var(--ink); }

.user-menu__panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 200;
  width: 312px;
  max-width: calc(100vw - 32px);
  padding: 10px;
  /* Liquid glass coerente con bottom-nav e sheet. */
  background:
    linear-gradient(180deg, oklch(100% 0 0 / 0.06), oklch(100% 0 0 / 0) 40%),
    color-mix(in oklab, var(--bg-elev-2) 97%, transparent);
  backdrop-filter: blur(32px) saturate(180%);
  -webkit-backdrop-filter: blur(32px) saturate(180%);
  border: 1px solid color-mix(in oklab, oklch(100% 0 0) 12%, var(--line-strong));
  border-radius: var(--r);
  box-shadow:
    0 26px 70px -22px rgb(0 0 0 / 0.78),
    inset 0 1px 0 oklch(100% 0 0 / 0.16),
    inset 0 -1px 0 oklch(0% 0 0 / 0.3);
  animation: user-menu-in var(--t-fast) var(--ease, ease) both;
}
@keyframes user-menu-in {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.user-menu__hello {
  margin: 4px 8px 10px;
  font-size: 0.92rem;
  color: var(--ink-soft);
}
.user-menu__hello strong { color: var(--ink); font-weight: 600; }
.user-menu__heading {
  margin: 0 8px 8px;
  font-size: 0.6rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.user-menu__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
}
.user-menu__item {
  display: block;
  width: 100%;
  padding: 9px 10px;
  border-radius: var(--r-sm);
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--ink-soft);
  text-align: left;
  background: none;
  border: none;
  cursor: pointer;
  transition: background var(--t-fast), color var(--t-fast);
}
.user-menu__item--wide { grid-column: 1 / -1; }
.user-menu__item:hover { background: oklch(96% 0.03 85 / 0.07); color: var(--ink); }
.user-menu__item.is-active {
  color: var(--ink);
  background: oklch(96% 0.03 85 / 0.06);
  box-shadow: inset 2px 0 0 var(--brand-soft);
}
.user-menu__item--danger { color: var(--danger); }
.user-menu__item--danger:hover { background: color-mix(in oklab, var(--danger) 14%, transparent); color: var(--danger); }
.user-menu__sep { margin: 8px 4px; border: none; border-top: 1px solid var(--line); }
.user-menu__logout { margin: 0; }

/* ----- Foto profilo nell'header — solo mobile (a destra) --------- */
.header-avatar {
  display: inline-flex;
  align-items: center;
  border-radius: 50%;
  transition: transform var(--t-fast);
}
.header-avatar:active { transform: scale(0.94); }
.header-avatar .user-pill__avatar {
  width: 34px;
  height: 34px;
  box-shadow: 0 0 0 1.5px var(--line-strong), 0 2px 8px -2px rgb(0 0 0 / 0.5);
}
.header-avatar.is-active .user-pill__avatar {
  box-shadow: 0 0 0 2px var(--brand-soft), 0 2px 10px -2px color-mix(in oklab, var(--brand) 60%, transparent);
}
@media (min-width: 760px) {
  .header-avatar { display: none; }
}

/* ----- Mini nav (Home / Chi siamo) — solo mobile, centrata -------- */
.site-nav--mini {
  display: none;
  gap: 22px;
  align-items: center;
}
.site-nav--mini .nav-link { font-size: 0.9rem; font-weight: 500; }
@media (max-width: 759px) {
  .site-nav--mini {
    display: flex;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    white-space: nowrap;
  }
}
@media (max-width: 380px) {
  .site-nav--mini { gap: 16px; }
  .site-nav--mini .nav-link { font-size: 0.84rem; }
}

/* ============================================================
   SETUP profilo (form a 2 colonne)
   ============================================================ */
.auth__card--wide { max-width: 560px; }

.field-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
@media (min-width: 540px) {
  .field-row { grid-template-columns: 1fr 1.4fr; gap: 16px; }
}

.field__optional {
  display: inline-block;
  margin-left: 8px;
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.14em;
  padding: 2px 7px;
  border-radius: var(--r-pill);
  background: oklch(96% 0.03 85 / 0.07);
  color: var(--ink-mute);
  text-transform: uppercase;
}

/* Custom select (mantenendo accessibilità nativa) */
.select-wrap {
  position: relative;
}
.select-wrap > select.input {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 38px;
  cursor: pointer;
}
.select-wrap__icon {
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--ink-mute);
  pointer-events: none;
}
.select-wrap > select.input:focus + .select-wrap__icon {
  color: var(--ink);
}

/* ============================================================
   APP NAV (link attivo nella pill, visibilità su mobile)
   ============================================================ */
/* Su mobile (< 760px) la nav app top scompare: serve la bottom-nav.
   Da 760px in su torna visibile dentro la pill. */
.site-nav--app {
  display: none;
  gap: 18px;
  align-items: center;
}
@media (min-width: 760px) {
  .site-nav--app { display: flex; }
}
@media (min-width: 760px) and (max-width: 920px) {
  .site-nav--app { gap: 12px; }
  .site-nav--app .nav-link { font-size: 0.84rem; }
}
.site-nav--app .nav-link {
  position: relative;
  padding: 6px 2px;
}
.nav-link.is-active { color: var(--ink); }
.nav-link.is-active::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: -6px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--brand-soft), var(--mint));
}

/* ============================================================
   BOTTOM NAV (mobile-first, pattern app nativa)
   ------------------------------------------------------------
   Fissa in basso, blur, safe-area-inset compatibile (iPhone).
   Visibile sotto 760px. La page-content riceve padding-bottom
   sufficiente tramite la classe .has-bottom-nav sul <body>.
   ============================================================ */
/* Pill flottante, centrata, sole icone — ispirata alle app native
   (es. shop.app). La .bottom-nav è solo il contenitore fisso che centra
   la pill; .bottom-nav__pill è la superficie visibile. */
.bottom-nav {
  position: fixed;
  left: 0;
  right: 0;
  bottom: calc(12px + env(safe-area-inset-bottom));
  z-index: 100;
  display: flex;
  justify-content: center;
  padding: 0 16px;
  pointer-events: none;
}
@media (min-width: 760px) {
  .bottom-nav { display: none; }
}

.bottom-nav__pill {
  pointer-events: auto;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 7px;
  /* Liquid glass: riflesso in alto, vetro più corposo, blur/saturazione alti. */
  background:
    linear-gradient(180deg, oklch(100% 0 0 / 0.08), oklch(100% 0 0 / 0) 55%),
    color-mix(in oklab, var(--bg-elev) 88%, transparent);
  backdrop-filter: blur(30px) saturate(180%);
  -webkit-backdrop-filter: blur(30px) saturate(180%);
  border: 1px solid color-mix(in oklab, oklch(100% 0 0) 12%, var(--line-strong));
  border-radius: var(--r-pill);
  box-shadow:
    0 18px 48px -16px rgb(0 0 0 / 0.72),
    0 2px 8px -2px rgb(0 0 0 / 0.5),
    inset 0 1px 0 oklch(100% 0 0 / 0.18),
    inset 0 -1px 0 oklch(0% 0 0 / 0.28);
  /* Forza composite layer (fix iOS Safari fixed+backdrop-filter). */
  transform: translateZ(0);
  -webkit-transform: translateZ(0);
}

.bottom-nav__link,
.bottom-nav summary.bottom-nav__link {
  position: relative;
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  color: var(--ink-mute);
  text-decoration: none;
  cursor: pointer;
  list-style: none;
  -webkit-tap-highlight-color: transparent;
  transition: color var(--t-fast), background var(--t-fast), transform var(--t-fast);
}
.bottom-nav__link:hover { color: var(--ink-soft); }
.bottom-nav__link:active { transform: scale(0.9); }
.bottom-nav__link.is-active {
  color: oklch(15% 0.02 280);
  background: linear-gradient(135deg, var(--brand-soft), var(--mint));
  box-shadow: 0 6px 16px -6px color-mix(in oklab, var(--brand) 60%, transparent);
}
.bottom-nav__link.is-active .bottom-nav__icon { color: inherit; }

.bottom-nav__icon {
  width: 23px;
  height: 23px;
  flex-shrink: 0;
}

/* Solo icone: l'etichetta resta nel DOM per gli screen reader ma è nascosta
   visivamente (l'aria-label sul link garantisce comunque il nome). */
.bottom-nav__label {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}
@media (max-width: 360px) {
  .bottom-nav__link,
  .bottom-nav summary.bottom-nav__link { width: 44px; height: 44px; }
  .bottom-nav__pill { gap: 2px; padding: 6px; }
}

/* Bottoncino "Altro" con sheet che spunta verso l'alto */
.bottom-nav__more { position: relative; }
.bottom-nav__more summary::-webkit-details-marker { display: none; }
.bottom-nav__more summary { list-style: none; }

.bottom-nav__more[open] > summary {
  color: var(--ink);
  background: oklch(96% 0.03 85 / 0.1);
}

.bottom-nav__sheet {
  position: absolute;
  bottom: calc(100% + 14px);
  right: 0;
  width: min(244px, calc(100vw - 32px));
  padding: 6px;
  /* Liquid glass (Apple-like): vetro quasi opaco con riflesso specolare in
     alto e ombra interna in basso, blur e saturazione spinti. Niente più
     "vedo le cose sotto": il fill è al 97%. */
  background:
    linear-gradient(180deg, oklch(100% 0 0 / 0.07), oklch(100% 0 0 / 0) 42%),
    color-mix(in oklab, var(--bg-elev-2) 97%, transparent);
  backdrop-filter: blur(32px) saturate(180%);
  -webkit-backdrop-filter: blur(32px) saturate(180%);
  border: 1px solid color-mix(in oklab, oklch(100% 0 0) 12%, var(--line-strong));
  border-radius: var(--r-lg);
  box-shadow:
    0 26px 70px -22px rgb(0 0 0 / 0.78),
    inset 0 1px 0 oklch(100% 0 0 / 0.16),
    inset 0 -1px 0 oklch(0% 0 0 / 0.3);
  display: grid;
  gap: 2px;
  z-index: 101;
  animation: bottom-sheet-in 200ms var(--ease) both;
}
@keyframes bottom-sheet-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.bottom-nav__sheet-link,
.bottom-nav__sheet-form button {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: transparent;
  border: 0;
  border-radius: var(--r);
  color: var(--ink-soft);
  font-family: inherit;
  font-size: 0.92rem;
  text-align: left;
  width: 100%;
  cursor: pointer;
  text-decoration: none;
  transition: background var(--t-fast), color var(--t-fast);
}
.bottom-nav__sheet-link:hover,
.bottom-nav__sheet-form button:hover {
  background: oklch(96% 0.03 85 / 0.06);
  color: var(--ink);
}
.bottom-nav__sheet-link--danger {
  color: var(--danger);
}
.bottom-nav__sheet-link--danger:hover {
  background: color-mix(in oklab, var(--danger) 12%, transparent);
  color: var(--danger);
}
.bottom-nav__sheet-form { margin: 0; }
.bottom-nav__sheet-icon {
  display: inline-grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border-radius: 8px;
  background: oklch(16% 0.014 275);
  border: 1px solid var(--line);
  color: var(--ink-mute);
  font-size: 0.86rem;
  line-height: 1;
}
.bottom-nav__sheet-link--danger .bottom-nav__sheet-icon {
  color: var(--danger);
  border-color: color-mix(in oklab, var(--danger) 40%, var(--line));
}

/* Spazio per non far sovrapporre la bottom-nav ai contenuti */
.has-bottom-nav {
  padding-bottom: calc(86px + env(safe-area-inset-bottom));
}
@media (min-width: 760px) {
  .has-bottom-nav { padding-bottom: 0; }
}

/* ============================================================
   STEP 3 — Cruscotto, movimenti, categorie
   ------------------------------------------------------------
   Tutte le pagine "app" condividono un layout editoriale
   coerente: padding generosi su desktop, mobile-first, pannelli
   in bg-elev con bordi sottili e numeri in monospace.
   ============================================================ */

/* ---------- Layout base pagina app ---------- */
.dashboard,
.page--list,
.page--report {
  padding: 116px 0 96px;
  position: relative;
  isolation: isolate;
}
.dashboard::before,
.page--report::before {
  content: '';
  position: absolute;
  inset: -10% -10% 70% -10%;
  z-index: -1;
  background:
    radial-gradient(50% 60% at 20% 10%, oklch(70% 0.2 285 / 0.16), transparent 70%),
    radial-gradient(40% 50% at 80% 0%, oklch(82% 0.14 165 / 0.10), transparent 72%);
  filter: blur(60px);
  pointer-events: none;
}
@media (min-width: 760px) {
  .dashboard,
  .page--list,
  .page--report { padding: 140px 0 120px; }
}

/* ---------- Intestazione lista (Movimenti, Categorie) ---------- */
.page__head { margin-bottom: 32px; }
.page__head-row {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
  justify-content: space-between;
  margin-top: 14px;
}
.page__lede {
  margin-top: 14px;
  max-width: 60ch;
  color: var(--ink-soft);
  font-size: 1rem;
  line-height: 1.6;
}

/* ============================================================
   CRUSCOTTO — Hero con saldo
   ============================================================ */
.dash-hero { margin-bottom: 36px; }
.dash-hero .display { margin: 10px 0 28px; }

.dash-hero__balance {
  display: grid;
  grid-template-columns: 1fr;
  gap: 22px;
  align-items: end;
  padding: 26px 24px;
  background:
    linear-gradient(180deg, oklch(70% 0.2 285 / 0.06), transparent 70%),
    var(--bg-elev);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-card);
}
@media (min-width: 760px) {
  .dash-hero__balance {
    grid-template-columns: 1.4fr 1fr;
    gap: 32px;
    padding: 34px 36px;
  }
}

.dash-balance__label {
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 8px;
}
.dash-balance__amount {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2.6rem, 7vw, 4.2rem);
  letter-spacing: -0.025em;
  line-height: 1;
  color: var(--ink);
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin: 0;
}
.dash-balance__amount .mono {
  font-family: var(--font-mono);
  font-size: 0.45em;
  color: var(--ink-mute);
  font-weight: 400;
  letter-spacing: -0.01em;
}
.dash-balance__amount small {
  font-family: var(--font-mono);
  font-size: 0.32em;
  font-weight: 400;
  color: var(--ink-soft);
  margin-left: -4px;
}
.dash-balance__sign { color: var(--danger); }
.dash-balance__delta {
  margin: 14px 0 0;
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}
.dash-balance__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--mint-strong);
  flex-shrink: 0;
}
.dash-balance__delta.is-negative .dash-balance__dot { background: var(--danger); }

/* Etichetta soft "(escluso fondo emergenza)" accanto al label "Disponibile". */
.dash-balance__label-soft {
  font-weight: 400;
  letter-spacing: 0.08em;
  text-transform: none;
  color: var(--ink-dim);
  font-size: 0.92em;
}

/* Riga "Questo mese: entrate / uscite / netto" sotto il numero grande.
   Sostituisce il vecchio "delta" che era prima sotto il cash-flow mensile
   trattato come numero principale. Tono neutro/informativo. */
.dash-balance__monthflow {
  margin: 14px 0 0;
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
}

.dash-balance__monthflow-label {
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  flex-shrink: 0;
}

.dash-balance__monthflow-vals {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 4px 8px;
  align-items: baseline;
}

.dash-balance__monthflow-net .mono { font-weight: 600; }
.dash-balance__monthflow.is-positive .dash-balance__monthflow-net { color: var(--mint); }
.dash-balance__monthflow.is-negative .dash-balance__monthflow-net { color: var(--warn); }

.dash-quick {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
@media (min-width: 540px) {
  .dash-quick { flex-direction: row; flex-wrap: wrap; }
  .dash-quick .btn { flex: 1; min-width: 0; }
}
@media (min-width: 760px) {
  .dash-quick { flex-direction: column; }
  .dash-quick .btn { flex: initial; }
}

/* ---------- Stats riga sotto hero ---------- */
.dash-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  margin: 22px 0 0;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: var(--r);
  overflow: hidden;
}
.dash-stats > li {
  padding: 16px 14px;
  background: var(--bg-elev);
}
.dash-stat__num {
  font-family: var(--font-display);
  font-size: 1.6rem;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin: 0 0 6px;
}
.dash-stat__num-soft { color: var(--ink-mute); font-size: 0.75em; }
.dash-stat__lbl {
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0;
}
@media (min-width: 760px) {
  .dash-stats { grid-template-columns: repeat(4, 1fr); }
  .dash-stats > li { padding: 20px 22px; }
  .dash-stat__num { font-size: 2rem; }
}

/* ---------- Grid pannelli ---------- */
.dash-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
.dash-side {
  display: grid;
  gap: 18px;
}
@media (min-width: 980px) {
  .dash-grid { grid-template-columns: 1.4fr 1fr; gap: 22px; }
}

.dash-panel {
  padding: 22px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-sm);
}
@media (min-width: 760px) { .dash-panel { padding: 28px; } }

.dash-panel__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 0 18px;
}
.dash-panel__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0;
}
.dash-empty {
  padding: 24px 0;
  color: var(--ink-mute);
  font-size: 0.94rem;
  text-align: center;
}
.dash-empty a {
  color: var(--ink);
  border-bottom: 1px solid var(--line-strong);
}
.dash-empty a:hover { border-color: var(--ink); }

/* ============================================================
   CATEGORIE — lista compatta con barra budget
   ============================================================ */
.cat-list {
  display: grid;
  gap: 14px;
  margin: 0;
}
.cat-list--compact { gap: 10px; }

.cat-row {
  display: grid;
  grid-template-columns: 12px 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 6px 0;
}
.cat-row__dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  display: block;
}
.cat-row__main { min-width: 0; }
.cat-row__name {
  margin: 0 0 6px;
  font-size: 0.94rem;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cat-list--compact .cat-row__name { margin: 0; }
.cat-row__bar {
  display: block;
  height: 5px;
  background: oklch(20% 0.014 275);
  border-radius: 999px;
  overflow: hidden;
  position: relative;
}
.cat-row__bar-fill {
  display: block;
  height: 100%;
  width: var(--p, 0%);
  border-radius: 999px;
  transition: width var(--t) var(--ease-soft);
}
.cat-row__bar-fill--warn { background: var(--warn); }
.cat-row__bar-fill--over { background: var(--danger); }
.cat-row__nobudget {
  margin: 0;
  font-size: 0.72rem;
  color: var(--ink-dim);
  letter-spacing: 0.06em;
}
.cat-row__num {
  font-size: 0.86rem;
  color: var(--ink);
  font-weight: 500;
  white-space: nowrap;
  text-align: right;
}
.cat-row__num-sub { color: var(--ink-mute); }
.cat-row__num--pos { color: var(--mint-strong); }

/* ============================================================
   MOVIMENTI — lista raggruppata per data
   ============================================================ */
.txn-groups {
  display: grid;
  gap: 26px;
}
.txn-group {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 18px 18px 8px;
}
@media (min-width: 760px) { .txn-group { padding: 22px 26px 10px; } }

.txn-group__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  padding: 0 0 10px;
  border-bottom: 1px dashed var(--line);
  margin-bottom: 8px;
}
.txn-group__date {
  margin: 0;
  font-size: 0.78rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink);
}
.txn-group__date-iso {
  margin: 0;
  font-size: 0.7rem;
  color: var(--ink-dim);
  letter-spacing: 0.06em;
}

.txn-list { display: grid; gap: 0; margin: 0; }
.txn-list--compact { gap: 0; }

.txn {
  display: grid;
  grid-template-columns: 34px 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 12px 0;
  border-bottom: 1px dashed var(--line);
  position: relative;
}
.txn:last-child { border-bottom: 0; }
.txn-list--compact .txn { padding: 10px 0; }
.txn-list--compact .txn:last-child { padding-bottom: 0; }

.txn__tag {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: oklch(12% 0.01 280);
  font-weight: 700;
  font-size: 0.92rem;
  font-family: var(--font-display);
  letter-spacing: -0.02em;
}
.txn__text { min-width: 0; }
.txn__desc {
  margin: 0;
  font-size: 0.96rem;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.txn__sub {
  margin: 2px 0 0;
  font-size: 0.74rem;
  color: var(--ink-mute);
  letter-spacing: 0.04em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.txn__impulse {
  color: var(--warn);
  text-transform: uppercase;
  letter-spacing: 0.14em;
}
.txn__amt {
  font-size: 0.98rem;
  font-weight: 600;
  color: var(--ink);
  white-space: nowrap;
}
.txn__amt--pos { color: var(--mint-strong); }

.txn__actions {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  gap: 4px;
  opacity: 0;
  transition: opacity var(--t-fast);
  background: linear-gradient(90deg, transparent, var(--bg-elev) 30%);
  padding-left: 28px;
}
.txn:hover .txn__actions,
.txn:focus-within .txn__actions { opacity: 1; }
.txn__edit,
.txn__delete {
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  background: transparent;
  border: 1px solid var(--line-strong);
  border-radius: 10px;
  color: var(--ink-soft);
  cursor: pointer;
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.txn__edit:hover { color: var(--ink); background: oklch(96% 0.03 85 / 0.06); }
.txn__delete:hover { color: var(--danger); border-color: var(--danger); }
@media (max-width: 540px) {
  /* Su mobile actions rientra nel grid flow: serve una 4ª colonna,
     altrimenti finisce nella riga 2 col 1 (34px) e i bottoni si schiacciano.
     flex-shrink: 0 sui bottoni li blinda contro ulteriori restringimenti
     quando lo spazio orizzontale è risicato. */
  .txn { grid-template-columns: 34px minmax(0, 1fr) auto auto; }
  .txn__actions {
    opacity: 1;
    position: static;
    transform: none;
    background: none;
    padding-left: 0;
    flex-shrink: 0;
  }
  .txn__edit,
  .txn__delete { flex-shrink: 0; }
}

/* ============================================================
   FILTRI (chip + select)
   ============================================================ */
.filters {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 28px;
}
@media (min-width: 760px) {
  .filters {
    flex-direction: row;
    align-items: end;
    justify-content: space-between;
    gap: 24px;
  }
}

.filters__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.chip {
  display: inline-flex;
  align-items: center;
  padding: 7px 14px;
  border-radius: var(--r-pill);
  border: 1px solid var(--line-strong);
  background: transparent;
  color: var(--ink-soft);
  font-size: 0.86rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.chip:hover { color: var(--ink); border-color: var(--ink-mute); }
.chip.is-active {
  background: var(--ink);
  color: oklch(12% 0.01 280);
  border-color: var(--ink);
}

.filters__select {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 220px;
}

/* ============================================================
   EMPTY STATE
   ============================================================ */
.empty-state {
  padding: 56px 24px;
  text-align: center;
  background: var(--bg-elev);
  border: 1px dashed var(--line-strong);
  border-radius: var(--r-xl);
}
.empty-state__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--brand-soft);
  margin: 0 0 14px;
}
.empty-state__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.6rem, 3vw, 2rem);
  letter-spacing: -0.02em;
  margin: 0 0 10px;
  color: var(--ink);
  line-height: 1.1;
}
.empty-state__desc {
  color: var(--ink-soft);
  max-width: 44ch;
  margin: 0 auto 22px;
  line-height: 1.6;
}

/* ============================================================
   EDITOR MOVIMENTO — segmented, importo, checkbox impulso
   ============================================================ */
.setup .auth__form { gap: 18px; }

/* Segmented control (Spesa / Entrata) */
.seg {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  padding: 4px;
  background: oklch(16% 0.014 275);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-pill);
}
.seg input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.seg__option {
  text-align: center;
  padding: 10px 14px;
  border-radius: var(--r-pill);
  cursor: pointer;
  font-size: 0.92rem;
  font-weight: 500;
  color: var(--ink-soft);
  transition: background var(--t-fast), color var(--t-fast), box-shadow var(--t-fast);
}
.seg__option:hover { color: var(--ink); }
.seg input:checked + .seg__option {
  background: var(--bg);
  color: var(--ink);
  box-shadow: 0 1px 0 0 var(--line-strong), 0 6px 18px -10px rgb(0 0 0 / 0.6);
}
.seg input:checked + .seg__option--expense { color: oklch(82% 0.14 25); }
.seg input:checked + .seg__option--income { color: var(--mint-strong); }
.seg input:focus-visible + .seg__option {
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand-soft) 40%, transparent);
}

/* Campo importo con simbolo €  */
.amount-field {
  position: relative;
  display: flex;
  align-items: center;
}
.amount-field__currency {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--ink-mute);
  font-size: 1rem;
  pointer-events: none;
}
.input--amount {
  padding-left: 36px;
  font-family: var(--font-mono);
  font-size: 1.15rem;
  letter-spacing: -0.01em;
}

/* Campo "Spesa impulsiva?" — segmented No/Non lo so + 2 select condizionali */
.field--impulse {
  padding: 14px 14px 12px;
  background: oklch(16% 0.014 275 / 0.6);
  border: 1px solid var(--line);
  border-radius: var(--r);
  transition: border-color var(--t-fast), background var(--t-fast);
  display: grid;
  gap: 12px;
}
.field--impulse .field__label {
  margin: 0;
  font-weight: 500;
  color: var(--ink);
}
.field--impulse .field__hint { margin: 0; }
.seg--impulse .seg__option--ask { color: var(--ink-mute); }
.seg--impulse input:checked + .seg__option--ok  { color: var(--mint-strong); }
.seg--impulse input:checked + .seg__option--ask { color: var(--warn); }

/* Mini-form domande: visibile solo quando "Non lo so" è selezionato.
   Il :has scopre il radio scelto e svela il blocco. Fallback: nascosto. */
.impulse-questions {
  display: none;
  padding: 12px 12px 4px;
  background: color-mix(in oklab, var(--warn) 6%, transparent);
  border: 1px solid color-mix(in oklab, var(--warn) 35%, var(--line));
  border-radius: var(--r-sm);
}
.field--impulse:has(input[name="impulse_choice"][value="unsure"]:checked) .impulse-questions {
  display: grid;
  gap: 12px;
}
.impulse-questions__intro {
  margin: 0;
  font-size: 0.82rem;
  color: var(--ink-soft);
  letter-spacing: 0.01em;
}
.field__label--sm {
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  color: var(--ink-mute);
}

/* Le entrate non possono essere impulsive — nascondi il blocco intero. */
.auth__form:has(input[name="kind"][value="income"]:checked) .field--impulse {
  display: none;
}

/* Action row (Annulla / Salva) */
.form-actions {
  display: flex;
  flex-direction: column-reverse;
  gap: 10px;
  margin-top: 8px;
}
.form-actions .btn { width: 100%; }
@media (min-width: 540px) {
  .form-actions {
    flex-direction: row;
    justify-content: flex-end;
    align-items: center;
    gap: 12px;
  }
  .form-actions .btn { width: auto; }
}

/* ============================================================
   PAGINA CATEGORIE
   ============================================================ */
.cats-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
@media (min-width: 880px) {
  .cats-grid { grid-template-columns: 1.4fr 1fr; gap: 22px; }
}

.cats-panel {
  padding: 22px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
}
@media (min-width: 760px) { .cats-panel { padding: 28px; } }

.cats-panel__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 0 18px;
}
.cats-panel__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0;
}
.cats-panel__count {
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  color: var(--ink-dim);
  margin: 0;
}

.cats-list {
  display: grid;
  gap: 10px;
  margin: 0;
}

.cat-item {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: oklch(16% 0.014 275 / 0.6);
  border: 1px solid var(--line);
  border-radius: var(--r);
  transition: border-color var(--t-fast);
}
.cat-item:hover { border-color: var(--line-strong); }

.cat-item__form {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
@media (max-width: 540px) {
  .cat-item__form {
    grid-template-columns: auto 1fr auto;
    grid-template-areas:
      'color name save'
      'budget budget budget';
    gap: 8px;
  }
  .cat-item__form > .cat-item__color { grid-area: color; }
  .cat-item__form > .cat-item__name { grid-area: name; }
  .cat-item__form > .cat-item__budget,
  .cat-item__form > .cat-item__nobudget { grid-area: budget; }
  .cat-item__form > .btn { grid-area: save; }
}

.cat-item__color {
  display: inline-flex;
}
.cat-item__color input[type='color'] {
  width: 28px;
  height: 28px;
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  padding: 0;
  background: transparent;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
}
.cat-item__color input[type='color']::-webkit-color-swatch-wrapper { padding: 0; }
.cat-item__color input[type='color']::-webkit-color-swatch { border: 0; border-radius: 6px; }
.cat-item__color input[type='color']::-moz-color-swatch { border: 0; border-radius: 6px; }

.cat-item__name {
  font-size: 0.94rem;
  padding: 8px 12px;
  background: var(--bg);
  min-width: 0;
}
.cat-item__budget {
  position: relative;
  display: flex;
  align-items: center;
  width: 130px;
}
.cat-item__budget .amount-field__currency {
  left: 10px;
  font-size: 0.86rem;
}
.cat-item__budget-input {
  padding: 8px 10px 8px 24px;
  font-size: 0.88rem;
}
.cat-item__nobudget {
  font-size: 0.72rem;
  color: var(--ink-dim);
  letter-spacing: 0.08em;
  padding: 0 6px;
}

.cat-item__del { display: inline-flex; }
.cat-item__del-btn {
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  background: transparent;
  border: 1px solid var(--line-strong);
  border-radius: 10px;
  color: var(--ink-mute);
  cursor: pointer;
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.cat-item__del-btn:hover {
  color: var(--danger);
  border-color: var(--danger);
}

.cat-item__used {
  grid-column: 1 / -1;
  margin: 0;
  font-size: 0.72rem;
  color: var(--ink-dim);
  letter-spacing: 0.06em;
}

/* Form nuova categoria */
.cats-new {
  margin-top: 28px;
  padding: 24px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
}
@media (min-width: 760px) { .cats-new { padding: 32px; } }

.cats-new__form {
  display: grid;
  gap: 18px;
  margin-top: 6px;
}
.cats-new__row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
@media (min-width: 640px) {
  .cats-new__row {
    grid-template-columns: 1fr auto 180px;
    align-items: end;
    gap: 16px;
  }
}
.cats-new__color {
  width: 48px;
  height: 48px;
  padding: 0;
  border-radius: 12px;
  cursor: pointer;
  background: transparent;
  appearance: none;
  -webkit-appearance: none;
}
.cats-new__color::-webkit-color-swatch-wrapper { padding: 0; }
.cats-new__color::-webkit-color-swatch { border: 1px solid var(--line-strong); border-radius: 10px; }
.cats-new__color::-moz-color-swatch { border: 1px solid var(--line-strong); border-radius: 10px; }

.cats-new__form > .btn { justify-self: start; }

/* ============================================================
   STEP 4 — Report mensile (Chart.js)
   ============================================================ */

/* ---------- Header con nav mese precedente/successivo ---------- */
.report-nav {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 14px;
}
.report-nav__btn {
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  flex-shrink: 0;
  border-radius: 50%;
  border: 1px solid var(--line-strong);
  background: var(--bg-elev);
  color: var(--ink-soft);
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.report-nav__btn:hover {
  color: var(--ink);
  background: oklch(96% 0.03 85 / 0.06);
  border-color: var(--ink-mute);
}
.report-nav__btn--ghost {
  opacity: 0.25;
  pointer-events: none;
}
.report-nav__title {
  display: flex;
  align-items: baseline;
  gap: 12px;
  flex: 1;
  margin: 0;
  min-width: 0;
}
.report-nav__month {
  font-style: italic;
  color: var(--brand-soft);
  margin: 0;
  line-height: 1;
}
.report-nav__year {
  font-size: 0.9rem;
  color: var(--ink-mute);
  letter-spacing: 0.06em;
}
.report-nav__sub {
  margin: 12px 0 0;
  font-size: 0.86rem;
}

/* ---------- KPI cards ---------- */
.kpi-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin: 32px 0;
}
@media (min-width: 640px) {
  .kpi-grid { grid-template-columns: repeat(3, 1fr); gap: 18px; }
}

.kpi {
  padding: 22px 22px 18px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: relative;
  overflow: hidden;
}
.kpi::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: var(--line);
}
.kpi--income::before { background: linear-gradient(90deg, var(--mint), transparent); }
.kpi--expense::before { background: linear-gradient(90deg, var(--brand), transparent); }
.kpi--balance::before { background: linear-gradient(90deg, var(--ink-soft), transparent); }

.kpi__label {
  margin: 0;
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.kpi__num {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.8rem, 4.5vw, 2.4rem);
  letter-spacing: -0.025em;
  line-height: 1;
  color: var(--ink);
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.kpi__num .mono {
  font-family: var(--font-mono);
  font-size: 0.42em;
  color: var(--ink-mute);
  font-weight: 400;
}
.kpi__num--neg { color: var(--ink); }
.kpi__sign { color: var(--danger); }

.kpi__delta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.76rem;
  font-family: var(--font-mono);
  color: var(--ink-mute);
  letter-spacing: 0.02em;
}
.kpi__delta-arrow {
  display: inline-grid;
  place-items: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  font-size: 0.62rem;
  background: oklch(20% 0.014 275);
  color: var(--ink-mute);
}
.kpi__delta--good .kpi__delta-arrow { background: color-mix(in oklab, var(--mint) 22%, transparent); color: var(--mint-strong); }
.kpi__delta--bad .kpi__delta-arrow { background: color-mix(in oklab, var(--danger) 22%, transparent); color: var(--danger); }
.kpi__delta-vs { color: var(--ink-dim); }

/* ---------- Grid pannelli grafici ---------- */
.report-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
@media (min-width: 980px) {
  .report-grid { grid-template-columns: 1fr 1fr; gap: 22px; }
}

.report-panel {
  padding: 22px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
}
@media (min-width: 760px) { .report-panel { padding: 28px; } }

/* Reusabile per dash-panel__head già esistente */
.dash-panel__count {
  margin: 0;
  font-size: 0.72rem;
  color: var(--ink-dim);
  letter-spacing: 0.06em;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.legend-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
}
.legend-dot--income { background: var(--mint-strong); }
.legend-dot--expense { background: var(--brand); }
.legend-dot + .legend-dot { margin-left: 6px; }

/* ---------- Distribuzione (doughnut + legenda) ---------- */
.distribution {
  display: grid;
  grid-template-columns: 1fr;
  gap: 22px;
  align-items: center;
}
@media (min-width: 640px) {
  .distribution { grid-template-columns: 220px 1fr; gap: 26px; }
}

.distribution__chart {
  position: relative;
  width: 100%;
  max-width: 280px;
  margin: 0 auto;
  aspect-ratio: 1 / 1;
}
.distribution__chart canvas {
  width: 100% !important;
  height: 100% !important;
}
.distribution__center {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  text-align: center;
  pointer-events: none;
}
.distribution__center-label {
  margin: 0;
  font-size: 0.62rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.distribution__center-num {
  margin: 4px 0 0;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.05rem, 2.4vw, 1.3rem);
  letter-spacing: -0.02em;
  color: var(--ink);
  line-height: 1.1;
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
}
.distribution__center-num .mono {
  font-family: var(--font-mono);
  font-size: 0.7em;
  color: var(--ink-mute);
}

.distribution__legend {
  display: grid;
  gap: 10px;
  margin: 0;
}

.legend-row {
  display: grid;
  grid-template-columns: 10px 1fr auto auto;
  align-items: center;
  gap: 10px;
  padding: 6px 0;
  border-bottom: 1px dashed var(--line);
  font-size: 0.88rem;
}
.legend-row:last-child { border-bottom: 0; }
.legend-row__dot {
  width: 10px;
  height: 10px;
  border-radius: 3px;
}
.legend-row__name {
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.legend-row__pct {
  color: var(--ink-mute);
  font-size: 0.78rem;
  min-width: 48px;
  text-align: right;
}
.legend-row__num {
  color: var(--ink);
  font-weight: 500;
  white-space: nowrap;
}

/* ---------- Andamento (bar chart) ---------- */
.trend {
  position: relative;
  height: 260px;
  width: 100%;
}
.trend canvas {
  width: 100% !important;
  height: 100% !important;
}
@media (min-width: 760px) { .trend { height: 280px; } }

/* ---------- Spese impulsive ---------- */
.report-impulses {
  margin-top: 28px;
  padding: 24px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
}
@media (min-width: 760px) { .report-impulses { padding: 32px; } }

.report-impulses__head {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 18px;
}
.report-impulses__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.4rem, 3vw, 1.9rem);
  letter-spacing: -0.025em;
  line-height: 1.15;
  color: var(--ink);
  margin: 6px 0 0;
  max-width: 32ch;
}
.report-impulses__title em {
  font-style: italic;
  color: var(--warn);
}
.report-impulses__title em .mono {
  font-family: var(--font-mono);
  font-size: 0.7em;
  color: var(--warn);
  font-style: normal;
}
.report-impulses__sub {
  margin: 8px 0 0;
  font-size: 0.78rem;
  color: var(--ink-mute);
  letter-spacing: 0.06em;
}

/* ============================================================
   STEP 5 — Obiettivi di risparmio
   ============================================================ */

/* ---------- Layout pagina obiettivi (riusa padding+aurora dashboard) ---------- */
.page--goals,
.page--goal-show {
  padding: 116px 0 96px;
  position: relative;
  isolation: isolate;
}
@media (min-width: 760px) {
  .page--goals,
  .page--goal-show { padding-top: 140px; }
}
.page--goals::before,
.page--goal-show::before {
  content: '';
  position: absolute;
  inset: -10% -10% 70% -10%;
  z-index: -1;
  background:
    radial-gradient(50% 60% at 25% 10%, oklch(82% 0.14 165 / 0.12), transparent 70%),
    radial-gradient(40% 50% at 80% 0%, oklch(70% 0.2 285 / 0.14), transparent 72%);
  filter: blur(60px);
  pointer-events: none;
}
@media (min-width: 760px) {
  .page--goals,
  .page--goal-show { padding-bottom: 120px; }
}

/* ---------- Conferma azione ---------- */
.goals-ok {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  margin-bottom: 18px;
  border-radius: var(--r);
  background: color-mix(in oklab, var(--mint) 14%, transparent);
  border: 1px solid color-mix(in oklab, var(--mint) 50%, var(--line-strong));
  color: var(--ink);
  font-size: 0.9rem;
}
.goals-ok__icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--mint-strong);
  color: oklch(15% 0.01 280);
  font-weight: 700;
  font-size: 0.8rem;
  line-height: 1;
}

/* ---------- Riepilogo aggregato ---------- */
.goals-summary {
  display: grid;
  grid-template-columns: 1fr;
  gap: 22px;
  padding: 26px 24px;
  margin-bottom: 28px;
  background:
    linear-gradient(180deg, oklch(82% 0.14 165 / 0.06), transparent 70%),
    var(--bg-elev);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-card);
}
@media (min-width: 760px) {
  .goals-summary {
    grid-template-columns: 1.4fr 1fr;
    gap: 32px;
    padding: 32px 36px;
    align-items: center;
  }
}

.goals-summary__main { min-width: 0; }
.goals-summary__kicker {
  margin: 0 0 8px;
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.goals-summary__num {
  margin: 0 0 14px;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2.2rem, 6vw, 3.4rem);
  letter-spacing: -0.025em;
  line-height: 1;
  color: var(--ink);
  display: flex;
  align-items: baseline;
  gap: 8px;
  flex-wrap: wrap;
}
.goals-summary__num .mono {
  font-family: var(--font-mono);
  font-size: 0.42em;
  color: var(--ink-mute);
  font-weight: 400;
}
.goals-summary__num-sub {
  font-family: var(--font-mono);
  font-size: 0.32em;
  color: var(--ink-soft);
  font-weight: 400;
}
.goals-summary__bar {
  display: block;
  height: 6px;
  background: oklch(20% 0.014 275);
  border-radius: 999px;
  overflow: hidden;
}
.goals-summary__bar-fill {
  display: block;
  height: 100%;
  width: var(--p, 0%);
  background: linear-gradient(90deg, var(--mint), var(--brand));
  border-radius: 999px;
  transition: width var(--t-slow) var(--ease-soft);
}
.goals-summary__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: var(--r);
  overflow: hidden;
  margin: 0;
}
.goals-summary__stats > li {
  padding: 16px 14px;
  background: var(--bg-elev);
}

/* ---------- Fondo emergenza ---------- */
.emergency-card {
  padding: 24px;
  margin-bottom: 28px;
  background:
    linear-gradient(135deg, oklch(82% 0.14 165 / 0.10), transparent 70%),
    var(--bg-elev);
  border: 1px solid color-mix(in oklab, var(--mint) 40%, var(--line-strong));
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-card);
}
@media (min-width: 760px) { .emergency-card { padding: 32px; } }

.emergency-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
}
.emergency-card__kicker {
  margin: 0 0 6px;
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mint-strong);
}
.emergency-card__name {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.6rem, 3.5vw, 2rem);
  letter-spacing: -0.025em;
  color: var(--ink);
  line-height: 1.1;
}
.emergency-card__amount {
  display: flex;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}
.emergency-card__num {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2rem, 5vw, 2.6rem);
  letter-spacing: -0.025em;
  line-height: 1;
  color: var(--ink);
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.emergency-card__num .mono {
  font-family: var(--font-mono);
  font-size: 0.42em;
  color: var(--ink-mute);
  font-weight: 400;
}
.emergency-card__sub {
  margin: 0;
  font-size: 0.82rem;
  color: var(--ink-mute);
  letter-spacing: 0.04em;
}
.emergency-card__actions {
  margin-top: 14px;
  display: flex;
  gap: 10px;
}

/* Chip varianti */
.chip--emergency {
  background: color-mix(in oklab, var(--mint) 24%, transparent);
  color: var(--mint-strong);
  border-color: color-mix(in oklab, var(--mint) 50%, var(--line-strong));
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.chip--reached {
  background: color-mix(in oklab, var(--brand) 24%, transparent);
  color: var(--brand-soft);
  border-color: color-mix(in oklab, var(--brand) 50%, var(--line-strong));
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

/* ---------- Barra progress riusabile ---------- */
.goal-bar {
  display: block;
  height: 8px;
  background: oklch(20% 0.014 275);
  border-radius: 999px;
  overflow: hidden;
  margin: 4px 0 0;
}
.goal-bar--emergency {
  height: 10px;
  background: color-mix(in oklab, var(--mint) 12%, oklch(20% 0.014 275));
}
.goal-bar--soft {
  height: 6px;
}
.goal-bar__fill {
  display: block;
  height: 100%;
  width: var(--p, 0%);
  border-radius: 999px;
  background: var(--brand);
  transition: width var(--t-slow) var(--ease-soft);
}

/* ---------- Griglia card obiettivi ---------- */
.goals-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-bottom: 28px;
}
@media (min-width: 640px) { .goals-grid { grid-template-columns: 1fr 1fr; gap: 18px; } }
@media (min-width: 1024px) { .goals-grid { grid-template-columns: repeat(3, 1fr); } }

.goal-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 22px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  color: inherit;
  text-decoration: none;
  transition: border-color var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);
}
.goal-card:hover {
  border-color: var(--ink-mute);
  transform: translateY(-2px);
  box-shadow: var(--shadow);
}
.goal-card--reached { border-color: color-mix(in oklab, var(--brand) 50%, var(--line-strong)); }
.goal-card--close { border-color: color-mix(in oklab, var(--warn) 50%, var(--line-strong)); }

.goal-card__head {
  display: flex;
  align-items: center;
  gap: 10px;
}
.goal-card__dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}
.goal-card__name {
  flex: 1;
  margin: 0;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.2rem;
  letter-spacing: -0.02em;
  color: var(--ink);
  line-height: 1.15;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.goal-card__num {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.5rem;
  letter-spacing: -0.025em;
  line-height: 1;
  color: var(--ink);
  display: flex;
  align-items: baseline;
  gap: 6px;
  flex-wrap: wrap;
}
.goal-card__num .mono {
  font-family: var(--font-mono);
  font-size: 0.5em;
  color: var(--ink-mute);
  font-weight: 400;
}
.goal-card__num-sub {
  font-family: var(--font-mono);
  font-size: 0.42em;
  color: var(--ink-soft);
  font-weight: 400;
}
.goal-card__foot {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  margin: 0;
  font-size: 0.72rem;
  color: var(--ink-mute);
  letter-spacing: 0.04em;
}
.goal-card__deadline { color: var(--ink-dim); }
.goal-card--close .goal-card__deadline { color: var(--warn); }

/* ---------- Form nuovo obiettivo ---------- */
.goals-new {
  margin-top: 28px;
  padding: 24px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
}
@media (min-width: 760px) { .goals-new { padding: 32px; } }

.goals-new__form {
  display: grid;
  gap: 18px;
  margin-top: 6px;
}
.goals-new__form > .btn { justify-self: start; }

.seg__option--disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

/* ============================================================
   Obiettivo singolo (show)
   ============================================================ */
.back-link {
  margin: 0 0 18px;
}
.link-arrow--back {
  border-bottom-color: var(--line);
  color: var(--ink-soft);
}
.link-arrow--back:hover {
  color: var(--ink);
  border-color: var(--ink-mute);
}

/* ---------- Hero obiettivo ---------- */
.goal-hero {
  margin-bottom: 28px;
}
.goal-hero__head { margin-bottom: 24px; }
.goal-hero__name {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  margin: 10px 0 0;
}
.goal-hero__dot {
  display: inline-block;
  width: 16px;
  height: 16px;
  border-radius: 50%;
}

.goal-hero__panel {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
  padding: 28px 24px;
  background: var(--bg-elev);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-card);
  align-items: center;
}
@media (min-width: 760px) {
  .goal-hero__panel {
    grid-template-columns: auto 1fr;
    gap: 36px;
    padding: 36px;
  }
}

/* Progress radial */
.goal-radial {
  position: relative;
  width: 200px;
  height: 200px;
  justify-self: center;
}
.goal-radial svg { display: block; }
.goal-radial__center {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  text-align: center;
  pointer-events: none;
}
.goal-radial__pct {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 2.6rem;
  letter-spacing: -0.025em;
  line-height: 1;
  color: var(--ink);
}
.goal-radial__pct-sub {
  font-family: var(--font-mono);
  font-size: 0.4em;
  color: var(--ink-mute);
  margin-left: 4px;
}
.goal-radial__lbl {
  margin: 4px 0 0;
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

/* KPI obiettivo */
.goal-hero__kpis {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
@media (min-width: 760px) { .goal-hero__kpis { gap: 22px; } }

.goal-kpi {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 14px 16px;
  background: oklch(16% 0.014 275 / 0.6);
  border: 1px solid var(--line);
  border-radius: var(--r);
}
.goal-kpi .kpi__label { margin: 0; }
.goal-kpi .kpi__num {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: -0.025em;
  margin: 0;
  display: flex;
  align-items: baseline;
  gap: 6px;
  color: var(--ink);
}
.goal-kpi .kpi__num .mono {
  font-family: var(--font-mono);
  font-size: 0.5em;
  color: var(--ink-mute);
  font-weight: 400;
}
.goal-kpi__date {
  font-family: var(--font-mono);
  font-size: 0.95rem;
  letter-spacing: 0.04em;
}
.goal-kpi__sub {
  margin: 0;
  font-size: 0.74rem;
  color: var(--ink-mute);
  letter-spacing: 0.06em;
}

/* ---------- Form deposito/prelievo ---------- */
.goal-add,
.goal-history,
.goal-manage {
  padding: 24px;
  margin-top: 18px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
}
@media (min-width: 760px) {
  .goal-add,
  .goal-history,
  .goal-manage { padding: 28px; }
}

.goal-add__form {
  display: grid;
  gap: 18px;
  margin-top: 6px;
}
.goal-add__form > .btn { justify-self: start; }

/* Tag movimento (versamento / prelievo) */
.goal-mov-tag {
  font-family: var(--font-display);
  font-size: 1.1rem;
  color: oklch(12% 0.01 280);
}
.goal-mov-tag--in { background: var(--mint-strong); }
.goal-mov-tag--out { background: var(--danger); color: var(--ink); }

/* ---------- Modifica / archivia ---------- */
.goal-manage__details {
  margin-bottom: 18px;
}
.goal-manage__summary {
  cursor: pointer;
  list-style: none;
  font-size: 0.78rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  padding: 8px 12px;
  border: 1px solid var(--line-strong);
  border-radius: var(--r);
  display: inline-block;
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.goal-manage__summary::-webkit-details-marker { display: none; }
.goal-manage__summary:hover {
  color: var(--ink);
  border-color: var(--ink-mute);
}
.goal-manage__details[open] .goal-manage__summary {
  color: var(--ink);
  border-color: var(--ink-mute);
  margin-bottom: 18px;
}
.goal-manage__form {
  display: grid;
  gap: 18px;
}
.goal-manage__form > .btn { justify-self: start; }
.goal-manage__archive {
  border-top: 1px dashed var(--line);
  padding-top: 18px;
}
.goal-manage__archive-btn {
  color: var(--danger);
  border-color: color-mix(in oklab, var(--danger) 45%, var(--line-strong));
}
.goal-manage__archive-btn:hover {
  background: color-mix(in oklab, var(--danger) 10%, transparent);
  border-color: var(--danger);
}

/* ============================================================
   Cruscotto — integrazione Risparmi + Disponibile escluso emergenza
   ============================================================ */
.dash-balance__shield {
  margin: 12px 0 0;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: color-mix(in oklab, var(--mint) 8%, transparent);
  border: 1px solid color-mix(in oklab, var(--mint) 35%, var(--line-strong));
  border-radius: var(--r-pill);
  font-size: 0.74rem;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
}
.dash-balance__shield-icon {
  color: var(--mint-strong);
  font-size: 0.8rem;
}
.dash-balance__shield-num {
  color: var(--ink);
  font-weight: 600;
  margin-left: 2px;
}

.dash-panel--savings {
  background:
    linear-gradient(180deg, oklch(82% 0.14 165 / 0.05), transparent 80%),
    var(--bg-elev);
}
.dash-savings__total {
  margin: 0 0 14px;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.8rem;
  letter-spacing: -0.025em;
  line-height: 1;
  color: var(--ink);
  display: flex;
  align-items: baseline;
  gap: 8px;
  flex-wrap: wrap;
}
.dash-savings__total .mono {
  font-family: var(--font-mono);
  font-size: 0.5em;
  color: var(--ink-mute);
  font-weight: 400;
}
.dash-savings__total-sub {
  font-family: var(--font-mono);
  font-size: 0.42em;
  color: var(--ink-soft);
  font-weight: 400;
}
.dash-savings__list {
  margin: 18px 0 0;
  display: grid;
  gap: 12px;
}
.dash-savings__row {
  display: grid;
  grid-template-columns: 12px 1fr auto;
  align-items: center;
  gap: 12px;
}
.dash-savings__tag {
  display: inline-block;
  margin-left: 8px;
  padding: 1px 6px;
  border-radius: var(--r-pill);
  background: color-mix(in oklab, var(--mint) 22%, transparent);
  color: var(--mint-strong);
  font-size: 0.62rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

/* ============================================================
   PAGINA PROFILO (gestione identità + impostazioni)
   ============================================================ */
.page--profile {
  padding: 116px 0 96px;
  position: relative;
  isolation: isolate;
}
@media (min-width: 760px) {
  .page--profile { padding-top: 140px; }
}
.page--profile::before {
  content: '';
  position: absolute;
  inset: -10% -10% 70% -10%;
  z-index: -1;
  background:
    radial-gradient(50% 60% at 80% 10%, oklch(70% 0.2 285 / 0.16), transparent 70%),
    radial-gradient(40% 50% at 20% 0%, oklch(82% 0.14 165 / 0.10), transparent 72%);
  filter: blur(60px);
  pointer-events: none;
}
@media (min-width: 760px) { .page--profile { padding-bottom: 120px; } }

/* ---------- Hero con avatar + identità ---------- */
.profile-hero {
  display: grid;
  grid-template-columns: 1fr;
  justify-items: center;
  text-align: center;
  gap: 18px;
  padding: 32px 24px;
  margin-bottom: 24px;
  background: var(--bg-elev);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-card);
}
@media (min-width: 640px) {
  .profile-hero {
    grid-template-columns: auto 1fr;
    justify-items: start;
    text-align: left;
    gap: 28px;
    padding: 36px 40px;
    align-items: center;
  }
}

.profile-hero__avatar {
  width: 112px;
  height: 112px;
  border-radius: 50%;
  overflow: hidden;
  background:
    conic-gradient(from 200deg at 50% 50%, var(--mint), var(--brand), oklch(82% 0.16 320), var(--mint));
  display: grid;
  place-items: center;
  box-shadow: inset 0 0 0 2px rgb(255 255 255 / 0.12), 0 8px 32px -12px oklch(70% 0.2 285 / 0.55);
  flex-shrink: 0;
}
.profile-hero__avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.profile-hero__avatar-initial {
  font-family: var(--font-display);
  font-size: 3rem;
  font-weight: 400;
  color: oklch(12% 0.01 280);
  line-height: 1;
}

.profile-hero__id { min-width: 0; }
.profile-hero__name {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.8rem, 4vw, 2.4rem);
  letter-spacing: -0.025em;
  line-height: 1.1;
  color: var(--ink);
}
.profile-hero__handle {
  margin: 6px 0 0;
  font-size: 0.84rem;
  color: var(--brand-soft);
  letter-spacing: 0.04em;
}
.profile-hero__email {
  margin: 6px 0 0;
  font-size: 0.92rem;
  color: var(--ink-mute);
}

/* ---------- Form card ---------- */
.profile-form-card,
.profile-account {
  padding: 24px;
  margin-bottom: 18px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
}
@media (min-width: 760px) {
  .profile-form-card,
  .profile-account { padding: 32px; }
}

.profile-form {
  display: grid;
  gap: 22px;
  margin-top: 6px;
}

/* ---------- Avatar field (upload + anteprima) ---------- */
.avatar-field {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 18px;
  align-items: center;
  padding: 18px;
  background: oklch(16% 0.014 275 / 0.6);
  border: 1px solid var(--line);
  border-radius: var(--r);
}
@media (max-width: 480px) {
  .avatar-field {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
  }
}

.avatar-field__preview {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  overflow: hidden;
  background:
    conic-gradient(from 200deg at 50% 50%, var(--mint), var(--brand), oklch(82% 0.16 320), var(--mint));
  display: grid;
  place-items: center;
  flex-shrink: 0;
  position: relative;
}
.avatar-field__preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.avatar-field__initial {
  font-family: var(--font-display);
  font-size: 2.2rem;
  font-weight: 400;
  color: oklch(12% 0.01 280);
  line-height: 1;
}

.avatar-field__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}
@media (max-width: 480px) {
  .avatar-field__actions { justify-content: center; }
}

.avatar-field__btn {
  cursor: pointer;
  position: relative;
  overflow: hidden;
}
.avatar-field__input {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
}
.avatar-field__remove {
  color: var(--danger);
  border-color: color-mix(in oklab, var(--danger) 40%, var(--line-strong));
}
.avatar-field__remove:hover {
  background: color-mix(in oklab, var(--danger) 10%, transparent);
  border-color: var(--danger);
}
.avatar-field__hint {
  flex-basis: 100%;
  margin: 0;
  font-size: 0.76rem;
  color: var(--ink-dim);
}

/* ---------- Pannello Account (sola lettura) ---------- */
.profile-account__list {
  display: grid;
  gap: 0;
  margin: 0;
}
.profile-account__list > div {
  display: grid;
  grid-template-columns: 1fr;
  gap: 4px;
  padding: 14px 0;
  border-bottom: 1px dashed var(--line);
}
.profile-account__list > div:last-child { border-bottom: 0; }
.profile-account__list dt {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.profile-account__list dd {
  margin: 0;
  color: var(--ink);
  font-size: 0.95rem;
}
.profile-account__list dd.mono { font-size: 0.86rem; color: var(--ink-soft); }
@media (min-width: 540px) {
  .profile-account__list > div {
    grid-template-columns: 200px 1fr;
    align-items: baseline;
  }
}

/* ---------- User-pill: stato attivo quando si è su /profile ---------- */
.user-pill__id.is-active {
  background: oklch(96% 0.03 85 / 0.12);
  border-color: var(--ink-mute);
}

/* ============================================================
   STEP 6 — Abbonamenti & addebiti ricorrenti
   ============================================================ */

.page--subs,
.page--sub-show {
  padding: 116px 0 96px;
  position: relative;
  isolation: isolate;
}
@media (min-width: 760px) {
  .page--subs,
  .page--sub-show { padding-top: 140px; }
}
.page--subs::before,
.page--sub-show::before {
  content: '';
  position: absolute;
  inset: -10% -10% 70% -10%;
  z-index: -1;
  background:
    radial-gradient(50% 60% at 80% 10%, oklch(70% 0.2 320 / 0.14), transparent 70%),
    radial-gradient(40% 50% at 20% 0%, oklch(70% 0.2 285 / 0.12), transparent 72%);
  filter: blur(60px);
  pointer-events: none;
}
@media (min-width: 760px) {
  .page--subs,
  .page--sub-show { padding-bottom: 120px; }
}

/* ---------- KPI proiezioni ---------- */
.subs-kpi {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin: 28px 0;
}
@media (min-width: 760px) {
  .subs-kpi {
    grid-template-columns: 1.4fr 1fr 1fr 1fr;
    gap: 16px;
  }
}

.subs-kpi__card {
  padding: 20px 18px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  display: flex;
  flex-direction: column;
  gap: 8px;
  position: relative;
  overflow: hidden;
}
.subs-kpi__card--main {
  grid-column: 1 / -1;
  background:
    linear-gradient(135deg, oklch(70% 0.2 285 / 0.08), transparent 60%),
    var(--bg-elev);
  border-color: var(--line-strong);
}
@media (min-width: 760px) {
  .subs-kpi__card--main { grid-column: auto; }
}

.subs-kpi__num {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2rem, 5vw, 2.8rem);
  letter-spacing: -0.025em;
  line-height: 1;
  color: var(--ink);
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.subs-kpi__num--sm { font-size: clamp(1.4rem, 3.5vw, 1.8rem); }
.subs-kpi__num .mono {
  font-family: var(--font-mono);
  font-size: 0.42em;
  color: var(--ink-mute);
  font-weight: 400;
}
.subs-kpi__sub {
  margin: 0;
  font-size: 0.74rem;
  color: var(--ink-mute);
  letter-spacing: 0.04em;
}

/* ---------- Sostenibilità ---------- */
.subs-sustain {
  padding: 22px 24px;
  margin-bottom: 28px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
}
@media (min-width: 760px) { .subs-sustain { padding: 28px 32px; } }

.subs-sustain--warn { border-color: color-mix(in oklab, var(--warn) 50%, var(--line-strong)); }
.subs-sustain--danger { border-color: color-mix(in oklab, var(--danger) 50%, var(--line-strong)); }

.subs-sustain__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}
.subs-sustain__msg {
  margin: 0 0 14px;
  color: var(--ink-soft);
  font-size: 0.96rem;
  line-height: 1.5;
}
.subs-sustain__msg strong { color: var(--ink); }
.subs-sustain__msg .link-arrow { margin-left: 6px; font-size: 0.86rem; }

.subs-sustain__bar {
  position: relative;
  margin-bottom: 10px;
}
.subs-sustain--warn .subs-sustain__bar-fill { background: var(--warn); }
.subs-sustain--danger .subs-sustain__bar-fill { background: var(--danger); }
.subs-sustain--ok .subs-sustain__bar-fill { background: var(--mint-strong); }
.subs-sustain__bar-mark {
  position: absolute;
  top: -3px;
  width: 1px;
  height: calc(100% + 6px);
  background: var(--ink-dim);
  opacity: 0.6;
}
.subs-sustain__legend {
  margin: 0;
  font-size: 0.68rem;
  color: var(--ink-dim);
  letter-spacing: 0.06em;
}

.subs-chip--warn {
  background: color-mix(in oklab, var(--warn) 24%, transparent);
  color: var(--warn);
  border-color: color-mix(in oklab, var(--warn) 50%, var(--line-strong));
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.subs-chip--danger {
  background: color-mix(in oklab, var(--danger) 24%, transparent);
  color: var(--danger);
  border-color: color-mix(in oklab, var(--danger) 50%, var(--line-strong));
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.subs-chip--cancelled {
  background: oklch(20% 0.014 275);
  color: var(--ink-mute);
  border-color: var(--line-strong);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

/* ---------- Mini-avviso sostenibilità nel form ---------- */
.subs-sustain-mini {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 12px 14px;
  border-radius: var(--r);
  font-size: 0.86rem;
  line-height: 1.5;
}
.subs-sustain-mini--warn {
  background: color-mix(in oklab, var(--warn) 12%, transparent);
  border: 1px solid color-mix(in oklab, var(--warn) 40%, var(--line-strong));
  color: var(--ink);
}
.subs-sustain-mini--danger {
  background: color-mix(in oklab, var(--danger) 12%, transparent);
  border: 1px solid color-mix(in oklab, var(--danger) 40%, var(--line-strong));
  color: var(--ink);
}
.subs-sustain-mini__icon {
  flex-shrink: 0;
  font-size: 1rem;
  line-height: 1.4;
}

/* ---------- Griglia card abbonamenti ---------- */
.subs-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-bottom: 28px;
}
@media (min-width: 640px) { .subs-grid { grid-template-columns: 1fr 1fr; gap: 18px; } }
@media (min-width: 1024px) { .subs-grid { grid-template-columns: repeat(3, 1fr); } }

.sub-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 22px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  color: inherit;
  text-decoration: none;
  transition: border-color var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);
}
.sub-card:hover {
  border-color: var(--ink-mute);
  transform: translateY(-2px);
  box-shadow: var(--shadow);
}

.sub-card__head {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}
.sub-card__dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  flex-shrink: 0;
}
.sub-card__id { min-width: 0; flex: 1; }
.sub-card__name {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.2rem;
  letter-spacing: -0.02em;
  color: var(--ink);
  line-height: 1.15;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sub-card__vendor {
  margin: 2px 0 0;
  font-size: 0.72rem;
  color: var(--ink-mute);
  letter-spacing: 0.04em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sub-card__amounts {
  display: flex;
  align-items: baseline;
  gap: 8px;
  flex-wrap: wrap;
}
.sub-card__num {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.5rem;
  letter-spacing: -0.025em;
  color: var(--ink);
  line-height: 1;
  display: flex;
  align-items: baseline;
  gap: 6px;
}
.sub-card__num .mono {
  font-family: var(--font-mono);
  font-size: 0.5em;
  color: var(--ink-mute);
  font-weight: 400;
}
.sub-card__freq {
  font-size: 0.74rem;
  color: var(--ink-mute);
  letter-spacing: 0.04em;
}

.sub-card__foot {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  margin: 0;
  font-size: 0.7rem;
  color: var(--ink-soft);
  letter-spacing: 0.04em;
}
.sub-card__next { color: var(--ink-dim); }

/* ---------- Archivio pausati/cancellati ---------- */
.subs-archive {
  margin-top: 16px;
  padding: 18px 20px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
}
.subs-archive__summary {
  list-style: none;
  cursor: pointer;
  color: var(--ink-soft);
  font-size: 0.78rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 6px 0;
}
.subs-archive__summary::-webkit-details-marker { display: none; }
.subs-archive__count { color: var(--ink-dim); margin-left: 6px; }
.subs-archive__group {
  margin: 18px 0 8px;
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.subs-archive__list {
  display: grid;
  gap: 6px;
  margin: 0;
}
.subs-archive__link {
  display: grid;
  grid-template-columns: 14px 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  background: oklch(16% 0.014 275 / 0.6);
  border: 1px solid var(--line);
  border-radius: var(--r);
  color: var(--ink-soft);
  text-decoration: none;
  transition: border-color var(--t-fast), color var(--t-fast);
}
.subs-archive__link:hover { color: var(--ink); border-color: var(--ink-mute); }
.subs-archive__name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.subs-archive__amt { color: var(--ink-dim); font-size: 0.82rem; }

/* ---------- Show abbonamento ---------- */
.sub-hero { margin-bottom: 28px; }
.sub-hero__name {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  margin: 10px 0 4px;
}
.sub-hero__dot {
  display: inline-block;
  width: 14px;
  height: 14px;
  border-radius: 50%;
}
.sub-hero__vendor {
  margin: 0 0 24px;
  font-size: 0.86rem;
  color: var(--ink-mute);
  letter-spacing: 0.06em;
}
.sub-hero__kpis {
  margin: 0;
}
.sub-hero__next {
  margin: 18px 0 0;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: color-mix(in oklab, var(--brand) 12%, transparent);
  border: 1px solid color-mix(in oklab, var(--brand) 40%, var(--line-strong));
  border-radius: var(--r-pill);
  color: var(--brand-soft);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
}

.sub-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 28px 0;
}
.sub-actions__form { margin: 0; }
.sub-actions__danger {
  color: var(--danger);
  border-color: color-mix(in oklab, var(--danger) 40%, var(--line-strong));
}
.sub-actions__danger:hover {
  background: color-mix(in oklab, var(--danger) 10%, transparent);
  border-color: var(--danger);
}

.sub-edit {
  padding: 24px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
}
@media (min-width: 760px) { .sub-edit { padding: 32px; } }

/* ---------- Cruscotto: card Abbonamenti ---------- */
.dash-panel--subs {
  background:
    linear-gradient(180deg, oklch(70% 0.2 285 / 0.05), transparent 80%),
    var(--bg-elev);
}
.dash-subs__alert {
  margin: 10px 0 14px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: var(--r-pill);
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
}
.dash-subs__alert--ok {
  background: color-mix(in oklab, var(--mint) 10%, transparent);
  color: var(--mint-strong);
}
.dash-subs__alert--warn {
  background: color-mix(in oklab, var(--warn) 12%, transparent);
  color: var(--warn);
}
.dash-subs__alert--danger {
  background: color-mix(in oklab, var(--danger) 14%, transparent);
  color: var(--danger);
}

/* ============================================================
   Reveal on scroll
   ============================================================ */
[data-reveal] {
  opacity: 0;
  transform: translateY(18px);
  transition:
    opacity var(--t-slow) var(--ease-soft),
    transform var(--t-slow) var(--ease-soft);
  will-change: opacity, transform;
}
[data-reveal].is-revealed {
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    transition: none !important;
    animation: none !important;
    scroll-behavior: auto !important;
  }
  [data-reveal] { opacity: 1; transform: none; }
  .marquee__track { animation: none; }
}

/* ============================================================
   STEP 7 — Educazione finanziaria
   ------------------------------------------------------------
   Hub /educazione + dettaglio /educazione/:slug con tre sezioni
   (lettura, flash cards, quiz). Palette dinamica per argomento
   via la variabile inline --edu-color.
   ============================================================ */

.page--edu,
.page--edu-show {
  padding: 116px 0 96px;
  position: relative;
  isolation: isolate;
}
@media (min-width: 760px) {
  .page--edu,
  .page--edu-show { padding-top: 140px; }
}
.page--edu::before,
.page--edu-show::before {
  content: '';
  position: absolute;
  inset: -10% -10% 70% -10%;
  z-index: -1;
  background:
    radial-gradient(50% 60% at 30% 10%, oklch(70% 0.2 285 / 0.16), transparent 70%),
    radial-gradient(40% 50% at 80% 0%, oklch(82% 0.14 165 / 0.10), transparent 72%);
  filter: blur(60px);
  pointer-events: none;
}

/* ---------- Hero hub ---------- */
.edu-head { margin-bottom: 28px; }
.edu-head .page__lede { margin-top: 16px; }

/* ---------- Barra riepilogo progresso aggregato ---------- */
.edu-summary {
  margin: 0 0 32px;
  padding: 18px 20px;
  background: var(--bg-elev);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-lg);
  display: grid;
  gap: 10px;
}
.edu-summary__bar {
  position: relative;
  height: 8px;
  background: oklch(20% 0.02 275 / 0.6);
  border-radius: 999px;
  overflow: hidden;
}
.edu-summary__fill {
  position: absolute;
  inset: 0 auto 0 0;
  background: linear-gradient(90deg, var(--brand-soft), var(--mint));
  border-radius: 999px;
  transition: width var(--t) var(--ease);
}
.edu-summary__line { margin: 0; color: var(--ink-soft); font-size: 0.92rem; }
.edu-summary__line strong { color: var(--ink); font-weight: 600; }

/* ---------- Griglia card argomenti ---------- */
.edu-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
@media (min-width: 640px)  { .edu-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; } }
@media (min-width: 1024px) { .edu-grid { grid-template-columns: repeat(3, 1fr); } }

.edu-card {
  position: relative;
  isolation: isolate;
}
.edu-card__link {
  /* position: relative + overflow: hidden — così la barra colorata ::before
     viene contenuta DENTRO i bordi arrotondati invece di protrudere fuori. */
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 12px;
  padding: 22px 22px 20px;
  background: var(--bg-elev);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-card);
  transition: transform var(--t) var(--ease), border-color var(--t) var(--ease), box-shadow var(--t) var(--ease);
  color: inherit;
  text-decoration: none;
  height: 100%;
}
.edu-card__link::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--edu-color, var(--brand-soft));
  opacity: 0.95;
}
.edu-card:hover .edu-card__link {
  transform: translateY(-2px);
  border-color: color-mix(in oklab, var(--edu-color, var(--brand-soft)) 35%, var(--line-strong));
  box-shadow: 0 18px 50px -22px color-mix(in oklab, var(--edu-color, var(--brand-soft)) 60%, transparent);
}

.edu-card--priority .edu-card__link {
  border-color: color-mix(in oklab, var(--edu-color, var(--danger)) 45%, var(--line-strong));
}
.edu-card--priority .edu-card__link::before { height: 4px; }

/* Card completata: il badge ✓ prende il posto del "X min" nell'angolo
   in alto a destra (prima si sovrapponevano). */
.edu-card--done .edu-card__minutes { display: none; }
.edu-card--done .edu-card__link::after {
  content: '✓ completato';
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 999px;
  background: color-mix(in oklab, var(--mint) 18%, transparent);
  border: 1px solid color-mix(in oklab, var(--mint) 55%, transparent);
  color: var(--mint-strong);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  /* Posizionato dentro la flex row di .edu-card__top tramite assoluto
     ancorato dove stava il badge minutes (top-right). */
  position: absolute;
  top: 22px;
  right: 22px;
}

.edu-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.edu-card__tag {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-mute);
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: oklch(16% 0.014 275 / 0.5);
}
.edu-card__tag--priority {
  color: oklch(15% 0.01 280);
  background: linear-gradient(90deg, var(--brand-soft), var(--mint));
  border-color: transparent;
}
.edu-card__tag--premium {
  color: oklch(15% 0.01 280);
  background: linear-gradient(90deg, var(--brand-soft), var(--mint));
  border-color: transparent;
}

/* Card di un argomento Premium non sbloccato: bordo tratteggiato + nota
   "Contenuto Premium" al posto degli step di avanzamento. */
.edu-card--locked .edu-card__link {
  border-style: dashed;
  border-color: color-mix(in oklab, var(--brand-soft) 40%, var(--line-strong));
}
.edu-card__locked-note {
  margin-top: 4px;
}
.edu-card__locked-note .mono {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.74rem;
  letter-spacing: 0.06em;
  color: var(--brand-soft);
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid color-mix(in oklab, var(--brand-soft) 45%, var(--line));
  background: color-mix(in oklab, var(--brand-soft) 12%, transparent);
}
.edu-card__minutes {
  font-size: 0.72rem;
  color: var(--ink-mute);
  letter-spacing: 0.04em;
}
.edu-card__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.4rem, 2.6vw, 1.7rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: 4px 0 0;
}
.edu-card__subtitle {
  margin: 0;
  color: var(--ink-soft);
  font-size: 0.92rem;
  line-height: 1.5;
}
.edu-card__progress {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 4px;
}
.edu-step {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px 4px 6px;
  border-radius: 999px;
  background: oklch(16% 0.014 275 / 0.5);
  border: 1px solid var(--line);
  color: var(--ink-mute);
  font-size: 0.76rem;
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.edu-step__num {
  display: grid;
  place-items: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--bg);
  border: 1px solid var(--line);
  font-size: 0.66rem;
  color: var(--ink-soft);
}
.edu-step--done {
  background: color-mix(in oklab, var(--mint) 14%, transparent);
  border-color: color-mix(in oklab, var(--mint) 50%, var(--line));
  color: var(--ink);
}
.edu-step--done .edu-step__num {
  background: var(--mint-strong);
  border-color: var(--mint-strong);
  color: oklch(14% 0.02 175);
}
.edu-step--locked {
  background: color-mix(in oklab, var(--brand-soft) 12%, transparent);
  border-color: color-mix(in oklab, var(--brand-soft) 45%, var(--line));
  color: var(--ink-soft);
}
.edu-step--locked .edu-step__num {
  background: transparent;
  border-color: var(--brand-soft);
  color: var(--brand-soft);
}
.edu-step--locked .edu-step__label {
  color: var(--brand-soft);
  font-weight: 500;
}

/* Pannello "Quiz Premium" sostituisce il form del quiz quando l'utente
   free apre il tab quiz di un topic gated. Tono coerente con .premium-active. */
.quiz-locked {
  background:
    radial-gradient(70% 70% at 100% 0%, oklch(72% 0.2 285 / 0.18), transparent 60%),
    var(--bg-elev);
  border: 1px solid oklch(45% 0.12 285);
  border-radius: var(--r-xl);
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 20px;
}
@media (min-width: 760px) {
  .quiz-locked { padding: 36px; }
}
.quiz-locked__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  color: var(--brand-soft);
  margin: 0;
  text-transform: uppercase;
}
.quiz-locked__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(1.4rem, 3vw, 1.9rem);
  margin: 0;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.quiz-locked__lede {
  margin: 0;
  font-size: 0.95rem;
  color: var(--ink-soft);
  line-height: 1.6;
  max-width: 60ch;
}
.quiz-locked__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

/* =================================================================
   Previsioni abbonamenti — pagina /abbonamenti/previsioni (Premium).
   Bento-grid di orizzonti + costo opportunità + what-if.
   ================================================================= */
.page--forecast { padding-bottom: 96px; padding-top: 96px;}

.forecast-horizons {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 24px;
  margin-bottom: 18px;
}
@media (min-width: 760px) {
  .forecast-horizons { padding: 32px; }
}
.forecast-horizons__head { margin-bottom: 18px; }
.forecast-horizons__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  color: var(--ink-mute);
  margin: 0 0 6px;
  text-transform: uppercase;
}
.forecast-horizons__sub {
  margin: 0;
  font-size: 0.95rem;
  color: var(--ink-soft);
  line-height: 1.55;
}
.forecast-horizons__sub strong { color: var(--ink); font-weight: 600; }

.forecast-horizons__grid {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
@media (min-width: 600px) {
  .forecast-horizons__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (min-width: 920px) {
  .forecast-horizons__grid { grid-template-columns: repeat(5, minmax(0, 1fr)); }
}

.forecast-horizon {
  padding: 18px 14px;
  background: oklch(20% 0.018 285 / 0.35);
  border: 1px solid var(--line);
  border-radius: var(--r);
}
.forecast-horizon__label {
  font-size: 0.66rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 8px;
}
.forecast-horizon__num {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 2.6vw, 1.9rem);
  color: var(--ink);
  margin: 0;
  letter-spacing: -0.02em;
  line-height: 1.05;
}
.forecast-horizon__num .mono {
  font-family: var(--font-mono);
  font-size: 0.55em;
  color: var(--ink-mute);
  margin-right: 4px;
}

/* Costo opportunità ----------------------------------------------- */
.forecast-opportunity {
  background:
    radial-gradient(60% 100% at 0% 0%, oklch(82% 0.14 165 / 0.10), transparent 60%),
    var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 24px;
  margin-bottom: 18px;
}
@media (min-width: 760px) {
  .forecast-opportunity { padding: 36px; }
}

.forecast-opportunity__main { margin-bottom: 20px; }
.forecast-opportunity__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  color: var(--mint);
  margin: 0 0 8px;
  text-transform: uppercase;
}
.forecast-opportunity__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.6rem, 3.2vw, 2.2rem);
  margin: 0 0 12px;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.forecast-opportunity__title em {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--mint);
}
.forecast-opportunity__lede {
  margin: 0;
  font-size: 0.95rem;
  color: var(--ink-soft);
  line-height: 1.65;
  max-width: 68ch;
}
.forecast-opportunity__lede strong { color: var(--ink); font-weight: 600; }

.forecast-opportunity__grid {
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr;
  margin-bottom: 16px;
}
@media (min-width: 600px) {
  .forecast-opportunity__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

.forecast-opp-card {
  background: oklch(20% 0.018 285 / 0.45);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 18px 16px;
}
.forecast-opp-card--accent {
  background:
    radial-gradient(80% 80% at 50% 0%, oklch(82% 0.14 165 / 0.18), transparent 70%),
    oklch(20% 0.018 285 / 0.55);
  border-color: color-mix(in oklab, var(--mint) 45%, var(--line));
}
.forecast-opp-card__lbl {
  font-size: 0.66rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 10px;
}
.forecast-opp-card__num {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2.8vw, 2rem);
  color: var(--ink);
  margin: 0;
  letter-spacing: -0.02em;
  line-height: 1.05;
}
.forecast-opp-card__num .mono {
  font-family: var(--font-mono);
  font-size: 0.55em;
  color: var(--ink-mute);
  margin-right: 4px;
}
.forecast-opp-card__num--gain { color: var(--mint); }

.forecast-opportunity__disclaimer {
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  color: var(--ink-dim);
  margin: 0;
  line-height: 1.5;
}
.forecast-opportunity__disclaimer a {
  color: var(--brand-soft);
  border-bottom: 1px solid color-mix(in oklab, var(--brand-soft) 40%, transparent);
}

/* Trend ---------------------------------------------------------- */
.forecast-trend {
  padding: 22px 24px;
  background: oklch(22% 0.04 70 / 0.18);
  border: 1px solid color-mix(in oklab, oklch(75% 0.12 70) 35%, var(--line));
  border-radius: var(--r-xl);
  margin-bottom: 18px;
}
.forecast-trend__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: oklch(82% 0.14 75);
  margin: 0 0 10px;
}
.forecast-trend__main,
.forecast-trend__projection {
  margin: 0 0 10px;
  font-size: 0.98rem;
  color: var(--ink-soft);
  line-height: 1.6;
}
.forecast-trend__projection:last-child { margin-bottom: 0; }
.forecast-trend strong { color: var(--ink); font-weight: 600; }

/* What-if + tabella voci ----------------------------------------- */
.forecast-perlist {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 24px;
}
@media (min-width: 760px) {
  .forecast-perlist { padding: 32px; }
}
.forecast-perlist__head { margin-bottom: 16px; }
.forecast-perlist__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  color: var(--ink-mute);
  margin: 0 0 6px;
  text-transform: uppercase;
}
.forecast-perlist__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(1.4rem, 3vw, 1.9rem);
  margin: 0 0 8px;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.forecast-perlist__lede {
  margin: 0;
  font-size: 0.92rem;
  color: var(--ink-soft);
  line-height: 1.6;
}

.forecast-whatif {
  display: grid;
  gap: 6px;
  padding: 18px 20px;
  background: oklch(20% 0.018 285 / 0.5);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  margin: 0 0 16px;
  transition: border-color var(--t-fast), background var(--t-fast);
}
.forecast-whatif.is-active {
  background:
    radial-gradient(80% 80% at 100% 0%, oklch(82% 0.14 165 / 0.18), transparent 70%),
    oklch(20% 0.018 285 / 0.6);
  border-color: color-mix(in oklab, var(--mint) 45%, var(--line));
}
.forecast-whatif__lbl {
  font-size: 0.66rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0;
}
.forecast-whatif__amount {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  color: var(--ink);
  margin: 0;
  letter-spacing: -0.02em;
  line-height: 1;
}
.forecast-whatif.is-active .forecast-whatif__amount { color: var(--mint); }
.forecast-whatif__amount .mono {
  font-family: var(--font-mono);
  font-size: 0.5em;
  color: var(--ink-mute);
  margin-right: 4px;
}
.forecast-whatif__sub {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--ink-mute);
  margin: 4px 0 0;
}
.forecast-whatif__sub strong { color: var(--ink); font-weight: 600; }

.forecast-table {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 6px;
}

.forecast-row {
  display: grid;
  grid-template-columns: 40px 1fr auto;
  gap: 14px;
  align-items: center;
  padding: 14px 16px;
  background: oklch(18% 0.014 285 / 0.45);
  border: 1px solid var(--line);
  border-radius: var(--r);
  position: relative;
}
@media (min-width: 600px) {
  .forecast-row {
    grid-template-columns: 40px 1fr auto auto;
  }
}

.forecast-row__check {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.forecast-row__check input { position: absolute; opacity: 0; pointer-events: none; }
.forecast-row__chip {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  background: transparent;
  border: 2px solid var(--sub-color, var(--line-strong));
  transition: background var(--t-fast), border-color var(--t-fast);
}
.forecast-row__check input:checked + .forecast-row__chip {
  background: var(--sub-color, var(--brand-soft));
  border-color: var(--sub-color, var(--brand-soft));
  position: relative;
}
.forecast-row__check input:checked + .forecast-row__chip::after {
  content: '✓';
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  font-weight: 700;
  color: oklch(12% 0.01 280);
}
.forecast-row__check input:focus-visible + .forecast-row__chip {
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand-soft) 30%, transparent);
}

.forecast-row__id { min-width: 0; }
.forecast-row__name {
  font-size: 0.98rem;
  color: var(--ink);
  margin: 0;
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.forecast-row__vendor {
  font-size: 0.7rem;
  color: var(--ink-mute);
  margin: 2px 0 0;
  letter-spacing: 0.04em;
}
.forecast-row__monthly {
  font-size: 0.85rem;
  color: var(--ink-soft);
  margin: 0;
  white-space: nowrap;
}
.forecast-row__five {
  font-size: 0.75rem;
  color: var(--ink-mute);
  margin: 0;
  letter-spacing: 0.04em;
  white-space: nowrap;
}
@media (max-width: 599.98px) {
  .forecast-row__five { display: none; }
}

.forecast-row:has(input:checked) {
  background: oklch(18% 0.014 285 / 0.7);
  text-decoration-color: color-mix(in oklab, var(--mint) 50%, transparent);
}
.forecast-row:has(input:checked) .forecast-row__name {
  text-decoration: line-through;
  color: var(--ink-mute);
}

/* CTA "Analisi predittiva" sulla pagina /abbonamenti (gated). */
.subs-forecast-cta { margin: 16px 0 0; }
.subs-forecast-cta__link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 18px;
  background:
    radial-gradient(80% 80% at 0% 50%, oklch(72% 0.2 285 / 0.16), transparent 60%),
    oklch(20% 0.018 285 / 0.5);
  border: 1px solid color-mix(in oklab, var(--brand-soft) 35%, var(--line));
  border-radius: var(--r-pill);
  font-size: 0.92rem;
  color: var(--ink);
  text-decoration: none;
  font-weight: 500;
  transition: border-color var(--t-fast), transform var(--t-fast) var(--ease);
}
.subs-forecast-cta__link:hover {
  border-color: var(--brand-soft);
  transform: translateY(-1px);
}
.subs-forecast-cta__icon {
  font-size: 1rem;
  color: var(--brand-soft);
  font-family: var(--font-mono);
}
.subs-forecast-cta__badge {
  margin-left: 6px;
  font-size: 0.6rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 3px 8px;
  background: var(--brand-soft);
  color: oklch(12% 0.01 280);
  border-radius: 999px;
  font-weight: 700;
}

/* =================================================================
   Avvisi avanzati di sostenibilità (Premium) sulla /abbonamenti.
   Breakdown per categoria + lista voci ad alto impatto.
   ================================================================= */
.subs-advanced {
  margin-top: 18px;
  padding: 24px;
  background:
    radial-gradient(60% 100% at 0% 0%, oklch(72% 0.2 285 / 0.10), transparent 60%),
    var(--bg-elev);
  border: 1px solid color-mix(in oklab, var(--brand-soft) 30%, var(--line));
  border-radius: var(--r-xl);
}
@media (min-width: 760px) {
  .subs-advanced { padding: 32px; }
}

.subs-advanced__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}
.subs-advanced__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0;
}
.subs-advanced__badge {
  font-size: 0.6rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 4px 10px;
  background: var(--brand-soft);
  color: oklch(12% 0.01 280);
  border-radius: 999px;
  font-weight: 700;
}
.subs-advanced__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(1.4rem, 2.8vw, 1.8rem);
  margin: 0 0 8px;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.subs-advanced__lede {
  margin: 0 0 18px;
  font-size: 0.95rem;
  color: var(--ink-soft);
  line-height: 1.55;
}
.subs-advanced__lede strong { color: var(--ink); font-weight: 600; }

/* Categoria breakdown */
.cat-bd {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 10px;
}
.cat-bd__row {
  display: grid;
  gap: 8px 16px;
  grid-template-columns: 1fr;
  padding: 14px 16px;
  background: oklch(18% 0.014 285 / 0.5);
  border: 1px solid var(--line);
  border-radius: var(--r);
}
@media (min-width: 720px) {
  .cat-bd__row {
    grid-template-columns: minmax(160px, 1.4fr) 2fr auto;
    align-items: center;
  }
}

.cat-bd__id {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.cat-bd__dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--cat-color, var(--brand-soft));
  flex-shrink: 0;
}
.cat-bd__name {
  margin: 0;
  font-size: 0.95rem;
  color: var(--ink);
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cat-bd__count {
  margin: 0;
  font-size: 0.66rem;
  letter-spacing: 0.12em;
  color: var(--ink-mute);
  text-transform: uppercase;
  white-space: nowrap;
}

.cat-bd__bar {
  position: relative;
  height: 8px;
  background: oklch(20% 0.018 285 / 0.6);
  border-radius: 999px;
  overflow: hidden;
}
.cat-bd__bar-fill {
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--p, 0%);
  background: linear-gradient(90deg, var(--cat-color, var(--brand-soft)),
    color-mix(in oklab, var(--cat-color, var(--brand-soft)) 70%, white));
  border-radius: inherit;
  transition: width 320ms var(--ease);
}

.cat-bd__nums {
  display: flex;
  flex-direction: column;
  gap: 2px;
  align-items: flex-end;
  white-space: nowrap;
}
.cat-bd__monthly {
  font-size: 0.92rem;
  color: var(--ink);
  margin: 0;
  font-weight: 500;
}
.cat-bd__pct {
  font-size: 0.68rem;
  letter-spacing: 0.08em;
  color: var(--ink-mute);
  margin: 0;
}

/* Lista voci ad alto impatto */
.subs-advanced__impact { margin-top: 22px; }
.subs-advanced__impact-kicker {
  font-size: 0.66rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: oklch(82% 0.14 30);
  margin: 0 0 8px;
}
.impact-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 4px;
}
.impact-row__link {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: color-mix(in oklab, oklch(75% 0.16 25) 10%, transparent);
  border: 1px solid color-mix(in oklab, oklch(75% 0.16 25) 35%, var(--line));
  border-radius: var(--r);
  text-decoration: none;
  font-size: 0.92rem;
  color: var(--ink);
  transition: border-color var(--t-fast);
}
.impact-row__link:hover { border-color: oklch(75% 0.16 25); }
.impact-row__name { font-weight: 500; }
.impact-row__pct { color: oklch(75% 0.16 25); font-weight: 600; }

.subs-sustain__custom {
  color: var(--brand-soft);
  font-style: normal;
}

.edu-summary__cta { margin-top: 14px; }

/* =================================================================
   Dashboard progressi educazione (Premium) — /educazione/progressi.
   ================================================================= */
.page--edu-progress { padding-bottom: 96px; padding-top: 96px; }

/* Badge a stelle ----------------------------------------------- */
.edu-badge {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 22px;
  align-items: center;
  padding: 28px 24px;
  background:
    radial-gradient(70% 100% at 0% 0%, oklch(72% 0.2 285 / 0.16), transparent 60%),
    var(--bg-elev);
  border: 1px solid color-mix(in oklab, var(--brand-soft) 30%, var(--line));
  border-radius: var(--r-xl);
  margin-bottom: 18px;
}
@media (min-width: 760px) {
  .edu-badge { padding: 36px; }
}
.edu-badge--lvl-2 {
  border-color: color-mix(in oklab, var(--mint) 40%, var(--line));
  background:
    radial-gradient(70% 100% at 0% 0%, oklch(82% 0.14 165 / 0.18), transparent 60%),
    var(--bg-elev);
}
.edu-badge--lvl-3 {
  border-color: color-mix(in oklab, oklch(82% 0.14 75) 55%, var(--line));
  background:
    radial-gradient(80% 110% at 0% 0%, oklch(82% 0.14 75 / 0.22), transparent 60%),
    var(--bg-elev);
}

.edu-badge__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 8px;
}
.edu-badge__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2rem, 5vw, 3rem);
  margin: 0 0 10px;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.edu-badge__title em {
  font-style: italic;
  background: linear-gradient(90deg, var(--brand-soft), var(--mint));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.edu-badge--lvl-3 .edu-badge__title em {
  background: linear-gradient(90deg, oklch(82% 0.14 75), oklch(95% 0.06 75));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.edu-badge__desc {
  margin: 0;
  font-size: 0.98rem;
  color: var(--ink-soft);
  line-height: 1.6;
  max-width: 60ch;
}

.edu-badge__stars {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}
.edu-badge__star {
  font-size: 2.2rem;
  color: var(--line-strong);
  line-height: 1;
  transition: color var(--t-fast), transform var(--t-fast) var(--ease);
}
.edu-badge__star.is-on {
  color: oklch(82% 0.14 75);
  transform: translateY(-1px);
  text-shadow: 0 0 18px color-mix(in oklab, oklch(82% 0.14 75) 50%, transparent);
}
@media (max-width: 599.98px) {
  .edu-badge { grid-template-columns: 1fr; }
  .edu-badge__star { font-size: 1.8rem; }
}

/* KPI ----------------------------------------------------------- */
.edu-kpi {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 18px;
}
@media (min-width: 760px) {
  .edu-kpi { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
.edu-kpi__card {
  padding: 18px 20px;
  background: oklch(18% 0.014 285 / 0.5);
  border: 1px solid var(--line);
  border-radius: var(--r);
}
.edu-kpi__card--accent {
  background:
    radial-gradient(70% 100% at 0% 0%, oklch(72% 0.2 285 / 0.16), transparent 60%),
    oklch(18% 0.014 285 / 0.7);
  border-color: color-mix(in oklab, var(--brand-soft) 35%, var(--line));
  grid-column: span 2;
}
@media (min-width: 760px) {
  .edu-kpi__card--accent { grid-column: span 1; }
}
.edu-kpi__num {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 2.6rem);
  color: var(--ink);
  margin: 6px 0 8px;
  letter-spacing: -0.02em;
  line-height: 1;
}
.edu-kpi__num-sub {
  font-family: var(--font-mono);
  font-size: 0.45em;
  color: var(--ink-mute);
  margin-left: 4px;
}
.edu-kpi__bar {
  position: relative;
  height: 6px;
  background: oklch(20% 0.018 285 / 0.6);
  border-radius: 999px;
  overflow: hidden;
  margin: 4px 0 0;
}
.edu-kpi__bar-fill {
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--p, 0%);
  background: linear-gradient(90deg, var(--brand-soft), var(--mint));
  border-radius: inherit;
  transition: width 320ms var(--ease);
}

/* Strong vs Weak ----------------------------------------------- */
.edu-strengths {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-bottom: 18px;
}
@media (min-width: 760px) {
  .edu-strengths { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
.edu-card-strong {
  padding: 22px 22px 18px;
  background: oklch(18% 0.014 285 / 0.5);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
}
.edu-card-strong--ok {
  background:
    radial-gradient(70% 100% at 0% 0%, oklch(82% 0.14 165 / 0.16), transparent 65%),
    oklch(18% 0.014 285 / 0.6);
  border-color: color-mix(in oklab, var(--mint) 40%, var(--line));
}
.edu-card-strong--warn {
  background:
    radial-gradient(70% 100% at 0% 0%, oklch(82% 0.14 75 / 0.16), transparent 65%),
    oklch(18% 0.014 285 / 0.6);
  border-color: color-mix(in oklab, oklch(82% 0.14 75) 45%, var(--line));
}
.edu-card-strong__kicker {
  font-size: 0.66rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 6px;
}
.edu-card-strong--ok .edu-card-strong__kicker { color: var(--mint); }
.edu-card-strong--warn .edu-card-strong__kicker { color: oklch(82% 0.14 75); }
.edu-card-strong__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(1.3rem, 2.6vw, 1.7rem);
  margin: 0 0 8px;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.edu-card-strong__num {
  font-size: 0.92rem;
  color: var(--ink-soft);
  margin: 0 0 14px;
  letter-spacing: 0.04em;
}

/* Ultimi quiz -------------------------------------------------- */
.edu-recent {
  padding: 22px 22px 18px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  margin-bottom: 18px;
}
.edu-recent__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 12px;
}
.edu-recent__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 6px;
}
.edu-recent__row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 14px;
  align-items: center;
  padding: 12px 14px;
  background: oklch(18% 0.014 285 / 0.5);
  border: 1px solid var(--line);
  border-radius: var(--r);
}
.edu-recent__id {
  display: grid;
  grid-template-columns: 12px 1fr;
  gap: 10px;
  row-gap: 2px;
  align-items: center;
  min-width: 0;
}
.edu-recent__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--row-color, var(--brand-soft));
  grid-row: 1 / span 2;
}
.edu-recent__title {
  margin: 0;
  font-size: 0.96rem;
  color: var(--ink);
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.edu-recent__when {
  margin: 0;
  font-size: 0.66rem;
  letter-spacing: 0.06em;
  color: var(--ink-mute);
}
.edu-recent__score {
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 600;
}
.edu-recent__score--ok {
  background: color-mix(in oklab, var(--mint) 18%, transparent);
  color: var(--mint);
}
.edu-recent__score--mid {
  background: color-mix(in oklab, oklch(82% 0.14 75) 18%, transparent);
  color: oklch(82% 0.14 75);
}
.edu-recent__score--low {
  background: color-mix(in oklab, oklch(75% 0.16 25) 18%, transparent);
  color: oklch(75% 0.16 25);
}
.edu-recent__cta {
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  color: var(--brand-soft);
  text-decoration: none;
  white-space: nowrap;
}
.edu-recent__cta:hover { color: var(--ink); }

@media (max-width: 599.98px) {
  .edu-recent__cta { display: none; }
}

/* Tabella per topic --------------------------------------------- */
.edu-table {
  padding: 22px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
}
.edu-table__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 12px;
}
.edu-table__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 4px;
}
.edu-table__row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 14px;
  align-items: center;
  padding: 12px 14px;
  border-bottom: 1px dashed var(--line);
}
.edu-table__row:last-child { border-bottom: 0; }
.edu-table__id {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.edu-table__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--row-color, var(--brand-soft));
  flex-shrink: 0;
}
.edu-table__title {
  color: var(--ink);
  text-decoration: none;
  font-size: 0.95rem;
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.edu-table__title:hover { color: var(--brand-soft); }
.edu-table__tag {
  font-size: 0.58rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 3px 7px;
  background: var(--brand-soft);
  color: oklch(12% 0.01 280);
  border-radius: 999px;
  font-weight: 700;
}

.edu-table__steps {
  display: flex;
  gap: 4px;
}
.edu-table__step {
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line-strong);
  border-radius: 6px;
  font-family: var(--font-mono);
  font-size: 0.62rem;
  color: var(--ink-mute);
}
.edu-table__step.is-done {
  background: color-mix(in oklab, var(--mint) 18%, transparent);
  border-color: var(--mint);
  color: var(--mint);
}
.edu-table__score {
  font-size: 0.85rem;
  color: var(--ink);
  min-width: 40px;
  text-align: right;
}

/* =================================================================
   Budget condivisi (Premium) — /budget-condiviso.
   ================================================================= */
.page--sb,
.page--sb-show,
.page--sb-new,
.page--sb-accept { padding-bottom: 96px; padding-top: 96px; }

/* Lista budget ---------------------------------------------------- */
.sb-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr;
}
@media (min-width: 720px) {
  .sb-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1020px) {
  .sb-list { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

.sb-card {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  transition: border-color var(--t-fast), transform var(--t-fast) var(--ease);
}
.sb-card:hover { border-color: color-mix(in oklab, var(--brand-soft) 40%, var(--line)); transform: translateY(-2px); }
.sb-card__link {
  display: block;
  padding: 22px;
  color: inherit;
  text-decoration: none;
}
.sb-card__top {
  display: flex;
  justify-content: space-between;
  font-size: 0.66rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 12px;
}
.sb-card__role { color: var(--brand-soft); }
.sb-card__name {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(1.4rem, 2.6vw, 1.7rem);
  margin: 0 0 10px;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.sb-card__total {
  margin: 0;
  font-size: 0.92rem;
  color: var(--ink-soft);
}
.sb-card__total strong { color: var(--ink); font-weight: 600; }
.sb-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 16px;
  padding-top: 12px;
  border-top: 1px dashed var(--line);
  font-size: 0.78rem;
  color: var(--brand-soft);
  letter-spacing: 0.04em;
  font-weight: 500;
}

/* Show page — KPI ------------------------------------------------- */
.sb-kpi {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-bottom: 18px;
}
@media (min-width: 720px) {
  .sb-kpi { grid-template-columns: 2fr 1fr; }
}
.sb-kpi__card {
  padding: 22px;
  background: oklch(18% 0.014 285 / 0.5);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
}
.sb-kpi__card--main {
  background:
    radial-gradient(70% 100% at 0% 0%, oklch(72% 0.2 285 / 0.16), transparent 60%),
    oklch(18% 0.014 285 / 0.6);
  border-color: color-mix(in oklab, var(--brand-soft) 35%, var(--line));
}
.sb-kpi__num {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4.2vw, 2.8rem);
  margin: 6px 0 6px;
  color: var(--ink);
  letter-spacing: -0.02em;
  line-height: 1;
}
.sb-kpi__num .mono {
  font-family: var(--font-mono);
  font-size: 0.45em;
  color: var(--ink-mute);
  margin-right: 4px;
}
.sb-kpi__sub {
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  color: var(--ink-mute);
  margin: 0;
  text-transform: uppercase;
}

/* Saldi membri ---------------------------------------------------- */
.sb-balances {
  padding: 22px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  margin-bottom: 18px;
}
.sb-balances__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 12px;
}
.sb-balances__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 8px;
}
.sb-balance {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 16px;
  align-items: center;
  padding: 14px 16px;
  background: oklch(18% 0.014 285 / 0.5);
  border: 1px solid var(--line);
  border-left: 3px solid var(--line-strong);
  border-radius: var(--r);
}
.sb-balance--pos { border-left-color: var(--mint); }
.sb-balance--neg { border-left-color: oklch(75% 0.16 25); }
.sb-balance--zero { border-left-color: var(--ink-mute); }

.sb-balance__id { display: flex; align-items: center; gap: 12px; min-width: 0; }
.sb-balance__avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: oklch(20% 0.018 285 / 0.7);
  border: 1px solid var(--line-strong);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
}
.sb-balance__avatar img { width: 100%; height: 100%; object-fit: cover; }
.sb-balance__avatar-letter { font-size: 0.95rem; color: var(--ink); font-weight: 600; }
.sb-balance__name {
  margin: 0;
  font-size: 0.96rem;
  color: var(--ink);
  font-weight: 500;
}
.sb-balance__me {
  font-size: 0.66rem;
  letter-spacing: 0.1em;
  color: var(--brand-soft);
  text-transform: lowercase;
}
.sb-balance__role {
  margin: 2px 0 0;
  font-size: 0.66rem;
  letter-spacing: 0.14em;
  color: var(--ink-mute);
  text-transform: uppercase;
}
.sb-balance__nums { text-align: right; }
.sb-balance__paid {
  margin: 0 0 4px;
  font-size: 0.72rem;
  color: var(--ink-mute);
  letter-spacing: 0.06em;
}
.sb-balance__paid strong { color: var(--ink); font-weight: 600; }
.sb-balance__bal {
  margin: 0;
  font-size: 0.85rem;
  color: var(--ink);
}
.sb-balance__bal .mono {
  font-size: 0.66rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-right: 4px;
}
.sb-balance--pos .sb-balance__bal strong { color: var(--mint); }
.sb-balance--neg .sb-balance__bal strong { color: oklch(75% 0.16 25); }

/* Settle ---------------------------------------------------------- */
.sb-settle {
  padding: 22px;
  background:
    radial-gradient(70% 100% at 0% 0%, oklch(82% 0.14 165 / 0.12), transparent 60%),
    var(--bg-elev);
  border: 1px solid color-mix(in oklab, var(--mint) 30%, var(--line));
  border-radius: var(--r-lg);
  margin-bottom: 18px;
}
.sb-settle__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mint);
  margin: 0 0 6px;
}
.sb-settle__lede {
  font-size: 0.92rem;
  color: var(--ink-soft);
  margin: 0 0 14px;
}
.sb-settle__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 8px;
}
.sb-settle__row {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 14px 16px;
  background: oklch(18% 0.014 285 / 0.5);
  border: 1px solid var(--line);
  border-radius: var(--r);
}
.sb-settle__from { color: oklch(75% 0.16 25); font-weight: 500; }
.sb-settle__to { color: var(--mint); font-weight: 500; }
.sb-settle__arrow { color: var(--ink-mute); font-family: var(--font-mono); }
.sb-settle__amount {
  font-size: 0.95rem;
  color: var(--ink);
  font-weight: 600;
}
@media (max-width: 599.98px) {
  .sb-settle__row {
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "from amount"
      "arrow amount"
      "to amount";
    gap: 4px 12px;
  }
  .sb-settle__from { grid-area: from; }
  .sb-settle__arrow { grid-area: arrow; }
  .sb-settle__to { grid-area: to; }
  .sb-settle__amount { grid-area: amount; align-self: center; }
}

/* Add expense ----------------------------------------------------- */
.sb-add {
  padding: 22px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  margin-bottom: 18px;
}
.sb-add__form { display: grid; gap: 12px; }

/* History --------------------------------------------------------- */
.sb-history {
  padding: 22px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  margin-bottom: 18px;
}
.sb-history__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 12px;
}
.sb-history__empty {
  font-size: 0.92rem;
  color: var(--ink-mute);
  margin: 0;
}
.sb-history__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 4px;
}
.sb-tx {
  display: grid;
  grid-template-columns: 56px 1fr auto auto;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border-bottom: 1px dashed var(--line);
}
.sb-tx:last-child { border-bottom: 0; }
.sb-tx__date {
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.sb-tx__main { min-width: 0; }
.sb-tx__desc {
  margin: 0;
  font-size: 0.96rem;
  color: var(--ink);
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sb-tx__by {
  margin: 2px 0 0;
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  color: var(--ink-mute);
}
.sb-tx__by strong { color: var(--ink-soft); font-weight: 500; }
.sb-tx__amount {
  font-size: 0.95rem;
  color: var(--ink);
  font-weight: 600;
  white-space: nowrap;
}
.sb-tx__del { margin: 0; }
.sb-tx__del-btn {
  background: transparent;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--ink-mute);
  width: 28px;
  height: 28px;
  font-size: 1rem;
  cursor: pointer;
  transition: color var(--t-fast), border-color var(--t-fast);
}
.sb-tx__del-btn:hover { color: oklch(75% 0.16 25); border-color: oklch(75% 0.16 25); }

/* Members + Inviti ----------------------------------------------- */
.sb-members {
  padding: 22px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  margin-bottom: 18px;
}
.sb-members__list {
  list-style: none;
  padding: 0;
  margin: 0 0 16px;
  display: grid;
  gap: 6px;
}
.sb-member {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 14px;
  background: oklch(18% 0.014 285 / 0.5);
  border: 1px solid var(--line);
  border-radius: var(--r);
}
.sb-member__role {
  font-size: 0.66rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

.sb-invite { margin-top: 12px; }
.sb-invite summary { cursor: pointer; }
.sb-invite__form {
  margin-top: 14px;
  display: grid;
  gap: 12px;
  padding: 16px;
  background: oklch(18% 0.014 285 / 0.5);
  border: 1px solid var(--line);
  border-radius: var(--r);
}
.sb-invite__locked {
  margin: 12px 0 0;
  font-size: 0.92rem;
  color: var(--ink-soft);
}

.sb-invite-pending {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px dashed var(--line);
}
.sb-invite-pending__kicker {
  font-size: 0.66rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 8px;
}
.sb-invite-pending__list { list-style: none; padding: 0; margin: 0; display: grid; gap: 4px; }
.sb-invite-pending__row {
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 8px 12px;
  background: oklch(18% 0.014 285 / 0.5);
  border: 1px solid var(--line);
  border-radius: var(--r);
}
.sb-invite-pending__email { color: var(--ink); font-size: 0.85rem; margin: 0; }
.sb-invite-pending__link {
  font-size: 0.7rem;
  color: var(--brand-soft);
  margin: 0;
  letter-spacing: 0.04em;
}
.sb-invite-pending__cancel {
  background: transparent;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--ink-mute);
  width: 28px; height: 28px;
  font-size: 1rem;
  cursor: pointer;
}
.sb-invite-pending__cancel:hover { color: oklch(75% 0.16 25); border-color: oklch(75% 0.16 25); }

/* Azioni budget --------------------------------------------------- */
.sb-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding-top: 18px;
  border-top: 1px dashed var(--line);
  margin-top: 18px;
}
.sb-rename__form {
  margin-top: 14px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

/* Form pagina nuova / accept ------------------------------------- */
.sb-form { display: grid; gap: 16px; }
.sb-form--accept { margin-top: 24px; }
.sb-accept-login { margin-top: 24px; }
.sb-accept-login p { margin: 0 0 14px; color: var(--ink-soft); font-size: 0.95rem; }
.edu-card__cta {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding-top: 10px;
  border-top: 1px dashed var(--line);
  color: var(--ink);
  font-weight: 500;
  font-size: 0.92rem;
}
.edu-card:hover .edu-card__cta { gap: 10px; }

.edu-disclaimer {
  margin: 36px 0 0;
  padding: 14px 16px;
  background: oklch(16% 0.014 275 / 0.4);
  border: 1px solid var(--line);
  border-radius: var(--r);
  font-size: 0.78rem;
  color: var(--ink-mute);
  letter-spacing: 0.02em;
  line-height: 1.6;
}

/* ---------- Pagina argomento (show) ---------- */
.back-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 18px;
  font-size: 0.86rem;
  color: var(--ink-mute);
  transition: color var(--t-fast), gap var(--t-fast);
}
.back-link:hover { color: var(--ink); gap: 10px; }

.edu-show__hero { margin: 0 0 36px; max-width: 60ch; }
.edu-show__hero .display { margin: 12px 0 10px; }
.edu-show__title {
  border-bottom: 2px solid var(--edu-color, var(--brand-soft));
  padding-bottom: 12px;
  display: inline-block;
}
.edu-show__subtitle {
  color: var(--ink-soft);
  font-size: 1.02rem;
  line-height: 1.6;
  margin: 4px 0 22px;
}
.edu-show__steps {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.edu-show__step a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px 6px 8px;
  border-radius: 999px;
  background: oklch(16% 0.014 275 / 0.5);
  border: 1px solid var(--line);
  color: var(--ink-soft);
  font-size: 0.82rem;
  transition: border-color var(--t-fast), color var(--t-fast), background var(--t-fast);
}
.edu-show__step a:hover { color: var(--ink); border-color: var(--line-strong); }
.edu-show__step .mono {
  display: grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--bg);
  border: 1px solid var(--line);
  font-size: 0.72rem;
  color: var(--ink-mute);
}
.edu-show__step.is-done a {
  background: color-mix(in oklab, var(--mint) 12%, transparent);
  border-color: color-mix(in oklab, var(--mint) 45%, var(--line));
  color: var(--ink);
}
.edu-show__step.is-done .mono {
  background: var(--mint-strong);
  border-color: var(--mint-strong);
  color: oklch(14% 0.02 175);
}

/* Step attualmente selezionato — riconoscibile a colpo d'occhio nella nav. */
.edu-show__step.is-current a {
  background: color-mix(in oklab, var(--brand-soft) 18%, transparent);
  border-color: var(--brand-soft);
  color: var(--ink);
  font-weight: 600;
}
.edu-show__step.is-current .mono {
  background: var(--brand-soft);
  border-color: var(--brand-soft);
  color: oklch(14% 0.02 280);
}
/* Quando lo step è sia done che current, "current" prevale sui colori. */
.edu-show__step.is-done.is-current a {
  background: color-mix(in oklab, var(--brand-soft) 18%, transparent);
  border-color: var(--brand-soft);
}

/* ---------- Sezioni (lettura / flash / quiz) ---------- */
.edu-section {
  scroll-margin-top: 120px;
  padding: 28px 24px;
  margin: 0 0 24px;
  background: var(--bg-elev);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-card);
}
@media (min-width: 760px) {
  .edu-section { padding: 36px 36px; margin-bottom: 32px; }
}
.edu-section__kicker {
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--edu-color, var(--brand-soft));
  margin: 0 0 8px;
}
.edu-section__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin: 0 0 6px;
}
.edu-section__lede {
  margin: 0 0 22px;
  color: var(--ink-soft);
  font-size: 1rem;
  line-height: 1.55;
}
.edu-section__action {
  margin: 28px 0 0;
  display: flex;
  justify-content: flex-end;
}
.edu-section__action .btn { width: 100%; justify-content: center; }
@media (min-width: 540px) { .edu-section__action .btn { width: auto; } }

/* ---------- Articolo lettura (typography editoriale) ---------- */
.edu-article {
  max-width: 64ch;
  color: var(--ink-soft);
  font-size: 1.02rem;
  line-height: 1.75;
}
.edu-article h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.3rem, 2.4vw, 1.7rem);
  color: var(--ink);
  margin: 32px 0 12px;
  letter-spacing: -0.015em;
}
.edu-article h2:first-of-type { margin-top: 12px; }
.edu-article p { margin: 0 0 14px; }
.edu-article ul {
  margin: 0 0 16px;
  padding: 0 0 0 22px;
  list-style: disc;
}
.edu-article li { margin-bottom: 8px; line-height: 1.65; }
.edu-article strong { color: var(--ink); font-weight: 600; }
.edu-article em {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--edu-color, var(--brand-soft));
}

/* ---------- Flash cards grid + flip ---------- */
.flash-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-bottom: 4px;
}
@media (min-width: 640px) { .flash-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .flash-grid { grid-template-columns: repeat(3, 1fr); } }

.flash-card {
  appearance: none;
  display: block;
  width: 100%;
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
  perspective: 1200px;
  min-height: 180px;
  text-align: left;
  font-family: inherit;
  color: inherit;
}
.flash-card__inner {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  min-height: 180px;
  transition: transform 600ms var(--ease);
  transform-style: preserve-3d;
}
.flash-card.is-flipped .flash-card__inner { transform: rotateY(180deg); }
.flash-card__face {
  position: absolute;
  inset: 0;
  padding: 18px 18px 16px;
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 10px;
  background: var(--bg);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-lg);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}
.flash-card__face--front {
  border-top: 3px solid var(--edu-color, var(--brand-soft));
}
.flash-card__face--back {
  transform: rotateY(180deg);
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--edu-color, var(--brand-soft)) 16%, transparent), transparent 70%),
    var(--bg-elev);
  border-color: color-mix(in oklab, var(--edu-color, var(--brand-soft)) 38%, var(--line-strong));
}
.flash-card__num {
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  color: var(--ink-mute);
  text-transform: uppercase;
}
.flash-card__text {
  font-size: 1.02rem;
  line-height: 1.5;
  color: var(--ink);
  align-self: center;
}
.flash-card__face--back .flash-card__text { color: var(--ink); }
.flash-card__hint {
  font-size: 0.7rem;
  letter-spacing: 0.06em;
  color: var(--ink-mute);
}
.flash-card:focus-visible .flash-card__face {
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--edu-color, var(--brand-soft)) 50%, transparent);
}
@media (prefers-reduced-motion: reduce) {
  .flash-card__inner { transition: none; }
}

/* ---------- Quiz ---------- */
.quiz-form { display: grid; gap: 20px; }
.quiz-q {
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 18px 18px 14px;
  margin: 0;
  background: var(--bg);
}
.quiz-q__legend {
  font-family: var(--font-display);
  font-size: 1.15rem;
  color: var(--ink);
  margin: 0 0 14px;
  padding: 0;
  display: flex;
  gap: 10px;
  align-items: baseline;
  line-height: 1.3;
}
.quiz-q__legend .mono {
  font-size: 0.74rem;
  letter-spacing: 0.12em;
  color: var(--edu-color, var(--brand-soft));
  text-transform: uppercase;
}
.quiz-q__options { display: grid; gap: 8px; }

.quiz-opt {
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  background: oklch(16% 0.014 275 / 0.4);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  cursor: pointer;
  transition: border-color var(--t-fast), background var(--t-fast);
}
.quiz-opt input {
  appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 1.5px solid var(--ink-mute);
  margin: 0;
  position: relative;
  background: transparent;
  cursor: pointer;
  transition: border-color var(--t-fast);
}
.quiz-opt input:checked {
  border-color: var(--edu-color, var(--brand-soft));
  background: radial-gradient(circle at center, var(--edu-color, var(--brand-soft)) 0 38%, transparent 42%);
}
.quiz-opt:has(input:checked) {
  border-color: color-mix(in oklab, var(--edu-color, var(--brand-soft)) 60%, var(--line-strong));
  background: color-mix(in oklab, var(--edu-color, var(--brand-soft)) 8%, transparent);
}
.quiz-opt__mark { display: none; }
.quiz-opt__text { font-size: 0.96rem; color: var(--ink); line-height: 1.5; }

/* ---------- Esito quiz ---------- */
.quiz-result {
  display: grid;
  gap: 18px;
  padding: 20px;
  background: var(--bg);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-lg);
  scroll-margin-top: 120px;
}
.quiz-result--ok  { border-color: color-mix(in oklab, var(--mint) 55%, var(--line-strong)); }
.quiz-result--mid { border-color: color-mix(in oklab, var(--warn) 55%, var(--line-strong)); }
.quiz-result--low { border-color: color-mix(in oklab, var(--danger) 55%, var(--line-strong)); }

.quiz-result__score {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 3.5vw, 2.2rem);
  margin: 0;
  color: var(--ink);
  display: flex;
  align-items: baseline;
  gap: 10px;
}
.quiz-result__score .mono {
  font-family: var(--font-mono);
  font-size: 1.8em;
  font-weight: 400;
}
.quiz-result--ok  .quiz-result__score .mono { color: var(--mint-strong); }
.quiz-result--mid .quiz-result__score .mono { color: var(--warn); }
.quiz-result--low .quiz-result__score .mono { color: var(--danger); }
.quiz-result__label { margin: 0; color: var(--ink-soft); font-size: 1rem; }
.quiz-result__retry {
  justify-self: start;
}

.quiz-review {
  list-style: none;
  margin: 4px 0 0;
  padding: 0;
  display: grid;
  gap: 14px;
}
.quiz-review__item {
  padding: 14px 16px;
  background: oklch(16% 0.014 275 / 0.4);
  border-left: 3px solid var(--line);
  border-radius: var(--r-sm);
}
.quiz-review__item.is-correct { border-left-color: var(--mint-strong); }
.quiz-review__item.is-wrong   { border-left-color: var(--danger); }
.quiz-review__q { margin: 0 0 10px; font-size: 0.96rem; color: var(--ink); line-height: 1.45; }
.quiz-review__q .mono {
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-right: 6px;
}
.quiz-review__options { list-style: none; margin: 0 0 8px; padding: 0; display: grid; gap: 4px; }
.quiz-review__opt {
  padding: 7px 12px;
  border-radius: var(--r-sm);
  font-size: 0.9rem;
  color: var(--ink-soft);
  display: flex;
  align-items: center;
  gap: 10px;
  background: transparent;
}
.quiz-review__opt .mono {
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.quiz-review__opt.is-right {
  color: var(--ink);
  background: color-mix(in oklab, var(--mint) 14%, transparent);
}
.quiz-review__opt.is-right .mono { color: var(--mint-strong); }
.quiz-review__opt.is-picked-wrong {
  color: var(--ink);
  background: color-mix(in oklab, var(--danger) 14%, transparent);
}
.quiz-review__opt.is-picked-wrong .mono { color: var(--danger); }
.quiz-review__exp {
  margin: 6px 0 0;
  padding-top: 8px;
  border-top: 1px dashed var(--line);
  font-size: 0.86rem;
  color: var(--ink-mute);
  line-height: 1.5;
}

/* ============================================================
   PWA — Banner "Installa l'app" + guida /installa
   ------------------------------------------------------------
   Il banner viene iniettato via /js/install-prompt.js solo se:
   - non sei in standalone (gia' installata)
   - hai aperto Talenis >= 3 volte
   - non hai dismissato di recente.
   Si ancora in basso, sopra la bottom-nav su mobile.
   ============================================================ */

.install-banner {
  position: fixed;
  left: 12px;
  right: 12px;
  bottom: calc(12px + env(safe-area-inset-bottom));
  z-index: 120;
  pointer-events: none;
  display: flex;
  justify-content: center;
  opacity: 0;
  transform: translateY(24px);
  transition: opacity var(--t) var(--ease), transform var(--t) var(--ease);
}
.install-banner.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.has-bottom-nav .install-banner {
  /* Sale sopra la pill flottante della bottom-nav (~60px + margine). */
  bottom: calc(88px + env(safe-area-inset-bottom));
}
@media (min-width: 760px) {
  .has-bottom-nav .install-banner { bottom: calc(20px + env(safe-area-inset-bottom)); }
  .install-banner {
    left: auto;
    right: 20px;
    bottom: 20px;
    max-width: 420px;
  }
}

.install-banner__inner {
  pointer-events: auto;
  width: 100%;
  max-width: 520px;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  padding: 14px 14px 14px 12px;
  background: color-mix(in oklab, var(--bg-elev) 92%, transparent);
  backdrop-filter: blur(22px) saturate(140%);
  -webkit-backdrop-filter: blur(22px) saturate(140%);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-lg);
  box-shadow:
    0 24px 60px -22px rgb(0 0 0 / 0.7),
    inset 0 1px 0 0 rgb(255 255 255 / 0.04);
}
.install-banner__icon {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--brand-soft), var(--mint));
  color: oklch(12% 0.01 280);
  align-self: start;
}
.install-banner__body { min-width: 0; }
.install-banner__title {
  margin: 0;
  font-weight: 600;
  font-size: 0.96rem;
  color: var(--ink);
  line-height: 1.2;
}
.install-banner__sub {
  margin: 4px 0 12px;
  color: var(--ink-soft);
  font-size: 0.82rem;
  line-height: 1.5;
}
.install-banner__actions {
  grid-column: 1 / -1;
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  flex-wrap: wrap;
}
.install-banner__btn {
  appearance: none;
  border: 1px solid transparent;
  border-radius: var(--r-pill);
  padding: 8px 16px;
  font-family: inherit;
  font-size: 0.84rem;
  font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: background var(--t-fast), border-color var(--t-fast), color var(--t-fast);
}
.install-banner__btn--ghost {
  background: transparent;
  color: var(--ink-mute);
  border-color: var(--line);
}
.install-banner__btn--ghost:hover {
  color: var(--ink);
  border-color: var(--line-strong);
}
.install-banner__btn--primary {
  background: var(--ink);
  color: oklch(10% 0.01 280);
  border-color: var(--ink);
}
.install-banner__btn--primary:hover {
  background: #fff;
  border-color: #fff;
}

/* ============================================================
   PAGINA /installa — guida iOS / Android / Desktop
   ============================================================ */

.page--install {
  padding: 116px 0 96px;
  position: relative;
  isolation: isolate;
}
@media (min-width: 760px) {
  .page--install { padding-top: 140px; }
}
.page--install::before {
  content: '';
  position: absolute;
  inset: -10% -10% 70% -10%;
  z-index: -1;
  background:
    radial-gradient(50% 60% at 30% 10%, oklch(70% 0.2 285 / 0.16), transparent 70%),
    radial-gradient(40% 50% at 80% 0%, oklch(82% 0.14 165 / 0.10), transparent 72%);
  filter: blur(60px);
  pointer-events: none;
}

.install-hero {
  max-width: 62ch;
  margin: 0 0 28px;
}
.install-hero .display { margin: 14px 0 12px; }
.install-hero__lede {
  margin: 0;
  color: var(--ink-soft);
  font-size: 1.05rem;
  line-height: 1.65;
}

/* ---------- Tabs OS ---------- */
.install-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 6px;
  margin: 0 0 22px;
  background: oklch(16% 0.014 275 / 0.6);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-pill);
  width: fit-content;
  max-width: 100%;
  overflow-x: auto;
}
.install-tab {
  appearance: none;
  border: 0;
  background: transparent;
  padding: 10px 18px;
  border-radius: var(--r-pill);
  font-family: inherit;
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--ink-mute);
  cursor: pointer;
  transition: background var(--t-fast), color var(--t-fast);
  white-space: nowrap;
}
.install-tab:hover { color: var(--ink-soft); }
.install-tab.is-active {
  background: var(--bg);
  color: var(--ink);
  box-shadow: 0 1px 0 0 var(--line-strong), 0 6px 18px -10px rgb(0 0 0 / 0.6);
}

/* ---------- Pannelli (steps) ---------- */
.install-panel {
  background: var(--bg-elev);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  padding: 24px;
  box-shadow: var(--shadow-card);
}
@media (min-width: 760px) { .install-panel { padding: 36px 36px 30px; } }

.install-steps {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 22px;
}
.install-step {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 14px;
  align-items: start;
  position: relative;
}
.install-step + .install-step::before {
  content: '';
  position: absolute;
  left: 21px;
  top: -22px;
  height: 22px;
  width: 2px;
  background: linear-gradient(180deg, transparent, var(--line-strong));
}
.install-step__num {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--bg);
  border: 1px solid var(--line-strong);
  font-size: 0.84rem;
  letter-spacing: 0.06em;
  color: var(--ink);
  font-weight: 500;
}
.install-step__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.25rem;
  letter-spacing: -0.01em;
  line-height: 1.25;
  margin: 4px 0 6px;
  color: var(--ink);
}
.install-step__title strong { color: var(--mint-strong); font-weight: 400; font-style: italic; }
.install-step__body p {
  margin: 0;
  color: var(--ink-soft);
  font-size: 0.96rem;
  line-height: 1.6;
}
.install-step__chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 10px;
  padding: 6px 14px;
  background: oklch(16% 0.014 275 / 0.7);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  font-family: var(--font-mono);
  font-size: 0.82rem;
  color: var(--ink);
}

/* ---------- FAQ ---------- */
.install-faq {
  margin: 30px 0 0;
  display: grid;
  gap: 8px;
  max-width: 64ch;
}
.install-faq__item {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 14px 16px;
  transition: border-color var(--t-fast);
}
.install-faq__item[open] { border-color: var(--line-strong); }
.install-faq__item summary {
  cursor: pointer;
  font-weight: 500;
  color: var(--ink);
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}
.install-faq__item summary::-webkit-details-marker { display: none; }
.install-faq__item summary::after {
  content: '+';
  font-family: var(--font-mono);
  color: var(--ink-mute);
  transition: transform var(--t-fast), color var(--t-fast);
}
.install-faq__item[open] summary::after {
  content: '−';
  color: var(--brand-soft);
}
.install-faq__item p {
  margin: 10px 0 0;
  color: var(--ink-soft);
  font-size: 0.92rem;
  line-height: 1.6;
}
.install-faq__item em { color: var(--ink); font-style: italic; font-family: var(--font-display); }

/* ============================================================
   Profilo · Sicurezza (2FA, cambia password, cambia email)
   ============================================================ */

.badge-verified {
  display: inline-block;
  margin-left: 8px;
  padding: 2px 8px;
  font-family: var(--font-mono);
  font-size: 0.66rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--mint-strong);
  background: color-mix(in oklab, var(--mint) 14%, transparent);
  border: 1px solid color-mix(in oklab, var(--mint) 40%, var(--line));
  border-radius: var(--r-pill);
  vertical-align: middle;
}

.profile-sec {
  padding: 24px;
  margin-bottom: 18px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
}
@media (min-width: 760px) {
  .profile-sec { padding: 32px; }
}

.profile-sec__row {
  display: grid;
  gap: 16px;
  padding: 22px 0;
  border-top: 1px dashed var(--line);
}
.profile-sec__row:first-of-type { border-top: 0; padding-top: 14px; }
@media (min-width: 760px) {
  .profile-sec__row {
    grid-template-columns: 1fr minmax(260px, 1fr);
    gap: 28px;
    align-items: start;
  }
}

.profile-sec__row-head { min-width: 0; }
.profile-sec__row-title {
  margin: 0 0 6px;
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 400;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.profile-sec__row-desc {
  margin: 0;
  color: var(--ink-mute);
  font-size: 0.92rem;
  line-height: 1.6;
}
.profile-sec__row-desc a {
  color: var(--brand-soft);
  border-bottom: 1px solid var(--line-strong);
}
.profile-sec__row-desc a:hover { color: var(--ink); border-color: var(--ink); }

.profile-sec__form {
  display: grid;
  gap: 16px;
  align-content: start;
}

.profile-sec__toggle-form {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

/* ---------- Toggle switch ---------- */
.toggle-switch {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 8px 14px 8px 8px;
  background: oklch(16% 0.014 275 / 0.7);
  border: 1px solid var(--line);
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: border-color var(--t-fast), background var(--t-fast);
}
.toggle-switch:hover { border-color: var(--line-strong); }

.toggle-switch__track {
  position: relative;
  display: inline-block;
  width: 44px;
  height: 26px;
  background: oklch(22% 0.012 275);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-pill);
  transition: background var(--t-fast), border-color var(--t-fast);
}
.toggle-switch__thumb {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 20px;
  height: 20px;
  background: var(--ink);
  border-radius: 50%;
  box-shadow: 0 2px 4px rgb(0 0 0 / 0.3);
  transition: transform var(--t) var(--ease), background var(--t-fast);
}
.toggle-switch__label {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-mute);
  user-select: none;
}
.toggle-switch[data-state='on'] .toggle-switch__track {
  background: color-mix(in oklab, var(--brand) 70%, transparent);
  border-color: var(--brand);
}
.toggle-switch[data-state='on'] .toggle-switch__thumb {
  transform: translateX(18px);
  background: #fff;
}
.toggle-switch[data-state='on'] .toggle-switch__label {
  color: var(--brand-soft);
}

/* Bottone invisibile sopra l'intero switch: invia il form al click. */
.toggle-switch__btn {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background: transparent;
  border: 0;
  border-radius: inherit;
  cursor: pointer;
  font: inherit;
  color: transparent;
}
.toggle-switch__btn:focus-visible {
  outline: 2px solid var(--brand-soft);
  outline-offset: 3px;
}

/* ---------- Banner cambio email in sospeso ---------- */
.profile-sec__pending {
  display: grid;
  gap: 16px;
  padding: 18px;
  margin-bottom: 8px;
  background: color-mix(in oklab, var(--warn) 10%, transparent);
  border: 1px solid color-mix(in oklab, var(--warn) 40%, var(--line));
  border-radius: var(--r-lg);
}
@media (min-width: 540px) {
  .profile-sec__pending {
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 18px;
  }
}
.profile-sec__pending-title {
  margin: 0 0 4px;
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 400;
  color: var(--ink);
}
.profile-sec__pending-text {
  margin: 0;
  color: var(--ink-soft);
  font-size: 0.92rem;
  line-height: 1.55;
}
.profile-sec__pending-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}
.profile-sec__pending-actions form { margin: 0; }

/* ============================================================
   Profilo · Accessi recenti
   ============================================================ */

.profile-logins {
  padding: 24px;
  margin-bottom: 18px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
}
@media (min-width: 760px) {
  .profile-logins { padding: 32px; }
}

.profile-logins__lede {
  margin: 0 0 18px;
  color: var(--ink-mute);
  font-size: 0.92rem;
  line-height: 1.6;
}

.profile-logins__list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.profile-logins__item {
  display: grid;
  gap: 6px;
  padding: 14px 0;
  border-top: 1px dashed var(--line);
}
.profile-logins__item:first-child { border-top: 0; padding-top: 0; }
@media (min-width: 540px) {
  .profile-logins__item {
    grid-template-columns: 1fr auto;
    align-items: baseline;
    gap: 18px;
  }
}

.profile-logins__main { min-width: 0; }
.profile-logins__device {
  margin: 0 0 2px;
  color: var(--ink);
  font-size: 0.98rem;
  line-height: 1.4;
}
.profile-logins__badge {
  display: inline-block;
  margin-left: 8px;
  padding: 2px 8px;
  font-family: var(--font-mono);
  font-size: 0.66rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--warn);
  background: color-mix(in oklab, var(--warn) 14%, transparent);
  border: 1px solid color-mix(in oklab, var(--warn) 40%, var(--line));
  border-radius: var(--r-pill);
  vertical-align: middle;
}
.profile-logins__meta {
  margin: 0;
  color: var(--ink-mute);
  font-size: 0.82rem;
}
.profile-logins__when {
  color: var(--ink-soft);
  font-size: 0.84rem;
  white-space: nowrap;
}

/* ============================================================
   ADMIN AREA — dashboard, lista utenti, verifica email
   Stile sobrio: dark obsidian + accenti danger/warn coerenti
   con il resto, niente fronzoli grafici tipo landing.
   ============================================================ */

.admin-page {
  padding-top: 110px;
  padding-bottom: 96px;
  min-height: 100vh;
}

.admin-page__head {
  margin-bottom: 36px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--line);
}
.admin-page__kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--danger);
  margin: 0 0 14px;
}
.admin-page__dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--danger);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--danger) 28%, transparent);
}
.admin-page__head-row {
  display: flex;
  flex-direction: column;
  gap: 18px;
  align-items: flex-start;
}
@media (min-width: 760px) {
  .admin-page__head-row {
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
  }
}
.admin-page__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2rem, 5vw, 3rem);
  letter-spacing: -0.025em;
  margin: 0;
  color: var(--ink);
  line-height: 1;
}
.admin-page__title em { font-style: italic; color: var(--brand-soft); }

.admin-page__nav {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-pill);
  padding: 6px;
}
.admin-page__nav-link {
  display: inline-flex;
  align-items: center;
  padding: 8px 14px;
  font-size: 0.84rem;
  font-weight: 500;
  color: var(--ink-soft);
  border-radius: var(--r-pill);
  transition: color var(--t-fast), background var(--t-fast);
  background: transparent;
  border: 0;
  font-family: inherit;
  cursor: pointer;
}
.admin-page__nav-link:hover { color: var(--ink); }
.admin-page__nav-link.is-active {
  background: var(--bg-elev-2);
  color: var(--ink);
}
.admin-page__nav-link--exit {
  color: var(--danger);
}
.admin-page__nav-link--exit:hover {
  background: color-mix(in oklab, var(--danger) 14%, var(--bg-elev));
  color: var(--ink);
}
.admin-page__logout-form { margin: 0; }

/* ----- Stats grid ----------------------------------------------- */
.admin-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-bottom: 40px;
}
@media (min-width: 760px) {
  .admin-stats { grid-template-columns: repeat(3, 1fr); gap: 16px; }
}
@media (min-width: 1080px) {
  .admin-stats { grid-template-columns: repeat(5, 1fr); }
}

.admin-stat {
  position: relative;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 18px 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: border-color var(--t-fast);
}
.admin-stat:hover { border-color: var(--line-strong); }
.admin-stat--accent {
  background:
    radial-gradient(70% 100% at 0% 0%, oklch(82% 0.14 165 / 0.10), transparent 70%),
    var(--bg-elev);
  border-color: color-mix(in oklab, var(--mint) 30%, var(--line-strong));
}
.admin-stat--danger {
  border-color: color-mix(in oklab, var(--danger) 35%, var(--line-strong));
  background:
    radial-gradient(70% 100% at 0% 0%, oklch(72% 0.2 25 / 0.08), transparent 70%),
    var(--bg-elev);
}
.admin-stat--muted { opacity: 0.85; }

.admin-stat__label {
  font-size: 0.66rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0;
}
.admin-stat__value {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 0;
  line-height: 1.05;
}
.admin-stat__sub {
  font-size: 0.78rem;
  color: var(--ink-mute);
  margin: 4px 0 0;
  line-height: 1.4;
}

/* ----- Card generica ------------------------------------------- */
.admin-card {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 24px 22px;
}
.admin-card__head {
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.admin-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.admin-card__sub { margin: 6px 0 0; font-size: 0.86rem; }
.admin-card__empty {
  margin: 0;
  color: var(--ink-mute);
  font-style: italic;
  padding: 20px 0;
  text-align: center;
}

/* ----- Tabella ------------------------------------------------- */
.admin-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--line);
  border-radius: var(--r);
  background: var(--bg-elev);
}
.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
}
.admin-table th,
.admin-table td {
  text-align: left;
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
  vertical-align: middle;
  color: var(--ink-soft);
  white-space: nowrap;
}
.admin-table thead th {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  background: var(--bg-elev-2);
  font-weight: 500;
  position: sticky;
  top: 0;
}
.admin-table tbody tr:hover { background: color-mix(in oklab, var(--bg-elev-2) 60%, transparent); }
.admin-table tbody tr.is-banned {
  background: color-mix(in oklab, var(--danger) 6%, transparent);
}
.admin-table__empty {
  text-align: center;
  font-style: italic;
  color: var(--ink-mute);
  padding: 24px 0;
}

.admin-row__actions { white-space: nowrap; }

/* ----- Pills di stato ------------------------------------------ */
.admin-pill {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  border: 1px solid var(--line-strong);
  background: var(--bg-elev-2);
  color: var(--ink-soft);
  white-space: nowrap;
}
.admin-pill--ok {
  background: color-mix(in oklab, var(--mint) 14%, var(--bg-elev-2));
  border-color: color-mix(in oklab, var(--mint) 50%, var(--line-strong));
  color: var(--mint);
}
.admin-pill--warn {
  background: color-mix(in oklab, var(--warn) 14%, var(--bg-elev-2));
  border-color: color-mix(in oklab, var(--warn) 50%, var(--line-strong));
  color: var(--warn);
}
.admin-pill--danger {
  background: color-mix(in oklab, var(--danger) 14%, var(--bg-elev-2));
  border-color: color-mix(in oklab, var(--danger) 50%, var(--line-strong));
  color: var(--danger);
}
.admin-pill--muted { color: var(--ink-mute); }

/* ----- Bottoni piccoli ----------------------------------------- */
.admin-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 12px;
  font-family: inherit;
  font-size: 0.78rem;
  font-weight: 500;
  border-radius: var(--r-sm);
  border: 1px solid var(--line-strong);
  background: var(--bg-elev-2);
  color: var(--ink-soft);
  cursor: pointer;
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
  text-decoration: none;
  list-style: none;
}
.admin-btn::-webkit-details-marker { display: none; }
.admin-btn:hover { background: var(--bg-elev); color: var(--ink); }
.admin-btn--ghost {
  background: transparent;
}
.admin-btn--danger {
  border-color: color-mix(in oklab, var(--danger) 50%, var(--line-strong));
  color: var(--danger);
}
.admin-btn--danger:hover {
  background: color-mix(in oklab, var(--danger) 18%, var(--bg-elev));
  color: var(--ink);
}

/* ----- Ban form (dentro <details>) ----------------------------- */
.admin-ban-form { display: inline-block; }
.admin-ban-form[open] .admin-btn {
  background: color-mix(in oklab, var(--danger) 18%, var(--bg-elev));
  color: var(--ink);
}
.admin-ban-form__panel {
  position: absolute;
  right: 14px;
  margin-top: 8px;
  background: var(--bg-elev);
  border: 1px solid var(--line-strong);
  border-radius: var(--r);
  padding: 16px;
  width: min(320px, 90vw);
  box-shadow: var(--shadow-card);
  z-index: 5;
  display: flex;
  flex-direction: column;
  gap: 12px;
  white-space: normal;
}
.admin-ban-form__fieldset {
  border: 0;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.admin-ban-form__legend {
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 4px;
  font-weight: 500;
  padding: 0;
}
.admin-ban-form__fieldset label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.86rem;
  color: var(--ink-soft);
  cursor: pointer;
}
.admin-ban-form__field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.admin-ban-form__field > span {
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 500;
}
.admin-ban-form__field input[type="datetime-local"],
.admin-ban-form__field textarea {
  font-family: inherit;
  font-size: 0.88rem;
  background: var(--bg-elev-2);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  color: var(--ink);
  padding: 8px 10px;
}
.admin-ban-form__field textarea { resize: vertical; min-height: 60px; }
.admin-ban-form__check {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  font-size: 0.84rem;
  color: var(--ink-soft);
  cursor: pointer;
}
.admin-ban-form__buttons {
  display: flex;
  justify-content: flex-end;
}

/* ----- Flash messages ------------------------------------------ */
.admin-flash {
  padding: 12px 16px;
  border-radius: var(--r-sm);
  margin: 0 0 20px;
  font-size: 0.92rem;
  border: 1px solid var(--line-strong);
}
.admin-flash--ok {
  background: color-mix(in oklab, var(--mint) 12%, var(--bg-elev));
  border-color: color-mix(in oklab, var(--mint) 40%, var(--line-strong));
  color: var(--ink);
}
.admin-flash--err {
  background: color-mix(in oklab, var(--danger) 12%, var(--bg-elev));
  border-color: color-mix(in oklab, var(--danger) 40%, var(--line-strong));
  color: var(--ink);
}

.admin-users__count {
  margin: 0 0 18px;
  font-size: 0.9rem;
}

/* ----- Comunicazioni legali ------------------------------------ */
.admin-comms__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: 20px;
  align-items: start;
}
@media (max-width: 860px) {
  .admin-comms__grid { grid-template-columns: 1fr; }
}
.admin-comms__form {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.admin-comms__fieldset {
  border: 0;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.admin-comms__legend {
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 500;
  margin-bottom: 4px;
  padding: 0;
}
.admin-comms__check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.92rem;
  color: var(--ink-soft);
  cursor: pointer;
}
.admin-comms__check input { margin-top: 3px; }
.admin-comms__field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.admin-comms__field > span {
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 500;
}
.admin-comms__field input[type="number"],
.admin-comms__field textarea {
  font-family: inherit;
  font-size: 0.92rem;
  background: var(--bg-elev-2);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  color: var(--ink);
  padding: 10px 12px;
}
.admin-comms__field input[type="number"] { max-width: 140px; }
.admin-comms__field textarea { resize: vertical; min-height: 72px; }
.admin-comms__effective {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 14px 16px;
  background: color-mix(in oklab, var(--mint) 8%, var(--bg-elev-2));
  border: 1px solid color-mix(in oklab, var(--mint) 36%, var(--line-strong));
  border-radius: var(--r);
}
.admin-comms__effective-label {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.admin-comms__effective-date {
  font-size: 1.25rem;
  color: var(--mint);
  font-weight: 600;
  letter-spacing: -0.01em;
}
.admin-comms__recap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
  padding-top: 6px;
  border-top: 1px solid var(--line);
}
.admin-comms__recap p { margin: 0; font-size: 0.9rem; }
.admin-comms__send {
  padding: 10px 20px;
  font-size: 0.9rem;
  background: var(--brand);
  border-color: transparent;
  color: #0a0a10;
  font-weight: 600;
}
.admin-comms__send:hover { color: #0a0a10; filter: brightness(1.06); }

/* ============================================================
   VERIFICA ADMIN — centrato, vibe "vault"
   ============================================================ */
.admin-verify {
  display: grid;
  place-items: center;
  padding: 140px 22px 80px;
  min-height: 100vh;
}
.admin-verify__card {
  width: 100%;
  max-width: 460px;
  background: var(--bg-elev);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  padding: 36px 32px;
  box-shadow: var(--shadow-card);
  position: relative;
}
.admin-verify__kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--danger);
  margin: 0 0 18px;
}
.admin-verify__dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--danger);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--danger) 28%, transparent);
}
.admin-verify__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.8rem, 4vw, 2.4rem);
  letter-spacing: -0.025em;
  line-height: 1.05;
  margin: 0 0 12px;
  color: var(--ink);
}
.admin-verify__title em { font-style: italic; color: var(--brand-soft); }
.admin-verify__sub {
  color: var(--ink-soft);
  font-size: 0.96rem;
  line-height: 1.55;
  margin: 0 0 22px;
}
.admin-verify__notice,
.admin-verify__alert {
  padding: 10px 14px;
  border-radius: var(--r-sm);
  margin: 0 0 16px;
  font-size: 0.88rem;
  border: 1px solid var(--line-strong);
}
.admin-verify__notice {
  background: color-mix(in oklab, var(--mint) 10%, var(--bg-elev-2));
  border-color: color-mix(in oklab, var(--mint) 40%, var(--line-strong));
  color: var(--ink);
}
.admin-verify__alert {
  background: color-mix(in oklab, var(--danger) 10%, var(--bg-elev-2));
  border-color: color-mix(in oklab, var(--danger) 40%, var(--line-strong));
  color: var(--ink);
}
.admin-verify__form { display: flex; flex-direction: column; gap: 12px; }
.admin-verify__label {
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 500;
}
.admin-verify__input {
  font-family: var(--font-mono);
  font-size: 1.6rem;
  letter-spacing: 0.4em;
  text-align: center;
  padding: 16px 12px;
  background: oklch(8% 0.01 280);
  border: 1px solid var(--line-strong);
  border-radius: var(--r);
  color: var(--ink);
}
.admin-verify__input:focus {
  outline: none;
  border-color: var(--brand-soft);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand) 22%, transparent);
}
.admin-verify__hint { margin: 0 0 8px; font-size: 0.82rem; color: var(--ink-mute); }
.admin-verify__resend { margin-top: 14px; }
.admin-verify__foot {
  margin: 24px 0 0;
  font-size: 0.66rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-dim);
  text-align: center;
}

/* ============================================================
   /sospeso — pagina vista da utenti bannati o IP bloccati
   ============================================================ */
.banned-page {
  display: grid;
  place-items: center;
  padding: 140px 22px 80px;
  min-height: 100vh;
}
.banned-page__card {
  width: 100%;
  max-width: 560px;
  background: var(--bg-elev);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  padding: 40px 32px;
  box-shadow: var(--shadow-card);
}
.banned-page__kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--danger);
  margin: 0 0 18px;
}
.banned-page__dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--danger);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--danger) 28%, transparent);
}
.banned-page__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.8rem, 4vw, 2.4rem);
  letter-spacing: -0.025em;
  line-height: 1.1;
  margin: 0 0 16px;
  color: var(--ink);
}
.banned-page__title em { font-style: italic; color: var(--brand-soft); }
.banned-page__intro {
  color: var(--ink-soft);
  font-size: 0.98rem;
  line-height: 1.6;
  margin: 0 0 24px;
}
.banned-page__sheet {
  margin: 0 0 28px;
  padding: 18px 20px;
  background: var(--bg-elev-2);
  border: 1px solid var(--line);
  border-radius: var(--r);
}
.banned-page__row {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 16px;
  padding: 10px 0;
  border-bottom: 1px dashed var(--line);
  align-items: baseline;
}
.banned-page__row:last-child { border-bottom: none; }
.banned-page__row dt {
  font-size: 0.68rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 500;
}
.banned-page__row dd {
  margin: 0;
  color: var(--ink-soft);
  font-size: 0.92rem;
  line-height: 1.5;
}
.banned-page__appeal {
  background:
    radial-gradient(80% 100% at 0% 0%, oklch(70% 0.2 285 / 0.10), transparent 70%),
    var(--bg-elev-2);
  border: 1px solid color-mix(in oklab, var(--brand-soft) 25%, var(--line-strong));
  border-radius: var(--r);
  padding: 20px;
  margin-bottom: 24px;
}
.banned-page__appeal-label {
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brand-soft);
  margin: 0 0 10px;
}
.banned-page__appeal p {
  margin: 0;
  color: var(--ink-soft);
  font-size: 0.94rem;
  line-height: 1.6;
}
.banned-page__mail {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: var(--ink);
  border-bottom: 1px solid var(--brand-soft);
  padding-bottom: 1px;
  font-weight: 600;
}
.banned-page__mail:hover {
  color: var(--brand-soft);
}
.banned-page__logout { margin: 0; }

.banned-page__gdpr {
  background: var(--bg-elev-2);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 18px 20px;
  margin: 0 0 20px;
}
.banned-page__gdpr p {
  margin: 0 0 12px;
  color: var(--ink-soft);
  font-size: 0.92rem;
  line-height: 1.55;
}
.banned-page__gdpr-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 6px;
}

/* ============================================================
   PROFILE · DATI & PRIVACY (GDPR) — export + cancellazione
   ============================================================ */
.profile-privacy__lede {
  color: var(--ink-soft);
  font-size: 0.96rem;
  line-height: 1.6;
  margin: 4px 0 22px;
  max-width: 62ch;
}

.privacy-tile {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 22px 22px;
  margin-bottom: 14px;
  transition: border-color var(--t-fast);
}
.privacy-tile:hover { border-color: var(--line-strong); }
@media (min-width: 720px) {
  .privacy-tile {
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 28px;
  }
}
.privacy-tile--danger {
  border-color: color-mix(in oklab, var(--danger) 30%, var(--line-strong));
  background:
    radial-gradient(80% 100% at 0% 0%, oklch(72% 0.2 25 / 0.08), transparent 70%),
    var(--bg-elev);
}
.privacy-tile--danger:hover {
  border-color: color-mix(in oklab, var(--danger) 55%, var(--line-strong));
}

.privacy-tile__head { display: flex; flex-direction: column; gap: 6px; }
.privacy-tile__kicker {
  font-size: 0.66rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0;
}
.privacy-tile__kicker--danger { color: var(--danger); }
.privacy-tile__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.45rem;
  letter-spacing: -0.015em;
  line-height: 1.15;
  color: var(--ink);
  margin: 0;
}
.privacy-tile__desc {
  color: var(--ink-soft);
  font-size: 0.94rem;
  line-height: 1.6;
  margin: 0;
  max-width: 56ch;
}
.privacy-tile__desc strong { color: var(--ink); font-weight: 600; }
.privacy-tile__action {
  justify-self: start;
}
@media (min-width: 720px) {
  .privacy-tile__action { justify-self: end; }
}

/* Form di cancellazione dentro <details> con expand fluido */
.privacy-tile--danger .privacy-delete {
  grid-column: 1 / -1;
}
.privacy-delete__summary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border: 1px solid color-mix(in oklab, var(--danger) 45%, var(--line-strong));
  border-radius: var(--r-pill);
  color: var(--danger);
  background: transparent;
  font-family: inherit;
  font-size: 0.86rem;
  font-weight: 500;
  cursor: pointer;
  list-style: none;
  user-select: none;
  transition: background var(--t-fast), color var(--t-fast);
}
.privacy-delete__summary::-webkit-details-marker { display: none; }
.privacy-delete__summary:hover {
  background: color-mix(in oklab, var(--danger) 14%, var(--bg-elev));
  color: var(--ink);
}
.privacy-delete__chev {
  display: inline-block;
  transition: transform var(--t) var(--ease);
}
.privacy-delete[open] .privacy-delete__chev { transform: rotate(180deg); }

.privacy-delete__form {
  margin-top: 18px;
  background: var(--bg-elev-2);
  border: 1px solid color-mix(in oklab, var(--danger) 35%, var(--line-strong));
  border-radius: var(--r);
  padding: 22px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  animation: privacy-delete-in 240ms var(--ease);
}
@keyframes privacy-delete-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

.privacy-delete__warn {
  background: color-mix(in oklab, var(--danger) 10%, transparent);
  border: 1px solid color-mix(in oklab, var(--danger) 40%, var(--line));
  border-radius: var(--r);
  padding: 14px 16px;
  color: var(--ink-soft);
  font-size: 0.92rem;
  line-height: 1.55;
}
.privacy-delete__warn p { margin: 0 0 10px; }
.privacy-delete__warn p:last-child { margin-bottom: 0; }
.privacy-delete__warn strong { color: var(--ink); }
.privacy-delete__warn ul {
  margin: 6px 0 10px;
  padding-left: 22px;
  list-style: disc;
}
.privacy-delete__warn li { margin-bottom: 3px; }

.privacy-delete__google {
  font-size: 0.88rem;
  margin: 0;
}

.privacy-delete__field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.privacy-delete__field > span {
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 500;
}
.privacy-delete__field > span code {
  font-family: var(--font-mono);
  background: color-mix(in oklab, var(--danger) 18%, var(--bg-elev));
  padding: 1px 6px;
  border-radius: var(--r-xs);
  letter-spacing: 0.15em;
  color: var(--ink);
}
.privacy-delete__field input {
  font-family: inherit;
  font-size: 0.95rem;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  color: var(--ink);
  padding: 10px 12px;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.privacy-delete__field input[name="confirm"] {
  font-family: var(--font-mono);
  letter-spacing: 0.18em;
  text-align: center;
}
.privacy-delete__field input:focus {
  outline: none;
  border-color: var(--danger);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--danger) 22%, transparent);
}

.privacy-delete__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
}
.privacy-delete__hint {
  font-size: 0.84rem;
}

/* ============================================================
   WELCOME SCREEN — onboarding post-setup
   "Ciao Nome, benvenuto su Talenis" + frasi in rotazione +
   orb pulsante con anelli concentrici e scintille. Loading
   minimo 5s con delay random (vedi welcome.js).
   ============================================================ */

.welcome-body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  overflow: hidden;
}

.welcome {
  position: relative;
  isolation: isolate;
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 40px 22px;
}

.welcome__aurora {
  position: absolute;
  inset: -30% -10% -10% -10%;
  z-index: -1;
  background:
    radial-gradient(45% 55% at 30% 35%, oklch(70% 0.2 285 / 0.40), transparent 70%),
    radial-gradient(40% 50% at 75% 25%, oklch(82% 0.14 165 / 0.22), transparent 72%),
    radial-gradient(60% 60% at 55% 85%, oklch(70% 0.2 320 / 0.18), transparent 72%);
  filter: blur(60px);
  pointer-events: none;
  animation: welcome-aurora 16s var(--ease) infinite alternate;
}
@keyframes welcome-aurora {
  0%   { transform: translate3d(-2%, -2%, 0) scale(1); opacity: 0.85; }
  100% { transform: translate3d( 3%,  2%, 0) scale(1.08); opacity: 1; }
}

.welcome__card {
  position: relative;
  width: 100%;
  max-width: 520px;
  text-align: center;
  padding: 36px 28px 32px;
}

/* ----- Halo: orb + anelli + scintille ---------------------------- */
.welcome__halo {
  position: relative;
  width: 180px;
  height: 180px;
  margin: 0 auto 32px;
}

.welcome__orb {
  position: absolute;
  inset: 60px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 35% 30%, oklch(95% 0.05 285), oklch(72% 0.18 285) 60%, oklch(45% 0.15 285) 100%);
  box-shadow:
    0 0 40px oklch(70% 0.2 285 / 0.6),
    0 0 80px oklch(70% 0.2 285 / 0.4),
    inset 0 2px 6px oklch(95% 0.05 285 / 0.5);
  animation: welcome-orb-pulse 2.6s var(--ease) infinite;
}
@keyframes welcome-orb-pulse {
  0%, 100% { transform: scale(1);    box-shadow: 0 0 40px oklch(70% 0.2 285 / 0.6), 0 0 80px oklch(70% 0.2 285 / 0.4), inset 0 2px 6px oklch(95% 0.05 285 / 0.5); }
  50%      { transform: scale(1.08); box-shadow: 0 0 60px oklch(70% 0.2 285 / 0.8), 0 0 120px oklch(70% 0.2 285 / 0.5), inset 0 2px 6px oklch(95% 0.05 285 / 0.5); }
}

.welcome__ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 1px solid color-mix(in oklab, var(--brand-soft) 35%, transparent);
  animation: welcome-ring-spin 12s linear infinite;
}
.welcome__ring--1 {
  inset: 0;
  border-style: dashed;
  border-color: color-mix(in oklab, var(--brand-soft) 30%, transparent);
}
.welcome__ring--2 {
  inset: 20px;
  border-style: solid;
  border-color: color-mix(in oklab, var(--mint) 28%, transparent);
  animation-direction: reverse;
  animation-duration: 16s;
}
.welcome__ring--3 {
  inset: 40px;
  border-style: dotted;
  border-color: color-mix(in oklab, var(--brand-soft) 22%, transparent);
  animation-duration: 9s;
}
@keyframes welcome-ring-spin {
  to { transform: rotate(360deg); }
}

.welcome__spark {
  position: absolute;
  font-family: var(--font-display);
  color: var(--mint);
  font-size: 1.2rem;
  opacity: 0;
  animation: welcome-spark 3.4s var(--ease) infinite;
  pointer-events: none;
  text-shadow: 0 0 8px oklch(82% 0.14 165 / 0.8);
}
.welcome__spark--a { top: 10%;  left: 18%; animation-delay: 0s; }
.welcome__spark--b { top: 20%;  right: 12%; animation-delay: 1.1s; color: var(--brand-soft); text-shadow: 0 0 8px oklch(82% 0.16 285 / 0.8); }
.welcome__spark--c { bottom: 8%; left: 38%; animation-delay: 2.2s; }
@keyframes welcome-spark {
  0%, 100% { opacity: 0; transform: scale(0.6) rotate(0deg);    }
  35%      { opacity: 1; transform: scale(1.1) rotate(180deg); }
  65%      { opacity: 1; transform: scale(1.0) rotate(220deg); }
}

/* ----- Tipografia ---------------------------------------------- */
.welcome__kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--brand-soft);
  margin: 0 0 18px;
}
.welcome__dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--brand-soft);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--brand) 28%, transparent);
  animation: welcome-dot-pulse 1.6s var(--ease) infinite;
}
@keyframes welcome-dot-pulse {
  0%, 100% { box-shadow: 0 0 0 4px color-mix(in oklab, var(--brand) 28%, transparent); }
  50%      { box-shadow: 0 0 0 8px color-mix(in oklab, var(--brand) 10%, transparent); }
}

.welcome__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2rem, 5.5vw, 3.2rem);
  line-height: 1.08;
  letter-spacing: -0.025em;
  margin: 0 0 18px;
  color: var(--ink);
  animation: welcome-fade-up 700ms var(--ease) both;
}
.welcome__title em {
  font-style: italic;
  color: var(--brand-soft);
}
.welcome__sub {
  font-family: var(--font-body);
  color: var(--ink-soft);
  font-size: 1rem;
  line-height: 1.55;
  margin: 0 0 36px;
  max-width: 36ch;
  margin-inline: auto;
  animation: welcome-fade-up 700ms var(--ease) 120ms both;
}
.welcome__sub em {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--ink);
  font-size: 1.05em;
}

@keyframes welcome-fade-up {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ----- Frasi rotanti ------------------------------------------ */
.welcome__phrase {
  font-family: var(--font-mono);
  font-size: 0.86rem;
  letter-spacing: 0.06em;
  color: var(--ink-soft);
  margin: 0 0 22px;
  min-height: 1.4em;
  transition:
    opacity var(--t-fast) var(--ease),
    transform var(--t-fast) var(--ease);
  opacity: 1;
  transform: translateY(0);
}
.welcome__phrase.is-out {
  opacity: 0;
  transform: translateY(-4px);
}

/* ----- Progress bar ------------------------------------------- */
.welcome__progress {
  position: relative;
  width: min(320px, 80%);
  height: 3px;
  margin: 0 auto;
  background: color-mix(in oklab, var(--ink) 8%, transparent);
  border-radius: var(--r-pill);
  overflow: hidden;
}
.welcome__progress-fill {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 0%; /* il JS lo porta a 100% con transition = totalMs */
  background:
    linear-gradient(90deg,
      var(--brand-soft) 0%,
      var(--mint) 100%);
  border-radius: var(--r-pill);
  box-shadow: 0 0 12px oklch(70% 0.2 285 / 0.5);
}
.welcome__progress-fill::after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 40px;
  background: linear-gradient(90deg, transparent, oklch(96% 0.03 85 / 0.6), transparent);
  animation: welcome-shimmer 1.4s var(--ease) infinite;
}
@keyframes welcome-shimmer {
  0%   { transform: translateX(-100%); opacity: 0; }
  50%  { opacity: 1; }
  100% { transform: translateX(100%); opacity: 0; }
}

.welcome__noscript {
  margin: 20px 0 0;
  font-size: 0.92rem;
  color: var(--ink-soft);
}
.welcome__noscript a {
  color: var(--brand-soft);
  border-bottom: 1px solid var(--brand-soft);
  padding-bottom: 1px;
}

@media (prefers-reduced-motion: reduce) {
  .welcome__aurora,
  .welcome__orb,
  .welcome__ring,
  .welcome__spark,
  .welcome__dot,
  .welcome__title,
  .welcome__sub,
  .welcome__progress-fill::after {
    animation: none !important;
  }
  .welcome__title,
  .welcome__sub { opacity: 1; transform: none; }
}

/* =================================================================
   Invito del fondatore — pagina pubblica /invito/:token
   Layout single-card, sobrio, premium. Stessa palette del resto.
   ================================================================= */

.page--invite {
    padding-top: clamp(8rem, 15vw, 12rem);
    padding-bottom: clamp(3rem, 8vw, 6rem);
}

.invite {
  position: relative;
  display: flex;
  justify-content: center;
}

.invite__aurora {
  position: absolute;
  inset: -10% -20% auto -20%;
  height: 60%;
  background:
    radial-gradient(60% 60% at 30% 20%, oklch(70% 0.2 285 / 0.20), transparent 70%),
    radial-gradient(50% 50% at 80% 30%, oklch(82% 0.14 165 / 0.14), transparent 70%);
  filter: blur(40px);
  pointer-events: none;
  z-index: 0;
}

.invite__card {
  position: relative;
  z-index: 1;
  max-width: 720px;
  width: 100%;
  background:
    linear-gradient(180deg, oklch(14% 0.018 275 / 0.92), oklch(11% 0.014 275 / 0.95));
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: clamp(1.75rem, 5vw, 3rem);
  box-shadow: var(--shadow-card), var(--shadow-glow);
  backdrop-filter: blur(8px);
}

.invite__kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 1.25rem;
}

.invite__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--mint);
  box-shadow: 0 0 12px oklch(82% 0.14 165 / 0.8);
  animation: invite-pulse 2.4s ease-in-out infinite;
}

@keyframes invite-pulse {
  0%, 100% { opacity: 0.6; transform: scale(0.9); }
  50%      { opacity: 1;   transform: scale(1.1); }
}

.invite__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2rem, 5.5vw, 3.25rem);
  line-height: 1.05;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 0 0 1.5rem;
}

.invite__title em {
  font-style: italic;
  color: var(--brand-soft);
}

.invite__lede {
  font-size: 1.0625rem;
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0 0 1rem;
  max-width: 60ch;
}

.invite__lede em {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.08em;
  color: var(--ink);
}

.invite__why {
  margin: 1.75rem 0;
  padding: 1.25rem 1.5rem;
  background: oklch(18% 0.02 275 / 0.55);
  border: 1px solid var(--line);
  border-left: 3px solid var(--brand-soft);
  border-radius: var(--r);
}

.invite__why-label {
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--brand-soft);
  margin: 0 0 0.5rem;
}

.invite__why-body {
  font-size: 0.97rem;
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0;
}

.invite__why-body strong { color: var(--ink); font-weight: 600; }

.invite__benefit {
  display: flex;
  gap: 1rem;
  align-items: center;
  margin: 1.75rem 0 2rem;
  padding: 1.25rem 1.5rem;
  background:
    linear-gradient(135deg, oklch(70% 0.2 285 / 0.10), oklch(82% 0.14 165 / 0.10));
  border: 1px solid oklch(70% 0.2 285 / 0.25);
  border-radius: var(--r);
}

.invite__benefit-icon {
  font-size: 1.75rem;
  line-height: 1;
  color: var(--mint);
  text-shadow: 0 0 16px oklch(82% 0.14 165 / 0.6);
  flex-shrink: 0;
}

.invite__benefit-title {
  font-family: var(--font-display);
  font-size: 1.4rem;
  line-height: 1.1;
  color: var(--ink);
  margin: 0 0 0.25rem;
}

.invite__benefit-sub {
  font-size: 0.92rem;
  line-height: 1.5;
  color: var(--ink-soft);
  margin: 0;
}

.invite__benefit-sub em {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--brand-soft);
}

.invite__cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  margin: 2rem 0 1.25rem;
}

.invite__cta .btn--lg {
  font-size: 1.05rem;
  padding: 1rem 2rem;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 240px;
  justify-content: center;
}

.invite__cta--logged { gap: 0.75rem; }

.invite__cta-note {
  font-size: 0.92rem;
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  justify-content: center;
}

.invite__cta-check {
  display: inline-grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: oklch(82% 0.14 165 / 0.18);
  color: var(--mint);
  font-weight: 700;
  font-size: 0.85rem;
  border: 1px solid oklch(82% 0.14 165 / 0.5);
}

.invite__login-link {
  color: var(--ink-mute);
  font-size: 0.9rem;
  text-decoration: none;
  transition: color var(--t-fast) var(--ease);
}

.invite__login-link strong {
  color: var(--ink-soft);
  font-weight: 600;
  border-bottom: 1px solid var(--line-strong);
  padding-bottom: 1px;
}

.invite__login-link:hover { color: var(--ink); }
.invite__login-link:hover strong { border-bottom-color: var(--brand-soft); }

.invite__footnote {
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-soft);
  text-align: center;
  margin: 1.5rem 0 0;
  padding-top: 1.5rem;
  border-top: 1px solid var(--line);
}

@media (prefers-reduced-motion: reduce) {
  .invite__dot { animation: none; }
}

/* =================================================================
   Cruscotto — Saldo totale (riga sotto al disponibile mensile)
   ================================================================= */

.dash-balance__total {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin: 12px 0 0;
  padding-top: 12px;
  border-top: 1px dashed var(--line);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  color: var(--ink-mute);
}

.dash-balance__total-label {
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.68rem;
  color: var(--ink-mute);
}

.dash-balance__total-num {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--ink);
}

.dash-balance__total-num.is-positive { color: var(--mint); }
.dash-balance__total-num.is-negative { color: var(--danger); }

/* Nudge "imposta il saldo iniziale" */
.dash-balance__nudge {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  margin: 10px 0 0;
  padding: 0.6rem 0.85rem;
  background: oklch(82% 0.14 75 / 0.08);
  border: 1px solid oklch(82% 0.14 75 / 0.3);
  border-radius: var(--r-sm);
  font-size: 0.82rem;
  line-height: 1.4;
  color: var(--ink-soft);
  text-decoration: none;
  transition: background var(--t-fast) var(--ease),
              border-color var(--t-fast) var(--ease);
}

.dash-balance__nudge:hover,
.dash-balance__nudge:focus-visible {
  background: oklch(82% 0.14 75 / 0.14);
  border-color: oklch(82% 0.14 75 / 0.5);
  outline: none;
}

.dash-balance__nudge strong { color: var(--ink); font-weight: 600; }

.dash-balance__nudge-icon {
  flex-shrink: 0;
  display: grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--warn);
  color: oklch(15% 0.02 75);
  font-weight: 800;
  font-size: 0.85rem;
  line-height: 1;
}

/* Nudge "imposta saldo iniziale" sulla pagina /compro */
.compro-context__nudge {
  display: block;
  margin-top: 0.6rem;
  padding: 0.55rem 0.75rem;
  background: oklch(82% 0.14 75 / 0.08);
  border: 1px solid oklch(82% 0.14 75 / 0.28);
  border-radius: var(--r-sm);
  font-size: 0.78rem;
  line-height: 1.4;
  color: var(--ink-soft);
  text-decoration: none;
  transition: background var(--t-fast) var(--ease),
              border-color var(--t-fast) var(--ease);
}

.compro-context__nudge:hover,
.compro-context__nudge:focus-visible {
  background: oklch(82% 0.14 75 / 0.14);
  border-color: oklch(82% 0.14 75 / 0.45);
  outline: none;
}

.compro-context__nudge strong { color: var(--ink); font-weight: 600; }

/* =================================================================
   Campo input con prefisso € (saldo di apertura, generico)
   ================================================================= */

.input-prefix {
  position: relative;
  display: flex;
  align-items: stretch;
}

.input-prefix__sym {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 36px;
  display: grid;
  place-items: center;
  color: var(--ink-mute);
  font-size: 0.95rem;
  pointer-events: none;
  border-right: 1px solid var(--line);
}

.input--with-prefix {
  padding-left: 48px;
}

.field__label-opt {
  font-weight: 400;
  color: var(--ink-mute);
  font-size: 0.85em;
  letter-spacing: 0;
  text-transform: none;
}

.opening-balance-field { margin-top: 1rem; }
.opening-balance-field .field__hint { line-height: 1.5; }
.opening-balance-field .field__hint strong { color: var(--ink-soft); font-weight: 600; }
.opening-balance-field .field__hint em {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--brand-soft);
}

/* =================================================================
   "Lo compro o no?" — card CTA sul cruscotto
   ================================================================= */

.dash-quick__advisor {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  margin-top: 0.5rem;
  padding: 0.85rem 1rem;
  background:
    linear-gradient(135deg, oklch(70% 0.2 285 / 0.10), oklch(82% 0.14 165 / 0.08));
  border: 1px solid oklch(70% 0.2 285 / 0.28);
  border-radius: var(--r);
  text-decoration: none;
  color: var(--ink-soft);
  transition: border-color var(--t-fast) var(--ease),
              transform var(--t-fast) var(--ease),
              background var(--t-fast) var(--ease);
}

.dash-quick__advisor:hover,
.dash-quick__advisor:focus-visible {
  border-color: oklch(70% 0.2 285 / 0.55);
  transform: translateY(-1px);
  outline: none;
}

.dash-quick__advisor-icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.25rem;
  color: var(--mint);
  background: oklch(82% 0.14 165 / 0.14);
  border: 1px solid oklch(82% 0.14 165 / 0.35);
}

.dash-quick__advisor-body {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.dash-quick__advisor-title {
  font-weight: 600;
  color: var(--ink);
  font-size: 0.96rem;
  line-height: 1.2;
}

.dash-quick__advisor-sub {
  font-size: 0.8rem;
  color: var(--ink-mute);
  line-height: 1.35;
}

.dash-quick__advisor-arrow {
  flex-shrink: 0;
  color: var(--brand-soft);
  font-size: 1.1rem;
  transition: transform var(--t-fast) var(--ease);
}

.dash-quick__advisor:hover .dash-quick__advisor-arrow {
  transform: translateX(3px);
}

/* =================================================================
   "Lo compro o no?" — pagina /compro (form + risultato)
   ================================================================= */

.page--compro { padding-block: clamp(1.5rem, 4vw, 3rem) clamp(2.5rem, 6vw, 5rem); }

.compro-context {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  margin: 1.25rem 0 1.5rem;
  padding: 1rem 1.25rem;
  background: oklch(14% 0.018 275 / 0.7);
  border: 1px solid var(--line);
  border-radius: var(--r);
}

.compro-context__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
}

.compro-context__label {
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0;
}

.compro-context__value {
  font-size: 1.5rem;
  font-weight: 600;
  margin: 0;
}

.compro-context__value.is-positive { color: var(--mint); }
.compro-context__value.is-negative { color: var(--danger); }

.compro-context__sub {
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  color: var(--ink-dim);
  margin: 0;
}

.compro-form {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.compro-card {
  background:
    linear-gradient(180deg, oklch(14% 0.018 275 / 0.7), oklch(11% 0.014 275 / 0.85));
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: clamp(1.1rem, 3vw, 1.75rem);
}

.compro-card__step {
  font-size: 0.68rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brand-soft);
  margin: 0 0 0.5rem;
}

.compro-card__q {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.35rem, 3.5vw, 1.7rem);
  color: var(--ink);
  margin: 0 0 1rem;
  line-height: 1.2;
}

.compro-field-row {
  display: grid;
  grid-template-columns: 1fr 130px;
  gap: 0.75rem;
}

@media (max-width: 480px) {
  .compro-field-row { grid-template-columns: 1fr; }
}

.compro-choices {
  display: grid;
  gap: 0.65rem;
}

.compro-choice {
  position: relative;
  display: block;
  padding: 0.95rem 1.1rem 0.95rem 3rem;
  background: oklch(18% 0.02 275 / 0.45);
  border: 1px solid var(--line);
  border-radius: var(--r);
  cursor: pointer;
  transition: background var(--t-fast) var(--ease),
              border-color var(--t-fast) var(--ease);
}

.compro-choice input[type="radio"] {
  position: absolute;
  left: 1rem;
  top: 1.05rem;
  width: 18px;
  height: 18px;
  margin: 0;
  cursor: pointer;
  accent-color: var(--brand);
}

.compro-choice:hover {
  background: oklch(20% 0.02 275 / 0.6);
  border-color: var(--line-strong);
}

.compro-choice:has(input:checked) {
  background: oklch(70% 0.2 285 / 0.12);
  border-color: oklch(70% 0.2 285 / 0.55);
  box-shadow: 0 0 0 3px oklch(70% 0.2 285 / 0.08);
}

.compro-choice__body {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.compro-choice__body strong {
  color: var(--ink);
  font-weight: 600;
  font-size: 0.97rem;
}

.compro-choice__body span:not(strong) {
  color: var(--ink-mute);
  font-size: 0.85rem;
  line-height: 1.4;
}

.compro-submit {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  margin-top: 0.5rem;
}

.compro-submit .btn--lg {
  min-width: 240px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.compro-submit__disclaimer {
  font-size: 0.68rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-dim);
  margin: 0;
}

/* =================================================================
   "Lo compro o no?" — verdetto
   ================================================================= */

.verdict {
  position: relative;
  margin: 1.5rem 0;
  padding: clamp(1.5rem, 4vw, 2.5rem);
  background:
    linear-gradient(180deg, oklch(14% 0.018 275 / 0.9), oklch(11% 0.014 275));
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  overflow: hidden;
  box-shadow: var(--shadow-card);
}

.verdict__halo {
  position: absolute;
  inset: -30% -30% auto -30%;
  height: 70%;
  pointer-events: none;
  filter: blur(40px);
  opacity: 0.55;
}

.verdict--go { border-color: oklch(82% 0.14 165 / 0.35); }
.verdict--go .verdict__halo {
  background: radial-gradient(60% 60% at 50% 20%, oklch(82% 0.14 165 / 0.5), transparent 70%);
}

.verdict--wait { border-color: oklch(82% 0.14 75 / 0.35); }
.verdict--wait .verdict__halo {
  background: radial-gradient(60% 60% at 50% 20%, oklch(82% 0.14 75 / 0.45), transparent 70%);
}

.verdict--no { border-color: oklch(72% 0.2 25 / 0.35); }
.verdict--no .verdict__halo {
  background: radial-gradient(60% 60% at 50% 20%, oklch(72% 0.2 25 / 0.45), transparent 70%);
}

.verdict__head {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.8rem;
  margin-bottom: 1rem;
}

.verdict__light {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  flex-shrink: 0;
  animation: verdict-pulse 2.2s ease-in-out infinite;
}

.verdict__light--go {
  background: var(--mint-strong);
  box-shadow: 0 0 18px oklch(82% 0.14 165 / 0.9);
}

.verdict__light--wait {
  background: var(--warn);
  box-shadow: 0 0 18px oklch(82% 0.14 75 / 0.9);
}

.verdict__light--no {
  background: var(--danger);
  box-shadow: 0 0 18px oklch(72% 0.2 25 / 0.9);
}

@keyframes verdict-pulse {
  0%, 100% { opacity: 0.6; transform: scale(0.95); }
  50%      { opacity: 1; transform: scale(1.08); }
}

.verdict__tag {
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin: 0;
}

.verdict__title {
  position: relative;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.8rem, 5vw, 2.6rem);
  line-height: 1.1;
  color: var(--ink);
  margin: 0 0 1rem;
  max-width: 22ch;
}

.verdict__item {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.5rem;
  margin: 0 0 1.5rem;
  padding: 0.7rem 0.9rem;
  background: oklch(18% 0.02 275 / 0.55);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
}

.verdict__item-label {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

.verdict__item-name {
  font-family: var(--font-display);
  font-size: 1.15rem;
  color: var(--ink);
}

.verdict__item-sep { color: var(--ink-dim); }
.verdict__item-price { color: var(--ink); font-weight: 600; }

.verdict__reasons {
  position: relative;
  list-style: none;
  margin: 0 0 1.75rem;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}

.verdict__reason {
  position: relative;
  padding-left: 1.5rem;
  font-size: 0.97rem;
  line-height: 1.55;
  color: var(--ink-soft);
}

.verdict__reason::before {
  content: '·';
  position: absolute;
  left: 0;
  top: -0.15em;
  font-size: 1.8rem;
  line-height: 1;
  color: var(--brand-soft);
}

.verdict__score {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--line);
}

.verdict__score-bar {
  flex: 1 1 auto;
  height: 6px;
  background: oklch(18% 0.02 275);
  border-radius: var(--r-pill);
  overflow: hidden;
}

.verdict__score-fill {
  height: 100%;
  border-radius: var(--r-pill);
  transition: width 600ms var(--ease);
}

.verdict--go .verdict__score-fill {
  background: linear-gradient(90deg, var(--mint), var(--mint-strong));
}

.verdict--wait .verdict__score-fill {
  background: linear-gradient(90deg, oklch(82% 0.14 75), var(--warn));
}

.verdict--no .verdict__score-fill {
  background: linear-gradient(90deg, oklch(72% 0.2 25 / 0.7), var(--danger));
}

.verdict__score-num {
  flex-shrink: 0;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--ink);
  margin: 0;
}

.verdict__score-num span {
  color: var(--ink-mute);
  font-weight: 400;
  font-size: 0.85rem;
  margin-left: 2px;
}

/* ---- impact "prima → dopo" ---- */

.verdict-impact {
  margin: 1.5rem 0;
  padding: 1.25rem 1.5rem;
  background: oklch(14% 0.018 275 / 0.6);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
}

.verdict-impact__row {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 1rem;
  align-items: center;
}

.verdict-impact__cell { text-align: center; }

.verdict-impact__lbl {
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 0.35rem;
}

.verdict-impact__num {
  font-size: clamp(1.05rem, 3vw, 1.35rem);
  font-weight: 600;
  margin: 0;
  color: var(--ink);
}

.verdict-impact__num.is-positive { color: var(--mint); }
.verdict-impact__num.is-negative { color: var(--danger); }

.verdict-impact__arrow {
  font-size: 1.4rem;
  color: var(--ink-mute);
}

.verdict-impact__note {
  text-align: center;
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  color: var(--ink-dim);
  margin: 0.75rem 0 0;
  padding-top: 0.75rem;
  border-top: 1px dashed var(--line);
}

/* ---- CTA finale ---- */

.verdict-cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.85rem;
  margin: 1.5rem 0 0;
  text-align: center;
}

.verdict-cta .btn--lg {
  min-width: 260px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.verdict-cta__alt {
  font-size: 0.85rem;
  color: var(--ink-mute);
  text-decoration: none;
  border-bottom: 1px solid var(--line-strong);
  padding-bottom: 1px;
  transition: color var(--t-fast) var(--ease);
}

.verdict-cta__alt:hover { color: var(--ink); }

.verdict-cta__hint {
  font-size: 0.88rem;
  line-height: 1.5;
  color: var(--ink-mute);
  margin: 0;
  max-width: 50ch;
}

/* =================================================================
   Banner invito sulle pagine /register e /login
   Compare quando hasFounderInvite è true (sessione ha founderInvite)
   ================================================================= */

.auth__invite-banner {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  margin: 0 0 1.25rem;
  padding: 0.9rem 1.1rem;
  background:
    linear-gradient(135deg, oklch(70% 0.2 285 / 0.12), oklch(82% 0.14 165 / 0.08));
  border: 1px solid oklch(70% 0.2 285 / 0.35);
  border-radius: var(--r);
  color: var(--ink-soft);
}

.auth__invite-banner-icon {
  font-size: 1.5rem;
  line-height: 1;
  color: var(--mint);
  text-shadow: 0 0 12px oklch(82% 0.14 165 / 0.6);
  flex-shrink: 0;
}

.auth__invite-banner-title {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--ink);
  margin: 0 0 0.2rem;
}

.auth__invite-banner-sub {
  font-size: 0.85rem;
  line-height: 1.45;
  color: var(--ink-soft);
  margin: 0;
}

.auth__invite-banner-sub strong { color: var(--brand-soft); font-weight: 600; }

/* =================================================================
   Badge "Amico del fondatore" — card profilo
   ================================================================= */

.founder-badge {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1.25rem;
  padding: 1.5rem 1.75rem;
  margin: 0 0 2rem;
  background:
    linear-gradient(135deg, oklch(14% 0.018 275 / 0.95), oklch(11% 0.014 275));
  border: 1px solid oklch(70% 0.2 285 / 0.35);
  border-radius: var(--r-lg);
  box-shadow:
    0 24px 60px -32px oklch(70% 0.2 285 / 0.5),
    inset 0 1px 0 oklch(70% 0.2 285 / 0.15);
  overflow: hidden;
}

.founder-badge__halo {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(120% 80% at 0% 0%, oklch(70% 0.2 285 / 0.18), transparent 50%),
    radial-gradient(80% 60% at 100% 100%, oklch(82% 0.14 165 / 0.12), transparent 60%);
  pointer-events: none;
}

.founder-badge__icon {
  position: relative;
  z-index: 1;
  width: 64px;
  height: 64px;
  flex-shrink: 0;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 2rem;
  color: var(--mint);
  background:
    radial-gradient(circle at 50% 50%, oklch(70% 0.2 285 / 0.25), transparent 70%);
  border: 1px solid oklch(82% 0.14 165 / 0.45);
  text-shadow: 0 0 18px oklch(82% 0.14 165 / 0.7);
}

.founder-badge__body { position: relative; z-index: 1; }

.founder-badge__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brand-soft);
  margin: 0 0 0.35rem;
}

.founder-badge__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.3rem, 3vw, 1.65rem);
  line-height: 1.15;
  color: var(--ink);
  margin: 0 0 0.4rem;
}

.founder-badge__title em {
  font-style: italic;
  color: var(--brand-soft);
}

.founder-badge__sub {
  font-size: 0.92rem;
  line-height: 1.5;
  color: var(--ink-soft);
  margin: 0;
  max-width: 56ch;
}

@media (max-width: 540px) {
  .founder-badge {
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
    gap: 1rem;
  }
}

/* =================================================================
   Admin · Inviti del fondatore — pagina /a/inviti
   ================================================================= */

.admin-stats--inline {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 1rem;
  margin-block: 1rem 1.5rem;
}

.admin-invite-status { margin-bottom: 1.5rem; }

.admin-invite-status__grid {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 0.5rem 0;
}

.admin-invite-status__row {
  display: grid;
  grid-template-columns: minmax(140px, 200px) 1fr;
  gap: 1rem;
  align-items: center;
}

.admin-invite-status__row--url { align-items: stretch; }

.admin-invite-status__label {
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0;
}

.admin-invite-status__value {
  font-size: 0.95rem;
  color: var(--ink-soft);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.admin-invite-status__token {
  font-family: var(--font-mono);
  font-size: 0.9rem;
  padding: 0.35rem 0.7rem;
  border-radius: var(--r-xs);
  background: oklch(18% 0.02 275);
  border: 1px solid var(--line);
  color: var(--ink);
}

.admin-invite-status__url-wrap {
  display: flex;
  gap: 0.5rem;
  align-items: stretch;
}

.admin-invite-status__url-input {
  flex: 1 1 auto;
  min-width: 0;
  padding: 0.6rem 0.85rem;
  background: oklch(18% 0.02 275);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  color: var(--ink);
  font-size: 0.85rem;
}

.admin-invite-status__url-input:focus {
  outline: none;
  border-color: var(--brand-soft);
  box-shadow: 0 0 0 3px oklch(70% 0.2 285 / 0.18);
}

@media (max-width: 640px) {
  .admin-invite-status__row {
    grid-template-columns: 1fr;
    gap: 0.5rem;
  }
}

/* Status pills (riusabili) */
.status-pill {
  display: inline-flex;
  align-items: center;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 0.3rem 0.7rem;
  border-radius: var(--r-pill);
  border: 1px solid transparent;
}

.status-pill--ok {
  color: var(--mint);
  background: oklch(82% 0.14 165 / 0.12);
  border-color: oklch(82% 0.14 165 / 0.3);
}

.status-pill--off {
  color: var(--ink-mute);
  background: oklch(28% 0.01 85 / 0.4);
  border-color: var(--line-strong);
}

.status-pill--err {
  color: var(--danger);
  background: oklch(72% 0.2 25 / 0.12);
  border-color: oklch(72% 0.2 25 / 0.3);
}

/* Tabella inviti */
.admin-table--invites .admin-table__name {
  font-weight: 600;
  color: var(--ink);
  margin: 0 0 0.15rem;
}

.admin-table--invites .admin-table__handle {
  font-size: 0.78rem;
  color: var(--ink-mute);
  margin: 0;
}

.admin-stat__link {
  color: var(--brand-soft);
  text-decoration: none;
  border-bottom: 1px solid oklch(70% 0.2 285 / 0.3);
  transition: border-color var(--t-fast) var(--ease);
}

.admin-stat__link:hover { border-bottom-color: var(--brand-soft); }

/* =================================================================
   Tour guidato di onboarding — spotlight + tooltip card.
   Le classi vengono iniettate da public/js/onboarding-tour.js solo per
   gli utenti con tour_completed_at = NULL. Una volta finito, sparisce.
   ================================================================= */

body.tour-active {
  /* Previene scrollbar laterali quando il box-shadow del spotlight
     “invade” lateralmente il documento. */
  overflow: hidden;
}

.tour-root {
  position: fixed;
  inset: 0;
  z-index: 100000;
  pointer-events: none;
  opacity: 0;
  transition: opacity 180ms var(--ease);
}
.tour-root.is-open { opacity: 1; }
.tour-root.is-closing { opacity: 0; }

/* Veil: copre tutto. Pointer-events attivo per "catchare" i click fuori
   dalla card (evitando che l'utente clicchi UI mentre il tour è aperto).
   Quando il step è centered (no target) lo veil è uniforme; quando c'è un
   target lo spotlight crea visualmente l'apertura via box-shadow. */
.tour-veil {
  position: absolute;
  inset: 0;
  background: oklch(0% 0 0 / 0.62);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  pointer-events: auto;
}

/* Quando lo step ha un target, il veil di base è meno opaco perché il
   "buco" attorno al target è creato dal box-shadow dello spotlight.
   Togliamo anche il backdrop-filter: se un parent del target ha
   transform/filter/contain creando uno stacking context, lo z-index
   100001 dello spotlight resta confinato lì e il blur del veil lo
   prenderebbe. Senza filter, il problema sparisce e visivamente non
   cambia nulla (il veil qui è transparent, il dim lo fa il box-shadow). */
.tour-veil:not([data-centered]) {
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  pointer-events: auto;
}

/* Spotlight applicato all'elemento target: una "luce" attorno + un
   gigantesco box-shadow inset-mimic che oscura tutto il resto.
   Di default il target è NON cliccabile (l'utente deve usare i bottoni
   del tour). Per i passi navigate il target diventa cliccabile (così
   se preme direttamente il link/bottone reale, va comunque avanti). */
.tour-spotlight {
  position: relative !important;
  z-index: 100001 !important;
  border-radius: 14px !important;
  pointer-events: none !important;
  box-shadow:
    0 0 0 4px oklch(82% 0.16 285 / 0.95),
    0 0 0 9999px oklch(0% 0 0 / 0.72) !important;
  transition: box-shadow 240ms var(--ease) !important;
  animation: tour-pulse 2.4s ease-in-out infinite !important;
}

.tour-spotlight.tour-spotlight--clickable {
  pointer-events: auto !important;
  cursor: pointer;
}

@keyframes tour-pulse {
  0%, 100% {
    box-shadow:
      0 0 0 4px oklch(82% 0.16 285 / 0.95),
      0 0 0 9999px oklch(0% 0 0 / 0.72);
  }
  50% {
    box-shadow:
      0 0 0 6px oklch(82% 0.16 285 / 1),
      0 0 22px 6px oklch(82% 0.16 285 / 0.45),
      0 0 0 9999px oklch(0% 0 0 / 0.72);
  }
}

/* Card tooltip: il contenuto del passo. Position absolute mossa da JS
   per agganciarla al target; per gli step centered si usa la variante
   --centered che la mette al centro del viewport. */
.tour-card {
  position: absolute;
  z-index: 100002;
  pointer-events: auto;
  width: min(94vw, 420px);
  background:
    linear-gradient(180deg, oklch(14% 0.018 275 / 0.99), oklch(11% 0.014 275));
  border: 1px solid var(--line-strong);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-card), 0 30px 80px -28px oklch(70% 0.2 285 / 0.5);
  padding: 1.25rem 1.4rem 1.1rem;
  color: var(--ink);
  transform: translateY(6px);
  opacity: 0;
  transition: transform 220ms var(--ease-soft), opacity 220ms var(--ease-soft),
              top 200ms var(--ease), left 200ms var(--ease);
}

.tour-root.is-open .tour-card {
  transform: translateY(0);
  opacity: 1;
}

.tour-card--centered {
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) translateY(6px);
}

.tour-root.is-open .tour-card--centered {
  transform: translate(-50%, -50%);
}

.tour-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.6rem;
}

.tour-card__progress {
  font-size: 0.66rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brand-soft);
  margin: 0;
}

.tour-card__skip {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--ink-mute);
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  padding: 0.3rem 0.65rem;
  border-radius: 999px;
  cursor: pointer;
  transition: color var(--t-fast), border-color var(--t-fast);
  font-family: var(--font-body);
}
.tour-card__skip:hover {
  color: var(--ink);
  border-color: var(--line-strong);
}

.tour-card__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(1.2rem, 3.2vw, 1.5rem);
  line-height: 1.18;
  color: var(--ink);
  margin: 0 0 0.65rem;
  letter-spacing: -0.01em;
}

.tour-card__body {
  font-size: 0.92rem;
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0 0 1rem;
}

.tour-card__body strong { color: var(--ink); font-weight: 600; }
.tour-card__body em {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--brand-soft);
}

.tour-card__nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
}

.tour-card__nav .btn--sm {
  font-size: 0.82rem;
  padding: 0.45rem 0.9rem;
}

@media (prefers-reduced-motion: reduce) {
  .tour-root, .tour-card { transition: none; }
  .tour-card { transform: none; }
  .tour-spotlight { animation: none !important; }
}

/* Mobile (< 760px): la bottom-nav fissa occupa ~80px e il viewport è
   stretto. Il posizionamento absolute calcolato dal JS rischia di
   piazzare la card sotto la fold o coperta dalla nav. Trasformiamo la
   card in bottom-sheet che sta sempre sopra la bottom-nav, full-width,
   con altezza limitata e scroll interno. Lo spotlight resta dov'è. */
@media (max-width: 759.98px) {
  .tour-card:not(.tour-card--centered) {
    position: fixed;
    top: auto !important;
    left: 12px !important;
    right: 12px;
    bottom: calc(96px + env(safe-area-inset-bottom, 0px));
    width: auto;
    max-width: none;
    max-height: 55vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  /* Anche per gli step centered: cap altezza così non straborda su
     viewport corti (iPhone SE, Android piccoli con tastiera). */
  .tour-card--centered {
    width: min(94vw, 420px);
    max-height: 80vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
}

/* =================================================================
   Modale di conferma custom — rimpiazzo delle confirm() native.
   Iniettata via JS (public/js/confirm-dialog.js) come ultimo nodo del
   body. La classe `is-open` attiva l'entrata, `is-closing` l'uscita.
   ================================================================= */

.modal-confirm {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  opacity: 0;
  transition: opacity 160ms var(--ease);
}

.modal-confirm.is-open { opacity: 1; }
.modal-confirm.is-closing { opacity: 0; }

.modal-confirm__backdrop {
  position: absolute;
  inset: 0;
  background: oklch(0% 0 0 / 0.7);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.modal-confirm__panel {
  position: relative;
  width: 100%;
  max-width: 460px;
  background:
    linear-gradient(180deg, oklch(14% 0.018 275 / 0.98), oklch(11% 0.014 275));
  border: 1px solid var(--line-strong);
  border-radius: var(--r-lg);
  padding: clamp(1.5rem, 4vw, 2rem);
  box-shadow: var(--shadow-card);
  transform: translateY(8px) scale(0.98);
  opacity: 0;
  transition: transform 200ms var(--ease-soft), opacity 200ms var(--ease-soft);
}

.modal-confirm.is-open .modal-confirm__panel {
  transform: translateY(0) scale(1);
  opacity: 1;
}

.modal-confirm.is-closing .modal-confirm__panel {
  transform: translateY(4px) scale(0.99);
  opacity: 0;
  transition-duration: 140ms;
}

.modal-confirm--danger .modal-confirm__panel {
  border-color: oklch(72% 0.2 25 / 0.4);
  box-shadow:
    var(--shadow-card),
    inset 0 1px 0 oklch(72% 0.2 25 / 0.15);
}

.modal-confirm__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(1.4rem, 4vw, 1.7rem);
  line-height: 1.15;
  color: var(--ink);
  margin: 0 0 0.65rem;
  letter-spacing: -0.01em;
}

.modal-confirm--danger .modal-confirm__title { color: var(--ink); }

.modal-confirm__body {
  font-size: 0.96rem;
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0 0 1.5rem;
}

.modal-confirm__actions {
  display: flex;
  gap: 0.6rem;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.modal-confirm__cancel,
.modal-confirm__ok {
  min-width: 110px;
  justify-content: center;
}

/* La variante .btn--danger esiste già nel design system (vedi sezione bottoni).
   Per le conferme distruttive la usiamo così com'è. */

@media (max-width: 480px) {
  .modal-confirm__actions { justify-content: stretch; }
  .modal-confirm__actions .btn { flex: 1 1 auto; }
}

@media (prefers-reduced-motion: reduce) {
  .modal-confirm,
  .modal-confirm__panel {
    transition: none;
  }
  .modal-confirm__panel { transform: none; }
}

/* =================================================================
   Cruscotto — riga superiore: titolo + 2 bottoni shortcut a destra
   ================================================================= */

.dash-hero__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.5rem;
  margin-bottom: 1.5rem;
}

.dash-hero__top .display { margin: 0; }

.dash-hero__shortcuts {
  display: flex;
  gap: 0.6rem;
  flex-shrink: 0;
}

.dash-shortcut {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  min-width: 78px;
  min-height: 78px;
  padding: 0.6rem 0.7rem;
  background:
    linear-gradient(180deg, oklch(14% 0.018 275 / 0.85), oklch(11% 0.014 275));
  border: 1px solid var(--line-strong);
  border-radius: var(--r-lg);
  color: var(--ink);
  text-decoration: none;
  cursor: pointer;
  font-family: var(--font-body);
  transition: border-color var(--t-fast) var(--ease),
              transform var(--t-fast) var(--ease),
              background var(--t-fast) var(--ease);
}

.dash-shortcut:hover,
.dash-shortcut:focus-visible {
  border-color: var(--brand-soft);
  transform: translateY(-2px);
  outline: none;
}

.dash-shortcut__icon {
  font-family: var(--font-display);
  font-size: 1.85rem;
  line-height: 1;
  color: var(--brand-soft);
}

.dash-shortcut--scan .dash-shortcut__icon { color: var(--mint); font-size: 1.6rem; }

.dash-shortcut__label {
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
  font-weight: 600;
}

@media (max-width: 640px) {
  .dash-hero__top {
    flex-direction: column;
    align-items: stretch;
    gap: 1rem;
  }
  .dash-shortcut {
    min-width: 70px;
    min-height: 70px;
  }
}

/* =================================================================
   Popup quick-add (qa-dialog)
   ================================================================= */

.qa-dialog {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 1rem;
  opacity: 0;
  transition: opacity 160ms var(--ease);
}

@media (min-width: 640px) {
  .qa-dialog { align-items: center; padding: 2rem; }
}

.qa-dialog.is-open { opacity: 1; }
.qa-dialog.is-closing { opacity: 0; }

.qa-dialog__backdrop {
  position: absolute;
  inset: 0;
  background: oklch(0% 0 0 / 0.7);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.qa-dialog__panel {
  position: relative;
  width: 100%;
  max-width: 480px;
  background:
    linear-gradient(180deg, oklch(14% 0.018 275 / 0.98), oklch(11% 0.014 275));
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  padding: 1.5rem 1.5rem 1.25rem;
  box-shadow: var(--shadow-card);
  transform: translateY(20px);
  opacity: 0;
  transition: transform 220ms var(--ease-soft), opacity 220ms var(--ease-soft);
  max-height: 90vh;
  overflow-y: auto;
}

.qa-dialog.is-open .qa-dialog__panel {
  transform: translateY(0);
  opacity: 1;
}

.qa-dialog__head {
  position: relative;
  margin-bottom: 1.25rem;
}

.qa-dialog__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brand-soft);
  margin: 0 0 0.35rem;
}

.qa-dialog__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: 1.7rem;
  line-height: 1.15;
  color: var(--ink);
  margin: 0;
}

.qa-dialog__close {
  position: absolute;
  top: -4px;
  right: -4px;
  width: 36px;
  height: 36px;
  background: transparent;
  border: 0;
  color: var(--ink-mute);
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  border-radius: 50%;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}

.qa-dialog__close:hover { background: var(--bg-elev-2); color: var(--ink); }

/* Chip frequenti dentro al popup */
.qa-dialog__chips { margin-bottom: 1.25rem; }
.qa-dialog__chips-label {
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 0.5rem;
}
.qa-dialog__chips-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}
.qa-dialog__chip {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.45rem 0.75rem;
  background: oklch(18% 0.02 275 / 0.7);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-pill);
  color: var(--ink-soft);
  font-size: 0.8rem;
  cursor: pointer;
  font-family: var(--font-body);
  transition: background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}
.qa-dialog__chip:hover {
  background: oklch(22% 0.02 275);
  border-color: var(--brand-soft);
  color: var(--ink);
}
.qa-dialog__chip-dot {
  width: 8px; height: 8px; border-radius: 50%;
}
.qa-dialog__chip-amt { font-weight: 600; color: var(--ink); font-size: 0.78rem; }
.qa-dialog__chip-desc {
  max-width: 12ch;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Form */
.qa-dialog__form { display: flex; flex-direction: column; gap: 0.85rem; }

.qa-dialog__fields {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 0.6rem;
}
@media (max-width: 420px) {
  .qa-dialog__fields { grid-template-columns: 1fr; }
}

.qa-dialog__label {
  display: block;
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 0.3rem;
  font-weight: 600;
}

.qa-dialog__amount-wrap {
  position: relative;
  display: flex;
  align-items: stretch;
}

.qa-dialog__currency {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 32px;
  display: grid;
  place-items: center;
  color: var(--ink-mute);
  font-size: 0.95rem;
  pointer-events: none;
  border-right: 1px solid var(--line);
}

.qa-dialog__amount {
  padding-left: 42px;
  font-size: 1.05rem;
  font-weight: 600;
}

.qa-dialog__income {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.85rem;
  color: var(--ink-soft);
  cursor: pointer;
  margin-top: 0.25rem;
}

.qa-dialog__income input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--brand);
}

.qa-dialog__error {
  background: oklch(72% 0.2 25 / 0.12);
  border: 1px solid oklch(72% 0.2 25 / 0.3);
  color: var(--danger);
  border-radius: var(--r-sm);
  padding: 0.6rem 0.85rem;
  font-size: 0.85rem;
}

.qa-dialog__actions {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
  margin-top: 0.5rem;
}

.qa-dialog__submit { min-width: 130px; }

@media (max-width: 420px) {
  .qa-dialog__actions .btn { flex: 1 1 auto; }
}

@media (prefers-reduced-motion: reduce) {
  .qa-dialog, .qa-dialog__panel { transition: none; }
  .qa-dialog__panel { transform: none; }
}

/* =================================================================
   Toast standalone per quick-add flash
   ================================================================= */

.qa-toast {
  position: fixed;
  left: 50%;
  bottom: 100px;
  transform: translateX(-50%) translateY(20px);
  z-index: 10000;
  padding: 0.7rem 1.2rem;
  border-radius: var(--r-pill);
  font-size: 0.9rem;
  font-weight: 500;
  opacity: 0;
  transition: opacity 220ms var(--ease), transform 220ms var(--ease-soft);
  max-width: 90vw;
  text-align: center;
  pointer-events: none;
  box-shadow: var(--shadow);
}

.qa-toast.is-visible { opacity: 1; transform: translateX(-50%) translateY(0); }

.qa-toast--ok {
  background: oklch(20% 0.05 165);
  color: var(--mint);
  border: 1px solid oklch(82% 0.14 165 / 0.4);
}

.qa-toast--err {
  background: oklch(20% 0.05 25);
  color: var(--danger);
  border: 1px solid oklch(72% 0.2 25 / 0.4);
}

/* =================================================================
   Onboarding notifiche PWA (banner)
   ================================================================= */

.notify-onboard {
  position: fixed;
  left: 50%;
  bottom: 84px;
  transform: translateX(-50%) translateY(40px);
  z-index: 9998;
  width: calc(100vw - 1.5rem);
  max-width: 380px;
  display: flex;
  gap: 0.8rem;
  padding: 1rem 1.1rem;
  background:
    linear-gradient(135deg, oklch(14% 0.018 275 / 0.98), oklch(11% 0.014 275));
  border: 1px solid var(--brand-soft);
  border-radius: var(--r-lg);
  box-shadow:
    var(--shadow-card),
    0 30px 80px -30px oklch(70% 0.2 285 / 0.5);
  opacity: 0;
  transition: opacity 240ms var(--ease), transform 240ms var(--ease-soft);
}

.notify-onboard.is-visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.notify-onboard__icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: oklch(82% 0.14 165 / 0.18);
  color: var(--mint);
  font-size: 1.2rem;
  border: 1px solid oklch(82% 0.14 165 / 0.4);
}

.notify-onboard__body { flex: 1 1 auto; min-width: 0; }

.notify-onboard__title {
  font-weight: 600;
  color: var(--ink);
  font-size: 0.95rem;
  margin: 0 0 0.25rem;
}

.notify-onboard__sub {
  font-size: 0.82rem;
  line-height: 1.45;
  color: var(--ink-soft);
  margin: 0 0 0.7rem;
}

.notify-onboard__actions {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

/* =================================================================
   Pagina /movimenti/scansiona — OCR scontrini
   ================================================================= */

/* Top padding generoso su mobile per non finire sotto la pill navbar
   floating (alta ~70-90px). Aggiungiamo anche il safe-area inset per
   i device con notch. */
.page--scan {
  padding-block:
    max(env(safe-area-inset-top, 0px), clamp(5rem, 14vw, 7rem))
    clamp(2.5rem, 6vw, 5rem);
}

@media (min-width: 760px) {
  .page--scan {
    padding-block:
      max(env(safe-area-inset-top, 0px), clamp(3rem, 6vw, 4.5rem))
      clamp(2.5rem, 6vw, 5rem);
  }
}

.scan-step {
  margin-top: 1.5rem;
  padding: clamp(1.25rem, 4vw, 2rem);
  background:
    linear-gradient(180deg, oklch(14% 0.018 275 / 0.85), oklch(11% 0.014 275));
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
}

.scan-warning {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  margin-bottom: 1.5rem;
  padding: 1rem 1.1rem;
  background: oklch(82% 0.14 75 / 0.1);
  border: 1px solid oklch(82% 0.14 75 / 0.35);
  border-radius: var(--r);
}

.scan-warning__icon {
  flex-shrink: 0;
  font-size: 1.5rem;
  color: var(--warn);
}

.scan-warning__title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.3rem;
  color: var(--ink);
  margin: 0 0 0.5rem;
}

.scan-warning__msg {
  color: var(--ink-soft);
  font-size: 0.95rem;
  line-height: 1.55;
  margin: 0 0 0.85rem;
}

.scan-warning__msg strong { color: var(--ink); font-weight: 600; }

.scan-warning__check {
  margin: 0;
  padding-left: 1.1rem;
  color: var(--ink-soft);
  font-size: 0.88rem;
  line-height: 1.6;
}

.scan-warning__check li::marker { color: var(--brand-soft); }

.scan-step__actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.85rem;
}

.scan-step__alt {
  font-size: 0.85rem;
  color: var(--ink-mute);
  text-decoration: none;
  border-bottom: 1px solid var(--line-strong);
  padding-bottom: 1px;
}

.scan-step__alt:hover { color: var(--ink); }

/* Loader (download + processing) */
.scan-loader {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.85rem;
  padding: 1.5rem 0;
}

.scan-loader__spinner {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 3px solid oklch(28% 0.01 85);
  border-top-color: var(--brand-soft);
  animation: scan-spin 0.9s linear infinite;
}

@keyframes scan-spin { to { transform: rotate(360deg); } }

.scan-loader__title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.3rem;
  color: var(--ink);
  margin: 0;
}

.scan-loader__sub {
  font-size: 0.8rem;
  letter-spacing: 0.12em;
  color: var(--ink-mute);
  margin: 0;
  text-transform: uppercase;
}

/* Camera frame: aspect 3:4 (porta) → permette di vedere tutto lo
   scontrino nel viewport mobile. */
.scan-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 4;
  background: oklch(8% 0.01 275);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 1rem;
}

.scan-frame__video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.scan-frame__canvas { display: none; }

/* L'overlay è il rettangolo VERTICALE da inquadrare — ratio ~1:2,5
   per assomigliare a uno scontrino italiano (es. 8cm × 20cm).
   inset alto/basso piccoli, inset laterali grossi → colonna centrale
   alta e stretta. */
.scan-frame__overlay {
  position: absolute;
  inset: 6% 26%;
  pointer-events: none;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}

.scan-frame__guides {
  position: absolute;
  inset: 0;
}

.scan-frame__guides span {
  position: absolute;
  width: 32px;
  height: 32px;
  border: 3px solid var(--mint);
  filter: drop-shadow(0 0 8px oklch(82% 0.14 165 / 0.5));
}

.scan-frame__guides span:nth-child(1) { top: 0; left: 0; border-right: 0; border-bottom: 0; border-top-left-radius: 6px; }
.scan-frame__guides span:nth-child(2) { top: 0; right: 0; border-left: 0; border-bottom: 0; border-top-right-radius: 6px; }
.scan-frame__guides span:nth-child(3) { bottom: 0; left: 0; border-right: 0; border-top: 0; border-bottom-left-radius: 6px; }
.scan-frame__guides span:nth-child(4) { bottom: 0; right: 0; border-left: 0; border-top: 0; border-bottom-right-radius: 6px; }

.scan-frame__hint {
  position: absolute;
  left: 50%;
  bottom: 10px;
  transform: translateX(-50%);
  background: oklch(0% 0 0 / 0.6);
  color: var(--ink);
  padding: 0.4rem 0.8rem;
  border-radius: var(--r-pill);
  font-size: 0.78rem;
  margin: 0;
  white-space: nowrap;
  max-width: calc(100% - 24px);
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Bottone flash in alto a destra dentro la cornice camera */
.scan-frame__flash {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  background: oklch(0% 0 0 / 0.55);
  border: 1px solid oklch(28% 0.01 85 / 0.7);
  border-radius: 50%;
  color: var(--ink);
  cursor: pointer;
  transition: background var(--t-fast) var(--ease),
              border-color var(--t-fast) var(--ease),
              color var(--t-fast) var(--ease);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

.scan-frame__flash:hover,
.scan-frame__flash:focus-visible {
  background: oklch(0% 0 0 / 0.75);
  outline: none;
}

.scan-frame__flash.is-on {
  background: oklch(82% 0.14 75 / 0.85);
  border-color: var(--warn);
  color: oklch(15% 0.04 75);
  box-shadow: 0 0 16px oklch(82% 0.14 75 / 0.55);
}

.scan-frame__flash.is-on .scan-frame__flash-icon {
  fill: oklch(15% 0.04 75);
}

.scan-capture__actions {
  display: flex;
  gap: 0.6rem;
  justify-content: center;
  margin-bottom: 0.85rem;
}

.scan-capture__hint {
  text-align: center;
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  color: var(--ink-dim);
  margin: 0;
}

/* Review */
.scan-review__title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.6rem;
  color: var(--ink);
  margin: 0 0 1.25rem;
}

.scan-review__preview {
  margin-bottom: 1.25rem;
  border-radius: var(--r);
  overflow: hidden;
  max-height: 240px;
  background: oklch(8% 0.01 275);
}

.scan-review__preview img {
  width: 100%;
  height: 240px;
  object-fit: cover;
  display: block;
}

.scan-review__form { display: flex; flex-direction: column; gap: 1rem; }
.scan-review__field { display: flex; flex-direction: column; gap: 0.4rem; }

.scan-review__items {
  background: oklch(18% 0.02 275 / 0.5);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  padding: 0.85rem 1rem;
}

.scan-review__items summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--ink);
}

.scan-review__items-hint {
  font-size: 0.78rem;
  color: var(--ink-mute);
  margin: 0.5rem 0;
  letter-spacing: 0.04em;
}

.scan-items-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.scan-item__btn {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 0.55rem 0.85rem;
  background: oklch(18% 0.02 275);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  color: var(--ink-soft);
  font-size: 0.85rem;
  cursor: pointer;
  font-family: var(--font-body);
  transition: border-color var(--t-fast), color var(--t-fast);
}

.scan-item__btn:hover { border-color: var(--brand-soft); color: var(--ink); }
.scan-item__amt { font-weight: 600; color: var(--ink); }

.scan-review__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin-top: 0.85rem;
}

.scan-review__error {
  background: oklch(72% 0.2 25 / 0.12);
  border: 1px solid oklch(72% 0.2 25 / 0.3);
  color: var(--danger);
  padding: 0.6rem 0.85rem;
  border-radius: var(--r-sm);
  font-size: 0.85rem;
}

/* Step error */
.scan-error {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.85rem;
  padding: 2rem 1rem;
  text-align: center;
}

.scan-error__icon {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: oklch(72% 0.2 25 / 0.15);
  color: var(--danger);
  font-size: 1.5rem;
  font-weight: 700;
  border: 1px solid oklch(72% 0.2 25 / 0.4);
}

.scan-error__title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.4rem;
  color: var(--ink);
  margin: 0;
}

.scan-error__msg { color: var(--ink-soft); margin: 0; }

/* =================================================================
   Quick-add — barra "Spesa veloce" sul cruscotto
   ================================================================= */

.quick-add {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: 1rem 1.1rem;
  background:
    linear-gradient(180deg, oklch(14% 0.018 275 / 0.85), oklch(11% 0.014 275));
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  margin-bottom: 0.85rem;
}

.quick-add__label {
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-family: var(--font-mono);
}

.quick-add__row {
  display: flex;
  gap: 0.5rem;
  align-items: stretch;
}

.quick-add__input {
  flex: 1 1 auto;
  min-width: 0;
  font-size: 0.95rem;
  padding: 0.7rem 0.85rem;
}

.quick-add__submit {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.7rem 1.1rem;
  font-size: 0.95rem;
}

@media (max-width: 540px) {
  .quick-add__submit-text { display: none; }
  .quick-add__submit { padding: 0.7rem 0.95rem; }
}

.quick-add__hint {
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  color: var(--ink-dim);
  margin: 0;
  line-height: 1.45;
}

.quick-add__hint strong { color: var(--ink-mute); font-weight: 600; }

.quick-add__flash {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  margin-top: 0.5rem;
  padding: 0.6rem 0.85rem;
  border-radius: var(--r-sm);
  font-size: 0.88rem;
  line-height: 1.4;
}

.quick-add__flash--ok {
  background: oklch(82% 0.14 165 / 0.12);
  border: 1px solid oklch(82% 0.14 165 / 0.3);
  color: var(--mint);
}

.quick-add__flash--err {
  background: oklch(72% 0.2 25 / 0.12);
  border: 1px solid oklch(72% 0.2 25 / 0.3);
  color: var(--danger);
}

/* =================================================================
   Chip "Spese frequenti" — one-tap = un movimento
   ================================================================= */

.quick-chips {
  margin-bottom: 0.85rem;
}

.quick-chips__label {
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 0.5rem;
}

.quick-chips__row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.quick-chip { margin: 0; }

.quick-chip__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.5rem 0.85rem;
  background: oklch(18% 0.02 275 / 0.6);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-pill);
  color: var(--ink-soft);
  font-size: 0.82rem;
  cursor: pointer;
  transition: background var(--t-fast) var(--ease),
              border-color var(--t-fast) var(--ease),
              transform var(--t-fast) var(--ease);
}

.quick-chip__btn:hover,
.quick-chip__btn:focus-visible {
  background: oklch(22% 0.02 275 / 0.8);
  border-color: var(--brand-soft);
  color: var(--ink);
  outline: none;
  transform: translateY(-1px);
}

.quick-chip__dot {
  flex-shrink: 0;
  width: 10px;
  height: 10px;
  border-radius: 50%;
}

.quick-chip__desc {
  font-weight: 500;
  max-width: 14ch;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.quick-chip__amt {
  font-weight: 600;
  color: var(--ink);
  font-size: 0.78rem;
}

.dash-quick__primary-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}

.dash-quick__primary-row .btn { flex: 1 1 auto; min-width: 160px; }

/* =================================================================
   Pannello Promemoria push su /profile
   ================================================================= */

.profile-reminders { margin-top: 1.5rem; }

.profile-reminders__lede {
  color: var(--ink-soft);
  font-size: 0.95rem;
  line-height: 1.5;
  margin: 0 0 1.25rem;
}

.reminder-form {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
  padding: 1rem 1.1rem;
  background: oklch(18% 0.02 275 / 0.4);
  border: 1px solid var(--line);
  border-radius: var(--r);
}

.reminder-form__row {
  display: flex;
  gap: 0.5rem;
  align-items: stretch;
}

.reminder-form__select { flex: 1 1 auto; min-width: 0; }

.reminder-device {
  padding: 1rem 1.1rem;
  background: oklch(18% 0.02 275 / 0.4);
  border: 1px solid var(--line);
  border-radius: var(--r);
}

.reminder-device__status {
  font-size: 0.82rem;
  color: var(--ink-soft);
  margin: 0 0 0.75rem;
  letter-spacing: 0.04em;
}

.reminder-device__status strong { color: var(--ink); font-weight: 600; }

.reminder-device__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

.reminder-device__test { display: inline-block; margin: 0; }

.reminder-device__hint {
  font-size: 0.72rem;
  color: var(--ink-dim);
  margin: 0;
  line-height: 1.5;
  letter-spacing: 0.04em;
}

/* =================================================================
   Pagina /premium — paywall + stato Premium attivo.
   La pricing card riusa le classi .plan* della landing. Qui solo:
   - hero introduttivo
   - chip di stato per chi è già Premium
   - FAQ a fisarmonica
   - card "Cosa hai sbloccato" per il caso lifetime/subscription
   ================================================================= */

.premium-page { padding-top: 72px; }

.premium-hero {
  padding: 24px 0 32px;
}

.premium-flash {
  margin: 0 0 1.5rem;
  padding: 0.85rem 1rem;
  border-radius: var(--r);
  font-size: 0.92rem;
  line-height: 1.5;
  border: 1px solid var(--line-strong);
}
.premium-flash strong { color: var(--ink); font-weight: 600; }

.premium-flash--ok {
  background: color-mix(in oklab, var(--mint) 14%, transparent);
  border-color: color-mix(in oklab, var(--mint) 35%, var(--line-strong));
  color: var(--ink);
}
.premium-flash--warn {
  background: color-mix(in oklab, oklch(75% 0.12 70) 14%, transparent);
  border-color: color-mix(in oklab, oklch(75% 0.12 70) 35%, var(--line-strong));
  color: var(--ink-soft);
}

.premium-hero__form { margin-top: 16px; }

.premium-hero__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  color: var(--ink-mute);
  margin: 0 0 1.25rem;
  text-transform: uppercase;
}
.premium-hero__sep { color: var(--brand-soft); }

.premium-hero__title {
  margin: 0 0 1.1rem;
}

.premium-hero__lede {
  font-size: clamp(1rem, 1.6vw, 1.12rem);
  color: var(--ink-soft);
  line-height: 1.6;
  max-width: 56ch;
  margin: 0 0 1.5rem;
}

.premium-hero__chip {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 0.55rem 0.9rem;
  border-radius: var(--r-pill);
  background: oklch(20% 0.018 285 / 0.6);
  border: 1px solid var(--line-strong);
  font-size: 0.92rem;
  color: var(--ink);
}
.premium-hero__chip .mono {
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  color: var(--ink-mute);
  text-transform: uppercase;
}
.premium-hero__chip strong { color: var(--ink); font-weight: 600; }

.premium-hero__chip--lifetime {
  background: linear-gradient(90deg,
    oklch(70% 0.16 285 / 0.18),
    oklch(80% 0.12 165 / 0.16));
  border-color: oklch(60% 0.14 285 / 0.55);
}
.premium-hero__chip--lifetime strong { color: var(--mint); }

.premium-plans {
  padding: 32px 0 80px;
}

.premium-plan__hint {
  margin: 14px 0 0;
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  color: var(--ink-dim);
  line-height: 1.55;
}

/* FAQ ------------------------------------------------------------ */
.premium-faq {
  margin-top: 64px;
}
.premium-faq__title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.6rem, 3vw, 2rem);
  margin: 0 0 1.25rem;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.premium-faq__item {
  border-top: 1px solid var(--line);
  padding: 1rem 0;
}
.premium-faq__item:last-child { border-bottom: 1px solid var(--line); }
.premium-faq__item summary {
  cursor: pointer;
  list-style: none;
  font-size: 1rem;
  color: var(--ink);
  font-weight: 500;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}
.premium-faq__item summary::-webkit-details-marker { display: none; }
.premium-faq__item summary::after {
  content: '+';
  font-family: var(--font-mono);
  font-size: 1.3rem;
  color: var(--brand-soft);
  transition: transform var(--t-fast) var(--ease);
}
.premium-faq__item[open] summary::after {
  content: '−';
  transform: rotate(0);
}
.premium-faq__item p {
  margin: 0.75rem 0 0;
  font-size: 0.92rem;
  color: var(--ink-soft);
  line-height: 1.6;
}

/* Stato Premium attivo (lifetime/subscription) ------------------- */
.premium-active {
  padding: 16px 0 96px;
}

.premium-active__card {
  background:
    radial-gradient(70% 70% at 0% 0%, oklch(72% 0.2 285 / 0.18), transparent 60%),
    var(--bg-elev);
  border: 1px solid oklch(45% 0.12 285);
  border-radius: var(--r-xl);
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.premium-active__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  color: var(--ink-mute);
  margin: 0;
  text-transform: uppercase;
}
.premium-active__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(1.6rem, 3vw, 2rem);
  margin: 0;
  color: var(--ink);
}
.premium-active__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 10px;
}
.premium-active__list li {
  position: relative;
  padding-left: 30px;
  font-size: 0.95rem;
  color: var(--ink-soft);
  line-height: 1.5;
}
.premium-active__list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.4em;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: color-mix(in oklab, var(--mint) 30%, transparent);
  box-shadow: inset 0 0 0 1px var(--mint);
}
.premium-active__cta { margin-top: 8px; }

/* Sezione "Il tuo piano" sulla pagina profilo (solo Free / Subscription;
   i lifetime vedono già il founder-badge in cima). */
.profile-plan {
  padding: 24px;
  margin-bottom: 18px;
  background:
    radial-gradient(70% 70% at 100% 0%, oklch(72% 0.2 285 / 0.12), transparent 55%),
    var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  display: flex;
  flex-direction: column;
  gap: 16px;
}
@media (min-width: 760px) {
  .profile-plan {
    padding: 32px;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 28px;
  }
}

.profile-plan__main { min-width: 0; max-width: 56ch; }

.profile-plan__kicker {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  color: var(--ink-mute);
  margin: 0 0 6px;
  text-transform: uppercase;
}

.profile-plan__name {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(1.4rem, 2.6vw, 1.8rem);
  margin: 0 0 8px;
  color: var(--ink);
  letter-spacing: -0.01em;
}

.profile-plan__lede {
  margin: 0;
  font-size: 0.95rem;
  color: var(--ink-soft);
  line-height: 1.55;
}
.profile-plan__lede strong { color: var(--ink); font-weight: 600; }

.profile-plan__actions {
  display: flex;
  gap: 0.5rem;
  flex-shrink: 0;
}

/* =================================================================
   Limiti del Piano Free — chip "X/Y" sotto al titolo + pannello
   "locked" che sostituisce il form di creazione quando il limite è
   raggiunto. Iniettati nelle pagine /obiettivi e /abbonamenti.
   ================================================================= */
.quota-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 14px 0 0;
  padding: 6px 12px;
  border-radius: var(--r-pill);
  background: oklch(20% 0.018 285 / 0.55);
  border: 1px solid var(--line);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.quota-chip strong {
  font-family: var(--font-mono);
  color: var(--ink);
  font-weight: 600;
  letter-spacing: 0;
}
.quota-chip__sep { color: var(--brand-soft); }

.goals-new--locked {
  background:
    radial-gradient(70% 70% at 100% 0%, oklch(72% 0.2 285 / 0.12), transparent 55%),
    var(--bg-elev);
  border: 1px solid oklch(45% 0.12 285 / 0.55);
  border-radius: var(--r-xl);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
@media (min-width: 760px) {
  .goals-new--locked { padding: 32px; }
}

.locked-panel__lede {
  margin: 0;
  font-size: 0.95rem;
  color: var(--ink-soft);
  line-height: 1.55;
  max-width: 60ch;
}
.locked-panel__lede strong { color: var(--ink); font-weight: 600; }

.locked-panel__actions {
  display: flex;
  gap: 0.5rem;
}

/* ============================================================
   SHARE TARGET — pagina di scelta dopo una condivisione
   (Registralo come spesa · Lo compro o no?)
   ============================================================ */
.page--share { padding-top: 24px; }

.share-preview {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 6px 16px;
  padding: 18px 22px;
  margin: 22px 0 28px;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  background:
    linear-gradient(180deg, oklch(96% 0.03 85 / 0.04), transparent 80%),
    var(--bg-elev);
}
.share-preview__label {
  flex-basis: 100%;
  margin: 0 0 2px;
  font-size: 0.62rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.share-preview__name {
  margin: 0;
  font-size: 1.12rem;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.3;
}
.share-preview__price {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--mint);
}
.share-preview__price--empty { color: var(--ink-mute); font-weight: 500; }

.share-choices {
  display: grid;
  gap: 14px;
}
@media (min-width: 640px) {
  .share-choices { grid-template-columns: 1fr 1fr; }
}

.share-choice {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: start;
  gap: 14px;
  padding: 22px 20px;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  background: var(--bg-elev);
  transition: transform var(--t-fast), border-color var(--t-fast),
              background var(--t-fast), box-shadow var(--t-fast);
}
.share-choice:hover {
  transform: translateY(-2px);
  border-color: var(--line-strong);
  background: var(--bg-elev-2);
  box-shadow: var(--shadow);
}
.share-choice__icon {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border-radius: 14px;
  background: oklch(96% 0.03 85 / 0.06);
  border: 1px solid var(--line);
}
.share-choice--advice .share-choice__icon { color: var(--brand-soft); }
.share-choice--expense .share-choice__icon { color: var(--mint); }
.share-choice__body { display: flex; flex-direction: column; gap: 5px; }
.share-choice__body strong {
  font-size: 1.04rem;
  font-weight: 600;
  color: var(--ink);
}
.share-choice__body span {
  font-size: 0.86rem;
  line-height: 1.45;
  color: var(--ink-mute);
}
.share-choice__arrow {
  align-self: center;
  color: var(--ink-mute);
  font-size: 1.1rem;
  transition: transform var(--t-fast), color var(--t-fast);
}
.share-choice:hover .share-choice__arrow {
  color: var(--ink);
  transform: translateX(3px);
}

.share-foot {
  margin-top: 26px;
  font-size: 0.82rem;
}
.share-foot a { color: var(--ink-mute); }
.share-foot a:hover { color: var(--ink); }

/* ============================================================
   PAYMENT RESULT OVERLAY (stile POS: conferma / errore)
   Mostrato al ritorno da Stripe su /premium?ok=1 o ?canceled=1.
   ============================================================ */
.pay-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  padding: 24px;
}
.pay-overlay.is-leaving { animation: pay-fade-out 0.3s ease forwards; }

.pay-overlay__backdrop {
  position: absolute;
  inset: 0;
  background: oklch(8% 0.01 275 / 0.72);
  backdrop-filter: blur(10px) saturate(120%);
  -webkit-backdrop-filter: blur(10px) saturate(120%);
  animation: pay-fade-in 0.3s ease both;
}

.pay-overlay__card {
  position: relative;
  width: 100%;
  max-width: 400px;
  padding: 38px 30px 30px;
  text-align: center;
  background:
    radial-gradient(120% 80% at 50% -10%, oklch(96% 0.03 85 / 0.06), transparent 60%),
    var(--bg-elev-2);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-card), 0 40px 120px -30px rgb(0 0 0 / 0.8);
  animation: pay-card-in 0.46s cubic-bezier(0.16, 1, 0.3, 1) 0.04s both;
}

/* ----- Sigillo animato (cerchio + glifo) ----- */
.pay-overlay__seal {
  display: grid;
  place-items: center;
  margin: 0 auto 22px;
  width: 132px;
  height: 132px;
  border-radius: 50%;
}
.pay-overlay__mark { display: block; overflow: visible; }
.pay-overlay__ring {
  stroke-dasharray: 327;
  stroke-dashoffset: 327;
  transform-origin: 60px 60px;
  transform: rotate(-90deg);
  animation: pay-ring-draw 0.55s ease 0.16s forwards;
}
.pay-overlay__glyph {
  stroke-dasharray: 90;
  stroke-dashoffset: 90;
  animation: pay-glyph-draw 0.34s ease 0.62s forwards;
}
.pay-overlay__glyph--2 { animation-delay: 0.82s; }

.pay-overlay--ok .pay-overlay__ring   { stroke: var(--mint); }
.pay-overlay--ok .pay-overlay__glyph  { stroke: var(--mint-strong); }
.pay-overlay--ok .pay-overlay__seal {
  box-shadow: 0 0 0 1px color-mix(in oklab, var(--mint) 30%, transparent),
              0 0 60px -6px color-mix(in oklab, var(--mint) 45%, transparent);
  animation: pay-seal-pulse 0.6s ease 0.7s both;
}
.pay-overlay--fail .pay-overlay__ring  { stroke: var(--danger); }
.pay-overlay--fail .pay-overlay__glyph { stroke: var(--danger); }
.pay-overlay--fail .pay-overlay__seal {
  box-shadow: 0 0 0 1px color-mix(in oklab, var(--danger) 30%, transparent),
              0 0 56px -8px color-mix(in oklab, var(--danger) 40%, transparent);
  animation: pay-seal-shake 0.4s ease 0.62s both;
}

.pay-overlay__kicker {
  margin: 0 0 8px;
  font-size: 0.64rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  animation: pay-text-in 0.4s ease 0.5s both;
}
.pay-overlay__title {
  margin: 0 0 10px;
  font-family: var(--font-display);
  font-size: 2rem;
  line-height: 1.1;
  color: var(--ink);
  animation: pay-text-in 0.4s ease 0.58s both;
}
.pay-overlay__text {
  margin: 0 auto 24px;
  max-width: 32ch;
  font-size: 0.94rem;
  line-height: 1.5;
  color: var(--ink-soft);
  animation: pay-text-in 0.4s ease 0.66s both;
}
.pay-overlay__cta { animation: pay-text-in 0.4s ease 0.74s both; }

@keyframes pay-fade-in  { from { opacity: 0; } to { opacity: 1; } }
@keyframes pay-fade-out { from { opacity: 1; } to { opacity: 0; } }
@keyframes pay-card-in {
  from { opacity: 0; transform: translateY(18px) scale(0.94); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes pay-ring-draw  { to { stroke-dashoffset: 0; } }
@keyframes pay-glyph-draw { to { stroke-dashoffset: 0; } }
@keyframes pay-text-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes pay-seal-pulse {
  0%   { transform: scale(1); }
  40%  { transform: scale(1.06); }
  100% { transform: scale(1); }
}
@keyframes pay-seal-shake {
  0%, 100% { transform: translateX(0); }
  25%      { transform: translateX(-6px); }
  75%      { transform: translateX(6px); }
}

@media (prefers-reduced-motion: reduce) {
  .pay-overlay__backdrop,
  .pay-overlay__card,
  .pay-overlay__kicker,
  .pay-overlay__title,
  .pay-overlay__text,
  .pay-overlay__cta,
  .pay-overlay--ok .pay-overlay__seal,
  .pay-overlay--fail .pay-overlay__seal {
    animation: none;
  }
  .pay-overlay__ring,
  .pay-overlay__glyph { stroke-dashoffset: 0; animation: none; }
}

/* =================================================================
   Referral · "Invita amici" (passaparola fra utenti)
   Distinto dalla pagina invito del fondatore.
   ================================================================= */
.page--referral { padding: clamp(1.5rem, 4vw, 3rem) 0 5rem; }
.referral { max-width: 760px; }

.referral__head { margin-bottom: clamp(1.5rem, 4vw, 2.5rem); }
.referral__kicker {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-mute); margin: 0 0 1rem;
}
.referral__dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--mint-strong);
  box-shadow: 0 0 12px 1px var(--mint);
}
.referral__title {
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(2rem, 6vw, 3rem); line-height: 1.05;
  letter-spacing: -0.02em; margin: 0 0 1rem; color: var(--ink);
}
.referral__title em { font-style: italic; color: var(--brand-soft); }
.referral__lede {
  font-size: clamp(1rem, 2.4vw, 1.12rem); line-height: 1.6;
  color: var(--ink-soft); max-width: 56ch; margin: 0;
}
.referral__lede strong { color: var(--ink); }

.referral__notice {
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: var(--r-lg); padding: 1.5rem; color: var(--ink-soft);
}

/* --- Card condivisione --- */
.referral__share {
  background:
    radial-gradient(120% 140% at 0% 0%, oklch(70% 0.2 285 / 0.12), transparent 55%),
    var(--bg-elev);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl); padding: clamp(1.25rem, 3.5vw, 2rem);
  box-shadow: var(--shadow);
  margin-bottom: clamp(1.25rem, 3vw, 2rem);
}
.referral__share-label {
  font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-mute); margin: 0 0 0.4rem;
}
.referral__code {
  font-size: clamp(1.6rem, 6vw, 2.4rem); font-weight: 600;
  letter-spacing: 0.22em; color: var(--ink); margin: 0 0 1.25rem;
}
.referral__link-row { display: flex; gap: 0.6rem; flex-wrap: wrap; }
.referral__link-input {
  flex: 1 1 220px; min-width: 0;
  background: var(--bg); border: 1px solid var(--line);
  border-radius: var(--r); padding: 0.8rem 1rem;
  color: var(--ink-soft); font-size: 0.9rem;
}
.referral__link-input:focus-visible {
  outline: 2px solid var(--brand); outline-offset: 2px;
}
.referral__copy { flex: 0 0 auto; white-space: nowrap; }
.referral__copy.is-done { background: var(--mint-strong); border-color: var(--mint-strong); }
.referral__share-native {
  display: inline-flex; align-items: center; gap: 0.4rem;
  margin-top: 0.85rem; background: none; border: none;
  color: var(--brand-soft); font: inherit; font-size: 0.92rem;
  cursor: pointer; padding: 0.25rem 0;
}
.referral__share-native:hover { text-decoration: underline; }

/* --- Bento statistiche --- */
.referral__bento {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.75rem;
  margin-bottom: clamp(1.25rem, 3vw, 2rem);
}
.referral__stat {
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: var(--r-lg); padding: 1.1rem 1.2rem;
}
.referral__stat--accent {
  grid-column: 1 / -1;
  background:
    radial-gradient(120% 140% at 100% 0%, oklch(82% 0.14 165 / 0.14), transparent 55%),
    var(--bg-elev);
  border-color: oklch(76% 0.18 165 / 0.4);
}
.referral__stat-label {
  font-size: 0.68rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-mute); margin: 0 0 0.35rem;
}
.referral__stat-value {
  font-size: clamp(1.6rem, 5vw, 2.2rem); font-weight: 600;
  color: var(--ink); margin: 0; line-height: 1;
}
.referral__stat--accent .referral__stat-value { color: var(--mint-strong); }
.referral__stat-sub { font-size: 0.78rem; color: var(--ink-mute); margin: 0.4rem 0 0; }

/* --- Barra progresso --- */
.referral__progress {
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: var(--r-lg); padding: 1.1rem 1.25rem;
  margin-bottom: clamp(1.25rem, 3vw, 2rem);
}
.referral__progress-head {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 1rem; margin-bottom: 0.75rem;
}
.referral__progress-head p { margin: 0; font-size: 0.92rem; color: var(--ink-soft); }
.referral__progress-head strong { color: var(--ink); }
.referral__bar {
  height: 10px; border-radius: var(--r-pill);
  background: var(--bg); overflow: hidden; border: 1px solid var(--line);
}
.referral__bar-fill {
  display: block; height: 100%; border-radius: var(--r-pill);
  background: linear-gradient(90deg, var(--brand), var(--mint-strong));
  transition: width var(--t) var(--ease);
}
.referral__progress--max p { margin: 0; color: var(--mint-strong); font-size: 0.95rem; }

/* --- Traguardi & amici --- */
.referral__section-title {
  font-family: var(--font-display); font-weight: 400;
  font-size: 1.4rem; color: var(--ink); margin: 0 0 0.9rem;
}
.referral__milestones, .referral__friends { margin-bottom: clamp(1.5rem, 4vw, 2.5rem); }
.referral__milestone-list, .referral__friend-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.5rem; }
.referral__milestone {
  display: flex; align-items: center; gap: 0.85rem;
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: var(--r); padding: 0.85rem 1.1rem;
}
.referral__milestone.is-reached {
  border-color: oklch(76% 0.18 165 / 0.45);
  background:
    linear-gradient(90deg, oklch(82% 0.14 165 / 0.08), transparent 60%),
    var(--bg-elev);
}
.referral__milestone-icon {
  flex: 0 0 1.6rem; height: 1.6rem; display: grid; place-items: center;
  border-radius: 50%; background: var(--bg); color: var(--ink-mute);
  font-size: 0.8rem; border: 1px solid var(--line);
}
.referral__milestone.is-reached .referral__milestone-icon {
  background: var(--mint-strong); color: var(--bg); border-color: var(--mint-strong);
}
.referral__milestone-friends { color: var(--ink); font-size: 0.92rem; }
.referral__milestone-bonus { margin-left: auto; color: var(--brand-soft); font-size: 0.88rem; }

.referral__friend {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: var(--r); padding: 0.8rem 1.1rem;
}
.referral__friend-name { color: var(--ink-soft); font-size: 0.94rem; }
.referral__friend-badge {
  font-size: 0.72rem; letter-spacing: 0.04em; padding: 0.25rem 0.6rem;
  border-radius: var(--r-pill); white-space: nowrap;
}
.referral__friend-badge--ok { background: oklch(76% 0.18 165 / 0.18); color: var(--mint-strong); }
.referral__friend-badge--wait { background: oklch(82% 0.14 75 / 0.16); color: var(--warn); }
.referral__friend-badge--void { background: oklch(72% 0.2 25 / 0.14); color: var(--danger); }

.referral__empty { color: var(--ink-mute); font-size: 0.95rem; margin: 0; }
.referral__footnote {
  font-size: 0.74rem; color: var(--ink-dim); line-height: 1.5;
  margin: 0; max-width: 60ch;
}

@media (min-width: 560px) {
  .referral__bento { grid-template-columns: repeat(3, 1fr); }
  .referral__stat--accent { grid-column: auto; }
}

/* =================================================================
   Utility — 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;
}

/* =================================================================
   Pagina /feedback — lascia un parere
   ================================================================= */
.page--feedback { padding-top: clamp(2rem, 6vw, 4rem); padding-bottom: 5rem; }

.feedback { max-width: 720px; }

.feedback__head { margin-bottom: 2rem; }

.feedback__kicker {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-mute); margin: 0 0 1rem;
}
.feedback__dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--brand-soft);
  box-shadow: 0 0 12px var(--brand-soft);
}

.feedback__title {
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(2rem, 7vw, 3.2rem); line-height: 1.05;
  letter-spacing: -0.02em; color: var(--ink); margin: 0 0 1rem;
}
.feedback__title em { font-style: italic; color: var(--brand-soft); }

.feedback__lede {
  font-size: 1.02rem; line-height: 1.6; color: var(--ink-soft);
  margin: 0; max-width: 58ch;
}

.feedback__thanks {
  display: flex; align-items: center; gap: 14px;
  padding: 1rem 1.2rem; margin-bottom: 1.5rem;
  background: oklch(76% 0.18 165 / 0.1);
  border: 1px solid oklch(76% 0.18 165 / 0.3);
  border-radius: var(--r);
}
.feedback__thanks-icon {
  flex-shrink: 0; width: 34px; height: 34px; border-radius: 50%;
  display: grid; place-items: center;
  background: oklch(76% 0.18 165 / 0.2); color: var(--mint-strong);
  font-size: 1.1rem;
}
.feedback__thanks-title { margin: 0; font-weight: 600; color: var(--ink); }
.feedback__thanks-sub { margin: 2px 0 0; font-size: 0.9rem; color: var(--ink-mute); }

.feedback__error {
  padding: 0.9rem 1.1rem; margin-bottom: 1.5rem;
  background: oklch(72% 0.2 25 / 0.12);
  border: 1px solid oklch(72% 0.2 25 / 0.35);
  border-radius: var(--r); color: var(--ink-soft); font-size: 0.92rem;
}

.feedback__card {
  background: linear-gradient(180deg, oklch(14% 0.018 275 / 0.85), oklch(11% 0.014 275));
  border: 1px solid var(--line-strong);
  border-radius: var(--r-lg);
  padding: clamp(1.25rem, 4vw, 2rem);
}

.feedback__form { display: flex; flex-direction: column; gap: 1.4rem; }

.feedback__optional {
  font-family: var(--font-body); text-transform: none; letter-spacing: 0;
  font-size: 0.72rem; color: var(--ink-dim);
}

.feedback__rating { display: flex; gap: 4px; }
.feedback__rating-opt { cursor: pointer; line-height: 1; }
.feedback__rating-opt input { position: absolute; opacity: 0; pointer-events: none; }
.feedback__rating-star {
  font-size: 1.7rem; color: var(--ink-dim);
  transition: color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
  display: inline-block;
}
.feedback__rating-opt:hover .feedback__rating-star { transform: scale(1.12); }
/* Riempimento "fino a" la stella scelta: usiamo :has sui fratelli successivi. */
.feedback__rating:hover .feedback__rating-opt:hover .feedback__rating-star,
.feedback__rating-opt:has(input:checked) .feedback__rating-star {
  color: var(--warn);
}
.feedback__rating-opt:has(~ .feedback__rating-opt input:checked) .feedback__rating-star {
  color: var(--warn);
}
.feedback__rating-opt:hover ~ .feedback__rating-opt .feedback__rating-star {
  color: var(--ink-dim);
}

.feedback__textarea { resize: vertical; min-height: 120px; line-height: 1.55; }

.feedback__actions {
  display: flex; gap: 0.7rem; flex-wrap: wrap; align-items: center;
}

.feedback__footnote {
  margin: 1.5rem 0 0; font-size: 0.74rem; color: var(--ink-dim);
  line-height: 1.5; max-width: 60ch;
}

@media (max-width: 480px) {
  .feedback__actions { flex-direction: column; align-items: stretch; }
  .feedback__actions .btn { width: 100%; justify-content: center; }
}

/* =================================================================
   Popup feedback (modale che appare dopo un po' di utilizzo)
   ================================================================= */
.feedback-pop {
  position: fixed; inset: 0; z-index: 9998;
  display: flex; align-items: flex-end; justify-content: center;
  padding: 1rem;
  opacity: 0; transition: opacity 200ms var(--ease);
}
.feedback-pop.is-open { opacity: 1; }
.feedback-pop.is-closing { opacity: 0; }

.feedback-pop__backdrop {
  position: absolute; inset: 0;
  background: oklch(0% 0 0 / 0.6);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
}

.feedback-pop__panel {
  position: relative; width: 100%; max-width: 440px;
  background: linear-gradient(180deg, oklch(15% 0.02 275 / 0.99), oklch(11% 0.014 275));
  border: 1px solid var(--line-strong);
  border-radius: var(--r-lg);
  padding: clamp(1.3rem, 4vw, 1.7rem);
  box-shadow: var(--shadow-card);
  transform: translateY(16px) scale(0.99);
  transition: transform 240ms var(--ease-soft);
}
.feedback-pop.is-open .feedback-pop__panel { transform: translateY(0) scale(1); }
.feedback-pop.is-closing .feedback-pop__panel { transform: translateY(10px) scale(0.99); }

.feedback-pop__x {
  position: absolute; top: 10px; right: 12px;
  width: 32px; height: 32px; border: none; background: transparent;
  color: var(--ink-mute); font-size: 1.5rem; line-height: 1; cursor: pointer;
  border-radius: 50%; transition: color var(--t-fast), background var(--t-fast);
}
.feedback-pop__x:hover { color: var(--ink); background: oklch(96% 0.03 85 / 0.07); }

.feedback-pop__kicker {
  font-size: 0.68rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--brand-soft); margin: 0 0 0.5rem;
}
.feedback-pop__title {
  font-family: var(--font-display); font-weight: 400; font-style: italic;
  font-size: clamp(1.4rem, 5vw, 1.7rem); line-height: 1.12;
  color: var(--ink); margin: 0 0 0.5rem; letter-spacing: -0.01em;
}
.feedback-pop__sub {
  font-size: 0.92rem; line-height: 1.5; color: var(--ink-soft); margin: 0 0 1rem;
}

.feedback-pop__rating { display: flex; gap: 4px; margin-bottom: 0.9rem; }
.feedback-pop__star {
  border: none; background: transparent; cursor: pointer;
  font-size: 1.6rem; line-height: 1; color: var(--ink-dim); padding: 0 2px;
  transition: color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.feedback-pop__star:hover { transform: scale(1.12); }
.feedback-pop__star.is-on { color: var(--warn); }

.feedback-pop__textarea { resize: vertical; min-height: 76px; line-height: 1.5; }

.feedback-pop__err {
  margin: 0.5rem 0 0; font-size: 0.82rem; color: var(--danger);
}

.feedback-pop__actions {
  display: flex; gap: 0.6rem; margin-top: 1rem; flex-wrap: wrap;
}
.feedback-pop__actions .btn { flex: 1 1 auto; justify-content: center; }

.feedback-pop__never {
  display: block; width: 100%; margin-top: 0.8rem;
  border: none; background: transparent; cursor: pointer;
  font-family: var(--font-body); font-size: 0.78rem; color: var(--ink-dim);
  transition: color var(--t-fast);
}
.feedback-pop__never:hover { color: var(--ink-mute); text-decoration: underline; }

.feedback-pop__thanks { text-align: center; padding: 1.5rem 0.5rem; }
.feedback-pop__thanks-icon {
  display: inline-grid; place-items: center;
  width: 48px; height: 48px; border-radius: 50%; margin-bottom: 0.8rem;
  background: oklch(76% 0.18 165 / 0.2); color: var(--mint-strong); font-size: 1.4rem;
}
.feedback-pop__thanks-title {
  font-family: var(--font-display); font-style: italic; font-size: 1.5rem;
  color: var(--ink); margin: 0 0 0.3rem;
}
.feedback-pop__thanks-sub { font-size: 0.9rem; color: var(--ink-mute); margin: 0; }

@media (min-width: 560px) {
  .feedback-pop { align-items: center; }
}
@media (prefers-reduced-motion: reduce) {
  .feedback-pop, .feedback-pop__panel { transition: opacity 120ms linear; }
  .feedback-pop__panel { transform: none; }
}

/* =================================================================
   Admin — elenco feedback
   ================================================================= */
.admin-feedback__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.9rem; }

.admin-feedback__item {
  padding: 1rem 1.1rem;
  background: oklch(15% 0.012 275 / 0.6);
  border: 1px solid var(--line-strong);
  border-radius: var(--r);
}
.admin-feedback__item--new { border-color: oklch(82% 0.14 75 / 0.35); }
.admin-feedback__item--archived { opacity: 0.6; }

.admin-feedback__meta {
  display: flex; align-items: center; gap: 0.7rem; flex-wrap: wrap;
  margin-bottom: 0.6rem; font-size: 0.78rem;
}
.admin-feedback__src { color: var(--ink-dim); }
.admin-feedback__rating { color: var(--warn); letter-spacing: 1px; }
.admin-feedback__rating-off { color: var(--ink-dim); }
.admin-feedback__when { color: var(--ink-mute); margin-left: auto; }

.admin-feedback__msg {
  margin: 0 0 0.7rem; color: var(--ink); line-height: 1.55;
  white-space: pre-wrap; word-break: break-word;
}

.admin-feedback__foot {
  display: flex; align-items: center; justify-content: space-between;
  gap: 0.8rem; flex-wrap: wrap;
}
.admin-feedback__author { font-size: 0.8rem; color: var(--ink-mute); }
.admin-feedback__actions { display: flex; gap: 0.5rem; }
.admin-feedback__actions form { margin: 0; }

