/* ============================================================
   MÄHMET — Premium High-Tech Landing
   Display: Archivo · Mono: Space Mono
   ============================================================ */
/* latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/k3kPo8UDI-1M0wlSV9XAw6lQkqWY8Q82sLyTOxK-vA.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/k3kPo8UDI-1M0wlSV9XAw6lQkqWY8Q82sLydOxI.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/k3kPo8UDI-1M0wlSV9XAw6lQkqWY8Q82sLyTOxK-vA.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/k3kPo8UDI-1M0wlSV9XAw6lQkqWY8Q82sLydOxI.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/k3kPo8UDI-1M0wlSV9XAw6lQkqWY8Q82sLyTOxK-vA.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/k3kPo8UDI-1M0wlSV9XAw6lQkqWY8Q82sLydOxI.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/k3kPo8UDI-1M0wlSV9XAw6lQkqWY8Q82sLyTOxK-vA.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/k3kPo8UDI-1M0wlSV9XAw6lQkqWY8Q82sLydOxI.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/k3kPo8UDI-1M0wlSV9XAw6lQkqWY8Q82sLyTOxK-vA.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/k3kPo8UDI-1M0wlSV9XAw6lQkqWY8Q82sLydOxI.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 900;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/k3kPo8UDI-1M0wlSV9XAw6lQkqWY8Q82sLyTOxK-vA.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 900;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/k3kPo8UDI-1M0wlSV9XAw6lQkqWY8Q82sLydOxI.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Space Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/i7dPIFZifjKcF5UAWdDRYE98RWq7.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Space Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/i7dPIFZifjKcF5UAWdDRYEF8RQ.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Space Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(fonts/i7dMIFZifjKcF5UAWdDRaPpZUFuaHjyV.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Space Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(fonts/i7dMIFZifjKcF5UAWdDRaPpZUFWaHg.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root {
  --bg:        #07090b;
  --bg-2:      #0c0f12;
  --surface:   #0f1316;
  --line:      #1b2126;
  --line-2:    #262e35;

  --text-1:    #eef3f7;
  --text-2:    #9aa6af;
  --text-3:    #5c676f;

  --accent:    #38b6ff;          /* Sensor-Blau */
  --accent-2:  #7fd4ff;
  --accent-dim:#1d4a66;
  --glow:      rgba(56,182,255,.55);
  --glow-soft: rgba(56,182,255,.14);
  --red:       #e23b32;          /* sparsamer Akzent (wie der Streifen) */

  --font-display: 'Archivo', system-ui, sans-serif;
  --font-mono: 'Space Mono', ui-monospace, monospace;

  --maxw: 1200px;
  --pad: clamp(1.25rem, 4vw, 3rem);

  --step--2: clamp(.7rem, .67rem + .12vw, .78rem);
  --step--1: clamp(.8rem, .76rem + .18vw, .9rem);
  --step-0:  clamp(.95rem, .9rem + .25vw, 1.075rem);
  --step-1:  clamp(1.1rem, 1rem + .4vw, 1.35rem);
  --step-2:  clamp(1.5rem, 1.2rem + 1.3vw, 2.4rem);
  --step-3:  clamp(2.1rem, 1.5rem + 2.6vw, 3.6rem);
  --step-4:  clamp(2.9rem, 1.8rem + 5.2vw, 6.4rem);
  --step-5:  clamp(3.6rem, 2rem + 8vw, 9rem);

  --ease: cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; scroll-padding-top: 80px; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font-display);
  font-size: var(--step-0);
  line-height: 1.6;
  color: var(--text-2);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

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

/* Icon-/Augen-Container: SVGs sauber an Wrapper-Breite binden */
.brand__eye, .stage__eye, .philo__eye { display: inline-block; line-height: 0; }
.brand__eye svg, .stage__eye svg, .philo__eye svg { width: 100%; height: auto; }

.wrap { width: min(var(--maxw), 100% - var(--pad) * 2); margin-inline: auto; }

