*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;color:#333;background:#f5f7fa}.container{max-width:1200px;margin:0 auto;padding:0 20px}header{background:#667eea;color:#fff;padding:30px 0;text-align:center;box-shadow:0 2px 4px #0000001a}header .container{display:flex;flex-direction:column;align-items:center;position:relative}header h1{font-size:2.5rem;margin-bottom:10px}.subtitle{font-size:1.1rem;opacity:.9}.auth-container{position:absolute;right:20px;top:50%;transform:translateY(-50%)}.auth-loading{color:#fffc;font-size:.9rem}.auth-buttons{display:flex;gap:10px}.user-menu{display:flex;align-items:center;gap:15px}#user-email{font-size:.9rem;opacity:.9}.btn-auth{padding:8px 16px;background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:4px;font-size:.9rem;cursor:pointer;transition:all .3s}.btn-auth:hover{background:#ffffff4d}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:40px;border-radius:12px;width:100%;max-width:400px;position:relative;box-shadow:0 10px 40px #0003}.modal-close{position:absolute;top:15px;right:20px;font-size:1.5rem;color:#999;cursor:pointer;transition:color .3s}.modal-close:hover{color:#333}.modal-content h2{margin-bottom:25px;color:#333;text-align:center}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#555}.form-group input{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#667eea}.auth-error{background:#ffebee;color:#c62828;padding:12px;border-radius:6px;margin-bottom:20px;font-size:.9rem}.auth-switch{text-align:center;margin-top:20px;color:#666}.auth-switch a{color:#667eea;text-decoration:none;font-weight:600}.auth-switch a:hover{text-decoration:underline}.event-detail-modal{max-width:680px;max-height:85vh;overflow-y:auto}.event-detail-rows{display:flex;flex-direction:column;gap:14px;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #f0f0f0}.event-detail-row{display:flex;flex-direction:column;gap:3px}.event-detail-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#667eea}.event-detail-value{font-size:.95rem;color:#333}.event-detail-description{margin-top:4px}.event-detail-description p{margin-top:8px;font-size:.95rem;color:#444;line-height:1.7;white-space:pre-wrap}.rsvp-section{margin-top:24px;display:flex;flex-direction:column;gap:10px}.rsvp-buttons{display:flex;gap:8px}.rsvp-btn{flex:1;padding:10px 8px;border:2px solid #ddd;border-radius:8px;background:#fff;color:#555;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s ease}.rsvp-btn:hover:not(:disabled){border-color:#aaa;color:#333}.rsvp-btn:disabled{opacity:.6;cursor:not-allowed}.rsvp-btn.rsvp-going{border-color:#2e7d32;background:#e8f5e9;color:#2e7d32;font-weight:600}.rsvp-btn.rsvp-maybe{border-color:#e65100;background:#fff3e0;color:#e65100;font-weight:600}.rsvp-btn.rsvp-not-going{border-color:#c62828;background:#ffebee;color:#c62828;font-weight:600}.login-required{text-align:center;padding:80px 20px;background:#fff;border-radius:12px;margin:40px 0;box-shadow:0 2px 8px #0000001a}.login-required h2{margin-bottom:15px;color:#333}.login-required p{color:#666;margin-bottom:25px}.stats-section{margin:40px 0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.stat-card{background:#fff;padding:30px;border-radius:8px;text-align:center;box-shadow:0 2px 8px #0000001a;transition:transform .2s}.stat-card:hover{transform:translateY(-5px)}.stat-card.highlight{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.stat-number{font-size:3rem;font-weight:700;margin-bottom:10px}.stat-label{font-size:.9rem;text-transform:uppercase;letter-spacing:1px;opacity:.8}.filters-section{background:#fff;padding:30px;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:40px}.filters-section h2{margin-bottom:20px;color:#667eea}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:20px}.filter-group label{display:block;font-weight:600;margin-bottom:8px;color:#555}.filter-group input[type=text],.filter-group input[type=date],.filter-group select{width:100%;padding:10px;border:2px solid #e0e0e0;border-radius:4px;font-size:1rem;transition:border-color .3s}.filter-group input[type=text]:focus,.filter-group input[type=date]:focus,.filter-group select:focus{outline:none;border-color:#667eea}.filter-group:has(#start-date-filter),.filter-group:has(#end-date-filter){position:relative}.filter-group input[type=date]{padding-right:40px}.btn-clear-date{position:absolute;right:10px;top:38px;width:24px;height:24px;border-radius:50%;border:none;background:#e0e0e0;color:#666;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-clear-date:hover{background:#667eea;color:#fff}.checkbox-group{display:flex;flex-direction:column;gap:8px}.checkbox-group label{display:flex;align-items:center;font-weight:400;cursor:pointer}.checkbox-group input[type=checkbox]{margin-right:8px;width:18px;height:18px;cursor:pointer}.filter-actions{display:flex;gap:10px}.btn{padding:12px 24px;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5568d3}.btn-primary:disabled{background:#a0a0a0;cursor:not-allowed}.btn-secondary{background:#e0e0e0;color:#555}.btn-secondary:hover{background:#d0d0d0}.map-section{background:#fff;padding:30px;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:40px}.map-section h2{margin-bottom:20px;color:#667eea}#map-container{width:100%;height:500px;border-radius:8px;overflow:hidden}#event-map,.leaflet-container{width:100%;height:100%}.leaflet-popup-content-wrapper{border-radius:8px}.event-popup{padding:12px;max-width:300px}.event-popup h4{margin:0 0 8px;color:#667eea}.event-popup p{margin:4px 0;font-size:.9rem;color:#666}.event-popup .popup-badges{display:flex;gap:4px;margin-top:8px;flex-wrap:wrap}.event-popup .popup-badge{padding:2px 8px;border-radius:10px;font-size:.7rem;font-weight:600}.event-popup a{color:#667eea;text-decoration:none;font-weight:600}.event-popup a:hover{text-decoration:underline}.events-section{margin-bottom:40px}.events-section h2{margin-bottom:20px;color:#333}.count-badge{display:inline-block;background:#667eea;color:#fff;padding:4px 12px;border-radius:20px;font-size:.9rem;margin-left:10px}.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.event-card{background:#fff;padding:24px;border-radius:8px;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.event-card:hover{transform:translateY(-5px);box-shadow:0 4px 16px #00000026}.event-badges{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.badge-niche{background:gold;color:#333}.badge-free{background:#4caf50;color:#fff}.badge-online{background:#2196f3;color:#fff}.badge-source{background:#e0e0e0;color:#555}.event-title{font-size:1.2rem;font-weight:700;margin-bottom:12px;color:#333;line-height:1.4}.event-title a{color:inherit;text-decoration:none;transition:color .3s}.event-title a:hover{color:#667eea}.event-meta{display:flex;flex-direction:column;gap:8px;font-size:.9rem;color:#666;margin-bottom:12px}.event-meta-item{display:flex;align-items:flex-start;gap:8px}.event-meta-item strong{min-width:60px;color:#333}.event-description{font-size:.9rem;color:#666;line-height:1.6;margin-top:12px;border-top:1px solid #f0f0f0;padding-top:12px}.loading{text-align:center;padding:40px;font-size:1.1rem;color:#666}.no-events{text-align:center;padding:60px 20px;background:#fff;border-radius:8px;color:#666}footer{background:#2c3e50;color:#fff;padding:30px 0;text-align:center;margin-top:60px}footer p{margin:5px 0}@media(max-width:768px){.container{padding:0 16px}header{padding:20px 0}header .container{padding-bottom:50px}.auth-container{position:relative;right:auto;top:auto;transform:none;margin-top:15px}header h1{font-size:2rem}.subtitle{font-size:1rem}.stats-section{margin:24px 0}.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.stat-card{padding:20px}.stat-number{font-size:2.2rem}.filters-section{padding:20px;margin-bottom:24px}.filters-grid{grid-template-columns:1fr;gap:14px}.filter-actions{flex-direction:column}.btn{width:100%}.map-section{padding:16px;margin-bottom:24px}#map-container{height:300px}.events-section{margin-bottom:24px}.events-grid{grid-template-columns:1fr;gap:12px}.event-card{padding:16px}.modal-content{margin:0;padding:24px;border-radius:0;width:100%;max-width:100%;min-height:100vh;align-self:flex-start}.event-detail-modal{max-height:100vh}.rsvp-buttons{flex-wrap:wrap}.rsvp-btn{min-width:calc(50% - 4px)}}@media(max-width:480px){header h1{font-size:1.6rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.stat-card{padding:14px}.stat-number{font-size:1.8rem}.stat-label{font-size:.75rem}.filters-section{padding:16px}.map-section{padding:12px}#map-container{height:240px}.event-card{padding:14px}.event-title{font-size:1.05rem}.modal-content{padding:16px}.rsvp-btn{min-width:100%}}
