:root{
  --bg:#0b1016;
  --bg2:#111824;
  --panel:rgba(255,255,255,.06);
  --panel-2:rgba(255,255,255,.04);
  --text:#eef2f7;
  --muted:#b8c3d1;
  --orange:#ff8a2a;
  --orange-2:#ffb868;
  --line:rgba(255,255,255,.16);
  --shadow:0 18px 60px rgba(0,0,0,.35);
  --radius:24px;
  --max:1240px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 15% 10%, rgba(255,138,42,.10), transparent 26%),
    radial-gradient(circle at 85% 0%, rgba(112,176,255,.08), transparent 22%),
    linear-gradient(180deg,#0a0e14 0%, #0b1016 42%, #0a0f16 100%);
  overflow-x:hidden;
}

a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

[data-lang]{display:none}
html.lang-de [data-lang="de"]{display:initial}
html.lang-en [data-lang="en"]{display:initial}

.nav{
  position:sticky;
  top:0;
  z-index:60;
  backdrop-filter:blur(14px);
  background:rgba(8,12,18,.72);
  border-bottom:1px solid rgba(255,255,255,.06);
}

.nav-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:14px 20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}

.brand{
  font-weight:800;
  letter-spacing:.02em;
  white-space:nowrap;
}

.brand span{color:var(--orange)}

.nav-right{
  display:flex;
  align-items:center;
  gap:20px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.nav-links{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
  color:var(--muted);
  font-size:.92rem;
}

.nav-links a:hover{color:#fff}

.lang-toggle{
  display:flex;
  gap:6px;
  padding:4px;
  border-radius:999px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
}

.lang-btn{
  border:0;
  cursor:pointer;
  color:var(--muted);
  background:transparent;
  padding:8px 12px;
  border-radius:999px;
  font-weight:800;
  letter-spacing:.04em;
  transition:.2s ease;
}

.lang-btn.active{
  background:linear-gradient(135deg,var(--orange),#ff6f19);
  color:#1d1208;
}

.hero{
  position:relative;
  min-height:92vh;
  display:grid;
  place-items:center;
  padding:46px 20px 30px;
  isolation:isolate;
  overflow:hidden;
}

.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(
      180deg,
      rgba(7,10,15,.30) 0%,
      rgba(7,10,15,.58) 48%,
      rgba(8,12,18,.90) 72%,
      rgba(8,12,18,1) 100%
    ),
    url("../img/pokal.jpg") center 22%/cover no-repeat;
  z-index:-2;
  transform:scale(1.02);
}

.hero::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-1px;
  height:320px;
  background:linear-gradient(
    180deg,
    rgba(11,16,22,0) 0%,
    rgba(11,16,22,.28) 22%,
    rgba(11,16,22,.62) 52%,
    rgba(11,16,22,.88) 78%,
    rgba(11,16,22,1) 100%
  );
  z-index:-1;
  pointer-events:none;
}

.hero-card{
  max-width:980px;
  width:100%;
  text-align:center;
  padding:28px;
  border-radius:32px;
  background:linear-gradient(180deg,rgba(9,14,21,.32),rgba(9,14,21,.56));
  border:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(10px);
  box-shadow:var(--shadow);
}

.eyebrow{
  display:inline-block;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(255,138,42,.14);
  color:var(--orange-2);
  border:1px solid rgba(255,138,42,.24);
  font-weight:800;
  font-size:.84rem;
  text-transform:uppercase;
  letter-spacing:.06em;
  margin-bottom:18px;
}

h1{
  margin:0;
  font-size:clamp(2.4rem, 6vw, 5.2rem);
  line-height:.98;
  letter-spacing:-.045em;
  text-wrap:balance;
}

.tagline{
  margin:16px 0 14px;
  font-size:clamp(1.18rem, 2.6vw, 2rem);
  color:var(--orange-2);
  font-weight:900;
  letter-spacing:.01em;
}

.intro{
  margin:0 auto;
  max-width:820px;
  line-height:1.75;
  color:#d8e0eb;
  font-size:clamp(1rem,1.3vw,1.12rem);
}

.hero-actions{
  margin-top:24px;
  display:flex;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:14px 18px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:#fff;
  font-weight:800;
  transition:.22s ease;
}

.btn:hover{
  transform:translateY(-2px);
  background:rgba(255,255,255,.11);
}

.btn-primary{
  background:linear-gradient(135deg,var(--orange),#ff6f19);
  color:#211307;
  border-color:transparent;
}

.section{
  max-width:var(--max);
  margin:0 auto;
  padding:78px 20px;
}

.section-head{margin-bottom:24px}

.section-head h2{
  margin:0 0 10px;
  font-size:clamp(1.9rem, 3vw, 3rem);
  letter-spacing:-.03em;
}

.section-head p{
  margin:0;
  max-width:820px;
  color:var(--muted);
  line-height:1.75;
}

.card{
  background:linear-gradient(180deg,var(--panel),var(--panel-2));
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}

/* =========================
   BRAIN SECTION
========================= */

.brain-reset{
  pointer-events: auto;
  z-index: 10;
  display:none;
  position:absolute;
  top:14px;
  right:16px;
  width:32px;
  height:32px;
  border:0;
  background:transparent;
  color:#ffb065;
  font-size:22px;
  line-height:1;
  cursor:pointer;
  opacity:.8;
  transition:opacity .2s ease, transform .2s ease;
}

.brain-reset:hover{
  opacity:1;
  transform:scale(1.08);
}

.detail-panel--brain:not(.is-empty) .brain-reset{
  display:block;
}

.brain-dot-left{
  position:absolute;
  right:-19px;
  top:50%;
  transform:translateY(-50%);
  width:12px;
  height:12px;
  background:#ffb065;
  border-radius:999px;
  box-shadow:
    0 0 0 6px rgba(255,176,101,.08),
    0 0 18px rgba(255,176,101,.25);
  z-index:6;
}

.brain-layout--interactive {
  max-width: 1280px;
  margin: 0 auto;
}

.brain-stage {
  position: relative;
  min-height: 820px;
  border-radius: 32px;
  padding: 2rem;
  overflow: hidden;
  background:
    radial-gradient(circle at 22% 38%, rgba(255, 148, 77, 0.16), transparent 28%),
    radial-gradient(circle at 75% 20%, rgba(255, 198, 102, 0.10), transparent 24%),
    linear-gradient(180deg, rgba(18, 21, 31, 0.94), rgba(9, 12, 19, 0.98));
  border: 1px solid rgba(255, 255, 255, 0.06);
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.35);
}

.brain-glow {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 34% 50%, rgba(255, 160, 84, 0.14), transparent 22%),
    radial-gradient(circle at 31% 64%, rgba(255, 195, 120, 0.10), transparent 28%);
  filter: blur(8px);
  opacity: 0.9;
}

