body{color:#1f2d3d;background:linear-gradient(#eef4fb 0%,#e8f0fa 100%);margin:0;font-family:Segoe UI,Arial,sans-serif}#root{min-height:100vh}h1,h2,h3,p{margin:0}*{box-sizing:border-box}:root{--bg:#eef4fb;--panel:#fff;--panel-soft:#f7fafe;--line:#d9e5f2;--text:#1f2d3d;--muted:#70839a;--primary:#2f7cf6;--primary-dark:#1e63d6;--danger:#e05050;--shadow:0 12px 28px #1b4a8714}.container{max-width:1320px;margin:0 auto;padding:24px}.app-shell,.page-body,.space-y{flex-direction:column;gap:18px;display:flex}.topbar{border:1px solid var(--line);box-shadow:var(--shadow);background:linear-gradient(#fff 0%,#f8fbff 100%);border-radius:18px;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:12px 14px;display:grid}.brand-block{align-items:center;gap:10px;display:flex}.brand-small{object-fit:contain;width:120px;max-width:100%;box-shadow:none;border:0;border-radius:0}.topbar h1{color:var(--text);letter-spacing:-.02em;font-size:20px}.subtitle{color:var(--muted);margin-top:2px;font-size:12px}.topnav{flex-wrap:wrap;gap:8px;display:flex}.topnav a{color:#315073;background:#eef5ff;border:1px solid #0000;border-radius:12px;padding:8px 12px;font-size:13px;font-weight:600;text-decoration:none;transition:all .18s}.topnav a:hover{background:#dfeeff;border-color:#c6dcff}.user-chip{border:1px solid var(--line);color:#47627f;background:#f3f7fc;border-radius:12px;justify-self:end;padding:8px 12px;font-size:13px;font-weight:600}.user-tools{justify-self:end;align-items:center;gap:8px;display:flex}.logout-btn{min-width:auto}.auth-loading-card{align-self:center;width:min(420px,100%)}.login-brand-image{object-fit:contain;width:min(320px,100%);box-shadow:none;border:0;border-radius:0;align-self:center;max-height:none}.panel,.card{background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:18px}.panel{padding:20px}.card{flex-direction:column;gap:10px;padding:16px;display:flex}.panel h2,.card h2,.card h3{color:var(--text)}.toast{z-index:20;color:#fff;background:#163b66;border-radius:14px;padding:14px 16px;font-size:14px;position:sticky;top:12px;box-shadow:0 12px 28px #0a1d3640}.grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.filter-grid,.form-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.form-grid label{color:#4e647d;flex-direction:column;gap:7px;font-size:13px;font-weight:600;display:flex}.section-heading{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.add-summary{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.summary-pill{color:#4f6781;background:#f3f7fd;border:1px solid #dde8f5;border-radius:999px;padding:8px 12px;font-size:12px;font-weight:700}.toolbar-file-trigger{justify-content:center;min-width:170px}.import-report-card{gap:8px;display:grid}.import-error-list{gap:6px;max-height:320px;padding-right:6px;display:grid;overflow:auto}.item-card-selectable{cursor:pointer;position:relative}.item-card-selected{background:linear-gradient(#fff 0%,#f4f9ff 100%);border-color:#8cb7ff;box-shadow:0 10px 24px #2f7cf629}.item-select-indicator{z-index:2;background:#ffffffeb;border:1px solid #d6e3f5;border-radius:999px;justify-content:center;align-items:center;width:28px;height:28px;display:flex;position:absolute;top:12px;right:12px;box-shadow:0 6px 14px #1a325414}.item-select-indicator input{width:16px;height:16px;min-height:auto;box-shadow:none;margin:0;padding:0}.add-layout{flex-direction:column;gap:14px;display:flex}.add-section{background:linear-gradient(#fff 0%,#fbfdff 100%);border:1px solid #e4edf7;border-radius:16px;padding:16px}.add-section-title{margin-bottom:12px}.add-section-title h3{color:#24384e;margin-bottom:4px;font-size:16px}.two-cols{grid-template-columns:repeat(2,minmax(0,1fr))}.location-grid{grid-template-columns:1fr 1fr 1.4fr}.add-footer{justify-content:space-between;align-items:center;gap:16px;padding:6px 2px 0;display:flex}.primary-wide{min-width:200px}.field-with-action{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;width:100%;display:grid}.field-with-action>input,.field-with-action>select{min-width:0}.field-with-action>.plus-btn{flex-shrink:0;width:42px;min-width:42px;height:42px;min-height:42px}.hint{color:var(--muted);font-size:13px;line-height:1.45}input,select,textarea,button{border:1px solid var(--line);min-height:42px;color:var(--text);box-sizing:border-box;background:#fff;border-radius:12px;padding:10px 12px;font-size:14px}input:focus,select:focus,textarea:focus{border-color:#8cb7ff;outline:none;box-shadow:0 0 0 3px #2f7cf61f}input:disabled,select:disabled,textarea:disabled{color:#9aadbf;background:#f3f7fb}textarea{resize:vertical;width:100%;min-height:108px;font-family:inherit}button{cursor:pointer;border-color:var(--primary);color:#fff;background:linear-gradient(#3b8cff 0%,#2f7cf6 100%);font-weight:700;transition:background .18s,border-color .18s,box-shadow .18s,transform .18s}button:hover{background:linear-gradient(#3a87fb 0%,#3178ec 100%);border-color:#5c98f2;box-shadow:0 8px 18px #2f7cf624}.ghost{color:var(--primary);background:#f6faff;border-color:#cfe0fb}.ghost:hover{background:#f1f7ff;border-color:#c7daf8;box-shadow:0 6px 14px #2f7cf614}.danger{border-color:var(--danger);background:var(--danger);color:#fff}.plus-btn,.icon-btn{border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;padding:0;font-weight:700;text-decoration:none;display:inline-flex}.plus-btn{color:var(--primary);background:#f4f8ff;border:1px solid #cfe0fb}.plus-btn:hover,.icon-btn:hover,.modal-close:hover{background:#eef5ff;border-color:#c6d8f3;box-shadow:0 6px 14px #2f7cf614}.actions{gap:8px;display:flex}.item-card{background:linear-gradient(#fff 0%,#fbfdff 100%)}.item-card-clickable{cursor:pointer;transition:transform .18s,box-shadow .18s,border-color .18s}.item-card-clickable:hover,.item-card-clickable:focus-visible{border-color:#c9dbf4;outline:none;transform:translateY(-2px);box-shadow:0 16px 30px #1b4a871f}.item-card h3{margin:0;font-size:18px}.chip{color:#2b67b5;background:#eaf3ff;border-radius:999px;width:fit-content;padding:5px 10px;font-size:12px;font-weight:700}.status-badge{border:1px solid #0000;border-radius:999px;align-items:center;width:fit-content;padding:6px 10px;font-size:12px;font-weight:700;display:inline-flex}.status-badge.found{color:#2d7042;background:#edf7ef;border-color:#cee7d5}.status-badge.missing{color:#c44949;background:#fff0f0;border-color:#f3cccc}.status-badge.writeoff{color:#9b7812;background:#fff6de;border-color:#f0df9d}.status-option-list{flex-wrap:wrap;gap:10px;display:flex}.status-option-btn{min-height:38px;box-shadow:none;padding:8px 12px}.status-option-btn.found{color:#9ab4a1;background:#fbfefb;border-color:#e6f0e8}.status-option-btn.missing{color:#d3a0a4;background:#fffafb;border-color:#f6e4e6}.status-option-btn.writeoff{color:#c3b07a;background:#fffdf7;border-color:#f3ead0}.status-option-btn.found:hover{background:#f6fbf7;border-color:#dbe9de;box-shadow:0 4px 10px #2d70420d}.status-option-btn.missing:hover{background:#fff6f6;border-color:#f1dcde;box-shadow:0 4px 10px #c449490d}.status-option-btn.writeoff:hover{background:#fffaf0;border-color:#efe4c3;box-shadow:0 4px 10px #9b78120d}.status-option-btn.is-active.found{color:#1f6a37;background:#dff4e5;border-color:#a9d6b6;box-shadow:0 8px 18px #2d704224}.status-option-btn.is-active.missing{color:#be2f2f;background:#ffe3e3;border-color:#efb5b5;box-shadow:0 8px 18px #c4494924}.status-option-btn.is-active.writeoff{color:#926d00;background:#ffefbd;border-color:#e4c86a;box-shadow:0 8px 18px #9b781224}.status-option-check{justify-content:center;align-items:center;width:14px;margin-right:6px;font-size:12px;display:inline-flex}.item-header-meta{flex-wrap:wrap;gap:8px;margin:8px 0 4px;display:flex}img{object-fit:cover;border:1px solid #e4edf7;border-radius:12px;width:100%;max-height:180px}.photo-thumb-button{width:100%;box-shadow:none;background:0 0;border:0;padding:0;display:block}.photo-thumb-button:hover{box-shadow:none;background:0 0;border-color:#0000;transform:none}.photo-thumb-button img{cursor:zoom-in}.error{color:#d14343;font-size:13px;font-weight:600}.inline-form{grid-template-columns:1fr auto;gap:10px;margin-bottom:14px;display:grid}.inline-form-3,.inline-form-4{grid-template-columns:1fr 1fr 1fr auto}.inline-form-user-edit{grid-template-columns:1.4fr 1fr 1fr auto}.directory-list{flex-direction:column;gap:10px;display:flex}.directory-toggle{width:100%;color:var(--text);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:10px;padding:4px 8px;transition:background .18s,border-color .18s,color .18s;display:flex}.directory-toggle:hover{color:#27415e;background:#f7fbff;border-color:#e8eef6}.directory-toggle h2{font-size:19px;line-height:1.2}.directory-toggle span{color:#8ea0b4;font-size:18px;line-height:1}.directory-row{grid-template-columns:1fr;gap:10px;display:grid}.directory-row.compact{background:var(--panel-soft);border:1px solid #e4edf7;border-radius:14px;grid-template-columns:1fr auto;align-items:center;padding:12px 14px}.directory-row.compact span{color:#38506b;font-weight:600}.directory-user-edit{grid-template-columns:1.4fr 1fr 1fr 180px;align-items:center;gap:10px;display:grid}.directory-row-3{grid-template-columns:1fr 1fr}.directory-row-4{grid-template-columns:1fr 1fr 1fr}.file-picker{flex-direction:column;gap:4px;display:flex}.file-trigger{color:#48637e;cursor:pointer;background:#f7faff;border:1px dashed #bdd2ef;border-radius:12px;justify-content:center;align-items:center;min-height:42px;padding:0 12px;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.file-trigger input{opacity:0;cursor:pointer;position:absolute;inset:0}.edit-photo-inline{grid-template-columns:90px 1fr;align-items:center;gap:10px;display:grid}.model-thumb{object-fit:cover;border:1px solid #dce7f2;border-radius:12px;width:90px;height:70px}.no-photo{color:#7a8ea6;background:#f7fafe;border:1px dashed #cbd8e8;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:10px;min-height:150px;font-size:13px;display:flex}.no-photo.small{min-height:70px}.placeholder-logo{object-fit:contain;width:56px;height:56px;box-shadow:none;border:0;border-radius:0}.scanner-empty{text-align:center;align-items:center}.scanner-panel{gap:16px}.scanner-page-head{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;display:flex}.scanner-shell{grid-template-columns:minmax(0,1.35fr) minmax(240px,.65fr);align-items:stretch;gap:16px;display:grid}.scanner-stage,.scanner-sidecard{background:linear-gradient(#fff 0%,#f9fbff 100%);border:1px solid #e1ebf6;border-radius:20px;padding:16px}.scanner-stage-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.scanner-stage-head h3,.scanner-sidecard h3{margin:0 0 4px;font-size:17px}.scanner-badge{color:#47617c;background:#f3f7fd;border:1px solid #d7e5f4;border-radius:999px;flex:none;padding:8px 12px;font-size:12px;font-weight:700}.scanner-badge.ready{color:#2d6a45;background:#eef8f2;border-color:#cfe7d6}.scanner-badge.error{color:#b14848;background:#fff2f2;border-color:#f2cfcf}.scanner-frame{background:#08121e;border:1px solid #d8e3f0;border-radius:18px;min-height:380px;position:relative;overflow:hidden}.scanner-reader{object-fit:cover;z-index:1;background:#08121e;display:block;position:absolute;inset:0;overflow:hidden;width:100%!important;height:100%!important}.scanner-overlay{pointer-events:none;z-index:3;position:absolute;inset:0}.scanner-target{border:2px solid #ffffffeb;border-radius:22px;width:min(78%,320px);height:min(34%,160px);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 999px #050e1842}.scanner-scanline{background:linear-gradient(90deg,#2f7cf600,#2f7cf6f2,#2f7cf600);width:min(72%,290px);height:2px;animation:2.1s ease-in-out infinite scanner-line-move;position:absolute;top:50%;left:50%;transform:translate(-50%);box-shadow:0 0 18px #2f7cf6bf}.scanner-sidecard{flex-direction:column;justify-content:center;align-items:flex-start;gap:12px;display:flex}.scanner-sidecard ul{color:#536b85;margin:0;padding-left:18px;line-height:1.55}.scanner-brand{object-fit:contain;width:72px;height:72px;box-shadow:none;border:0;border-radius:0}.scanner-result{background:linear-gradient(#fff 0%,#fbfdff 100%);max-width:560px}.scanner-result-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.status-editor-row{background:linear-gradient(#fff 0%,#f8fbff 100%);border:1px solid #e1ebf6;border-radius:16px;justify-content:space-between;align-items:end;gap:16px;padding:14px 16px;display:flex}.status-editor-label{letter-spacing:.03em;text-transform:uppercase;color:#72849a;margin:0 0 8px;font-size:12px;font-weight:700}.status-editor-control{min-width:240px}@keyframes scanner-line-move{0%{opacity:.85;transform:translate(-50%,-58px)}50%{opacity:1;transform:translate(-50%,58px)}to{opacity:.85;transform:translate(-50%,-58px)}}.modal-actions{justify-content:flex-end;margin-top:8px}.nested-modal-backdrop{z-index:80;background:#12213333;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.nested-modal-card{background:#fff;border:1px solid #d7e4f2;border-radius:18px;flex-direction:column;gap:12px;width:min(420px,100%);padding:18px;display:flex;box-shadow:0 20px 48px #0e213d2e}.nested-modal-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.nested-modal-header h3{color:#24384e;margin:0;font-size:17px}.nested-modal-actions{justify-content:flex-end}.export-choice-card{width:min(460px,100%)}.export-choice-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.confirm-icon-btn{border-radius:14px;width:46px;min-width:46px;height:46px;padding:0;font-size:22px;line-height:1}.modal-backdrop{z-index:60;background:#12213370;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-card{background:#fff;border:1px solid #d7e4f2;border-radius:20px;width:min(980px,100%);max-height:calc(100vh - 40px);padding:20px;overflow:auto;box-shadow:0 24px 60px #0e213d38}.modal-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.modal-close{color:#37516f;background:#f5f8fd;border:1px solid #d7e5f5;flex:none;font-size:22px;line-height:1}.item-modal-grid{grid-template-columns:minmax(260px,340px) 1fr;gap:18px;display:grid}.item-modal-media{flex-direction:column;gap:12px;display:flex}.item-photo-strip{grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:10px;display:grid}.item-photo-strip.editor{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.log-list{gap:12px;display:grid}.log-card{background:#f8fbff;border:1px solid #dbe6f2;border-radius:16px;gap:6px;padding:14px 16px;display:grid}.log-card-top{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.log-change-list{gap:8px;margin-top:6px;display:grid}.log-change-row{background:#fff;border:1px solid #e3ecf6;border-radius:12px;gap:2px;padding:10px 12px;display:grid}.item-photo-thumb{object-fit:cover;width:100%;height:82px}.item-editor-photos{flex-direction:column;gap:12px;display:flex}.media-block{flex-direction:column;gap:10px;display:flex}.media-block-title{letter-spacing:.03em;text-transform:uppercase;color:#72849a;margin:0;font-size:12px;font-weight:700}.item-photo-card{position:relative}.model-photo-card{max-width:220px}.item-photo-card .item-photo-thumb{height:108px}.model-photo-thumb{height:140px}.photo-delete-btn{border-radius:10px;width:34px;min-width:34px;height:34px;min-height:34px;font-size:15px;position:absolute;top:8px;right:8px;box-shadow:0 8px 18px #19273a29}.item-photo-upload{width:fit-content}.photo-preview-backdrop{z-index:90;background:#09121dbd;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.photo-preview-card{max-width:min(1100px,100%);max-height:calc(100vh - 48px);position:relative}.photo-preview-close{z-index:2;position:absolute;top:12px;right:12px}.photo-preview-image{object-fit:contain;background:#09121d;border:1px solid #dbe7f566;border-radius:18px;width:auto;max-width:100%;height:auto;max-height:calc(100vh - 48px);box-shadow:0 24px 60px #040c1659}.toggle-chip{color:#40566f;background:#f8fbff;border:1px solid #dbe6f2;border-radius:14px;align-items:center;gap:10px;width:fit-content;padding:10px 12px;font-size:13px;font-weight:600;display:inline-flex}.toggle-chip input{width:16px;height:16px;min-height:16px;margin:0}.item-details{flex-direction:column;display:flex}.details-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.detail-row{background:#f9fbfe;border:1px solid #e2ebf5;border-radius:14px;flex-direction:column;gap:6px;padding:12px 14px;display:flex}.detail-row span{color:#72849a;text-transform:uppercase;letter-spacing:.03em;font-size:12px;font-weight:700}.detail-row strong{color:#22384f;word-break:break-word;font-size:14px;line-height:1.45}.detail-row-wide{grid-column:1/-1}.login-shell{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{gap:14px;width:100%;max-width:420px;padding:28px}.login-badge{width:fit-content;color:var(--primary);background:#e8f1ff;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:700}@media (width<=980px){.topbar{grid-template-columns:1fr;align-items:stretch}.user-chip{justify-self:start}.filter-grid,.form-grid,.two-cols,.location-grid,.scanner-shell,.item-modal-grid,.details-grid,.inline-form,.inline-form-3,.inline-form-4,.directory-row,.directory-row-3,.directory-row-4,.directory-row.compact,.edit-photo-inline{grid-template-columns:1fr}.actions{flex-wrap:wrap}.section-heading,.add-footer,.modal-header,.scanner-page-head,.scanner-stage-head,.scanner-result-head,.nested-modal-header,.status-editor-row{flex-direction:column;align-items:flex-start}.add-summary{justify-content:flex-start}.status-editor-control{width:100%;min-width:100%}.scanner-frame{min-height:320px}.modal-card{padding:16px}}
