
:root{
  --bg:#0f0f12;
  --card:#15151a;
  --text:#f3f2ef;
  --muted:#b8b7b2;
  --gold:#d6b25e;
  --gold2:#f2d58b;
  --line:rgba(214,178,94,.25);
  --shadow: 0 12px 30px rgba(0,0,0,.35);
  --radius:18px;
  --container: 1120px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--text);
  background:
    radial-gradient(900px 600px at 10% 10%, rgba(214,178,94,.14), transparent 60%),
    radial-gradient(800px 500px at 90% 0%, rgba(242,213,139,.10), transparent 60%),
    linear-gradient(180deg, #0b0b0d 0%, #101015 55%, #0b0b0d 100%);
  line-height:1.6;
}

a{color:inherit; text-decoration:none}
a:hover{color:var(--gold2)}
img{max-width:100%; display:block}

.container{
  width:min(var(--container), calc(100% - 2rem));
  margin:0 auto;
}

.skip-link{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip-link:focus{left:1rem; top:1rem; width:auto; height:auto; padding:.6rem .9rem; background:var(--card); border:1px solid var(--line); border-radius:12px; z-index:9999}

.site-top{
  padding:1.2rem 0 0;
}
.brand-strip img{
  width:100%;
  border-radius:16px;
  box-shadow: var(--shadow);
  border: 1px solid rgba(255,255,255,.06);
}

.nav-wrap{
  margin-top: .9rem;
  background: rgba(21,21,26,.72);
  backdrop-filter: blur(10px);
  border:1px solid rgba(214,178,94,.20);
  border-radius: 16px;
  box-shadow: 0 10px 26px rgba(0,0,0,.28);
}
.navbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:.75rem .9rem;
}
.nav-left{
  display:flex; align-items:center; gap:.8rem;
}
.badge{
  display:inline-flex; align-items:center; gap:.55rem;
  padding:.35rem .6rem;
  border-radius: 999px;
  border:1px solid rgba(214,178,94,.25);
  background: rgba(214,178,94,.08);
  color: var(--gold2);
  font-size:.9rem;
  white-space:nowrap;
}
.badge svg{width:18px;height:18px;opacity:.95}

.nav-toggle{
  display:none;
  border:1px solid rgba(214,178,94,.28);
  background: rgba(0,0,0,.18);
  color: var(--text);
  border-radius: 12px;
  padding:.55rem .7rem;
  cursor:pointer;
}
.nav-toggle:focus{outline:2px solid rgba(214,178,94,.45); outline-offset:2px}

.nav-links{
  display:flex;
  align-items:center;
  gap:.35rem;
  flex-wrap:wrap;
}
.nav-links a{
  padding:.55rem .8rem;
  border-radius: 12px;
  color: var(--text);
  font-weight:600;
  font-size:.96rem;
  border:1px solid transparent;
}
.nav-links a:hover{
  border-color: rgba(214,178,94,.25);
  background: rgba(214,178,94,.08);
}
.nav-links a.active{
  border-color: rgba(214,178,94,.32);
  background: rgba(214,178,94,.12);
  color: var(--gold2);
}

.main{
  padding: 1.4rem 0 2.2rem;
}
.hero{
  margin-top: 1.1rem;
  position:relative;
  overflow:hidden;
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.06);
  box-shadow: var(--shadow);
  background:
    radial-gradient(900px 450px at 10% 0%, rgba(214,178,94,.22), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
}
.hero-inner{
  padding: 2.2rem 1.6rem;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 1.2rem;
  align-items:center;
}
.kicker{
  color: var(--gold2);
  font-weight:700;
  letter-spacing:.06em;
  text-transform: uppercase;
  font-size:.82rem;
}
h1,h2,h3{line-height:1.2; margin:.45rem 0 .65rem}
h1{font-size: clamp(1.7rem, 2.5vw, 2.35rem)}
h2{font-size: clamp(1.35rem, 1.9vw, 1.75rem)}
h3{font-size:1.12rem}
p{margin:.35rem 0 .9rem; color: rgba(243,242,239,.92)}
.small{font-size:.95rem; color: var(--muted)}

.cta-row{
  display:flex; gap:.7rem; flex-wrap:wrap;
  margin-top: 1.1rem;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  padding:.75rem 1rem;
  border-radius: 14px;
  border:1px solid rgba(214,178,94,.28);
  background: rgba(214,178,94,.10);
  color: var(--gold2);
  font-weight:800;
  cursor:pointer;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}
.btn:hover{transform: translateY(-1px); background: rgba(214,178,94,.14); border-color: rgba(214,178,94,.42)}
.btn.primary{
  background: linear-gradient(135deg, rgba(214,178,94,.28), rgba(242,213,139,.10));
}
.btn.ghost{
  background: rgba(0,0,0,.18);
  color: var(--text);
  border-color: rgba(255,255,255,.10);
}
.btn svg{width:18px;height:18px}

.hero-card{
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(214,178,94,.18);
  border-radius: 16px;
  padding: 1rem 1rem;
}
.hero-card .line{
  display:flex; gap:.6rem; align-items:flex-start;
  padding:.55rem .35rem;
  border-bottom: 1px solid rgba(214,178,94,.12);
}
.hero-card .line:last-child{border-bottom:none}
.hero-card strong{color:var(--gold2)}
.hero-card .meta{font-size:.95rem; color: rgba(243,242,239,.86)}

