/* ====== Core Theme (Dark) ====== */
:root{
  --bg:#0b1020; --panel:rgba(255,255,255,.06); --muted:rgba(224,232,255,.72);
  --text:#f8fafc; --primary:#22d3ee; --accent:#a78bfa; --ok:#34d399; --line:rgba(255,255,255,.12);
  --shadow:0 20px 40px rgba(0,0,0,.35); --radius:22px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Outfit',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:
  radial-gradient(1000px 600px at 85% -10%, rgba(34,211,238,.18), transparent 60%),
  radial-gradient(900px 600px at -10% 30%, rgba(167,139,250,.18), transparent 60%),
  linear-gradient(180deg,#0a0f1e 0%, #0b1020 58%, #0b1020 100%);
  background-attachment:fixed; overflow-x:hidden}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
.container{width:min(1200px,92vw); margin:0 auto}
.small{font-size:13px}
.muted{color:var(--muted)}

/* Background FX */
.bgfx{position:fixed;inset:0;z-index:-2}
.noise{position:fixed;inset:0;z-index:-1;opacity:.06;pointer-events:none;background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="120" height="120" viewBox="0 0 120 120"><filter id="n"><feTurbulence type="fractalNoise" baseFrequency="0.9" numOctaves="2" stitchTiles="stitch"/></filter><rect width="120" height="120" filter="url(#n)" opacity="0.35"/></svg>');background-size:220px;animation:grain 6s steps(6) infinite}
@keyframes grain{to{transform:translate3d(0,0,0)}}

/* ===== Header ===== */
.site-header{position:sticky;top:0;z-index:50;background:linear-gradient(180deg,rgba(11,16,32,.9),rgba(11,16,32,.6));backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px;font-weight:800}
.brand-mark{width:36px;height:36px;border-radius:12px;background:conic-gradient(from 200deg,var(--primary),var(--accent));box-shadow:var(--shadow)}
.brand small{display:block;color:var(--muted);font-weight:500;font-size:12px;margin-top:-6px}
.menu-toggle{display:none}
.nav-links{display:flex;gap:8px;flex-wrap:wrap}
.nav-links a{padding:10px 14px;border-radius:14px;border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.03));transition:.2s}
.nav-links a:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.24)}
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:14px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#0b1020;font-weight:800;border:none;box-shadow:var(--shadow)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:14px;background:transparent;border:1px solid rgba(255,255,255,.18)}

