/* City Landing Page Styles */
.city-hero{background:linear-gradient(135deg,var(--secondary-color) 0%,#1a1a2e 100%);position:relative;overflow:hidden;padding:140px 0 80px}
@media(max-width:991px){.city-hero{padding:120px 0 60px}}
.city-hero::before{content:'';position:absolute;top:-50%;right:-20%;width:60%;height:200%;background:radial-gradient(ellipse,rgba(208,2,41,0.15) 0%,transparent 70%);pointer-events:none}
.hero-badge{display:inline-block;padding:0.5rem 1rem;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);border-radius:50px;font-size:0.8rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:white;margin-bottom:1.5rem}
.hero-title{font-size:clamp(2rem,5vw,3.25rem);font-weight:800;line-height:1.1;margin-bottom:1.5rem;color:white}
.hero-subtitle{font-size:1.15rem;line-height:1.7;color:rgba(255,255,255,0.9);margin-bottom:2rem;max-width:60ch}
.hero-features{display:flex;flex-wrap:wrap;gap:0.75rem;margin-bottom:2rem}
.hero-feature{display:inline-flex;align-items:center;gap:0.5rem;padding:0.5rem 1rem;background:rgba(255,255,255,0.1);border-radius:8px;font-size:0.85rem;color:white}
.hero-feature i{color:var(--primary-color)}
.hero-cta{display:inline-flex;align-items:center;gap:0.5rem;padding:1rem 2rem;background:var(--primary-color);color:white;font-weight:700;border-radius:50px;text-decoration:none;transition:all 0.3s ease}
.hero-cta:hover{background:#b50303;color:white;transform:translateY(-2px)}
.hero-cta-secondary{display:inline-flex;align-items:center;gap:0.5rem;padding:1rem 2rem;background:transparent;border:2px solid rgba(255,255,255,0.3);color:white;font-weight:600;border-radius:50px;text-decoration:none;transition:all 0.3s ease}
.hero-cta-secondary:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.5);color:white}
.course-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
@media(max-width:1199px){.course-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:575px){.course-grid{grid-template-columns:1fr}}
.course-card{background:white;border-radius:12px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,0.08);transition:all 0.3s ease;text-decoration:none;color:inherit;display:flex;flex-direction:column}
.course-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,0.12);color:inherit}
.course-card-image{height:160px;background-size:cover;background-position:center;position:relative}
.course-card-badge{position:absolute;top:12px;left:12px;padding:4px 12px;background:var(--primary-color);color:white;font-size:0.75rem;font-weight:600;border-radius:4px;text-transform:uppercase}
.course-card-content{padding:1.25rem;flex:1;display:flex;flex-direction:column}
.course-card-title{font-size:1.1rem;font-weight:700;margin-bottom:0.5rem;color:var(--secondary-color)}
.course-card-desc{font-size:0.9rem;color:#666;line-height:1.5;margin-bottom:1rem;flex:1}
.course-card-meta{display:flex;flex-wrap:wrap;gap:0.75rem;font-size:0.8rem;color:#888}
.course-card-meta span{display:flex;align-items:center;gap:0.25rem}
.course-card-footer{padding:1rem 1.25rem;border-top:1px solid #eee;display:flex;justify-content:space-between;align-items:center}
.course-price{font-weight:700;color:var(--primary-color)}
.course-price span{font-weight:400;font-size:0.85rem;color:#666}
.course-link{font-weight:600;color:var(--secondary-color);font-size:0.9rem}
.stats-section{background:var(--neutral-color-bg);padding:4rem 0}
.stat-card{text-align:center;padding:2rem}
.stat-icon{width:60px;height:60px;background:rgba(208,2,41,0.1);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}
.stat-icon i{font-size:1.5rem;color:var(--primary-color)}
.stat-number{font-size:3rem;font-weight:800;color:var(--primary-color);line-height:1;margin-bottom:0.5rem}
.stat-label{font-size:1rem;color:#666;font-weight:500}
.benefits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}
.benefit-card{background:white;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,0.06)}
.benefit-icon{width:50px;height:50px;background:rgba(208,2,41,0.1);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.benefit-icon i{font-size:1.5rem;color:var(--primary-color)}
.benefit-title{font-weight:700;font-size:1.1rem;margin-bottom:0.5rem;color:var(--secondary-color)}
.benefit-desc{font-size:0.9rem;color:#666;line-height:1.6}
.faq-item{background:white;border-radius:12px;margin-bottom:1rem;box-shadow:0 2px 8px rgba(0,0,0,0.04);overflow:hidden}
.faq-question{padding:1.25rem 1.5rem;font-weight:600;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background 0.2s ease}
.faq-question:hover{background:#f9f9f9}
.faq-question i{transition:transform 0.3s ease}
.faq-question.active i{transform:rotate(180deg)}
.faq-answer{display:none;padding:0 1.5rem 1.25rem;color:#555;line-height:1.7}
.faq-answer.show{display:block}
.event-card{background:white;border-radius:12px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,0.08);display:flex;margin-bottom:1rem}
.event-date{background:var(--primary-color);color:white;padding:1rem 1.25rem;text-align:center;min-width:80px;display:flex;flex-direction:column;justify-content:center}
.event-date .month{font-size:0.75rem;text-transform:uppercase;font-weight:600}
.event-date .day{font-size:1.75rem;font-weight:800;line-height:1}
.event-content{padding:1rem 1.25rem;flex:1;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.event-info h4{font-size:1rem;font-weight:700;margin-bottom:0.25rem;color:var(--secondary-color)}
.event-info p{font-size:0.85rem;color:#666;margin:0}
.event-cta{padding:0.5rem 1.25rem;background:var(--primary-color);color:white;border-radius:6px;font-weight:600;font-size:0.85rem;text-decoration:none;transition:background 0.2s ease}
.event-cta:hover{background:var(--secondary-color);color:white}
@media(max-width:575px){.event-card{flex-direction:column}.event-date{flex-direction:row;gap:0.5rem;padding:0.75rem 1rem}}
.cta-section{background:linear-gradient(135deg,var(--secondary-color) 0%,#1a1a2e 100%);padding:5rem 0;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;top:-50%;left:-20%;width:60%;height:200%;background:radial-gradient(ellipse,rgba(208,2,41,0.15) 0%,transparent 70%);pointer-events:none}
.city-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem 1rem;background:white;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,0.06);text-decoration:none;color:inherit;transition:all 0.3s ease;height:100%}
.city-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px rgba(0,0,0,0.1);color:inherit}
.city-card-icon{width:50px;height:50px;background:rgba(208,2,41,0.1);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:0.75rem}
.city-card-icon i{font-size:1.25rem;color:var(--primary-color)}
.city-card-name{font-size:1rem;font-weight:700;margin-bottom:0.25rem;color:var(--secondary-color);text-align:center}
.city-card-state{font-size:0.85rem;color:#666;margin:0;text-align:center}
.city-card:hover .city-card-icon{background:var(--primary-color)}
.city-card:hover .city-card-icon i{color:white}
.calendar-filters-row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:10px}
.select-month,.select-workshop{position:relative;display:inline-flex;align-items:center;height:40px;background:#F8F8F8;border:1px solid #EAEAEA;border-radius:6px;padding:0 0.75rem;gap:0.5rem}
.select-month-icon path,.select-workshop-icon path{fill:var(--primary-color)}
.select-month select,.select-workshop select{border:none;background:transparent;padding:0;font-size:0.875rem;color:#000;cursor:pointer;min-width:7rem;outline:none;height:100%}
.select-workshop::before{content:'';position:absolute;left:10px;top:50%;transform:translateY(-50%);width:16px;height:16px;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDI0IDI0Ij48cGF0aCBmaWxsPSIjQTUwNDA0IiBkPSJNMTkgM0g1Yy0xLjEgMC0yIC45LTIgMnYxNGMwIDEuMS45IDIgMiAyaDE0YzEuMSAwIDItLjkgMi0yVjVjMC0xLjEtLjktMi0yLTJtLTUgMTRIN3YtMmg3em0zLTRIN3YtMmg5em0wLTRIN1Y3aDl6Ii8+PC9zdmc+);background-size:cover;pointer-events:none}
.select-workshop{padding:0 0.5rem 0 0}
.select-workshop select{padding-left:1.8rem;min-width:8rem}
.btn-calendar{background-color:#F8F8F8;border:1px solid #EAEAEA;outline:none;font-size:0.875rem;color:#000}
.course-type-filter{display:inline-flex;align-items:center;background:#F8F8F8;border:1px solid #EAEAEA;border-radius:6px;padding:4px;gap:4px;height:40px}
.course-type-btn{padding:0 1rem;border:none;border-radius:4px;background:transparent;color:#000;font-size:0.875rem;font-weight:500;cursor:pointer;transition:all 0.2s ease;white-space:nowrap;height:32px;display:flex;align-items:center}
.course-type-btn:hover{background:rgba(0,0,0,0.05)}
.course-type-btn.active{background:var(--primary-color);color:white;box-shadow:0 2px 4px rgba(208,2,41,0.2)}
.view-toggle-filter{display:inline-flex;align-items:center;background:#F8F8F8;border:1px solid #EAEAEA;border-radius:6px;padding:4px;gap:4px;height:40px}
.view-toggle-btn{padding:0 0.75rem;border:none;border-radius:4px;background:transparent;color:#000;cursor:pointer;transition:all 0.2s ease;display:flex;align-items:center;justify-content:center;height:32px}
.view-toggle-btn:hover{background:rgba(0,0,0,0.05)}
.view-toggle-btn.active{background:var(--secondary-color);color:white}
.view-toggle-btn svg{width:18px;height:18px}
@media(max-width:767px){.calendar-filters-row{flex-direction:column}.calendar-filters-row>*{width:100%;justify-content:center}.select-month select,.select-workshop select{min-width:unset;flex:1}}
.calendar-list-table{width:100%;border-collapse:separate;border-spacing:0}
.calendar-list-table thead th{background:var(--neutral-color-bg);padding:1rem 1.25rem;font-weight:600;font-size:0.85rem;text-transform:uppercase;letter-spacing:0.5px;color:#666;border-bottom:2px solid #e0e0e0;white-space:nowrap}
.calendar-list-table thead th:first-child{border-radius:8px 0 0 0}
.calendar-list-table thead th:last-child{border-radius:0 8px 0 0}
.calendar-list-row{transition:background 0.2s ease}
.calendar-list-row:hover{background:rgba(208,2,41,0.03)}
.calendar-list-row td{padding:1.25rem;vertical-align:middle;border-bottom:1px solid #eee}
.calendar-list-date{display:flex;align-items:center;gap:1rem}
.date-badge{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:55px;padding:0.5rem 0.75rem;background:var(--primary-color);border-radius:8px;color:white;flex-shrink:0}
.date-badge .date-weekday{font-size:0.65rem;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;opacity:0.9}
.date-badge .date-month{font-size:0.7rem;font-weight:600;text-transform:uppercase;letter-spacing:0.5px}
.date-badge .date-day{font-size:1.4rem;font-weight:700;line-height:1}
.date-full{display:none}
.calendar-list-location{font-weight:500}
.calendar-list-course .course-link{color:var(--secondary-color);font-weight:600;text-decoration:none;transition:color 0.2s ease}
.calendar-list-course .course-link:hover{color:var(--primary-color)}
.badge-livestream{display:inline-block;margin-left:0.5rem;padding:2px 8px;background:var(--secondary-color);color:white;font-size:0.7rem;font-weight:600;border-radius:4px;text-transform:uppercase;vertical-align:middle}
.calendar-list-time{color:#666;font-size:0.9rem}
.calendar-list-price{white-space:nowrap}
.calendar-list-price .price-sale{font-weight:700;font-size:1.1rem;color:var(--secondary-color);margin-right:0.5rem}
.calendar-list-price .price-regular{color:#999;text-decoration:line-through;font-size:0.9rem}
.calendar-list-action .btn{white-space:nowrap}
@media(max-width:991px){.calendar-list-table thead{display:none}.calendar-list-table,.calendar-list-table tbody,.calendar-list-table tr,.calendar-list-table td{display:block}.calendar-list-row{background:white;border:1px solid #eee;border-radius:12px;padding:1rem;margin-bottom:1rem;box-shadow:0 2px 8px rgba(0,0,0,0.04)}.calendar-list-row:hover{background:white;box-shadow:0 4px 12px rgba(0,0,0,0.08)}.calendar-list-row td{padding:0.5rem 0;border-bottom:none}.calendar-list-date{justify-content:flex-start;margin-bottom:0.5rem}.date-full{display:inline;font-weight:500;color:#333}.calendar-list-location{font-size:1.1rem;margin-bottom:0.25rem}.calendar-list-course{font-size:0.95rem;color:#666}.calendar-list-price{margin:0.75rem 0}.calendar-list-action{padding-top:0.5rem!important}.calendar-list-action .btn{width:100%;justify-content:center}}
.calendar-card-view>[class*="col-"]{padding:0 12px;margin-bottom:2rem}
.calendar-card-view .course-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,0.08);transition:all 0.3s ease;height:100%;display:flex;flex-direction:column}
.calendar-card-view .course-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,0.12)}
.calendar-card-view .course-card-image{position:relative;overflow:hidden;aspect-ratio:4/3}
.calendar-card-view .course-card-image img{width:100%;height:100%;object-fit:cover;transition:transform 0.3s ease}
.calendar-card-view .course-card:hover .course-card-image img{transform:scale(1.05)}
.calendar-card-view .course-card-date-badge{position:absolute;top:12px;left:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:55px;padding:8px 10px;background:var(--primary-color);border-radius:8px;color:white;text-align:center;box-shadow:0 2px 8px rgba(0,0,0,0.2)}
.calendar-card-view .course-card-date-badge .date-weekday{font-size:0.6rem;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;opacity:0.9}
.calendar-card-view .course-card-date-badge .date-month{font-size:0.65rem;font-weight:600;text-transform:uppercase;letter-spacing:0.5px}
.calendar-card-view .course-card-date-badge .date-day{font-size:1.35rem;font-weight:700;line-height:1}
.calendar-card-view .course-card-badge{position:absolute;top:12px;left:auto;right:12px;padding:4px 10px;border-radius:4px;font-size:0.7rem;font-weight:600;text-transform:uppercase;letter-spacing:0.5px}
.calendar-card-view .course-card-badge.livestream{background:var(--secondary-color);color:white}
.calendar-card-view .course-card-content{padding:1.25rem;display:flex;flex-direction:column;flex:1}
.calendar-card-view .course-card-location{display:flex;align-items:center;gap:6px;font-size:0.8rem;color:#666;margin-bottom:8px}
.calendar-card-view .course-card-title{font-size:1rem;font-weight:700;line-height:1.3;margin:0 0 8px 0;color:#1a1a1a}
.calendar-card-view .course-card-title a{color:inherit;text-decoration:none;transition:color 0.2s ease}
.calendar-card-view .course-card-title a:hover{color:var(--primary-color)}
.calendar-card-view .course-card-time{display:flex;align-items:center;gap:6px;font-size:0.8rem;color:#666;margin-bottom:12px}
.calendar-card-view .course-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:12px;border-top:1px solid #f0f0f0}
.calendar-card-view .course-card-price{display:flex;flex-direction:column}
.calendar-card-view .course-card-price .price-sale{font-size:1.15rem;font-weight:700;color:var(--secondary-color)}
.calendar-card-view .course-card-price .price-regular{font-size:0.8rem;color:#999;text-decoration:line-through}
.calendar-card-view .course-card-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;background:var(--primary-color);color:white;font-size:0.85rem;font-weight:600;border-radius:6px;text-decoration:none;transition:all 0.2s ease}
.calendar-card-view .course-card-btn:hover{background:var(--secondary-color);color:white;transform:translateX(2px)}
