@import "https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&family=Syne:wght@400;500;600;700&family=Inter:wght@300;400;500&display=swap";*{box-sizing:border-box;margin:0;padding:0}body{color:#e8e6e0;background:#0d0e0f;font-family:Inter,sans-serif}:root{--bg:#0d0e0f;--surface:#161718;--surface2:#1e2021;--surface3:#262829;--border:#ffffff12;--border2:#ffffff1f;--accent:#d4a843;--accent-dim:#d4a84326;--text:#e8e6e0;--text2:#9a9890;--text3:#5c5a55;--red:#e05252;--green:#52a876;--green-dim:#52a8761f;--blue:#5284c8;--blue-dim:#5284c81f;--orange:#e07a3a;--orange-dim:#e07a3a1f;--purple:#9b72cf;--purple-dim:#9b72cf1f;--loc-lee:#e0a03a;--loc-lee-dim:#e0a03a1f;--loc-pat:#d4645c;--loc-pat-dim:#d4645c1f;--loc-jon:#4aad8b;--loc-jon-dim:#4aad8b1f;--mono:"DM Mono",monospace;--display:"Syne",sans-serif}.app{height:100dvh;display:flex;overflow:hidden}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:220px;display:flex}.sidebar-header{padding:calc(14px + env(safe-area-inset-top)) 16px 14px;border-bottom:1px solid var(--border)}.logo{font-family:var(--display);letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-size:15px;font-weight:700}.logo-sub{color:var(--text3);letter-spacing:.12em;text-transform:uppercase;font-size:10px;font-family:var(--mono);margin-top:2px}.sidebar-nav{flex:1;padding:12px 8px;overflow-y:auto}.sidebar-footer{padding:8px 8px calc(8px + env(safe-area-inset-bottom));border-top:1px solid var(--border)}.nav-label{font-size:9px;font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--text3);margin-bottom:6px;padding:0 12px}.nav-item{cursor:pointer;color:var(--text2);border-radius:6px;align-items:center;gap:10px;padding:8px 12px;font-size:13px;transition:all .15s;display:flex}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:var(--accent-dim);color:var(--accent)}.nav-count{font-family:var(--mono);color:var(--text3);margin-left:auto;font-size:10px}.nav-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.nav-icon{text-align:center;flex-shrink:0;width:16px;font-size:12px}.main{flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{background:var(--surface);border-bottom:1px solid var(--border);min-height:48px;padding:env(safe-area-inset-top) 20px 0;flex-shrink:0;align-items:center;gap:12px;display:flex}.topbar-title{font-family:var(--display);letter-spacing:.02em;font-size:14px;font-weight:600}.content{flex:1;padding:0 20px 20px;overflow-y:auto}.search-input{background:var(--surface);border:1px solid var(--border);min-width:180px;color:var(--text);border-radius:6px;outline:none;padding:7px 12px;font-family:inherit;font-size:12px}.search-input::placeholder{color:var(--text3)}.search-input:focus{border-color:var(--border2)}.ask-loadout-btn{font-family:var(--mono);border:1px solid var(--border);background:var(--surface);color:var(--text2);cursor:pointer;white-space:nowrap;letter-spacing:.02em;border-radius:6px;padding:7px 14px;font-size:11px;transition:all .15s}.ask-loadout-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.filter-bar{z-index:10;background:var(--bg);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:4px;padding:16px 0 12px;display:flex;position:sticky;top:0}.filter-chip{font-size:10px;font-family:var(--mono);cursor:pointer;border:1px solid var(--border);color:var(--text3);background:0 0;border-radius:20px;padding:4px 10px;transition:all .15s}.filter-chip:hover{border-color:var(--border2);color:var(--text2)}.case-grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));align-items:start;gap:14px;display:grid}.case-panel{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-direction:column;height:420px;transition:height .25s;display:flex;position:relative;overflow:hidden}.case-panel.collapsed{height:auto}.case-stripe{flex-shrink:0;height:2px}.case-panel-header{border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;flex-shrink:0;align-items:flex-start;gap:10px;padding:12px 14px 14px;display:flex}.case-panel-header:hover{background:var(--surface2)}.case-panel.collapsed .case-panel-header{border-bottom:none}.case-panel-toggle{color:var(--accent);flex-shrink:0;margin-top:3px;font-size:10px;transition:transform .2s}.case-panel-drag{color:var(--text3);cursor:grab;opacity:.4;flex-shrink:0;margin-top:2px;padding:0 2px;font-size:11px;transition:opacity .15s}.case-panel-drag:hover{opacity:1;color:var(--text2)}.case-panel-drag:active{cursor:grabbing}.case-panel.dragging{opacity:.4;border-color:var(--accent)}.case-panel.drag-over{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.case-panel-info{flex:1;min-width:0}.case-panel-name{font-family:var(--display);cursor:text;font-size:14px;font-weight:600}.case-panel-name-input{font-family:var(--display);color:var(--text);background:var(--surface);border:1px solid var(--accent);border-radius:4px;outline:none;width:100%;padding:1px 6px;font-size:14px;font-weight:600}.case-panel-tag{font-family:var(--mono);letter-spacing:.06em;color:var(--accent);opacity:.7;white-space:nowrap;flex-shrink:0;margin-top:1px;font-size:13px;font-weight:500}.case-panel-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:1px;display:flex}.case-panel-bottom-row{justify-content:space-between;align-items:center;gap:10px;margin-top:4px;display:flex}.case-panel-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;display:flex}.case-panel-type-input{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--text);background:var(--surface);border:1px solid var(--accent);border-radius:3px;outline:none;width:100%;padding:1px 4px;font-size:10px;font-weight:500}.meta-label{font-family:var(--mono);color:var(--text3);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:500}.case-loc-select{font-family:var(--mono);letter-spacing:.06em;border:1px solid var(--border);background:var(--surface2);color:var(--text2);cursor:pointer;box-sizing:border-box;appearance:none;text-align:center;text-transform:uppercase;direction:ltr;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5' viewBox='0 0 8 5'%3E%3Cpath d='M0 0l4 5 4-5z' fill='%235c5a55'/%3E%3C/svg%3E");background-position:right 3px center;background-repeat:no-repeat;border-radius:3px;outline:none;padding:1px 14px 1px 2px;font-size:10px;font-weight:500}.case-loc-select:hover{border-color:var(--border2)}.case-loc-select:focus{border-color:var(--accent)}.case-panel-body{flex:1;min-height:0;padding:6px 14px 14px;overflow-y:auto}.case-panel-body::-webkit-scrollbar{width:4px}.case-panel-body::-webkit-scrollbar-track{background:0 0}.case-panel-body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.case-panel-empty{text-align:center;color:var(--text3);padding:20px 0;font-size:12px}.case-panel-footer{border-top:1px solid var(--border);flex-shrink:0;gap:6px;padding:8px 14px;display:flex}.case-action-btn{border:1px dashed var(--border2);color:var(--text3);cursor:pointer;font-size:10px;font-family:var(--mono);background:0 0;border-radius:5px;flex:1;padding:4px 10px;transition:all .15s}.case-action-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.case-panel-actions{border-top:1px solid var(--border);gap:6px;margin-top:6px;padding:8px 0 4px;display:flex}.case-panel.misc-container{border-style:dashed;border-color:var(--border2)}.case-panel.misc-container .case-stripe{height:1px;background:var(--border2)!important}.case-panel.gobag-panel{border-color:var(--border2);max-width:600px}.group-header{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--text3);border-bottom:1px solid var(--border);-webkit-user-select:none;user-select:none;align-items:center;gap:5px;margin-top:10px;margin-bottom:4px;padding-bottom:4px;font-size:9px;display:flex}.group-header:first-child{margin-top:4px}.group-section{margin-bottom:2px}.group-action{color:var(--text3);cursor:pointer;font-size:11px;font-family:var(--mono);opacity:0;background:0 0;border:none;border-radius:3px;flex-shrink:0;padding:0 3px;transition:all .15s}.group-header:hover .group-action{opacity:.6}.group-action:hover{color:var(--text2);background:var(--surface2);opacity:1!important}.group-delete:hover{color:var(--red)!important;background:#e052521a!important}.group-name-input{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--text);background:var(--surface);border:1px solid var(--accent);border-radius:3px;outline:none;flex:1;min-width:0;padding:1px 4px;font-size:9px}.item-row{white-space:nowrap;align-items:center;gap:0;padding:3px 0;font-size:12px;line-height:1.3;display:flex}.item-row.highlighted{background:var(--accent-dim);border-radius:4px;margin:0 -4px;padding:3px 4px}.item-left{flex:1;align-items:center;gap:6px;min-width:0;display:flex;overflow:hidden}.item-right{flex-shrink:0;align-items:center;gap:3px;margin-left:8px;display:flex}.row-box{border:1px solid var(--border);width:18px;height:18px;font-family:var(--mono);color:var(--text3);border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;font-size:8px;transition:all .12s;display:flex}.row-box:empty{opacity:.4}.row-box-repair{color:var(--red);background:#e052521a;border-color:#e0525266;font-weight:700}.row-box-clickable{cursor:pointer}.row-box-clickable:hover{background:#e0525240}.item-check{border:1.5px solid var(--border2);cursor:pointer;background:0 0;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;transition:all .12s;display:flex}.item-check:hover{border-color:var(--text2)}.item-check.checked{background:var(--accent);border-color:var(--accent)}.item-check.checked:after{content:"✓";color:#0d0e0f;font-size:9px;font-weight:700}.item-qty{font-family:var(--mono);color:var(--text3);text-align:right;flex-shrink:0;width:22px;font-size:10px}.item-name-wrap{flex:1;min-width:0;position:relative}.item-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.item-name-tip{background:var(--surface3);border:1px solid var(--border2);color:var(--text);white-space:normal;z-index:300;pointer-events:none;border-radius:6px;max-width:360px;padding:6px 10px;font-size:11px;line-height:1.4;position:fixed;box-shadow:0 6px 20px #00000080}.loc-badge{font-family:var(--mono);letter-spacing:.04em;cursor:default;border-radius:3px;padding:1px 4px;font-size:8px;font-weight:500;line-height:1.2}.sub-items{border-left:2px solid var(--border2);margin-left:22px;padding-left:6px}.bag-row{cursor:pointer}.bag-count{font-family:var(--mono);color:var(--text3);flex-shrink:0;font-size:9px}.note-marker{background:var(--orange-dim);width:16px;height:16px;color:var(--orange);cursor:pointer;font-size:10px;font-family:var(--mono);border:none;border-radius:3px;justify-content:center;align-items:center;line-height:1;transition:background .15s;display:flex}.note-marker:hover{background:#e07a3a40}.note-add{width:16px;height:16px;color:var(--text3);cursor:pointer;font-size:12px;font-family:var(--mono);opacity:.3;background:0 0;border:1px solid #0000;border-radius:3px;justify-content:center;align-items:center;line-height:1;transition:all .15s;display:flex}.note-add:hover{opacity:1;color:var(--orange);border-color:var(--orange-dim);background:var(--orange-dim)}.note-tooltip{background:var(--surface3);border:1px solid var(--border2);color:var(--text);white-space:normal;z-index:300;pointer-events:none;border-radius:6px;width:280px;max-height:140px;padding:8px 10px;font-size:11px;line-height:1.45;position:fixed;overflow-y:auto;box-shadow:0 6px 20px #00000080}.note-tooltip .note-tip-hint{font-family:var(--mono);color:var(--text3);margin-top:6px;font-size:9px;display:block}.note-popup-overlay{z-index:200;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.popup-close{color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:16px}.popup-close:hover{background:var(--surface2);color:var(--text)}.note-textarea{background:var(--surface2);border:1px solid var(--border);width:100%;min-height:80px;color:var(--text);resize:vertical;border-radius:6px;outline:none;padding:10px 12px;font-family:inherit;font-size:13px;line-height:1.5}.note-textarea:focus{border-color:var(--accent)}.btn{font-size:12px;font-family:var(--mono);cursor:pointer;border:1px solid var(--border2);color:var(--text2);background:0 0;border-radius:6px;padding:6px 14px;transition:all .15s}.btn:hover{background:var(--surface2);color:var(--text)}.btn-accent{background:var(--accent);color:#0d0e0f;border-color:var(--accent);font-weight:500}.btn-accent:hover{background:#e0b54a}.btn-red{background:var(--red);color:#fff;border-color:var(--red);font-weight:500}.btn-red:hover{background:#e86060}.detail-panel{background:var(--surface);border:1px solid var(--border2);border-radius:10px;flex-direction:column;width:520px;max-width:92vw;max-height:88vh;display:flex;overflow:hidden}.detail-header{border-bottom:1px solid var(--border);align-items:flex-start;gap:12px;padding:18px 20px 14px;display:flex}.detail-title{font-family:var(--display);font-size:15px;font-weight:600;line-height:1.3}.detail-subtitle{font-family:var(--mono);color:var(--text3);margin-top:3px;font-size:10px}.detail-body{flex:1;padding:18px 20px;overflow-y:auto}.detail-section-label{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--text3);border-bottom:1px solid var(--border);margin-bottom:10px;padding-bottom:6px;font-size:9px}.detail-fields-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.detail-field-label{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--text3);margin-bottom:4px;font-size:9px}.detail-input{background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);border-radius:6px;outline:none;padding:8px 10px;font-family:inherit;font-size:12px}.detail-input:focus{border-color:var(--accent)}.detail-input::placeholder{color:var(--text3)}.detail-textarea{background:var(--surface2);border:1px solid var(--border);width:100%;min-height:72px;color:var(--text);resize:vertical;border-radius:6px;outline:none;padding:10px 12px;font-family:inherit;font-size:12px;line-height:1.5}.detail-textarea:focus{border-color:var(--accent)}.detail-textarea::placeholder{color:var(--text3)}.detail-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:14px 20px;display:flex}.detail-repair-entry{background:var(--surface2);border:1px solid var(--border);border-left:3px solid var(--red);border-radius:6px;margin-bottom:8px;padding:10px 12px}.detail-repair-entry:last-child{margin-bottom:0}.detail-repair-header{align-items:center;gap:8px;margin-bottom:4px;display:flex}.detail-status-btn{font-size:11px;font-family:var(--mono);cursor:pointer;border:1px solid var(--border2);color:var(--text2);background:0 0;border-radius:6px;padding:5px 12px;transition:all .15s}.detail-status-btn:hover{border-color:var(--red);color:var(--red);background:#e0525214}.detail-status-btn.active-missing{border-color:var(--red);color:var(--red);background:#e0525226;font-weight:500}.settings-panel{padding:16px}.settings-menu-item{cursor:pointer;color:var(--text2);border:1px solid var(--border);border-radius:6px;align-items:center;gap:10px;padding:10px 12px;font-size:13px;transition:all .15s;display:flex}.settings-menu-item:hover{background:var(--surface2);color:var(--text);border-color:var(--border2)}.settings-back{font-family:var(--mono);color:var(--text3);cursor:pointer;padding:4px 0;font-size:11px;transition:color .15s}.settings-back:hover{color:var(--accent)}.settings-color-input{border:1px solid var(--border2);cursor:pointer;background:0 0;border-radius:3px;flex-shrink:0;width:22px;height:16px;padding:0}.settings-color-input::-webkit-color-swatch-wrapper{padding:1px}.settings-color-input::-webkit-color-swatch{border:none;border-radius:2px}.settings-color-lg{border:1px solid var(--border2);cursor:pointer;background:0 0;border-radius:4px;flex-shrink:0;width:32px;height:28px;padding:0}.settings-color-lg::-webkit-color-swatch-wrapper{padding:2px}.settings-color-lg::-webkit-color-swatch{border:none;border-radius:2px}.color-picker-bar{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px;padding:10px 0;display:flex}.color-presets{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:10px;display:flex}.color-preset{cursor:pointer;border:2px solid #0000;border-radius:5px;flex-shrink:0;width:22px;height:22px;transition:all .12s}.color-preset:hover{border-color:#ffffff4d;transform:scale(1.15)}.color-preset.active{border-color:var(--text);transform:scale(1.15)}.color-preset-custom{align-items:center;display:flex}.color-picker-list{flex-direction:column;gap:1px;display:flex}.color-picker-row{cursor:pointer;border-radius:5px;align-items:center;gap:8px;padding:6px 8px;transition:background .12s;display:flex}.color-picker-row:hover{background:var(--surface2)}.color-picker-row.selected{background:var(--accent-dim)}.color-picker-swatch{border-radius:1px;flex-shrink:0;width:12px;height:4px}.color-picker-tag{font-family:var(--mono);color:var(--accent);flex-shrink:0;width:68px;font-size:10px}.color-picker-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:12px;overflow:hidden}.select-bar{background:var(--surface2);border-bottom:1px solid var(--border2);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;padding:8px 20px;display:flex}.select-bar-count{font-family:var(--mono);color:var(--accent);white-space:nowrap;font-size:12px}.select-bar-sep{background:var(--border2);flex-shrink:0;width:1px;height:20px}.select-bar-btn{font-size:10px;font-family:var(--mono);cursor:pointer;border:1px solid var(--border2);color:var(--text2);white-space:nowrap;background:0 0;border-radius:6px;padding:5px 10px;transition:all .12s}.select-bar-btn:hover{background:var(--surface3);color:var(--text)}.select-bar-btn.repair{border-color:var(--red);color:var(--red)}.select-bar-btn.repair:hover{background:#e052521a}.select-bar-btn.clear-loc{border-color:var(--text3);color:var(--text3)}.select-bar-btn.clear-loc:hover{background:var(--surface3);color:var(--text2)}.select-bar-select{font-size:11px;font-family:var(--mono);cursor:pointer;border:1px solid var(--border2);background:var(--surface);color:var(--text2);border-radius:6px;outline:none;padding:5px 8px}.select-bar-select:hover{border-color:var(--text3)}.select-bar-clear{color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:4px;margin-left:auto;padding:2px 6px;font-size:14px}.select-bar-clear:hover{color:var(--text);background:var(--surface3)}.locview-header{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:16px;padding:16px 20px}.locview-empty{text-align:center;color:var(--text3);padding:40px 20px;font-size:12px;line-height:1.6}.locview-case-group{margin-bottom:16px}.locview-case-label{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--text3);border-bottom:1px solid var(--border);margin-bottom:6px;padding-bottom:4px;font-size:10px}.locview-item{white-space:nowrap;align-items:center;gap:8px;padding:4px 0;font-size:12px;display:flex}.locview-item-name{color:var(--text);text-overflow:ellipsis;flex:1;overflow:hidden}.locview-remove{color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:3px;flex-shrink:0;padding:1px 5px;font-size:14px}.locview-remove:hover{color:var(--red);background:#e052521a}.case-loc-view-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:8px;align-items:center;gap:10px;margin-bottom:8px;padding:10px 14px;transition:all .15s;display:flex}.case-loc-view-card:hover{background:var(--surface2);border-color:var(--border2)}.case-loc-view-name{font-family:var(--display);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;font-weight:600;overflow:hidden}.case-loc-view-tag{font-family:var(--mono);color:var(--accent);opacity:.7;font-size:10px}.case-loc-view-meta{font-family:var(--mono);color:var(--text3);font-size:9px}.repair-modal{background:var(--surface);border:1px solid var(--border2);border-radius:10px;flex-direction:column;width:520px;max-width:90vw;max-height:85vh;display:flex;overflow:hidden}.repair-modal-header{border-bottom:1px solid var(--border);padding:16px 20px 14px}.repair-modal-title{font-family:var(--display);font-size:15px;font-weight:600}.repair-modal-items{font-family:var(--mono);color:var(--text3);margin-top:4px;font-size:10px}.repair-modal-body{flex-direction:column;flex:1;gap:14px;padding:16px 20px;display:flex;overflow-y:auto}.repair-modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:14px 20px;display:flex}.repair-file-zone{border:1.5px dashed var(--border2);text-align:center;cursor:pointer;border-radius:8px;padding:16px;transition:all .15s}.repair-file-zone:hover{border-color:var(--text3);background:var(--surface2)}.repair-file-zone.has-files{border-color:var(--accent);background:var(--accent-dim);border-style:solid}.repair-file-list{flex-direction:column;gap:6px;margin-top:10px;display:flex}.repair-file-item{background:var(--surface2);border-radius:5px;align-items:center;gap:8px;padding:6px 8px;font-size:11px;display:flex}.repair-file-name{color:var(--text2);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.repair-file-size{font-family:var(--mono);color:var(--text3);flex-shrink:0;font-size:9px}.repair-file-remove{color:var(--text3);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 4px;font-size:12px}.repair-file-remove:hover{color:var(--red)}.repair-thumb{object-fit:cover;border-radius:4px;flex-shrink:0;width:40px;height:40px}.ticket-card{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--red);border-radius:10px;margin-bottom:12px;padding:16px 18px}.ticket-card.resolved{border-left-color:var(--green);opacity:.75}.ticket-focused{box-shadow:0 0 0 2px var(--red);animation:1.5s ease-out ticket-pulse}@keyframes ticket-pulse{0%{box-shadow:0 0 0 4px #e0525266}to{box-shadow:0 0 0 2px var(--red)}}.ticket-header{align-items:flex-start;gap:10px;margin-bottom:10px;display:flex}.ticket-date{font-family:var(--mono);color:var(--text3);white-space:nowrap;font-size:10px}.ticket-id{font-family:var(--mono);color:var(--red);white-space:nowrap;font-size:10px}.ticket-items{flex-wrap:wrap;gap:4px;margin-bottom:8px;display:flex}.ticket-item-chip{font-family:var(--mono);background:var(--surface2);border:1px solid var(--border);color:var(--text2);border-radius:4px;padding:2px 8px;font-size:10px}.ticket-desc{color:var(--text);margin-bottom:10px;font-size:13px;line-height:1.5}.ticket-media{flex-wrap:wrap;gap:8px;display:flex}.ticket-media-thumb{object-fit:cover;border:1px solid var(--border);cursor:pointer;border-radius:6px;width:80px;height:60px}.ticket-media-file{background:var(--surface2);border:1px solid var(--border);color:var(--text2);border-radius:6px;align-items:center;gap:6px;padding:6px 10px;font-size:11px;display:flex}.ticket-section-label{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--text3);border-bottom:1px solid var(--border);margin-top:24px;margin-bottom:10px;padding-bottom:6px;font-size:10px}.ticket-section-label:first-child{margin-top:0}.ticket-resolved-badge{font-family:var(--mono);background:var(--green-dim);color:var(--green);text-transform:uppercase;letter-spacing:.04em;border-radius:4px;padding:2px 7px;font-size:9px}.ticket-service-notes{border-top:1px solid var(--border);margin-top:10px;padding-top:10px}.ticket-service-note{background:var(--surface2);border-left:2px solid var(--blue);border-radius:6px;margin-bottom:6px;padding:8px 10px}.ticket-service-note-text{color:var(--text);font-size:12px;line-height:1.5}.ticket-service-note-meta{font-family:var(--mono);color:var(--text3);margin-top:4px;font-size:9px}.ticket-add-note{gap:8px;margin-top:8px;display:flex}.ticket-add-note input{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:6px;outline:none;flex:1;padding:6px 10px;font-family:inherit;font-size:12px}.ticket-add-note input:focus{border-color:var(--accent)}.ticket-add-note button{font-size:11px;font-family:var(--mono);cursor:pointer;border:1px solid var(--border2);color:var(--text2);white-space:nowrap;background:0 0;border-radius:6px;padding:6px 12px}.ticket-add-note button:hover{background:var(--surface3);color:var(--text)}.ticket-resolve-btn{font-size:11px;font-family:var(--mono);cursor:pointer;border:1px solid var(--green);color:var(--green);background:0 0;border-radius:6px;margin-top:10px;padding:6px 14px;transition:all .15s}.ticket-resolve-btn:hover{background:var(--green-dim)}.shoot-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-left:3px solid var(--accent);border-radius:10px;margin-bottom:10px;padding:14px 18px;transition:all .15s}.shoot-card:hover{background:var(--surface2);border-color:var(--border2)}.shoot-card.status-prepping{border-left-color:var(--orange)}.shoot-card.status-active{border-left-color:var(--green)}.shoot-card.status-wrapped{border-left-color:var(--blue)}.shoot-card.status-archived{border-left-color:var(--text3);opacity:.75;background:var(--surface)}.shoot-card.status-archived:hover{opacity:1}.shoots-archive-separator{align-items:center;gap:10px;margin:22px 0 12px;display:flex}.shoots-archive-line{background:var(--border);flex:1;height:1px}.shoots-archive-label{font-family:var(--mono);color:var(--text3);letter-spacing:.08em;text-transform:uppercase;font-size:10px}.shoot-archive-manifest{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.shoot-archive-chip{font-family:var(--mono);background:var(--surface2);color:var(--text2);white-space:nowrap;border-radius:4px;padding:2px 8px;font-size:9px}.shoot-header{align-items:flex-start;gap:10px;margin-bottom:6px;display:flex}.shoot-client{font-family:var(--display);flex:1;font-size:14px;font-weight:600}.shoot-status-badge{font-family:var(--mono);text-transform:uppercase;letter-spacing:.04em;border-radius:4px;padding:2px 7px;font-size:9px}.shoot-project{color:var(--text2);margin-bottom:4px;font-size:12px}.shoot-dates{font-family:var(--mono);color:var(--text3);font-size:10px}.shoot-manifest{margin-top:12px}.shoot-manifest-remove{color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:3px;flex-shrink:0;padding:0 4px;font-size:12px}.shoot-manifest-remove:hover{color:var(--red);background:#e052521a}.shoot-page{flex-direction:column;gap:12px;display:flex}.shoot-topbar{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-wrap:wrap;align-items:center;gap:8px;padding:12px 16px;display:flex}.shoot-topbar-status{font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;border-radius:4px;flex-shrink:0;padding:3px 8px;font-size:9px;font-weight:600}.shoot-topbar-info{flex:1;align-items:baseline;gap:8px;min-width:0;display:flex}.shoot-topbar-client{font-family:var(--display);white-space:nowrap;font-size:16px;font-weight:700}.shoot-topbar-project{color:var(--text2);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.shoot-topbar-dates{flex-wrap:wrap;flex-shrink:0;gap:6px;display:flex}.shoot-date-chip{font-family:var(--mono);color:var(--text3);background:var(--surface2);white-space:nowrap;border-radius:4px;padding:2px 8px;font-size:9px}.shoot-topbar-actions{flex-shrink:0;gap:4px;margin-left:auto;display:flex}.shoot-stats{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.shoot-stat{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:8px;padding:12px 14px}.shoot-stat-num{font-family:var(--display);color:var(--accent);font-size:22px;font-weight:700;display:block}.shoot-stat-label{font-family:var(--mono);letter-spacing:.14em;color:var(--text3);margin-top:2px;font-size:8px;display:block}.shoot-grid{grid-template-columns:1fr 1fr;align-items:start;gap:12px;display:grid}.shoot-col{background:var(--surface);border:1px solid var(--border);border-radius:10px;min-height:120px;padding:14px 16px}.shoot-col-header{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--text3);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:8px;font-size:10px;display:flex}.shoot-col-empty{text-align:center;color:var(--text3);padding:20px 10px;font-size:11px;line-height:1.5}.shoot-add-select{font-family:var(--mono);border:1px solid var(--border);background:var(--surface2);color:var(--text3);cursor:pointer;border-radius:4px;outline:none;padding:2px 6px;font-size:9px}.shoot-add-select:hover{border-color:var(--accent);color:var(--accent)}.shoot-gear-row{align-items:center;gap:8px;padding:4px 0;font-size:12px;display:flex}.shoot-gear-row:hover{background:var(--surface2);border-radius:4px;margin:0 -8px;padding:4px 8px}.shoot-gear-tag{font-family:var(--mono);color:var(--accent);opacity:.7;flex-shrink:0;width:68px;font-size:10px}.shoot-gear-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.shoot-gear-loc{font-family:var(--mono);color:var(--text3);text-transform:uppercase;flex-shrink:0;font-size:9px}.shoot-item-case-label{font-family:var(--mono);color:var(--text3);letter-spacing:.08em;text-transform:uppercase;margin-top:6px;margin-bottom:2px;font-size:9px}.shoot-item-case-label:first-child{margin-top:0}.case-layout{background:var(--surface2);-webkit-user-select:none;user-select:none;border-radius:6px;min-height:200px;position:relative;overflow:hidden}.case-layout-photo{border-radius:6px;width:100%;display:block}.case-layout-upload{min-height:220px;color:var(--text3);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:10px;display:flex}.case-layout-upload:hover{background:var(--border);border-radius:6px}.case-layout-upload input{display:none}.case-layout-pin{cursor:grab;-webkit-user-select:none;user-select:none;z-index:2;position:absolute;transform:translate(-50%,-100%)}.case-layout-pin:active{cursor:grabbing}.case-layout-pin-dot{background:var(--accent);border:2px solid var(--bg);border-radius:50%;width:8px;height:8px;margin:0 auto}.case-layout-pin-label{background:var(--surface);border:1px solid var(--border);font-family:var(--mono);color:var(--text);border-radius:4px;align-items:flex-start;gap:4px;max-width:180px;margin-top:2px;padding:3px 4px 3px 7px;font-size:9px;display:flex;box-shadow:0 2px 6px #0000004d}.case-layout-pin-text{white-space:pre-wrap;word-break:break-word;line-height:1.3;display:inline-block}.case-layout-pin-delete{background:var(--border);color:var(--text2);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;min-width:20px;height:20px;min-height:20px;padding:0;font-size:16px;line-height:1;transition:background .15s,color .15s;display:inline-flex}.case-layout-pin-delete:hover{background:var(--red);color:#fff}.case-action-btn.active{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.case-layout-toolbar{flex-wrap:wrap;align-items:center;gap:8px;padding:8px 0;display:flex}.case-layer-nav{border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:8px;padding:6px 4px 10px;display:flex}.case-layer-nav-center{flex-direction:column;flex:1;align-items:center;gap:2px;min-width:0;display:flex}.case-layer-name{font-family:var(--display);color:var(--text);letter-spacing:.01em;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:13px;font-weight:600;overflow:hidden}.case-layer-name-input{background:var(--surface);border:1px solid var(--accent);font-family:var(--display);color:var(--text);text-align:center;border-radius:4px;outline:none;min-width:120px;padding:2px 6px;font-size:13px;font-weight:600}.case-layer-arrow{background:var(--surface);border:1px solid var(--border);color:var(--text2);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;width:28px;height:28px;font-size:11px;transition:all .15s;display:inline-flex}.case-layer-arrow:hover:not(:disabled){color:var(--accent);border-color:var(--accent)}.case-layer-arrow:disabled{opacity:.35;cursor:default}.case-layer-reorder{background:var(--surface);border:1px solid var(--border);color:var(--text2);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;font-size:9px;transition:all .15s;display:inline-flex}.case-layer-reorder:hover:not(:disabled){color:var(--accent);border-color:var(--accent)}.case-layer-reorder:disabled{opacity:.3;cursor:default}.case-flip-btn{border:1px solid var(--border);cursor:pointer;color:var(--text3);background:0 0;border-radius:4px;padding:2px 6px;font-size:11px;transition:all .15s}.case-flip-btn:hover{color:var(--accent);border-color:var(--accent)}.loadout-chat{background:var(--bg);border-left:1px solid var(--border);z-index:200;flex-direction:column;width:400px;display:flex;position:fixed;top:0;bottom:0;right:0;box-shadow:-4px 0 20px #0000004d}.loadout-chat-header{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:14px 16px;display:flex}.loadout-chat-header h2{font-family:var(--display);flex:1;font-size:15px;font-weight:700}.loadout-chat-messages{flex-direction:column;flex:1;gap:10px;padding:12px 16px;display:flex;overflow-y:auto}.loadout-chat-msg{border-radius:8px;max-width:90%;padding:8px 12px;font-size:12px;line-height:1.5}.loadout-chat-msg.user{background:var(--accent-dim);color:var(--accent);border-bottom-right-radius:2px;align-self:flex-end}.loadout-chat-msg.assistant{background:var(--surface);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:2px;align-self:flex-start}.loadout-chat-msg.system{color:var(--text3);background:0 0;align-self:center;font-size:11px;font-style:italic}.loadout-chat-input{border-top:1px solid var(--border);flex-shrink:0;gap:8px;padding:12px 16px;display:flex}.loadout-chat-input input{background:var(--surface);border:1px solid var(--border);color:var(--text);font-size:12px;font-family:var(--body);border-radius:6px;outline:none;flex:1;padding:8px 12px}.loadout-chat-input input:focus{border-color:var(--accent)}.loadout-chat-input button{background:var(--accent);color:var(--bg);cursor:pointer;font-size:11px;font-weight:600;font-family:var(--mono);border:none;border-radius:6px;padding:8px 14px}.loadout-chat-input button:disabled{opacity:.4;cursor:default}.add-case-modal{background:var(--surface);border:1px solid var(--border2);border-radius:10px;flex-direction:column;width:440px;max-width:90vw;display:flex;overflow:hidden}.add-case-modal-header{border-bottom:1px solid var(--border);padding:16px 20px 14px}.add-case-modal-title{font-family:var(--display);font-size:15px;font-weight:600}.add-case-modal-body{flex-direction:column;gap:12px;padding:16px 20px;display:flex}.add-case-modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:14px 20px;display:flex}.add-case-field{flex-direction:column;gap:4px;display:flex}.add-case-field-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.empty-state{text-align:center;color:var(--text3);padding:48px 20px;font-size:13px}.search-results-summary{margin-bottom:10px;padding:4px 0}.auth-loading{background:var(--bg);justify-content:center;align-items:center;height:100dvh;display:flex}.auth-loading-inner{text-align:center}.login-page{background:var(--bg);justify-content:center;align-items:center;height:100dvh;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:16px;width:360px;max-width:90vw;padding:32px 28px;display:flex}.login-header{text-align:center;border-bottom:1px solid var(--border);padding-bottom:8px}.login-field{flex-direction:column;gap:4px;display:flex}.login-error{color:var(--red);font-size:12px;font-family:var(--mono);background:#e052521a;border:1px solid #e052524d;border-radius:6px;padding:8px 12px}.case-qr-btn{border:1px solid var(--border2);color:var(--text3);cursor:pointer;background:0 0;border-radius:4px;padding:2px 6px;font-size:13px;line-height:1;transition:all .15s}.case-qr-btn:hover{color:var(--accent);border-color:var(--accent-dim);background:var(--surface2)}.hamburger-btn{color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:18px;line-height:1;display:none}.hamburger-btn:hover{background:var(--surface2)}.sidebar-backdrop{z-index:90;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;display:none;position:fixed;inset:0}@media (width<=767px){.hamburger-btn{justify-content:center;align-items:center;display:inline-flex}.sidebar{z-index:100;width:260px;transition:transform .22s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:2px 0 20px #0000004d}.app.sidebar-open .sidebar{transform:translate(0)}.app.sidebar-open .sidebar-backdrop{display:block}.main{width:100%}.topbar{gap:8px;padding-left:12px;padding-right:12px}.content{padding:0 12px 16px}.case-grid{grid-template-columns:1fr;gap:10px}.shoot-grid{grid-template-columns:1fr!important}.shoot-topbar{padding:10px 12px}.add-case-modal{max-width:520px;width:calc(100vw - 24px)!important}.add-case-field-row{grid-template-columns:1fr}.filter-bar{flex-wrap:wrap;gap:6px}.detail-panel{max-width:520px;width:calc(100vw - 24px)!important}}
