/* === ALAB Hero/Hotspot – vollständig gekapselt unter #alab-hero === */

/* Component Scope Reset (berührt Header nicht) */
#alab-hero, 
#alab-hero * {
  box-sizing: border-box;
}

/* CSS Variables nur für das Modul */
#alab-hero{
  /* Brand Colors */
  --accent-gradient-start: #E5C44D;
  --accent-gradient-end: #F3D663;
  --text-primary: #2D3436;
  --text-secondary: #636E72;
  --background-light: #F8F9FA;
  --background-white: #FFFFFF;
  --border-light: #E9ECEF;

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(0,0,0,.04), 0 1px 2px rgba(0,0,0,.06);
  --shadow-md: 0 4px 6px -1px rgba(0,0,0,.04), 0 2px 4px -1px rgba(0,0,0,.06);
  --shadow-lg: 0 10px 25px -5px rgba(0,0,0,.06), 0 10px 10px -5px rgba(0,0,0,.04);
  --shadow-xl: 0 20px 40px -10px rgba(0,0,0,.08), 0 10px 20px -5px rgba(0,0,0,.05);
  --shadow-2xl: 0 25px 50px -12px rgba(0,0,0,.10), 0 12px 25px -8px rgba(0,0,0,.05);
  --shadow-glow: 0 0 40px rgba(229,196,77,.15);

  /* Typography (nur im Modul genutzt) */
  --font-heading: 'Poppins', 'Plus Jakarta Sans', sans-serif;
  --font-body: 'Inter', 'Manrope', sans-serif;

  /* Spacing & Radius */
  --container-max-width: 1400px;
  --spacing-xs: .5rem;
  --spacing-sm: 1rem;
  --spacing-md: 1.5rem;
  --spacing-lg: 2rem;
  --spacing-xl: 3rem;
  --radius-sm: 8px;
  --radius-md: 16px;
  --radius-lg: 24px;
  --radius-xl: 32px;

  /* Modulweite Defaults (nicht global) */
  color: var(--text-primary);
  background-color: #fff;
  line-height: 1.6;
  min-height: 100%;
  overflow-x: hidden; /* nur innerhalb des Moduls */
  font-family: var(--font-body);
}

/* Container – umbenannt, damit nichts kollidiert */
#alab-hero .alab-container{
  max-width: var(--container-max-width);
  margin: 0 auto;
  padding: var(--spacing-xl) var(--spacing-md);
}

/* Section Header */
#alab-hero .section-header{
  text-align: center;
  margin-bottom: calc(var(--spacing-xl)*1.5);
  position: relative;
  animation: alab-fadeInDown .8s cubic-bezier(.2,.6,.2,1);
}

#alab-hero .eyebrow{
  display: inline-block;
  background: linear-gradient(135deg,var(--accent-gradient-start),var(--accent-gradient-end));
  color: var(--text-primary);
  padding: 8px 20px;
  border-radius: 24px;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: var(--spacing-md);
  position: relative;
  box-shadow: 0 4px 15px rgba(229,196,77,.2);
  animation: alab-slideInUp .6s cubic-bezier(.2,.6,.2,1);
}

@keyframes alab-fadeInDown{
  from{opacity:0; transform:translateY(-20px)}
  to{opacity:1; transform:translateY(0)}
}
@keyframes alab-slideInUp{
  from{opacity:0; transform:translateY(20px)}
  to{opacity:1; transform:translateY(0)}
}

#alab-hero .title{
  font-family: var(--font-heading);
  font-size: clamp(2.5rem, 4vw, 3.5rem);
  font-weight: 800;
  line-height: 1.2;
  margin-bottom: var(--spacing-md);
  background: linear-gradient(135deg, var(--text-primary) 0%, #4A5568 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: alab-fadeIn .8s cubic-bezier(.2,.6,.2,1) .2s both;
  letter-spacing: -.02em;
}

#alab-hero .subtitle{
  font-size: 1.2rem;
  color: var(--text-secondary);
  max-width: 650px;
  margin: 0 auto;
  line-height: 1.7;
  animation: alab-fadeIn .8s cubic-bezier(.2,.6,.2,1) .4s both;
}

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

/* Layout */
#alab-hero .hotspot-container{
  position: relative;           /* wichtig für Cards */
  margin-bottom: var(--spacing-xl);
  display: flex;
  align-items: center;
  gap: var(--spacing-lg);
}