.section{
  margin-top: 1.6rem;
  position:relative;
}
.section.decor{
  overflow:hidden;
}
.section.decor::before{
  content:"";
  position:absolute;
  inset:-120px -60px auto auto;
  width: 360px;
  height: 360px;
  background-image: url("../img/Design.png");
  background-size: contain;
  background-repeat:no-repeat;
  opacity:.18;
  transform: rotate(8deg);
  pointer-events:none;
  filter: saturate(1.05);
}
.grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 1rem;
}
.card{
  grid-column: span 12;
  background: rgba(21,21,26,.72);
  border:1px solid rgba(255,255,255,.06);
  border-radius: var(--radius);
  padding: 1.2rem 1.2rem;
  box-shadow: 0 12px 26px rgba(0,0,0,.28);
}
.card.gold{
  border-color: rgba(214,178,94,.22);
}
.card h2{margin-top:0}

.list{
  margin: .6rem 0 0;
  padding-left: 1.1rem;
  color: rgba(243,242,239,.9);
}
.list li{margin:.35rem 0}
.pills{
  display:flex; flex-wrap:wrap; gap:.5rem;
  margin-top: .6rem;
}
.pill{
  border:1px solid rgba(214,178,94,.22);
  background: rgba(214,178,94,.08);
  color: var(--gold2);
  border-radius: 999px;
  padding:.35rem .65rem;
  font-weight:700;
  font-size:.9rem;
}
.gallery{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 1rem;
}
.figure{
  grid-column: span 12;
  border-radius: var(--radius);
  overflow:hidden;
  border:1px solid rgba(255,255,255,.06);
  background: rgba(0,0,0,.18);
  box-shadow: var(--shadow);
}
.figure img{aspect-ratio: 4/3; width:100%; object-fit:cover}
.figure .cap{
  padding:.8rem .9rem;
  border-top:1px solid rgba(255,255,255,.06);
  color: rgba(243,242,239,.86);
  font-size:.95rem;
}

.form{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 1rem;
}
.field{grid-column: span 12}
.field label{
  display:block;
  font-weight:800;
  margin:0 0 .35rem;
  color: rgba(243,242,239,.92);
}
.input, select, textarea{
  width:100%;
  border-radius: 14px;
  border:1px solid #533f0e; /*-- Rand Boxen -- */
  background: #000000; /*-- Hintergrund Boxen -- */
  color: var(--text);
  padding:.75rem .85rem;
  font-size:1rem;
  outline:none;
}
textarea{min-height: 140px; resize: vertical}
.input:focus, select:focus, textarea:focus{
  border-color: rgba(214,178,94,.45);
  box-shadow: 0 0 0 3px #d6b25e; /*-- Umrandung aktiv Boxen -- */
}
.help{
  margin-top:.35rem;
  color: var(--muted);
  font-size:.92rem;
}
.checkbox-row{
  display:flex; flex-wrap:wrap; gap:.65rem;
}
.check{
  display:flex; gap:.5rem; align-items:center;
  padding:.5rem .65rem;
  border-radius: 14px;
  border:1px solid rgba(214,178,94,.18);
  background: rgba(214,178,94,.06);
}
.check input{width:18px;height:18px}
.notice{
  border:1px solid rgba(214,178,94,.22);
  background: rgba(214,178,94,.08);
  border-radius: var(--radius);
  padding: .9rem 1rem;
  color: rgba(243,242,239,.92);
}
.alert{
  border:1px solid rgba(242,213,139,.25);
  background: rgba(242,213,139,.08);
  border-radius: 16px;
  padding: .8rem 1rem;
  margin-bottom: 1rem;
}
.alert.success{border-color: rgba(120, 255, 185, .22); background: rgba(120,255,185,.08)}
.alert.error{border-color: rgba(255,120,120,.22); background: rgba(255,120,120,.08)}
.mini-cta{
  display:flex; gap:.7rem; flex-wrap:wrap; align-items:center;
}

.accordion{
  display:grid; gap:.75rem;
}
details{
  background: rgba(0,0,0,.18);
  border:1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  padding: .8rem 1rem;
}
details[open]{border-color: rgba(214,178,94,.25)}
summary{
  cursor:pointer;
  font-weight:900;
  color: rgba(243,242,239,.95);
}
summary::-webkit-details-marker{display:none}
summary::after{
  content:"+";
  float:right;
  color: var(--gold2);
  font-size: 1.2rem;
  margin-left: .8rem;
}
details[open] summary::after{content:"–"}

.site-footer{
  padding: 1.2rem 0 2.2rem;
}
.footer-card{
  border-radius: 16px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.06);
  box-shadow: var(--shadow);
}
.footer-card img{width:100%}
.footer-bottom{
  margin-top: .95rem;
  display:flex;
  flex-wrap:wrap;
  gap:.7rem;
  align-items:center;
  justify-content:space-between;
  color: rgba(243,242,239,.80);
  font-size:.95rem;
}
.footer-links{
  display:flex; flex-wrap:wrap; gap:.65rem;
}
.footer-links a{
  padding:.35rem .55rem;
  border-radius: 12px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.16);
}
.footer-links a:hover{border-color: rgba(214,178,94,.28); background: rgba(214,178,94,.08)}
hr.sep{
  border:none;
  height:1px;
  background: linear-gradient(90deg, transparent, rgba(214,178,94,.35), transparent);
  margin: 1.2rem 0;
}

@media (min-width: 740px){
  .field.half{grid-column: span 6}
  .field.third{grid-column: span 4}
  .figure{grid-column: span 6}
  .card.span7{grid-column: span 7}
  .card.span5{grid-column: span 5}
}
@media (max-width: 820px){
  .hero-inner{grid-template-columns: 1fr}
}
@media (max-width: 720px){
  .nav-toggle{display:inline-flex}
  .nav-links{
    display:none;
    width:100%;
    padding:.2rem .2rem .6rem;
  }
  .nav-wrap.open .nav-links{display:flex}
  .navbar{flex-wrap:wrap}
  .nav-links a{width:100%}
}
