/* WealthIntelligence — design tokens (forked from dopo.me Foundation) */
:root {
  --jade-0:#F2F5F6; --jade-100:#E2E9EA; --jade-200:#C1D0D2; --jade-300:#98B3B8;
  --jade-400:#63939A; --jade-500:#307D86; --jade-600:#27666D; --jade-700:#205359; --jade-800:#173B3F;

  --sky-0:#F9FCFD; --sky-100:#F2F8F9; --sky-200:#E4F1F4; --sky-300:#D5EAEE;
  --sky-400:#BDDEE5; --sky-500:#B2D1D8; --sky-600:#9AB5BB; --sky-700:#7E9499; --sky-800:#59696C;

  --gr-0:#F9FCFD; --gr-100:#E7E8E9; --gr-200:#CFD2D2; --gr-300:#B7BBBC;
  --gr-400:#9FA5A5; --gr-500:#878E8F; --gr-600:#6F7779; --gr-700:#576162; --gr-800:#3F4A4C; --gr-900:#0F1D1F;

  --olive-0:#F3F7F4; --olive-100:#E3EDE6; --olive-200:#C2DACA; --olive-300:#8CBE9E;
  --olive-400:#3AA166; --olive-500:#34915C; --olive-600:#2F8353; --olive-700:#276B44; --olive-800:#1B4C30;

  --red-0:#FBF3F3; --red-100:#F8E2E2; --red-200:#EDC2C2; --red-300:#E0B8B8;
  --red-400:#E43737; --red-500:#D43737; --red-600:#B22D2D; --red-700:#8B2525; --red-800:#641A1A;

  --yel-0:#FDFBF2; --yel-100:#FBF1E2; --yel-200:#F7E1C0; --yel-300:#F2C867;
  --yel-400:#EDB526; --yel-500:#D5A322; --yel-600:#C1941F; --yel-700:#8E7016; --yel-800:#705512;

  --paper:#FAFAF7; --paper-2:#F4F2EC;
  --ink:#0F1D1F; --ink-muted:#576162;
  --line:#E7E4DC; --line-strong:#D4D0C5;
  --accent: var(--olive-500);
  --accent-soft:#E9EFE5;
  --accent-ink: var(--olive-800);

  /* Trigger semantic colors */
  --trigger-permanent: var(--jade-700);   /* decesso / inf. permanente */
  --trigger-temporary: var(--yel-600);    /* inf. temporanea */
  --trigger-permanent-soft:#E2E9EA;
  --trigger-temporary-soft:#FBF1E2;

  --f-sans:'Inter', ui-sans-serif, system-ui, -apple-system, sans-serif;
  --f-serif:'Spectral','Cormorant Garamond', Georgia, serif;
  --f-mono:'JetBrains Mono', ui-monospace, monospace;

  --r-sm:6px; --r-md:10px; --r-lg:16px; --r-xl:24px;

  --s-shadow:0 1px 2px rgba(15,29,31,.05), 0 1px 0 rgba(15,29,31,.02);
  --s-shadow-md:0 6px 24px -8px rgba(15,29,31,.12), 0 1px 0 rgba(15,29,31,.03);
  --s-shadow-lg:0 20px 60px -20px rgba(15,29,31,.20);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--paper); color:var(--ink); font-family:var(--f-sans);
  font-size:15px; line-height:1.45;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
#root{min-height:100vh}

/* Typography */
.t-display{font-family:var(--f-serif);font-weight:400;font-style:italic;letter-spacing:-0.01em;line-height:1.05}
.t-h1{font-family:var(--f-serif);font-weight:400;font-style:italic;letter-spacing:-0.005em;line-height:1.1}
.t-eyebrow{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted);font-weight:500}
.t-mono{font-family:var(--f-mono);font-size:11px;letter-spacing:.02em;color:var(--ink-muted)}
.t-num{font-family:var(--f-serif);font-style:italic;font-weight:400}

