/* =========================================================
   Kitzerow Keramik — astro2 — Dark Luxury
   Barrierefreiheit: WCAG 2.2 AA
   ========================================================= */

:root {
  --bg-0: #0a0a0b;
  --bg-1: #0f0f11;
  --bg-2: #15161a;
  --bg-3: #1c1d22;
  --line: rgba(255,255,255,0.10);
  --line-strong: rgba(255,255,255,0.22);

  --ink-0: #f5f1ea;       /* off-white, ~18.5:1 auf bg-0 */
  --ink-1: #dcd6c9;       /* ~14:1 auf bg-0 */
  --ink-2: #aca598;       /* ~8.5:1 auf bg-0 — AA Large+Body ok */
  --ink-3: #7d776d;

  --gold: #d4b276;        /* ~9:1 auf bg-0, ~8:1 auf bg-1 — AA ok für body */
  --gold-soft: #ead9b4;
  --gold-ink: #2a1e09;

  --focus: #ffd27a;       /* sehr hell — klar sichtbar als Fokusring */

  --serif: "Cormorant Garamond", "Playfair Display", Georgia, serif;
  --sans:  "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  --maxw: 1360px;
  --pad: clamp(1.25rem, 4vw, 3rem);
  --ease: cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth; scroll-padding-top: 88px}
html,body{margin:0;padding:0}
body{
  font-family: var(--sans);
  font-weight: 300;
  color: var(--ink-1);
  background: var(--bg-0);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:color .3s var(--ease)}
a:hover{color:var(--gold-soft)}

/* Globale Fokus-Sichtbarkeit (WCAG 2.4.7, 2.4.11) */
*:focus{outline:none}
*:focus-visible{
  outline: 3px solid var(--focus);
  outline-offset: 3px;
  border-radius: 2px;
}
a:focus-visible, button:focus-visible{
  outline-offset: 4px;
}

/* Skip link (WCAG 2.4.1) */
.skip-link{
  position: absolute;
  top: -100px; left: 12px;
  background: var(--gold);
  color: var(--gold-ink);
  padding: .85rem 1.25rem;
  font-weight: 500;
  font-size: .9rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  z-index: 1000;
  transition: top .2s ease;
  border-radius: 2px;
}
.skip-link:focus{top: 12px}

h1,h2,h3,h4{
  font-family: var(--serif);
  font-weight: 300;
  color: var(--ink-0);
  letter-spacing: -0.01em;
  line-height: 1.15;
  margin: 0 0 0.4em;
}
h1{font-size: clamp(2.6rem, 6.5vw, 5.6rem)}
h2{font-size: clamp(2rem, 4.2vw, 3.6rem)}
h3{font-size: 1.25rem; font-family: var(--sans); font-weight: 500; letter-spacing: .02em; color: var(--ink-0)}
h4{font-size: .85rem; font-family: var(--sans); text-transform: uppercase; letter-spacing: .18em; color: var(--gold); font-weight: 500}
.serif-italic{font-style:italic; color: var(--gold-soft)}

p{margin:0 0 1em}
.lede{font-size: clamp(1.05rem, 1.2vw, 1.2rem); color: var(--ink-1); max-width: 60ch}
.lede--center{margin-inline:auto;text-align:center}

/* Eyebrow */
.eyebrow{
  font-family: var(--sans);
  text-transform: uppercase;
  letter-spacing: .28em;
  font-size: .72rem;
  color: var(--ink-2);
  margin: 0 0 1.5rem;
}
.eyebrow--gold{color: var(--gold)}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:.6rem;
  padding: .95rem 1.6rem;
  font-family: var(--sans);
  font-size: .85rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all .4s var(--ease);
  background: none;
  color: var(--ink-0);
  border-radius: 0;
  font-weight: 500;
}
.btn--primary{
  background: linear-gradient(180deg, var(--gold-soft), var(--gold));
  color: var(--gold-ink);
  border-color: var(--gold);
  box-shadow: 0 10px 30px -10px rgba(212,178,118,.35);
}
.btn--primary:hover{
  background: var(--ink-0);
  color: var(--gold-ink);
  transform: translateY(-1px);
  box-shadow: 0 18px 40px -12px rgba(245,241,234,.3);
}
.btn--primary[disabled]{opacity:.55;cursor:not-allowed}
.btn--ghost{border-color: var(--line-strong); color: var(--ink-0)}
.btn--ghost:hover{border-color: var(--gold); color: var(--gold-soft)}
.btn--link{
  padding: .5rem 0;
  border-bottom: 1px solid var(--line-strong);
  letter-spacing: .18em;
  color: var(--ink-0);
}
.btn--link:hover{border-color: var(--gold); color: var(--gold-soft)}
.btn--wide{width:100%; justify-content:center}

