:root{--md-primary: #006b5f;--md-primary-hover: #005248;--md-on-primary: #ffffff;--md-primary-container: #9ff2e4;--md-primary-container-hover: #83d6c8;--md-on-primary-container: #00201c;--md-secondary: #4a635f;--md-on-secondary: #ffffff;--md-secondary-container: #cce8e1;--md-on-secondary-container: #203b36;--md-tertiary: #66587a;--md-tertiary-container: #ecdcff;--md-error: #ba1a1a;--md-error-container: #ffdad6;--md-error-container-subtle: #fff3f3;--md-on-error-container: #410002;--md-info-container: #d8e2ff;--md-info-container-subtle: #eef4ff;--md-on-info-container: #001a41;--md-info-outline: #adc6ff;--md-warning: #f2be4b;--md-warning-container: #ffdea6;--md-warning-container-subtle: #fff9ef;--md-warning-container-hover: #f6c778;--md-on-warning-container: #271900;--md-warning-outline: #e6c9a0;--md-warning-outline-variant: #ead5b4;--md-success-container: #8defd5;--md-on-success-container: #003c35;--md-surface: #fbfdf8;--md-surface-container-lowest: #f8faf6;--md-surface-container-low: #f3f6f0;--md-surface-container: #edf1eb;--md-surface-container-high: #e8ece5;--md-surface-container-highest: #e2e6df;--md-on-surface: #191c1b;--md-on-surface-variant: #3f4946;--md-outline: #6f7975;--md-outline-variant: #bec9c4;--md-outline-soft: #e0e7e3;--md-inverse-surface: #111c19;--md-inverse-on-surface: #ffffff;--md-link: #285ea8;--md-focus-ring: color-mix(in srgb, var(--md-primary) 28%, transparent);--md-scrim: #000000;--md-backdrop-subtle: color-mix(in srgb, var(--md-on-surface) 34%, transparent);--md-backdrop: color-mix(in srgb, var(--md-on-surface) 46%, transparent);--md-backdrop-strong: color-mix(in srgb, var(--md-on-surface) 68%, transparent);--md-shape-corner-none: 0;--md-shape-corner-extra-small: 4px;--md-shape-corner-small: 8px;--md-shape-corner-medium: 12px;--md-shape-corner-large: 16px;--md-shape-corner-extra-large: 28px;--md-shape-corner-full: 999px;--md-type-display-small-size: 1.72rem;--md-type-headline-small-size: 1.7rem;--md-type-title-large-size: 1.2rem;--md-type-title-medium-size: 1rem;--md-type-title-small-size: .9rem;--md-type-body-medium-size: .9rem;--md-type-body-small-size: .84rem;--md-type-label-large-size: .875rem;--md-type-label-medium-size: .82rem;--md-type-label-small-size: .78rem;--md-type-label-extra-small-size: .66rem;--md-type-line-height-tight: 1.1;--md-type-line-height-title: 1.3;--md-type-line-height-body: 1.6;--md-type-line-height-compact: 1.35;--md-elevation-level0: none;--md-elevation-level1: 0 1px 2px rgba(17, 28, 25, .14), 0 1px 3px rgba(17, 28, 25, .1);--md-elevation-level2: 0 2px 6px rgba(17, 28, 25, .14), 0 8px 24px rgba(17, 28, 25, .12);--md-elevation-level3: 0 6px 14px rgba(17, 28, 25, .16), 0 14px 34px rgba(17, 28, 25, .14);--md-elevation-dialog: 0 20px 70px rgba(0, 0, 0, .22);--md-elevation-dialog-strong: 0 20px 70px rgba(0, 0, 0, .28);--md-elevation-fab: 0 10px 28px rgba(0, 84, 74, .3);--md-elevation-fab-hover: 0 12px 32px rgba(0, 84, 74, .36);--bookshelf-surface: #4a2313;--bookshelf-plank-start: #5c2c18;--bookshelf-plank-end: #3f1b0d;--bookshelf-grain-highlight: rgba(255, 255, 255, .05);--bookshelf-grain-shadow: rgba(42, 18, 8, .18);--bookshelf-row-wash: rgba(104, 55, 31, .24);--bookshelf-row-depth: rgba(70, 31, 16, .18);--bookshelf-shelf-shadow: rgba(47, 20, 10, .64);--bookshelf-shelf-face: rgba(102, 49, 24, .96);--bookshelf-shelf-edge: rgba(87, 38, 18, .98);--bookshelf-shelf-gap: rgba(39, 17, 9, 1);--bookshelf-inset-highlight: rgba(255, 255, 255, .12);--bookshelf-inset-shadow: rgba(23, 9, 4, .38);--bookshelf-cover-elevation: drop-shadow(0 7px 5px rgba(0, 0, 0, .34));--bookshelf-cover-elevation-hover: drop-shadow(0 10px 7px rgba(0, 0, 0, .4)) brightness(1.03);--bookshelf-title-shadow: 0 1px 2px rgba(0, 0, 0, .58);color:var(--md-on-surface);background:var(--md-surface);font-family:Inter,Noto Sans JP,Yu Gothic UI,Hiragino Kaku Gothic ProN,Meiryo,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at 12% 0%,color-mix(in srgb,var(--md-primary-container) 42%,transparent),transparent 32%),var(--md-surface)}button,input,select,textarea{font:inherit}button{min-height:40px;border:0;border-radius:var(--md-shape-corner-full);background:var(--md-surface-container-high);color:var(--md-on-surface);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 16px;font-weight:600;transition:background .14s ease,box-shadow .14s ease,color .14s ease}button:hover{background:var(--md-surface-container-highest)}button:disabled{cursor:not-allowed;opacity:.58}button:disabled:hover{background:var(--md-surface-container-high)}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--md-focus-ring);outline-offset:2px}.material-symbol{flex:0 0 auto;fill:currentColor}input,select,textarea{width:100%;min-height:40px;border:1px solid var(--md-outline-variant);border-radius:var(--md-shape-corner-small);background:var(--md-surface);color:var(--md-on-surface);padding:0 12px}textarea{min-height:96px;padding:10px 12px;resize:vertical}.app-shell{min-height:100vh;max-width:1440px;margin:0 auto;padding:24px 24px 96px}.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:16px;margin:-8px -8px 16px;padding:12px 16px;border-radius:var(--md-shape-corner-small);background:color-mix(in srgb,var(--md-surface) 92%,transparent);box-shadow:var(--md-elevation-level1);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}h1,h2,h3,p{margin-top:0}h1{margin-bottom:0;font-size:var(--md-type-headline-small-size);line-height:var(--md-type-line-height-tight)}h2{font-size:var(--md-type-title-large-size);line-height:var(--md-type-line-height-title)}h3{font-size:var(--md-type-title-medium-size)}.topbar-actions,.detail-actions,.quick-actions,.form-actions,.tag-suggestions,.inline-actions{display:flex;flex-wrap:wrap;gap:8px}.primary-button{min-height:40px;background:var(--md-primary);color:var(--md-on-primary);font-weight:700;box-shadow:var(--md-elevation-level1)}.primary-button:hover{background:var(--md-primary-hover);box-shadow:var(--md-elevation-level2)}.primary-button:disabled,.primary-button:disabled:hover{background:var(--md-surface-container-high);color:var(--md-on-surface-variant);box-shadow:var(--md-elevation-level0)}.icon-button{width:40px;min-width:40px;padding:0;border-radius:var(--md-shape-corner-full);background:transparent;color:var(--md-on-surface-variant);box-shadow:var(--md-elevation-level0);font-size:var(--md-type-title-medium-size)}.icon-button:hover{background:var(--md-surface-container-high)}.icon-button .material-symbol{width:22px;height:22px}.button-with-icon{display:inline-flex;align-items:center;gap:8px}.button-icon{width:18px;height:18px;flex:0 0 auto;fill:currentColor}.button-icon.material-symbol{fill:currentColor}.settings-menu{position:relative}.settings-menu-panel{position:absolute;top:calc(100% + 8px);right:0;z-index:40;display:grid;width:min(280px,calc(100vw - 32px));gap:4px;padding:8px;border-radius:var(--md-shape-corner-small);background:var(--md-surface-container);box-shadow:var(--md-elevation-level2)}.settings-menu-panel button{min-height:44px;justify-content:flex-start;border-radius:var(--md-shape-corner-small);background:transparent;box-shadow:var(--md-elevation-level0)}.settings-menu-panel button:hover{background:var(--md-surface-container-high)}.settings-menu-panel button:disabled:hover{background:transparent}.settings-menu-section-title,.settings-menu-empty{margin:0;padding:8px 12px 4px;color:var(--md-on-surface-variant);font-size:var(--md-type-label-small-size);font-weight:700}.settings-menu-empty{display:block;padding-bottom:8px;font-weight:600}.settings-menu-divider{height:1px;margin:4px 0;background:var(--md-outline-variant)}.secondary-button{width:100%;background:var(--md-secondary-container);color:var(--md-on-secondary-container);box-shadow:var(--md-elevation-level0)}.secondary-button:hover{background:color-mix(in srgb,var(--md-secondary-container) 82%,var(--md-on-secondary-container))}.danger-button{color:var(--md-error);background:var(--md-error-container)}.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}.notice-line,.filters-panel,.detail-dialog,.empty-state{border:1px solid var(--md-outline-variant);border-radius:var(--md-shape-corner-small);background:var(--md-surface);box-shadow:var(--md-elevation-level1)}.app-footer{display:flex;justify-content:flex-end;margin-top:14px;color:var(--md-on-surface-variant);font-size:var(--md-type-label-medium-size)}.footer-connection{display:flex;align-items:center;gap:8px;min-height:32px;padding:4px 10px;border-radius:var(--md-shape-corner-full);color:var(--md-on-surface-variant);background:var(--md-surface-container-low)}.state-dot{width:10px;height:10px;border-radius:var(--md-shape-corner-full);background:var(--md-error)}.state-dot.online{background:var(--md-primary)}.notice-line{margin:0 0 12px;padding:12px;color:var(--md-on-surface-variant);background:var(--md-surface-container-low)}.empty-actions{display:flex;flex-wrap:wrap;gap:8px}.active-filter-chips{display:flex;flex-wrap:wrap;gap:6px}.active-filter-chips button{display:inline-flex;min-width:0;min-height:30px;align-items:center;gap:6px;padding:4px 8px;background:var(--md-secondary-container);color:var(--md-on-secondary-container);font-size:var(--md-type-label-medium-size)}.active-filter-chips span{min-width:0;overflow-wrap:anywhere}.active-filter-chips strong{flex:0 0 auto;color:var(--md-secondary);font-size:var(--md-type-label-small-size)}.workspace{display:grid;grid-template-columns:minmax(0,1fr);gap:18px;align-items:start}.filters-toggle-row{display:flex;flex-wrap:wrap;align-items:center;flex:1 1 360px;gap:10px;min-width:0;order:1}.filter-toggle-button{min-height:44px;min-width:118px;padding:0 10px;border:1px solid var(--md-outline-variant);border-radius:var(--md-shape-corner-small);background:var(--md-surface);box-shadow:var(--md-elevation-level1);white-space:nowrap}.filter-toggle-button:hover{background:var(--md-surface-container-low)}.filter-toggle-count{display:inline-flex;align-items:center;justify-content:center;min-width:64px;min-height:26px;padding:2px 8px;border-radius:var(--md-shape-corner-full);background:var(--md-surface-container);color:var(--md-on-surface-variant);font-size:var(--md-type-label-small-size);font-weight:800}.filter-toggle-count.active{background:var(--md-secondary-container);color:var(--md-on-secondary-container)}.filter-toggle-summary{flex:1 1 320px;min-width:0}.disclosure-icon{transition:transform .14s ease}.disclosure-icon.open{transform:rotate(180deg)}.filters-panel{flex:0 0 100%;margin-top:10px;order:20;padding:14px;background:color-mix(in srgb,var(--md-surface) 88%,var(--md-surface-container-low))}.search-field{display:grid;grid-template-columns:24px minmax(0,1fr);align-items:center;gap:8px;min-height:50px;margin-bottom:14px;padding:0 14px;border:1px solid var(--md-outline-variant);border-radius:var(--md-shape-corner-medium);background:var(--md-surface);color:var(--md-on-surface-variant)}.search-field input{min-height:48px;border:0;background:transparent;padding:0}.field-block{display:grid;gap:6px;margin-bottom:12px}.field-block span{color:var(--md-on-surface-variant);font-size:var(--md-type-body-small-size);font-weight:700}.field-error,.field-count{margin:0;font-size:var(--md-type-label-medium-size)}.field-error{color:var(--md-error);font-weight:700}.field-count{color:var(--md-on-surface-variant);text-align:right}.field-count.invalid{color:var(--md-error)}input[aria-invalid=true],select[aria-invalid=true],textarea[aria-invalid=true]{border-color:var(--md-error)}.field-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.field-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.field-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.filter-chip-groups{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px 28px;padding:14px 0;border-top:1px solid var(--md-outline-variant);border-bottom:1px solid var(--md-outline-variant)}.filter-chip-group p{margin-bottom:8px;color:var(--md-on-surface-variant);font-size:var(--md-type-body-small-size);font-weight:700}.filter-chip-row{display:flex;flex-wrap:wrap;gap:8px}.filter-chip-row button{min-width:0;min-height:38px;padding:6px 14px;border:1px solid var(--md-outline-variant);border-radius:var(--md-shape-corner-full);background:var(--md-surface);box-shadow:var(--md-elevation-level0);white-space:nowrap}.filter-chip-row button.active{border-color:var(--md-primary);background:var(--md-primary-container);color:var(--md-on-primary-container);font-weight:800}.tag-filter-field{max-width:320px;margin-top:14px}.filter-condition-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding-top:12px;border-top:1px solid var(--md-outline-variant)}.filter-condition-title{display:inline-flex;align-items:center;min-height:30px;color:var(--md-on-surface-variant);font-size:var(--md-type-body-small-size);font-weight:800}.filter-condition-empty{min-height:30px;padding:5px 10px;border-radius:var(--md-shape-corner-full);background:var(--md-surface-container);color:var(--md-on-surface-variant);font-size:var(--md-type-label-medium-size)}.compact-button{width:auto;min-height:32px;padding:4px 10px;font-size:var(--md-type-label-medium-size)}.segmented-control{display:inline-grid;grid-template-columns:repeat(2,44px);gap:0;width:max-content;border:1px solid var(--md-outline-variant);border-radius:var(--md-shape-corner-small);overflow:hidden}.segmented-control button{width:44px;min-width:44px;min-height:40px;padding:0;border-radius:var(--md-shape-corner-none)}.segmented-control button+button{border-left:1px solid var(--md-outline-variant)}.segmented-control button:first-child{border-radius:var(--md-shape-corner-small) 0 0 var(--md-shape-corner-small)}.segmented-control button:last-child{border-radius:0 var(--md-shape-corner-small) var(--md-shape-corner-small) 0}.segmented-control .active{background:var(--md-secondary-container);color:var(--md-on-secondary-container)}.view-mode-icon{width:20px;height:20px;fill:currentColor}.view-mode-icon.material-symbol{fill:currentColor}.library-area{min-width:0}.library-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:8px;margin-bottom:12px}.toolbar-select{display:block;margin-left:auto;order:2;width:132px}.toolbar-select select{min-height:40px}.manual-order-edit-button{width:auto;min-height:40px;order:3;white-space:nowrap}.toolbar-hint{flex-basis:100%;margin:-2px 0 0;order:30;color:var(--md-on-surface-variant);font-size:var(--md-type-label-medium-size);text-align:right}.sort-direction-icon{width:20px;height:20px;fill:currentColor}.sort-direction-icon.material-symbol{fill:currentColor}.sort-direction-button{order:3}.segmented-control{order:4}.floating-add-button{position:fixed;right:24px;bottom:24px;z-index:16;width:64px;min-width:64px;height:64px;min-height:64px;padding:0;border-radius:var(--md-shape-corner-large);background:var(--md-primary-container);color:var(--md-on-primary-container);box-shadow:var(--md-elevation-fab);font-size:var(--md-type-display-small-size);line-height:var(--md-type-line-height-tight)}.floating-add-icon.material-symbol{width:30px;height:30px}.floating-add-button:hover{background:var(--md-primary-container-hover);box-shadow:var(--md-elevation-fab-hover)}.item-list,.item-grid{display:grid;gap:12px}.item-grid{--bookshelf-row-height: 256px;--bookshelf-column-min: 104px;grid-template-columns:repeat(auto-fill,minmax(var(--bookshelf-column-min),1fr));grid-auto-rows:var(--bookshelf-row-height);align-items:stretch;column-gap:clamp(14px,2vw,28px);row-gap:0;padding:18px clamp(12px,2vw,24px) 0;border-radius:var(--md-shape-corner-small);overflow:hidden;background-color:var(--bookshelf-surface);background-image:linear-gradient(90deg,var(--bookshelf-grain-highlight) 0 1px,transparent 1px 13px),repeating-linear-gradient(90deg,var(--bookshelf-grain-shadow) 0 3px,transparent 3px 12px),repeating-linear-gradient(to bottom,var(--bookshelf-row-wash) 0,var(--bookshelf-row-depth) calc(var(--bookshelf-row-height) - 36px),var(--bookshelf-shelf-shadow) calc(var(--bookshelf-row-height) - 36px),var(--bookshelf-shelf-face) calc(var(--bookshelf-row-height) - 28px),var(--bookshelf-shelf-edge) calc(var(--bookshelf-row-height) - 12px),var(--bookshelf-shelf-gap) calc(var(--bookshelf-row-height) - 4px),var(--bookshelf-shelf-gap) var(--bookshelf-row-height)),linear-gradient(180deg,var(--bookshelf-plank-start),var(--bookshelf-plank-end));box-shadow:inset 0 1px 0 var(--bookshelf-inset-highlight),inset 0 0 42px var(--bookshelf-inset-shadow)}.library-card{border:1px solid var(--md-outline-variant);border-radius:var(--md-shape-corner-small);background:var(--md-surface);overflow:hidden;box-shadow:var(--md-elevation-level1)}.library-card.selected{border-color:var(--md-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--md-primary) 18%,transparent),var(--md-elevation-level2)}.bookshelf-card{display:flex;align-items:flex-end;justify-content:center;min-width:0;min-height:var(--bookshelf-row-height);padding:16px 4px 32px;border:0;border-radius:var(--md-shape-corner-none);background:transparent;box-shadow:var(--md-elevation-level0);overflow:visible}.bookshelf-card.selected{border-color:transparent;box-shadow:var(--md-elevation-level0)}.card-main{position:relative;width:100%;min-height:0;display:grid;grid-template-columns:82px minmax(0,1fr);gap:14px;padding:12px;border:0;border-radius:var(--md-shape-corner-none);text-align:left}.card-select-target{position:absolute;inset:0;z-index:1;width:100%;height:100%;min-height:0;padding:0;border-radius:var(--md-shape-corner-none);background:transparent}.card-select-target:hover{background:color-mix(in srgb,var(--md-primary) 6%,transparent)}.card-select-target:focus-visible{outline-offset:-3px}.cover-thumb{width:82px;aspect-ratio:8 / 11;border-radius:var(--md-shape-corner-small);object-fit:cover;background:var(--md-surface-container-highest)}.bookshelf-card-main{position:relative;display:flex;align-items:flex-end;justify-content:center;width:min(100%,118px);height:calc(var(--bookshelf-row-height) - 64px);min-height:0;padding:0;border:0;border-radius:var(--md-shape-corner-none);background:transparent;box-shadow:var(--md-elevation-level0);overflow:visible;transition:filter .14s ease,transform .14s ease}.bookshelf-card-main:hover{background:transparent;transform:translateY(-3px)}.bookshelf-card-main:active{transform:translateY(-1px)}.bookshelf-card-main:focus-visible{outline:0}.bookshelf-cover{display:block;width:100%;height:100%;border-radius:var(--md-shape-corner-none);background:transparent;filter:var(--bookshelf-cover-elevation);object-fit:contain;object-position:bottom center}.bookshelf-card-main:hover .bookshelf-cover{filter:var(--bookshelf-cover-elevation-hover)}.bookshelf-card.selected .bookshelf-cover,.bookshelf-card-main:focus-visible .bookshelf-cover{outline:3px solid var(--md-primary);outline-offset:5px}.bookshelf-title-overlay{position:absolute;right:0;bottom:0;left:0;display:-webkit-box;max-height:58%;padding:8px 7px;overflow:hidden;border-radius:var(--md-shape-corner-none);background:color-mix(in srgb,var(--md-scrim) 56%,transparent);color:var(--md-inverse-on-surface);font-size:var(--md-type-label-small-size);font-weight:700;line-height:var(--md-type-line-height-compact);opacity:0;overflow-wrap:anywhere;pointer-events:none;text-align:center;text-shadow:var(--bookshelf-title-shadow);transform:translateY(4px);transition:opacity .14s ease,transform .14s ease;-webkit-box-orient:vertical;-webkit-line-clamp:3}.bookshelf-card-main:hover .bookshelf-title-overlay,.bookshelf-card-main:focus-visible .bookshelf-title-overlay{opacity:1;transform:translateY(0)}.card-content{min-width:0}.card-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.card-title-row h2{margin-bottom:6px;overflow-wrap:anywhere}.card-content p{margin-bottom:8px;color:var(--md-on-surface-variant)}.type-pill{flex:0 0 auto;padding:4px 8px;border-radius:var(--md-shape-corner-full);background:var(--md-info-container);color:var(--md-on-info-container);font-size:var(--md-type-label-small-size);font-weight:700}.card-chip-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.card-chip-row span,.card-chip-row .tag-chip{padding:4px 7px;border-radius:var(--md-shape-corner-small);background:var(--md-surface-container);color:var(--md-on-surface-variant);font-size:var(--md-type-label-small-size)}.card-chip-row .tag-chip{position:relative;z-index:2;min-height:0;background:var(--md-warning-container);color:var(--md-on-warning-container)}.card-chip-row .tag-chip:hover{background:var(--md-warning-container-hover)}.short-comment{margin-bottom:0}.tag-row{display:flex;flex-wrap:wrap;gap:6px;padding:0 12px 12px}.tag-row button,.tag-suggestions button{min-height:28px;padding:3px 8px;background:var(--md-warning-container);color:var(--md-on-warning-container);font-size:var(--md-type-label-small-size)}.detail-backdrop{position:fixed;inset:0;z-index:18;display:grid;place-items:start center;padding:42px 18px 18px;background:var(--md-backdrop-subtle)}.detail-dialog{width:min(1120px,100%);max-height:calc(100vh - 60px);overflow:auto;padding:0;border-radius:var(--md-shape-corner-large);background:var(--md-surface);box-shadow:var(--md-elevation-level2)}.detail-dialog-header{position:sticky;top:0;z-index:3;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin:0;padding:20px 24px 14px;border-bottom:1px solid var(--md-outline-variant);background:color-mix(in srgb,var(--md-surface) 96%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.detail-dialog-header h2{margin-bottom:0}.detail-content{display:grid;gap:16px;padding:18px 24px 24px}.detail-summary{display:grid;grid-template-columns:156px minmax(0,1fr) auto;gap:20px;align-items:start}.detail-title-block{min-width:0}.detail-title-block h2{margin:6px 0 8px;font-size:var(--md-type-display-small-size);line-height:var(--md-type-line-height-title)}.detail-cover{width:156px;aspect-ratio:3 / 4;border-radius:var(--md-shape-corner-small);object-fit:cover;background:var(--md-surface-container-highest);box-shadow:var(--md-elevation-level2)}.detail-subtitle{margin-bottom:14px;color:var(--md-on-surface-variant);overflow-wrap:anywhere}.detail-actions{display:grid;grid-template-columns:repeat(3,52px);justify-content:end;gap:8px;padding:14px;border:1px solid var(--md-outline-variant);border-radius:var(--md-shape-corner-small);background:var(--md-surface)}.detail-icon-action{width:52px;min-width:52px;height:52px;min-height:52px;padding:0;border-radius:var(--md-shape-corner-full)}.detail-icon-action.primary{color:var(--md-on-primary);background:var(--md-primary)}.detail-icon-action.danger{color:var(--md-error)}.detail-icon-action svg:not(.material-symbol),.detail-section-icon svg:not(.material-symbol){width:23px;height:23px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.detail-icon-action .material-symbol,.detail-section-icon .material-symbol{width:23px;height:23px;fill:currentColor}.detail-progress-panel{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;padding:12px 14px;border:1px solid var(--md-outline-variant);border-radius:var(--md-shape-corner-small);background:var(--md-surface-container-lowest)}.detail-progress-summary{min-width:0}.detail-progress-summary span{display:block;color:var(--md-on-surface-variant);font-size:var(--md-type-label-medium-size);font-weight:800}.detail-progress-summary strong{display:block;margin-top:3px;font-size:var(--md-type-title-large-size);overflow-wrap:anywhere}.progress-stepper{display:grid;grid-template-columns:52px minmax(0,1fr) 52px 52px;gap:8px;align-items:center;padding:10px;border:1px solid var(--md-outline-variant);border-radius:var(--md-shape-corner-small);background:var(--md-surface-container-low)}.progress-stepper strong{min-width:0;text-align:center;overflow-wrap:anywhere}.draft-progress-stepper{display:grid;gap:6px}.draft-progress-stepper>span{color:var(--md-on-surface-variant);font-size:var(--md-type-label-medium-size);font-weight:700}.detail-section-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.detail-section{display:grid;gap:12px;align-content:start;min-width:0;padding:16px;border:1px solid var(--md-outline-variant);border-radius:var(--md-shape-corner-small);background:var(--md-surface)}.detail-section.wide{grid-column:span 2}.detail-section-header{display:grid;grid-template-columns:42px minmax(0,1fr);gap:10px;align-items:center}.detail-section-icon{width:42px;height:42px;display:grid;place-items:center;border-radius:var(--md-shape-corner-full);color:var(--md-on-success-container);background:var(--md-success-container)}.detail-section h3{margin:0;color:var(--md-on-surface);font-size:var(--md-type-title-medium-size)}.detail-field-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 14px;margin:0}.detail-field-list.single{grid-template-columns:1fr}.detail-field-list.two{grid-template-columns:repeat(2,minmax(0,1fr))}.detail-field-list.three{grid-template-columns:repeat(3,minmax(0,1fr))}.detail-field{min-width:0;padding:10px 0;border-top:1px solid var(--md-outline-soft)}.detail-field dt{margin-bottom:4px;color:var(--md-on-surface-variant);font-size:var(--md-type-label-small-size);font-weight:700;overflow-wrap:anywhere}.detail-field dd{margin:0;overflow-wrap:anywhere;font-weight:650}.detail-field a{color:var(--md-link)}.detail-tags{padding:0}.metadata-description{margin:0;color:var(--md-on-surface-variant);font-size:var(--md-type-body-medium-size);line-height:var(--md-type-line-height-body)}.notes-block{padding:12px;border-radius:var(--md-shape-corner-small);background:var(--md-surface-container-low)}.notes-block pre{white-space:pre-wrap;margin:0;color:var(--md-on-surface-variant)}.empty-state,.empty-detail{padding:24px}.form-backdrop{position:fixed;inset:0;z-index:20;display:grid;place-items:center;padding:18px;background:var(--md-backdrop)}.scanner-backdrop{position:fixed;inset:0;z-index:30;display:grid;place-items:center;padding:18px;background:var(--md-backdrop-strong)}.item-form{width:min(1120px,100%);max-height:calc(100vh - 60px);overflow:auto;border-radius:var(--md-shape-corner-large);background:var(--md-surface);padding:0;box-shadow:var(--md-elevation-dialog)}.bulk-dialog,.manual-order-dialog{width:min(900px,100%);max-height:92vh;overflow:auto;border-radius:var(--md-shape-corner-small);background:var(--md-surface);padding:18px;box-shadow:var(--md-elevation-dialog)}.manual-order-dialog{width:min(840px,100%)}.manual-order-live{min-height:1.4em;margin:8px 0 12px;color:var(--md-on-surface-variant);font-size:var(--md-type-label-large-size)}.manual-order-list{display:grid;gap:8px;max-height:min(58vh,560px);margin:0;padding:0;overflow:auto;list-style:none}.manual-order-row{display:grid;grid-template-columns:40px 44px 44px minmax(0,1fr) auto;gap:10px;align-items:center;min-height:66px;padding:10px;border:1px solid var(--md-outline-variant);border-radius:var(--md-shape-corner-small);background:var(--md-surface-container-low)}.manual-order-row.is-dragging{position:relative;z-index:2;border-color:var(--md-primary);background:var(--md-surface);box-shadow:var(--md-elevation-level2)}.manual-order-drag-handle{touch-action:none;cursor:grab}.manual-order-drag-handle:active{cursor:grabbing}.manual-order-index{display:inline-grid;place-items:center;width:36px;min-width:36px;height:36px;border-radius:var(--md-shape-corner-full);background:var(--md-surface);color:var(--md-on-surface-variant);font-size:var(--md-type-label-medium-size);font-weight:700}.manual-order-cover{width:40px;aspect-ratio:8 / 11;border-radius:var(--md-shape-corner-extra-small);object-fit:cover;background:var(--md-surface-container-highest)}.manual-order-copy{display:grid;gap:2px;min-width:0}.manual-order-copy strong,.manual-order-copy small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.manual-order-copy small{color:var(--md-on-surface-variant)}.manual-order-actions{display:grid;grid-template-columns:repeat(4,40px);gap:4px}.manual-order-actions .icon-button{width:40px;min-width:40px;min-height:40px;padding:0}.bulk-input-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:10px;align-items:end;margin-bottom:14px}.bulk-queue{display:grid;gap:8px;margin-top:14px}.bulk-queue-entry{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;padding:10px;border:1px solid var(--md-outline-variant);border-radius:var(--md-shape-corner-small);background:var(--md-surface-container)}.bulk-queue-entry.loading{border-color:var(--md-info-outline);background:var(--md-info-container-subtle)}.bulk-queue-entry.error{border-color:var(--md-error-container);background:var(--md-error-container-subtle)}.bulk-queue-entry p,.bulk-queue-entry small{margin:3px 0 0;color:var(--md-on-surface-variant)}.scanner-dialog{width:min(620px,100%);border-radius:var(--md-shape-corner-small);background:var(--md-surface);padding:18px;box-shadow:var(--md-elevation-dialog-strong)}.scanner-stage{position:relative;overflow:hidden;aspect-ratio:4 / 3;border-radius:var(--md-shape-corner-small);background:var(--md-inverse-surface)}.scanner-stage video{width:100%;height:100%;object-fit:cover}.scan-frame{position:absolute;inset:22%;border:3px solid var(--md-warning);border-radius:var(--md-shape-corner-small);box-shadow:0 0 0 999px color-mix(in srgb,var(--md-scrim) 24%,transparent)}.manual-scan-row{display:grid;grid-template-columns:minmax(0,1fr) 88px;gap:10px;align-items:end}.form-header{position:sticky;top:0;z-index:3;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin:0;padding:20px 24px 14px;border-bottom:1px solid var(--md-outline-variant);background:color-mix(in srgb,var(--md-surface) 96%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.form-header h2{margin-bottom:0}.form-content{display:grid;gap:16px;padding:18px 24px 24px}.form-summary{display:grid;grid-template-columns:156px minmax(0,1fr);gap:20px;align-items:start}.form-preview-cover{width:156px;aspect-ratio:3 / 4;border-radius:var(--md-shape-corner-small);object-fit:cover;background:var(--md-surface-container-highest);box-shadow:var(--md-elevation-level2)}.form-title-block{min-width:0}.form-title-block h2{margin:6px 0 8px;font-size:var(--md-type-display-small-size);line-height:var(--md-type-line-height-title);overflow-wrap:anywhere}.form-title-block p{margin-bottom:14px;color:var(--md-on-surface-variant);overflow-wrap:anywhere}.form-preview-chips{display:flex;flex-wrap:wrap;gap:6px}.form-preview-chips span{padding:4px 8px;border-radius:var(--md-shape-corner-full);background:var(--md-surface-container);color:var(--md-on-surface-variant);font-size:var(--md-type-label-small-size);font-weight:700}.form-progress-panel{align-items:start}.form-progress-panel .draft-progress-stepper{min-width:min(420px,100%)}.form-section-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.form-section{display:grid;gap:12px;align-content:start;min-width:0;padding:16px;border:1px solid var(--md-outline-variant);border-radius:var(--md-shape-corner-small);background:var(--md-surface)}.form-section.wide{grid-column:span 2}.form-section-header{display:grid;grid-template-columns:42px minmax(0,1fr);gap:10px;align-items:center}.form-section-icon{width:42px;height:42px;display:grid;place-items:center;border-radius:var(--md-shape-corner-full);color:var(--md-on-success-container);background:var(--md-success-container)}.form-section h3{margin:0;color:var(--md-on-surface);font-size:var(--md-type-title-medium-size)}.form-section-icon .material-symbol{width:23px;height:23px}.form-section-body{display:grid;gap:12px}.helper-text{color:var(--md-on-surface-variant);font-size:var(--md-type-body-medium-size)}.lookup-feedback{padding:8px 10px;border:1px solid var(--md-outline-variant);border-radius:var(--md-shape-corner-small);background:var(--md-surface-container-high);color:var(--md-on-surface-variant);font-size:var(--md-type-body-medium-size)}.lookup-feedback.success{border-color:var(--md-info-outline);background:var(--md-info-container-subtle);color:var(--md-on-surface)}.candidate-box,.duplicate-box{display:grid;gap:8px;padding:12px;border:1px solid var(--md-warning-outline);border-radius:var(--md-shape-corner-small);background:var(--md-warning-container-subtle);margin-bottom:12px}.candidate-box{border-color:var(--md-info-outline);background:var(--md-info-container-subtle)}.candidate-box h3,.duplicate-box h3{margin-bottom:2px}.candidate-row,.duplicate-row{display:grid;min-height:0;padding:8px;text-align:left}.duplicate-entry{display:grid;gap:8px}.candidate-row{grid-template-columns:52px minmax(0,1fr);gap:10px;align-items:center}.candidate-thumb{width:52px;aspect-ratio:8 / 11;border-radius:var(--md-shape-corner-small);object-fit:cover;background:var(--md-surface-container-highest)}.candidate-copy{display:grid;gap:2px;min-width:0}.candidate-row small,.duplicate-row small{color:var(--md-on-surface-variant)}.duplicate-row.strong{border-color:var(--md-error)}.duplicate-row[aria-expanded=true]{background:var(--md-surface);box-shadow:inset 3px 0 0 var(--md-error)}.duplicate-detail{display:grid;grid-template-columns:76px minmax(0,1fr);gap:10px;padding:10px;border:1px solid var(--md-warning-outline-variant);border-radius:var(--md-shape-corner-small);background:var(--md-surface)}.duplicate-detail img{width:76px;aspect-ratio:8 / 11;border-radius:var(--md-shape-corner-small);object-fit:cover;background:var(--md-surface-container-highest)}.duplicate-detail-copy{display:grid;gap:8px;min-width:0}.duplicate-detail-copy strong{overflow-wrap:anywhere}.duplicate-detail dl{display:grid;grid-template-columns:72px minmax(0,1fr);gap:4px 8px;margin:0}.duplicate-detail dt,.duplicate-detail dd{min-width:0;margin:0;overflow-wrap:anywhere;font-size:var(--md-type-body-small-size)}.duplicate-detail dt{color:var(--md-on-surface-variant);font-weight:700}.cover-edit-row{display:grid;grid-template-columns:150px minmax(0,1fr);gap:12px;align-items:start}.cover-edit-row img{width:150px;aspect-ratio:8 / 11;border-radius:var(--md-shape-corner-small);object-fit:cover;background:var(--md-surface-container-highest)}.cover-actions{margin:10px 0}.cover-candidate-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:8px;margin-top:10px}.cover-candidate{display:grid;gap:6px;justify-items:center;min-width:0;padding:8px;text-align:center}.cover-candidate img{width:64px;aspect-ratio:8 / 11;border-radius:var(--md-shape-corner-small);object-fit:cover;background:var(--md-surface-container-highest)}.cover-candidate span{max-width:100%;overflow:hidden;color:var(--md-on-surface-variant);font-size:var(--md-type-label-small-size);text-overflow:ellipsis;white-space:nowrap}.form-actions{justify-content:flex-end;padding-top:12px;border-top:1px solid var(--md-outline-variant)}@media(max-width:1160px){.workspace{grid-template-columns:minmax(0,1fr)}}@media(max-width:760px){.app-shell{padding:14px 14px 88px}.topbar,.form-header{align-items:stretch;flex-direction:column}.topbar-actions{display:flex}.workspace,.filter-chip-groups,.field-grid,.field-grid.two,.field-grid.three,.form-summary,.form-section-grid,.cover-edit-row,.duplicate-detail,.progress-stepper,.manual-scan-row,.bulk-input-row,.bulk-queue-entry{grid-template-columns:1fr}.filters-toggle-row{align-items:stretch;flex-direction:column}.filter-toggle-button{width:100%}.filter-toggle-summary{flex-basis:auto;width:100%}.toolbar-hint{text-align:left}.manual-order-actions{grid-template-columns:repeat(4,minmax(44px,1fr))}.manual-order-actions .icon-button{width:100%;min-width:44px;min-height:44px}.manual-order-row{grid-template-columns:44px 44px minmax(0,1fr);gap:8px}.manual-order-drag-handle{grid-column:1;grid-row:1;width:44px;min-width:44px;min-height:44px}.manual-order-index{grid-column:1;grid-row:2}.manual-order-cover{grid-column:2;grid-row:1 / span 2}.manual-order-copy{grid-column:3;grid-row:1 / span 2;align-self:center}.manual-order-actions{grid-column:1 / -1}.duplicate-detail img{width:92px}.detail-backdrop{place-items:end center;padding:12px}.detail-dialog{max-height:calc(100vh - 24px);border-radius:var(--md-shape-corner-large)}.detail-content{max-width:100vw;overflow-x:hidden;padding:16px}.detail-summary,.detail-section-grid,.detail-field-list,.detail-progress-panel,.form-progress-panel{grid-template-columns:1fr;width:100%;max-width:100%}.detail-field-list.two{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 10px}.detail-field-list.three{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px 10px}.detail-field-list.three .detail-field dd{font-size:var(--md-type-body-medium-size)}.detail-section.wide,.form-section.wide{grid-column:auto}.detail-cover,.form-preview-cover{width:112px}.detail-title-block h2,.form-title-block h2{font-size:var(--md-type-title-large-size);overflow-wrap:anywhere}.detail-actions{grid-template-columns:repeat(3,1fr);width:100%;max-width:100%}.detail-icon-action{width:100%;min-width:0;border-radius:var(--md-shape-corner-full)}.detail-progress-panel .quick-actions{display:grid;grid-template-columns:1fr}.filter-condition-row{align-items:flex-start;flex-direction:column}.tag-filter-field{max-width:none}.item-grid{--bookshelf-row-height: 190px;--bookshelf-column-min: 76px;column-gap:10px;padding:14px 10px 0}.bookshelf-card{padding:12px 2px 26px}.bookshelf-card-main{width:min(100%,90px);height:calc(var(--bookshelf-row-height) - 54px)}.bookshelf-title-overlay{padding:6px 5px;font-size:var(--md-type-label-extra-small-size);-webkit-line-clamp:3}.floating-add-button{right:16px;bottom:16px;width:58px;min-width:58px;height:58px;min-height:58px}.card-main{grid-template-columns:72px minmax(0,1fr)}.cover-thumb{width:72px}.item-form{max-height:96vh;border-radius:var(--md-shape-corner-large);padding:0}}