#alab-hero .hero-image-wrapper{
  position: relative;
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
  border-radius: var(--radius-xl);
  overflow: visible;
  padding: 20px;
  filter: drop-shadow(0 10px 30px rgba(229,196,77,.08));
}

#alab-hero .hero-image{
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  max-height: 600px;
}

/* --- Hotspots (nur einmal definiert) --- */
#alab-hero .hotspot{
  position: absolute;
  width: 56px;
  height: 56px;
  cursor: pointer;
  z-index: 40;
  transform: translate(-50%, -50%); /* stabile Zentrierung */
  transition: transform .2s cubic-bezier(.4,0,.2,1);
  will-change: transform;
  -webkit-font-smoothing: antialiased;
  backface-visibility: hidden;
}
#alab-hero .hotspot > *{ pointer-events: none; }

#alab-hero .hotspot-pulse{
  position: absolute; inset: 0;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(229,196,77,.4) 0%, rgba(243,214,99,.2) 50%, transparent 70%);
  opacity: .3;
  animation: alab-pulse 2.5s cubic-bezier(.4,0,.6,1) infinite;
  will-change: transform, opacity;
}

#alab-hero .hotspot-inner{
  position: absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width: 42px; height: 42px; border-radius: 50%;
  background: linear-gradient(135deg,#E5C44D 0%, #F3D663 50%, #E5C44D 100%);
  display:flex; align-items:center; justify-content:center;
  box-shadow: 0 2px 8px rgba(0,0,0,.1), 0 4px 16px rgba(229,196,77,.3), inset 0 1px 0 rgba(255,255,255,.5);
  transition: transform .2s cubic-bezier(.4,0,.2,1), box-shadow .2s ease;
  border: 2px solid rgba(255,255,255,.8);
}

#alab-hero .hotspot-icon{
  color:#2D3436; font-size:16px; font-weight:800; line-height:1;
  font-family: var(--font-heading); text-shadow:0 1px 2px rgba(255,255,255,.8);
  user-select:none;
}

/* Label */
#alab-hero .hotspot-label{
  position:absolute; top:-40px; left:50%; transform:translateX(-50%) scale(.9);
  background: linear-gradient(135deg,#FFFFFF 0%, #FAFAFA 100%);
  padding: 8px 16px; border-radius:24px; font-size:.9rem; font-weight:600; white-space:nowrap;
  box-shadow: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04), 0 0 0 1px rgba(229,196,77,.2);
  opacity:0; pointer-events:none; transition: opacity .15s ease, transform .15s cubic-bezier(.4,0,.2,1);
  border:1px solid rgba(229,196,77,.3); z-index:100;
}
#alab-hero .hotspot:hover{ transform: translate(-50%, -50%) scale(1.02); transition-delay:.05s; }
#alab-hero .hotspot:hover .hotspot-pulse{ animation:none; opacity:.5; }
#alab-hero .hotspot:hover .hotspot-inner{ transform:translate(-50%,-50%) scale(1.1); }
#alab-hero .hotspot:hover .hotspot-label{ opacity:1; transform:translateX(-50%) scale(1) translateY(-2px); }
#alab-hero .hotspot.active .hotspot-pulse{ animation:none; opacity:.6; }
#alab-hero .hotspot.active .hotspot-inner{ transform:translate(-50%,-50%) scale(1.15); }
#alab-hero .hotspot.inactive{ opacity:.4; pointer-events:none; }

@keyframes alab-pulse{
  0%{ transform:scale(1); opacity:.3 }
  50%{ transform:scale(1.4); opacity:.08 }
  100%{ transform:scale(1); opacity:.3 }
}

/* Info Cards */
#alab-hero .info-card{
  position:absolute;
  background: rgba(255,255,255,.98);
  border-radius: var(--radius-lg);
  box-shadow: 0 10px 40px rgba(0,0,0,.08), 0 2px 10px rgba(0,0,0,.04), 0 0 0 1px rgba(229,196,77,.1);
  padding: var(--spacing-lg);
  width: 380px; z-index:30; opacity:0; visibility:hidden;
  transform: scale(.95) translateY(10px);
  transition: opacity .25s ease, transform .25s cubic-bezier(.4,0,.2,1), visibility .25s;
  pointer-events:none; border:1px solid rgba(229,196,77,.2);
  backface-visibility:hidden;
}
#alab-hero .info-card.active{ opacity:1; visibility:visible; transform: scale(1) translateY(0); pointer-events:auto; }
#alab-hero .info-card::before{
  content:''; position:absolute; width:2px; height:30px;
  background: linear-gradient(135deg,var(--accent-gradient-start),var(--accent-gradient-end));
  opacity:0; transition:opacity .3s ease;
}
#alab-hero .info-card.active::before{ opacity:1; }