.cta-row{display:flex; flex-wrap:wrap; gap:1.25rem; margin-top: 2rem; align-items:center}

/* =========================================================
   NAV
========================================================= */
.nav{
  position: fixed; inset: 0 0 auto 0;
  z-index: 100;
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  background: rgba(10,10,11,0.65);
  border-bottom: 1px solid var(--line);
}
.nav__inner{
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 1.1rem var(--pad);
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 2rem;
}
.nav__logo{display:flex; align-items:center; gap:.8rem}
.nav__logo-mark{
  width: 38px; height: 38px;
  display:grid; place-items:center;
  border: 1px solid var(--gold);
  color: var(--gold);
  font-family: var(--serif);
  font-size: 1.3rem;
  font-style: italic;
  flex-shrink:0;
}
.nav__logo-text{
  display:flex; flex-direction:column; line-height:1.1;
  font-family: var(--serif);
  font-size: 1.05rem;
  color: var(--ink-0);
  letter-spacing: .02em;
}
.nav__logo-text small{
  font-family: var(--sans);
  font-size: .6rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--ink-2);
  margin-top: 2px;
  font-weight: 400;
}
.nav__menu{display:flex; gap:1.8rem; justify-content:center; flex-wrap: wrap}
.nav__menu a{
  font-size: .78rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--ink-1);
  position: relative;
  padding: .4rem 0;
}
.nav__menu a::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px;
  height:1px; background: var(--gold);
  transform: scaleX(0); transform-origin: left;
  transition: transform .4s var(--ease);
}
.nav__menu a:hover::after, .nav__menu a:focus-visible::after{transform: scaleX(1)}
.nav__cta{font-size:.72rem; white-space: nowrap}

@media (max-width: 1100px){
  .nav__menu{display:none}
  .nav__inner{grid-template-columns: auto 1fr auto}
}

/* =========================================================
   HERO
========================================================= */
.hero{
  position: relative;
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  align-items: flex-end;
  padding: 9rem var(--pad) 6rem;
  overflow: hidden;
  isolation: isolate;
}
.hero__media{position:absolute; inset:0; z-index:-1}
.hero__img{
  width:100%; height:100%; object-fit: cover;
  filter: saturate(.95) brightness(.55) contrast(1.05);
  transform: scale(1.05);
  animation: heroZoom 20s ease-out forwards;
}
@keyframes heroZoom{to{transform:scale(1.12)}}
.hero__veil{
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 30% 40%, rgba(0,0,0,0) 0%, rgba(0,0,0,.55) 70%),
    linear-gradient(180deg, rgba(10,10,11,.65) 0%, rgba(10,10,11,.15) 30%, rgba(10,10,11,.85) 80%, var(--bg-0) 100%);
}
.hero__grain{
  position:absolute; inset:0;
  opacity:.10; pointer-events:none; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}
.hero__content{
  position: relative;
  max-width: var(--maxw);
  width: 100%;
  margin: 0 auto;
}
.hero__title{margin-bottom: 1.5rem; font-weight: 300}
.hero__title em{color: var(--gold-soft); font-style: italic}
.hero__lede{
  font-size: clamp(1.05rem, 1.3vw, 1.25rem);
  max-width: 58ch;
  color: var(--ink-0);
  margin-bottom: 2.5rem;
}
.hero__ctas{display:flex; gap:1.5rem; flex-wrap:wrap; align-items:center; margin-bottom: 4rem}
.hero__meta{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--line);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  max-width: 720px;
  margin: 0;
}
.hero__meta > div{
  background: rgba(10,10,11,.65);
  padding: 1rem 1.25rem;
  backdrop-filter: blur(4px);
}
.hero__meta dt{
  font-size: .65rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-2);
  margin-bottom: .3rem;
}
.hero__meta dd{
  margin:0;
  font-family: var(--serif);
  font-size: 1.35rem;
  color: var(--ink-0);
}
@media(max-width: 680px){.hero__meta{grid-template-columns: repeat(2, 1fr)}}