.detail-panel--brain {
  position: absolute;
  top: 2.2rem;
  left: 2.5rem;
  width: min(560px, 46%);
  min-height: 260px;
  padding: 1.7rem 3.4rem 1.5rem 1.8rem;
  border-radius: 30px;
  z-index: 5;
  background:
    radial-gradient(circle at 35% 80%, rgba(255, 160, 84, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(50, 41, 37, 0.84), rgba(29, 28, 35, 0.88));
  border: 1px solid rgba(255, 176, 101, 0.28);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.28);
  transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease;
}

.detail-panel--brain::after {
  display:none;
  content: "";
  position: absolute;
  left: 155px;
  bottom: -15px;
  width: 30px;
  height: 30px;
  background: linear-gradient(135deg, rgba(255,176,101,.28), rgba(60,43,26,.92));
  border-right: 1px solid rgba(255, 176, 101, 0.38);
  border-bottom: 1px solid rgba(255, 176, 101, 0.38);
  box-shadow: 0 0 14px rgba(255,176,101,.12);
  transform: rotate(45deg);
  border-radius: 0 0 8px 0;
}

.detail-panel--brain.is-empty {
  border-color: rgba(255, 176, 101, 0.16);
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.22);
}

.detail-panel--brain:not(.is-empty) {
  border-color: rgba(255, 176, 101, 0.34);
  box-shadow: 0 18px 52px rgba(255, 140, 60, 0.10);
}

.detail-panel--brain h3 {
  margin: 0 0 1rem;
  font-size: clamp(1.5rem, 2.2vw, 1.95rem);
  line-height: 1.08;
}

.detail-panel--brain p {
  margin: 0;
  color: rgba(255, 255, 255, 0.88);
  line-height: 1.72;
}

