/* ══════════════════════════════════════════════
   TSCode – style.css  |  v2.0
   ══════════════════════════════════════════════ */

/* ── RESET & VARIABLES ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:        #F2F0EB;
  --surface:   #FFFFFF;
  --primary:   #1E2D40;
  --accent:    #3D6B52;
  --accent-lt: #5A8A6E;
  --muted:     #8A9BB0;
  --border:    #DDD9D0;
  --text:      #1E2D40;
  --text-soft: #4A5568;
  --gold:      #B8956A;
  --radius:    12px;
  --shadow:    0 4px 24px rgba(30,45,64,.08);
  --shadow-lg: 0 12px 48px rgba(30,45,64,.14);
  --shadow-xl: 0 24px 80px rgba(30,45,64,.18);
}

html { scroll-behavior: smooth; }

body {
  font-family: 'Inter', sans-serif;
  background: var(--bg);
  color: var(--text);
  font-size: 16px;
  line-height: 1.65;
  overflow-x: hidden;
}

h1,h2,h3,h4 { font-family: 'Playfair Display', serif; line-height: 1.25; }

img { max-width: 100%; display: block; }

/* ── NAV ── */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  background: rgba(242,240,235,.94);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border); padding: 0 2rem;
}
.nav-inner {
  max-width: 1140px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  height: 68px;
}
.logo { display: flex; align-items: center; text-decoration: none; flex-shrink: 0; }
.logo-img { height: 52px; width: auto; display: block; }

.nav-links { display: flex; align-items: center; gap: 2rem; list-style: none; }
.nav-links a {
  text-decoration: none; color: var(--text-soft);
  font-size: .88rem; font-weight: 500; transition: color .2s;
}
.nav-links a:hover, .nav-links a.active { color: var(--primary); }
.nav-cta {
  background: var(--primary) !important; color: #fff !important;
  padding: .5rem 1.2rem; border-radius: 8px; transition: background .2s !important;
}
.nav-cta:hover { background: var(--accent) !important; }

