:root{
  --bg:#0b0b0c; --fg:#f2f2f2; --muted:#a7a7ad;
  --line:rgba(255,255,255,.14);
  --card:#141417;
  --max:1100px;
  --radius:16px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial;
  background:var(--bg); color:var(--fg);
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
/* Keyboard focus (only when tabbing) */
a:focus-visible,
button:focus-visible{
  outline: 2px solid rgba(255,255,255,.55);
  outline-offset: 3px;
  border-radius: 10px;
}
.wrap{width:min(var(--max),100%);margin:0 auto;padding:0 20px}

/* Header */
header{
  position:sticky;top:0;z-index:10;
  background:rgba(11,11,12,.78);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}
.headerbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand img{
  height: 70px;      /* Desktop-Lesbarkeit */
  width: auto;
  display:block;
}

@media (max-width: 900px){
  .brand img{ height: 38px; }
}
@media (max-width: 560px){
  .brand img{ height: 32px; }
}
.brand .name{font-weight:750;letter-spacing:.02em}
.brand .sub{color:var(--muted);font-size:13px;margin-left:2px}
nav{display:flex;gap:14px;font-size:14px;color:var(--muted);flex-wrap:wrap;justify-content:flex-end}
nav a:hover{color:var(--fg)}

/* Active nav + accessibility */
nav a[aria-current="page"]{
  color: var(--fg);
  position: relative;
}
nav a[aria-current="page"]::after{
  content:"";
  position:absolute;
  left:0; right:0;
  bottom:-6px;
  height:1px;
  background: rgba(255,255,255,.55);
}


/* Sections */
.section{padding:34px 0}
.h1{font-size:clamp(30px,4.6vw,52px);letter-spacing:-0.03em;margin:0}
.lead{color:var(--muted);line-height:1.6;max-width:70ch;margin-top:10px}
.kicker{color:var(--muted);font-size:14px;letter-spacing:.08em;margin:0 0 12px}

/* Lists */
.list{display:grid;gap:10px;margin-top:18px}
.item{
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:14px;
  background:rgba(255,255,255,.04);
  display:flex;align-items:baseline;justify-content:space-between;gap:12px;
  transition: border-color .18s ease, transform .18s ease, background .18s ease;

}
.item:hover{
  border-color: rgba(255,255,255,.28);
  background: rgba(255,255,255,.05);
  transform: translateY(-1px);
}

.item .title{font-weight:650}
.item .meta{color:var(--muted);font-size:13px}

/* Prev/Next */
.pn{
  display:flex;
  justify-content:space-between;
  gap:12px;
  margin-top: 22px;
  color: var(--muted);
  font-size: 14px;
}

.pn a,
.pn span{
  display:inline-flex;
  align-items:center;
  padding: 8px 12px;
  border-radius: 999px;
}

.pn a{
  color: var(--muted);
  transition: color .18s ease, background .18s ease, transform .18s ease;
}

.pn a:hover{
  color: var(--fg);
  background: rgba(255,255,255,.06);
  transform: translateY(-1px);
}

.pn a:focus-visible{
  background: rgba(255,255,255,.08);
}
/* Project page */
.projectTop{
  display:grid;grid-template-columns: 1.6fr 1fr;
  gap:18px;align-items:start
}
.video{
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--card);
  aspect-ratio:16/9;
}
.video iframe{width:100%;height:100%;border:0}
.info{
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:16px;
  background:rgba(255,255,255,.03);
}
.info h2{margin:0 0 8px;font-size:20px}
.info .line{color:var(--muted);line-height:1.55}
.back{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin: 2px 0 16px;
  padding: 6px 10px;
  color: var(--muted);
  font-size: 14px;
  border-radius: 999px;
  transition: color .18s ease, background .18s ease, transform .18s ease;
}
.back:hover{
  color: var(--fg);
  background: rgba(255,255,255,.06);
  transform: translateY(-1px);
}
.back:focus-visible{
  background: rgba(255,255,255,.08);
}
/* Stills: erst Platzhalter (damit nix kaputt aussieht), später echte Bilder */
.stills{
  margin-top:18px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  align-items:start; /* <-- DAS ist die wichtige Zeile */
}
.stillPh{
  border-radius:14px; overflow:hidden; border:1px solid var(--line);
  background:
    radial-gradient(600px 220px at 20% 30%, rgba(255,255,255,.14), transparent 55%),
    linear-gradient(135deg, rgba(255,255,255,.10), rgba(255,255,255,0));
  aspect-ratio:16/10;
}

/* Wenn du echte Stills nutzt: <a><img></a> */
.stills a{
  border-radius: 0;          /* eckig wie Caleb */
  overflow: hidden;
  border: 0;                 /* kein Rahmen */
  display:block;
}
.stills img{width:100%;height:auto;display:block}