.detail-panel--brain .detail-quote {
  margin-top: 1.15rem;
  padding-top: 1rem;
}

.detail-quote {
  margin-top: 1rem;
  padding-top: 0.9rem;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  color: #ffb065;
  font-weight: 800;
  font-style: italic;
  line-height: 1.35;
}

.connections {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
}

.connection-path,
.connections path {
  fill: none;
  stroke: url(#fade-to-brain);
  stroke-width: 2.5;
  stroke-linecap: round;
  /*stroke-dasharray: 10 12;*/
  opacity: 0.26;
  transition: opacity 0.25s ease, stroke-width 0.25s ease, filter 0.25s ease;
}

.connection-path.active,
.connections path.active {
  stroke: url(#fade-to-brain);
  stroke-width: 5;
  opacity: 1;
  filter: drop-shadow(0 0 12px rgba(255, 176, 101, 0.35));
}

.brain-core {
  position: absolute;
  left: 10%;
  top: 280px;
  width: min(34%, 390px);
  z-index: 2;
  display: flex;
  justify-content: center;
  align-items: center;
}

.brain-core img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  filter:
    drop-shadow(0 0 26px rgba(255,176,101,.22))
    drop-shadow(0 0 58px rgba(255,176,101,.12))
    drop-shadow(0 24px 48px rgba(0, 0, 0, 0.35));
}

.brain-nodes {
  position: absolute;
  top: 155px;
  right: 2.2rem;
  width: min(360px, 31%);
  display: flex;
  flex-direction: column;
  gap: 1.15rem;
  z-index: 3;
}

.node--side {
  position: relative;
  width: 100%;
  text-align: left;
  cursor: pointer;
  padding: 1.05rem 1.1rem 0.95rem 1.2rem;
  border-radius: 28px 20px 30px 18px / 22px 30px 20px 28px;
  background:
    radial-gradient(circle at 20% 30%, rgba(255, 176, 101, 0.08), transparent 42%),
    linear-gradient(180deg, rgba(28, 32, 42, 0.90), rgba(21, 25, 34, 0.94));
  border: 1px solid rgba(255, 176, 101, 0.16);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.22);
  transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.node--side:hover {
  transform: translateX(-4px);
}

.node--side.active {
  background:
    radial-gradient(circle at 18% 32%, rgba(255, 176, 101, 0.16), transparent 45%),
    linear-gradient(180deg, rgba(60, 43, 26, 0.96), rgba(37, 28, 20, 0.96));
  border-color: rgba(255, 176, 101, 0.44);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.30);
}

.node--side::before {
  display: none;
  content: "";
  position: absolute;
  left: -18px;
  top: 50%;
  width: 11px;
  height: 11px;
  border-radius: 999px;
  transform: translateY(-50%);
  background: rgba(255, 176, 101, 0.34);
  box-shadow: 0 0 0 6px rgba(255, 176, 101, 0.08);
  transition: background 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.node--side.active::before {
  background: #ffb065;
  box-shadow:
    0 0 0 8px rgba(255, 176, 101, 0.10),
    0 0 18px rgba(255, 176, 101, 0.45);
  transform: translateY(-50%) scale(1.08);
}

.node--side::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  pointer-events: none;
  background: radial-gradient(circle at 24% 26%, rgba(255, 176, 101, 0.08), transparent 42%);
  opacity: 0.75;
}

.node--side h3 {
  margin: 0 0 0.5rem;
  font-size: 1.18rem;
  line-height: 1.08;
  color: rgba(255, 255, 255, 0.96);
}

.node--side p {
  margin: 0;
  font-size: 0.97rem;
  line-height: 1.58;
  color: rgba(255, 255, 255, 0.80);
}

.node--side small {
  display: inline-block;
  margin-top: 0.75rem;
  font-size: 0.86rem;
  color: #ffb065;
  font-weight: 800;
  letter-spacing: 0.01em;
}

.node--side.active h3 {
  color: #ffffff;
}

.node--side.active p {
  color: rgba(255, 255, 255, 0.92);
}

.node--side.active small {
  color: #ffb065;
}

