@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap";:root{color-scheme:light;--bg: #efe2cf;--bg-deep: #d7c0a2;--ink: #16242b;--ink-soft: #475961;--panel: rgba(255, 249, 239, .88);--panel-solid: #fffaf0;--line: rgba(22, 36, 43, .12);--accent: #156f63;--accent-strong: #0e5a50;--accent-warm: #d46d3d;--accent-warm-soft: rgba(212, 109, 61, .16);--danger: #b84333;--danger-soft: rgba(184, 67, 51, .12);--shadow: 0 24px 70px rgba(42, 28, 17, .16);--radius-lg: 24px;--radius-md: 18px;--radius-sm: 12px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Bricolage Grotesque,system-ui,sans-serif;color:var(--ink);background:radial-gradient(circle at 15% 20%,rgba(21,111,99,.16),transparent 30%),radial-gradient(circle at 85% 10%,rgba(212,109,61,.18),transparent 24%),radial-gradient(circle at 50% 100%,rgba(255,255,255,.35),transparent 40%),linear-gradient(180deg,#f5e8d7 0%,var(--bg) 45%,#e5d1b5 100%)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.28;background-image:linear-gradient(rgba(22,36,43,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(22,36,43,.04) 1px,transparent 1px);background-size:42px 42px;-webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.8),transparent 92%);mask-image:linear-gradient(180deg,rgba(0,0,0,.8),transparent 92%)}button,input,select,textarea{font:inherit}button,input,select,textarea{border-radius:var(--radius-sm)}button{border:1px solid transparent;background:#16242b0f;color:var(--ink);cursor:pointer;padding:10px 14px;transition:transform .14s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease}button:hover{transform:translateY(-1px);box-shadow:0 10px 24px #2018111f}button:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}button.primary{background:linear-gradient(135deg,var(--accent-warm),#ef9b52);color:#fff8f1}button.ghost{background:transparent;border-color:#ffffff38;color:#fef8ef}button.ghost.warm{border-color:#f4c6a773;color:#ffd8c4}button.danger{background:var(--danger);color:#fff5f0}input,select,textarea{width:100%;border:1px solid var(--line);background:#ffffffd6;color:var(--ink);padding:10px 12px}textarea{resize:vertical;min-height:96px}.app{min-height:100%;display:grid;grid-template-rows:auto 1fr}.topbar{display:grid;gap:18px;padding:22px 24px 18px;background:linear-gradient(135deg,#0a1b24f2,#132c33e0),linear-gradient(180deg,rgba(255,255,255,.02),transparent);color:#fef6eb;border-bottom:1px solid rgba(255,255,255,.08);box-shadow:inset 0 -1px #ffffff0d}.hero-panel{display:flex;align-items:flex-start;justify-content:space-between;gap:24px}.brand-block{display:flex;align-items:center;gap:14px}.brand{display:grid;gap:6px}.brand h1{margin:0;font-size:clamp(2rem,3vw,2.9rem);line-height:.94;letter-spacing:-.04em}.brand span{color:#fef6ebb8;font-size:.96rem}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:54px;padding:8px 14px;border-radius:999px;background:#d46d3d29;border:1px solid rgba(244,198,167,.24);color:#ffd7bf;font-family:IBM Plex Mono,monospace;font-size:.78rem;text-transform:uppercase}.summary-strip{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end}.summary-chip{min-width:108px;padding:12px 14px;border-radius:16px;background:#ffffff14;border:1px solid rgba(255,255,255,.08);display:grid;gap:4px;animation:rise-in .36s ease both}.summary-chip strong{font-size:1.3rem}.summary-chip span{color:#fef6eba8;font-size:.84rem}.toolbar-card{display:grid;gap:14px;padding:16px;border-radius:var(--radius-lg);background:#ffffff12;border:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.toolbar-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.toolbar-group{display:flex;gap:10px;flex-wrap:wrap}.toolbar-search,.toolbar-select{display:grid;gap:6px;min-width:min(280px,100%);color:#fef6ebb8;font-size:.82rem}.toolbar-search input,.toolbar-select select{min-width:200px;border-color:#ffffff24;background:#ffffff1f;color:#fff8f0}.toolbar-search input::placeholder{color:#ffffff75}.toolbar-footnote{color:#fef6eba3;font-size:.82rem;display:flex;gap:6px;flex-wrap:wrap;align-items:center}kbd{font-family:IBM Plex Mono,monospace;font-size:.74rem;padding:2px 6px;border-radius:8px;background:#ffffff1f;border:1px solid rgba(255,255,255,.12)}.main{display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:18px;padding:18px 24px 24px;min-height:0}.canvas-shell,.sidebar{min-height:0;background:linear-gradient(180deg,#fffaf0d6,#fff6eaeb);border:1px solid rgba(75,47,23,.12);box-shadow:var(--shadow)}.canvas-shell{position:relative;border-radius:28px;overflow:hidden}.canvas-shell:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at 20% 20%,rgba(21,111,99,.12),transparent 20%),radial-gradient(circle at 80% 10%,rgba(212,109,61,.12),transparent 18%)}.canvas-overlay{position:absolute;z-index:2;display:flex;gap:10px;flex-wrap:wrap;pointer-events:none}.canvas-overlay-top{top:18px;left:18px;right:18px}.canvas-overlay-bottom{left:18px;bottom:18px}.canvas-badge,.canvas-hint{padding:8px 12px;border-radius:999px;background:#fffaf0d6;border:1px solid rgba(22,36,43,.08);color:var(--ink-soft);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.canvas-badge{font-family:IBM Plex Mono,monospace;font-size:.78rem}.canvas-badge.accent,.canvas-hint.active{background:#156f6324;color:var(--accent-strong)}.canvas-hint{font-size:.84rem}svg{width:100%;height:100%;display:block;cursor:grab;background:radial-gradient(rgba(21,111,99,.08) 1px,transparent 1px),linear-gradient(180deg,#ffffff2e,#fff0);background-size:32px 32px,auto}svg:active{cursor:grabbing}.link{stroke:#16242b52;stroke-width:2.6px;transition:stroke .16s ease}.link.parent{stroke-dasharray:9 7}.link.spouse{stroke:#d46d3d8c}.node rect{rx:22px;ry:22px;stroke:#ffffff7a;stroke-width:2px;filter:drop-shadow(0 12px 20px rgba(19,29,36,.16))}.node text{pointer-events:none}.node-title{fill:#fffaf2;font-size:12px;font-weight:700}.node-subtitle{fill:#fffaf2c7;font-size:11px}.node.selected rect{stroke:#ffd18c;stroke-width:3px}.node.link-source rect{stroke:#9be7d9;stroke-width:3px}.node-pin{fill:#fff8ef;stroke:#16242b4d;stroke-width:1px}.sidebar{border-radius:28px;padding:16px;overflow:auto;display:grid;align-content:start;gap:14px}.panel-section{padding:16px;border-radius:20px;background:#ffffff94;border:1px solid rgba(22,36,43,.08);display:grid;gap:12px;animation:rise-in .36s ease both}.section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.section-header h2{margin:0;font-size:1rem}.section-header p{margin:4px 0 0;color:var(--ink-soft);font-size:.84rem}.status-pill{padding:6px 10px;border-radius:999px;font-family:IBM Plex Mono,monospace;font-size:.74rem;text-transform:uppercase;background:#16242b14;color:var(--ink-soft)}.status-pill.saved,.status-pill.idle{background:#156f631f;color:var(--accent-strong)}.status-pill.saving{background:#d46d3d29;color:#8f431f}.status-pill.error{background:var(--danger-soft);color:var(--danger)}.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.stats-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))}.stat-card{padding:12px;border-radius:16px;background:#fffaf0e6;border:1px solid rgba(22,36,43,.06);display:grid;gap:4px}.stat-card span{color:var(--ink-soft);font-size:.8rem}.stat-card strong{font-size:1.2rem}.status-banner,.helper-card{padding:12px 14px;border-radius:16px;background:#156f631a;color:var(--accent-strong);border:1px solid rgba(21,111,99,.12)}.helper-card{background:#16242b0d;color:var(--ink-soft);border-color:#16242b14}.field{display:grid;gap:8px}.field label{color:var(--ink-soft);font-size:.82rem}.range{display:grid;grid-template-columns:1fr auto 1fr;gap:8px;align-items:center}.range span{color:var(--ink-soft);font-size:.82rem;text-align:center}.list{list-style:none;margin:0;padding:0;display:grid;gap:8px}.list li{padding:10px 12px;border-radius:14px;background:#fffaf0d1;border:1px solid rgba(22,36,43,.06);display:flex;justify-content:space-between;gap:12px;align-items:center;color:var(--ink-soft);font-size:.86rem}.list.error li{background:#b843330f;color:#903424}.list.warning li{background:#d46d3d14;color:#8f431f}.list.activity li time{font-family:IBM Plex Mono,monospace;font-size:.74rem;color:#475961b8}.link-button,.mini-button{background:transparent;border:none;padding:0;box-shadow:none}.link-button{color:var(--accent-strong);text-align:left}.link-button:hover,.mini-button:hover{transform:none;box-shadow:none;text-decoration:underline}.mini-button{color:var(--danger);font-size:.78rem}.mini-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.mini-stats div{padding:10px;border-radius:14px;background:#fffaf0db;border:1px solid rgba(22,36,43,.06);display:grid;gap:3px}.mini-stats span{color:var(--ink-soft);font-size:.78rem}.relation-stack{display:grid;gap:8px}.relation-row{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:10px 12px;border-radius:14px;background:#fffaf0d1;border:1px solid rgba(22,36,43,.06)}.action-row{display:flex;gap:10px;flex-wrap:wrap}.action-row button{flex:1;min-width:100px}.tag-list{display:flex;gap:8px;flex-wrap:wrap}.tag{padding:6px 10px;border-radius:999px;background:var(--accent-warm-soft);color:#8f431f;font-size:.78rem}@keyframes rise-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1180px){.main{grid-template-columns:1fr 360px}.hero-panel{flex-direction:column;align-items:flex-start}.summary-strip{justify-content:flex-start}}@media (max-width: 980px){.main{grid-template-columns:1fr}.canvas-shell{min-height:62vh}.sidebar{max-height:none}}@media (max-width: 720px){.topbar,.main{padding-left:14px;padding-right:14px}.toolbar-card,.panel-section{padding:14px}.stats-grid,.mini-stats{grid-template-columns:1fr 1fr}.toolbar-row{flex-direction:column;align-items:stretch}.toolbar-group,.action-row{width:100%}.action-row button{flex:1 1 auto}}
