:root{--bg: #faf9f5;--surface: #ffffff;--surface-2: #f2efe6;--border: #e9e3d6;--text: #3a342a;--muted: #8c8268;--accent: #5f7d4f;--accent-soft: #5f7d4f1f;--link: #9a5b34;--danger: #b4593f;--radius: 18px;--radius-sm: 12px;--shadow-sm: 0 1px 2px rgba(74, 60, 36, .07), 0 2px 8px rgba(74, 60, 36, .05);--shadow-md: 0 6px 20px rgba(74, 60, 36, .1), 0 2px 6px rgba(74, 60, 36, .06);--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);color-scheme:light}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,system-ui,sans-serif;-webkit-font-smoothing:antialiased;overscroll-behavior-y:none}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer}h1{font-size:1.5rem;margin:0}h2{font-size:1.05rem}.app{min-height:100%;display:flex;flex-direction:column}.app__header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:calc(12px + var(--safe-top)) 16px 12px;background:color-mix(in oklab,var(--bg) 88%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.brand{display:flex;align-items:center;gap:8px;font-weight:600}.brand__mark{color:var(--link);font-size:1.25rem}.header-actions{display:flex;align-items:center;gap:8px}.header-icon{display:grid;place-items:center;width:40px;height:40px;border-radius:50%;color:var(--muted);background:var(--surface);border:1px solid var(--border)}.header-icon:active{background:var(--surface-2)}.header-icon:disabled{opacity:.5}.header-icon--active{background:var(--accent);border-color:var(--accent);color:#fff}.lang-switch{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:2px}.lang-switch__btn{border:none;background:transparent;color:var(--muted);font-size:.72rem;font-weight:700;letter-spacing:.03em;padding:5px 9px;border-radius:999px}.lang-switch__btn.active{background:var(--accent);color:#fff}.app__main{flex:1;padding-bottom:calc(24px + var(--safe-bottom))}.page{padding:16px;max-width:880px;margin:0 auto}.page__head{margin-bottom:16px}.muted{color:var(--muted);font-size:.9rem}.section-title{color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;margin:20px 0 8px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:transform .12s ease,box-shadow .12s ease}.card:active{transform:scale(.98)}.card:hover{box-shadow:var(--shadow-md)}.card__media{aspect-ratio:4 / 3;background:var(--surface-2)}.card__media img{width:100%;height:100%;object-fit:cover;display:block}.card__placeholder,.card__media .card__placeholder{width:100%;height:100%;display:grid;place-items:center;color:var(--border);font-size:2.5rem}.card__body{padding:10px 12px}.card__title{font-size:1rem;margin:0 0 4px}.card__meta{display:flex;gap:10px;margin:0;color:var(--muted);font-size:.8rem}.back-link{color:var(--muted);font-size:.9rem;display:inline-block;margin-bottom:8px}.segmented{display:grid;grid-template-columns:1fr 1fr;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px;margin:4px 0 16px}.segmented button{border:none;background:transparent;color:var(--muted);padding:9px;border-radius:6px;font-weight:500}.segmented button.active{background:var(--accent);color:#fff}.photo{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--surface-2);border:1px solid var(--border);touch-action:pan-x pan-y}.photo img{width:100%;display:block}.photo--empty{aspect-ratio:4 / 3;display:grid;place-items:center;color:var(--muted)}.photo--placing{cursor:crosshair}.hotspot{position:absolute;transform:translate(-50%,-50%);display:flex;align-items:center;gap:6px;z-index:2;cursor:pointer;-webkit-user-select:none;user-select:none}.hotspot--arranging{cursor:grab;touch-action:none}.hotspot--dragging{z-index:6;cursor:grabbing}.hotspot--dragging .hotspot__dot{transform:scale(1.15);box-shadow:0 4px 14px #00000080}.hotspot__dot{width:26px;height:26px;display:grid;place-items:center;background:var(--accent);color:#fff;font-size:.78rem;font-weight:700;border-radius:50%;border:2px solid #fff;box-shadow:0 2px 8px #00000080}.hotspot__label{background:#000000b8;color:#fff;font-size:.78rem;padding:3px 8px;border-radius:999px;white-space:nowrap;max-width:40vw;overflow:hidden;text-overflow:ellipsis}.hotspot--leaf .hotspot__dot{background:var(--surface-2)}.section-list{display:flex;flex-direction:column;gap:1px;border-radius:var(--radius);overflow:hidden}.section-row{display:flex;justify-content:space-between;align-items:center;padding:14px;background:var(--surface)}.section-row:active{background:var(--surface-2)}.chip-row{display:flex;flex-wrap:wrap;gap:6px}.chip{display:inline-flex;align-items:center;font-size:.78rem;padding:3px 10px;border-radius:999px;border:1px solid var(--border);background:var(--surface-2);color:var(--text)}.chip--btn{transition:background .1s ease}.chip--active{background:var(--accent);border-color:var(--accent);color:#fff}.richtext{line-height:1.55;color:var(--text)}.richtext p{margin:0 0 10px}.richtext a{color:var(--link);text-decoration:underline}.inventory__filter{width:100%;padding:10px 12px;margin-bottom:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text)}.contents__summary{margin:0 0 12px}.table-scroll{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}.table{width:100%;border-collapse:collapse;font-size:.88rem}.table th,.table td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--border);white-space:nowrap}.table th{color:var(--muted);font-weight:600;background:var(--surface);position:sticky;top:0}.table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.table tbody tr:last-child td{border-bottom:none}.cell-strong{font-weight:600}.table-empty{text-align:center;color:var(--muted)}.group-row td{background:var(--surface-2);font-weight:600;position:relative}.loc-trail{display:inline-flex;align-items:center;flex-wrap:wrap;gap:2px}.loc-trail--here{color:var(--muted);font-weight:600}.loc-link{color:var(--link)}.loc-sep{color:var(--muted);margin:0 5px;font-weight:700}.group-count{float:right;color:var(--muted);font-weight:600;font-size:.8rem}.source-link{color:var(--link);display:inline-flex;align-items:center;gap:6px}.depth-badge{font-size:.7rem;color:var(--muted);border:1px solid var(--border);border-radius:4px;padding:0 4px}.search-box{display:flex;gap:8px;align-items:center}.search-box input{flex:1;min-width:0;padding:13px 16px;font-size:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text)}.search-clear{flex:none}.search-box input:focus{outline:2px solid var(--accent);border-color:var(--accent)}.filters{margin:14px 0;display:flex;flex-direction:column;gap:12px}.filter-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);display:block;margin-bottom:6px}.results{display:flex;flex-direction:column;gap:8px;margin-top:8px}.result-row{display:flex;align-items:center;gap:12px;padding:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm)}.result-thumb{width:48px;height:48px;flex:none;border-radius:8px;overflow:hidden;background:var(--surface-2);display:grid;place-items:center;color:var(--border)}.result-thumb img{width:100%;height:100%;object-fit:cover}.result-body{display:flex;flex-direction:column;gap:3px;min-width:0}.result-title{font-weight:600}.result-matches{display:flex;flex-wrap:wrap;gap:4px 8px;font-size:.8rem}.match{color:var(--text);background:var(--surface-2);border-radius:6px;padding:1px 7px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.match--note{font-style:italic;color:var(--muted);background:transparent;padding:1px 0}.match--more{background:transparent;color:var(--muted);padding:1px 0}.match--click{border:1px solid var(--border);cursor:pointer;font:inherit}.match--click:hover{border-color:var(--accent);color:var(--link)}.empty{text-align:center;padding:48px 16px}.empty a{color:var(--link);text-decoration:underline}.spinner-wrap{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px;color:var(--muted)}.spinner{width:22px;height:22px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-box{padding:14px;border:1px solid var(--danger);color:var(--danger);border-radius:var(--radius-sm);margin:16px}.login{min-height:100dvh;display:grid;place-items:center;padding:24px}.login__card{width:100%;max-width:360px;display:flex;flex-direction:column;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:28px 24px}.login__top{display:flex;align-items:center;justify-content:space-between;gap:10px}.login__brand{display:flex;align-items:center;gap:10px}.login__brand h1{font-size:1.25rem}.login__brand .brand__mark{font-size:1.6rem}.login__sub{margin:-6px 0 6px}.field{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:var(--muted)}.field input{padding:11px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:1rem}.field input:focus{outline:2px solid var(--accent);border-color:var(--accent)}.btn-primary{margin-top:6px;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:600;font-size:1rem}.btn-primary:disabled{opacity:.6}.login__error{color:var(--danger);font-size:.85rem;margin:0}.crumbs{display:flex;flex-wrap:wrap;align-items:center;gap:2px;font-size:.82rem;margin-bottom:8px}.crumb{color:var(--muted);padding:2px 0}.crumb--current{color:var(--text);font-weight:600}.crumb-sep{color:var(--muted);margin:0 6px;font-weight:700}.crumb-wrap{display:inline-flex;align-items:center}.btn-secondary,.btn-ghost{padding:10px 14px;border-radius:var(--radius-sm);font-weight:500;font-size:.9rem}.btn-secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.btn-secondary--on{background:var(--accent);border-color:var(--accent);color:#fff}.btn-secondary:disabled{opacity:.5}.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}.btn-sm{padding:8px 12px;font-size:.85rem}.btn-danger{color:var(--danger);border-color:color-mix(in oklab,var(--danger) 40%,var(--border));margin-top:24px;width:100%}.btn-danger-solid{background:var(--danger)}.link-btn{background:none;border:none;color:var(--link);font-size:.85rem;padding:4px 6px}.page__head--row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.section-head{display:flex;align-items:center;justify-content:space-between}.editable-title{display:flex;align-items:center;gap:6px}.title-edit{display:flex;gap:8px;align-items:center}.title-edit input{flex:1;padding:8px 10px;font-size:1.2rem;font-weight:600;background:var(--surface-2);border:1px solid var(--accent);border-radius:var(--radius-sm);color:var(--text)}.photo-controls{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:12px}.map-toolbar{margin-bottom:10px;display:flex;gap:8px}.map-toolbar .btn-secondary{flex:1}.arrange-hint{margin:-2px 0 10px}.legend{list-style:none;margin:12px 0 0;padding:0;display:flex;flex-direction:column;gap:6px}.legend__item{display:flex;align-items:center;gap:8px;font-size:.92rem}.legend__num{width:22px;height:22px;flex:none;display:grid;place-items:center;background:var(--accent);color:#fff;border-radius:50%;font-size:.72rem;font-weight:700}.legend__link{color:var(--link)}.section-row--editable{display:flex;align-items:stretch;gap:1px}.section-row__link{flex:1;display:flex;justify-content:space-between;align-items:center;padding:14px;background:var(--surface)}.section-row__link:active{background:var(--surface-2)}.inv-editor{display:flex;flex-direction:column;gap:10px;margin-bottom:8px}.inv-editor__list{display:flex;flex-direction:column;gap:6px}.inv-row{display:flex;gap:1px}.inv-row__main{flex:1;display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:11px 12px;text-align:left;background:var(--surface);border:1px solid var(--border);border-right:none;border-radius:var(--radius-sm) 0 0 var(--radius-sm);color:var(--text)}.inv-row__del{width:44px;flex:none;background:var(--surface);border:1px solid var(--border);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--danger)}.inv-row__del:active{background:var(--surface-2)}.picker{display:flex;flex-direction:column;gap:10px}.picker__create{display:flex;gap:8px}.picker__create input{flex:1;padding:9px 11px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text)}.picker__create button{padding:0 16px;background:var(--surface-2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm)}.chip--add{border-style:dashed;color:var(--muted)}.taxonomy-row{margin-top:8px}.rs__control{background:var(--surface-2)!important;border:1px solid var(--border)!important;border-radius:var(--radius-sm)!important;box-shadow:none!important;min-height:44px!important}.rs__control--is-focused{border-color:var(--accent)!important;outline:2px solid var(--accent)!important}.rs__placeholder{color:var(--muted)!important}.rs__input-container,.rs__single-value{color:var(--text)!important}.rs__multi-value{background:var(--accent-soft)!important;border:1px solid var(--border)!important;border-radius:999px!important}.rs__multi-value__label{color:var(--text)!important}.rs__multi-value__remove:hover{background:var(--danger)!important;color:#fff!important}.rs__indicator-separator{background:var(--border)!important}.rs__dropdown-indicator,.rs__clear-indicator{color:var(--muted)!important}.rs__menu{background:var(--surface)!important;border:1px solid var(--border)!important;border-radius:var(--radius-sm)!important;box-shadow:var(--shadow-md)!important;overflow:hidden!important}.rs__option{color:var(--text)!important;cursor:pointer!important}.rs__option--is-focused{background:var(--surface-2)!important}.rs__option--is-selected{background:var(--accent)!important;color:#fff!important}.combo{position:relative;display:flex;flex-direction:column;gap:8px}.combo__selected{gap:6px}.combo__input{width:100%;padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:1rem}.combo__input:focus{outline:2px solid var(--accent);border-color:var(--accent)}.combo__menu{position:absolute;top:100%;left:0;right:0;z-index:5;margin-top:4px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);max-height:220px;overflow-y:auto;display:flex;flex-direction:column}.combo__opt{display:flex;align-items:center;gap:8px;text-align:left;padding:10px 12px;background:none;border:none;color:var(--text);font-size:.92rem;border-bottom:1px solid var(--border)}.combo__opt:last-child{border-bottom:none}.combo__opt:hover,.combo__opt:focus{background:var(--surface-2)}.combo__opt--add{color:var(--link);font-weight:600}.combo__dot{width:10px;height:10px;border-radius:50%;background:var(--muted);flex:none}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#3a301e57;display:flex;align-items:flex-end;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sheet{width:100%;max-width:520px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;padding:18px 18px calc(20px + var(--safe-bottom));max-height:85dvh;overflow-y:auto;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-md);animation:sheet-up .18s ease}@keyframes sheet-up{0%{transform:translateY(20px);opacity:.6}}.sheet__head{display:flex;align-items:center;justify-content:space-between}.sheet__head h2{font-size:1.1rem}.sheet__close{background:none;border:none;color:var(--muted);font-size:1.1rem}.sheet__body{display:flex;flex-direction:column;gap:14px}.field select,.notes-textarea{width:100%;padding:11px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:1rem}.notes-textarea{resize:vertical;font-family:inherit;line-height:1.5}.segmented--inline{margin:0}.move-note{margin:0;padding:9px 11px;background:var(--accent-soft);border-radius:var(--radius-sm);font-size:.85rem;color:var(--text)}.inv-row__thumb,.item-cell__thumb,.item-photo__preview{flex:none;padding:0;border:1px solid var(--border);background:var(--surface-2);border-radius:8px;overflow:hidden;cursor:zoom-in}.inv-row__thumb{width:44px;height:44px}.inv-row__thumb img,.item-cell__thumb img,.item-photo__preview img{width:100%;height:100%;object-fit:cover;display:block}.item-cell{display:inline-flex;align-items:center;gap:8px}.item-cell__thumb{width:30px;height:30px}.inv-row__edit{margin-left:auto;color:var(--muted)}.item-photo{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.upload-error{color:var(--danger);font-size:.85rem}.move-field{margin-top:6px;padding-top:14px;border-top:1px solid var(--border)}.move-field .btn-secondary{width:100%}.tree,.tree-children{list-style:none;margin:0;padding:0}.tree{margin-top:8px}.tree-actions{display:flex;gap:12px;flex:none}.tree-row{display:flex;align-items:center;gap:6px;padding:7px 8px;border-radius:8px}.tree-row:hover{background:var(--surface-2)}.tree-toggle{width:20px;height:20px;flex:none;display:grid;place-items:center;background:none;border:none;color:var(--muted);transition:transform .12s ease}.tree-toggle.open{transform:rotate(90deg)}.tree-toggle--leaf{visibility:hidden}.tree-icon{color:var(--accent);flex:none}.tree-place-thumb{width:26px;height:26px;flex:none;padding:0;border:1px solid var(--border);border-radius:6px;overflow:hidden;background:var(--surface-2);cursor:zoom-in}.tree-place-thumb img{width:100%;height:100%;object-fit:cover;display:block}.tree-filter{max-width:440px}.view-toggle{max-width:240px;margin:0 0 12px}.tree-place{font-weight:600;color:var(--text)}.tree-place:hover{color:var(--link)}.tree-count{color:var(--muted);font-size:.8rem}.tree-item{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:5px 8px;font-size:.9rem}.tree-item__dot{color:var(--border)}.tree-item__thumb{width:24px;height:24px;flex:none;padding:0;border:1px solid var(--border);border-radius:5px;overflow:hidden;background:var(--surface-2);cursor:zoom-in}.tree-item__thumb img{width:100%;height:100%;object-fit:cover;display:block}.tree-item__name{color:var(--text)}.item-photo__preview{width:56px;height:56px}.match__thumb{width:22px;height:22px;border-radius:5px;object-fit:cover;vertical-align:middle;margin-right:5px;cursor:zoom-in}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;background:#141008db;display:grid;place-items:center;padding:24px;cursor:zoom-out}.lightbox img{max-width:100%;max-height:100%;border-radius:8px}.lightbox__close{position:fixed;top:calc(12px + var(--safe-top));right:16px;width:40px;height:40px;border-radius:50%;background:#ffffff26;color:#fff;border:none;font-size:1.1rem}@media(min-width:640px){h1{font-size:1.75rem}.grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.sheet{border-radius:var(--radius);margin-bottom:5vh;align-self:center}.sheet-backdrop{align-items:center}}
