*{margin:0;padding:0;box-sizing:border-box;font-family:Tajawal,Segoe UI,Tahoma,Arial,sans-serif;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}html{overscroll-behavior:none}:root{--primary: #1e3a5f;--primary-dark: #0a1628;--accent: #00b4d8;--success: #00b894;--warning: #fdcb6e;--danger: #e17055;--bg: #0a1628;--card-bg: rgba(255,255,255,.05);--text: #ffffff;--text-muted: rgba(255,255,255,.6);--bg-primary: #081a31;--bg-secondary: #0f2b4d;--surface: rgba(255,255,255,.08);--surface-strong: rgba(255,255,255,.12);--text-primary: #f2f7ff;--accent-hover: #0da9c8;--radius-lg: 18px;--radius-md: 12px;--shadow-card: 0 20px 50px rgba(0,0,0,.35);--text-secondary: rgba(255,255,255,.6);--border-color: rgba(255,255,255,.12);--border-default: rgba(255,255,255,.12);--border-light: rgba(255,255,255,.08);--shadow-sm: 0 2px 8px rgba(0,0,0,.2);--shadow-md: 0 8px 24px rgba(0,0,0,.3);--shadow-lg: 0 16px 40px rgba(0,0,0,.4);--shadow-glow-accent: 0 4px 15px rgba(0,180,216,.3);--radius-sm: 10px;--radius-xl: 20px;--radius-pill: 25px;--transition-fast: .15s ease;--transition-normal: .25s ease;--btn-primary: linear-gradient(135deg, #1e3a5f 0%, #2a5a8f 100%);--btn-primary-hover: linear-gradient(135deg, #244570 0%, #3268a0 100%);--btn-primary-flat: #2a4f7a;--btn-cancel: #4a5568;--z-base: 1;--z-card: 10;--z-sticky: 100;--z-nav: 200;--z-dropdown: 1000;--z-modal-backdrop: 2000;--z-modal: 2500;--z-toast: 3000;--z-tooltip: 3500;--z-overlay: 9999}h1,h2,h3{font-weight:700;line-height:1.3;color:var(--text)}h1{font-size:1.3rem}h2{font-size:1.1rem}h3{font-size:.95rem}[data-theme=light]{--primary: #4a90c4;--primary-dark: #e8ecf1;--bg: #f0f2f5;--card-bg: rgba(255,255,255,.85);--text: #1a1a2e;--text-muted: rgba(0,0,0,.55);--bg-primary: #e8ecf1;--bg-secondary: #dde3ea;--surface: rgba(0,0,0,.04);--surface-strong: rgba(0,0,0,.08);--text-primary: #1a1a2e;--text-secondary: rgba(0,0,0,.6);--border-color: rgba(0,0,0,.12);--border-default: rgba(0,0,0,.1);--border-light: rgba(0,0,0,.06);--shadow-card: 0 8px 30px rgba(0,0,0,.1);--shadow-sm: 0 2px 8px rgba(0,0,0,.08);--shadow-md: 0 4px 16px rgba(0,0,0,.1);--shadow-lg: 0 8px 30px rgba(0,0,0,.15);--shadow-glow-accent: 0 4px 15px rgba(0,180,216,.2)}body{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);min-height:100vh;min-height:100dvh;color:var(--text);padding-bottom:calc(70px + env(safe-area-inset-bottom,0px));max-width:430px;margin:0 auto;box-shadow:0 0 50px #00000080;-webkit-overflow-scrolling:touch;overscroll-behavior-y:none}@media(max-width:600px){body{max-width:100%;box-shadow:none}.stats-grid{gap:8px;padding:8px}.stat-card{padding:10px 6px}.stat-card .icon{font-size:1.3rem;margin-bottom:3px}.stat-card .number{font-size:1.2rem;margin-bottom:2px}.stat-card .label{font-size:.75rem}.filter-buttons{gap:5px;padding:0 10px 10px}.filter-btn{padding:6px 10px;font-size:.78rem}.section-header{padding:0 10px 8px;flex-wrap:wrap;gap:8px}.section-header h2{font-size:1rem}.add-btn{padding:7px 12px;font-size:.8rem}.search-container{padding:0 10px 10px}.tab-btn{padding:7px 12px;font-size:.8rem}.detail-header{padding:8px 12px;margin:-10px -10px 10px}.companies-main-tabs{gap:4px!important;margin-bottom:10px!important}.company-main-tab{padding:8px 4px!important;font-size:.75rem!important;border-radius:10px!important}.company-main-tab span:first-child{font-size:1.1rem!important}.company-main-tab span:last-child{font-size:.75rem!important}.report-types{gap:8px;padding:10px}.report-type-card{padding:14px 10px;border-radius:12px}.report-icon{font-size:1.8rem;margin-bottom:6px}.report-title{font-size:.85rem}.report-desc{font-size:.75rem}.report-header-bar{padding:10px;flex-direction:column;align-items:flex-start}.report-actions{flex-wrap:wrap;gap:5px}.report-btn{padding:6px 10px;font-size:.78rem}#page-conditions .section-header{flex-direction:column;align-items:flex-end}#page-conditions .section-header h2{width:100%}#page-users .section-header{flex-direction:column;align-items:flex-end}#page-users .section-header h2{width:100%}.page{padding:10px;-webkit-overflow-scrolling:touch}.summary-stats-grid{grid-template-columns:repeat(2,1fr)!important}.form-row{grid-template-columns:1fr!important}input,select,textarea{font-size:16px!important}.voice-cmd-btn{width:42px!important;height:42px!important;font-size:1.2rem!important;opacity:.5;left:8px!important;bottom:calc(130px + env(safe-area-inset-bottom,0px))!important}.voice-cmd-btn:active{opacity:1}.ai-chat-btn{width:42px!important;height:42px!important;font-size:1.3rem!important;opacity:.5;left:8px!important;bottom:calc(75px + env(safe-area-inset-bottom,0px))!important}.ai-chat-btn:active{opacity:1}.uploaded-images,.patrol-photos-preview{grid-template-columns:repeat(2,1fr)!important}}@media(min-width:601px)and (max-width:1024px){body{max-width:768px}.stats-grid{grid-template-columns:repeat(4,1fr)}.report-types{grid-template-columns:repeat(3,1fr)}.modal-content{max-width:600px}}@media(max-width:900px)and (orientation:landscape){body{max-width:100%;padding-bottom:60px}.nav-tabs{height:50px}.modal-content{max-height:85vh}}.header{background:linear-gradient(135deg,#1e3a5fd9,#2d5a87d9);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:10px 14px;padding-top:calc(10px + env(safe-area-inset-top,0px));display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-default);box-shadow:var(--shadow-md);position:sticky;top:0;z-index:100}.header h1{font-size:.88rem;display:flex;align-items:center;gap:4px;white-space:nowrap}.header-actions{display:flex;gap:3px}.header-btn{background:var(--surface);border:1px solid var(--border-light);color:#fff;width:36px;height:36px;border-radius:var(--radius-sm);font-size:.85rem;cursor:pointer;transition:background var(--transition-fast)}.header-btn:hover{background:var(--surface-strong)}.more-menu-btn{font-size:1.4rem!important;font-weight:900;letter-spacing:2px;min-width:44px;min-height:44px;touch-action:manipulation;-webkit-tap-highlight-color:rgba(255,255,255,.15)}.notification-badge-inline{background:var(--danger, #e74c3c);color:#fff;font-size:.65rem;padding:1px 5px;border-radius:10px;font-weight:700;min-width:16px;text-align:center}.more-menu-overlay{display:none;position:fixed;inset:0;z-index:10000;background:transparent}.more-menu-overlay.show{display:block}.more-menu-dropdown{display:none;position:fixed;min-width:170px;background:linear-gradient(160deg,#1e3a5f,#2a5a8f);border-radius:14px;box-shadow:0 8px 32px #0006,0 2px 8px #0003;z-index:10001;overflow:hidden;padding:6px 0}.more-menu-dropdown.show{display:block}.more-menu-item{display:block;width:100%;padding:13px 18px;background:none;border:none;color:#fff;font-size:.95rem;font-weight:500;text-align:right;cursor:pointer;touch-action:manipulation;transition:background .12s}.more-menu-item:hover,.more-menu-item:active{background:#ffffff1f}.more-menu-logout{color:#ff6b6b}.nav-tabs{display:grid;grid-template-columns:repeat(5,1fr);background:#0000002e;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:8px 6px;padding-bottom:calc(8px + env(safe-area-inset-bottom,0px));gap:4px;position:fixed;bottom:0;left:0;right:0;max-width:430px;margin:0 auto;z-index:1000;border-bottom:none;border-top:1px solid rgba(255,255,255,.04)}body:has(.modal.active) .nav-tabs,body:has(.voice-modal.active) .nav-tabs{display:none!important}.nav-tab{background:transparent;border:none;color:var(--text-muted);padding:8px 2px 6px;border-radius:0;font-size:.75rem;cursor:pointer;transition:all var(--transition-fast);display:flex;flex-direction:column;align-items:center;gap:2px;text-align:center;overflow:hidden;white-space:nowrap;touch-action:manipulation}.nav-tab.active{background:transparent;color:var(--accent);box-shadow:none;font-weight:700;position:relative}.nav-tab.active:before{content:"";position:absolute;top:0;left:20%;right:20%;height:3px;background:var(--accent);border-radius:0 0 3px 3px}.nav-tab:hover:not(.active){background:transparent;color:var(--text)}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:15px}.stat-card{background:var(--surface);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:18px 12px;border-radius:var(--radius-lg);text-align:center;border:1px solid var(--border-default);transition:transform var(--transition-normal),box-shadow var(--transition-normal),border-color var(--transition-normal);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--success));opacity:0;transition:opacity .3s}.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-glow-accent);border-color:#00b4d866}.stat-card:hover:before{opacity:1}.stat-card[onclick]{cursor:pointer}.stat-card[onclick]:active{transform:scale(.95);transition-duration:.1s}.stat-card[onclick]:after{content:"◂";position:absolute;top:6px;left:6px;font-size:.6rem;opacity:.3;color:var(--text-muted)}.stat-card .icon{font-size:2rem;margin-bottom:8px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.stat-card .number{font-size:1.8rem;font-weight:700;color:var(--accent);margin-bottom:4px;text-shadow:0 2px 10px rgba(0,180,216,.3)}.stat-card .label{font-size:.85rem;color:var(--text-muted)}.search-container{padding:0 15px 15px}.search-box{background:var(--surface);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:12px 15px;display:flex;align-items:center;gap:10px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.search-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #00b4d81a}.search-box input{flex:1;background:none;border:none;color:#fff;font-size:1rem;outline:none}.search-box input::placeholder{color:var(--text-muted)}.category-section{margin-bottom:15px}.category-header{background:var(--surface-strong);padding:12px 15px;border-radius:var(--radius-md);display:flex;justify-content:space-between;align-items:center;cursor:pointer;margin-bottom:10px;border:1px solid var(--border-default);transition:background var(--transition-fast)}.category-header:hover{background:#ffffff26}.category-header h3{font-size:1.1rem;display:flex;align-items:center;gap:10px}.category-header .count{background:var(--accent);padding:4px 12px;border-radius:20px;font-size:.85rem}.category-header .toggle-icon{transition:transform .3s}.category-header.collapsed .toggle-icon{transform:rotate(-90deg)}.category-content{display:grid;gap:10px}.category-content.collapsed{display:none}.filter-buttons{display:flex;gap:8px;padding:0 15px 15px;overflow-x:auto;flex-wrap:wrap}.filter-btn{background:var(--surface);border:1px solid var(--border-default);color:var(--text-muted);padding:8px 15px;border-radius:var(--radius-pill);font-size:.85rem;cursor:pointer;white-space:nowrap;transition:all var(--transition-fast)}.filter-btn:hover:not(.active){background:var(--surface-strong)}.filter-btn.active{background:var(--btn-primary);border-color:#2a5a8f80;color:#fff;box-shadow:0 4px 15px #1e3a5f66}.filter-btn-warranty.active{background:linear-gradient(135deg,#2ecc71,#27ae60);border-color:#27ae60;color:#fff;box-shadow:0 0 15px #27ae604d}.filter-btn-faults.active{background:linear-gradient(135deg,#e74c3c,#e67e22);border-color:#e74c3c;color:#fff;box-shadow:0 0 15px #e74c3c4d}.fault-details{padding:8px 12px;margin:-5px 0 10px;border-radius:0 0 12px 12px;background:#e74c3c14;border:1px solid rgba(231,76,60,.15);border-top:none}[data-theme=light] .fault-details{background:#e74c3c0f;border-color:#e74c3c1f}.fault-item{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:.82rem}.fault-item-note{color:var(--text-muted);font-size:.78rem}.section-header{display:flex;justify-content:space-between;align-items:center;padding:0 15px 10px}.section-header h2{font-size:1.1rem}.add-btn{background:var(--btn-primary);color:#fff;border:1px solid rgba(255,255,255,.1);padding:10px 20px;border-radius:var(--radius-pill);font-size:.9rem;cursor:pointer;display:flex;align-items:center;gap:5px;transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast);box-shadow:var(--shadow-sm)}.add-btn:hover{background:var(--btn-primary-hover);transform:translateY(-1px);box-shadow:0 4px 15px #1e3a5f66}.list-container{padding:0 15px}.patrol-card{background:var(--surface);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:15px;margin-bottom:10px;cursor:pointer;transition:transform var(--transition-normal),box-shadow var(--transition-normal),border-color var(--transition-normal)}.patrol-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#00b4d84d}.patrol-card:active{transform:translateY(0)}.patrol-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.patrol-info h3{font-size:1.1rem;margin-bottom:3px}.patrol-info .type{font-size:.85rem;color:var(--text-muted)}.patrol-status{padding:5px 12px;border-radius:15px;font-size:.8rem;font-weight:700}.patrol-warranty-badge{padding:4px 10px;border-radius:15px;font-size:.75rem;font-weight:700;white-space:nowrap}.status-operational{background:#00b89433;color:var(--success)}.status-maintenance{background:#fdcb6e33;color:var(--warning)}.status-outofservice{background:#e1705533;color:var(--danger)}.patrol-stats{display:flex;gap:15px;padding-top:10px;border-top:1px solid rgba(255,255,255,.1)}.patrol-stat{display:flex;align-items:center;gap:5px;font-size:.85rem;color:var(--text-muted)}.patrol-stat .count{color:var(--text);font-weight:700}.equipment-card{background:var(--surface);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:12px;margin-bottom:10px;display:flex;align-items:center;gap:12px;transition:all var(--transition-fast)}.equipment-card:hover{background:var(--surface-strong);border-color:#00b4d840}.equipment-icon{width:45px;height:45px;background:#00b4d833;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.3rem}.equipment-details{flex:1}.equipment-details h4{font-size:.95rem;margin-bottom:3px}.equipment-details .model{font-size:.8rem;color:var(--text-muted)}.equipment-status{width:12px;height:12px;border-radius:50%}.equipment-status.working{background:var(--success)}.equipment-status.fault{background:var(--danger);animation:faultPulse 1.5s ease-in-out infinite}@keyframes faultPulse{0%,to{box-shadow:0 0 #e74c3c80}50%{box-shadow:0 0 0 5px #e74c3c00}}.equipment-status-badge{min-width:60px;text-align:center;transition:all .3s ease}.equipment-card:hover .equipment-status-badge{transform:scale(1.05)}.equipment-card[style*="border-right: 5px solid #e74c3c"]{background:linear-gradient(90deg,rgba(231,76,60,.1) 0%,transparent 30%)}.duty-stats-row{display:flex;gap:8px;flex-wrap:wrap}.duty-search-bar{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.duty-search-input-wrap{display:flex;align-items:center;gap:8px;background:var(--card-bg);border-radius:12px;padding:8px 12px;border:1px solid rgba(255,255,255,.08)}.duty-search-input-wrap>span{font-size:1rem;opacity:.6}.duty-search-input-wrap input[type=text]{flex:1;background:none;border:none;color:var(--text);font-size:16px;outline:none;min-width:0}.duty-search-input-wrap input[type=text]::placeholder{color:var(--text-secondary);opacity:.5}.duty-search-input-wrap input[type=date]{background:none;border:none;border-right:1px solid rgba(255,255,255,.1);padding-right:8px;color:var(--text);font-size:16px;width:auto;min-width:36px;cursor:pointer;opacity:.6;transition:opacity .2s}.duty-search-input-wrap input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.7);cursor:pointer}.duty-search-input-wrap input[type=date].has-value{width:auto;opacity:1}.duty-clear-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:.9rem;padding:2px 6px;border-radius:50%;line-height:1}.duty-clear-btn:hover{color:var(--accent)}.duty-shift-filter{display:flex;gap:4px}.duty-shift-btn{background:var(--bg);border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);padding:5px 12px;border-radius:8px;font-size:.85rem;cursor:pointer;transition:all .2s}.duty-shift-btn.active{background:var(--btn-primary);color:#fff;border-color:#2a5a8f80}.duty-shift-divider{display:flex;align-items:center;gap:10px;margin:18px 0 10px;padding:0 5px}.duty-shift-divider:before,.duty-shift-divider:after{content:"";flex:1;height:1px;opacity:.3}.duty-shift-divider .shift-badge{font-size:.9rem;font-weight:700;padding:4px 14px;border-radius:20px;white-space:nowrap;color:#fff}.duty-log-entry{background:var(--card-bg);border-radius:12px;padding:12px 15px;margin-bottom:8px;display:flex;gap:12px;align-items:flex-start;border-right:3px solid transparent;transition:transform .15s}.duty-log-entry:active{transform:scale(.98)}.duty-log-entry.shift-1{border-right-color:#3498db}.duty-log-entry.shift-2{border-right-color:#27ae60}.duty-log-entry.shift-3{border-right-color:#9b59b6}.duty-log-entry.manual-entry{background:#3498db14}.duty-log-entry .entry-icon{font-size:1.4rem;min-width:28px;text-align:center;padding-top:2px}.duty-log-entry .entry-content{flex:1;min-width:0}.duty-log-entry .entry-title{font-weight:600;font-size:1rem;margin-bottom:3px;line-height:1.4}.duty-log-entry .entry-details{font-size:.9rem;color:var(--text-secondary);line-height:1.4;margin-bottom:4px}.duty-log-entry .entry-meta{display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--text-secondary);opacity:.8}.duty-log-entry .entry-time{font-weight:600;font-variant-numeric:tabular-nums}.duty-followup-entry{background:#e67e221a;border-radius:12px;padding:12px 15px;margin-bottom:8px;display:flex;gap:12px;align-items:center;border-right:4px solid #e67e22;transition:transform .15s}.duty-followup-entry:active{transform:scale(.98)}.duty-followup-entry.done{background:#27ae601a;border-right-color:#27ae60}.duty-followup-entry.done .followup-text{text-decoration:line-through;opacity:.7}.duty-followup-entry .followup-icon{font-size:1.3rem;min-width:24px;text-align:center}.duty-followup-entry .followup-content{flex:1;min-width:0}.duty-followup-entry .followup-text{font-weight:600;font-size:.98rem;line-height:1.4}.duty-followup-entry .followup-meta{font-size:.85rem;color:var(--text-secondary);opacity:.8;margin-top:3px}.duty-toggle-done-btn{background:#ffffff1f;border:1px solid rgba(255,255,255,.15);color:var(--text);padding:4px 10px;border-radius:8px;font-size:.85rem;cursor:pointer;white-space:nowrap;transition:all .2s}.duty-toggle-done-btn:hover{background:#27ae604d}.duty-followup-entry.done .duty-toggle-done-btn{background:#27ae6033;border-color:#27ae60;color:#27ae60}.duty-section-divider{margin:10px 0;border:none;height:1px;background:var(--text-secondary);opacity:.15}.duty-mini-stat{background:#1e3a5fb3;border:1px solid rgba(0,180,216,.2);color:var(--text);padding:6px 14px;border-radius:20px;font-size:.9rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:4px}.duty-mini-stat span{font-weight:700;color:var(--accent)}.duty-mini-stat:hover{background:#00b4d826;border-color:#00b4d880}.duty-mini-stat-followup span{color:#e67e22}.duty-accordion{cursor:pointer;display:flex;align-items:center;gap:8px;padding:10px 12px;background:#ffffff0a;border-radius:10px;margin-bottom:6px;font-size:.95rem;font-weight:600;-webkit-user-select:none;user-select:none;transition:background .2s}.duty-accordion:hover{background:#ffffff14}.duty-accordion .acc-arrow{transition:transform .2s;font-size:.8rem;opacity:.5}.duty-accordion.open .acc-arrow{transform:rotate(90deg)}.duty-accordion .acc-count{margin-right:auto;font-size:.85rem;opacity:.6;font-weight:400}.duty-accordion-body{display:none;padding-bottom:4px}.duty-accordion-body.open{display:block}.duty-photo-upload{background:#ffffff0f;border:1px dashed rgba(255,255,255,.2);border-radius:10px;padding:12px;text-align:center;cursor:pointer;font-size:.95rem;color:var(--text-secondary);transition:all .2s}.duty-photo-upload:hover{background:#ffffff1a;border-color:#ffffff4d}.duty-photo-preview{margin-top:8px;text-align:center}.duty-photo-preview img{max-width:100%;max-height:200px;border-radius:10px;border:1px solid rgba(255,255,255,.1)}.duty-photo-preview .remove-photo{display:inline-block;margin-top:6px;font-size:.75rem;color:#e74c3c;cursor:pointer}.duty-entry-photo{margin-top:6px}.duty-entry-photo img{max-width:100%;max-height:150px;border-radius:8px;cursor:pointer;border:1px solid rgba(255,255,255,.1)}.duty-shift-photo-section{padding:10px 12px;border-top:1px dashed rgba(142,68,173,.3);text-align:center}.duty-shift-photo-label{font-size:.92rem;font-weight:600;color:#8e44ad;margin-bottom:8px}.duty-shift-photo-img{max-width:100%;max-height:220px;border-radius:10px;cursor:pointer;border:1px solid rgba(142,68,173,.25);display:block;margin:0 auto 6px}.duty-shift-photo-meta{font-size:.85rem;color:var(--text-secondary, #888);margin-bottom:6px}.duty-shift-photo-actions{display:flex;gap:8px;justify-content:center}.duty-shift-photo-btn{padding:6px 14px;border-radius:8px;border:1px solid rgba(142,68,173,.3);background:#8e44ad1a;color:var(--text, white);font-size:.9rem;cursor:pointer}.duty-shift-photo-btn.duty-shift-photo-add{width:100%;padding:10px;font-size:.95rem;background:#8e44ad14;border:1px dashed rgba(142,68,173,.35);border-radius:10px}.duty-shift-photo-btn.duty-shift-photo-delete{border-color:#e74c3c4d;background:#e74c3c1a}.duty-shift-photo-compact{cursor:default}.duty-entry-patrol-badge{display:inline-block;background:#00b4d826;color:var(--accent);padding:2px 8px;border-radius:6px;font-size:.85rem;font-weight:600;margin-left:6px}.duty-entry-edit-btn{background:none;border:none;color:var(--text-secondary);font-size:.95rem;cursor:pointer;padding:4px 6px;border-radius:6px;opacity:.5;transition:all .2s}.duty-entry-edit-btn:hover{opacity:1;background:#ffffff1a}.duty-inline-add-btn{background:#ffffff0f;border:1px dashed rgba(255,255,255,.15);color:var(--text-secondary);padding:8px;border-radius:10px;font-size:.9rem;cursor:pointer;text-align:center;margin-bottom:6px;transition:all .2s;width:100%}.duty-inline-add-btn:hover{background:#ffffff1a;color:var(--text);border-color:#ffffff40}.split-shift-header{font-weight:700;font-size:.95rem;padding:10px 12px;border-radius:10px;background:#ffffff0d;border-right:4px solid transparent;color:var(--text);display:flex;align-items:center;gap:8px}.split-shift-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.split-row{background:var(--card-bg);border-radius:10px;padding:10px 12px;margin-top:4px;cursor:pointer;transition:background .15s}.split-row:active{background:#ffffff14}.split-row.split-row-done{opacity:.7}.split-summary{display:flex;align-items:center;gap:8px;min-height:22px}.split-type-icon{font-size:.9rem;flex-shrink:0;min-width:22px;text-align:center}.split-time{font-weight:700;font-size:.78rem;color:var(--accent);font-variant-numeric:tabular-nums;flex-shrink:0}.split-entry-text{font-size:.82rem;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.split-text-done{text-decoration:line-through;opacity:.7}.split-detail{display:none;padding-top:10px;margin-top:8px;border-top:1px solid rgba(255,255,255,.08)}.split-row.expanded .split-detail{display:block}.split-detail-fulltext{font-size:.85rem;line-height:1.5;margin-bottom:6px}.split-detail-patrol{margin-bottom:4px}.split-detail-user{font-size:.75rem;color:var(--text-secondary);margin-bottom:6px}.split-detail-actions{display:flex;gap:8px;margin-top:8px}.split-shift-label{flex:1}.split-header-photo-btn{font-size:1.1rem;cursor:pointer;opacity:.6;transition:opacity .15s;flex-shrink:0;padding:2px 4px}.split-header-photo-btn:hover{opacity:1}.split-group-separator{height:1px;background:#ffffff0f;margin:14px 20px 2px}.modal{display:none;position:fixed;inset:0;width:100%;height:100%;background:#000000b3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1000;justify-content:center;align-items:center;padding:20px}.modal.active{display:flex}#imageViewer{padding:0}.modal-content{background:linear-gradient(180deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);padding:25px;padding-bottom:calc(25px + env(safe-area-inset-bottom,0px));border-radius:20px 20px 0 0;width:100%;max-width:430px;max-height:90vh;max-height:90dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;animation:slideUpSheet .3s ease;border:1px solid var(--border-default);box-shadow:var(--shadow-lg);margin:0 auto;position:fixed;bottom:0;left:0;right:0}.modal-content:before{content:"";display:block;width:36px;height:4px;background:#ffffff4d;border-radius:2px;margin:0 auto 12px}@keyframes slideUpSheet{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid var(--border-light)}.modal-header h3{font-size:1.3rem}.close-btn{background:var(--surface);border:1px solid var(--border-light);color:#fff;width:40px;height:40px;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:background var(--transition-fast)}.close-btn:hover{background:var(--surface-strong)}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:8px;font-size:.95rem;color:var(--text-muted)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:14px;border:1px solid var(--border-default);border-radius:var(--radius-md);font-size:1rem;background:var(--surface);color:var(--text-primary);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #00b4d81f}.form-group textarea{min-height:80px;resize:vertical}.form-group input:read-only,.form-group textarea:read-only{cursor:default;opacity:.7;background:#ffffff08}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{opacity:.5;cursor:not-allowed;background:#ffffff05}.form-group select option{background:var(--primary-dark)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.submit-btn{width:100%;padding:16px;background:var(--btn-primary);color:#fff;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);font-size:1.1rem;font-weight:700;cursor:pointer;margin-top:10px;transition:background var(--transition-fast),transform var(--transition-fast);box-shadow:var(--shadow-sm)}.submit-btn:hover{background:var(--btn-primary-hover);transform:translateY(-1px)}.submit-btn:active{transform:translateY(0)}.submit-btn:disabled,.submit-btn.loading{opacity:.6;cursor:not-allowed;pointer-events:none;transform:none}.submit-btn.loading:after{content:"";display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:btnSpin .6s linear infinite;margin-right:8px;vertical-align:middle}.btn-danger{background:linear-gradient(135deg,var(--danger) 0%,#c0392b 100%)}.radio-option{transition:all .2s ease}.radio-option:hover{background:#f0f8ff!important;border-color:#3498db!important}.radio-option:has(input:checked){background:#e8f4f8!important;border-color:#e67e22!important;box-shadow:0 0 0 2px #e67e2233}.radio-option input[type=radio]{width:18px;height:18px;accent-color:#e67e22}.detail-header{background:linear-gradient(135deg,#1e3a5fe6,#2d5a87d9);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:6px 10px;margin:-15px -15px 8px;border-radius:0 0 var(--radius-md) var(--radius-md)}.detail-header-row1{display:flex;align-items:center;justify-content:space-between;gap:8px}.detail-header .back-btn{background:var(--surface);border:1px solid var(--border-light);color:#fff;padding:3px 8px;border-radius:var(--radius-pill);font-size:.75rem;cursor:pointer;flex-shrink:0;transition:background var(--transition-fast)}.detail-header .back-btn:hover{background:var(--surface-strong)}.detail-header-title{flex:1;text-align:center;font-size:.85rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-header-sep{margin:0 4px;opacity:.6}.detail-type-inline{font-weight:400;opacity:.8;font-size:.78rem}.qr-btn-mini{background:#ffffff26;color:#fff;border:none;padding:3px 8px;border-radius:8px;font-size:.8rem;cursor:pointer;flex-shrink:0}.detail-header-row2{display:flex;align-items:center;justify-content:space-between;margin-top:4px;gap:8px}.detail-stats-inline{display:flex;align-items:center;gap:4px;font-size:.75rem;color:#ffffffd9}.detail-stats-inline b{color:var(--accent);font-size:.8rem}.detail-stats-dot{opacity:.4;font-size:.6rem}.warranty-badge-inline{font-size:.75rem;font-weight:700;padding:2px 6px;border-radius:4px;white-space:nowrap;flex-shrink:0}.warranty-active{background:#2ecc7126;color:#2ecc71;border:2px solid #000;box-shadow:0 0 12px #2ecc7126}.warranty-expiring{background:#f39c1226;color:#f39c12;border:2px solid #000}.warranty-partial{background:#f39c121f;color:#e67e22;border:2px solid #000}.warranty-none{background:#e74c3c26;color:#e74c3c;border:2px solid #000}.warranty-shield{font-size:.75rem;margin-right:4px;vertical-align:middle}.warranty-shield-active{filter:drop-shadow(0 0 4px rgba(46,204,113,.6));opacity:1}.warranty-shield-expiring{filter:drop-shadow(0 0 4px rgba(243,156,18,.6));animation:pulse-warranty 2s infinite}.warranty-shield-expired{opacity:.3;filter:grayscale(1)}@keyframes pulse-warranty{0%,to{opacity:1}50%{opacity:.5}}.tabs-container{display:flex;justify-content:center;flex-wrap:wrap;gap:8px;margin-bottom:15px;padding:0 10px}.tab-btn{background:var(--surface);border:1px solid var(--border-default);color:var(--text-muted);padding:10px 20px;border-radius:var(--radius-pill);font-size:.9rem;cursor:pointer;white-space:nowrap;transition:all var(--transition-fast)}.tab-btn:hover:not(.active){background:var(--surface-strong)}.tab-btn.active{background:var(--btn-primary);border-color:#2a5a8f80;color:#fff;box-shadow:0 4px 15px #1e3a5f66}.image-upload-area{border:2px dashed var(--border-default);border-radius:var(--radius-lg);padding:30px;text-align:center;cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast)}.image-upload-area:hover{border-color:var(--accent);background:#00b4d80d}.image-upload-area .icon{font-size:2.5rem;margin-bottom:10px}.uploaded-images{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}.uploaded-image{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden}.uploaded-image img{width:100%;height:100%;object-fit:cover}.uploaded-image .remove-img{position:absolute;top:5px;left:5px;background:var(--danger);border:none;color:#fff;width:24px;height:24px;border-radius:50%;cursor:pointer}.need-card{background:var(--surface);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:12px;margin-bottom:10px;transition:all var(--transition-fast)}.need-card:hover{background:var(--surface-strong)}.need-card.priority-high{border-right:4px solid var(--danger)}.need-card.priority-medium{border-right:4px solid var(--warning)}.need-card.priority-low{border-right:4px solid var(--success)}.need-header{display:flex;justify-content:space-between;margin-bottom:8px}.need-title{font-weight:700}.need-priority{font-size:.8rem;padding:3px 10px;border-radius:10px}.priority-high .need-priority{background:#e1705533;color:var(--danger)}.priority-medium .need-priority{background:#fdcb6e33;color:var(--warning)}.priority-low .need-priority{background:#00b89433;color:var(--success)}.need-desc{font-size:.9rem;color:var(--text-muted)}.doc-card{background:var(--surface);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:12px;margin-bottom:10px;display:flex;align-items:center;gap:12px;transition:all var(--transition-fast)}.doc-card:hover{background:var(--surface-strong)}.doc-icon{width:45px;height:45px;background:#fdcb6e33;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.3rem}.doc-details{flex:1}.doc-details h4{font-size:.95rem;margin-bottom:3px}.doc-details .doc-meta{font-size:.8rem;color:var(--text-muted)}#toast-live-region{position:fixed;bottom:0;left:0;right:0;z-index:var(--z-toast, 3000);pointer-events:none}#toast-live-region .toast{pointer-events:auto}.toast{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom,0px));left:50%;transform:translate(-50%);background:var(--surface-strong);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-default);color:#fff;padding:12px 25px;border-radius:var(--radius-lg);max-width:calc(100% - 32px);box-shadow:var(--shadow-md);z-index:3000;animation:fadeInOut 2.5s ease}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%) translateY(20px)}15%{opacity:1;transform:translate(-50%) translateY(0)}85%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-20px)}}.toast.success{background:#27ae60eb;border-color:#2ecc714d;display:flex;align-items:center;gap:10px}.toast.success:before{content:"";display:inline-block;width:22px;height:22px;min-width:22px;border-radius:50%;background:#ffffff40;position:relative}.toast.success:after{content:"";position:absolute;left:28px;top:50%;width:6px;height:11px;border:solid #fff;border-width:0 2.5px 2.5px 0;transform:translateY(-55%) rotate(45deg);animation:toastCheckPop .35s ease .15s both}@keyframes toastCheckPop{0%{opacity:0;transform:translateY(-55%) rotate(45deg) scale(0)}60%{transform:translateY(-55%) rotate(45deg) scale(1.2)}to{opacity:1;transform:translateY(-55%) rotate(45deg) scale(1)}}.toast.error{background:#c0392beb;border-color:#e74c3c4d;display:flex;align-items:center;gap:10px}.toast.error:before{content:"✕";display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;min-width:22px;border-radius:50%;background:#ffffff40;font-size:.7rem;font-weight:700}.toast.warning{background:#d35400eb;border-color:#f39c124d;display:flex;align-items:center;gap:10px}.toast.warning:before{content:"!";display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;min-width:22px;border-radius:50%;background:#ffffff40;font-size:.8rem;font-weight:700}.toast.undo{background:var(--surface-strong);display:flex;align-items:center;gap:12px}.toast.undo .undo-btn{background:#fff3;border:none;color:#5dade2;font-weight:700;padding:4px 12px;border-radius:8px;cursor:pointer;font-size:.85rem}.notifications-panel{position:fixed;top:0;right:-350px;width:350px;max-width:90vw;height:100vh;height:100dvh;background:var(--bg-primary);border-left:1px solid var(--border-default);z-index:2500;transition:right .3s ease;box-shadow:-5px 0 30px #0006;display:flex;flex-direction:column}.notifications-panel.open{right:0}.notifications-header{padding:20px;background:var(--bg-secondary);border-bottom:1px solid var(--border-default);display:flex;justify-content:space-between;align-items:center}.notifications-header h3{margin:0;font-size:1.1rem}.notifications-list{flex:1;overflow-y:auto;padding:10px}.notification-item{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:12px;margin-bottom:10px;border-right:3px solid var(--accent);cursor:pointer;transition:all var(--transition-fast)}.notification-item:hover{background:var(--surface-strong)}.notification-item.unread{border-right-color:var(--danger);background:#e770551a}.notification-item .notif-title{font-weight:700;margin-bottom:5px}.notification-item .notif-desc{font-size:.85rem;color:var(--text-muted)}.notification-item .notif-time{font-size:.75rem;color:var(--text-muted);margin-top:5px}.notification-badge{background:var(--danger);color:#fff;border-radius:50%;width:18px;height:18px;font-size:.7rem;display:flex;align-items:center;justify-content:center;position:absolute;top:-5px;right:-5px}.notif-btn-container{position:relative}.activity-item{display:flex;gap:12px;padding:12px;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-md);margin-bottom:8px;transition:background var(--transition-fast)}.activity-item:hover{background:var(--surface-strong)}.activity-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}.activity-icon.add{background:#00b89433}.activity-icon.edit{background:#00b4d833}.activity-icon.delete{background:#e7705533}.activity-icon.issue{background:#fdcb6e33}.activity-icon.login{background:#6c5ce733}.activity-content{flex:1}.activity-content .activity-title{font-weight:500;margin-bottom:3px}.activity-content .activity-desc{font-size:.85rem;color:var(--text-muted)}.activity-content .activity-time{font-size:.75rem;color:var(--text-muted);margin-top:5px}.overlay{position:fixed;inset:0;background:#00000080;z-index:2400;display:none}.overlay.show{display:block}.voice-cmd-btn{position:fixed;bottom:calc(150px + env(safe-area-inset-bottom,0px));left:20px;width:55px;height:55px;border-radius:50%;background:linear-gradient(135deg,#00b894,#00cec9);border:none;color:#fff;font-size:1.5rem;cursor:pointer;box-shadow:0 4px 20px #00b89480;z-index:1000;transition:all .3s;display:flex;align-items:center;justify-content:center}.voice-cmd-btn:hover{transform:scale(1.1);box-shadow:0 6px 30px #00b894b3}.voice-cmd-btn.listening{background:linear-gradient(135deg,#e17055,#d63031);animation:pulse-voice 1s infinite}@keyframes pulse-voice{0%,to{transform:scale(1);box-shadow:0 4px 20px #e1705580}50%{transform:scale(1.1);box-shadow:0 6px 30px #e17055cc}}.voice-modal{position:fixed;inset:0;background:#000000e6;z-index:3000;display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .3s}.voice-modal.active{opacity:1;visibility:visible}.voice-modal-content{text-align:center;padding:30px}.voice-animation{width:150px;height:150px;border-radius:50%;background:linear-gradient(135deg,#00b894,#00cec9);display:flex;align-items:center;justify-content:center;font-size:4rem;margin:0 auto 30px;position:relative}.voice-animation.listening{animation:voice-pulse 1.5s infinite}.voice-animation:before,.voice-animation:after{content:"";position:absolute;width:100%;height:100%;border-radius:50%;border:3px solid rgba(0,184,148,.5);animation:voice-ripple 1.5s infinite}.voice-animation:after{animation-delay:.5s}@keyframes voice-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes voice-ripple{0%{transform:scale(1);opacity:1}to{transform:scale(1.5);opacity:0}}.voice-animation.thinking{background:linear-gradient(135deg,#6c5ce7,#a29bfe);animation:thinking-pulse 1.5s ease-in-out infinite}.voice-animation.thinking:before,.voice-animation.thinking:after{border-color:#6c5ce780}@keyframes thinking-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.7}}.voice-status{font-size:1.3rem;color:#fff;margin-bottom:15px}.voice-transcript{font-size:1.1rem;color:var(--accent);min-height:30px;max-width:300px;margin:0 auto 20px;direction:rtl}.voice-cancel-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.3);color:#fff;padding:12px 40px;border-radius:30px;font-size:1rem;cursor:pointer;transition:all .3s}.voice-cancel-btn:hover{background:#fff3}.voice-examples{margin-top:30px;color:var(--text-muted);font-size:.85rem}.voice-examples p{margin:5px 0}.voice-answer-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);border:2px solid var(--accent);border-radius:20px;padding:25px;z-index:3100;opacity:0;transition:all .3s;max-width:90%;width:320px;text-align:center;box-shadow:0 10px 40px #00000080}.voice-answer-popup.show{opacity:1;transform:translate(-50%,-50%) scale(1)}.voice-answer-icon{font-size:3rem;margin-bottom:15px}.voice-answer-text{font-size:1.2rem;color:#fff;margin-bottom:10px;line-height:1.6}.voice-answer-source{font-size:.8rem;color:var(--success);background:#00b89433;padding:5px 15px;border-radius:20px;display:inline-block}.ai-chat-btn{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom,0px));left:20px;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);border:1px solid rgba(255,255,255,.15);color:#fff;font-size:1.8rem;cursor:pointer;box-shadow:0 4px 20px #667eea80;z-index:1000;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center}.ai-chat-btn:hover{transform:scale(1.1);box-shadow:0 6px 30px #667eeab3;border-color:#ffffff4d}.ai-chat-btn.has-response{animation:pulse-ai 2s infinite}@keyframes pulse-ai{0%,to{box-shadow:0 4px 20px #667eea80}50%{box-shadow:0 4px 30px #667eeacc}}.ai-chat-panel{position:fixed;bottom:0;left:0;right:0;height:85vh;height:85dvh;background:var(--bg-primary);z-index:2600;border-radius:var(--radius-xl) var(--radius-xl) 0 0;transform:translateY(100%);transition:transform .3s ease;display:flex;flex-direction:column;box-shadow:0 -5px 30px #00000080;border-top:1px solid var(--border-default)}.ai-chat-panel.open{transform:translateY(0)}.ai-chat-header{padding:15px 20px;background:linear-gradient(135deg,#667eead9,#764ba2d9);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-xl) var(--radius-xl) 0 0;border-bottom:1px solid rgba(255,255,255,.15);display:flex;justify-content:space-between;align-items:center}.ai-chat-header h3{margin:0;display:flex;align-items:center;gap:10px}.ai-chat-messages{flex:1;overflow-y:auto;padding:15px;display:flex;flex-direction:column;gap:12px}.ai-message{max-width:85%;padding:12px 16px;border-radius:var(--radius-lg);font-size:.95rem;line-height:1.5;transition:transform var(--transition-fast)}.ai-message.user{background:linear-gradient(135deg,#667eeae6,#764ba2e6);color:#fff;align-self:flex-start;border-bottom-left-radius:5px;box-shadow:0 2px 10px #667eea4d}.ai-message.assistant{background:var(--surface);border:1px solid var(--border-light);color:var(--text);align-self:flex-end;border-bottom-right-radius:5px}.ai-message.assistant pre{background:#0000004d;padding:10px;border-radius:var(--radius-sm);overflow-x:auto;margin:8px 0}.ai-message.assistant code{font-family:monospace;font-size:.85rem}.ai-message.streaming{min-height:24px}.streaming-cursor{display:inline;animation:blink-cursor .7s infinite;color:var(--accent);font-weight:700}@keyframes blink-cursor{0%,to{opacity:1}50%{opacity:0}}.ai-action-btn{display:inline-flex;align-items:center;padding:2px 8px;margin:0 4px;border:1px solid rgba(102,126,234,.4);border-radius:12px;background:#667eea26;color:#667eea;font-size:.75rem;cursor:pointer;vertical-align:middle;transition:all .2s}.ai-action-btn:hover{background:#667eea4d;transform:scale(1.05)}.ai-message h2,.ai-message h3,.ai-message h4{margin:12px 0 6px;font-size:1rem}.ai-message h2{font-size:1.1rem}.ai-message ul,.ai-message ol{margin:8px 0;padding-right:24px}.ai-message li{margin:3px 0}.ai-message table{width:100%;border-collapse:collapse;margin:10px 0;font-size:.85rem}.ai-message th,.ai-message td{border:1px solid var(--border-default);padding:6px 10px;text-align:right}.ai-message th{background:#667eea1a;font-weight:600}.ai-message pre{background:#0000004d;padding:12px;border-radius:var(--radius-sm);direction:ltr;text-align:left;overflow-x:auto;margin:8px 0;white-space:pre-wrap;word-break:break-word}.ai-message pre code{background:none;padding:0;font-size:.85rem}.ai-message a{color:#667eea;text-decoration:underline}.ai-message blockquote{border-right:3px solid var(--accent);padding:4px 12px;margin:8px 0;background:#0000001a;border-radius:0 var(--radius-sm) var(--radius-sm) 0}.ai-message hr{border:none;border-top:1px solid var(--border-default);margin:12px 0}.ai-message img{max-width:100%;border-radius:var(--radius-sm);margin:8px 0}.ai-message.system{background:#fdcb6e1f;border:1px solid rgba(253,203,110,.25);color:var(--warning);align-self:center;font-size:.85rem;text-align:center;border-radius:var(--radius-pill)}.ai-chat-input{padding:15px;background:#00000040;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-top:1px solid var(--border-light);display:flex;gap:10px;align-items:flex-end}.ai-chat-input textarea{flex:1;background:var(--surface);border:1px solid var(--border-default);border-radius:var(--radius-pill);padding:12px 18px;color:var(--text);font-size:1rem;resize:none;max-height:100px;font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.ai-chat-input textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.ai-chat-input button{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);border:1px solid rgba(255,255,255,.15);color:#fff;font-size:1.3rem;cursor:pointer;flex-shrink:0;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.ai-chat-input button:hover{transform:scale(1.05);box-shadow:0 4px 15px #667eea66}.ai-chat-input button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.ai-image-upload-btn{width:45px;height:45px;border-radius:50%;background:var(--surface);border:1px solid var(--border-default);color:#fff;font-size:1.2rem;cursor:pointer;flex-shrink:0;transition:all var(--transition-fast)}.ai-image-upload-btn:hover{background:var(--surface-strong);border-color:#667eea66}.ai-voice-btn{width:45px;height:45px;border-radius:50%;background:var(--surface);border:1px solid var(--border-default);color:#fff;font-size:1.2rem;cursor:pointer;flex-shrink:0;transition:all var(--transition-fast)}.ai-voice-btn:hover{background:var(--surface-strong);border-color:#667eea66}.ai-voice-btn.recording{background:#e74c3c;animation:pulse-recording 1s infinite;border-color:#e74c3c}@keyframes pulse-recording{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.ai-image-preview{padding:10px 15px;background:#00000040;border-top:1px solid var(--border-light);display:none;align-items:center;gap:10px}.ai-image-preview.show{display:flex}.ai-image-preview img{width:60px;height:60px;object-fit:cover;border-radius:8px;border:2px solid var(--accent)}.ai-image-preview .image-info{flex:1;font-size:.85rem;color:var(--text-muted)}.ai-image-preview .remove-image{background:var(--danger);border:none;color:#fff;width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:1rem}.ai-message img{max-width:100%;border-radius:10px;margin-top:8px}.ai-typing{display:flex;gap:5px;padding:10px}.ai-typing span{width:8px;height:8px;background:var(--accent);border-radius:50%;animation:typing 1s infinite}.ai-typing span:nth-child(2){animation-delay:.2s}.ai-typing span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}.ai-suggestions{display:flex;flex-wrap:wrap;gap:8px;padding:10px 15px;border-bottom:1px solid var(--border-light);background:#0000001a}.ai-suggestion-btn{background:#667eea26;border:1px solid rgba(102,126,234,.25);color:#667eea;padding:8px 14px;border-radius:var(--radius-pill);font-size:.8rem;cursor:pointer;transition:all var(--transition-fast)}.ai-suggestion-btn:hover{background:#667eea4d;border-color:#667eea80;transform:translateY(-1px);box-shadow:0 2px 8px #667eea33}#sync-indicator{cursor:pointer;transition:all .3s}#sync-indicator.syncing{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.photos-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.photo-card{background:var(--card-bg);border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;cursor:pointer}.photo-card img{width:100%;aspect-ratio:4/3;object-fit:cover}.photo-card .photo-label{padding:8px;text-align:center;font-size:.85rem;color:var(--text-muted)}.patrol-photo-upload{border:2px dashed rgba(255,255,255,.3);border-radius:12px;padding:20px;text-align:center;cursor:pointer;transition:all .3s;margin-top:10px}.patrol-photo-upload:hover{border-color:var(--accent);background:#00b4d81a}.patrol-photo-upload .upload-icon{font-size:2.5rem;margin-bottom:10px}.patrol-photo-upload p{color:var(--text-muted);font-size:.9rem}.patrol-photos-preview{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:15px}.patrol-photo-preview-item{position:relative;border-radius:10px;overflow:hidden;aspect-ratio:1}.patrol-photo-preview-item img{width:100%;height:100%;object-fit:cover}.patrol-photo-preview-item .remove-photo{position:absolute;top:5px;right:5px;background:#e77055e6;border:none;color:#fff;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center}.patrol-photo-preview-item .photo-type-label{position:absolute;bottom:0;left:0;right:0;background:#000000b3;padding:4px;font-size:.7rem;text-align:center}.catalog-upload-area{border:2px dashed rgba(255,255,255,.3);border-radius:12px;padding:20px;text-align:center;cursor:pointer;transition:all .3s;margin-top:10px;background:#3498db1a}.catalog-upload-area:hover{border-color:#3498db;background:#3498db33}.catalog-upload-area .upload-icon{font-size:2rem;margin-bottom:8px}.catalog-upload-area p{color:var(--text-muted);font-size:.85rem;margin:0}.catalog-preview{margin-top:10px;padding:12px;background:#3498db26;border-radius:10px;display:none}.catalog-preview.active{display:flex;align-items:center;gap:10px}.catalog-preview .file-icon{font-size:1.5rem}.catalog-preview .file-name{flex:1;font-size:.85rem;color:#3498db;word-break:break-all}.catalog-preview .remove-btn{background:#e74c3c;border:none;color:#fff;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:.8rem}.catalog-current{display:flex;align-items:center;gap:10px;padding:12px;background:#2ecc7126;border-radius:10px;margin-bottom:10px}.catalog-link{flex:1;color:#2ecc71;text-decoration:none;font-size:.9rem}.catalog-link:hover{text-decoration:underline}.catalog-remove-btn{background:#e74c3c;border:none;color:#fff;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:.8rem}.equipment-catalog-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;background:#3498db33;border:1px solid #3498db;border-radius:8px;color:#3498db;font-size:.8rem;cursor:pointer;text-decoration:none;margin-top:8px;transition:all .3s}.equipment-catalog-btn:hover{background:#3498db4d}.photo-type-selector{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.photo-type-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:6px 12px;border-radius:8px;font-size:.8rem;cursor:pointer;transition:all .3s}.photo-type-btn:hover,.photo-type-btn.selected{background:var(--btn-primary-flat);border-color:#2a5a8f80}.photo-type-btn.has-photo{background:var(--success);border-color:var(--success)}.image-viewer-content{background:var(--primary-dark);width:100%;height:100%;max-width:100%;max-height:100%;display:flex;flex-direction:column;position:relative}.image-viewer-close{position:absolute;top:15px;left:15px;z-index:10;background:#00000080;border-radius:50%;width:40px;height:40px}.image-viewer-title{padding:15px 60px;text-align:center;font-size:1.1rem;font-weight:600;background:#0000004d}.image-viewer-container{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:10px;touch-action:none;-ms-touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.image-viewer-container img{max-width:100%;max-height:100%;object-fit:contain;border-radius:10px;transform-origin:center center;transition:transform .25s ease-out;will-change:transform;-webkit-user-drag:none}#imageViewer.active{touch-action:none}.image-viewer-zoom-hint{text-align:center;font-size:.7rem;color:#fff6;padding:4px;background:#0003}.viewer-btn-danger{background:#e74c3c!important}.viewer-btn-danger:hover{background:#c0392b!important}.image-viewer-actions{display:flex;gap:15px;padding:20px;justify-content:center;background:#0000004d}.viewer-btn{display:flex;flex-direction:column;align-items:center;gap:5px;background:var(--btn-primary);border:1px solid rgba(255,255,255,.1);padding:15px 30px;border-radius:12px;color:#fff;font-size:.9rem;cursor:pointer;transition:all .3s}.viewer-btn:hover{background:var(--btn-primary-hover);transform:scale(1.05)}.viewer-btn span:first-child{font-size:1.5rem}.empty-state{text-align:center;padding:50px 20px;color:var(--text-muted);animation:emptyFadeIn .4s ease}@keyframes emptyFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.empty-state .icon{font-size:3.5rem;margin-bottom:15px;opacity:.7;width:100px;height:100px;line-height:100px;border-radius:50%;background:#00b4d80f;display:inline-block;animation:emptyIconPulse 2s ease-in-out infinite}@keyframes emptyIconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.empty-state p{font-size:.9rem;line-height:1.6;margin:0}.empty-state .empty-action-btn{display:inline-block;margin-top:14px;padding:10px 24px;background:var(--btn-primary, linear-gradient(135deg, #1e3a5f, #2a5a8f));color:#fff;border:none;border-radius:12px;font-size:.85rem;font-weight:600;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.empty-state .empty-action-btn:active{transform:scale(.96)}.empty-state .empty-sub{font-size:.78rem;color:var(--text-muted);opacity:.7;margin-top:8px}.upload-progress-bar{width:100%;height:4px;background:#ffffff1a;border-radius:2px;margin-top:8px;overflow:hidden;display:none}.upload-progress-bar.active{display:block}.upload-progress-fill{height:100%;background:linear-gradient(90deg,#3498db,#2ecc71);border-radius:2px;transition:width .2s;width:0%}.upload-progress-text{font-size:.7rem;color:var(--text-muted);text-align:center;margin-top:4px;display:none}.upload-progress-text.active{display:block}.field-error{display:block;font-size:.73rem;color:var(--danger, #e74c3c);margin-top:4px;padding-right:2px;opacity:0;max-height:0;overflow:hidden;transition:opacity .2s,max-height .2s}.field-error.visible{opacity:1;max-height:30px}.form-group input.invalid,.form-group select.invalid,.form-group textarea.invalid{border-color:var(--danger, #e74c3c);box-shadow:0 0 0 2px #e74c3c1f}.char-counter{font-size:.7rem;color:var(--text-muted);text-align:left;margin-top:3px;opacity:.7}.char-counter.near-limit{color:var(--warning, #f39c12);opacity:1}.char-counter.at-limit{color:var(--danger, #e74c3c);opacity:1;font-weight:600}.activity-item[data-type=add],.activity-item[data-type=create]{border-right:3px solid #27ae60!important}.activity-item[data-type=edit],.activity-item[data-type=update]{border-right:3px solid #3498db!important}.activity-item[data-type=delete]{border-right:3px solid #e74c3c!important}.activity-item[data-type=issue]{border-right:3px solid #f39c12!important}.activity-item[data-type=login]{border-right:3px solid #9b59b6!important}.activity-item[data-type=sync_all],.activity-item[data-type=save-coast-guard-data],.activity-item[data-type=bulk_save]{border-right:3px solid #1abc9c!important}.stock-bar{height:4px;background:#ffffff14;border-radius:2px;margin-top:4px;overflow:hidden}.stock-bar-fill{height:100%;border-radius:2px;transition:width .3s}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text-muted);padding:6px 0;flex-wrap:wrap}.breadcrumb a{color:var(--accent);text-decoration:none;cursor:pointer}.breadcrumb a:hover{text-decoration:underline}.breadcrumb .sep{opacity:.4}.breadcrumb .current{color:var(--text-primary);font-weight:600}.save-success-overlay{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;z-index:99999;pointer-events:none}.save-success-check{width:70px;height:70px;border-radius:50%;background:#27ae60f2;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff;box-shadow:0 4px 20px #27ae6066;animation:successPop 1s ease forwards}.save-success-text{color:#27ae60;font-size:1rem;font-weight:700;text-shadow:0 1px 4px rgba(0,0,0,.3);animation:successTextFade 1s ease forwards}@keyframes successPop{0%{transform:scale(0);opacity:0}30%{transform:scale(1.2);opacity:1}50%{transform:scale(.95)}70%{transform:scale(1)}to{transform:scale(1);opacity:0}}@keyframes successTextFade{0%{opacity:0;transform:translateY(5px)}30%{opacity:1;transform:translateY(0)}70%{opacity:1}to{opacity:0}}#sync-indicator{display:inline-block;cursor:pointer}#sync-indicator.syncing{animation:syncPulse 1s ease-in-out infinite}@keyframes syncPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.form-fieldset{border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:12px;margin-bottom:12px;background:#ffffff04}.form-fieldset-legend{font-size:.78rem;font-weight:600;color:var(--accent);margin-bottom:8px;display:flex;align-items:center;gap:5px}[data-theme=light] .form-fieldset{border-color:#00000014;background:#00000004}.info-tip{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#00b4d826;color:var(--accent);font-size:.65rem;cursor:help;margin-right:4px;position:relative;vertical-align:middle}.info-tip:after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);right:50%;transform:translate(50%);background:var(--surface-strong, #1a2a4a);color:#fff;padding:6px 10px;border-radius:8px;font-size:.72rem;font-weight:400;white-space:nowrap;max-width:220px;white-space:normal;pointer-events:none;opacity:0;transition:opacity .2s;z-index:100;box-shadow:0 2px 8px #0000004d;line-height:1.4}.info-tip:hover:after,.info-tip:focus:after{opacity:1}.ripple-container{position:relative;overflow:hidden}.ripple-effect{position:absolute;border-radius:50%;background:#ffffff40;transform:scale(0);animation:rippleAnim .5s ease-out;pointer-events:none}@keyframes rippleAnim{to{transform:scale(4);opacity:0}}.warranty-calendar{margin-top:12px;padding:12px;background:#ffffff05;border-radius:10px;border:1px solid var(--border)}.warranty-cal-title{font-size:.85rem;font-weight:600;margin-bottom:10px;display:flex;align-items:center;gap:6px}.warranty-cal-item{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:.8rem}.warranty-cal-item:last-child{border-bottom:none}.warranty-cal-bar{flex:1;height:6px;background:#ffffff0f;border-radius:3px;overflow:hidden;min-width:60px}.warranty-cal-fill{height:100%;border-radius:3px;transition:width .3s}.warranty-cal-date{font-size:.7rem;color:var(--text-muted);min-width:70px;text-align:left}.warranty-cal-label{min-width:100px;font-weight:500}@media(prefers-contrast:more){:root{--border: rgba(255,255,255,.4);--text-muted: rgba(255,255,255,.8);--text-secondary: rgba(255,255,255,.85)}.card,.stat-card,.modal-content{border-width:2px}.submit-btn,.add-btn,.filter-btn.active{border:2px solid #fff}.empty-state .icon{opacity:1}.form-group input,.form-group select,.form-group textarea{border-width:2px}}@media(prefers-contrast:more)and (prefers-color-scheme:light){:root{--border: rgba(0,0,0,.4);--text-muted: rgba(0,0,0,.7)}.submit-btn,.add-btn,.filter-btn.active{border-color:#000}}.section-header-sticky{position:sticky;top:0;z-index:15;background:var(--bg, #0a1628);margin:0 -16px;padding:8px 16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}[data-theme=light] .section-header-sticky{background:#f5f7faf2}.report-types{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:15px}.report-type-card{background:var(--card-bg);border:1px solid rgba(255,255,255,.1);border-radius:15px;padding:20px 15px;text-align:center;cursor:pointer;transition:all .3s}.report-type-card:hover{background:#00b4d833;border-color:var(--accent);transform:translateY(-2px)}.report-icon{font-size:2.5rem;margin-bottom:10px}.report-title{font-weight:700;margin-bottom:5px}.report-desc{font-size:.8rem;color:var(--text-muted)}.report-select{width:100%;padding:14px;border:1px solid rgba(255,255,255,.1);border-radius:12px;font-size:1rem;background:var(--card-bg);color:#fff}.report-select option{background:var(--primary-dark)}.report-preview{margin:15px;background:var(--card-bg);border:1px solid rgba(255,255,255,.1);border-radius:15px;overflow:hidden}.report-preview.hidden{display:none}.report-header-bar{background:linear-gradient(135deg,var(--primary) 0%,rgba(0,180,216,.3) 100%);padding:15px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}.report-header-bar h3{font-size:1.1rem}.report-actions{display:flex;gap:8px}.report-btn{background:var(--btn-primary);border:1px solid rgba(255,255,255,.1);color:#fff;padding:8px 15px;border-radius:20px;font-size:.85rem;cursor:pointer;display:flex;align-items:center;gap:5px}.report-btn:hover{background:var(--btn-primary-hover)}.report-content{padding:15px;max-height:60vh;overflow-y:auto}.report-section{margin-bottom:20px}.report-section-title{font-size:1rem;font-weight:700;margin-bottom:10px;padding-bottom:5px;border-bottom:1px solid rgba(255,255,255,.1);color:var(--accent)}.report-stat-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.05)}.report-stat-label{color:var(--text-muted)}.report-stat-value{font-weight:700}.report-item{background:#ffffff08;padding:12px;border-radius:10px;margin-bottom:10px}.report-item-header{display:flex;justify-content:space-between;margin-bottom:5px}.report-item-title{font-weight:700}.report-item-date{font-size:.8rem;color:var(--text-muted)}.report-item-desc{font-size:.9rem;color:var(--text-muted)}.summary-header{text-align:center;padding:20px 15px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:15px;margin-bottom:15px}.summary-patrol-number{font-size:1.8rem;font-weight:700;color:#fff}.summary-patrol-info{color:#ffffffb3;font-size:.9rem;margin-top:5px}.summary-warranty-badge{display:inline-block;padding:3px 12px;border-radius:20px;font-size:.8rem;margin-top:8px;font-weight:700}.summary-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:15px}.summary-stat-card{background:var(--card-bg);border-radius:12px;padding:12px 8px;text-align:center;border:1px solid rgba(255,255,255,.1)}.summary-stat-card .num{font-size:1.5rem;font-weight:700}.summary-stat-card .lbl{font-size:.7rem;color:var(--text-muted);margin-top:2px}.summary-section{background:var(--card-bg);border-radius:12px;padding:12px 15px;margin-bottom:12px;border:1px solid rgba(255,255,255,.1)}.summary-section h3{font-size:.95rem;margin-bottom:10px;color:var(--text)}.summary-problem-card{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:#e74c3c1a;border-radius:8px;margin-bottom:6px;border-right:3px solid var(--danger)}.summary-problem-card.has-note{border-right-color:var(--warning);background:#fdcb6e1a}.summary-problem-card .device-name{font-size:.85rem;font-weight:600}.summary-problem-card .device-detail{font-size:.75rem;color:var(--text-muted)}.summary-problem-card .status-badge{font-size:.7rem;padding:2px 8px;border-radius:10px;white-space:nowrap}.summary-need-card{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:#3498db1a;border-radius:8px;margin-bottom:6px;border-right:3px solid var(--accent)}.summary-need-card.urgent{border-right-color:var(--danger);background:#e74c3c1a}.summary-need-card .need-name{font-size:.85rem;font-weight:600}.summary-need-card .need-detail{font-size:.75rem;color:var(--text-muted)}.summary-timeline-item{padding:8px 10px;border-right:2px solid var(--accent);margin-bottom:6px;margin-right:5px}.summary-timeline-item .timeline-date{font-size:.7rem;color:var(--text-muted)}.summary-timeline-item .timeline-text{font-size:.85rem;color:var(--text)}.summary-full-detail-btn{display:block;width:100%;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;text-align:center;margin-top:15px}.summary-full-detail-btn:active{opacity:.8}.summary-empty{text-align:center;color:var(--text-muted);padding:15px;font-size:.85rem}@media(max-width:400px){.summary-stats-grid{grid-template-columns:repeat(2,1fr)}}@media print{body{background:#fff!important;color:#000!important;padding:0!important;max-width:100%!important;font-size:12pt!important}.header,.nav-tabs,.login-screen,.report-actions,.report-types,.report-select,.section-header button,.developer-credit,.add-btn,.submit-btn,.filter-buttons,.voice-cmd-btn,.ai-chat-btn,.scroll-top-btn,.toast,#global-upload-progress,.back-btn,.pull-refresh-indicator,.notifications-panel,.stat-card:after{display:none!important}.page{display:none!important}.page.active,#page-reports{display:block!important;padding:0!important}.card,.stat-card,.patrol-card,.equipment-card,.issue-card,.warranty-card,.permit-card,.company-card{background:#fff!important;border:1px solid #ddd!important;color:#000!important;box-shadow:none!important;break-inside:avoid}.stat-card .number,.stat-card .label,.stat-card .icon{color:#000!important}.duty-entry,.duty-accordion-content,.duty-shift-entry{background:#fff!important;border:1px solid #ccc!important;color:#000!important;break-inside:avoid}.issue-card{border-right:3px solid #999!important}.report-preview{display:block!important;margin:0!important;border:none!important;background:#fff!important}.report-header-bar{background:none!important;border-bottom:2px solid #333!important;color:#000!important}.report-content{max-height:none!important;color:#000!important}.report-section-title{color:#333!important}.report-stat-label,.report-item-desc,.report-item-date{color:#666!important}.report-item{background:#f5f5f5!important;border:1px solid #ddd!important}.section-header h2,.detail-header span{color:#000!important;font-size:14pt!important}*{color:#000!important}a{text-decoration:none!important}@page{margin:1.5cm;size:A4}.modal-overlay,.context-menu,.action-sheet-backdrop,.ai-chat-panel,.global-search-results,#toast-live-region{display:none!important}*{box-shadow:none!important}table{word-break:break-word}pre,code{white-space:pre-wrap!important}.badge,.status-badge{border:1px solid #999!important;padding:2px 6px!important}}.timeline-container{position:relative;padding:10px 0}.timeline-container:before{content:"";position:absolute;right:20px;top:0;bottom:0;width:3px;background:#ffffff1a;border-radius:3px}.timeline-item{position:relative;padding:15px 15px 15px 50px;margin-bottom:15px;background:var(--card-bg);border:1px solid rgba(255,255,255,.1);border-radius:12px;margin-right:35px}.timeline-item:before{content:"";position:absolute;right:-27px;top:20px;width:16px;height:16px;border-radius:50%;border:3px solid var(--primary-dark)}.timeline-item:after{content:"";position:absolute;right:-35px;top:24px;width:20px;height:3px}.timeline-item.event-positive:before{background:var(--success);box-shadow:0 0 10px var(--success)}.timeline-item.event-positive{border-right:4px solid var(--success)}.timeline-item.event-negative:before{background:var(--danger);box-shadow:0 0 10px var(--danger)}.timeline-item.event-negative{border-right:4px solid var(--danger)}.timeline-item.event-neutral:before{background:var(--warning);box-shadow:0 0 10px var(--warning)}.timeline-item.event-neutral{border-right:4px solid var(--warning)}.timeline-date{font-size:.8rem;color:var(--accent);margin-bottom:5px;font-weight:700}.timeline-type{display:inline-block;padding:3px 10px;border-radius:15px;font-size:.75rem;margin-bottom:8px}.event-positive .timeline-type{background:#00b89433;color:var(--success)}.event-negative .timeline-type{background:#e1705533;color:var(--danger)}.event-neutral .timeline-type{background:#fdcb6e33;color:var(--warning)}.timeline-title{font-weight:700;margin-bottom:5px;font-size:1rem}.timeline-desc{font-size:.9rem;color:var(--text-muted);line-height:1.5}.timeline-actions{display:flex;gap:10px;margin-top:10px}.timeline-action-btn{background:#ffffff1a;border:none;color:var(--text-muted);padding:5px 12px;border-radius:15px;font-size:.8rem;cursor:pointer}.timeline-action-btn:hover{background:#fff3;color:var(--text)}.timeline-empty{text-align:center;padding:40px 20px;color:var(--text-muted)}.timeline-empty .icon{font-size:3rem;margin-bottom:10px;opacity:.5}.timeline-images{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}.timeline-image{width:70px;height:70px;border-radius:10px;overflow:hidden;cursor:pointer;border:2px solid rgba(255,255,255,.1);transition:all .3s}.timeline-image:hover{border-color:var(--accent);transform:scale(1.05)}.timeline-image img{width:100%;height:100%;object-fit:cover}.login-screen{position:fixed;inset:0;background:linear-gradient(160deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);display:flex;align-items:center;justify-content:center;z-index:9999}.login-screen:before{content:"";position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(0,180,216,.15) 0%,rgba(102,126,234,.05) 40%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;animation:loginGlow 4s ease-in-out infinite alternate}@keyframes loginGlow{0%{opacity:.7;transform:translate(-50%,-50%) scale(1)}to{opacity:1;transform:translate(-50%,-50%) scale(1.1)}}.login-bg-shapes{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}.login-shape{position:absolute;border-radius:50%;opacity:.07;filter:blur(40px)}.login-shape-1{width:300px;height:300px;background:#1e3a5f;top:-50px;right:-50px;animation:loginFloat1 8s ease-in-out infinite alternate}.login-shape-2{width:200px;height:200px;background:#00b4d8;bottom:10%;left:-30px;animation:loginFloat2 10s ease-in-out infinite alternate}.login-shape-3{width:150px;height:150px;background:#2a5a8f;top:40%;right:20%;animation:loginFloat3 12s ease-in-out infinite alternate}@keyframes loginFloat1{0%{transform:translate(0)}to{transform:translate(-30px,30px)}}@keyframes loginFloat2{0%{transform:translate(0)}to{transform:translate(20px,-20px)}}@keyframes loginFloat3{0%{transform:translate(0)}to{transform:translate(-15px,15px)}}.password-group{position:relative}.password-toggle{position:absolute;left:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:1.1rem;padding:4px;opacity:.6;transition:opacity .2s}.password-toggle:hover{opacity:1}.remember-me{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-muted);margin-bottom:16px;cursor:pointer;justify-content:flex-end}.remember-me input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent)}.login-btn.loading{pointer-events:none;opacity:.7}.login-btn.loading:after{content:"";display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;margin-right:8px;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.login-screen.hidden{display:none}.login-box{background:#ffffff0f;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-xl);padding:40px 32px;width:calc(100% - 32px);max-width:420px;text-align:center;box-shadow:var(--shadow-lg),0 0 80px #00b4d814;position:relative;z-index:1;animation:loginCardIn .5s ease-out}.login-logo{width:100px;height:100px;margin:0 auto 20px;display:block;filter:drop-shadow(0 4px 12px rgba(0,180,216,.25))}.login-logo img{width:100%;height:100%;object-fit:contain}.login-title{font-size:1.4rem;font-weight:700;letter-spacing:.5px;margin-bottom:8px;color:var(--text-primary)}.login-subtitle{color:var(--text-muted);margin-bottom:28px;font-size:.88rem;line-height:1.5}.login-form .form-group{margin-bottom:20px;text-align:right}.login-form input{width:100%;padding:14px 16px;height:50px;border:1px solid var(--border-default);border-radius:var(--radius-md);background:#ffffff0d;color:var(--text-primary);font-size:1rem;text-align:right;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast)}.login-form input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #00b4d826;background:#ffffff14}.login-form input::placeholder{color:var(--text-muted)}.login-btn{width:100%;padding:14px;height:50px;background:var(--btn-primary);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:#fff;font-size:1.05rem;font-weight:600;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast);box-shadow:var(--shadow-sm)}.login-btn:hover{background:var(--btn-primary-hover);transform:translateY(-1px);box-shadow:0 4px 15px #1e3a5f66}.login-btn:active{transform:translateY(0)}.login-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.login-error{background:#e06b6b1f;border:1px solid var(--danger);color:var(--danger);padding:12px 16px;border-radius:var(--radius-md);margin-bottom:20px;font-size:.9rem;display:none}.login-error.show{display:block}.login-register-section{margin-top:20px;padding-top:20px;border-top:1px solid var(--border-light)}.login-register-text{font-size:.85rem;color:var(--text-muted);margin-bottom:10px}.login-register-btn{background:var(--surface);border:1px solid var(--border-default);color:var(--text-primary);padding:12px 25px;border-radius:var(--radius-md);font-size:.95rem;cursor:pointer;width:100%;transition:all var(--transition-fast)}.login-register-btn:hover{background:var(--surface-strong);border-color:#fff3;transform:translateY(-1px)}@keyframes loginCardIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.login-box{animation:none}.login-screen:before{animation:none}.login-shape,.onboarding-icon.highlight{animation:none}}@media(max-width:600px){.login-box{padding:32px 20px}.login-logo{width:80px;height:80px}.login-title{font-size:1.25rem}}.app-container.hidden{display:none}.logout-btn{background:#e770554d;color:#fff}.role-badge{background:#00b4d84d;color:#fff;padding:3px 8px;border-radius:15px;font-size:.75rem;font-weight:700;margin-left:3px}.user-card{background:var(--card-bg);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:15px;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between}.user-card .user-info{display:flex;align-items:center;gap:12px}.user-card .user-avatar{width:45px;height:45px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.user-card .user-details h4{margin:0;font-size:1rem}.user-card .user-details .user-role{font-size:.8rem;color:var(--text-muted)}.user-card .user-status{padding:4px 10px;border-radius:10px;font-size:.75rem}.user-card .user-status.active{background:#00b89433;color:#00b894}.user-card .user-status.inactive{background:#e7705533;color:#e17055}.perm-section{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:10px 12px;margin-bottom:8px}.perm-section-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-weight:600;font-size:.9rem}.perm-section-header .perm-icon{font-size:1.1rem}.perm-ops{display:flex;flex-wrap:wrap;gap:6px 14px;padding-right:24px}.perm-ops label{display:flex;align-items:center;gap:5px;font-size:.82rem;cursor:pointer;color:var(--text-secondary, #ccc)}.perm-ops input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent, #00b894);cursor:pointer}.issue-card{background:var(--card-bg);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:15px;margin-bottom:10px}.issue-card.status-pending{border-right:4px solid #fdcb6e}.issue-card.status-inprogress{border-right:4px solid #00b4d8}.issue-card.status-resolved{border-right:4px solid #00b894}.issue-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.issue-title{font-weight:700;font-size:1rem}.issue-status{padding:4px 10px;border-radius:10px;font-size:.75rem}.issue-meta{font-size:.8rem;color:var(--text-muted)}.lang-btn{background:#00b4d84d;font-size:.75rem;font-weight:700}html[dir=ltr]{direction:ltr;text-align:left}html[dir=ltr] .header-logo{margin-left:0;margin-right:10px}html[dir=ltr] .form-group,html[dir=ltr] .login-form .form-group,html[dir=ltr] input,html[dir=ltr] textarea,html[dir=ltr] select{text-align:left}.developer-credit{text-align:center;padding:15px;color:var(--text-muted);font-size:.8rem;border-top:1px solid rgba(255,255,255,.1);margin-top:20px}.login-credit{margin-top:24px;padding:12px 16px;background:#ffffff0a;border-radius:var(--radius-md);border:1px solid var(--border-light);font-size:.82rem;color:var(--text-muted);font-weight:500;line-height:1.6}.header-logo{width:28px;height:28px;object-fit:contain;margin-left:6px}.hidden{display:none!important}.pagination-controls{display:flex;justify-content:center;align-items:center;gap:6px;padding:15px 0;direction:ltr;flex-wrap:wrap}.pagination-controls button{background:var(--card-bg);border:1px solid rgba(255,255,255,.15);color:var(--text-primary);padding:6px 12px;border-radius:8px;cursor:pointer;font-size:.85rem;min-width:36px;transition:background .2s}.pagination-controls button:hover:not(:disabled){background:var(--accent);color:#fff}.pagination-controls button.active{background:var(--accent);color:#fff;font-weight:700}.pagination-controls button:disabled{opacity:.4;cursor:default}.pagination-info{text-align:center;color:var(--text-muted);font-size:.8rem;padding:5px 0}.photo-card.loading .photo-spinner{display:flex}.photo-card.loading img{opacity:0}.photo-card.loaded img{opacity:1;transition:opacity .3s ease}.photo-card.unavailable{background:#ffffff0d;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:120px}.photo-card.unavailable img{display:none}.photo-card.unavailable .unavailable-icon{font-size:2rem;opacity:.5}.photo-spinner{display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:30px;height:30px;border:3px solid rgba(255,255,255,.2);border-top:3px solid var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}.needs-category-section{margin-bottom:15px}.needs-category-header{background:var(--card-bg);padding:12px 15px;border-radius:10px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;margin-bottom:5px}.needs-category-header:hover{background:#ffffff1a}.needs-category-header h4{display:flex;align-items:center;gap:8px;font-size:.95rem}.needs-category-header .urgent-badge{color:#e74c3c;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.needs-category-content{padding-right:10px}.needs-category-content.collapsed{display:none}.needs-category-header.collapsed .toggle-icon{transform:rotate(-90deg)}.need-card.clickable{cursor:pointer;transition:transform .2s,box-shadow .2s}.need-card.clickable:hover{transform:translate(-5px);box-shadow:0 4px 15px #0000004d}.need-card.highlighted{border:2px solid var(--accent);animation:highlightPulse 2s ease-in-out}@keyframes highlightPulse{0%,to{box-shadow:0 0 #00b4d866}50%{box-shadow:0 0 20px 5px #00b4d866}}.page{display:none;padding:15px;opacity:0;transform:translateY(8px)}.page.active{display:block;opacity:1;transform:translateY(0)}input[type=file]{display:none}.company-card{background:var(--card-bg);border-radius:12px;padding:15px;margin-bottom:10px;cursor:pointer;transition:transform .2s,box-shadow .2s}.company-card:hover{transform:translate(-5px);box-shadow:0 4px 15px #0000004d}.company-card .company-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.company-card .company-name{font-weight:700;font-size:1.05rem}.company-card .company-type-badge{padding:4px 10px;border-radius:15px;font-size:.75rem;font-weight:700}.company-card .company-type-badge.local{background:#2ecc7133;color:#2ecc71}.company-card .company-type-badge.international{background:#3498db33;color:#3498db}.company-card .company-details{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;font-size:.85rem;color:#ffffffb3}.company-card .company-details .detail-item{display:flex;align-items:center;gap:5px}.company-card .specialty-badge{display:inline-block;padding:2px 8px;background:#9b59b633;color:#9b59b6;border-radius:10px;font-size:.75rem;margin-top:8px}.company-actions{display:flex;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,.1)}.company-action-btn{flex:1;padding:8px;border:none;border-radius:8px;cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center;gap:5px;transition:background .2s}.company-action-btn.whatsapp,.company-action-btn.call,.company-action-btn.email{background:#1e3a5f4d;color:#7ba7d4}.company-action-btn.whatsapp:hover,.company-action-btn.call:hover,.company-action-btn.email:hover{background:#1e3a5f80}.quotation-card{background:var(--card-bg);border-radius:12px;padding:15px;margin-bottom:10px;cursor:pointer;transition:transform .2s,box-shadow .2s;border-right:4px solid var(--accent)}.quotation-card:hover{transform:translate(-5px);box-shadow:0 4px 15px #0000004d}.quotation-card.status-new{border-right-color:#9b59b6}.quotation-card.status-reviewing{border-right-color:#f39c12}.quotation-card.status-approved{border-right-color:#2ecc71}.quotation-card.status-rejected{border-right-color:#e74c3c}.quotation-card.status-paid{border-right-color:#3498db}.quotation-card.status-received{border-right-color:#1abc9c}.quotation-card .quotation-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.quotation-card .quotation-title{font-weight:700;font-size:.95rem;flex:1}.quotation-card .quotation-amount{font-weight:700;font-size:1.1rem;color:var(--accent)}.quotation-card .quotation-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:.8rem;color:#fff9}.quotation-card .quotation-status{display:inline-block;padding:3px 10px;border-radius:12px;font-size:.75rem;font-weight:700}.quotation-status.new{background:#9b59b633;color:#9b59b6}.quotation-status.reviewing{background:#f39c1233;color:#f39c12}.quotation-status.approved{background:#2ecc7133;color:#2ecc71}.quotation-status.rejected{background:#e74c3c33;color:#e74c3c}.quotation-status.paid{background:#3498db33;color:#3498db}.quotation-status.received{background:#1abc9c33;color:#1abc9c}.quotation-link-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:#00b4d826;border-radius:10px;font-size:.75rem;color:var(--accent)}#page-companies .stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:15px}#page-companies .stat-card{background:var(--card-bg);border-radius:10px;padding:12px;text-align:center}#page-companies .stat-card .icon{font-size:1.5rem;margin-bottom:5px}#page-companies .stat-card .number{font-size:1.3rem;font-weight:700;color:var(--accent)}#page-companies .stat-card .label{font-size:.75rem;color:#fff9}#followup-dashboard{margin-bottom:12px!important}#followup-dashboard h3{font-size:.9rem;margin-bottom:8px!important}#followup-dashboard .stats-grid{gap:6px;padding:0}#followup-dashboard .stat-card{padding:8px 4px;border-radius:10px}#followup-dashboard .stat-card .icon{font-size:1.1rem;margin-bottom:2px}#followup-dashboard .stat-card .number{font-size:1.1rem;margin-bottom:1px}#followup-dashboard .stat-card .label{font-size:.68rem}#page-issues .section-header{flex-direction:column;align-items:flex-end;gap:8px}#page-issues .section-header h2{width:100%}.warranty-card{background:var(--card-bg);border-radius:12px;padding:15px;margin-bottom:10px;cursor:pointer;transition:transform .2s,box-shadow .2s;border-right:4px solid #9b59b6}.warranty-card:hover{transform:translate(-5px);box-shadow:0 4px 15px #0000004d}.warranty-card.status-active{border-right-color:#2ecc71}.warranty-card.status-expiring{border-right-color:#f39c12}.warranty-card.status-expired{border-right-color:#e74c3c}.warranty-card .warranty-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.warranty-card .warranty-title{font-weight:700;font-size:.95rem;flex:1}.warranty-card .warranty-status{padding:3px 10px;border-radius:12px;font-size:.75rem;font-weight:700}.warranty-status.active{background:#2ecc7133;color:#2ecc71}.warranty-status.expiring{background:#f39c1233;color:#f39c12}.warranty-status.expired{background:#e74c3c33;color:#e74c3c}.warranty-card .warranty-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:.8rem;color:#fff9}.warranty-days-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.75rem;font-weight:700}.warranty-days-badge.safe{background:#2ecc7133;color:#2ecc71}.warranty-days-badge.warning{background:#f39c1233;color:#f39c12}.warranty-days-badge.danger{background:#e74c3c33;color:#e74c3c}.warranty-progress-bar{width:100%;height:6px;background:#ffffff14;border-radius:3px;margin-top:10px;overflow:hidden}.warranty-progress-fill{height:100%;border-radius:3px;transition:width .6s ease}.warranty-progress-fill.safe{background:linear-gradient(90deg,#27ae60,#2ecc71)}.warranty-progress-fill.warning{background:linear-gradient(90deg,#e67e22,#f39c12)}.warranty-progress-fill.danger{background:linear-gradient(90deg,#c0392b,#e74c3c)}.warranty-end-date{font-size:.72rem;color:#ffffff73;margin-right:4px}.permit-card{background:var(--card-bg);border-radius:12px;padding:15px;margin-bottom:10px;cursor:pointer;transition:transform .2s,box-shadow .2s;border-right:4px solid #e67e22}.permit-card:hover{transform:translate(-5px);box-shadow:0 4px 15px #0000004d}.permit-card.status-active{border-right-color:#2ecc71}.permit-card.status-expired{border-right-color:#e74c3c}.permit-card .permit-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.permit-card .permit-title{font-weight:700;font-size:.95rem;flex:1}.permit-card .permit-status{padding:3px 10px;border-radius:12px;font-size:.75rem;font-weight:700}.permit-status.active{background:#2ecc7133;color:#2ecc71}.permit-status.expired{background:#e74c3c33;color:#e74c3c}.permit-card .permit-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:.8rem;color:#fff9}.permit-card .permit-person{display:flex;align-items:center;gap:5px;margin-top:8px;padding:8px;background:#ffffff0d;border-radius:8px}.permit-template-card:hover{transform:scale(1.02);transition:transform .2s}.person-card,.vehicle-card{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:8px;transition:transform .15s,box-shadow .15s}.person-card:hover,.vehicle-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0003}.permit-form-preview{background:#fff;color:#333;padding:20px;border-radius:8px;direction:rtl}.permit-form-preview h2{text-align:center;border-bottom:2px solid #333;padding-bottom:10px;margin-bottom:15px}.permit-form-preview .form-field{margin-bottom:10px;display:flex;align-items:center;gap:10px}.permit-form-preview .form-field label{min-width:120px;font-weight:700}.permit-form-preview .form-field .value{flex:1;border-bottom:1px solid #999;padding:5px;min-height:25px}.notepad-textarea{flex:1;width:100%;border:none;outline:none;resize:none;padding:16px;font-size:1rem;font-family:inherit;line-height:1.8;direction:rtl;background:var(--bg-primary, #fff);color:var(--text-primary, #333)}.notepad-textarea::placeholder{color:#aaa}#notepad-save-status.saved{color:#ffffffe6}.global-search-wrapper{padding:8px 15px;background:var(--bg-primary);position:relative;z-index:100}.global-search-bar{display:flex;gap:8px;align-items:center}.global-search-input-wrap{flex:1;position:relative}.global-search-input-wrap input{width:100%;padding:10px 35px 10px 12px;border:1px solid var(--border-default);border-radius:var(--radius-sm);font-size:.9rem;background:var(--surface);color:var(--text-primary);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.global-search-input-wrap input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #00b4d81a}.global-search-input-wrap .global-search-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:1rem;opacity:.5;pointer-events:none}.global-search-input-wrap .global-search-clear{position:absolute;left:8px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--text-muted);display:none;padding:2px 4px}.global-search-scope{padding:10px 8px;border:1px solid var(--border-default);border-radius:var(--radius-sm);font-size:.8rem;background:var(--surface);color:var(--text-primary);cursor:pointer;min-width:110px}.global-search-results{position:absolute;top:100%;left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-md);margin-top:6px;max-height:350px;overflow-y:auto;display:none;box-shadow:var(--shadow-lg);z-index:200}.global-search-results.active{display:block}.global-result-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border-light)}.global-result-item:last-child{border-bottom:none}.global-result-item:hover{background:var(--surface-strong)}.global-result-item .result-icon{font-size:1.3rem;flex-shrink:0}.global-result-item .result-info{flex:1;min-width:0}.global-result-item .result-title{font-size:.9rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.global-result-item .result-subtitle{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.global-search-no-results{padding:16px;text-align:center;color:var(--text-muted);font-size:.85rem}.page.active{animation:pageFadeIn .25s ease}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.skeleton-container{padding:10px;animation:skeletonFadeIn .2s ease}@keyframes skeletonFadeIn{0%{opacity:0}to{opacity:1}}.skeleton{background:linear-gradient(90deg,var(--surface) 25%,rgba(255,255,255,.12) 50%,var(--surface) 75%);background-size:200% 100%;animation:skeletonShimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}.skeleton-card{height:80px;margin-bottom:10px;border-radius:var(--radius-lg)}.skeleton-stat{height:90px;border-radius:var(--radius-lg);flex:1;min-width:0}.skeleton-stat-row{display:flex;gap:8px;margin-bottom:12px}.skeleton-text,.skeleton-line{height:14px;width:60%;margin-bottom:8px}.skeleton-text.short,.skeleton-line.w50{width:40%}@keyframes skeletonShimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.btn-saving{pointer-events:none;opacity:.75}.btn-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:btnSpin .6s linear infinite;vertical-align:middle}@keyframes btnSpin{to{transform:rotate(360deg)}}.scroll-top-btn{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom,0px));right:20px;width:44px;height:44px;border-radius:50%;background:var(--btn-primary-flat);border:1px solid rgba(255,255,255,.15);color:#fff;font-size:1.2rem;cursor:pointer;z-index:999;opacity:0;visibility:hidden;transform:translateY(10px);transition:all var(--transition-normal);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center}.scroll-top-btn.show{opacity:1;visibility:visible;transform:translateY(0)}.scroll-top-btn:hover{background:var(--btn-primary-hover);box-shadow:0 4px 15px #1e3a5f66;transform:translateY(-2px)}.form-group input:focus:invalid,.form-group select:focus:invalid,.form-group textarea:focus:invalid{border-color:var(--danger);box-shadow:0 0 0 3px #e170551f}.form-group input:not(:placeholder-shown):valid{border-left:3px solid var(--success)}.form-group textarea:not(:placeholder-shown):valid{border-left:3px solid var(--success)}.char-counter{display:block;text-align:left;font-size:.75rem;color:var(--text-muted);margin-top:4px;opacity:.7}.char-counter.warning{color:var(--warning);opacity:1}.char-counter.danger{color:var(--danger);opacity:1}.card-animate{opacity:0;transform:translateY(15px);animation:cardEnter .4s ease forwards}.card-animate:nth-child(1){animation-delay:.03s}.card-animate:nth-child(2){animation-delay:.06s}.card-animate:nth-child(3){animation-delay:.09s}.card-animate:nth-child(4){animation-delay:.12s}.card-animate:nth-child(5){animation-delay:.15s}.card-animate:nth-child(6){animation-delay:.18s}.card-animate:nth-child(7){animation-delay:.21s}.card-animate:nth-child(8){animation-delay:.24s}.card-animate:nth-child(9){animation-delay:.27s}.card-animate:nth-child(10){animation-delay:.3s}@keyframes cardEnter{to{opacity:1;transform:translateY(0)}}.offline-banner{display:none;background:linear-gradient(135deg,#e17055e6,#c0392be6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;padding:10px 15px;text-align:center;font-size:.85rem;font-weight:600;position:sticky;top:52px;z-index:99;border-bottom:1px solid rgba(255,255,255,.15);animation:slideDown .3s ease}.offline-banner.show{display:flex;align-items:center;justify-content:center;gap:8px}.online-banner{display:none;background:linear-gradient(135deg,#00b894e6,#009678e6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;padding:10px 15px;text-align:center;font-size:.85rem;font-weight:600;position:sticky;top:52px;z-index:99;animation:slideDown .3s ease}.online-banner.show{display:flex;align-items:center;justify-content:center;gap:8px}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.image-viewer-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:1.3rem;cursor:pointer;z-index:10;display:none;align-items:center;justify-content:center;transition:all var(--transition-fast)}.image-viewer-nav:hover{background:#000000b3;border-color:#fff6}.image-viewer-nav.prev{right:15px}.image-viewer-nav.next{left:15px}.image-viewer-counter{position:absolute;top:15px;right:60px;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);padding:6px 14px;border-radius:var(--radius-pill);font-size:.8rem;color:#fff;z-index:10;display:none}.pull-refresh-indicator{position:fixed;top:-60px;left:50%;transform:translate(-50%);width:44px;height:44px;border-radius:50%;background:var(--bg-secondary);border:1px solid var(--border-default);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;font-size:1.2rem;z-index:9999;transition:top .2s ease}.pull-refresh-indicator.pulling{top:70px}.pull-refresh-indicator.refreshing{top:70px;animation:spin 1s linear infinite}body{letter-spacing:.2px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.stat-card .label,.patrol-stat,.equipment-details .model,.need-desc,.doc-details .doc-meta,.notification-item .notif-desc,.activity-content .activity-desc{line-height:1.5}.stat-card .number{letter-spacing:-.5px}.patrol-info h3,.detail-header-title,.modal-header h3{letter-spacing:.3px}:root{--status-new: #3498db;--status-in-progress: #f39c12;--status-follow-up: #e67e22;--status-follow-up-company: #9b59b6;--status-completed: #27ae60;--status-rejected: #e74c3c;--shift-1: #3498db;--shift-2: #27ae60;--shift-3: #9b59b6}.onboarding-overlay{position:fixed;inset:0;background:#000000d9;z-index:99999;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s}.onboarding-overlay.active{opacity:1;visibility:visible}.onboarding-card{background:#1e283cf2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:40px 30px 30px;max-width:400px;width:90%;text-align:center;position:relative;border:1px solid rgba(255,255,255,.1);box-shadow:0 20px 60px #00000080;animation:onboardSlideUp .5s ease}@keyframes onboardSlideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.onboarding-skip{position:absolute;top:12px;left:12px;background:#ffffff1a;border:none;color:#fff9;padding:6px 16px;border-radius:20px;cursor:pointer;font-size:.85rem;transition:background .2s,color .2s}.onboarding-skip:hover{background:#fff3;color:#fff}.onboarding-icon{font-size:3.5rem;margin-bottom:16px;display:block}.onboarding-title{font-size:1.4rem;font-weight:700;color:#fff;margin-bottom:12px}.onboarding-desc{font-size:1rem;color:#ffffffb3;line-height:1.7;margin-bottom:24px;white-space:pre-line}.onboarding-icon.highlight{animation:onboardPulse 2s ease-in-out infinite}@keyframes onboardPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.onboarding-dots{display:flex;justify-content:center;gap:8px;margin-bottom:20px}.onboarding-dot{width:10px;height:10px;border-radius:50%;background:#fff3;transition:background .3s,transform .3s;cursor:pointer}.onboarding-dot.active{background:var(--accent, #3498db);transform:scale(1.3)}.onboarding-actions{display:flex;gap:10px;justify-content:center}.onboarding-actions button{padding:10px 28px;border-radius:12px;border:none;font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .2s,opacity .2s}.onboarding-actions button:active{transform:scale(.96)}#onboardingNext{background:linear-gradient(135deg,var(--accent, #3498db),#2980b9);color:#fff}#onboardingPrev{background:#ffffff1a;color:#ffffffb3}#onboardingPrev:hover{background:#ffffff26}#onboardingPrev.hidden-btn{opacity:0;pointer-events:none}.skip-link{position:absolute;top:-50px;left:0;background:var(--accent, #3498db);color:#fff;padding:10px 20px;z-index:100000;font-size:.95rem;font-weight:600;border-radius:0 0 8px;text-decoration:none;transition:top .3s}.skip-link:focus{top:0}[data-theme=light] .warranty-active{background:#2ecc711a;color:#27ae60}[data-theme=light] .warranty-expiring{background:#f39c121a;color:#e67e22}[data-theme=light] .warranty-partial{background:#f39c1214;color:#d35400}[data-theme=light] .warranty-none{background:#e74c3c1a;color:#c0392b}[data-theme=light] body{background:linear-gradient(135deg,#e8ecf1,#dde3ea);box-shadow:0 0 50px #00000014}[data-theme=light] .header{background:linear-gradient(135deg,#4a90c4e6,#3b82b4e6);color:#fff}[data-theme=light] .header-btn{color:#fff;background:#ffffff26;border-color:#fff3}[data-theme=light] .login-screen{background:linear-gradient(160deg,#e8ecf1,#d5dce4)}[data-theme=light] .login-box{background:#ffffffd9;border-color:#00000014}[data-theme=light] .login-title,[data-theme=light] .login-subtitle,[data-theme=light] .login-credit{color:#2c3e50}[data-theme=light] .login-form input{background:#0000000a;border-color:#0000001f;color:#1a1a2e}[data-theme=light] .login-btn{background:var(--btn-primary)}[data-theme=light] .modal-content{background:#fffffff2;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-color:#00000014}[data-theme=light] .modal-header{color:#fff}[data-theme=light] .nav-tabs{background:#ffffffe6;border-top-color:#00000014}[data-theme=light] .nav-tab{color:#00000080}[data-theme=light] .nav-tab.active{color:var(--accent)}[data-theme=light] .toast{background:#fffffff2;color:#1a1a2e;border-color:#00000014}[data-theme=light] .ai-chat-panel{background:#fffffffa}[data-theme=light] .ai-chat-messages .user-msg{background:var(--accent);color:#fff}[data-theme=light] .ai-chat-messages .ai-msg{background:#0000000d;color:#1a1a2e}[data-theme=light] .notifications-panel{background:#fffffffa;color:#1a1a2e}[data-theme=light] .detail-header{background:linear-gradient(135deg,#4a90c4e6,#3b82b4e6);color:#fff}[data-theme=light] .global-search-results{background:#fffffffa;border-color:#0000001a}[data-theme=light] .global-search-result-item:hover{background:#00b4d814}[data-theme=light] .filter-btn{background:#0000000d;color:#1a1a2e;border-color:#0000001a}[data-theme=light] .filter-btn.active{background:var(--btn-primary);color:#fff}[data-theme=light] .stat-card,[data-theme=light] .card{background:#ffffffd9;border-color:#0000000f}[data-theme=light] input,[data-theme=light] select,[data-theme=light] textarea{background:#00000008;border-color:#0000001f;color:#1a1a2e}[data-theme=light] input::placeholder,[data-theme=light] textarea::placeholder{color:#0006;opacity:1}[data-theme=light] .report-content{background:#ffffffe6;color:#1a1a2e}[data-theme=light] .onboarding-card{background:#fffffff2;color:#1a1a2e;border-color:#00000014}[data-theme=light] .login-register-btn{color:var(--accent);border-color:var(--accent)}[data-theme=light] .login-register-text{color:#00000080}.theme-toggle-btn{background:var(--surface);border:1px solid var(--border-light);color:#fff;width:32px;height:32px;border-radius:var(--radius-sm);font-size:1rem;cursor:pointer;transition:background var(--transition-fast);display:flex;align-items:center;justify-content:center}.theme-toggle-login{position:absolute;top:15px;right:15px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;width:36px;height:36px;border-radius:50%;font-size:1.1rem;cursor:pointer;z-index:10;transition:background .2s;display:flex;align-items:center;justify-content:center}[data-theme=light] .theme-toggle-login{background:#00000014;border-color:#0000001f;color:#1a1a2e}body,.header,.login-screen,.login-box,.modal-content,.nav-tabs,.card,.stat-card,.toast,.ai-chat-panel,.notifications-panel,.global-search-results,.filter-btn{transition:background .3s ease,color .3s ease,border-color .3s ease}.skeleton-container{padding:12px}.skeleton{background:linear-gradient(90deg,var(--surface) 0%,var(--surface-strong) 40%,var(--surface) 80%);background-size:300% 100%;animation:shimmer 1.8s infinite ease-in-out;border-radius:var(--radius-md)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{height:90px;margin-bottom:10px;border-radius:var(--radius-md)}.skeleton-stat-row{display:flex;gap:10px;margin-bottom:10px}.skeleton-stat{flex:1;height:70px;border-radius:var(--radius-md)}.skeleton-line{height:14px;margin-bottom:8px;border-radius:6px}.skeleton-line.w75{width:75%}.skeleton-line.w50{width:50%}.skeleton-line.w30{width:30%}[data-theme=light] .skeleton{background:linear-gradient(90deg,#0000000f,#0000001f,#0000000f 80%);background-size:300% 100%;animation:shimmer 1.8s infinite ease-in-out}.form-group label .required,.required-star{color:var(--danger);font-weight:700;margin-right:2px}@media(pointer:coarse){.filter-btn{min-height:44px;padding:8px 12px;font-size:.82rem}.tab-btn{min-height:44px;padding:8px 14px;font-size:.82rem}.header-btn{width:44px;height:44px;font-size:1rem}.nav-tab{min-height:52px;padding:10px 2px 8px}.duty-shift-btn,.photo-type-btn{min-height:44px;padding:8px 14px}.submit-btn,.add-btn{min-height:46px}.duty-toggle-done-btn{min-height:44px;padding:8px 14px}.company-action-btn{min-height:44px}.back-btn{min-height:44px;min-width:44px}}:focus-visible{outline:2px solid var(--accent, #3498db);outline-offset:2px;box-shadow:0 0 0 4px #00b4d826}:focus:not(:focus-visible){outline:none;box-shadow:none}button:focus-visible,.submit-btn:focus-visible,.add-btn:focus-visible,.filter-btn:focus-visible{outline:2px solid #fff;outline-offset:2px;box-shadow:0 0 0 4px #00b4d84d}.more-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:12px 15px;border:none;background:transparent;color:var(--text);font-size:.95rem;cursor:pointer;border-radius:8px;transition:background .2s;text-align:right}.more-menu-item:hover{background:#ffffff1a}.more-menu-item span{font-size:1.2rem}.nav-tab-more{flex:1}.more-menu-item-h{display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 12px;border:none;background:#ffffff0d;color:var(--text);font-size:.8rem;cursor:pointer;border-radius:10px;transition:background .2s}.more-menu-item-h:hover{background:#ffffff26}.more-menu-item-h span{font-size:1.3rem}.more-menu-item-h small{font-size:.7rem;opacity:.8}::-webkit-scrollbar{width:0;height:0}.nav-tab,.header,.card,.stat-card,button,.filter-btn,.tab-btn,.section-header{user-select:none;-webkit-user-select:none}button,a,.nav-tab,.card,.filter-btn,.tab-btn,.btn,.submit-btn,.add-btn,.back-btn,.company-action-btn,.equipment-card,.company-card,.patrol-card,.duty-log-entry,input,select,textarea,label{touch-action:manipulation}button:active,.nav-tab:active,.card:active,.filter-btn:active,.tab-btn:active,.btn:active{transform:scale(.96);opacity:.85;transition:transform .08s ease,opacity .08s ease}.header-btn:active{transform:scale(.9);transition:transform .08s ease}.equipment-card:active,.company-card:active,.patrol-card:active,.duty-log-entry:active,.duty-followup-entry:active{transform:scale(.98);opacity:.92;transition:transform .1s ease,opacity .1s ease}.submit-btn:active,.add-btn:active,.login-btn:active{transform:scale(.95);filter:brightness(.9);transition:transform .08s ease,filter .08s ease}.card,.equipment-card,.company-card,.patrol-card{transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease}.dashboard-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media(max-width:600px){.dashboard-charts-grid{grid-template-columns:1fr}}.chart-card{background:var(--surface);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border-default);border-radius:var(--radius-md, 10px);padding:12px;transition:transform .2s,box-shadow .2s}.chart-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md, 0 4px 12px rgba(0,0,0,.15))}.chart-card-title{margin:0 0 8px;font-size:.85rem;color:var(--accent);text-align:center;font-weight:600}.chart-canvas-wrapper{position:relative;width:100%;height:220px}.chart-canvas-wrapper canvas{width:100%!important;height:100%!important}[data-theme=light] .chart-card{background:#ffffffd9;border-color:#0000000f}button,.btn,[role=button],a.nav-item,.action-btn,.tab-btn,.menu-item{min-height:44px;min-width:44px}@media(min-width:768px){.app-container,#appContainer{max-width:768px;margin:0 auto}}@media(min-width:1024px){.app-container,#appContainer{max-width:900px}}@media(pointer:fine){::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-secondary);border-radius:3px}}.context-menu-content{padding:16px 16px calc(16px + env(safe-area-inset-bottom,0px));max-width:400px}.context-menu-title{text-align:center;font-size:.95rem;font-weight:700;color:var(--text, #fff);padding:8px 0 14px;border-bottom:1px solid var(--border-default, rgba(255,255,255,.1));margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.context-menu-actions{display:flex;flex-direction:column;gap:6px}.context-menu-action{display:flex;align-items:center;gap:12px;padding:14px 16px;border:none;border-radius:12px;background:var(--card-bg, rgba(255,255,255,.05));color:var(--text, #fff);font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s;width:100%;text-align:right;font-family:inherit}.context-menu-action:active{transform:scale(.97)}.context-menu-action .ctx-icon{font-size:1.3rem;width:32px;text-align:center;flex-shrink:0}.context-menu-action.ctx-delete{color:#e74c3c}.context-menu-action.ctx-delete:hover,.context-menu-action.ctx-delete:active{background:#e74c3c26}.context-menu-action.ctx-edit{color:#3498db}.context-menu-action.ctx-edit:hover,.context-menu-action.ctx-edit:active{background:#3498db26}.context-menu-action.ctx-add{color:#27ae60}.context-menu-action.ctx-add:hover,.context-menu-action.ctx-add:active{background:#27ae6026}.context-menu-action.ctx-view{color:var(--accent, #00b4d8)}.context-menu-action.ctx-view:hover,.context-menu-action.ctx-view:active{background:#00b4d826}.context-menu-cancel{display:block;width:100%;margin-top:10px;padding:14px;border:none;border-radius:12px;background:#ffffff14;color:var(--text-muted, rgba(255,255,255,.6));font-size:1rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s}.context-menu-cancel:active{background:#ffffff26}.long-press-active{transform:scale(.96);opacity:.85;transition:transform .2s,opacity .2s}.pull-refresh-spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:pull-spin .6s linear infinite;vertical-align:middle;margin-left:6px}@keyframes pull-spin{to{transform:rotate(360deg)}}@supports (-webkit-touch-callout: none){@media(display-mode:standalone){html,body{overscroll-behavior:none;-webkit-overflow-scrolling:touch}.header{padding-top:calc(10px + env(safe-area-inset-top,20px))}}}@supports (-webkit-touch-callout: none){body{-webkit-text-size-adjust:100%;-webkit-overflow-scrolling:touch}.page,.modal-content{-webkit-overflow-scrolling:touch}.modal{overscroll-behavior:contain}.ai-chat-messages,.notifications-panel,.companies-list-container{-webkit-overflow-scrolling:touch}}body.keyboard-open .nav-tabs,body.keyboard-open .voice-cmd-btn,body.keyboard-open .ai-chat-btn{display:none!important}body.keyboard-open .modal-content{max-height:calc(100dvh - var(--keyboard-height, 0px))!important;transition:max-height .2s ease}body.keyboard-open .page{padding-bottom:10px!important}body.offline-mode:before{content:"⚠️ لا يوجد اتصال بالإنترنت";position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;text-align:center;padding:6px 12px;font-size:12px;font-weight:600;z-index:100002;font-family:Tajawal,sans-serif;max-width:430px;margin:0 auto;animation:slideDown .3s ease}body.offline-mode .header{margin-top:28px}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.page{will-change:transform,opacity}.page.page-enter{animation:pageSlideIn .28s cubic-bezier(.25,.46,.45,.94) forwards}.page.page-exit{animation:pageSlideOut .22s cubic-bezier(.55,.06,.68,.19) forwards}@keyframes pageSlideIn{0%{transform:translate(25px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes pageSlideOut{0%{transform:translate(0);opacity:1}to{transform:translate(-20px);opacity:0}}@media(prefers-reduced-motion:reduce){.page.page-enter,.page.page-exit{animation:none!important}}.insp-shift-history{display:flex;gap:6px;margin-bottom:8px}.insp-shift-card{flex:1;padding:8px;border-radius:8px;cursor:pointer;text-align:center;border:2px solid transparent;transition:border-color .15s}.insp-shift-card:active{opacity:.8}.insp-shift-done{background:#27ae601a;border-color:#27ae604d}.insp-shift-pending{background:var(--surface);border-color:var(--border)}.insp-shift-active{border-color:#5dade2!important;box-shadow:0 0 0 1px #5dade2}.insp-shift-num{font-weight:700;font-size:.88rem;color:var(--text);margin-bottom:2px}.insp-shift-info{font-size:.76rem;color:var(--text-secondary)}.insp-shift-by{font-size:.7rem;color:var(--text-secondary);opacity:.8;margin-top:2px}.insp-recent-section{margin:8px 0;padding:8px;background:var(--surface);border-radius:10px;border:1px solid var(--border)}.insp-recent-title{font-weight:700;font-size:.88rem;margin-bottom:6px;color:var(--text)}.insp-recent-tabs{display:flex;gap:4px;margin-bottom:8px}.insp-recent-tab{flex:1;padding:5px 8px;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text-secondary);font-size:.78rem;font-weight:600;cursor:pointer;text-align:center}.insp-recent-tab.active{background:var(--btn-primary-flat);color:#fff;border-color:var(--btn-primary-flat)}.insp-recent-cards{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.insp-recent-card{min-width:110px;max-width:140px;padding:8px;background:var(--background);border-radius:8px;border:1px solid var(--border);cursor:pointer;flex-shrink:0}.insp-recent-card:active{opacity:.7}.insp-recent-date{font-weight:700;font-size:.85rem;color:var(--text);margin-bottom:3px}.insp-recent-meta{font-size:.7rem;color:var(--text-secondary);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.insp-recent-bottom{font-size:.72rem;color:var(--text-secondary);display:flex;align-items:center;gap:4px;flex-wrap:wrap}.insp-recent-empty{font-size:.8rem;color:var(--text-muted);text-align:center;padding:12px}.insp-rbadge{display:inline-block;padding:1px 6px;border-radius:4px;font-size:.68rem;font-weight:600}.insp-rbadge-ok{background:#27ae6026;color:#27ae60}.insp-rbadge-warn{background:#f39c1226;color:#f39c12}.insp-rbadge-bad{background:#e74c3c26;color:#e74c3c}.insp-recent-overlay{position:fixed;inset:0;background:#0009;z-index:10000;display:flex;align-items:center;justify-content:center}.insp-recent-detail-box{background:var(--surface);border-radius:12px;width:90%;max-width:420px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.insp-recent-detail-header{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:var(--btn-primary-flat);color:#fff;font-weight:700;font-size:.9rem}.insp-recent-detail-list{overflow-y:auto;padding:8px}.insp-recent-detail-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-bottom:1px solid var(--border);font-size:.82rem}.insp-recent-detail-row:last-child{border-bottom:none}.insp-recent-detail-num{font-weight:700;min-width:44px;color:var(--text)}.insp-recent-detail-broken{font-size:.72rem;color:#e74c3c;margin-right:auto}.inspection-reminder{display:flex;align-items:center;gap:10px;padding:10px 14px;margin:8px 0;background:linear-gradient(135deg,#eaf4fc,#d6eaf8);border:1px solid #85c1e9;border-radius:10px}.inspection-reminder-icon{font-size:1.5rem;flex-shrink:0}.inspection-reminder-text{flex:1;font-size:.85rem;color:#1a5276;font-weight:600}.inspection-reminder-btn{padding:6px 14px;background:var(--btn-primary-flat);color:#fff;border:none;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap}.inspection-reminder-btn:active{opacity:.8}.inspection-reminder-close{background:none;border:none;font-size:1.2rem;color:#5d6d7e;cursor:pointer;padding:4px}.inspection-reminder-close:active{opacity:.6}.insp-toolbar{padding:8px}.insp-stats-text{font-size:.85rem;color:var(--text);margin-bottom:4px}.insp-progress-bar{height:8px;background:var(--surface);border-radius:4px;overflow:hidden;margin-bottom:8px}.insp-progress-fill{height:100%;background:linear-gradient(90deg,#27ae60,#2ecc71);border-radius:4px;transition:width .3s}.insp-search-row{display:flex;gap:6px;align-items:center}.insp-search-input{flex:1;padding:7px 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);font-size:.88rem;box-sizing:border-box}.insp-shift-select{padding:7px 8px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);font-size:.82rem}.insp-cat-header{display:flex;align-items:center;gap:6px;padding:8px;font-weight:600;font-size:.88rem;cursor:pointer;border-bottom:2px solid var(--border);color:var(--text);-webkit-user-select:none;user-select:none;background:var(--surface);margin-top:6px;border-radius:6px 6px 0 0}.insp-cat-header:active{opacity:.7}.insp-cat-stats{font-weight:400;font-size:.78rem;opacity:.8}.insp-cat-all-btn{margin-right:auto;background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff;border:none;padding:4px 10px;border-radius:6px;font-size:.72rem;font-weight:600;cursor:pointer;white-space:nowrap}.insp-cat-all-btn:active{opacity:.8}.insp-cat-arrow{font-size:.7rem;opacity:.5}.insp-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:10px}.insp-table{width:100%;border-collapse:collapse;font-size:.8rem;direction:rtl}.insp-table th{background:#1e3a5f;color:#fff;padding:6px 8px;position:sticky;top:0;z-index:2;white-space:nowrap;font-weight:600;font-size:.76rem;text-align:center}.insp-table th.insp-th-num{position:sticky;right:0;z-index:3;min-width:52px}.insp-table th.insp-th-notes{min-width:90px}.insp-table td{padding:4px 6px;border:1px solid #333;text-align:center;vertical-align:middle}.insp-table tbody tr:nth-child(2n){background:#ffffff08}.insp-table tbody tr:hover{background:#ffffff0f}.insp-td-num{position:sticky;right:0;background:#1a1a2e;z-index:1;cursor:pointer;font-weight:700;font-size:.85rem;color:var(--text);min-width:52px;white-space:nowrap}.insp-td-num:hover{color:#5dade2;text-decoration:underline}.insp-td-eq{cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.76rem;font-weight:600;padding:5px 4px;min-width:55px;white-space:nowrap;transition:background .15s}.insp-td-eq:active{opacity:.7}.insp-td-empty{color:#555;cursor:default;font-weight:400}.insp-cell-w{background:#27ae6040;color:#2ecc71}.insp-cell-nw{background:#e74c3c40;color:#e74c3c}.insp-cell-np{background:#64646433;color:#999}.insp-cell-skip{background:#f39c1233;color:#f39c12;font-weight:700;font-size:1rem}.insp-td-notes{min-width:90px;padding:0}.insp-td-notes input{width:100%;background:transparent;border:none;color:#e0e0e0;padding:5px 6px;font-size:.76rem;box-sizing:border-box;outline:none}.insp-td-notes input:focus{background:#ffffff14}.insp-note-popup{position:fixed;z-index:9999;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:6px;display:flex;gap:4px;box-shadow:0 4px 12px #0006}.insp-note-popup input{padding:6px 10px;border:1px solid var(--border);border-radius:6px;background:var(--background);color:var(--text);font-size:.82rem;min-width:160px}.insp-note-popup button{background:#27ae60;color:#fff;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-weight:700}.insp-export-overlay{position:fixed;inset:0;background:#0009;z-index:10000;display:flex;align-items:center;justify-content:center}.insp-export-box{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px;min-width:300px;max-width:90vw;direction:rtl}.insp-export-input{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--background);color:var(--text);font-size:.88rem;box-sizing:border-box}.insp-mark-all-btn{background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff;border:none;padding:6px 12px;border-radius:8px;font-size:.78rem;font-weight:700;cursor:pointer;white-space:nowrap}.insp-mark-all-btn:active{opacity:.8}.insp-save-all-btn{background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff;border:none;padding:6px 14px;border-radius:8px;cursor:pointer;font-weight:600;font-size:.78rem;white-space:nowrap}.insp-save-all-btn:active{opacity:.8}.insp-badge{display:inline-block;padding:4px 12px;border-radius:16px;font-weight:700;font-size:.82rem}.insp-ready{background:#27ae6026;color:#27ae60}.insp-partial{background:#f39c1226;color:#e67e22}.insp-not-ready{background:#e74c3c26;color:#e74c3c}.insp-hist-card{border:1px solid var(--border);border-radius:10px;padding:10px;margin-bottom:8px;background:var(--surface)}.insp-hist-header{font-weight:600;font-size:.88rem;color:var(--text)}.insp-hist-meta{font-size:.8rem;color:var(--text-secondary);margin-top:4px;display:flex;gap:6px;flex-wrap:wrap;align-items:center}.insp-hist-notes{font-size:.82rem;color:var(--text);margin-top:4px;padding:4px 8px;background:var(--background);border-radius:6px}.insp-hist-changes{font-size:.8rem;color:var(--text-secondary);margin-top:6px;padding-top:6px;border-top:1px solid var(--border)}.insp-empty{text-align:center;padding:30px;color:var(--text-secondary);font-size:.9rem}.insp-landscape-hint{display:none;text-align:center;padding:8px;background:#f39c121f;color:#f39c12;font-size:.8rem;border-radius:6px;margin-bottom:6px}.insp-fs-btn{background:#f39c12;color:#fff;border:none;padding:3px 10px;border-radius:4px;font-size:.78rem;cursor:pointer;font-weight:600;margin-right:4px}@media(max-width:768px)and (orientation:portrait){.insp-landscape-hint{display:block}}@media(max-width:768px){#modal-inspection-list{padding:0!important;align-items:stretch!important}#modal-inspection-list>.modal-content{max-width:100%!important;width:100%!important;height:100dvh;max-height:100dvh;border-radius:0;margin:0;display:flex;flex-direction:column}#modal-inspection-list .modal-header{flex-shrink:0;border-radius:0}#modal-inspection-list .modal-body{flex:1;max-height:none!important;overflow-y:auto;-webkit-overflow-scrolling:touch}.insp-td-eq{min-width:58px;padding:8px 4px;font-size:.8rem}.insp-td-num{padding:8px 6px;font-size:.88rem}.insp-table th{padding:8px 6px;font-size:.78rem}}#modal-inspection-list:fullscreen,#modal-inspection-list:-webkit-full-screen{background:var(--background);padding:0}#modal-inspection-list:fullscreen .modal-content,#modal-inspection-list:-webkit-full-screen .modal-content{max-width:100%!important;width:100%!important;height:100%;max-height:100%;border-radius:0;margin:0}#modal-inspection-list:fullscreen .insp-landscape-hint,#modal-inspection-list:-webkit-full-screen .insp-landscape-hint{display:none}.inv-landscape-hint{display:none;text-align:center;padding:8px;background:#f39c121f;color:#f39c12;font-size:.8rem;border-radius:6px;margin-bottom:6px}.inv-fs-btn{background:#f39c12;color:#fff;border:none;padding:3px 10px;border-radius:4px;font-size:.78rem;cursor:pointer;font-weight:600;margin-right:4px}@media(max-width:768px)and (orientation:portrait){.inv-landscape-hint{display:block}}#section-inventory:fullscreen,#section-inventory:-webkit-full-screen{background:var(--background);padding:10px;overflow-y:auto;-webkit-overflow-scrolling:touch}#section-inventory:fullscreen .inv-landscape-hint,#section-inventory:-webkit-full-screen .inv-landscape-hint{display:none}#section-inventory:fullscreen .inv-fullscreen-btn:after,#section-inventory:-webkit-full-screen .inv-fullscreen-btn:after{content:""}@media(max-width:768px){.inv-fullscreen-btn{display:inline-block}}#modal-department .modal-content{width:100%!important;max-width:100vw!important;height:100%!important;max-height:100vh!important;max-height:100dvh!important;border-radius:0!important;margin:0!important}.dept-landscape-hint{display:none;text-align:center;padding:8px;background:#f39c121f;color:#f39c12;font-size:.8rem;border-radius:6px;margin:6px 8px}.dept-fs-btn{background:#f39c12;color:#fff;border:none;padding:3px 10px;border-radius:4px;font-size:.78rem;cursor:pointer;font-weight:600;margin-right:4px}.dept-fs-tab-btn{flex:0 0 auto!important;padding:10px 12px;font-size:1rem;display:none}@media(max-width:768px)and (orientation:portrait){.dept-landscape-hint,.dept-fs-tab-btn{display:block}}#modal-department:fullscreen,#modal-department:-webkit-full-screen{background:var(--background);padding:0}#modal-department:fullscreen .modal-content,#modal-department:-webkit-full-screen .modal-content{max-width:100%!important;width:100%!important;height:100%!important;max-height:100%!important;border-radius:0!important;margin:0!important}#modal-department:fullscreen .dept-landscape-hint,#modal-department:-webkit-full-screen .dept-landscape-hint{display:none}#modal-department:fullscreen .dept-fs-tab-btn,#modal-department:-webkit-full-screen .dept-fs-tab-btn{display:none}#dept-inline-wrapper:fullscreen,#dept-inline-wrapper:-webkit-full-screen{background:var(--background);padding:8px;overflow-y:auto}#dept-inline-wrapper:fullscreen .dept-landscape-hint,#dept-inline-wrapper:-webkit-full-screen .dept-landscape-hint{display:none}#dept-inline-wrapper:fullscreen .dept-fs-tab-btn,#dept-inline-wrapper:-webkit-full-screen .dept-fs-tab-btn{display:none}#dept-inline-wrapper:fullscreen .dept-inline-back-header,#dept-inline-wrapper:-webkit-full-screen .dept-inline-back-header{position:sticky;top:0;z-index:10;background:var(--background);padding-bottom:8px}.dept-tabs{display:flex;gap:4px;padding:8px;background:#00000026;border-bottom:1px solid rgba(255,255,255,.06);overflow-x:auto;-webkit-overflow-scrolling:touch}.dept-tab-btn{flex:1;padding:10px 8px;border:none;border-radius:8px;background:transparent;color:var(--text-muted);font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s}.dept-tab-btn.active{background:linear-gradient(135deg,#1e3a5f,#2a5a8f);color:#fff}.dept-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:14px}.dept-stat-card{background:var(--card-bg);border-radius:10px;padding:16px 10px;text-align:center;border-right:3px solid var(--accent)}.dept-stat-number{font-size:1.5rem;font-weight:700;color:var(--accent)}.dept-stat-label{font-size:.7rem;color:var(--text-muted);margin-top:4px}.dept-alerts{margin-bottom:10px}.dept-alert{padding:8px 12px;border-radius:8px;font-size:.8rem;margin-bottom:4px}.dept-alert-danger{background:#e53e3e1f;color:#e53e3e;border:1px solid rgba(229,62,62,.25)}.dept-alert-warning{background:#d69e2e1f;color:#d69e2e;border:1px solid rgba(214,158,46,.25)}.dept-section-title{font-size:.9rem;font-weight:700;color:var(--text);margin:10px 0 6px;padding:0 4px}.dept-toolbar{display:flex;gap:8px;margin-bottom:8px;align-items:center;flex-wrap:wrap}.dept-search{flex:1;min-width:150px;padding:8px 12px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:var(--card-bg);color:var(--text);font-size:.8rem}.dept-filter-select{padding:8px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:var(--card-bg);color:var(--text);font-size:.8rem}.dept-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.dept-table{width:100%;border-collapse:collapse;font-size:.8rem}.dept-table th{background:#1e3a5f66;color:var(--text);padding:8px 6px;text-align:right;font-weight:600;font-size:.75rem;white-space:nowrap}.dept-table td{padding:7px 6px;border-bottom:1px solid rgba(255,255,255,.06);color:var(--text)}.dept-table tr:hover{background:#ffffff0a}.dept-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.7rem;font-weight:600}.dept-badge-warning{background:#d69e2e33;color:#d69e2e}.dept-badge-ok{color:var(--text-muted)}.dept-device-count{font-size:.8rem;color:var(--text-muted);margin-bottom:6px}.dept-device-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px}.dept-device-card{background:var(--card-bg);border-radius:10px;padding:12px;cursor:pointer;border:1px solid rgba(255,255,255,.06);transition:all .2s}.dept-device-card:hover{border-color:#2a5a8f80;transform:translateY(-1px)}.dept-device-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.dept-device-serial{font-weight:700;font-size:.85rem;color:var(--text)}.dept-device-info{font-size:.75rem;color:var(--text-muted);line-height:1.6}.dept-device-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;flex-wrap:wrap;gap:8px}.dept-device-detail-info{font-size:.85rem;line-height:1.8;color:var(--text)}.dept-status-filters{display:flex;gap:4px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px}.dept-filter-btn{padding:6px 10px;border-radius:16px;border:1px solid rgba(255,255,255,.15);background:transparent;color:var(--text-muted);font-size:.75rem;cursor:pointer;white-space:nowrap;transition:all .2s}.dept-filter-btn.active{background:linear-gradient(135deg,#1e3a5f,#2a5a8f);color:#fff;border-color:transparent}.dept-filter-count{display:inline-block;background:#ffffff26;padding:0 5px;border-radius:8px;font-size:.65rem;margin-right:2px}.dept-jc-card{background:var(--card-bg);border-radius:10px;padding:12px;margin-bottom:6px;border:1px solid rgba(255,255,255,.06);cursor:pointer;transition:all .2s}.dept-jc-card:hover{border-color:#2a5a8f80}.dept-jc-card.dept-jc-overdue{border-right:3px solid #e53e3e}.dept-jc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.dept-jc-number{font-weight:700;font-size:.85rem;color:var(--accent)}.dept-jc-status{display:inline-block;padding:2px 8px;border-radius:10px;color:#fff;font-size:.7rem;font-weight:600}.dept-jc-priority{font-size:.8rem}.dept-jc-info{font-size:.75rem;color:var(--text-muted);line-height:1.6}.dept-jc-detail-header{margin-bottom:12px}.dept-jc-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 16px;font-size:.8rem;color:var(--text);margin-bottom:12px;line-height:1.7}.dept-jc-detail-desc{background:#00000026;padding:10px;border-radius:8px;font-size:.8rem;color:var(--text);margin-bottom:10px}.dept-jc-actions{display:flex;gap:6px;flex-wrap:wrap;margin:10px 0}.dept-action-btn{padding:8px 14px;border:none;border-radius:8px;color:#fff;font-size:.8rem;font-weight:600;cursor:pointer;transition:opacity .2s}.dept-action-btn:hover{opacity:.85}.dept-note{background:#0000001f;padding:8px 10px;border-radius:8px;margin-bottom:4px;border-right:3px solid rgba(42,90,143,.5)}.dept-note-header{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text-muted);margin-bottom:4px}.dept-note-text{font-size:.8rem;color:var(--text);white-space:pre-wrap}.dept-add-note{display:flex;gap:6px;align-items:flex-end;margin-top:8px}.dept-add-note textarea{flex:1;padding:8px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:var(--card-bg);color:var(--text);font-size:.8rem;resize:vertical}.dept-reports{display:grid;grid-template-columns:1fr;gap:8px}.dept-report-card{background:var(--card-bg);border-radius:10px;padding:16px;cursor:pointer;border:1px solid rgba(255,255,255,.06);transition:all .2s;display:flex;align-items:center;gap:12px}.dept-report-card:hover{border-color:#2a5a8f80;transform:translateY(-1px)}.dept-report-icon{font-size:1.5rem}.dept-report-title{font-size:.9rem;font-weight:700;color:var(--text)}.dept-report-desc{font-size:.75rem;color:var(--text-muted)}.dept-empty{text-align:center;padding:20px;color:var(--text-muted);font-size:.85rem}.dept-file-label{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--btn-primary-flat);color:#fff;border-radius:8px;cursor:pointer;font-size:.85rem;font-weight:600;margin-top:6px}.dept-file-label:hover{opacity:.9}.dept-attachments-preview{display:flex;flex-direction:column;gap:4px;margin-bottom:4px}.dept-attachment-item{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#ffffff0d;border-radius:8px;font-size:.82rem;flex-wrap:wrap}.dept-attachment-thumb{width:48px;height:48px;object-fit:cover;border-radius:6px;cursor:pointer;border:1px solid rgba(255,255,255,.1)}.dept-attachment-link{color:var(--text);text-decoration:none;font-weight:500}.dept-attachment-link:hover{text-decoration:underline}.dept-attachments-list{display:flex;flex-direction:column;gap:6px}.dept-landing{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;padding:16px 8px;max-width:900px;margin:0 auto}.dept-landing-card{background:var(--card-bg);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:24px 18px;cursor:pointer;text-align:center;transition:transform .15s,box-shadow .15s}.dept-landing-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000004d;border-color:#2a5a8f66}.dept-landing-icon{font-size:2.2rem;margin-bottom:10px}.dept-landing-title{font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:6px}.dept-landing-desc{font-size:.78rem;color:var(--text-muted);margin-bottom:10px}.dept-landing-count{display:inline-block;background:#2a4f7a33;color:var(--accent);padding:4px 14px;border-radius:20px;font-size:.82rem;font-weight:600}.dept-back-header{display:flex;align-items:center;margin-bottom:12px}.dept-back-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--btn-primary-flat);color:#fff;border:none;border-radius:8px;font-size:.9rem;cursor:pointer}.dept-back-btn:hover{opacity:.85}.dept-book-card{background:var(--card-bg);border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:14px;margin-bottom:8px;cursor:pointer;transition:border-color .15s}.dept-book-card:hover{border-color:#2a5a8f66}.dept-book-name{font-weight:700;font-size:.9rem;color:var(--text);margin-bottom:4px}.dept-book-meta{font-size:.75rem;color:var(--text-muted);line-height:1.5}.dept-book-file{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;background:#2a4f7a33;color:var(--accent);border-radius:6px;font-size:.75rem;margin-top:6px;text-decoration:none}.dept-book-file:hover{background:#2a4f7a59}.dept-book-card.completed{opacity:.7;border-color:#38a16933}.book-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.book-filter-group{display:flex;gap:4px;flex-wrap:wrap}.book-filter-btn{padding:5px 12px;border:1px solid #4a5568;border-radius:8px;background:transparent;color:#a0aec0;font-size:.75rem;cursor:pointer;transition:all .15s}.book-filter-btn:hover{border-color:#718096;color:#e2e8f0}.book-filter-btn.active{background:var(--btn-primary-flat);color:#fff;border-color:var(--btn-primary-flat)}.book-filter-btn.pending.active{background:#d69e2e;border-color:#d69e2e;color:#1a202c}.book-filter-btn.completed.active{background:#38a169;border-color:#38a169;color:#fff}.book-filter-btn.shift-1.active{background:#3182ce;border-color:#3182ce;color:#fff}.book-filter-btn.shift-2.active{background:#805ad5;border-color:#805ad5;color:#fff}.book-filter-btn.shift-3.active{background:#dd6b20;border-color:#dd6b20;color:#fff}.book-shift-badge{display:inline-block;padding:2px 8px;border-radius:6px;font-size:.7rem;font-weight:700}.book-shift-badge.shift-1{background:#3182ce33;color:#63b3ed}.book-shift-badge.shift-2{background:#805ad533;color:#b794f4}.book-shift-badge.shift-3{background:#dd6b2033;color:#f6ad55}.book-status-badge{display:inline-block;padding:2px 8px;border-radius:6px;font-size:.7rem;font-weight:700}.book-status-badge.pending{background:#d69e2e33;color:#ecc94b}.book-status-badge.completed{background:#38a16933;color:#68d391}.book-action-btns{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.book-action-btn{padding:4px 12px;border:none;border-radius:6px;font-size:.75rem;cursor:pointer;transition:opacity .15s}.book-action-btn:hover{opacity:.85}.book-action-btn.transfer{background:#805ad5;color:#fff}.book-action-btn.complete{background:#38a169;color:#fff}.book-action-btn.note{background:var(--btn-primary-flat);color:#fff}.book-log{margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.06)}.book-log-entry{display:flex;flex-wrap:wrap;gap:6px;align-items:baseline;padding:4px 0;font-size:.72rem;color:#a0aec0}.book-log-entry+.book-log-entry{border-top:1px dashed rgba(255,255,255,.04)}.book-log-type{background:#2a4f7a4d;color:#90cdf4;padding:1px 6px;border-radius:4px;font-size:.68rem}.book-log-user{color:#e2e8f0;font-weight:500}.book-log-date{color:#718096;font-size:.68rem}.book-log-note{width:100%;color:#cbd5e0;font-size:.72rem;padding-right:4px}.book-log-toggle{background:none;border:none;color:var(--accent);font-size:.72rem;cursor:pointer;padding:4px 0}.book-log-toggle:hover{text-decoration:underline}.book-notif-banner{position:fixed;top:16px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#2d3748,#1a2332);border:1px solid #805ad5;border-radius:12px;padding:12px 20px;color:#e2e8f0;font-size:.85rem;z-index:100000;display:flex;align-items:center;gap:12px;box-shadow:0 4px 20px #0006;animation:slideDown .3s ease;max-width:90vw}.book-notif-banner button{background:none;border:none;color:#a0aec0;font-size:1rem;cursor:pointer;padding:0 4px}@keyframes slideDown{0%{transform:translate(-50%) translateY(-20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.dept-wh-item{background:var(--card-bg);border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:14px;margin-bottom:8px}.dept-wh-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.dept-wh-item-name{font-weight:700;font-size:.9rem;color:var(--text)}.dept-wh-qty{font-size:1rem;font-weight:700;padding:2px 12px;border-radius:8px}.dept-wh-qty.ok{background:#38a16926;color:#38a169}.dept-wh-qty.low{background:#e53e3e26;color:#e53e3e}.dept-wh-cat{font-size:.72rem;color:var(--text-muted);margin-bottom:4px}.dept-wh-actions{display:flex;gap:6px;margin-top:8px}.dept-wh-btn{padding:6px 14px;font-size:.78rem;border:none;border-radius:8px;cursor:pointer;font-weight:600;color:#fff}.dept-wh-btn.in{background:#38a169}.dept-wh-btn.in:hover{background:#2f855a}.dept-wh-btn.out{background:#e53e3e}.dept-wh-btn.out:hover{background:#c53030}.dept-wh-log-item{padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.05);font-size:.82rem}.dept-wh-log-item:last-child{border-bottom:none}.dept-wh-log-type{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.72rem;font-weight:600;margin-left:6px}.dept-wh-log-type.in{background:#38a16926;color:#38a169}.dept-wh-log-type.out{background:#e53e3e26;color:#e53e3e}.dept-sub-tabs{display:flex;gap:4px;margin-bottom:12px}.dept-sub-tab{padding:8px 16px;border:1px solid rgba(255,255,255,.1);background:transparent;color:var(--text-muted);border-radius:8px;cursor:pointer;font-size:.82rem;font-weight:600;transition:all .15s}.dept-sub-tab.active{background:var(--btn-primary-flat);color:#fff;border-color:transparent}@media(max-width:600px){.dept-landing{grid-template-columns:1fr;gap:12px}}@media(max-width:500px){.dept-stats{grid-template-columns:repeat(2,1fr)}.dept-jc-detail-grid,.dept-device-grid{grid-template-columns:1fr}}.ios-device body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}.ios-device ::-webkit-scrollbar{display:none}.ios-device *{scrollbar-width:none}.ios-device *{-webkit-tap-highlight-color:rgba(0,0,0,0)}.ios-device button,.ios-device .nav-tab,.ios-device .header,.ios-device .card,.ios-device .stat-card,.ios-device .equipment-card,.ios-device .company-card,.ios-device .patrol-card,.ios-device .filter-btn,.ios-device .tab-btn,.ios-device .section-header,.ios-device .nav-tabs,.ios-device .dept-landing-card,.ios-device .duty-log-entry{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.ios-device .modal-content p,.ios-device .modal-content span,.ios-device .ai-response-text,.ios-device .issue-note-text,.ios-device .equipment-note{-webkit-user-select:text;user-select:text}.ios-device .nav-tab:active{transform:none!important;opacity:.5;transition:opacity .05s ease}.ios-device .equipment-card:active,.ios-device .company-card:active,.ios-device .patrol-card:active,.ios-device .duty-log-entry:active,.ios-device .dept-landing-card:active{background-color:#ffffff0f;transform:scale(.985);transition:transform .05s ease-out,background-color .05s ease-out}.ios-device .header-btn:active{transform:scale(.85);opacity:.7;transition:transform .05s,opacity .05s}.ios-standalone .header{padding-top:calc(12px + env(safe-area-inset-top,47px))}.ios-standalone.offline-mode:before{padding-top:calc(6px + env(safe-area-inset-top,47px))}.ios-device .nav-tabs{background:#0a1628c7;-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px);border-top:.5px solid rgba(255,255,255,.08);padding:6px 6px 0;padding-bottom:calc(6px + env(safe-area-inset-bottom,0px));gap:0}[data-theme=light] .ios-device .nav-tabs,.ios-device[data-theme=light] .nav-tabs{background:#f2f2f7d1;border-top-color:#0000001f}.ios-device .nav-tab{padding:4px 2px 2px;font-size:.65rem;font-weight:500;gap:1px;border-radius:0;min-height:46px}.ios-device .nav-tab span:first-child{font-size:1.35rem!important;line-height:1.2}.ios-device .nav-tab.active{color:var(--accent);background:transparent}.ios-device .nav-tab.active:before,.ios-device .nav-tab.active:after{display:none}.ios-standalone{overscroll-behavior:none}.ios-standalone .page,.ios-standalone .modal-content,.ios-standalone .ai-chat-messages,.ios-standalone .notifications-panel,.ios-standalone .companies-list-container,.ios-standalone .insp-recent-cards{overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.ios-device .page{-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.ios-device .insp-recent-cards{scroll-snap-type:x proximity}.ios-device .insp-recent-card{scroll-snap-align:start}.ios-device .submit-btn,.ios-device .add-btn,.ios-device .login-btn{min-height:48px;border-radius:12px;font-weight:600}.ios-device .filter-btn{border-radius:20px;min-height:36px;padding:6px 14px}.ios-device .filter-btn.active{font-weight:700}.ios-device .tab-btn{border-radius:8px;font-weight:600}.ios-device .stat-card,.ios-device .equipment-card,.ios-device .company-card,.ios-device .patrol-card{border-radius:14px}.ios-device .modal-content{border-radius:14px 14px 0 0;max-height:92dvh}.ios-standalone .modal-content{max-height:calc(100dvh - env(safe-area-inset-top,47px));padding-bottom:calc(25px + env(safe-area-inset-bottom,34px))}.ios-device .modal{background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.ios-device.keyboard-open .modal-content{max-height:calc(100dvh - var(--keyboard-height, 0px) - 20px)!important;transition:max-height .25s cubic-bezier(.4,0,.2,1)}.ios-device input,.ios-device select,.ios-device textarea{border-radius:10px;-webkit-appearance:none;appearance:none}.ios-device select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.5)' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:left 12px center;padding-left:30px}[data-theme=light] .ios-device select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(0,0,0,0.4)' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E")}@media(orientation:landscape){.ios-device body{padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px)}.ios-device .header{padding-left:calc(14px + env(safe-area-inset-left,0px));padding-right:calc(14px + env(safe-area-inset-right,0px))}.ios-device .nav-tabs{padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px)}.ios-device .voice-cmd-btn,.ios-device .ai-chat-btn{left:calc(8px + env(safe-area-inset-left,0px))!important}.ios-device .modal-content{margin-left:env(safe-area-inset-left,0px);margin-right:env(safe-area-inset-right,0px)}.ios-device .page{padding-left:calc(10px + env(safe-area-inset-left,0px));padding-right:calc(10px + env(safe-area-inset-right,0px))}.ios-device .nav-tabs{padding-top:2px;padding-bottom:calc(2px + env(safe-area-inset-bottom,0px))}.ios-device .nav-tab{min-height:38px;padding:2px 2px 1px;font-size:.58rem}.ios-device .nav-tab span:first-child{font-size:1.1rem!important}.ios-device body{padding-bottom:calc(50px + env(safe-area-inset-bottom,0px))}.ios-device #modal-inspection-list>.modal-content{padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px)}.ios-device .insp-table-wrap{margin-left:env(safe-area-inset-left,0px);margin-right:env(safe-area-inset-right,0px)}.ios-device #modal-inspection-list .modal-header{padding-left:calc(12px + env(safe-area-inset-left,0px));padding-right:calc(12px + env(safe-area-inset-right,0px))}.ios-device .modal-content{max-height:92dvh;border-radius:12px}}#launcher-container{display:none;flex-direction:column;flex:1;min-height:calc(100vh - 120px);min-height:calc(100dvh - 120px)}.launcher-header{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;background:linear-gradient(135deg,#1a2d47,#0f1f33);border-bottom:1px solid rgba(255,255,255,.06);font-size:.75rem;color:#a0b4cc;flex-wrap:wrap}.launcher-header .lh-name{font-weight:700;color:#f5f5f5;font-size:.8rem}.launcher-header .lh-sep{opacity:.3;margin:0 1px}.launcher-header .lh-wx{display:inline-flex;align-items:center;gap:5px}.launcher-header .lh-dot{width:7px;height:7px;border-radius:50%;background:#00b894;display:inline-block}.launcher-header .lh-dot.stale{background:#fdcb6e}.launcher-header .lh-time{font-size:.68rem;color:#8e9aaf}[data-theme=light] .launcher-header{background:linear-gradient(135deg,#e0e8f0,#d0dae6);border-bottom-color:#00000014;color:#4a5568}[data-theme=light] .launcher-header .lh-name{color:#1a2d47}#launcher-container.active{display:flex!important}.launcher-grid{display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:1fr;gap:2px;flex:1;min-height:0}.launcher-grid.grid-4{grid-template-rows:1fr 1fr}.launcher-grid.grid-6{grid-template-rows:1fr 1fr 1fr}.launcher-grid.grid-8{grid-template-rows:1fr 1fr 1fr 1fr}.launcher-card{display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.06);transition:transform .15s;padding:16px 8px;-webkit-tap-highlight-color:transparent}.launcher-card:nth-child(odd){background:linear-gradient(160deg,#1a2d47,#0f1f33)}.launcher-card:nth-child(2n){background:linear-gradient(160deg,#172940,#0e1c30)}.launcher-card:active{transform:scale(.97);background:#2e86c12e!important}.launcher-card .lc-icon{font-size:3rem;margin-bottom:10px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.launcher-card .lc-title{font-size:1.1rem;font-weight:800;margin-bottom:3px;color:var(--text, #f5f5f5)}.launcher-card .lc-desc{font-size:.72rem;color:var(--text-muted, #8e9aaf)}.launcher-card.extra-card{border-right:3px solid var(--accent, #2E86C1)}.launcher-card.extra-card .lc-perm{position:relative;margin-top:6px;font-size:.7rem;background:#2e86c166;color:#e0ecff;padding:3px 10px;border-radius:10px;display:inline-block}.launcher-card .lc-badge{position:absolute;top:12px;left:12px;background:#e74c3c;color:#fff;font-size:.75rem;font-weight:800;min-width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #e74c3c80;animation:lc-badge-pulse 2s infinite}@keyframes lc-badge-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.launcher-fab{position:fixed;bottom:calc(24px + env(safe-area-inset-bottom,0px));left:16px;transform:none;background:#e74c3cd9;color:#fff;border:none;padding:12px 22px;border-radius:25px;font-size:.9rem;font-weight:700;font-family:Tajawal,sans-serif;cursor:pointer;box-shadow:0 2px 10px #0003;z-index:100;display:none;-webkit-tap-highlight-color:transparent;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.launcher-fab:active{transform:scale(.96)}.launcher-back-float{position:fixed;bottom:calc(20px + env(safe-area-inset-bottom,0px));left:50%;transform:translate(-50%);padding:12px 28px;border-radius:30px;border:none;background:linear-gradient(135deg,#2e86c1bf,#3498dbbf);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;font-size:.95rem;font-weight:700;font-family:Tajawal,sans-serif;cursor:pointer;z-index:101;display:none;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;box-shadow:0 4px 20px #2e86c166;transition:opacity .2s,transform .15s;white-space:nowrap}.launcher-back-float:active{transform:translate(-50%) scale(.95);opacity:.85}.alerts-page{position:fixed;inset:0;z-index:200;background:linear-gradient(180deg,#0f1f33,#1a2d47);display:flex;flex-direction:column;overflow:hidden;direction:rtl}.alerts-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(135deg,#1e3a5f,#2a5a8f);border-bottom:1px solid rgba(255,255,255,.08)}.alerts-title{color:#f5f5f5;font-size:1.1rem;font-weight:700}.alerts-close{background:#ffffff26;border:none;color:#fff;font-size:1.2rem;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.alerts-body{flex:1;overflow-y:auto;padding:12px 16px 80px;-webkit-overflow-scrolling:touch}.alerts-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:12px}.alerts-empty-icon{font-size:3rem}.alerts-empty-text{color:#a0b4cc;font-size:1rem;font-weight:600}.alerts-group{margin-bottom:16px;border-radius:12px;overflow:hidden;background:#ffffff0a}.alerts-group-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;font-size:.85rem;font-weight:700;color:#fff}.alerts-group-header.ag-red{background:linear-gradient(135deg,#c0392b,#e74c3c)}.alerts-group-header.ag-orange{background:linear-gradient(135deg,#d35400,#e67e22)}.alerts-group-header.ag-yellow{background:linear-gradient(135deg,#b8860b,#daa520)}.alerts-group-header.ag-blue{background:linear-gradient(135deg,#1e3a5f,#2e86c1)}.ag-count{background:#0000004d;padding:2px 10px;border-radius:10px;font-size:.78rem}.alerts-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-top:1px solid rgba(255,255,255,.06);cursor:pointer;transition:background .15s}.alerts-item:active{background:#ffffff14}.ai-main{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.ai-title{color:#ddd;font-size:.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ai-sub{color:#8e9aaf;font-size:.72rem}.ai-arrow{color:#5a7a9a;font-size:.9rem;margin-right:8px;flex-shrink:0}[data-theme=light] .alerts-page{background:linear-gradient(180deg,#edf2f7,#e2e8f0)}[data-theme=light] .alerts-header{background:linear-gradient(135deg,#e0e8f0,#d0dae6);border-bottom-color:#00000014}[data-theme=light] .alerts-title{color:#1a2d47}[data-theme=light] .alerts-close{background:#0000001a;color:#333}[data-theme=light] .alerts-empty-text{color:#4a5568}[data-theme=light] .alerts-group{background:#0000000a}[data-theme=light] .alerts-item{border-top-color:#0000000f}[data-theme=light] .alerts-item:active{background:#0000000f}[data-theme=light] .ai-title{color:#2d3748}[data-theme=light] .ai-sub{color:#718096}[data-theme=light] .ai-arrow{color:#a0aec0}.alerts-item.alerts-item-static{cursor:default}.alerts-item.alerts-item-static:active{background:transparent}body.launcher-view-only .add-btn,body.launcher-view-only .submit-btn,body.launcher-view-only .delete-btn,body.launcher-view-only .edit-btn,body.launcher-view-only [onclick*=openAdd],body.launcher-view-only [onclick*=delete],body.launcher-view-only [onclick*=remove],body.launcher-view-only .fab-add,body.launcher-view-only .launcher-fab,body.launcher-mode .nav-tabs,body.simplified-user .nav-tabs,body.launcher-mode #global-search-wrapper,body.launcher-mode .page{display:none!important}[data-theme=light] .launcher-card:nth-child(odd){background:linear-gradient(160deg,#e8edf3,#dce3ed)}[data-theme=light] .launcher-card:nth-child(2n){background:linear-gradient(160deg,#dce3ed,#d0d9e6)}[data-theme=light] .launcher-card .lc-title{color:#1a1a2e}[data-theme=light] .launcher-card .lc-desc{color:#666}[data-theme=light] .launcher-card:active{background:#2e86c11f!important}.launcher-user-row{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#ffffff0d;border-radius:10px;margin-bottom:8px;gap:8px}.launcher-user-row .lu-name{font-weight:600;font-size:.9rem}.launcher-user-row .lu-role{font-size:.75rem;color:var(--text-muted)}[data-theme=light] .launcher-user-row{background:#0000000a}#achievement-page{padding-bottom:80px}.achievement-header{background:var(--header-bg);padding:14px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:50}.achievement-title{font-size:17px;font-weight:700}.achievement-back-btn{background:#ffffff14;border:none;color:var(--text);padding:7px 14px;border-radius:8px;cursor:pointer;font-size:13px}.achievement-profile{text-align:center;padding:20px 16px 16px}.achievement-avatar{width:60px;height:60px;background:linear-gradient(135deg,var(--btn-primary-flat),#1a5276);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 10px;border:2px solid rgba(46,134,193,.4)}.achievement-name{font-size:18px;font-weight:700;margin-bottom:4px}.achievement-role{font-size:13px;color:var(--text-secondary)}.achievement-period-filter{display:flex;gap:8px;padding:0 16px 14px;overflow-x:auto;-webkit-overflow-scrolling:touch}.achievement-period-btn{flex-shrink:0;padding:7px 16px;border-radius:20px;border:1px solid var(--border-color);background:#ffffff0a;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s}.achievement-period-btn.active{background:var(--btn-primary-flat);color:#fff;border-color:var(--btn-primary-flat);font-weight:600}.achievement-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 16px 14px}.achievement-stat-card{background:var(--card-bg);border-radius:12px;padding:14px;border:1px solid var(--border-color);text-align:center}.achievement-stat-icon{font-size:22px;margin-bottom:6px}.achievement-stat-number{font-size:26px;font-weight:800}.achievement-stat-label{font-size:12px;color:var(--text-secondary);margin-top:2px}.achievement-export{display:flex;gap:10px;padding:0 16px 14px}.achievement-export-btn{flex:1;padding:10px;border-radius:10px;border:1px solid var(--border-color);background:var(--card-bg);color:var(--text);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px}.achievement-section-title{padding:8px 16px;font-size:14px;font-weight:600;color:var(--text-secondary)}.achievement-manual-item{display:flex;gap:12px;align-items:flex-start;padding:12px 16px;margin:0 16px 8px;background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color)}.achievement-manual-icon{font-size:20px;flex-shrink:0;margin-top:2px}.achievement-manual-content{flex:1;min-width:0}.achievement-manual-title{font-size:14px;font-weight:600;margin-bottom:4px}.achievement-manual-desc{font-size:12px;color:var(--text-secondary);margin-bottom:4px;line-height:1.4}.achievement-manual-meta{font-size:11px;color:var(--text-secondary);opacity:.7}.achievement-date-sep{font-size:13px;color:var(--text-secondary);font-weight:600;padding:12px 16px 8px}.achievement-timeline-item{display:flex;gap:10px;align-items:flex-start;padding:10px 16px;margin:0 16px 6px;background:var(--card-bg);border-radius:10px;border:1px solid var(--border-color)}.achievement-tl-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}.ach-icon-issue{background:#e74c3c26}.ach-icon-complete{background:#27ae6026}.ach-icon-inspection{background:#2e86c126}.ach-icon-equipment{background:#f39c1226}.ach-icon-duty{background:#8e44ad26}.ach-icon-login{background:#64646426}.ach-icon-other{background:#9696961a}.achievement-tl-content{flex:1;min-width:0}.achievement-tl-title{font-size:13px;font-weight:500;line-height:1.4;margin-bottom:2px}.achievement-tl-meta{font-size:11px;color:var(--text-secondary);opacity:.6}
