.directory-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e4e8ec);display:flex;flex-direction:column;position:relative}.directory-container:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:70%;height:70%;background-image:url(/logo-watermark.jpg);background-size:contain;background-position:center;background-repeat:no-repeat;opacity:.06;pointer-events:none;z-index:0}.directory-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(135deg,#1a365d,#2c5282);color:#fff;position:sticky;top:0;z-index:100;box-shadow:0 2px 10px #00000026}.directory-header h1{margin:0;font-size:20px;font-weight:600;flex:1;text-align:center}.filter-section{padding:16px 20px 0}.filter-heading{font-size:14px;font-weight:600;color:#4a5568;text-transform:uppercase;letter-spacing:.5px;margin:0 0 16px;text-align:center}.type-nav-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;max-width:400px;margin:0 auto}.type-nav-button{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 12px;background:#fff;border:2px solid transparent;border-radius:16px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #00000014;min-height:100px}.type-nav-button:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0000001f}.type-nav-button:active{transform:translateY(-1px)}.type-nav-button.selected{border-color:#2c5282;box-shadow:0 6px 20px #2c528240}.type-nav-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:10px;font-size:24px;position:relative}.type-nav-label{font-size:13px;font-weight:600;color:#2d3748;text-align:center}.nav-favorites-badge{position:absolute;top:-6px;right:-6px;background:#e53e3e;color:#fff;font-size:11px;font-weight:600;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.all-type .type-nav-icon{background:linear-gradient(135deg,#f7fafc,#e2e8f0)}.all-type:hover,.all-type.selected{background:linear-gradient(135deg,#f7fafc,#fff)}.favorites-type .type-nav-icon{background:linear-gradient(135deg,#fffaf0,#feebc8)}.favorites-type:hover,.favorites-type.selected{background:linear-gradient(135deg,#fffaf0,#fff)}.filter-label{font-size:13px;font-weight:600;color:#4a5568;margin-bottom:8px}.filter-type-buttons{display:flex;gap:8px}.filter-button{background:#fff;border:2px solid #e2e8f0;color:#2d3748;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.filter-button:hover{border-color:#2c5282;color:#2c5282}.filter-button.selected{background:linear-gradient(135deg,#2c5282,#1a365d);border-color:transparent;color:#fff}.location-select-section{padding:16px 20px 0}.location-dropdown{width:100%;padding:14px 44px 14px 16px;font-size:16px;border:2px solid #e2e8f0;border-radius:12px;background:#fff;color:#2d3748;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%234a5568' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:20px}.search-section{padding:16px 20px}.search-input{width:100%;padding:14px 16px;font-size:16px;border:2px solid #e2e8f0;border-radius:12px;background:#fff;color:#2d3748;transition:all .2s ease}.search-input:focus{outline:none;border-color:#2c5282;box-shadow:0 0 0 3px #2c528226}.search-input::placeholder{color:#a0aec0}.results-section{flex:1;padding:0 20px 20px}.error-container,.empty-state{text-align:center;padding:40px 20px;color:#4a5568}.error-message{color:#c53030}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding:0 4px}.results-count{font-size:14px;font-weight:500;color:#718096}.user-hire-date{color:#a0aec0;font-size:12px;margin-top:2px}.user-terminated-badge{display:flex;align-items:center;justify-content:center;font-size:20px;padding:4px;opacity:.8}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:24px;padding:32px 24px;max-width:400px;width:100%;max-height:90vh;overflow-y:auto;position:relative;text-align:center;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:16px;right:16px;background:#f7fafc;border:none;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#4a5568;transition:all .2s ease}.modal-favorite{position:absolute;top:16px;left:16px;background:#f7fafc;border:none;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#cbd5e0;transition:all .2s ease}.modal-favorite:hover,.modal-favorite.is-favorite{background:#fefcbf;color:#ecc94b}.modal-favorite svg{width:20px;height:20px}.modal-avatar{width:80px;height:80px;background:linear-gradient(135deg,#2c5282,#1a365d);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:28px;margin:0 auto 16px}.modal-name{font-size:24px;font-weight:700;color:#1a365d;margin:0 0 4px}.modal-title{font-size:16px;color:#4a5568;margin:0 0 4px}.modal-department{font-size:14px;color:#718096;margin:0 0 4px}.modal-location{font-size:14px;color:#a0aec0;margin:0 0 20px}.modal-actions{display:flex;gap:12px;justify-content:center;margin-bottom:20px}.modal-button{display:flex;align-items:center;gap:8px;padding:12px 20px;border-radius:12px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s ease;color:#fff}.modal-button svg{width:18px;height:18px}.modal-button:hover{transform:translateY(-2px)}.email-button{background:linear-gradient(135deg,#2c5282,#1a365d)}.phone-button{background:linear-gradient(135deg,#276749,#22543d)}.teams-modal-button{background:linear-gradient(135deg,#6264a7,#4b4d8a)}.teams-modal-button.disabled{background:#718096!important}.teams-modal-button.no-teams svg{opacity:.7}.modal-email,.modal-phone{font-size:14px;color:#4a5568;margin:8px 0 0}.modal-forwarding{font-size:13px;margin:8px 0;padding:8px 12px;border-radius:6px;text-align:center}.modal-button.forwarded-external,.modal-button.forwarded-internal{position:relative}.modal-button.forwarded-external .modal-forwarding-arrow{color:#c53030;margin-left:4px;font-weight:700}.modal-button.forwarded-internal .modal-forwarding-arrow{color:#2f855a;margin-left:4px;font-weight:700}.modal-dates{margin-top:16px;padding-top:16px;border-top:1px solid #e2e8f0}.modal-hire-date,.modal-term-date{font-size:13px;color:#4a5568;margin:6px 0}.modal-term-date{color:#c53030}.date-label{font-weight:600;color:#2d3748}.modal-term-date .date-label{color:#c53030}.modal-terminated-notice{margin:16px 0;padding:12px 16px;background:#fff5f5;border:1px solid #feb2b2;border-radius:8px;color:#c53030;font-weight:600;text-align:center}.modal-unlicensed-notice{margin:16px 0;padding:12px 16px;background:#f7fafc;border:1px solid #cbd5e0;border-radius:8px;color:#4a5568;font-weight:600;text-align:center}.modal-button.disabled{background:#a0aec0!important;cursor:not-allowed;opacity:.7}.modal-button.disabled:hover{background:#a0aec0!important;transform:none}.modal-button.no-email svg{opacity:.7}@media (max-width: 480px){.directory-header{padding:12px 16px}.directory-header h1{font-size:18px}.filter-section,.location-select-section,.search-section,.results-section{padding-left:16px;padding-right:16px}.type-button{padding:8px 14px;font-size:13px}.user-card{padding:12px}.user-avatar{width:44px;height:44px;font-size:14px}.user-name{font-size:15px}.action-button{width:32px;height:32px}.action-button svg{width:16px;height:16px}.modal-actions{flex-direction:column}.modal-button{justify-content:center}}@media (prefers-color-scheme: dark){.directory-container{background:linear-gradient(135deg,#1a202c,#2d3748)}.filter-heading,.results-count{color:#a0aec0}.type-nav-button{background:#2d3748;border-color:#4a5568}.type-nav-button:hover{box-shadow:0 6px 20px #0000004d}.type-nav-button.selected{border-color:#63b3ed}.type-nav-label{color:#e2e8f0}.cc-type:hover,.cc-type.selected{background:linear-gradient(135deg,#553c9a,#2d3748)}.all-type:hover,.all-type.selected{background:linear-gradient(135deg,#4a5568,#2d3748)}.parish-type:hover,.parish-type.selected{background:linear-gradient(135deg,#2a4365,#2d3748)}.school-type:hover,.school-type.selected{background:linear-gradient(135deg,#22543d,#2d3748)}.favorites-type:hover,.favorites-type.selected{background:linear-gradient(135deg,#744210,#2d3748)}.filter-label{color:#a0aec0}.filter-button{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.filter-button:hover{border-color:#63b3ed;color:#63b3ed}.filter-button.selected{background:linear-gradient(135deg,#3182ce,#2b6cb0)}.location-dropdown,.search-input{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.location-dropdown:focus,.search-input:focus{border-color:#63b3ed}.user-card{background:#2d3748}.user-name{color:#e2e8f0}.user-title{color:#a0aec0}.user-department,.user-hire-date{color:#718096}.modal-content{background:#2d3748}.modal-close{background:#4a5568;color:#e2e8f0}.modal-close:hover{background:#718096}.modal-favorite{background:#4a5568}.modal-name{color:#e2e8f0}.modal-title,.modal-email,.modal-phone{color:#a0aec0}.modal-dates{border-top-color:#4a5568}.modal-hire-date{color:#a0aec0}.modal-hire-date .date-label{color:#e2e8f0}.modal-term-date,.modal-term-date .date-label{color:#fc8181}.modal-terminated-notice{background:#2d2020;border-color:#742a2a;color:#fc8181}.modal-unlicensed-notice{background:#2d3748;border-color:#4a5568;color:#a0aec0}.action-button.disabled{background:#4a5568}.modal-button.disabled{background:#4a5568!important}.forwarding-indicator{border-color:#2d3748}.forwarding-indicator.external{background:#c53030;color:#fff}.forwarding-indicator.internal{background:#2f855a;color:#fff}.modal-forwarding.external{background:#2d2020;border-color:#742a2a;color:#fc8181}.modal-forwarding.internal{background:#1c3d2e;border-color:#276749;color:#68d391}.modal-department,.modal-location{color:#718096}.loading-container p,.empty-state,.error-container{color:#a0aec0}.loading-spinner{border-color:#4a5568;border-top-color:#63b3ed}.app-footer{background:#2d3748b3;border-top-color:#4a5568}.app-footer p{color:#a0aec0}.app-footer a{color:#63b3ed}}.locations-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e4e8ec);display:flex;flex-direction:column;position:relative}.locations-container:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:70%;height:70%;background-image:url(/logo-watermark.jpg);background-size:contain;background-position:center;background-repeat:no-repeat;opacity:.06;pointer-events:none;z-index:0}.status-bar-spacer{height:50px;background:#fff;width:100%;flex-shrink:0}.back-button,.refresh-button{background:#ffffff26;border:none;color:#fff;width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.back-button:hover,.refresh-button:hover{background:#ffffff40;transform:scale(1.05)}.back-button:active,.refresh-button:active{transform:scale(.95)}.back-button svg,.refresh-button svg{width:22px;height:22px}.locations-content{flex:1;padding:20px;max-width:600px;margin:0 auto;width:100%;box-sizing:border-box}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px}.loading-spinner{width:48px;height:48px;border:4px solid #e4e8ec;border-top-color:#2c5282;border-radius:50%;animation:spin 1s linear infinite}.loading-container p{margin-top:16px;color:#4a5568;font-size:16px}.error-container{display:flex;flex-direction:column;align-items:center;padding:40px 20px;text-align:center}.error-message{color:#c53030;font-size:16px;margin-bottom:20px}.retry-button{background:#2c5282;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease}.retry-button:hover{background:#1a365d}.type-filter-section{margin-bottom:24px}.type-filter-section h2,.location-select-section h2{font-size:14px;font-weight:600;color:#4a5568;text-transform:uppercase;letter-spacing:.5px;margin:0 0 16px;text-align:center}.type-nav-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:400px;margin:0 auto}.type-nav-button{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px;background:#fff;border:2px solid transparent;border-radius:20px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #00000014;min-height:120px}.type-nav-button:hover{transform:translateY(-4px);box-shadow:0 8px 25px #00000026}.type-nav-button:active{transform:translateY(-2px)}.type-nav-button.selected{border-color:#2c5282;box-shadow:0 8px 25px #2c52824d}.type-nav-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:12px;font-size:28px}.type-nav-label{font-size:14px;font-weight:600;color:#2d3748;text-align:center}.type-filter-section.collapsed{margin-bottom:16px}.type-nav-grid.collapsed{grid-template-columns:1fr;max-width:200px}.type-nav-button.collapsed{flex-direction:row;padding:12px 16px;min-height:auto;gap:12px}.type-nav-button.collapsed .type-nav-icon{width:36px;height:36px;margin-bottom:0;font-size:18px;border-radius:10px}.type-nav-button.collapsed .type-nav-label{font-size:13px}.checking-employees{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#f7fafc;border-radius:12px;font-size:13px;color:#4a5568}.mini-spinner{width:16px;height:16px;border:2px solid #e2e8f0;border-top-color:#2c5282;border-radius:50%;animation:spin 1s linear infinite}.cc-type .type-nav-icon{background:linear-gradient(135deg,#faf5ff,#e9d8fd)}.cc-type:hover,.cc-type.selected{background:linear-gradient(135deg,#faf5ff,#fff)}.parish-type .type-nav-icon{background:linear-gradient(135deg,#ebf8ff,#bee3f8)}.parish-type:hover,.parish-type.selected{background:linear-gradient(135deg,#ebf8ff,#fff)}.school-type .type-nav-icon{background:linear-gradient(135deg,#f0fff4,#c6f6d5)}.school-type:hover,.school-type.selected{background:linear-gradient(135deg,#f0fff4,#fff)}.office-type .type-nav-icon{background:linear-gradient(135deg,#fffaf0,#feebc8)}.office-type:hover,.office-type.selected{background:linear-gradient(135deg,#fffaf0,#fff)}.cemetery-type .type-nav-icon{background:linear-gradient(135deg,#faf5ff,#e9d8fd)}.cemetery-type:hover,.cemetery-type.selected{background:linear-gradient(135deg,#faf5ff,#fff)}.default-type .type-nav-icon{background:linear-gradient(135deg,#f7fafc,#e2e8f0)}.default-type:hover,.default-type.selected{background:linear-gradient(135deg,#f7fafc,#fff)}.location-select-section{margin-bottom:24px;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.location-dropdown{width:100%;padding:14px 44px 14px 16px;font-size:16px;border:2px solid #e2e8f0;border-radius:12px;background:#fff;color:#2d3748;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%234a5568' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:20px}.location-dropdown:hover{border-color:#2c5282}.location-dropdown:focus{outline:none;border-color:#2c5282;box-shadow:0 0 0 3px #2c528226}.location-details-section{animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.location-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px #0000001a;border:1px solid #e2e8f0}.location-title{font-size:22px;font-weight:700;color:#1a365d;margin:0 0 20px;padding-bottom:16px;border-bottom:2px solid #e2e8f0}.location-detail{display:flex;align-items:flex-start;gap:14px;padding:14px 0;border-bottom:1px solid #f0f4f8}.location-detail:last-child{border-bottom:none;padding-bottom:0}.detail-icon{width:40px;height:40px;background:linear-gradient(135deg,#ebf4ff,#e0e7ff);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.detail-icon svg{width:20px;height:20px;stroke:#2c5282}.detail-link{color:#2c5282;text-decoration:none;font-size:16px;line-height:1.5;transition:all .2s ease;word-break:break-word}.detail-link:hover{color:#1a365d;text-decoration:underline}.address-link{font-weight:500}.phone-link{font-weight:600;font-size:18px}.website-link{display:inline-flex;align-items:center;gap:6px;font-weight:500}.location-actions{display:flex;gap:12px;margin-top:24px;padding-top:20px;border-top:2px solid #e2e8f0}.location-action-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px 12px;border:none;border-radius:16px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0000001a}.location-action-btn svg{width:24px;height:24px}.location-action-btn:hover{transform:translateY(-3px);box-shadow:0 6px 20px #00000026}.location-action-btn:active{transform:translateY(-1px)}.employees-btn{background:#3182ce;color:#fff}.employees-btn svg{stroke:#fff}.employees-btn:hover{background:#2b6cb0}.metrics-btn{background:#dd6b20;color:#fff}.metrics-btn svg{stroke:#fff}.metrics-btn:hover{background:#c05621}.documents-btn{background:#805ad5;color:#fff}.documents-btn svg{stroke:#fff}.documents-btn:hover{background:#6b46c1}.empty-state{text-align:center;padding:40px 20px;color:#4a5568}.department-employees-section{padding:0 20px;margin-top:20px}.department-header{font-size:20px;font-weight:600;color:#1a365d;margin-bottom:16px;display:flex;align-items:center;gap:12px}.employee-count{font-size:14px;font-weight:400;color:#718096}.user-list{display:flex;flex-direction:column;gap:12px}.user-card{display:flex;align-items:center;gap:14px;padding:16px;background:#fff;border-radius:16px;box-shadow:0 2px 8px #00000014;cursor:pointer;transition:all .2s ease;position:relative}.user-card:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0000001f}.user-avatar{width:50px;height:50px;background:linear-gradient(135deg,#2c5282,#1a365d);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:16px;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-weight:600;color:#1a365d;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-title{color:#4a5568;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-department{color:#718096;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.favorite-button{background:none;border:none;padding:8px;cursor:pointer;color:#cbd5e0;transition:all .2s ease}.favorite-button:hover{color:#ecc94b;transform:scale(1.1)}.favorite-button.is-favorite{color:#ecc94b}.favorite-button svg{width:24px;height:24px}.user-actions{display:flex;flex-direction:column;gap:6px}.action-button{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;transition:all .2s ease;background:#2c5282}.action-button:hover{transform:scale(1.05);background:#1a365d}.action-button svg{width:18px;height:18px}.action-button.teams-button{background:#6264a7}.action-button.teams-button:hover{background:#4b4d8a}.action-button.disabled{background:#a0aec0;cursor:not-allowed;opacity:.7}.action-button.disabled:hover{transform:none;background:#a0aec0}.action-button.no-email{position:relative}.action-button.no-email svg,.action-button.no-teams svg{opacity:.6}.action-button.teams-button.disabled{background:#718096}.email-button-wrapper{position:relative;display:flex;flex-direction:column;align-items:center}.forwarding-indicator{position:absolute;bottom:-6px;right:-8px;font-size:16px;font-weight:700;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;line-height:1;border:2px solid white;box-shadow:0 2px 4px #0000004d}.forwarding-indicator.external{background:#e53e3e;color:#fff}.forwarding-indicator.internal{background:#38a169;color:#fff}.user-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.user-modal{background:#fff;border-radius:20px;padding:32px 24px;max-width:400px;width:100%;text-align:center;position:relative;max-height:90vh;overflow-y:auto}.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#718096;transition:all .2s ease}.modal-close:hover{background:#edf2f7;color:#2d3748}.modal-close svg{width:20px;height:20px}.modal-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#1a365d,#2c5282);display:flex;align-items:center;justify-content:center;color:#fff;font-size:28px;font-weight:600;margin:0 auto 16px}.modal-name{font-size:22px;font-weight:700;color:#1a365d;margin:0 0 4px}.modal-title{font-size:15px;color:#4a5568;margin:0 0 4px}.modal-department{font-size:13px;color:#718096;margin:0 0 24px}.modal-contact-list{display:flex;flex-direction:column;gap:10px}.modal-contact-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f7fafc;border-radius:10px;color:#2d3748;text-decoration:none;transition:all .2s ease}.modal-contact-item:hover{background:#3182ce;color:#fff}.modal-contact-item svg{width:20px;height:20px;flex-shrink:0}.modal-contact-item span{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-contact-item.teams-link{background:#5558af;color:#fff}.modal-contact-item.teams-link:hover{background:#4a4d9e}.modal-forwarding{font-size:13px;margin:0;padding:8px 12px;border-radius:6px;text-align:center}.modal-forwarding.external{background:#fff5f5;color:#c53030;border:1px solid #feb2b2}.modal-forwarding.internal{background:#f0fff4;color:#2f855a;border:1px solid #9ae6b4}.modal-forwarding .forwarding-address{font-weight:600;word-break:break-all}.modal-favorite{position:absolute;top:16px;left:16px;background:none;border:none;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#cbd5e0;transition:all .2s ease}.modal-favorite:hover{color:#ecc94b;transform:scale(1.1)}.modal-favorite.is-favorite{color:#ecc94b}.modal-favorite svg{width:24px;height:24px}@media (max-width: 480px){.locations-content{padding:16px}.page-header{padding:12px 16px}.page-header h1{font-size:18px}.type-button{padding:8px 14px;font-size:13px}.location-card{padding:20px}.location-title{font-size:20px}.detail-icon{width:36px;height:36px}.detail-icon svg{width:18px;height:18px}.location-actions{gap:8px}.location-action-btn{padding:12px 8px;font-size:11px}.location-action-btn svg{width:20px;height:20px}}@media (prefers-color-scheme: dark){.locations-container{background:linear-gradient(135deg,#1a202c,#2d3748)}.type-nav-button{background:#2d3748;border-color:#4a5568}.type-nav-button:hover{box-shadow:0 8px 25px #0000004d}.type-nav-button.selected{border-color:#63b3ed}.type-nav-label{color:#e2e8f0}.checking-employees{background:#2d3748;color:#a0aec0}.mini-spinner{border-color:#4a5568;border-top-color:#63b3ed}.cc-type:hover,.cc-type.selected{background:linear-gradient(135deg,#553c9a,#2d3748)}.parish-type:hover,.parish-type.selected{background:linear-gradient(135deg,#2a4365,#2d3748)}.school-type:hover,.school-type.selected{background:linear-gradient(135deg,#22543d,#2d3748)}.office-type:hover,.office-type.selected{background:linear-gradient(135deg,#744210,#2d3748)}.cemetery-type:hover,.cemetery-type.selected{background:linear-gradient(135deg,#44337a,#2d3748)}.default-type:hover,.default-type.selected{background:linear-gradient(135deg,#4a5568,#2d3748)}.location-dropdown{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.location-card{background:#2d3748;border-color:#4a5568}.location-title{color:#e2e8f0;border-bottom-color:#4a5568}.location-detail{border-bottom-color:#4a5568}.detail-icon{background:linear-gradient(135deg,#2b6cb0,#2c5282)}.detail-icon svg{stroke:#e2e8f0}.detail-link{color:#63b3ed}.detail-link:hover{color:#90cdf4}.type-filter-section h2,.location-select-section h2,.loading-container p{color:#a0aec0}.loading-spinner{border-color:#4a5568;border-top-color:#63b3ed}.empty-state{color:#a0aec0}.location-actions{border-top-color:#4a5568}.employees-btn{background:#2b6cb0;color:#fff}.employees-btn svg{stroke:#fff}.employees-btn:hover{background:#3182ce}.metrics-btn{background:#c05621;color:#fff}.metrics-btn svg{stroke:#fff}.metrics-btn:hover{background:#dd6b20}.documents-btn{background:#6b46c1;color:#fff}.documents-btn svg{stroke:#fff}.documents-btn:hover{background:#805ad5}.app-footer{background:#2d3748b3;border-top-color:#4a5568}.app-footer p{color:#a0aec0}.app-footer a{color:#63b3ed}.department-header{color:#e2e8f0}.employee-count{color:#a0aec0}.user-card{background:#2d3748}.user-name{color:#e2e8f0}.user-title{color:#a0aec0}.user-department{color:#718096}.favorite-button{color:#4a5568}.favorite-button:hover,.favorite-button.is-favorite{color:#ecc94b}.action-button{background:#4a5568}.action-button:hover{background:#63b3ed}.action-button.teams-button{background:#5558af}.user-modal-overlay{background:#000c}.user-modal{background:#2d3748}.modal-name{color:#e2e8f0}.modal-title,.modal-department{color:#a0aec0}.modal-contact-item{background:#4a5568;color:#e2e8f0}.modal-contact-item:hover{background:#63b3ed}.modal-favorite{color:#4a5568}.modal-favorite:hover,.modal-favorite.is-favorite{color:#ecc94b}.forwarding-indicator{border-color:#2d3748}.forwarding-indicator.external{background:#c53030;color:#fff}.forwarding-indicator.internal{background:#2f855a;color:#fff}.modal-forwarding.external{background:#2d2020;border-color:#742a2a;color:#fc8181}.modal-forwarding.internal{background:#1c3d2e;border-color:#276749;color:#68d391}.action-button.disabled{background:#4a5568}}.news-container{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#667eea,#764ba2);position:relative}.news-container:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" preserveAspectRatio="none"><text x="50" y="55" font-size="40" text-anchor="middle" fill="rgba(255,255,255,0.03)" font-family="serif">✝</text></svg>');background-size:80px 80px;pointer-events:none;z-index:0}.news-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#fffffff2;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:10}.news-header h1{font-size:20px;font-weight:700;color:#1a202c;margin:0}.news-header .back-button{width:40px;height:40px;border:none;background:#f7fafc;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.news-header .back-button:hover{background:#edf2f7}.news-header .back-button svg{width:24px;height:24px;color:#4a5568}.news-header .refresh-button{width:40px;height:40px;border:none;background:#f7fafc;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.news-header .refresh-button:hover{background:#edf2f7}.news-header .refresh-button svg{width:20px;height:20px;color:#4a5568}.news-content{flex:1;padding:20px;overflow-y:auto;position:relative;z-index:1}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#fff}.loading-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.loading-container p{font-size:16px;opacity:.9}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#fff;text-align:center}.error-icon{margin-bottom:16px}.error-icon svg{width:48px;height:48px;opacity:.8}.error-container p{font-size:16px;margin-bottom:20px;opacity:.9}.retry-button{padding:12px 24px;background:#fff;color:#667eea;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.retry-button:hover{transform:scale(1.05);box-shadow:0 4px 12px #0003}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#fff;text-align:center}.empty-icon{margin-bottom:16px}.empty-icon svg{width:64px;height:64px;opacity:.6}.empty-state p{font-size:16px;opacity:.9}.news-list{display:flex;flex-direction:column;gap:16px}.news-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 12px #0000001a;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column}.news-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000026}.news-card.main-hub{border:2px solid #667eea}.news-image{width:100%;height:180px;overflow:hidden;background:#f7fafc;cursor:pointer}.news-image img{width:100%;height:100%;object-fit:cover}.news-body{padding:16px;flex:1}.news-meta{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}.news-site{font-size:12px;font-weight:600;color:#667eea;background:#ebf4ff;padding:4px 8px;border-radius:4px}.news-site.clickable{cursor:pointer;transition:all .2s ease}.news-site.clickable:hover{background:#667eea;color:#fff;transform:scale(1.05)}.hub-badge{font-size:10px;font-weight:700;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);padding:3px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.news-date{font-size:12px;color:#718096;margin-left:auto}.news-title{font-size:18px;font-weight:700;color:#1a202c;margin:0 0 8px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;cursor:pointer;transition:color .2s ease}.news-title:hover{color:#667eea}.news-description{font-size:14px;color:#4a5568;margin:0 0 8px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;cursor:pointer}.news-author{font-size:12px;color:#718096;margin:0;font-style:italic}.news-icon{display:flex;align-items:center;justify-content:center;padding:0 16px;color:#667eea;opacity:.6;cursor:pointer}.news-icon svg{width:28px;height:28px}.news-icon:hover{opacity:1}.news-container .app-footer{padding:16px 20px;text-align:center;background:#ffffffb3;border-top:1px solid #e2e8f0;position:relative;z-index:1}.news-container .app-footer p{margin:0;font-size:12px;color:#4a5568;line-height:1.5}.news-container .app-footer a{color:#667eea;text-decoration:none;font-weight:500}.news-container .status-bar-spacer{height:50px;background:#fffffff2;flex-shrink:0}@media (min-width: 768px){.news-content{max-width:800px;margin:0 auto;padding:24px}.news-card{flex-direction:row}.news-image{width:200px;height:auto;min-height:150px;flex-shrink:0}.news-body{padding:20px}.news-icon{display:flex;align-items:center;padding:0 16px;color:#667eea;cursor:pointer}.news-icon svg{width:28px;height:28px}.news-icon:hover{color:#764ba2}}@media (min-width: 1024px){.news-content{max-width:900px}.news-image{width:250px}}@media (prefers-color-scheme: dark){.news-header{background:#1a202cf2;border-bottom-color:#2d3748}.news-header h1{color:#f7fafc}.news-header .back-button,.news-header .refresh-button{background:#2d3748}.news-header .back-button:hover,.news-header .refresh-button:hover{background:#4a5568}.news-header .back-button svg,.news-header .refresh-button svg{color:#e2e8f0}.news-card{background:#2d3748}.news-card.main-hub{border-color:#805ad5}.news-image{background:#1a202c}.news-site{background:#4a5568;color:#b794f4}.news-site.clickable:hover{background:#805ad5;color:#fff}.news-title{color:#f7fafc}.news-title:hover{color:#b794f4}.news-description{color:#a0aec0}.news-author,.news-date{color:#718096}.news-icon{color:#b794f4}.news-icon:hover{color:#d6bcfa;opacity:1}.news-container .app-footer{background:#1a202ce6;border-top-color:#2d3748}.news-container .app-footer p{color:#a0aec0}.news-container .app-footer a{color:#b794f4}.news-container .status-bar-spacer{background:#1a202cf2}}*,*:before,*:after{box-sizing:border-box}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fa}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a365d,#2c5282,#3182ce);padding:20px;padding-top:calc(20px + env(safe-area-inset-top,0px));padding-bottom:calc(20px + env(safe-area-inset-bottom,0px))}.login-card{background:#fff;border-radius:24px;padding:48px 40px;text-align:center;max-width:400px;width:100%;box-shadow:0 20px 60px #0000004d}.login-logo{width:min(200px,50vw);height:min(200px,50vw);object-fit:contain;margin-bottom:24px;border-radius:16px}.login-card h1{margin:0 0 16px;font-size:28px;font-weight:700;color:#1a365d}.login-disclaimer{color:#4a5568;font-size:14px;line-height:1.6;margin:0 0 32px}.login-button{width:100%;padding:16px 24px;font-size:16px;font-weight:600;color:#fff;background:linear-gradient(135deg,#2c5282,#1a365d);border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #2c528266}.login-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2c528280}.login-button:active{transform:translateY(0)}.login-copyright{margin:24px 0 0;font-size:12px;color:#718096}.login-version{margin:8px 0 0;font-size:11px;color:#a0aec0}.home-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e4e8ec);display:flex;flex-direction:column;position:relative}.home-container:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:70%;height:70%;background-image:url(/logo-watermark.jpg);background-size:contain;background-position:center;background-repeat:no-repeat;opacity:.06;pointer-events:none;z-index:0}.home-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(135deg,#1a365d,#2c5282);color:#fff;box-shadow:0 2px 10px #00000026}.status-bar-spacer{height:50px;background:#fff;width:100%;flex-shrink:0;position:relative;z-index:101}.home-logo{width:44px;height:44px;object-fit:contain;border-radius:8px;background:#fff;padding:4px}.home-header h1{margin:0;font-size:20px;font-weight:600;flex:1;text-align:center}.logout-button{background:#ffffff26;border:none;color:#fff;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.logout-button:hover{background:#ffffff40}.nav-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;padding:24px 20px;max-width:500px;margin:0 auto;width:100%;flex:1;align-content:start}.nav-button{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 20px;background:#fff;border:none;border-radius:20px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #00000014;min-height:160px}.nav-button:hover{transform:translateY(-4px);box-shadow:0 8px 25px #00000026}.nav-button:active{transform:translateY(-2px)}.nav-icon{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.nav-icon svg{width:32px;height:32px}.nav-label{font-size:15px;font-weight:600;color:#2d3748;text-align:center}.directory-button .nav-icon{background:linear-gradient(135deg,#ebf8ff,#bee3f8)}.directory-button .nav-icon svg{stroke:#2b6cb0}.directory-button:hover{background:linear-gradient(135deg,#ebf8ff,#fff)}.locations-button .nav-icon{background:linear-gradient(135deg,#f0fff4,#c6f6d5)}.locations-button .nav-icon svg{stroke:#276749}.locations-button:hover{background:linear-gradient(135deg,#f0fff4,#fff)}.metrics-button .nav-icon{background:linear-gradient(135deg,#fffaf0,#feebc8)}.metrics-button .nav-icon svg{stroke:#c05621}.metrics-button:hover{background:linear-gradient(135deg,#fffaf0,#fff)}.news-button .nav-icon{background:linear-gradient(135deg,#faf5ff,#e9d8fd)}.news-button .nav-icon svg{stroke:#6b46c1}.news-button:hover{background:linear-gradient(135deg,#faf5ff,#fff)}.app-footer{padding:16px 20px;text-align:center;background:#ffffffb3;border-top:1px solid #e2e8f0;margin-top:auto;position:relative;z-index:1}.app-footer p{margin:0;font-size:12px;color:#4a5568;line-height:1.5}.app-footer a{color:#2c5282;text-decoration:none;font-weight:500}.app-footer a:hover{text-decoration:underline}.footer-version{margin-top:8px!important;font-size:11px!important;color:#a0aec0!important}.placeholder-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e4e8ec);display:flex;flex-direction:column;position:relative}.placeholder-container:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:70%;height:70%;background-image:url(/logo-watermark.jpg);background-size:contain;background-position:center;background-repeat:no-repeat;opacity:.06;pointer-events:none;z-index:0}.placeholder-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}.placeholder-icon{width:80px;height:80px;background:linear-gradient(135deg,#e2e8f0,#cbd5e0);border-radius:20px;display:flex;align-items:center;justify-content:center;margin-bottom:24px}.placeholder-icon svg{width:40px;height:40px;stroke:#718096}.placeholder-content p{font-size:18px;color:#4a5568;margin:0}.page-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(135deg,#1a365d,#2c5282);color:#fff;position:sticky;top:0;z-index:100;box-shadow:0 2px 10px #00000026}.page-header h1{margin:0;font-size:20px;font-weight:600;flex:1;text-align:center}.back-button{background:#ffffff26;border:none;color:#fff;width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.back-button:hover{background:#ffffff40;transform:scale(1.05)}.back-button:active{transform:scale(.95)}.back-button svg{width:22px;height:22px}@media (max-width: 480px){.login-card{padding:36px 24px;border-radius:20px}.login-card h1{font-size:24px}.nav-grid{gap:12px;padding:16px}.nav-button{padding:24px 16px;min-height:140px;border-radius:16px}.nav-icon{width:56px;height:56px;margin-bottom:12px}.nav-icon svg{width:28px;height:28px}.nav-label{font-size:14px}.home-header{padding:12px 16px}.home-header h1{font-size:18px}.home-logo{width:40px;height:40px}}@media (prefers-color-scheme: dark){body{background:#1a202c}.home-container,.placeholder-container{background:linear-gradient(135deg,#1a202c,#2d3748)}.nav-button{background:#2d3748}.nav-button:hover{background:#3d4a5c}.nav-label{color:#e2e8f0}.directory-button .nav-icon{background:linear-gradient(135deg,#2b6cb0,#3182ce)}.directory-button .nav-icon svg{stroke:#fff}.locations-button .nav-icon{background:linear-gradient(135deg,#276749,#38a169)}.locations-button .nav-icon svg{stroke:#fff}.metrics-button .nav-icon{background:linear-gradient(135deg,#c05621,#dd6b20)}.metrics-button .nav-icon svg{stroke:#fff}.news-button .nav-icon{background:linear-gradient(135deg,#6b46c1,#805ad5)}.news-button .nav-icon svg{stroke:#fff}.placeholder-icon{background:linear-gradient(135deg,#4a5568,#2d3748)}.placeholder-icon svg{stroke:#a0aec0}.placeholder-content p{color:#a0aec0}.app-footer{background:#2d3748b3;border-top-color:#4a5568}.app-footer p{color:#a0aec0}.app-footer a{color:#63b3ed}.logout-button{background:#ffffff1a}.logout-button:hover{background:#fff3}}.update-banner{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#2c5282,#1a365d);color:#fff;padding:16px 20px;display:flex;flex-direction:column;gap:12px;z-index:9999;box-shadow:0 4px 20px #0000004d;animation:slideDown .3s ease}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.update-banner-content{display:flex;align-items:center;gap:12px;font-size:14px;font-weight:500}.update-icon{width:24px;height:24px;flex-shrink:0}.update-banner-actions{display:flex;gap:12px}.update-btn{background:#fff;color:#1a365d;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.update-btn:hover{background:#edf2f7;transform:translateY(-1px)}.dismiss-btn{background:#fff3;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.dismiss-btn:hover{background:#ffffff4d}@media (min-width: 480px){.update-banner{flex-direction:row;align-items:center;justify-content:space-between}}.install-banner{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 16px;background:#edf2f7;color:#2d3748;font-size:14px}.install-button{background:#2c5282;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer}.install-button:hover{background:#1a365d}.dismiss-button{background:none;border:none;color:#718096;font-size:20px;cursor:pointer;padding:4px 8px}.dismiss-button:hover{color:#4a5568}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{overscroll-behavior-y:none;-webkit-overflow-scrolling:touch}