/* ---- Typo-Bausteine ---- */
.kicker {
  font-family: var(--font-mono);
  font-size: var(--step--2);
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--accent);
}
h1,h2,h3 { font-family: var(--font-display); color: var(--text-1); line-height: 1.02; letter-spacing: -.02em; font-weight: 800; }

/* ---- Buttons (eckig) ---- */
.btn {
  display: inline-flex; align-items: center; gap: .6em;
  font-family: var(--font-mono);
  font-size: var(--step--1);
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: .95rem 1.5rem;
  border: 1px solid var(--line-2);
  color: var(--text-1);
  background: transparent;
  transition: border-color .25s var(--ease), background .25s var(--ease), color .25s var(--ease), box-shadow .25s var(--ease);
}
.btn--primary {
  border-color: var(--accent);
  color: #04121c;
  background: var(--accent);
  box-shadow: 0 0 0 0 var(--glow);
}
.btn--primary:hover { box-shadow: 0 0 28px -4px var(--glow); background: var(--accent-2); border-color: var(--accent-2); }
.hero__cta .btn--primary::after { content: '↓'; }
.btn--ghost:hover { border-color: var(--accent); color: var(--accent); }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--bg) 78%, transparent);
  backdrop-filter: blur(14px) saturate(120%);
  -webkit-backdrop-filter: blur(14px) saturate(120%);
  border-bottom: 1px solid var(--line);
}
.nav__inner { display: flex; align-items: center; justify-content: space-between; height: 64px; gap: 1.5rem; }
.brand { display: flex; align-items: center; gap: .6rem; }
.brand__eye { color: var(--accent); width: 30px; filter: drop-shadow(0 0 6px var(--glow)); }
.brand__word { font-family: var(--font-display); font-weight: 800; letter-spacing: .14em; font-size: 1.05rem; color: var(--text-1); }
/* dezenter, dauerhaft sichtbarer Satire-Hinweis */
.brand__tag { font-family: var(--font-mono); font-size: .56rem; line-height: 1; letter-spacing: .16em; text-transform: uppercase; color: var(--text-3); border: 1px solid var(--line-2); padding: .2rem .38rem; margin-left: .2rem; white-space: nowrap; }
.nav__links { display: flex; gap: 1.9rem; }
.nav__links a {
  font-family: var(--font-mono); font-size: var(--step--2);
  letter-spacing: .12em; text-transform: uppercase; color: var(--text-2);
  position: relative; padding-block: .4rem; transition: color .2s var(--ease);
}
.nav__links a::after { content:''; position:absolute; left:0; right:0; bottom:0; height:1px; background: var(--accent); transform: scaleX(0); transform-origin: left; transition: transform .25s var(--ease); }
.nav__links a:hover { color: var(--text-1); }
.nav__links a:hover::after { transform: scaleX(1); }
.nav__cta { padding: .6rem 1rem; }

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; overflow: hidden; padding-block: clamp(4rem, 12vh, 9rem) clamp(3rem, 8vh, 6rem); min-height: 88svh; display: flex; align-items: center; background: var(--bg); }
.hero__grid { position: absolute; inset: 0; background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 64px 64px; mask-image: radial-gradient(120% 90% at 50% 35%, #000 30%, transparent 75%); opacity: .5; }
.hero__glow { position: absolute; left: 50%; bottom: -10%; width: 80vw; height: 70vh; transform: translateX(-50%);
  background: radial-gradient(50% 50% at 50% 50%, var(--glow-soft), transparent 70%); pointer-events: none; }
.hero__inner { position: relative; z-index: 2; text-align: center; display: flex; flex-direction: column; align-items: center; }
.hero__title { font-size: var(--step-5); font-weight: 900; letter-spacing: -.04em; margin: 1.4rem 0 0; }
.hero__title span { display: block; }
.hero__title-2 { font-size: var(--step-3); font-weight: 700; color: var(--text-2); letter-spacing: -.02em; margin-top: .1em; }
.hero__sub { max-width: 36ch; font-size: var(--step-1); color: var(--text-2); margin-top: 1.6rem; }
.hero__cta { display: flex; flex-wrap: wrap; gap: 1.2rem 1.6rem; align-items: center; justify-content: center; margin-top: 2.2rem; }
.hero__status { font-family: var(--font-mono); font-size: var(--step--2); letter-spacing: .12em; text-transform: uppercase; color: var(--text-3); display: inline-flex; align-items: center; gap: .55rem; }
.hero__status i { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 10px var(--glow); animation: blink 2.4s var(--ease) infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.25} }

/* Produkt-Bühne mit leuchtendem Auge */
.stage { position: relative; margin-top: clamp(2.5rem, 6vw, 4.5rem); width: min(760px, 100%); aspect-ratio: 16/7;
  border: 1px solid var(--line); background:
    radial-gradient(60% 120% at 50% 120%, var(--glow-soft), transparent 60%),
    linear-gradient(180deg, var(--bg-2), var(--bg));
  display: grid; place-items: center; overflow: hidden; }
.stage img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.stage::before { content:''; position:absolute; inset:0; background-image: linear-gradient(90deg, var(--line) 1px, transparent 1px); background-size: 48px 48px; opacity:.3; mask-image: radial-gradient(70% 100% at 50% 100%, #000, transparent 70%); }
.stage__eye { color: var(--accent); width: clamp(110px, 22vw, 200px); filter: drop-shadow(0 0 22px var(--glow)) drop-shadow(0 0 60px var(--glow-soft)); animation: breathe 4.5s var(--ease) infinite; }
@keyframes breathe { 0%,100%{ transform: scale(1); opacity:.92 } 50%{ transform: scale(1.04); opacity:1 } }
.stage__label { position: absolute; left: 1rem; bottom: .8rem; z-index: 2; font-family: var(--font-mono); font-size: var(--step--2); letter-spacing: .2em; color: var(--text-2); }
/* Foto-Variante der Bühne (echtes Render) */
.stage--photo { aspect-ratio: 16/9; background: #060708; }
.stage--photo::before { display: none; }
.stage--photo::after { content: ''; position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, transparent 55%, rgba(5,7,9,.6)); pointer-events: none; }

/* ============================================================
   BILDBAND (Lifestyle)
   ============================================================ */
.band { position: relative; overflow: hidden; border-top: 1px solid var(--line); background: #060708; }
.band picture { display: block; }
.band img { display: block; width: 100%; height: auto; object-fit: contain; }
.band::after { content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 55%; pointer-events: none; background:
    linear-gradient(180deg, transparent 0%, rgba(7,9,11,.35) 55%, rgba(7,9,11,.9) 100%); }
.band__cap { position: absolute; left: 0; right: 0; bottom: clamp(1.6rem, 5vw, 3.2rem); z-index: 2; }
.band__line { max-width: 18ch; }
.band__line { font-family: var(--font-display); font-weight: 800; font-size: var(--step-3); letter-spacing: -.02em; color: var(--text-1); margin-top: .6rem; }
.band .kicker { color: var(--accent-2); }

.hero__scroll { position: absolute; left: 50%; bottom: 1.4rem; transform: translateX(-50%); width: 22px; height: 36px; border: 1px solid var(--line-2); border-radius: 12px; z-index: 2; }
.hero__scroll span { position: absolute; left: 50%; top: 7px; width: 3px; height: 7px; background: var(--accent); border-radius: 2px; transform: translateX(-50%); animation: scrolldot 1.8s var(--ease) infinite; }
@keyframes scrolldot { 0%{opacity:0; transform: translate(-50%,0)} 40%{opacity:1} 80%,100%{opacity:0; transform: translate(-50%,12px)} }

/* ============================================================
   SECTIONS
   ============================================================ */
.section { padding-block: clamp(4.5rem, 11vw, 9rem); border-top: 1px solid var(--line); }
.section--alt { background: var(--bg-2); }
.head { max-width: 62ch; margin-bottom: clamp(2.5rem, 6vw, 4.5rem); }
.head .kicker { display: inline-block; margin-bottom: 1.1rem; }
.head__title { font-size: var(--step-4); font-weight: 900; }
.head__lead { color: var(--text-2); font-size: var(--step-1); margin-top: 1.3rem; max-width: 52ch; }

/* 2x2 Feature-Grid */
.grid-2x2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--line); border: 1px solid var(--line); }
.feat { background: var(--bg); padding: clamp(1.8rem, 4vw, 3rem); position: relative; transition: background .3s var(--ease); }
.section--alt .feat { background: var(--bg-2); }
.feat:hover { background: var(--surface); }
.feat::before { content:''; position:absolute; top:0; left:0; width: 0; height: 2px; background: var(--accent); transition: width .4s var(--ease); box-shadow: 0 0 12px var(--glow); }
.feat:hover::before { width: 64px; }
.feat__icon { display: inline-grid; place-items: center; width: 42px; height: 42px; color: var(--accent); margin-bottom: 1.4rem; }
.feat__icon svg { width: 100%; height: 100%; filter: drop-shadow(0 0 8px var(--glow-soft)); }
.feat__tag { font-family: var(--font-mono); font-size: var(--step--2); letter-spacing: .2em; text-transform: uppercase; color: var(--accent); margin-bottom: .7rem; }
.feat__title { font-size: var(--step-2); font-weight: 800; margin-bottom: .9rem; }
.feat__body { color: var(--text-2); font-size: var(--step-0); max-width: 46ch; }

/* Technische Daten */
.specs { border: 1px solid var(--line); }
.spec { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; padding: 1.1rem clamp(1rem, 3vw, 1.8rem); border-bottom: 1px solid var(--line); transition: background .2s var(--ease); }
.spec:last-child { border-bottom: 0; }
.spec:hover { background: var(--surface); }
.spec__k { font-family: var(--font-mono); font-size: var(--step--1); letter-spacing: .04em; color: var(--text-3); text-transform: uppercase; }
.spec__v { font-family: var(--font-mono); font-size: var(--step--1); color: var(--text-1); text-align: right; }

/* Zubehör-Karten */
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.2rem, 3vw, 2rem); }
.card { border: 1px solid var(--line); background: var(--surface); display: flex; flex-direction: column; transition: border-color .3s var(--ease), transform .3s var(--ease); }
.card:hover { border-color: var(--line-2); transform: translateY(-3px); }
.card__media { position: relative; aspect-ratio: 16/10; overflow: hidden;
  background: radial-gradient(70% 120% at 50% 120%, var(--glow-soft), transparent 60%), linear-gradient(180deg, var(--bg-2), #0a0d10);
  border-bottom: 1px solid var(--line); display: grid; place-items: center; }
.card__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.card__part { font-family: var(--font-mono); font-size: clamp(2rem, 6vw, 3.4rem); font-weight: 700; letter-spacing: .04em; color: var(--text-1); opacity: .9; }
.card__motif { position: absolute; bottom: -40px; left: 50%; transform: translateX(-50%); width: 160px; height: 160px; border: 1px solid var(--accent-dim); border-radius: 50%; opacity: .5; }
.card__motif--roof { border-radius: 8px 8px 0 0; width: 200px; height: 90px; bottom: -10px; }
.card__body { padding: clamp(1.5rem, 3.5vw, 2.4rem); }
.card__note { font-family: var(--font-mono); font-size: var(--step--2); letter-spacing: .12em; text-transform: uppercase; color: var(--accent); margin-top: 1.2rem; padding-top: 1.2rem; border-top: 1px solid var(--line); }
.card__media img { z-index: 0; }
.card__media::after { content: ''; position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, transparent 56%, rgba(7,9,11,.6)); pointer-events: none; }
.card__plabel { position: absolute; left: 1rem; bottom: .85rem; z-index: 2; font-family: var(--font-mono); font-size: var(--step--2); letter-spacing: .18em; color: var(--text-1); }