.hero__scroll{
  position: absolute;
  right: var(--pad);
  bottom: 2rem;
  width: 2px; height: 60px;
  background: var(--line-strong);
  overflow: hidden;
}
.hero__scroll span{
  position:absolute; inset:0;
  background: var(--gold);
  transform: translateY(-100%);
  animation: scrollLine 2.4s infinite var(--ease);
}
@keyframes scrollLine{
  0%{transform:translateY(-100%)}
  50%{transform:translateY(0)}
  100%{transform:translateY(100%)}
}

/* =========================================================
   TRUST STRIP
========================================================= */
.trust{
  background: var(--bg-1);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 3.5rem var(--pad);
}
.trust__inner{
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 3rem;
  align-items: center;
}
.trust__lead{
  font-family: var(--serif);
  font-size: clamp(1.1rem, 1.4vw, 1.45rem);
  font-style: italic;
  color: var(--ink-0);
  max-width: 40ch;
  margin: 0;
}
.trust__list{
  list-style: none; padding:0; margin:0;
  display: grid;
  grid-template-columns: repeat(4, auto);
  gap: 3rem;
}
.trust__list li{display:flex; flex-direction:column; gap:.25rem}
.trust__list strong{
  font-family: var(--serif);
  font-size: 2rem;
  color: var(--gold);
  font-weight: 400;
  line-height: 1;
}
.trust__list span{
  font-size: .7rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink-2);
}
@media(max-width: 900px){
  .trust__inner{grid-template-columns: 1fr}
  .trust__list{grid-template-columns: repeat(2, 1fr); gap:1.5rem}
}

/* =========================================================
   SECTIONS
========================================================= */
.section{
  padding: clamp(5rem, 10vw, 9rem) var(--pad);
  position: relative;
}
.section--dark{background: var(--bg-1)}
.section--graphite{
  background: linear-gradient(180deg, var(--bg-1), var(--bg-2));
  position: relative;
}
.section--graphite::before{
  content:""; position:absolute; inset:0;
  background: radial-gradient(ellipse at 80% 10%, rgba(212,178,118,.06), transparent 60%);
  pointer-events: none;
}
.section__inner{max-width: var(--maxw); margin: 0 auto; position: relative}
.section__header{text-align:center; margin-bottom: 4rem}
.section__header h2{max-width: 22ch; margin-inline:auto}

/* Split */
.split{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2.5rem, 6vw, 6rem);
  align-items: center;
}
.split--reverse .split__text{order: 2}
.split--reverse .split__media{order: 1}
@media (max-width: 900px){
  .split{grid-template-columns: 1fr}
  .split--reverse .split__text, .split--reverse .split__media{order: initial}
}

.stack-frame{
  position: relative;
  overflow: hidden;
  aspect-ratio: 4/5;
  border: 1px solid var(--line-strong);
  box-shadow: 0 40px 80px -30px rgba(0,0,0,.7);
  margin: 0;
}
.stack-frame img{
  width:100%; height:100%; object-fit:cover;
  transition: transform 1.2s var(--ease);
  filter: saturate(.95) brightness(.95);
}
.stack-frame:hover img{transform: scale(1.04)}
.stack-frame--offset{
  margin-top: -4rem;
  margin-left: 4rem;
  aspect-ratio: 1/1;
  max-width: 60%;
}
@media(max-width: 900px){
  .stack-frame--offset{margin-left:2rem; margin-top:-2rem}
}

