: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;--header-h: 56px;--filter-h: 48px}*,*: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:100dvh;overflow:hidden}.content-area{flex:1;overflow:hidden;position:relative}.header{height:var(--header-h);background:var(--bg-surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px;flex-shrink:0;gap:10px}.header-left{display:flex;align-items:center}.header-logo{display:flex;align-items:center;gap:9px}.logo-icon{width:32px;height:32px;flex-shrink:0}.logo-text{font-family:var(--font-display);font-size:22px;letter-spacing:1px;color:var(--text)}.logo-text span{color:var(--accent)}.header-section-tabs{display:flex;gap:2px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:3px}.section-tab{font-family:var(--font-body);font-size:13px;font-weight:500;padding:5px 14px;border-radius:6px;color:var(--text-muted);transition:all .15s}.section-tab.active{background:var(--accent);color:#fff}.header-actions{display:flex;align-items:center;gap:10px}.btn-submit-event{font-family:var(--font-body);font-size:12px;font-weight:500;padding:7px 14px;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:var(--filter-h);background:var(--bg-surface);border-bottom:1px solid var(--border);display:flex;align-items:center;flex-shrink:0;gap:8px;padding-right:14px}.filter-bar-scroll{display:flex;align-items:center;gap:6px;flex:1;overflow-x:auto;padding:0 14px;scrollbar-width:none}.filter-bar-scroll::-webkit-scrollbar{display:none}.view-tabs{display:flex;gap:2px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:2px;flex-shrink:0}.view-tab{font-size:12px;font-weight:500;padding:4px 11px;border-radius:6px;color:var(--text-muted);white-space:nowrap;transition:all .15s}.view-tab.active{background:var(--bg-surface);color:var(--text);border:1px solid var(--border)}.filter-divider{width:1px;height:20px;background:var(--border);flex-shrink:0}.filter-chip{font-size:12px;font-weight:500;padding:5px 12px;border-radius:20px;border:1px solid var(--border);color:var(--text-muted);background:transparent;white-space:nowrap;transition:all .15s;flex-shrink:0}.filter-chip:hover{border-color:var(--border-h);color:var(--text)}.filter-count{font-size:12px;color:var(--text-dim);white-space:nowrap;flex-shrink:0}.map-container{position:relative;width:100%;height:100%}.map-container .leaflet-container{width:100%;height:100%;background:#e8e4dc}.map-legend{position:absolute;bottom:24px;left:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;z-index:500;display:flex;flex-direction:column;gap:5px;box-shadow:var(--shadow)}.legend-item{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--text-muted)}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-diamond{width:10px;height:10px;transform:rotate(45deg);border-radius:2px;flex-shrink:0}.legend-divider{height:1px;background:var(--border);margin:2px 0}.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}.map-popup{padding:10px 12px;min-width:160px}.map-popup-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:3px}.map-popup-sub{font-size:11px;color:var(--text-muted)}.map-popup-btn{margin-top:8px;font-size:11px;font-weight:600;color:var(--accent);cursor:pointer;background:none;border:none;padding:0}.map-popup-btn:hover{color:var(--accent-h)}.timeline-view{height:100%;overflow-y:auto;padding:24px;background:var(--bg)}.timeline-month{margin-bottom:32px}.timeline-month-header{font-family:var(--font-display);font-size:28px;font-weight:400;letter-spacing:1px;text-transform:uppercase;color:var(--text);margin-bottom:14px;display:flex;align-items:baseline;gap:10px}.timeline-month-header small{font-size:13px;font-weight:600;color:var(--text-dim);letter-spacing:2px;font-family:var(--font-body)}.timeline-month-count{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--accent);color:#fff;font-size:11px;font-weight:700;font-family:var(--font-body)}.timeline-grid{display:flex;flex-direction:column;gap:8px}.grid-view{height:100%;overflow-y:auto;background:var(--bg)}.grid-view-inner{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:10px;padding:20px;max-width:1400px;margin:0 auto}.no-events{text-align:center;padding:48px;color:var(--text-dim);font-family:var(--font-display);font-size:20px;letter-spacing:1px}.event-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:all .15s;position:relative}.event-card:hover{border-color:var(--border-h);transform:translateY(-1px);box-shadow:var(--shadow)}.event-card.featured{border-color:#c8602a59}.featured-stripe{height:3px;background:var(--accent)}.e-card-body{display:flex;align-items:flex-start;gap:12px;padding:13px 14px}.e-card-date{display:flex;flex-direction:column;align-items:center;min-width:38px;padding-top:2px}.e-card-day{font-family:var(--font-display);font-size:26px;line-height:1;color:var(--text)}.e-card-month{font-size:10px;font-weight:600;letter-spacing:1.5px;color:var(--text-dim);text-transform:uppercase;margin-top:1px}.e-card-info{flex:1;min-width:0}.e-card-title{font-size:14px;font-weight:600;color:var(--text);margin:5px 0 3px;line-height:1.3}.e-card-loc{font-size:12px;color:var(--text-muted)}.e-card-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}.e-card-price{font-family:var(--font-display);font-size:20px;color:var(--text)}.type-tag{display:inline-block;font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;padding:2px 8px;border-radius:20px}.spots-badge{font-size:11px;font-weight:500;padding:2px 8px;border-radius:4px;background:rgba(61,107,68,.1);color:var(--green);white-space:nowrap}.spots-badge.sold-out{background:rgba(139,38,53,.1);color:#8b2635}.spots-badge.low-spots{background:rgba(200,96,42,.1);color:var(--accent)}.featured-badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--accent);padding:2px 8px;background:rgba(200,96,42,.1);border-radius:4px}.url-breadcrumb{background:#faf7f2;border-bottom:1px solid var(--border);padding:8px 20px}.url-breadcrumb-path{font-size:11px;font-family:DM Sans,monospace;margin-bottom:4px;line-height:1}.url-breadcrumb-domain{color:var(--text-dim)}.url-breadcrumb-slug{color:var(--accent);font-weight:500}.url-breadcrumb-crumbs{display:flex;align-items:center;flex-wrap:wrap;gap:2px;font-size:11px}.url-breadcrumb-crumb-wrap{display:flex;align-items:center;gap:2px}.url-breadcrumb-sep{color:var(--text-dim);font-size:10px}.url-breadcrumb-crumb{color:var(--text-dim)}.url-breadcrumb-crumb.active{color:var(--text-muted);font-weight:500}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.55);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;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:580px;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:20px 20px 16px;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:30px;height:30px;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:16px;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:30px;font-weight:400;line-height:1.1;color:var(--text);letter-spacing:.5px}.modal-location{font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:5px;margin-top:6px}.modal-body{padding:18px 20px}.modal-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:18px}.modal-stat{background:var(--bg-surface);padding:12px;display:flex;flex-direction:column;gap:3px}.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;font-weight:400;color:var(--text);letter-spacing:.5px}.modal-description{font-size:14px;line-height:1.65;color:var(--text-muted);margin-bottom:16px}.modal-footer{padding:16px 20px;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;font-weight:400;letter-spacing:1.5px;text-transform:uppercase;padding:11px 24px;border-radius:var(--radius);background:var(--accent);color:#fff;transition:background .15s;white-space:nowrap;display:inline-block}.btn-register:hover{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-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:#2aab93;padding:3px 9px;background:rgba(42,171,147,.1);border:1px solid rgba(42,171,147,.3);border-radius:20px}.bp-type-dot{width:8px;height:8px;background:#2aab93;transform:rotate(45deg);border-radius:2px;flex-shrink:0}.bp-section-label{font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim);margin-bottom:8px}.bp-trails-section{margin-bottom:16px}.bp-trail-grades{display:flex;gap:6px;flex-wrap:wrap}.bp-grade-pill{font-size:12px;font-weight:500;padding:4px 10px;border-radius:20px}.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;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:20px;color:var(--text);letter-spacing:.5px}.bp-facilities{margin-bottom:4px}.bp-facility-chips{display:flex;flex-wrap:wrap;gap:5px}.facility-chip{font-size:11px;padding:3px 9px;border-radius:4px;background:var(--bg);border:1px solid var(--border);color:var(--text-muted)}@media (max-width: 640px){.header{padding:0 12px}.btn-submit-event{display:none}.logo-text{font-size:20px}.modal-overlay{padding:0;align-items:flex-end}.modal{max-width:100%;max-height:85dvh;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.modal-stats{grid-template-columns:repeat(2,1fr)}.map-legend{display:none}.grid-view-inner{grid-template-columns:1fr;padding:12px}.timeline-view{padding:16px}}