body[data-serif="off"] .t-display,
body[data-serif="off"] .t-h1,
body[data-serif="off"] .t-num { font-family: var(--f-sans); font-style: normal; font-weight: 500; letter-spacing: -0.02em; }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 16px; border-radius:999px;
  font:inherit; font-weight:500; font-size:14px;
  border:1px solid transparent; cursor:pointer;
  transition:all .18s ease; white-space:nowrap;
}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--gr-800)}
.btn-secondary{background:var(--paper);color:var(--ink);border-color:var(--line-strong)}
.btn-secondary:hover{background:var(--paper-2)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:var(--olive-600)}
.btn-ghost{background:transparent;color:var(--ink-muted)}
.btn-ghost:hover{background:var(--paper-2);color:var(--ink)}
.btn-warn{background:var(--yel-600);color:#fff}
.btn-warn:hover{background:var(--yel-700)}
.btn-danger{background:var(--red-600);color:#fff}
.btn-danger:hover{background:var(--red-700)}
.btn-sm{padding:6px 12px;font-size:13px}
.btn-icon{padding:8px;border-radius:10px}

/* Chips */
.chip{
  display:inline-flex; align-items:center; gap:6px;
  padding:4px 10px; border-radius:999px;
  font-size:12px; font-weight:500;
  background:var(--paper-2); color:var(--ink-muted);
  border:1px solid var(--line);
}
.chip-solid{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.chip-accent{background:var(--accent-soft);color:var(--accent-ink);border-color:transparent}
.chip-warn{background:var(--trigger-temporary-soft);color:var(--trigger-temporary);border-color:transparent}
.chip-muted{background:var(--gr-100);color:var(--ink-muted);border-color:transparent}
.chip-permanent{background:var(--trigger-permanent-soft);color:var(--trigger-permanent);border-color:transparent}
.chip-temporary{background:var(--trigger-temporary-soft);color:var(--trigger-temporary);border-color:transparent}

/* Cards */
.card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); }
.card-paper{background:var(--paper);border:1px solid var(--line)}
.divider{height:1px;background:var(--line);border:0;margin:0}

/* Inputs */
.input{
  width:100%; padding:10px 14px; border-radius:10px;
  border:1px solid var(--line-strong); background:#fff;
  font:inherit; font-size:14px; color:var(--ink);
  transition:border .15s;
}
.input:focus{outline:0;border-color:var(--ink)}
.input-search{ background:var(--paper-2); border-color:transparent; padding-left:38px; }

/* Sidebar nav */
.nav-link{
  display:flex; align-items:center; gap:12px;
  padding:10px 14px; border-radius:10px;
  color:var(--ink-muted); font-weight:500; font-size:14px;
  text-decoration:none; cursor:pointer;
  transition:all .15s; position:relative;
}
.nav-link:hover{background:rgba(15,29,31,.04);color:var(--ink)}
.nav-link.active{background:var(--ink);color:var(--paper)}
.nav-link .dot{width:6px;height:6px;border-radius:50%;background:var(--red-500);position:absolute;right:14px}

/* Monogram */
.mono{
  display:inline-flex; align-items:center; justify-content:center;
  width:40px; height:40px; border-radius:50%;
  font-weight:600; font-size:14px; color:#fff;
  letter-spacing:-.01em; flex-shrink:0;
}
.mono-sm{width:28px;height:28px;font-size:11px}
.mono-lg{width:56px;height:56px;font-size:18px}
.mono-xl{width:96px;height:96px;font-size:28px}
.mono-stack{display:flex}
.mono-stack .mono{box-shadow:0 0 0 2px var(--paper);margin-left:-10px}
.mono-stack .mono:first-child{margin-left:0}

/* Scrollbar */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:8px}
::-webkit-scrollbar-track{background:transparent}

/* Layout grid */
.app{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.main{padding:40px 56px 80px;max-width:1400px;margin:0 auto;width:100%}

/* Utility */
.row{display:flex;align-items:center;gap:12px}
.col{display:flex;flex-direction:column;gap:12px}
.grow{flex:1}
.muted{color:var(--ink-muted)}
.hairline{border-bottom:1px solid var(--line)}

/* Tweaks panel */
.tweaks{
  position:fixed;bottom:24px;right:24px;z-index:80;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--s-shadow-md);
  padding:16px;width:260px; font-size:13px;
}
.tweaks h4{margin:0 0 10px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted);font-weight:500}
.tweak-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0}
.toggle{ display:inline-flex;background:var(--paper-2);border-radius:999px;padding:2px; }
.toggle button{
  padding:4px 12px;border-radius:999px;border:0;background:transparent;
  font:inherit;font-size:12px;color:var(--ink-muted);cursor:pointer;
}
.toggle button.on{background:#fff;color:var(--ink);box-shadow:0 1px 2px rgba(0,0,0,.08)}

/* Drawer / modal */
.backdrop{ position:fixed;inset:0;background:rgba(15,29,31,.32);z-index:90; backdrop-filter:blur(2px); }
.drawer{
  position:fixed;top:0;right:0;bottom:0;width:min(560px,92vw);
  background:var(--paper);z-index:91;
  box-shadow:var(--s-shadow-lg);
  overflow-y:auto; border-left:1px solid var(--line);
}
.modal{
  position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);
  background:var(--paper);border-radius:18px;z-index:91;
  width:min(520px,92vw);max-height:88vh;overflow-y:auto;
  box-shadow:var(--s-shadow-lg);
  border:1px solid var(--line);
}