/* ============================================================
   FILM / VIDEO
   ============================================================ */
.film { padding-block: clamp(2.5rem, 6vw, 5rem); background: var(--bg); border-top: 1px solid var(--line); }
.film__kicker { display: inline-block; margin-bottom: .9rem; }
.film__title { font-size: var(--step-2); font-weight: 800; letter-spacing: -.02em; color: var(--text-1); margin-bottom: 1.4rem; }
.film__frame { position: relative; border: 1px solid var(--line); background: #060708; overflow: hidden; }
.film__video { width: 100%; height: auto; display: block; }

/* Ton-an/aus-Button auf dem Video */
.film__sound { position: absolute; right: .7rem; bottom: .7rem; z-index: 3;
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .5rem .8rem; cursor: pointer;
  font-family: var(--font-mono); font-size: var(--step--2); letter-spacing: .12em; text-transform: uppercase;
  color: var(--text-1); background: color-mix(in srgb, var(--bg) 62%, transparent);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  border: 1px solid var(--line-2); transition: border-color .2s var(--ease), color .2s var(--ease); }
.film__sound:hover { border-color: var(--accent); color: var(--accent); }
.film__sound svg { width: 18px; height: 18px; }
.film__sound .snd-wave { opacity: 0; transition: opacity .2s var(--ease); }
.film__sound .snd-slash { opacity: 1; color: var(--red); transition: opacity .2s var(--ease); }
.film__sound.is-on .snd-wave { opacity: 1; }
.film__sound.is-on .snd-slash { opacity: 0; }

/* ============================================================
   PHILOSOPHIE
   ============================================================ */
.philo { position: relative; overflow: hidden; padding-block: clamp(6rem, 16vw, 12rem); border-top: 1px solid var(--line); text-align: center; background: var(--bg); }
.philo__glow { bottom: auto; top: 50%; transform: translate(-50%,-50%); height: 90vh; }
.philo__inner { position: relative; z-index: 2; display: flex; flex-direction: column; align-items: center; }
.philo__eye { color: var(--accent); width: 78px; filter: drop-shadow(0 0 18px var(--glow)); margin-bottom: 2.4rem; animation: breathe 4.5s var(--ease) infinite; }
.philo__quote { font-family: var(--font-display); font-weight: 700; font-size: var(--step-3); line-height: 1.2; letter-spacing: -.02em; color: var(--text-1); max-width: 22ch; }
.philo__by { font-family: var(--font-mono); font-size: var(--step--1); letter-spacing: .14em; text-transform: uppercase; color: var(--text-3); margin-top: 2.2rem; }

/* ============================================================
   RECHTSSEITEN (Impressum / Datenschutz)
   ============================================================ */
.doc { padding-block: clamp(4.5rem, 10vw, 7.5rem) clamp(3.5rem, 8vw, 6rem); }
.doc .kicker { display: inline-block; margin-bottom: 1.1rem; }
.doc h1 { font-size: var(--step-4); font-weight: 900; margin-bottom: 2.2rem; overflow-wrap: break-word; hyphens: auto; }
.doc h2 { font-size: var(--step-2); font-weight: 800; color: var(--text-1); margin: 2.6rem 0 .8rem; }
.doc p, .doc li { color: var(--text-2); max-width: 70ch; }
.doc p + p { margin-top: 1rem; }
.doc a { color: var(--accent); }
.doc a:hover { color: var(--accent-2); }
.doc ul { margin: .7rem 0 0 1.1rem; display: flex; flex-direction: column; gap: .4rem; }
.doc strong { color: var(--text-1); }
.doc .meta { margin-top: 2.6rem; padding-top: 1.3rem; border-top: 1px solid var(--line); font-family: var(--font-mono); font-size: var(--step--2); letter-spacing: .04em; color: var(--text-3); }

/* Kontaktseite */
.contact-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(2rem, 5vw, 4rem); align-items: start; }
.contact-mail { display: inline-block; font-family: var(--font-mono); font-size: var(--step-1); color: var(--accent); margin-top: .4rem; word-break: break-word; }
.contact-mail:hover { color: var(--accent-2); }
.contact-meta { font-family: var(--font-mono); font-size: var(--step--1); letter-spacing: .04em; color: var(--text-3); margin-top: 2rem; line-height: 1.7; }
.cform { display: grid; gap: 1.1rem; border: 1px solid var(--line); background: var(--surface); padding: clamp(1.5rem, 4vw, 2.4rem); }
.cfield { display: flex; flex-direction: column; gap: .45rem; }
.cfield label { font-family: var(--font-mono); font-size: var(--step--2); letter-spacing: .14em; text-transform: uppercase; color: var(--text-3); }
.cfield input, .cfield textarea { font-family: var(--font-display); font-size: var(--step-0); color: var(--text-1); background: var(--bg); border: 1px solid var(--line-2); padding: .8rem 1rem; }
.cfield input::placeholder, .cfield textarea::placeholder { color: var(--text-3); }
.cfield input:focus, .cfield textarea:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--glow-soft); }
.cfield textarea { resize: vertical; min-height: 120px; line-height: 1.5; }
.cform__hint { font-family: var(--font-mono); font-size: var(--step--2); color: var(--text-3); }
@media (max-width: 760px) { .contact-grid { grid-template-columns: 1fr; } }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { border-top: 1px solid var(--line); background: var(--bg-2); padding-block: clamp(3rem, 6vw, 4.5rem) 2rem; }
.footer__inner { display: flex; justify-content: space-between; align-items: flex-start; gap: 2rem; flex-wrap: wrap; padding-bottom: 2.2rem; border-bottom: 1px solid var(--line); }
.footer__brand { display: flex; gap: .9rem; align-items: flex-start; }
.footer__brand .brand__eye { width: 34px; color: var(--accent); }
.footer__word { font-family: var(--font-display); font-weight: 800; letter-spacing: .14em; color: var(--text-1); }
.footer__tag { color: var(--text-3); font-size: var(--step--1); max-width: 32ch; margin-top: .3rem; }
.footer__legal { display: flex; flex-wrap: wrap; gap: 1.4rem; }
.footer__legal a { font-family: var(--font-mono); font-size: var(--step--2); letter-spacing: .12em; text-transform: uppercase; color: var(--text-2); transition: color .2s var(--ease); }
.footer__legal a:hover { color: var(--accent); }
.footer__bottom { display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; margin-top: 1.6rem; }
.footer__bottom p, .footer__disclaimer { font-family: var(--font-mono); font-size: var(--step--2); letter-spacing: .04em; color: var(--text-3); }
.footer__disclaimer { max-width: 56ch; text-align: right; }