/* ===== Hero ===== */
.hero{display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:center;padding:64px 0 32px}
.kicker{color:var(--primary);letter-spacing:.2em;font-size:13px;text-transform:uppercase;font-weight:700}
h1{font-size:clamp(32px,5vw,56px);line-height:1.02;margin:10px 0 16px}
.lead{color:var(--muted);font-size:clamp(16px,1.6vw,20px)}
.grad1,.grad2,.grad3{background-clip:text;-webkit-background-clip:text;color:transparent}
.grad1{background-image:linear-gradient(90deg,#7dd3fc,#60a5fa)}
.grad2{background-image:linear-gradient(90deg,#f472b6,var(--accent))}
.grad3{background-image:linear-gradient(90deg,#34d399,#22d3ee)}
.cta{margin-top:20px;display:flex;gap:12px;flex-wrap:wrap}
.pill-list{display:flex;gap:10px;flex-wrap:wrap;margin:16px 0 0}
.pill-list li{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:rgba(255,255,255,.06);padding:6px 12px;border-radius:9999px;font-size:14px}

/* ===== Sections & Cards ===== */
.section{padding:72px 0}
.section-title{font-size:clamp(24px,3.4vw,36px);margin:0 0 12px}
.grid{display:grid;gap:18px}
.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}
.card{background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.02));border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.badge{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:rgba(255,255,255,.06);padding:6px 10px;border-radius:999px;font-weight:700;margin-bottom:8px}
.clean{list-style:none;padding:0;margin:12px 0 0}
.clean li{display:flex;gap:10px;align-items:flex-start;margin:8px 0}
.featured{outline:2px solid rgba(34,211,238,.35)}

/* ===== Gallery ===== */
/* ===== Gallery ===== */
.gallery{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:12px;
  margin-top:12px;
  align-items:start;   /* NEU: Kacheln nicht mehr in der Höhe strecken */
}


/* ===== Steps ===== */
.steps{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}
.step{background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));border:1px solid var(--line);border-radius:18px;padding:14px}
.step span{display:inline-grid;place-items:center;width:32px;height:32px;border-radius:999px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#0b1020;font-weight:900;margin-bottom:8px}

/* ===== Kontakt ===== */
#kontakt .grid{gap:32px;align-items:stretch}
#kontakt form.card{display:flex;flex-direction:column;gap:16px;padding:24px}
#kontakt form.card label{font-weight:600;display:flex;flex-direction:column;gap:6px}
#kontakt input,#kontakt textarea{border:none;border-radius:12px;padding:10px 14px;background:rgba(255,255,255,.08);color:var(--text);font-size:15px;outline:none;transition:background .2s, box-shadow .2s}
#kontakt input:focus,#kontakt textarea:focus{background:rgba(255,255,255,.12);box-shadow:0 0 0 2px rgba(34,211,238,.4) inset}
#kontakt .contact-direct{padding:24px;display:flex;flex-direction:column;justify-content:center;gap:14px}
#kontakt .badge{align-self:flex-start}

/* ===== Footer ===== */
.site-footer{border-top:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.01));padding:32px 0 60px;margin-top:28px}
.foot{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:20px}
.linklike{background:none;border:none;padding:0;color:inherit;cursor:pointer}
.copyright{margin-top:24px;color:var(--muted);font-size:14px}

/* ===== Modal ===== */
.modal::backdrop{background:rgba(6,10,22,.65)}
.panel{width:min(900px,92vw);max-height:80vh;overflow:auto;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(255,255,255,.96));color:#0b1020;border-radius:18px;box-shadow:var(--shadow)}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid rgba(0,0,0,.08)}
.close{background:#0b1020;color:#fff;border:none;padding:8px 10px;border-radius:10px;cursor:pointer}
.agb{padding:14px 16px}

/* ===== Animations ===== */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s ease}
.reveal.in{opacity:1;transform:translateY(0)}
.btn-primary:hover,.btn-ghost:hover,.nav-links a:hover{transform:translateY(-2px);box-shadow:0 18px 36px rgba(0,0,0,.35)}

/* Accessibility */
.skip{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip:focus{left:12px;top:12px;width:auto;height:auto;background:#fff;color:#000;padding:10px;border-radius:8px;z-index:999}

/* ===== Responsive ===== */
@media (max-width: 1020px){
  .hero{grid-template-columns:1fr}
}
@media (max-width: 900px){
  .gallery .tile{grid-column:span 6}
  .gallery .tile.large{grid-column:span 12}
  .grid.two{grid-template-columns:1fr}
  .grid.three{grid-template-columns:1fr}
  .foot{grid-template-columns:1fr}
  .menu-toggle{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:10px;border:1px solid var(--line);background:rgba(255,255,255,.06)}
  .nav-links{position:absolute;inset:56px 0 auto auto;right:4vw;background:rgba(11,16,32,.95);backdrop-filter:blur(8px);padding:10px;border-radius:14px;display:none;flex-direction:column}
  .nav-links.open{display:flex}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{transition:none !important; animation:none !important}
  html{scroll-behavior:auto}
}


/* ===== Logos ===== */
.brand-logo{width:36px;height:36px;border-radius:10px;box-shadow:var(--shadow);object-fit:contain;background:#0b1020}
.brand-wordmark{height:18px;display:block}
.brand{gap:12px}
@media (max-width:680px){
  .brand-wordmark{height:16px}
}


/* Ensure raster logos are visible on dark backgrounds */
.brand-logo, .brand-wordmark{
  image-rendering:auto;
  filter: brightness(0) invert(1) contrast(1.05);
  opacity: 0.98;
}
/* Size tweaks */
.brand-logo{width:36px;height:36px;border-radius:8px;background:transparent}
.brand-wordmark{height:20px}
@media (max-width:680px){ .brand-wordmark{height:18px} }


/* Header/Footer wordmark only */
.brand { align-items:center; }
.brand-wordmark{height:20px; filter:brightness(0) invert(1) contrast(1.05);}
@media (max-width:680px){ .brand-wordmark{height:18px} }


/* Step layout fix */
.steps{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}
.step{display:grid;grid-template-columns:auto 1fr;align-items:flex-start;gap:10px;padding:16px;border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));border:1px solid var(--line)}
.step h3{margin:0 0 4px;font-size:16px}
.step p{margin:0}
.step span{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:999px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#0b1020;font-weight:900}

/* Sections anchor offset (sticky header overlap fix) */
section{scroll-margin-top:84px}

/* Header button contrast */
.btn-primary{color:#091120}
.site-header .btn-primary{color:#0b1020; filter:none}

/* Logo tile (centered) */
.tile.logo{display:grid;place-items:center;background:radial-gradient(400px 200px at 50% 30%, rgba(255,255,255,.05), transparent 60%), var(--panel)}
.tile.logo img{height:28px;filter:brightness(0) invert(1)}

/* Pricing visual improvements */
.price-grid .card{position:relative;overflow:hidden}
.price-grid .card .price{display:flex;align-items:baseline;gap:6px;margin:12px 0 6px}
.price-grid .card .price strong{font-size:28px}
.price-grid .featured{box-shadow:0 30px 60px rgba(43,201,208,.15);outline:2px solid rgba(34,211,238,.35)}
.price-grid .card::after{content:'';position:absolute;inset:auto -20% -40% -20%;height:120px;background:linear-gradient(90deg,rgba(34,211,238,.15),rgba(167,139,250,.15));filter:blur(30px)}


/* ===== Gallery / Tiles (fix) ===== */

/* Kachel: Rahmen ohne feste Höhe – passt sich dem Bild an */
.tile{
  grid-column: span 4;
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--line);
  background: var(--panel);
  padding: 0;      /* wichtig: kein Innenabstand */
  height: auto;    /* wichtig: Höhe kommt vom Bild */
  display: block;  /* kein Flex/Grid, nichts streckt das Bild */
}

/* Große Kachel – ebenfalls ohne feste Höhe */
.tile.large{
  grid-column: span 8;
  height: auto;
}

/* Bild steuert die Höhe der Kachel, nichts wird beschnitten */
.tile img{
  display: block;         /* entfernt Zeilenabstand */
  width: 100%;
  height: auto;
  object-fit: contain;    /* komplett sichtbar */
  filter: saturate(105%);
  opacity: .92;
  transition: transform .2s, opacity .2s;
}

/* Optionaler Hover bleibt erhalten */
.tile:hover img{
  transform: scale(1.04);
  opacity: 1;
}

/* Labels/Badges dürfen die Kachelhöhe nicht vergrößern */
.tile .cap{
  position: absolute;
  left: 12px;
  bottom: 12px;
}

/* Standardabstände entfernen, falls figure/figcaption benutzt wird */
figure.tile, .tile figure, .tile figcaption{ margin: 0; }

/* ===== Responsive: nur Spaltenbreite anpassen, KEINE Höhen! ===== */
@media (max-width: 900px){
  .gallery .tile{ grid-column: span 6; }
  .gallery .tile.large{ grid-column: span 12; }
}


.gallery .tile{ align-self:start; }  /* optional, aber schadet nicht */
