:root{--color-primary:#1e40af;--color-primary-light:#3b82f6;--color-primary-dark:#1e3a8a;--color-secondary:#dc2626;--color-secondary-hover:#b91c1c;--color-white:#fff;--color-gray-50:#f9fafb;--color-gray-100:#f3f4f6;--color-gray-200:#e5e7eb;--color-gray-300:#d1d5db;--color-gray-400:#9ca3af;--color-gray-500:#6b7280;--color-gray-600:#4b5563;--color-gray-700:#374151;--color-gray-800:#1f2937;--color-gray-900:#111827;--color-success:#10b981;--color-warning:#f59e0b;--shadow-sm:0 1px 2px 0 rgba(0,0,0,.05);--shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px 0 rgba(0,0,0,.06);--shadow-md:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04);--radius-sm:0.25rem;--radius:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--transition:all 0.2s ease;--transition-slow:all 0.3s ease}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:16px;line-height:1.6;color:var(--color-gray-800);background-color:var(--color-gray-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto}button{cursor:pointer}button,input,select,textarea{font-family:inherit}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.container{max-width:1280px;margin:0 auto;padding:0 1.5rem}.layout{min-height:100vh;display:flex;flex-direction:column}.main{flex:1 1;padding-top:1rem}.header{background:var(--color-white);border-bottom:1px solid var(--color-gray-200);position:-webkit-sticky;position:sticky;top:0;z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:hsla(0,0%,100%,.95)}.header-content{justify-content:space-between;padding:1rem 0;gap:2rem}.header-content,.logo{display:flex;align-items:center}.logo{gap:.5rem;font-size:1.5rem;font-weight:800;color:var(--color-primary);transition:var(--transition)}.logo:hover{color:var(--color-secondary)}.logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--color-primary) 0,var(--color-secondary) 100%);border-radius:var(--radius);justify-content:center;color:#fff;font-size:1.25rem}.logo-icon,.nav{display:flex;align-items:center}.nav{gap:.5rem}.nav-link{padding:.5rem 1rem;border-radius:var(--radius);font-weight:500;color:var(--color-gray-600);transition:var(--transition)}.nav-link.active,.nav-link:hover{background:var(--color-gray-100);color:var(--color-primary)}.header-actions{display:flex;align-items:center;gap:1rem}.header-controls{display:flex;align-items:center;gap:.5rem}.header-search{flex:0 0 180px}.header-search-input{position:relative;display:flex;align-items:center}.header-search-input svg{position:absolute;left:.5rem;color:var(--color-gray-400);pointer-events:none}.header-search-input input{width:100%;padding:.375rem .5rem .375rem 1.75rem;border:1px solid var(--color-gray-300);border-radius:var(--radius);font-size:.8rem;transition:var(--transition);background:var(--color-gray-50)}.header-search-input input:focus{outline:none;border-color:var(--color-primary);background:var(--color-white);box-shadow:0 0 0 3px rgba(30,64,175,.1)}.language-switcher select{padding:.375rem .5rem;font-size:.8rem}.language-switcher select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(30,64,175,.1)}.language-switcher select{padding:.5rem 1rem;border:1px solid var(--color-gray-300);border-radius:var(--radius);background:var(--color-white);font-size:.875rem;color:var(--color-gray-700);cursor:pointer;transition:var(--transition)}.language-switcher select:hover{border-color:var(--color-primary)}.hero{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-dark) 100%);color:var(--color-white);padding:4rem 0;margin-bottom:2rem;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");opacity:.5}.hero-content{position:relative;z-index:1;text-align:center;max-width:800px;margin:0 auto}.hero h1{font-size:3rem;font-weight:800;margin-bottom:1rem;line-height:1.2}.hero p{font-size:1.25rem;opacity:.9;margin-bottom:2rem}.filter-section{background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:1.5rem;margin:-1rem auto 2rem;max-width:1280px;position:relative;z-index:10}.filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.filter-title{font-size:1.125rem;font-weight:600;color:var(--color-gray-800)}.filter-clear{padding:.375rem .75rem;background:var(--color-gray-100);color:var(--color-gray-600);border:none;border-radius:var(--radius);font-size:.875rem;cursor:pointer;transition:var(--transition)}.filter-clear:hover{background:var(--color-gray-200);color:var(--color-gray-800)}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:1rem;gap:1rem}.filters-fieldset{border:none;margin:0;padding:0}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-gray-500)}.filter-input,.filter-select{padding:.75rem 1rem;border:2px solid var(--color-gray-200);border-radius:var(--radius);font-size:.9375rem;background:var(--color-white);transition:var(--transition)}.filter-input:focus,.filter-select:focus{outline:none;border-color:var(--color-primary)}.filter-actions{display:flex;align-items:flex-end;gap:1rem}.btn-filter{padding:.75rem 1.5rem;background:var(--color-primary);color:var(--color-white);border:none;border-radius:var(--radius);font-weight:600;transition:var(--transition)}.btn-filter:hover{background:var(--color-primary-dark)}.btn-reset{padding:.75rem 1.5rem;background:var(--color-white);color:var(--color-gray-600);border:2px solid var(--color-gray-200);border-radius:var(--radius);font-weight:500;transition:var(--transition)}.btn-reset:hover{border-color:var(--color-gray-300);background:var(--color-gray-50)}.active-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-gray-100)}.filter-tag{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:var(--color-primary);background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-light) 100%);color:var(--color-white);border-radius:9999px;font-size:.8125rem;font-weight:500}.filter-tag button{background:none;border:none;color:var(--color-white);opacity:.8;cursor:pointer;padding:0;line-height:1}.filter-tag button:hover{opacity:1}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding:0 .5rem}.section-title{font-size:1.5rem;font-weight:700;color:var(--color-gray-900)}.section-count{font-size:.875rem;color:var(--color-gray-500)}.pagination{gap:.5rem;margin:2rem 0 3rem;flex-wrap:wrap}.pagination,.pagination-btn{display:flex;align-items:center;justify-content:center}.pagination-btn{min-width:40px;height:40px;padding:0 .75rem;background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius);font-size:.875rem;font-weight:500;color:var(--color-gray-700);cursor:pointer;transition:var(--transition)}.pagination-btn:hover:not(:disabled){background:var(--color-gray-50);border-color:var(--color-gray-300);color:var(--color-gray-900)}.pagination-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-btn[aria-current=page]{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.pagination-ellipsis{display:flex;align-items:center;justify-content:center;min-width:40px;height:40px;color:var(--color-gray-400);font-size:.875rem}.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));grid-gap:1.5rem;gap:1.5rem;padding-bottom:3rem}.event-card{background:var(--color-white);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow);transition:var(--transition-slow);border:1px solid var(--color-gray-100)}.event-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl);border-color:var(--color-primary-light)}.event-card-link{display:block}.event-card-image{position:relative;height:200px;background:linear-gradient(135deg,var(--color-gray-100) 0,var(--color-gray-200) 100%);overflow:hidden}.event-card-image img{width:100%;height:100%;object-fit:cover;transition:var(--transition-slow)}.event-card:hover .event-card-image img{transform:scale(1.05)}.image-wrapper{position:relative;width:100%;height:100%;overflow:hidden;background:linear-gradient(135deg,var(--color-gray-100) 0,var(--color-gray-200) 100%)}.image-skeleton{position:absolute;inset:0;background:linear-gradient(90deg,var(--color-gray-200) 25%,var(--color-gray-100) 50%,var(--color-gray-200) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;opacity:0;transition:opacity .3s ease;z-index:1}.image-skeleton.visible{opacity:1}.image-content{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .3s ease,transform .5s ease;z-index:2}.image-content.loading{opacity:0}.image-content.error,.image-content.loaded{opacity:1}.image-wrapper:hover .image-content.loaded{transform:scale(1.05)}.image-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:linear-gradient(135deg,var(--color-gray-100) 0,var(--color-gray-200) 100%);color:var(--color-gray-400)}.image-placeholder svg{opacity:.5}.event-detail-image .image-wrapper{height:100%;min-height:400px}.event-detail-image .image-skeleton{position:absolute;inset:0;z-index:1}.event-detail-image .image-content{z-index:2}.event-card-badge{position:absolute;top:1rem;left:1rem;padding:.375rem .75rem;background:var(--color-secondary);color:var(--color-white);border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.event-card-favorite{position:absolute;top:1rem;right:1rem;width:36px;height:36px;background:var(--color-white);border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);transition:var(--transition);opacity:0}.event-card:hover .event-card-favorite{opacity:1}.event-card-favorite:hover{background:var(--color-secondary);color:var(--color-white)}.event-card-content{padding:1.25rem}.event-card-date{display:inline-flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--color-primary);font-weight:600;margin-bottom:.5rem}.event-card-title{font-size:1.125rem;font-weight:700;color:var(--color-gray-900);margin-bottom:.75rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.event-card-meta{display:flex;flex-direction:column;gap:.5rem}.event-card-meta-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--color-gray-600)}.event-card-meta-item svg{flex-shrink:0;color:var(--color-gray-400)}.event-card-footer{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-top:1px solid var(--color-gray-100);background:var(--color-gray-50)}.event-card-price{font-size:1.125rem;font-weight:700;color:var(--color-primary)}.event-card-price span{font-size:.75rem;font-weight:400;color:var(--color-gray-500)}.btn-ticket{padding:.5rem 1rem;background:var(--color-primary);color:var(--color-white);border:none;border-radius:var(--radius);font-size:.875rem;font-weight:600;transition:var(--transition)}.btn-ticket:hover{background:var(--color-primary-dark)}.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--color-gray-500);margin-bottom:1.5rem}.breadcrumb-link{color:var(--color-primary);text-decoration:none;transition:var(--transition)}.breadcrumb-link:hover{color:var(--color-primary-dark);text-decoration:underline}.breadcrumb-separator{color:var(--color-gray-300)}.breadcrumb-current{color:var(--color-gray-700);font-weight:500}.event-detail-card{background:var(--color-white);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid var(--color-gray-100);margin-bottom:2rem;animation:fadeInUp .5s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.event-detail-image{position:relative;height:400px;background:linear-gradient(135deg,var(--color-gray-100) 0,var(--color-gray-200) 100%);overflow:hidden}.event-detail-image:after{content:"";position:absolute;bottom:0;left:0;right:0;height:150px;background:linear-gradient(0deg,rgba(0,0,0,.4) 0,transparent);pointer-events:none}.event-detail-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.event-detail-card:hover .event-detail-image img{transform:scale(1.05)}.event-detail-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-gray-100) 0,var(--color-gray-200) 100%);color:var(--color-gray-400)}.event-detail-badge{position:absolute;top:1.5rem;left:1.5rem;padding:.5rem 1rem;background:var(--color-secondary);color:var(--color-white);border-radius:9999px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;z-index:10;box-shadow:var(--shadow-md)}.event-detail-favorite{position:absolute;top:1.5rem;right:1.5rem;width:48px;height:48px;background:var(--color-white);border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);transition:var(--transition);color:var(--color-gray-400);z-index:10;cursor:pointer}.event-detail-favorite:hover{background:var(--color-secondary);color:var(--color-white);transform:scale(1.1)}.event-detail-content{padding:2rem}.event-detail-header{margin-bottom:1.5rem}.event-detail-date{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--color-gray-50);border-radius:var(--radius-lg);font-size:.875rem;color:var(--color-primary);font-weight:600;margin-bottom:1rem}.event-detail-title{font-size:2rem;font-weight:800;color:var(--color-gray-900);line-height:1.2;margin-bottom:.75rem}.event-detail-artists{margin-bottom:1.5rem;font-size:1rem}.event-detail-artist{font-weight:600;padding:.25rem .75rem;background:linear-gradient(135deg,rgba(30,64,175,.1),rgba(59,130,246,.1));border-radius:9999px;font-size:.875rem}.event-detail-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-gray-100)}.event-detail-meta-item{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:var(--color-gray-50);border-radius:var(--radius-lg);transition:var(--transition)}.event-detail-meta-item:hover{background:var(--color-gray-100)}.event-detail-meta-item svg{flex-shrink:0;width:20px;height:20px;color:var(--color-primary)}.meta-item-content{display:flex;flex-direction:column;gap:.25rem}.meta-item-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-gray-500)}.meta-item-value{font-size:.9375rem;font-weight:600;color:var(--color-gray-800)}.meta-item-value.location{color:var(--color-primary)}.event-detail-footer{display:flex;align-items:center;justify-content:space-between;gap:1rem}.event-detail-price{display:flex;flex-direction:column;gap:.25rem}.event-detail-price-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-gray-500)}.event-detail-price-value{font-size:1.5rem;font-weight:800;color:var(--color-primary)}.event-detail-btn{padding:1rem 2rem;font-size:1rem;font-weight:700;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);transition:var(--transition)}.event-detail-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-xl)}.event-description-section{background:var(--color-white);border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow);border:1px solid var(--color-gray-100)}.event-description-section h2{font-size:1.25rem;font-weight:700;color:var(--color-gray-900);margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-gray-100)}.event-description-section div{color:var(--color-gray-700);line-height:1.7}.event-description-section div p{margin-bottom:1rem}.event-description-section div a{color:var(--color-primary)}.event-description-section div img{max-width:100%;height:auto;border-radius:var(--radius);margin:1rem 0}.no-events{text-align:center;padding:4rem 2rem;background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow)}.no-events svg{width:80px;height:80px;color:var(--color-gray-300);margin-bottom:1.5rem}.no-events h3{font-size:1.5rem;font-weight:700;color:var(--color-gray-900);margin-bottom:.5rem}.no-events p{color:var(--color-gray-500)}.error-message{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-lg);color:#dc2626;margin-bottom:1.5rem}.error-message svg{flex-shrink:0}.error-message span{flex:1 1;font-weight:500}.error-message .btn-retry{padding:.5rem 1rem;background:#dc2626;color:#fff;border:none;border-radius:var(--radius);font-weight:500;cursor:pointer;transition:background .2s}.error-message .btn-retry:hover{background:#b91c1c}.footer{background:var(--color-gray-900);color:var(--color-gray-300);padding:3rem 0 2rem;margin-top:auto}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:2rem;gap:2rem;margin-bottom:2rem}.footer-brand .logo{color:var(--color-white);margin-bottom:1rem}.footer-brand p{font-size:.875rem;opacity:.7}.footer-title{font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-white);margin-bottom:1rem}.footer-links{list-style:none}.footer-links li{margin-bottom:.5rem}.footer-links a{font-size:.875rem;opacity:.7;transition:var(--transition)}.footer-links a:hover{opacity:1;color:var(--color-white)}.footer-bottom{padding-top:2rem;border-top:1px solid var(--color-gray-800);flex-wrap:wrap;justify-content:space-between;align-items:center;font-size:.875rem;opacity:.6}.footer-bottom,.footer-social{display:flex;gap:1rem}.footer-social a{width:36px;height:36px;background:var(--color-gray-800);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.footer-social a:hover{background:var(--color-primary)}.loading{display:flex;align-items:center;justify-content:center;padding:4rem 2rem}.loading-spinner{width:48px;height:48px;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.skeleton{background:linear-gradient(90deg,var(--color-gray-200) 25%,var(--color-gray-100) 50%,var(--color-gray-200) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width:1024px){.hero h1{font-size:2.5rem}.search-section{margin:-1rem 1rem 2rem}.filters-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.header-content{flex-wrap:wrap}.nav{order:3;width:100%;justify-content:center;margin-top:1rem}.hero{padding:3rem 0}.hero h1{font-size:2rem}.hero p{font-size:1rem}.search-main{flex-direction:column}.filters-grid{grid-template-columns:1fr}.filter-actions{flex-direction:column}.btn-filter,.btn-reset{width:100%}.events-grid{grid-template-columns:1fr}.event-detail-title{font-size:1.5rem}.event-detail-meta{grid-template-columns:1fr}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mt-0{margin-top:0}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.event-card-artists{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.5rem;font-size:.8125rem;color:var(--color-gray-600)}.event-card-artist{color:var(--color-primary);font-weight:500}.event-card-artists-more{color:var(--color-gray-400);font-style:italic}.event-detail-artists{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.9375rem}.event-detail-artists-label{font-weight:600;color:var(--color-gray-500);font-size:.875rem}.event-detail-artist{color:var(--color-primary);font-weight:500}