*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5;color:#333;background-color:#f5f5f5}body{margin:0;min-height:100vh}.app-layout{display:flex;min-height:100vh}.sidebar{width:250px;min-width:250px;background:#1a1a2e;color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto}.sidebar-header{padding:1.25rem 1rem;display:flex;align-items:center;gap:.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{font-size:1.5rem}.sidebar-title{font-size:1.15rem;font-weight:700;letter-spacing:.02em}.sidebar-nav{display:flex;flex-direction:column;padding:.5rem 0;flex:1}.nav-item{display:flex;align-items:center;gap:.65rem;padding:.55rem 1.15rem;color:#ffffffb3;text-decoration:none;font-size:.88rem;transition:background .15s,color .15s;border-left:3px solid transparent}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.active{background:#ffffff1f;color:#fff;border-left-color:#e63946}.nav-icon{font-size:1rem;width:1.4rem;text-align:center;flex-shrink:0}.nav-label{white-space:nowrap}.main-area{flex:1;margin-left:250px;display:flex;flex-direction:column;min-height:100vh}.app-header{background:#fff;box-shadow:0 1px 3px #0000001a;padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}.header-spacer{flex:1}.header-user{display:flex;align-items:center;gap:.75rem}.user-name{font-weight:500;color:#555}.content{padding:1.5rem;flex:1}.page-title{font-size:1.5rem;font-weight:700;color:#1a1a2e;margin-bottom:1rem}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.text-muted{color:#888;font-size:.9rem}.text-center{text-align:center;color:#999;padding:1rem}.font-mono{font-family:SF Mono,Consolas,Monaco,monospace;font-size:.88em}.card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #00000014;padding:1.25rem;margin-bottom:1rem}.card h3{font-size:1.05rem;margin-bottom:.75rem;color:#1a1a2e}.stat-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.stat-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #00000014;padding:1.25rem;border-top:3px solid #4a90d9;text-align:center}.stat-value{font-size:2rem;font-weight:700;color:#1a1a2e;line-height:1.2}.stat-label{font-size:.82rem;color:#888;margin-top:.25rem;text-transform:uppercase;letter-spacing:.03em}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.detail-list{display:grid;grid-template-columns:140px 1fr;gap:.35rem .75rem;font-size:.92rem}.detail-list dt{color:#888;font-weight:500}.detail-list dd{color:#333}.table-wrap{overflow-x:auto;background:#fff;border-radius:8px;box-shadow:0 1px 3px #00000014}.table{width:100%;border-collapse:collapse;font-size:.88rem}.table thead{background:#f8f9fa}.table th{padding:.65rem .75rem;text-align:left;font-weight:600;color:#555;border-bottom:2px solid #e9ecef;white-space:nowrap}.table td{padding:.55rem .75rem;border-bottom:1px solid #f0f0f0;color:#444}.table tbody tr:nth-child(2n){background:#fafafa}.table tbody tr:hover{background:#f0f4ff}.clickable-row{cursor:pointer}.json-cell pre{font-size:.78rem;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:pre-wrap;word-break:break-all;margin:0}.status-badge{display:inline-block;padding:.15rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;background:#e0e0e0;color:#555}.status-aging{background:#dbeafe;color:#1e40af}.status-ready{background:#d1fae5;color:#065f46}.status-reserved{background:#ffedd5;color:#9a3412}.status-bottled{background:#d1fae5;color:#166534}.status-closed{background:#e5e7eb;color:#6b7280}.status-on-hold,.status-on_hold,.status-damaged{background:#fee2e2;color:#991b1b}.status-sampling{background:#ede9fe;color:#5b21b6}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:6px;font-size:.88rem;font-weight:500;border:none;cursor:pointer;transition:background .15s,opacity .15s;text-decoration:none;white-space:nowrap;font-family:inherit;line-height:1.4}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#e63946;color:#fff}.btn-primary:hover:not(:disabled){background:#c62d3a}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#5a6268}.btn-success{background:#28a745;color:#fff}.btn-success:hover:not(:disabled){background:#218838}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background:#c82333}.btn-sm{padding:.25rem .6rem;font-size:.8rem}.btn-block{width:100%}.action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.form-group{margin-bottom:.85rem}.form-group label{display:block;font-weight:500;margin-bottom:.25rem;color:#555;font-size:.88rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.45rem .65rem;border:1px solid #d1d5db;border-radius:6px;font-size:.88rem;font-family:inherit;transition:border-color .15s;background:#fff;color:#333}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#e63946;box-shadow:0 0 0 2px #e6394626}.form-group textarea{min-height:70px;resize:vertical}.form-row{display:flex;gap:.75rem}.form-row .form-group{flex:1}.form-actions{display:flex;gap:.5rem;margin-top:1rem}.checkbox-group{display:flex;gap:1.25rem}.checkbox-group label{display:inline-flex;align-items:center;gap:.35rem;cursor:pointer}.checkbox-group input[type=checkbox]{width:auto}.filters{display:flex;gap:.65rem;margin-bottom:1rem;flex-wrap:wrap;align-items:center}.filters select,.filter-input,.filters input[type=date]{padding:.4rem .6rem;border:1px solid #d1d5db;border-radius:6px;font-size:.88rem;font-family:inherit;background:#fff;color:#333}.filter-input{min-width:200px}.tabs{display:flex;gap:0;border-bottom:2px solid #e5e7eb;margin-bottom:1rem}.tab{padding:.55rem 1.15rem;border:none;background:none;font-size:.88rem;font-weight:500;color:#888;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;font-family:inherit}.tab:hover{color:#555}.tab.active{color:#e63946;border-bottom-color:#e63946}.timeline{position:relative;padding-left:1.5rem}.timeline:before{content:"";position:absolute;left:.45rem;top:0;bottom:0;width:2px;background:#e5e7eb}.timeline-item{position:relative;padding-bottom:1.25rem;padding-left:.75rem}.timeline-item:before{content:"";position:absolute;left:-1.15rem;top:.35rem;width:8px;height:8px;border-radius:50%;background:#e63946}.timeline-date{font-size:.78rem;color:#888}.timeline-action{font-weight:600;color:#1a1a2e;font-size:.92rem}.timeline-desc{color:#555;font-size:.88rem}.timeline-user{font-size:.78rem;color:#aaa}.alert{padding:.65rem 1rem;border-radius:6px;margin-bottom:.85rem;font-size:.88rem}.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.alert-success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:10px;width:100%;max-width:520px;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb}.modal-header h3{font-size:1.1rem;color:#1a1a2e;margin:0}.modal-close{background:none;border:none;font-size:1.5rem;color:#999;cursor:pointer;padding:0;line-height:1}.modal-close:hover{color:#333}.modal-body{padding:1.25rem}.loading{text-align:center;padding:3rem;color:#888;font-size:1rem}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);padding:1rem}.login-card{background:#fff;border-radius:12px;padding:2.5rem;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:1.75rem}.login-logo{font-size:3rem;display:block;margin-bottom:.5rem}.login-header h1{font-size:1.5rem;color:#1a1a2e;margin-bottom:.25rem}.login-header p{color:#888;font-size:.88rem}@media (max-width: 768px){.sidebar{width:60px;min-width:60px}.sidebar-title,.nav-label{display:none}.sidebar-header{justify-content:center}.nav-item{justify-content:center;padding:.55rem;border-left:none}.main-area{margin-left:60px}.form-row{flex-direction:column;gap:0}.detail-grid{grid-template-columns:1fr}}
