/* =============================================
   Premium Redesign — Ergotherapie Mo@media(min-width:768px){
  .nav-toggle{display:none}
  .site-nav{
    position:static;
    transform:none;
    background:transparent;
    box-shadow:none;
    display:flex;
    align-items:center;
    gap:8px;
    max-height:none;
    overflow:visible;
    border-bottom:none;
  }
  .site-nav ul{display:flex;gap:8px;padding:0}
  .site-nav a{
    padding:10px 18px;
    position:relative;
    display:inline-block;
    font-size:0.9rem;
    font-weight:600;
    border-radius:8px;
    transition:all 0.2s ease;
  }
  .site-nav a::before{
    border-radius:8px;
  }
  .site-nav a::after{
    content:"";
    position:absolute;
    left:50%;
    bottom:2px;
    height:2px;
    width:0;
    background:linear-gradient(90deg, var(--primary), var(--primary-600));
    border-radius:1px;
    transform:translateX(-50%);
    transition:width 0.2s ease;
  }
  .site-nav a:hover::after{
    width:calc(100% - 36px);
  }
  .site-nav a:hover{
    transform:translateY(0px);
    box-shadow:0 1px 4px rgba(76, 161, 163, 0.1);
  }
  .site-nav a.active::after{
    width:calc(100% - 36px);
  }
}Modern, friendly palette
   - Glassmorphism accents
   - Subtle, classy animations
   ============================================= */
:root{
  --bg: #ffffff;
  --bg-soft:#FAFAFA;
  --surface:#ffffff;
  --text:#2B2B2B;
  --muted:#6B6B6B;
  --primary:#4CA1A3;      /* calm teal-blue */
  --primary-600:#3A8A8C;
  --primary-700:#2D6A6C;
  --accent:#E67E73;        /* warm coral (muted) */
  --accent-600:#cf6e64;
  --sand:#F7F2EB;          /* warm background */
  --border:#EAE6E1;
  --shadow-sm:0 6px 16px rgba(45,106,108,0.08);
  --shadow-md:0 12px 26px rgba(45,106,108,0.14);
  --shadow-lg:0 20px 44px rgba(45,106,108,0.18);
  --radius:18px;
  --radius-sm:14px;
  --container:1140px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: 'Poppins',system-ui,-apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* Remove default blue links */
a{color:inherit;text-decoration:none}
a:hover{text-decoration:none}

img,svg,video{max-width:100%;height:auto;display:block}
.container{max-width:var(--container);margin:0 auto;padding:0 22px}

.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:12px;top:12px;background:#fff;padding:8px 10px;border-radius:8px;box-shadow:var(--shadow-sm)}

/* Header */
.site-header{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:1000;
  background:rgba(255,255,255,0.95);
  backdrop-filter: blur(20px) saturate(160%);
  border-bottom:1px solid rgba(76, 161, 163, 0.1);
  transition: all 0.3s ease;
}
.site-header.scrolled{
  background:rgba(255,255,255,0.98);
  box-shadow: 0 4px 20px rgba(45, 106, 108, 0.08);
}
.header-inner{height:84px;display:flex;align-items:center;justify-content:space-between;gap:15px}
.brand{display:inline-flex;align-items:center;gap:12px;text-decoration:none;color:var(--primary-700);font-weight:700;letter-spacing:.3px;flex-shrink:0;transition:all 0.2s ease}
.brand:hover{color:var(--primary);transform:translateY(0px)}
.brand img{height:46px;width:auto;transition:transform 0.2s ease}
.brand:hover img{transform:scale(1.02)}
.nav-toggle{background:transparent;border:0;padding:10px;display:inline-flex;flex-direction:column;gap:4px;cursor:pointer;z-index:1001;flex-shrink:0;border-radius:8px;transition:all 0.3s ease}
.nav-toggle:hover{background:rgba(76, 161, 163, 0.08)}
.nav-toggle-bar{width:24px;height:2px;background:var(--primary-700);border-radius:2px;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1)}
.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(1){transform:rotate(45deg) translate(6px, 6px)}
.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(2){opacity:0;transform:scale(0)}
.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(3){transform:rotate(-45deg) translate(6px, -6px)}

@media(max-width: 767px) {
  /* Mobile navigation by default - HIDDEN */
  .site-nav{
    position:fixed; 
    top:85px; 
    left:0; 
    right:0; 
    transform:translateY(-100%);
    opacity:0;
    visibility:hidden;
    transition:all .4s cubic-bezier(0.4, 0, 0.2, 1); 
    background:rgba(255,255,255,0.98); 
    box-shadow:0 8px 32px rgba(45, 106, 108, 0.12);
    backdrop-filter: blur(20px);
    z-index:1000;
    max-height:calc(100vh - 85px);
    overflow-y:auto;
    border-bottom: 1px solid rgba(76, 161, 163, 0.1);
  }
  .site-nav.open{
    transform:translateY(0);
    opacity:1;
    visibility:visible;
  }
  .site-nav ul{list-style:none;margin:0;padding:24px 20px;display:grid;gap:4px}
  .site-nav a{
    color:var(--text);
    text-decoration:none;
    font-weight:600;
    padding:14px 20px;
    border-radius:12px;
    display:block;
    transition:all 0.2s ease;
    position:relative;
    z-index:1002;
    font-size:0.95rem;
    letter-spacing:0.3px;
  }
  .site-nav a::before{
    content:"";
    position:absolute;
    top:0;
    left:0;
    right:0;
    bottom:0;
    background:linear-gradient(135deg, rgba(76, 161, 163, 0.08), rgba(45, 106, 108, 0.12));
    border-radius:12px;
    opacity:0;
    transform:scale(0.95);
    transition:all 0.2s ease;
    z-index:-1;
  }
  .site-nav a:hover::before{
    opacity:1;
    transform:scale(1);
  }
  .site-nav a:hover{
    color:var(--primary-700);
    transform:translateY(0px);
    box-shadow:0 2px 8px rgba(76, 161, 163, 0.1);
  }
  .site-nav a.active{
    color:var(--primary);
    background:linear-gradient(135deg, rgba(76, 161, 163, 0.12), rgba(45, 106, 108, 0.08));
    box-shadow:0 2px 8px rgba(76, 161, 163, 0.2);
  }
}

/* Desktop Navigation */
@media(min-width:768px){
  .nav-toggle{display:none}
  .site-nav{
    position:static;
    transform:none;
    opacity:1;
    visibility:visible;
    background:transparent;
    box-shadow:none;
    display:flex;
    align-items:center;
    gap:8px;
    max-height:none;
    overflow:visible;
    border-bottom:none;
    top:auto;
    left:auto;
    right:auto;
  }
  .site-nav ul{display:flex;gap:8px;padding:0;list-style:none}
  .site-nav a{
    padding:10px 18px;
    position:relative;
    display:inline-block;
    font-size:0.9rem;
    font-weight:600;
    border-radius:8px;
    transition:all 0.2s ease;
  }
  .site-nav a::before{
    border-radius:8px;
  }
  .site-nav a::after{
    content:"";
    position:absolute;
    left:50%;
    bottom:2px;
    height:2px;
    width:0;
    background:linear-gradient(90deg, var(--primary), var(--primary-600));
    border-radius:1px;
    transform:translateX(-50%);
    transition:width 0.2s ease;
  }
  .site-nav a:hover::after{
    width:calc(100% - 36px);
  }
  .site-nav a:hover{
    transform:translateY(0px);
    box-shadow:0 1px 4px rgba(76, 161, 163, 0.1);
  }
  .site-nav a.active::after{
    width:calc(100% - 36px);
  }
}