#alab-hero .info-card.position-bottom{ top: calc(100% + 16px); left:50%; transform:translateX(-50%); }
#alab-hero .hotspot-container.has-card{ padding-bottom: 24rem; }

#alab-hero .info-card-content{ display:flex; flex-direction:column; gap: var(--spacing-sm); }
#alab-hero .info-card-image{
  width:100%; height:180px; border-radius: var(--radius-md); overflow:hidden;
  margin-bottom: var(--spacing-xs);
  background: linear-gradient(135deg,#f5f5f5 0%, #e8e8e8 100%);
  display:flex; align-items:center; justify-content:center;
}
#alab-hero .info-card-image img{ width:100%; height:100%; object-fit:contain; padding:10px; }

#alab-hero .info-card h3{
  font-family: var(--font-heading); font-size:1.35rem; font-weight:700; color:var(--text-primary);
  margin-bottom: var(--spacing-sm); position:relative; padding-left:24px;
}
#alab-hero .info-card h3::before{
  content:''; position:absolute; left:0; top:50%; transform:translateY(-50%);
  width:4px; height:24px; background: linear-gradient(180deg,var(--accent-gradient-start),var(--accent-gradient-end));
  border-radius:2px;
}
#alab-hero .info-card p{ font-size:.95rem; color:var(--text-secondary); line-height:1.6; margin-bottom: var(--spacing-sm); }

/* Specs */
#alab-hero .specs-list{ list-style:none; padding: var(--spacing-md) 0 0; border-top:1px solid rgba(229,196,77,.15); margin-top: var(--spacing-sm); }
#alab-hero .specs-list li{
  display:flex; align-items:center; gap: var(--spacing-sm);
  padding: var(--spacing-sm) var(--spacing-xs); font-size:.9rem; color:var(--text-primary);
  transition: transform .3s ease, background .3s ease; border-radius: var(--radius-sm); position:relative;
}
#alab-hero .specs-list li:hover{ background: rgba(229,196,77,.05); transform: translateX(5px); }
#alab-hero .spec-icon{ font-size:1.1rem; display:inline-flex; align-items:center; justify-content:center; min-width:24px; }
#alab-hero .spec-icon svg{ stroke:#E5C44D; transition: transform .3s ease, stroke .3s ease; }
#alab-hero .specs-list li:hover .spec-icon svg{ stroke: var(--accent-gradient-end); transform: scale(1.15); }

/* Side Panels */
#alab-hero .side-panel{ display:flex; flex-direction:column; gap: var(--spacing-md); width:200px; flex-shrink:0; }
#alab-hero .left-panel{ align-items:flex-end; }
#alab-hero .right-panel{ align-items:flex-start; }

/* Stat Cards */
#alab-hero .stat-card{
  background: rgba(255,255,255,.7); backdrop-filter: blur(10px);
  border-radius: var(--radius-lg); padding: var(--spacing-md); text-align:center;
  box-shadow: var(--shadow-lg); transition: transform .4s cubic-bezier(.2,.6,.2,1), box-shadow .4s, border-color .4s, background .4s;
  width:100%; border:1px solid rgba(229,196,77,.15); position:relative; overflow:hidden;
}
#alab-hero .stat-card::before{
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background: linear-gradient(90deg,var(--accent-gradient-start),var(--accent-gradient-end));
  opacity:0; transition:opacity .3s ease;
}
#alab-hero .stat-card:hover{
  transform: translateY(-8px) scale(1.02);
  box-shadow: var(--shadow-xl), 0 0 30px rgba(229,196,77,.1);
  border-color: var(--accent-gradient-start);
  background: rgba(255,255,255,.85);
}
#alab-hero .stat-card:hover::before{ opacity:1; }
#alab-hero .stat-icon{ font-size:2rem; margin-bottom: var(--spacing-xs); display:flex; align-items:center; justify-content:center; }
#alab-hero .stat-icon svg{ stroke: var(--text-primary); transition: transform .3s ease, stroke .3s ease; }
#alab-hero .stat-card:hover .stat-icon svg{ stroke:#E5C44D; transform: scale(1.1); }
#alab-hero .stat-value{ font-family: var(--font-heading); font-size:1.5rem; font-weight:700; color:var(--text-primary); margin-bottom:4px; }
#alab-hero .stat-label{ font-size:.85rem; color:var(--text-secondary); font-weight:500; }

