/* Reset and Base Styles */
* { margin: 0; padding: 0; box-sizing: border-box; }

:root{
  /* Colores principales basados en el logo */
  --primary-color: #0d1f3c;        /* Azul oscuro del logo */
  --primary-medium: #1a3557;       /* Azul medio */
  --primary-light: #2d4a73;        /* Azul más claro */
  --primary-lighter: #4a6b94;      /* Azul suave */
  
  /* Dorados del logo */
  --gold-dark: #be953b;            /* Dorado oscuro del logo */
  --gold-medium: #c9a053;          /* Dorado medio */
  --gold-light: #d4a503;           /* Dorado claro (mantienes el original) */
  --gold-lighter: #e5c570;         /* Dorado muy claro */
  
  --secondary-color: #2c3e50;
  --text-dark: #2c3e50;
  --text-light: #6c757d;
  --white: #ffffff;
  --light-gray: #f8f9fa;
  --border-color: #e9ecef;
  --shadow: 0 2px 10px rgba(0,0,0,.1);
  --shadow-hover: 0 4px 20px rgba(0,0,0,.15);
  --border-radius: 8px;
  --transition: all .3s ease;
  --font-family: 'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;

  /* Footer */
  --footer-bg: #1f3140;
  --footer-text: rgba(255,255,255,.88);
  --footer-dim: rgba(255,255,255,.68);
  --footer-border: rgba(255,255,255,.12);
  --footer-accent: var(--gold-dark);
}

html, body { overflow-x:hidden; }
body { font-family:var(--font-family); line-height:1.6; color:var(--text-dark); background-color:var(--white); }
body.no-scroll { overflow:hidden; }

/* Layout helpers */
.container { max-width:1700px; margin:0 auto; padding:0 20px; }
.row { display:flex; flex-wrap:wrap; margin:0 -15px; }
.col-md-6,.col-md-4,.col-md-8 { padding:0 15px; }
.col-md-6 { flex:0 0 50%; max-width:50%; }
.col-md-4 { flex:0 0 33.333333%; max-width:33.333333%; }
.col-md-8 { flex:0 0 66.666667%; max-width:66.666667%; }

@media (max-width:768px){
  .col-md-6,.col-md-4,.col-md-8 { flex:0 0 100%; max-width:100%; }
}
/* Esta regla quita los números de todas las listas ordenadas */
ol {
    list-style-type: none;
}

/* O, si quieres ser más específico, puedes usar una clase */
.mi-clase-de-lista {
    list-style-type: none;
}
/* Typography */
h1,h2,h3,h4,h5,h6{ font-weight:600; line-height:1.2; margin-bottom:1rem; color:var(--text-dark); }
h1{ font-size:3rem; font-weight:700; }
h2{ font-size:2.5rem; }
h3{ font-size:2rem; }
h4{ font-size:1.5rem; }
h5{ font-size:1.25rem; }
h6{ font-size:1rem; }
p{ margin-bottom:1rem; color:var(--text-light); }
.text-center{ text-align:center; }

