.dashboard-container{align-items:center;background:linear-gradient(#0a1929a6,#0a1929e6),url(https://plus.unsplash.com/premium_photo-1687157829884-fae305709c06?fm=jpg&q=60&w=3000&ixlib=rb-4.1.0&ixid=M3wxMjA3fDB8MHxzZWFyY2h8MXx8cG9saWNlfGVufDB8fDB8fHww) no-repeat 50% fixed;background-size:cover;display:flex;flex-direction:column;min-height:100vh;padding:40px 20px}.dashboard-container h1{animation:slideDown 1s ease-in-out;background:#1e3a8acc;border-radius:12px;box-shadow:0 8px 20px #0000004d;color:#fff;font-size:2.5rem;font-weight:700;margin-bottom:10px;padding:15px 30px;text-align:center;text-shadow:2px 2px 4px #00000080}.dashboard-subtitle{color:#e0e7ff;font-size:1.2rem;font-weight:500;margin-bottom:30px;text-align:center;text-shadow:1px 1px 2px #00000080}.stats-container{display:flex;gap:20px;justify-content:center;margin-bottom:30px;max-width:1200px;width:100%}.stat-card{animation:fadeInUp .8s ease-out;background:#fffffff2;border-radius:12px;box-shadow:0 8px 20px #0000004d;padding:20px 40px;text-align:center}.stat-card h3{color:#1e3a8a;font-size:1rem;font-weight:600;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.stat-card h2{color:#1e3a8a;font-size:2.5rem;font-weight:700;margin:0}.filters-container{gap:15px;margin-bottom:30px}.search-input{border:none;box-shadow:0 4px 10px #0003;padding:12px 20px;width:300px}.types-container{gap:20px;max-width:1200px}.type-column{background:#fffffff2;border-radius:15px;box-shadow:0 10px 30px #0000004d;padding:20px}.type-column h2{border-bottom:2px solid #e0e0e0;color:#1e3a8a;font-size:1.5rem;margin-bottom:20px;padding-bottom:10px}.duty-list{display:flex;flex-direction:column;gap:12px;margin-top:15px}.duty-list-item{align-items:center;background:linear-gradient(135deg,#1e3a8a,#3b82f6);border:2px solid #ffffff1a;border-radius:10px;box-shadow:0 4px 12px #00000026;color:#fff;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;justify-content:space-between;line-height:1.4;padding:16px 20px;text-align:left;transition:all .3s ease}.duty-list-item:hover{background:linear-gradient(135deg,#1e40af,#2563eb);border-color:#fff3;box-shadow:0 6px 16px #00000040;transform:translateY(-3px)}.duty-list-item.duty-item{background:linear-gradient(135deg,#059669,#10b981);border-color:#fff3}.duty-list-item.duty-item:hover{background:linear-gradient(135deg,#047857,#059669)}.duty-content{word-wrap:break-word;flex:1 1;margin-right:15px;overflow-wrap:break-word}.duty-name{display:block;font-weight:600;margin-bottom:4px}.duty-count{align-items:center;background:linear-gradient(135deg,#f59e0b,#fbbf24);border:2px solid #fff;border-radius:50%;box-shadow:0 3px 8px #0000004d;color:#fff;display:flex;flex-shrink:0;font-size:.85rem;font-weight:700;height:32px;justify-content:center;width:32px}.modal-overlay{align-items:flex-start;background:#000000b3;box-sizing:border-box;overflow-y:auto;padding:10px}.modal-content{border-radius:15px;box-shadow:0 15px 40px #0006;box-sizing:border-box;margin:20px auto;max-height:calc(100vh - 40px);max-width:900px;min-height:auto;padding:30px;width:100%}.close-btn{background:none;background-color:#1e3a8a1a;color:#1e3a8a;font-size:1.8rem;right:15px;top:10px;transition:transform .3s ease;z-index:10}.close-btn:hover{background-color:#1e3a8a33;transform:rotate(90deg)}.blocklist-container h2{color:#1e3a8a;font-size:1.8rem;margin-bottom:20px;padding-right:40px}.quarter-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-top:20px}.quarter-card{background:#f8f9fa;border-left:4px solid #1e3a8a;border-radius:10px;box-shadow:0 4px 10px #0000001a;display:flex;flex-direction:column;gap:10px;padding:20px}.quarter-card:hover{box-shadow:0 8px 20px #00000026;transform:translateY(-3px)}.quarter-card h3{color:#1e3a8a;font-size:1.4rem;margin:0}.badge{background:#1e3a8a;border-radius:4px;padding:4px 8px;width:fit-content}.quarter-card p{color:#335b75;font-size:.95rem;font-weight:500;margin:5px 0}.quarter-card small{color:#6c757d;font-size:.85rem}.no-quarters{color:#6c757d;padding:40px}.personnel-image-wrapper{align-items:center;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border:3px solid #1e3a8a;border-radius:8px;display:flex;height:180px;justify-content:center;margin-bottom:12px;overflow:hidden;width:100%}.personnel-thumbnail{height:100%;object-fit:cover;width:100%}.personnel-details-modal h2{color:#1e3a8a;font-size:1.8rem;line-height:1.3;margin-bottom:25px;padding-right:40px;text-align:center}.personnel-detail-image-container{background:linear-gradient(135deg,#1e3a8a,#2563eb);border-radius:15px;box-shadow:0 8px 20px #1e3a8a4d;cursor:pointer;margin:0 auto 30px;max-width:250px;padding:15px;text-align:center;transition:all .3s ease}.personnel-detail-image-container:hover{box-shadow:0 12px 30px #1e3a8a66;transform:translateY(-5px)}.personnel-detail-image{border:5px solid #fff;border-radius:10px;box-shadow:0 4px 15px #0003;display:block;height:280px;margin:0 auto;max-width:220px;object-fit:cover;width:100%}.image-label{color:#fff;display:block;font-size:12px;font-style:italic;font-weight:500;margin-top:12px;text-shadow:1px 1px 2px #0000004d}.personnel-details-with-image{display:flex;gap:25px;margin-bottom:25px}.personnel-image-left{flex-shrink:0;width:200px}.personnel-image-left .personnel-detail-image-container{margin:0;max-width:200px}.personnel-image-left .personnel-detail-image{height:220px;max-width:170px}.personnel-info-right{flex:1 1}.personnel-list-image{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border:3px solid #1e3a8a;border-radius:50%;flex-shrink:0;height:80px;margin-right:15px;overflow:hidden;width:80px}.personnel-list-image img{height:100%;object-fit:cover;width:100%}.image-modal-overlay{animation:fadeIn .3s ease-out;box-sizing:border-box;height:100%;padding:20px;width:100%;z-index:2000}.image-modal-content{border-radius:15px;box-shadow:0 10px 40px #00000080;max-width:90%}.full-size-image{border-radius:10px;box-shadow:0 4px 20px #0000004d;display:block;height:auto;margin:0 auto;max-height:80vh;max-width:100%;width:auto}.file-input{background-color:#f8f9fa;border:2px dashed #1e3a8a;border-radius:8px;cursor:pointer;font-size:.95rem;padding:10px;transition:all .3s ease;width:100%}.file-input:hover{background-color:#e9ecef;border-color:#152c6e}.image-preview-container{align-items:center;background:#f8f9fa;border:2px solid #e9ecef;border-radius:10px;display:flex;flex-direction:column;gap:10px;margin-top:15px;padding:15px}.image-preview{border:4px solid #1e3a8a;border-radius:12px;box-shadow:0 4px 12px #00000026;max-height:350px;max-width:300px;object-fit:cover}.details-grid{grid-gap:15px;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:25px}.detail-item{background:#f8f9fa;border-left:3px solid #1e3a8a;border-radius:8px;padding:12px}.detail-item label{color:#495057;font-weight:700}.detail-item span{color:#1e3a8a;font-size:1.1rem;font-weight:500;word-break:break-word}.section-divider{background:#e9ecef;height:2px;margin:25px 0}.personnel-details-modal h3{color:#1e3a8a;font-size:1.4rem;margin-bottom:20px}.bills-grid{grid-gap:15px;gap:15px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-bottom:25px}.bill-card{background:#f8f9fa;border-left:4px solid #1e3a8a;border-radius:8px;box-shadow:0 2px 6px #0000001a;display:flex;flex-direction:column;gap:8px;padding:15px}.bill-card p{color:#495057;font-size:.95rem;margin:0}.duty-history-card{text-align:left}.duty-history-card p{color:#1f2937;font-size:.95rem;margin:0}.duty-assignment{color:#3b82f6!important;font-size:1rem!important;font-weight:600}.duty-dates{align-items:center;color:#6b7280;display:flex;flex-wrap:wrap;gap:6px;margin:8px 0}.duty-dates small{font-size:.8rem}.location{color:#6b7280;display:block;font-size:.85rem;font-style:italic;margin-top:4px}.remarks{background:#f3f4f6;color:#4b5563!important;font-size:.85rem!important;margin-top:8px!important}.admin-remarks,.remarks{border-radius:4px;font-style:italic;padding:8px}.admin-remarks{background:#fef3c7;color:#92400e;font-size:.85rem;margin-top:8px}.status-badge{min-width:70px;text-align:center}.status-badge.active{background:#d4edda;color:#155724}.status-badge.on-leave{background:#fff3cd;color:#856404}.status-badge.transferred{background:#d1ecf1;color:#0c5460}.status-badge.retired{background:#e2e3e5;color:#383d41}.status-badge.present{background:#d4edda;color:#155724}.status-badge.absent{background:#f8d7da;color:#721c24}.status-badge.on-duty{background:#d1ecf1;color:#0c5460}.status-badge.pending{background:#fff3cd}.status-badge.approved{background:#d4edda;color:#155724}.status-badge.rejected{background:#f8d7da;color:#721c24}.status-badge.casual{background:#e0e7ff;color:#3730a3}.status-badge.sick{background:#fecaca;color:#991b1b}.status-badge.earned{background:#d1fae5;color:#065f46}.status-badge.special{background:#fbcfe8;color:#831843}.repair-work-section{display:flex;flex-direction:column;gap:15px}.repair-detail{background:#fff;border-left:4px solid #1e3a8a;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:15px}.repair-description{color:#333;font-size:1rem;font-weight:500;line-height:1.5;margin:0 0 12px}.repair-meta{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-top:8px}.repair-meta span{color:#666;font-size:.9rem}.error-message,.loading-spinner{background:#ffffffe6;border-radius:15px;box-shadow:0 10px 30px #0003;padding:60px 20px;text-align:center}.loading-spinner p{color:#1e3a8a;font-size:1.2rem}.error-message p{color:#dc3545;font-size:1.2rem;margin-bottom:20px}.error-message button{background:#1e3a8a;font-size:1rem;padding:12px 24px;transition:background-color .3s ease}.error-message button:hover{background:#152c6e}.loading-bills{padding:30px}.loading-bills,.no-data{color:#6c757d;font-style:italic;text-align:center}.no-data{grid-column:1/-1;padding:20px}.no-duties{background:#f8f9fa;border:2px dashed #dee2e6;border-radius:8px;color:#6c757d;font-style:italic;padding:30px;text-align:center}@media (max-width:991px) and (min-width:768px){.dashboard-container{padding:30px 15px}.types-container{flex-wrap:wrap;gap:15px}.type-column{flex-basis:calc(50% - 15px);flex-grow:1;flex-shrink:0;margin-bottom:20px;min-width:300px}.modal-content{margin:15px;padding:25px}.quarter-grid{gap:15px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.details-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.bills-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.personnel-detail-image-container{max-width:200px}.personnel-detail-image{height:240px;max-width:170px}}@media (max-width:767px){.dashboard-container{padding:20px 10px}.dashboard-container h1{font-size:1.8rem;padding:12px 20px}.dashboard-subtitle{font-size:1rem}.stat-card{padding:15px 30px}.stat-card h2{font-size:2rem}.filters-container{align-items:center;flex-direction:column;gap:10px}.search-input{max-width:350px;width:100%}.types-container{flex-direction:column}.type-column{margin-bottom:15px;padding:15px;width:100%}.duty-list-item{font-size:.9rem;padding:14px 16px}.duty-count{font-size:.8rem;height:28px;width:28px}.modal-content{margin:10px auto;padding:20px;width:calc(100% - 10px)}.quarter-grid{gap:12px;grid-template-columns:1fr}.personnel-image-wrapper{height:200px}.personnel-detail-image-container{max-width:180px}.personnel-detail-image{height:200px;max-width:150px}.details-grid{gap:12px;grid-template-columns:1fr}.bills-grid{gap:10px;grid-template-columns:1fr}.repair-meta{gap:8px}.duty-dates,.repair-meta{align-items:flex-start;flex-direction:column}.duty-dates{gap:4px}.personnel-details-with-image{flex-direction:column}.personnel-image-left{margin-bottom:20px;width:100%}.personnel-image-left .personnel-detail-image-container{margin:0 auto;max-width:180px}}@media (max-width:479px){.dashboard-container h1{font-size:1.5rem;padding:10px 15px}.stat-card h2{font-size:1.8rem}.duty-list-item{font-size:.85rem;padding:12px 14px}.duty-count{font-size:.75rem;height:26px;width:26px}.modal-content{padding:15px}.blocklist-container h2,.personnel-details-modal h2{font-size:1.4rem;padding-right:30px}.personnel-detail-image-container{max-width:160px;padding:12px}.personnel-detail-image{height:180px;max-width:136px}.image-label{font-size:11px}}.admin-container{background:linear-gradient(#0009,#0009),url(https://images.unsplash.com/photo-1506806732259-39c2d0268443) no-repeat 50% fixed;background-size:cover;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh;padding:2rem}.admin-header{animation:slideDown .8s ease-out;color:#fff;font-size:2.75rem;font-weight:700;margin-bottom:2rem;text-align:center;text-shadow:0 4px 8px #0000004d}.admin-tabs{flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:2rem}.tab-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:2px solid #ffffff4d;color:#fff;font-size:1rem;font-weight:600;padding:.875rem 1.75rem;transition:all .3s ease;white-space:nowrap}.tab-btn:hover{background:#ffffff40;border-color:#ffffff80;box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.tab-btn.active{background:#fff;border-color:#fff;box-shadow:0 4px 16px #ffffff4d;color:#1f2937}.admin-sections{grid-gap:2.5rem;display:grid;gap:2.5rem;grid-template-columns:1fr;margin:0 auto;max-width:1400px}.quarter-section,.repair-section{animation:slideUp .6s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #ffffff4d;border-radius:16px;box-shadow:0 10px 30px #0003;color:#1f2937;padding:2rem}.section-header{border-bottom:2px solid #e5e7eb;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem}.section-header h2{color:#374151;font-size:1.75rem}.header-buttons{flex-wrap:wrap;gap:1rem}.loading-spinner{align-items:center;color:#fff;display:flex;font-size:1.1rem;justify-content:center;padding:3rem}.error-message{background:#ffffffe6;border-radius:12px;color:#ef4444;margin:2rem auto;max-width:500px;padding:3rem;text-align:center}.error-message button{background:#ef4444;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;margin-top:1rem;padding:.75rem 1.5rem;transition:background .2s}.error-message button:hover{background:#dc2626}.form-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:1.5rem}.form-group{display:flex;flex-direction:column}.form-group label{color:#374151;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{background:#fff;border:2px solid #e5e7eb;border-radius:8px;color:#374151;font-family:inherit;font-size:.875rem;padding:.75rem;transition:all .2s ease}.form-group textarea{min-height:80px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.error-text{color:#ef4444;font-size:.75rem;font-weight:500;margin-top:.25rem}.btn{align-items:center;border-radius:8px;display:inline-flex;font-size:.875rem;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;transition:all .2s ease;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:#3b82f6}.btn-primary:hover:not(:disabled){background:#2563eb;box-shadow:0 4px 12px #3b82f666;transform:translateY(-1px)}.btn-secondary{background:#6b7280}.btn-secondary:hover:not(:disabled){background:#4b5563;transform:translateY(-1px)}.btn-danger{background:#ef4444}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.btn-sm{font-size:.75rem;padding:.5rem 1rem}.form-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:flex-start;margin-top:1.5rem}.update-quarter-form{background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.update-quarter-form h3{color:#374151;font-weight:600;margin:0 0 1.5rem}.quarters-summary{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.quarters-summary h3{color:#2c3e50;font-weight:600;margin:0 0 1rem}.summary-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.summary-item{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;text-align:center;transition:all .2s ease}.summary-item:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000001a}.summary-item h4{color:#6b7280;font-size:.875rem;font-weight:500;letter-spacing:.5px;margin:0 0 .5rem;text-transform:uppercase}.summary-number{color:#1f2937;display:block;font-size:2rem;font-weight:700}.summary-number.occupied{color:#10b981}.repair-section h3{border-bottom:2px solid #e5e7eb;color:#374151;font-size:1.25rem;font-weight:600;margin:0 0 1.5rem;padding-bottom:.75rem}.repair-list{display:flex;flex-direction:column;gap:1rem}.repair-item{align-items:flex-start;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:1rem;justify-content:space-between;padding:1.5rem;transition:all .2s ease}.repair-item:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000001a}.repair-info{flex:1 1}.repair-info h4{align-items:center;color:#1f2937;display:flex;flex-wrap:wrap;font-size:1.1rem;font-weight:600;gap:.5rem;margin:0 0 .75rem}.repair-info p{color:#6b7280;font-size:.875rem;line-height:1.6;margin:.5rem 0}.repair-info strong{color:#374151;font-weight:600}.repair-info em{color:#9ca3af;font-size:.85rem}.repair-actions{align-items:flex-start;display:flex;flex-shrink:0;gap:.5rem}.status-badge{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;padding:.35rem .75rem;white-space:nowrap}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.on-leave{background:#fef3c7;color:#92400e}.status-badge.transferred{background:#dbeafe;color:#1e40af}.status-badge.retired{background:#f3f4f6;color:#374151}.status-badge.pending{background:#fef3c7;color:#92400e}.status-badge.approved{background:#d1fae5;color:#065f46}.status-badge.rejected{background:#fecaca;color:#991b1b}.no-items{background:#f9fafb;border-radius:8px;color:#9ca3af;font-style:italic;padding:2rem;text-align:center}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:1200px){.admin-sections{gap:2rem}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}}@media (max-width:768px){.admin-container{padding:1rem}.admin-header{font-size:2rem;margin-bottom:1.5rem}.admin-tabs{gap:.5rem}.tab-btn{font-size:.9rem;padding:.75rem 1.25rem}.quarter-section,.repair-section{padding:1.5rem}.section-header{align-items:flex-start;flex-direction:column;gap:1rem}.header-buttons{flex-direction:column;width:100%}.header-buttons .btn{width:100%}.form-grid{grid-template-columns:1fr}.repair-item{align-items:stretch;flex-direction:column;gap:1rem}.repair-actions{justify-content:flex-start;width:100%}.repair-actions .btn{flex:1 1}.form-actions{flex-direction:column}.form-actions .btn{width:100%}.summary-grid{gap:.75rem;grid-template-columns:repeat(2,1fr)}.summary-number{font-size:1.5rem}}@media (max-width:480px){.admin-header{font-size:1.75rem}.admin-tabs{flex-direction:column}.tab-btn{width:100%}.section-header h2{font-size:1.5rem}.quarter-section,.repair-section,.update-quarter-form{padding:1rem}.summary-grid{grid-template-columns:1fr}.repair-info h4{font-size:1rem}.repair-info p{font-size:.8rem}.repair-actions{flex-wrap:wrap}}.admin-tabs-container{align-items:center;display:flex;gap:20px;justify-content:space-between;margin-bottom:20px}.admin-tabs{display:flex;flex:1 1;gap:10px}.tab-btn{background-color:#ffffffe6;border:none;border-radius:12px;box-shadow:0 2px 8px #0000001a;color:#333;cursor:pointer;font-size:16px;font-weight:500;overflow:hidden;padding:12px 28px;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)}.tab-btn:before{background:linear-gradient(90deg,#0000,#fff6,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.tab-btn:hover:before{left:100%}.tab-btn:hover{background-color:#fff;box-shadow:0 6px 20px #00000026;transform:translateY(-3px) scale(1.02)}.tab-btn:active{transform:translateY(-1px) scale(.98);transition:all .1s ease}.tab-btn.active{background:linear-gradient(135deg,#2196f3,#1976d2);box-shadow:0 4px 15px #2196f366;color:#fff;font-weight:600;transform:translateY(-2px)}.tab-btn.active:after{animation:slideIn .3s ease;background:#fff9;border-radius:2px;bottom:-2px;content:"";height:3px;left:50%;position:absolute;transform:translateX(-50%);width:60%}@keyframes slideIn{0%{width:0}to{width:60%}}.btn.btn-refresh-top{align-items:center;background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:12px;box-shadow:0 3px 12px #28a74559;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;overflow:hidden;padding:12px 24px;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1);white-space:nowrap}.btn.btn-refresh-top:before{background:#ffffff4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s ease,height .6s ease;width:0}.btn.btn-refresh-top:hover:before{height:300px;width:300px}.btn.btn-refresh-top:hover:not(:disabled){background:linear-gradient(135deg,#218838,#1ea87a);box-shadow:0 6px 20px #28a74580;transform:translateY(-3px) scale(1.05)}.btn.btn-refresh-top:active:not(:disabled){box-shadow:0 3px 8px #28a7454d;transform:translateY(-1px) scale(.98);transition:all .1s ease}.btn.btn-refresh-top:disabled{background:linear-gradient(135deg,#6c757d,#5a6268);box-shadow:none;cursor:not-allowed;opacity:.6}.btn.btn-refresh-top:disabled:before{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;content:"";display:inline-block;height:14px;margin-right:6px;width:14px}.section-header{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:10px;box-shadow:0 2px 4px #0000000d;display:flex;justify-content:space-between;margin-bottom:20px;padding:15px}.section-header h2{color:#2c3e50;font-size:24px;font-weight:600;margin:0}.header-buttons{align-items:center;display:flex;gap:10px}.btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#2196f3,#1976d2);box-shadow:0 3px 8px #2196f34d;color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#1976d2,#1565c0);box-shadow:0 4px 12px #2196f366;transform:translateY(-2px)}.btn-secondary{background:linear-gradient(135deg,#6c757d,#5a6268);box-shadow:0 3px 8px #6c757d4d;color:#fff}.btn-secondary:hover{background:linear-gradient(135deg,#5a6268,#495057);box-shadow:0 4px 12px #6c757d66;transform:translateY(-2px)}.btn-danger{background:linear-gradient(135deg,#dc3545,#c82333);box-shadow:0 3px 8px #dc35454d;color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#c82333,#bd2130);box-shadow:0 4px 12px #dc354566;transform:translateY(-2px)}@media (max-width:992px){.admin-tabs-container{flex-wrap:wrap}.admin-tabs{width:100%}.btn.btn-refresh-top{justify-content:center;width:100%}}@media (max-width:768px){.section-header{align-items:flex-start;flex-direction:column;gap:15px}.header-buttons{flex-wrap:wrap;width:100%}.btn{flex:1 1;min-width:120px}.admin-tabs{flex-wrap:wrap}.tab-btn{flex:1 1;min-width:100px}}@media (max-width:480px){.section-header h2{font-size:20px}.btn{font-size:12px;padding:8px 16px}.btn.btn-refresh-top{font-size:13px;padding:10px 18px}.tab-btn{font-size:14px;padding:10px 16px}}.search-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 4px #0000000d;margin-bottom:20px;padding:20px}.search-container{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.search-input{border:2px solid #e2e8f0;border-radius:8px;flex:1 1;min-width:300px;padding:12px 16px}.search-input:focus{box-shadow:0 0 0 3px #3b82f61a}.search-btn{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:12px 24px;transition:all .3s ease;white-space:nowrap}.search-btn:hover:not(:disabled){background:#2563eb;transform:translateY(-1px)}.search-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.clear-search-btn{background:#6b7280;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:12px 16px;transition:all .3s ease;white-space:nowrap}.clear-search-btn:hover{background:#4b5563;transform:translateY(-1px)}.search-info{background:#dbeafe;border:1px solid #93c5fd;border-radius:6px;margin-top:12px;padding:8px 12px}.search-results-count{color:#1e40af;font-size:.9rem;font-weight:600}.no-results{background:#f9fafb;border:2px dashed #d1d5db;border-radius:8px;color:#6b7280;padding:40px 20px;text-align:center}.no-results p{font-size:1.1rem;margin:0}@media (max-width:768px){.search-container{align-items:stretch;flex-direction:column}.search-input{min-width:auto}.clear-search-btn,.search-btn{width:100%}}.officer-dashboard-container{align-items:center;background:linear-gradient(#0006,#1e40af4d),url(https://images.unsplash.com/photo-1519452575417-564c1401ecc0?q=80&w=2070&auto=format&fit=crop&ixlib=rb-4.0.3&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D) no-repeat 50% fixed;background-attachment:fixed;background-size:cover;color:#1a202c;display:flex;flex-direction:column;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh;padding:40px 20px}.officer-dashboard-container h1{animation:slideDown 1s ease-in-out;border:2px solid #fff3;border-radius:16px;box-shadow:0 12px 30px #1e40af66;color:#fff;font-size:2.8rem;font-weight:800;margin-bottom:15px;padding:20px 40px;text-align:center;text-shadow:none}.officer-dashboard-container p{animation:slideDown 1s ease-in-out;animation-delay:.2s;animation-fill-mode:both;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #1e40af33;border-radius:12px;box-shadow:0 6px 20px #0000001a;color:#1f2937;font-size:1.3rem;font-weight:600;margin-bottom:20px;padding:15px 30px;text-shadow:none}.officer-dashboard-subtitle{backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background:#ffffffe6;border:1px solid #e5e7eb;border-radius:8px;color:#374151!important;font-size:1.2rem!important;font-weight:600;margin-bottom:30px;padding:10px 20px;text-align:center;text-shadow:none}.read-only-badge{animation:pulse 2s infinite;background:linear-gradient(135deg,#f59e0b,#d97706);border:2px solid #ffffff4d;border-radius:25px;box-shadow:0 4px 15px #f59e0b4d;color:#fff;display:inline-block;font-size:.9rem;font-weight:700;letter-spacing:.5px;margin-left:15px;padding:10px 18px;text-transform:uppercase}.read-only .block-card{background:linear-gradient(135deg,#64748b,#475569)!important;color:#fff!important;cursor:not-allowed;opacity:.9;position:relative}.read-only .block-card:before{align-items:center;background:#f59e0b;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 8px #0000004d;color:#fff;content:"👁️";display:flex;font-size:12px;height:24px;justify-content:center;left:-8px;position:absolute;top:-8px;width:24px}.read-only .block-card:hover{background:linear-gradient(135deg,#475569,#334155)!important;box-shadow:0 6px 16px #64748b66;transform:translateY(-2px)}.read-only .quarter-card{cursor:not-allowed;opacity:.9;position:relative}.read-only .quarter-card:after{background:#f59e0b;border:1px solid #ffffff4d;border-radius:6px;color:#fff;content:"Read Only";font-size:.75rem;font-weight:700;padding:4px 8px;position:absolute;right:10px;text-shadow:none;top:10px}.read-only .quarter-card:hover{box-shadow:0 6px 16px #00000026;transform:translateY(-2px)}.read-only button:not(.close-btn),.read-only input,.read-only select{background-color:#f3f4f6!important;color:#6b7280!important;cursor:not-allowed;opacity:.6;pointer-events:none}.filters-container{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#fffffff2;border:2px solid #1e40af1a;border-radius:16px;box-shadow:0 8px 25px #0000001a;display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-bottom:40px;max-width:1000px;padding:25px;width:100%}.search-input{background:#fff;border:2px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 12px #0000001a;color:#374151;font-size:1rem;font-weight:500;padding:15px 20px;transition:all .3s ease;width:320px}.search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f633,0 4px 12px #0000001a;outline:none;transform:translateY(-2px)}.search-input::placeholder{color:#9ca3af}.filter-select{background:#fff;border:2px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 12px #0000001a;color:#374151;cursor:pointer;font-size:1rem;font-weight:500;min-width:140px;padding:15px 20px;transition:all .3s ease}.filter-select:focus{border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f633,0 4px 12px #0000001a;outline:none;transform:translateY(-2px)}.types-container{display:flex;gap:25px;justify-content:space-between;max-width:1400px;width:100%}.type-column{animation:fadeInUp .8s ease-out;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);background:#ffffffe6;border:2px solid #ffffff4d;border-radius:20px;box-shadow:0 12px 35px #0000004d;flex:1 1;padding:30px;transition:all .3s ease}.type-column:hover{box-shadow:0 16px 45px #0003;transform:translateY(-5px)}.type-column h2{-webkit-text-fill-color:#1e40af!important;background:none!important;-webkit-background-clip:initial!important;border-bottom:3px solid #e5e7eb;color:#1e40af!important;font-size:1.8rem!important;font-weight:700!important;margin-bottom:25px;padding-bottom:15px;position:relative;text-align:center;text-shadow:none}.type-column h2:after{background:linear-gradient(135deg,#3b82f6,#1e40af);border-radius:2px;bottom:-3px;content:"";height:3px;left:50%;position:absolute;transform:translateX(-50%);width:60px}.block-list{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(70px,1fr));margin-top:20px}.block-card{align-items:center;background:linear-gradient(135deg,#1e40af,#3b82f6);border:2px solid #fff3;border-radius:12px;box-shadow:0 6px 16px #1e40af4d;color:#fff!important;cursor:pointer;display:flex;font-size:1.6rem;font-weight:700;height:70px;justify-content:center;position:relative;text-shadow:0 1px 2px #0003;transition:all .3s ease}.block-card:hover{background:linear-gradient(135deg,#1e3a8a,#1e40af);box-shadow:0 12px 25px #1e40af66;transform:translateY(-8px) scale(1.05)}.occupancy-indicator{display:flex;gap:4px;position:absolute;right:-10px;top:-10px}.filled-circle{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 3px 8px #10b98166}.filled-circle,.vacant-circle{align-items:center;border:2px solid #fff;border-radius:50%;color:#fff;display:flex;font-size:.75rem;font-weight:700;height:24px;justify-content:center;width:24px}.vacant-circle{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 3px 8px #ef444466}.modal-overlay{animation:fadeIn .3s ease-out;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#000000bf;z-index:1000}.modal-content{animation:scaleIn .4s ease-out;background:#fff;border:2px solid #ffffff4d;border-radius:20px;box-shadow:0 25px 60px #0006;color:#1f2937;max-height:85vh;max-width:1000px;overflow-y:auto;padding:40px;position:relative;width:90%}.close-btn{background:#ef44441a;border-radius:50%;color:#ef4444;font-size:2rem;position:absolute;right:25px;top:20px;width:40px}.close-btn:hover{background:#ef444433;color:#dc2626;transform:rotate(90deg) scale(1.1)}.blocklist-container h2{-webkit-text-fill-color:#1e40af!important;background:none!important;-webkit-background-clip:initial!important;color:#1e40af!important;font-size:2rem!important;font-weight:700!important;margin-bottom:30px;text-align:center;text-shadow:none}.quarter-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin-top:25px}.quarter-card{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #1e40af1a;border-radius:15px;box-shadow:0 6px 20px #0000001a;cursor:pointer;overflow:hidden;padding:25px;position:relative;transition:all .3s ease}.quarter-card:before{background:linear-gradient(135deg,#3b82f6,#1e40af);content:"";height:3px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.quarter-card:hover:before{transform:scaleX(1)}.quarter-card:hover{background:linear-gradient(135deg,#fff,#f8fafc);box-shadow:0 12px 30px #00000026;transform:translateY(-8px) scale(1.02)}.quarter-card h3{color:#1e40af!important;font-size:1.5rem!important;font-weight:700!important;margin:0 0 15px;text-shadow:none}.badge{background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:6px;box-shadow:0 2px 8px #1e40af4d;color:#fff;display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.5px;margin-bottom:15px;padding:6px 12px;text-transform:uppercase}.quarter-card p{color:#374151!important;font-size:1rem;font-weight:600;margin:12px 0}.quarter-card small{color:#6b7280!important;font-weight:500}.vacant{background:#dc26261a;border-radius:4px;color:#dc2626!important;font-weight:700!important;padding:2px 8px}.no-quarters{background:#6b72800d;border:2px dashed #d1d5db;border-radius:12px;color:#6b7280!important;font-size:1.2rem;font-style:italic;grid-column:1/-1;padding:60px;text-align:center}.quarter-modal h2{-webkit-text-fill-color:#1e40af!important;background:none!important;-webkit-background-clip:initial!important;color:#1e40af!important;font-size:2rem!important;font-weight:700!important;margin-bottom:30px;text-align:center;text-shadow:none}.details-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:30px}.detail-item{background:#f8fafce6;border:2px solid #1e40af1a;border-radius:12px;display:flex;flex-direction:column;padding:20px;transition:all .3s ease}.detail-item:hover{background:#f8fafc;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.detail-item label{color:#4b5563!important;font-size:.9rem;font-weight:700!important;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.detail-item span{color:#1e40af!important;font-size:1.2rem!important;font-weight:600!important}.section-divider{background:linear-gradient(135deg,#e5e7eb,#d1d5db);border-radius:2px;height:3px;margin:30px 0}.quarter-modal h3{color:#1e40af!important;font-size:1.6rem!important;font-weight:700!important;margin-bottom:25px}.bills-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.bill-card{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #1e40af1a;border-radius:12px;box-shadow:0 4px 15px #0000001a;padding:20px;text-align:center;transition:all .3s ease}.bill-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-4px)}.bill-card p{color:#6b7280!important;font-size:.9rem;font-weight:600;margin:0 0 12px}.bill-card h4{color:#1e40af!important;font-size:1.4rem!important;font-weight:700!important;margin:0 0 15px}.status-badge{border-radius:6px;font-size:.8rem}.status-badge.paid{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:1px solid #10b981;color:#065f46!important}.status-badge.pending{background:linear-gradient(135deg,#fee2e2,#fecaca);border:1px solid #ef4444;color:#991b1b!important}.repair-work-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:20px}.repair-item{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #0ea5e933;border-radius:12px;padding:20px;transition:all .3s ease}.repair-item:hover{background:linear-gradient(135deg,#fff,#f0f9ff);box-shadow:0 8px 25px #0ea5e926;transform:translateY(-4px)}.repair-item label{color:#1e40af!important;display:block;font-size:.9rem;font-weight:700!important;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.repair-item span{color:#475569!important;font-size:1.1rem;font-weight:600!important}@keyframes fadeInUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.officer-dashboard-container *{visibility:visible!important}.officer-dashboard-container h1,.officer-dashboard-container h2,.officer-dashboard-container h3,.officer-dashboard-container p{opacity:1!important}@media (max-width:1024px){.types-container{flex-wrap:wrap}.type-column{flex-basis:calc(50% - 20px);flex-grow:1;flex-shrink:0;margin-bottom:25px}.search-input{width:280px}}@media (max-width:768px){.officer-dashboard-container{padding:20px 15px}.officer-dashboard-container h1{font-size:2.2rem;padding:15px 25px}.officer-dashboard-container p{font-size:1.1rem;padding:12px 20px}.filters-container{align-items:center;flex-direction:column;gap:15px;padding:20px}.filter-select,.search-input{max-width:320px;width:100%}.type-column{flex:1 0 100%;padding:20px}.block-list{gap:12px;grid-template-columns:repeat(auto-fill,minmax(60px,1fr))}.block-card{font-size:1.4rem;height:60px}.modal-content{padding:25px;width:95%}.details-grid,.quarter-grid{grid-template-columns:1fr}.bills-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}@media (max-width:480px){.officer-dashboard-container h1{font-size:1.8rem;padding:12px 20px}.filters-container,.type-column{padding:15px}.block-card{font-size:1.2rem;height:50px}.modal-content,.quarter-card{padding:20px}.detail-item{padding:15px}}.debug *{background:#ff00001a!important;border:1px solid red!important}.login-container{align-items:center;background:linear-gradient(#0a1929d9,#0a1929f2),url(https://plus.unsplash.com/premium_photo-1687157829884-fae305709c06?fm=jpg&q=60&w=3000&ixlib=rb-4.1.0&ixid=M3wxMjA3fDB8MHxzZWFyY2h8MXx8cG9saWNlfGVufDB8fDB8fHww) no-repeat 50% fixed;background-size:cover;display:flex;flex-direction:column;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.login-container:before{background:radial-gradient(circle at 20% 50%,#1e3a8a26 0,#0000 50%),radial-gradient(circle at 80% 80%,#1e3a8a26 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.login-box{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#fffffffa;border-radius:20px;box-shadow:0 20px 60px #0006;max-width:450px;padding:2.5rem;position:relative;transition:all .5s ease;width:100%;z-index:1}.login-box.compact{max-width:420px;padding:2rem}.login-header{margin-bottom:2rem;text-align:center}.police-logo{background-size:70%;border:4px solid #f90;box-shadow:0 0 20px #f909,0 8px 25px #0000004d;font-size:3rem;height:90px;margin:0 auto 1.2rem;transition:transform .3s ease;width:90px}.police-logo:hover{transform:scale(1.05)}.login-header h2{color:#1e3a8a;font-size:1.6rem;font-weight:700;letter-spacing:-.5px;margin-bottom:.5rem}.login-header p{color:#64748b;font-size:.95rem;font-weight:500}.status-message{animation:slideDown .3s ease;border-radius:10px;font-size:.9rem;font-weight:500;margin-bottom:1.5rem;padding:1rem 1.2rem;text-align:center}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.status-error{background-color:#fee2e2;border:2px solid #fecaca;color:#dc2626}.input-group{margin-bottom:1.5rem}.input-group label{color:#1e3a8a;display:block;font-size:.9rem;font-weight:600;margin-bottom:.6rem}.input-group input{background:#f8fafc;border:2px solid #e5e7eb;border-radius:10px;box-sizing:border-box;font-size:1rem;padding:.9rem 1rem;transition:all .3s ease;width:100%}.input-group input:focus{background:#fff;border-color:#1e3a8a;box-shadow:0 0 0 4px #1e3a8a1a;outline:none}.input-group input:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.7}.login-btn{align-items:center;background:linear-gradient(135deg,#1e3a8a,#152c6e);border:none;border-radius:10px;box-shadow:0 4px 15px #1e3a8a66;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;margin-bottom:1.5rem;padding:1rem;transition:all .3s ease;width:100%}.login-btn:hover:not(:disabled){background:linear-gradient(135deg,#152c6e,#0f1f4d);box-shadow:0 6px 20px #1e3a8a80;transform:translateY(-2px)}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{background:#9ca3af;cursor:not-allowed;opacity:.7}.login-btn.loading{background:linear-gradient(135deg,#6b7280,#4b5563)}.spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:18px;width:18px}.additional-options{align-items:center;display:flex;font-size:.85rem;justify-content:space-between;margin-bottom:1.5rem}.remember-me{align-items:center;color:#64748b;cursor:pointer;display:flex;gap:.5rem;transition:color .3s ease}.remember-me:hover{color:#1e3a8a}.remember-me input{cursor:pointer;height:16px;width:16px}.forgot-password{color:#1e3a8a;font-weight:600;text-decoration:none;transition:all .3s ease}.forgot-password:hover{color:#152c6e;text-decoration:underline}.demo-section{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border:2px solid #cbd5e1;border-radius:12px;margin-top:2rem;padding:1.5rem}.demo-section h4{color:#1e3a8a;font-size:1.1rem;font-weight:700;margin-bottom:.5rem;text-align:center}.demo-info{color:#64748b;font-size:.85rem;font-weight:500;margin-bottom:1rem;text-align:center}.demo-buttons{display:flex;flex-direction:column;gap:.75rem}.demo-btn{background:#fff;border:2px solid #0000;border-radius:10px;box-shadow:0 2px 8px #0000001a;cursor:pointer;font-size:.9rem;gap:1rem;padding:1rem 1.2rem;text-align:left;transition:all .3s ease}.demo-btn,.demo-btn .role-icon{align-items:center;display:flex}.demo-btn .role-icon{font-size:2rem;justify-content:center;min-width:50px}.demo-btn .role-text{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.demo-btn .role-text strong{color:#1e3a8a;font-size:1rem;font-weight:700}.demo-btn .role-text small{color:#64748b;font-size:.8rem;font-weight:500}.demo-btn:hover:not(:disabled){box-shadow:0 6px 20px #00000026;transform:translateY(-3px)}.demo-btn:disabled{cursor:not-allowed;opacity:.5}.demo-btn.admin{border-color:#dc2626}.demo-btn.admin:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);border-color:#dc2626;color:#fff}.demo-btn.admin:hover:not(:disabled) .role-text small,.demo-btn.admin:hover:not(:disabled) .role-text strong{color:#fff}.demo-btn.officer{border-color:#1e3a8a}.demo-btn.officer:hover:not(:disabled){background:linear-gradient(135deg,#1e3a8a,#152c6e);border-color:#1e3a8a;color:#fff}.demo-btn.officer:hover:not(:disabled) .role-text small,.demo-btn.officer:hover:not(:disabled) .role-text strong{color:#fff}.demo-note{color:#64748b;font-size:.8rem;font-style:italic;margin-top:1rem;text-align:center}.welcome-screen{animation:fadeIn .5s ease;background:linear-gradient(135deg,#1e3a8a,#152c6e);border-radius:15px;box-shadow:0 10px 30px #1e3a8a4d;color:#fff;padding:3rem 2rem;text-align:center}.welcome-spinner{animation:spin 1s linear infinite;border:4px solid #fff3;border-radius:50%;border-top-color:#fff;height:60px;margin:0 auto 1.5rem;width:60px}.welcome-screen h2{color:#fff;font-size:1.6rem;font-weight:700;margin-bottom:.5rem}.welcome-screen p{color:#ffffffe6;font-size:.95rem;font-weight:500}.login-footer{color:#fffffff2;font-size:.85rem;margin-top:2rem;position:relative;text-align:center;z-index:1}.login-footer p{font-weight:500;margin:.25rem 0}.footer-links{display:flex;gap:1rem;justify-content:center;margin-top:.5rem}.footer-links a{color:#fffffff2;font-weight:500;text-decoration:none;transition:all .3s ease}.footer-links a:hover{color:#fff;text-decoration:underline}@media (max-width:500px){.login-container{padding:1rem}.login-box{padding:2rem 1.5rem}.login-header h2{font-size:1.3rem}.police-logo{height:70px;width:70px}.demo-btn{padding:.85rem}.demo-btn .role-icon{font-size:1.6rem;min-width:45px}.demo-btn .role-text strong{font-size:.95rem}.demo-btn .role-text small{font-size:.75rem}.additional-options{align-items:flex-start;flex-direction:column;gap:.75rem}.welcome-screen{padding:2rem 1.5rem}.welcome-screen h2{font-size:1.3rem}}.login-box{animation:fadeIn .5s ease}.demo-btn:focus,.input-group input:focus,.login-btn:focus{outline:3px solid #1e3a8a;outline-offset:2px}.demo-btn:focus{outline-color:#f90}.police-logo{position:relative}.police-logo:after{border:2px solid #0000;border-radius:50%;bottom:-4px;content:"";left:-4px;position:absolute;right:-4px;top:-4px;transition:border-color .3s ease}.police-logo:hover:after{border-color:#ff99004d}@media print{.login-container{display:none}}@keyframes pulse{0%,to{box-shadow:0 0 20px #f909,0 8px 25px #0000004d}50%{box-shadow:0 0 30px #f90c,0 8px 35px #0006}}.police-logo{animation:pulse 3s ease-in-out infinite}.navbar{background:linear-gradient(135deg,#1e3a8a,#0f2a61);box-shadow:0 4px 12px #00000026;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;height:80px;padding:0;position:sticky;top:0;z-index:1000}.navbar-container{align-items:center;display:flex;height:100%;justify-content:space-between;padding:0 2rem;position:relative;width:100%}.navbar-brand{align-items:center;display:flex;flex:0 0 auto}.brand-icon{background-color:#fff;background-position:50%;background-repeat:no-repeat;background-size:contain;border-radius:50%;box-shadow:0 0 12px #ffffff40;height:60px;transition:all .3s ease;width:60px}.brand-icon:hover{box-shadow:0 0 18px #fff6;transform:scale(1.05)}.navbar-title{align-items:center;display:flex;flex-direction:column;left:50%;position:absolute;text-align:center;transform:translateX(-50%)}.navbar-title .brand-title{font-size:1.8rem;font-weight:700;letter-spacing:.5px;margin:0;white-space:nowrap}.navbar-title .brand-subtitle{font-size:.9rem;letter-spacing:.5px;margin:0;opacity:.9}.navbar-links{flex:0 0 auto;gap:1.2rem}.nav-link,.navbar-links{align-items:center;display:flex}.nav-link{background:#ffffff14;border:1px solid #ffffff26;border-radius:8px;color:#fff;font-weight:600;gap:8px;padding:.6rem 1.2rem;text-decoration:none;transition:all .3s ease;white-space:nowrap}.nav-link:hover{background:#fff3;box-shadow:0 4px 10px #0003;transform:translateY(-2px)}.btn-logout{align-items:center;background:#ffffff26;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-weight:600;gap:8px;padding:.6rem 1.2rem;transition:all .3s ease;white-space:nowrap}.btn-logout:hover{background:#dc3545e6;box-shadow:0 4px 10px #0003;transform:translateY(-2px)}.hamburger-menu{background:#ffffff1a;border-radius:5px;cursor:pointer;display:none;flex-direction:column;gap:6px;padding:.5rem}.hamburger-menu span{background:#fff;border-radius:2px;height:3px;transition:all .3s ease;width:28px}.hamburger-menu.active{background:#fff3}.hamburger-menu.active span:first-child{transform:rotate(45deg) translate(6px,6px)}.hamburger-menu.active span:nth-child(2){opacity:0}.hamburger-menu.active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.requests-btn{cursor:pointer;position:relative}.request-badge{align-items:center;background-color:#ff4757;border-radius:50%;color:#fff;display:flex;font-size:12px;font-weight:700;height:18px;justify-content:center;position:absolute;right:-5px;top:-5px;width:18px}.requests-popup{background-color:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 8px 32px #00000026;max-height:600px;overflow:hidden;position:absolute;right:20px;top:100%;width:450px;z-index:1001}.popup-header{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:2px solid #f8f9fa;border-top-left-radius:12px;border-top-right-radius:12px;display:flex;justify-content:space-between;min-height:60px;padding:15px 20px}.popup-header h3{color:#2c3e50;flex:1 1;font-size:1.2rem;font-weight:700;margin:0 20px 0 0;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.popup-actions{flex-shrink:0;gap:10px;min-width:88px}.popup-actions,.refresh-btn{align-items:center;display:flex}.refresh-btn{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;height:40px;justify-content:center;min-width:40px;padding:10px 12px;transition:all .3s ease}.refresh-btn:hover{background:#0056b3;transform:scale(1.05)}.refresh-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.close-btn{align-items:center;background:#dc3545;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;height:40px;justify-content:center;min-width:40px;padding:10px;transition:all .3s ease}.close-btn:hover{background:#c82333;transform:scale(1.05)}.popup-content{max-height:500px;overflow-y:auto;padding:20px}.error-message,.loading-message,.no-requests{background:#f8f9fa;border-radius:8px;color:#6c757d;margin:30px 0;padding:20px;text-align:center}.error-message{background:#f8d7da;color:#dc3545}.retry-btn{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;margin-top:10px;padding:8px 16px}.requests-list{list-style:none;margin:0;padding:0}.request-item{background:#fff;border:2px solid #e9ecef;border-radius:12px;margin-bottom:16px;overflow:hidden;transition:all .3s ease}.request-item:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.request-item.pending{border-left:6px solid #ffc107}.request-item.in-progress{border-left:6px solid #007bff}.request-item.resolved{border-left:6px solid #28a745}.request-content{align-items:flex-start;display:flex;gap:15px;padding:20px;position:relative}.request-image{margin-bottom:15px}.request-image img{border-radius:8px;box-shadow:0 2px 8px #0000001a;height:120px;max-width:200px;object-fit:cover;width:100%}.request-details{flex:1 1;min-width:0}.request-details h4{color:#2c3e50;font-size:1.1rem;font-weight:600;line-height:1.4;margin:0 0 15px}.request-info{margin-bottom:15px}.request-info p{color:#6c757d;justify-content:space-between;margin:0 0 8px}.request-info strong{color:#495057;font-weight:600;min-width:80px}.status-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:12px;font-weight:700;gap:6px;letter-spacing:.5px;margin-bottom:15px;padding:6px 12px;text-transform:uppercase}.status-badge.pending{background-color:#fff3cd;border:1px solid #ffeaa7;color:#856404}.status-badge.in-progress{background-color:#cce5ff;border:1px solid #b3d9ff;color:#004085}.status-badge.resolved{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.admin-response{background:#f8f9fa;border-left:4px solid #007bff;border-radius:8px;margin-top:15px;padding:15px}.admin-response strong{color:#495057;display:block;margin-bottom:8px}.admin-response p{color:#6c757d;line-height:1.5;margin:0}.request-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:15px}.resolve-btn{align-items:center;background:#28a745;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;min-width:100px;padding:10px 20px;transition:all .3s ease;white-space:nowrap}.resolve-btn:hover{background:#218838;box-shadow:0 4px 8px #28a7454d;transform:translateY(-1px)}.resolve-btn:active{transform:translateY(0)}.resolve-btn:disabled{background:#6c757d;cursor:not-allowed;opacity:.6;transform:none}.modal-overlay{align-items:center;background:#00000080;display:flex;height:100%;justify-content:center;left:0;padding:20px;position:fixed;top:0;width:100%;z-index:1002}.resolve-modal{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal-header{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:2px solid #f8f9fa;border-top-left-radius:12px;border-top-right-radius:12px;display:flex;justify-content:space-between;padding:20px}.modal-header h3{color:#2c3e50;font-size:1.3rem;font-weight:700;margin:0}.modal-content{padding:25px}.form-group{margin-bottom:20px}.form-group label{color:#495057;display:block;font-weight:600;margin-bottom:8px}.form-group textarea{border:2px solid #e9ecef;border-radius:8px;font-family:inherit;font-size:14px;padding:12px;resize:vertical;transition:border-color .3s ease;width:100%}.form-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.modal-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:25px}.btn-resolve{background:#28a745;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .3s ease}.btn-resolve:hover{background:#218838;box-shadow:0 4px 8px #28a7454d;transform:translateY(-1px)}.btn-cancel{background:#6c757d;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .3s ease}.btn-cancel:hover{background:#5a6268;box-shadow:0 4px 8px #6c757d4d;transform:translateY(-1px)}.request-image-container{background:#f5f5f5;border-radius:8px;box-shadow:0 2px 8px #0000001a;cursor:pointer;flex-shrink:0;height:120px;margin-right:15px;overflow:hidden;position:relative;transition:transform .3s ease;width:120px}.request-image-container:hover{transform:scale(1.05)}.request-thumbnail{display:block;height:100%;object-fit:cover;width:100%}.image-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.request-image-container:hover .image-overlay{opacity:1}.image-overlay i{color:#fff;font-size:24px}.image-modal-overlay{align-items:center;animation:fadeIn .3s ease;background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.image-modal-content{background:#fff;border-radius:8px;box-shadow:0 10px 40px #0000004d;max-height:90vh;max-width:90vw;padding:20px;position:relative}.image-modal-content img{border-radius:4px;display:block;max-height:80vh;max-width:100%;object-fit:contain}.image-modal-close{align-items:center;background:#f44;border:none;border-radius:50%;box-shadow:0 4px 8px #0003;color:#fff;cursor:pointer;display:flex;font-size:18px;height:40px;justify-content:center;position:absolute;right:-15px;top:-15px;transition:transform .2s ease;width:40px;z-index:10001}.image-modal-close:hover{background:#c00;transform:scale(1.1)}.image-modal-actions{margin-top:15px;text-align:center}.image-modal-link{background:#007bff;border-radius:4px;color:#fff;display:inline-block;padding:10px 20px;text-decoration:none;transition:background .3s ease}.image-modal-link:hover{background:#0056b3}.image-modal-link i{margin-right:8px}.officer-view-badge{align-items:center;background:#6c757d;border-radius:20px;color:#fff;display:flex;font-size:12px;font-weight:500;gap:5px;padding:6px 12px;position:absolute;right:10px;top:10px}.officer-view-badge i{font-size:14px}.modal-request-image{margin-top:15px;text-align:center}.modal-request-image img{border:2px solid #e0e0e0;max-width:100%;transition:transform .2s ease}.modal-request-image img:hover{border-color:#007bff;transform:scale(1.02)}.request-info p{align-items:center;display:flex;font-size:14px;gap:8px;margin:8px 0}.request-info p i{color:#007bff;text-align:center;width:16px}.request-info p strong{color:#555;min-width:100px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width:1100px){.navbar{height:75px}.brand-icon{height:55px;width:55px}.navbar-title .brand-title{font-size:1.6rem}.navbar-title .brand-subtitle{font-size:.85rem}.requests-popup{width:400px}}@media (max-width:968px){.navbar-title .brand-title{font-size:1.4rem}.navbar-title .brand-subtitle{font-size:.8rem}.btn-logout,.nav-link{font-size:.9rem;padding:.5rem 1rem}.requests-popup{right:15px;width:350px}}@media (max-width:768px){.hamburger-menu{display:flex}.navbar-links{background:linear-gradient(135deg,#1e3a8a,#0f2a61);border-radius:0 0 0 12px;box-shadow:0 5px 15px #0003;clip-path:polygon(100% 0,100% 0,100% 0,100% 0);flex-direction:column;gap:.8rem;padding:1.2rem;position:absolute;right:0;top:100%;transition:clip-path .4s ease;width:220px}.navbar-links.active{clip-path:polygon(100% 0,100% 100%,0 100%,0 0)}.navbar{height:70px}.navbar-container{padding:0 1.5rem}.brand-icon{height:50px;width:50px}.navbar-title .brand-title{font-size:1.3rem}.navbar-title .brand-subtitle{display:none}.requests-popup{border-radius:12px;left:10px;max-height:calc(100vh - 90px);position:fixed;right:10px;top:70px;width:auto}.popup-header{flex-wrap:nowrap;gap:0;min-height:50px;padding:12px 15px}.popup-header h3{font-size:1rem;margin-right:15px;max-width:calc(100% - 100px)}.popup-actions{gap:8px;justify-content:flex-end;min-width:80px}.close-btn,.refresh-btn{flex-shrink:0;font-size:13px;height:36px;min-width:36px;padding:8px}.popup-header h3{font-size:1.1rem}.popup-content{max-height:calc(100vh - 170px);padding:15px}.request-content{flex-direction:column;padding:15px}.request-details h4{font-size:1rem}.request-info p{align-items:flex-start;flex-direction:column;gap:4px}.request-info strong{min-width:auto}.request-image img{height:100px;max-width:150px}.request-image-container{height:200px;margin-bottom:15px;margin-right:0;width:100%}.request-actions{justify-content:center}.image-modal-content,.modal-overlay{padding:10px}.resolve-modal{margin:0;max-width:none}.modal-header{padding:15px}.modal-content{padding:20px}.modal-actions{flex-direction:column;gap:10px}.btn-cancel,.btn-resolve{padding:15px;width:100%}}@media (max-width:576px){.navbar-container{padding:0 1rem}.navbar-title .brand-title{font-size:1.2rem}.brand-icon{height:45px;width:45px}.navbar-title{left:45%}.requests-popup{left:5px;right:5px}.popup-content,.popup-header,.request-content{padding:12px}.request-details h4{font-size:.95rem;margin-bottom:10px}.request-info p{font-size:13px;margin-bottom:6px}.status-badge{font-size:11px;padding:4px 10px}.admin-response{margin-top:10px;padding:12px}.request-image img{height:80px;max-width:120px}.resolve-btn{font-size:13px;padding:8px 16px}.modal-header h3{font-size:1rem}.modal-content{padding:15px}.form-group textarea{font-size:13px;padding:10px}.btn-cancel,.btn-resolve{font-size:13px;padding:12px}}@media (max-width:480px){.navbar-title .brand-title{font-size:1.1rem}.navbar-title{left:46%;transform:translateX(-45%)}.popup-header h3{font-size:1rem}.request-details h4{font-size:.9rem;line-height:1.3}.request-info p{font-size:12px}.status-badge{font-size:10px;padding:3px 8px}.request-image img{height:70px;max-width:100px}.resolve-btn{font-size:12px;padding:6px 12px}}@media (max-width:400px){.navbar-container{padding:0 .8rem}.navbar-title .brand-title{font-size:1rem;line-height:1.2;max-width:120px;text-align:center;white-space:normal}.brand-icon{height:40px;width:40px}.navbar{height:65px}.navbar-title{left:45%;transform:translateX(-45%)}.hamburger-menu{padding:.4rem}.hamburger-menu span{height:2.5px;width:24px}.navbar-links{padding:1rem;width:200px}.btn-logout,.nav-link{font-size:.85rem;padding:.5rem .8rem}.requests-popup{left:5px;max-height:calc(100vh - 75px);right:5px;top:65px}.popup-header{align-items:center;flex-direction:row;min-height:48px;padding:10px 12px}.popup-header h3{flex:1 1;font-size:.9rem;line-height:1.2;margin:0 12px 0 0;max-width:calc(100% - 80px)}.popup-actions{flex-shrink:0;gap:6px;justify-content:flex-end;min-width:70px}.close-btn,.refresh-btn{flex-shrink:0;font-size:11px;height:30px;min-width:30px;padding:5px}.popup-content{max-height:calc(100vh - 140px);padding:10px}.request-content{padding:10px}.request-details h4{font-size:.85rem;margin-bottom:8px}.request-info p{font-size:11px;margin-bottom:4px}.status-badge{font-size:9px;margin-bottom:10px;padding:2px 6px}.admin-response{margin-top:8px;padding:10px}.admin-response strong{font-size:12px;margin-bottom:6px}.admin-response p{font-size:11px}.request-image img{height:60px;max-width:80px}.resolve-btn{font-size:11px;padding:5px 10px}.request-actions{margin-top:10px}.modal-content{padding:12px}.form-group label{font-size:13px}.form-group textarea{font-size:12px;padding:8px}.btn-cancel,.btn-resolve{font-size:12px;padding:10px}.modal-header h3{font-size:.95rem}}.popup-content::-webkit-scrollbar{width:6px}.popup-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.popup-content::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.popup-content::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.loading-screen{background:linear-gradient(#0a1929e6,#0a1929f2);color:#fff;flex-direction:column;font-family:Arial,sans-serif;height:100%;left:0;position:fixed;top:0;width:100%;z-index:9999}.loading-screen,.police-logo{align-items:center;display:flex;justify-content:center}.police-logo{background-color:#1e3a8a;background-image:url(/static/media/UP_Police.74f99cd76626b524dde9.png);background-position:50%;background-repeat:no-repeat;background-size:80%;border:3px solid #f90;border-radius:50%;box-shadow:0 0 20px #ff990080;height:120px;margin-bottom:20px;width:120px}.loading-text{font-size:18px;letter-spacing:2px;margin-bottom:10px}.welcome-text{color:#f90;font-size:22px;font-weight:700;letter-spacing:1px;margin:15px 0;text-transform:uppercase}.user-role{background:#f903;border-radius:20px;font-size:16px;margin-bottom:20px;padding:5px 15px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#f90;height:40px;margin-top:20px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.fade-out{opacity:0;transition:opacity .5s ease-out}body{background:#f5f6fa;color:#2d3436;font-family:Arial,sans-serif;margin:0}.container{margin:auto;max-width:1000px;padding:20px}h1,h2{color:#1e3799}.navbar{align-items:center;background:#1e3799;color:#fff;display:flex;justify-content:space-between;padding:15px}.navbar a{color:#fff;margin-right:15px;text-decoration:none}.navbar .btn-logout{background:#ff4d4d;border:none;color:#fff;cursor:pointer;padding:6px 12px}.card{background:#fff;border-radius:8px;box-shadow:0 2px 6px #0000001a;margin:20px 0;padding:20px}.table{border-collapse:collapse;margin-top:10px;width:100%}.table td,.table th{border:1px solid #dcdde1;padding:10px;text-align:left}.table th{background:#f1f2f6}.filled{color:green;font-weight:700}.vacant{color:red;font-weight:700}.form{display:flex;flex-direction:column}.form input{border:1px solid #ccc;border-radius:4px;margin:8px 0;padding:10px}.btn-submit{background:#1e3799;border:none;border-radius:4px;color:#fff;cursor:pointer;margin-top:10px;padding:10px}.btn-submit:hover{background:#0c2461}
/*# sourceMappingURL=main.bce48a6b.css.map*/