:root{color-scheme:light;--bg: #f5f4f1;--panel: #ffffff;--line: #e4e1db;--text: #15171a;--muted: #5f615e;--accent: #3e566b;--error: #b04040;--shadow: 0 1px 3px rgba(20, 23, 26, .06), 0 1px 2px rgba(20, 23, 26, .05);font-family:Nunito,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-size:16px;line-height:1.5}.center{min-height:100dvh;display:grid;place-items:center;padding:24px}.muted{color:var(--muted)}.error{color:var(--error);margin:0}.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px}.brand img{border-radius:9px}.card{width:100%;max-width:360px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:28px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px}.card h1{margin:6px 0 0;font-size:22px}.card p{margin:0}label{display:flex;flex-direction:column;gap:6px;font-size:14px;color:var(--muted)}input[type=email],input[type=password],input[type=text],input:not([type]){background:#f1efe9;border:1px solid var(--line);border-radius:10px;padding:10px 12px;color:var(--text);font-size:16px}input:focus{outline:2px solid var(--accent);outline-offset:1px}button{background:var(--accent);color:#fff;border:1px solid transparent;border-radius:10px;padding:10px 16px;line-height:1.2;font-weight:600;font-size:15px;cursor:pointer}button:disabled{opacity:.6;cursor:default}button.ghost{background:transparent;color:var(--muted);border:1px solid var(--line)}.app{min-height:100dvh}.topbar{display:flex;align-items:center;gap:12px;padding:calc(14px + env(safe-area-inset-top)) max(20px,env(safe-area-inset-right)) 14px max(20px,env(safe-area-inset-left));border-bottom:1px solid var(--line)}.spacer{flex:1}.badge{font-size:12px;text-transform:uppercase;letter-spacing:.05em;background:#eef1f4;color:var(--accent);padding:3px 8px;border-radius:999px}.content{max-width:720px;margin:0 auto;padding:32px max(20px,env(safe-area-inset-right)) calc(32px + env(safe-area-inset-bottom)) max(20px,env(safe-area-inset-left))}.content h1{font-size:26px}.panel{margin-top:28px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:var(--shadow)}.panel h2{margin-top:0;font-size:18px}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.row input[type=email]{flex:1;min-width:200px}.check{flex-direction:row;align-items:center;gap:6px;color:var(--text)}.invite-link{margin-top:14px;word-break:break-all}.invite-link code{color:var(--accent)}.content.wide{max-width:1100px}.library{margin-top:4px}.lib-bar{display:flex;align-items:center;gap:12px;margin-bottom:16px}.lib-bar h2{margin:0;font-size:22px;flex:1}.upload{background:var(--accent);color:#fff;border:1px solid transparent;border-radius:10px;height:40px;padding:0 16px;display:inline-flex;align-items:center;justify-content:center;line-height:1;white-space:nowrap;font-weight:600;font-size:15px;cursor:pointer}.upload.busy{opacity:.6;cursor:default}.media-head{display:flex;align-items:center;gap:10px;margin-bottom:14px}.media-head h2{margin:0 auto 0 0;font-size:22px}.media-actions{display:flex;align-items:center;gap:8px}.overflow{position:relative;display:inline-flex}.overflow-btn{height:40px;padding:0 10px;display:inline-grid;place-items:center;color:var(--muted)}.overflow-btn:hover{color:var(--text)}.overflow-menu{position:absolute;top:calc(100% + 6px);right:0;z-index:30;min-width:190px;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:6px;display:flex;flex-direction:column}.overflow-item{background:none;border:0;color:var(--text);text-align:left;padding:10px 12px;border-radius:8px;font-size:15px;font-weight:500;cursor:pointer}.overflow-item:hover{background:#f1efe9}.overflow-danger{color:var(--error)}.overflow-danger:hover{background:#faf0f0}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.tile{position:relative;margin:0;aspect-ratio:1;border-radius:10px;overflow:hidden;background:var(--panel);cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.tile img{width:100%;height:100%;object-fit:cover;display:block}.tile.selected{outline:3px solid var(--accent);outline-offset:-3px}.tile.selected img{opacity:.82}.tile-check{position:absolute;top:6px;left:6px;width:22px;height:22px;border-radius:999px;display:grid;place-items:center;font-size:14px;font-weight:800;color:#fff;background:#14171a59;border:2px solid #fff;box-shadow:0 1px 3px #00000059}.tile-check.on{background:var(--accent)}.tile-select{position:absolute;top:6px;left:6px;width:30px;height:30px;display:grid;place-items:center;border:0;background:transparent;padding:0;cursor:pointer}.tile-select-dot{width:22px;height:22px;border-radius:999px;background:#14171a59;border:2px solid #fff;box-shadow:0 1px 3px #00000059}.tile-select:hover .tile-select-dot{background:var(--accent)}@media (hover: none){.tile-select{display:none}}.selectbar{display:flex;align-items:center;flex-wrap:wrap;gap:12px;row-gap:8px;margin:4px 0 12px;padding:8px 12px;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);position:sticky;top:calc(8px + env(safe-area-inset-top));z-index:6}.selectbar-count{font-size:14px;font-weight:600;flex:1}.selectbar-status{font-size:14px;color:var(--muted)}.selectbar .danger{color:var(--error)}.bulk-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;overflow-y:auto;display:flex;align-items:flex-start;justify-content:center;padding:clamp(16px,6vh,60px) 16px max(16px,env(safe-area-inset-bottom));background:#0206178c}.bulk-card{width:440px;max-width:100%;display:flex;flex-direction:column;gap:12px;background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:16px 18px}.bulk-card-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.bulk-card-head h3{margin:0;font-size:17px}.bulk-card>p.muted{margin:0;font-size:14px;line-height:1.45}.bulk-x{background:none;border:0;color:var(--muted);font-size:22px;line-height:1;cursor:pointer;padding:0 4px}.bulk-x:hover{color:var(--text)}.bulk-x:disabled{opacity:.5;cursor:default}.notice{margin:4px 0 12px;padding:8px 12px;font-size:14px;color:var(--text);background:#eef2f6;border:1px solid var(--line);border-radius:10px}.xfers{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.xfer{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}.xfer-icon{display:inline-grid;place-items:center;width:18px;height:18px;border-radius:999px;background:#eef1f4;color:var(--accent);font-size:12px;font-weight:800}.xfer.done .xfer-icon{background:#e3f0e6;color:#3a8a4f}.xfer.error .xfer-icon{background:#f3e0e0;color:var(--error)}.xfer-text{display:flex;flex-direction:column;line-height:1.15;min-width:0}.xfer-label{font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.xfer-detail{font-size:12px}.xfer-bar{width:60px;height:5px;border-radius:999px;background:#e9e6e0;overflow:hidden;flex:0 0 auto}.xfer-bar>span{display:block;height:100%;background:var(--accent);transition:width .2s}.tile .play{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.tile .play:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-40%,-50%);border-style:solid;border-width:11px 0 11px 18px;border-color:transparent transparent transparent rgba(255,255,255,.92);filter:drop-shadow(0 1px 4px rgba(0,0,0,.6))}@media (hover: hover){.tile .tile-select{opacity:0;transition:opacity .12s}.tile:hover .tile-select,.tile .tile-select:focus-visible{opacity:1}}.lib-bar h2{flex:0 0 auto}.search{display:flex;align-items:center;flex:0 1 260px;height:40px;background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden}.search:focus-within{outline:2px solid var(--accent);outline-offset:1px;border-color:transparent}.search-go{display:grid;place-items:center;height:100%;padding:0 4px 0 10px;border:0;background:none;color:var(--muted);border-radius:0;cursor:pointer}.search-go:hover{color:var(--text)}.search input{flex:1;min-width:0;border:0;background:transparent;color:var(--text);padding:0 12px 0 6px;font-size:16px;font-family:inherit;height:100%}.search input:focus{outline:none}.crumb{display:flex;align-items:center;gap:12px;margin-bottom:14px;color:var(--muted);font-size:14px}.link{background:none;border:0;color:var(--accent);cursor:pointer;padding:0;font-size:14px}.albums{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.album{display:flex;flex-direction:column;gap:3px;text-align:left;color:var(--text);background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:8px;cursor:pointer;box-shadow:var(--shadow)}.album-cover{aspect-ratio:1;border-radius:8px;overflow:hidden;background:#f1efe9;margin-bottom:5px}.album-cover img{width:100%;height:100%;object-fit:cover;display:block}.album-empty{display:block;width:100%;height:100%}.album-name{font-weight:600;font-size:14px}.album-note{font-size:13px;color:var(--muted)}.album-count{font-size:13px;color:var(--accent)}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;padding:max(20px,env(safe-area-inset-top)) max(20px,env(safe-area-inset-right)) max(20px,env(safe-area-inset-bottom)) max(20px,env(safe-area-inset-left));background:#020617f0;display:grid;place-items:center}.lightbox-toolbar{position:fixed;top:calc(14px + env(safe-area-inset-top));right:calc(16px + env(safe-area-inset-right));z-index:1101;display:flex;gap:8px}.lightbox-btn{height:38px;padding:0 14px;border-radius:999px;border:0;background:#ffffff1f;color:#fff;font-size:14px;cursor:pointer}.lightbox-btn:hover{background:#ffffff38}.lightbox-btn[aria-pressed=true]{background:#ffffff52}.lightbox-btn:disabled{opacity:.6;cursor:default}.lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);z-index:1101;width:48px;height:48px;border-radius:999px;border:0;cursor:pointer;background:#ffffff1f;color:#fff;font-size:30px;line-height:1;display:grid;place-items:center}.lightbox-nav:hover{background:#ffffff38}.lightbox-nav.prev{left:calc(16px + env(safe-area-inset-left))}.lightbox-nav.next{right:calc(16px + env(safe-area-inset-right))}@media (max-width: 760px){.lightbox-nav{width:40px;height:40px;font-size:24px;background:#ffffff2e}}.lightbox-body{display:flex;gap:14px;width:100%;max-width:1200px;max-height:90vh}.lightbox-stage{flex:1 1 auto;min-width:0;display:grid;place-items:center}.lightbox-stage img,.lightbox-stage video{max-width:100%;max-height:90vh;border-radius:8px;display:block}.lightbox-panel{flex:0 0 320px;max-height:90vh;overflow-y:auto;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:18px}.panel-block h3{margin:0 0 8px;font-size:14px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.chip{display:inline-flex;align-items:center;gap:4px;background:#f1efe9;border:1px solid var(--line);border-radius:999px;padding:3px 6px 3px 10px;font-size:14px}.chip-alias,.chip-x{background:none;border:0;color:var(--muted);cursor:pointer;padding:2px 6px}.chip-alias{font-size:12px}.chip-x:hover{color:var(--error)}.tagger{position:relative}.tag-menu{position:absolute;left:0;right:0;top:100%;margin-top:4px;z-index:5;background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow-y:auto;max-height:220px}.tag-opt{display:block;width:100%;text-align:left;background:none;border:0;color:var(--text);padding:8px 10px;cursor:pointer;font-size:14px}.tag-opt:hover{background:#f1efe9}.tag-opt.create{color:var(--accent);border-top:1px solid var(--line)}.comments{display:flex;flex-direction:column;gap:10px;margin-bottom:10px}.comment-head{display:flex;justify-content:space-between;align-items:baseline;font-size:14px}.comment p{margin:2px 0 0;font-size:15px}.comment-form{display:flex;flex-direction:column;gap:6px}.comment-form textarea{width:100%;resize:vertical;font-family:inherit;font-size:16px}.person-head{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px 20px;margin-bottom:18px;box-shadow:var(--shadow)}.person-head h2{margin:0;font-size:22px}.person-note{margin:4px 0 0}.family{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-top:16px}.relation h3{margin:0 0 8px;font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.rel-people{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.rel-chip{display:flex;align-items:center;justify-content:space-between;gap:6px;background:#f1efe9;border:1px solid var(--line);border-radius:8px;padding:5px 8px 5px 10px}.rel-chip .link{font-size:14px;text-align:left}@media (max-width: 760px){.lib-bar{flex-wrap:wrap}.lightbox-body{flex-direction:column;max-height:92vh;overflow-y:auto}.lightbox-panel{flex:0 0 auto;max-height:none}.lightbox-stage img,.lightbox-stage video{max-height:60vh}}.brand-link{text-decoration:none;color:inherit;display:inline-flex}.mainnav{display:flex;align-items:center;gap:2px;margin-left:6px}.mainnav-group{display:flex;gap:4px}.mainnav-divider{width:1px;height:22px;background:var(--line);margin:0 8px}.mainnav a{text-decoration:none;color:var(--muted);font-weight:600;font-size:15px;padding:6px 12px;border-radius:9px}.mainnav a:hover{color:var(--text);background:#f1efe9}.mainnav a.active{color:var(--accent);background:#eef1f4}.who{font-size:14px}.menu-btn{display:none;align-items:center;gap:7px;min-height:44px;background:transparent;border:1px solid var(--line);color:var(--text);border-radius:10px;padding:8px 12px;font-size:15px;font-weight:700;cursor:pointer}.menu-btn:hover{background:#f1efe9}.nav-scrim{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#02061773;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .2s ease,visibility .2s ease}.nav-scrim.open{opacity:1;visibility:visible;pointer-events:auto}.nav-drawer{position:fixed;top:0;left:0;height:100dvh;width:min(84vw,320px);display:flex;flex-direction:column;background:var(--panel);border-right:1px solid var(--line);box-shadow:3px 0 16px #14171a1f;padding:calc(14px + env(safe-area-inset-top)) 12px calc(14px + env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-left));transform:translate(-100%);transition:transform .22s ease;overflow-y:auto}.nav-scrim.open .nav-drawer{transform:translate(0)}.nav-drawer-head{display:flex;align-items:center;justify-content:space-between;margin:2px 2px 10px}.nav-drawer-close{width:40px;height:40px;display:grid;place-items:center;cursor:pointer;border:1px solid var(--line);background:var(--panel);color:var(--muted);border-radius:999px}.nav-drawer-close:hover{color:var(--text)}.nav-drawer-links{display:flex;flex-direction:column;gap:2px}.nav-drawer-link{display:flex;align-items:center;gap:12px;min-height:52px;padding:0 14px;border-radius:11px;text-decoration:none;color:var(--text);font-size:17px;font-weight:600}.nav-drawer-link:hover{background:#f1efe9}.nav-drawer-link.active{background:#eef1f4;color:var(--accent)}.nav-drawer-sep{height:1px;background:var(--line);margin:8px 12px}.nav-drawer-profile{margin-top:auto;padding-top:14px;border-top:1px solid var(--line);border-radius:0}@media (max-width: 820px){.mainnav{display:none}.menu-btn{display:inline-flex}.nav-scrim{display:block}}.filter{max-width:260px}.people-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.person-card{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px 10px;cursor:pointer;color:var(--text);box-shadow:var(--shadow)}.person-card:hover{border-color:var(--accent)}.avatar,.cover-mono{display:grid;place-items:center;width:56px;height:56px;border-radius:999px;background:var(--accent);color:#fff;font-weight:700;font-size:20px}.person-card-name{font-weight:600;font-size:15px}.recipe-card{overflow:hidden;text-decoration:none}.cover-mono{width:100%;height:100%;border-radius:0;font-size:46px}.recipe{max-width:760px}.recipe-cover{width:100%;max-height:360px;object-fit:cover;border-radius:14px;border:1px solid var(--line);box-shadow:var(--shadow);margin-bottom:6px}.recipe-head{display:flex;align-items:baseline;gap:12px}.recipe-head h2{margin:6px 0;flex:1;font-size:26px}.recipe-actions{display:flex;gap:12px}.link.danger{color:var(--error)}.recipe-desc{font-size:17px;line-height:1.5}.recipe-block{margin-top:22px}.recipe-block h3{font-size:14px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:8px}.ingredients{padding-left:20px;display:flex;flex-direction:column;gap:4px}.steps{padding-left:22px;display:flex;flex-direction:column;gap:10px}.steps li{line-height:1.5;padding-left:4px}.recipe-form{max-width:640px;display:flex;flex-direction:column;gap:14px}.recipe-form h2{margin:0}.recipe-form>label{font-weight:600;color:var(--text)}.recipe-form textarea{font-family:inherit;resize:vertical;width:100%;background:#f1efe9;border:1px solid var(--line);border-radius:10px;padding:10px 12px;color:var(--text);font-size:16px}.grow1{flex:1}.grow2{flex:2}.lines{display:flex;flex-direction:column;gap:8px}.lines-label{font-weight:600;font-size:14px}.line-row{display:flex;gap:8px;align-items:flex-start}.line-row input,.line-row textarea{flex:1}.line-row .chip-x{padding:8px 6px;font-size:16px}.cover-field{display:flex;flex-direction:column;gap:8px;align-items:flex-start}.cover-preview{width:160px;height:160px;object-fit:cover;border-radius:12px;border:1px solid var(--line)}@media (max-width: 620px){.topbar{flex-wrap:wrap;row-gap:8px}.who{display:none}}input[type=search]{-webkit-appearance:none;-moz-appearance:none;appearance:none}.filter{width:240px;max-width:100%}.person-title{display:flex;gap:14px;align-items:center;margin-bottom:2px}.person-title h2{margin:0}.avatar.xl{width:64px;height:64px;font-size:24px}.tree{display:flex;flex-direction:column;align-items:center;gap:0;margin:20px 0 8px}.tier{display:flex;justify-content:center;gap:30px}.tree-link{width:2px;height:22px;background:var(--line)}.tree-node{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;width:100px;text-align:center}.tree-node .avatar{width:52px;height:52px;font-size:18px}.tree-avatar{background:none;border:0;padding:0;cursor:pointer;border-radius:999px}.tree-name{font-size:14px;font-weight:600;line-height:1.25}button.tree-name{background:none;border:0;padding:0;cursor:pointer;color:var(--accent)}button.tree-name:hover{text-decoration:underline}.tree-unlink{position:absolute;top:-6px;right:4px;width:30px;height:30px;border-radius:999px;display:grid;place-items:center;border:1px solid var(--line);background:var(--panel);color:var(--muted);font-size:15px;line-height:1;cursor:pointer;opacity:0;transition:opacity .12s}.tree-node:hover .tree-unlink{opacity:1}.tier-focal{align-items:flex-start;gap:0}.tier-focal .focal .avatar{width:56px;height:56px;font-size:19px;box-shadow:0 0 0 4px #eef1f4}.couple{display:flex;align-items:flex-start}.couple-bar{width:30px;height:2px;background:var(--line);margin-top:28px}.tier-children .tree-node{padding-top:22px}.tier-children .tree-node:before{content:"";position:absolute;top:0;left:50%;width:0;height:22px;border-left:2px solid var(--line)}.tier-children .tree-node:after{content:"";position:absolute;top:0;left:-15px;right:-15px;height:0;border-top:2px solid var(--line)}.tier-children .tree-node:first-child:after{left:50%}.tier-children .tree-node:last-child:after{right:50%}.tier-children .tree-node:only-child:after{display:none}.tree-add-bar{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:16px}.ghost.sm{font-size:14px;padding:6px 12px}.add-relative{display:flex;gap:8px;align-items:center}.add-relative .tagger{min-width:210px}img.avatar{object-fit:cover}.avatar.sm{width:30px;height:30px;font-size:13px}.profile-link{display:flex;align-items:center;gap:8px;text-decoration:none;color:var(--text);padding:4px 8px;border-radius:999px}.profile-link:hover{background:#f1efe9}.profile{max-width:480px}.profile-signout{margin-top:24px;padding-top:18px;border-top:1px solid var(--line)}.profile-avatar-row{display:flex;align-items:center;gap:18px;margin:14px 0 22px}.profile-form{display:flex;flex-direction:column;gap:14px}.profile-form>label{font-weight:600;color:var(--text)}.profile-form input:disabled{opacity:.7;cursor:not-allowed}.profile .panel{margin-top:26px}.tree-view{display:flex;flex-direction:column}.family-select{height:40px;margin-right:8px;padding:0 10px;border:1px solid var(--line);border-radius:10px;background:var(--panel);color:var(--text);font-size:14px;font-weight:600;cursor:pointer;max-width:220px}.tree-controls{display:flex;gap:4px}.tree-controls .ghost{padding:7px 12px;font-size:15px;line-height:1}.tree-canvas-wrap{position:relative;height:72vh;min-height:460px;margin-top:4px;overflow:hidden;border:1px solid var(--line);border-radius:14px;background:#faf9f7;box-shadow:var(--shadow);cursor:grab;touch-action:none}.tree-canvas-wrap:active{cursor:grabbing}.tree-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.tree-canvas{position:absolute;top:0;left:0;transform-origin:0 0}.tree-lines{position:absolute;top:0;left:0;overflow:visible;pointer-events:none}.tree-lines line{stroke:#c9c5bd;stroke-width:2}.tnode{position:absolute;display:flex;align-items:center;gap:9px;padding:0 10px;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);cursor:pointer;text-align:left;color:var(--text)}.tnode:hover{border-color:var(--accent)}.tnode.sel{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}.tnode-av{width:40px;height:40px;border-radius:999px;object-fit:cover;flex:0 0 auto}.tnode-av.mono{display:grid;place-items:center;background:var(--accent);color:#fff;font-weight:700;font-size:14px}.tnode.acct .tnode-av{box-shadow:0 0 0 2px #eef1f4,0 0 0 4px var(--accent)}.tnode-body{display:flex;flex-direction:column;min-width:0}.tnode-name{font-weight:600;font-size:14px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:92px}.tnode-dates{font-size:12px;color:var(--muted)}.detail{position:fixed;top:0;right:0;height:100dvh;width:350px;max-width:92vw;z-index:40;background:var(--panel);border-left:1px solid var(--line);box-shadow:-3px 0 16px #14171a1a;padding:calc(22px + env(safe-area-inset-top)) max(20px,env(safe-area-inset-right)) calc(22px + env(safe-area-inset-bottom)) 20px;overflow-y:auto}.detail-close{position:absolute;top:calc(12px + env(safe-area-inset-top));right:calc(12px + env(safe-area-inset-right));width:38px;height:38px;border-radius:999px;border:1px solid var(--line);background:var(--panel);color:var(--muted);font-size:18px;cursor:pointer}.detail-head{display:flex;gap:12px;align-items:center;margin:4px 40px 18px 0}.detail-head h3{margin:0 0 4px;font-size:19px}.detail-facts,.detail-form{display:flex;flex-direction:column;gap:12px}.fact{display:flex;flex-direction:column;gap:1px;margin:0}.fact-label{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.detail-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:8px}.detail-form>label,.detail-form .row>label{font-weight:600;color:var(--text);font-size:14px}.detail-form textarea{font-family:inherit;resize:vertical;width:100%;background:#f1efe9;border:1px solid var(--line);border-radius:10px;padding:9px 11px;color:var(--text);font-size:16px}.detail-rels{margin-top:22px;display:flex;flex-direction:column;gap:16px}.rel h4{margin:0 0 6px;font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.rel-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}.rel-tag{display:inline-flex;align-items:center;gap:4px;background:#f1efe9;border:1px solid var(--line);border-radius:999px;padding:3px 6px 3px 10px;font-size:14px}.rel-tag .link,.rel-add{font-size:14px}.album-title{font-size:22px;margin:6px 0 14px}@media (max-width: 620px){.detail{width:100vw;max-width:100vw}}.viewtabs{display:flex;gap:16px;border-bottom:1px solid var(--line);margin:2px 0 18px}.viewtabs button{background:none;border:0;border-bottom:2px solid transparent;margin-bottom:-1px;color:var(--muted);font-weight:600;font-size:15px;padding:9px 2px;border-radius:0;cursor:pointer}.viewtabs button:hover{color:var(--text)}.viewtabs button.on{color:var(--accent);border-bottom-color:var(--accent)}@media (max-width: 640px){.media-head{flex-wrap:wrap}.media-actions{flex:1 1 100%}.media-actions .search{flex:1 1 auto}.viewtabs{gap:12px;overflow-x:auto}.timeline-wrap{grid-template-columns:30px minmax(0,1fr);gap:6px}.grid{grid-template-columns:repeat(auto-fill,minmax(92px,1fr))}}.timeline{display:flex;flex-direction:column;gap:24px}.tl-group{display:flex;flex-direction:column;gap:8px;scroll-margin-top:14px}.tl-head{display:flex;align-items:center;gap:10px;margin:0;font-size:15px;color:var(--muted);font-weight:700;position:sticky;top:0;background:var(--bg);padding:6px 0;z-index:1}.tl-select{margin-left:auto;font-size:14px}.timeline-wrap{display:grid;grid-template-columns:46px minmax(0,1fr);gap:10px;align-items:start}.scrubber{position:sticky;top:12px;height:calc(100dvh - 130px);min-height:220px;z-index:4}.scrub-track{position:relative;height:100%;width:100%;cursor:pointer;touch-action:none}.scrub-track:before{content:"";position:absolute;left:50%;top:4px;bottom:4px;width:2px;background:var(--line);border-radius:2px;transform:translate(-50%)}.scrub-tick{position:absolute;left:50%;width:7px;height:2px;background:var(--line);border-radius:2px;transform:translate(-50%,-50%)}.scrub-year{position:absolute;left:0;right:0;transform:translateY(-50%);text-align:center;font-size:12px;font-weight:700;color:var(--muted);background:var(--bg);padding:3px 0;-webkit-user-select:none;user-select:none;pointer-events:none}.scrub-thumb{position:absolute;left:50%;width:10px;height:10px;border-radius:999px;background:var(--accent);transform:translate(-50%,-50%);box-shadow:0 0 0 3px var(--bg);z-index:2}.scrub-bubble{position:absolute;left:calc(100% + 8px);transform:translateY(14px);white-space:nowrap;background:var(--accent);color:#fff;font-size:13px;font-weight:600;padding:5px 10px;border-radius:999px;box-shadow:var(--shadow);pointer-events:none;z-index:3}.photo-map{height:72vh;min-height:460px;border-radius:14px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);position:relative;z-index:0}.map-marker img{width:46px;height:46px;object-fit:cover;border-radius:9px;border:2px solid #fff;box-shadow:0 1px 5px #00000073;cursor:pointer;display:block}.leaflet-container{font-family:inherit;background:#e9e7e2}.place-view p{margin:0 0 6px}.place-edit{display:flex;flex-direction:column;gap:10px}.place-edit>label{font-weight:600;color:var(--text);font-size:14px}.locpick{display:flex;flex-direction:column;gap:8px}.locpick .search{flex:none}.locpick-map{height:200px;border-radius:10px;overflow:hidden;border:1px solid var(--line)}.locpick-hint{margin:0;font-size:13px}.loc-pin{display:grid;place-items:center}.loc-pin span{width:14px;height:14px;border-radius:999px;background:var(--accent);border:3px solid #fff;box-shadow:0 1px 4px #00000073}.porch{display:flex;flex-direction:column;gap:12px;max-width:760px}.chat-list{display:flex;flex-direction:column;gap:3px;height:62vh;min-height:320px;overflow-y:auto;padding:12px 6px;border:1px solid var(--line);border-radius:14px;background:var(--panel);box-shadow:var(--shadow)}.chat-empty{margin:auto}.msg{display:flex;gap:8px;align-items:flex-end;padding:1px 6px}.msg.mine{flex-direction:row-reverse}.msg-av{width:30px;flex:0 0 auto}.msg-col{display:flex;flex-direction:column;max-width:76%}.msg.mine .msg-col{align-items:flex-end}.msg-head{display:flex;align-items:baseline;gap:6px;margin:6px 0 1px 12px;font-size:12px}.msg.mine .msg-head{flex-direction:row-reverse;margin:6px 12px 1px 0}.msg-author{color:var(--muted);font-weight:700}.msg-time{color:var(--muted)}.chat-day{align-self:center;margin:12px auto 6px;padding:3px 12px;font-size:12px;font-weight:700;color:var(--muted);background:#f1efe9;border:1px solid var(--line);border-radius:999px}.bubble{position:relative;background:#f1efe9;border-radius:14px;padding:7px 12px;font-size:15px;line-height:1.45;white-space:pre-wrap;word-break:break-word}.msg.mine .bubble{background:var(--accent);color:#fff}.bubble,.poll,.comment{-webkit-touch-callout:none}.ctx-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200}.ctx-menu{position:fixed;z-index:1201;min-width:150px;display:flex;flex-direction:column;gap:2px;padding:6px;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow)}.ctx-reacts{display:flex;gap:2px;padding-bottom:5px;margin-bottom:3px;border-bottom:1px solid var(--line)}.ctx-react{background:none;border:0;cursor:pointer;font-size:22px;line-height:1;padding:4px 6px;border-radius:8px}.ctx-react:hover{background:#f1efe9}.ctx-item{background:none;border:0;text-align:left;cursor:pointer;color:var(--text);font-size:15px;padding:9px 10px;border-radius:8px;font-family:inherit}.ctx-item:hover{background:#f1efe9}.ctx-danger{color:var(--error)}.reactions{display:flex;flex-wrap:wrap;gap:4px;margin:3px 0 2px 12px}.msg-content{position:relative}.msg-content.has-reactions{margin-bottom:14px}.msg-content.has-reactions>.bubble,.msg-content.has-reactions>.poll{padding-bottom:16px}.msg-content .reactions{position:absolute;right:8px;bottom:-10px;z-index:1;margin:0}.reaction{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;font-size:13px;line-height:1.2;background:#f1efe9;border:1px solid var(--line);border-radius:999px;cursor:pointer;color:var(--text)}.reaction span{font-size:16px;line-height:1}.reaction.mine{background:#eef1f4;border-color:var(--accent);color:var(--accent);font-weight:600}.comment-reactions{margin:5px 0 0}.poll{position:relative;max-width:320px;display:flex;flex-direction:column;gap:8px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:10px 12px}.poll-q{font-weight:700;font-size:15px;line-height:1.3}.poll-options{display:flex;flex-direction:column;gap:6px}.poll-option{position:relative;display:flex;align-items:center;gap:8px;overflow:hidden;text-align:left;background:#f1efe9;border:1px solid var(--line);border-radius:9px;padding:8px 10px;cursor:pointer;color:var(--text);font-size:14px}.poll-option:hover{border-color:var(--accent)}.poll-option.mine{border-color:var(--accent);background:#eef1f4}.poll-bar{position:absolute;left:0;top:0;bottom:0;z-index:0;background:#e3e8ee;transition:width .3s ease}.poll-option.mine .poll-bar{background:#dce6f0}.poll-option-text{position:relative;z-index:1;flex:1}.poll-option-count{position:relative;z-index:1;font-weight:700;font-variant-numeric:tabular-nums;color:var(--muted)}.poll-option.mine .poll-option-count{color:var(--accent)}.poll-total{font-size:12px}.poll-fields{display:flex;flex-direction:column;gap:8px}.poll-fields-label{font-weight:600;font-size:14px;color:var(--text)}.poll-field-row{display:flex;gap:8px;align-items:center}.poll-field-row input{flex:1}.poll-btn{flex:0 0 auto}.composer{display:flex;gap:8px;align-items:flex-end}.composer textarea{flex:1;resize:none;font-family:inherit;font-size:16px;line-height:1.4;max-height:140px;background:#f1efe9;border:1px solid var(--line);border-radius:12px;padding:10px 12px;color:var(--text)}.call-shell{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#0e0f11}.call-connecting{display:grid;place-items:center;color:#fff}.call-header{display:flex;align-items:center;gap:12px;color:#fff;background:#16181b;padding:calc(12px + env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) 12px max(16px,env(safe-area-inset-left))}.call-header-info{display:flex;flex-direction:column;min-width:0;flex:1}.call-header-info strong{font-size:16px}.call-roster{font-size:13px;color:#ffffffb3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.call-header-btn{flex:0 0 auto;background:#ffffff24;color:#fff;border:0;border-radius:9px;padding:8px 14px;font-weight:700;font-family:inherit;font-size:14px;cursor:pointer}.call-header-btn:hover{background:#ffffff3d}.call-stage{flex:1;min-height:0}.call-shell.minimized{inset:auto;right:max(16px,env(safe-area-inset-right));bottom:calc(16px + env(safe-area-inset-bottom));width:min(320px,calc(100vw - 32px));background:#16181b;border:1px solid #2a2d31;border-radius:14px;box-shadow:0 6px 24px #0006;overflow:hidden}.call-mini{display:flex;flex-direction:column}.call-mini-info{display:flex;flex-direction:column;gap:1px;align-items:flex-start;text-align:left;background:none;border:0;cursor:pointer;padding:10px 12px;color:#fff;width:100%}.call-mini-info:hover{background:#ffffff14}.call-mini-info strong{font-size:14px}.call-mini-info .muted{font-size:12px;color:#ffffffa6}.porch-workspace{display:flex;gap:16px;align-items:flex-start}.rooms-rail{flex:0 0 220px;position:sticky;top:16px;align-self:flex-start;background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:10px;max-height:80vh;display:flex;flex-direction:column}.rooms-rail-head{display:flex;align-items:center;gap:8px;margin:4px 6px 10px}.rooms-rail-head h2{margin:0;font-size:14px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);flex:1}button.sm{padding:5px 10px;font-size:14px}.rooms-rail nav{display:flex;flex-direction:column;gap:2px;flex:1 1 auto;overflow-y:auto;min-height:0}.rail-voice-slot:not(:empty){flex:0 0 auto;margin-top:8px}.room-item{display:flex;align-items:center;gap:8px;text-decoration:none;color:var(--text);padding:8px 10px;border-radius:9px;font-size:15px;font-weight:600}.room-item:hover{background:#f1efe9}.room-item.active{background:#eef1f4;color:var(--accent)}.room-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-live{font-size:10px;font-weight:800;letter-spacing:.04em;color:#fff;background:#3a8a4f;padding:2px 6px;border-radius:999px}.room-unread{font-size:12px;font-weight:700;color:#fff;background:var(--accent);padding:1px 7px;border-radius:999px}.chan-cat{display:flex;align-items:center;justify-content:space-between;padding:12px 8px 3px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.chan-add{background:none;border:0;color:var(--muted);font-size:17px;line-height:1;cursor:pointer;padding:0 4px}.chan-add:hover{color:var(--text)}.room-item.chan{width:100%;background:none;border:0;text-align:left;cursor:pointer;font-family:inherit}.room-item.chan:disabled{opacity:.5;cursor:default}.chan-hash,.chan-speaker{color:var(--muted);flex:0 0 auto}.room-item.chan.voice.in,.room-item.chan.voice.in .chan-speaker{color:var(--accent)}.chan-count{flex:0 0 auto;font-size:11px;font-weight:700;color:var(--muted);background:#e9e6e0;padding:1px 7px;border-radius:999px}.rail-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100}.rail-menu{position:fixed;min-width:168px;max-width:240px;background:var(--panel);border:1px solid var(--line);border-radius:10px;box-shadow:0 12px 30px #00000040;padding:5px}.rail-menu-head{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:5px 8px 6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rail-menu-item{display:block;width:100%;text-align:left;background:none;border:0;padding:8px 10px;border-radius:7px;font-size:14px;font-weight:600;color:var(--text);cursor:pointer}.rail-menu-item:hover{background:#f1efe9}.rail-menu-item.danger{color:#c0302f}.rail-menu-item.danger:hover{background:#fbeceb}.porch-workspace .porch{flex:1;min-width:0;max-width:none}.room-empty{flex:1;padding:48px 20px;text-align:center}.call-banner{display:flex;align-items:center;gap:12px;justify-content:space-between;background:#3a8a4f;color:#fff;padding:10px 20px;font-size:14px}.call-banner strong{font-weight:800}.call-banner .muted-inv{color:#fffc}.call-banner-join{background:#ffffff2e;color:#fff;text-decoration:none;font-weight:700;padding:6px 14px;border-radius:9px;white-space:nowrap;border:0;cursor:pointer;font-family:inherit;font-size:inherit}.call-banner-join:hover{background:#ffffff4d}.call-btn{display:inline-flex;align-items:center;gap:8px}.call-btn.live{background:#3a8a4f}.call-btn.live:hover{background:#347a46}.call-btn.leave{background:var(--error)}.call-btn.leave:hover{background:#9a3636}.live-dot{width:9px;height:9px;border-radius:999px;background:#fff;animation:live-pulse 1.6s ease-out infinite}@keyframes live-pulse{0%{box-shadow:0 0 #ffffffa6}70%{box-shadow:0 0 0 7px #fff0}to{box-shadow:0 0 #fff0}}.room-entry{display:flex;flex-direction:column}.room-callers{list-style:none;margin:2px 0 6px;padding:0 0 0 14px;display:flex;flex-direction:column;gap:4px}.room-callers li{display:flex;flex-direction:column;gap:2px;min-width:0}.caller-av{width:20px;height:20px;border-radius:999px;flex:0 0 auto;object-fit:cover;overflow:hidden;display:inline-grid;place-items:center;background:#eef1f4;color:var(--accent);font-size:9px;font-weight:800}.caller-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.caller-state{flex:0 0 auto;display:inline-grid;place-items:center;color:var(--muted)}.caller-av.speaking{box-shadow:0 0 0 2px #3ba55d}.caller-row{display:flex;align-items:center;gap:8px;width:100%;min-width:0;background:none;border:0;padding:2px 4px 2px 0;border-radius:6px;font:inherit;font-size:13px;color:var(--text);text-align:left;cursor:pointer}.caller-row:disabled{cursor:default}.caller-row:not(:disabled):hover{background:#f1efe9}.caller-you{color:var(--muted);font-weight:600}.caller-mute-tag{margin-left:auto;flex:0 0 auto;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}.caller-vol{display:flex;align-items:center;gap:8px;padding:1px 4px 4px 28px}.caller-vol input[type=range]{flex:1;min-width:0;accent-color:var(--accent);height:4px}.caller-vol-mute{flex:0 0 auto;background:none;border:0;padding:0;font-size:11px;font-weight:700;color:var(--accent);cursor:pointer}.caller-vol-pct{flex:0 0 auto;font-size:11px;color:var(--muted);width:36px;text-align:right}.room-row{display:flex;align-items:center;gap:2px}.room-row .room-item{flex:1;min-width:0}.room-join{flex:0 0 auto;display:grid;place-items:center;padding:6px;border:0;border-radius:8px;background:none;color:var(--muted);cursor:pointer}.room-join:hover{background:#eef1f4;color:var(--accent)}.room-join.live{color:#3ba55d}.room-injoin{flex:0 0 auto;font-size:11px;font-weight:800;color:#3ba55d;padding:0 8px}.voice-bar{position:fixed;left:12px;bottom:12px;z-index:1000;width:264px;max-width:calc(100vw - 24px);background:#20242e;color:#fff;border-radius:12px;padding:8px 8px 10px 12px;box-shadow:0 10px 30px #00000059;display:flex;flex-direction:column;gap:6px}.voice-bar.docked{position:static;left:auto;bottom:auto;width:auto;z-index:auto;box-shadow:none;padding:8px 8px 9px 10px}.voice-bar-loading{align-items:center;justify-content:center;min-height:40px;font-size:13px}.voice-bar-info{display:flex;align-items:center;gap:9px}.voice-bar-dot{width:9px;height:9px;border-radius:999px;background:#3ba55d;flex:0 0 auto}.voice-bar-text{display:flex;flex-direction:column;line-height:1.25;min-width:0}.voice-bar-text strong{font-size:13px;color:#3ba55d}.voice-bar-room{font-size:12px;color:#ffffffb3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voice-controls{display:flex;align-items:center;gap:6px}.vctl{flex:0 0 auto;display:grid;place-items:center;width:38px;height:34px;padding:0;line-height:0;border:0;border-radius:8px;background:#2b303b;color:#e3e6ea;cursor:pointer}.vctl:hover{background:#353b48}.vctl.off{background:#3b2030;color:#f25478}.vctl.off:hover{background:#4a2740}.vctl.active{background:#3ba55d;color:#fff}.vctl.active:hover{background:#2f8a4c}.vctl.leave{background:#d83c3e;color:#fff;margin-left:auto}.vctl.leave:hover{background:#c0302f}.voice-bar-dot.off{background:#f25478}.voice-video{position:fixed;right:16px;bottom:16px;z-index:999;width:360px;max-width:calc(100vw - 32px);height:240px;background:#000;border-radius:12px;overflow:hidden;box-shadow:0 10px 30px #0006}.voice-video-grid{width:100%;height:100%}.voice-video:fullscreen{top:0;right:0;bottom:0;left:0;width:100%;height:100%;max-width:none;border-radius:0}.voice-video-bar{position:absolute;top:7px;right:7px;z-index:2;display:flex;gap:4px}.vv-btn{display:grid;place-items:center;width:28px;height:28px;padding:0;border:0;border-radius:7px;background:#14161ca6;color:#fff;cursor:pointer}.vv-btn:hover{background:#14161ceb}.voice-video-show{position:fixed;right:16px;bottom:16px;z-index:999;display:inline-flex;align-items:center;gap:7px;padding:8px 13px;border:0;border-radius:999px;background:#20242e;color:#fff;font-size:13px;font-weight:600;cursor:pointer;box-shadow:0 8px 24px #00000059}.voice-video-show:hover{background:#2b303b}@media (max-width: 720px){.voice-bar{left:8px;right:8px;bottom:8px;width:auto}.voice-video{right:8px;left:8px;bottom:84px;width:auto}.voice-video-show{right:8px;bottom:84px}}@media (max-width: 720px){.porch-workspace{flex-direction:column}.rooms-rail{flex:1 0 auto;width:100%;position:static;max-height:none}.rooms-rail nav{flex-direction:row;flex-wrap:wrap}}.storagebar{padding:8px 20px;border-bottom:1px solid var(--line);background:var(--panel)}.storagebar-row{display:flex;align-items:center;gap:10px}.storagebar-track{display:flex;width:200px;height:9px;border-radius:999px;overflow:hidden;background:#e9e6e0;flex:0 0 auto;margin-left:auto}.storagebar-track .seg{height:100%}.seg.photos,.swatch.photos{background:#3e566b}.seg.videos,.swatch.videos{background:#3a8a4f}.seg.chat,.swatch.chat{background:#c9a13b}.swatch.free{background:#e9e6e0}.storagebar-label{font-size:14px;color:var(--muted)}.storagebar-toggle{background:transparent;border:0;padding:4px 6px;cursor:pointer;display:inline-flex;align-items:center}.storagebar-toggle .chev{width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid var(--muted);transition:transform .15s}.storagebar-toggle.open .chev{transform:rotate(180deg)}.storagebar-detail{display:flex;flex-direction:column;gap:6px;margin-top:10px;max-width:440px;margin-left:auto}.storagebar-item{display:flex;align-items:center;gap:10px;font-size:14px}.swatch{width:11px;height:11px;border-radius:3px;flex:0 0 auto}.storagebar-item-label{font-weight:600;min-width:54px}.storagebar-item-count{flex:1;font-size:13px}.storagebar-item-bytes{font-variant-numeric:tabular-nums;font-weight:600}.drive-list{list-style:none;margin:4px 0 0;padding:0;display:flex;flex-direction:column;gap:6px}.drive-item-wrap{background:var(--panel);border:1px solid var(--line);border-radius:12px}.drive-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--panel);border:1px solid var(--line);border-radius:12px}.drive-item-wrap .drive-item{border:0}.drive-icon{flex:0 0 auto;width:44px;height:44px;display:grid;place-items:center}.file-ico{width:40px;height:40px;display:block}.file-thumb{width:44px;height:44px;object-fit:cover;border-radius:8px;display:block}.drag-handle{cursor:pointer}.drive-item.drop-over{outline:2px solid var(--accent);outline-offset:-2px;background:#eef3f8}.drive-crumbs .link.drop-over{background:#eef3f8;outline:2px solid var(--accent);outline-offset:3px;border-radius:6px}.drive-check{flex:0 0 auto;width:24px;height:24px;padding:0;border-radius:999px;display:grid;place-items:center;background:var(--panel);border:2px solid var(--line);color:#fff;font-size:13px;font-weight:800;cursor:pointer}.drive-check.on{background:var(--accent);border-color:var(--accent)}.drive-item.sel{background:#eef3f8;outline:2px solid var(--accent);outline-offset:-2px}.drive-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:12px;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:8px 12px}.drive-toolbar-count{font-weight:600;margin-right:auto}.drive-preview{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;display:grid;place-items:center;gap:14px;background:#020617eb;padding:max(24px,env(safe-area-inset-top)) 20px}.drive-preview img{max-width:92vw;max-height:80vh;border-radius:8px;display:block}.drive-preview-x{position:fixed;top:calc(14px + env(safe-area-inset-top));right:16px;width:40px;height:40px;padding:0;border-radius:999px;border:0;background:#ffffff24;color:#fff;font-size:22px;line-height:1;cursor:pointer}.drive-preview-x:hover{background:#ffffff3d}.drive-preview-bar{display:flex;align-items:center;gap:12px;color:#fff;max-width:92vw}.drive-preview-name{font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drive-preview-bar button{background:#ffffff24;border:0;color:#fff}.drive-preview-bar button:hover{background:#ffffff3d}.drive-main{flex:1 1 auto;min-width:0;display:flex;flex-direction:column}.drive-name{color:var(--text);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drive-meta{font-size:13px;color:var(--muted)}.drive-item .link{flex:0 0 auto}.drive-share{padding:0 14px 12px 70px;display:flex;flex-wrap:wrap;align-items:center;gap:8px}.drive-share-pick{background:#f1efe9;border:1px solid var(--line);border-radius:9px;padding:6px 10px;font-size:14px;font-family:inherit;color:var(--text)}@media (max-width: 620px){.drive-share{padding-left:14px}}.drive-crumbs{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin:8px 0 12px;font-size:14px}.drive-crumbs .link{font-weight:600}.drive-crumbs .link:disabled{color:var(--text);cursor:default;opacity:1}.drive-crumb{display:inline-flex;align-items:center;gap:6px}.drive-crumb-sep{color:var(--muted)}.drive-folder-open,.drive-file-main{background:none;border:0;text-align:left;cursor:pointer;padding:0}.drive-move{flex:0 0 auto;background:#f1efe9;border:1px solid var(--line);border-radius:9px;padding:5px 8px;font-size:14px;font-family:inherit;color:var(--text);cursor:pointer;max-width:130px}.wiki-input{font-family:inherit}.wiki-body{line-height:1.65;font-size:16px;margin:6px 0 10px;word-break:break-word}.wiki-body p{margin:0 0 12px}.wiki-body h2{font-size:20px;margin:18px 0 8px}.wiki-body h3{font-size:17px;margin:16px 0 6px}.wiki-body ul,.wiki-body ol{margin:0 0 12px;padding-left:22px}.wiki-body li{margin:2px 0}.wiki-body a{color:var(--accent)}.wiki-body blockquote{margin:0 0 12px;padding-left:12px;border-left:3px solid var(--line);color:var(--muted)}.wiki-body-plain{white-space:pre-wrap}.wiki-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}.wiki-gallery-thumb{padding:0;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--panel);cursor:pointer;aspect-ratio:1}.wiki-gallery-thumb img{width:100%;height:100%;object-fit:cover;display:block}.wiki-gallery-edit{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.wiki-gallery-edit-item{position:relative;width:96px;height:96px;border-radius:10px;overflow:hidden;border:1px solid var(--line)}.wiki-gallery-edit-item img{width:100%;height:100%;object-fit:cover;display:block}.wiki-thumb-x{position:absolute;top:3px;right:3px;display:grid;place-items:center;width:22px;height:22px;border:0;border-radius:999px;background:#0009;color:#fff;font-size:15px;line-height:1;cursor:pointer}.wiki-thumb-x:hover{background:#000000d1}.wiki-meta{margin:2px 0 0}.wiki-layout{display:grid;grid-template-columns:210px minmax(0,1fr) 270px;gap:28px;align-items:start}.wiki-rail{position:sticky;top:16px;font-size:14px}.wiki-index-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.wiki-index-head h2{margin:0;font-size:22px}.upload.sm{padding:6px 12px;font-size:14px}.wiki-index-search{width:100%;margin:10px 0 6px;padding:7px 10px;font-size:14px;font-family:inherit;background:var(--panel);border:1px solid var(--line);border-radius:9px;color:var(--text)}.wiki-index-sort{width:100%;margin-bottom:10px;padding:7px 10px;font-size:14px;font-family:inherit;background:#f1efe9;border:1px solid var(--line);border-radius:9px;color:var(--text)}.wiki-index-list{list-style:none;margin:0;padding:0;max-height:70vh;overflow:auto}.wiki-index-list li{margin:0}.wiki-index-link{display:block;padding:5px 8px;border-radius:8px;text-decoration:none;color:var(--text);line-height:1.3;border-left:2px solid transparent}.wiki-index-link:hover{background:#ecece6}.wiki-index-link.current{background:#eef1f4;color:var(--accent);font-weight:700;border-left-color:var(--accent)}.wiki-index-year{color:var(--muted);font-size:13px;font-weight:400}.wiki-article{min-width:0}.wiki-article .recipe-head h2{font-size:28px;border-bottom:1px solid var(--line);padding-bottom:8px}.wiki-aside{display:flex;flex-direction:column;gap:16px}.wiki-infobox{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px;box-shadow:var(--shadow)}.wiki-infobox-cover{aspect-ratio:4 / 3;border-radius:8px;overflow:hidden;background:#f1efe9;margin-bottom:10px}.wiki-infobox-cover img{width:100%;height:100%;object-fit:cover;display:block}.wiki-infobox-cover .cover-mono{width:100%;height:100%;font-size:56px}.wiki-infobox-title{font-weight:800;font-size:15px;text-align:center;margin-bottom:10px}.wiki-facts{display:grid;grid-template-columns:auto 1fr;gap:4px 10px;margin:0;font-size:14px}.wiki-facts dt{color:var(--muted);font-weight:700}.wiki-facts dd{margin:0}.wiki-infobox-tags{margin-top:10px;margin-bottom:0}.wiki-toc{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px 14px}.wiki-toc-head{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700;margin-bottom:8px}.wiki-toc ul{list-style:none;margin:0;padding:0}.wiki-toc li{margin:3px 0}.wiki-toc li.sub{padding-left:14px}.wiki-toc .link{text-align:left;line-height:1.35}@media (max-width: 980px){.wiki-layout{grid-template-columns:minmax(0,1fr)}.wiki-rail{position:static}.wiki-index{order:3}.wiki-aside{order:2}.wiki-article{order:1}.wiki-index-list{max-height:none}.wiki-infobox-cover{max-width:280px}}.rte{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--panel)}.rte-toolbar{display:flex;flex-wrap:wrap;gap:2px;padding:6px;border-bottom:1px solid var(--line);background:#f8f7f4}.rte-btn{background:transparent;border:1px solid transparent;color:var(--muted);border-radius:7px;padding:4px 9px;font-size:14px;font-weight:700;cursor:pointer}.rte-btn:hover{background:#ecece6;color:var(--text)}.rte-btn.on{background:#eef1f4;color:var(--accent);border-color:var(--line)}.rte-block{background:var(--panel);border:1px solid var(--line);color:var(--text);border-radius:7px;padding:4px 8px;margin-right:4px;font-family:inherit;font-size:14px;font-weight:700;cursor:pointer}.rte-block:hover{background:#ecece6}.rte-content{padding:10px 14px}.rte-content .ProseMirror{outline:none;min-height:200px;line-height:1.6;font-size:16px}.rte-content .ProseMirror p{margin:0 0 10px}.rte-content .ProseMirror h2{font-size:20px;margin:14px 0 6px}.rte-content .ProseMirror h3{font-size:17px;margin:12px 0 6px}.rte-content .ProseMirror ul,.rte-content .ProseMirror ol{padding-left:22px}.wiki-controls{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:14px}.wiki-controls select{background:#f1efe9;border:1px solid var(--line);border-radius:10px;padding:8px 10px;font-size:14px;color:var(--text);font-family:inherit}.album-meta{font-size:12px;color:var(--accent);font-weight:600}.wiki-byline{margin:2px 0 0}.album-by{font-size:12px;color:var(--muted)}.hub-photos{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.hub-photo{width:72px;height:72px;border-radius:8px;overflow:hidden;background:var(--panel);display:block}.hub-photo img{width:100%;height:100%;object-fit:cover;display:block}.hub-family{display:flex;flex-direction:column;gap:10px;margin-bottom:8px}.hub-rel-cards{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.hub-person{display:inline-flex;align-items:center;gap:8px;text-decoration:none;color:var(--text);background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:4px 12px 4px 4px;font-size:14px;font-weight:600}.hub-person:hover{border-color:var(--accent)}.detail-stories{margin-top:6px}.detail-stories h4{margin:0 0 6px;font-size:14px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.story-links{list-style:none;margin:0 0 6px;padding:0;display:flex;flex-direction:column;gap:3px;font-size:14px}.agenda{display:flex;flex-direction:column;gap:18px;max-width:680px}.agenda-divider{margin:6px 0 0;font-size:14px;color:var(--muted);border-top:1px solid var(--line);padding-top:14px}.agenda-month{display:flex;flex-direction:column;gap:8px}.agenda-month-label{margin:0 0 4px;font-size:14px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.event-card{display:flex;gap:14px;align-items:baseline;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px 14px;box-shadow:var(--shadow)}.event-when{flex:0 0 148px;font-weight:700;font-size:14px;color:var(--accent)}.event-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.event-title{font-weight:600}.event-loc{font-size:14px}.event-note{margin:4px 0 0;font-size:15px;white-space:pre-wrap;word-break:break-word}.event-actions{display:flex;gap:8px;flex:0 0 auto}.event-form{display:flex;flex-direction:column;gap:10px;max-width:520px;margin-bottom:6px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px;box-shadow:var(--shadow)}.event-form input[type=date]{font-family:inherit}@media (max-width: 560px){.event-card{flex-direction:column;gap:4px}.event-when{flex-basis:auto}}.search-section{margin-bottom:18px}@media (hover: none){.tree-unlink{opacity:1}}.dialog-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;display:flex;align-items:center;justify-content:center;overflow-y:auto;padding:clamp(16px,8vh,80px) 16px max(16px,env(safe-area-inset-bottom));background:#0206178c}.dialog-card{width:400px;max-width:100%;display:flex;flex-direction:column;gap:14px;background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:20px 20px 18px}.dialog-card h3{margin:0;font-size:18px}.dialog-card form{display:flex;flex-direction:column;gap:14px}.dialog-card label{color:var(--text);font-weight:600}.dialog-body{margin:0;line-height:1.45}.dialog-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:2px}.btn-danger{background:var(--error);border-color:transparent;color:#fff}.btn-danger:hover{background:#9a3636}.trash-link{font-size:14px}.trash-note{margin:0 0 16px;font-size:14px;line-height:1.45;max-width:640px}.trash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.trash-card{margin:0;display:flex;flex-direction:column;gap:8px}.trash-thumb{width:100%;aspect-ratio:1;object-fit:cover;border-radius:10px;background:var(--panel);display:block}.trash-actions{display:flex;gap:8px}.trash-actions .ghost{flex:1}.trash-forever{color:var(--error)}.trash-forever:hover{border-color:var(--error)}.trash-row{flex-wrap:wrap;row-gap:8px}.sb-cover-empty{display:grid;place-items:center;width:100%;height:100%;background:#efe9dd;color:var(--muted);font-weight:700;font-size:14px}.sb-view{max-width:1000px}.sb-crumb{align-items:center;gap:12px}.sb-title{font-size:22px;margin:0}.sb-empty{text-align:center;padding:40px 0;display:flex;flex-direction:column;align-items:center;gap:14px}.sb-stage{display:flex;align-items:center;gap:8px}.sb-flip{flex:0 0 auto;width:44px;height:44px;border-radius:999px;border:1px solid var(--line);background:var(--panel);color:var(--muted);font-size:26px;line-height:1;cursor:pointer;display:grid;place-items:center}.sb-flip:hover:not(:disabled){color:var(--text);border-color:var(--accent)}.sb-flip:disabled{opacity:.4;cursor:default}.sb-book{flex:1;min-width:0;position:relative;perspective:1800px}.sb-page{position:relative;width:100%;aspect-ratio:4 / 3;overflow:hidden;-webkit-user-select:none;user-select:none;border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow)}.bg-paper{background:linear-gradient(#fcf9f1,#f4eee0)}.bg-white{background:#fff}.bg-kraft{background:#cdab7e}.bg-linen{background:#ece6da}.bg-cork{background:#c79a62}.bg-slate{background:#2f343a}.sb-flip-layer{position:absolute;top:0;right:0;bottom:0;left:0;transform-origin:left center;backface-visibility:hidden;pointer-events:none;box-shadow:-10px 0 28px #00000047}@keyframes sb-turn-next{0%{transform:rotateY(0)}to{transform:rotateY(-110deg)}}@keyframes sb-turn-prev{0%{transform:rotateY(-110deg)}to{transform:rotateY(0)}}.sb-flip-layer.flip-next{animation:sb-turn-next .55s ease-in forwards}.sb-flip-layer.flip-prev{animation:sb-turn-prev .55s ease-out forwards}.sb-page-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;pointer-events:none;padding:16px;text-align:center}.sb-item{position:absolute}.sb-item.editable{cursor:move;touch-action:none}.sb-item.selected{outline:2px solid var(--accent);outline-offset:3px}.sb-photo{position:relative;line-height:0}.sb-photo img{width:100%;height:auto;display:block}.frame-polaroid{background:#fff;padding:5% 5% 0;box-shadow:0 3px 12px #00000047}.frame-polaroid .sb-caption{padding:7% 5% 9%;text-align:center;font-size:13px;color:#333;min-height:1.1em;word-break:break-word;line-height:1.3}.frame-plain{background:#fff;padding:2.5%;box-shadow:0 2px 9px #00000038}.frame-rounded{box-shadow:0 2px 9px #00000038;border-radius:7%}.frame-rounded .sb-photo img{border-radius:7%}.frame-jagged{filter:drop-shadow(0 2px 6px rgba(0,0,0,.3))}.frame-jagged .sb-photo img{clip-path:polygon(0% 4%,4% 0%,8% 4%,12% 0%,16% 4%,20% 0%,24% 4%,28% 0%,32% 4%,36% 0%,40% 4%,44% 0%,48% 4%,52% 0%,56% 4%,60% 0%,64% 4%,68% 0%,72% 4%,76% 0%,80% 4%,84% 0%,88% 4%,92% 0%,96% 4%,100% 0%,100% 96%,96% 100%,92% 96%,88% 100%,84% 96%,80% 100%,76% 96%,72% 100%,68% 96%,64% 100%,60% 96%,56% 100%,52% 96%,48% 100%,44% 96%,40% 100%,36% 96%,32% 100%,28% 96%,24% 100%,20% 96%,16% 100%,12% 96%,8% 100%,4% 96%,0% 100%)}.frame-wavy{filter:drop-shadow(0 2px 6px rgba(0,0,0,.3))}.frame-wavy .sb-photo img{--sb-scallop: radial-gradient(11px at 50% 16px, #000 99%, #0000 101%) 50% -1px / 24px 51% repeat-x, radial-gradient(11px at 50% calc(100% - 16px) , #000 99%, #0000 101%) 50% calc(100% + 1px) / 24px 51% repeat-x;-webkit-mask:var(--sb-scallop);mask:var(--sb-scallop)}.sb-caption-float{text-align:center;font-size:12px;color:var(--text);margin-top:3px;word-break:break-word}.sb-handle{position:absolute;width:22px;height:22px;border-radius:999px;background:var(--accent);border:2px solid #fff;box-shadow:0 1px 4px #0006;cursor:pointer;touch-action:none;z-index:50}.sb-resize{right:-11px;bottom:-11px;cursor:nwse-resize}.sb-rotate{left:50%;top:-32px;transform:translate(-50%);cursor:grab}.sb-pageline{text-align:center;font-size:13px;margin:8px 0}.sb-tools,.sb-itembar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:center;margin:4px 0}.sb-itembar{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:8px 10px;box-shadow:var(--shadow);margin-top:10px}.sb-frames{display:flex;gap:4px;flex-wrap:wrap}.sb-frame-chip{background:#f1efe9;border:1px solid var(--line);border-radius:999px;padding:5px 11px;font-size:13px;cursor:pointer;color:var(--text);font-family:inherit}.sb-frame-chip.on{background:#eef1f4;border-color:var(--accent);color:var(--accent);font-weight:600}.sb-caption-input{flex:1;min-width:140px}.sb-picker{width:640px;max-width:100%}.sb-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:6px;max-height:50vh;overflow-y:auto}.sb-pick{padding:0;border:0;border-radius:8px;overflow:hidden;cursor:pointer;aspect-ratio:1;background:var(--panel)}.sb-pick img{width:100%;height:100%;object-fit:cover;display:block}.sb-pick.on{outline:3px solid var(--accent);outline-offset:-3px}.sb-strip{display:flex;gap:8px;overflow-x:auto;padding:8px 2px;margin:4px 0}.sb-thumb{position:relative;flex:0 0 auto;width:76px;padding:0;border:2px solid var(--line);border-radius:8px;background:var(--panel);cursor:pointer;overflow:hidden;touch-action:none}.sb-thumb.current{border-color:var(--accent)}.sb-thumb-page{position:relative;display:block;width:100%;aspect-ratio:4 / 3}.sb-thumb-item{position:absolute;height:auto;box-shadow:0 1px 2px #0000004d}.sb-thumb-n{position:absolute;bottom:2px;right:4px;font-size:10px;font-weight:700;color:#fff;background:#00000080;border-radius:4px;padding:0 4px}.sb-bgs{display:flex;align-items:center;gap:8px;justify-content:center;flex-wrap:wrap;margin:6px 0;font-size:13px}.sb-bg-swatch{width:26px;height:26px;border-radius:7px;border:1px solid var(--line);cursor:pointer;padding:0}.sb-bg-swatch.on{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}.sb-trash-card{cursor:default}.sb-trash-actions{display:flex;gap:8px;margin-top:6px}.sb-trash-actions .ghost{flex:1}
