:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;font-weight:400;color-scheme:light;color:#2d3748;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2}a{text-decoration:none;color:inherit}button{font-family:inherit;cursor:pointer}input,textarea{font-family:inherit}.error-boundary{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:2rem}.error-boundary-content{max-width:600px;text-align:center;color:#fff}.error-boundary-content h1{font-size:2rem;margin-bottom:1rem;color:gold}.error-boundary-content p{font-size:1.1rem;margin-bottom:2rem;line-height:1.6}.error-boundary-button{background:gold;color:#1a1a2e;border:none;padding:.8rem 2rem;font-size:1rem;font-weight:600;border-radius:25px;cursor:pointer;transition:all .3s ease}.error-boundary-button:hover{background:#ffed4e;transform:translateY(-2px);box-shadow:0 4px 12px #ffd7004d}.error-details{margin-top:2rem;text-align:left;background:#ffffff1a;padding:1rem;border-radius:8px}.error-details summary{cursor:pointer;font-weight:600;margin-bottom:.5rem}.error-details pre{color:#ff6b6b;font-size:.9rem;overflow-x:auto;white-space:pre-wrap;word-wrap:break-word}.header{background:linear-gradient(135deg,#e76f51,#f4a261,#2a9d8f);color:#fff;padding:1rem 0;box-shadow:0 2px 10px #0003}.container{max-width:1200px;margin:0 auto;padding:0 1rem 0 2rem}.header-content{display:flex;justify-content:space-between;align-items:center}.logo{text-decoration:none;color:#fff;display:flex;align-items:center;gap:1rem;margin-left:-.5rem;margin-right:3rem}.logo-image{height:60px;width:60px;border-radius:50%;object-fit:cover;box-shadow:0 2px 8px #0003;transition:transform .2s}.logo:hover .logo-image{transform:scale(1.05)}.logo h1{margin:0;font-size:1.5rem;font-weight:700;white-space:nowrap}.nav{display:flex;gap:1.3rem;align-items:center;flex-wrap:nowrap}.nav a{color:#fff;text-decoration:none;font-weight:500;transition:opacity .2s;white-space:nowrap;font-size:.95rem}.nav a:hover{opacity:.8}.user-name{font-weight:500;padding:.5rem 1rem;background:#fff3;border-radius:20px;white-space:nowrap}.btn{padding:.4rem 1rem;border:none;border-radius:20px;font-weight:600;font-size:.9rem;cursor:pointer;text-decoration:none;display:inline-block;transition:all .2s;white-space:nowrap}.btn-primary{background:#fff;color:#667eea}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0003}.btn-secondary{background:#fff3;color:#fff;border:1px solid white}.btn-secondary:hover{background:#ffffff4d}.lang-toggle{background:#fff3;color:#fff;border:1px solid white;padding:.4rem .8rem;border-radius:20px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s;white-space:nowrap}.lang-toggle:hover{background:#ffffff4d}.dropdown{position:relative}.dropdown-toggle{background:none;border:none;color:#fff;font-weight:500;font-size:.95rem;cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:.3rem;padding:0;transition:opacity .2s}.dropdown-toggle:hover{opacity:.8}.dropdown-arrow{font-size:.7rem;transition:transform .3s ease}.dropdown-arrow.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:100%;left:0;margin-top:.5rem;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:180px;overflow:hidden;z-index:1000;animation:dropdownFadeIn .2s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-menu a{display:block;padding:.75rem 1rem;color:#333;text-decoration:none;font-weight:500;transition:background .2s}.dropdown-menu a:hover{background:#e76f511a;opacity:1}.mobile-menu-toggle{display:none;flex-direction:column;justify-content:space-around;width:2rem;height:2rem;background:transparent;border:none;cursor:pointer;padding:0;z-index:1001}.mobile-menu-toggle span{width:2rem;height:.2rem;background:#fff;border-radius:10px;transition:all .3s linear;position:relative;transform-origin:1px}.mobile-menu-toggle span:first-child.active{transform:rotate(45deg)}.mobile-menu-toggle span:nth-child(2).active{opacity:0;transform:translate(20px)}.mobile-menu-toggle span:last-child.active{transform:rotate(-45deg)}.mobile-overlay{display:none}@media(max-width:768px){.container{padding:0 1rem}.header-content{position:relative}.logo{margin-right:0;margin-left:0}.logo h1{font-size:1rem}.logo-image{height:50px;width:50px}.mobile-menu-toggle{display:flex}.nav{position:fixed;right:-100%;top:0;height:100vh;width:80%;max-width:300px;background:linear-gradient(135deg,#e76f51,#f4a261,#2a9d8f);flex-direction:column;align-items:stretch;padding:5rem 2rem 2rem;gap:1rem;box-shadow:-2px 0 10px #0000004d;transition:right .3s ease-in-out;z-index:1000;overflow-y:auto}.nav.mobile-open{right:0}.mobile-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999}.nav a,.nav .btn,.nav .lang-toggle{text-align:left;padding:.5rem 1rem;font-size:1rem;width:100%}.nav .btn{text-align:center}.user-name{width:100%;text-align:center;padding:.5rem 1rem}.dropdown{width:100%}.dropdown-toggle{width:100%;text-align:left;padding:.5rem 1rem;justify-content:space-between}.dropdown-menu{position:static;margin-top:0;box-shadow:none;background:#ffffff1a;border-radius:0}.dropdown-menu a{color:#fff;padding:.75rem 1.5rem;background:#ffffff0d}.dropdown-menu a:hover{background:#ffffff26}}@media(max-width:480px){.logo h1{font-size:.9rem}.logo-image{height:45px;width:45px}}.offline-indicator{position:fixed;top:0;left:0;right:0;padding:12px 20px;text-align:center;z-index:9999;animation:slideDown .3s ease-out;font-size:14px;font-weight:500}.offline-indicator.offline{background-color:#f59e0b;color:#1a1a2e}.offline-indicator.online{background-color:#10b981;color:#fff}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.offline-indicator-content{display:flex;align-items:center;justify-content:center;gap:8px;max-width:1200px;margin:0 auto}.offline-indicator-icon{font-size:16px;font-weight:700}.offline-indicator-text{line-height:1.4}@media(max-width:768px){.offline-indicator{padding:10px 16px;font-size:13px}.offline-indicator-icon{font-size:14px}}.install-prompt{position:fixed;bottom:20px;left:50%;transform:translate(-50%);width:calc(100% - 40px);max-width:500px;background-color:#1a1a2e;color:#fff;border-radius:12px;box-shadow:0 4px 20px #0000004d;padding:20px;z-index:1000;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.install-prompt-content{display:flex;flex-direction:column;gap:16px}.install-prompt-text h3{margin:0 0 8px;font-size:18px;font-weight:600}.install-prompt-text p{margin:0;font-size:14px;opacity:.9;line-height:1.5}.install-prompt-actions{display:flex;gap:12px}.install-prompt-button{flex:1;padding:12px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.install-prompt-button.install{background-color:#e94560;color:#fff}.install-prompt-button.install:hover{background-color:#d63850;transform:translateY(-1px);box-shadow:0 2px 8px #e9456066}.install-prompt-button.dismiss{background-color:#ffffff1a;color:#fff}.install-prompt-button.dismiss:hover{background-color:#fff3}@media(max-width:768px){.install-prompt{bottom:10px;width:calc(100% - 20px);padding:16px}.install-prompt-text h3{font-size:16px}.install-prompt-text p{font-size:13px}.install-prompt-button{padding:10px 16px;font-size:13px}}.notification-prompt{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;padding:20px;max-width:400px;width:90%;z-index:1000;animation:slideUp .3s ease-out}.notification-prompt-content h3{margin:0 0 10px;font-size:1.2rem;color:#1a1a2e}.notification-prompt-content p{margin:0 0 15px;color:#666;font-size:.95rem}.notification-prompt-error{color:#e63946;background:#fee;padding:8px 12px;border-radius:6px;font-size:.9rem;margin:10px 0}.notification-prompt-actions{display:flex;gap:10px;justify-content:flex-end}.notification-prompt-actions .btn{padding:8px 16px;border-radius:6px;font-size:.9rem;cursor:pointer;border:none;transition:all .2s}.notification-prompt-actions .btn:disabled{opacity:.6;cursor:not-allowed}.notification-prompt-actions .btn-primary{background:#e63946;color:#fff}.notification-prompt-actions .btn-primary:hover{background:#d62828}.notification-prompt-actions .btn-text{background:transparent;color:#666}.notification-prompt-actions .btn-text:hover{color:#333}@keyframes slideUp{0%{transform:translate(-50%,100px);opacity:0}to{transform:translate(-50%);opacity:1}}@media(max-width:768px){.notification-prompt{bottom:10px;width:95%}}*{box-sizing:border-box}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.btn{padding:.5rem 1.5rem;border:none;border-radius:20px;font-weight:600;cursor:pointer;text-decoration:none;display:inline-block;transition:all .2s;font-size:1rem}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 8px #667eea66}.btn-secondary{background:#667eea1a;color:#667eea;border:1px solid #667eea}.btn-secondary:hover:not(:disabled){background:#667eea33}.btn-full{width:100%}.success-message{background:#c6f6d5;color:#22543d;padding:1rem;border-radius:8px;margin-bottom:1rem}.show-more-text{position:relative;display:block;margin-top:1rem}.show-more-text .text-content{margin:0 0 .5rem}.toggle-button{background:none;border:none;color:#007bff;cursor:pointer;padding:0;margin-top:5px;font-weight:700}.toggle-button:hover{text-decoration:underline}.show-more-text .linkified-url{color:#007bff;text-decoration:underline;word-break:break-all}.show-more-text .linkified-url:hover{color:#0056b3;text-decoration:none}.home-page{min-height:calc(100vh - 80px)}.hero{background:linear-gradient(135deg,#e76f51,#f4a261,#2a9d8f);color:#fff;padding:2rem}.hero-container{display:flex;align-items:flex-start;gap:2rem;max-width:1200px;margin:0 auto}.hero-poster{flex:1;flex-shrink:0;margin-top:1rem;display:flex;align-items:flex-start}.poster-image-hero{width:auto;max-width:none;height:auto;max-height:370px;object-fit:contain;border-radius:12px;box-shadow:0 10px 30px #0006;transition:transform .3s ease}.poster-image-hero:hover{transform:scale(1.05)}.hero-text{flex:2;text-align:left}@keyframes fadeInScale{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.hero h1{font-size:2.5rem;margin-bottom:1rem}.subtitle{font-size:1.3rem;margin-bottom:1.5rem;opacity:.9}.welcome{font-size:1.1rem;margin:0}.welcome .inline-link{color:#fff;text-decoration:none;font-weight:600;border-bottom:2px solid transparent;transition:border-color .3s ease}.welcome .inline-link:hover{border-bottom-color:#fff}.hero-text .welcome+.welcome{margin-top:1rem}.stacked-cards-title{font-size:1rem;font-weight:600;opacity:.9;text-align:center;margin:.5rem 0 0}.dance-styles-preview-stacked{flex:1.5;display:flex;flex-direction:column;gap:1rem;margin-top:-2rem}.dance-styles-preview-stacked .dance-style-cards{display:flex;flex-direction:column;gap:.75rem;margin-bottom:0}.dance-styles-preview-stacked .dance-style-card{padding:1rem 1.25rem;border-radius:10px;text-align:center;color:#fff;box-shadow:0 4px 15px #0000001a;transition:all .3s ease;cursor:pointer;text-decoration:none;display:block}.dance-styles-preview-stacked .dance-style-card:hover{transform:translateY(-4px);box-shadow:0 6px 20px #00000026;color:#fff}.dance-styles-preview-stacked .dance-style-card:visited{color:#fff}.dance-styles-preview-stacked .dance-style-card.cuban-salsa{background:linear-gradient(135deg,#e76f51,#f4a261)}.dance-styles-preview-stacked .dance-style-card.bachata{background:linear-gradient(135deg,#2a9d8f,#47b5a6)}.dance-styles-preview-stacked .dance-style-card.rueda{background:linear-gradient(135deg,#f4a261,#e9c46a)}.dance-styles-preview-stacked .dance-style-card h3{font-size:1.2rem;margin-bottom:.25rem;font-weight:700;text-shadow:1px 1px 3px rgba(0,0,0,.2)}.dance-styles-preview-stacked .dance-style-card p{font-size:1.1rem;line-height:1.6;opacity:1}.classes-info{padding:4rem 2rem;background:#f4e7d3}.section-title{text-align:center;color:#264653;font-size:2.5rem;margin-bottom:2rem;font-weight:700}.class-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:3rem}.class-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 6px #0000001a;transition:transform .2s;position:relative}.class-card:hover{transform:translateY(-5px);box-shadow:0 8px 12px #00000026}.class-card.monday{border-top:4px solid #2A9D8F}.class-card.tuesday{border-top:4px solid #E76F51}.event-type-badge{display:inline-block;padding:.35rem .75rem;border-radius:4px;font-size:.85rem;font-weight:600;color:#fff;margin-bottom:1rem}.class-badge{background-color:#007bff}.event-badge{background-color:#28a745}.external-badge{background-color:#6c757d}.class-card h2{color:#264653;margin-bottom:1rem}.class-card .date{font-size:1.1rem;font-weight:600;color:#264653;margin-bottom:.5rem}.class-card .time{font-size:1.5rem;font-weight:600;color:#e76f51;margin-bottom:.75rem}.class-card .dance-style{font-size:1rem;font-weight:500;color:#2a9d8f;margin-bottom:.5rem}.class-card .level{font-size:.9rem;font-weight:500;color:#f4a261;margin-bottom:.5rem}.class-card .description{color:#718096;line-height:1.6}.class-card .btn-primary{margin-top:1.5rem}.loading{text-align:center;padding:3rem;font-size:1.2rem;color:#718096}.no-items{text-align:center;padding:3rem}.no-items p{font-size:1.2rem;color:#718096;margin-bottom:2rem}.cta{text-align:center}.btn-large{padding:1rem 3rem;font-size:1.2rem;background:#e76f51;color:#fff;text-decoration:none;border-radius:30px;display:inline-block;font-weight:600;transition:all .2s}.btn-large:hover{background:#d65a3c;transform:translateY(-2px);box-shadow:0 8px 16px #e76f5166}.location-section{padding:4rem 2rem;background:#fff}.location-section h2{text-align:center;color:#2d3748;font-size:2.5rem;margin-bottom:1rem}.location-subtitle{text-align:center;color:#718096;font-size:1.2rem;margin-bottom:2rem}.map-container{max-width:900px;margin:0 auto;border-radius:12px;overflow:hidden;box-shadow:0 10px 40px #00000026;border:3px solid #E76F51}.map-container iframe{display:block}.footer-text{font-size:.8rem;text-align:center;color:#718096;margin-top:2rem;padding-bottom:1rem}@media(max-width:992px){.hero-container{flex-direction:column;gap:2rem}.hero-text,.hero-poster,.dance-styles-preview-stacked{width:100%;max-width:500px;margin:0 auto}.hero-poster{order:1;text-align:center}.hero-text{order:2;text-align:center}.hero-text .welcome{text-align:center}.dance-styles-preview-stacked{order:3}}@media(max-width:768px){.hero h1{font-size:2rem}.subtitle{font-size:1.2rem}.section-subtitle{font-size:1.1rem;padding:0 1rem}.dance-style-cards{grid-template-columns:1fr;gap:1.5rem;padding:0 1rem}.dance-style-card{padding:2rem 1.5rem}.dance-style-card h3{font-size:1.5rem}.dance-style-card p{font-size:1rem}.class-cards{grid-template-columns:1fr}.location-section{padding:3rem 1rem}.location-section h2{font-size:2rem}.map-container iframe{height:300px}}.auth-page{min-height:calc(100vh - 80px);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e76f51,#f4a261,#2a9d8f);padding:2rem}.auth-container{background:#fff;padding:3rem;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:400px;width:100%}.auth-container h2{margin-bottom:2rem;color:#2d3748;text-align:center}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column}.form-group label{margin-bottom:.5rem;color:#4a5568;font-weight:500}.form-group input{padding:.75rem;border:1px solid #cbd5e0;border-radius:8px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#e76f51;box-shadow:0 0 0 3px #e76f511a}.btn-full{width:100%;padding:.75rem;font-size:1rem}.error-message{background:#fed7d7;color:#c53030;padding:1rem;border-radius:8px;margin-bottom:1rem}.success-message{text-align:center;color:#2d3748}.success-message h2{color:#48bb78;margin-bottom:1rem}.auth-link{text-align:center;margin-top:1rem;color:#718096}.auth-link a{color:#667eea;text-decoration:none;font-weight:600}.auth-link a:hover{text-decoration:underline}
