/* dopo.me — design tokens */
:root {
  --jade-400:#63939A; --jade-500:#307D86; --jade-600:#27666D; --jade-700:#205359; --jade-800:#173B3F;
  --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-400:#E43737; --red-500:#D43737; --red-600:#B22D2D;
  --yel-100:#FBF1E2; --yel-400:#EDB526; --yel-700:#8E7016;
  --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);
  --destiny-people:var(--olive-500); --destiny-oblio:var(--gr-500); --destiny-hidden:var(--jade-700);
  --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}
#root{min-height:100vh}
.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}
.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-ghost{background:transparent;color:var(--ink-muted)}
.btn-ghost:hover{background:var(--paper-2);color:var(--ink)}
.btn-sm{padding:6px 12px;font-size:13px}
.btn-icon{padding:8px;border-radius:10px}
.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:#FBF1E2;color:#8E7016;border-color:transparent}
.chip-muted{background:var(--gr-100);color:var(--ink-muted);border-color:transparent}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg)}
.card-paper{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg)}
.divider{height:1px;background:var(--line);border:0;margin:0}
.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}
.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)}
.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}
.destiny{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-muted)}
.destiny::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--gr-300)}
.destiny[data-d="people"]::before{background:var(--destiny-people)}
.destiny[data-d="oblio"]::before{background:var(--destiny-oblio)}
.destiny[data-d="hidden"]::before{background:var(--destiny-hidden)}
.destiny[data-d="none"]::before{background:var(--red-400);box-shadow:0 0 0 3px rgba(228,55,55,.15)}
.kind-tag{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:6px;font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;background:rgba(255,255,255,.7);backdrop-filter:blur(8px);color:var(--ink);border:1px solid rgba(15,29,31,.08)}
.ruled{background-image:repeating-linear-gradient(to bottom,transparent 0 25px,rgba(15,29,31,.08) 25px 26px);padding-top:4px}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:8px}
::-webkit-scrollbar-track{background:transparent}
.app{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.main{padding:40px 56px 80px;max-width:1400px;margin:0 auto;width:100%}
.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)}
.destiny-card{padding:16px;border-radius:12px;border:1px solid var(--line);cursor:pointer;transition:all .15s;background:#fff;display:flex;gap:14px;align-items:flex-start}
.destiny-card:hover{border-color:var(--line-strong);background:var(--paper)}
.destiny-card.selected{border-color:var(--ink);background:var(--paper)}
.destiny-card .dot{width:10px;height:10px;border-radius:50%;margin-top:6px;flex-shrink:0}
.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(520px,92vw);background:var(--paper);z-index:91;box-shadow:var(--s-shadow-lg);overflow-y:auto;border-left:1px solid var(--line)}
.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{height:5px;background:var(--line);border-radius:99px;overflow:hidden}
.progress div{height:100%;background:var(--accent);border-radius:99px;transition:width .4s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.fade-in{animation:fadeIn .25s ease}
.mem-cover{border-radius:12px;border:1px solid var(--line);overflow:hidden;aspect-ratio:3/4;position:relative}
.mem-letter{background:#F7F4EE}
.mem-audio{background:var(--jade-800);color:#fff}
.mem-photo{background:var(--jade-400)}
.mem-video{background:var(--gr-800);color:#fff}
.mem-doc{background:var(--paper-2)}
.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)}

/* Sidebar */
.sidebar{background:#fff;border-right:1px solid var(--line);display:flex;flex-direction:column;padding:24px 16px;position:sticky;top:0;height:100vh;overflow-y:auto}
.sidebar-logo{display:flex;align-items:baseline;gap:1px;padding:4px 14px 20px;font-size:22px;font-weight:700;letter-spacing:-0.04em;color:var(--ink)}
.sidebar-logo span{color:var(--accent);font-weight:700}
.sidebar-nav{display:flex;flex-direction:column;gap:2px;flex:1}
.sidebar-section{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted);font-weight:500;padding:14px 14px 6px}
.sidebar-progress{background:var(--paper-2);border-radius:var(--r-lg);padding:16px;margin-top:16px;border:1px solid var(--line)}
.sidebar-user{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:10px;margin-top:8px;cursor:pointer}
.sidebar-user:hover{background:var(--paper-2)}
.nav-badge{background:var(--red-400);color:#fff;font-size:10px;font-weight:600;border-radius:999px;padding:1px 6px;margin-left:auto}

/* Inventory layout */
.inv-layout{display:grid;grid-template-columns:220px 1fr;gap:0;min-height:0}
.inv-sidebar{border-right:1px solid var(--line);padding:0 16px 0 0}
.inv-main{padding-left:32px}
.filter-group{margin-bottom:20px}
.filter-label{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted);font-weight:500;margin-bottom:8px}
.filter-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px;cursor:pointer;font-size:13px;color:var(--ink-muted);transition:all .12s}
.filter-item:hover{background:var(--paper-2);color:var(--ink)}
.filter-item.active{background:var(--accent-soft);color:var(--accent-ink);font-weight:500}
.filter-count{margin-left:auto;font-size:11px;color:var(--ink-muted)}

/* Memory grid */
.mem-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.mem-card{cursor:pointer;transition:transform .15s}
.mem-card:hover{transform:translateY(-2px)}
.mem-card-cover{border-radius:12px;border:1px solid var(--line);overflow:hidden;aspect-ratio:3/4;position:relative;display:flex;flex-direction:column;padding:16px}
.mem-card-meta{margin-top:10px}
.mem-card-title{font-size:13px;font-weight:500;color:var(--ink);line-height:1.3;margin-bottom:4px}
.mem-card-sub{font-size:12px;color:var(--ink-muted)}

/* Circle grid */
.circle-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.person-card{padding:20px;cursor:pointer;transition:all .15s}
.person-card:hover{border-color:var(--line-strong);box-shadow:var(--s-shadow-md)}

/* Bequest grid */
.bequest-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.bequest-card{padding:20px;cursor:pointer;transition:all .15s;position:relative;overflow:hidden}
.bequest-card:hover{border-color:var(--line-strong);box-shadow:var(--s-shadow-md)}
.bequest-locked{filter:blur(0px)}
.bequest-lock-overlay{position:absolute;inset:0;background:rgba(250,250,247,.85);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;border-radius:var(--r-lg)}

/* Profile */
.profile-grid{display:grid;grid-template-columns:1fr 340px;gap:32px}
.mailbox-row{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}
.mailbox-row:last-child{border-bottom:0}
.connected-dot{width:8px;height:8px;border-radius:50%;background:var(--olive-400);flex-shrink:0}
.disconnected-dot{width:8px;height:8px;border-radius:50%;background:var(--gr-300);flex-shrink:0}

/* Suggestions cards */
.suggestions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:40px}
.suggestion-card{padding:20px;cursor:pointer;transition:all .15s}
.suggestion-card:hover{border-color:var(--line-strong);box-shadow:var(--s-shadow-md);transform:translateY(-1px)}