/* Buttons */
.btn{--b:var(--primary);--c:#fff;display:inline-flex;align-items:center;gap:10px;border:none;border-radius:999px;padding:14px 22px;font-weight:700;text-decoration:none;color:var(--c);background:linear-gradient(180deg, var(--b), var(--primary-600));box-shadow:var(--shadow-sm);transition:.25s transform ease}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn:active{transform:translateY(0)}
.btn.primary{--b:var(--primary);background:var(--primary);color:#fff}
.btn.primary:hover{background:var(--primary-700);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn.ghost{background:transparent;color:var(--primary);border:2px solid var(--primary);box-shadow:none}
.btn.ghost:hover{background:var(--primary);color:#fff}
.btn.full{width:100%}

/* Hero */
/* Hero Section */
.hero {
  min-height: 100vh;
  background: linear-gradient(135deg, #4CA1A3 0%, #2D6A6C 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: relative;
  overflow: hidden;
  z-index: 20; /* High z-index to stay above sprites */
}
 .hero-gallery {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
}
 .hero-gallery-item {
  background-size: cover;
  background-position: center;
  opacity: .28;
  transition: opacity .8s ease, transform 7s ease;
}
 .hero-gallery-item.active {
  opacity: .6;
  transform: scale(1.05);
}
 .hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(0, 0, 0, .35), rgba(0, 0, 0, .15));
  z-index: 1;
}
 .hero-content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 64px 0;
  max-width: 800px;
}
 .hero h1 {
  margin: 0 0 12px;
  color: #fff;
  font-size: clamp(34px, 6vw, 54px);
  line-height: 1.12;
  letter-spacing: -.3px;
  text-shadow: 0 8px 22px rgba(0, 0, 0, .25);
}
 .hero p {
  margin: 0 auto 22px;
  color: rgba(255, 255, 255, .96);
  max-width: 62ch;
  font-size: 1.1rem;
}
}
.hero-gallery{position:absolute;inset:0;display:grid;grid-template-columns:repeat(4,1fr);gap:2px}
.hero-gallery-item{background-size:cover;background-position:center;opacity:.28;transition:opacity .8s ease, transform 7s ease}
.hero-gallery-item.active{opacity:.6;transform:scale(1.05)}
.hero::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(0,0,0,.35), rgba(0,0,0,.15));
  z-index:1;
}
.hero-content{position:relative;z-index:2;text-align:center;padding:64px 0;max-width:800px}
.hero h1{margin:0 0 12px;color:#fff;font-size:clamp(34px,6vw,54px);line-height:1.12;letter-spacing:-.3px;text-shadow:0 8px 22px rgba(0,0,0,.25)}
.hero p{margin:0 auto 22px;color:rgba(255,255,255,.96);max-width:62ch;font-size:1.1rem}

/* Hero Actions */
.hero-actions{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:20px;
  margin:25px 0;
  flex-wrap:wrap;
}
.hero-actions .btn{
  min-width:200px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,0.18) !important;
  backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,0.3) !important;
  color:#fff !important;
  box-shadow:0 8px 24px rgba(0,0,0,0.15), 0 0 0 1px rgba(255,255,255,0.1) inset;
  transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.hero-actions .btn:hover{
  background:rgba(255,255,255,0.28) !important;
  border-color:rgba(255,255,255,0.5) !important;
  box-shadow:0 12px 32px rgba(0,0,0,0.2), 0 0 0 1px rgba(255,255,255,0.2) inset;
  transform:translateY(-2px);
}
.hero-actions .btn i{
  color:#fff;
  opacity:0.9;
}
.hero-actions .btn .fa-whatsapp{
  color:#25D366 !important;
  opacity:1;
  filter:drop-shadow(0 2px 4px rgba(37,211,102,0.3));
}
.hero-actions .btn .fa-calendar-check{
  color:#4CAF50 !important;
  opacity:1;
  filter:drop-shadow(0 2px 4px rgba(76,175,80,0.3));
}

/* Hero Locations */
.hero-locations{display:flex;justify-content:center;gap:20px;margin:20px 0 25px;flex-wrap:wrap}
.location-item{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,0.15);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.2);border-radius:25px;padding:8px 16px;color:#fff;font-weight:600;font-size:0.95rem;box-shadow:0 4px 12px rgba(0,0,0,0.1)}
.location-item i{color:var(--accent);font-size:1rem}

/* Sections */
.section{padding:76px 0}
.section h2{font-size:clamp(24px,3.4vw,34px);margin:0 0 10px;color:var(--primary-700)}
.section .section-intro{color:var(--muted);margin-bottom:28px}

/* Glass card */
.card{
  background:rgba(255,255,255,0.78);
  border:1px solid rgba(255,255,255,0.6);
  box-shadow:var(--shadow-sm);
  border-radius:var(--radius);
  backdrop-filter: blur(8px);
}

/* Services Slideshow */
.services-slideshow{position:relative;max-width:880px;margin:0 auto;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-md);overflow:hidden;padding-bottom:15px;z-index:10}
.services-slide{display:none;padding:40px 40px 20px;text-align:center;min-height:320px}
.services-slide.active{display:block;animation:fadeIn .45s ease}
.services-slide .icon{width:84px;height:84px;border-radius:22px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--primary-700));color:#fff;margin:0 auto 18px;font-size:2rem;box-shadow:var(--shadow-sm)}
.services-slide h3{margin:0 0 12px;font-size:2rem;color:var(--primary-700)}
.services-slide p{margin:0 0 18px;color:var(--muted);font-size:1.08rem}
.services-slide .features{list-style:none;margin:0 auto;max-width:420px;display:grid;gap:8px;padding:0}
.services-slide .features li{display:flex;gap:8px;align-items:center}
.services-slide .features i{color:var(--primary)}

.slideshow-controls{display:flex;justify-content:center;gap:12px;margin:18px 0 10px;padding:0 20px}

/* Slideshow Controls */
.slideshow-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-top: 30px;
}

.slideshow-control {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: 2px solid var(--primary);
  background: white;
  color: var(--primary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  transition: all 0.3s ease;
  box-shadow: 0 4px 12px rgba(45, 106, 108, 0.2);
}

.slideshow-control:hover {
  background: var(--primary);
  color: white;
  transform: scale(1.1);
  box-shadow: 0 6px 20px rgba(45, 106, 108, 0.3);
}

/* Gallery Slideshow */
.gallery-slideshow{position:relative;max-width:900px;margin:0 auto;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-md);overflow:hidden;padding-bottom:15px;z-index:10}
.gallery-slide{display:none;position:relative}
.gallery-slide.active{display:block;animation:fadeIn .5s ease}
.gallery-slide img{width:100%;height:400px;object-fit:cover}
.slide-caption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent, rgba(0,0,0,0.7));color:#fff;padding:40px 30px 25px;text-align:center}
.slide-caption h3{margin:0 0 8px;font-size:1.5rem}
.slide-caption p{margin:0;opacity:0.9;font-size:1rem}

