/* =========================================================
   HEADER
   ========================================================= */

.site-header{
  position: sticky;
  top: 0;
  z-index: 1000;

  background: var(--header-bg);
  backdrop-filter: blur(var(--header-blur));
  border-bottom: 1px solid var(--border);
}

/* Header insgesamt etwas höher/luftiger */
.header-inner{
  padding-block: var(--space-8);     /* vorher ~24px */
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-8);              /* vorher 32px */
}

/* Brand links: Logo + Claim zentriert untereinander */
.brand{
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
  min-width: 300px;
}

.brand-logo{
  height: 64px;
  width: auto;
  object-fit: contain;
  display: block;
}

.brand-claim{
  margin: 0;
  font-family: var(--font-accent);
  font-weight: 400;
  font-size: 1.0625rem; /* 17px */
  color: var(--text-1);
  letter-spacing: 0.2px;
}

.header-right{
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
}

/* Language switch */
.lang-switch{
  display: flex;
  gap: 8px;
}

.lang-link{
  font-size: 0.75rem; /* 12px */
  letter-spacing: 0.6px;
  text-transform: uppercase;

  padding: 6px 10px;
  border-radius: var(--pill-radius);
  border: 1px solid var(--border);

  color: var(--text-1);
  background: var(--card-bg-1);
  transition: border-color 150ms ease, transform 150ms ease, background 150ms ease;
}

.lang-link:hover{
  transform: translateY(var(--hover-lift));
  border-color: var(--hover-border);
  background: var(--accent-10);
}

.lang-link.is-active{
  border-color: var(--accent-75);
  background: var(--accent-18);
  color: var(--text-0);
}

/* Contact options */
.header-contact{
  display: flex;
  align-items: stretch;
  gap: 14px;
}

/* =========================================================
   CONTACT DOCK
   Default: Desktop/Tablet => Kontakte im Header inline (nebeneinander)
   Dock-Mode: html.dock-enabled => iOS-like Bottom Overlay
   ========================================================= */

/* Default: Toggle versteckt, Panel ist die “normale” Zeile */
.header-contact[data-contact-dock]{
  display: flex;
  align-items: stretch;
  gap: 14px;
}

.header-contact[data-contact-dock] .contact-dock-toggle{
  display: none;
}

.header-contact[data-contact-dock] .contact-dock-panel{
  display: flex;
  align-items: stretch;
  gap: 14px;
}

/* =========================================================
   UI UTILITIES
   ========================================================= */

.card{
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: linear-gradient(180deg, var(--card-bg-1), var(--card-bg-2));
}

.card--hover{
  transition: transform 150ms ease, border-color 150ms ease, background 150ms ease;
}

.card--hover:hover{
  transform: translateY(var(--hover-lift));
  border-color: var(--hover-border);
  background: linear-gradient(180deg, var(--accent-10), var(--card-bg-hover-2));
}

.contact-item{
  display: flex;
  align-items: center;
  gap: 12px;

  padding: 12px 14px;
}

.contact-item:hover{
  transform: translateY(var(--hover-lift));
  border-color: var(--hover-border);
  background: linear-gradient(180deg, var(--accent-10), var(--card-bg-hover-2));
}

.contact-icon{
  width: 22px;
  height: 22px;
  object-fit: contain;
  opacity: 0.95;
}

.contact-text{
  display: flex;
  flex-direction: column;
  gap: 3px;
  line-height: 1.1;
  min-width: 0;
}

.contact-title{
  font-size: 0.8125rem; /* 13px */
  color: var(--text-2);
}

.contact-value{
  font-size: 0.875rem; /* 14px */
  color: var(--text-0);
  letter-spacing: 0.2px;
  overflow-wrap: anywhere;
}

/* =========================================================
   SCROLL TO TOP BUTTON
   ========================================================= */