/* Hours */
.hours{
  margin: 2rem 0;
  padding: 1.5rem 1.75rem;
  border: 1px solid var(--line-strong);
  background: rgba(0,0,0,.3);
  display: grid;
  gap: .5rem;
  font-family: var(--sans);
  font-size: .95rem;
}
.hours > div{display:flex; justify-content:space-between; gap:2rem; color:var(--ink-1)}
.hours strong{color:var(--gold); font-weight: 500; letter-spacing: .12em; text-transform:uppercase; font-size:.72rem}
.hours__note{
  display:block !important;
  padding-top: .75rem;
  border-top: 1px solid var(--line);
  font-style: italic;
  color: var(--ink-2);
  font-size: .85rem;
  justify-content: flex-start !important;
}

/* Grids */
.grid{display:grid; gap: 1.5rem}
.grid--collections{grid-template-columns: repeat(3, 1fr)}
.grid--etagen{grid-template-columns: repeat(4, 1fr)}
.grid--trio{grid-template-columns: repeat(3, 1fr); margin-bottom: 3rem}
.grid--refs{grid-template-columns: repeat(3, 1fr)}
@media(max-width: 1100px){
  .grid--etagen{grid-template-columns: repeat(2, 1fr)}
  .grid--refs{grid-template-columns: repeat(2, 1fr)}
}
@media(max-width: 960px){.grid--collections, .grid--trio{grid-template-columns: repeat(2, 1fr)}}
@media(max-width: 620px){
  .grid--collections, .grid--trio, .grid--etagen, .grid--refs{grid-template-columns: 1fr}
}

/* Card */
.card{
  background: var(--bg-2);
  border: 1px solid var(--line);
  overflow: hidden;
  transition: all .5s var(--ease);
  position: relative;
  display:flex; flex-direction: column;
}
.card:hover{
  border-color: var(--gold);
  transform: translateY(-4px);
  box-shadow: 0 30px 60px -30px rgba(0,0,0,.8);
}
.card__media{aspect-ratio: 4/3; overflow: hidden; position: relative}
.card__media::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, transparent 55%, rgba(0,0,0,.55));
  pointer-events: none;
}
.card__media img{
  width:100%; height:100%; object-fit:cover;
  transition: transform 1.2s var(--ease);
  filter: saturate(.95) brightness(.95);
}
.card:hover .card__media img{transform: scale(1.06); filter:saturate(1.05) brightness(1)}
.card__body{padding: 1.75rem; flex: 1}
.card__body h3{margin-bottom: .6rem; color: var(--ink-0)}
.card__body p{color: var(--ink-2); font-size: .95rem; margin:0}

.card--floor .card__num{
  display:block;
  font-family: var(--serif);
  font-style: italic;
  color: var(--gold);
  font-size: .95rem;
  letter-spacing: .1em;
  margin-bottom: .4rem;
}

/* Service card */
.service-card{
  padding: 2.5rem 2rem;
  border: 1px solid var(--line);
  background: var(--bg-2);
  text-align: center;
  transition: border-color .4s var(--ease);
}
.service-card:hover{border-color: var(--gold)}
.service-card__icon{
  display:inline-grid; place-items:center;
  width: 60px; height: 60px;
  border: 1px solid var(--gold);
  color: var(--gold);
  margin-bottom: 1.5rem;
  border-radius: 50%;
}
.service-card h3{margin-bottom: 1rem}
.service-card p{color: var(--ink-2); font-size: .95rem; margin:0; line-height:1.7}

/* Ref card */
.ref-card{
  padding: 2rem 2rem 2.25rem;
  border: 1px solid var(--line);
  background: rgba(0,0,0,.25);
  transition: all .4s var(--ease);
}
.ref-card:hover{border-color: var(--gold); background: rgba(0,0,0,.4)}
.ref-card h3{
  margin-bottom: 1.5rem;
  padding-bottom: .75rem;
  border-bottom: 1px solid var(--line);
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.35rem;
  color: var(--gold-soft);
  font-style: italic;
  letter-spacing: 0;
  text-transform: none;
}
.ref-card ul{list-style: none; padding:0; margin:0; display:grid; gap:.65rem}
.ref-card li{
  font-size: .92rem;
  color: var(--ink-1);
  line-height: 1.4;
  padding-left: 1rem;
  position: relative;
}
.ref-card li::before{
  content: ""; position: absolute;
  left: 0; top: .55em;
  width: 6px; height: 1px;
  background: var(--gold);
}
.ref-card strong{color: var(--ink-0); font-weight: 500}

