/* ================= MMC – Minimal & Elegant (komplett) ================= */

/* -------- Variablen -------- */
:root{
  --gold:#B28E4F; --gold-hover:#FFD78A;
  --text:#FFFFFF; --text-muted:rgba(255,255,255,.90);
  --bg-dark:rgba(0,0,0,.25); --glass:rgba(20,16,12,.55);

  --ease:cubic-bezier(.22,.61,.36,1);
  --t-fast:.30s; --t-mid:.55s; --t-slow:.85s;

  --dockH:60px; --dock-bottom:16px; --contentGap:12px; --panelMaxW:1100px;
  --logo2Size:92px; --logo2Top:10px; --headGap:12px;

  --font-sans: system-ui,-apple-system,"Segoe UI Variable Text","Segoe UI",
               Roboto,"Helvetica Neue",Arial,"Noto Sans","Liberation Sans",sans-serif;
}
@media (max-width:768px){
  :root{ --logo2Size:78px; --logo2Top:8px; --headGap:10px; --contentGap:10px; }
}

/* -------- Reset & Typo -------- */
*{ box-sizing:border-box; }
html,body{ color-scheme:dark; }
html,body{
  font-family:var(--font-sans); font-weight:300; letter-spacing:.005em; line-height:1.7;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
@supports (font-variation-settings: normal){ html,body{ font-variation-settings:"wght" 320; } }
h1,h2,h3{ font-weight:400; letter-spacing:.01em; margin:0 0 .35rem; }
b,strong{ font-weight:500; }

/* -------- Global -------- */
body{
  margin:0; padding:0;
  background:url('../../media/hintergrund.jpg') no-repeat center center fixed;
  background-size:cover;
  color:var(--text);
  display:flex; flex-direction:column; align-items:center; justify-content:flex-start;
  min-height:100vh; text-align:center; overflow-x:hidden;
}
a, a:visited{ color:var(--gold); text-decoration:none; }
a:hover{ color:var(--gold-hover); }
.spacer{ height:8vh; transition:height var(--t-mid) var(--ease); }

/* Scrollbars gold */
body,.content-card,.inc-layout .card,.inc-layout .figure{
  scrollbar-color:var(--gold) rgba(255,255,255,.12);
  scrollbar-width:thin;
}
body::-webkit-scrollbar, .content-card::-webkit-scrollbar{ width:10px; height:10px; }
body::-webkit-scrollbar-track, .content-card::-webkit-scrollbar-track{
  background:rgba(255,255,255,.08); border-radius:999px;
}
body::-webkit-scrollbar-thumb, .content-card::-webkit-scrollbar-thumb{
  background:var(--gold); border-radius:999px; border:2px solid transparent;
  background-clip:padding-box; box-shadow:inset 0 0 0 1px rgba(0,0,0,.15);
}
body::-webkit-scrollbar-thumb:hover, .content-card::-webkit-scrollbar-thumb:hover{ background:var(--gold-hover); }

/* -------- Branding -------- */
.logo{
  position:relative; z-index:120; pointer-events:auto;
  max-width:280px; margin-bottom:16px; height:auto; cursor:pointer;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.25));
  transition:transform var(--t-mid) var(--ease);
}
.logo:active{ transform:scale(.98); }
.logo2{
  position:fixed; left:50%; top:var(--logo2Top); transform:translateX(-50%);
  display:none; z-index:120; pointer-events:auto;
  width:var(--logo2Size); height:var(--logo2Size); aspect-ratio:1/1; object-fit:contain; cursor:pointer;
  filter:drop-shadow(0 4px 10px rgba(0,0,0,.45));
  transition:transform var(--t-mid) var(--ease), opacity var(--t-mid) var(--ease);
}
.slogan{ max-width:420px; margin-bottom:28px; height:auto; opacity:.96; }
/* SEO-Text sichtbar im DOM, aber visuell versteckt */
.slogan-vis{
  position:absolute !important;
  width:1px; height:1px; margin:-1px; padding:0;
  overflow:hidden; clip:rect(0 0 0 0); clip-path:inset(50%);
  white-space:nowrap; border:0;
}

/* -------- Navigation/Dock -------- */
.button-row{
  display:flex; gap:20px; flex-wrap:wrap; justify-content:center;
  max-width:1000px; padding:0 16px; z-index:70;
  transition:all var(--t-slow) var(--ease);
}
.button-row a{ position:relative; display:inline-flex; padding:2px 2px 8px; border-radius:14px; transition:transform var(--t-fast) ease; }
.button-row a img{
  width:80px; height:80px; object-fit:contain; border-radius:10px;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.25));
  transition: transform .2s ease, filter .2s ease, width var(--t-mid) var(--ease), height var(--t-mid) var(--ease);
}
.button-row a:hover img{ transform:scale(1.08); }
/* aktiv */
.button-row a::after{
  content:""; position:absolute; left:10px; right:10px; bottom:0; height:2px;
  background:transparent; transform:scaleX(0); opacity:0; border-radius:2px;
  transition: transform var(--t-fast) var(--ease), opacity var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.button-row a.active::after{ background:var(--gold); transform:scaleX(1); opacity:1; }

/* Dock-Mode (Content offen) */
body.mode-content .spacer{ height:2.8vh; }
body.mode-content .logo{ display:none; }
body.mode-content .logo2{ display:block; }
body.mode-content .slogan{ opacity:0; transform:translateY(-6px); margin-bottom:0; pointer-events:none; }
body.mode-content .button-row{
  position:fixed; left:50%; transform:translateX(-50%); bottom:var(--dock-bottom);
  max-width:min(100vw - 24px, 980px);
  padding:8px 12px; border-radius:14px; background:var(--bg-dark); backdrop-filter:blur(6px);
  box-shadow:0 8px 24px rgba(0,0,0,.25);
}
body.mode-content .button-row a img{ width:46px; height:46px; }
body.mode-content .button-row a{ padding-bottom:10px; }

/* -------- Content-Panel -------- */
.content-panel{
  position:fixed; left:50%; transform:translateX(-50%) translateY(16px);
  top:calc(var(--logo2Top) + var(--logo2Size) + var(--headGap));
  bottom:calc(var(--dockH) + var(--dock-bottom) + var(--contentGap));
  width:min(100% - 32px, var(--panelMaxW));
  opacity:0; pointer-events:none; z-index:60;
  transition:transform var(--t-slow) var(--ease), opacity var(--t-mid) var(--ease);
}
.content-panel.active{ opacity:1; pointer-events:auto; transform:translateX(-50%) translateY(0); }
.content-card{
  height:100%; overflow:auto; overflow-x:hidden; scrollbar-gutter:stable both-edges;
  padding:22px 22px 28px;
  background:var(--glass); backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.08); border-radius:18px; box-shadow:0 12px 38px rgba(0,0,0,.35);
  text-align:left; color:var(--text);
}
.content-card h1{ margin:0 40px 10px 0; font-size:1.6rem; color:var(--gold); }
.content-card p{ margin:0 0 14px; }
#content-body{ opacity:1; transform:translateY(0); transition:opacity var(--t-mid) var(--ease), transform var(--t-mid) var(--ease); }
#content-body.fade-out{ opacity:0; transform:translateY(8px); }