/* Feature Cards */
#alab-hero .feature-card{
  background: linear-gradient(135deg, rgba(255,255,255,.6), rgba(229,196,77,.05));
  backdrop-filter: blur(8px);
  border:1px solid rgba(229,196,77,.2);
  border-radius: var(--radius-md);
  padding: var(--spacing-md); width:100%;
  transition: transform .4s cubic-bezier(.2,.6,.2,1), border-color .4s, box-shadow .4s;
  position:relative; overflow:hidden;
}
#alab-hero .feature-card::after{
  content:''; position:absolute; inset:0; background: linear-gradient(135deg, transparent, rgba(229,196,77,.1));
  opacity:0; transition: opacity .3s ease;
}
#alab-hero .feature-card:hover{ transform: translateX(-8px) scale(1.02); border-color: var(--accent-gradient-start); box-shadow: var(--shadow-lg), 0 0 20px rgba(229,196,77,.15); }
#alab-hero .feature-card:hover::after{ opacity:1; }
#alab-hero .feature-icon{ font-size:1.5rem; margin-bottom: var(--spacing-xs); display:flex; align-items:center; justify-content:flex-start; }
#alab-hero .feature-icon svg{ stroke: var(--text-primary); transition: transform .3s ease, stroke .3s ease; }
#alab-hero .feature-card:hover .feature-icon svg{ stroke:#E5C44D; transform: rotate(-5deg) scale(1.1); }
#alab-hero .feature-card h4{ font-family: var(--font-heading); font-size:.9rem; font-weight:600; color:var(--text-primary); margin-bottom:4px; }
#alab-hero .feature-card p{ font-size:.8rem; color: var(--text-secondary); line-height:1.4; }

/* Mobile Component List */
#alab-hero .mobile-component-list{ display:none; }
#alab-hero .component-accordion{ display:flex; flex-direction:column; gap: var(--spacing-sm); }
#alab-hero .accordion-item{
  display:flex; align-items:center; gap: var(--spacing-sm); padding: var(--spacing-md);
  background: rgba(255,255,255,.7); backdrop-filter: blur(8px);
  border:1px solid rgba(229,196,77,.15); border-radius: var(--radius-md);
  font-family: var(--font-body); font-size:1rem; color:var(--text-primary);
  cursor:pointer; transition: transform .4s cubic-bezier(.2,.6,.2,1), box-shadow .4s, border-color .4s, background .4s;
  text-align:left; width:100%; position:relative; overflow:hidden;
}
#alab-hero .accordion-item::before{
  content:''; position:absolute; left:0; top:0; bottom:0; width:4px;
  background: linear-gradient(180deg,var(--accent-gradient-start),var(--accent-gradient-end));
  transform: scaleY(0); transition: transform .3s ease;
}
#alab-hero .accordion-item:hover{ border-color: var(--accent-gradient-start); box-shadow: var(--shadow-lg); transform: translateX(6px); background: rgba(255,255,255,.85); }
#alab-hero .accordion-item:hover::before{ transform: scaleY(1); }
#alab-hero .accordion-item.active{
  background: linear-gradient(135deg, rgba(229,196,77,.15), rgba(243,214,99,.1));
  border-color: var(--accent-gradient-start); box-shadow: var(--shadow-xl);
}
#alab-hero .accordion-item.active::before{ transform: scaleY(1); width:100%; opacity:.1; }
#alab-hero .accordion-icon{ font-size:1.5rem; display:flex; align-items:center; justify-content:center; transition: transform .3s ease; }
#alab-hero .accordion-icon svg{ stroke: var(--text-primary); transition: transform .3s ease, stroke .3s ease; }
#alab-hero .accordion-item:hover .accordion-icon svg,
#alab-hero .accordion-item.active .accordion-icon svg{ stroke:#E5C44D; }
#alab-hero .accordion-title{ flex:1; font-weight:500; }
#alab-hero .accordion-arrow{ font-size:1.25rem; transition: transform .3s ease; }
#alab-hero .accordion-item.active .accordion-arrow{ transform: rotate(90deg); }

