.toast{position:fixed;top:20px;right:20px;min-width:280px;max-width:400px;padding:14px 18px;border-radius:12px;box-shadow:0 4px 16px #00000026;display:flex;align-items:center;gap:12px;font-size:15px;font-weight:500;z-index:9999;transition:opacity .3s ease,transform .3s ease}.toast-visible{opacity:1;transform:translateY(0)}.toast-hidden{opacity:0;transform:translateY(-10px)}.toast-icon{font-size:20px;line-height:1;flex-shrink:0}.toast-message{flex:1;line-height:1.4}.toast-success{background:#d9f7be;color:#256c1d;border-left:4px solid #52c41a}.toast-error{background:#ffd6d6;color:#a80000;border-left:4px solid #ff4d4f}.toast-warning{background:#fff1b8;color:#8a6d00;border-left:4px solid #faad14}.toast-info{background:#d6e4ff;color:#1034a6;border-left:4px solid #1890ff}@media (max-width: 640px){.toast{top:10px;right:10px;left:10px;max-width:none;min-width:auto}}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:#f4f7f9}.app-container{display:flex;flex-direction:column;min-height:100vh;width:100%;max-width:100%;margin:0 auto}.app-hero{background:linear-gradient(90deg,#1f46c6,#0b2e91);border-radius:12px;margin-top:16px;min-height:140px;padding:0}.hero-center{max-width:1000px;height:100%;margin:0 auto;padding:20px 16px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.app-title{margin:0;color:#fff;font-size:clamp(32px,5vw,56px);font-weight:800;letter-spacing:.5px;line-height:1.1}.app-subtitle{margin:8px 0 0;color:#fffffff2;font-size:clamp(14px,1.6vw,20px);font-weight:500;line-height:1.35}.authbar{margin:10px 0 12px;padding:10px 14px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:10px;display:flex;align-items:center;justify-content:space-between;gap:12px}.authbar__who{color:#0f172a;font-weight:600}.authbar__right{display:flex;align-items:center}.main-content{display:flex;flex-grow:1;padding:0 12px 30px;gap:24px;width:100%;max-width:1200px;margin:0 auto}.form-section{flex:0 0 380px;background-color:#fff;border-radius:12px;padding:25px;box-shadow:0 2px 10px #0000000d;width:100%;max-width:100%}.list-section{flex-grow:1;background-color:#fff;border-radius:12px;padding:0;box-shadow:0 2px 10px #0000000d;width:100%;max-width:100%;margin:0 auto}@media (max-width: 768px){.app-hero{border-radius:0;min-height:120px;margin:0 -12px;width:calc(100% + 24px)}.hero-center{max-width:100%;padding:16px 12px}.authbar{margin:8px 0 10px;padding:10px 12px}.main-content{flex-direction:column;max-width:100%;width:100%;gap:12px;display:block;box-sizing:border-box;padding:0}.form-section{display:none!important}.list-section{padding:0;border-radius:0;box-shadow:none;background:transparent;box-sizing:border-box;width:100%;max-width:100%!important;margin:0}.list-wrap,.filters,.cards{width:100%!important;max-width:100%!important;padding:0!important;margin:0!important;box-sizing:border-box!important}}@media (max-width: 1024px){.form-section.only-desktop{display:none!important}}@media (max-width: 360px){.app-title{font-size:24px}.app-subtitle{font-size:13px}}*,*:before,*:after{box-sizing:border-box}html,body{width:100%;overflow-x:hidden}img,video{max-width:100%;height:auto;display:block}.app-container{max-width:clamp(320px,100vw,1440px);margin:0 auto;padding:16px clamp(12px,4vw,24px) 48px}.app-content-line{max-width:1200px;margin:0 auto;width:100%;padding:0 16px;box-sizing:border-box}.app-grid{display:grid;grid-template-columns:minmax(220px,300px) 1fr;gap:28px;align-items:start}.app-grid>*{min-width:0}.form-section{display:flex;flex-direction:column}.form-section .rf-screen{flex:1;display:flex;flex-direction:column}.form-section .rf-body{flex:1}.form-section .rf-footer{margin-top:12px}.right-pane{display:grid;grid-auto-rows:min-content;gap:14px;min-width:0;max-width:100%}.list-wrap{width:100%;max-width:min(1000px,100%);margin:0;min-width:0}.cards{display:grid;grid-template-columns:1fr;gap:14px;min-width:0}.mc-card{padding:14px 16px;width:100%;max-width:100%;overflow:hidden}.mc-card__row{display:flex;gap:8px;flex-wrap:wrap;min-width:0}.mc-card__title,.mc-card__value{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mc-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.mc-badges{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:8px}.mc-status-badge.recall{background:#fee2e2;color:#b91c1c;border-color:#fecdd3}.calendar-item{padding:10px 12px;max-width:100%}.react-datepicker .MuiPickersDay-root,.MuiPickersDay-root{font-weight:700!important;font-size:1.0625rem!important}.MuiDialog-root .MuiClockPicker-root{transform:scale(1.1)}.MuiDialog-root .MuiDialog-paper{padding:20px}.filters,.tabs{display:flex;gap:8px;flex-wrap:wrap;min-width:0}.filters__chip,.tab{padding:10px 12px;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-actions{display:flex;gap:8px;flex-wrap:wrap;min-width:0}.card-actions .btn{flex:1 1 auto;min-width:120px;max-width:100%}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:36px;padding:0 14px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;color:#111827;font-size:14px;line-height:1;cursor:pointer;text-decoration:none;transition:background-color .12s ease,box-shadow .12s ease,transform .05s ease,color .12s ease,border-color .12s ease}.btn:hover{background:#f8fafc;box-shadow:0 2px 8px #0000000d}.btn:active{transform:translateY(1px)}.btn-group{display:inline-flex;gap:8px}.btn-active{background:#eef2ff;border-color:#c7d2fe;color:#1e40af}.toolbar-metrics{margin:12px 0 14px;padding:14px 18px;border:1px solid #e5e7eb;border-radius:14px;background:#fafafa;display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:space-between}.toolbar-metrics .metrics-text{font-size:15px;line-height:1.5;display:flex;flex-direction:column;gap:4px}.toolbar-metrics .metrics-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.toolbar-metrics .btn{padding:0 12px;height:34px}.authbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:8px 0 12px;padding:10px 12px;border:1px solid #eee;border-radius:10px;background:#fff}@media (min-width: 1024px){.toolbar-metrics{padding:16px 20px}.toolbar-metrics .metrics-text{font-size:17px}}@media (min-width: 1440px){.app-content-line{max-width:1200px}.toolbar-metrics .metrics-text{font-size:18px}}@media (max-width: 640px){.app-container{padding:0 12px 24px;width:100%;max-width:100%;box-sizing:border-box}.app-content-line{padding:0 12px;width:100%;max-width:100%;margin:0;box-sizing:border-box}.toolbar-metrics{margin:10px 0;padding:10px 12px}.toolbar-metrics .metrics-text{font-size:14px}.btn{height:34px;padding:0 12px;font-size:13px}}.fab-add{position:fixed;right:16px;bottom:16px;width:64px;height:64px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#1e88e5!important;color:#fff!important;font-size:44px;line-height:1;font-weight:700;border:none;outline:none;cursor:pointer;box-shadow:0 12px 26px #00000047;z-index:1000;-webkit-tap-highlight-color:transparent}.fab-add:active{transform:translateY(1px);box-shadow:0 10px 22px #0000003d}@media (min-width: 768px){.fab-add{display:none}}.rf-footer{position:sticky;bottom:0;background:#fff;border-top:1px solid #eee;padding:12px 0 0}.rf__submit{width:100%;height:44px;font-size:16px;border-radius:12px}.rf-body{padding-bottom:72px}.login-panel{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.login-role{font-size:12px;opacity:.8}.login-form{display:flex;gap:8px;align-items:center}.login-input{padding:10px 12px;height:44px;font-size:16px}.login-submit{height:46px;font-size:16px}.login-error{color:#dc2626;font-size:12px}@media (max-width: 768px){.login-form{flex-direction:column;width:100%;max-width:420px;margin:0 auto;align-items:stretch}.login-submit{width:100%}}@media (max-width: 900px){.app-grid{display:block!important;grid-template-columns:1fr!important;gap:0!important}.right-pane{max-width:100%!important;width:100%!important}.app-container .list-section,.app-container .list-wrap,.app-container .filters,.app-container .cards,.app-container .main-content{width:100%!important;max-width:100%!important;margin:0!important;padding:0!important;box-sizing:border-box!important}.list-wrap{max-width:100%!important}}.rf-screen{height:auto;display:flex;flex-direction:column;gap:10px;padding:14px;border-radius:12px;background:#fff;box-shadow:0 1px 3px #1018280f,0 1px 2px #10182808}.rf__title{margin:2px 0 6px;font-size:24px;line-height:1.2}.rf-body{flex:0 0 auto;display:flex;flex-direction:column;gap:10px;padding:2px 0}.rf__field{display:flex;flex-direction:column;gap:6px}.rf__label{font-size:14px;color:#111827}.rf__input{width:100%;height:38px;padding:8px 12px;background:#fff;color:#000;border:1px solid #e5e7eb;border-radius:10px;outline:none}.rf__input::placeholder{color:#9ca3af}.rf__textarea{height:auto;min-height:64px;resize:vertical}.rf__hint{color:#6b7280;font-size:12px}.error{color:#b00020;font-size:13px}.rf-footer{margin-top:12px;position:static;background:transparent;border-top:none;padding:0}.rf__submit{width:100%;height:44px;border-radius:12px;background:linear-gradient(135deg,#0950d8,#0b3aa0);color:#fff;font-weight:600;border:none;cursor:pointer}.rf__submit:disabled{opacity:.7;cursor:not-allowed}.rf__cancel{width:100%;height:40px;border-radius:10px;background:#f3f4f6;color:#111827;border:1px solid #e5e7eb;margin-top:8px;cursor:pointer}.rf__cancel:hover{background:#eef2ff}.modal-fullscreen{height:100vh;max-height:100vh;overflow:hidden;display:flex;flex-direction:column}.modal-fullscreen .rf-screen,.modal-fullscreen .rf{height:100%;max-height:100%;padding:12px;gap:8px;box-shadow:none;border-radius:0}.modal-fullscreen .rf-body{flex:0 0 auto;gap:8px;padding:0;overflow:hidden}.modal-fullscreen .rf__title{font-size:20px;margin:0 0 6px}.modal-fullscreen .rf__input{height:34px;padding:6px 10px}.modal-fullscreen .rf__textarea{min-height:50px;resize:none}.modal-fullscreen .rf-footer{margin-top:6px}.modal-fullscreen .rf__submit{height:42px;border-radius:10px}@media (max-width: 480px){.modal-fullscreen{height:100vh;max-height:100vh}}.rf-body{padding-bottom:0}.mc-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #1018280f,0 1px 2px #10182808;padding:16px 18px;width:100%;max-width:100%;overflow:hidden;box-sizing:border-box}.mc-header{display:flex;align-items:flex-start;justify-content:space-between;min-width:0;gap:10px}.mc-title{font-size:18px;font-weight:700;color:#0f172a;margin-bottom:10px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mc-badges{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.mc-status-badge{padding:6px 10px;border-radius:999px;font-size:13px;font-weight:600;color:#683232;background:#ffe4e6;box-shadow:inset 0 0 0 2px #00000008}.mc-status-badge.assigned{background:#fff3bf;color:#5f4e00}.mc-status-badge.measured{background:#dbeafe;color:#1e3a8a}.mc-status-badge.tz_sent{background:#eaffd1;color:#164e1f}.mc-status-badge.done{background:#f3f4f6;color:#374151}.mc-status-badge.unknown{background:#eef2ff;color:#1f3a8a}.mc-status-badge.returned{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.mc-status-badge.recall{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.mc-body{margin-top:8px;display:grid;gap:6px;font-size:15px;line-height:1.45;color:#1f2937;min-width:0}.mc-actions{margin-top:14px;display:grid;grid-template-columns:max-content 1fr max-content;gap:12px;align-items:center;min-width:0}.btn-outline{background:#fff;color:#0f172a;border:1px solid #e5e7eb;border-radius:10px;padding:10px 16px;box-shadow:0 1px 2px #1018280f;cursor:pointer}.btn-outline:hover{box-shadow:0 2px 6px #1018281a}.assign-input{height:40px;border:1px solid #e5e7eb;border-radius:10px;padding:0 12px;color:#111827;background:#fff;width:100%;max-width:100%;box-sizing:border-box}.btn-blue{background:#1e3a8a;color:#fff;border:none;border-radius:10px;padding:10px 16px;cursor:pointer;box-shadow:0 1px 2px #1018280f}.btn-blue:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 480px){.mc-header{flex-direction:column;align-items:flex-start}.mc-badges{margin-top:6px}.mc-actions{grid-template-columns:1fr}.btn-outline,.btn-blue{width:100%}.mc-card{width:100%;max-width:100%;margin:0;border-radius:10px}}.om-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:10000}.om-modal{position:relative;width:min(600px,92vw);max-height:92vh;background:#fff;border:1px solid #e5e7eb;border-radius:14px;box-shadow:0 30px 80px #00000047;display:flex;flex-direction:column;overflow:hidden}.om-header{display:flex;align-items:center;padding:14px 18px;border-bottom:1px solid #e5e7eb;flex:0 0 auto}.om-title-lg,.om-title{margin:0;font-weight:800;letter-spacing:.2px}.om-title-lg{font-size:28px}.om-title{font-size:20px}.om-body{flex:1 1 auto;min-height:0;padding:18px 20px;overflow:auto;font-weight:500}.kv-row{display:grid;grid-template-columns:28px 160px 1fr;align-items:start;gap:8px 12px;padding:8px 0}.kv-ico{width:28px;text-align:center;font-size:20px;line-height:1.2}.kv-key{color:#374151;font-weight:700}.kv-val{color:#0f172a;font-weight:600}.kv-name{font-weight:800;font-size:1.1875rem;line-height:1.25}.kv-row.client .kv-val{font-weight:800}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.form-grid{display:grid;grid-template-columns:1fr;gap:12px}.form-grid label{font-weight:500;color:#111;display:flex;flex-direction:column;gap:6px}.form-grid input,.form-grid textarea,.form-grid select{background:#fff;color:#000;caret-color:#000;border:1px solid #e5e7eb;border-radius:8px;padding:12px;width:100%;max-width:100%;box-sizing:border-box}.form-grid input:focus,.form-grid textarea:focus,.form-grid select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26;outline:none}.modal-actions-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:16px 20px;border-top:1px solid #f1f5f9;background:#fff;position:sticky;bottom:0;flex:0 0 auto;z-index:1}.modal-actions-row .btn-left,.modal-actions-row .btn-right{display:flex;gap:10px}.btn-primary{background:#1e3a8a;color:#fff;border:0;padding:10px 20px;border-radius:10px;font-weight:600;font-size:14px;cursor:pointer;min-width:110px;text-align:center;white-space:nowrap}.btn-secondary{background:#f3f4f6;color:#111827;border:0;padding:10px 20px;border-radius:10px;font-weight:600;font-size:14px;cursor:pointer;min-width:110px;text-align:center;white-space:nowrap}.recall-card{grid-column:1 / -1;border:1px dashed #d1d5db;border-radius:10px;padding:10px 12px;background:#f9fafb;display:flex;flex-direction:column;gap:8px}.recall-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.recall-actions{display:flex;gap:8px;flex-wrap:wrap}.details{display:flex;flex-direction:column;gap:10px}.row{display:flex;gap:10px;align-items:flex-start;line-height:1.55}@media (max-width: 600px){.om-modal{width:96vw;max-height:94vh}.form-grid{grid-template-columns:1fr}.kv-row{grid-template-columns:24px 110px 1fr}.kv-name{font-size:1.125rem}.modal-actions-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:16px 20px}.modal-actions-row .btn-left,.modal-actions-row .btn-right{display:contents}.modal-actions-row button{width:100%;min-width:0;padding:12px 16px;font-size:14px;text-align:center}}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{border:1px solid #e5e7eb;border-radius:12px;padding:16px;background:#fff}.skeleton-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.skeleton-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:16px}@media (prefers-color-scheme: dark){.skeleton{background:linear-gradient(90deg,#2a2a2a 25%,#1a1a1a,#2a2a2a 75%);background-size:200% 100%}.skeleton-card{background:#1f1f1f;border-color:#3a3a3a}}.filters{display:flex;flex-direction:column;gap:12px;width:100%;box-sizing:border-box;padding:14px 16px;background:#fff;border:1px solid #e5e7eb;border-radius:14px;box-shadow:0 6px 18px #0000000d}.filters-top{display:flex;align-items:center;gap:12px;width:100%;flex-wrap:wrap;padding:0}.filters-actions button.active{font-weight:600;background:#eef2ff;border-color:#c7d2fe;color:#1e40af}.status-row{display:flex;flex-wrap:wrap;gap:10px;margin:8px 0 12px;align-items:center;justify-content:flex-start}.stat-btn{border:1px solid transparent;border-radius:12px;padding:6px 10px;font-weight:600;background:#fff;color:#111;transition:all .15s ease;font-size:14px;min-width:110px}.stat-btn.red{background:#ffe1e1;border-color:#f5bcbc;color:#7f1d1d}.stat-btn.yellow{background:#fff5cc;border-color:#ffe59a;color:#7a5a00}.stat-btn.blue{background:#e6efff;border-color:#c9defe;color:#1e3a8a}.stat-btn.green{background:#e8f8e3;border-color:#c8efbe;color:#1b6b2a}.stat-btn.gray{background:#f3f4f6;border-color:#e5e7eb;color:#374151}.stat-btn:hover{filter:brightness(.98);box-shadow:0 2px 8px #0000000f}.stat-btn.active{box-shadow:0 0 0 3px #2563eb2e}.stat-reset{margin-left:auto;border:1px solid #111;background:#fff;color:#111;padding:10px 14px;border-radius:12px}.search-input{background:#fff;color:#000;caret-color:#000;border:1px solid #ddd;border-radius:6px;padding:8px;width:100%}@media (max-width: 768px){.filters{padding:12px;border-radius:12px}.status-row{justify-content:center;gap:8px}.filters-top{gap:10px;justify-content:center}.filters-actions{width:100%;justify-content:center}.filters-actions button{min-width:120px}}.list-wrap{display:flex;flex-direction:column;gap:12px;width:100%;box-sizing:border-box;padding:0;margin:0}.cards>*{width:100%}.hint{margin:8px 0}.calendar-stub{border:1px solid #eee;padding:12px;border-radius:8px}.calendar-item{padding:8px;margin:6px 0;border-radius:6px;cursor:pointer}@media (max-width: 768px){.list-wrap{width:100%!important;max-width:100%!important;margin:0 auto!important;padding:0!important;box-sizing:border-box!important}}.calendar-head{display:flex;align-items:center;gap:16px;margin:8px 0 12px}.calendar-head h2{margin:0;font-size:20px}.calendar-head .legend{margin-left:auto;display:flex;gap:12px;flex-wrap:wrap;font-size:13px;color:#374151}.calendar-head .legend span{display:inline-flex;align-items:center;gap:6px}.calendar-head .legend i{display:inline-block;width:14px;height:14px;border-radius:4px;background:#e5e7eb}.legend{display:flex;gap:12px;flex-wrap:wrap;margin:6px 0 12px;color:#374151;font-size:13px}.legend span{display:inline-flex;align-items:center;gap:6px}.legend i{display:inline-block;width:14px;height:14px;border-radius:4px;background:#e5e7eb}.calendar-metrics{margin:12px 0 10px;padding:12px 14px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;font-size:16px;display:flex;align-items:center;flex-wrap:wrap;gap:8px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;width:100%;max-width:100%;box-sizing:border-box}.calendar-colhead{text-align:center;font-weight:600;color:#374151;padding:6px 0}.calendar-cell{border:1px solid #e5e7eb;border-radius:10px;background:#fff;min-height:110px;padding:8px;display:flex;flex-direction:column;transition:box-shadow .12s ease,transform .05s ease;position:relative;overflow:hidden}.calendar-cell:hover{box-shadow:0 2px 10px #0000000f}.calendar-cell:active{transform:translateY(1px)}.calendar-cell.muted{opacity:.55}.cell-top{display:flex;align-items:center;gap:8px}.cell-day{font-weight:700;font-size:15px;color:#111827}.cell-day.today{color:#1e88e5}.cell-count{color:#111827;min-width:28px;height:24px;border-radius:999px;padding:0 8px;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;border:1px solid #e5e7eb;background:#e5e7eb}.cell-meta{margin-top:6px;font-size:12px;color:#6b7280}.cell-overdue{position:absolute;left:0;right:0;bottom:0;height:34%;background:linear-gradient(180deg,#ef444400,#ef4444d9 65%);pointer-events:none;border-radius:0 0 10px 10px}.calendar-head .btn{padding:8px 14px;font-size:14px;line-height:1.2}@media (max-width: 640px){.calendar-head{gap:12px;flex-wrap:wrap}.calendar-head h2{font-size:18px}.legend{flex-wrap:wrap}.calendar-grid{gap:4px;grid-template-columns:repeat(7,minmax(0,1fr));overflow-x:hidden}.calendar-cell{min-height:78px;padding:6px}.cell-count{min-width:24px;height:22px;font-size:12px}}@media (min-width: 1024px){.calendar-head h2{font-size:22px}}.admin-page{max-width:1400px;margin:0 auto;padding:24px}.admin-header{margin-bottom:24px;display:flex;justify-content:space-between;align-items:center}.admin-header h1{font-size:28px;font-weight:700;color:#111827;margin:0}.admin-tabs{display:flex;gap:8px;border-bottom:2px solid #e5e7eb;margin-bottom:32px}.tab,.tab-active{padding:12px 20px;font-size:15px;font-weight:600;border:none;background:transparent;color:#6b7280;cursor:pointer;border-bottom:3px solid transparent;transition:all .2s;position:relative;top:2px}.tab:hover{color:#1e88e5}.tab-active{color:#1e88e5;border-bottom-color:#1e88e5}.admin-content{min-height:400px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:32px}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;text-align:center;box-shadow:0 1px 3px #0000000d}.stat-value{font-size:32px;font-weight:700;color:#1e88e5;margin-bottom:8px}.stat-label{font-size:14px;color:#6b7280;font-weight:500}.section-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:24px}@media (max-width: 968px){.section-row{grid-template-columns:1fr}}.section-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000000d}.section-card h3{font-size:18px;font-weight:700;color:#111827;margin:0 0 16px}.section-card h4{font-size:16px;font-weight:600;color:#374151;margin:16px 0 12px}.empty-state{text-align:center;color:#9ca3af;padding:32px;font-size:15px}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table th{text-align:left;padding:12px;background:#f9fafb;color:#374151;font-weight:600;border-bottom:2px solid #e5e7eb}.data-table td{padding:12px;border-bottom:1px solid #e5e7eb;color:#111827}.data-table tbody tr:hover{background:#f9fafb}.violation-list{display:flex;flex-direction:column;gap:12px}.violation-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;font-size:14px}.violation-age{font-weight:700;color:#dc2626;font-size:13px}.users-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.section-header h2{font-size:20px;font-weight:700;color:#111827;margin:0}.role-select{padding:6px 10px;border:1px solid #d1d5db;border-radius:6px;background:#fff;font-size:14px;cursor:pointer}.btn-danger-sm{padding:6px 12px;background:#fee2e2;color:#991b1b;border:1px solid #fca5a5;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.btn-danger-sm:hover{background:#fecaca}.settings-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px}.settings-section h2{font-size:20px;font-weight:700;color:#111827;margin:0 0 24px}.settings-form{display:flex;flex-direction:column;gap:24px;max-width:600px}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px}.setting-item label{flex:1}.setting-item strong{display:block;font-size:15px;color:#111827;margin-bottom:4px}.setting-desc{font-size:13px;color:#6b7280;margin:0}.setting-item input{width:100px;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:15px;text-align:center}.reports-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px}.reports-section h2{font-size:20px;font-weight:700;color:#111827;margin:0 0 24px}.report-actions{display:flex;gap:12px}.foreman-report{margin-bottom:24px}.bulk-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px}.bulk-section h2{font-size:20px;font-weight:700;color:#111827;margin:0 0 24px}.bulk-controls{display:flex;gap:12px;margin-bottom:24px;align-items:center}.bulk-select{flex:1;padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:15px;background:#fff;cursor:pointer}.bulk-list{display:flex;flex-direction:column;gap:8px;max-height:600px;overflow-y:auto}.bulk-item{display:flex;align-items:center;gap:12px;padding:12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;transition:all .2s}.bulk-item:hover{background:#f3f4f6}.bulk-item input[type=checkbox]{width:18px;height:18px;cursor:pointer}.bulk-item-content{flex:1;display:flex;justify-content:space-between;align-items:center;font-size:14px;gap:12px}.status-badge{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase;white-space:nowrap;flex-shrink:0}.status-new{background:#dbeafe;color:#1e40af}.status-assigned{background:#fef3c7;color:#92400e}.status-measured{background:#e0e7ff;color:#3730a3}.status-tz_sent{background:#ddd6fe;color:#5b21b6}.status-done{background:#d1fae5;color:#065f46}.status-spec_sent,.status-unknown{background:#fee2e2;color:#991b1b;text-transform:none}.btn-primary{padding:10px 20px;background:#1e88e5;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #1e88e54d}.btn-primary:hover{background:#1565c0;box-shadow:0 4px 12px #1e88e566}.btn-primary:disabled{background:#9ca3af;cursor:not-allowed;box-shadow:none}.btn-secondary{padding:10px 20px;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#f3f4f6}.history-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px}.history-section h2{font-size:20px;font-weight:700;color:#111827;margin:0 0 24px}.history-filters{display:flex;gap:12px;margin-bottom:24px;align-items:center;flex-wrap:wrap}.filter-input{flex:1;min-width:200px;padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:15px;background:#fff}.filter-input::placeholder{color:#9ca3af}.filter-select{padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:15px;background:#fff;cursor:pointer;min-width:150px}.filter-count{font-size:14px;color:#6b7280;font-weight:600}.history-content{display:grid;grid-template-columns:1fr;gap:16px}.history-list{display:flex;flex-direction:column;gap:8px;max-height:800px;overflow-y:auto}.history-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;cursor:pointer;transition:all .2s}.history-item:hover{background:#f3f4f6;border-color:#d1d5db}.history-item.selected{background:#eff6ff;border-color:#1e88e5}.history-item-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.history-item-main{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.history-item-main strong{font-size:15px;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-item-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.history-item-meta small{font-size:12px;color:#9ca3af}.history-item-details{display:flex;flex-direction:column;gap:10px;margin-top:16px;padding-top:16px;border-top:1px solid #e5e7eb}.detail-row{display:grid;grid-template-columns:150px 1fr;gap:12px;font-size:14px;padding:8px;background:#fff;border-radius:6px}.detail-label{font-weight:600;color:#374151}.detail-value{color:#111827;word-break:break-word}@media (max-width: 768px){.history-filters{flex-direction:column}.filter-input,.filter-select{min-width:100%}.history-item-header{flex-direction:column;align-items:flex-start}.history-item-meta{align-items:flex-start}.detail-row{grid-template-columns:1fr}.detail-label:after{content:":"}}