/* Team grid */
.team-grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 1rem;
  margin-bottom: 3rem;
}
.team-card{
  padding: 1.75rem 1.5rem;
  border: 1px solid var(--line);
  background: var(--bg-2);
  transition: all .4s var(--ease);
  display:flex; flex-direction: column; gap: .35rem;
}
.team-card:hover{border-color: var(--gold); transform: translateY(-3px)}
.team-card--lead{
  border-color: var(--gold);
  background: linear-gradient(180deg, rgba(212,178,118,.08), transparent 80%), var(--bg-2);
}
.team-card__initials{
  width: 48px; height: 48px;
  display: grid; place-items: center;
  border: 1px solid var(--gold);
  color: var(--gold);
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.05rem;
  margin-bottom: .9rem;
  border-radius: 50%;
}
.team-card h3{
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.2rem;
  color: var(--ink-0);
  margin: 0;
  letter-spacing: 0;
}
.team-card__role{
  font-size: .8rem;
  letter-spacing: .1em;
  color: var(--gold);
  text-transform: uppercase;
  margin: 0;
  font-weight: 500;
}
.team-card__mail{
  font-size: .85rem;
  margin: 0;
  color: var(--ink-2);
  word-break: break-all;
}
.team-card__mail a{color: var(--ink-1); border-bottom: 1px dotted var(--line-strong)}
.team-card__mail a:hover{color: var(--gold-soft); border-color: var(--gold)}

/* Benefits list */
.benefits{
  list-style:none; padding:0; margin: 2rem 0;
  display: grid; gap: 1rem;
}
.benefits li{
  display:flex; align-items:flex-start; gap:1.25rem;
  padding: 1rem 0;
  border-top: 1px solid var(--line);
  color: var(--ink-1);
  font-size: 1rem;
}
.benefits li:last-child{border-bottom: 1px solid var(--line)}
.benefits li span{
  flex-shrink: 0;
  color: var(--gold);
  font-family: var(--serif);
  font-style: italic;
  font-size: 1rem;
  letter-spacing: .05em;
  width: 2.5rem;
}

/* Deep / Accordion (<details>) */
.deep{
  margin-top: 3rem;
  border: 1px solid var(--line-strong);
  background: rgba(0,0,0,.25);
}
.deep > summary{
  list-style: none;
  cursor: pointer;
  padding: 1.4rem 1.75rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  font-family: var(--sans);
  font-size: .85rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-0);
  font-weight: 500;
  transition: background .3s var(--ease);
}
.deep > summary:hover{background: rgba(212,178,118,.05)}
.deep > summary::-webkit-details-marker{display:none}
.deep > summary::marker{display:none; content:""}
.deep__chev{transition: transform .4s var(--ease); color: var(--gold); flex-shrink:0}
.deep[open] > summary .deep__chev{transform: rotate(180deg)}
.deep__body{
  padding: 0 1.75rem 1.75rem;
  border-top: 1px solid var(--line);
  padding-top: 1.5rem;
}
.deep__body--partners{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 1.5rem;
}
.deep__body--partners h4{margin-bottom: .35rem}
.deep__body--partners p{color: var(--ink-1); font-size: .92rem; margin: 0; line-height: 1.5}
.brand-list{
  list-style: none; padding: 0; margin: 0 0 1.5rem;
  display: flex; flex-wrap: wrap; gap: .6rem;
}
.brand-list li{
  padding: .5rem 1rem;
  border: 1px solid var(--line-strong);
  font-family: var(--serif);
  font-size: 1.05rem;
  color: var(--ink-1);
  font-style: italic;
  letter-spacing: .02em;
}
.brand-list--team li{font-style: normal; font-family: var(--sans); font-size: .85rem; letter-spacing: .1em}
.deep__note{
  color: var(--ink-2);
  font-style: italic;
  font-size: .92rem;
  margin: 0;
}