@media (max-width: 1100px) {
  .brain-stage {
    min-height: auto;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
  }

  .detail-panel--brain,
  .brain-core,
  .brain-nodes,
  .connections {
    position: relative;
    inset: auto;
    left: auto;
    right: auto;
    top: auto;
    bottom: auto;
    width: 100%;
  }

  .connections {
    display: none;
  }

  .detail-panel--brain {
    min-height: auto;
  }

  .detail-panel--brain::after {
    display: none;
  }

  .brain-core {
    max-width: 420px;
    margin: 0 auto;
  }

  .brain-nodes {
    display: grid;
    gap: 1rem;
  }

  .node--side::before {
    display: none;
  }
}

@media (max-width: 680px) {
  .brain-stage {
    padding: 1rem;
    border-radius: 24px;
  }

  .detail-panel--brain {
    width: 100%;
    padding: 1.2rem 1.2rem 1.1rem;
  }

  .detail-panel--brain h3 {
    font-size: 1.25rem;
  }

  .node--side p {
    font-size: 0.93rem;
  }
}

.link-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1rem;
}

.link-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.7rem 1rem;
  border-radius: 999px;
  background: rgba(255, 176, 101, 0.12);
  border: 1px solid rgba(255, 176, 101, 0.28);
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.link-chip:hover {
  transform: translateY(-1px);
  background: rgba(255, 176, 101, 0.18);
  border-color: rgba(255, 176, 101, 0.42);
}

@media (max-width:760px){
  .nav-inner{flex-direction:column; align-items:flex-start}
  .nav-right{width:100%; justify-content:space-between}
  .hero{min-height:84vh}
  .hero-card{padding:22px 18px}
  .hero-actions{gap:10px}
  .btn{width:100%}
}

.about-shell{
  padding:30px;
}

.about-intro{
  max-width:980px;
  margin-bottom:28px;
}

.about-intro h2{
  margin:0 0 14px;
  font-size:clamp(1.9rem, 3vw, 3rem);
  letter-spacing:-.03em;
}

.about-intro p{
  margin:0;
  color:#dbe4ef;
  line-height:1.85;
  font-size:1.03rem;
}

.about-intro strong{
  color:#fff;
}

.about-body{
  display:grid;
  grid-template-columns:minmax(0,1.45fr) minmax(260px,.72fr);
  gap:28px;
  align-items:start;
}

.about-copy{
  color:#dde4ef;
  line-height:1.9;
}

.about-copy p{
  margin:0 0 22px;
}

.about-copy p:last-child{
  margin-bottom:0;
}

.about-copy strong{
  color:#fff;
}

.about-side{
  display:flex;
  flex-direction:column;
  gap:16px;
  align-items:flex-start;
}

.about-portrait{
  width:100%;
  max-width:320px;
  overflow:hidden;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--shadow);
  background:#0f141c;
}

.about-portrait img{
  width:100%;
  aspect-ratio:1 / 1.08;
  object-fit:cover;
  object-position:center top;
  display:block;
}

.about-note{
  max-width:320px;
  padding:14px 16px;
  border-radius:18px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  color:#dfe7f2;
  line-height:1.65;
  font-size:.92rem;
}

@media (max-width:1080px){
  .about-body{
    grid-template-columns:1fr;
  }

  .about-side{
    align-items:flex-start;
  }

  .about-portrait,
  .about-note{
    max-width:340px;
  }
}

@media (max-width:760px){
  .about-shell{
    padding:22px;
  }

  .about-intro{
    margin-bottom:22px;
  }

  .about-portrait,
  .about-note{
    max-width:100%;
  }
}

.portrait-small{
  overflow:hidden;
  border-radius:20px;
  max-width:280px;
  justify-self:start;
  box-shadow:var(--shadow);
}

.portrait-small img{
  width:100%;
  aspect-ratio:1 / 1.12;
  object-fit:cover;
  object-position:center top;
}

.mini-note{
  padding:14px 16px;
  color:#d2dbe7;
  line-height:1.7;
  font-size:.92rem;
}

.slideshow{
  position:relative;
  overflow:hidden;
  min-height:460px;
  border-radius:var(--radius);
  background:#090d13;
}

.slide{
  position:absolute;
  inset:0;
  opacity:0;
  transition:opacity .7s ease;
}

.slide.active{
  opacity:1;
}

.slide img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}

.slide.denker img{
  object-position:center 18%;
}

