:root{--cat-nature:#22C55E;--cat-sport:#F97316;--cat-culture:#A855F7;--cat-fun:#EC4899;--cat-indoor:#3B82F6;--cat-food:#EAB308;--cat-water:#06B6D4;--cat-animal:#10B981;--age-0-3:#F472B6;--age-4-8:#FB923C;--age-9-12:#34D399;--age-teens:#60A5FA;--sidebar-w:340px;--bg-panel:#FFFFFF;--bg-hover:#F8FAFC;--border:#E2E8F0;--text-dark:#0F172A;--text-mid:#475569;--text-light:#94A3B8;--shadow-sm:0 1px 3px rgba(0,0,0,0.08);--shadow-md:0 4px 16px rgba(0,0,0,0.1);--shadow-lg:0 12px 40px rgba(0,0,0,0.15);--radius-sm:8px;--radius-md:12px;--radius-lg:16px}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Outfit',-apple-system,sans-serif;background:#F1F5F9;color:var(--text-dark);overflow:hidden;height:100vh;width:100vw}
.top-header{position:fixed;top:0;left:0;right:0;z-index:2500;height:56px;background:#FFF;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:16px;box-shadow:0 1px 4px rgba(0,0,0,0.06)}
.header-left{display:flex;align-items:center;gap:10px;flex-shrink:0}
.mobile-toggle-header{display:flex;width:36px;height:36px;border-radius:8px;border:none;background:var(--bg-hover);cursor:pointer;font-size:18px;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}
.mobile-toggle-header:hover{background:#E2E8F0}
.header-logo{display:flex;align-items:center;gap:8px}
.header-logo .logo-icon{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#6366F1,#EC4899);display:flex;align-items:center;justify-content:center;font-size:17px;box-shadow:0 2px 6px rgba(99,102,241,0.25)}
.header-logo-text{font-size:13px;font-weight:800;line-height:1.15;white-space:nowrap}
.header-center{flex:1;display:flex;justify-content:center;align-items:center;max-width:520px;margin:0 auto;gap:8px}
.header-search-wrapper{position:relative;flex:1}
.search-autocomplete{display:none;position:absolute;top:100%;left:0;right:0;margin-top:4px;background:#FFF;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--border);max-height:260px;overflow-y:auto;z-index:3000}
.search-autocomplete.open{display:block}
.search-ac-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;font-size:12.5px;font-weight:500;transition:background .1s}
.search-ac-item:hover{background:var(--bg-hover)}
.search-ac-item .ac-icon{font-size:16px;opacity:.5}
.search-ac-item .ac-main{font-weight:700;color:var(--text-dark)}
.search-ac-item .ac-sub{font-size:11px;color:var(--text-light);margin-left:6px}
.geolocate-btn{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--border);background:#FFF;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#6366F1;transition:all .2s;flex-shrink:0}
.geolocate-btn:hover{border-color:#6366F1;background:rgba(99,102,241,0.04);transform:scale(1.05)}
.header-search-wrapper{position:relative;width:100%}
.header-search-wrapper .search-input{width:100%;padding:9px 14px 9px 38px;border:1.5px solid var(--border);border-radius:20px;font-family:'Outfit',sans-serif;font-size:13px;font-weight:500;color:var(--text-dark);background:var(--bg-hover);outline:none;transition:all .2s}
.header-search-wrapper .search-input:focus{border-color:#6366F1;background:#FFF;box-shadow:0 0 0 3px rgba(99,102,241,0.1)}
.header-search-wrapper .search-icon-el{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:14px;opacity:.4;pointer-events:none}
.header-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.auth-btn{display:flex;align-items:center;gap:6px;padding:7px 16px;background:#FFF;border:1.5px solid var(--border);border-radius:20px;cursor:pointer;font-family:'Outfit',sans-serif;font-size:12.5px;font-weight:600;color:var(--text-dark);transition:all .15s;white-space:nowrap}
.auth-btn:hover{border-color:#6366F1;color:#6366F1;background:rgba(99,102,241,0.04)}
.auth-btn.logged-in{border-color:#22C55E;color:#166534;background:rgba(34,197,94,0.06)}
.auth-user-menu{position:relative}
.auth-dropdown{position:absolute;top:100%;right:0;margin-top:6px;background:#FFF;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--border);min-width:180px;z-index:3000;display:none;overflow:hidden}
.auth-dropdown.open{display:block}
.auth-dropdown a{display:block;padding:10px 16px;font-size:12.5px;font-weight:600;color:var(--text-dark);text-decoration:none;transition:background .1s;cursor:pointer}
.auth-dropdown a:hover{background:var(--bg-hover)}
.auth-dropdown a.danger{color:#EF4444}
.auth-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,0.5);backdrop-filter:blur(4px);z-index:4000;justify-content:center;align-items:center}
.auth-overlay.open{display:flex}
.auth-modal{background:#FFF;border-radius:var(--radius-lg);box-shadow:0 8px 32px rgba(0,0,0,0.12);width:420px;max-width:95vw;overflow:hidden}
.auth-tabs-bar{display:flex;border-bottom:1px solid var(--border)}
.auth-tab{flex:1;padding:16px 16px 14px;border:none;background:none;border-bottom:2px solid transparent;cursor:pointer;font-family:'Outfit',sans-serif;font-size:14px;font-weight:600;color:var(--text-light);transition:all .15s;text-align:center}
.auth-tab.active{color:#3B82F6;border-bottom-color:#3B82F6}
.auth-tab:hover:not(.active){color:var(--text-mid)}
.auth-body{padding:24px 28px 20px}
.auth-field{margin-bottom:16px}
.auth-field label{display:block;font-size:13px;font-weight:600;color:var(--text-dark);margin-bottom:6px}
.auth-field input{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:'Outfit',sans-serif;font-size:13.5px;font-weight:500;color:var(--text-dark);background:#FFF;outline:none;transition:border-color .15s}
.auth-field input:focus{border-color:#3B82F6;box-shadow:0 0 0 3px rgba(59,130,246,0.1)}
.auth-field input::placeholder{color:var(--text-light);font-weight:400}
.auth-input-password{position:relative}
.auth-input-password input{width:100%;padding-right:42px}
.auth-pw-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);border:none;background:none;cursor:pointer;color:var(--text-light);padding:4px;display:flex;align-items:center;justify-content:center;transition:color .15s}
.auth-pw-toggle:hover{color:var(--text-mid)}
.auth-forgot-row{display:flex;justify-content:flex-end;margin-bottom:4px}
.auth-forgot-link{font-size:12.5px;font-weight:600;color:#3B82F6;text-decoration:none;transition:color .15s}
.auth-forgot-link:hover{color:#2563EB;text-decoration:underline}
.auth-error{color:#EF4444;font-size:12px;font-weight:600;min-height:18px;margin-bottom:4px}
.auth-submit{width:100%;padding:12px;border:none;border-radius:var(--radius-sm);background:#3B82F6;color:#FFF;font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s}
.auth-submit:hover{background:#2563EB;box-shadow:0 4px 12px rgba(59,130,246,0.3)}
.auth-submit:disabled{opacity:.5;cursor:not-allowed}
.auth-submit-green{background:#22C55E}
.auth-submit-green:hover{background:#16A34A;box-shadow:0 4px 12px rgba(34,197,94,0.3)}
.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-divider span{font-size:12px;font-weight:500;color:var(--text-light);white-space:nowrap}
.auth-social-row{display:flex;gap:12px;margin-bottom:20px}
.auth-social-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:#FFF;cursor:pointer;font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;color:var(--text-dark);transition:all .15s}
.auth-social-btn:hover{border-color:#CBD5E1;background:var(--bg-hover)}
.auth-footer-text{text-align:center;font-size:11px;color:var(--text-light);padding-top:4px}
.event-float-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;background:linear-gradient(135deg,#F59E0B,#D97706);border-radius:24px;border:none;box-shadow:var(--shadow-md);cursor:pointer;font-family:'Outfit',sans-serif;font-size:13px;font-weight:700;color:#FFF;transition:all .2s;white-space:nowrap}
.event-float-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(245,158,11,0.4)}
.events-list{display:flex;flex-direction:column;gap:2px}
.events-share-hint{font-size:11px;color:#475569;background:rgba(99,102,241,0.08);border:1px dashed rgba(99,102,241,0.25);padding:8px 10px;border-radius:8px;margin-bottom:8px}
.ev-item{display:flex;align-items:center;gap:10px;padding:10px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s}
.ev-item:hover{background:var(--bg-hover)}
.ev-item-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#F59E0B,#D97706);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;color:#FFF}
.ev-item-info{flex:1;min-width:0}
.ev-item-title{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ev-item-meta{font-size:10px;color:var(--text-light);margin-top:2px}
.ev-item-badge{font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:0.5px;flex-shrink:0}
.ev-item-badge.public{background:rgba(34,197,94,0.1);color:#166534}
.ev-item-badge.private{background:rgba(239,68,68,0.1);color:#991B1B}
.ev-item-share{border:none;background:rgba(14,165,233,0.12);color:#0369A1;width:30px;height:30px;border-radius:8px;cursor:pointer;font-size:14px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.ev-item-share:hover{background:rgba(14,165,233,0.22)}
.ev-user-results{max-height:120px;overflow-y:auto;margin-top:4px}
.ev-user-result{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;transition:background .1s}
.ev-user-result:hover{background:var(--bg-hover)}
.ev-invitee-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.ev-invitee-tag{display:flex;align-items:center;gap:4px;padding:4px 10px;background:rgba(99,102,241,0.08);border:1px solid rgba(99,102,241,0.2);border-radius:12px;font-size:11px;font-weight:600;color:#4338CA}
.ev-invitee-tag .remove{cursor:pointer;font-size:14px;line-height:1;margin-left:2px;opacity:.6}
.ev-invitee-tag .remove:hover{opacity:1}
.ev-detail-participant{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:12px}
.ev-detail-avatar{width:28px;height:28px;border-radius:50%;background:#6366F1;color:#FFF;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex-shrink:0}
/* ═══════════════════════════════════════════════════════════
   EVENT DETAIL MODAL — Redesigned
   ═══════════════════════════════════════════════════════════ */
.evd-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,0.5);backdrop-filter:blur(6px);z-index:3000;justify-content:center;align-items:center}
.evd-overlay.open{display:flex}
.evd-modal{background:#FFF;border-radius:20px;box-shadow:0 25px 60px rgba(0,0,0,0.18);width:460px;max-width:95vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:evd-in .3s cubic-bezier(.34,1.56,.64,1)}
@keyframes evd-in{from{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}
.evd-scroll{flex:1;overflow-y:auto}
/* Hero */
.evd-hero{position:relative;width:100%;height:220px;background:linear-gradient(135deg,#6366F1,#8B5CF6);overflow:hidden;flex-shrink:0}
.evd-hero-img{width:100%;height:100%;object-fit:cover;display:block}
.evd-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.6) 0%,rgba(0,0,0,0) 60%);pointer-events:none}
.evd-hero-actions{position:absolute;top:12px;right:12px;display:flex;gap:8px;z-index:2}
.evd-hero-btn{width:36px;height:36px;border-radius:50%;border:none;background:rgba(255,255,255,0.2);backdrop-filter:blur(8px);cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;color:#FFF;transition:all .15s;line-height:1}
.evd-hero-btn:hover{background:rgba(255,255,255,0.35);transform:scale(1.08)}
.evd-hero-bottom{position:absolute;bottom:16px;left:16px;right:16px;z-index:2}
.evd-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:700;margin-bottom:8px}
.evd-badge.public{background:rgba(34,197,94,0.9);color:#FFF}
.evd-badge.private{background:rgba(99,102,241,0.9);color:#FFF}
.evd-hero-title{font-size:22px;font-weight:800;color:#FFF;line-height:1.2;text-shadow:0 2px 8px rgba(0,0,0,0.3)}
/* Content */
.evd-content{padding:20px 24px 24px}
.evd-e2ee-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;background:rgba(34,197,94,0.1);border-radius:12px;font-size:10px;font-weight:700;color:#166534;margin-bottom:12px}
.evd-info-row{display:flex;align-items:center;gap:14px;padding:10px 0}
.evd-info-icon{width:40px;height:40px;border-radius:12px;background:rgba(99,102,241,0.08);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.evd-info-text{flex:1;min-width:0}
.evd-info-primary{font-size:14px;font-weight:700;color:var(--text-dark);text-transform:capitalize}
.evd-info-secondary{font-size:12px;color:var(--text-light);margin-top:2px}
.evd-divider{height:1px;background:var(--border);margin:8px 0}
.evd-section-title{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-light);margin:16px 0 8px}
.evd-desc{font-size:13px;color:var(--text-mid);line-height:1.6;margin-bottom:12px}
/* Organizer */
.evd-organizer{display:flex;align-items:center;gap:12px;padding:14px 0;border-top:1px solid var(--border)}
.evd-organizer-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#6366F1,#8B5CF6);color:#FFF;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;flex-shrink:0}
.evd-organizer-info{flex:1}
.evd-organizer-label{font-size:11px;color:var(--text-light);font-weight:500}
.evd-organizer-name{font-size:14px;font-weight:700;color:var(--text-dark)}
/* Participants */
.evd-participants-section{padding:14px 0;border-top:1px solid var(--border)}
.evd-participants-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.evd-avatars-stack{display:flex}
.evd-stack-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#6366F1,#8B5CF6);color:#FFF;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;border:2px solid #FFF;margin-left:-8px;flex-shrink:0}
.evd-stack-avatar:first-child{margin-left:0}
.evd-stack-more{background:#E2E8F0;color:var(--text-mid);font-size:10px}
.evd-participants-count{font-size:13px;font-weight:600;color:var(--text-mid);margin-left:auto}
.evd-progress{height:6px;background:#F1F5F9;border-radius:3px;overflow:hidden}
.evd-progress-bar{height:100%;background:linear-gradient(90deg,#6366F1,#8B5CF6);border-radius:3px;transition:width .3s}
/* S'y rendre nav */
.ev-detail-nav-wrap{position:relative}
.ev-detail-nav-btn{width:100%;padding:12px 16px;border:none;border-radius:var(--radius-md);background:linear-gradient(135deg,#22C55E,#16A34A);color:#FFF;font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px rgba(34,197,94,0.3);display:flex;align-items:center;justify-content:center;gap:8px}
.ev-detail-nav-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(34,197,94,0.4)}
.ev-detail-nav-arrow{font-size:10px;margin-left:4px;transition:transform .2s}
.ev-detail-nav-choices{display:none;margin-top:8px;background:#FFF;border-radius:var(--radius-md);box-shadow:var(--shadow-md);border:1px solid var(--border);overflow:hidden}
.ev-detail-nav-choices.open{display:flex;flex-direction:column}
.ev-detail-nav-choice{display:flex;align-items:center;gap:10px;padding:12px 16px;font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;color:var(--text-dark);text-decoration:none;transition:background .15s;cursor:pointer;border-bottom:1px solid #F1F5F9}
.ev-detail-nav-choice:last-child{border-bottom:none}
.ev-detail-nav-choice:hover{background:var(--bg-hover)}
/* Map button */
.evd-map-btn{width:100%;padding:12px;border:none;border-radius:var(--radius-md);background:linear-gradient(135deg,#6366F1,#8B5CF6);color:#FFF;font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px rgba(99,102,241,0.3);display:flex;align-items:center;justify-content:center;gap:8px;margin-top:10px}
.evd-map-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(99,102,241,0.4)}
/* Footer */
.evd-footer{display:none;gap:10px;padding:16px 24px;border-top:1px solid var(--border);background:#FFF;flex-shrink:0}
.evd-btn-outline{flex:1;padding:12px 20px;border:1.5px solid var(--border);border-radius:12px;background:#FFF;font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;color:var(--text-mid);cursor:pointer;transition:all .15s}
.evd-btn-outline:hover{border-color:#CBD5E1;background:var(--bg-hover)}
.evd-btn-primary{flex:1;padding:12px 20px;border:none;border-radius:12px;background:linear-gradient(135deg,#6366F1,#8B5CF6);color:#FFF;font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px rgba(99,102,241,0.3)}
.evd-btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(99,102,241,0.4)}
.evd-btn-status{flex:1;padding:12px 20px;border-radius:12px;font-family:'Outfit',sans-serif;font-size:13px;font-weight:700;text-align:center}
.evd-btn-status.accepted{background:rgba(34,197,94,0.08);color:#166534}
.evd-btn-status.declined{background:rgba(239,68,68,0.08);color:#991B1B}
@media(max-width:768px){.evd-modal{width:100%;max-width:100%;max-height:100vh;border-radius:0;height:100vh}.evd-hero{height:200px}.evd-content{padding:16px}}
.notif-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;border-radius:9px;background:#EF4444;color:#FFF;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid #FFF;line-height:1}
.notif-badge-inline{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;border-radius:8px;background:#EF4444;color:#FFF;font-size:9px;font-weight:800;padding:0 4px;margin-left:6px;line-height:1}
.marker-private-badge{position:absolute;top:-4px;right:-6px;background:#6366F1;color:#FFF;font-size:8px;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid #FFF;z-index:1}
.popup-owner-actions{display:flex;gap:2px}
.popup-owner-actions button{border:none;background:none;cursor:pointer;font-size:14px;padding:2px 4px;border-radius:4px;opacity:.5;transition:all .15s}
.popup-owner-actions button:hover{opacity:1;background:rgba(0,0,0,0.05)}
.popup-private-tag{display:inline-block;padding:2px 7px;border-radius:4px;background:#6366F1;color:#FFF;font-size:9px;font-weight:700;letter-spacing:.3px}
.ev-new-badge{display:inline-block;padding:1px 6px;border-radius:4px;background:linear-gradient(135deg,#F59E0B,#EF4444);color:#FFF;font-size:8px;font-weight:800;letter-spacing:0.5px;vertical-align:middle;margin-left:4px;animation:pulse-new 2s ease-in-out infinite}
@keyframes pulse-new{0%,100%{opacity:1}50%{opacity:.6}}
.app-layout{display:flex;height:calc(100vh - 56px - 30px);width:100vw;margin-top:56px}
.app-layout.footer-expanded{height:calc(100vh - 56px - 64px)}
.app-footer{position:fixed;bottom:0;left:0;right:0;z-index:2500;background:#FFF;border-top:1px solid var(--border);display:flex;flex-direction:column;align-items:center;padding:6px 16px;box-shadow:0 -1px 4px rgba(0,0,0,0.06)}
.footer-actions{display:flex;gap:8px;align-items:center;justify-content:center;margin-bottom:4px;flex-wrap:wrap}
.footer-copy{font-size:10px;color:var(--text-light);font-weight:500}
.footer-btn{display:flex;align-items:center;gap:5px;padding:8px 12px;border-radius:20px;border:none;cursor:pointer;font-family:'Outfit',sans-serif;font-size:12px;font-weight:700;transition:all .2s;white-space:nowrap;min-width:0}
.footer-icon{display:inline-flex;align-items:center;justify-content:center;font-size:14px;line-height:1}
.footer-label{display:inline}
.footer-event{background:linear-gradient(135deg,#F59E0B,#D97706);color:#FFF;box-shadow:0 2px 8px rgba(245,158,11,0.25)}
.footer-event:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(245,158,11,0.35)}
.footer-add{background:linear-gradient(135deg,#6366F1,#8B5CF6);color:#FFF;box-shadow:0 2px 8px rgba(99,102,241,0.25)}
.footer-add:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(99,102,241,0.35)}
.footer-fav{background:#FFF;border:1.5px solid var(--border);color:var(--text-dark)}
.footer-fav:hover{border-color:#EF4444;color:#EF4444}
.sidebar-title{font-size:15px;font-weight:800;color:var(--text-dark)}
.main-cat-row{display:flex;gap:8px}
.main-cat-btn{flex:1;padding:10px 12px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:#FFF;cursor:pointer;font-family:'Outfit',sans-serif;font-size:12.5px;font-weight:700;color:var(--text-dark);transition:all .15s;text-align:center}
.main-cat-btn.active{border-color:#6366F1;background:rgba(99,102,241,0.06);color:#4338CA}
.main-cat-btn:not(.active){opacity:.5}
.sidebar{width:var(--sidebar-w);height:100%;background:var(--bg-panel);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;z-index:1000;box-shadow:2px 0 20px rgba(0,0,0,0.06)}
.sidebar-header{padding:20px 24px 16px;border-bottom:1px solid var(--border)}
.logo{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.logo-icon{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#6366F1,#EC4899);display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 2px 8px rgba(99,102,241,0.3)}
.logo-text{font-size:15px;font-weight:800;line-height:1.15}
.logo-text small{display:block;font-size:10px;font-weight:500;color:var(--text-light);letter-spacing:.5px;text-transform:uppercase;margin-top:1px}
.search-wrapper{position:relative}
.search-input{width:100%;padding:10px 14px 10px 38px;border:1.5px solid var(--border);border-radius:var(--radius-md);font-family:'Outfit',sans-serif;font-size:13.5px;font-weight:500;color:var(--text-dark);background:var(--bg-hover);outline:none;transition:all .2s}
.search-input:focus{border-color:#6366F1;background:#FFF;box-shadow:0 0 0 3px rgba(99,102,241,0.1)}
.search-input::placeholder{color:var(--text-light)}
.search-icon-el{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:15px;opacity:.4;pointer-events:none}
.sidebar-scroll{flex:1;overflow-y:auto}
.filter-section{padding:16px 20px;border-bottom:1px solid var(--border)}
.filter-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-light);margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.filter-section-title .reset-btn{font-size:10px;font-weight:600;color:#6366F1;cursor:pointer;text-transform:none;letter-spacing:0;border:none;background:none;padding:2px 6px;border-radius:4px;transition:all .15s;display:none}
.filter-section-title .reset-btn.visible{display:inline-block}
.filter-section-title .reset-btn:hover{background:rgba(99,102,241,0.08)}
.category-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.cat-btn{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius-md);background:#FFF;cursor:pointer;transition:all .2s;position:relative;overflow:hidden;font-family:'Outfit',sans-serif}
.cat-btn:hover{border-color:#CBD5E1;background:var(--bg-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.cat-btn.active{border-color:var(--c);background:var(--cbg)}
.cat-btn.active .cat-label{color:var(--c);font-weight:700}
.cat-icon{width:32px;height:32px;border-radius:4px;transform:rotate(45deg);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;border:2px solid #FFF;box-shadow:0 2px 6px rgba(0,0,0,0.2)}
.cat-icon span{transform:rotate(-45deg)}
.cat-label{font-size:12px;font-weight:600;color:var(--text-mid);line-height:1.2}
.cat-count{position:absolute;top:5px;right:8px;font-size:9px;font-weight:700;color:var(--text-light);background:var(--bg-hover);padding:1px 5px;border-radius:6px}
.cat-btn.active .cat-count{background:rgba(255,255,255,0.3);color:var(--c)}
.age-slider{background:#FFF;border:1.5px solid var(--border);border-radius:12px;padding:10px}
.age-slider-values{display:flex;justify-content:space-between;font-size:12px;font-weight:700;color:var(--text-mid);margin-bottom:6px}
.age-slider-inputs{display:flex;flex-direction:column;gap:8px}
.age-slider input[type="range"]{width:100%;accent-color:#6366F1;cursor:pointer}
.weather-row{display:flex;gap:8px}
.weather-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:#FFF;cursor:pointer;font-family:'Outfit',sans-serif;font-size:12px;font-weight:600;color:var(--text-mid);transition:all .2s}
.weather-btn:hover{border-color:#CBD5E1}
.weather-btn.active{border-color:#3B82F6;background:rgba(59,130,246,0.06);color:#3B82F6}
.weather-btn .w-icon{font-size:18px}
.sidebar-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg-hover)}
.results-count{font-size:12px;font-weight:600;color:var(--text-mid)}
.results-count strong{color:var(--text-dark);font-weight:800;font-size:16px}
.map-area{flex:1;position:relative}
#map{width:100%;height:100%;z-index:1}
.leaflet-control-zoom{border:none!important;box-shadow:var(--shadow-md)!important;border-radius:var(--radius-md)!important;overflow:hidden}
.leaflet-control-zoom a{width:36px!important;height:36px!important;line-height:36px!important;font-size:18px!important;color:var(--text-dark)!important;border-bottom:1px solid var(--border)!important}
.leaflet-control-zoom a:hover{background:var(--bg-hover)!important}
.marker-container{background:none!important;border:none!important}
.marker-forza{display:flex;flex-direction:column;align-items:center;cursor:pointer;filter:drop-shadow(0 3px 6px rgba(0,0,0,0.35));transition:all .25s cubic-bezier(.34,1.56,.64,1)}
.marker-forza:hover{transform:scale(1.3) translateY(-4px);z-index:9999!important;filter:drop-shadow(0 6px 16px rgba(0,0,0,0.45))}
.marker-badge{width:36px;height:36px;border-radius:5px;transform:rotate(45deg);display:flex;align-items:center;justify-content:center;border:2.5px solid #FFF;position:relative}
.marker-badge span{transform:rotate(-45deg);font-size:16px;line-height:1}
.marker-tail{width:3px;height:10px;background:#FFF;margin-top:-3px;border-radius:0 0 2px 2px}
.marker-forza.pulse .marker-badge::after{content:'';position:absolute;inset:-6px;border-radius:7px;border:2px solid currentColor;opacity:0;animation:mp 2s ease-in-out infinite}
@keyframes mp{0%,100%{opacity:0;transform:scale(.9)}50%{opacity:.5;transform:scale(1.15)}}
.marker-forza.dimmed{opacity:.1;filter:grayscale(1);pointer-events:none;transform:scale(.65)}
.marker-fav{position:absolute;top:-4px;right:-4px;width:16px;height:16px;background:#FFF;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;transform:rotate(-45deg);box-shadow:0 1px 4px rgba(0,0,0,0.2);opacity:0;transition:all .2s;cursor:pointer;z-index:10}
.marker-forza:hover .marker-fav{opacity:1}
.marker-fav.active{opacity:1!important;background:var(--cat-fun)}
.poi-cluster-container{background:none!important;border:none!important}
.poi-cluster-marker{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#4F46E5,#2563EB);border:3px solid #FFF;box-shadow:0 6px 16px rgba(37,99,235,0.4);display:flex;align-items:center;justify-content:center;color:#FFF;font-family:'Outfit',sans-serif;font-weight:800;font-size:14px}
.poi-cluster-marker span{line-height:1}
.leaflet-popup-content-wrapper{border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-lg)!important;padding:0!important;overflow:hidden}
.leaflet-popup-content{margin:0!important;width:300px!important}
.leaflet-popup-tip{box-shadow:var(--shadow-md)!important}
.popup-card{font-family:'Outfit',sans-serif}
.popup-body{padding:16px 18px 18px}
.popup-cat-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#FFF;margin-bottom:8px}
.popup-title{font-size:17px;font-weight:800;line-height:1.2;margin-bottom:4px}
.popup-address{font-size:11.5px;color:var(--text-light);margin-bottom:14px}
.popup-stats{display:flex;gap:6px;margin-bottom:14px}
.popup-stat{flex:1;text-align:center;padding:8px 4px;background:#F8FAFC;border-radius:var(--radius-sm);border:1px solid var(--border)}
.popup-stat-icon{font-size:18px;display:block;margin-bottom:2px}
.popup-stat-val{font-size:14px;font-weight:800;display:block}
.popup-stat-label{font-size:8.5px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-light)}
.popup-ages{display:flex;gap:5px;margin-bottom:14px;flex-wrap:wrap}
.popup-age-tag{padding:3px 10px;border-radius:12px;font-size:10.5px;font-weight:600;background:#F1F5F9;color:var(--text-mid);border:1px solid var(--border)}
.popup-age-tag.match{background:rgba(34,197,94,0.08);border-color:rgba(34,197,94,0.3);color:#166534}
.popup-access-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.popup-access-tag{font-size:10px;font-weight:600;color:var(--text-mid);display:flex;align-items:center;gap:3px}
.popup-desc{font-size:12px;color:#64748B;line-height:1.5;margin-bottom:16px}
.popup-cta{width:100%;padding:12px;border:none;border-radius:var(--radius-md);background:linear-gradient(135deg,#6366F1,#8B5CF6);color:#FFF;font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px rgba(99,102,241,0.3);display:flex;align-items:center;justify-content:center;gap:8px}
.popup-cta:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(99,102,241,0.4)}
.radar-btn-map{position:absolute;top:16px;right:16px;z-index:1000;width:44px;height:44px;border-radius:50%;border:none;background:#FFF;box-shadow:var(--shadow-md);cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.radar-btn-map:hover{transform:scale(1.1);box-shadow:var(--shadow-lg)}
.fav-float-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;background:#FFF;border-radius:24px;border:none;box-shadow:var(--shadow-md);cursor:pointer;font-family:'Outfit',sans-serif;font-size:13px;font-weight:700;color:var(--text-dark);transition:all .2s}
.fav-float-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.fav-float-count{background:var(--cat-fun);color:#FFF;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800}
.ev-button-new{display:inline-flex;align-items:center;justify-content:center;padding:2px 7px;border-radius:999px;background:linear-gradient(135deg,#F59E0B,#EF4444);color:#FFF;font-size:9px;font-weight:800;letter-spacing:.5px;line-height:1;margin-left:6px;animation:pulse-new 2s ease-in-out infinite}
.fav-panel{position:absolute;bottom:72px;right:16px;z-index:1000;width:300px;max-height:350px;overflow-y:auto;background:#FFF;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border);transform:translateY(10px);opacity:0;pointer-events:none;transition:all .25s cubic-bezier(.34,1.56,.64,1)}
.fav-panel.open{transform:translateY(0);opacity:1;pointer-events:auto}
.fav-panel-header{padding:14px 16px;border-bottom:1px solid var(--border);font-size:13px;font-weight:700;display:flex;align-items:center;gap:6px}
#eventsPanel{right:328px}
.fav-item{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid #F1F5F9;cursor:pointer;transition:background .15s}
.fav-item:hover{background:var(--bg-hover)}
.fav-item:last-child{border-bottom:none}
.fav-item-icon{width:30px;height:30px;border-radius:4px;transform:rotate(45deg);display:flex;align-items:center;justify-content:center;font-size:13px;border:2px solid #FFF;box-shadow:0 2px 6px rgba(0,0,0,0.15);flex-shrink:0}
.fav-item-icon span{transform:rotate(-45deg)}
.fav-item-info{flex:1;min-width:0}
.fav-item-name{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fav-item-meta{font-size:10px;color:var(--text-light);margin-top:1px}
.fav-empty{padding:24px;text-align:center;font-size:12px;color:var(--text-light)}
.legend-bar{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:1000;display:flex;align-items:center;gap:4px;padding:6px 8px;background:rgba(255,255,255,0.92);backdrop-filter:blur(12px);border-radius:14px;box-shadow:var(--shadow-md);border:1px solid rgba(0,0,0,0.06)}
.legend-item{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:8px;font-size:10px;font-weight:600;color:var(--text-mid)}
.legend-dot{width:10px;height:10px;border-radius:3px;transform:rotate(45deg);flex-shrink:0}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#CBD5E1;border-radius:4px}
.mobile-toggle{display:none;position:absolute;top:16px;left:16px;z-index:1001;width:44px;height:44px;border-radius:50%;border:none;background:#FFF;box-shadow:var(--shadow-md);cursor:pointer;font-size:20px;align-items:center;justify-content:center}
.bottom-actions{display:none}
.add-poi-float-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;background:linear-gradient(135deg,#6366F1,#8B5CF6);border-radius:24px;border:none;box-shadow:var(--shadow-md);cursor:pointer;font-family:'Outfit',sans-serif;font-size:13px;font-weight:700;color:#FFF;transition:all .2s}
.add-poi-float-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(99,102,241,0.4)}
.add-poi-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,0.5);backdrop-filter:blur(4px);z-index:3000;justify-content:center;align-items:center}
.add-poi-overlay.open{display:flex}
.add-poi-modal{background:#FFF;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:520px;max-width:95vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}
.add-poi-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-size:15px;font-weight:800;font-family:'Outfit',sans-serif}
.event-detail-share-btn{margin-left:auto;margin-right:8px;border:none;border-radius:8px;padding:8px 10px;background:linear-gradient(135deg,#0EA5E9,#2563EB);color:#FFF;font-family:'Outfit',sans-serif;font-size:12px;font-weight:700;cursor:pointer}
.event-detail-share-btn:hover{opacity:.92}
.add-poi-close{width:32px;height:32px;border-radius:50%;border:none;background:var(--bg-hover);cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;color:var(--text-mid);transition:all .15s}
.add-poi-close:hover{background:#E2E8F0;color:var(--text-dark)}
.add-poi-body{padding:20px;overflow-y:auto;flex:1}
.add-poi-row{display:flex;gap:12px;margin-bottom:12px}
.add-poi-row.checkboxes{flex-wrap:wrap;gap:8px 16px;margin-bottom:14px}
.add-poi-row.wrap{flex-wrap:wrap}
.add-poi-field{flex:1;min-width:0}
.add-poi-field.full{flex:1 1 100%}
.add-poi-field label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-light);margin-bottom:4px}
.add-poi-field input,.add-poi-field select{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:'Outfit',sans-serif;font-size:13px;font-weight:500;color:var(--text-dark);background:#FFF;outline:none;transition:border-color .15s}
.add-poi-field input:focus,.add-poi-field select:focus{border-color:#6366F1}
.add-poi-check{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-mid);cursor:pointer;white-space:nowrap}
.add-poi-check input[type="checkbox"]{width:16px;height:16px;accent-color:#6366F1;cursor:pointer}
.add-poi-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-light);margin-bottom:8px}
.add-poi-submit{width:100%;padding:13px;border:none;border-radius:var(--radius-md);background:linear-gradient(135deg,#22C55E,#16A34A);color:#FFF;font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px rgba(34,197,94,0.3);margin-top:8px}
.add-poi-submit:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(34,197,94,0.4)}
.add-poi-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}
.add-poi-error{color:#EF4444;font-size:12px;font-weight:600;margin-top:4px;min-height:18px}
.add-poi-success{color:#22C55E;font-size:12px;font-weight:600;margin-top:4px}
.input-with-btn{display:flex;gap:6px}
.input-with-btn input{flex:1}
.geocode-btn{width:40px;height:38px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:#FFF;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.geocode-btn:hover{background:#F1F5F9;border-color:#6366F1}
.add-poi-hint{font-size:10px;color:var(--text-light);margin-top:3px;min-height:14px}
.add-poi-field select:disabled{background:#F1F5F9;color:var(--text-mid);cursor:default}
.leaflet-contextmenu{background:#FFF;border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,0.15);border:1px solid #E2E8F0;padding:4px 0;font-family:'Outfit',sans-serif;font-size:13px;min-width:200px}
.leaflet-contextmenu a{display:block;padding:8px 16px;color:#0F172A;text-decoration:none;font-weight:500;transition:background .1s}
.leaflet-contextmenu a:hover{background:#F1F5F9}
.ev-new-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#EF4444;color:#FFF;font-size:10px;font-weight:800;margin-left:4px;line-height:1}
.popup-cta{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:10px 16px;border:none;border-radius:8px;background:linear-gradient(135deg,#6366F1,#8B5CF6);color:#FFF;font-family:'Outfit',sans-serif;font-size:12px;font-weight:700;cursor:pointer;transition:opacity .15s;white-space:nowrap}
.popup-cta:hover{opacity:.9}
.popup-owner-icons{position:absolute;top:-4px;right:8px;display:flex;gap:3px;z-index:1}
.popup-icon-btn{width:28px;height:28px;border-radius:6px;border:1px solid rgba(0,0,0,0.08);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:all .15s;padding:0;line-height:1}
.popup-icon-btn.popup-icon-edit{background:#FFF9E6;color:#B45309}
.popup-icon-btn.popup-icon-edit:hover{background:#FEF3C7;box-shadow:0 2px 6px rgba(245,158,11,0.25)}
.popup-icon-btn.popup-icon-delete{background:#FEF2F2;color:#DC2626}
.popup-icon-btn.popup-icon-delete:hover{background:#FEE2E2;box-shadow:0 2px 6px rgba(239,68,68,0.25)}
.sidebar{transition:transform .3s ease, width .3s ease, min-width .3s ease;overflow:hidden}
.sidebar:not(.open){width:0;min-width:0;padding:0;border:none;transform:translateX(0)}
.sidebar:not(.open) .sidebar-scroll,.sidebar:not(.open) .sidebar-header,.sidebar:not(.open) .sidebar-footer{display:none}
.search-close-btn{display:none;width:32px;height:32px;border-radius:50%;border:none;background:var(--bg-hover);cursor:pointer;font-size:14px;color:var(--text-mid);align-items:center;justify-content:center;flex-shrink:0;position:absolute;right:6px;top:50%;transform:translateY(-50%);z-index:2}
@media(max-width:768px){.sidebar{position:fixed;left:0;top:56px;z-index:2000;bottom:30px;height:auto;transform:translateX(-100%)!important;transition:transform .3s;width:var(--sidebar-w)!important;min-width:var(--sidebar-w)!important}.app-layout.footer-expanded .sidebar{bottom:64px}.sidebar.open{transform:translateX(0)!important}.mobile-toggle{display:none}.legend-bar{display:none}.footer-actions{gap:6px}.footer-btn{padding:7px 8px;font-size:10px;gap:0;min-width:40px;justify-content:center}.footer-label{display:none}
#eventsPanel{right:16px}
.top-header{padding:0 8px;gap:8px}
.header-left{gap:6px}
.header-logo-text{display:none}
.header-right .auth-btn{padding:5px 10px;font-size:11px}
.header-center{flex:1;max-width:none;margin:0}
.top-header.search-focused .header-left{display:none!important}
.top-header.search-focused .header-right{display:none!important}
.top-header.search-focused .header-center{flex:1;max-width:none}
.top-header.search-focused .search-close-btn{display:flex}
.top-header.search-focused .search-input{padding-right:40px}
}

.add-poi-check-inline{margin-top:8px}
.amenity-tag{gap:8px}
.amenity-highlight-btn{border:none;background:rgba(99,102,241,0.12);color:#4338CA;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:700;cursor:pointer}
.amenity-highlight-btn.active{background:#4338CA;color:#FFF}

.add-poi-amenity-btn{border:none;padding:9px 14px;border-radius:10px;background:linear-gradient(135deg,#6366F1,#8B5CF6);color:#FFF;font-family:'Outfit',sans-serif;font-size:12px;font-weight:700;cursor:pointer;box-shadow:0 3px 10px rgba(99,102,241,0.25);transition:all .15s}
.add-poi-amenity-btn:hover{transform:translateY(-1px);box-shadow:0 6px 14px rgba(99,102,241,0.35)}

/* ═══════════════════════════════════════════════════════════
   EVENT CREATION MODAL — Redesigned
   ═══════════════════════════════════════════════════════════ */
.ev-modal-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,0.5);backdrop-filter:blur(6px);z-index:4000;justify-content:center;align-items:center}
.ev-modal-overlay.open{display:flex}
.ev-modal{background:#FFF;border-radius:20px;box-shadow:0 25px 60px rgba(0,0,0,0.15);width:480px;max-width:95vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:ev-modal-in .3s cubic-bezier(.34,1.56,.64,1)}
@keyframes ev-modal-in{from{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}

/* Header */
.ev-modal-header{background:linear-gradient(135deg,#7C3AED 0%,#6366F1 40%,#818CF8 100%);padding:22px 24px 18px;position:relative;display:flex;align-items:flex-start;justify-content:space-between}
.ev-modal-header-content{display:flex;align-items:center;gap:14px}
.ev-modal-header-icon{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,0.18);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.ev-modal-title{font-size:17px;font-weight:800;color:#FFF;margin:0;line-height:1.2;letter-spacing:-0.2px}
.ev-modal-subtitle{font-size:11.5px;font-weight:500;color:rgba(255,255,255,0.7);margin:3px 0 0;line-height:1.3}
.ev-modal-close{width:30px;height:30px;border-radius:50%;border:none;background:rgba(255,255,255,0.15);backdrop-filter:blur(8px);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.85);transition:all .15s;flex-shrink:0;margin-top:2px}
.ev-modal-close:hover{background:rgba(255,255,255,0.3);color:#FFF}

/* Body */
.ev-modal-body{padding:20px 24px 24px;overflow-y:auto;flex:1}

/* Section rows */
.ev-section{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid #F1F5F9}
.ev-section:first-child{padding-top:4px}
.ev-section:last-of-type{border-bottom:none}
.ev-section-icon{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#EEF2FF,#E0E7FF);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#6366F1;margin-top:2px}
.ev-section-content{flex:1;min-width:0}

/* Labels */
.ev-label{display:block;font-size:13px;font-weight:700;color:var(--text-dark);margin-bottom:6px}
.ev-label-opt{font-weight:500;color:var(--text-light);font-size:11px}

/* Inputs */
.ev-input{width:100%;padding:10px 14px;border:1.5px solid #E2E8F0;border-radius:10px;font-family:'Outfit',sans-serif;font-size:13.5px;font-weight:500;color:var(--text-dark);background:#FAFBFC;outline:none;transition:all .2s}
.ev-input:focus{border-color:#6366F1;background:#FFF;box-shadow:0 0 0 3px rgba(99,102,241,0.08)}
.ev-input::placeholder{color:#94A3B8;font-weight:400}
.ev-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer}
.ev-textarea{width:100%;padding:10px 14px;border:1.5px solid #E2E8F0;border-radius:10px;font-family:'Outfit',sans-serif;font-size:13.5px;font-weight:500;color:var(--text-dark);background:#FAFBFC;outline:none;transition:all .2s;resize:vertical;min-height:70px}
.ev-textarea:focus{border-color:#6366F1;background:#FFF;box-shadow:0 0 0 3px rgba(99,102,241,0.08)}
.ev-textarea::placeholder{color:#94A3B8;font-weight:400}

/* Friends search */
.ev-friends-search-wrap{position:relative}
.ev-friends-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#94A3B8;pointer-events:none;z-index:1}
.ev-friends-search{padding-left:34px !important}

/* Invitee chips */
.ev-invitees-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.ev-invitees-chips .ev-invitee-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px 5px 5px;background:linear-gradient(135deg,rgba(99,102,241,0.06),rgba(139,92,246,0.06));border:1px solid rgba(99,102,241,0.15);border-radius:20px;font-size:12px;font-weight:600;color:#4338CA;transition:all .15s}
.ev-invitees-chips .ev-invitee-chip:hover{background:rgba(99,102,241,0.1);border-color:rgba(99,102,241,0.3)}
.ev-invitee-avatar{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#6366F1,#8B5CF6);color:#FFF;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;flex-shrink:0}
.ev-invitee-chip .remove{cursor:pointer;font-size:14px;line-height:1;margin-left:2px;opacity:.5;transition:opacity .15s}
.ev-invitee-chip .remove:hover{opacity:1}

/* Visibility toggle */
.ev-visibility-toggle{display:flex;gap:8px}
.ev-vis-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border-radius:12px;border:1.5px solid #E2E8F0;background:#FAFBFC;cursor:pointer;font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;color:var(--text-mid);transition:all .2s}
.ev-vis-btn:hover{border-color:#CBD5E1;background:#F1F5F9}
.ev-vis-btn.active{border-color:#6366F1;background:rgba(99,102,241,0.06);color:#4338CA}
.ev-vis-btn.active svg{stroke:#4338CA}
.ev-vis-hint{font-size:11px;font-weight:500;color:var(--text-light);margin-top:8px;padding:0;line-height:1.4;font-style:italic}

/* Friends section slide-in */
.ev-friends-section{animation:ev-friends-in .25s ease-out}
@keyframes ev-friends-in{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* Error */
.ev-error-msg{color:#EF4444;font-size:12px;font-weight:600;min-height:18px;margin-top:4px;text-align:center}
.ev-error-msg.add-poi-success{color:#22C55E}

/* Submit button */
.ev-submit-btn{width:100%;padding:14px;border:none;border-radius:12px;background:linear-gradient(135deg,#7C3AED,#6366F1);color:#FFF;font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .25s;box-shadow:0 4px 15px rgba(99,102,241,0.25);margin-top:12px;display:flex;align-items:center;justify-content:center;gap:8px;letter-spacing:0.2px}
.ev-submit-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(99,102,241,0.4);background:linear-gradient(135deg,#6D28D9,#4F46E5)}
.ev-submit-btn:active{transform:translateY(0);box-shadow:0 2px 8px rgba(99,102,241,0.3)}
.ev-submit-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* Mobile adjustments */
@media(max-width:768px){
  .ev-modal{width:100%;max-width:100%;max-height:100vh;border-radius:0;height:100vh}
  .ev-modal-header{padding:20px 16px 16px}
  .ev-modal-body{padding:16px}
  .ev-section{gap:10px;padding:12px 0}
  .ev-section-icon{width:32px;height:32px;border-radius:8px}
}