/* Responsive */
@media (max-width:1200px){
  #alab-hero .side-panel{ width:150px; }
  #alab-hero .stat-value{ font-size:1.25rem; }
  #alab-hero .feature-card h4{ font-size:.85rem; }
}
@media (max-width:968px){
  #alab-hero .hotspot-container{ flex-direction: column; }
  #alab-hero .side-panel{ width:100%; flex-direction:row; justify-content:center; }
  #alab-hero .left-panel, #alab-hero .right-panel{ align-items:center; }
  #alab-hero .stat-card, #alab-hero .feature-card{ max-width:200px; }
}
@media (max-width:768px){
  #alab-hero .alab-container{ padding: var(--spacing-lg) var(--spacing-sm); }
  #alab-hero .hotspot-container{ display:none; }
  #alab-hero .mobile-component-list{ display:block; }
  #alab-hero .title{ font-size:1.75rem; }
  #alab-hero .subtitle{ font-size:1rem; }
  /* falls du eine kompakte Section verstecken willst – scoped */
  #alab-hero .komp-section{ display:none !important; }
}
@media (min-width:769px) and (max-width:1024px){
  #alab-hero .info-card{ width:320px; }
  #alab-hero .hero-image-wrapper{ max-width:100%; }
}

/* Print */
@media print{
  #alab-hero .hotspot, 
  #alab-hero .info-card{ display:none !important; }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce){
  #alab-hero *{
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
}

/* High Contrast */
@media (prefers-contrast: high){
  #alab-hero .hotspot-inner{ border:2px solid var(--text-primary); }
  #alab-hero .info-card{ border:2px solid var(--text-primary); }
}

@media (max-width: 768px){
  .komp-section { display: none !important; }
}


/* === Quadratische Box hinter Zahlenbadge entfernen === */
#alab-hero .hotspot{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* Falls ein Pseudo-Element die Kachel zeichnet */
#alab-hero .hotspot::before,
#alab-hero .hotspot::after,
#alab-hero .hotspot-inner::before,
#alab-hero .hotspot-inner::after{
  content: none !important;
  display: none !important;
  background: transparent !important;
  box-shadow: none !important;
}

/* Sicherheitsnetz: falls ein zusätzliches Wrapper-Div existiert */
#alab-hero .hotspot > .badge-bg,
#alab-hero .hotspot > .hotspot-bg{
  display: none !important;
}

/* Den eigentlichen goldenen Kreis unverändert lassen */
#alab-hero .hotspot-inner{
  background: linear-gradient(135deg,#E5C44D 0%, #F3D663 50%, #E5C44D 100%);
  border-radius: 50%;
  box-shadow: 0 2px 8px rgba(0,0,0,.1), 0 4px 16px rgba(229,196,77,.3), inset 0 1px 0 rgba(255,255,255,.5);
}

/* === Kompaktere Stat-Boxen (alle 6) === */
#alab-hero {
  --stat-panel-w: 140px;   /* vorher 200px */
  --stat-pad: 12px;        /* vorher var(--spacing-md) */
  --stat-radius: 12px;     /* vorher var(--radius-lg) */
  --stat-icon-size: 1.4rem;/* vorher 2rem */
  --stat-value-size: 1.1rem; /* vorher 1.5rem */
  --stat-label-size: 0.78rem; /* vorher 0.85rem */
  --stat-gap: 10px;        /* vertikaler Abstand zwischen Boxen */
}

/* Side-Panels schmaler, dadurch Karten kleiner */
#alab-hero .side-panel{
  width: var(--stat-panel-w);
  gap: var(--stat-gap);
}

/* Karten-Optik kompakter */
#alab-hero .stat-card{
  padding: var(--stat-pad);
  border-radius: var(--stat-radius);
  box-shadow: var(--shadow-sm);
}

/* Hover-Effekt dezenter, damit es „klein“ bleibt */
#alab-hero .stat-card:hover{
  transform: translateY(-4px) scale(1.01);
  box-shadow: var(--shadow-md);
}

/* Inhalte runterskalieren */
#alab-hero .stat-icon{ font-size: var(--stat-icon-size); margin-bottom: 6px; }
#alab-hero .stat-value{ font-size: var(--stat-value-size); margin-bottom: 2px; }
#alab-hero .stat-label{ font-size: var(--stat-label-size); }

/* Optional: bei sehr breiten Screens noch etwas kleiner */
@media (min-width: 1280px){
  #alab-hero {
    --stat-panel-w: 130px;
    --stat-pad: 10px;
    --stat-icon-size: 1.3rem;
    --stat-value-size: 1.05rem;
    --stat-label-size: 0.76rem;
  }
}
