.layout{min-height:100vh;display:flex;flex-direction:column}.layout-header{background:var(--surface);border-bottom:1px solid var(--border);padding:.75rem 1.5rem;display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.layout-brand{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:1.1rem}.layout-logo{font-size:1.5rem}.layout-logo-img{height:32px;width:auto;display:block;object-fit:contain}.layout-nav{display:flex;gap:.25rem;flex-wrap:wrap}.layout-nav a{padding:.5rem .85rem;border-radius:var(--radius);color:var(--text-muted);text-decoration:none;font-weight:500;font-size:.9rem}.layout-nav a:hover{color:var(--text);background:var(--surface-hover);text-decoration:none}.layout-nav a.active{color:var(--accent);background:#3b82f626;text-decoration:none}.layout-logout{margin-left:auto;background:transparent;color:var(--text-muted);font-size:.9rem}.layout-logout:hover{color:var(--danger)}.layout-main{flex:1;padding:1.5rem;max-width:1400px;margin:0 auto;width:100%}@media (max-width: 768px){.layout-header{flex-direction:column;align-items:stretch}.layout-nav{justify-content:flex-start}.layout-logout{margin-left:0}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:linear-gradient(135deg,var(--bg) 0%,#1a2332 50%,#0f1419 100%)}.login-center{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:2.5rem;width:100%;flex-wrap:wrap}.login-logo-wrap{display:flex;align-items:center;justify-content:center;max-width:320px;max-height:320px;flex-shrink:0}@media (max-width: 700px){.login-center{flex-direction:column;gap:1.5rem}}.login-logo{width:100%;height:auto;display:block;object-fit:contain}.login-card{width:100%;max-width:380px}.login-card h1{margin-top:0;margin-bottom:.25rem;font-size:1.5rem}.login-subtitle{color:var(--text-muted);margin-bottom:1.5rem;font-size:.95rem}.login-error{color:var(--danger);font-size:.9rem;margin:.5rem 0 0}.page-title{margin-top:0;margin-bottom:.25rem;font-size:1.5rem}.page-subtitle{color:var(--text-muted);margin-bottom:1.5rem;font-size:.95rem}.page-loading,.page-error{padding:2rem;text-align:center}.page-error{color:var(--danger)}.dashboard-actions{margin-bottom:1.5rem}.dashboard-actions-title{margin-top:0;margin-bottom:1rem;font-size:1.1rem}.dashboard-actions-grid a{text-decoration:none}.section-title{font-size:1rem;color:var(--text-muted);margin-bottom:.75rem}.dashboard-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem;margin-top:1.5rem}.chart-card{min-height:320px}.chart-card h3{margin-top:0;margin-bottom:1rem;font-size:1rem}.chart-card-wide{grid-column:1 / -1;max-width:600px}.no-data{color:var(--text-muted);padding:2rem;text-align:center}.link-name{font-weight:500;color:var(--accent);text-decoration:none}.link-name:hover{text-decoration:underline}.button-link{padding:.35rem .65rem;font-size:.85rem;background:var(--surface-hover);color:var(--text);border-radius:6px;text-decoration:none}.detail-header{margin-bottom:1rem}.back-link{display:inline-block;margin-bottom:.5rem;color:var(--text-muted);font-size:.9rem;text-decoration:none}.back-link:hover{color:var(--accent)}.employee-profile{margin-bottom:1.5rem}.profile-row{margin-bottom:1rem}.profile-row .label{display:block;font-size:.85rem;color:var(--text-muted);margin-bottom:.25rem}.tools-list{background:var(--bg);padding:.75rem;border-radius:6px;font-size:.9rem;white-space:pre-wrap;margin:0}.section-title{font-size:1rem;margin-bottom:.75rem;color:var(--text-muted)}.actions-buttons .button-link,.actions-buttons .danger{flex-shrink:0}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.modal-wide{max-width:560px}.modal.modal-equipment-batch{max-height:90vh;overflow-y:auto}.equipment-create-block{padding:1rem 0;border-bottom:1px solid var(--border);margin-bottom:0}.equipment-create-block:first-child{padding-top:0}.equipment-create-block-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;gap:.5rem}.equipment-create-block-title{font-weight:600;color:var(--text);font-size:.95rem}.equipment-add-row{padding:1rem 0 0;margin-top:.5rem}.equipment-add-row button{width:100%;justify-content:center}.equipment-batch-assign .form-hint{display:block;margin-top:.25rem;font-size:.8rem;color:var(--text-muted)}@media (max-width: 600px){.form-row{grid-template-columns:1fr}}.detail-header{margin-bottom:1.5rem}.back-link{display:inline-block;margin-bottom:.5rem;color:var(--accent);text-decoration:none;font-size:.9rem}.back-link:hover{text-decoration:underline}.equipment-profile .profile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.profile-row{display:flex;flex-direction:column;gap:.25rem}.profile-row .label{font-size:.8rem;color:var(--text-muted)}.used-by-card .used-by-summary{margin:0 0 .75rem}.used-by-list{margin:0;padding-left:1.5rem;columns:2;column-gap:2rem}.used-by-list li{margin-bottom:.25rem}.section-title{margin:1.5rem 0 .75rem;font-size:1.1rem}.section-title:first-of-type{margin-top:0}.cell-clip{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 600px){.used-by-list{columns:1}}.modal form{display:flex;flex-direction:column;gap:0}.modal .form-group{margin-bottom:1rem}.modal .form-group:last-of-type{margin-bottom:0}.modal .form-group label{display:block;margin-bottom:.35rem;font-weight:500;color:var(--text-muted);font-size:.9rem}.modal .form-group input,.modal .form-group select,.modal .form-group textarea{width:100%;min-height:2.5rem;padding:.5rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.95rem;font-family:inherit;box-sizing:border-box}.modal .form-group textarea{min-height:4rem;resize:vertical}.modal .form-group input[type=file]{min-height:auto;padding:.5rem 0;font-size:.9rem}.modal .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.modal .form-row .form-group{margin-bottom:0;min-width:0}@media (max-width: 520px){.modal .form-row{grid-template-columns:1fr}}.cell-clip{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-block;vertical-align:middle}.cell-expanded{white-space:normal;word-break:break-word;max-width:360px;display:inline-block;vertical-align:middle}.repair-expand-btn{margin-left:.5rem;padding:.2rem .5rem;font-size:.8rem;background:var(--surface-hover);border:1px solid var(--border);border-radius:4px;color:var(--text);cursor:pointer;white-space:nowrap;vertical-align:middle}.repair-expand-btn:hover{background:var(--border)}.modal-photos{max-width:95vw;max-height:90vh;overflow:auto;width:100%}.photos-viewer-hint{margin:-.5rem 0 1rem;font-size:.9rem;color:var(--text-muted)}.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;margin:1rem 0}.photo-wrap{background:var(--surface-hover);border-radius:8px;overflow:hidden;aspect-ratio:4/3;min-height:200px}.photo-wrap img{width:100%;height:100%;object-fit:contain;display:block}.photo-wrap.photo-clickable{border:none;padding:0;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.photo-wrap.photo-clickable:hover{transform:scale(1.02);box-shadow:0 4px 12px #0000004d}.photo-error{display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.9rem}.photo-lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;z-index:1100;display:flex;align-items:center;justify-content:center;padding:1rem}.photo-lightbox-content{position:relative;max-width:95vw;max-height:95vh;display:flex;flex-direction:column;align-items:center;gap:1rem}.photo-lightbox-close{position:absolute;top:-.5rem;right:-.5rem;width:2.5rem;height:2.5rem;border:none;border-radius:50%;background:var(--surface);color:var(--text);font-size:1.5rem;line-height:1;cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center;padding:0;transition:background .15s}.photo-lightbox-close:hover{background:var(--surface-hover)}.photo-lightbox-zoom-controls{display:flex;align-items:center;gap:.75rem}.photo-lightbox-zoom-label{min-width:4rem;text-align:center;font-size:.9rem;color:var(--text-muted)}.photo-lightbox-image-wrap{overflow:auto;max-width:90vw;max-height:70vh;display:flex;align-items:center;justify-content:center;transform-origin:center center}.photo-lightbox-image-wrap img{max-width:100%;max-height:70vh;width:auto;height:auto;object-fit:contain;display:block}.photo-lightbox-nav{display:flex;align-items:center;justify-content:center;gap:1.5rem}.photo-lightbox-counter{font-size:.95rem;color:var(--text-muted)}.form-hint{display:block;margin-top:.25rem;font-size:.8rem;color:var(--text-muted)}.actions-cell{white-space:nowrap}.actions-buttons{display:flex;flex-wrap:nowrap;align-items:center;gap:.5rem}.cell-clip{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-form{margin-bottom:1.5rem}.search-form .search-bar{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end}.results-count{margin:0 0 1rem;font-size:.9rem;color:var(--text-muted)}.employee-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem}.employee-card{display:flex;flex-direction:column}.employee-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.employee-card-name{font-weight:600;font-size:1.1rem;color:var(--accent);text-decoration:none}.employee-card-name:hover{text-decoration:underline}.employee-card-count{font-size:.85rem;color:var(--text-muted);background:var(--bg);padding:.25rem .5rem;border-radius:6px}.employee-card-tools-text{font-size:.9rem;color:var(--text-muted);margin:0 0 .75rem;white-space:pre-wrap}.employee-equipment-list{list-style:none;margin:0;padding:0}.employee-equipment-list li{display:flex;align-items:center;gap:.5rem;padding:.4rem 0;border-bottom:1px solid var(--border);font-size:.9rem}.employee-equipment-list li:last-child{border-bottom:none}.eq-serial{font-weight:500;min-width:80px}.eq-type{color:var(--text-muted);font-size:.85rem;min-width:70px}.eq-model{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.eq-link{font-size:.85rem}.no-equipment{color:var(--text-muted);font-size:.9rem;margin:0}.form-hint{margin:0 0 1rem;font-size:.9rem;color:var(--text-muted)}.toolbar{margin-bottom:1rem}.table-card{overflow-x:auto}.button-link{padding:.35rem .65rem;font-size:.85rem;background:var(--surface-hover);color:var(--text);border:none;border-radius:6px;cursor:pointer;text-decoration:none}.button-link:hover{background:var(--border)}.no-data{padding:2rem;text-align:center;color:var(--text-muted)}:root{--bg: #0f1419;--surface: #1a2332;--surface-hover: #243044;--border: #2d3a4f;--text: #e6edf3;--text-muted: #8b9cb3;--accent: #3b82f6;--accent-hover: #2563eb;--success: #22c55e;--warning: #eab308;--danger: #ef4444;--radius: 10px;--font: "DM Sans", system-ui, sans-serif}*{box-sizing:border-box}body{margin:0;font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5}#root{min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}input,select,textarea,button{font-family:inherit;font-size:.95rem}button{cursor:pointer;border:none;border-radius:var(--radius);padding:.5rem 1rem;font-weight:500;transition:background .15s,color .15s}button.primary{background:var(--accent);color:#fff}button.primary:hover{background:var(--accent-hover)}button.secondary{background:var(--surface-hover);color:var(--text)}button.secondary:hover{background:var(--border)}button.danger{background:var(--danger);color:#fff}button.danger:hover{filter:brightness(1.1)}.dashboard-action-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 1.5rem;font-size:1rem;min-height:52px;border-radius:var(--radius);font-weight:600;text-decoration:none;border:none;cursor:pointer;transition:transform .15s,box-shadow .15s}.dashboard-action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f659}.dashboard-action-btn.primary{background:var(--accent);color:#fff}.dashboard-action-btn.secondary{background:var(--surface-hover);color:var(--text);border:1px solid var(--border)}.dashboard-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}table{width:100%;border-collapse:collapse}th,td{padding:.65rem .85rem;text-align:left;border-bottom:1px solid var(--border)}th{font-weight:600;color:var(--text-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}tr:hover td{background:var(--surface-hover)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.35rem;font-weight:500;color:var(--text-muted);font-size:.9rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.5rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #3b82f633}.search-bar{display:flex;gap:.75rem;flex-wrap:nowrap;margin-bottom:1.25rem;align-items:stretch}.search-bar input,.search-bar select{flex:1 1 0;min-width:0;padding:.5rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);height:2.25rem;box-sizing:border-box}.search-bar input:focus,.search-bar select:focus{outline:none;border-color:var(--accent)}@media (max-width: 900px){.search-bar{flex-wrap:wrap}.search-bar input,.search-bar select{flex:1 1 140px}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);max-width:560px;width:100%;max-height:90vh;overflow-y:auto;padding:1.5rem}.modal h2{margin-top:0;margin-bottom:1.25rem;font-size:1.25rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border)}.tabs{display:flex;gap:.25rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border);overflow-x:auto}.tabs a{padding:.65rem 1rem;color:var(--text-muted);border-radius:var(--radius) var(--radius) 0 0;font-weight:500;white-space:nowrap}.tabs a:hover{color:var(--text);background:var(--surface-hover);text-decoration:none}.tabs a.active{color:var(--accent);background:var(--surface);border-bottom:2px solid var(--accent);margin-bottom:-1px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.stat-card .value{font-size:1.75rem;font-weight:700;color:var(--accent)}.stat-card .label{font-size:.85rem;color:var(--text-muted);margin-top:.25rem}