.dots{
  position:absolute;
  bottom:16px;
  right:16px;
  display:flex;
  gap:8px;
  z-index:5;
}

.dot{
  width:10px;
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.3);
  border:0;
  padding:0;
  cursor:pointer;
}

.dot.active{
  background:var(--orange);
}

.contact-grid{
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:24px;
  align-items:start;
}

.contact-card,
.links-card{
  padding:28px;
}

.contact-card h3,
.links-card h3{
  margin:0 0 12px;
  font-size:1.7rem;
}

.contact-list{
  display:grid;
  gap:10px;
  color:#dbe4ef;
  line-height:1.7;
}

.icon-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(84px,1fr));
  gap:14px;
  margin-top:18px;
}

.icon-link{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:92px;
  padding:14px 10px;
  border-radius:20px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  transition:.22s ease;
  color:#f0f4fa;
  text-align:center;
  font-size:.84rem;
  font-weight:700;
}

.icon-link:hover{
  transform:translateY(-3px);
  background:rgba(255,255,255,.1);
  border-color:rgba(255,138,42,.32);
}

.icon-link svg{
  width:28px;
  height:28px;
  fill:var(--orange-2);
}

.quote{
  margin-top:18px;
  color:#e2e9f3;
  font-style:italic;
  opacity:.88;
}

.footer{
  max-width:var(--max);
  margin:0 auto;
  padding:18px 20px 42px;
  text-align:center;
  color:var(--muted);
}

.reveal{
  opacity:1;
  transform:none;
  transition:opacity .8s ease, transform .8s ease;
}

.js .reveal{
  opacity:0;
  transform:translateY(26px);
}

.reveal.visible{
  opacity:1;
  transform:translateY(0);
}

/* sticky AIBO */
.aibo-guide{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:80;
  width:min(390px, calc(100vw - 36px));
  pointer-events:none;
  overflow:visible;
}

.aibo-bubble{
  position:relative;
  margin:0 70px 12px 0;
  background:#fff;
  color:#1b2230;
  border-radius:42px;
  padding:18px 22px;
  box-shadow:0 20px 45px rgba(0,0,0,.24);
  border:3px solid #1b2230;
  pointer-events:none;

  opacity:0;
  transform:translateY(10px) scale(.96);
  transition:opacity .24s ease, transform .24s ease;
}

.aibo-bubble.is-visible{
  opacity:1;
  transform:translateY(0) scale(1);
  pointer-events:auto;
}

.aibo-bubble::after{
  content:"";
  position:absolute;
  right: 40px;
  bottom:-12px;
  width:28px;
  height:24px;
  background:#fff;
  border-right:3px solid #1b2230;
  border-bottom:3px solid #1b2230;
  border-bottom-right-radius:10px;
  transform:skewX(18deg) rotate(32deg);
}

.aibo-bubble-text{
  white-space: pre-line;
  margin:0;
  line-height:1.7;
  font-weight:600;
  min-height:86px;
}

.aibo-guide img{
  width:150px;
  margin-left:auto;
  filter:drop-shadow(0 16px 24px rgba(0,0,0,.32));
  pointer-events:auto;
  cursor:pointer;
  transform-origin:center;
  transition:opacity .22s ease, transform .22s ease, filter .22s ease;
}

/* Idle = gespiegelt, aber keine Animation */
#aibo-img.aibo-idle{
  animation:none;
  transform:scale(1.1);
}

/* Aktives Standardbild = gespiegelt + wobble */
#aibo-img.aibo-speaking{
  animation:wobble-mirrored 3.8s ease-in-out infinite;
}

/* Datenschutz = nicht gespiegelt + wobble */
#aibo-img.aibo-playful{
  animation:wobble-normal 3.2s ease-in-out infinite;
}

/* Impressum = nicht gespiegelt + sanftes Atmen */
#aibo-img.aibo-sleeping{
  animation:sleep-breathe 4.2s ease-in-out infinite;
}

@keyframes wobble-mirrored{
  0%,100%{transform:scaleX(-1) translateY(0) rotate(0deg)}
  25%{transform:scaleX(-1) translateY(-4px) rotate(-1deg)}
  50%{transform:scaleX(-1) translateY(-7px) rotate(.8deg)}
  75%{transform:scaleX(-1) translateY(-3px) rotate(-.6deg)}
}