/* -------- Include Basics -------- */
.inc .eyebrow{ display:inline-block; font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); opacity:.9; margin-bottom:6px; }
/* Überschriften gold & ruhiger, mit mehr Top-Luft */
.inc h2{ font-size:1.8rem; line-height:1.25; color:var(--gold); margin:1.2rem 0 .6rem; }
.inc .eyebrow + h2{ margin-top:.3rem; }
.inc h3{ font-size:1.1rem; color:var(--gold); margin:1.1rem 0 .5rem; }
.inc .muted{ color:var(--text-muted); }
.inc .rule{ height:1px; width:100%; margin:.9rem 0 1.1rem; background:linear-gradient(90deg,transparent,var(--gold),transparent); opacity:.55; }

/* Layout */
.inc-layout{ --gap:18px; --colL:1.6fr; --colR:1fr; }
.inc-layout .grid{ display:grid; grid-template-columns:var(--colL) var(--colR); grid-template-areas:"main side"; gap:var(--gap); align-items:start; }
.inc-layout .main{ grid-area:main; }
.inc-layout .side{ grid-area:side; display:grid; gap:var(--gap); }
.inc-layout .card{
  padding:16px 16px 18px; border-radius:14px; background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08); box-shadow:0 10px 26px rgba(0,0,0,.28); text-align:left;
}
.inc-layout .card + .card{ margin-top:var(--gap); }
.inc-layout .card p{ margin:0 0 .7rem; color:var(--text); }
.inc-layout .figure{ position:relative; border-radius:14px; overflow:hidden; border:1px solid rgba(255,255,255,.08); box-shadow:0 10px 30px rgba(0,0,0,.35); margin:0; }
.inc-layout .figure img, .inc-layout .figure video{ display:block; width:100%; height:auto; max-width:100%; object-position:center; }
.inc-layout .figure--ratio{ height:auto; aspect-ratio:var(--ratio,16/9); }
.inc-layout .figure--ratio img, .inc-layout .figure--ratio video{ height:100%; object-fit:cover; }
.inc-layout .figure .cap{ position:absolute; left:0; right:0; bottom:0; padding:10px 12px; font-size:.9rem; color:var(--text); background:linear-gradient(180deg,transparent,rgba(0,0,0,.55)); }

/* CTA-Buttons */
.inc .cta{ margin-top:.9rem; display:flex; flex-wrap:wrap; gap:10px; }
.inc .btn{
  display:inline-block; padding:10px 14px; border-radius:999px;
  border:1px solid rgba(178,142,79,.45); color:var(--text);
  background:rgba(0,0,0,.18); backdrop-filter:blur(4px);
  transition:background .2s ease, border-color .2s ease, transform .2s ease;
}
.inc .btn:hover{ background:rgba(178,142,79,.12); border-color:var(--gold); transform:translateY(-1px); }

/* Home-Intro */
.home-intro{ margin:16px auto 12px; padding:0 16px; max-width:900px; }

/* Home-Intro: beide Zeilen in Gold, schlank */
.home-intro .home-claim,
.home-intro .home-claim-sub{
  color: var(--gold) !important;
  font-weight: 300;
}
.home-claim{ color:var(--gold); font-weight:400; font-size:1rem; margin:.25rem 0 .45rem; }
.home-claim-sub{ color:var(--text-muted); font-size:.95rem; font-weight:300; margin:0; }
.home-legal{ margin-top:.45rem; font-size:.82rem; opacity:.85; }
.home-legal a{ color:var(--gold); }

/* Responsive */
@media (max-width:1000px){
  .inc-layout .grid{ grid-template-columns:1fr; grid-template-areas:"main" "side"; }
  .inc h2{ font-size:1.55rem; }
}
@media (max-width:768px){
  .logo{ max-width:200px; }
  .slogan{ max-width:300px; margin-bottom:20px; }
  .button-row{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; max-width:520px; }
  .button-row a img{ width:120px; height:120px; }
  body.mode-content .button-row{ grid-template-columns:repeat(4,1fr); gap:12px; }
  body.mode-content .button-row a img{ width:44px; height:44px; }
  .content-panel{ width:calc(100% - 16px); }
  .content-card{ padding:16px 14px 22px; border-radius:14px; }
  .content-card h1{ font-size:1.35rem; }
}