/* Pull-Quote */
.pull-quote{
  margin: 2.5rem 0 0;
  padding: 2rem 0 2rem 2rem;
  border-left: 2px solid var(--gold);
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.2rem;
  color: var(--ink-0);
  line-height: 1.55;
}
.pull-quote cite{
  display: block;
  margin-top: 1.25rem;
  font-family: var(--sans);
  font-style: normal;
  font-size: .75rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink-2);
}

/* Address card */
.address-card{
  margin-top: 3rem;
  padding: 2rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  text-align: left;
  border: 1px solid var(--line-strong);
  background: rgba(0,0,0,.35);
  font-size: .95rem;
  color: var(--ink-1);
}
.address-card strong{
  display: inline-block;
  color: var(--gold);
  font-weight: 500;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: .7rem;
  margin-bottom: .25rem;
}
.address-card a{color: var(--ink-0); border-bottom: 1px dotted var(--line-strong)}
.address-card a:hover{color: var(--gold-soft); border-color: var(--gold)}
@media(max-width: 760px){.address-card{grid-template-columns: 1fr; gap: 1.25rem}}

/* Final/Form */
.final{
  background:
    radial-gradient(ellipse at 50% 0%, rgba(212,178,118,.08), transparent 60%),
    var(--bg-1);
  border-top: 1px solid var(--line);
}
.final__inner{max-width: 760px; margin: 0 auto; text-align:center}
.final__inner h2{margin-bottom:1rem}
.form{margin-top: 3rem; text-align: left; display: grid; gap: 1.5rem}
.form__row{display:grid; grid-template-columns: 1fr 1fr; gap: 1.5rem}
@media(max-width:640px){.form__row{grid-template-columns: 1fr}}
.form label{
  display:flex; flex-direction:column; gap:.5rem;
  font-size: .72rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-2);
  font-weight: 500;
}
.form input, .form select, .form textarea{
  font-family: var(--sans);
  font-size: 1rem;
  font-weight: 300;
  color: var(--ink-0);
  background: rgba(0,0,0,.35);
  border: 1px solid var(--line-strong);
  padding: 1rem 1.1rem;
  border-radius: 0;
  outline: none;
  letter-spacing: 0;
  text-transform: none;
  transition: border-color .3s var(--ease), background .3s var(--ease);
}
.form input:focus-visible, .form select:focus-visible, .form textarea:focus-visible{
  border-color: var(--gold);
  background: rgba(0,0,0,.5);
  outline: 3px solid var(--focus);
  outline-offset: 0;
}
.form textarea{resize:vertical; min-height: 140px}
.form__note{
  font-size: .82rem;
  color: var(--ink-2);
  text-align:center;
  margin: 0;
  font-style: italic;
}
.form__note a{color: var(--gold-soft); border-bottom: 1px solid var(--line-strong)}

/* Footer */
.footer{
  background: #050506;
  border-top: 1px solid var(--line);
  padding: 3rem var(--pad) 2rem;
}
.footer__inner{
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 2.5rem;
  align-items: center;
}
.footer__brand{display:flex; align-items:center; gap:1rem; color: var(--ink-1)}
.footer__brand small{color: var(--ink-2); font-size: .75rem; letter-spacing: .1em}
.footer__nav{display:flex; gap:1.5rem; justify-content:center; flex-wrap:wrap}
.footer__nav a{
  font-size: .72rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.footer__nav a:hover{color: var(--gold-soft)}
.footer__legal{
  display:flex; gap:1.5rem; align-items:center; justify-content:flex-end;
  font-size: .72rem;
  letter-spacing: .12em;
  color: var(--ink-2);
  flex-wrap: wrap;
}
.footer__legal a{color: var(--ink-1)}
.footer__legal a:hover{color: var(--gold-soft)}
@media(max-width: 900px){
  .footer__inner{grid-template-columns: 1fr; text-align:center; justify-items:center}
  .footer__legal{justify-content:center}
}

/* =========================================================
   SUBPAGES (team.html, sortiment/*.html)
========================================================= */
.subpage{padding-top: 76px}

/* Page-Hero */
.page-hero{
  padding: 6rem var(--pad) 3rem;
  background: linear-gradient(180deg, var(--bg-1), var(--bg-0));
  border-bottom: 1px solid var(--line);
  position: relative;
  isolation: isolate;
}
.page-hero--img{
  padding: 9rem var(--pad) 5rem;
  min-height: 60vh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}
.page-hero__media{
  position: absolute; inset:0; z-index: -1;
}
.page-hero__media img{
  width:100%; height:100%; object-fit:cover;
  filter: saturate(.95) brightness(.5) contrast(1.05);
}
.page-hero__veil{
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(10,10,11,.5) 0%, rgba(10,10,11,0) 30%, rgba(10,10,11,.85) 85%, var(--bg-0) 100%),
    radial-gradient(ellipse at 30% 50%, transparent, rgba(0,0,0,.5));
}
.page-hero__inner{
  max-width: var(--maxw);
  margin: 0 auto;
  width: 100%;
  position: relative;
}
.page-hero__title{
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(2.4rem, 5.5vw, 4.5rem);
  line-height: 1.1;
  color: var(--ink-0);
  margin: .5rem 0 0;
  letter-spacing: -0.01em;
}
.page-hero__lede{
  color: var(--ink-1);
  font-size: clamp(1.05rem, 1.2vw, 1.2rem);
  max-width: 60ch;
  margin-top: 1.5rem;
}