/* ============================================================
   REVEAL-ANIMATION
   ============================================================ */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s var(--ease), transform .7s var(--ease); transition-delay: calc(var(--d, 0) * 90ms); }
.reveal.is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
  .reveal { opacity: 1; transform: none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 820px) {
  .nav__links { display: none; }
  .grid-2x2 { grid-template-columns: 1fr; }
  .grid-2 { grid-template-columns: 1fr; }
  .footer__disclaimer { text-align: left; }
  .footer__bottom { flex-direction: column; }
  .footer__inner { flex-direction: column; gap: 1.6rem; }
}
@media (max-width: 540px) {
  .spec { grid-template-columns: 1fr; gap: .25rem; }
  .spec__v { text-align: left; }
  .stage { aspect-ratio: 4/3; }
  .stage--photo { aspect-ratio: 4/3; }

  /* Header kompakt halten, Kontakt-Button bleibt sichtbar */
  .nav__inner { gap: .6rem; }
  .nav__cta { padding: .55rem .85rem; }

  /* Hero-CTA: volle Breite = große Tap-Targets */
  .hero__cta { width: 100%; gap: 1rem; }
  .hero__cta .btn { width: 100%; justify-content: center; }
  .hero__status { justify-content: center; }

  /* Kontaktformular-Button gut greifbar */
  .cform .btn { width: 100%; }
}
@media (max-width: 380px) {
  /* Auf sehr schmalen Phones Satire-Badge ausblenden, damit nichts überläuft */
  .brand__tag { display: none; }
}