.burger { display: none; flex-direction: column; gap: 5px; cursor: pointer; border: none; background: none; padding: 4px; }
.burger span { display: block; width: 24px; height: 2px; background: var(--primary); border-radius: 2px; transition: .3s; }
.burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2) { opacity: 0; }
.burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── HERO ── */
.hero-wrapper { background: var(--bg); }
.hero {
  min-height: 100vh; display: flex; align-items: center;
  padding: 7rem 2rem 5rem; max-width: 1200px; margin: 0 auto; position: relative;
}
.hero-inner {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 4rem; align-items: center; width: 100%;
}
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: .5rem;
  font-size: .8rem; font-weight: 600; letter-spacing: .12em;
  text-transform: uppercase; color: var(--accent); margin-bottom: 1.5rem;
}
.hero-eyebrow::before,.hero-eyebrow::after { content:'';display:block;width:28px;height:1px;background:var(--accent); }
.hero h1 { font-size: clamp(2.4rem,5vw,3.8rem); margin-bottom: 1.2rem; color: var(--primary); }
.hero h1 em { color: var(--accent); font-style: normal; }
.hero p { font-size: 1.1rem; color: var(--text-soft); max-width: 520px; margin: 0 0 2.5rem; }
.btn-group { display: flex; gap: 1rem; flex-wrap: wrap; }
.btn {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .85rem 2rem; border-radius: 10px; font-size: .95rem; font-weight: 600;
  text-decoration: none; transition: all .2s; cursor: pointer; border: none; font-family: inherit;
}
.btn-primary { background: var(--primary); color: #fff; }
.btn-primary:hover { background: var(--accent); transform: translateY(-2px); box-shadow: var(--shadow); }
.btn-outline { background: transparent; color: var(--primary); border: 2px solid var(--border); }
.btn-outline:hover { border-color: var(--primary); transform: translateY(-2px); }
.btn-accent { background: var(--accent); color: #fff; }
.btn-accent:hover { background: var(--accent-lt); transform: translateY(-2px); }

.hero-stats { display: flex; gap: 3rem; margin-top: 3.5rem; flex-wrap: wrap; }
.stat-num { font-family:'Playfair Display',serif; font-size:1.8rem; font-weight:700; color:var(--primary); }
.stat-label { font-size:.78rem; color:var(--muted); letter-spacing:.06em; text-transform:uppercase; }

.hero-image-wrap { position: relative; z-index: 1; }
.hero-image-frame { border-radius: 20px; overflow: hidden; box-shadow: var(--shadow-lg); aspect-ratio: 4/5; }
.hero-image-frame img { width:100%; height:100%; object-fit:cover; }
.hero-deco-card {
  position: absolute; top: -1.5rem; right: -1.5rem;
  background: var(--primary); border-radius: 14px; padding: 1rem 1.2rem;
  color: #fff; text-align: center; box-shadow: var(--shadow-lg); z-index: 2;
}
.hero-deco-num { font-family:'Playfair Display',serif; font-size:1.6rem; font-weight:700; }
.hero-deco-label { font-size:.7rem; color:rgba(255,255,255,.6); text-transform:uppercase; letter-spacing:.08em; }
.hero-image-badge {
  position: absolute; bottom: 1.5rem; left: 1.5rem; right: 1.5rem;
  background: rgba(255,255,255,.9); backdrop-filter: blur(12px);
  border-radius: 12px; padding: 1rem 1.2rem;
  display: flex; align-items: center; gap: .8rem; z-index: 2;
}
.hero-badge-dot { width:10px; height:10px; border-radius:50%; background:var(--accent); flex-shrink:0; animation:pulse 2s infinite; }
@keyframes pulse { 0%,100%{box-shadow:0 0 0 3px rgba(61,107,82,.25)}50%{box-shadow:0 0 0 6px rgba(61,107,82,.1)} }
.hero-badge-text { font-size:.82rem; font-weight:600; color:var(--primary); }
.hero-badge-text span { display:block; font-size:.75rem; font-weight:400; color:var(--text-soft); }

/* ── ORNAMENT ── */
.nordic-ornament { text-align:center; padding:1.5rem; font-size:1.2rem; color:var(--border); letter-spacing:.4em; }

/* ── SECTIONS ── */
section { padding: 6rem 2rem; }
.section-header { text-align:center; max-width:640px; margin:0 auto 4rem; }
.section-eyebrow { font-size:.78rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); margin-bottom:.8rem; }
.section-header h2 { font-size:clamp(1.8rem,4vw,2.6rem); margin-bottom:1rem; }
.section-header p { color:var(--text-soft); }

/* ── GALLERY ── */
#galerie { background:var(--bg); padding:3rem 2rem; }
.gallery-grid { display:grid; grid-template-columns:1.4fr 1fr 1fr; grid-template-rows:280px 280px; gap:1rem; max-width:1100px; margin:0 auto; }
.gallery-item { border-radius:14px; overflow:hidden; position:relative; }
.gallery-item:first-child { grid-row:1/3; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.gallery-item:hover img { transform:scale(1.04); }
.gallery-item-label {
  position:absolute; bottom:0; left:0; right:0; padding:.8rem 1rem;
  background:linear-gradient(to top,rgba(30,45,64,.75),transparent);
  color:#fff; font-size:.82rem; font-weight:500;
}

/* ── SERVICES ── */
#leistungen { background:var(--surface); }
.services-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:2rem; max-width:1100px; margin:0 auto; }
.service-card { background:var(--bg); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; transition:transform .25s,box-shadow .25s; }
.service-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.service-card-img { width:100%; height:200px; object-fit:cover; }
.service-card-body { padding:2rem; }
.service-icon { width:48px; height:48px; border-radius:12px; background:var(--primary); display:flex; align-items:center; justify-content:center; margin-bottom:1.2rem; }
.service-icon svg { width:24px; height:24px; stroke:#fff; fill:none; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; }
.service-card h3 { font-size:1.25rem; margin-bottom:.7rem; }
.service-card p { color:var(--text-soft); font-size:.93rem; margin-bottom:1.4rem; }
.service-tags { display:flex; flex-wrap:wrap; gap:.5rem; }
.tag { font-size:.75rem; font-weight:500; background:var(--surface); border:1px solid var(--border); color:var(--text-soft); padding:.25rem .7rem; border-radius:99px; }

/* ── PROCESS ── */
#prozess { background:var(--bg); }
.process-steps { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:2rem; max-width:1100px; margin:0 auto; }
.step { text-align:center; padding:2rem 1.5rem; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); transition:transform .25s,box-shadow .25s; }
.step:hover { transform:translateY(-3px); box-shadow:var(--shadow); }
.step-num { font-family:'Playfair Display',serif; font-size:2.5rem; font-weight:700; color:var(--border); line-height:1; margin-bottom:1rem; }
.step h4 { font-size:1rem; margin-bottom:.5rem; }
.step p { font-size:.88rem; color:var(--text-soft); }

/* ── PRICING ── */
#preise { background:var(--surface); }
.pricing-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(290px,1fr)); gap:2rem; max-width:1000px; margin:0 auto; align-items:start; }
.pricing-card { background:var(--bg); border:1px solid var(--border); border-radius:var(--radius); padding:2.5rem; position:relative; transition:transform .25s,box-shadow .25s; }
.pricing-card.featured { background:var(--primary); border-color:var(--primary); color:#fff; transform:scale(1.03); }
.pricing-card:not(.featured):hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.pricing-card.featured:hover { transform:scale(1.03) translateY(-4px); box-shadow:var(--shadow-lg); }
.pricing-badge { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--gold); color:#fff; font-size:.72rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; padding:.25rem .9rem; border-radius:99px; white-space:nowrap; }
.pricing-name { font-family:'Playfair Display',serif; font-size:1.2rem; font-weight:600; margin-bottom:.5rem; color:inherit; }
.pricing-desc { font-size:.88rem; opacity:.7; margin-bottom:1.8rem; }
.pricing-price { margin-bottom:2rem; }
.price-from { font-size:.78rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; opacity:.6; }
.price-num { font-family:'Playfair Display',serif; font-size:2.8rem; font-weight:700; line-height:1.1; }
.price-num sup { font-size:1.1rem; vertical-align:top; margin-top:.5rem; display:inline-block; }
.price-period { font-size:.85rem; opacity:.6; margin-top:.2rem; }
.pricing-features { list-style:none; margin-bottom:2rem; display:flex; flex-direction:column; gap:.7rem; }
.pricing-features li { display:flex; align-items:flex-start; gap:.7rem; font-size:.9rem; }
.pricing-features li .check { flex-shrink:0; margin-top:.15rem; }
.pricing-features li .check svg { width:16px; height:16px; }
.pricing-card:not(.featured) .check svg { stroke:var(--accent); fill:none; stroke-width:2.5; stroke-linecap:round; stroke-linejoin:round; }
.pricing-card.featured .check svg { stroke:#7ECBA1; fill:none; stroke-width:2.5; stroke-linecap:round; stroke-linejoin:round; }
.pricing-card.featured li { color:rgba(255,255,255,.9); }
.pricing-note { text-align:center; margin-top:2rem; font-size:.85rem; color:var(--muted); }
.btn-pricing { display:block; width:100%; text-align:center; padding:.9rem; border-radius:9px; font-size:.95rem; font-weight:600; text-decoration:none; transition:.2s; cursor:pointer; border:none; font-family:inherit; }
.btn-pricing-dark { background:var(--primary); color:#fff; }
.btn-pricing-dark:hover { background:var(--accent); }
.btn-pricing-light { background:#fff; color:var(--primary); }
.btn-pricing-light:hover { background:rgba(255,255,255,.88); }

/* ── TRUST ── */
#vertrauen { background:var(--bg); }
.trust-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:1.5rem; max-width:1100px; margin:0 auto; }
.trust-card { padding:2rem; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); transition:transform .25s,box-shadow .25s; }
.trust-card:hover { transform:translateY(-3px); box-shadow:var(--shadow); }
.trust-icon { font-size:1.6rem; margin-bottom:1rem; }
.trust-card h4 { font-size:1rem; margin-bottom:.4rem; }
.trust-card p { font-size:.88rem; color:var(--text-soft); }

/* ══════════════════════════════════════════════
   NEUE SEKTIONEN
   ══════════════════════════════════════════════ */

/* ── PORTFOLIO ── */
#portfolio { background: var(--surface); }

.portfolio-filters {
  display: flex; justify-content: center; gap: .75rem;
  flex-wrap: wrap; margin-bottom: 3rem;
}
.filter-btn {
  padding: .55rem 1.4rem; border-radius: 99px;
  border: 1.5px solid var(--border); background: transparent;
  color: var(--text-soft); font-size: .85rem; font-weight: 500;
  cursor: pointer; transition: all .2s; font-family: inherit;
}
.filter-btn:hover, .filter-btn.active {
  background: var(--primary); border-color: var(--primary);
  color: #fff;
}
.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 2rem; max-width: 1100px; margin: 0 auto;
}
.project-card {
  border-radius: var(--radius); overflow: hidden;
  background: var(--bg); border: 1px solid var(--border);
  transition: transform .3s, box-shadow .3s;
  position: relative;
}
.project-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-xl); }
.project-card[data-hidden] { display: none; }

