:root{--bg: #f5f1eb;--bg-surface: #ffffff;--bg-card: #ffffff;--bg-hover: #ede9e2;--accent: #c8602a;--accent-h: #b05020;--green: #3d6b44;--purple: #6b4fa0;--gold: #7a6520;--text: #2a2420;--text-muted: #7a6e64;--text-dim: #b0a89e;--border: #ddd8d0;--border-h: #c8c0b8;--radius: 8px;--radius-lg: 14px;--shadow: 0 4px 24px rgba(0,0,0,.08);--font-display:"Bebas Neue", sans-serif;--font-body: "DM Sans", sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}button{cursor:pointer;border:none;background:none;font-family:inherit}a{color:inherit;text-decoration:none}.app{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden}.content-area{flex:1;overflow:hidden;position:relative}@keyframes spin{to{transform:rotate(360deg)}}.loader-ring{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}.header{height:56px;background:var(--bg-surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 20px;flex-shrink:0;gap:12px}.header-logo{display:flex;align-items:center;gap:10px}.logo-icon{width:34px;height:34px;flex-shrink:0}.logo-text{font-family:var(--font-display);font-size:24px;letter-spacing:1px;color:var(--text);line-height:1}.logo-text span{color:var(--accent)}.header-tagline{font-size:12px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim)}.header-actions{display:flex;align-items:center}.btn-submit-event{font-size:12px;font-weight:600;padding:7px 16px;border-radius:var(--radius);border:1px solid var(--border-h);color:var(--text-muted);background:var(--bg-surface);transition:all .15s;white-space:nowrap}.btn-submit-event:hover{border-color:var(--accent);color:var(--accent)}.filter-bar{height:46px;background:var(--bg-surface);border-bottom:1px solid var(--border);display:flex;align-items:center;flex-shrink:0;gap:0;overflow:hidden}.filter-left{display:flex;align-items:center;gap:6px;flex:1;overflow-x:auto;padding:0 16px;scrollbar-width:none;-webkit-overflow-scrolling:touch}.filter-left::-webkit-scrollbar{display:none}.filter-label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim);white-space:nowrap;flex-shrink:0}.filter-chip{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:500;padding:5px 12px;border-radius:99px;border:1px solid var(--border);color:var(--text-muted);background:transparent;white-space:nowrap;flex-shrink:0;transition:all .15s}.filter-chip:hover{border-color:var(--border-h);color:var(--text)}.chip-dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0}.filter-divider{width:1px;height:22px;background:var(--border);margin:0 4px;flex-shrink:0}.bp-diamond-dot{width:8px;height:8px;transform:rotate(45deg);display:inline-block;flex-shrink:0;transition:background .15s;border-radius:2px}.bp-toggle-active{background:rgba(42,171,147,.15)!important;border-color:#2aab93!important;color:#2aab93!important}.view-switcher{display:flex;align-items:stretch;height:100%;border-left:1px solid var(--border);flex-shrink:0}.view-btn{display:flex;align-items:center;gap:6px;padding:0 16px;font-size:12px;font-weight:600;letter-spacing:.5px;color:var(--text-muted);background:transparent;border:none;border-right:1px solid var(--border);transition:all .15s;white-space:nowrap}.view-btn:last-child{border-right:none}.view-btn:hover{color:var(--text);background:var(--bg-hover)}.view-btn.active{color:var(--accent);background:var(--bg-card)}.map-view{display:flex;height:100%;overflow:hidden}.map-sidebar{width:320px;flex-shrink:0;display:flex;flex-direction:column;background:var(--bg-surface);border-right:1px solid var(--border);overflow:hidden}.sidebar-header{padding:14px 18px 10px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-count{font-family:var(--font-display);font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted)}.sidebar-count strong{color:var(--accent);font-size:18px;letter-spacing:0}.sidebar-list{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:4px}.map-container{flex:1;position:relative}.map-container .leaflet-container{width:100%;height:100%;background:#e8e4dc}.leaflet-popup-content-wrapper{background:var(--bg-card)!important;border:1px solid var(--border-h)!important;border-radius:var(--radius)!important;box-shadow:var(--shadow)!important;color:var(--text)!important}.leaflet-popup-tip{background:var(--bg-card)!important}.leaflet-popup-content{margin:0!important}.popup-title{font-size:13px;font-weight:600;color:var(--text);padding:10px 12px 3px}.popup-meta{font-size:11px;color:var(--text-muted);padding:0 12px 4px}.popup-link{font-size:11px;font-weight:600;color:var(--accent);padding:4px 12px 10px;cursor:pointer;display:block}.popup-link:hover{color:var(--accent-h)}.event-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;cursor:pointer;transition:all .15s;position:relative}.event-card:hover{border-color:var(--border-h);background:var(--bg-hover)}.event-card.featured{border-color:#c8602a66}.event-card.selected{border-color:var(--accent);background:var(--bg-hover)}.featured-badge{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-display);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);margin-bottom:6px}.event-type-tag{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-display);font-size:11px;letter-spacing:1px;text-transform:uppercase;padding:2px 8px;border-radius:99px;margin-bottom:6px}.event-card-title{font-family:var(--font-display);font-size:18px;line-height:1.15;color:var(--text);margin-bottom:4px}.event-card-meta{font-size:13px;color:var(--text-muted);margin-bottom:8px}.event-card-meta span+span:before{content:" · "}.event-card-stats{display:flex;gap:14px;margin-bottom:8px}.stat-item{display:flex;flex-direction:column}.stat-label{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim)}.stat-value{font-family:var(--font-display);font-size:15px;color:var(--text)}.event-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}.spots-indicator{display:flex;align-items:center;gap:6px}.spots-bar{width:50px;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.spots-fill{height:100%;border-radius:2px;transition:width .3s}.spots-fill.low{background:#c0392b}.spots-fill.mid{background:#e67e22}.spots-fill.good{background:var(--green)}.spots-text{font-size:11px;color:var(--text-muted)}.spots-text.sold-out{color:#c0392b;font-weight:600}.spots-text.low-spots{color:#e67e22;font-weight:600}.event-price{font-family:var(--font-display);font-size:16px;color:var(--text)}.event-price.free{color:var(--green)}.grid-view{height:100%;overflow-y:auto;padding:20px 24px}.grid-view-inner{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;max-width:1400px;margin:0 auto}.no-events{text-align:center;padding:48px;color:var(--text-dim);font-family:var(--font-display);font-size:18px;letter-spacing:1px;text-transform:uppercase}.timeline-view{display:flex;flex-direction:column;height:100%;overflow:hidden}.month-tabs{display:flex;gap:2px;padding:12px 24px 0;background:var(--bg);border-bottom:1px solid var(--border);overflow-x:auto;flex-shrink:0;scrollbar-width:none}.month-tabs::-webkit-scrollbar{display:none}.month-tab{font-family:var(--font-display);font-size:13px;letter-spacing:1px;text-transform:uppercase;padding:10px 18px;color:var(--text-muted);border-radius:var(--radius) var(--radius) 0 0;transition:all .15s;white-space:nowrap;position:relative}.month-tab:hover{color:var(--text);background:var(--bg-hover)}.month-tab.active{color:var(--text);background:var(--bg-surface);border:1px solid var(--border);border-bottom:1px solid var(--bg-surface);margin-bottom:-1px}.month-tab-count{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--accent);color:#fff;font-size:10px;font-weight:800;font-family:var(--font-body);margin-left:6px;vertical-align:middle}.timeline-content{flex:1;overflow-y:auto;padding:24px;background:var(--bg-surface)}.timeline-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px;max-width:1200px;margin:0 auto}.timeline-month-header{font-family:var(--font-display);font-size:28px;letter-spacing:1px;text-transform:uppercase;color:var(--text);margin-bottom:16px;display:flex;align-items:baseline;gap:10px}.timeline-month-header small{font-size:13px;font-weight:600;font-family:var(--font-body);color:var(--text-dim);letter-spacing:2px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-card);border:1px solid var(--border-h);border-radius:var(--radius-lg);width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow);animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:24px 24px 18px;border-bottom:1px solid var(--border)}.modal-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.modal-close{width:32px;height:32px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:var(--text-muted);background:var(--bg-surface);border:1px solid var(--border);font-size:18px;flex-shrink:0;transition:all .15s}.modal-close:hover{color:var(--text);border-color:var(--border-h)}.modal-title{font-family:var(--font-display);font-size:32px;line-height:1.1;color:var(--text)}.modal-location{font-size:14px;color:var(--text-muted);display:flex;align-items:center;gap:5px;margin-top:6px}.modal-body{padding:20px 24px}.modal-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:20px}.modal-stat{background:var(--bg-surface);padding:14px;display:flex;flex-direction:column;gap:2px}.modal-stat-label{font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim)}.modal-stat-value{font-family:var(--font-display);font-size:20px;color:var(--text)}.modal-description{font-size:15px;line-height:1.65;color:var(--text-muted);margin-bottom:20px}.modal-spots{display:flex;flex-direction:column;gap:6px}.modal-spots-bar{height:5px;background:var(--border);border-radius:3px;overflow:hidden}.modal-spots-fill{height:100%;border-radius:3px;transition:width .4s}.modal-footer{padding:18px 24px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-organiser{font-size:13px;color:var(--text-dim)}.modal-organiser strong{color:var(--text-muted)}.btn-register{font-family:var(--font-display);font-size:16px;letter-spacing:1px;text-transform:uppercase;padding:12px 28px;border-radius:var(--radius);background:var(--accent);color:#fff;transition:background .15s;white-space:nowrap;display:inline-block;border:none;cursor:pointer}.btn-register:hover:not(:disabled){background:var(--accent-h)}.btn-register:disabled{background:var(--border);color:var(--text-dim);cursor:not-allowed}.bp-type-tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-display);font-size:11px;letter-spacing:1px;text-transform:uppercase;padding:2px 8px;border-radius:99px;margin-bottom:6px;background:rgba(42,171,147,.15);color:#2aab93}.bp-type-dot{width:7px;height:7px;background:#2aab93;transform:rotate(45deg);display:inline-block;flex-shrink:0;border-radius:2px}.bp-trails-section{margin-bottom:18px}.bp-section-label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim);margin-bottom:10px}.bp-trail-grades{display:flex;flex-wrap:wrap;gap:8px}.bp-grade-pill{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:99px;font-size:13px;font-weight:500}.bp-meta-row{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:16px}.bp-meta-item{background:var(--bg-surface);padding:12px 14px;display:flex;flex-direction:column;gap:3px}.bp-meta-label{font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim)}.bp-meta-value{font-family:var(--font-display);font-size:18px;color:var(--text)}.bp-facilities{margin-bottom:4px}.bp-facility-chips{display:flex;flex-wrap:wrap;gap:6px}.facility-chip{font-size:11px;padding:4px 10px;border-radius:4px;background:var(--bg);border:1px solid var(--border);color:var(--text-muted)}@media (max-width: 640px){.header{padding:0 14px}.header-tagline,.btn-submit-event{display:none}.filter-left{padding:0 10px}.filter-divider{display:none}.filter-chip{padding:4px 10px;font-size:11px}.view-switcher{border-left:1px solid var(--border);border-top:none}.view-btn{padding:0 11px;font-size:11px;gap:4px}.map-sidebar{display:none}.map-view{flex-direction:column}.map-container{flex:1;width:100%;min-height:0}.map-container .leaflet-container{width:100%!important;height:100%!important}.grid-view{padding:12px}.grid-view-inner{grid-template-columns:1fr}.month-tabs{padding:8px 12px 0;gap:2px}.month-tab{padding:8px 10px;font-size:11px}.timeline-content{padding:16px 12px}.timeline-grid{grid-template-columns:1fr}.modal-overlay{padding:0;align-items:flex-end}.modal{max-width:100%;max-height:90dvh;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.modal-stats{grid-template-columns:repeat(2,1fr)}.modal-title{font-size:24px}.modal-footer{flex-direction:column;align-items:stretch}.btn-register{width:100%;text-align:center}}
