*{margin:0;padding:0;box-sizing:border-box}body{margin:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa}#root{height:100vh;width:100vw}html,body{height:100%}@media (max-width: 768px){html,body{height:auto;min-height:100%;overflow-y:auto}#root{height:auto;min-height:100vh}}button{cursor:pointer}input,textarea,select{font-family:inherit}.event-list{height:100%;overflow-y:auto;padding:20px;background:#f8f9fa}.event-list h2{color:#2c3e50;margin-bottom:20px;font-size:24px;text-align:center}.date-header{color:#34495e;font-size:18px;font-weight:700;margin-bottom:15px;padding-bottom:5px;border-bottom:2px solid #3498db}.event-item{background:#fff;border-radius:10px;padding:15px;margin-bottom:10px;border-left:4px solid #3498db;box-shadow:0 2px 4px #0000001a;cursor:pointer;transition:all .3s ease}.event-item:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.event-item.selected{border-left-color:#e74c3c;box-shadow:0 4px 12px #e74c3c33}.event-time{color:#7f8c8d;font-weight:700;margin-bottom:6px}.event-location-category{display:flex;align-items:center;gap:12px;margin-bottom:8px}.event-location{color:#e74c3c;font-weight:500}.event-category{display:flex;align-items:center;gap:6px;background:#f8f9fa;padding:4px 10px;border-radius:20px;border:1px solid #e0e0e0}.category-icon{width:24px;height:24px;object-fit:contain}.category-name{font-size:13px;font-weight:500;color:#2c3e50}.venue-list{height:100%;display:flex;flex-direction:column;background:#fff}.venue-list-header{padding:24px;border-bottom:1px solid #e0e0e0;background:#fafafa}.venue-list-header h2{margin:0 0 8px;font-size:20px;font-weight:300;color:#333}.venue-count{margin:0;font-size:14px;color:#666}.venue-list-content{flex:1;overflow-y:auto;padding:16px}.venue-list-empty{display:flex;justify-content:center;align-items:center;height:200px;color:#666;font-style:italic}.venue-item{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px;margin-bottom:16px;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #0000000d}.venue-item:hover{border-color:#ccc;box-shadow:0 2px 8px #0000001a}.venue-item.selected{border-color:#333;box-shadow:0 2px 8px #00000026;background:#fafafa}.venue-main{margin-bottom:16px}.venue-name{margin:0 0 8px;font-size:18px;font-weight:500;color:#333}.venue-address{margin:0 0 8px;font-size:14px;color:#666;line-height:1.4}.venue-description{margin:0;font-size:13px;color:#888;font-style:italic}.venue-events{margin-top:16px;padding-top:12px;border-top:1px solid #f0f0f0}.venue-events-title{margin:0 0 12px;font-size:14px;font-weight:500;color:#2c3e50}.venue-events-list{display:flex;flex-direction:column;gap:8px}.venue-event-item{background:#f8f9fa;padding:10px 12px;border-radius:6px;border-left:3px solid #3498db}.venue-event-title{font-size:13px;font-weight:500;color:#2c3e50;margin-bottom:4px;line-height:1.4}.venue-event-info{font-size:12px;color:#7f8c8d;margin-bottom:4px}.venue-event-badge{display:inline-block;font-size:11px;padding:2px 8px;border-radius:3px;margin-top:4px}.venue-event-badge.ticket{background:#d4edda;color:#155724}.venue-event-badge.finished{background:#e2e3e5;color:#383d41}.venue-no-events{margin:12px 0 0;font-size:13px;color:#95a5a6;font-style:italic}.venue-actions{display:flex;justify-content:flex-end}.map-button{background:#333;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:12px;font-weight:400;transition:background .2s ease}.map-button:hover{background:#555}@media (max-width: 768px){.venue-list-header{padding:16px}.venue-list-header h2{font-size:18px}.venue-list-content{padding:12px}.venue-item{padding:16px;margin-bottom:12px}.venue-name{font-size:16px}}.category-list{height:100%;overflow-y:auto;padding:20px;background:#f8f9fa}.category-list h2{color:#2c3e50;margin-bottom:20px;font-size:24px;text-align:center}.category-group{margin-bottom:35px;background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a}.category-header{display:flex;align-items:center;gap:12px;padding-bottom:15px;border-bottom:3px solid #3498db;margin-bottom:20px}.category-header-icon{width:40px;height:40px;object-fit:contain}.category-title{color:#2c3e50;font-size:20px;font-weight:700;margin:0}.category-count{color:#7f8c8d;font-size:16px;font-weight:400}.category-events{display:flex;flex-direction:column;gap:12px}.category-event-item{background:#f8f9fa;border-radius:8px;padding:15px;border-left:4px solid #3498db;cursor:pointer;transition:all .3s ease}.category-event-item:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px);background:#fff}.category-event-item.selected{border-left-color:#e74c3c;box-shadow:0 4px 12px #e74c3c33;background:#fff}.event-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.event-title{font-weight:700;color:#2c3e50;font-size:16px;flex:1}.event-header-actions{display:flex;align-items:center;gap:8px}.share-link-button{background:#3498db;border:1px solid #3498db;border-radius:6px;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;transition:all .2s ease;padding:6px 12px;white-space:nowrap;font-weight:500}.share-link-button:hover{background:#2980b9;border-color:#2980b9;transform:translateY(-1px);box-shadow:0 2px 4px #0003}.event-info{display:flex;gap:15px;margin-bottom:8px;flex-wrap:wrap}.event-date-time{color:#7f8c8d;font-weight:700;font-size:14px}.event-location{color:#e74c3c;font-weight:500;font-size:14px}.event-description{color:#34495e;line-height:1.4;font-size:14px}.event-tabs{height:100%;display:flex;flex-direction:column;background:#fff}.tab-header{display:flex;border-bottom:1px solid #e0e0e0;background:#fafafa}.tab-button{flex:1;padding:16px 24px;border:none;background:transparent;cursor:pointer;font-size:14px;font-weight:400;color:#666;border-bottom:3px solid transparent;transition:all .2s ease}.tab-button:hover{background:#f5f5f5;color:#333}.tab-button.active{color:#333;border-bottom-color:#333;background:#fff;font-weight:500}.tab-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.tab-content>*{flex:1;height:100%}@media (max-width: 768px){.tab-button{padding:12px 16px;font-size:13px}}.google-map{height:100%;display:flex;flex-direction:column;position:relative}.map-container{flex:1;width:100%;height:100%;position:relative}.open-in-google-maps-btn{position:absolute;top:16px;left:16px;background:#4285f4;color:#fff;border:none;padding:10px 16px;border-radius:25px;font-weight:700;font-size:14px;cursor:pointer;box-shadow:0 2px 8px #00000040;z-index:1000;transition:all .3s ease;display:none;align-items:center;gap:6px}.open-in-google-maps-btn:hover{background:#3367d6;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.open-in-google-maps-btn:active{transform:translateY(0);box-shadow:0 2px 6px #0003}.api-key-warning{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#e74c3ce6;color:#fff;padding:20px;border-radius:8px;text-align:center;font-weight:700;z-index:1000}@media (max-width: 768px){.open-in-google-maps-btn{display:flex;top:12px;left:12px;padding:8px 14px;font-size:13px}}.event-form-container{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.event-form{background:#fff;border-radius:15px;box-shadow:0 10px 30px #0000004d;max-width:600px;width:90%;max-height:90vh;overflow-y:auto}.event-form form{padding:30px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:14px;transition:border-color .3s ease,box-shadow .3s ease;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.form-group input.error,.form-group textarea.error,.form-group select.error{border-color:#e74c3c;box-shadow:0 0 0 2px #e74c3c33}.form-row{display:flex;gap:20px}.form-row .form-group{flex:1}@media (max-width: 768px){.event-form{width:95%;margin:20px}.form-header,.event-form form{padding:20px}.form-row{flex-direction:column;gap:0}.form-actions{flex-direction:column}.form-actions button{width:100%}}.event-manager{height:100%;display:flex;flex-direction:column}.events-list{flex:1;overflow-y:auto}.date-group{margin-bottom:30px}.date-header{color:#34495e;font-size:16px;font-weight:700;margin-bottom:15px;padding:10px 0;border-bottom:2px solid #3498db}.event-card{background:#fff;border-radius:10px;padding:20px;margin-bottom:15px;box-shadow:0 2px 4px #0000001a;border-left:4px solid #3498db;transition:box-shadow .3s ease}.event-card:hover{box-shadow:0 4px 8px #00000026}.event-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.event-title{margin:0;color:#2c3e50;font-size:18px}.event-actions{display:flex;gap:10px;align-items:center}.status-select,.category-select{padding:6px 10px;border:1px solid #ddd;border-radius:5px;background:#fff;cursor:pointer;font-size:13px}.category-select{min-width:140px}.edit-button,.delete-button{background:none;border:none;cursor:pointer;padding:8px;border-radius:5px;transition:background .3s ease;font-size:16px}.edit-button:disabled,.delete-button:disabled{opacity:.5;cursor:not-allowed}.event-info{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:15px;font-size:14px}.event-time,.event-location{color:#7f8c8d;font-weight:500}.event-description{color:#34495e;line-height:1.5;font-size:14px}.status-badge{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:700}.status-ticket-supported{background-color:#3498db;color:#fff}.status-ticket-not-supported{background-color:#e74c3c;color:#fff}.status-finished{background-color:#000;color:#fff}.empty-state{text-align:center;padding:40px;color:#7f8c8d;background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a}.location-form-container{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.location-form{background:#fff;border-radius:15px;box-shadow:0 10px 30px #0000004d;max-width:600px;width:90%;max-height:90vh;overflow-y:auto}.form-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:1px solid #eee;background:#f8f9fa;border-radius:15px 15px 0 0}.form-header h3{margin:0;color:#2c3e50;font-size:20px}.close-button{background:none;border:none;font-size:20px;cursor:pointer;color:#7f8c8d;padding:5px;border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;transition:background .3s ease}.close-button:hover{background:#ecf0f1}.location-form form{padding:30px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:700;color:#2c3e50}.form-group input,.form-group textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:14px;transition:border-color .3s ease,box-shadow .3s ease;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.form-group input.error,.form-group textarea.error{border-color:#e74c3c;box-shadow:0 0 0 2px #e74c3c33}.form-group textarea{resize:vertical;font-family:inherit}.coordinates-section{border:2px solid #f1f2f6;border-radius:12px;padding:20px;margin:25px 0;background:#fafbfc}.coordinates-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.coordinates-header h4{margin:0;color:#2c3e50;font-size:16px}.coords-helper-button{background:#3498db;color:#fff;border:none;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:700;transition:background .3s ease}.coords-helper-button:hover:not(:disabled){background:#2980b9}.coords-helper-button:disabled{background:#bdc3c7;cursor:not-allowed}.coordinates-inputs{display:flex;gap:15px;margin-bottom:15px}.coordinates-inputs .form-group{flex:1;margin-bottom:0}.coordinates-info{background:#e8f5fe;color:#0277bd;padding:10px;border-radius:6px;font-size:13px;border-left:4px solid #03a9f4}.error-message{color:#e74c3c;font-size:12px;margin-top:5px;display:block}.form-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:30px;padding-top:20px;border-top:1px solid #eee}.cancel-button,.submit-button{padding:12px 24px;border:none;border-radius:8px;font-weight:700;cursor:pointer;transition:all .3s ease;font-size:14px}.cancel-button{background:#ecf0f1;color:#2c3e50}.cancel-button:hover:not(:disabled){background:#d5dbdb}.submit-button{background:#3498db;color:#fff}.submit-button:hover:not(:disabled){background:#2980b9;transform:translateY(-1px)}.cancel-button:disabled,.submit-button:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 768px){.location-form{width:95%;margin:20px}.form-header,.location-form form{padding:20px}.coordinates-inputs{flex-direction:column;gap:0}.coordinates-header{flex-direction:column;align-items:flex-start;gap:10px}.coords-helper-button{width:100%}.form-actions{flex-direction:column}.form-actions button{width:100%}}.location-manager{height:100%;display:flex;flex-direction:column}.manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:20px;background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a}.manager-header h3{margin:0;color:#2c3e50;font-size:20px}.create-button{background:#27ae60;color:#fff;border:none;padding:12px 20px;border-radius:8px;cursor:pointer;font-weight:700;transition:background .3s ease}.create-button:hover:not(:disabled){background:#229954}.create-button:disabled{background:#bdc3c7;cursor:not-allowed}.locations-grid{flex:1;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;padding-bottom:20px}.location-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;border-left:4px solid #e74c3c;transition:box-shadow .3s ease,transform .2s ease;height:fit-content}.location-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.location-card-header{display:flex;justify-content:space-between;align-items:center;padding:20px 20px 15px;border-bottom:1px solid #f1f2f6}.location-name{margin:0;color:#2c3e50;font-size:18px;font-weight:700}.location-actions{display:flex;gap:8px}.edit-button,.delete-button{background:none;border:none;cursor:pointer;padding:8px;border-radius:6px;transition:background .3s ease;font-size:16px}.edit-button:hover:not(:disabled){background:#ecf0f1}.delete-button:hover:not(:disabled){background:#fadbd8}.delete-button:disabled{opacity:.4;cursor:not-allowed}.edit-button:disabled{opacity:.5;cursor:not-allowed}.location-info{padding:15px 20px 20px}.location-address{color:#7f8c8d;font-size:14px;margin-bottom:12px;font-weight:500}.location-coordinates{color:#95a5a6;font-size:13px;margin-bottom:12px;font-family:monospace}.location-description{color:#34495e;font-size:14px;line-height:1.5;margin-bottom:15px;padding:10px;background:#f8f9fa;border-radius:6px}.location-events{border-top:1px solid #f1f2f6;padding-top:15px}.event-count{color:#3498db;font-weight:700;font-size:14px;margin-bottom:10px}.related-events{display:flex;flex-direction:column;gap:6px}.related-event{background:#e8f4fd;color:#2c3e50;padding:8px 12px;border-radius:6px;font-size:13px;border-left:3px solid #3498db}.more-events{color:#7f8c8d;font-size:12px;font-style:italic;padding:4px 0}.empty-state{grid-column:1 / -1;text-align:center;padding:40px;color:#7f8c8d;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}@media (max-width: 768px){.locations-grid{grid-template-columns:1fr}.manager-header{flex-direction:column;gap:15px;text-align:center}.create-button{width:100%}}.data-management{padding:20px;background:#f8f9fa;border-radius:8px;margin:20px 0}.data-management-header{margin-bottom:30px;text-align:center}.data-management-header h3{color:#2c3e50;margin-bottom:10px;font-size:1.5em}.data-management-header p{color:#6c757d;margin:0}.message{padding:12px;border-radius:6px;margin-bottom:20px;font-weight:500}.message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.message.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.data-management-section{margin-bottom:30px}.data-management-section h4{color:#495057;margin-bottom:15px;font-size:1.2em;border-bottom:2px solid #e9ecef;padding-bottom:8px}.export-buttons{display:flex;gap:15px;flex-wrap:wrap}.export-button{padding:12px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:180px}.export-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.export-button:disabled{opacity:.6;cursor:not-allowed}.export-button.events{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.export-button.locations{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.export-button.all{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.import-section{display:flex;flex-direction:column;gap:15px}.import-item{background:#fff;padding:15px;border-radius:6px;border:2px solid #e9ecef;transition:border-color .2s ease}.import-item:hover{border-color:#ced4da}.import-label{display:block;font-weight:500;color:#495057;cursor:pointer}.import-label input[type=file]{display:block;margin-top:8px;padding:8px;width:100%;border:1px solid #ced4da;border-radius:4px;background:#f8f9fa;font-size:14px}.import-label input[type=file]:disabled{opacity:.6;cursor:not-allowed}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000;color:#fff}.loading-spinner{width:50px;height:50px;border:5px solid rgba(255,255,255,.3);border-top:5px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:15px}.loading-overlay p{font-size:18px;font-weight:500}@media (max-width: 768px){.export-buttons{flex-direction:column}.export-button{width:100%;min-width:unset}.data-management{margin:10px 0;padding:15px}.data-management-header h3{font-size:1.3em}.data-management-section h4{font-size:1.1em}.loading-overlay{position:fixed;z-index:9999}}.admin-panel{height:100%;display:flex;flex-direction:column;background:#f8f9fa;min-height:0}.admin-header{display:flex;justify-content:space-between;align-items:center;padding:20px;background:#fff;border-bottom:2px solid #e74c3c}.admin-header h2{margin:0;color:#2c3e50;font-size:24px}.refresh-button{background:#3498db;color:#fff;border:none;padding:10px 16px;border-radius:8px;cursor:pointer;font-weight:700;transition:background .3s ease}.refresh-button:hover:not(:disabled){background:#2980b9}.refresh-button:disabled{background:#bdc3c7;cursor:not-allowed}.admin-tabs{display:flex;background:#fff;border-bottom:1px solid #ddd}.tab-button{flex:1;padding:15px 20px;background:none;border:none;cursor:pointer;font-weight:700;color:#7f8c8d;border-bottom:3px solid transparent;transition:all .3s ease}.tab-button:hover{background:#f8f9fa}.tab-button.active{color:#e74c3c;border-bottom-color:#e74c3c;background:#f8f9fa}.admin-content{flex:1;overflow-y:auto;padding:20px;min-height:0}@media (max-width: 768px){.admin-panel{height:auto;min-height:100%;flex-shrink:0;width:100%;display:flex;flex-direction:column}.admin-content{flex:1;overflow-y:visible;min-height:auto;padding:10px;width:100%;box-sizing:border-box}.admin-header{padding:15px;flex-shrink:0}.admin-header h2{font-size:20px}.refresh-button{padding:8px 12px;font-size:12px}.tab-button{padding:12px 15px;font-size:14px}.admin-tabs{flex-shrink:0}}.resizable-splitter-container{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}.resizable-top-panel{overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;-webkit-overflow-scrolling:touch}.resizable-bottom-panel{overflow:hidden;display:flex;flex-direction:column;flex:1}.resizable-splitter{height:8px;background:#e0e0e0;cursor:row-resize;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background-color .2s ease;position:relative;z-index:10}.resizable-splitter:hover{background:#ccc}.resizable-splitter.dragging{background:#999}.splitter-handle{display:flex;align-items:center;justify-content:center;width:100%;height:100%;position:relative}.splitter-line{height:1px;background:#999;flex:1}.splitter-grip{font-size:12px;color:#666;padding:0 8px;-webkit-user-select:none;user-select:none;transform:rotate(90deg);line-height:1}.resizable-splitter:hover .splitter-grip{color:#333}.resizable-splitter.dragging .splitter-grip{color:#000}@media (max-width: 768px){.resizable-splitter-container{position:fixed;inset:60px 0 0}.resizable-top-panel{position:fixed;top:60px;left:0;right:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.resizable-splitter{position:fixed;left:0;right:0;height:12px;background:#ddd;z-index:1000}.resizable-bottom-panel{position:fixed;left:0;right:0;bottom:0;overflow:hidden}.splitter-grip{font-size:14px;padding:0 12px}.resizable-splitter:hover{background:#bbb}.resizable-splitter.dragging{background:#888}}.resizable-top-panel>*,.resizable-bottom-panel>*{height:100%;width:100%}.event-detail-container{padding:20px;max-width:800px;margin:0 auto}.event-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:12px}.back-button,.share-button{padding:10px 20px;border:1px solid #ddd;border-radius:6px;background:#fff;cursor:pointer;font-size:14px;transition:all .2s}.back-button:hover,.share-button:hover{background:#f5f5f5;border-color:#999}.event-detail{background:#fff;border-radius:8px;padding:24px;box-shadow:0 2px 8px #0000001a}.event-detail .event-header{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #f0f0f0}.event-detail .event-header h1{margin:0;font-size:28px;color:#333}.event-info{display:flex;flex-direction:column;gap:20px}.info-item{display:flex;flex-direction:column;gap:8px}.info-item strong{color:#666;font-size:14px}.info-item p{margin:0;color:#333;font-size:16px;line-height:1.6}.event-not-found{text-align:center;padding:60px 20px}.event-not-found h2{color:#666;margin-bottom:24px}@media (max-width: 768px){.event-detail-container{padding:12px}.event-detail{padding:16px}.event-detail .event-header h1{font-size:22px}.event-detail-header{flex-direction:column;align-items:stretch}.back-button,.share-button{width:100%}}.app{height:100vh;display:flex;flex-direction:column;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;background-color:#fafafa;color:#333}.app-header{background:#fff;color:#333;padding:24px 32px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 3px #0000001a;border-bottom:1px solid #e0e0e0}.header-title{display:flex;align-items:center;gap:20px}.app-header h1{margin:0;font-size:24px;font-weight:300;letter-spacing:.5px;white-space:nowrap}.zen-link{color:#27ae60!important;text-decoration:none!important;font-size:18px!important;font-weight:400!important;padding:4px 12px!important;border:1px solid #27ae60!important;border-radius:15px!important;display:inline!important;margin-left:15px!important;vertical-align:middle!important}.zen-link:hover{background-color:#229954!important;color:#fff!important;transform:translateY(-1px);box-shadow:0 2px 4px #27ae604d}.header-controls{display:flex;gap:15px}.portal-button{padding:10px 16px;border:none;border-radius:25px;font-weight:700;cursor:pointer;transition:all .3s ease;font-size:14px;background:#27ae60;color:#fff}.portal-button:hover{background:#229954;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.mode-toggle{padding:8px;border-radius:4px;font-weight:400;cursor:pointer;transition:all .2s ease;font-size:18px;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.mode-toggle.participant{background:#f5f5f5;color:#333;border:1px solid #ddd}.mode-toggle.admin{background:#333;color:#fff;border:1px solid #333}.mode-toggle:hover{opacity:.8}.app-main{flex:1;display:flex;overflow:hidden}.app-main-mobile{display:none}.event-section{flex:1;display:flex;flex-direction:column;border-right:1px solid #e0e0e0;background:#fff}.map-section{flex:1;display:flex;flex-direction:column;background:#fff}.admin-section{flex:1;display:flex;justify-content:center;align-items:flex-start;background:#fafafa;overflow-y:auto;-webkit-overflow-scrolling:touch}.event-detail-page{flex:1;display:flex;overflow:hidden}.event-detail-page>div:first-child{flex:1;overflow-y:auto}.event-detail-page .map-section{flex:1}.admin-placeholder{text-align:center;padding:48px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000014;max-width:500px;border:1px solid #e0e0e0}.admin-placeholder h2{color:#333;margin-bottom:24px;font-weight:300}.admin-placeholder ul{text-align:left;color:#666;line-height:1.6}.loading-container{height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;background:#fafafa}.loading-spinner{width:40px;height:40px;border:3px solid #f0f0f0;border-top:3px solid #333;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:24px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-container{height:100vh;display:flex;justify-content:center;align-items:center;background:#fafafa}.error-message{text-align:center;padding:48px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000014;max-width:500px;border:1px solid #e0e0e0}.error-message h2{color:#d32f2f;margin-bottom:16px;font-weight:300}.retry-button{background:#333;color:#fff;border:none;padding:12px 24px;border-radius:4px;cursor:pointer;font-weight:400;margin-top:24px;transition:background .2s ease}.retry-button:hover{background:#555}@media (max-width: 768px){.app{min-height:100vh;height:auto}.app-header{flex-shrink:0;flex-direction:row;gap:10px;padding:16px 20px}.header-title{gap:12px}.app-header h1{font-size:18px;margin:0}.zen-link{font-size:12px;padding:4px 8px}.header-controls{gap:8px}.portal-button,.mode-toggle{padding:6px;font-size:16px;width:36px;height:36px}.app-main{flex:1;flex-direction:column;min-height:0;overflow-y:auto}.event-section,.map-section{display:none}.app-main-mobile{display:flex;flex:1;flex-direction:column;min-height:0;overflow-y:auto}.admin-section{flex:1;justify-content:flex-start;align-items:stretch;background:#fafafa;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0}}
