body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.home-page{min-height:70vh}.hero{background:#f8f8f8;padding:5rem 2rem;text-align:center}.hero-content{margin:0 auto;max-width:800px}.hero h1{font-family:Georgia,serif;font-size:4rem;font-weight:300;letter-spacing:4px;margin-bottom:.5rem}.hero h2{color:#666;font-size:1.5rem;font-weight:400;letter-spacing:1px}.hero h2,.tagline{margin-bottom:2rem}.tagline{color:#444;font-size:1.2rem;font-style:italic}.description{color:#555;font-size:1.1rem;line-height:1.8;margin:0 auto;max-width:600px}.events-preview{background:#fff;padding:4rem 2rem}.section-header{border-bottom:1px solid #eee;margin-bottom:3rem;padding-bottom:1rem}.section-header h3{color:#333;font-size:1.5rem;font-weight:400}.view-all{color:#666;font-size:.9rem;text-decoration:none}.view-all:hover{color:#000}.events-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:3rem}.event-card{border:1px solid #eee;display:flex;gap:1.5rem;padding:1.5rem;transition:all .2s ease}.event-card:hover{border-color:#ddd}.event-date{align-items:center;background:#f8f8f8;border-radius:4px;display:flex;flex-direction:column;height:60px;justify-content:center;width:60px}.date-day{font-size:1.5rem;font-weight:400}.date-month{font-size:.8rem}.event-details h4{line-height:1.4;margin-bottom:.5rem}.center-button{margin-top:2rem}.agenda-button{background:#000;border:none;color:#fff;display:inline-block;font-size:.9rem;letter-spacing:1px;padding:1rem 2rem;text-decoration:none;transition:all .2s ease}.agenda-button:hover{background:#333}.info-section{background:#f8f8f8;padding:4rem 2rem}.info-icon{font-size:2.5rem;margin-bottom:1rem;opacity:.8}.info-item h4{font-size:1.2rem;font-weight:400;margin-bottom:1rem}@media (max-width:768px){.hero{padding:3rem 1rem}.hero h1{font-size:3rem;letter-spacing:2px}.hero h2{font-size:1.2rem}.events-preview,.info-section{padding:3rem 1rem}.section-header{align-items:flex-start;flex-direction:column;gap:.5rem}.event-card{flex-direction:column;gap:1rem}.event-date{flex-direction:row;gap:1rem;height:auto;justify-content:flex-start;padding:.5rem 1rem;width:100%}.date-day{font-size:1.2rem}.events-grid{grid-template-columns:1fr}}.error-state{padding:2rem}.retry-btn{padding:.5rem 1rem}.loading-events{padding:3rem}.loading-events,.no-events{color:#666;text-align:center}.no-events{font-style:italic;padding:2rem}.today-events-section{background:#f8f8f8;margin:2rem 0;padding:3rem 2rem}.today-events-section h3{color:#333;font-size:1.5rem;font-weight:400;margin-bottom:2rem;text-align:center}.today-events-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:0 auto;max-width:900px}.today-event-card{background:#fff;border:1px solid #eee;border-radius:8px;padding:1.5rem}.today-event-card h4{color:#333;font-size:1.2rem;font-weight:400;margin-bottom:.5rem}.today-event-card p{color:#666;font-size:.9rem;margin-bottom:.5rem}.today-event-card .event-desc{color:#888;font-size:.85rem;line-height:1.4;margin-top:.75rem}@media (max-width:768px){.today-events-section{padding:2rem 1rem}.today-events-grid{grid-template-columns:1fr}}.highlighted-events-section{background:linear-gradient(135deg,#f8f9ff,#f3e9ff);overflow:hidden;padding:4rem 2rem;position:relative}.highlighted-events-section:before{background:linear-gradient(90deg,#8a4fff,#ff6b6b,#ffd166);content:"";height:4px;left:0;position:absolute;right:0;top:0;z-index:1}.highlighted-events-section .section-header{align-items:center;border-bottom:none;display:flex;justify-content:space-between;margin-bottom:2rem}.highlighted-events-section h3{color:#333;font-size:1.8rem;font-weight:400;margin:0}.highlighted-badge{background:linear-gradient(135deg,gold,orange);border-radius:20px;box-shadow:0 4px 10px #ffd7004d;color:#333;font-size:.9rem;font-weight:600;letter-spacing:1px;padding:.5rem 1rem}.highlighted-events-grid{grid-gap:0;display:grid;gap:0;grid-template-columns:1fr}.highlighted-event-card{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000001a;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.highlighted-event-card:hover{box-shadow:0 15px 40px #00000026;transform:translateY(-5px)}.highlighted-event-content{display:flex;min-height:400px}.highlighted-event-image{flex:1 1;min-height:400px;overflow:hidden;position:relative}.highlighted-image{display:block;height:100%;object-fit:cover;transition:transform .5s ease;width:100%}.highlighted-event-card:hover .highlighted-image{transform:scale(1.05)}.image-overlay{background:linear-gradient(45deg,#8a4fff33,#ff6b6b1a);bottom:0;left:0;position:absolute;right:0;top:0;z-index:1}.highlighted-event-info{display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:2.5rem}.highlighted-event-info.with-image{flex:1 1}.highlighted-event-header{margin-bottom:1.5rem}.highlighted-event-header h2{color:#333;font-family:Georgia,serif;font-size:2.2rem;font-weight:300;line-height:1.2;margin-bottom:.75rem}.highlighted-event-date{align-items:center;color:#666;display:flex;font-size:1.1rem;gap:.5rem}.highlighted-date-full{font-weight:500}.highlighted-date-time{font-weight:400}.highlighted-event-description{margin-bottom:2rem}.highlighted-event-description p{color:#555;font-size:1.05rem;line-height:1.7}.highlighted-event-details{grid-gap:1.5rem;background:#f8f9ff;border:1px solid #e6e9ff;border-radius:8px;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:2rem;padding:1.5rem}.highlighted-detail-item{display:flex;flex-direction:column;gap:.25rem}.highlighted-detail-label{color:#666;font-size:.85rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.highlighted-detail-value{color:#333;font-size:1rem;font-weight:500}.highlighted-event-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:auto}.highlighted-ticket-btn{align-items:center;background:#00b894;border-radius:6px;color:#fff;display:inline-flex;font-size:1rem;font-weight:600;justify-content:center;min-width:180px;padding:1rem 2rem;text-decoration:none;transition:all .3s ease}.highlighted-ticket-btn:hover{background:#00a085;box-shadow:0 5px 15px #00b89433;transform:translateY(-2px)}.highlighted-info-btn{background:#0984e3;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;min-width:180px;padding:1rem 2rem;transition:all .3s ease}.highlighted-info-btn:hover{background:#0770c4;box-shadow:0 5px 15px #0984e333;transform:translateY(-2px)}.highlighted-view-btn{align-items:center;background:#8a4fff;border-radius:6px;color:#fff;display:inline-flex;font-size:1rem;font-weight:600;justify-content:center;min-width:180px;padding:1rem 2rem;text-decoration:none;transition:all .3s ease}.highlighted-view-btn:hover{background:#7640e5;box-shadow:0 5px 15px #8a4fff33;transform:translateY(-2px)}.more-highlighted{align-items:center;border-top:1px solid #e6e9ff;display:flex;justify-content:space-between;margin-top:2rem;padding-top:2rem;text-align:center}.more-highlighted-text{color:#666;font-size:.95rem;font-weight:500}.view-all-highlighted{color:#8a4fff;font-size:.9rem;font-weight:600;text-decoration:none;transition:color .2s ease}.view-all-highlighted:hover{color:#7640e5;text-decoration:underline}@media (max-width:1024px){.highlighted-event-content{flex-direction:column;min-height:auto}.highlighted-event-image{min-height:300px}.highlighted-event-info{padding:2rem}.highlighted-event-header h2{font-size:1.8rem}}@media (max-width:768px){.highlighted-events-section{padding:3rem 1rem}.highlighted-events-section .section-header{align-items:flex-start;flex-direction:column;gap:1rem}.highlighted-event-image{min-height:250px}.highlighted-event-info{padding:1.5rem}.highlighted-event-header h2{font-size:1.6rem}.highlighted-event-date{align-items:flex-start;flex-direction:column;gap:.25rem}.highlighted-event-details{grid-template-columns:1fr;padding:1rem}.highlighted-event-actions{flex-direction:column}.highlighted-info-btn,.highlighted-ticket-btn,.highlighted-view-btn{justify-content:center;min-width:100%;width:100%}.more-highlighted{flex-direction:column;gap:1rem;text-align:center}}@media (max-width:480px){.highlighted-events-section h3{font-size:1.5rem}.highlighted-badge{font-size:.8rem;padding:.4rem .8rem}.highlighted-event-image{min-height:200px}.highlighted-event-header h2{font-size:1.4rem}.highlighted-event-description p{font-size:.95rem}}.home-class-schedule{color:#666}.classes-preview-section{background:#000;padding:3rem 2rem}.classes-preview-section .section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.classes-preview-section h3{color:#bbb;font-size:1.5rem;font-weight:400;margin:0}.classes-preview-section .view-all{color:#666;font-size:.9rem;text-decoration:none}.classes-preview-section .view-all:hover{color:#fff}.classes-grid{margin-bottom:2rem}.class-card{transition:all .3s ease}.class-level,.class-price{font-size:.9rem;font-weight:500;opacity:.8}.view-classes-btn{background:#000;border:none;border-radius:4px;color:#fff;display:inline-block;font-size:.9rem;letter-spacing:1px;padding:1rem 2rem;text-decoration:none;transition:all .2s ease}.view-classes-btn:hover{background:#333}.center-button{text-align:center}@media (max-width:768px){.classes-preview-section{padding:2rem 1rem}.classes-preview-section .section-header{align-items:flex-start;flex-direction:column;gap:.5rem}.classes-grid{gap:1.5rem;grid-template-columns:1fr}.class-card{height:350px}.class-overlay{padding:1.5rem}.class-content h3{font-size:1.5rem}.class-meta{align-items:flex-start;flex-direction:column;gap:.5rem}}@media (max-width:480px){.classes-preview-section h3{font-size:1.3rem}.class-card{height:300px}.class-overlay{padding:1.25rem}.class-content h3{font-size:1.3rem}.class-description{font-size:.9rem}}.class-meta .instructor{font-size:.9rem;font-style:italic;opacity:.7}.class-meta{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.class-level,.class-meta .instructor,.class-price{font-size:.9rem;font-weight:500;opacity:.8}@media (max-width:768px){.class-meta{align-items:flex-start;flex-direction:column;gap:.5rem}}.agenda-page{min-height:70vh}.agenda-header{background:#f8f8f8;padding:3rem 2rem;text-align:center}.agenda-header h1{font-family:Georgia,serif;font-size:2.5rem;font-weight:300;margin-bottom:.5rem}.agenda-content{margin:0 auto;max-width:800px;padding:3rem 2rem}.month-section{margin-bottom:4rem}.month-title{border-bottom:1px solid #eee;color:#333;font-size:1.8rem;font-weight:400;margin-bottom:2rem;padding-bottom:.5rem}.events-list{display:flex;flex-direction:column;gap:1.5rem}.event-item{border:1px solid #eee;display:flex;gap:1.5rem;padding:1.5rem;transition:border-color .2s ease}.event-date{flex-shrink:0}.date-box{align-items:center;background:#f8f8f8;border-radius:4px;display:flex;flex-direction:column;height:70px;justify-content:center;width:70px}.date-day{font-size:1.8rem;font-weight:300}.date-month{color:#666;font-size:.9rem;letter-spacing:1px;text-transform:uppercase}.event-details h3{font-size:1.3rem;font-weight:400;line-height:1.4;margin-bottom:.5rem}.event-meta{margin-bottom:.75rem}.event-description{color:#555;font-size:.95rem;line-height:1.6}.current-month{background:#f8f8f8;margin-top:3rem;padding:3rem 2rem}.current-month h3{font-size:1.5rem;font-weight:400;margin-bottom:2rem;text-align:center}.current-events{display:flex;flex-wrap:wrap;gap:3rem;justify-content:center}.current-event{background:#fff;border:1px solid #eee;max-width:300px;padding:1.5rem 2rem;text-align:center}.current-event h4{font-size:1.1rem;font-weight:400;margin-bottom:.5rem}.current-event p{color:#666;font-size:.9rem}@media (max-width:768px){.agenda-header{padding:2rem 1rem}.agenda-header h1{font-size:2rem}.agenda-content{padding:2rem 1rem}.month-title{font-size:1.5rem}.event-item{flex-direction:column;gap:1rem;padding:1.25rem}.date-box{flex-direction:row;gap:1rem;height:auto;justify-content:flex-start;padding:.75rem 1rem;width:100%}.date-day{font-size:1.3rem}.current-month{padding:2rem 1rem}.current-events{align-items:center;flex-direction:column;gap:1.5rem}.current-event{max-width:none;width:100%}}.empty-subtext{color:#888;font-size:.9rem;font-style:italic;margin-top:.5rem}.event-item{cursor:pointer}.event-item:hover{background-color:#fafafa;border-color:#ddd}.event-item.expanded{background-color:#f8f9ff;border-color:#8a4fff;box-shadow:0 5px 20px #8a4fff1a}.event-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.5rem}.expand-icon{align-items:center;background:#f0f0f0;border-radius:50%;color:#666;display:flex;flex-shrink:0;font-size:1.2rem;font-weight:600;height:24px;justify-content:center;margin-left:1rem;transition:all .3s ease;width:24px}.event-item.expanded .expand-icon{background:#8a4fff;color:#fff;transform:rotate(180deg)}.event-description.preview{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:#666;display:-webkit-box;font-size:.95rem;line-height:1.5;margin-top:.75rem;max-height:4.5em;overflow:hidden;text-overflow:ellipsis}.event-description.full{color:#555;font-size:1rem;line-height:1.6}.event-description.full,.expanded-content{border-top:1px solid #eee;margin-top:1rem;padding-top:1rem}.expanded-content{animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.view-more-btn{background:#8a4fff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.view-more-btn:hover{background:#7640e5;box-shadow:0 5px 15px #8a4fff33;transform:translateY(-2px)}@media (max-width:768px){.event-header{align-items:center}.expand-icon{font-size:1.3rem;height:28px;width:28px}.event-details-grid{gap:1rem;grid-template-columns:1fr;padding:1rem}.view-more-btn{padding:1rem;width:100%}.event-description.preview{-webkit-line-clamp:2;max-height:3em}}.no-website-message{background:#f8f9ff;border:1px solid #e6e9ff;border-radius:6px;color:#666;font-size:.9rem;padding:1rem;text-align:center}.event-item.has-image{border-left:3px solid #8a4fff}.event-title-wrapper{align-items:center;display:flex;gap:.5rem}.image-indicator{color:#8a4fff;cursor:help;font-size:1rem;opacity:.8}.collapsed-content{align-items:flex-start;display:flex;gap:1.5rem;margin-top:.75rem}.collapsed-content .event-description.preview{flex:1 1;margin-top:0}.event-image-preview{border:2px solid #0000;border-radius:6px;cursor:pointer;flex-shrink:0;height:100px;overflow:hidden;transition:all .3s ease;width:100px}.event-image-preview:hover{border-color:#8a4fff;transform:scale(1.05)}.preview-image{display:block;height:100%;object-fit:cover;width:100%}.event-image-expanded{background:#fff;border:1px solid #eee;border-radius:8px;margin:1.5rem 0;padding:1.5rem;text-align:center}.expanded-image{border-radius:6px;box-shadow:0 5px 15px #0000001a;display:block;height:auto;margin:0 auto;max-height:400px;max-width:100%;width:auto}.image-caption{color:#666;font-size:.9rem;font-style:italic;margin-top:1rem;text-align:center}.event-details-grid{grid-gap:1rem;background:#fff;border:1px solid #eee;border-radius:8px;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:1.5rem 0;padding:1.5rem}.detail-item{gap:.25rem}.detail-label{font-size:.85rem;letter-spacing:.5px;text-transform:uppercase}.detail-value{font-weight:500}@media (max-width:768px){.collapsed-content{flex-direction:column;gap:1rem}.event-image-preview{height:150px;order:-1;width:100%}.event-title-wrapper{align-items:flex-start;flex-direction:column;gap:.25rem}.image-indicator{align-self:flex-start}.expanded-image{max-height:300px}.event-details-grid{grid-template-columns:1fr;padding:1rem}}@media (max-width:480px){.event-image-preview{height:120px}.expanded-image{max-height:250px}.event-image-expanded{margin:1rem 0;padding:1rem}}.event-actions{border-top:1px solid #eee;margin-top:1.5rem;padding-top:1rem}.action-buttons-row{display:flex;flex-wrap:wrap;gap:1rem}.ticket-btn{align-items:center;background:#00b894;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;flex:1 1;font-size:.95rem;font-weight:600;gap:.5rem;justify-content:center;min-width:200px;padding:.75rem 1.5rem;transition:all .3s ease}.ticket-btn:hover{background:#00a085;box-shadow:0 5px 15px #00b89433;transform:translateY(-2px)}.save-event-btn{align-items:center;background:#8a4fff;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;flex:1 1;font-size:.95rem;font-weight:600;gap:.5rem;justify-content:center;min-width:200px;padding:.75rem 1.5rem;transition:all .3s ease}.save-event-btn:disabled{cursor:not-allowed;opacity:.7}.save-event-btn:not(:disabled):hover{box-shadow:0 5px 15px #8a4fff33;transform:translateY(-2px)}.save-event-btn.saved{background:#0984e3}.save-event-btn.saved:hover{background:#0770c4;box-shadow:0 5px 15px #0984e333}.save-event-btn .icon{font-size:1.1rem;font-weight:700}.login-hint{background:#f8f9ff;border:1px solid #e6e9ff;border-radius:4px;color:#666;font-size:.9rem;margin-top:1rem;padding:.75rem;text-align:center}.website-link{color:#0984e3;font-weight:600;transition:color .2s ease}.website-link:hover{color:#0770c4;text-decoration:underline}@media (max-width:768px){.action-buttons-row{flex-direction:column}.save-event-btn,.ticket-btn{justify-content:center;min-width:100%;width:100%}.event-details-grid{grid-template-columns:1fr}}@media (max-width:480px){.save-event-btn,.ticket-btn{font-size:.9rem;padding:1rem}.login-hint{font-size:.85rem}}.event-item{scroll-margin-top:20px;transition:all .3s ease}.event-item.expanded{animation:highlight-pulse 2s ease}@keyframes highlight-pulse{0%{box-shadow:0 0 0 0 #8a4fffb3}70%{box-shadow:0 0 0 10px #8a4fff00}to{box-shadow:0 0 0 0 #8a4fff00}}.home-classes-section{background:#fff;padding:3rem 2rem}.home-classes-section .home-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.home-classes-section h3{color:#333;font-size:1.5rem;font-weight:400;margin:0}.home-classes-section .home-view-all{color:#666;font-size:.9rem;text-decoration:none}.home-classes-section .home-view-all:hover{color:#000}.home-classes-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:2rem}.home-class-card{background:#fafafa;border:1px solid #eee;border-radius:8px;padding:1.5rem;transition:border-color .2s ease}.home-class-card:hover{border-color:#ccc}.home-class-header{margin-bottom:1rem}.home-class-title-wrapper h4{color:#333;font-size:1.1rem;font-weight:400;margin-bottom:.25rem}.home-class-schedule{color:#333;font-size:.85rem}.home-class-description{margin-bottom:1rem}.home-class-description p{color:#555;font-size:.9rem;line-height:1.4}.home-class-details{border-top:1px solid #eee;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem;padding-top:1rem}.home-class-detail-item{display:flex;justify-content:space-between}.home-class-detail-label{color:#666;font-size:.8rem;font-weight:500}.home-class-detail-value{color:#333;font-size:.9rem;font-weight:500}.home-class-actions{margin-top:auto}.home-class-view-btn{background:#000;border:none;border-radius:4px;color:#fff;cursor:pointer;display:block;font-size:.9rem;padding:.75rem;text-align:center;text-decoration:none;transition:background .2s ease;width:100%}.home-class-view-btn:hover{background:#333}.home-classes-button{background:#000;border-radius:4px;color:#fff;display:inline-block;font-size:.9rem;padding:.75rem 1.5rem;text-decoration:none;transition:background .2s ease}.home-classes-button:hover{background:#333}.home-center-button{text-align:center}@media (max-width:768px){.home-classes-section{padding:2rem 1rem}.home-classes-section .home-section-header{align-items:flex-start;flex-direction:column;gap:.5rem}.home-classes-grid{gap:1rem;grid-template-columns:1fr}.home-class-card{padding:1.25rem}}@media (max-width:480px){.home-classes-section h3{font-size:1.3rem}}and this is the css that i want to copycat here .classes-page{min-height:70vh}.classes-header{background:#f8f8f8;padding:3rem 2rem;text-align:center}.classes-header h1{font-family:Georgia,serif;font-size:2.5rem;font-weight:300;margin-bottom:.5rem}.subtitle{color:#666;font-size:1.1rem}.classes-content{padding:3rem 2rem}.container{margin:0 auto;max-width:1200px}.classes-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.class-card{border-radius:4px;color:#fff;display:block;height:400px;overflow:hidden;position:relative;text-decoration:none;transition:transform .3s ease}.class-card:hover{box-shadow:0 10px 30px #0003;transform:translateY(-5px)}.class-overlay{background:linear-gradient(#0000,#000000e6);bottom:0;color:#fff;display:flex;flex-direction:column;justify-content:flex-end;left:0;min-height:60%;padding:2rem;position:absolute;right:0}.class-content h3{font-size:1.8rem;font-weight:400;line-height:1.2;margin-bottom:.5rem}.class-schedule{font-size:1rem;letter-spacing:.5px;margin-bottom:1rem}.class-description{font-size:.95rem;line-height:1.5;margin-bottom:1.5rem;opacity:.8}.class-footer{align-items:center;border-top:1px solid #fff3;display:flex;justify-content:space-between;padding-top:1rem}.instructor{font-size:.9rem;font-style:italic;opacity:.7}.class-card.dance{background-color:#8a4fff}.class-card.painting{background-color:#ff6b6b}.class-card.yoga{background-color:#4ecdc4}.class-card.photography{background-color:#45b7d1}.class-card.writing{background-color:#96ceb4}.class-card.ceramics{background-color:#feca57}.class-card.dance{background:linear-gradient(#0000004d,#000000b3),url(https://images.unsplash.com/photo-1519895609939-d2a6491c1196?ixlib=rb-1.2.1&auto=format&fit=crop&w=800&q=80)}.class-card.painting{background:linear-gradient(#0000004d,#000000b3),url(https://images.unsplash.com/photo-1579965342577-2c9d4ef5d0b8?ixlib=rb-1.2.1&auto=format&fit=crop&w=800&q=80)}.class-card.yoga{background:linear-gradient(#0000004d,#000000b3),url(https://images.unsplash.com/photo-1544367567-0f2fcb009e0b?ixlib=rb-1.2.1&auto=format&fit=crop&w=800&q=80)}.class-card.photography{background:linear-gradient(#0000004d,#000000b3),url(https://images.unsplash.com/photo-1518837695005-2083093ee35b?ixlib=rb-1.2.1&auto=format&fit=crop&w=800&q=80)}.class-card.writing{background:linear-gradient(#0000004d,#000000b3),url(https://images.unsplash.com/photo-1455390582262-044cdead277a?ixlib=rb-1.2.1&auto=format&fit=crop&w=800&q=80)}.class-card.ceramics{background:linear-gradient(#0000004d,#000000b3),url(https://images.unsplash.com/photo-1574323347407-f5e1ad6d020b?ixlib=rb-1.2.1&auto=format&fit=crop&w=800&q=80)}.classes-info{background:#f8f8f8;padding:4rem 2rem}.info-grid{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:0 auto;max-width:900px}.info-item{text-align:center}.info-item h3{color:#333;font-size:1.3rem;font-weight:400;margin-bottom:1rem}.info-item p{color:#666;font-size:.95rem;line-height:1.6}@media (max-width:768px){.classes-header{padding:2rem 1rem}.classes-header h1{font-size:2rem}.classes-content{padding:2rem 1rem}.classes-grid{gap:1.5rem;grid-template-columns:1fr}.class-card{height:350px}.class-overlay{padding:1.5rem}.class-content h3{font-size:1.5rem}.classes-info{padding:3rem 1rem}.info-grid{gap:2rem;grid-template-columns:1fr}}.loading-spinner{display:inline-block}.retry-btn{background:#8a4fff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;margin-top:1rem;padding:.75rem 1.5rem;transition:all .3s ease}.retry-btn:hover{background:#7640e5;transform:translateY(-2px)}.empty-state{padding:4rem}.empty-state p{margin-bottom:.5rem}.class-card.default{background-color:#45b7d1}.class-card{background-position:50%;background-repeat:no-repeat;background-size:cover}.class-card:before{background:linear-gradient(180deg,#0000 0,#0000 50%,#0000004d 70%,#000000b3);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:1}.class-content{position:relative;z-index:2}.class-detail-page{min-height:70vh}.detail-header{background-position:50%;background-size:cover;height:400px;position:relative}.detail-header.dance{background:linear-gradient(#0009,#0009),url(https://images.unsplash.com/photo-1519895609939-d2a6491c1196?ixlib=rb-1.2.1&auto=format&fit=crop&w=1600&q=80)}.detail-header.painting{background:linear-gradient(#0009,#0009),url(https://images.unsplash.com/photo-1579965342577-2c9d4ef5d0b8?ixlib=rb-1.2.1&auto=format&fit=crop&w=1600&q=80)}.header-overlay{align-items:center;background-color:grey;bottom:0;color:#fff;display:flex;left:0;position:absolute;right:0;top:0}.detail-header h1{font-family:Georgia,serif;font-size:3rem;font-weight:300;margin:1rem 0 .5rem}.class-schedule{font-size:1.2rem;opacity:.9}.back-link{color:#fff;display:inline-block;font-size:.9rem;margin-bottom:1rem;opacity:.8;text-decoration:none}.back-link:hover{opacity:1}.detail-content{padding:4rem 2rem}.detail-grid{grid-gap:4rem;display:grid;gap:4rem;grid-template-columns:2fr 1fr;margin:0 auto;max-width:1200px}.main-info{display:flex;flex-direction:column;gap:4rem}.info-section h2{color:#333;font-size:1.8rem;font-weight:300;margin-bottom:1.5rem}.info-section p{color:#555;font-size:1.05rem;line-height:1.7}.gallery-section h2{color:#333;font-size:1.8rem;font-weight:300;margin-bottom:1.5rem}.gallery-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr);margin-top:1rem}.gallery-item{aspect-ratio:1;border-radius:8px;transition:transform .3s ease}.gallery-item:hover{transform:scale(1.03)}.gallery-item img{display:block;height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.gallery-item:hover img{transform:scale(1.05)}.sidebar{align-self:start;display:flex;flex-direction:column;gap:2rem;position:-webkit-sticky;position:sticky;top:2rem}.info-card{background:#fafafa;border:1px solid #eee;border-radius:8px;padding:2rem}.info-card h3{border-bottom:1px solid #eee;color:#333;font-size:1.3rem;font-weight:400;margin-bottom:1.5rem;padding-bottom:.75rem}.detail-item{display:flex;flex-direction:column;margin-bottom:1.25rem}.detail-item:last-child{margin-bottom:0}.detail-label{color:#666;font-size:.9rem;font-weight:600;margin-bottom:.25rem}.detail-value{color:#333;font-size:1rem}.instructor-card .instructor-info{display:flex;flex-direction:column;gap:1.5rem}.instructor-image{border:3px solid #fff;border-radius:50%;box-shadow:0 5px 15px #0000001a;height:120px;margin:0 auto;overflow:hidden;width:120px}.instructor-image img{display:block;height:100%;object-fit:cover;width:100%}.instructor-details{text-align:center}.instructor-details h4{color:#333;font-size:1.2rem;font-weight:400;margin-bottom:.75rem}.instructor-details p{color:#666;font-size:.95rem;line-height:1.6}.contact-card h3{margin-bottom:1rem}.contact-info p{color:#666;font-size:.95rem;line-height:1.5;margin-bottom:1.5rem}.contact-methods{display:flex;flex-direction:column;gap:1rem}.contact-method{color:#555;font-size:.95rem;gap:.75rem}.contact-icon,.contact-method{align-items:center;display:flex}.contact-icon{background:#f0f0f0;border-radius:50%;font-size:1.2rem;height:30px;justify-content:center;width:30px}@media (max-width:1024px){.detail-grid{gap:3rem;grid-template-columns:1fr}.detail-header{height:300px}.detail-header h1{font-size:2.5rem}.sidebar{position:static}}@media (max-width:768px){.detail-header{height:250px}.detail-header h1{font-size:2rem}.detail-content{padding:2rem 1rem}.gallery-section h2,.info-section h2{font-size:1.5rem}.gallery-grid{gap:.75rem;grid-template-columns:1fr}.gallery-item{aspect-ratio:16/9}.instructor-info{flex-direction:column;text-align:center}.info-card{padding:1.5rem}}.lightbox{align-items:center;animation:fadeIn .3s ease;background:#000000f2;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.lightbox-content{animation:slideUp .3s ease;background:#0000;max-height:90vh;max-width:1200px;position:relative;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.lightbox-close{align-items:center;background:none;border:none;color:#fff;cursor:pointer;display:flex;font-size:2.5rem;height:40px;justify-content:center;padding:0;position:absolute;right:0;top:-40px;transition:transform .2s ease;width:40px;z-index:1001}.lightbox-close:hover{transform:scale(1.2)}.lightbox-image-container{align-items:center;border-radius:8px;display:flex;height:70vh;justify-content:center;margin-bottom:1rem;overflow:hidden;position:relative;width:100%}.lightbox-image{display:block;max-height:100%;max-width:100%;object-fit:contain}.lightbox-nav{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:2.5rem;height:60px;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s ease;width:60px}.lightbox-nav:hover{background:#ffffff4d;transform:translateY(-50%) scale(1.1)}.lightbox-nav.prev{left:20px}.lightbox-nav.next{right:20px}.lightbox-caption{color:#fff;font-size:1rem;margin-bottom:1.5rem;opacity:.8;text-align:center}.lightbox-thumbnails{display:flex;gap:.5rem;justify-content:center;max-width:100%;overflow-x:auto;padding:1rem}.thumbnail{border:2px solid #0000;border-radius:4px;cursor:pointer;flex-shrink:0;height:80px;opacity:.6;overflow:hidden;transition:all .3s ease;width:80px}.thumbnail:hover{opacity:.8}.thumbnail.active{border-color:#8a4fff;opacity:1;transform:scale(1.05)}.thumbnail img{display:block;height:100%;object-fit:cover;width:100%}.gallery-item{cursor:pointer;overflow:hidden;position:relative}.gallery-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.gallery-item:hover .gallery-overlay{opacity:1}.zoom-icon{color:#fff;font-size:2rem;transform:scale(.8);transition:transform .3s ease}.gallery-item:hover .zoom-icon{transform:scale(1)}@media (max-width:768px){.lightbox-content{max-height:85vh;width:95%}.lightbox-image-container{height:60vh}.lightbox-nav{font-size:2rem;height:50px;width:50px}.lightbox-nav.prev{left:10px}.lightbox-nav.next{right:10px}.lightbox-close{right:50%;top:-50px;transform:translateX(50%)}.thumbnail{height:60px;width:60px}.lightbox-thumbnails{padding:.5rem}}@media (max-width:480px){.lightbox-image-container{height:50vh}.lightbox-nav{font-size:1.5rem;height:40px;width:40px}.thumbnail{height:50px;width:50px}}.loading-state{min-height:70vh;padding:4rem}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#8a4fff;height:50px;margin-bottom:1rem;width:50px}.error-state{align-items:center;color:#ff6b6b;display:flex;flex-direction:column;justify-content:center;min-height:70vh;padding:4rem;text-align:center}.error-state .back-link{color:#8a4fff;font-weight:600;margin-top:1rem;text-decoration:none}.error-state .back-link:hover{text-decoration:underline}.detail-header.default{background:linear-gradient(#0009,#0009),#45b7d1}.action-card{background:linear-gradient(135deg,#f9f5ff,#f3e9ff);border:1px solid #8a4fff}.action-description{color:#666;font-size:.95rem;line-height:1.5;margin-bottom:1.5rem}.save-class-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:.75rem;justify-content:center;margin-bottom:.5rem;padding:1rem 1.5rem;transition:all .3s ease;width:100%}.save-class-btn:not(:disabled):hover{box-shadow:0 5px 15px #8a4fff33;transform:translateY(-2px)}.save-class-btn:disabled{cursor:not-allowed;opacity:.7}.save-class-btn{background:#8a4fff;color:#fff}.save-class-btn .icon{font-size:1.2rem;font-weight:700}.save-class-btn.saved{background:#00b894;color:#fff}.save-class-btn.saved .icon{font-size:1.2rem}.spinner-small{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:18px;width:18px}.login-prompt{color:#666;font-size:.9rem;margin-top:.5rem;text-align:center}.login-prompt a{color:#8a4fff;font-weight:500;text-decoration:none}.login-prompt a:hover{text-decoration:underline}.action-buttons{display:flex;flex-direction:column;gap:1rem}.enroll-btn{background:#0984e3;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:1rem 1.5rem;text-align:center;text-decoration:none;transition:all .3s ease;width:100%}.enroll-btn:hover{background:#0770c4;box-shadow:0 5px 15px #0984e333;transform:translateY(-2px)}@media (max-width:768px){.save-class-btn{font-size:.95rem;padding:.875rem 1.25rem}.action-description{font-size:.9rem}}.admin-login{align-items:center;display:flex;justify-content:center;min-height:70vh;padding:2rem}.login-container{box-shadow:0 5px 20px #0000001a;max-width:400px}.login-container h2{color:#333;font-size:1.8rem;font-weight:300;margin-bottom:.5rem}.login-container p{color:#666;font-size:.9rem;margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-group input{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem 1rem;transition:border-color .2s;width:100%}.form-group input:focus{border-color:#8a4fff;outline:none}button{background:#8a4fff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem;transition:background-color .2s;width:100%}button:hover:not(:disabled){background:#7640e5}button:disabled{cursor:not-allowed;opacity:.5}.error-message{color:#ff6b6b;font-size:.9rem;margin-bottom:1rem;text-align:center}.admin-dashboard{background:#f8f8f8;min-height:70vh;padding:2rem}.dashboard-header{margin-bottom:3rem;text-align:center}.dashboard-content{grid-template-columns:1fr 2fr;margin:0 auto;max-width:1200px}.event-form-section{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:2rem}.event-form-section h2{color:#333;font-size:1.5rem;font-weight:300;margin-bottom:1.5rem}.event-form{display:flex;flex-direction:column;gap:1.5rem}.form-group label{color:#555;display:block;margin-bottom:.5rem}.form-group input,.form-group textarea{font-size:1rem;transition:border-color .2s;width:100%}.submit-btn{background:#8a4fff;font-size:1rem}.submit-btn:hover{background:#7640e5}.cancel-btn{font-size:1rem}.events-list-section{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:2rem}.events-list-section h2{color:#333;font-size:1.5rem;font-weight:300;margin-bottom:1.5rem}.loading,.no-events{color:#666;font-style:italic;padding:2rem;text-align:center}.events-table{border:1px solid #eee;border-radius:4px;overflow:hidden}.table-header{grid-template-columns:1.5fr 2fr 1fr 1.5fr}.table-cell{border-right:1px solid #eee}.table-cell:last-child{border-right:none}.table-row{grid-template-columns:1.5fr 2fr 1fr 1.5fr}.table-row:hover{background:#fafafa}.table-cell.date{color:#666;font-size:.9rem}.table-cell.time{color:#666}.delete-btn,.edit-btn{border-radius:3px;padding:.25rem .75rem}.edit-btn{background:#4ecdc4}.edit-btn:hover{background:#3db8af}@media (max-width:768px){.admin-dashboard{padding:1rem}.form-row,.table-header,.table-row{grid-template-columns:1fr}.table-cell,.table-header,.table-row{padding:.5rem}.table-cell{border-bottom:1px solid #eee;border-right:none}.table-cell:last-child{border-bottom:none}.table-cell.actions{justify-content:flex-start}}.table-header,.table-row{grid-template-columns:1.5fr 2fr .8fr .8fr 1.5fr}.table-cell.duration{color:#666;font-size:.9rem}@media (max-width:1024px){.dashboard-content{grid-template-columns:1fr}.table-header,.table-row{grid-template-columns:1.2fr 1.5fr .7fr .7fr 1.2fr}}@media (max-width:768px){.admin-dashboard{padding:1rem}.form-row,.table-header,.table-row{grid-template-columns:1fr}.table-cell,.table-header,.table-row{padding:.5rem}.table-cell{border-bottom:1px solid #eee;border-right:none;display:flex;justify-content:space-between}.table-cell:before{color:#555;content:attr(data-label);font-weight:600;margin-right:1rem}.table-cell:last-child{border-bottom:none}.table-cell.actions{justify-content:flex-start}}.website-link{color:#8a4fff;display:inline-block;font-size:1.2rem;padding:.25rem;text-decoration:none;transition:all .2s ease}.website-link:hover{color:#7640e5;transform:scale(1.2)}.field-hint{color:#666;display:block;margin-top:.25rem}.table-header,.table-row{grid-template-columns:1.5fr 2fr .8fr .5fr 1.5fr}.table-cell.website{align-items:center;display:flex;justify-content:center}@media (max-width:1200px){.table-header,.table-row{grid-template-columns:1.2fr 1.5fr .7fr .4fr 1.2fr}}@media (max-width:768px){.admin-dashboard{padding:1rem}.form-row,.table-header,.table-row{grid-template-columns:1fr}.table-cell,.table-header,.table-row{padding:.5rem}.table-cell{align-items:center;border-bottom:1px solid #eee;border-right:none;display:flex;justify-content:space-between}.table-cell:before{color:#555;content:attr(data-label);font-weight:600;margin-right:1rem}.table-cell:last-child{border-bottom:none}.table-cell.actions{justify-content:flex-start}.table-cell.date:before{content:"Fecha:"}.table-cell.title:before{content:"Título:"}.table-cell.time:before{content:"Hora:"}.table-cell.website:before{content:"Web:"}.table-cell.actions:before{content:"Acciones:"}}.table-cell.image{text-align:center}.image-link{color:#8a4fff;cursor:help;display:inline-block;font-size:1.2rem;padding:.25rem;transition:transform .2s ease}.image-link:hover{transform:scale(1.2)}.table-header{background:#f8f8f8;color:#555}.table-header,.table-row{grid-template-columns:1.5fr 2fr .8fr .5fr .5fr 1.5fr}.table-row{transition:background-color .2s}@media (max-width:1200px){.table-header,.table-row{grid-template-columns:1.2fr 1.5fr .7fr .4fr .4fr 1.2fr}}@media (max-width:768px){.admin-dashboard{padding:1rem}.form-row,.table-header,.table-row{grid-template-columns:1fr}.table-cell,.table-header,.table-row{padding:.5rem}.table-cell{align-items:center;border-bottom:1px solid #eee;border-right:none;display:flex;justify-content:space-between}.table-cell:before{color:#555;content:attr(data-label);font-weight:600;margin-right:1rem}.table-cell:last-child{border-bottom:none}.table-cell.actions{justify-content:flex-start}.table-cell.date:before{content:"Fecha:"}.table-cell.title:before{content:"Título:"}.table-cell.time:before{content:"Hora:"}.table-cell.website:before{content:"Web:"}.table-cell.image:before{content:"Imagen:"}.table-cell.actions:before{content:"Acciones:"}}.highlight-btn{align-items:center;background:none;border:none;color:#ccc;cursor:pointer;display:flex;font-size:1.5rem;height:30px;justify-content:center;padding:0;transition:all .2s ease;width:30px}.highlight-btn:hover{transform:scale(1.2)}.highlight-btn.active{color:gold}.checkbox-group{margin:1rem 0}.checkbox-label{align-items:center;color:#333;cursor:pointer;display:flex;font-weight:500;margin-bottom:.25rem}.checkbox-input{display:none}.checkbox-custom{border:2px solid #8a4fff;border-radius:4px;height:20px;margin-right:10px;position:relative;transition:all .2s ease;width:20px}.checkbox-input:checked+.checkbox-custom{background-color:#8a4fff}.checkbox-input:checked+.checkbox-custom:after{color:#fff;content:"✓";font-size:14px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.checkbox-text{font-size:1rem}.table-cell.highlighted{min-width:80px;text-align:center}@media (max-width:768px){.table-cell.highlighted{min-width:60px}.highlight-btn{font-size:1.3rem;height:25px;width:25px}}.section-toggle .toggle-status{background:#e6e9ff;color:#8a4fff}.visibility-toggle.active~.toggle-description{color:#00b894}.visibility-toggle.inactive~.toggle-description{color:#ff6b6b}.classes-dashboard{background:#f8f8f8;min-height:100vh;padding:2rem}.dashboard-header{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem;padding:2rem}.dashboard-header h1{color:#333;font-family:Georgia,serif;font-size:2rem;font-weight:300;margin-bottom:.5rem}.dashboard-header p{color:#666;font-size:1rem;margin-bottom:1.5rem}.section-toggle{background:#f8f9ff;border:1px solid #e6e9ff;border-radius:8px;margin-top:1.5rem;max-width:500px;padding:1.5rem}.toggle-label{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.toggle-title{color:#333;font-size:1rem;font-weight:600}.toggle-status{background:#e6e9ff;border-radius:12px;color:#8a4fff;font-size:.85rem;font-weight:500;padding:.25rem .75rem}.visibility-toggle{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.75rem;justify-content:center;padding:1rem;transition:all .3s ease;width:100%}.visibility-toggle.active{background:#00b894;color:#fff}.visibility-toggle.active:hover{background:#00a085;box-shadow:0 5px 15px #00b89433;transform:translateY(-2px)}.visibility-toggle.inactive{background:#ff6b6b;color:#fff}.visibility-toggle.inactive:hover{background:#ff5252;box-shadow:0 5px 15px #ff6b6b33;transform:translateY(-2px)}.visibility-toggle:disabled{cursor:not-allowed;opacity:.7;transform:none!important}.toggle-icon{font-size:1.2rem}.toggle-text{font-size:.95rem}.toggle-description{border-top:1px solid #e6e9ff;color:#666;font-size:.9rem;line-height:1.4;margin-top:1rem;padding-top:1rem}.toggle-spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}.dashboard-content{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:1fr 1fr}@media (max-width:1024px){.dashboard-content{grid-template-columns:1fr}}.class-form-section,.classes-list-section{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:2rem}.class-form-section h2,.classes-list-section h2{border-bottom:1px solid #eee;color:#333;font-size:1.5rem;font-weight:400;margin-bottom:1.5rem;padding-bottom:1rem}.class-form{display:flex;flex-direction:column;gap:1.5rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}@media (max-width:768px){.form-row{grid-template-columns:1fr}}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:#333;font-size:.9rem;font-weight:500}.form-group input,.form-group textarea{border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:.95rem;padding:.75rem;transition:border-color .2s ease}.form-group input:focus,.form-group textarea:focus{border-color:#8a4fff;outline:none}.form-group textarea{min-height:80px;resize:vertical}.field-hint{color:#888;font-size:.8rem;font-style:italic}.gallery-input{display:flex;gap:.5rem}.gallery-url-input{flex:1 1}.add-gallery-btn{background:#8a4fff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;padding:.75rem 1rem;transition:background .2s ease;width:50px}.add-gallery-btn:hover{background:#7640e5}.gallery-preview{margin-top:1rem}.gallery-preview h4{color:#666;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.gallery-list{display:flex;flex-direction:column;gap:.5rem}.gallery-item{align-items:center;background:#f8f9ff;border:1px solid #e6e9ff;border-radius:4px;display:flex;justify-content:space-between;padding:.5rem}.gallery-url{color:#666;font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.remove-gallery-btn{align-items:center;background:#ff6b6b;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1rem;height:24px;justify-content:center;transition:background .2s ease;width:24px}.remove-gallery-btn:hover{background:#ff5252}.form-actions{display:flex;gap:1rem;margin-top:1rem}.submit-btn{background:#000;border:none;border-radius:4px;color:#fff;cursor:pointer;flex:1 1;font-size:.9rem;font-weight:600;padding:.75rem 1.5rem;transition:background .2s ease}.submit-btn:hover{background:#333}.cancel-btn{background:#666;border:none;border-radius:4px;color:#fff;cursor:pointer;flex:1 1;font-size:.9rem;font-weight:600;padding:.75rem 1.5rem;transition:background .2s ease}.cancel-btn:hover{background:#555}.classes-table{border:1px solid #eee;border-radius:8px;overflow:hidden}.table-header{background:#f8f9ff;color:#333;font-size:.85rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.table-header,.table-row{border-bottom:1px solid #eee;grid-template-columns:2fr 1.5fr 1fr 1fr 1.5fr 1fr;padding:1rem}.table-row{align-items:center;transition:background .2s ease}.table-row:hover{background:#f8f9ff}.table-cell{color:#333;font-size:.9rem;padding:.5rem}.table-cell.title{font-weight:500}.table-cell.actions{display:flex;gap:.5rem}.delete-btn,.edit-btn{border:none;border-radius:4px;cursor:pointer;font-size:.85rem;padding:.5rem 1rem;transition:all .2s ease}.edit-btn{background:#8a4fff;color:#fff}.edit-btn:hover{background:#7640e5}.delete-btn{background:#ff6b6b;color:#fff}.delete-btn:hover{background:#ff5252}.loading,.no-classes{color:#666;font-size:1rem;padding:3rem;text-align:center}@media (max-width:768px){.classes-dashboard{padding:1rem}.class-form-section,.classes-list-section,.dashboard-header{padding:1.5rem}.table-header,.table-row{gap:.5rem;grid-template-columns:1fr}.table-cell.actions{justify-content:flex-start}}.login-page{align-items:center;background:#f8f8f8;display:flex;justify-content:center;min-height:70vh;padding:2rem}.login-container{background:#fff;border-radius:8px;box-shadow:0 2px 20px #0000000d;max-width:500px;padding:3rem;width:100%}.login-header{margin-bottom:2.5rem;text-align:center}.login-header h1{color:#333;font-family:Georgia,serif;font-size:2rem;font-weight:400;margin-bottom:.5rem}.login-header p{color:#666;font-size:1rem}.login-options{margin-bottom:2.5rem}.google-login-section{margin-bottom:2rem}.google-login-section h3{color:#333;font-size:1.2rem;font-weight:400;margin-bottom:.75rem}.login-description{color:#666;font-size:.95rem;line-height:1.5;margin-bottom:1.5rem}.google-login-btn{align-items:center;background:#fff;border:1px solid #ddd;border-radius:4px;color:#333;cursor:pointer;display:flex;font-size:1rem;gap:.75rem;justify-content:center;padding:1rem 1.5rem;transition:all .2s ease;width:100%}.google-login-btn:hover{background:#f8f8f8;border-color:#ccc}.google-icon{align-items:center;background:#4285f4;border-radius:50%;color:#fff;display:flex;font-size:.9rem;font-weight:700;height:24px;justify-content:center;width:24px}.login-info{background:#f8f8f8;border-left:3px solid #8a4fff;border-radius:4px;padding:1.5rem}.login-info h4{color:#333;font-size:1.1rem;font-weight:400;margin-bottom:1rem}.login-info ul{list-style:none;padding:0}.login-info li{color:#666;font-size:.95rem;margin-bottom:.5rem;padding-left:1.2rem;position:relative}.login-info li:before{color:#8a4fff;content:"✓";left:0;position:absolute}.login-footer{border-top:1px solid #eee;padding-top:1.5rem;text-align:center}.login-footer p{color:#888;font-size:.9rem;line-height:1.5}.login-footer a{color:#666;text-decoration:none}.login-footer a:hover{color:#000;text-decoration:underline}@media (max-width:768px){.login-page{padding:1rem}.login-container{padding:2rem}.login-header h1{font-size:1.8rem}}@media (max-width:480px){.login-container{padding:1.5rem}.login-header h1{font-size:1.6rem}}.profile-page{background:#f8f8f8;min-height:70vh;padding:2rem}.profile-container{background:#fff;border-radius:8px;box-shadow:0 2px 20px #0000000d;margin:0 auto;max-width:800px;padding:2.5rem}.profile-header{border-bottom:1px solid #eee;margin-bottom:3rem;padding-bottom:2rem;text-align:center}.profile-header h1{color:#333;font-family:Georgia,serif;font-size:2.2rem;font-weight:400;margin-bottom:.5rem}.profile-header p{color:#666;font-size:1.1rem}.profile-info{align-items:center;border-bottom:1px solid #eee;display:flex;gap:2rem;margin-bottom:3rem;padding-bottom:2rem}.profile-avatar{flex-shrink:0}.profile-avatar img{border:3px solid #f8f8f8;border-radius:50%;height:100px;object-fit:cover;width:100px}.avatar-placeholder{align-items:center;background:#8a4fff;border-radius:50%;color:#fff;display:flex;font-size:2.5rem;font-weight:300;height:100px;justify-content:center;width:100px}.profile-details{flex:1 1}.profile-details h2{color:#333;font-size:1.8rem;font-weight:400;margin-bottom:.5rem}.profile-email{color:#666;font-size:1rem;margin-bottom:1.5rem}.profile-stats{display:flex;gap:2rem}.profile-sections{grid-gap:2rem;display:grid;gap:2rem}.profile-section{border:1px solid #eee;border-radius:6px;padding:1.5rem}.profile-section h3{color:#333;font-size:1.3rem;font-weight:400;margin-bottom:1.5rem}.empty-state{padding:2rem 1rem}.empty-state p{color:#666;font-size:1rem;margin-bottom:1rem}.explore-link{align-items:center;color:#8a4fff;display:inline-flex;font-size:.95rem;gap:.5rem;text-decoration:none}.explore-link:hover{color:#7640e5;text-decoration:underline}@media (max-width:768px){.profile-page{padding:1rem}.profile-container{padding:2rem}.profile-info{flex-direction:column;gap:1.5rem;text-align:center}.profile-stats{justify-content:center}}@media (max-width:480px){.profile-container{padding:1.5rem}.profile-header h1{font-size:1.8rem}.profile-details h2{font-size:1.5rem}.profile-stats{flex-direction:column;gap:1rem}}.section-header h3{margin-bottom:0}.saved-classes-grid{grid-gap:1rem;display:grid;gap:1rem}.saved-class-card{align-items:center;border:1px solid #eee;border-radius:8px;display:flex;gap:1rem;padding:1rem;transition:all .3s ease}.saved-class-card:hover{border-color:#ddd;box-shadow:0 2px 8px #0000000d}.class-image{border-radius:6px;flex-shrink:0;height:80px;overflow:hidden;width:80px}.class-image img{height:100%;object-fit:cover;width:100%}.class-image-placeholder{align-items:center;background:linear-gradient(135deg,#8a4fff,#6c63ff);color:#fff;display:flex;font-size:2rem;font-weight:700;height:100%;justify-content:center;width:100%}.class-details{flex:1 1}.class-details h4{color:#333;font-size:1.1rem;font-weight:400;margin-bottom:.5rem}.class-schedule{color:#fff;font-size:.9rem;margin-bottom:.25rem}.class-price{color:#8a4fff;font-size:.9rem;font-weight:500}.class-actions{align-items:center;display:flex;gap:.5rem}.view-class-btn{background:#8a4fff;border-radius:4px;color:#fff;font-size:.9rem;padding:.5rem 1rem;text-decoration:none;transition:background .2s ease}.view-class-btn:hover{background:#7640e5}.remove-class-btn{align-items:center;background:#fff;border:1px solid #ff7675;border-radius:50%;color:#ff7675;cursor:pointer;display:flex;font-size:1.2rem;height:32px;justify-content:center;transition:all .2s ease;width:32px}.remove-class-btn:hover:not(:disabled){background:#ff7675;color:#fff}.remove-class-btn:disabled{cursor:not-allowed;opacity:.5}.spinner-tiny{animation:spin .8s linear infinite;border:2px solid #ff76754d;border-radius:50%;border-top-color:#ff7675;height:16px;width:16px}.loading-state{align-items:center;display:flex;flex-direction:column;justify-content:center}.loading-spinner-small{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#8a4fff;height:40px;margin-bottom:1rem;width:40px}.login-prompt-section{padding:3rem;text-align:center}.login-prompt-section h1{font-size:2rem;margin-bottom:1rem}.login-prompt-section p{color:#666;margin-bottom:2rem}.login-btn{background:#8a4fff;border-radius:6px;color:#fff;display:inline-block;font-size:1rem;padding:1rem 2rem;text-decoration:none;transition:background .2s ease}.login-btn:hover{background:#7640e5}@media (max-width:768px){.saved-class-card{align-items:stretch;flex-direction:column;gap:1rem}.class-image{height:150px;width:100%}.class-actions{justify-content:space-between}.section-header{align-items:flex-start;flex-direction:column;gap:.5rem}}.saved-events-grid{grid-gap:1rem;display:grid;gap:1rem}.saved-event-card{align-items:center;border:1px solid #eee;border-radius:8px;display:flex;gap:1rem;padding:1rem;transition:all .3s ease}.saved-event-card:hover{border-color:#ddd;box-shadow:0 2px 8px #0000000d}.event-date-badge{align-items:center;background:#8a4fff;border-radius:6px;color:#fff;display:flex;flex-direction:column;flex-shrink:0;height:60px;justify-content:center;width:60px}.event-day{font-size:1.4rem;font-weight:300}.event-month{font-size:.8rem;letter-spacing:.5px;text-transform:uppercase}.event-details{flex:1 1}.event-details h4{color:#333;font-size:1.1rem;font-weight:400;margin-bottom:.25rem}.event-time{color:#666;font-size:.9rem;margin-bottom:.25rem}.event-desc-preview{color:#888;font-size:.85rem;line-height:1.3}.event-actions{align-items:center;display:flex;gap:.5rem}.view-event-btn{background:#0984e3;border-radius:4px;color:#fff;font-size:.9rem;padding:.5rem 1rem;text-decoration:none;transition:background .2s ease}.view-event-btn:hover{background:#0770c4}.remove-event-btn{align-items:center;background:#fff;border:1px solid #ff7675;border-radius:50%;color:#ff7675;cursor:pointer;display:flex;font-size:1.2rem;height:32px;justify-content:center;transition:all .2s ease;width:32px}.remove-event-btn:hover:not(:disabled){background:#ff7675;color:#fff}.remove-event-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.saved-event-card{align-items:stretch;flex-direction:column;gap:1rem;text-align:center}.event-date-badge{flex-direction:row;gap:1rem;height:auto;padding:.5rem;width:100%}.event-actions,.event-date-badge{justify-content:center}}.admin-activity{background:#f8f8f8;min-height:100vh;padding:2rem}.admin-header{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem;padding:2rem}.admin-header h1{color:#333;font-family:Georgia,serif;font-size:2rem;font-weight:300;margin-bottom:.5rem}.admin-header p{color:#666;font-size:1rem}.admin-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.refresh-btn{background:#000;font-size:.9rem;padding:.75rem 1.5rem;transition:background .2s ease}.refresh-btn:hover{background:#333}.stats-summary{gap:2rem}.stat-item{text-align:center}.stat-number{display:block;font-size:1.8rem;font-weight:300;margin-bottom:.25rem}.stat-label{font-size:.9rem}.activity-tabs{border-bottom:1px solid #eee;margin-bottom:2rem;padding-bottom:1rem}.activity-tabs,.tab{display:flex;gap:.5rem}.tab{align-items:center;background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:.9rem;padding:.75rem 1.5rem;transition:all .2s ease}.tab:hover{background:#f0f0f0}.tab.active{background:#000;color:#fff}.tab-count{background:#fff3;border-radius:10px;font-size:.8rem;padding:.1rem .5rem}.activity-content{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:2rem}.loading-state{padding:3rem}.spinner{border:3px solid #f3f3f3;border-top-color:#000;display:inline-block;margin-bottom:1rem}.item-card{border:1px solid #eee;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem;transition:border-color .2s ease}.item-card:hover{border-color:#ddd}.item-header{margin-bottom:1.5rem}.item-header h3{color:#333;font-size:1.2rem;font-weight:400;margin-bottom:.5rem}.item-meta{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.meta-item{color:#666;font-size:.9rem}.save-count{color:#8a4fff;font-size:.9rem;font-weight:500;margin-left:auto}.users-list h4{color:#666;font-size:.95rem;font-weight:500;margin-bottom:1rem}.users-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.user-badge{background:#f8f9ff;border:1px solid #e6e9ff;border-radius:6px;padding:.75rem;transition:background .2s ease}.user-badge:hover{background:#f0f3ff}.user-email{font-size:.9rem;margin-bottom:.25rem}.user-date{font-size:.8rem}.user-card{border:1px solid #eee;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.user-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.user-header h3{color:#333;font-size:1.2rem;font-weight:400;margin:0}.user-stats{display:flex;gap:.75rem}.stat-badge{background:#f0f0f0;color:#666}.stat-badge,.total-badge{border-radius:12px;font-size:.8rem;font-weight:500;padding:.25rem .75rem}.total-badge{background:#000;color:#fff}.saved-section{margin-bottom:1.5rem}.saved-section h4{color:#666;font-size:.95rem;font-weight:500;margin-bottom:.75rem}.saved-items{display:flex;flex-direction:column;gap:.5rem}.saved-item{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:.5rem 0}.saved-item:last-child{border-bottom:none}.item-title{color:#333;font-size:.9rem}.item-date{color:#888;font-size:.8rem}@media (max-width:768px){.admin-activity{padding:1rem}.admin-header{padding:1.5rem}.admin-controls{align-items:flex-start;flex-direction:column}.stats-summary{justify-content:space-between;width:100%}.activity-tabs{overflow-x:auto;padding-bottom:.5rem;white-space:nowrap}.activity-content{padding:1rem}.user-header{align-items:flex-start;flex-direction:column}.user-stats{align-self:flex-start}.users-grid{grid-template-columns:1fr}}@media (max-width:480px){.item-meta{align-items:flex-start;flex-direction:column;gap:.5rem}.save-count{margin-left:0}.saved-item{align-items:flex-start;flex-direction:column;gap:.25rem}}.save-count.no-saves{color:#888;opacity:.7}.no-users{background:#f8f9fa;border-radius:8px;margin-top:1rem;padding:1rem;text-align:center}.no-users-text{color:#666;font-style:italic;margin:0}.admin-badge{align-items:center;background:#ffc107;border-radius:12px;color:#856404;display:inline-flex;font-size:.85rem;font-weight:500;gap:.25rem;padding:.25rem .75rem}.admin-toggle-btn{border:none;border-radius:4px;cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:all .2s}.admin-toggle-btn.add{background:#28a745;color:#fff}.admin-toggle-btn.remove{background:#dc3545;color:#fff}.admin-toggle-btn:hover{opacity:.9}.admin-toggle-btn:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.no-saved-items{background:#f8f9fa;border-radius:8px;color:#666;font-style:italic;padding:1.5rem;text-align:center}.stats-summary{display:flex;flex-wrap:wrap;gap:1.5rem}.stat-item{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;min-width:120px;padding:.75rem 1.5rem}.stat-number{color:#333;font-size:1.5rem;font-weight:600}.stat-label{color:#666;font-size:.875rem;margin-top:.25rem}.admin-management{margin:0 auto;max-width:1200px;padding:2rem}.management-header{margin-bottom:2rem}.management-header h1{font-size:2rem;margin-bottom:.5rem}.management-header p{color:#666;font-size:1.1rem}.alert{border-radius:8px;font-weight:500;margin-bottom:1.5rem;padding:1rem}.alert.success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.alert.error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.add-admin-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;padding:1.5rem}.add-admin-section h2{color:#333;margin-bottom:1.5rem}.add-admin-methods{grid-gap:2rem;display:grid;gap:2rem}.admin-method{border:2px solid #e0e0e0;border-radius:8px;padding:1.5rem}.admin-method h3{color:#444;margin-bottom:1rem}.email-input-group,.search-input-group{display:flex;gap:1rem;margin-bottom:1rem}.email-input,.search-input{border:1px solid #ddd;border-radius:6px;flex:1 1;font-size:1rem;padding:.75rem 1rem}.add-btn,.search-btn{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:background .2s}.add-btn:hover,.search-btn:hover{background:#0056b3}.method-hint{color:#666;display:block;font-size:.875rem;margin-top:.5rem}.search-results{margin-top:1.5rem}.search-results h4{color:#444;margin-bottom:1rem}.user-result{align-items:center;background:#f9f9f9;border:1px solid #e0e0e0;border-radius:6px;display:flex;justify-content:space-between;margin-bottom:.5rem;padding:1rem}.user-info{flex:1 1}.user-email{color:#333;font-weight:500}.user-name{color:#666;font-size:.9rem;margin:.25rem 0}.user-date{color:#888;font-size:.85rem}.make-admin-btn{background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:500;padding:.5rem 1rem}.make-admin-btn.disabled{background:#6c757d;cursor:not-allowed}.make-admin-btn:hover:not(.disabled){background:#218838}.current-admins-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;padding:1.5rem}.section-header{justify-content:space-between;margin-bottom:1.5rem}.refresh-btn,.section-header{align-items:center;display:flex}.refresh-btn{background:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;gap:.5rem;padding:.5rem 1rem}.admins-table{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.table-header{background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:grid;grid-template-columns:2fr 1fr 1.5fr 1fr}.table-header .table-cell{color:#333;font-weight:600;padding:1rem}.table-row{border-bottom:1px solid #e0e0e0;display:grid;grid-template-columns:2fr 1fr 1.5fr 1fr}.table-row:last-child{border-bottom:none}.table-cell{display:flex;flex-direction:column;justify-content:center;padding:1rem}.admin-email{color:#333;font-weight:500}.admin-name{color:#666;font-size:.9rem;margin-top:.25rem}.remove-admin-btn{background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:500;padding:.5rem 1rem}.remove-admin-btn:hover{background:#c82333}.super-admin-info{background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;margin-top:2rem;padding:1.5rem}.super-admin-info h3{color:#856404;margin-bottom:1rem}.super-admin-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.super-admin-item{align-items:center;background:#fff;border:1px solid #ffeaa7;border-radius:4px;display:flex;justify-content:space-between;padding:.75rem}.super-email{color:#333;font-weight:500}.super-badge{background:#856404;border-radius:12px;color:#fff;font-size:.85rem;font-weight:500;padding:.25rem .75rem}.info-note{color:#856404;display:block;font-size:.875rem}.loading-state{padding:2rem;text-align:center}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:40px;margin:0 auto 1rem;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.empty-state{color:#666;padding:3rem;text-align:center}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;line-height:1.6}.simple-nav{background:#fff;border-bottom:1px solid #eee;padding:1.5rem 2rem}.nav-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px}.logo{color:#000;font-family:Georgia,serif;font-size:2rem;font-weight:300;letter-spacing:2px;text-decoration:none}.nav-links{display:flex;gap:2rem}.nav-link{color:#666;font-size:1rem;padding:.5rem 0;position:relative;text-decoration:none;transition:color .2s}.nav-link:hover{color:#000}main{min-height:70vh}.simple-footer{background:#f8f8f8;color:#666;font-size:.9rem;line-height:1.8;padding:3rem 2rem;text-align:center}.simple-footer p{margin-bottom:.5rem}.logout-btn{background:none;border:none;color:#666;cursor:pointer;font-family:inherit;font-size:1rem;padding:.5rem 0;transition:color .2s}.logout-btn:hover{color:#000}.auth-loading{color:#666;padding:4rem;text-align:center}@media (max-width:768px){.simple-nav{padding:1rem}.nav-content{align-items:center;flex-direction:column;gap:1.5rem}.logo{font-size:1.8rem;margin-bottom:.5rem;text-align:center;width:100%}.nav-links{border-top:1px solid #f0f0f0;display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center;padding-top:.5rem;width:100%}.nav-link{padding:.25rem 0}.logout-btn,.nav-link{font-size:.95rem}}@media (max-width:480px){.simple-nav{padding:.75rem 1rem}.nav-content{gap:1rem}.logo{font-size:1.6rem;margin-bottom:.25rem}.nav-links{gap:1rem;padding-top:.75rem}.logout-btn,.nav-link{font-size:.9rem}}
/*# sourceMappingURL=main.10c1f1b2.css.map*/