:root{color:#172126;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;margin:0}button,input,select,textarea{letter-spacing:0}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline-offset:2px;outline:3px solid #167b7f3d}:root{--ink:#12202a;--muted:#637481;--line:#dbe5ea;--line-strong:#b8c9d1;--surface:#fff;--surface-soft:#f7fafc;--page:#f3f7f9;--teal:#00968f;--teal-dark:#004854;--teal-soft:#e0f7f4;--green:#07935e;--green-soft:#e1f7ec;--amber:#e27a00;--amber-soft:#fff1dc;--red:#dd332f;--red-soft:#ffe6e2;--blue:#1e78d7;--blue-soft:#e6f0ff;--purple:#7455db;--purple-soft:#f0ecff;--cyan:#008aa8;--cyan-soft:#e2f7fb;--shadow-soft:0 10px 30px #1a2b3814;--shadow-panel:0 16px 42px #162d3c1a}.app-shell{background:radial-gradient(circle at top right, #00968f17, transparent 440px), linear-gradient(180deg, #fbfdfe 0, var(--page) 460px), var(--page);min-height:100vh;color:var(--ink);grid-template-columns:226px minmax(0,1fr);display:grid}.sidebar{background:radial-gradient(circle at 25% 10%,#00b7a652,#0000 260px),linear-gradient(#083c4d 0%,#00303c 52%,#002936 100%);border-right:1px solid #ffffff17;flex-direction:column;gap:24px;height:100vh;padding:22px 12px;display:flex;position:sticky;top:0;box-shadow:16px 0 44px #00232f38}.brand{align-items:center;gap:12px;padding:0 4px;display:flex}.brand-mark{color:#eaffff;background:#ffffff1a;border-radius:10px;place-items:center;width:42px;height:42px;display:grid;box-shadow:inset 0 0 0 1px #fff3}.brand strong,.brand span{display:block}.brand strong{color:#fff;font-size:17px;line-height:1.2}.brand span{color:#e6fafcb8;margin-top:3px;font-size:12px}.nav-list{gap:8px;display:grid}.nav-item,button,select,input,textarea{font:inherit}.nav-item{color:#eefbfcdb;cursor:pointer;letter-spacing:0;background:0 0;border:0;border-radius:9px;align-items:center;gap:11px;min-height:50px;padding:0 14px;font-weight:850;display:flex}.nav-item.active,.nav-item:hover{color:#fff;background:linear-gradient(135deg,#00a89d,#007b86);box-shadow:0 14px 24px #000d1440}.sidebar-panel{background:#ffffff14;border:1px solid #ffffff29;border-radius:10px;margin-top:auto;padding:14px}.sidebar-panel-title{color:#fff;align-items:center;gap:8px;font-weight:700;display:flex}.sidebar-panel p{color:#e6fafcb8;margin:8px 0 0;font-size:12px;line-height:1.55}.main{flex-direction:column;min-width:0;padding:20px 22px 28px;display:flex}.topbar{order:0}#dashboard-section{order:1}.search-row{order:2}.barcode-panel{order:3}.metrics-grid{order:4}.workspace{order:5}.approval-panel{order:6}#loan-section{order:7}.audit-panel{order:8}.backup-panel{order:9}#history-section{order:10}#dashboard-section,#loan-section,#inventory-section,#map-section,#history-section{scroll-margin-top:18px}.main.page-dashboard .search-row,.main.page-dashboard .workspace,.main.page-dashboard .approval-panel,.main.page-dashboard #loan-section,.main.page-dashboard #history-section,.main.page-inventory #dashboard-section,.main.page-inventory .barcode-panel,.main.page-inventory .metrics-grid,.main.page-inventory .registration-next-panel,.main.page-inventory .audit-panel,.main.page-inventory .backup-panel,.main.page-inventory .approval-panel,.main.page-inventory #loan-section,.main.page-inventory #history-section,.main.page-map #dashboard-section,.main.page-map .search-row,.main.page-map .barcode-panel,.main.page-map .metrics-grid,.main.page-map .registration-next-panel,.main.page-map .audit-panel,.main.page-map .backup-panel,.main.page-map .approval-panel,.main.page-map #loan-section,.main.page-map #history-section,.main.page-map .inventory-panel,.main.page-loan #dashboard-section,.main.page-loan .search-row,.main.page-loan .metrics-grid,.main.page-loan .workspace,.main.page-loan .registration-next-panel,.main.page-loan .audit-panel,.main.page-loan .backup-panel,.main.page-loan #history-section,.main.page-history #dashboard-section,.main.page-history .search-row,.main.page-history .barcode-panel,.main.page-history .metrics-grid,.main.page-history .registration-next-panel,.main.page-history .audit-panel,.main.page-history .backup-panel,.main.page-history .approval-panel,.main.page-history #loan-section,.main.page-history .workspace{display:none}.main.page-inventory .workspace,.main.page-map .workspace{grid-template-columns:minmax(0,1fr)}.main.page-inventory .workspace{grid-template-columns:minmax(0,1.28fr) minmax(360px,.72fr)}.main.page-inventory .map-panel{display:block}.main.page-inventory .map-panel>.panel-heading,.main.page-inventory .map-panel>.photo-map,.main.page-inventory .map-panel>.location-detail{display:none}.main.page-inventory .map-panel>.detail-card{grid-area:auto}.main.page-map .map-panel{grid-template-columns:minmax(310px,.72fr) minmax(420px,1fr)}.topbar{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffdb;border-bottom:1px solid #e3ebef;justify-content:space-between;align-items:center;gap:20px;min-height:58px;margin:-20px -22px 18px;padding:12px 22px;display:flex}.topbar-actions{align-items:center;gap:10px;display:flex}.production-sync{color:#536872;background:#fff;border:1px solid #dbe5ea;border-radius:10px;align-items:center;gap:8px;min-height:38px;margin:-6px 0 12px;padding:8px 12px;font-size:12px;font-weight:800;display:flex;box-shadow:0 8px 18px #1c2f360a}.production-sync.active{color:#075b51;background:#eaf8f6;border-color:#94d4cf}.operator-switch{color:#42525a;background:var(--surface);border:1px solid #d7e3e8;border-radius:999px;align-items:center;gap:9px;min-width:206px;min-height:42px;padding:0 12px;display:flex;box-shadow:0 8px 18px #1c2f360a}.operator-switch.admin{color:#0d5c45;background:var(--green-soft);border-color:#9bd1bb}.operator-switch span{gap:1px;min-width:0;display:grid}.operator-switch small{color:#6d7d84;font-size:10px;line-height:1}.operator-switch strong{width:100%;min-width:0;color:inherit;font-size:13px;font-weight:800;line-height:1.2}h1,h2,h3,p{margin:0}h1{font-size:22px;font-weight:900;line-height:1.2}h2{font-size:17px;font-weight:800;line-height:1.25}h3{font-size:16px;line-height:1.25}.topbar p,.panel-heading p{color:var(--muted);margin-top:6px;font-size:13px}.primary-button,.secondary-button,.ghost-button,.danger-button,.icon-button{cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:8px;font-weight:700;display:inline-flex}.primary-button{color:#fff;background:linear-gradient(135deg,#008c8a,#006977);height:42px;padding:0 16px;box-shadow:0 12px 20px #00697733}.secondary-button,.ghost-button{color:#243238;background:var(--surface);border-color:var(--line);min-height:36px;padding:0 12px}.secondary-button:hover,.ghost-button:hover{background:#f2f7f8}.danger-button{min-height:36px;color:var(--red);background:var(--red-soft);border-color:#f3b3aa;padding:0 12px}button:disabled{cursor:not-allowed;opacity:.45}.search-row{grid-template-columns:minmax(260px,1fr) 180px 160px 160px;gap:10px;margin-bottom:12px;display:grid}.operation-panel{box-shadow:none;background:0 0;border:0;border-radius:0;grid-template-columns:120px minmax(0,1fr) 170px;align-items:stretch;gap:10px;margin-bottom:12px;padding:0;display:grid}.operation-heading{align-content:center;display:grid}.operation-heading h2{color:var(--teal-dark);font-size:13px}.operation-heading p{color:var(--muted);margin-top:5px;font-size:11px;line-height:1.45}.operation-mode-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.operation-mode{text-align:left;color:#243238;cursor:pointer;background:linear-gradient(#fff,#f8fbfc);border:1px solid #d7e6ea;border-radius:9px;gap:4px;min-height:62px;padding:10px 12px;display:grid;box-shadow:0 8px 20px #1c2f360a}.operation-mode.active{color:#063f44;box-shadow:inset 4px 0 0 var(--teal), 0 12px 22px #00898f1a;background:linear-gradient(#f4fffb,#e0f8f4);border-color:#72c7c8}.operation-mode span,.operation-mode small,.operation-current span,.operation-current small{color:var(--muted);font-size:11px;font-weight:800}.operation-mode strong{font-size:13px;line-height:1.35}.operation-current{background:linear-gradient(135deg,#f3fffc,#edf7ff);border:1px solid #b6dfe2;border-radius:9px;align-content:center;gap:4px;padding:10px;display:grid}.operation-current strong{color:var(--teal-dark);font-size:18px}.barcode-panel,.audit-panel,.approval-panel,.backup-panel,.loan-panel{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-soft);border-radius:8px;margin-bottom:14px}.audit-panel{border-top:5px solid var(--amber);background:linear-gradient(#fff 0%,#fff8ea 100%)}.barcode-panel{background:#f9fefe;border:1px solid #85cdd3;border-radius:10px;grid-template-columns:136px minmax(0,1fr) 158px;align-items:center;gap:12px;min-height:74px;padding:10px 12px 10px 18px;display:grid;box-shadow:0 12px 28px #006a7814}.barcode-panel h2{color:#15303a;font-size:16px}.audit-panel h2{color:var(--amber)}.backup-panel h2{color:var(--teal-dark)}.barcode-panel p{color:var(--muted);margin-top:5px;font-size:11px}.barcode-box{min-height:50px;color:var(--teal-dark);background:#fff;border:1px solid #9dd5d9;border-radius:8px;align-items:center;gap:10px;padding:0 12px;display:flex}.barcode-box:focus-within,.search-box:focus-within,.select-box:focus-within{border-color:var(--teal);box-shadow:0 0 0 3px #00898f24}.barcode-box input{color:#172126;background:0 0;border:0;outline:0;width:100%;min-width:0}.barcode-ready-button{color:#fff;background:linear-gradient(135deg,#008c8a,#006977);border-color:#006977;height:50px}.registration-next-panel{background:linear-gradient(90deg,#16844f24,#0000 46%),#f0fbf6;border:1px solid #b8d8d8;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px;min-height:84px;margin-bottom:14px;padding:14px;display:grid}.registration-next-panel span,.registration-next-panel small{color:#62737b;font-size:12px;line-height:1.45;display:block}.registration-next-panel strong{color:var(--green);margin-top:3px;font-size:18px;line-height:1.25;display:block}.registration-next-actions{gap:8px;display:flex}.audit-panel{padding-bottom:14px}.audit-actions{gap:8px;display:flex}.audit-controls{grid-template-columns:minmax(260px,1fr) minmax(280px,1fr) 118px;gap:10px;padding:0 16px 12px;display:grid}.audit-location-select{min-width:0}.audit-summary{grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;padding:0 16px 12px;display:grid}.audit-summary div{background:linear-gradient(#fff,#fff5dc);border:1px solid #eadfb8;border-radius:8px;align-content:center;gap:4px;min-height:58px;padding:10px;display:grid}.audit-summary span{color:var(--muted);font-size:11px;font-weight:800}.audit-summary strong{color:var(--amber);font-size:22px;line-height:1}.audit-body{grid-template-columns:minmax(0,1.2fr) minmax(260px,.8fr);gap:10px;padding:0 16px;display:grid}.audit-expected-list,.audit-scan-list{gap:8px;display:grid}.audit-expected{text-align:left;color:#243238;cursor:pointer;background:#fff;border:1px solid #dbe3e7;border-radius:8px;grid-template-columns:76px minmax(0,1fr) auto;align-items:center;gap:8px;min-height:60px;padding:9px 10px;display:grid}.audit-expected.confirmed{background:var(--green-soft);border-color:#9ad0b7}.audit-expected.missing{background:var(--red-soft);border-color:#efb5ac}.audit-expected span,.audit-expected small{color:var(--muted);font-size:12px;font-weight:800}.audit-expected strong{min-width:0;font-size:13px}.audit-scan{background:#f8fbfb;border:1px solid #dbe3e7;border-radius:8px;gap:4px;min-height:62px;padding:10px;display:grid}.audit-scan.confirmed{background:var(--green-soft);border-color:#9ad0b7}.audit-scan.wrong-location{background:var(--amber-soft);border-color:#ead4a5}.audit-scan.unknown{background:var(--red-soft);border-color:#efb5ac}.audit-scan span{color:var(--teal-dark);font-size:11px;font-weight:900}.audit-scan strong{font-size:13px}.audit-scan small,.audit-empty{color:var(--muted);font-size:12px;line-height:1.45}.audit-scan .secondary-button{justify-self:start;margin-top:2px}.search-box,.select-box{border:1px solid var(--line);color:#607078;background:#fff;border-radius:8px;align-items:center;gap:10px;min-height:44px;padding:0 12px;display:flex}.search-box input,.select-box select{color:#172126;background:0 0;border:0;outline:0;width:100%;min-width:0}.metrics-grid{box-shadow:var(--shadow-soft);background:#fff;border:1px solid #e0e8ec;border-radius:10px;grid-template-columns:repeat(6,minmax(0,1fr));gap:0;margin-bottom:12px;display:grid;overflow:hidden}.metric{background:#fff;border:0;border-right:1px solid #e5edf0;border-radius:0;grid-template-columns:24px 1fr;align-items:center;column-gap:9px;min-height:70px;padding:12px 14px;display:grid}.metric:last-child{border-right:0}.metric:first-child{background:linear-gradient(#fff,#f3fffb);border-color:#0000}.metric:nth-child(2){background:linear-gradient(#fff,#f5fbff);border-color:#0000}.metric:nth-child(3){background:linear-gradient(#fff,#fffaf4);border-color:#0000}.metric:nth-child(4){background:linear-gradient(#fff,#fff6f5);border-color:#0000}.metric:nth-child(5){background:linear-gradient(#fff,#f8fafb);border-color:#0000}.metric.value{background:linear-gradient(#fff,#f7fbff);border-color:#0000}.metric svg{color:var(--teal)}.metric:nth-child(2) svg{color:var(--blue)}.metric:nth-child(3) svg{color:var(--amber)}.metric:nth-child(4) svg{color:var(--red)}.metric.value svg{color:var(--purple)}.metric span{color:var(--muted);font-size:11px;font-weight:850}.metric strong{grid-column:1/-1;margin-top:6px;font-size:23px;line-height:1}.metric.value strong{font-size:19px}.backup-panel{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px;min-height:72px;padding:14px 16px;display:grid}.backup-panel h2{font-size:16px}.backup-panel p{color:var(--muted);margin-top:5px;font-size:12px;line-height:1.45}.backup-actions{gap:8px;display:flex}.hidden-file-input{display:none}.workspace{grid-template-columns:minmax(580px,1.08fr) minmax(600px,.92fr);align-items:start;gap:12px;display:grid}.inventory-panel,.map-panel,.history-panel,.detail-card,.location-detail{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-panel);border-radius:10px}.inventory-panel{min-width:0}.panel-heading{border-bottom:1px solid #e5edf0;justify-content:space-between;align-items:center;gap:16px;min-height:58px;padding:13px 14px;display:flex}.panel-heading.compact{border-bottom:0;min-height:auto;padding-bottom:10px}.table-wrap{overflow-x:auto}.mobile-item-list{display:none}.mobile-item-stack,.mobile-inline-detail{display:contents}table{border-collapse:collapse;width:100%;min-width:820px}th,td{text-align:left;vertical-align:middle;border-bottom:1px solid #e5ebee;padding:10px 12px;font-size:12px}th{color:var(--muted);z-index:1;background:#fbfdfe;font-size:11px;font-weight:900;position:sticky;top:0}tbody tr{cursor:pointer}tbody tr:hover,.selected-row{background:#d7f3f1}td strong,td span{display:block}td span{color:var(--muted);margin-top:4px;font-size:12px}.table-photo{width:34px;height:34px;color:var(--teal);background:#f5fafb;border:1px solid #d9e5ea;border-radius:7px;place-items:center;margin-top:0;display:grid;overflow:hidden}.table-photo img,.mobile-item-photo img{object-fit:cover;width:100%;height:100%;display:block}.table-photo.has-image{background:#eaf2f4}.status{border-radius:999px;justify-content:center;min-width:66px;padding:5px 9px;font-size:12px;font-weight:800;line-height:1;display:inline-flex}.status.保管中{color:var(--green);background:var(--green-soft)}.status.使用中,.status.貸出中{color:var(--amber);background:var(--amber-soft)}.status.未返却{color:var(--red);background:var(--red-soft)}.status.廃棄申請中{color:var(--amber);background:var(--amber-soft)}.status.削除申請中{color:var(--red);background:var(--red-soft)}.status.廃棄済み,.status.削除済み{color:#677278;background:#e6ebee}.approval-list{gap:8px;padding:12px 16px 16px;display:grid}.approval-item{background:#fffaf0;border:1px solid #ead4a5;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;min-height:58px;padding:10px;display:grid}.approval-item strong,.approval-item span{display:block}.approval-item span{color:var(--muted);margin-top:4px;font-size:12px}.approval-item p{color:#42525a;margin-top:7px;font-size:12px;line-height:1.45}.approval-actions{gap:8px;display:flex}.mobile-handoff-card{background:linear-gradient(135deg,#008c8a1f,#1f78d714),#fff;border:1px solid #a8d8dc;border-radius:10px;gap:12px;margin:0 16px 12px;padding:14px;display:grid}.mobile-handoff-head,.mobile-handoff-item-main,.mobile-handoff-actions{justify-content:space-between;align-items:center;gap:10px;display:flex}.mobile-handoff-head span,.mobile-handoff-item-main span,.mobile-handoff-message,.mobile-handoff-facts span,.return-confirm-box span{color:var(--muted);font-size:12px;line-height:1.45}.mobile-handoff-head strong,.mobile-handoff-item-main strong{color:var(--teal-dark);font-size:17px;line-height:1.3;display:block}.mobile-handoff-head small,.mobile-handoff-item-main small{color:#0d4e52;background:var(--teal-soft);white-space:nowrap;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:900}.mobile-scan-box{min-height:52px;color:var(--teal-dark);background:#fff;border:1px solid #92cfd4;border-radius:9px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:9px;padding:0 8px 0 12px;display:grid}.mobile-scan-box:focus-within{border-color:var(--teal);box-shadow:0 0 0 3px #00898f24}.mobile-scan-box input{color:#172126;background:0 0;border:0;outline:0;min-width:0;font-size:16px}.mobile-scan-box button{color:#fff;background:var(--teal);border:0;border-radius:7px;min-height:38px;padding:0 14px;font-weight:900}.mobile-handoff-target{background:#f8fbfb;border:1px solid #d7e3e8;border-radius:9px;gap:11px;padding:12px;display:grid}.mobile-handoff-target.active{background:#fffaf0;border-color:#e6c276}.mobile-handoff-item-main{align-items:flex-start}.mobile-handoff-item-main>span{font-weight:900}.mobile-handoff-facts{gap:7px;display:grid}.mobile-handoff-facts span{color:#34464e;align-items:flex-start;gap:7px;font-weight:800;display:flex}.mobile-handoff-facts svg{color:var(--teal);flex:none;margin-top:1px}.mobile-loan-breakdown{background:#fff;border:1px solid #d8e6ea;border-radius:8px;gap:8px;padding:10px;display:grid}.mobile-loan-breakdown>div:first-child{gap:3px;display:grid}.mobile-loan-breakdown span,.mobile-loan-breakdown small{color:#60737d;font-size:12px;line-height:1.35}.mobile-loan-breakdown strong{color:#10262f;min-width:0;font-size:13px;line-height:1.35}.mobile-loan-row{border-top:1px solid #eef3f5;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:3px 8px;padding-top:8px;display:grid}.mobile-loan-row small{grid-column:1/-1}.mobile-quantity-box{color:#34464e;background:#fff;border:1px solid #cfe0e5;border-radius:8px;grid-template-columns:minmax(0,1fr) 96px auto;align-items:center;gap:8px;min-height:48px;padding:8px 10px;font-size:13px;font-weight:900;display:grid}.mobile-quantity-box input{color:#172126;background:#fff;border:1px solid #cfd9de;border-radius:7px;width:100%;min-height:34px;padding:0 8px;font-size:16px;font-weight:900}.mobile-quantity-box span{color:var(--muted);font-size:12px;font-weight:900}.return-confirm-box{background:linear-gradient(135deg,#ffc8573d,#fff7dfeb),#fff7df;border:2px solid #e5b840;border-radius:9px;gap:6px;padding:12px;display:grid}.return-confirm-box strong{color:#704700;font-size:16px;line-height:1.35}.return-confirm-box p{color:#172126;background:#fff;border:1px solid #efcf73;border-radius:8px;padding:9px;font-size:13px;font-weight:900;line-height:1.45}.return-confirm-box small{color:#765212;font-size:12px;font-weight:800;line-height:1.45}.mobile-handoff-actions button{flex:1 1 0;min-height:48px}.loan-list{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;padding:12px 16px 16px;display:grid}.loan-item{text-align:left;color:#243238;cursor:pointer;background:#f8fbfb;border:1px solid #dbe3e7;border-radius:8px;gap:4px;min-height:72px;padding:10px;display:grid}.loan-item.overdue{background:var(--red-soft);border-color:#efb5ac}.loan-item span,.loan-item strong,.loan-item small{display:block}.loan-item span{font-size:13px;font-weight:800}.loan-item strong{color:var(--teal-dark);font-size:12px}.loan-item small{color:var(--muted);font-size:12px}.loan-empty{min-height:72px;color:var(--muted);background:#f8fbfb;border:1px dashed #cbd9de;border-radius:8px;grid-column:1/-1;place-items:center;font-size:13px;font-weight:800;display:grid}.mobile-recent-actions{background:#fff;border:1px solid #d7e5e9;border-radius:10px;gap:8px;margin:0 16px 16px;padding:12px;display:grid}.mobile-recent-heading{justify-content:space-between;align-items:center;gap:8px;display:flex}.mobile-recent-heading span,.mobile-recent-actions>p{color:#657985;font-size:12px;font-weight:800}.mobile-recent-heading strong{color:var(--teal-dark);background:var(--teal-soft);border-radius:999px;padding:4px 8px;font-size:12px}.mobile-recent-item{background:#f8fbfc;border:1px solid #e0eaee;border-radius:8px;gap:4px;padding:10px;display:grid}.mobile-recent-item span{color:var(--teal);font-size:12px;font-weight:900}.mobile-recent-item strong{color:#16262e;font-size:14px;line-height:1.35}.mobile-recent-item small,.mobile-recent-item p{color:#60737d;font-size:12px;line-height:1.45}.map-panel{box-shadow:none;background:0 0;border:0;grid-template-columns:minmax(250px,.85fr) minmax(280px,1fr);gap:12px;padding:0;display:grid}.map-panel>.panel-heading,.map-panel>.photo-map,.map-panel>.location-detail,.map-panel>.detail-card{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-panel);border-radius:10px}.map-panel>.panel-heading{border-bottom:1px solid var(--line);grid-column:2;padding:13px 14px}.map-panel>.photo-map,.map-panel>.location-detail{grid-column:2}.map-panel>.detail-card{order:-1;grid-area:1/1/span 3}.map-photo-actions{gap:8px;display:flex}.photo-map{aspect-ratio:1.12;background:#dce4e6;min-height:294px;position:relative;overflow:hidden}.photo-map img{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.floor-label{color:#fff;background:#111f26a8;border-radius:7px;padding:6px 8px;font-size:12px;font-weight:800;position:absolute;bottom:14px;left:14px}.map-pin{color:#fff;background:var(--teal);border:1px solid #fff;border-radius:999px;min-height:30px;padding:0 10px;font-size:12px;font-weight:800;position:absolute;transform:translate(-50%,-50%);box-shadow:0 8px 16px #00000038}.map-pin.active{color:#172126;background:#ffc857}.location-detail,.detail-card{padding:14px}.detail-card{min-height:100%}.empty-detail{text-align:center;background:linear-gradient(135deg,#00968f1a,#1f78d714),#f8fbfc;border:1px dashed #c8d9df;border-radius:10px;align-content:center;place-items:center;gap:10px;min-height:360px;padding:24px;display:grid}.empty-detail svg{color:var(--teal)}.empty-detail span{color:var(--teal-dark);font-size:12px;font-weight:900}.empty-detail h3{color:#172126;max-width:360px;font-size:18px;line-height:1.35}.empty-detail p{max-width:420px;color:var(--muted);font-size:13px;font-weight:700;line-height:1.65}.empty-detail .action-row{width:min(100%,360px)}.item-photo{background:linear-gradient(135deg,#00968f1a,#1f78d714),#f5fafb;border:1px solid #d8e4e9;border-radius:10px;min-height:176px;margin-bottom:14px;position:relative;overflow:hidden}.item-photo img,.form-photo img{object-fit:cover;width:100%;height:100%;display:block}.item-photo.has-image{background:#edf3f5}.item-photo-placeholder{color:#60737c;align-content:center;place-items:center;gap:8px;min-height:176px;font-size:12px;font-weight:850;display:grid}.item-photo-placeholder svg{color:var(--teal)}.item-photo-actions{justify-content:flex-end;gap:8px;display:flex;position:absolute;bottom:10px;left:10px;right:10px}.item-photo-actions .ghost-button{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffeb;min-height:34px}.location-header,.detail-title{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.location-header span,.detail-title span:first-child{color:#6b7b82;font-size:12px;font-weight:800}.icon-button{background:#fff;border-color:#cfd9de;width:36px;height:36px}.location-detail p,.location-detail small,.memo{color:#5e7078;margin-top:9px;font-size:12px;line-height:1.55;display:block}.cabinet-zone{gap:10px;margin-top:12px;display:grid}.view-switch,.shelf-tabs{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;display:grid}.view-switch button,.shelf-tabs button{color:#52636b;cursor:pointer;background:#fff;border:1px solid #cfd9de;border-radius:7px;min-height:34px;font-size:12px;font-weight:800}.view-switch button.active,.shelf-tabs button.active{color:var(--teal-dark);background:var(--teal-soft);border-color:#8bc3c4}.cabinet-exterior,.cabinet-interior{background:#e7edf0;border:1px solid #cfd9de;border-radius:8px;position:relative;overflow:hidden}.cabinet-exterior{grid-template-columns:1fr 1fr;align-items:stretch;gap:2px;min-height:170px;padding:14px;display:grid}.cabinet-door{color:#fff;background:linear-gradient(90deg,#ffffff2e,#0000 18%),repeating-linear-gradient(#728188 0 9px,#5b6970 9px 12px);border:1px solid #84949b;place-items:center;font-size:12px;font-weight:900;display:grid}.cabinet-door.left{border-radius:6px 2px 2px 6px}.cabinet-door.right{border-radius:2px 6px 6px 2px}.cabinet-exterior>span{color:#fff;background:#111f26b3;border-radius:7px;padding:7px 9px;font-size:11px;font-weight:800;position:absolute;bottom:12px;left:14px;right:14px}.cabinet-interior{background:linear-gradient(90deg,#0000 48%,#43515833 48% 52%,#0000 52%),#edf2f3;grid-template-rows:repeat(4,52px);gap:8px;padding:10px;display:grid}.shelf-row{color:#27363d;cursor:pointer;background:linear-gradient(#ffffffbd,#ffffff61),#d7e0e3;border:1px solid #a9b8bf;border-radius:6px;justify-content:space-between;align-items:center;padding:0 12px;display:flex}.shelf-row span,.shelf-row strong{font-size:12px;font-weight:900}.shelf-row.active,.shelf-row:hover{border-color:var(--teal);background:#dff3f3}.shelf-tabs{grid-template-columns:repeat(5,minmax(0,1fr))}.location-items{gap:6px;margin-top:12px;display:grid}.location-item{color:#243238;background:#fff;border:1px solid #d9e0e4;border-radius:7px;justify-content:space-between;align-items:center;gap:10px;min-height:38px;padding:0 10px;display:flex}.location-item.active,.location-item:hover{background:var(--teal-soft);border-color:#8bc3c4}.detail-card dl{grid-template-columns:1fr 1fr;gap:10px;margin:14px 0 0;display:grid}.detail-card dt{color:#6b7b82;font-size:11px;font-weight:800}.detail-card dd{color:#172126;margin:3px 0 0;font-size:13px;font-weight:700}.label-management{background:linear-gradient(135deg,#f8fffd,#f4f8ff);border:1px solid #cfe2e6;border-radius:8px;grid-template-columns:minmax(0,1fr) minmax(128px,.75fr);gap:10px;margin-top:12px;padding:10px;display:grid}.label-management>div,.label-management label{gap:4px;display:grid}.label-management span,.label-management small,.label-management label{color:var(--muted);font-size:11px;line-height:1.45}.label-management strong{color:var(--teal-dark);word-break:break-all;font-size:14px;line-height:1.35}.label-management select{color:#172126;background:#fff;border:1px solid #cfd9de;border-radius:8px;width:100%;min-height:36px;padding:0 9px}.label-preview{background:#fff;border:1px dashed #b9cbd2;border-radius:8px;padding:8px}.label-output-grid,.label-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.label-output-grid{grid-column:1/-1}.label-preview pre{color:var(--teal-dark);white-space:pre-wrap;word-break:break-word;margin:0;font-family:inherit;font-size:13px;font-weight:700;line-height:1.45}.label-issue-date{grid-column:1/-1}.label-actions{align-content:start}.discard-audit,.loan-audit{background:#fffaf0;border:1px solid #ead4a5;border-radius:8px;margin-top:12px;padding:10px}.loan-audit{background:#f0f8f8;border-color:#b9d7d8}.loan-audit.overdue{background:var(--red-soft);border-color:#efb5ac}.discard-audit strong,.loan-audit strong{color:#704700;font-size:12px;display:block}.loan-audit strong{color:#0d4e52}.discard-audit p,.loan-audit p{color:#42525a;margin-top:6px;font-size:12px;line-height:1.5}.action-row{grid-template-columns:repeat(auto-fit,minmax(92px,1fr));gap:8px;margin-top:14px;display:grid}.history-panel{margin-top:14px}.history-summary{background:#f7fbfa;border-bottom:1px solid #e5edf0;grid-template-columns:repeat(2,minmax(120px,1fr)) auto;align-items:stretch;gap:10px;padding:12px 14px;display:grid}.history-summary div{background:#fff;border:1px solid #dce8e9;border-radius:8px;min-width:0;padding:10px 12px}.history-summary span,.history-column-head span{color:#687b82;font-size:12px;font-weight:700;display:block}.history-summary strong{color:#0d4e52;margin-top:2px;font-size:22px;display:block}.history-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:0;display:grid}.history-column{min-width:0}.history-column+.history-column{border-left:1px solid #e5edf0}.history-column-head{border-bottom:1px solid #e5edf0;padding:13px 14px 10px}.history-column-head strong{color:#16373b;display:block}.timeline{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:0;display:grid;overflow-x:hidden}.timeline-item{border-right:1px solid #e2e8eb;min-height:112px;padding:14px 16px}.timeline-item span{color:#0d4e52;margin-bottom:10px;font-size:12px;font-weight:800;display:inline-flex}.timeline-item strong{display:block}.timeline-item p{color:#66777e;margin-top:8px;font-size:12px;line-height:1.5}.scan-log-list{gap:8px;padding:12px;display:grid}.scan-log-card{background:#fff;border:1px solid #dce8e9;border-left:4px solid #168c88;border-radius:8px;min-width:0;padding:12px}.scan-log-card.mode-audit{border-left-color:#2f73d8}.scan-log-card.mode-checkout{border-left-color:#9b6bdb}.scan-log-card.mode-return{border-left-color:#1b9f64}.scan-log-card div{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.scan-log-card span{color:#0d6464;background:#edf8f7;border-radius:999px;flex:none;padding:3px 7px;font-size:11px;font-weight:800}.scan-log-card strong{color:#153236;text-align:right;min-width:0;font-size:13px}.scan-log-card p,.scan-log-card small{color:#607178;overflow-wrap:anywhere;margin-top:7px;font-size:12px;line-height:1.45;display:block}.history-empty{color:#687b82;margin:0;padding:14px;font-size:13px}.modal-backdrop{z-index:20;overscroll-behavior:contain;background:#0e191f6b;place-items:center;padding:20px;display:grid;position:fixed;inset:0;overflow-y:auto}.modal{overscroll-behavior:contain;background:#fff;border-radius:8px;width:min(440px,100%);max-height:calc(100dvh - 40px);padding:22px;overflow-y:auto;box-shadow:0 24px 64px #00000047}.wide-modal{width:min(680px,100%)}.modal-icon{color:#9a2c20;background:#fff2ef;border-radius:8px;place-items:center;width:46px;height:46px;display:grid}.modal-icon.success{color:#0d6b6f;background:#e7f3f3}.modal-icon.warning{color:#7a4b00;background:#fff4d8}.modal h2{margin-top:14px;font-size:20px}.modal p{color:#5e7078;margin-top:8px;font-size:13px;line-height:1.6}.form-error{font-weight:800;color:#9a2c20!important}.duplicate-alert{background:#fff5f2;border:1px solid #efb4aa;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px 12px;margin-top:14px;padding:12px;display:grid}.duplicate-alert strong,.duplicate-alert span{min-width:0}.duplicate-alert strong{color:#9a2c20;font-size:13px}.duplicate-alert span{color:#5f6f77;word-break:break-all;font-size:12px;line-height:1.5}.duplicate-alert button{grid-area:1/2/span 2}.login-hints{background:#f8fbff;border:1px solid #d8e3e5;border-radius:8px;gap:6px;margin-top:14px;padding:10px;display:grid}.login-hints span{color:var(--muted);font-size:12px;font-weight:800}.modal-stock-summary{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.modal-stock-summary span,.modal-stock-summary strong{color:#40545d;background:#f7fbfc;border:1px solid #d7e4e7;border-radius:8px;min-width:0;padding:8px 10px;font-size:12px;line-height:1.2}.modal-stock-summary strong{color:#006c67;background:#e8f7f4;border-color:#9fd8d0}.field-hint{color:#66777e;font-size:12px;font-weight:700;line-height:1.4}.modal label{color:#243238;gap:8px;margin-top:16px;font-size:13px;font-weight:800;display:grid}.modal input,.modal select,.modal textarea{color:#172126;background:#fff;border:1px solid #cfd9de;border-radius:8px;outline:0;width:100%;min-height:98px;padding:10px}.modal input,.modal select{min-height:42px}.modal textarea{resize:vertical}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:16px;display:grid}.field{color:#243238;gap:7px;font-size:13px;font-weight:800;display:grid}.field.span-2{grid-column:1/-1}.barcode-entry-guide{background:linear-gradient(135deg,#f8fffd,#f4f9ff);border:1px solid #d6e5e8;border-radius:8px;padding:12px}.barcode-entry-guide>span{color:#243238;font-size:13px;font-weight:850}.barcode-entry-guide small{color:var(--muted);font-size:12px;line-height:1.55}.barcode-entry-options{flex-wrap:wrap;gap:8px;display:flex}.camera-scanner-panel{background:#10242b;border:1px solid #9dd5d9;border-radius:8px;min-height:220px;position:relative;overflow:hidden}.camera-scanner-panel video{object-fit:cover;width:100%;height:260px;display:block}.camera-scan-frame{pointer-events:none;border:2px solid #ffffffe0;border-radius:10px;position:absolute;inset:54px 28px;box-shadow:0 0 0 999px #0000003d,0 0 24px #00968f61}.camera-scanner-panel .ghost-button{background:#ffffffeb;position:absolute;bottom:10px;right:10px}.form-photo{background:#f8fbfb;border:1px solid #d7e3e8;border-radius:8px;grid-template-columns:minmax(0,1fr) 168px;align-items:stretch;gap:12px;min-height:132px;padding:10px;display:grid}.form-photo.has-image img{border-radius:7px;max-height:150px}.form-photo-placeholder{color:#60737c;background:#fff;border:1px dashed #b9cbd2;border-radius:7px;align-content:center;place-items:center;gap:8px;min-height:110px;font-size:12px;font-weight:850;display:grid}.form-photo-placeholder svg{color:var(--teal)}.form-photo-actions{align-content:center;gap:8px;display:grid}.modal-actions{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff5;border-top:1px solid #e3ecef;justify-content:flex-end;gap:8px;margin:16px -22px -22px;padding:14px 22px 22px;display:flex;position:sticky;bottom:-22px}@media (width<=1120px){.app-shell{grid-template-columns:1fr}.sidebar{flex-direction:row;align-items:center;height:auto;padding:12px;position:static;overflow-x:auto}.brand{flex:none}.nav-list{min-width:max-content;display:flex}.sidebar-panel{display:none}.workspace,.search-row,.main.page-inventory .workspace,.map-panel{grid-template-columns:1fr}.map-panel>.panel-heading,.map-panel>.photo-map,.map-panel>.location-detail,.map-panel>.detail-card{grid-area:auto/1}.map-panel>.panel-heading{order:1}.map-panel>.photo-map{order:2}.map-panel>.location-detail{order:3}.map-panel>.detail-card{order:4}.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=720px){.app-shell{background:#f6f8f9}.sidebar{flex-wrap:nowrap;gap:10px;padding:8px 10px;overflow-x:hidden}.nav-list,.sidebar-panel{display:none}.brand-mark{width:34px;height:34px}.brand strong{font-size:14px}.brand span{font-size:10px}.main{padding:10px}.topbar{border:1px solid var(--line);border-radius:10px;flex-direction:column;gap:10px;margin:0 0 12px;padding:12px}.topbar>div:first-child{display:none}.topbar-actions{grid-template-columns:1fr 1fr;gap:8px;width:100%;display:grid}.operator-switch{grid-column:1/-1;width:100%;min-width:0}.topbar-actions .mobile-hidden-action,.topbar-actions .mobile-logged-in-hidden,.topbar-actions .mobile-logged-out-hidden{display:none}h1{font-size:21px}.topbar p{font-size:12px}.primary-button{width:100%}.search-row{gap:8px;margin-bottom:10px}.operation-panel{grid-template-columns:1fr;gap:10px;padding:12px}.operation-mode-grid{grid-template-columns:1fr}.operation-mode{min-height:72px}.barcode-panel{grid-template-columns:1fr;gap:10px;padding:12px}.scanner-actions{grid-template-columns:1fr 1fr;width:100%;display:grid}.scanner-controls{grid-template-columns:1fr;padding:0 10px 10px}.scanner-import-status{grid-template-columns:1fr;margin:0 10px 10px}.registration-next-panel{grid-template-columns:1fr;padding:12px}.registration-next-actions{grid-template-columns:1fr;display:grid}.audit-actions{grid-template-columns:1fr 1fr;width:100%;display:grid}.audit-controls{grid-template-columns:1fr;padding:0 10px 10px}.audit-summary{grid-template-columns:repeat(2,minmax(0,1fr));padding:0 10px 10px}.audit-summary div:last-child{grid-column:1/-1}.audit-body{grid-template-columns:1fr;padding:0 10px}.audit-expected{grid-template-columns:62px minmax(0,1fr)}.audit-expected small{grid-column:1/-1}.barcode-box{min-height:42px}.barcode-ready-button{width:100%}.search-box,.select-box{border-radius:7px;min-height:40px}.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.backup-panel{grid-template-columns:1fr;gap:10px;padding:12px}.backup-actions{grid-template-columns:1fr;display:grid}.backup-actions .secondary-button,.backup-actions .danger-button{width:100%}.metric{min-height:64px;padding:10px}.metric strong{font-size:22px}.metric.value{grid-column:1/-1}.approval-list{padding:10px}.mobile-handoff-card{margin:0 10px 10px;padding:12px}.mobile-handoff-head,.mobile-handoff-item-main,.mobile-handoff-actions{flex-direction:column;align-items:stretch}.mobile-handoff-head small,.mobile-handoff-item-main small{width:max-content;max-width:100%}.mobile-scan-box{grid-template-columns:auto minmax(0,1fr);padding:8px 10px}.mobile-scan-box button{grid-column:1/-1;width:100%}.loan-list{grid-template-columns:1fr;padding:10px}.approval-item{grid-template-columns:1fr}.approval-actions{grid-template-columns:1fr 1fr;display:grid}.panel-heading{align-items:flex-start;min-height:auto;padding:12px}.panel-heading h2{font-size:16px}.panel-heading p{font-size:12px}.table-wrap{display:none}.mobile-item-list{gap:8px;padding:10px;display:grid}.mobile-item-stack{gap:0;display:grid}.mobile-item-card{text-align:left;color:#172126;background:#fff;border:1px solid #d9e0e4;border-radius:8px;gap:7px;width:100%;padding:12px;display:grid}.mobile-item-photo{width:100%;height:96px;color:var(--teal);background:#f5fafb;border:1px solid #d9e5ea;border-radius:8px;place-items:center;display:grid;overflow:hidden}.mobile-item-card.active{background:#edf7f7;border-color:#8bc3c4;border-bottom-right-radius:0;border-bottom-left-radius:0}.mobile-item-top,.mobile-item-meta,.mobile-item-location{justify-content:space-between;align-items:center;gap:8px;display:flex}.mobile-item-top{color:#6b7b82;font-size:11px;font-weight:800}.mobile-item-card>strong{font-size:15px;line-height:1.35}.mobile-item-meta,.mobile-item-location{color:#52636b;justify-content:flex-start;font-size:12px;line-height:1.4}.mobile-item-location{color:#172126;font-weight:700}.mobile-inline-detail{background:#fff;border:1px solid #8bc3c4;border-top:0;border-radius:0 0 8px 8px;gap:10px;margin-top:-1px;padding:12px;display:grid;box-shadow:0 12px 24px #0c364214}.mobile-inline-facts{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.mobile-inline-facts div{background:#f8fbfc;border:1px solid #e0eaee;border-radius:8px;gap:4px;min-width:0;padding:9px;display:grid}.mobile-inline-facts span,.mobile-inline-location{color:#647783;font-size:12px;line-height:1.45}.mobile-inline-facts strong{color:#172126;word-break:keep-all;min-width:0;font-size:14px;line-height:1.25}.mobile-inline-location{color:#1a3038;background:#f4f9fa;border:1px solid #d8e7eb;border-radius:8px;align-items:flex-start;gap:7px;padding:9px;font-weight:800;display:flex}.mobile-inline-location span{min-width:0}.mobile-inline-actions{grid-template-columns:1fr 1fr;gap:8px;display:grid}.mobile-inline-actions .primary-button,.mobile-inline-actions .secondary-button{width:100%;min-width:0;padding-left:8px;padding-right:8px}.mobile-inline-actions .secondary-button:last-child{grid-column:1/-1}.map-panel{padding:0}.map-photo-actions{grid-template-columns:1fr 1fr;width:100%;display:grid}.photo-map{height:240px}.action-row,.detail-card dl,.label-management,.label-output-grid,.label-actions,.form-photo,.item-photo-actions,.form-photo-actions{grid-template-columns:1fr}.location-items{gap:8px}.location-item{min-height:44px}.view-switch{grid-template-columns:1fr 1fr}.shelf-tabs{flex-wrap:wrap;display:flex}.shelf-tabs button{flex:calc(33.333% - 6px);min-width:70px}.timeline{grid-template-columns:1fr;display:grid;overflow-x:visible}.history-summary,.history-grid{grid-template-columns:1fr}.history-summary{padding:10px}.history-column+.history-column{border-top:1px solid #e5edf0;border-left:0}.scan-log-card div{grid-template-columns:auto minmax(0,1fr);display:grid}.timeline-item{border-bottom:1px solid #e2e8eb;border-right:0;min-height:auto;padding:12px}.form-grid{grid-template-columns:1fr}.field.span-2{grid-column:auto}.barcode-entry-options{grid-template-columns:1fr;display:grid}.camera-scanner-panel{min-height:190px}.camera-scanner-panel video{height:210px}.camera-scan-frame{inset:46px 18px}.modal-backdrop{align-items:start;padding:12px}.modal{max-height:calc(100dvh - 24px);margin:10px 0;padding:18px}.modal-actions{grid-template-columns:1fr;margin-bottom:-18px;margin-left:-18px;margin-right:-18px;padding:12px 18px 18px;display:grid;bottom:-18px}.duplicate-alert{grid-template-columns:1fr}.duplicate-alert button{grid-area:auto}.operation-panel,.search-row,.barcode-panel,.metrics-grid,.registration-next-panel,.audit-panel,.backup-panel,.inventory-panel,.map-panel,.approval-panel,.history-panel{display:none}.main #loan-section.loan-panel{box-shadow:none;background:0 0;border:0;gap:10px;display:grid}.main #loan-section.loan-panel .panel-heading{border:1px solid var(--line);box-shadow:var(--shadow-panel);background:#fff;border-radius:10px}}
