.events-page{min-height:100vh;background:#f8fafc;padding:2rem 0}.events-container{max-width:1200px;margin:0 auto;padding:0 1rem}.events-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e2e8f0}.header-content h1{font-size:2.5rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.header-content p{font-size:1.125rem;color:#6b7280}.view-toggle{display:flex;background:white;border-radius:8px;padding:4px;box-shadow:0 1px 3px rgba(0,0,0,.1)}.view-btn{padding:.5rem 1rem;border:none;background:transparent;border-radius:4px;font-weight:500;cursor:pointer;transition:all .2s ease;color:#6b7280}.view-btn.active{background:#3b82f6;color:white;box-shadow:0 1px 2px rgba(0,0,0,.1)}.view-btn:hover:not(.active){background:#f3f4f6;color:#374151}.events-filters{background:white;border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 1px 3px rgba(0,0,0,.1)}.search-bar{display:flex;margin-bottom:1rem;max-width:400px}.search-input{flex:1 1;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:8px 0 0 8px;font-size:1rem;outline:none;transition:border-color .2s ease}.search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.search-btn{padding:.75rem 1rem;background:#3b82f6;color:white;border:none;border-radius:0 8px 8px 0;cursor:pointer;font-size:1rem;transition:background-color .2s ease}.search-btn:hover{background:#2563eb}.filter-row{display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-end;margin-bottom:1rem}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.875rem;font-weight:500;color:#374151}.filter-select{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;background:white;min-width:120px;cursor:pointer}.filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#374151;cursor:pointer}.checkbox-label input[type=checkbox]{width:1rem;height:1rem;accent-color:#3b82f6}.events-count{font-size:.875rem;color:#6b7280;font-weight:500}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:#6b7280}.loading-spinner{width:3rem;height:3rem;border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.empty-state{display:flex;justify-content:center;align-items:center;padding:4rem 2rem}.empty-content{text-align:center;max-width:400px}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-content h3{font-size:1.5rem;font-weight:600;color:#374151;margin-bottom:.5rem}.empty-content p{color:#6b7280}.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));grid-gap:2rem;gap:2rem;margin-bottom:3rem}.event-card{background:white;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px rgba(0,0,0,.05);transition:all .3s ease;border:1px solid #e5e7eb}.event-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px rgba(0,0,0,.1)}.event-image{position:relative;width:100%;height:200px;overflow:hidden}.card-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.event-card:hover .card-image{transform:scale(1.05)}.event-badges{position:absolute;top:1rem;right:1rem;display:flex;flex-direction:column;gap:.5rem}.badge{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge.featured{background:#fbbf24;color:#92400e}.badge.type.online{background:#10b981;color:white}.badge.type.offline{background:#6366f1;color:white}.badge.type.hybrid{background:#8b5cf6;color:white}.badge.price{background:#1f2937;color:white;font-size:.625rem;padding:.2rem .5rem;font-weight:700}.event-content{padding:1.5rem}.event-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.event-category{font-size:.75rem;font-weight:600;color:#3b82f6;text-transform:uppercase;letter-spacing:.5px}.event-date{font-size:.875rem;color:#6b7280;font-weight:500}.event-title{margin-bottom:1rem}.event-title a{font-size:1.25rem;font-weight:600;color:#1f2937;text-decoration:none;line-height:1.3;transition:color .2s ease}.event-title a:hover{color:#3b82f6}.event-description{color:#6b7280;line-height:1.6;font-size:.9rem}.event-description,.event-details{margin-bottom:1.5rem}.detail-item{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.875rem;color:#4b5563}.detail-item .icon{font-size:1rem}.event-speakers{margin-bottom:1.5rem;padding:1rem;background:#f8fafc;border-radius:8px;border-left:4px solid #3b82f6}.speakers-label{font-size:.75rem;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem;display:block}.speakers-list{display:flex;flex-direction:column;gap:.25rem}.speaker-name{font-size:.875rem;color:#1f2937;font-weight:500}.more-speakers{font-size:.75rem;color:#6b7280;font-style:italic}.event-actions{display:flex;gap:.75rem}.btn{padding:.75rem 1.5rem;border-radius:8px;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;border:none}.btn-primary{background:#3b82f6;color:white;flex:1 1}.btn-primary:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 8px rgba(59,130,246,.3)}.btn-secondary{background:white;color:#374151;border:2px solid #d1d5db;flex:1 1}.btn-secondary:hover{border-color:#9ca3af;background:#f9fafb}.pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:3rem}.page-btn{padding:.75rem 1rem;border:1px solid #d1d5db;background:white;color:#374151;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:44px}.page-btn:hover:not(:disabled){border-color:#3b82f6;color:#3b82f6}.page-btn.active{background:#3b82f6;color:white;border-color:#3b82f6}.page-btn:disabled{opacity:.5;cursor:not-allowed}.page-numbers{display:flex;gap:.25rem}.calendar-view{background:white;border-radius:16px;padding:2rem;box-shadow:0 4px 6px rgba(0,0,0,.05);border:1px solid #e5e7eb}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #f3f4f6}.calendar-header h2{font-size:1.875rem;font-weight:600;color:#1f2937;margin:0}.calendar-nav-btn{background:#3b82f6;color:white;border:none;width:40px;height:40px;border-radius:50%;font-size:1.25rem;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.calendar-nav-btn:hover{background:#2563eb;transform:translateY(-1px)}.calendar-grid{width:100%}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:1px;gap:1px;margin-bottom:1rem}.weekday{background:#f8fafc;padding:1rem;text-align:center;font-weight:600;color:#6b7280;text-transform:uppercase;font-size:.75rem;letter-spacing:.5px}.weekday-short{display:none}.weekday-full{display:inline}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:1px;gap:1px;background:#e5e7eb;border-radius:8px;overflow:hidden}.calendar-day{background:white;min-height:120px;padding:.75rem;position:relative;cursor:pointer;transition:all .2s ease;border:2px solid transparent}.calendar-day:hover{background:#f8fafc;border-color:#3b82f6}.calendar-day.has-event{background:#eff6ff}.calendar-day.has-event:hover{background:#dbeafe}.day-number{font-weight:600;color:#374151;font-size:1rem}.day-events{margin-top:.5rem}.event-dot{width:8px;height:8px;background:#3b82f6;border-radius:50%;margin-bottom:.25rem}.event-preview{font-size:.75rem;color:#1f2937;font-weight:500;line-height:1.2;margin-top:.25rem;background:rgba(59,130,246,.1);padding:.25rem;border-radius:4px;border-left:3px solid #3b82f6;display:flex;align-items:center;gap:.25rem;margin-bottom:.25rem}.event-title{font-size:.65rem;line-height:1.1}.more-events{font-size:.6rem;color:#6b7280;font-style:italic;text-align:center;margin-top:.25rem}.calendar-day.other-month{opacity:.3}.calendar-day.today{background:#eff6ff;border-color:#3b82f6}.calendar-day.today .day-number{color:#3b82f6;font-weight:700}.calendar-footer{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb;text-align:center}.calendar-footer p{color:#6b7280;margin-bottom:1rem;font-size:.875rem}.btn-outline{background:transparent;border:2px solid #3b82f6;color:#3b82f6}.btn-outline:hover{background:#3b82f6;color:white}@media (max-width:768px){.events-page{padding:1rem 0}.events-container{padding:0 .5rem}.events-header{flex-direction:column;align-items:flex-start;gap:1rem}.header-content h1{font-size:2rem}.events-grid{grid-template-columns:1fr;gap:1.5rem}.filter-row{flex-direction:column;gap:.75rem}.filter-group,.filter-select{width:100%}.search-bar{max-width:none}.event-actions{flex-direction:column}.pagination{flex-wrap:wrap;gap:.25rem}.page-btn{padding:.5rem .75rem;font-size:.875rem}.calendar-view{padding:1rem;border-radius:12px}.calendar-header{flex-direction:column;gap:1rem;text-align:center;margin-bottom:1.5rem}.calendar-header h2{font-size:1.5rem;order:2}.calendar-nav-controls{display:flex;justify-content:center;align-items:center;gap:2rem;order:1;width:100%}.calendar-nav-btn{width:35px;height:35px;font-size:1rem}.calendar-weekdays{gap:0}.weekday{padding:.5rem .25rem;font-size:.6rem;letter-spacing:.25px}.calendar-days{gap:0}.calendar-day{min-height:80px;padding:.5rem .25rem;font-size:.75rem}.day-number{font-size:.875rem;margin-bottom:.25rem}.event-preview{font-size:.6rem;padding:.125rem .25rem;margin-bottom:.125rem;border-left-width:2px}.event-dot{width:6px;height:6px}.event-title{font-size:.55rem;line-height:1.1}.more-events{font-size:.55rem;margin-top:.125rem}.calendar-footer{margin-top:1.5rem;padding-top:1rem}.calendar-footer p{font-size:.8rem}}@media (max-width:480px){.event-content,.events-filters{padding:1rem}.view-toggle{width:100%}.view-btn{flex:1 1;text-align:center}.calendar-view{padding:.75rem}.calendar-header h2{font-size:1.25rem}.calendar-nav-controls{gap:1.5rem}.calendar-nav-btn{width:32px;height:32px;font-size:.875rem}.weekday{padding:.4rem .125rem;font-size:.55rem}.weekday-full{display:none}.weekday-short{display:inline;font-weight:700}.calendar-day{min-height:70px;padding:.4rem .125rem}.day-number{font-size:.8rem;margin-bottom:.125rem}.event-preview{font-size:.5rem;padding:.1rem .2rem;margin-bottom:.1rem;border-left-width:1.5px}.event-dot{width:4px;height:4px}.event-title{font-size:.5rem;line-height:1}.more-events{font-size:.5rem;margin-top:.1rem}.calendar-footer{margin-top:1rem}.calendar-footer p{font-size:.75rem;margin-bottom:.75rem}.btn-outline{padding:.6rem 1.2rem;font-size:.8rem}}