*{margin:0;padding:0;box-sizing:border-box}body{font-family:Hiragino Kaku Gothic ProN,Hiragino Sans,Meiryo,sans-serif;background-color:#f5f5f5}.header{background:linear-gradient(135deg,#8b4513,sienna);color:#fff;padding:1rem 2rem;box-shadow:0 2px 10px #0000001a}.header h1{font-size:1.8rem;font-weight:700;display:flex;align-items:center;gap:.5rem}.header-icon{font-size:2rem}.header-logo{height:50px;vertical-align:middle}.header-beta{font-size:1.2rem;font-weight:400;opacity:.9;margin-left:.5rem}.container{display:flex;height:calc(100vh - 80px);position:relative}.sidebar-toggle-btn{position:absolute;left:350px;top:50%;transform:translateY(-50%);z-index:1000;width:30px;height:60px;background:#8b4513;border:none;border-radius:0 8px 8px 0;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:2px 0 8px #0003}.sidebar-toggle-btn:hover{background:sienna;box-shadow:2px 0 12px #0000004d}.sidebar-toggle-btn i{font-size:14px;transition:transform .3s ease}.container.sidebar-collapsed .sidebar-toggle-btn{left:0}.sidebar{width:350px;min-width:350px;flex-shrink:0;background:#fff;border-right:1px solid #ddd;overflow-y:auto;box-shadow:2px 0 10px #0000001a;transition:transform .3s ease,width .3s ease,min-width .3s ease;transform:translate(0);display:flex;flex-direction:column}.container.sidebar-collapsed .sidebar{transform:translate(-350px);width:0;min-width:0;border-right:none;box-shadow:none}.sidebar-content{flex:1;overflow-y:auto;display:flex;flex-direction:column}.sidebar-footer{padding:1rem;background:#f8f8f8;border-top:1px solid #ddd;margin-top:auto}.footer-links{display:flex;flex-direction:column;gap:.75rem;margin-bottom:.75rem}.footer-links a{color:#8b4513;text-decoration:none;font-size:.9rem;display:flex;align-items:center;gap:.5rem;transition:color .2s}.footer-links i{font-size:.85rem}.footer-copyright{font-size:.75rem;color:#666;text-align:center;padding-top:.5rem;border-top:1px solid #ddd}.footer-copyright a{color:#8b4513;text-decoration:none;transition:color .2s}.footer-links a:hover,.footer-copyright a:hover{color:sienna;text-decoration:underline}.map-container{flex:1;position:relative;transition:margin-left .3s ease}#map{width:100%;height:100%}.tabs{display:flex;background:#fff;border-bottom:1px solid #ddd}.tab{flex:1;padding:1rem;text-align:center;cursor:pointer;border-bottom:3px solid transparent;transition:all .2s;font-weight:600;color:#666}.tab.active{color:#8b4513;border-bottom-color:#8b4513;background:#f8f9fa}.tab:hover{background:#f8f9fa}.search-section{padding:1.5rem;border-bottom:1px solid #eee}.search-section h3{color:#8b4513;margin-bottom:1rem;font-size:1.1rem;display:flex;align-items:center;gap:.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#333;font-size:.9rem}.form-control{width:100%;padding:.5rem;border:2px solid #e1e1e1;border-radius:6px;font-size:.9rem;transition:border-color .2s}select.form-control option{font-size:14px;padding:6px 8px}.form-control:focus{outline:none;border-color:#8b4513}.prefecture-multi-select{position:relative;width:100%}.prefecture-multi-select .dropdown-toggle{width:100%;padding:.5rem;background:#fff;border:2px solid #e1e1e1;border-radius:6px;text-align:left;cursor:pointer;font-size:.9rem;display:flex;justify-content:space-between;align-items:center;transition:border-color .2s}.prefecture-multi-select .dropdown-toggle:hover{border-color:#8b4513}.prefecture-multi-select .dropdown-toggle:focus{outline:none;border-color:#8b4513}.prefecture-multi-select .dropdown-arrow{color:#666;font-size:.8rem;transition:transform .2s}.prefecture-multi-select .dropdown-menu.show .dropdown-arrow{transform:rotate(180deg)}.prefecture-multi-select .dropdown-menu{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #e1e1e1;border-top:none;border-radius:0 0 6px 6px;max-height:250px;overflow-y:auto;z-index:1000;display:none;box-shadow:0 4px 8px #0000001a}.prefecture-multi-select .dropdown-menu.show{display:block}.prefecture-multi-select .dropdown-menu label{display:flex;align-items:center;padding:.5rem .75rem;margin:0;font-weight:400;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background-color .2s}.prefecture-multi-select .dropdown-menu label:hover{background-color:#f8f9fa}.prefecture-multi-select .dropdown-menu label:last-child{border-bottom:none}.prefecture-multi-select .dropdown-menu input[type=checkbox]{margin-right:.5rem;cursor:pointer}.prefecture-tags{margin-top:.5rem;min-height:20px}.prefecture-tag{display:inline-block;background:#8b4513;color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.8rem;margin:.125rem .25rem .125rem 0;transition:background-color .2s}.prefecture-tag .tag-remove{margin-left:.5rem;cursor:pointer;font-weight:700}.prefecture-tag .tag-remove:hover{color:#fcc}.period-filter{display:flex;gap:.5rem;flex-wrap:wrap}.period-btn{padding:.3rem .8rem;border:2px solid #ddd;background:#fff;border-radius:20px;cursor:pointer;transition:all .2s;font-size:.8rem;font-weight:600}.period-btn.active{color:#fff;border-color:inherit}.period-last-month{border-color:#f44336}.period-last-month.active{background:#f44336;border-color:#f44336}.period-last-3months{border-color:#ff9800}.period-last-3months.active{background:#ff9800;border-color:#ff9800}.period-this-year{border-color:#ffc107}.period-this-year.active{background:#ffc107;border-color:#ffc107}.period-last-2years{border-color:#4caf50}.period-last-2years.active{background:#4caf50;border-color:#4caf50}.period-older{border-color:#9e9e9e}.period-older.active{background:#9e9e9e;border-color:#9e9e9e}.incident-type-filter{display:flex;gap:.5rem;flex-wrap:wrap}.incident-type-btn{padding:.4rem .8rem;border:2px solid #ddd;background:#fff;border-radius:20px;cursor:pointer;transition:all .2s;font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:.3rem}.incident-type-btn:hover{background-color:#f5f5f5;transform:translateY(-1px)}.incident-type-btn.active{background:#8b4513;color:#fff;border-color:#8b4513}.incident-type-btn i{font-size:.9rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h3{margin:0}.reset-btn-compact{padding:.4rem .8rem;background:#f8f9fa;color:#6c757d;border:1px solid #dee2e6;border-radius:4px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.3rem}.reset-btn-compact:hover{background:#e9ecef;color:#495057;border-color:#adb5bd}.reset-btn-compact i{font-size:.8rem}.search-btn{width:100%;padding:.75rem;background:linear-gradient(135deg,#8b4513,sienna);color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s}.search-btn:hover{transform:translateY(-2px)}.statistics-section{padding:1.5rem;border-bottom:1px solid #eee}.statistics-section h3{color:#8b4513;margin-bottom:1.5rem;font-size:1.1rem;display:flex;align-items:center}.statistics-section .form-group{margin-bottom:1.5rem}.stat-card{background:#f8f9fa;padding:1rem;border-radius:8px;margin-bottom:.5rem;border-left:4px solid #8B4513}.stat-card h4{color:#8b4513;font-size:.9rem;margin-bottom:.5rem}.stat-number{font-size:1.5rem;font-weight:700;color:#333}.stat-number:after{content:"件";font-size:1rem;margin-left:.25rem}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #e9ecef}.stat-item:last-child{border-bottom:none}.stat-label{display:flex;align-items:center;color:#495057;font-size:.9rem}.stat-label:before{content:"";display:inline-block;width:12px;height:12px;margin-right:.5rem;border-radius:2px;background-color:var(--period-color, #6c757d)}.stat-value{font-weight:700;color:#333;font-size:1rem;min-width:3rem;text-align:right}.stat-value:after{content:"件";font-size:.85rem;margin-left:.25rem;color:#6c757d}@media (max-width: 768px){.mobile-modal .statistics-section{padding:1rem}.mobile-modal .statistics-section h3{font-size:1rem;margin-bottom:1rem}.mobile-modal .form-group{margin-bottom:1rem}.mobile-modal .form-group label{font-size:.85rem;margin-bottom:.25rem}.mobile-modal .form-control{padding:.5rem;font-size:.9rem}.mobile-modal .stat-card{padding:.75rem;margin-bottom:.5rem}.mobile-modal .stat-card h4{font-size:.85rem;margin-bottom:.4rem}.mobile-modal .stat-number{font-size:1.3rem}.mobile-modal .stat-number:after{font-size:.9rem}.mobile-modal .stat-item{padding:.4rem 0}.mobile-modal .stat-label{font-size:.85rem}.mobile-modal .stat-label:before{width:10px;height:10px;margin-right:.4rem}.mobile-modal .stat-value{font-size:.9rem;min-width:2.5rem}.mobile-modal .stat-value:after{font-size:.8rem}.mobile-modal .search-section{padding:.75rem}.mobile-modal .search-section h3{font-size:.95rem;margin-bottom:.5rem}.mobile-modal .section-header{margin-bottom:.5rem}.mobile-modal .form-group{margin-bottom:.6rem}.mobile-modal .form-group label{font-size:.8rem;margin-bottom:.2rem}.mobile-modal .form-control,.mobile-modal .dropdown-toggle{padding:.4rem .5rem;font-size:.85rem}.mobile-modal .prefecture-tags{margin-top:.3rem;gap:.25rem}.mobile-modal .prefecture-tag{padding:.2rem .4rem;font-size:.75rem}.mobile-modal .search-btn,.mobile-modal .reset-btn-compact{padding:.45rem .9rem;font-size:.85rem}.mobile-modal .incident-type-filters{gap:.3rem}.mobile-modal .incident-type-btn{padding:.35rem .7rem;font-size:.8rem}.mobile-modal .incident-type-btn i{font-size:.75rem}}.legend{position:absolute;bottom:20px;right:20px;background:#fff;padding:1rem;border-radius:8px;box-shadow:0 2px 10px #00000026;z-index:1000}.legend h4{margin-bottom:.5rem;color:#8b4513;font-size:.9rem}.legend-item{display:flex;align-items:center;gap:.5rem;margin-bottom:.3rem;font-size:.8rem}.legend-color{width:20px;height:20px;border-radius:50% 50% 50% 0;border:2px solid white;box-shadow:0 1px 3px #0000004d;transform:rotate(-45deg);position:relative}.legend-color:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(45deg);color:#fff;font-size:8px;font-weight:700}.loading{display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 20px #00000026;z-index:2000}.spinner{border:4px solid #f3f3f3;border-top:4px solid #8B4513;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto 1rem}.popup-content{max-width:300px}.popup-header{background:#8b4513;color:#fff;padding:.5rem;margin:-.5rem -.5rem .5rem;border-radius:3px 3px 0 0;font-weight:700}.popup-detail{margin-bottom:.3rem;font-size:.9rem}.popup-detail strong{color:#8b4513}.severity-badge{display:inline-block;padding:.2rem .5rem;border-radius:12px;color:#fff;font-size:.8rem;font-weight:700}.mobile-menu-btn,.mobile-drawer,.mobile-bottom-bar,.mobile-overlay,.mobile-copyright{display:none}.mobile-modal{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:3000;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.mobile-modal.open{display:flex;align-items:center;justify-content:center;padding:1rem}.mobile-menu-btn{background:none;border:none;color:#fff;font-size:1.2rem;padding:.5rem;cursor:pointer;border-radius:4px;transition:background-color .2s}.mobile-menu-btn:hover{background-color:#fff3}@media (min-width: 769px){.mobile-menu-btn,.mobile-drawer,.mobile-bottom-bar,.mobile-modal,.mobile-overlay{display:none!important}body{min-width:800px}.container{height:calc(100vh - 80px);min-width:800px}.map-container{position:relative}#map{width:100%;height:100%}}@media (max-width: 768px){body,.container{min-width:0}.sidebar-toggle-btn{display:none}:root{--mobile-font-size: 16px;--mobile-touch-target: 44px}.header{display:flex;align-items:center;justify-content:center;padding:1rem;position:relative}.mobile-menu-btn{position:absolute;left:1rem;display:block}.header h1{font-size:1.5rem;margin:0}.header-logo{height:35px}.header-beta{font-size:.9rem;margin-left:.3rem}.container{flex-direction:column;height:calc(100vh - 80px)}.sidebar{display:none}.map-container{flex:1;height:calc(100vh - 160px);min-height:400px;position:relative}#map{width:100%;height:100%}.legend{bottom:90px;right:10px;padding:.5rem;font-size:.8rem}.legend-item{font-size:.7rem}.mobile-drawer{display:block;position:fixed;top:0;left:-300px;width:300px;height:100vh;background:#fff;box-shadow:2px 0 10px #0000004d;z-index:2000;transition:left .3s ease}.mobile-drawer.open{left:0}.drawer-header{background:linear-gradient(135deg,#8b4513,sienna);color:#fff;padding:1rem;display:flex;justify-content:space-between;align-items:center}.drawer-header h3{margin:0;font-size:1.2rem}.drawer-close-btn{background:none;border:none;color:#fff;font-size:1.2rem;padding:.5rem;cursor:pointer;border-radius:4px}.drawer-close-btn:hover{background-color:#fff3}.drawer-content{padding:0}.drawer-item{display:flex;align-items:center;padding:1rem;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background-color .2s;gap:.75rem}.drawer-item:hover{background-color:#f8f9fa}.drawer-item.active{background-color:#e3f2fd;border-left:4px solid #8B4513}.bottom-btn i{font-size:1.2rem;color:#8b4513}.bottom-btn span{font-size:.7rem;color:#666;font-weight:600}.drawer-separator{height:1px;background:#e0e0e0;margin:.5rem 0}.drawer-footer{padding:1rem;background:#f8f8f8;border-top:1px solid #e0e0e0}.drawer-link{display:flex;align-items:center;gap:.5rem;padding:.75rem;color:#8b4513;text-decoration:none;font-size:.9rem;transition:background-color .2s}.drawer-link i{font-size:.85rem}.drawer-link:hover{background-color:#f0f0f0;text-decoration:underline}.drawer-item i{color:#8b4513;width:20px;text-align:center}.drawer-item.active i,.drawer-item.active span{color:#8b4513;font-weight:600}.mobile-copyright{display:block;position:fixed;bottom:80px;left:0;right:0;background:#ffffffe6;padding:.25rem;text-align:center;font-size:.65rem;color:#999;z-index:999;border-top:1px solid #e0e0e0}.mobile-bottom-bar{display:flex;position:fixed;bottom:0;left:0;right:0;height:80px;background:#fff;border-top:1px solid #e0e0e0;z-index:1000;box-shadow:0 -2px 10px #0000001a}.bottom-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;transition:background-color .2s;padding:.5rem;gap:.25rem}.bottom-btn:hover{background-color:#f8f9fa}.mobile-modal{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:3000;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.mobile-modal.open{display:flex;align-items:center;justify-content:center;padding:1rem}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:400px;max-height:80vh;overflow:hidden;box-shadow:0 10px 30px #0000004d}.modal-header{background:linear-gradient(135deg,#8b4513,sienna);color:#fff;padding:1rem;display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0;font-size:1.1rem}.modal-close-btn{background:none;border:none;color:#fff;font-size:1.2rem;padding:.5rem;cursor:pointer;border-radius:4px}.modal-close-btn:hover{background-color:#fff3}.modal-body{padding:1.5rem;overflow-y:auto;max-height:calc(80vh - 80px)}.modal-body .form-control{font-size:16px;padding:.75rem;min-height:44px}.modal-body select.form-control{font-size:16px;background-color:#fff;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="8" viewBox="0 0 12 8"><path fill="%23666" d="M6 8L0 2h12z"/></svg>');background-repeat:no-repeat;background-position:right 12px center;background-size:12px 8px;padding-right:40px}.modal-body input.form-control{font-size:16px}.modal-body label{font-size:14px;font-weight:600;margin-bottom:.5rem}.modal-body .period-btn{font-size:14px;padding:.6rem 1rem;min-height:44px;display:inline-flex;align-items:center;justify-content:center}.modal-body .search-btn{font-size:16px;padding:.8rem 1.5rem;min-height:48px;width:100%;margin-top:1rem}.modal-body .form-group{margin-bottom:1.2rem}select{font-size:16px!important;min-height:44px}select option{font-size:16px!important;padding:10px!important;line-height:1.4!important}.mobile-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1500}.mobile-overlay.open{display:block}}.main-content-area{flex:1;position:relative;background:#fff;display:flex;flex-direction:column;transition:margin-left .3s ease}.main-view-tabs{display:flex;background:#fff;border-bottom:2px solid #e0e0e0;box-shadow:0 2px 4px #0000001a}.main-view-tab{flex:1;padding:1rem;text-align:center;cursor:pointer;border-bottom:3px solid transparent;transition:all .3s ease;font-weight:600;color:#666;background:#f8f9fa;border-right:1px solid #e0e0e0}.main-view-tab:last-child{border-right:none}.main-view-tab.active{color:#8b4513;border-bottom-color:#8b4513;background:#fff;transform:translateY(2px)}.main-view-tab:hover:not(.active){background:#e9ecef;color:#495057}.main-view-tab i{margin-right:.5rem;font-size:1.1rem}.view-content{display:none;width:100%;height:100%;flex:1}.view-content.active{display:flex;flex-direction:column}.list-view-container{height:100%;overflow:hidden;display:flex;flex-direction:column}.list-view-header{padding:1rem 1.5rem;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.list-view-title{font-size:1.2rem;font-weight:700;color:#8b4513;margin:0}.list-view-count{background:#8b4513;color:#fff;padding:.3rem .8rem;border-radius:15px;font-size:.9rem;font-weight:600}.list-view-body{flex:1;overflow-y:auto;padding:0}.table-container{flex:1;overflow:auto;min-width:0}.sighting-table{width:100%;border-collapse:collapse;font-size:.9rem;min-width:1200px;table-layout:auto}.sighting-table th{background:#8b4513;color:#fff;padding:.8rem;text-align:left;font-weight:600;position:sticky;top:0;z-index:10}.sighting-table td{padding:.8rem;border-bottom:1px solid #e0e0e0;vertical-align:top;line-height:1.4}.sighting-table tbody tr{transition:background-color .2s}.sighting-table tbody tr:hover{background:#f8f9fa;cursor:pointer}.incident-type-badge{padding:.2rem .6rem;border-radius:12px;font-size:.8rem;font-weight:600;text-align:center;min-width:60px;display:inline-flex;align-items:center;justify-content:center;gap:.3rem;background:#f8f9fa;color:#333;border:1px solid #dee2e6}.incident-type-icon{font-size:.9rem}.human-damage-indicator{display:inline-block;padding:.2rem .5rem;border-radius:8px;font-size:.7rem;font-weight:600;background:#f8f9fa;color:#333;border:1px solid #dee2e6}.date-cell{width:120px;font-weight:600;color:#495057;white-space:nowrap}.location-cell{width:180px;max-width:180px;overflow-wrap:break-word;white-space:normal;line-height:1.4}.description-cell{width:350px;max-width:350px;overflow-wrap:break-word;word-break:break-all;white-space:normal;color:#666;font-size:.85rem;line-height:1.4;padding:.8rem .6rem}.source-cell{max-width:120px;text-align:center;overflow-wrap:break-word;white-space:normal}.source-link{color:#8b4513;text-decoration:none;font-size:.85rem;font-weight:600;padding:.2rem .5rem;border-radius:4px;transition:all .2s;display:inline-block}.source-link:hover{background:#f0f0f0;text-decoration:underline}.source-link:visited{color:#6d3410}.view-on-map-btn{background:#8b4513;color:#fff;border:none;padding:.3rem .6rem;border-radius:4px;font-size:.8rem;cursor:pointer;transition:background .2s}.view-on-map-btn:hover{background:sienna}.pagination-container{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#f8f9fa;border-top:1px solid #e0e0e0;flex-wrap:wrap;gap:1rem}.pagination-info{font-size:.9rem;color:#666}.pagination-controls{display:flex;align-items:center;gap:.5rem}.pagination-btn{padding:.5rem 1rem;border:1px solid #dee2e6;background:#fff;color:#333;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-btn:hover:not(:disabled){background:#e9ecef}.page-numbers{display:flex;align-items:center;gap:.25rem}.page-btn{padding:.5rem .75rem;border:1px solid #dee2e6;background:#fff;color:#333;border-radius:4px;cursor:pointer;font-size:.9rem;min-width:40px;text-align:center;transition:all .2s}.page-btn:hover{background:#e9ecef}.page-btn.active{background:#8b4513;color:#fff;border-color:#8b4513}.page-dots{padding:.5rem;color:#666}.pagination-size{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.page-size-select{padding:.4rem;border:1px solid #dee2e6;border-radius:4px;font-size:.9rem;background:#fff}.sighting-cards{display:none;padding:1rem;gap:1rem;flex-direction:column;height:100%;overflow-y:auto}.sighting-card{background:#fff;border-radius:8px;padding:1rem;box-shadow:0 2px 8px #0000001a;border-left:4px solid #8B4513;cursor:pointer;transition:all .2s;width:100%;box-sizing:border-box;overflow-wrap:break-word}.sighting-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.card-date{font-weight:600;color:#8b4513;font-size:.9rem}.card-content{margin-bottom:.5rem}.card-prefecture{font-size:.8rem;color:#666;margin-bottom:.2rem}.card-location{font-weight:600;margin-bottom:.3rem;color:#333}.card-type-damage{display:flex;gap:.5rem;margin-bottom:.3rem}.card-description{color:#666;font-size:.9rem;line-height:1.4;overflow-wrap:break-word;white-space:pre-wrap}.card-actions{display:flex;justify-content:space-between;align-items:center;margin-top:.8rem}.source-link-mobile{color:#8b4513;text-decoration:none;font-size:.8rem;font-weight:600;padding:.3rem .6rem;border-radius:4px;transition:all .2s}.source-link-mobile:hover{background:#f0f0f0;text-decoration:underline}.mobile-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:#666;font-size:.9rem}.mobile-spinner{border:3px solid #f3f3f3;border-top:3px solid #8B4513;border-radius:50%;width:30px;height:30px;animation:spin 1s linear infinite;margin-bottom:.8rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.mobile-end-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.5rem 2rem;padding-bottom:80px;color:#4caf50;font-size:.9rem;font-weight:600}.mobile-end-message i{font-size:1.5rem;margin-bottom:.5rem}@media (max-width: 768px){.main-view-tabs{display:none}.main-content-area{height:calc(100vh - 160px);position:relative}.table-container{display:none}.sighting-cards{display:flex}.pagination-container{display:none}.mobile-bottom-bar .bottom-btn.map-view-btn.active,.mobile-bottom-bar .bottom-btn.list-view-btn.active{background:#e3f2fd}.mobile-bottom-bar .bottom-btn.active i,.mobile-bottom-bar .bottom-btn.active span{color:#1976d2}.legend-toggle-icon{top:15px!important;right:10px!important}.legend-expandable{top:60px!important;right:10px!important;min-width:calc(100vw - 30px)!important}}.expandable-legend{position:absolute;bottom:20px;right:20px;z-index:1000}.legend-trigger{width:50px;height:50px;border-radius:50%;background:#fffffff2;border:2px solid #ddd;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;color:#666;box-shadow:0 2px 8px #00000026;transition:all .3s ease}.legend-trigger:hover{background:#f8f9fa;color:#333;transform:scale(1.05)}.legend-trigger.expanded{background:#007bff;color:#fff;border-color:#007bff}.legend-content{display:none;position:absolute;bottom:60px;right:0;background:#fffffff2;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border-radius:8px;padding:15px;box-shadow:0 4px 12px #0003;min-width:280px}.legend-section{margin-bottom:15px}.legend-section:last-child{margin-bottom:0}.legend-section h4{margin:0 0 8px;font-size:14px;font-weight:600;color:#333;border-bottom:1px solid #eee;padding-bottom:4px}.legend-items{display:flex;flex-wrap:wrap;gap:8px}.legend-items.event-types,.legend-items.period-colors{flex-direction:row}.legend-item{display:flex;align-items:center;padding:4px 8px;border-radius:4px;background:#f8f9facc;font-size:12px;white-space:nowrap}.legend-item i{margin-right:6px;width:16px;text-align:center;color:#666}.period-color{width:16px;height:16px;border-radius:50%;margin-right:6px;border:1px solid rgba(0,0,0,.1);flex-shrink:0}@media (max-width: 768px){.expandable-legend{bottom:15px;right:15px}.legend-trigger{width:45px;height:45px;font-size:16px}.legend-content{bottom:55px;right:0;min-width:260px;max-width:calc(100vw - 40px)}.legend-items{gap:6px}.legend-item{font-size:11px;padding:3px 6px}.legend-item i,.period-color{width:14px;height:14px;margin-right:5px}}.legend-toggle-icon{position:absolute!important;top:15px!important;left:60px!important;cursor:pointer!important;z-index:2000!important;transition:transform .2s ease!important;pointer-events:auto!important}.legend-toggle-icon:hover{transform:scale(1.1)!important}.legend-marker-icon{width:36px!important;height:36px!important;background:#fffffff2!important;border:2px solid #007bff!important;border-radius:50%!important;display:flex!important;align-items:center!important;justify-content:center!important;box-shadow:0 2px 8px #00000040!important}.legend-marker-icon i{color:#007bff!important;font-size:16px!important;width:auto!important}.legend-marker-text{background:#fffffff2!important;border:2px solid #007bff!important;border-radius:4px!important;padding:4px 8px!important;display:flex!important;align-items:center!important;justify-content:center!important;box-shadow:0 2px 8px #00000040!important;font-weight:600!important;font-size:12px!important;color:#007bff!important;white-space:nowrap!important;min-width:auto!important}.legend-expandable{background:#fffffff2!important;border-bottom:1px solid #ddd!important;padding:8px 12px!important;font-size:13px!important;max-height:0!important;overflow:hidden!important;transition:max-height .3s ease,padding .3s ease!important;position:absolute!important;top:55px!important;left:60px!important;min-width:300px!important;z-index:1500!important;border-radius:4px!important;box-shadow:0 2px 8px #00000026!important}.legend-expandable.expanded{max-height:100px!important;padding:8px 12px!important}.legend-expandable.collapsed{max-height:0!important;padding:0 12px!important}.legend-compact-row{display:flex!important;align-items:center!important;gap:4px!important;margin-bottom:3px!important;flex-wrap:wrap!important}.legend-compact-row:last-child{margin-bottom:0!important}.legend-compact-row strong{font-size:13px!important;color:#333!important;min-width:40px!important}.legend-compact-item{display:flex!important;align-items:center!important;gap:3px!important;margin-right:4px!important;color:#333!important}.legend-compact-item i{color:#6c757d!important;width:12px!important;text-align:center!important;font-size:inherit!important}.statistics-section h3 i,.search-section h3 i{margin-right:.5rem}.legend-compact-item .period-color{width:8px!important;height:8px!important;border-radius:2px!important;border:1px solid rgba(0,0,0,.2)!important}#sighting-table-body tr td{vertical-align:middle}.data-source-cell{padding:4px!important;text-align:center}.data-source-text{color:#6c757d;font-style:italic}.clickable-cell{cursor:pointer;transition:background-color .2s}.clickable-cell:hover{background-color:#f8f9fa}.map-action-cell{padding:4px!important;text-align:center}.map-action-cell:empty{text-align:center;color:#6c757d}.map-action-cell:empty:after{content:"-"}@media (max-width: 768px){.card-actions{display:flex;gap:8px;flex-wrap:wrap}.card-actions .view-on-map-btn{flex:1;min-width:100px}}.legend-toggle-icon.active .legend-marker-icon{background:#007bff1a!important;border-color:#0056b3!important}.legend-toggle-icon.active .legend-marker-icon i{color:#0056b3!important}.legend-toggle-icon.active .legend-marker-text{background:#007bff1a!important;border-color:#0056b3!important;color:#0056b3!important}@media (max-width: 768px){.legend-toggle-icon{top:15px!important;right:10px!important;left:auto!important}.legend-marker-icon{width:40px!important;height:40px!important}.legend-marker-icon i{font-size:18px!important}.legend-marker-text{padding:4px 8px!important;font-size:12px!important;display:flex!important;align-items:center!important;justify-content:center!important;min-width:auto!important}.legend-expandable{top:60px!important;right:10px!important;left:10px!important;font-size:12px!important;padding:6px 8px!important;min-width:calc(100vw - 30px)!important}.legend-compact-row strong{font-size:12px!important;min-width:35px!important}.legend-compact-item{gap:0!important;margin-right:2px!important;font-size:11px!important}.legend-compact-item i{width:12px!important;font-size:11px!important}.legend-compact-item .period-color{width:8px!important;height:8px!important}.legend-expandable.expanded{max-height:100px!important}}.container.sidebar-collapsed .sidebar-toggle-btn i{transform:rotate(180deg)}