.to-top{
  position: fixed;
  right: max(18px, env(safe-area-inset-right));
  bottom: max(18px, env(safe-area-inset-bottom));

  width: var(--toTop-size);
  height: var(--toTop-size);
  border-radius: var(--pill-radius);

  border: 1px solid var(--border-button);
  background: var(--toTop-bg);
  color: var(--text-0);
  box-shadow: var(--shadow);
  cursor: pointer;

  display: grid;
  place-items: center;

  transform: translate3d(0, var(--toTopLift, 0px), 0);
  transition: transform 180ms ease, opacity 180ms ease;

  touch-action: manipulation;
  z-index:2000;
  pointer-events:auto;
}

.to-top.to-top--lift{
  --toTopLift: var(--toTop-lift);
}

/* =========================================================
   PAGE LOAD (global)
   ========================================================= */

/* nur wenn JS aktiv ist */
.has-js body{
  opacity: 0;
  transform: translateY(var(--anim-page-distance));
  transition:
    opacity var(--anim-page-dur) var(--anim-ease),
    transform var(--anim-page-dur) var(--anim-ease);
  transition-delay: var(--anim-page-delay);
}

.has-js body.is-ready{
  opacity: 1;
  transform: none;
}

/* =========================================================
   REVEAL (reusable utility)
   Use: class="reveal" + optional CSS vars per element
   ========================================================= */

/* nur wenn JS aktiv ist (sonst niemals verstecken!) */
.has-js .reveal{
  opacity: 0;
  transform: translateY(var(--reveal-distance, var(--anim-reveal-distance)));
  transition:
    opacity var(--reveal-dur, var(--anim-reveal-dur)) var(--anim-ease),
    transform var(--reveal-dur, var(--anim-reveal-dur)) var(--anim-ease);
  transition-delay: var(--reveal-delay, var(--anim-reveal-delay));
  will-change: transform, opacity;
}

.has-js .reveal.is-inview{
  opacity: 1;
  transform: none;
}

/* Motion-reduction */
@media (prefers-reduced-motion: reduce){
  .has-js body,
  .has-js .reveal{
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
    animation: none !important;
  }
}

/* =========================================================
   SECTION – Band Utility (reusable)
   ========================================================= */
.section--band{
  position: relative;
  isolation: isolate;
}

.section--band::before{
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;

  /* dezenter Wechsel, nicht “hell”, nur Tiefe */
  background:
    radial-gradient(900px 420px at 20% 15%, rgba(160,143,106,0.10), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));

  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

/* Container bleibt normal, aber sitzt “über” dem Band */
.section--band .container{
  position: relative;
  z-index: 1;
}

/* Reviews Panel minimal stärker abheben */
.reviews-panel{
  background: linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.02));
  border-color: rgba(255,255,255,0.14);
}

/* =========================================================
   CARDS – Interactive (reusable)
   ========================================================= */

:root{
  --card-lift: -3px;
  --card-fx-range: 6px; /* nur für optionales Maus-Follow */
  --card-glow: rgba(160,143,106,0.18);
  --card-hover-shadow: 0 18px 55px rgba(0,0,0,0.42);
}

@media (hover:hover) and (pointer:fine){
  .card--interactive{
    position: relative;
    transform: translate3d(var(--card-x, 0px), calc(var(--card-y, 0px) + 0px), 0);
    transition:
      transform 220ms var(--anim-ease),
      border-color 220ms var(--anim-ease),
      box-shadow 220ms var(--anim-ease);
    will-change: transform;
  }

  .card--interactive::after{
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    opacity: 0;
    transition: opacity 220ms var(--anim-ease);

    /* Glanzpunkt (wenn kein JS: bleibt schön zentriert) */
    background: radial-gradient(
      520px circle at var(--mx, 50%) var(--my, 35%),
      var(--card-glow),
      transparent 30%
    );
  }

  .card--interactive:hover{
    transform: translate3d(var(--card-x, 0px), calc(var(--card-y, 0px) + var(--card-lift)), 0);
    border-color: var(--hover-border);
    box-shadow: var(--card-hover-shadow);
  }

  .card--interactive:hover::after{
    opacity: 1;
  }
}