.gallery-controls{display:flex;justify-content:center;gap:12px;margin:18px 0 10px;padding:0 20px}
.gallery-btn{width:12px;height:12px;border-radius:50%;background:#DCDCDC;border:none;cursor:pointer;transition:.25s transform ease}
.gallery-btn.active{background:var(--primary);transform:scale(1.2)}

/* Qualifications Slideshow */
.qualifications-slideshow{position:relative;background:linear-gradient(145deg,#ffffff 0%,#f3f9f9 100%);border:1px solid #e2efef;box-shadow:0 18px 42px -14px rgba(45,106,108,.22);padding:70px 72px 110px;overflow:hidden}
.qual-slide{position:absolute;inset:0;padding:56px 72px 40px;opacity:0;transform:translateY(26px) scale(.965);transition:opacity .7s cubic-bezier(.4,.85,.3,1),transform .7s cubic-bezier(.4,.85,.3,1);display:flex;flex-direction:column;justify-content:flex-start}
.qual-slide.active{position:relative;opacity:1;transform:translateY(0) scale(1);z-index:2}
.qual-slide .qual-icon{position:relative;isolation:isolate;box-shadow:0 10px 28px -8px rgba(45,106,108,.4)}
.qual-slide .qual-icon::after{content:"";position:absolute;inset:-10px;border-radius:50%;background:radial-gradient(rgba(76,161,163,.35), transparent 70%);filter:blur(2px);z-index:-1}
.qual-slide h3{letter-spacing:.3px;font-size:1.9rem}
.qual-slide p{font-size:1.05rem;line-height:1.55}
.qual-details{margin-top:4px}
.qual-badge{background:#eef7f7;border:1px solid #d4ecec;transition:background .3s,border-color .3s,transform .3s}
.qual-badge:hover{background:#e2f1f1;border-color:#c2e4e4;transform:translateY(-2px)}
.qual-controls{position:absolute;left:0;right:0;bottom:28px;display:flex;justify-content:center;gap:14px;z-index:5;padding:0}
.qual-btn{position:relative;width:16px;height:16px;border-radius:50%;background:transparent;border:2px solid var(--primary);cursor:pointer;padding:0;transition:transform .45s,border-color .4s}
.qual-btn::after{content:"";position:absolute;inset:2px;border-radius:50%;background:var(--primary);transform:scale(0);transition:transform .55s cubic-bezier(.55,.1,.3,1.5)}
.qual-btn:hover{transform:scale(1.25)}
.qual-btn.active::after{transform:scale(1)}
.qual-btn.active{border-color:var(--primary-700)}
.qualifications-slideshow .qual-arrow,
.qualifications-slideshow .qual-toggle{position:absolute;top:16px;width:50px;height:50px;border:none;border-radius:50%;background:rgba(255,255,255,.6);backdrop-filter:blur(9px);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--primary-700);font-size:1.1rem;box-shadow:0 8px 26px -10px rgba(0,0,0,.25);transition:background .35s, transform .35s, color .35s;z-index:10}
.qualifications-slideshow .qual-arrow:hover,
.qualifications-slideshow .qual-toggle:hover{background:var(--primary);color:#fff;transform:scale(1.1)}
.qualifications-slideshow .qual-prev{left:16px}
.qualifications-slideshow .qual-next{left:78px}
.qualifications-slideshow .qual-toggle{right:16px}
.qualifications-slideshow .qual-toggle[data-state="paused"]{background:rgba(255,255,255,.9);color:var(--primary)}
.qualifications-slideshow::after{content:"";position:absolute;left:0;bottom:0;height:4px;width:0;background:linear-gradient(90deg,var(--primary),var(--primary-600));border-radius:2px;animation:qualProgress var(--qual-progress,0s) linear forwards;opacity:.85}
@keyframes qualProgress{from{width:0}to{width:100%}}
@media(max-width:900px){
  .qualifications-slideshow{padding:70px 46px 110px}
  .qual-slide{padding:48px 46px 36px}
  .qualifications-slideshow .qual-prev{left:12px}
  .qualifications-slideshow .qual-next{left:68px}
}
@media(max-width:640px){
  .qualifications-slideshow{padding:66px 26px 96px}
  .qual-slide{padding:44px 20px 30px}
  .qual-slide h3{font-size:1.55rem}
  .qualifications-slideshow .qual-arrow,
  .qualifications-slideshow .qual-toggle{width:44px;height:44px;top:12px}
  .qualifications-slideshow .qual-prev{left:10px}
  .qualifications-slideshow .qual-next{left:62px}
  .qualifications-slideshow .qual-toggle{right:10px}
  .qual-btn{width:14px;height:14px}
}

/* Testimonials */
.testimonials{background:linear-gradient(135deg,var(--sand) 0%, #F3FBFB 100%);padding:88px 0}
.testimonials h2{text-align:center;margin-bottom:46px}
.testimonials-grid{display:grid;grid-template-columns:1fr;gap:22px;max-width:980px;margin:0 auto}
.testimonial-card{background:var(--surface);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);border-left:4px solid var(--accent)}
.testimonial-quote{font-style:italic;color:var(--text);margin:0 0 12px}
.testimonial-author{display:flex;align-items:center;gap:10px}
.testimonial-avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-700));display:grid;place-items:center;color:#fff;font-weight:700}

@media(min-width:768px){.testimonials-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.testimonials-grid{grid-template-columns:repeat(3,1fr)}}

/* Interactive Map */
.interactive-map-container{max-width:1000px;margin:0 auto;background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);z-index:10;position:relative}

.map-header{background:linear-gradient(135deg,var(--primary),var(--primary-700));color:#fff;padding:20px 30px}
.map-info{display:flex;gap:30px;align-items:center;flex-wrap:wrap}
.location-badge,.coverage-info{display:flex;align-items:center;gap:8px;font-weight:600}
.location-badge i{color:var(--accent);font-size:1.1rem}
.coverage-info i{color:#fff;font-size:1rem;opacity:0.9}

.enhanced-map{position:relative;height:450px;overflow:hidden}
.map-overlay{position:absolute;inset:0;z-index:10;pointer-events:none}

/* Service Area Circle */
.service-area-circle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:400px;height:400px;border:3px dashed var(--accent);border-radius:50%;display:grid;place-items:center;animation:pulseRadius 4s ease-in-out infinite;pointer-events:none}
.center-marker{background:var(--accent);color:#fff;width:80px;height:80px;border-radius:50%;display:grid;place-items:center;font-size:1.5rem;box-shadow:0 8px 25px rgba(230,126,115,0.4);text-align:center;line-height:1.2}
.marker-label{font-size:0.7rem;font-weight:600;margin-top:4px}
.area-radius{position:absolute;top:-25px;left:50%;transform:translateX(-50%);background:rgba(76,161,163,0.9);color:#fff;padding:4px 12px;border-radius:15px;font-size:0.8rem;font-weight:600;backdrop-filter:blur(5px)}

/* Location Markers */
.location-markers{position:absolute;inset:0}
.location-marker{position:absolute;background:var(--primary);color:#fff;width:40px;height:40px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);display:grid;place-items:center;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px rgba(76,161,163,0.3)}
.location-marker i{transform:rotate(45deg);font-size:1.1rem}
.location-marker:hover{transform:rotate(-45deg) scale(1.2);box-shadow:0 8px 25px rgba(76,161,163,0.5)}

/* Marker Tooltips */
.marker-tooltip{position:absolute;bottom:120%;left:50%;transform:translateX(-50%) rotate(45deg);background:rgba(0,0,0,0.8);color:#fff;padding:6px 10px;border-radius:6px;font-size:0.8rem;font-weight:500;opacity:0;pointer-events:none;transition:opacity .3s ease;white-space:nowrap}
.location-marker:hover .marker-tooltip{opacity:1}

.map-footer{background:var(--sand);padding:20px 30px}
.coverage-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px}
.stat-item{text-align:center;padding:15px;background:#fff;border-radius:12px;box-shadow:var(--shadow-sm);transition:transform .3s ease}
.stat-item:hover{transform:translateY(-2px)}
.stat-item i{color:var(--primary);font-size:1.5rem;margin-bottom:8px;display:block}
.stat-item span{display:block;color:var(--muted);font-size:0.9rem;margin-bottom:4px}
.stat-item strong{color:var(--primary-700);font-size:1.1rem;font-weight:700}

@keyframes pulseRadius{0%,100%{opacity:0.6;transform:translate(-50%,-50%) scale(1)}50%{opacity:0.3;transform:translate(-50%,-50%) scale(1.1)}}

@media(max-width:768px){
  .header-inner{
    padding:0 15px;
    gap:10px;
  }
  .brand span{
    font-size:0.9rem;
  }
  .map-info{flex-direction:column;gap:15px;align-items:flex-start}
  .enhanced-map{height:350px}
  .service-area-circle{width:300px;height:300px}
  .center-marker{width:60px;height:60px;font-size:1.2rem}
  .coverage-stats{grid-template-columns:1fr}
}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr;gap:20px}
.contact-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm);z-index:10;position:relative}
.form-row{display:grid;grid-template-columns:1fr;gap:12px}
.form-field{display:grid;gap:6px}
label{font-size:.96rem}
input:not([type="checkbox"]),textarea,select{width:100%;padding:12px 14px;border-radius:12px;border:1px solid #E1E7E7;background:#F9FCFC;color:var(--text);font:inherit;box-shadow:inset 0 1px 0 rgba(16,24,40,.02);transition:border-color .2s, box-shadow .2s}
input:not([type="checkbox"]):focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #EAF4F4}
select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23667085' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}
.form-consent{display:flex;align-items:center;gap:12px;font-size:.92rem;color:var(--muted);margin-top:8px}
.form-consent input[type="checkbox"]{width:20px;height:20px;min-width:20px;cursor:pointer;margin:0;accent-color:var(--primary)}
.form-consent label{margin:0;cursor:pointer;user-select:none}
.form-feedback{margin-top:10px;font-weight:700;padding:12px;border-radius:8px;background:#f0f9ff}

/* Button spinner for form submission */
.btn-spinner{display:none}
.btn-text,.btn-spinner{transition:opacity .2s}
button[disabled]{opacity:0.7;cursor:not-allowed}

/* Mobile consent label wrap fix */
@media (max-width: 600px) {
  .form-consent { align-items: flex-start; }
  .form-consent label { flex: 1; line-height:1.4; word-break:break-word; hyphens:auto; }
}

/* Social Media Links */
.socials{display:flex;gap:12px;justify-content:center}
.social{position:relative;width:44px;height:44px;display:grid;place-items:center;border-radius:50%;text-decoration:none;font-size:1.2rem;transition:all .3s cubic-bezier(0.4, 0, 0.2, 1);overflow:hidden}

/* Social Link Tooltips */
.social-tooltip{position:absolute;bottom:120%;left:50%;transform:translateX(-50%);background:rgba(0,0,0,0.8);color:#fff;padding:6px 10px;border-radius:6px;font-size:0.8rem;font-weight:500;opacity:0;pointer-events:none;transition:opacity .3s ease;white-space:nowrap}
.social-tooltip::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:4px solid transparent;border-top-color:rgba(0,0,0,0.8)}
.social:hover .social-tooltip{opacity:1}

/* Instagram */
.social-instagram{background:linear-gradient(45deg, #f09433 0%,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%);color:#fff;box-shadow:0 4px 15px rgba(188,24,136,0.3)}
.social-instagram:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 8px 25px rgba(188,24,136,0.4)}

/* Facebook */
.social-facebook{background:linear-gradient(45deg, #1877f2, #42a5f5);color:#fff;box-shadow:0 4px 15px rgba(24,119,242,0.3)}
.social-facebook:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 8px 25px rgba(24,119,242,0.4)}

/* WhatsApp */
.social-whatsapp{background:linear-gradient(45deg, #25d366, #128c7e);color:#fff;box-shadow:0 4px 15px rgba(37,211,102,0.3)}
.social-whatsapp:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 8px 25px rgba(37,211,102,0.4)}

/* Pulse Animation on Hover */
.social::before{content:'';position:absolute;inset:0;border-radius:50%;opacity:0;transition:all .3s ease}
.social-instagram:hover::before{background:radial-gradient(circle, rgba(188,24,136,0.2) 0%, transparent 70%);opacity:1;animation:pulse 1.5s infinite}
.social-facebook:hover::before{background:radial-gradient(circle, rgba(24,119,242,0.2) 0%, transparent 70%);opacity:1;animation:pulse 1.5s infinite}
.social-whatsapp:hover::before{background:radial-gradient(circle, rgba(37,211,102,0.2) 0%, transparent 70%);opacity:1;animation:pulse 1.5s infinite}

@keyframes pulse{0%,100%{transform:scale(1);opacity:0.3}50%{transform:scale(1.2);opacity:0.1}}

@media(min-width:740px){.contact-grid{grid-template-columns:1fr 1.2fr;gap:22px}.form-row{grid-template-columns:1fr 1fr}}

/* Footer */
.site-footer{background:var(--primary-700);color:#E7F2F2;margin-top:36px}
.footer-grid{display:grid;grid-template-columns:1fr;gap:16px;padding:28px 0 10px}
.footer-box h3,.footer-box h4{margin:0 0 8px;color:#fff}
.footer-list{list-style:none;margin:0;padding:0;display:grid;gap:6px}
.site-footer a{color:#D6F1F1;text-decoration:none;transition:color .3s ease}
.site-footer a:hover{color:#fff}
.footer-legal{border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 0 22px;flex-wrap:wrap}

/* FAQ Page Styles */
.faq-page {
  min-height: calc(100vh - 200px);
  padding-top: 120px;
}

.faq-content {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 20px;
}

.faq-intro {
  text-align: center;
  margin-bottom: 50px;
  background: white;
  padding: 40px;
  border-radius: 20px;
  box-shadow: 0 8px 32px rgba(45, 106, 108, 0.1);
}

.faq-intro h1 {
  color: var(--primary-700);
  margin-bottom: 15px;
  font-size: 2.2rem;
}

.faq-intro h1 i {
  margin-right: 12px;
  color: var(--primary);
}

.faq-intro p {
  color: var(--text-secondary);
  font-size: 1.1rem;
  line-height: 1.6;
}

.faq-categories {
  display: grid;
  gap: 30px;
  margin-bottom: 60px;
}

.faq-category {
  background: white;
  border-radius: 20px;
  padding: 30px;
  box-shadow: 0 8px 32px rgba(45, 106, 108, 0.1);
  border: 1px solid var(--primary-100);
}

.faq-category h2 {
  color: var(--primary-700);
  margin-bottom: 25px;
  font-size: 1.5rem;
  display: flex;
  align-items: center;
  gap: 12px;
}

.faq-category h2 i {
  color: var(--primary);
  font-size: 1.2rem;
}

.faq-list {
  display: grid;
  gap: 15px;
}

.faq-item {
  border: 1px solid var(--primary-100);
  border-radius: 12px;
  overflow: hidden;
  transition: all 0.3s ease;
}

.faq-item:hover {
  box-shadow: 0 4px 16px rgba(45, 106, 108, 0.1);
}

.faq-question {
  width: 100%;
  background: var(--bg-soft);
  border: none;
  padding: 20px 25px;
  text-align: left;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 15px;
  font-weight: 600;
  color: var(--primary-700);
  transition: all 0.3s ease;
  font-size: 1rem;
}

.faq-question span {
  flex: 1;
  line-height: 1.5;
  word-wrap: break-word;
}

.faq-question:hover {
  background: var(--primary-100);
}

.faq-question.active {
  background: var(--primary);
  color: white;
}

.faq-icon {
  font-size: 1.2rem;
  transition: transform 0.3s ease;
  color: var(--primary);
  flex-shrink: 0;
  margin-top: 2px;
}

.faq-item.active .faq-icon {
  transform: rotate(180deg);
}

.faq-item.active .faq-question {
  background: var(--primary);
  color: white;
}

.faq-item.active .faq-question .faq-icon {
  color: white;
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.5s ease, padding 0.5s ease;
  background: white;
  padding: 0 25px;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

.faq-item.active .faq-answer {
  padding: 25px;
  overflow: visible;
}

.faq-answer p {
  margin: 0 0 15px 0;
  line-height: 1.8;
  color: var(--text);
  word-wrap: break-word;
  overflow-wrap: break-word;
}

.faq-answer p:last-child {
  margin-bottom: 0;
}

.faq-answer ul {
  margin: 15px 0;
  padding-left: 20px;
  color: var(--text);
}

.faq-answer li {
  margin-bottom: 8px;
  line-height: 1.5;
}

.faq-highlight {
  background: var(--primary-100);
  color: var(--primary-700);
  padding: 15px 20px;
  border-radius: 10px;
  margin: 20px 0;
  border-left: 4px solid var(--primary);
}

.faq-highlight strong {
  color: var(--primary-700);
}

.faq-contact-cta {
  background: linear-gradient(135deg, var(--primary), var(--primary-700));
  color: white;
  padding: 40px;
  border-radius: 20px;
  text-align: center;
  margin-top: 50px;
}

.faq-contact-cta h3 {
  margin-bottom: 15px;
  color: white;
}

.faq-contact-cta p {
  margin-bottom: 25px;
  opacity: 0.9;
  font-size: 1.1rem;
}

@media(max-width: 768px) {
  .faq-page {
    padding-top: 100px;
  }
  
  .faq-intro {
    padding: 25px 20px;
    margin: 0 20px 40px 20px;
  }
  
  .faq-category {
    padding: 25px 20px;
    margin: 0 20px;
  }
  
  .faq-question {
    padding: 15px 20px;
    font-size: 0.95rem;
    gap: 10px;
  }
  
  .faq-question span {
    font-size: 0.95rem;
  }
  
  .faq-answer {
    font-size: 0.9rem;
    padding: 0 20px;
  }
  
  .faq-answer.active {
    padding: 20px;
  }
  
  .faq-contact-cta {
    padding: 30px 20px;
    margin: 40px 20px 0 20px;
  }
}

/* Legal Pages (Datenschutz, Impressum) */
.legal-page {
  min-height: calc(100vh - 200px);
  padding-top: 120px;
}

.legal-content {
  padding: 60px 0;
}

.legal-wrapper {
  display: grid;
  grid-template-columns: 250px 1fr;
  gap: 40px;
  max-width: 1200px;
  margin: 0 auto;
}

.legal-nav {
  position: sticky;
  top: 140px;
  height: fit-content;
  background: white;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 25px;
  box-shadow: 0 8px 32px rgba(45, 106, 108, 0.08);
}

.legal-nav h3 {
  color: var(--primary-700);
  margin: 0 0 20px;
  font-size: 1.1rem;
}

.legal-nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.legal-nav li {
  margin-bottom: 8px;
}

.legal-nav a {
  color: var(--muted);
  text-decoration: none;
  font-size: 0.9rem;
  padding: 6px 0;
  display: block;
  transition: color 0.2s ease;
}

.legal-nav a:hover {
  color: var(--primary);
}

.legal-text {
  background: white;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 40px;
  box-shadow: 0 8px 32px rgba(45, 106, 108, 0.08);
}

.legal-text section {
  margin-bottom: 40px;
}

.legal-text h2 {
  color: var(--primary-700);
  border-bottom: 2px solid var(--primary);
  padding-bottom: 10px;
  margin-bottom: 20px;
}

.legal-text h3 {
  color: var(--primary-700);
  margin: 25px 0 15px;
}

.legal-text p {
  line-height: 1.7;
  margin-bottom: 15px;
}

.legal-text ul {
  margin: 15px 0;
  padding-left: 20px;
}

.legal-text li {
  margin-bottom: 8px;
  line-height: 1.6;
}

.contact-box {
  background: var(--sand);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 20px;
  margin: 20px 0;
  line-height: 1.6;
}

.contact-box strong {
  color: var(--primary-700);
}

.contact-box a {
  color: var(--primary);
  text-decoration: none;
}

.contact-box a:hover {
  text-decoration: underline;
}

/* Mobile Anpassungen für Legal Pages */
@media (max-width: 900px) {
  .legal-wrapper {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  
  .legal-nav {
    position: static;
    order: 1;
  }
  
  .legal-text {
    padding: 25px 20px;
    order: 2;
  }
}

@media (max-width: 600px) {
  .legal-page {
    padding-top: 100px;
  }
  
  .legal-content {
    padding: 40px 0;
  }
  
  .legal-nav {
    margin: 0 20px;
    padding: 20px;
  }
  
  .legal-text {
    margin: 0 20px;
    padding: 20px 15px;
  }
}

/* Reveal (AOS alternative fallback) */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .6s ease, transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* About page quick bits kept from original */
.page-hero{background:linear-gradient(135deg,var(--primary) 0%, var(--primary-700) 100%);color:#fff;padding:120px 0 84px;text-align:center}
.page-hero h1{font-size:clamp(28px,5vw,42px);margin:0 0 14px}
.hero-subtitle{font-size:1.16rem;margin:0;opacity:.95}

/* About page layout */
.about-content {
  padding: 60px 0;
}

.about-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
}

.about-image {
  display: flex;
  justify-content: center;
  align-items: center;
}

.about-image img {
  width: 400px;
  height: 400px;
  border-radius: 50%;
  object-fit: cover;
  box-shadow: 0 16px 48px rgba(45, 106, 108, 0.2);
  border: 5px solid white;
}

.about-text {
  text-align: center;
}

.about-text h2 {
  color: var(--primary-700);
  margin-bottom: 25px;
  font-size: 1.8rem;
}

.about-text p {
  line-height: 1.7;
  margin-bottom: 20px;
  color: var(--text);
}

@media(min-width: 768px) {
  .about-grid {
    grid-template-columns: 1fr 1.2fr;
    gap: 60px;
  }
  
  .about-text {
    text-align: left;
  }
  
  .about-image {
    justify-content: center;
  }
}

@media(min-width: 1024px) {
  .about-image img {
    width: 450px;
    height: 450px;
  }
}

/* Qualifikations-Karten (ersetzt Slideshow) */
.qualifications-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 30px;
  margin: 40px 0;
}

.qualification-card {
  background: linear-gradient(145deg, #ffffff 0%, #f8fbfb 100%);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 0;
  box-shadow: 0 8px 32px rgba(45, 106, 108, 0.08);
  transition: all 0.3s ease;
  overflow: hidden;
}

.qualification-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 48px rgba(45, 106, 108, 0.15);
}

.card-header {
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-700) 100%);
  color: white;
  padding: 25px 25px 20px;
  text-align: center;
  position: relative;
}

.qual-icon {
  width: 70px;
  height: 70px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(10px);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 15px;
  font-size: 1.8rem;
  border: 2px solid rgba(255, 255, 255, 0.3);
}

.qualification-card h3 {
  margin: 0 0 8px;
  font-size: 1.3rem;
  font-weight: 700;
}

.qual-level {
  background: rgba(255, 255, 255, 0.2);
  padding: 6px 16px;
  border-radius: 20px;
  font-size: 0.85rem;
  font-weight: 600;
  display: inline-block;
  border: 1px solid rgba(255, 255, 255, 0.3);
}

.card-content {
  padding: 25px;
}

.card-content p {
  margin: 0 0 20px;
  line-height: 1.6;
  color: var(--text);
  font-size: 0.95rem;
}

.cert-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.cert-badge {
  background: var(--sand);
  color: var(--primary-700);
  padding: 6px 12px;
  border-radius: 15px;
  font-size: 0.8rem;
  font-weight: 600;
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 6px;
  transition: all 0.2s ease;
}

.cert-badge:hover {
  background: var(--primary);
  color: white;
  transform: scale(1.05);
}

.cert-badge.primary {
  background: linear-gradient(135deg, var(--primary), var(--primary-600));
  color: white;
  border-color: var(--primary-600);
}

.cert-badge.primary:hover {
  transform: scale(1.05);
  box-shadow: 0 4px 12px rgba(45, 106, 108, 0.3);
}

.cert-badge i {
  font-size: 0.7rem;
}

.qualifications-footer {
  background: linear-gradient(135deg, #f6fbfb, #eef6f6);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 25px;
  text-align: center;
  margin-top: 40px;
}

.continuing-education h4 {
  margin: 0 0 12px;
  color: var(--primary-700);
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.continuing-education p {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
  max-width: 800px;
  margin: 0 auto;
}

/* Highlight-Karte für neueste Qualifikation */
.qualification-card.highlight {
  border: 2px solid var(--primary);
  box-shadow: 0 12px 40px rgba(45, 106, 108, 0.15);
  position: relative;
}

.qualification-card.highlight::before {
  content: "NEU";
  position: absolute;
  top: -8px;
  right: 15px;
  background: var(--accent);
  color: white;
  padding: 4px 12px;
  border-radius: 12px;
  font-size: 0.7rem;
  font-weight: 700;
  z-index: 10;
}

.qualification-card.highlight:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 60px rgba(45, 106, 108, 0.2);
}

/* Kurs-Details Sektion */
.course-details {
  margin-top: 20px;
  padding-top: 15px;
  border-top: 1px solid var(--border);
}

.course-details h5 {
  margin: 0 0 12px;
  color: var(--primary-700);
  font-size: 0.9rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 6px;
}

.course-details ul {
  margin: 0;
  padding-left: 16px;
  list-style: none;
}

.course-details li {
  margin-bottom: 6px;
  font-size: 0.85rem;
  line-height: 1.4;
  color: var(--muted);
  position: relative;
}

.course-details li::before {
  content: "→";
  position: absolute;
  left: -16px;
  color: var(--primary);
  font-weight: 600;
}

/* Spezial-Icon für obere Extremität */
.qual-icon.spezialkurs {
  background: linear-gradient(135deg, var(--accent), var(--accent-600));
}

/* Prevent horizontal scrolling */
body, html {
  overflow-x: hidden;
}

/* Modern slideshow navigation arrows */
.quotes-slideshow .slideshow-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255, 255, 255, 0.9);
  border: 2px solid var(--primary);
  width: 50px;
  height: 50px;
  border-radius: 50%;
  cursor: pointer;
  color: var(--primary);
  font-size: 1.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  backdrop-filter: blur(10px);
  box-shadow: 0 4px 15px rgba(45, 106, 108, 0.2);
}

.quotes-slideshow .slideshow-nav:hover {
  background: var(--primary);
  color: white;
  transform: translateY(-50%) scale(1.1);
  box-shadow: 0 6px 25px rgba(45, 106, 108, 0.4);
}

.quotes-slideshow .slideshow-nav.prev {
  left: -25px;
}

.quotes-slideshow .slideshow-nav.next {
  right: -25px;
}

@media(max-width: 768px) {
  .quotes-slideshow .slideshow-nav {
    width: 40px;
    height: 40px;
    font-size: 1rem;
  }
  
  .quotes-slideshow .slideshow-nav.prev {
    left: -20px;
  }
  
  .quotes-slideshow .slideshow-nav.next {
    right: -20px;
  }
}

/* Modern Slideshow Base */
.modern-slideshow {
  position: relative;
  overflow: hidden;
  padding: 18px 22px 70px;
  border-radius: 26px;
  background: linear-gradient(135deg, #ffffff 0%, #f6fafb 100%);
  box-shadow: 0 12px 38px -10px rgba(20,60,70,.18);
}

.modern-slideshow .ms-track > * {
  opacity: 0;
  transform: translateX(35px) scale(.97);
  transition: opacity .6s ease, transform .6s cubic-bezier(.4,.8,.3,1);
  position: absolute;
  inset: 18px 22px 90px;
  overflow-y: auto;
}

.modern-slideshow .ms-track > *.active {
  position: relative;
  opacity: 1;
  transform: translateX(0) scale(1);
}

.modern-slideshow .ms-nav,
.modern-slideshow .ms-toggle {
  position: absolute;
  top: 12px;
  z-index: 5;
  width: 46px;
  height: 46px;
  border: none;
  border-radius: 50%;
  backdrop-filter: blur(8px);
  background: rgba(255,255,255,.55);
  color: var(--primary);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 4px 18px -4px rgba(0,0,0,.25);
  transition: background .3s, transform .35s;
  font-size: 1.05rem;
}

.modern-slideshow .ms-nav:hover,
.modern-slideshow .ms-toggle:hover {
  background: var(--primary);
  color: #fff;
  transform: scale(1.08);
}

.modern-slideshow .ms-prev { left: 12px; }
.modern-slideshow .ms-next { left: 64px; }
.modern-slideshow .ms-toggle { right: 12px; }

.modern-slideshow .ms-dots {
  position: absolute;
  left: 0; right: 0; bottom: 18px;
  display: flex;
  justify-content: center;
  gap: 10px;
  padding: 6px 10px;
}

.modern-slideshow .ms-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 2px solid var(--primary);
  background: transparent;
  cursor: pointer;
  position: relative;
  transition: background .4s, transform .4s;
}

.modern-slideshow .ms-dot::after {
  content: '';
  position: absolute;
  inset: 2px;
  border-radius: 50%;
  background: var(--primary);
  transform: scale(0);
  transition: transform .45s cubic-bezier(.55,.1,.3,1.4);
}

.modern-slideshow .ms-dot:hover {
  transform: scale(1.2);
}

.modern-slideshow .ms-dot.active::after {
  transform: scale(1);
}

.modern-slideshow .ms-toggle[data-state="paused"] {
  background: rgba(255,255,255,.85);
}

.modern-slideshow .ms-toggle[data-state="paused"] i {
  color: var(--primary);
}

/* Quote specific tweaks */
.quotes-section.modern-slideshow {
  padding-top: 60px;
}

.quotes-section .ms-track > .quote-slide {
  opacity: 0;
  transform: translateY(8px) scale(.99);
  transition: opacity .8s ease, transform .8s ease;
  position: absolute;
  inset: 18px 22px 90px;
  overflow-y: auto;
}

.quotes-section.modern-slideshow .ms-track > .quote-slide.active {
  position: relative;
  opacity: 1;
  transform: translateY(0) scale(1);
}

/* Langsamere Dot-Animationen für Zitate */
.quotes-section .ms-dot::after {
  transition: transform .6s ease;
}

.quotes-section .ms-dot:hover {
  transform: scale(1.15);
}

/* --- Leistungen Seite Optimierungen --- */
/* Grid für Leistungs-Karten (falls noch nicht vorhanden) */
#leistungen .services-grid{
  display:grid;
  gap:48px 38px;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  margin:0 0 10px;
  padding:0;
}

/* Kartenlayout */
.service-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:18px;
  padding:32px 28px 30px;
  box-shadow:var(--shadow-sm);
  display:flex;
  flex-direction:column;
  gap:14px;
  position:relative;
  transition:box-shadow .35s, transform .35s;
}
.service-card:hover{
  box-shadow:var(--shadow-md);
  transform:translateY(-3px);
}

/* Icon in Karte (optional – falls vorhanden) */
.service-card .icon{
  width:70px;height:70px;
  border-radius:20px;
  background:linear-gradient(135deg,var(--primary),var(--primary-700));
  color:#fff;
  display:grid;place-items:center;
  font-size:1.55rem;
  box-shadow:0 6px 18px -6px rgba(45,106,108,.45);
}

/* Überschriften & Fließtext straffen */
.service-card h2{
  margin:6px 0 4px;
  font-size:1.45rem;
  line-height:1.25;
  color:var(--primary-700);
  letter-spacing:.2px;
}
.service-card p{
  margin:0 0 10px;
  font-size:0.98rem;
  line-height:1.55;
  color:var(--muted);
}

/* Punkte-Liste vereinheitlichen */
.service-points{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:6px;
  font-size:0.92rem;
}
.service-points li{
  position:relative;
  padding-left:18px;
  line-height:1.4;
  color:var(--text);
}
.service-points li::before{
  content:"•";
  position:absolute;
  left:0;
  top:0;
  color:var(--primary);
  font-weight:700;
  line-height:1.1;
}

/* Letztes Element kein extra Abstand */
#leistungen .services-grid > *:last-child{margin-bottom:0}

/* Intro-Abstand etwas reduziert */
#leistungen .section-intro{margin-bottom:34px}

/* Hinweisbox (info-hint) */
.info-hint{
  background:linear-gradient(135deg,#f6fbfb,#eef6f6);
  border:1px solid #d8ebeb;
  padding:18px 22px;
  border-radius:14px;
  font-size:0.9rem;
  line-height:1.5;
  color:var(--primary-700);
  box-shadow:0 4px 14px -6px rgba(45,106,108,.15);
  max-width:880px;
  margin:0 auto;
}
.info-hint strong{color:var(--primary-700)}

/* Weißraum unter Leistungsbereich verkleinern, ohne globales Layout zu stören */
#leistungen.section{padding-bottom:48px}
#leistungen + .section{padding-top:30px}

/* Mobile Feintuning */
@media(max-width:640px){
  #leistungen .services-grid{gap:34px 24px}
  .service-card{padding:26px 22px 26px}
  .service-card h2{font-size:1.3rem}
  .service-card p{font-size:0.95rem}
  .service-points{gap:5px}
}

/* Sicherstellen, dass keine alten Sprite-Reste stören (Falls styles vor dieser Stelle fehlen) */
.floating-sprite,
.sprite,
.sprite-hand,
.sprite-cross,
[data-sprite],
.sprites-wrapper{
  display:none !important;
  visibility:hidden !important;
  pointer-events:none !important;
}

/* Zentrierter CTA Block Leistungen */
.leistungen-cta{
  max-width:960px;
  margin:60px auto 0;
  text-align:center;
  padding:0 24px 10px;
}
.leistungen-cta h2{
  margin:0 0 14px;
  font-size:clamp(1.3rem,2.2vw,1.55rem);
  color:var(--primary-700);
  letter-spacing:.3px;
}
.leistungen-cta p{
  margin:0 0 26px;
  font-size:.95rem;
  line-height:1.55;
  color:var(--muted);
  max-width:680px;
}
.leistungen-cta .cta-actions{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
}
.leistungen-cta .cta-actions .btn{
  min-width:180px;
  justify-content:center;
  font-size:.9rem;
  padding:13px 22px;
}

/* Ghost Button Angleichen */
.leistungen-cta .btn.ghost{
  border:2px solid var(--primary);
  background:transparent;
  color:var(--primary-700);
  font-weight:700;
  box-shadow:none;
  transition:background .25s,color .25s;
}
.leistungen-cta .btn.ghost:hover{
  background:var(--primary);
  color:#fff;
}

/* Mobile Verfeinerung */
@media (max-width:700px){
  .leistungen-cta{margin-top:46px;padding:0 12px}
  .leistungen-cta p{margin-bottom:22px}
  .leistungen-cta .cta-actions{gap:12px}
  .leistungen-cta .cta-actions .btn{width:100%}
}

/* Erweiterte Leistungen-Seite Styles */
.service-header {
  border-bottom: 1px solid var(--border);
  padding-bottom: 15px;
  margin-bottom: 20px;
}

.service-subtitle {
  color: var(--muted);
  font-size: 0.9rem;
  margin: 5px 0 0;
  font-weight: normal;
}

.service-content h4 {
  color: var(--primary-700);
  font-size: 1rem;
  margin: 20px 0 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.indications-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.indication-tag {
  background: var(--primary);
  color: white;
  padding: 4px 10px;
  border-radius: 12px;
  font-size: 0.8rem;
  font-weight: 600;
}

/* Therapieablauf Einführung */
.therapy-intro-section {
  background: white;
  padding: 60px 0;
}

.therapy-intro-box {
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
  padding: 40px 30px;
  background: linear-gradient(135deg, var(--primary-50), var(--sand));
  border-radius: 20px;
  box-shadow: 0 10px 40px rgba(45, 106, 108, 0.1);
}

.therapy-intro-icon {
  width: 80px;
  height: 80px;
  margin: 0 auto 25px;
  background: linear-gradient(135deg, var(--primary), var(--primary-600));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 24px rgba(45, 106, 108, 0.25);
}

.therapy-intro-icon i {
  font-size: 2.5rem;
  color: white;
}

.therapy-intro-box h2 {
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  color: var(--primary-700);
  margin: 0 0 20px 0;
  font-weight: 700;
}

.therapy-intro-box p {
  font-size: 1.1rem;
  line-height: 1.8;
  color: var(--text);
  margin: 0;
  max-width: 700px;
  margin: 0 auto;
}

@media (max-width: 600px) {
  .therapy-intro-section {
    padding: 40px 0;
  }
  
  .therapy-intro-box {
    padding: 30px 20px;
  }
  
  .therapy-intro-icon {
    width: 70px;
    height: 70px;
  }
  
  .therapy-intro-icon i {
    font-size: 2rem;
  }
  
  .therapy-intro-box p {
    font-size: 1rem;
  }
}

/* Therapie-Prozess */
.therapy-process {
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-700) 100%);
  color: #fff;
  padding: 120px 0 84px;
  text-align: center;
}

.therapy-process h2 {
  font-size: clamp(28px, 5vw, 42px);
  margin: 0 0 14px;
  color: #fff;
}

.therapy-process .section-intro {
  font-size: 1.16rem;
  margin: 0 0 50px 0;
  opacity: 0.95;
  color: #fff;
}

.therapy-process .container {
  max-width: 1200px;
}

.therapy-process .process-steps {
  background: white;
  border-radius: 20px;
  padding: 60px 40px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 30px;
  margin-top: 0;
}

.step-card {
  background: var(--surface);
  border-radius: 16px;
  padding: 25px;
  box-shadow: 0 4px 16px rgba(45, 106, 108, 0.08);
  position: relative;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  border: 1px solid var(--border);
}

.step-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 32px rgba(45, 106, 108, 0.15);
}

.step-number {
  position: absolute;
  top: -15px;
  left: 25px;
  width: 40px;
  height: 40px;
  background: var(--primary);
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 1.2rem;
}

.step-content h3 {
  margin: 10px 0 15px;
  color: var(--primary-700);
  display: flex;
  align-items: center;
  gap: 10px;
}

.step-content ul {
  list-style: none;
  padding: 0;
  margin: 15px 0 0;
}

.step-content li {
  padding: 3px 0;
  font-size: 0.9rem;
  color: var(--muted);
}

.step-content li::before {
  content: "✓";
  color: var(--primary);
  font-weight: bold;
  margin-right: 8px;
}

/* Info Cards */
.info-section {
  padding: 80px 0;
}

.info-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 30px;
}

.info-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 30px;
  text-align: center;
  box-shadow: 0 8px 32px rgba(45, 106, 108, 0.08);
  transition: transform 0.3s ease;
}

.info-card:hover {
  transform: translateY(-3px);
}

.info-icon {
  width: 80px;
  height: 80px;
  background: linear-gradient(135deg, var(--primary), var(--primary-700));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  font-size: 2rem;
  color: white;
}

.info-card h3 {
  color: var(--primary-700);
  margin-bottom: 15px;
}

.info-card ul {
  text-align: left;
  list-style: none;
  padding: 0;
  margin-top: 15px;
}

.info-card li {
  padding: 5px 0;
  font-size: 0.9rem;
}

.info-card li::before {
  content: "→";
  color: var(--primary);
  font-weight: bold;
  margin-right: 8px;
}

/* FAQ Sektion */
.faq-section {
  background: linear-gradient(135deg, var(--sand), #f3fbfb);
  padding: 80px 0;
}

.faq-grid {
  display: grid;
  gap: 15px;
  max-width: 800px;
  margin: 0 auto;
}

.faq-item {
  background: white;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(45, 106, 108, 0.08);
}

.faq-question {
  width: 100%;
  background: none;
  border: none;
  padding: 20px 25px;
  text-align: left;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 600;
  color: var(--primary-700);
  transition: all 0.3s ease;
}

.faq-question:hover {
  background: var(--sand);
}

.faq-question.active {
  background: var(--primary);
  color: white;
}

.faq-icon {
  transition: transform 0.3s ease;
  color: var(--primary);
}

.faq-question.active .faq-icon {
  color: white;
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease, padding 0.3s ease;
  background: white;
}

.faq-answer.active {
  max-height: 300px;
  padding: 20px 25px;
}

.faq-answer p {
  margin: 0;
  line-height: 1.6;
  color: var(--text);
}

/* Mobile Anpassungen */
@media (max-width: 768px) {
  .process-steps {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  
  .info-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  
  .step-card,
  .info-card {
    padding: 20px;
  }
  
  .faq-question {
    padding: 15px 20px;
    font-size: 0.95rem;
  }
  
  .faq-answer.active {
    padding: 15px 20px;
  }
}

/* =============================================
   Professional CV Timeline Styles
   ============================================= */

.cv-timeline {
  max-width: 1000px;
  margin: 0 auto;
  position: relative;
}

.cv-timeline::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 4px;
  background: linear-gradient(180deg, var(--primary), var(--primary-600));
  transform: translateX(-50%);
  border-radius: 2px;
}

.cv-entry {
  display: flex;
  margin-bottom: 60px;
  align-items: center;
  gap: 40px;
  position: relative;
}

.cv-entry:nth-child(even) {
  flex-direction: row-reverse;
}

.cv-entry:nth-child(even) .cv-content {
  text-align: right;
}

.cv-year {
  flex: 0 0 140px;
  text-align: center;
  position: relative;
  z-index: 2;
}

.cv-year .year {
  display: block;
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--primary);
  background: white;
  padding: 12px 8px;
  border-radius: 12px;
  border: 3px solid var(--primary);
  box-shadow: 0 6px 20px rgba(76, 161, 163, 0.15);
  margin-bottom: 8px;
}

.year-badge {
  font-size: 0.75rem;
  padding: 4px 8px;
  border-radius: 10px;
  font-weight: 600;
  color: white;
  background: var(--text-secondary);
}

.year-badge.current {
  background: linear-gradient(135deg, var(--primary), var(--primary-600));
  animation: pulse 2s infinite;
}

.year-badge.excellence {
  background: linear-gradient(135deg, #ffd700, #ffed4a);
  color: #d97706;
}

.year-badge.scholarship {
  background: linear-gradient(135deg, #8b5cf6, #a855f7);
}

.year-badge.foundation {
  background: linear-gradient(135deg, #10b981, #059669);
}

.cv-content {
  flex: 1;
  background: white;
  padding: 30px;
  border-radius: 16px;
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);
  border: 1px solid rgba(76, 161, 163, 0.1);
  position: relative;
  transition: all 0.3s ease;
}

.cv-content:hover {
  transform: translateY(-3px);
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.15);
}

.cv-content::before {
  content: '';
  position: absolute;
  top: 40px;
  width: 0;
  height: 0;
  border: 12px solid transparent;
}

.cv-entry:nth-child(odd) .cv-content::before {
  left: -24px;
  border-right-color: white;
}

.cv-entry:nth-child(even) .cv-content::before {
  right: -24px;
  border-left-color: white;
}

.cv-content h3 {
  color: var(--primary);
  font-size: 1.3rem;
  font-weight: 600;
  margin-bottom: 8px;
}

.cv-content h3 i {
  margin-right: 8px;
  color: var(--primary-600);
}

.cv-position {
  color: var(--text-secondary);
  font-size: 0.9rem;
  font-weight: 500;
  font-style: italic;
  margin-bottom: 15px;
}

.cv-content p {
  color: var(--text-primary);
  line-height: 1.6;
  margin-bottom: 20px;
}

.cv-highlights {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.cv-entry:nth-child(even) .cv-highlights {
  justify-content: flex-end;
}

.achievement {
  background: linear-gradient(135deg, var(--primary), var(--primary-600));
  color: white;
  padding: 5px 10px;
  border-radius: 12px;
  font-size: 0.75rem;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.achievement.gold {
  background: linear-gradient(135deg, #ffd700, #ffed4a);
  color: #d97706;
}

.achievement i {
  font-size: 0.65rem;
}

.highlight-entry .cv-content {
  border-left: 5px solid var(--primary);
}

.excellence-entry .cv-content {
  border-left: 5px solid #ffd700;
  background: linear-gradient(135deg, #fffbeb, #fefce8);
}

.scholarship-entry .cv-content {
  border-left: 5px solid #8b5cf6;
  background: linear-gradient(135deg, #faf5ff, #f3e8ff);
}

.cv-summary {
  margin-top: 60px;
  text-align: center;
}

.summary-card {
  background: linear-gradient(135deg, #f8f9fa, #e9ecef);
  padding: 40px;
  border-radius: 20px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  max-width: 700px;
  margin: 0 auto;
}

.summary-card h4 {
  color: var(--primary);
  font-size: 1.4rem;
  margin-bottom: 20px;
  font-weight: 600;
}

.summary-card h4 i {
  margin-right: 8px;
}

.summary-card p {
  color: var(--text-primary);
  line-height: 1.7;
  margin-bottom: 30px;
}

.vision-stats {
  display: flex;
  justify-content: center;
  gap: 40px;
  flex-wrap: wrap;
}

.stat-item {
  text-align: center;
}

.stat-number {
  display: block;
  font-size: 2rem;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: 5px;
}

.stat-label {
  font-size: 0.9rem;
  color: var(--text-secondary);
  font-weight: 500;
}

@keyframes pulse {
  0% { transform: scale(1); }
  50% { transform: scale(1.05); }
  100% { transform: scale(1); }
}

/* CV Responsive */
@media (max-width: 768px) {
  .cv-timeline::before {
    left: 30px;
  }
  
  .cv-entry {
    flex-direction: column !important;
    align-items: flex-start;
    padding-left: 60px;
  }
  
  .cv-entry:nth-child(even) .cv-content {
    text-align: left;
  }
  
  .cv-entry:nth-child(even) .cv-highlights {
    justify-content: flex-start;
  }
  
  .cv-year {
    position: absolute;
    left: 0;
    top: 20px;
    flex: none;
    width: 80px;
  }
  
  .cv-content {
    width: 100%;
    margin-left: 0;
  }
  
  .cv-content::before {
    left: -12px !important;
    right: auto !important;
    border-right-color: white !important;
    border-left-color: transparent !important;
  }
  
  .cv-highlights {
    justify-content: flex-start !important;
  }
  
  .vision-stats {
    gap: 20px;
  }
}

/* Success Modal */
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  animation: fadeIn 0.3s ease;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

.modal-content {
  background: white;
  border-radius: 16px;
  padding: 40px 50px;
  max-width: 500px;
  width: 90%;
  text-align: center;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
  animation: slideUp 0.3s ease;
}

@keyframes slideUp {
  from {
    transform: translateY(30px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

.modal-icon {
  width: 80px;
  height: 80px;
  margin: 0 auto 20px;
  background: linear-gradient(135deg, var(--primary), var(--primary-600));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: scaleIn 0.5s ease 0.2s both;
}

@keyframes scaleIn {
  from {
    transform: scale(0);
  }
  to {
    transform: scale(1);
  }
}

.modal-icon i {
  font-size: 2.5rem;
  color: white;
}

.modal-content h2 {
  font-size: 1.75rem;
  color: var(--primary-700);
  margin: 0 0 15px 0;
  font-weight: 700;
}

.modal-content p {
  font-size: 1.05rem;
  color: var(--text);
  margin: 0 0 25px 0;
  line-height: 1.6;
}

.modal-redirect {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 15px 20px;
  background: var(--bg-soft);
  border-radius: 8px;
  color: var(--muted);
  font-size: 0.95rem;
}

.modal-redirect i {
  color: var(--primary);
  font-size: 1.1rem;
}

#countdown {
  font-weight: 600;
  color: var(--primary);
}

@media (max-width: 600px) {
  .modal-content {
    padding: 30px 25px;
  }
  
  .modal-icon {
    width: 70px;
    height: 70px;
  }
  
  .modal-icon i {
    font-size: 2rem;
  }
  
  .modal-content h2 {
    font-size: 1.4rem;
  }
  
  .modal-content p {
    font-size: 0.95rem;
  }
}

/* Floating WhatsApp Button */
.whatsapp-float {
  position: fixed;
  bottom: 25px;
  right: 25px;
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, #25D366, #128C7E);
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 30px;
  box-shadow: 0 4px 20px rgba(37, 211, 102, 0.4);
  z-index: 9998;
  transition: all 0.3s ease;
  text-decoration: none;
  animation: pulse-whatsapp 2s infinite;
}

.whatsapp-float:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 30px rgba(37, 211, 102, 0.6);
}

.whatsapp-float i {
  animation: shake-whatsapp 0.5s ease-in-out;
}

.whatsapp-float:hover i {
  animation: shake-whatsapp 0.5s ease-in-out infinite;
}

@keyframes pulse-whatsapp {
  0%, 100% {
    box-shadow: 0 4px 20px rgba(37, 211, 102, 0.4);
  }
  50% {
    box-shadow: 0 4px 30px rgba(37, 211, 102, 0.7);
  }
}

@keyframes shake-whatsapp {
  0%, 100% { transform: rotate(0deg); }
  25% { transform: rotate(-15deg); }
  75% { transform: rotate(15deg); }
}

/* Mobile Anpassung */
@media (max-width: 600px) {
  .whatsapp-float {
    width: 55px;
    height: 55px;
    font-size: 26px;
    bottom: 20px;
    right: 20px;
  }
}