/* Buttons */
.btn{ display:inline-block; padding:12px 24px; border:none; border-radius:var(--border-radius); font-size:1rem; font-weight:500; text-decoration:none; text-align:center; cursor:pointer; transition:var(--transition); line-height:1.5; }
.btn-primary{ background:var(--gold-lighter); color:var(--white); box-shadow:var(--shadow); }
.btn-primary:hover{ background:var(--primary-dark); box-shadow:var(--shadow-hover); transform:translateY(-2px); }
.btn-outline{ background:transparent; color:var(--primary-color); border:2px solid var(--primary-color); }
.btn-outline:hover{ background:var(--primary-color); color:#fff; }
.btn-outline-small{ padding:8px 16px; font-size:.875rem; }
.btn-block{ width:100%; }
.btn-footer{ margin-top:1rem; }

/* Images */
.img-fluid{ max-width:100%; height:auto; border-radius:var(--border-radius); }

/* ===== Header ===== */
.main-header{
  background:#fff;
  box-shadow:var(--shadow);
  position:sticky;
  top:0;
  z-index:4000; /* <- MÁS ALTO QUE EL OVERLAY */
}
.header-content{ display:flex; align-items:center; justify-content:space-between; padding:1rem 0; }
.logo{ display:flex; align-items:center; text-decoration:none; color:var(--text-dark); }
.logo-img{ width:200px; height:50px; margin-right:12px; object-fit:contain; }
.logo-text{ font-size:1.25rem; font-weight:700; line-height:1.2; }
.logo-text small{ font-size:.875rem; font-weight:400; color:var(--text-light); }

.desktop-nav{ display:flex; }
.nav-menu{ display:flex; list-style:none; margin:0; padding:0; align-items:center; }
.nav-menu li{ position:relative; margin:0 1rem; }
.nav-link{ text-decoration:none; color:var(--text-dark); font-weight:500; padding:.5rem 0; transition:var(--transition); }
.nav-link:hover{ color:var(--primary-color); }

/* Mega-menu */
.has-megamenu{ position:relative; overflow:visible; }
.has-megamenu.open .megamenu,
.has-megamenu:hover .megamenu,
.has-megamenu .megamenu:hover{ display:block; pointer-events:auto; }

.has-megamenu .megamenu{
  position:absolute; top:100%; left:15%; transform:translateX(-15%);
  margin-top:0; width:min(1100px, calc(100vw - 32px));
  background:#fff !important; border:1px solid #e5e7eb; border-radius:12px;
  box-shadow:0 20px 40px rgba(0,0,0,.12);
  padding:16px 18px 20px; display:none; pointer-events:auto; z-index:3000; isolation:isolate;
}
.has-megamenu::after{ content:""; position:absolute; left:0; right:0; top:100%; height:10px; }

.megamenu-tabs{ display:flex; gap:8px; border-bottom:1px solid #f1f5f9; padding-bottom:8px; margin-bottom:12px; }
.megamenu-tabs .tab-btn{ appearance:none; background:#f8fafc; border:1px solid #e5e7eb; border-radius:999px; padding:8px 14px; font-size:14px; line-height:1; cursor:pointer; white-space:nowrap; }
.megamenu-tabs .tab-btn.active{ background:#0ea5e9; color:#fff; border-color:#0ea5e9; }

.megamenu-panels{ position:relative; }
.megamenu-panel[hidden]{ display:none !important; }

.menu-grid-4{ display:grid !important; grid-template-columns:repeat(4, minmax(200px,1fr)); gap:8px 24px; list-style:none; margin:0; padding:0; }
.menu-grid-4 li{ margin:0; }
.menu-grid-4 a{ display:inline-block; padding:4px 6px; border-radius:8px; text-decoration:none; color:#0f172a; line-height:1.4; }
.menu-grid-4 a:hover{ background:#f1f5f9; }
@media (max-width:1200px){ .menu-grid-4{ grid-template-columns:repeat(3, minmax(180px,1fr)); } }
@media (max-width:992px){  .menu-grid-4{ grid-template-columns:repeat(2, minmax(160px,1fr)); } }

/* Header Actions */
.header-actions{ display:flex; align-items:center; gap:1rem; }

/* Language Selector */
.language-selector{ position:relative; }
.lang-toggle{
  display:flex; align-items:center; gap:.5rem; background:none; border:1px solid var(--border-color);
  padding:.5rem 1rem; border-radius:var(--border-radius); cursor:pointer; transition:var(--transition);
}
.lang-toggle:hover{ border-color:var(--primary-color); }
.current-lang{ font-weight:500; font-size:.875rem; }
.lang-arrow{ transition:var(--transition); }
.language-selector:hover .lang-arrow{ transform:rotate(180deg); }
.lang-menu{
  position:absolute; top:100%; right:0; background:#fff; box-shadow:var(--shadow); border-radius:var(--border-radius);
  padding:.5rem 0; min-width:80px; opacity:0; visibility:hidden; transform:translateY(-10px); transition:var(--transition);
}
.language-selector:hover .lang-menu{ opacity:1; visibility:visible; transform:translateY(0); }
.lang-option{ display:block; padding:.5rem 1rem; text-decoration:none; color:var(--text-dark); font-size:.875rem; transition:var(--transition); }
.lang-option:hover,.lang-option.active{ background:var(--primary-color); color:#fff; }

/* Book Button */
.book-btn{ padding:.75rem 1.5rem; font-weight:600; border-radius:25px; }

/* ===== Mobile Menu Toggle (Hamburguesa) ===== */
.mobile-menu-toggle{
  display:none;
  flex-direction:column;
  background:none;
  border:none;
  cursor:pointer;
  padding:.5rem;
  z-index:4001; /* por encima del overlay */
}
.hamburger-line{ width:25px; height:3px; background-color:var(--text-dark); margin:3px 0; transition:transform .28s ease, opacity .28s ease; }

/* Estado activo -> “X” */
.mobile-menu-toggle.active .hamburger-line:nth-child(1){ transform:translateY(6px) rotate(45deg); }
.mobile-menu-toggle.active .hamburger-line:nth-child(2){ opacity:0; }
.mobile-menu-toggle.active .hamburger-line:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

/* Mostrar hamburguesa y ocultar nav de escritorio en ≤1024px */
@media (max-width:1024px){
  .desktop-nav{ display:none; }
  .mobile-menu-toggle{ display:flex; }
}

/* ===== Mobile Navigation (panel deslizante) ===== */
.mobile-nav{
  display:block;
  position:fixed; top:0; right:0;
  width:360px; max-width:92vw; height:100dvh;
  background:#fff; box-shadow:var(--shadow-hover); z-index:3001;
  overflow-y:auto; -webkit-overflow-scrolling:touch; box-sizing:border-box;
  transform:translateX(100%); transition:transform .28s ease;
  border-top-left-radius:14px; border-bottom-left-radius:14px;
}
.mobile-nav.active{ transform:translateX(0); }
@media (max-width:480px){
  .mobile-nav{ width:100vw; max-width:100vw; border-radius:0; }
}
.mobile-nav-content{
  padding:calc(16px + env(safe-area-inset-top)) 20px calc(16px + env(safe-area-inset-bottom)) 20px;
}
.mobile-menu{ list-style:none; margin:0; padding:0; }
.mobile-menu li{ margin:1rem 0; }
.mobile-nav-link{
  text-decoration:none; color:var(--text-dark); font-weight:500; font-size:1.125rem;
  display:block; padding:.75rem 0; border-bottom:1px solid var(--border-color);
}
.mobile-nav-link:hover{ color:var(--primary-color); }

/* Accordion */
.mobile-accordion-toggle{
  width:100%; background:none; border:none; text-align:left; font-size:1.125rem; font-weight:500;
  color:var(--text-dark); padding:.9rem 0; cursor:pointer; display:flex; justify-content:space-between; align-items:center;
  border-bottom:1px solid var(--border-color);
}
.accordion-arrow{ transition:var(--transition); }
.mobile-accordion.active .accordion-arrow{ transform:rotate(180deg); }
.mobile-accordion-content{ max-height:0; overflow:hidden; transition:max-height .3s ease; }
.mobile-accordion.active .mobile-accordion-content{ max-height:1000px; }
.mobile-service-category{ margin:1rem 0; }
.mobile-service-category h5{ color:var(--primary-color); font-size:1rem; margin-bottom:.5rem; }
.mobile-service-category ul{ list-style:none; margin-left:1rem; }
.mobile-service-category li{ margin:.25rem 0; }
.mobile-service-category a{ text-decoration:none; color:var(--text-light); font-size:.9rem; padding:.35rem 0; display:block; }
.mobile-service-category a:hover{ color:var(--primary-color); }

.mobile-nav-footer{ margin-top:2rem; padding-top:2rem; border-top:1px solid var(--border-color); }
.mobile-contact-info{ margin-top:1rem; font-size:.875rem; }
.mobile-contact-info p{ margin:.5rem 0; }

/* Overlay (debajo del header para que el botón sea clickeable) */
.mobile-menu-overlay{
  display:none; position:fixed; inset:0;
  background-color:rgba(0,0,0,.5); backdrop-filter:blur(2px);
  z-index:2200; /* header (4000) y panel (3001) quedan arriba */
}
.mobile-menu-overlay.active{ display:block; }

/* ===== Hero ===== */
.hero{
  background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-lighter) 100%);
  color: #fff; 
  padding: 6rem 0; 
  text-align: center; 
  position: relative; 
  overflow: hidden;
}
.hero::before{
  content:''; position:absolute; inset:0;
  background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="50" cy="50" r="1" fill="white" opacity="0.1"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');
  opacity:.1;
}
.hero-content{ position:relative; z-index:1; max-width:800px; margin:0 auto; }
.hero h1{ color:#fff; margin-bottom:1.5rem; font-size:3.5rem; }
.hero p{ font-size:1.25rem; margin-bottom:2rem; color:rgba(255,255,255,.9); }

/* Page Header */
.page-header{
  background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-lighter) 100%);
  color: #fff; 
  padding: 4rem 0 2rem; 
  text-align: center;
}
.page-header h1{ color:#fff; font-size:3rem; }

/* Sections */
section{ padding:4rem 0; }
.about-preview,.services-preview,.membership-preview,.contact-preview{ background-color:var(--light-gray); }
.about-preview:nth-child(even),.services-preview:nth-child(even),.membership-preview:nth-child(even),.contact-preview:nth-child(even){ background-color:#fff; }

/* Service Cards */
.services-grid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(300px, 1fr)); gap:2rem; margin-top:2rem; }
.service-card{
  background:#fff; padding:2rem; border-radius:var(--border-radius); box-shadow:var(--shadow); text-align:center; transition:var(--transition);
}
.service-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-hover); }
.service-icon{
  width:80px; height:80px; margin:0 auto 1.5rem; background:var(--primary-color); border-radius:50%;
  display:flex; align-items:center; justify-content:center;color: var(--white);
}
.service-icon i {
  font-size: 40px; /* aumenta este valor para agrandar el icono */
  line-height: 1;
  color: var(--white); /* asegura que tenga el color correcto */
}
.service-icon img{ width:60px; height:60px; filter:brightness(0) invert(1); }
.service-card h3{ color:var(--text-dark); margin-bottom:1rem; }
.service-card p{ margin-bottom:1.5rem; }



/* Contact Info */
.contact-info{ margin-bottom:2rem; }
.contact-item{
  display:flex; align-items:center; margin:1rem 0; padding:1rem; background:#fff; border-radius:var(--border-radius); box-shadow:var(--shadow);
}
.contact-icon{
  width:40px; height:40px; background:var(--primary-color); border-radius:50%; display:flex; align-items:center; justify-content:center; margin-right:1rem; flex-shrink:0;color: var(--white);
}
.contact-icon img{ width:20px; height:20px; filter:brightness(0) invert(1); }
.contact-text h4{ margin-bottom:.25rem; color:var(--text-dark); }
.contact-text p{ margin:0; color:var(--text-light); }

/* Map */
.map-container{ border-radius:var(--border-radius); overflow:hidden; box-shadow:var(--shadow); }
.map-container iframe{ width:100%; height:300px; border:none; }
.map-container-inicio{border-radius:var(--border-radius); overflow:hidden; box-shadow:var(--shadow); }

/* ===== Footer ===== */
.main-footer{ background:var(--footer-bg); color:var(--footer-text); padding:3.5rem 0 1.5rem; }
.footer-content{ display:grid; grid-template-columns:1.3fr 1fr 1fr 1fr 1.1fr; gap:2.5rem 2rem; align-items:start; }
.footer-section h3,.footer-section h4{ color:#fff; margin-bottom:.75rem; letter-spacing:.2px; }
.footer-logo{ display:grid; grid-template-columns:48px 1fr; align-items:center; gap:.75rem; margin-bottom:.75rem; }
.footer-logo-img{ width:200px; height:200px; object-fit:contain; }
.footer-description{ color:var(--footer-dim); line-height:1.7; margin-bottom:1.25rem; }

.footer-contact .contact-item{ background:transparent !important; box-shadow:none !important; padding:.4rem 0; margin:.25rem 0; display:grid; grid-template-columns:36px 1fr; gap:.75rem; align-items:center; }
.footer-contact .contact-icon{ width:36px; height:36px; border-radius:10px; background:rgba(255,255,255,.08) !important; color:#fff; display:flex; align-items:center; justify-content:center; }
.footer-contact .contact-text p, .footer-contact span{ color:var(--footer-text); }

.footer-links{ list-style:none; margin:0; padding:0; display:grid; gap:.45rem; }
.footer-links a{ color:var(--footer-dim); text-decoration:none; padding:.15rem 0; transition:color .2s ease, transform .2s ease; }
.footer-links a:hover{ color:#fff; transform:translateX(2px); }

.hours-info p{ color:var(--footer-dim); margin:.25rem 0; }

.social-links{ display:flex; gap:.6rem; margin-top:.5rem; }
.social-link{
  width:40px; height:40px; border-radius:12px; background:rgba(255,255,255,.1);
  color:#fff; display:flex; align-items:center; justify-content:center;
  transition:transform .2s ease, background .2s ease, box-shadow .2s ease;
}
.social-link:hover{ transform:translateY(-2px); background:var(--footer-accent); box-shadow:0 6px 18px rgba(0,0,0,.25); }

.btn-footer{ margin-top:1rem; background:var(--footer-accent); border-radius:12px; padding:.9rem 1.2rem; box-shadow:0 8px 24px rgba(0,0,0,.18); }
.btn-footer:hover{ filter:brightness(.95); transform:translateY(-2px); }

.footer-section:not(:first-child){ border-left:1px solid var(--footer-border); padding-left:1.25rem; }
.footer-bottom{ border-top:1px solid var(--footer-border); margin-top:2.25rem; }
.footer-bottom-content{ gap:.75rem; }
.footer-bottom p,.footer-legal a,.footer-legal span{ color:var(--footer-dim); }
.footer-legal a:hover{ color:#fff; }

.contact-item .contact-link{
  display:flex; flex-direction:column; gap:.25rem;
  padding:.75rem 0; text-decoration:none; color:inherit;
}
.contact-item .contact-link:hover { text-decoration:underline; }
.social-links {
  display:flex; align-items:center; gap:12px;
}

.social-links h4 { margin:0; }

.social-icons {
  display:flex; align-items:center; gap:10px;  /* espacio entre iconos */
}

.social-link-contact {
  display:inline-flex;
  width:40px; height:40px;                      /* tamaño del círculo */
  border-radius:50%;
  align-items:center; justify-content:center;
  background: var(--primary-color);
  color: #fff;                                   /* los SVG usan currentColor */
  border: 1.5px solid var(--primary-color);
  text-decoration:none;
  transition: transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
}

.social-link-contact:hover {
  background: transparent;
  color: var(--primary-color);
  border-color: var(--primary-color);
  transform: translateY(-1px);
}

.social-link-contact svg {
  width:18px; height:18px; display:block;       /* tamaño del ícono */
  fill: currentColor;
}

@media (max-width: 480px){
  .social-link-contact { width:44px; height:44px; }
  .social-link-contact svg { width:20px; height:20px; }
}

@media (max-width:1100px){
  .footer-content{ grid-template-columns:1fr 1fr 1fr; }
  .footer-section:first-child{ grid-column:1 / -1; }
}
@media (max-width:720px){
  .footer-content{ grid-template-columns:1fr; gap:1.75rem; }
  .footer-section{ border-left:none !important; padding-left:0 !important; }
  .footer-logo{ grid-template-columns:80px 1fr; }
  .footer-logo-img{ width:100px; height:100px; }
  .btn-footer{ width:100%; }
  .footer-bottom-content{ flex-direction:column; text-align:center; }
}
/* Alert Messages */
.alert {
    padding: 1rem 1.5rem;
    margin-bottom: 1.5rem;
    border-radius: var(--border-radius);
    font-weight: 500;
    animation: slideDown 0.3s ease;
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.alert-success {
    background-color: #d4edda;
    color: #155724;
    border: 1px solid #c3e6cb;
}

.alert-error {
    background-color: #f8d7da;
    color: #721c24;
    border: 1px solid #f5c6cb;
}
/* ===== Modals / Calendly ===== */
.modal{ display:none; position:fixed; top:0; left:0; width:100%; height:100%; background-color:rgba(0,0,0,.5); z-index:2000; align-items:center; justify-content:center; }
.modal.active{ display:flex; }
.modal-content{ background:#fff; padding:2rem; border-radius:var(--border-radius); max-width:90%; max-height:90%; overflow-y:auto; position:relative; }
.close{ position:absolute; top:1rem; right:1rem; font-size:2rem; cursor:pointer; color:var(--text-light); transition:var(--transition); }
.close:hover{ color:var(--text-dark); }

.calendly-modal .modal-content{ width:90%; max-width:800px; height:80%; padding:0; }
.calendly-embed{ width:100%; height:100%; border-radius:var(--border-radius); overflow:hidden; }
.calendly-close{ background:#fff; border-radius:50%; width:40px; height:40px; display:flex; align-items:center; justify-content:center; top:1rem; right:1rem; z-index:2001; }

/* ===== Forms ===== */
.contact-form{ background:#fff; padding:2rem; border-radius:var(--border-radius); box-shadow:var(--shadow); }
.form-group{ margin-bottom:1.5rem; }
.form-group label{ display:block; margin-bottom:.5rem; font-weight:500; color:var(--text-dark); }
.form-group input,.form-group textarea{
  width:100%; padding:.75rem; border:1px solid var(--border-color); border-radius:var(--border-radius); font-size:1rem; transition:var(--transition);
}
.form-group input:focus,.form-group textarea:focus{ outline:none; border-color:var(--primary-color); box-shadow:0 0 0 3px rgba(185,140,2,.1); }

/* ===== Error Page ===== */
.error-page{ padding:6rem 0; text-align:center; }
.error-content h1{ font-size:8rem; color:var(--primary-color); margin-bottom:1rem; }
.error-content h2{ margin-bottom:1rem; }
.error-content p{ margin-bottom:2rem; font-size:1.125rem; }

/* ===== Service Pages ===== */
.service-hero{
  background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-lighter) 100%);
  color: #fff; 
  padding: 4rem 0; 
  text-align: center;
}
.service-hero h1{ color:#fff; margin-bottom:1rem; }
.service-hero p{ color:#fff; margin-bottom:1rem; }
.service-content{ padding:4rem 0; }
.service-section{ margin-bottom:3rem; }
.service-section h2{ color:var(--primary-color); border-bottom:2px solid var(--primary-color); padding-bottom:.5rem; margin-bottom:1.5rem; }
.service-list{ list-style:none; margin:1rem 0; }
.service-list li{ padding:.5rem 0; position:relative; padding-left:2rem; }
.service-list li::before{ content:'•'; position:absolute; left:0; color:var(--primary-color); font-weight:bold; font-size:1.5rem; }
.service-steps{ counter-reset:step-counter; }
.service-steps li{ counter-increment:step-counter; padding-left:3rem; }
.service-steps li::before{
  content:counter(step-counter); position:relative; left:0; top:.5rem;margin-bottom: 15px;
  background:var(--primary-color); color:#fff; width:2rem; height:2rem; border-radius:50%;
  display:flex; align-items:center; justify-content:center; font-weight:bold; font-size:.875rem;
}
.faq-item{ margin-bottom:1.5rem; background:var(--light-gray); border-radius:var(--border-radius); overflow:hidden; }
.faq-question{ background:var(--primary-color); color:#fff; padding:1rem; margin:0; font-weight:600; }
.faq-answer{ padding:1rem; margin:0; }

/* ===== Responsive Tweaks ===== */
@media (max-width:768px){
  .hero h1{ font-size:2.5rem; }
  .hero p{ font-size:1rem; }
  .page-header h1{ font-size:2rem; }
  .megamenu{ display:none; } /* mega menú solo desktop */
  .services-grid,.membership-cards{ grid-template-columns:1fr; }
  .footer-content{ grid-template-columns:1fr; }
  .footer-bottom-content{ flex-direction:column; gap:1rem; text-align:center; }
  .contact-item{ flex-direction:column; text-align:center; }
  .contact-icon{ margin-right:0; margin-bottom:1rem; }
  .calendly-modal .modal-content{ width:95%; height:90%; }
}
@media (max-width:480px){
  .container{ padding:0 15px; }
  .hero{ padding:4rem 0; }
  .hero h1{ font-size:2rem; }
  section{ padding:2rem 0; }
  .service-card,.membership-card{ padding:1.5rem; }
  .contact-form{ padding:1.5rem; }
}

/* ===== Animations ===== */
.fade-in{ opacity:0; transform:translateY(20px); transition:all .6s ease; }
.fade-in.visible{ opacity:1; transform:translateY(0); }
.slide-in-left{ opacity:0; transform:translateX(-50px); transition:all .6s ease; }
.slide-in-left.visible{ opacity:1; transform:translateX(0); }
.slide-in-right{ opacity:0; transform:translateX(50px); transition:all .6s ease; }
.slide-in-right.visible{ opacity:1; transform:translateX(0); }

/* ===== Utilities ===== */
.text-primary{ color:var(--primary-color); }
.bg-primary{ background:var(--primary-color); }
.bg-light{ background:var(--light-gray); }
.mt-1{ margin-top:.25rem; } .mt-2{ margin-top:.5rem; } .mt-3{ margin-top:1rem; } .mt-4{ margin-top:1.5rem; } .mt-5{ margin-top:3rem; }
.mb-1{ margin-bottom:.25rem; } .mb-2{ margin-bottom:.5rem; } .mb-3{ margin-bottom:1rem; } .mb-4{ margin-bottom:1.5rem; } .mb-5{ margin-bottom:3rem; }
.p-1{ padding:.25rem; } .p-2{ padding:.5rem; } .p-3{ padding:1rem; } .p-4{ padding:1.5rem; } .p-5{ padding:3rem; }