.breadcrumb{
  font-size: .72rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-2);
  margin-bottom: 2rem;
}
.breadcrumb a{color: var(--ink-2); border-bottom: 1px dotted var(--line-strong)}
.breadcrumb a:hover{color: var(--gold)}
.breadcrumb span[aria-current]{color: var(--gold)}

/* Team subpage — section headers */
.team-section{padding: 4rem var(--pad)}
.team-section__header{
  margin-bottom: 3rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid var(--line);
}
.team-section__header h2{
  font-size: clamp(1.6rem, 2.8vw, 2.2rem);
  color: var(--ink-0);
  margin-bottom: .5rem;
}
.team-section__lede{
  color: var(--ink-2);
  font-style: italic;
  font-family: var(--serif);
  font-size: 1.1rem;
  margin: 0;
}

.team-full{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.5rem;
}
.team-full-card{
  background: var(--bg-2);
  border: 1px solid var(--line);
  overflow: hidden;
  transition: all .4s var(--ease);
  scroll-margin-top: 100px;
}
.team-full-card:hover{border-color: var(--gold); transform: translateY(-3px)}
.team-full-card:target{
  border-color: var(--gold);
  box-shadow: 0 30px 60px -25px rgba(212,178,118,.35), 0 0 0 1px var(--gold);
}
.team-full-card img{
  width: 100%;
  aspect-ratio: 320/395;
  object-fit: cover;
  filter: saturate(.95);
}
.team-full-card__body{padding: 1.5rem 1.5rem 1.75rem}
.team-full-card h3{
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.4rem;
  color: var(--ink-0);
  margin: 0 0 .3rem;
  letter-spacing: 0;
}
.team-full-card .role{
  font-size: .72rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 1rem;
  font-weight: 500;
}
.team-full-card .contact{
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: .4rem;
  font-size: .92rem;
  border-top: 1px solid var(--line);
  padding-top: 1rem;
}
.team-full-card .contact a{
  color: var(--ink-1);
  border-bottom: 1px dotted var(--line-strong);
  word-break: break-all;
}
.team-full-card .contact a:hover{color: var(--gold-soft); border-color: var(--gold)}

/* Team preview (Startseite) */
.team-grid--preview{grid-template-columns: repeat(auto-fill, minmax(220px, 1fr))}
.team-grid--preview .team-card{
  padding: 0;
  overflow: hidden;
  display: block;
  cursor: pointer;
}
.team-card__photo{
  width: 100%;
  aspect-ratio: 320/395;
  object-fit: cover;
  filter: saturate(.95) brightness(.95);
  transition: transform 1s var(--ease), filter .4s var(--ease);
  margin-bottom: 1rem;
}
.team-grid--preview .team-card:hover .team-card__photo{
  transform: scale(1.04);
  filter: saturate(1) brightness(1);
}
.team-grid--preview .team-card h3{padding: 0 1.25rem; margin-bottom: .3rem}
.team-grid--preview .team-card .team-card__role{padding: 0 1.25rem 1.25rem}