/* Home hero */
.home-hero{display:grid;grid-template-columns:1.5fr 1fr;gap:32px;align-items:start;margin-bottom:48px}
.hero-display{font-size:64px;line-height:1.0;margin:0 0 16px}
.hero-sub{font-size:16px;color:var(--ink-muted);line-height:1.55;max-width:440px;margin:0 0 24px}

/* Stats in hero */
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line)}
.stat-cell{background:#fff;padding:16px 20px}
.stat-num{font-family:var(--f-serif);font-style:italic;font-size:28px;line-height:1;color:var(--ink);margin-bottom:4px}
.stat-label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted);font-weight:500}

/* Search wrapper */
.search-wrap{position:relative;flex:1}
.search-wrap svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--ink-muted)}

/* Drawer inner */
.drawer-header{padding:24px 24px 0;display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.drawer-body{padding:24px}
.drawer-footer{padding:16px 24px 24px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end;position:sticky;bottom:0;background:var(--paper)}

/* People picker */
.people-picker{display:flex;flex-direction:column;gap:8px;margin-top:12px}
.people-picker-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;border:1px solid var(--line);cursor:pointer;transition:all .12s}
.people-picker-item:hover{border-color:var(--line-strong);background:var(--paper-2)}
.people-picker-item.selected{border-color:var(--ink);background:var(--paper)}

/* Section headers */
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.section-title{font-size:16px;font-weight:600;color:var(--ink)}

/* Inactivity settings */
.inact-setting{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}
.inact-setting:last-child{border-bottom:0}
.inact-val{font-family:var(--f-serif);font-style:italic;font-size:22px;color:var(--ink);margin-right:4px}

/* Toggle switch */
.switch{position:relative;display:inline-block;width:40px;height:22px}
.switch input{opacity:0;width:0;height:0}
.slider{position:absolute;cursor:pointer;inset:0;background:var(--gr-300);border-radius:999px;transition:.2s}
.slider:before{content:"";position:absolute;height:16px;width:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}
input:checked+.slider{background:var(--accent)}
input:checked+.slider:before{transform:translateX(18px)}

/* Responsive table rows */
.latest-services-tbl td:first-child{padding-left:0}
.latest-services-tbl th:first-child{padding-left:0}

/* Nav count badge */
.nav-count{margin-left:auto;background:var(--paper-2);color:var(--ink-muted);font-size:11px;font-weight:500;border-radius:999px;padding:2px 8px;min-width:24px;text-align:center}
.nav-link.active .nav-count{background:rgba(255,255,255,.15);color:rgba(255,255,255,.7)}

/* Inventory type tabs */
.inv-type-tabs{display:flex;margin-bottom:20px;border-bottom:1px solid var(--line)}
.inv-tab{padding:10px 20px;border:none;background:transparent;font:inherit;font-size:14px;font-weight:500;color:var(--ink-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s;display:inline-flex;align-items:center;gap:8px}
.inv-tab:hover{color:var(--ink)}
.inv-tab.active{color:var(--ink);border-bottom-color:var(--ink)}
.inv-tab-count{font-size:11px;opacity:0.5;background:rgba(15,29,31,.06);padding:1px 7px;border-radius:999px}
.inv-tab.active .inv-tab-count{opacity:0.7}

/* Memory drawer cover */
.mem-drawer-cover{height:180px;position:relative;display:flex;flex-direction:column;padding:20px 24px;overflow:hidden}

/* Memory "add new" card */
.mem-card-new{opacity:0.55;transition:opacity .15s}
.mem-card-new:hover{opacity:1}
.mem-card-new-cover{border-radius:12px;border:2px dashed var(--line-strong);aspect-ratio:3/4;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;cursor:pointer;transition:border-color .15s}
.mem-card-new:hover .mem-card-new-cover{border-color:var(--ink)}