/* Tables */
.tbl{width:100%;border-collapse:separate;border-spacing:0}
.tbl th{
  text-align:left;font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-muted);font-weight:500;
  padding:12px 16px;border-bottom:1px solid var(--line);
}
.tbl td{padding:14px 16px;border-bottom:1px solid var(--line);font-size:14px}
.tbl tr:hover td{background:var(--paper-2);cursor:pointer}
.tbl tr:last-child td{border-bottom:0}

/* Progress */
.progress{height:4px;background:var(--gr-100);border-radius:999px;overflow:hidden}
.progress > div{height:100%;background:var(--accent);border-radius:999px;transition:width .4s}

/* Vault matrix */
.matrix{
  width:100%; border-collapse:separate; border-spacing:0;
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  overflow:hidden;
}
.matrix th, .matrix td{
  padding:12px 14px; border-bottom:1px solid var(--line);
  font-size:13px; vertical-align:middle;
}
.matrix thead th{
  position:sticky; top:0; background:var(--paper-2);
  font-size:10px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-muted); font-weight:500;
  text-align:center;
}
.matrix thead th.head-cassetta{ text-align:left; min-width:240px; }
.matrix thead th.head-trigger{ min-width:140px; }
.matrix thead th.head-actions{ min-width:120px; }
.matrix tbody td.cell-cassetta{
  text-align:left;
  background:var(--paper);
  border-right:1px solid var(--line);
}
.matrix tbody td.cell-person{
  text-align:center;
  border-left:1px solid var(--line);
  cursor:pointer;
  user-select:none;
  transition:background .12s;
}
.matrix tbody td.cell-person:hover{ background:var(--paper-2); }
.matrix tbody td.cell-person.on{ background:var(--accent-soft); }
.matrix tbody tr:last-child td{border-bottom:0}

.cell-dot{
  display:inline-block; width:14px; height:14px; border-radius:4px;
  border:1.5px solid var(--line-strong); background:#fff;
  vertical-align:middle;
}
.cell-dot.on{ background:var(--accent); border-color:var(--accent); }
.cell-dot.on::after{ content:""; display:block; width:5px; height:9px; margin:0 auto; margin-top:1px; border-right:2px solid #fff; border-bottom:2px solid #fff; transform:rotate(45deg); }

.matrix-person-head{
  display:flex; flex-direction:column; align-items:center; gap:6px;
}

/* Cassetta cell */
.cassetta-row{ display:flex; gap:12px; align-items:center; }
.cassetta-icon{
  width:38px; height:38px; border-radius:10px;
  display:inline-flex; align-items:center; justify-content:center;
  color:#fff; font-size:18px; font-weight:600; flex-shrink:0;
}
.cassetta-name{ font-weight:500; font-size:14px; }
.cassetta-meta{ font-size:11px; color:var(--ink-muted); margin-top:2px; }

/* Trigger badge */
.trigger-badge{
  display:inline-flex; align-items:center; gap:6px;
  padding:4px 10px; border-radius:999px;
  font-size:11px; font-weight:500; letter-spacing:.02em;
  border:1px solid transparent;
}
.trigger-badge.permanent{ background:var(--trigger-permanent-soft); color:var(--trigger-permanent); }
.trigger-badge.temporary{ background:var(--trigger-temporary-soft); color:var(--trigger-temporary); }
.trigger-dot{ width:7px; height:7px; border-radius:50%; }
.trigger-dot.permanent{ background:var(--trigger-permanent); }
.trigger-dot.temporary{ background:var(--trigger-temporary); }

/* Vault status pill */
.status-pill{
  display:inline-flex; align-items:center; gap:6px;
  padding:3px 10px; border-radius:999px;
  font-size:11px; font-weight:500;
  background:var(--paper-2); color:var(--ink-muted);
  border:1px solid var(--line);
}
.status-pill.active{
  background:var(--red-100); color:var(--red-700);
  border-color:transparent;
}
.status-pill.active .trigger-dot{
  background:var(--red-500);
  box-shadow:0 0 0 3px rgba(228,55,55,.18);
}

/* Animations */
@keyframes fadeSlide { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:none} }
.fade-in{animation:fadeSlide .25s ease-out}

/* Empty state card */
.empty-state{
  padding:48px; text-align:center; color:var(--ink-muted);
  background:#fff; border:1px dashed var(--line-strong); border-radius:var(--r-lg);
}
