:root{--card-bg: #ffffff;--card-border: #e5e7eb;--card-text: #1f2937;--card-text-muted: #6b7280;--card-accent: #ef4444;--type-class: #3b82f6;--type-class-bg: #eff6ff;--type-class-border: #bfdbfe;--type-event: #f97316;--type-event-bg: #fff7ed;--type-event-border: #fed7aa;--type-club: #8b5cf6;--type-club-bg: #f5f3ff;--type-club-border: #ddd6fe}.all-classes{max-width:1400px;margin:0 auto;padding:40px 20px}.all-classes__header{text-align:center;margin-bottom:40px}.all-classes__header-top{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:16px;margin-bottom:16px}.all-classes__title{font-size:36px;font-weight:700;color:var(--card-text);margin:0}.all-classes__view-link{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:8px;font-size:14px;font-weight:500;color:var(--card-text);text-decoration:none;transition:all .2s}.all-classes__view-link:hover{background:#f3f4f6;border-color:var(--card-accent);color:var(--card-accent)}.all-classes__view-link svg{stroke:currentColor}.all-classes__description{font-size:16px;color:var(--card-text-muted);max-width:700px;margin:0 auto;line-height:1.6}.all-classes__filter-bar{display:flex;gap:12px;margin-bottom:16px;align-items:center;justify-content:center;flex-wrap:wrap}.all-classes__view-toggle{display:flex;gap:4px;background:#f3f4f6;padding:4px;border-radius:8px}.all-classes__view-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;border-radius:6px;cursor:pointer;color:#6b7280;transition:all .2s}.all-classes__view-btn:hover{color:#374151;background:#e5e7eb}.all-classes__view-btn.is-active{background:#fff;color:var(--card-accent);box-shadow:0 1px 3px #0000001a}.all-classes__search{flex:1;min-width:250px;max-width:400px}.all-classes__search-input{width:100%;padding:12px 16px;border:1px solid var(--card-border);border-radius:8px;font-size:14px;outline:none;transition:border-color .2s}.all-classes__search-input:focus{border-color:var(--card-accent)}.all-classes__filter-toggle{display:flex;align-items:center;gap:6px;padding:12px 20px;background:#f3f4f6;border:1px solid var(--card-border);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.all-classes__filter-toggle:hover{background:#e5e7eb}.all-classes__filter-toggle.is-active{background:var(--card-accent);border-color:var(--card-accent);color:#fff}.all-classes__filter-toggle.is-active .all-classes__filter-toggle-arrow{transform:rotate(180deg)}.all-classes__filter-toggle-arrow{transition:transform .2s}.all-classes__filters{display:none;background:#f9fafb;border:1px solid var(--card-border);border-radius:8px;padding:16px;margin-bottom:24px}.all-classes__filters.is-open{display:block}.all-classes__filters-row{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end}.all-classes__filter-group{display:flex;flex-direction:column;gap:6px;min-width:140px}.all-classes__filter-group--actions{margin-left:auto}.all-classes__filter-label{font-size:12px;font-weight:600;color:var(--card-text-muted);text-transform:uppercase;letter-spacing:.5px}.all-classes__filter-select{padding:8px 12px;border:1px solid var(--card-border);border-radius:6px;font-size:14px;background:#fff;cursor:pointer;min-width:150px}.all-classes__filter-select:focus{outline:none;border-color:var(--card-accent)}.all-classes__filter-buttons{display:flex;gap:6px;flex-wrap:wrap}.all-classes__month-buttons{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.all-classes__month-buttons::-webkit-scrollbar{height:4px}.all-classes__month-buttons::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.all-classes__month-buttons::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:2px}.all-classes__filter-group--months{min-width:0;flex:1}.all-classes__filter-chip{padding:6px 14px;background:#fff;border:1px solid var(--card-border);border-radius:20px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.all-classes__filter-chip:hover{background:#f3f4f6}.all-classes__filter-chip.is-active{background:var(--card-accent);color:#fff;border-color:var(--card-accent)}.all-classes__filter-clear{padding:8px 16px;background:transparent;border:1px solid var(--card-border);border-radius:6px;font-size:13px;color:var(--card-text-muted);cursor:pointer;transition:all .2s}.all-classes__filter-clear:hover{background:#fee2e2;border-color:#ef4444;color:#ef4444}.all-classes__active-filters{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.all-classes__active-filters:empty{display:none}.all-classes__active-filter{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--card-accent);color:#fff;border-radius:20px;font-size:12px;font-weight:500}.all-classes__active-filter-remove{display:flex;align-items:center;justify-content:center;width:16px;height:16px;background:#fff3;border:none;border-radius:50%;cursor:pointer;padding:0;font-size:14px;line-height:1;color:#fff}.all-classes__active-filter-remove:hover{background:#fff6}.all-classes__month-pagination{display:flex;align-items:center;justify-content:center;gap:16px;padding:20px 0;margin:0 0 24px;border-bottom:1px solid var(--card-border)}.all-classes__month-nav-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:#fff;border:1px solid var(--card-border);border-radius:50%;cursor:pointer;transition:all .2s;color:var(--card-text)}.all-classes__month-nav-btn:hover:not(:disabled){background:#f3f4f6;border-color:var(--card-accent);color:var(--card-accent)}.all-classes__month-nav-btn:disabled{opacity:.4;cursor:not-allowed}.all-classes__month-nav-btn svg{stroke:currentColor}.all-classes__month-display{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:200px}.all-classes__month-current{font-size:22px;font-weight:600;color:var(--card-text)}.all-classes__month-indicator{font-size:13px;color:var(--card-text-muted);font-weight:500}@media(max-width:768px){.all-classes__filter-bar{justify-content:stretch}.all-classes__search{max-width:none;flex:1 0 100%}.all-classes__filter-toggle{flex:1;justify-content:center}.all-classes__filters-row{flex-direction:column;align-items:stretch}.all-classes__filter-group{width:100%}.all-classes__filter-group--actions{margin-left:0;margin-top:8px}.all-classes__filter-select,.all-classes__filter-buttons{width:100%}.all-classes__filter-chip{flex:1;text-align:center}}.all-classes__filter-btn{padding:10px 20px;background:#f3f4f6;border:1px solid var(--card-border);border-radius:8px;font-size:14px;font-weight:500;color:var(--card-text);cursor:pointer;transition:all .2s}.all-classes__filter-btn:hover,.all-classes__filter-btn.is-active{background:var(--card-accent);border-color:var(--card-accent);color:#fff}.all-classes__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.all-classes__empty{text-align:center;padding:80px 20px;color:var(--card-text-muted);grid-column:1 / -1;background:#f9fafb;border-radius:12px;border:1px dashed var(--card-border)}.all-classes__empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.all-classes__empty-title{font-size:18px;font-weight:600;color:var(--card-text);margin:0 0 8px}.all-classes__empty-text{font-size:14px;margin:0 0 16px}.all-classes__empty-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:var(--card-accent);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.all-classes__empty-btn:hover{opacity:.9}.class-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s;display:flex;flex-direction:column}.class-card:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-2px)}.class-card__image{width:100%;height:180px;object-fit:cover;background:#f3f4f6}.class-card__image--placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:48px}.class-card__body{padding:20px;flex:1;display:flex;flex-direction:column}.class-card__date{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--card-text-muted);margin-bottom:8px}.class-card__date svg{width:14px;height:14px;stroke:var(--card-text-muted)}.class-card__title{font-size:18px;font-weight:600;color:var(--card-text);margin:0 0 12px;line-height:1.3}.class-card__meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.class-card__instructor{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--card-text-muted)}.class-card__instructor svg{width:14px;height:14px;stroke:var(--card-text-muted)}.class-card__skill-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500;background:#e0f2fe;color:#0369a1}.class-card__skill-badge--beginner{background:#dcfce7;color:#166534}.class-card__skill-badge--intermediate{background:#fef3c7;color:#92400e}.class-card__skill-badge--advanced{background:#fee2e2;color:#991b1b}.class-card__type-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.class-card__type-badge--class{background:var(--type-class-bg);color:var(--type-class);border:1px solid var(--type-class-border)}.class-card__type-badge--event{background:var(--type-event-bg);color:var(--type-event);border:1px solid var(--type-event-border)}.class-card__type-badge--club{background:var(--type-club-bg);color:var(--type-club);border:1px solid var(--type-club-border)}.class-card__footer{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid var(--card-border);margin-top:auto}.class-list-item{display:flex;align-items:center;gap:16px;padding:16px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;cursor:pointer;transition:all .2s}.class-list-item:hover{border-color:#9ca3af;box-shadow:0 2px 8px #0000000f}.class-list-item__image--placeholder{background:#f3f4f6;display:flex;align-items:center;justify-content:center;color:#9ca3af}.class-list-item__header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.class-list-item__type-badge{padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.3px}.class-list-item__type-badge--class{background:var(--type-class, #3b82f6)}.class-list-item__type-badge--event{background:var(--type-event, #f97316)}.class-list-item__type-badge--club{background:var(--type-club, #8b5cf6)}.class-list-item__title{font-size:16px;font-weight:600;color:var(--card-text);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.class-list-item__meta{display:flex;flex-wrap:wrap;gap:12px;font-size:13px;color:var(--card-text-muted)}.class-list-item__meta-item{display:flex;align-items:center;gap:4px}.class-list-item__meta-item svg{width:14px;height:14px}.class-list-item__right{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0}.class-list-item__price{font-size:18px;font-weight:700;color:#111827}.class-list-item__spots{font-size:12px;color:var(--card-text-muted)}.class-list-item__spots--available{color:#16a34a}@media(max-width:600px){.class-list-item{flex-wrap:wrap}.class-list-item__image{width:60px;height:60px}.class-list-item__content{flex:1 0 calc(100% - 90px)}.class-list-item__right{flex:1 0 100%;flex-direction:row;justify-content:space-between;align-items:center;padding-top:12px;margin-top:8px;border-top:1px solid var(--card-border)}}.class-card__footer-left{display:flex;flex-direction:column;gap:4px}.class-card__price{font-size:20px;font-weight:700;color:#111827}.class-card__spots{font-size:13px;color:var(--card-text-muted)}.class-card__spots--sold-out{color:#dc2626;font-weight:500}.class-card__footer-right{display:flex;align-items:center;gap:8px}.class-card__share-wrapper{display:flex;align-items:center;gap:6px}.class-card__share-callout{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:#16a34a;animation:pulse-callout 2s ease-in-out infinite}.class-card__share-arrow{width:16px;height:16px;stroke:#16a34a;animation:bounce-arrow 1s ease-in-out infinite}@keyframes pulse-callout{0%,to{opacity:1}50%{opacity:.7}}@keyframes bounce-arrow{0%,to{transform:translate(0)}50%{transform:translate(3px)}}.class-card__share-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--card-border);border-radius:50%;background:var(--card-bg);cursor:pointer;transition:all .2s}.class-card__share-btn:hover{background:#f3f4f6;border-color:var(--card-text-muted)}.class-card__share-btn svg{width:18px;height:18px;stroke:var(--card-text-muted)}.class-cards__modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999999;display:none;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.class-cards__modal.is-active{display:flex}.class-cards__modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;touch-action:none;z-index:-1}.class-cards__modal-content{position:relative;background:var(--card-bg);border-radius:12px;max-width:800px;width:100%;box-shadow:0 20px 40px #0003;margin:20px auto;max-height:calc(100vh - 80px);overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.class-cards__modal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#374151;border:none;border-radius:50%;cursor:pointer;z-index:10;transition:all .2s;color:#fff}.class-cards__modal-close:hover{background:#1f2937}.class-cards__modal-close svg{width:14px;height:14px;stroke:#fff}.class-cards__modal-topbar{display:flex;align-items:center;justify-content:flex-start;gap:16px;padding:20px 50px 20px 24px;background:#f9fafb;border-bottom:1px solid var(--card-border)}.class-cards__modal-topbar-left{display:flex;align-items:center;gap:12px;flex:1}.class-cards__modal-topbar-title{font-size:20px;font-weight:600;color:var(--card-text);margin:0}.class-cards__modal-status{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:#16a34a}.class-cards__modal-status-dot{width:8px;height:8px;background:#16a34a;border-radius:50%}.class-cards__modal-status--sold-out{color:#dc2626}.class-cards__modal-status--sold-out .class-cards__modal-status-dot{background:#dc2626}.class-cards__modal-price{font-size:18px;font-weight:600}.class-cards__modal-image{width:100%;max-height:300px;object-fit:cover}.class-cards__modal-body-inner{padding:24px 24px 48px}.class-cards__modal-meta{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:20px}.class-cards__modal-meta-item{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--card-text)}.class-cards__modal-meta-item svg{stroke:var(--card-text-muted)}.class-cards__modal-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.class-cards__modal-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;background:#f3f4f6;border-radius:20px;font-size:12px;color:var(--card-text-muted)}.class-cards__modal-description{font-size:15px;line-height:1.7;color:var(--card-text);margin-bottom:24px}.class-cards__modal-kits{background:#f9fafb;border:1px solid var(--card-border);border-radius:8px;padding:16px;margin-bottom:20px}.class-cards__modal-kits-title{font-size:14px;font-weight:600;color:var(--card-text);margin:0 0 12px}.class-cards__modal-kit{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--card-border)}.class-cards__modal-kit:last-child{border-bottom:none;padding-bottom:0}.class-cards__modal-kit-image{width:50px;height:50px;object-fit:cover;border-radius:6px;background:#e5e7eb}.class-cards__modal-kit-info{flex:1}.class-cards__modal-kit-name{font-size:14px;font-weight:500;color:var(--card-text)}.class-cards__modal-kit-price{font-size:13px;color:var(--card-accent);font-weight:500}.class-cards__modal-kit-btn{padding:8px 16px;background:#f3f4f6;border:1px solid var(--card-border);border-radius:6px;font-size:13px;font-weight:500;color:var(--card-text);cursor:pointer;transition:all .2s}.class-cards__modal-kit-btn:hover{background:#e5e7eb}.class-cards__modal-schedule{background:#fffbeb;border:1px solid #fcd34d;border-radius:8px;padding:16px;margin-bottom:20px}.class-cards__modal-schedule-title{font-size:14px;font-weight:600;color:#92400e;margin:0 0 8px}.class-cards__modal-schedule-day{font-size:14px;font-weight:600;color:#92400e}.class-cards__modal-schedule-date{font-size:20px;font-weight:700;color:#92400e}.class-cards__modal-schedule-time{font-size:14px;color:#b45309}.class-cards__modal-hosted{padding:16px 0;border-top:1px solid var(--card-border)}.class-cards__modal-hosted-title{font-size:14px;font-weight:600;color:var(--card-text);margin:0 0 8px}.class-cards__modal-hosted-name{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--card-text)}.class-cards__modal-details{display:flex;flex-wrap:wrap;gap:16px;padding:16px 0;border-top:1px solid var(--card-border)}.class-cards__modal-detail-item{display:flex;align-items:center;gap:8px;font-size:14px}.class-cards__modal-detail-label{color:var(--card-text-muted)}.class-cards__modal-detail-value{color:var(--card-text);font-weight:500}.class-cards__skill-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:500;background:#e0f2fe;color:#0369a1}.class-cards__skill-badge--beginner{background:#dcfce7;color:#166534}.class-cards__skill-badge--intermediate{background:#fef3c7;color:#92400e}.class-cards__skill-badge--advanced{background:#fee2e2;color:#991b1b}.class-cards__modal-disclaimer{margin-top:20px;padding:16px;background:#fffbeb;border:1px solid #fcd34d;border-radius:8px;font-size:13px;line-height:1.5;color:#92400e}.class-cards__modal-disclaimer-title{font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:6px;font-size:14px}.class-cards__modal-disclaimer-content{line-height:1.6}.class-cards__modal-disclaimer-content strong{display:block;margin-bottom:10px;font-size:14px}.class-cards__modal-disclaimer-list{margin:0 0 12px;padding:0 0 0 20px;list-style-type:disc}.class-cards__modal-disclaimer-list li{margin-bottom:6px;padding-left:4px}.class-cards__modal-disclaimer-list li:last-child{margin-bottom:0}.class-cards__modal-disclaimer-closing{margin:12px 0 0;font-style:italic;font-weight:500}.class-cards__modal-footer{padding:20px 24px;border-top:1px solid var(--card-border);display:flex;align-items:center;gap:16px;background:var(--card-bg);margin-top:16px}.class-cards__modal-book-btn{display:flex;align-items:center;gap:8px;padding:14px 28px;background:var(--card-accent);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.class-cards__modal-book-btn:hover{opacity:.9}.class-cards__modal-book-btn:disabled{background:#d1d5db;cursor:not-allowed}.class-cards__modal-book-btn .price{opacity:.9;font-weight:500}.class-cards__modal-share{display:flex;align-items:center;gap:10px;margin-left:auto}.class-cards__modal-share-text{display:flex;align-items:center;gap:4px;font-size:14px;color:#16a34a;font-weight:600;animation:pulse-callout 2s ease-in-out infinite}.class-cards__modal-share-arrow{width:18px;height:18px;stroke:#16a34a;animation:bounce-arrow 1s ease-in-out infinite}.class-cards__modal-share-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;background:#f3f4f6;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s}.class-cards__modal-share-btn:hover{background:#e5e7eb;border-color:#9ca3af}.class-cards__cart-confirm{display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px 24px}.class-cards__cart-confirm-icon{width:64px;height:64px;background:#dcfce7;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.class-cards__cart-confirm-icon svg{width:32px;height:32px;stroke:#16a34a}.class-cards__cart-confirm-title{font-size:20px;font-weight:600;color:var(--card-text);margin:0 0 8px}.class-cards__cart-confirm-message{font-size:15px;color:var(--card-text-muted);margin:0 0 24px}.class-cards__cart-confirm-buttons{display:flex;gap:12px;width:100%;max-width:360px}.class-cards__cart-confirm-btn{flex:1;padding:14px 20px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.class-cards__cart-confirm-btn--continue{background:#f3f4f6;border:1px solid #d1d5db;color:#374151}.class-cards__cart-confirm-btn--continue:hover{background:#e5e7eb}.class-cards__cart-confirm-btn--checkout{background:var(--card-accent);border:none;color:#fff}.class-cards__cart-confirm-btn--checkout:hover{opacity:.9}.class-cards__modal-share-btn svg{stroke:#374151}.class-cards__loading{text-align:center;padding:60px 20px;color:var(--card-text-muted)}.all-classes__grid.is-filtering{opacity:.5;pointer-events:none}.all-classes__grid.is-filtering .class-card{transform:scale(.98)}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.class-card{animation:cardFadeIn .3s ease-out forwards}.class-card:nth-child(1){animation-delay:0ms}.class-card:nth-child(2){animation-delay:50ms}.class-card:nth-child(3){animation-delay:.1s}.class-card:nth-child(4){animation-delay:.15s}.class-card:nth-child(5){animation-delay:.2s}.class-card:nth-child(6){animation-delay:.25s}.class-card:nth-child(n+7){animation-delay:.3s}.class-card--skeleton{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;overflow:hidden;animation:none}.class-card__skeleton-image{height:180px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.class-card__skeleton-body{padding:16px}.class-card__skeleton-line{height:16px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px;margin-bottom:12px}.class-card__skeleton-line--short{width:60%}.class-card__skeleton-line--medium{width:80%}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.all-classes__grid--list{display:flex;flex-direction:column;gap:12px}.class-list-item{display:flex;align-items:center;gap:16px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;padding:16px;cursor:pointer;transition:all .2s}.class-list-item:hover{border-color:var(--card-accent);box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.class-list-item__image{width:80px;height:80px;border-radius:8px;object-fit:cover;flex-shrink:0}.class-list-item__image--placeholder{display:flex;align-items:center;justify-content:center;background:#f3f4f6;color:var(--card-text-muted)}.class-list-item__content{flex:1;min-width:0}.class-list-item__header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.class-list-item__title{font-size:16px;font-weight:600;color:var(--card-text);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.class-list-item__type-badge{display:inline-flex;align-items:center;padding:4px 10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-radius:12px;flex-shrink:0}.class-list-item__type-badge--class{background:var(--type-class-bg);color:var(--type-class);border:1px solid var(--type-class-border)}.class-list-item__type-badge--event{background:var(--type-event-bg);color:var(--type-event);border:1px solid var(--type-event-border)}.class-list-item__type-badge--club{background:var(--type-club-bg);color:var(--type-club);border:1px solid var(--type-club-border)}.class-list-item__meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.class-list-item__meta-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--card-text-muted)}.class-list-item__meta-item svg{width:14px;height:14px;flex-shrink:0}.class-list-item__right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.class-list-item__price{font-size:18px;font-weight:700;color:var(--card-accent)}.class-list-item__spots{font-size:12px;font-weight:500}.class-list-item__spots--available{color:#059669}.class-list-item__spots--sold-out{color:#dc2626}.class-cards__modal-type-badge{display:inline-flex;align-items:center;padding:4px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-radius:12px;flex-shrink:0}.class-cards__modal-type-badge--class{background:var(--type-class-bg);color:var(--type-class);border:1px solid var(--type-class-border)}.class-cards__modal-type-badge--event{background:var(--type-event-bg);color:var(--type-event);border:1px solid var(--type-event-border)}.class-cards__modal-type-badge--club{background:var(--type-club-bg);color:var(--type-club);border:1px solid var(--type-club-border)}.class-cards__modal-quantity{display:flex;align-items:center;justify-content:space-between;padding:16px;background:#f9fafb;border-radius:12px;margin-bottom:16px}.class-cards__modal-quantity-label{font-size:14px;font-weight:500;color:var(--card-text)}.class-cards__modal-quantity-controls{display:flex;align-items:center;gap:12px}.class-cards__modal-quantity-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#fff;border:1px solid var(--card-border);border-radius:8px;cursor:pointer;color:var(--card-text);transition:all .2s}.class-cards__modal-quantity-btn:hover:not(:disabled){background:#f3f4f6;border-color:var(--card-accent);color:var(--card-accent)}.class-cards__modal-quantity-btn:disabled{opacity:.4;cursor:not-allowed}.class-cards__modal-quantity-value{font-size:18px;font-weight:600;color:var(--card-text);min-width:32px;text-align:center}@media(max-width:768px){.all-classes{padding:24px 16px}.all-classes__title{font-size:28px}.all-classes__grid{grid-template-columns:1fr;gap:16px}.all-classes__filters{flex-direction:column;align-items:stretch}.all-classes__search{max-width:none}.class-cards__modal{padding:20px 12px}.class-cards__modal-content{margin:10px auto;max-height:calc(100vh - 40px)}.class-cards__modal-topbar{flex-direction:column;align-items:flex-start;gap:12px}.class-cards__modal-footer{flex-direction:column;align-items:stretch}.class-cards__modal-book-btn{justify-content:center}.class-cards__modal-share{margin-left:0;justify-content:center}.class-list-item{flex-wrap:wrap;gap:12px}.class-list-item__image{width:60px;height:60px}.class-list-item__content{order:3;width:100%}.class-list-item__right{margin-left:auto}.class-list-item__header{flex-wrap:wrap}.class-list-item__title{width:100%;order:2;white-space:normal}.class-cards__modal-quantity{flex-direction:column;align-items:stretch;gap:12px}.class-cards__modal-quantity-controls{justify-content:center}}.class-cards__booking-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:10001;display:none;align-items:center;justify-content:center;padding:20px}.class-cards__booking-modal.is-active{display:flex}.class-cards__modal-content--booking{max-width:500px}.class-cards__booking-header{padding:24px;border-bottom:1px solid var(--card-border)}.class-cards__booking-label{font-size:14px;color:var(--card-text-muted);margin:0 0 8px}.class-cards__booking-title{font-size:20px;font-weight:600;color:var(--card-text);margin:0 0 16px}.class-cards__booking-meta{display:flex;flex-wrap:wrap;gap:16px}.class-cards__booking-meta-item{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--card-text-muted)}.class-cards__booking-meta-item svg{flex-shrink:0}.class-cards__booking-content{padding:24px}.class-cards__quantity-section{text-align:center;padding:40px 20px}.class-cards__quantity-icon{width:80px;height:80px;margin:0 auto 20px;background:#d1fae5;border-radius:50%;display:flex;align-items:center;justify-content:center}.class-cards__quantity-icon svg{width:40px;height:40px;color:#10b981;stroke:#10b981}.class-cards__quantity-label{font-size:20px;font-weight:500;color:var(--card-text);margin-bottom:24px}.class-cards__quantity-selector{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px}.class-cards__quantity-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--card-bg);border:1px solid var(--card-border);border-radius:6px;font-size:20px;color:var(--card-text-muted);cursor:pointer;transition:all .2s}.class-cards__quantity-btn:hover{background:#f3f4f6;border-color:var(--card-text-muted)}.class-cards__quantity-value{font-size:20px;font-weight:600;min-width:50px;text-align:center;padding:8px 16px;border:1px solid var(--card-border);border-radius:6px}.class-cards__continue-btn{width:auto;min-width:140px;padding:12px 32px;background:#10b981;color:#fff;border:none;border-radius:6px;font-size:15px;font-weight:600;cursor:pointer;margin-top:24px;transition:background .2s}.class-cards__continue-btn:hover{opacity:.9}
/*# sourceMappingURL=/cdn/shop/t/22/assets/class-cards.css.map */
