.homepage{min-height:100vh;display:flex;flex-direction:column}.hero{padding:calc(100px + var(--spacing-2xl)) var(--spacing-md) var(--spacing-2xl);background:var(--color-bg-dark);position:relative;overflow:hidden}.hero-content{max-width:800px;margin:0 auto;text-align:center;position:relative;z-index:1}.hero h1{font-size:clamp(2.5rem,6vw,4rem);font-weight:700;margin-bottom:var(--spacing-md);line-height:1.1;color:var(--color-text-light)}.hero h1 span{background:var(--color-primary);padding:.1em .3em;display:inline-block}.hero-subtitle{font-size:1.2rem;color:rgba(255,255,255,.7);max-width:600px;margin:0 auto var(--spacing-lg)}.hero-cta{display:flex;justify-content:center;gap:var(--spacing-sm)}.hero-decoration{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;background:radial-gradient(circle,rgba(229,57,53,.15) 0,transparent 70%);pointer-events:none}.hero-search{background:var(--color-bg);border-radius:50px;padding:.5rem;display:flex;align-items:center;max-width:700px;margin:var(--spacing-lg) auto 0;box-shadow:0 4px 20px rgba(0,0,0,.15)}.hero-search input{flex:1 1;border:none;padding:.75rem 1rem;font-size:.95rem;background:transparent;color:var(--color-text);outline:none}.hero-search input::placeholder{color:var(--color-text-muted)}.hero-search .btn-primary{padding:.75rem 1.5rem}.categories-section{padding:var(--spacing-xl) 0;background:var(--color-bg)}.categories-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.categories-header h2{font-size:1.25rem;font-weight:600}.categories-header .view-all{color:var(--color-primary);font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:.25rem}.categories-section h2{text-align:center;font-size:1.5rem;margin-bottom:var(--spacing-lg)}.categories-grid{display:flex;justify-content:center;flex-wrap:wrap;gap:var(--spacing-md)}.category-card{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg-card);border-radius:50px;border:1px solid var(--color-border);cursor:pointer;transition:all .2s ease;min-width:100px}.category-card.active,.category-card:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.category-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--color-text)}.category-name{font-size:.85rem;color:var(--color-text);font-weight:500}.events-section{padding:var(--spacing-2xl) 0;background:var(--color-bg)}.section-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xl)}.section-header-text h2{font-size:1.5rem;font-weight:600;margin-bottom:.25rem}.section-header-text p{color:var(--color-text-muted);font-size:.9rem}.section-header .view-all{color:var(--color-primary);font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:.25rem}.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));grid-gap:var(--spacing-lg);gap:var(--spacing-lg)}@media (max-width:400px){.events-grid{grid-template-columns:1fr}}.event-card{background:var(--color-bg-card);border-radius:16px;overflow:hidden;box-shadow:0 2px 8px var(--color-shadow);transition:all .3s ease}.event-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px rgba(0,0,0,.12)}.event-image{position:relative;height:180px;background:var(--color-bg-secondary)}.event-image img{width:100%;height:100%;object-fit:cover}.event-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f3f4f6,#e5e7eb)}.event-image-placeholder span{font-size:2rem;font-weight:700;color:var(--color-border);letter-spacing:.2em}.event-category-badge{position:absolute;bottom:var(--spacing-sm);left:var(--spacing-sm);background:rgba(0,0,0,.7);color:#fff;padding:.25rem .75rem;border-radius:4px;font-size:.7rem;font-weight:500;text-transform:uppercase}.event-favorite{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:32px;height:32px;background:rgba(255,255,255,.9);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.event-favorite:hover{background:#fff;transform:scale(1.1)}.event-format-badge{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:rgba(255,255,255,.95);color:var(--color-text);padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:500}.event-content{padding:var(--spacing-md);display:flex;gap:var(--spacing-md);align-items:flex-start}.event-date-inline{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--color-primary);font-weight:600;margin-bottom:.5rem}.event-date-inline svg{width:14px;height:14px}.event-date{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-sm);background:var(--color-bg-secondary);border-radius:8px;min-width:60px;align-self:flex-start}.event-day{font-size:1.5rem;font-weight:700;line-height:1;color:var(--color-text)}.event-month{font-size:.75rem;text-transform:uppercase;color:var(--color-primary);font-weight:600}.event-details{flex:1 1}.event-title{font-size:1rem;font-weight:600;margin-bottom:.5rem;line-height:1.3;color:var(--color-text)}.event-description{font-size:.85rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.event-description,.event-meta{color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.event-meta{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem}.event-location{display:flex;align-items:center;gap:.25rem}.event-location:before{content:"📍";font-size:.9em}.event-time:before{content:"🕐 "}.event-footer{display:flex;justify-content:space-between;align-items:center;padding-top:var(--spacing-sm);border-top:1px solid var(--color-border);margin-top:var(--spacing-sm)}.event-price{font-weight:700;color:var(--color-primary);font-size:.9rem}.event-price.free{color:#10b981}.event-city{font-size:.8rem;text-transform:uppercase}.event-city,.no-events{color:var(--color-text-muted)}.no-events{text-align:center;padding:var(--spacing-2xl)}.no-events p{margin-bottom:var(--spacing-xs)}.cta-section{padding:var(--spacing-2xl) 0;background:var(--color-bg-secondary);text-align:center}.cta-section h2{font-size:2rem;margin-bottom:var(--spacing-sm);color:var(--color-text)}.cta-section p{color:var(--color-text-muted);margin-bottom:var(--spacing-lg);max-width:500px;margin-left:auto;margin-right:auto}@media (max-width:768px){.hero{padding:calc(120px + var(--spacing-xl)) var(--spacing-md) var(--spacing-xl)}.event-content{flex-direction:column}.event-date{flex-direction:row;gap:var(--spacing-xs)}}