@import "https://fonts.googleapis.com/css2?family=Caveat:wght@400;500;600;700&family=Kalam:wght@300;400;700&family=Architects+Daughter&family=JetBrains+Mono:wght@400;500&display=swap";
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-leading:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-duration:initial}}}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.sticky{position:sticky}.z-\[300\]{z-index:300}.container{width:100%}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-flex{display:inline-flex}.h-\[calc\(100dvh-56px-64px\)\]{height:calc(100dvh - 120px)}.h-full{height:100%}.min-h-\[44px\]{min-height:44px}.w-1\/2{width:50%}.w-1\/3{width:33.3333%}.w-3\/5{width:60%}.w-4\/5{width:80%}.w-full{width:100%}.min-w-\[44px\]{min-width:44px}.flex-1{flex:1}.shrink-0{flex-shrink:0}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-pointer{cursor:pointer}.resize{resize:both}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.overflow-hidden{overflow:hidden}.rounded-full{border-radius:3.40282e38px}.border{border-style:var(--tw-border-style);border-width:1px}.border-\[1\.5px\]{border-style:var(--tw-border-style);border-width:1.5px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.bg-transparent{background-color:#0000}.object-cover{object-fit:cover}.leading-none{--tw-leading:1;line-height:1}.break-all{word-break:break-all}.whitespace-nowrap{white-space:nowrap}.lowercase{text-transform:lowercase}.opacity-25{opacity:.25}.opacity-75{opacity:.75}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-\[border-color\,box-shadow\]{transition-property:border-color,box-shadow;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.duration-\[150ms\]{--tw-duration:.15s;transition-duration:.15s}.select-none{-webkit-user-select:none;user-select:none}@media (hover:hover){.hover\:opacity-90:hover{opacity:.9}}.focus\:shadow-\[0_0_0_3px_rgba\(220\,38\,38\,0\.12\)\]:focus{--tw-shadow:0 0 0 3px var(--tw-shadow-color,#dc26261f);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.focus\:shadow-\[0_0_0_3px_var\(--color-primary-light\)\]:focus{--tw-shadow:0 0 0 3px var(--tw-shadow-color,var(--color-primary-light));box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.active\:opacity-80:active{opacity:.8}.active\:opacity-90:active{opacity:.9}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}:root{--ink:#1a1a1a;--ink-soft:#4a4a4a;--ink-faint:#8a8a8a;--paper:#fdfcf7;--paper-warm:#f5f1e6;--paper-line:#e8e2d0;--accent:#c8a96e;--accent-soft:#f0e3c4;--indigo:#2b3f6f;--indigo-soft:#d8dfee;--red:#c84a3a;--green:#4a7c59}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:var(--paper-warm);color:var(--ink);min-height:100dvh;margin:0;font-family:Kalam,Caveat,sans-serif}.hand-title{letter-spacing:-.01em;font-family:Caveat,cursive;font-weight:700}.hand-body{font-family:Kalam,cursive;font-weight:400}.hand-mono{letter-spacing:-.02em;color:var(--ink-soft);font-family:JetBrains Mono,monospace;font-size:11px}.note{color:var(--ink-soft);font-family:Architects Daughter,cursive;font-size:12px}.sketch-box{background:var(--paper);border:1.5px solid var(--ink);border-radius:6px 14px 8px 12px/12px 8px 14px 6px;position:relative}.sketch-box-soft{background:var(--paper);border:1.5px solid var(--ink);border-radius:8px 16px 10px 14px/14px 10px 16px 8px;position:relative;box-shadow:2px 3px #1a1a1a14}.sketch-circle{border:1.5px solid var(--ink);background:var(--paper);border-radius:50%}.hand-underline{display:inline-block;position:relative}.hand-underline:after{content:"";background:var(--accent);opacity:.5;border-radius:50%;height:5px;position:absolute;bottom:-3px;left:-2px;right:-4px;transform:rotate(-.5deg)}.hatch{background-image:repeating-linear-gradient(-45deg, var(--ink-faint), var(--ink-faint) 1px, transparent 1px, transparent 6px);opacity:.35}.hatch-warm{background-image:repeating-linear-gradient(-45deg, var(--accent), var(--accent) 1px, transparent 1px, transparent 5px);opacity:.55}.hatch-cool{background-image:repeating-linear-gradient(-45deg, var(--indigo), var(--indigo) 1px, transparent 1px, transparent 5px);opacity:.35}.squiggle{opacity:.65;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 6'><path d='M0,3 Q5,0 10,3 T20,3 T30,3 T40,3 T50,3 T60,3 T70,3 T80,3' stroke='%231a1a1a' stroke-width='1.2' fill='none'/></svg>");background-repeat:repeat-x;background-size:80px 6px;height:6px}.squiggle.thin{opacity:.5;background-size:80px 4px;height:3px}.line-rule{background:var(--ink);border-radius:2px;height:1.5px}.line-rule.dashed{border-top:1.5px dashed var(--ink);background:0 0;height:0}.photo-ph{background:var(--paper);border:1.5px solid var(--ink);border-radius:4px 8px 6px 10px/8px 4px 10px 6px;position:relative;overflow:hidden}.photo-ph:before{content:"";background:repeating-linear-gradient(135deg, transparent 0 8px, var(--ink-faint) 8px 9px);opacity:.4;position:absolute;inset:0}.avatar{background:var(--paper);border:1.5px solid var(--ink);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-family:Caveat,cursive;font-weight:700;display:inline-flex;position:relative;overflow:hidden}.avatar.deceased{filter:grayscale();opacity:.65}.avatar-hatched{background-image:repeating-linear-gradient(45deg, var(--accent-soft) 0 4px, transparent 4px 6px)}.sk-btn{border:1.5px solid var(--ink);background:var(--paper);cursor:pointer;white-space:nowrap;color:var(--ink);border-radius:18px 22px 18px 24px/22px 18px 24px;align-items:center;gap:6px;padding:6px 14px;font-family:Kalam,cursive;font-size:13px;font-weight:700;text-decoration:none;transition:transform .1s,box-shadow .1s;display:inline-flex;box-shadow:2px 2px #1a1a1a1f}.sk-btn:hover{transform:translate(-1px,-1px);box-shadow:3px 3px #1a1a1a26}.sk-btn:active{transform:translate(0);box-shadow:1px 1px #1a1a1a1f}.sk-btn.primary{background:var(--ink);color:var(--paper)}.sk-btn.accent{background:var(--accent);color:var(--ink)}.sk-btn.ghost{box-shadow:none;background:0 0;border-color:#0000}.sk-btn.sm{padding:3px 10px;font-size:11px}.sk-btn.lg{justify-content:center;width:100%;padding:10px 20px;font-size:15px}.sk-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.sk-input{border:1.5px solid var(--ink);background:var(--paper);width:100%;color:var(--ink);border-radius:6px 12px/12px 6px;outline:none;padding:8px 12px;font-family:Kalam,cursive;font-size:14px;transition:box-shadow .15s}.sk-input:focus{box-shadow:2px 2px 0 var(--accent)}.sk-input::placeholder{color:var(--ink-faint)}.sk-input.lg{padding:10px 14px;font-size:15px}.sk-input.error{border-color:var(--red)}textarea.sk-input{resize:vertical;min-height:80px}.chip{border:1.2px solid var(--ink);background:var(--paper);white-space:nowrap;border-radius:12px 16px 12px 18px/16px 12px 18px;align-items:center;gap:4px;padding:1px 8px;font-family:Kalam,cursive;font-size:11px;display:inline-flex}.chip.warm{background:var(--accent-soft)}.chip.cool{background:var(--indigo-soft)}.chip.muted{color:var(--ink-soft);background:#ececec}.chip.active{background:var(--ink);color:var(--paper)}.bottom-nav{background:var(--paper);border-top:1.5px solid var(--ink);z-index:200;justify-content:space-around;align-items:center;height:56px;padding:0 4px;display:flex;position:fixed;bottom:0;left:0;right:0}@media (min-width:768px){.bottom-nav--mobile{display:none}}.nav-item{color:var(--ink-soft);flex-direction:column;justify-content:center;align-items:center;gap:2px;min-width:44px;min-height:44px;padding:4px 6px;font-family:Kalam,cursive;font-size:9px;text-decoration:none;display:flex}.nav-item.active{color:var(--ink);font-weight:700}.nav-item.active .nav-ic{background:var(--accent-soft);border-color:var(--ink)}.nav-ic{border:1.5px solid var(--ink-soft);background:var(--paper);border-radius:6px 9px 6px 10px/9px 6px 10px;justify-content:center;align-items:center;width:26px;height:26px;font-size:13px;display:flex}.app-header{z-index:100;border-bottom:1.5px solid var(--ink);background:var(--paper);justify-content:space-between;align-items:center;height:44px;padding:0 16px;display:flex;position:sticky;top:0}.navbar-desktop-nav{display:none}@media (min-width:768px){.app-header{height:52px;padding:0 24px}.navbar-desktop-nav{flex:1;justify-content:center;align-items:center;gap:4px;display:flex}.navbar-desktop-link{color:var(--ink-soft);white-space:nowrap;border-radius:10px 14px/14px 10px;align-items:center;gap:5px;padding:5px 12px;font-family:Kalam,cursive;font-size:13px;font-weight:600;text-decoration:none;transition:background .1s,color .1s;display:flex}.navbar-desktop-link:hover{background:var(--paper-warm);color:var(--ink)}.navbar-desktop-link.active{background:var(--accent-soft);color:var(--ink);font-weight:700}}.tab-strip{border:1.5px solid var(--ink);background:var(--paper);border-radius:14px 18px 14px 20px/18px 14px 20px;gap:2px;padding:3px;display:inline-flex}.tab-strip button{cursor:pointer;color:var(--ink-soft);background:0 0;border:none;border-radius:10px;padding:4px 12px;font-family:Kalam,cursive;font-size:12px;font-weight:600}.tab-strip button.active{background:var(--ink);color:var(--paper)}.rough-divider{color:var(--ink-soft);align-items:center;gap:8px;margin:8px 0;font-family:Caveat,cursive;font-size:14px;display:flex}.rough-divider:before,.rough-divider:after{content:"";background:var(--ink);opacity:.4;border-radius:2px;flex:1;height:1.5px}.tree-node{background:var(--paper);border:1.5px solid var(--ink);text-align:center;border-radius:6px 10px 6px 12px/10px 6px 12px;padding:6px;font-family:Kalam,cursive;position:relative}.tree-node .tn-gender{opacity:.5;font-family:sans-serif;font-size:9px;line-height:1;position:absolute;top:4px;right:5px}.tree-node.male .tn-avatar{color:#2b3f6f;background:#d0dff5}.tree-node.female .tn-avatar{color:#7a3050;background:#f5d0e0}.tree-node .tn-avatar{border:1.2px solid var(--ink);background:var(--paper-warm);border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;margin:0 auto;font-family:Caveat,cursive;font-size:13px;font-weight:700;display:flex}.tree-node .tn-name{margin-top:3px;font-size:10px;font-weight:700;line-height:1.15}.tree-node .tn-meta{color:var(--ink-soft);font-family:JetBrains Mono,monospace;font-size:8px}.tree-node.deceased{opacity:.85;color:#d4cfc9;background:#2e2b28;border-color:#5a5550}.tree-node.deceased .tn-name{color:#d4cfc9}.tree-node.deceased .tn-meta{color:#8a8480}.tree-node.deceased .tn-gender{opacity:.4}.tree-node.deceased.male .tn-avatar{color:#8aaad4;filter:none;background:#3a4a6a}.tree-node.deceased.female .tn-avatar{color:#d48aaa;filter:none;background:#5a3a4a}.tree-node.deceased .tn-avatar{border-color:#5a5550}.tree-node.spouse{border-style:dashed}.tree-node.you{background:var(--accent-soft);border-width:2px}.tree-node.root{background:var(--indigo-soft);border-width:2px}.tree-svg{pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.reaction{border:1.2px solid var(--ink);background:var(--paper);cursor:pointer;border-radius:10px 14px/14px 10px;align-items:center;gap:3px;padding:1px 6px;font-family:Kalam,cursive;font-size:11px;display:inline-flex}.reaction.active{background:var(--accent-soft)}.muted{color:var(--ink-soft)}.pb-nav,.main-content{padding-bottom:64px}@media (min-width:768px){.main-content{padding-bottom:0}}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}