.project-img-wrap {
  position: relative; overflow: hidden; height: 220px;
}
.project-img-wrap img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .5s ease;
}
.project-card:hover .project-img-wrap img { transform: scale(1.06); }

.project-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, transparent 40%, rgba(30,45,64,.85));
  display: flex; align-items: flex-end;
  padding: 1.5rem; opacity: 0;
  transition: opacity .3s;
}
.project-card:hover .project-overlay { opacity: 1; }
.project-overlay a {
  color: #fff; font-weight: 600; font-size: .85rem;
  text-decoration: none; border: 1.5px solid rgba(255,255,255,.6);
  padding: .4rem 1rem; border-radius: 6px;
  transition: background .2s;
}
.project-overlay a:hover { background: rgba(255,255,255,.15); }

.project-cat-badge {
  position: absolute; top: 1rem; right: 1rem;
  background: var(--accent); color: #fff;
  font-size: .7rem; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; padding: .25rem .7rem; border-radius: 6px;
}

.project-body { padding: 1.5rem; }
.project-body h3 { font-size: 1.1rem; margin-bottom: .4rem; }
.project-body p { font-size: .88rem; color: var(--text-soft); margin-bottom: 1rem; }
.project-tech { display: flex; flex-wrap: wrap; gap: .4rem; }
.tech-tag {
  font-size: .72rem; font-weight: 600;
  background: rgba(30,45,64,.06); color: var(--primary);
  padding: .2rem .6rem; border-radius: 4px;
}