.team-cta{
  margin-top: 3rem;
  text-align: center;
}
.team-cta__note{
  margin-top: 1rem;
  color: var(--ink-2);
  font-style: italic;
  font-family: var(--serif);
  font-size: 1.05rem;
}

/* Sortiment body */
.sortiment-body{
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 4rem;
  align-items: start;
}
@media (max-width: 900px){.sortiment-body{grid-template-columns: 1fr; gap: 2rem}}

.sortiment-article p{
  font-size: clamp(1.05rem, 1.15vw, 1.15rem);
  color: var(--ink-1);
  margin-bottom: 1.5rem;
  max-width: 62ch;
  line-height: 1.75;
}
.sortiment-article p em{
  font-family: var(--serif);
  font-style: italic;
  color: var(--gold-soft);
}
.sortiment-article a{color: var(--gold-soft); border-bottom: 1px solid var(--line-strong)}
.sortiment-article a:hover{border-color: var(--gold)}

.sortiment-aside{
  background: var(--bg-2);
  border: 1px solid var(--line-strong);
  padding: 2rem 1.75rem;
  position: sticky;
  top: 100px;
}
.aside-title{
  font-size: .75rem !important;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  font-family: var(--sans) !important;
  font-weight: 500 !important;
  margin: 0 0 1.5rem !important;
}
.facts{margin: 0 0 2rem}
.facts div{
  padding: 1rem 0;
  border-top: 1px solid var(--line);
}
.facts div:last-child{border-bottom: 1px solid var(--line)}
.facts dt{
  font-size: .7rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-2);
  margin-bottom: .35rem;
}
.facts dd{
  margin: 0;
  color: var(--ink-0);
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.05rem;
}
.aside-cta{display:grid; gap: .8rem}

/* Sortiment galerie */
.gallery{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.25rem;
}
.gallery__item{
  margin: 0;
  aspect-ratio: 4/3;
  overflow: hidden;
  border: 1px solid var(--line);
}
.gallery__item img{
  width: 100%; height: 100%; object-fit: cover;
  filter: saturate(.95) brightness(.9);
  transition: transform 1.2s var(--ease), filter .4s var(--ease);
}
.gallery__item:hover img{transform: scale(1.05); filter: saturate(1) brightness(1)}

/* Related categories */
.related-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 1rem;
}
.related-card{
  padding: 1.5rem 1.25rem;
  border: 1px solid var(--line-strong);
  background: rgba(0,0,0,.25);
  font-family: var(--serif);
  font-size: 1.15rem;
  color: var(--ink-1);
  text-align: center;
  transition: all .4s var(--ease);
}
.related-card:hover{
  border-color: var(--gold);
  color: var(--gold-soft);
  transform: translateY(-2px);
}
.related-card[aria-current="page"]{
  border-color: var(--gold);
  background: rgba(212,178,118,.08);
  color: var(--gold-soft);
}

/* Card-as-link (Sortiment-Karten mit href) */
.card--link{cursor: pointer; color: inherit}
.card--link:hover{color: inherit}
.card__more{
  display: inline-block;
  margin-top: 1rem;
  font-size: .72rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 500;
}

/* Reveal */
.reveal{opacity:0; transform: translateY(24px); transition: opacity 1s var(--ease), transform 1s var(--ease)}
.reveal.is-in{opacity:1; transform: translateY(0)}

/* =========================================================
   Barrierefreiheit: reduce motion & high contrast
========================================================= */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .reveal{opacity:1; transform:none}
  html{scroll-behavior: auto}
}

@media (prefers-contrast: more){
  :root{
    --ink-1: #ffffff;
    --ink-2: #e3dcce;
    --line: rgba(255,255,255,0.25);
    --line-strong: rgba(255,255,255,0.5);
  }
  .btn--link{border-bottom-width: 2px}
}

/* Print */
@media print{
  .nav, .hero__scroll, .hero__grain, .hero__veil, .form{display:none}
  body{background: white; color: black}
  .section{padding: 2rem 1rem; break-inside: avoid}
  .hero__img{display:none}
}