@media (max-width:900px){
  .projectTop{grid-template-columns:1fr}
  .stills{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:560px){
  .stills{grid-template-columns:1fr}
}

/* Footer */
footer{border-top:1px solid var(--line);padding:18px 0;color:var(--muted);font-size:14px}


.contactLink{
  color: var(--fg);
  text-decoration: none;
}
.contactLink:hover{
  color: #ffffff;
  opacity: .9;
}


.featureCard{
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  background:rgba(255,255,255,.04);
  display:block;
  transition: border-color .18s ease, transform .18s ease;
  will-change: transform;
}
.featureThumb{
  display:block;
  width:100%;
  aspect-ratio: 7 / 1;
  background-size: cover;
  background-position: center;
  transform: scale(1);
  transition: transform .25s ease;
  will-change: transform;
}
.featureMeta{
  padding:10px;
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:12px;
}
.featureMeta .title{font-weight:650}
.featureMeta .meta{color:var(--muted);font-size:13px}
.featureCard:hover{
  border-color: rgba(255,255,255,.28);
  transform: translateY(-1px);
}
.featureCard:hover .featureThumb{
  transform: scale(1.015);
}

/* ===== Lightbox (Caleb-style) ===== */
.lb{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.82);
  display:none;
  z-index:9999;
}
.lb.open{ display:block; }

.lb-inner{
  position:absolute;
  inset:18px;
  display:grid;
  place-items:center;
}

.lb-img{
  max-width: min(1200px, 96vw);
  max-height: 90vh;
  width:auto;
  height:auto;
  display:block;
  box-shadow: 0 30px 120px rgba(0,0,0,.6);
}

.lb-btn{
  position:absolute;
  top:18px;
  padding:10px 12px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.06);
  color:var(--fg);
  cursor:pointer;
  user-select:none;
  font-size:14px;
}
.lb-close{ right:18px; }

.lb-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:48px;
  height:72px;
  display:grid;
  place-items:center;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.06);
  cursor:pointer;
  user-select:none;
  font-size:22px;
}
.lb-prev{ left:18px; }
.lb-next{ right:18px; }

.lb-count{
  position:absolute;
  bottom:18px;
  color:rgba(255,255,255,.75);
  font-size:13px;
}

/* ===== Contact page polish ===== */
.contactGrid{
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

@media (max-width: 760px){
  .contactGrid{ grid-template-columns: 1fr; }
}

.contactCard{
  position: relative;
  display:block;
  padding: 18px;
  background:
    radial-gradient(600px 220px at 20% 20%, rgba(255,255,255,.10), transparent 55%),
    rgba(255,255,255,.035);
  border-color: rgba(255,255,255,.12);
}

.contactCard:hover{
  border-color: rgba(255,255,255,.26);
  background:
    radial-gradient(600px 220px at 20% 20%, rgba(255,255,255,.12), transparent 55%),
    rgba(255,255,255,.045);
  transform: translateY(-1px);
}

.contactCard .title{
  letter-spacing: .08em;
  font-size: 12px;
  text-transform: uppercase;
  color: rgba(255,255,255,.78);
  margin-bottom: 10px;
}

.contactMeta{
  margin-top: 6px;
  line-height: 1.65;
}

.contactLink{
  display:inline-block;
  color: var(--fg);
  font-weight: 650;
  margin-bottom: 2px;
}
.contactLink:hover{
  opacity: .9;
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* Links/Social area */
.contactLinks{
  margin-top: 22px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.10);
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

@media (max-width: 760px){
  .contactLinks{ grid-template-columns: 1fr; }
}

.contactLinksTitle{
  color: rgba(255,255,255,.78);
  font-weight: 650;
  margin-bottom: 10px;
}

.contactLinksCol a{
  display:block;
  color: var(--muted);
  padding: 6px 0;
}
.contactLinksCol a:hover{
  color: var(--fg);
}

/* Agency logo in contact cards */
.agencyLogo{
  position: absolute;
  top: 20px;
  right: 14px;

  height: 34px;        /* vorher 22px */
  max-width: 160px;    /* neu: verhindert "zu breit" */
  width: auto;

  opacity: .72;        /* leicht stärker */
  filter: grayscale(1);
  transition: opacity .18s ease, transform .18s ease, filter .18s ease;
  pointer-events: none;
}


.contactCard:hover .agencyLogo{
  opacity: .9;
  filter: grayscale(0);
  transform: translateY(-1px);
}

@media (max-width: 760px){
  .agencyLogo{
    height: 28px;      /* vorher 20px */
    top: 12px;
    right: 12px;
  }
}

.agencyLogo.wpa{
  height: 100px;
  max-width: 190px;
  opacity: .8;
  filter: grayscale(0.2); /* optional: weniger grau */
}
@media (max-width: 760px){
  .agencyLogo.wpa{ height: 50px; }
}