/* ── DEMO WORLDS ── */
#demos { background: var(--primary); color: #fff; position: relative; overflow: hidden; }
#demos::before {
  content: '';
  position: absolute; inset: 0; z-index: 0;
  background: radial-gradient(ellipse 80% 60% at 20% 40%, rgba(61,107,82,.15), transparent),
              radial-gradient(ellipse 60% 80% at 80% 70%, rgba(184,149,106,.08), transparent);
}
#demos .section-header { position: relative; z-index: 1; }
#demos .section-eyebrow { color: var(--accent-lt); }
#demos .section-header h2 { color: #fff; }
#demos .section-header p { color: rgba(255,255,255,.65); }

.demos-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.5rem; max-width: 1100px; margin: 0 auto;
  position: relative; z-index: 1;
}
.demo-card {
  border-radius: 16px; overflow: hidden;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  transition: transform .3s, box-shadow .3s, border-color .3s;
  cursor: pointer;
}
.demo-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 60px rgba(0,0,0,.35);
  border-color: rgba(255,255,255,.25);
}
.demo-card-img {
  height: 180px; overflow: hidden; position: relative;
}
.demo-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.demo-card:hover .demo-card-img img { transform: scale(1.07); }
.demo-card-img-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, transparent 50%, rgba(0,0,0,.6));
}
.demo-card-body { padding: 1.5rem; }
.demo-card-icon {
  width: 42px; height: 42px; border-radius: 10px; margin-bottom: 1rem;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem;
}
.demo-card-body h3 { font-size: 1.1rem; color: #fff; margin-bottom: .4rem; }
.demo-card-body p { font-size: .85rem; color: rgba(255,255,255,.6); margin-bottom: 1.2rem; }
.demo-card-btn {
  display: inline-flex; align-items: center; gap: .4rem;
  font-size: .82rem; font-weight: 600; color: #fff;
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
  padding: .5rem 1.1rem; border-radius: 7px;
  transition: background .2s; cursor: pointer; font-family: inherit;
  text-decoration: none; border: none;
}
.demo-card-btn:hover { background: rgba(255,255,255,.2); }
.demo-card-btn svg { width:14px; height:14px; stroke:currentColor; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }

/* ── KI WEBSITE CHECK ── */
#ki-check {
  background: #0A0E1A;
  color: #fff;
  position: relative;
  overflow: hidden;
}
#ki-check::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 10% 20%, rgba(61,107,82,.15), transparent),
    radial-gradient(ellipse 50% 60% at 90% 80%, rgba(30,45,64,.3), transparent);
}
.ki-check-inner { max-width: 860px; margin: 0 auto; position: relative; z-index: 1; }
#ki-check .section-eyebrow { color: #5A8A6E; }
#ki-check .section-header h2 { color: #fff; }
#ki-check .section-header p { color: rgba(255,255,255,.6); }