/* Motion-reduction: keine Effekte */
@media (prefers-reduced-motion: reduce){
  .card--interactive{ transition: none !important; transform: none !important; }
  .card--interactive::after{ display: none !important; }
}

/* =========================================================
   NOTICE – WEF (glass toast)
   ========================================================= */

.notice{
  position: fixed;
  left: 50%;
  bottom: max(18px, env(safe-area-inset-bottom));
  transform: translateX(-50%);
  z-index: 2000;
  width: min(920px, calc(100% - 28px));
}

.notice-card{
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-4);
  align-items: start;

  padding: var(--space-5);
  border-radius: calc(var(--radius) + 6px);
  border: 1px solid rgba(255,255,255,0.14);

  background: rgba(15,16,18,0.58);
  backdrop-filter: blur(12px);
  box-shadow: 0 18px 60px rgba(0,0,0,0.50);

  opacity: 0;
  transform: translate3d(0, 10px, 0);
  transition: opacity 260ms var(--anim-ease), transform 260ms var(--anim-ease);
}

.notice.is-open .notice-card{
  opacity: 1;
  transform: none;
}

.notice-msg{
  margin: 0;
  color: var(--text-1);
  line-height: 1.55;
}

.notice-link{
  color: var(--text-0);
  text-decoration: none;
  border-bottom: 1px solid rgba(160,143,106,0.45);
}
.notice-link:hover{
  border-bottom-color: rgba(160,143,106,0.85);
}

.notice-close{
  width: 38px;
  height: 38px;
  border-radius: var(--pill-radius);
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(255,255,255,0.06);
  color: var(--text-0);
  cursor: pointer;
  line-height: 1;
  font-size: 20px;
}

/* Sprachumschaltung per html[lang] */
html[lang="de"] .notice-msg--en{ display:none; }
html[lang="en"] .notice-msg--de{ display:none; }

@media (max-width: 480px){
  .notice-card{
    padding: var(--space-4);
    gap: var(--space-3);
  }
}

/* =========================================================
   FOOTER
   ========================================================= */

.site-footer{
  background: linear-gradient(180deg, var(--footer-grad-1), var(--footer-grad-2));
  color: var(--footer-text);
  border-top: 1px solid var(--footer-border);
}

.footer-inner{
  padding-block: var(--space-10);    /* vorher ~40px */
  display: grid;
  grid-template-columns: 1.2fr 0.8fr 1.4fr;
  gap: var(--space-8);              /* vorher 26px -> 40px, wirkt luftiger */
  align-items: start;
}

.footer-brand{
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
}

.footer-logo{
  height: 60px;
  width: auto;
  object-fit: contain;
}

.footer-claim{
  font-family: var(--font-accent);
  font-size: 1rem; /* 16px */
  color: var(--footer-claim);
}

