/* === RESET & BASE === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Poppins',sans-serif;font-size:16px;line-height:1.6;color:#333;background:#fff}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit;transition:.3s}
ul{list-style:none}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:700;line-height:1.2;color:#2a1a2e}

:root{
  --primary:#9b2c5e;
  --primary-dark:#6b1f43;
  --accent:#d4a574;
  --gold:#c8a16a;
  --dark:#2a1a2e;
  --light:#fdf6f0;
  --gray:#777;
  --bg-soft:#fbf3eb;
}

.container{max-width:1200px;margin:0 auto;padding:0 20px}

/* === BUTTONS === */
.btn{display:inline-block;padding:14px 32px;border-radius:50px;font-weight:500;cursor:pointer;border:none;font-size:15px;letter-spacing:.5px;transition:all .3s}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 8px 20px rgba(155,44,94,.3)}
.btn-outline{background:transparent;color:var(--primary);border:2px solid var(--primary)}
.btn-outline:hover{background:var(--primary);color:#fff}
.btn-light{background:#fff;color:var(--primary)}
.btn-light:hover{background:var(--accent);color:#fff}
.btn-block{display:block;width:100%;text-align:center}

/* === HEADER === */
.header{background:#fff;position:sticky;top:0;z-index:100;box-shadow:0 2px 10px rgba(0,0,0,.05)}
.nav-container{display:flex;justify-content:space-between;align-items:center;padding:18px 20px}
.logo{display:flex;align-items:center;gap:10px;font-family:'Cormorant Garamond',serif;font-size:26px;color:var(--dark)}
.logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}
.logo-text strong{color:var(--primary);font-weight:700}
.nav ul{display:flex;gap:35px}
.nav a{color:var(--dark);font-weight:500;font-size:15px;position:relative}
.nav a::after{content:'';position:absolute;bottom:-5px;left:0;width:0;height:2px;background:var(--primary);transition:.3s}
.nav a:hover::after,.nav a.active::after{width:100%}
.nav a.active{color:var(--primary)}
.menu-toggle{display:none;background:none;border:none;font-size:24px;color:var(--dark);cursor:pointer}

/* === HERO === */
.hero{position:relative;height:90vh;min-height:600px;background:url('images/danza-arabe.webp') center/cover;display:flex;align-items:center;color:#fff}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(42,26,46,.85),rgba(155,44,94,.4))}
.hero-content{position:relative;max-width:700px}
.hero h1{font-size:64px;margin-bottom:20px;color:#fff}
.hero h1 span{color:var(--accent);font-style:italic}
.hero p{font-size:18px;margin-bottom:30px;opacity:.95}
.hero-buttons{display:flex;gap:15px;flex-wrap:wrap}
.hero-buttons .btn-outline{color:#fff;border-color:#fff}
.hero-buttons .btn-outline:hover{background:#fff;color:var(--primary)}

/* === SECTIONS === */
section{padding:80px 0}
.section-title{font-size:42px;text-align:center;margin-bottom:15px}
.section-subtitle{text-align:center;color:var(--gray);font-size:17px;max-width:700px;margin:0 auto 50px}
.bg-soft{background:var(--bg-soft)}
.pre-title{display:inline-block;color:var(--primary);font-weight:600;letter-spacing:2px;text-transform:uppercase;font-size:13px;margin-bottom:10px}

/* === BENEFITS === */
.benefits{background:var(--bg-soft)}
.benefits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:30px}
.benefit-card{background:#fff;padding:40px 30px;border-radius:15px;text-align:center;transition:.3s;box-shadow:0 5px 20px rgba(0,0,0,.05)}
.benefit-card:hover{transform:translateY(-8px);box-shadow:0 15px 40px rgba(0,0,0,.1)}
.benefit-card i{font-size:42px;color:var(--primary);margin-bottom:20px}
.benefit-card h3{font-size:24px;margin-bottom:12px}
.benefit-card p{color:var(--gray);font-size:14.5px}

/* === LEVELS === */
.levels-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px}
.level-card{background:#fff;border-radius:15px;overflow:hidden;box-shadow:0 5px 25px rgba(0,0,0,.08);transition:.3s}
.level-card:hover{transform:translateY(-8px)}
.level-img{height:260px;background-size:cover;background-position:center}
.level-body{padding:30px}
.badge{display:inline-block;background:var(--primary);color:#fff;padding:6px 18px;border-radius:50px;font-size:12px;font-weight:500;letter-spacing:1px;text-transform:uppercase;margin-bottom:15px}
.level-body h3{font-size:28px;margin-bottom:12px}
.level-body p{color:var(--gray);margin-bottom:20px;font-size:15px}
.link-arrow{color:var(--primary);font-weight:600;display:inline-flex;align-items:center;gap:8px}
.link-arrow:hover{gap:14px;color:var(--primary-dark)}

/* === MODES === */
.modes-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.mode-text h2{font-size:42px;margin-bottom:20px}
.mode-text p{color:var(--gray);margin-bottom:25px;font-size:16px}
.mode-list{margin-bottom:30px}
.mode-list li{padding:10px 0;display:flex;align-items:center;gap:12px;color:var(--dark)}
.mode-list i{color:var(--primary);font-size:20px}
.mode-img img{border-radius:15px;box-shadow:0 20px 40px rgba(0,0,0,.15)}

/* === TESTIMONIALS === */
.testimonials{background:var(--bg-soft)}
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px}
.testimonial{background:#fff;padding:35px;border-radius:15px;position:relative;box-shadow:0 5px 20px rgba(0,0,0,.05)}
.testimonial>i{font-size:32px;color:var(--accent);margin-bottom:15px}
.testimonial p{font-style:italic;color:#555;margin-bottom:20px;font-size:15px;line-height:1.7}
.testimonial h4{font-size:18px;margin-bottom:3px;color:var(--dark)}
.testimonial span{color:var(--gray);font-size:13px}

/* === CTA === */
.cta{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;text-align:center}
.cta h2{color:#fff;font-size:42px;margin-bottom:15px}
.cta p{margin-bottom:30px;font-size:17px;opacity:.95}

/* === FOOTER === */
.footer{background:var(--dark);color:#fff;padding:70px 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1.5fr 1.5fr;gap:40px;padding-bottom:50px}
.footer-logo{font-family:'Cormorant Garamond',serif;font-size:28px;color:#fff;margin-bottom:15px}
.footer-logo strong{color:var(--accent)}
.footer h4{color:#fff;font-size:20px;margin-bottom:20px;font-family:'Poppins',sans-serif;font-weight:600}
.footer p{color:#bbb;margin-bottom:20px;font-size:14.5px}
.footer ul li{margin-bottom:10px}
.footer ul a{color:#bbb;font-size:14.5px}
.footer ul a:hover{color:var(--accent)}
.contact-list li{display:flex;align-items:flex-start;gap:10px;color:#bbb;font-size:14px;margin-bottom:12px}
.contact-list i{color:var(--accent);margin-top:4px}
.social{display:flex;gap:12px;margin-top:15px}
.social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px}
.social a:hover{background:var(--primary);transform:translateY(-3px)}
.newsletter{display:flex;background:#fff;border-radius:50px;overflow:hidden;margin-top:10px}
.newsletter input{flex:1;border:none;padding:12px 18px;outline:none;font-size:14px}
.newsletter button{background:var(--primary);border:none;color:#fff;padding:0 18px;cursor:pointer}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;text-align:center;color:#888;font-size:14px}

/* === PAGE HERO === */
.page-hero{height:50vh;min-height:350px;background-size:cover;background-position:center;position:relative;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(42,26,46,.7),rgba(155,44,94,.6));display:flex;flex-direction:column;justify-content:center;align-items:center;padding:0 20px}
.page-hero h1{font-size:54px;color:#fff;margin-bottom:10px}
.page-hero p{font-size:18px;opacity:.95}

/* === ABOUT === */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-img img{border-radius:15px;box-shadow:0 20px 40px rgba(0,0,0,.15)}
.about-text h2{font-size:40px;margin-bottom:20px}
.about-text p{color:var(--gray);margin-bottom:18px}
.stats{display:flex;gap:30px;margin-top:30px}
.stats div{text-align:center}
.stats strong{display:block;font-size:36px;color:var(--primary);font-family:'Cormorant Garamond',serif}
.stats span{color:var(--gray);font-size:13px}

/* === MISSION === */
.mission{background:var(--bg-soft)}
.mission-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px}
.mission-card{background:#fff;padding:40px 30px;border-radius:15px;text-align:center}
.mission-card i{font-size:42px;color:var(--primary);margin-bottom:20px}
.mission-card h3{font-size:26px;margin-bottom:12px}
.mission-card p{color:var(--gray);font-size:15px}

/* === TEAM === */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:30px}
.team-card{background:#fff;border-radius:15px;overflow:hidden;box-shadow:0 5px 20px rgba(0,0,0,.08);transition:.3s}
.team-card:hover{transform:translateY(-5px)}
.team-card img{width:100%;height:300px;object-fit:cover}
.team-info{padding:25px;text-align:center}
.team-info h3{font-size:22px;margin-bottom:5px}
.team-info span{color:var(--primary);font-weight:500;font-size:13px;display:block;margin-bottom:12px}
.team-info p{color:var(--gray);font-size:14px;margin-bottom:15px}
.team-social{display:flex;gap:10px;justify-content:center}
.team-social a{width:36px;height:36px;border-radius:50%;background:var(--bg-soft);display:flex;align-items:center;justify-content:center;color:var(--primary)}
.team-social a:hover{background:var(--primary);color:#fff}

/* === CLASSES PAGE === */
.classes-intro{padding:60px 0 40px}
.class-detail{padding:60px 0}
.class-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.class-grid.reverse .class-img{order:2}
.class-img img{border-radius:15px;box-shadow:0 20px 40px rgba(0,0,0,.15)}
.class-info h2{font-size:38px;margin:15px 0 20px}
.class-info p{color:var(--gray);margin-bottom:25px}
.class-features{margin-bottom:30px}
.class-features li{padding:10px 0;display:flex;align-items:center;gap:12px;border-bottom:1px solid #f0f0f0}
.class-features i{color:var(--primary);width:20px}

/* === PRICING === */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px;margin-top:30px}
.pricing-card{background:#fff;border-radius:15px;padding:40px 30px;text-align:center;box-shadow:0 5px 20px rgba(0,0,0,.05);position:relative;transition:.3s}
.pricing-card:hover{transform:translateY(-5px)}
.pricing-card.featured{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;transform:scale(1.05)}
.pricing-card.featured h3,.pricing-card.featured .price{color:#fff}
.pricing-card.featured ul li{border-color:rgba(255,255,255,.2)}
.featured-tag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;padding:5px 16px;border-radius:50px;font-size:12px;font-weight:600;letter-spacing:1px}
.pricing-card h3{font-size:26px;margin-bottom:15px}
.price{font-size:42px;font-family:'Cormorant Garamond',serif;color:var(--primary);font-weight:700;margin-bottom:25px}
.price span{font-size:16px;color:var(--gray);font-family:'Poppins',sans-serif;font-weight:400}
.pricing-card.featured .price span{color:rgba(255,255,255,.8)}
.pricing-card ul{margin-bottom:30px;text-align:left}
.pricing-card ul li{padding:10px 0;border-bottom:1px solid #f0f0f0;display:flex;align-items:center;gap:10px}
.pricing-card ul i{color:var(--primary)}
.pricing-card.featured ul i{color:var(--accent)}

/* === EVENTS PAGE === */
.events-section{padding:60px 0 80px}
.search-bar{position:relative;max-width:600px;margin:0 auto 40px}
.search-bar i{position:absolute;left:20px;top:50%;transform:translateY(-50%);color:var(--gray)}
.search-bar input{width:100%;padding:16px 20px 16px 50px;border:2px solid #e0e0e0;border-radius:50px;font-size:15px;outline:none;transition:.3s}
.search-bar input:focus{border-color:var(--primary)}
.events-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px}
.event-card{background:#fff;border-radius:15px;overflow:hidden;box-shadow:0 5px 20px rgba(0,0,0,.08);transition:.3s}
.event-card:hover{transform:translateY(-8px);box-shadow:0 15px 40px rgba(0,0,0,.12)}
.event-img{height:220px;background-size:cover;background-position:center;position:relative}
.event-date{position:absolute;top:15px;left:15px;background:#fff;padding:8px 14px;border-radius:10px;text-align:center;color:var(--primary);font-size:12px;font-weight:600;line-height:1.2;box-shadow:0 4px 10px rgba(0,0,0,.1)}
.event-date strong{display:block;font-size:22px;font-family:'Cormorant Garamond',serif}
.event-body{padding:25px}
.event-meta{color:var(--primary);font-size:13px;font-weight:500;display:flex;align-items:center;gap:6px;margin-bottom:10px}
.event-body h3{font-size:22px;margin-bottom:10px;line-height:1.3}
.event-body p{color:var(--gray);font-size:14.5px;margin-bottom:15px}
.no-results{text-align:center;color:var(--gray);font-size:18px;padding:40px}

/* === ARTICLE === */
.article-hero{height:60vh;min-height:400px;background-size:cover;background-position:center;position:relative}
.article-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(42,26,46,.5),rgba(42,26,46,.85));display:flex;align-items:flex-end;color:#fff;padding-bottom:60px}
.article-tag{display:inline-block;background:var(--primary);padding:6px 16px;border-radius:50px;font-size:12px;letter-spacing:1px;text-transform:uppercase;margin-bottom:15px}
.article-hero h1{font-size:48px;color:#fff;margin-bottom:20px;max-width:900px}
.article-meta{display:flex;gap:25px;flex-wrap:wrap;font-size:14px;opacity:.9}
.article-meta i{margin-right:6px;color:var(--accent)}
.article-content{padding:60px 0}
.article-grid{display:grid;grid-template-columns:2fr 1fr;gap:50px}
.article-main p,.article-main ul{margin-bottom:20px;color:#444;font-size:16px;line-height:1.8}
.lead{font-size:19px !important;color:var(--dark) !important;font-weight:500}
.article-main h2{font-size:32px;margin:35px 0 18px}
.article-main h3{font-size:24px;margin:25px 0 15px}
.article-main img{border-radius:12px;margin:30px 0;width:100%}
.article-list li{padding:8px 0 8px 25px;position:relative}
.article-list li::before{content:'';position:absolute;left:0;top:16px;width:8px;height:8px;background:var(--primary);border-radius:50%}
blockquote{background:var(--bg-soft);border-left:4px solid var(--primary);padding:25px 30px;margin:30px 0;font-style:italic;font-size:17px;border-radius:8px}
blockquote cite{display:block;margin-top:12px;font-size:14px;color:var(--primary);font-style:normal;font-weight:600}
.article-tags{margin-top:40px;display:flex;flex-wrap:wrap;gap:10px}
.article-tags span{background:var(--bg-soft);color:var(--primary);padding:6px 16px;border-radius:50px;font-size:13px;font-weight:500}
.sidebar-card{background:var(--bg-soft);padding:30px;border-radius:15px;margin-bottom:25px}
.sidebar-card h3{font-size:22px;margin-bottom:18px}
.event-info li{padding:10px 0;border-bottom:1px solid rgba(0,0,0,.06);font-size:14.5px}
.event-info i{color:var(--primary);margin-right:8px;width:18px}
.event-info li:last-child{border:none}
.related-events li{margin-bottom:12px}
.related-events a{color:#444;font-size:14.5px;display:block;padding:8px 0;border-bottom:1px solid rgba(0,0,0,.06);transition:.3s}
.related-events a:hover{color:var(--primary);padding-left:5px}
.share-buttons{display:flex;gap:10px}
.share-buttons a{width:42px;height:42px;border-radius:50%;background:#fff;color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:16px;transition:.3s}
.share-buttons a:hover{background:var(--primary);color:#fff}

/* === CONTACT === */
.contact-section{padding:80px 0}
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:60px}
.contact-info h2{font-size:34px;margin-bottom:15px}
.contact-info>p{color:var(--gray);margin-bottom:35px}
.contact-item{display:flex;gap:18px;margin-bottom:25px;align-items:flex-start}
.contact-item>i{width:50px;height:50px;background:var(--bg-soft);color:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.contact-item h4{font-size:18px;margin-bottom:5px;font-family:'Poppins',sans-serif}
.contact-item p{color:var(--gray);font-size:14.5px}
.social-contact{display:flex;gap:12px;margin-top:35px}
.social-contact a{width:42px;height:42px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;transition:.3s}
.social-contact a:hover{background:var(--primary-dark);transform:translateY(-3px)}
.contact-form-wrap{background:var(--bg-soft);padding:45px;border-radius:15px}
.contact-form-wrap h2{font-size:32px;margin-bottom:10px}
.contact-form-wrap>p{color:var(--gray);margin-bottom:25px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-group{margin-bottom:18px}
.form-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:500;color:var(--dark)}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:13px 16px;border:1px solid #e0e0e0;border-radius:10px;font-size:14.5px;font-family:inherit;outline:none;transition:.3s;background:#fff}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary)}
.form-status{margin-top:15px;padding:12px;border-radius:8px;text-align:center;display:none}
.form-status.success{display:block;background:#d4edda;color:#155724}
.form-status.error{display:block;background:#f8d7da;color:#721c24}

.map-section iframe{display:block}

/* === RESPONSIVE === */
@media(max-width:992px){
  .hero h1{font-size:48px}
  .section-title{font-size:34px}
  .modes-grid,.about-grid,.class-grid,.contact-grid,.article-grid{grid-template-columns:1fr;gap:40px}
  .class-grid.reverse .class-img{order:0}
  .footer-grid{grid-template-columns:1fr 1fr}
  .pricing-card.featured{transform:none}
}

@media(max-width:768px){
  .menu-toggle{display:block}
  .nav{position:fixed;top:75px;right:-100%;width:80%;max-width:300px;height:100vh;background:#fff;box-shadow:-5px 0 20px rgba(0,0,0,.1);transition:.3s;padding:30px}
  .nav.active{right:0}
  .nav ul{flex-direction:column;gap:20px}
  .hero{height:auto;padding:100px 0;min-height:auto}
  .hero h1{font-size:38px}
  .page-hero h1{font-size:38px}
  .section-title{font-size:28px}
  .article-hero h1{font-size:32px}
  section{padding:60px 0}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .stats{flex-wrap:wrap;gap:20px;justify-content:space-between}
  .contact-form-wrap{padding:30px 25px}
}

@media(max-width:480px){
  .hero h1{font-size:32px}
  .hero p{font-size:15px}
  .btn{padding:12px 24px;font-size:14px}
  .hero-buttons{flex-direction:column;width:100%}
  .hero-buttons .btn{width:100%;text-align:center}
}