.ki-input-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 20px; padding: 2.5rem;
  margin-bottom: 2.5rem;
}
.ki-input-row {
  display: flex; gap: 1rem; align-items: stretch;
}
.ki-url-input {
  flex: 1; background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12); border-radius: 10px;
  padding: .9rem 1.3rem; color: #fff; font-size: 1rem; font-family: inherit;
  outline: none; transition: border-color .2s;
}
.ki-url-input::placeholder { color: rgba(255,255,255,.3); }
.ki-url-input:focus { border-color: #5A8A6E; }
.ki-analyze-btn {
  background: linear-gradient(135deg, #3D6B52, #5A8A6E);
  color: #fff; border: none; border-radius: 10px;
  padding: .9rem 2rem; font-size: .95rem; font-weight: 700;
  cursor: pointer; font-family: inherit; white-space: nowrap;
  transition: opacity .2s, transform .2s;
}
.ki-analyze-btn:hover { opacity: .9; transform: translateY(-1px); }
.ki-analyze-btn:disabled { opacity: .5; cursor: not-allowed; transform: none; }

/* Loading state */
.ki-loading {
  display: none; text-align: center; padding: 2rem 0;
}
.ki-loading.active { display: block; }
.ki-loading-dots { display: flex; gap: .5rem; justify-content: center; margin-bottom: 1rem; }
.ki-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: #5A8A6E; animation: kiBounce 1.2s ease-in-out infinite;
}
.ki-dot:nth-child(2) { animation-delay: .2s; }
.ki-dot:nth-child(3) { animation-delay: .4s; }
@keyframes kiBounce {
  0%,80%,100% { transform: scale(1); opacity: .7; }
  40% { transform: scale(1.3); opacity: 1; }
}
.ki-loading-text { font-size: .9rem; color: rgba(255,255,255,.6); }
.ki-progress-track {
  height: 3px; background: rgba(255,255,255,.1);
  border-radius: 3px; margin-top: 1.2rem; overflow: hidden;
}
.ki-progress-fill {
  height: 100%; background: linear-gradient(90deg, #3D6B52, #5A8A6E);
  border-radius: 3px; width: 0%; transition: width .3s ease;
}

/* Results */
.ki-results { display: none; }
.ki-results.active { display: block; }
.ki-results-url {
  text-align: center; margin-bottom: 2rem;
  font-size: .85rem; color: rgba(255,255,255,.5);
}
.ki-results-url strong { color: #5A8A6E; }

.ki-scores-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(150px,1fr));
  gap: 1.5rem; margin-bottom: 2.5rem;
}
.ki-score-item { text-align: center; }
.ki-score-ring {
  position: relative; width: 100px; height: 100px;
  margin: 0 auto 1rem;
}
.ki-score-ring svg { transform: rotate(-90deg); }
.ki-score-ring .ring-bg { fill: none; stroke: rgba(255,255,255,.08); stroke-width: 6; }
.ki-score-ring .ring-fill {
  fill: none; stroke-width: 6; stroke-linecap: round;
  stroke-dasharray: 251;
  stroke-dashoffset: 251;
  transition: stroke-dashoffset 1.5s cubic-bezier(.4,0,.2,1);
}
.ki-score-num {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Playfair Display', serif; font-size: 1.4rem; font-weight: 700;
}
.ki-score-label { font-size: .82rem; color: rgba(255,255,255,.6); font-weight: 500; }

/* score colors */
.ring-great { stroke: #3D6B52; }
.ring-good  { stroke: #B8956A; }
.ring-ok    { stroke: #4A7FA5; }
.ring-warn  { stroke: #A04040; }
.score-great { color: #5A8A6E; }
.score-good  { color: #C9A96E; }
.score-ok    { color: #5A9EC5; }
.score-warn  { color: #C06060; }

.ki-cta-box {
  background: linear-gradient(135deg, rgba(61,107,82,.2), rgba(30,45,64,.3));
  border: 1px solid rgba(61,107,82,.3);
  border-radius: 14px; padding: 2rem; text-align: center;
}
.ki-cta-box h3 { font-size: 1.3rem; margin-bottom: .5rem; }
.ki-cta-box p { color: rgba(255,255,255,.6); margin-bottom: 1.5rem; font-size: .92rem; }

/* ── BEWERTUNGEN ── */
#bewertungen { background: var(--surface); }
.reviews-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px,1fr));
  gap: 1.5rem; max-width: 1100px; margin: 0 auto;
}
.review-card {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 2rem;
  transition: transform .25s, box-shadow .25s;
}
.review-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.review-stars { color: #F59E0B; font-size: 1.1rem; margin-bottom: 1rem; letter-spacing: .1em; }
.review-text { font-size: .93rem; color: var(--text-soft); margin-bottom: 1.5rem; font-style: italic; line-height: 1.7; }
.review-author { display: flex; align-items: center; gap: .9rem; }
.review-avatar {
  width: 44px; height: 44px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: .9rem; color: #fff; flex-shrink: 0;
}
.review-name { font-weight: 600; font-size: .9rem; }
.review-service { font-size: .78rem; color: var(--muted); }

.reviews-summary {
  text-align: center; margin-bottom: 3rem;
  display: flex; justify-content: center; align-items: center; gap: 1.5rem; flex-wrap: wrap;
}
.reviews-big-score {
  font-family: 'Playfair Display', serif; font-size: 3.5rem;
  font-weight: 700; color: var(--primary); line-height: 1;
}
.reviews-stars-big { color: #F59E0B; font-size: 1.4rem; letter-spacing: .1em; }
.reviews-count { font-size: .85rem; color: var(--muted); }

/* ── ÜBER UNS ── */
#ueber-uns { background: var(--bg); }
.about-grid {
  display: grid; grid-template-columns: 1fr 1.2fr;
  gap: 5rem; max-width: 1000px; margin: 0 auto; align-items: center;
}
.about-img-wrap {
  position: relative;
}
.about-img-frame {
  border-radius: 20px; overflow: hidden;
  box-shadow: var(--shadow-xl);
  aspect-ratio: 3/4;
}
.about-img-frame img { width:100%; height:100%; object-fit:cover; }
.about-img-badge {
  position: absolute; bottom: -1.5rem; right: -1.5rem;
  background: var(--primary); border-radius: 14px;
  padding: 1.2rem 1.5rem; text-align: center;
  box-shadow: var(--shadow-lg);
}
.about-badge-num { font-family:'Playfair Display',serif; font-size:1.8rem; font-weight:700; color:#fff; line-height:1; }
.about-badge-label { font-size:.7rem; color:rgba(255,255,255,.6); text-transform:uppercase; letter-spacing:.08em; }

.about-content .section-eyebrow { text-align: left; display: block; }
.about-content h2 { font-size: clamp(1.8rem,3.5vw,2.4rem); margin-bottom: 1.2rem; }
.about-content p { color: var(--text-soft); margin-bottom: 1rem; }
.about-skills { display: flex; flex-wrap: wrap; gap: .6rem; margin: 1.5rem 0; }
.skill-pill {
  background: var(--surface); border: 1.5px solid var(--border);
  color: var(--primary); padding: .4rem .9rem; border-radius: 99px;
  font-size: .82rem; font-weight: 600;
}
.about-values { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 2rem; }
.about-value { display: flex; align-items: flex-start; gap: .8rem; }
.about-value-icon { font-size: 1.2rem; flex-shrink: 0; margin-top: .1rem; }
.about-value-text h4 { font-size: .9rem; margin-bottom: .2rem; font-family: 'Inter', sans-serif; font-weight: 600; }
.about-value-text p { font-size: .82rem; color: var(--muted); margin: 0; }

/* ── FAQ ── */
#faq { background: var(--surface); }
.faq-list { max-width: 760px; margin: 0 auto; }
.faq-item {
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}
.faq-item:last-child { border-bottom: none; }
.faq-question {
  width: 100%; display: flex; justify-content: space-between; align-items: center;
  padding: 1.4rem 0; background: none; border: none; cursor: pointer;
  font-family: inherit; font-size: 1rem; font-weight: 600;
  color: var(--primary); text-align: left; gap: 1rem;
  transition: color .2s;
}
.faq-question:hover { color: var(--accent); }
.faq-icon {
  width: 24px; height: 24px; border-radius: 50%;
  background: var(--bg); border: 1.5px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; transition: transform .3s, background .2s, border-color .2s;
  font-size: .9rem; color: var(--primary); font-weight: 700;
}
.faq-item.open .faq-icon { transform: rotate(45deg); background: var(--accent); border-color: var(--accent); color: #fff; }
.faq-answer {
  max-height: 0; overflow: hidden;
  transition: max-height .4s cubic-bezier(.4,0,.2,1), padding .3s;
}
.faq-answer-inner { padding: 0 0 1.4rem; color: var(--text-soft); font-size: .95rem; line-height: 1.7; }
.faq-item.open .faq-answer { max-height: 300px; }

/* ── CONTACT ── */
#kontakt { background: var(--primary); color: #fff; }
#kontakt .section-eyebrow { color: var(--accent-lt); }
#kontakt .section-header h2 { color: #fff; }
#kontakt .section-header p { color: rgba(255,255,255,.65); }
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; max-width:960px; margin:0 auto; align-items:start; }
.contact-info h3 { font-size:1.3rem; margin-bottom:1.5rem; color:#fff; }
.contact-item { display:flex; align-items:flex-start; gap:1rem; margin-bottom:1.2rem; }
.contact-item-icon { width:40px; height:40px; border-radius:10px; background:rgba(255,255,255,.08); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.contact-item-icon svg { width:18px; height:18px; stroke:var(--accent-lt); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.contact-item-text { font-size:.9rem; color:rgba(255,255,255,.75); }
.contact-item-text strong { display:block; color:#fff; margin-bottom:.1rem; }
.contact-form { display:flex; flex-direction:column; gap:1rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-group { display:flex; flex-direction:column; gap:.4rem; }
.form-group label { font-size:.8rem; font-weight:500; color:rgba(255,255,255,.6); letter-spacing:.05em; text-transform:uppercase; }
.form-group input,.form-group select,.form-group textarea { background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.12); border-radius:8px; padding:.75rem 1rem; color:#fff; font-size:.93rem; font-family:'Inter',sans-serif; outline:none; transition:.2s; -webkit-appearance:none; }
.form-group input::placeholder,.form-group textarea::placeholder { color:rgba(255,255,255,.3); }
.form-group input:focus,.form-group select:focus,.form-group textarea:focus { border-color:var(--accent-lt); background:rgba(255,255,255,.1); }
.form-group select option { background:var(--primary); color:#fff; }
.form-group textarea { resize:vertical; min-height:110px; }
.form-submit { background:var(--accent); color:#fff; border:none; border-radius:9px; padding:.9rem; font-size:.95rem; font-weight:600; cursor:pointer; transition:.2s; margin-top:.5rem; font-family:inherit; }
.form-submit:hover { background:var(--accent-lt); transform:translateY(-1px); }
.form-submit:disabled { opacity:.6; cursor:not-allowed; transform:none; }

/* ── TOAST ── */
.toast { position:fixed; bottom:2rem; right:2rem; z-index:999; background:var(--accent); color:#fff; padding:1rem 1.5rem; border-radius:10px; font-weight:500; font-size:.95rem; box-shadow:var(--shadow-lg); transform:translateY(80px); opacity:0; transition:.4s cubic-bezier(.34,1.56,.64,1); pointer-events:none; }
.toast.show { transform:translateY(0); opacity:1; }
.toast.error { background:#c0392b; }

/* ── WHATSAPP BUTTON ── */
.whatsapp-fab {
  position: fixed; bottom: 5.5rem; right: 1.5rem; z-index: 300;
  width: 58px; height: 58px; border-radius: 50%;
  background: #25D366;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 20px rgba(37,211,102,.45);
  text-decoration: none; transition: transform .25s, box-shadow .25s;
  animation: waPulseRing 2.5s ease-in-out infinite;
}
.whatsapp-fab:hover {
  transform: scale(1.1);
  box-shadow: 0 8px 30px rgba(37,211,102,.55);
  animation: none;
}
.whatsapp-fab svg { width: 30px; height: 30px; fill: #fff; }
@keyframes waPulseRing {
  0% { box-shadow: 0 4px 20px rgba(37,211,102,.45), 0 0 0 0 rgba(37,211,102,.4); }
  50% { box-shadow: 0 4px 20px rgba(37,211,102,.45), 0 0 0 12px rgba(37,211,102,0); }
  100% { box-shadow: 0 4px 20px rgba(37,211,102,.45), 0 0 0 0 rgba(37,211,102,0); }
}

.whatsapp-tooltip {
  position: absolute; right: calc(100% + .75rem); top: 50%;
  transform: translateY(-50%); white-space: nowrap;
  background: #1E2D40; color: #fff;
  padding: .4rem .9rem; border-radius: 8px;
  font-size: .82rem; font-weight: 500; pointer-events: none;
  opacity: 0; transition: opacity .2s;
}
.whatsapp-tooltip::after {
  content: ''; position: absolute; right: -.4rem; top: 50%;
  transform: translateY(-50%); width: 0; height: 0;
  border-left: 5px solid #1E2D40;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
}
.whatsapp-fab:hover .whatsapp-tooltip { opacity: 1; }

/* ── FOOTER ── */
footer { background:#131E2B; color:rgba(255,255,255,.5); padding:3rem 2rem; }
.footer-inner { max-width:1100px; margin:0 auto; display:flex; flex-wrap:wrap; justify-content:space-between; align-items:center; gap:1.5rem; }
.footer-logo { text-decoration:none; display:block; }
.footer-logo img { height:36px; width:auto; filter:brightness(0) invert(1); }
.footer-links { display:flex; gap:2rem; list-style:none; flex-wrap:wrap; }
.footer-links a { color:rgba(255,255,255,.45); text-decoration:none; font-size:.85rem; transition:color .2s; }
.footer-links a:hover { color:#fff; }
.footer-copy { font-size:.8rem; }

/* ── SCROLL ANIMATIONS ── */
.reveal { opacity:0; transform:translateY(24px); transition:opacity .6s ease,transform .6s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }

.reveal-left { opacity:0; transform:translateX(-40px); transition:opacity .7s ease,transform .7s ease; }
.reveal-left.visible { opacity:1; transform:translateX(0); }

.reveal-right { opacity:0; transform:translateX(40px); transition:opacity .7s ease,transform .7s ease; }
.reveal-right.visible { opacity:1; transform:translateX(0); }

.reveal-zoom { opacity:0; transform:scale(.9); transition:opacity .6s ease,transform .6s ease; }
.reveal-zoom.visible { opacity:1; transform:scale(1); }

/* ── RESPONSIVE ── */
@media (max-width: 1024px) {
  .about-grid { grid-template-columns: 1fr; max-width: 600px; }
  .about-img-wrap { display: none; }
}

@media (max-width: 900px) {
  .hero-inner { grid-template-columns:1fr; }
  .hero-image-wrap { display:none; }
  .hero p { max-width:100%; }
  .immo-door-container { display: none; }
}

@media (max-width: 760px) {
  .nav-links { display:none; flex-direction:column; position:fixed; top:68px; left:0; right:0; background:var(--bg); border-bottom:1px solid var(--border); padding:1.5rem 2rem; gap:1.2rem; box-shadow:var(--shadow-lg); }
  .nav-links.open { display:flex; }
  .burger { display:flex; }
  .pricing-card.featured { transform:scale(1); }
  .pricing-card.featured:hover { transform:translateY(-4px); }
  .hero-stats { gap:2rem; }
  .contact-grid { grid-template-columns:1fr; gap:2.5rem; }
  .gallery-grid { grid-template-columns:1fr 1fr; grid-template-rows:200px 200px 200px; }
  .gallery-item:first-child { grid-column:1/-1; grid-row:auto; }
  .reviews-summary { flex-direction: column; gap: .5rem; }
  .about-values { grid-template-columns: 1fr; }
  .ki-input-row { flex-direction: column; }
  .hw-nav-links, .rest-nav-links, .kfz-nav-links { display: none; }
}

@media (max-width: 480px) {
  .form-row { grid-template-columns:1fr; }
  .btn-group { flex-direction:column; }
  .btn { justify-content:center; }
  section { padding:4rem 1.25rem; }
  .hero { padding:6rem 1.25rem 4rem; }
  #galerie { padding: 2rem 1.25rem; }
  .ki-scores-grid { grid-template-columns: repeat(3,1fr); }
}