@keyframes wobble-normal{
  0%,100%{transform:translateY(0) rotate(0deg)}
  25%{transform:translateY(-4px) rotate(-1deg)}
  50%{transform:translateY(-7px) rotate(.8deg)}
  75%{transform:translateY(-3px) rotate(-.6deg)}
}

@keyframes sleep-breathe{
  0%,100%{transform:translateY(0) scale(1)}
  50%{transform:translateY(1px) scale(1.02)}
}

/* Herzchen */
.aibo-heart{
  position:absolute;
  right:48px;
  bottom:82px;
  font-size:28px;
  line-height:1;
  color:#ff3b57;
  opacity:0;
  transform:translateY(0) scale(.8);
  pointer-events:none;
  text-shadow:0 4px 14px rgba(255,59,87,.35);
}

.aibo-heart.is-animating{
  animation:aibo-heart-pop .9s ease-out forwards;
}

@keyframes aibo-heart-pop{
  0%{
    opacity:0;
    transform:translateY(8px) scale(.6);
  }
  18%{
    opacity:1;
    transform:translateY(0) scale(1);
  }
  100%{
    opacity:0;
    transform:translateY(-34px) scale(1.12);
  }
}

@media (max-width:1080px){
  .about-grid,
  .contact-grid{
    grid-template-columns:1fr;
  }

  .portrait-small{
    max-width:320px;
  }
}

@media (max-width:760px){
  .portrait-small{
    max-width:100%;
  }

  .slideshow{
    min-height:340px;
  }

  .aibo-guide{
    right:10px;
    left:10px;
    bottom:10px;
    width:auto;
    overflow:visible;
  }

 .aibo-bubble{
    margin:0 72px 8px 0;
    border-radius:30px;
    padding:14px 14px 12px;
  }

  .aibo-bubble-text{
    min-height:72px;
    font-size:.95rem;
  }

  .aibo-guide img{
    width:110px;
  }

  .icon-grid{
    grid-template-columns:repeat(3, minmax(0,1fr));
  }
}

.footer-links{
  display:flex;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:10px;
}

.footer-links a{
  color:var(--muted);
  transition:.2s ease;
}

.footer-links a:hover{
  color:#fff;
}

.footer-note{
  color:var(--muted);
}

.legal-page .nav{
  position:sticky;
}

.legal-content{
  min-height:70vh;
}

.legal-card{
  padding:28px;
  line-height:1.8;
  color:#dde4ef;
}

.legal-card h2{
  margin-top:28px;
  margin-bottom:10px;
  font-size:1.25rem;
  color:#fff;
}

.legal-card h2:first-child{
  margin-top:0;
}

.legal-card a{
  color:var(--orange-2);
}

.affiliate-note{
  margin-top:10px;
  font-size:0.72rem;
  line-height:1.35;
  color:rgba(238,242,247,.58);
  text-align:left;
  max-width:320px;
  letter-spacing:0.01em;
}

.affiliate-star{
  color:var(--orange-2);
  margin-left:1px;
}

/* Mobile-only: AIBO blendet beim Scrollen aus */
@media (max-width: 760px){
  .aibo-guide{
    transition: opacity .35s ease, transform .35s ease;
  }

  .aibo-guide.aibo-mobile-hidden{
    opacity: 0;
    transform: translateY(18px);
    pointer-events: none;
  }

  .aibo-guide.aibo-mobile-hidden .aibo-bubble{
    opacity: 0 !important;
    pointer-events: none !important;
  }
}

#scrollTopBtn{
  position: fixed;
  left: 24px;
  bottom: 24px;
  width: 46px;
  height: 46px;
  border: none;
  border-radius: 999px;
  background: linear-gradient(135deg, #ffb065, #ff8a2a);
  color: #1b2230;
  font-size: 22px;
  font-weight: 800;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 8px 22px rgba(0,0,0,.28);
  opacity: 0;
  transform: translateY(18px);
  pointer-events: none;
  transition: opacity .25s ease, transform .25s ease, box-shadow .25s ease;
  z-index: 79;
}

#scrollTopBtn.show{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

#scrollTopBtn:hover{
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(0,0,0,.32);
}

@media (max-width: 760px){
  #scrollTopBtn{
    left: 14px;
    bottom: 14px;
    width: 42px;
    height: 42px;
    font-size: 20px;
  }
}