*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:#f5f5f5}.app{display:flex;flex-direction:column;height:100vh;height:100dvh}.header{background-color:#2d5a27;color:#fff;padding:1rem 2rem;display:flex;flex-direction:column;gap:1rem;box-shadow:0 2px 4px #0000001a}.header-top{display:flex;justify-content:space-between;align-items:center;width:100%}.header h1{font-size:1.5rem;font-weight:600;margin:0}.header-stats{font-size:.9rem;opacity:.9}.filters-container{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;width:100%}.filter-group{display:flex;gap:.5rem}.filter-divider{width:1px;height:24px;background-color:#ffffff4d}.filter-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s;display:flex;align-items:center;justify-content:center}.filter-btn:hover{background:#ffffff40}.filter-btn.active{background:#fff;color:#2d5a27;border-color:#fff;font-weight:500}.filter-btn.small{padding:.4rem .6rem;min-width:36px}.month-rest{display:none}.clear-btn{background:transparent;border:none;color:#fffc;cursor:pointer;font-size:.85rem;padding:.4rem;margin-left:auto}.clear-btn:hover{color:#fff;text-decoration:underline}@media (min-width: 1200px){.month-rest{display:inline}}@media (max-width: 768px){.header{padding:1rem}.filters-container{gap:.5rem;overflow-x:auto;padding-bottom:.5rem;-webkit-overflow-scrolling:touch}.filter-group{flex-shrink:0}}.main-content{display:flex;flex:1;overflow:hidden}.map-container{flex:1;position:relative}.leaflet-container{height:100%;width:100%}.sidebar{width:380px;background:#fff;border-left:1px solid #e0e0e0;display:flex;flex-direction:column;transition:width .3s ease;position:relative;overflow:visible}.sidebar-content{height:100%;overflow-y:auto;display:flex;flex-direction:column;width:380px;background:#fff}.sidebar.collapsed{width:0;border-left:none}.sidebar.collapsed .sidebar-content{display:none}.sidebar-toggle{position:absolute;left:-32px;top:10px;width:32px;height:32px;background:#fff;border:1px solid #e0e0e0;border-right:none;border-radius:4px 0 0 4px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1001;color:#555;font-size:14px;box-shadow:-2px 0 4px #0000001a}.sidebar-toggle:hover{background:#f5f5f5;color:#333}.sidebar-header{padding:1rem;border-bottom:1px solid #e0e0e0;background:#fafafa}.sidebar-header h2{font-size:1.1rem;color:#333;margin-bottom:.5rem}.search-input{width:100%;padding:.5rem .75rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.search-input:focus{outline:none;border-color:#2d5a27}.campsite-list{flex:1;overflow-y:auto}.campsite-item{padding:1rem;border-bottom:1px solid #eee;cursor:pointer;transition:background-color .2s}.campsite-item:hover{background-color:#f5f5f5}.campsite-item.selected{background-color:#e8f5e9;border-left:3px solid #2d5a27}.campsite-item h3{font-size:1rem;color:#333;margin-bottom:.25rem}.campsite-item .location{font-size:.85rem;color:#666;margin-bottom:.25rem}.campsite-item .info{font-size:.8rem;color:#888}.campsite-popup{min-width:250px}.campsite-popup h3{font-size:1rem;color:#2d5a27;margin-bottom:.5rem}.campsite-popup .popup-location{font-size:.85rem;color:#666;margin-bottom:.5rem}.campsite-popup .popup-info{font-size:.8rem;color:#333;margin-bottom:.5rem}.campsite-popup .popup-season{font-size:.8rem;color:#666;font-style:italic}.campsite-image-container{margin:0 0 10px;text-align:center}.campsite-image{max-width:100%;height:auto;max-height:120px;display:block;margin:0 auto;border-radius:4px;object-fit:cover}.campsite-popup .popup-info{display:flex;align-items:center;gap:4px}.capacity-icon{font-size:1rem}.campsite-links{margin-top:.75rem}.campsite-link,.campsite-link:link,.campsite-link:visited,.campsite-link:active{display:inline-block;font-size:.75rem;padding:4px 8px;border-radius:3px;text-decoration:none!important;background-color:#2d5a27;color:#fff!important;transition:opacity .2s}.campsite-link:hover{opacity:.8;text-decoration:none!important;color:#fff!important}.loading{display:flex;justify-content:center;align-items:center;height:100%;color:#666}.error{display:flex;justify-content:center;align-items:center;height:100%;color:#d32f2f;padding:2rem;text-align:center}.custom-marker{background-color:#2d5a27;border:2px solid white;border-radius:50%;width:12px;height:12px;box-shadow:0 2px 4px #0000004d}.map-wrapper{position:relative;height:100%;width:100%}.map-controls{position:absolute;top:80px;left:10px;right:auto;z-index:1000;background:#fff;padding:8px 12px;border-radius:4px;box-shadow:0 2px 6px #0003;display:flex;flex-direction:column;gap:4px;font-size:.85rem}.bird-toggle{display:flex;align-items:center;gap:6px;cursor:pointer;-webkit-user-select:none;user-select:none}.bird-toggle input{cursor:pointer}.bird-count{color:#e74c3c;font-weight:500}.zoom-hint{color:#888;font-size:.75rem;font-style:italic}.loading-indicator{color:#2196f3;font-size:.75rem}.bird-popup{min-width:200px;max-width:250px}.bird-image-container{margin:0 0 10px;text-align:center}.bird-image{max-width:100%;height:auto;display:block;margin:0 auto;border-radius:4px}.bird-popup h4{font-size:1rem;color:#e74c3c;margin-bottom:.25rem}.bird-popup .scientific-name{font-size:.8rem;color:#666;margin-bottom:.5rem}.bird-popup .observation-count{font-size:.85rem;color:#333;margin-bottom:.25rem}.bird-popup .last-seen{font-size:.8rem;color:#888;margin-bottom:.5rem}.bird-links{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}.bird-link{font-size:.75rem;padding:4px 8px;border-radius:3px;text-decoration:none;transition:opacity .2s}.bird-link:hover{opacity:.8}.bird-link.vogelbescherming{background-color:#2d5a27;color:#fff}.bird-link.waarneming{background-color:#f39c12;color:#fff}.bird-histogram{margin:8px 0;padding:6px 0;border-top:1px solid #eee;border-bottom:1px solid #eee}.histogram-bars{display:flex;gap:2px;height:24px;align-items:flex-end}.histogram-bar-container{flex:1;height:100%;display:flex;align-items:flex-end}.histogram-bar{width:100%;min-height:2px;border-radius:1px 1px 0 0;transition:height .2s}.histogram-labels{display:flex;gap:2px;margin-top:2px}.histogram-label{flex:1;text-align:center;font-size:8px;color:#888;font-weight:500}.histogram-no-data{margin-top:4px;font-size:9px;color:#999;font-style:italic;text-align:center}.rarity-icon{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:4px;font-size:.8rem;margin:6px 0}.rarity-icon i{font-size:12px}.rarity-label{font-weight:500}.rarity-icon.rare-1{background-color:#28a74526;color:#28a745}.rarity-icon.rare-1 i{color:#28a745}.rarity-icon.rare-2{background-color:#007bff26;color:#007bff}.rarity-icon.rare-2 i{color:#007bff}.rarity-icon.rare-3{background-color:#ff990026;color:#f90}.rarity-icon.rare-3 i{color:#f90}.rarity-icon.rare-4{background-color:#dc354526;color:#dc3545}.rarity-icon.rare-4 i{color:#dc3545}.rarity-icon.rare-unknown{background-color:#6c757d26;color:#6c757d}.rarity-icon.rare-unknown i{color:#6c757d}.map-attribution{position:absolute;bottom:0;left:0;z-index:1000;background:#ffffffb3;padding:2px 5px;font-size:11px;color:#333;pointer-events:auto;border-top-right-radius:4px}.map-attribution a{color:#0078a8;text-decoration:none}.map-attribution a:hover{text-decoration:underline}@media (max-width: 768px){.main-content{flex-direction:column}.sidebar{width:100%;height:40%;border-left:none;border-top:1px solid #e0e0e0;transition:height .3s ease}.sidebar-content{width:100%}.sidebar.collapsed{width:100%;height:0;border-top:none}.sidebar-toggle{left:50%;top:-32px;margin-left:-16px;width:32px;height:32px;border-left:1px solid #e0e0e0;border-right:1px solid #e0e0e0;border-top:1px solid #e0e0e0;border-bottom:none;border-radius:4px 4px 0 0;box-shadow:0 -2px 4px #0000001a;z-index:2000}.map-container{height:60%}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000;padding:1rem}.modal-content{background:#fff;border-radius:8px;padding:2rem;max-width:600px;width:100%;position:relative;box-shadow:0 4px 12px #0003;max-height:90vh;overflow-y:auto}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;line-height:1;padding:0}.modal-close:hover{color:#333}.modal-body{margin-top:1rem;font-size:.95rem;line-height:1.6;color:#333}.modal-body p{margin-bottom:1rem}.modal-body ul{padding-left:1.5rem;margin-bottom:1rem}.modal-body li{margin-bottom:.5rem}.modal-body a{color:#2d5a27;text-decoration:underline}.modal-body a:hover{color:#1a3c18}.about-btn{background:none;border:none;color:#fffc;font-size:1.2rem;cursor:pointer;padding:.2rem;display:flex;align-items:center;justify-content:center;transition:color .2s;margin-left:.5rem}.about-btn:hover{color:#fff}.login-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.85rem;display:flex;align-items:center;gap:6px;transition:all .2s;margin-left:.5rem}.login-btn:hover{background:#ffffff40}.login-btn-text{display:none}@media (min-width: 600px){.login-btn-text{display:inline}}.user-menu{position:relative;margin-left:.5rem}.user-menu-trigger{background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.85rem;display:flex;align-items:center;gap:6px;transition:all .2s}.user-menu-trigger:hover{background:#ffffff40}.user-menu-name{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 600px){.user-menu-name{display:none}}.user-menu-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:200px;z-index:2001;overflow:hidden}.user-menu-header{padding:12px 16px;background:#f9f9f9}.user-menu-email{font-size:.85rem;color:#333;font-weight:500}.user-menu-favorites-count{font-size:.8rem;color:#666;margin-top:4px}.user-menu-favorites-count i{color:#e74c3c}.user-menu-divider{height:1px;background:#eee}.user-menu-item{width:100%;padding:12px 16px;border:none;background:none;text-align:left;cursor:pointer;font-size:.9rem;color:#333;display:flex;align-items:center;gap:8px;transition:background .2s}.user-menu-item:hover{background:#f5f5f5}.user-menu-item i{color:#666;width:16px}.auth-modal{max-width:400px}.auth-modal h2{margin-bottom:1.5rem;color:#2d5a27}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-field{display:flex;flex-direction:column;gap:4px}.auth-field label{font-size:.9rem;color:#333;font-weight:500}.auth-field .optional{font-weight:400;color:#888}.auth-field input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.auth-field input:focus{outline:none;border-color:#2d5a27}.auth-field input:disabled{background:#f5f5f5;color:#888}.auth-error{background:#fee;border:1px solid #fcc;color:#c00;padding:.75rem;border-radius:4px;font-size:.9rem}.auth-submit{background:#2d5a27;color:#fff;border:none;padding:.75rem 1rem;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s;margin-top:.5rem}.auth-submit:hover:not(:disabled){background:#1a3c18}.auth-submit:disabled{background:#999;cursor:not-allowed}.auth-switch{margin-top:1.5rem;text-align:center;font-size:.9rem;color:#666}.auth-switch-btn{background:none;border:none;color:#2d5a27;font-weight:500;cursor:pointer;text-decoration:underline}.auth-switch-btn:hover{color:#1a3c18}.favorite-btn{background:none;border:none;cursor:pointer;padding:4px;font-size:1.1rem;color:#ccc;transition:all .2s;display:flex;align-items:center;justify-content:center}.favorite-btn:hover{color:#e74c3c;transform:scale(1.1)}.favorite-btn.is-favorite{color:#e74c3c}.favorite-btn.is-favorite:hover{color:#c0392b}.favorite-btn-small{font-size:.9rem;padding:2px}.campsite-item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.campsite-item-header h3{flex:1;margin-bottom:0}.popup-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px}.popup-header h3,.popup-header h4{flex:1;margin:0}.bird-popup .popup-header h4,.campsite-popup .popup-header h3{margin-bottom:0}.all-birds-page{position:fixed;top:0;left:0;right:0;bottom:0;background:#f5f5f5;z-index:3000;display:flex;flex-direction:column;overflow:hidden}.all-birds-header{background:#2d5a27;color:#fff;padding:1rem 2rem;display:flex;align-items:center;gap:1rem;flex-shrink:0}.all-birds-header h1{font-size:1.5rem;margin:0;flex:1}.bird-count-badge{background:#fff3;padding:.3rem .8rem;border-radius:16px;font-size:.9rem}.back-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem 1rem;border-radius:4px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:.9rem;transition:background .2s}.back-btn:hover{background:#ffffff40}.all-birds-controls{background:#fff;padding:1rem 2rem;border-bottom:1px solid #e0e0e0;display:flex;gap:1rem;flex-wrap:wrap;align-items:center;flex-shrink:0}.all-birds-controls .search-input{flex:1;min-width:200px;max-width:400px}.filter-controls{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.favorites-filter{display:flex;align-items:center;gap:6px;cursor:pointer;-webkit-user-select:none;user-select:none;padding:.5rem .75rem;background:#f5f5f5;border-radius:4px;font-size:.9rem}.favorites-filter:hover{background:#eee}.favorites-filter input{cursor:pointer}.favorites-filter i{color:#e74c3c}.sort-select{padding:.5rem .75rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;background:#fff;cursor:pointer}.sort-select:focus{outline:none;border-color:#2d5a27}.login-prompt{background:#fff3cd;border:1px solid #ffc107;color:#856404;padding:.75rem 2rem;display:flex;align-items:center;gap:8px;font-size:.9rem;flex-shrink:0}.login-prompt i{color:#856404}.login-link{background:none;border:none;color:#2d5a27;font-weight:600;cursor:pointer;text-decoration:underline;padding:0;margin-left:8px}.login-link:hover{color:#1a3c18}.all-birds-grid{flex:1;overflow-y:auto;padding:1.5rem 2rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;align-content:start}.bird-card{background:#fff;border-radius:8px;padding:1rem;box-shadow:0 2px 4px #0000001a;transition:box-shadow .2s,transform .2s}.bird-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.bird-card.is-favorite{border:2px solid #e74c3c}.bird-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:.5rem}.bird-card-header h3{font-size:1.1rem;color:#333;margin:0;flex:1}.bird-card-image{margin:.75rem 0;text-align:center}.bird-card-image img{max-width:100%;height:auto;max-height:150px;border-radius:4px;object-fit:contain}.bird-card .scientific-name{font-size:.85rem;color:#666;margin-bottom:.5rem}.bird-card .bird-histogram{margin:.75rem 0}.bird-card-links{display:flex;gap:8px;margin-top:.75rem;flex-wrap:wrap}.no-birds-found{grid-column:1 / -1;text-align:center;padding:3rem;color:#666;font-size:1.1rem}.all-birds-loading,.all-birds-error{flex:1;display:flex;justify-content:center;align-items:center;font-size:1.1rem;color:#666}.all-birds-error{color:#d32f2f}@media (max-width: 768px){.all-birds-header{padding:1rem}.all-birds-header h1{font-size:1.2rem}.back-btn span{display:none}.all-birds-controls{padding:1rem;flex-direction:column;align-items:stretch}.all-birds-controls .search-input{max-width:none}.filter-controls{justify-content:space-between}.all-birds-grid{padding:1rem;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.login-prompt{padding:.75rem 1rem;flex-wrap:wrap}}.all-campsites-page{position:fixed;top:0;left:0;right:0;bottom:0;background:#f5f5f5;z-index:3000;display:flex;flex-direction:column;overflow:hidden}.all-campsites-header{background:#2d5a27;color:#fff;padding:1rem 2rem;display:flex;align-items:center;gap:1rem;flex-shrink:0}.all-campsites-header h1{font-size:1.5rem;margin:0;flex:1}.campsite-count-badge{background:#fff3;padding:.3rem .8rem;border-radius:16px;font-size:.9rem}.all-campsites-controls{background:#fff;padding:1rem 2rem;border-bottom:1px solid #e0e0e0;display:flex;gap:1rem;flex-wrap:wrap;align-items:center;flex-shrink:0}.all-campsites-controls .search-input{flex:1;min-width:200px;max-width:400px}.province-select{padding:.5rem .75rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;background:#fff;cursor:pointer;min-width:150px}.province-select:focus{outline:none;border-color:#2d5a27}.all-campsites-grid{flex:1;overflow-y:auto;padding:1.5rem 2rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;align-content:start}.campsite-card{background:#fff;border-radius:8px;padding:1rem;box-shadow:0 2px 4px #0000001a;transition:box-shadow .2s,transform .2s}.campsite-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.campsite-card.is-favorite{border:2px solid #e74c3c}.campsite-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:.5rem}.campsite-card-header h3{font-size:1.1rem;color:#333;margin:0;flex:1}.campsite-card-title{cursor:pointer;transition:color .2s}.campsite-card-title:hover{color:#2d5a27}.campsite-card-image{margin:.75rem 0;text-align:center;cursor:pointer}.campsite-card-image img{width:100%;height:150px;border-radius:4px;object-fit:cover}.campsite-card-info{margin:.75rem 0}.campsite-location{font-size:.9rem;color:#666;margin-bottom:.5rem;display:flex;align-items:center;gap:6px}.campsite-location i{color:#e74c3c}.campsite-meta{display:flex;gap:1rem;margin-bottom:.5rem;font-size:.9rem}.campsite-rating{color:#f39c12;font-weight:500}.campsite-rating i{margin-right:4px}.campsite-capacity{color:#666}.campsite-capacity i{margin-right:4px;color:#2d5a27}.campsite-season{font-size:.85rem;color:#888;display:flex;align-items:center;gap:6px}.campsite-season i{color:#2d5a27}.campsite-card-links{display:flex;gap:8px;margin-top:.75rem;flex-wrap:wrap}.campsite-card-links .campsite-link{font-size:.8rem;padding:6px 12px;border-radius:4px;text-decoration:none;transition:opacity .2s;display:flex;align-items:center;gap:6px;cursor:pointer;border:none}.campsite-card-links .campsite-link:hover{opacity:.85}.campsite-card-links .campsite-link.website{background-color:#2d5a27;color:#fff}.campsite-card-links .campsite-link.map-link{background-color:#3498db;color:#fff}.no-campsites-found{grid-column:1 / -1;text-align:center;padding:3rem;color:#666;font-size:1.1rem}.all-campsites-loading,.all-campsites-error{flex:1;display:flex;justify-content:center;align-items:center;font-size:1.1rem;color:#666}.all-campsites-error{color:#d32f2f}@media (max-width: 768px){.all-campsites-header{padding:1rem}.all-campsites-header h1{font-size:1.2rem}.all-campsites-controls{padding:1rem;flex-direction:column;align-items:stretch}.all-campsites-controls .search-input{max-width:none}.province-select{width:100%}.all-campsites-grid{padding:1rem;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}}