.footer-links{
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.footer-link,
.footer-links a{
  color: var(--footer-link);
  text-decoration: none;
  transition: color 150ms ease;
}

.footer-links a:hover,
.footer-link:hover{
  color: var(--footer-link-hover);
}

.footer-contact{
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.footer-line{
  display: grid;
  grid-template-columns: 90px 1fr;
  align-items: baseline;
}

.footer-label{
  font-size: 0.75rem; /* 12px */
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--footer-label);
}

.footer-value{
  font-size: 0.875rem; /* 14px */
  color: var(--footer-value);
  overflow-wrap: anywhere;
}

.footer-reviews{
  margin-top: 8px;
  padding-top: 12px;
  border-top: 1px solid var(--footer-divider);
  display: flex;
  align-items: center;
  gap: 10px;
}

.reviews-stars{
  color: var(--accent);
  letter-spacing: 1px;
}

.footer-bottom{
  border-top: 1px solid var(--footer-border);
  background: var(--footer-bottom-bg);
}

.footer-bottom-inner{
  padding-block: var(--space-4);

  display: flex;
  justify-content: center;
  align-items: center;

  text-align: center;
  color: var(--footer-bottom-text);
  font-size: 0.8125rem;
}

/* =========================================================
   MEDIA QUERIES
   ========================================================= */

/* Tablet/Laptop */
@media (max-width: 1024px){
  .header-inner{
    padding-block: var(--space-7); /* etwas kompakter */
    gap: var(--space-6);
  }

  .brand{
    min-width: 260px;
  }

  .header-contact{
    flex-wrap: wrap;
    justify-content: flex-end;
  }

  .contact-item{
    padding: 11px 12px;
  }

  .header-contact[data-contact-dock] .contact-dock-panel{
    flex-wrap: wrap;
    justify-content: flex-end;
  }
}

/* Tablet/Mobile */
@media (max-width: 768px){
  .site-header{ overflow-x: clip; }

  .header-inner{
    flex-direction: column;
    align-items: stretch;
    padding-block: var(--space-7); /* etwas kompakter */
    gap: var(--space-6);
  }

  .brand{
    min-width: unset;
    max-width: 100%;
  }

  .brand-logo{ height: 58px; }
  .brand-claim{ font-size: 1rem; }

  .header-right{
    align-items: stretch;
    gap: 12px;
  }

  .lang-switch{
    justify-content: center;
    flex-wrap: wrap;
  }

  /* bis 768: normale Kontakte (ohne Dock) als Column */
  .header-contact:not([data-contact-dock]){
    flex-direction: column;
    gap: 10px;
  }

  /* Dock-Markup bleibt im Header hier als Grid,
     ABER: sobald Dock aktiv ist (html.dock-enabled), wird es fixed unten */
  .header-contact[data-contact-dock] .contact-dock-panel{
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 10px;
  }

  .header-contact[data-contact-dock] .contact-dock-panel .contact-item:first-child{
    grid-column: 1 / -1;
  }

  .contact-item{
    width: 100%;
    min-width: 0;
  }

  /* Footer responsive */
  .footer-inner{
    grid-template-columns: 1fr;
    gap: var(--space-6);
    padding-block: var(--space-9);
  }
}

/* =========================================================
   DOCK MODE (aktiviert durch JS: html.dock-enabled)
   ========================================================= */

html.dock-enabled{
  --contact-dock-width: min(460px, calc(100vw - 20px));
  --contact-dock-bottom-gap: 10px;
  --contact-dock-radius: 22px;

  --contact-dock-space-open: 250px;
  --contact-dock-space-collapsed: 86px;
}

/* Reserve je Zustand */
html.dock-enabled.contact-dock-open body{
  padding-bottom: calc(var(--contact-dock-space-open) + env(safe-area-inset-bottom));
  transition: padding-bottom 320ms cubic-bezier(.2,.8,.2,1);
}
html.dock-enabled.contact-dock-collapsed body{
  padding-bottom: calc(var(--contact-dock-space-collapsed) + env(safe-area-inset-bottom));
  transition: padding-bottom 320ms cubic-bezier(.2,.8,.2,1);
}

/* Dock Container */
html.dock-enabled .header-contact[data-contact-dock]{
  position: fixed;
  left: 50%;
  bottom: calc(env(safe-area-inset-bottom) + var(--contact-dock-bottom-gap));
  transform: translateX(-50%);
  width: var(--contact-dock-width);
  z-index: 1200;

  display: grid;
  grid-template-rows: auto auto;
  gap: 10px;

  pointer-events: none;
}
html.dock-enabled .header-contact[data-contact-dock] > *{ pointer-events: auto; }

/* Pill / Toggle */
html.dock-enabled .header-contact[data-contact-dock] .contact-dock-toggle{
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;

  padding: 12px 14px;
  border-radius: var(--pill-radius);

  background: rgba(21,23,27,0.90);
  backdrop-filter: blur(12px);

  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  color: var(--text-0);

  font: inherit;
  text-align: left;

  transform: translateY(0);
  transition:
    transform 220ms ease,
    border-color 220ms ease,
    background 220ms ease;
}

html.dock-enabled .header-contact[data-contact-dock] .contact-dock-toggle:active{
  transform: translateY(1px);
}

html.dock-enabled .header-contact[data-contact-dock] .contact-dock-label{
  font-size: 0.875rem;
  letter-spacing: 0.2px;
}

html.dock-enabled .header-contact[data-contact-dock] .contact-dock-chevron{
  opacity: 0.9;
  transition: transform 320ms cubic-bezier(.2,.8,.2,1);
  transform: rotate(180deg);
}

html.dock-enabled .header-contact[data-contact-dock].is-collapsed .contact-dock-chevron{
  transform: rotate(0deg);
}

/* Panel */
html.dock-enabled .header-contact[data-contact-dock] .contact-dock-panel{
  overflow: clip;

  border-radius: var(--contact-dock-radius);
  background: rgba(15,16,18,0.88);
  backdrop-filter: blur(12px);

  border: 1px solid var(--border);
  box-shadow: var(--shadow);

  padding: 12px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 10px;

  transform-origin: bottom center;
  max-height: 320px;
  opacity: 1;
  transform: translateY(0);

  transition:
    max-height 380ms cubic-bezier(.2,.8,.2,1),
    opacity 220ms ease,
    transform 380ms cubic-bezier(.2,.8,.2,1),
    border-color 220ms ease;
}

html.dock-enabled .header-contact[data-contact-dock] .contact-dock-panel .contact-item:first-child{
  grid-column: 1 / -1;
}

/* Eingeklappt */
html.dock-enabled .header-contact[data-contact-dock].is-collapsed .contact-dock-panel{
  max-height: 0;
  opacity: 0;
  transform: translateY(10px);
  border-color: transparent;
  padding-top: 0;
  padding-bottom: 0;
  pointer-events: none;
}

/* Dock-Karten kompakt + Home-Mobile-Header-Overrides neutralisieren */
html.dock-enabled .header-contact[data-contact-dock] .contact-item{
  width: 100%;
  min-width: 0;
  max-width: 100%;
  padding: 10px 10px;

  justify-content: flex-start;
  text-align: left;
}

html.dock-enabled .header-contact[data-contact-dock] .contact-icon{
  display: none !important;
}

html.dock-enabled .header-contact[data-contact-dock] .contact-text{
  align-items: flex-start;
  text-align: left;
}

/* Optional: im collapsed State keine “leere” Gap-Zeile */
html.dock-enabled .header-contact[data-contact-dock].is-collapsed{
  gap: 0;
}

/* To-top: Dock-Abstand über bottom (nicht via transform-lift) */
html.dock-enabled .to-top{
  bottom: calc(max(18px, env(safe-area-inset-bottom)) + var(--toTopDockOffset, 0px));
  transition: bottom 180ms cubic-bezier(.2,.8,.2,1), transform 180ms ease, opacity 180ms ease;
  will-change: bottom;
}

/* während JS pro Frame nachführt: KEINE bottom-transition (sonst bouncy) */
html.dock-enabled .to-top.is-dock-follow{
  transition: transform 180ms ease, opacity 180ms ease;
}

/* verhindert “schwebt” durch to-top--lift auf Mobile */
html.dock-enabled .to-top.to-top--lift{
  --toTopLift: 0px;
}

/* Motion-Reduce */
@media (prefers-reduced-motion: reduce){
  html.dock-enabled.contact-dock-open body,
  html.dock-enabled.contact-dock-collapsed body,
  html.dock-enabled .contact-dock-toggle,
  html.dock-enabled .contact-dock-chevron,
  html.dock-enabled .contact-dock-panel{
    transition: none !important;
  }
}
