/*
===============================================================================
Kontaktmodul – Styles
Datei: /assets/kontaktmodul/kontakt.css
Stand: 29.12.2025, MEZ
Zweck:
  - Underline-Inputs (Formular)
  - Datenschutzzeile + Abstand zum Button
  - Submit-Button Styling (scoped)
  - Reveal: Unterstreichung erst NACH Klick (wenn Link vorhanden)
  - Modal Styles (#kontaktModal)
Hinweis:
  - Alles ist auf form[data-kontakt], .kontakt-* und #kontaktModal begrenzt.
===============================================================================
*/

/* =========================
   Variablen
   ========================= */
:root{
  /* allgemein */
  --kontakt-ink: #2A2A2A;

  /* Formular */
  --kontakt-line: rgba(42,42,42,.38);
  --kontakt-line-hover: rgba(42,42,42,.62);
  --kontakt-line-focus: #2A2A2A;
  --kontakt-focus-ring: rgba(42,42,42,.12);
  --kontakt-placeholder: rgba(42,42,42,.45);

  /* Modal */
  --km-border: rgba(42,42,42,.22);
  --km-shadow: rgba(0,0,0,.18);
  --km-focus: rgba(42,42,42,.14);
}

/* =============================================================================
   1) FORMULAR – Underline Inputs (nur im Modul)
============================================================================= */
form[data-kontakt] .form-control{
  background: transparent;
  border: 0 !important;
  border-bottom: 1px solid var(--kontakt-line) !important;
  border-radius: 0 !important;
  box-shadow: none !important;

  padding-left: 0 !important;
  padding-right: 0 !important;
  padding-top: .55rem;
  padding-bottom: .55rem;

  color: var(--kontakt-ink);
  transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
}

form[data-kontakt] .form-control:hover{
  border-bottom-color: var(--kontakt-line-hover) !important;
}

form[data-kontakt] .form-control:focus{
  border-bottom-color: var(--kontakt-line-focus) !important;
  box-shadow: 0 8px 0 -6px var(--kontakt-focus-ring) !important;
  outline: none !important;
}

form[data-kontakt] .form-control::placeholder{
  color: var(--kontakt-placeholder);
  opacity: 1;
}

form[data-kontakt] textarea.form-control{
  resize: vertical;
  min-height: 140px;
}

form[data-kontakt] .form-label{
  color: var(--kontakt-ink);
  opacity: .9;
}

form[data-kontakt] .form-text.text-danger{
  font-size: .875em;
  margin-top: .35rem;
}

/* =============================================================================
   2) DATENSCHUTZ-ZEILE + Abstand zum Button
============================================================================= */
form[data-kontakt] .kontakt-legal{
  font-size: .875em;
  line-height: 1.35;
  opacity: .75;
  margin: 0;
}

form[data-kontakt] .kontakt-legal a{
  color: inherit;
  font-size: 1em;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  opacity: .75;
}

form[data-kontakt] .kontakt-legal a:hover{
  opacity: 1;
}

form[data-kontakt] .kontakt-legal + button[type="submit"]{
  margin-top: 1rem;
}

/* =============================================================================
   3) SUBMIT BUTTON – nur im Modul
============================================================================= */
form[data-kontakt] button[type="submit"].sww-button{
  appearance: none;
  -webkit-appearance: none;

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

  padding: .75rem 1.25rem;
  border-radius: 999px;

  background: #2A2A2A !important;
  border: 1px solid #2A2A2A !important;
  color: #F4F2EE !important;

  font-weight: 500;
  letter-spacing: .01em;

  box-shadow: 0 10px 26px rgba(0,0,0,.12);
  transition: transform .18s ease, filter .18s ease, box-shadow .18s ease;
}

form[data-kontakt] button[type="submit"].sww-button:hover{
  transform: translateY(-1px);
  filter: brightness(.98);
  box-shadow: 0 14px 34px rgba(0,0,0,.16);
}

form[data-kontakt] button[type="submit"].sww-button:active{
  transform: translateY(0);
  box-shadow: 0 8px 18px rgba(0,0,0,.12);
}

form[data-kontakt] button[type="submit"].sww-button:focus-visible{
  outline: none;
  box-shadow: 0 0 0 4px rgba(42,42,42,.18), 0 10px 26px rgba(0,0,0,.12);
}

/* Optional: falls .btn-lg zu groß wirkt */
form[data-kontakt] .btn-lg.sww-button{
  font-size: 1rem;
}

/* =============================================================================
   4) REVEAL – Unterstreichung erst NACH Klick (wenn Link vorhanden)
   Voraussetzung:
     - Trigger hat .kontakt-reveal
     - Textcontainer hat .kontakt-text
     - Nach Klick setzt dein JS ein <a> in .kontakt-text und fügt .revealed hinzu
============================================================================= */
.kontakt-reveal{
  cursor: pointer;
  color: inherit;
  text-decoration: none;
  outline: none;
}

.kontakt-reveal.revealed{
  cursor: default;
}

/* Wichtig: KEINE Unterstreichung vor dem Reveal */
.kontakt-reveal .kontakt-text,
.kontakt-reveal .kontakt-text a{
  text-decoration: none;
}

/* Erst wenn revealed: Link bekommt Unterstreichung NUR bei Hover/Focus */
.kontakt-reveal.revealed .kontakt-text a{
  color: inherit;
  text-decoration: none;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}

.kontakt-reveal.revealed .kontakt-text a:hover,
.kontakt-reveal.revealed .kontakt-text a:focus-visible{
  text-decoration: underline;
}

/* Tastatur-Fokus am Trigger selbst (dezent) */
.kontakt-reveal:focus-visible{
  outline: 2px solid rgba(42,42,42,.22);
  outline-offset: 3px;
  border-radius: 6px;
}

/* =============================================================================
   5) Screenreader helper
============================================================================= */
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* =============================================================================
   6) MODAL – Feedback (Bootstrap 5) – nur #kontaktModal
============================================================================= */

/* =========================
   Kontakt-Modal ohne Header
   ========================= */

#kontaktModal .modal-dialog{
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 .75rem;
}

#kontaktModal .modal-content{
  position: relative;
  background: rgba(255,255,255,.92);
  border: 1px solid var(--km-border, rgba(42,42,42,.14));
  border-radius: 18px;
  box-shadow: 0 22px 70px var(--km-shadow, rgba(0,0,0,.18));
  overflow: hidden;

  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}

/* Close oben rechts, ohne Header */
#kontaktModal .km-close{
  position: absolute;
  top: .75rem;
  right: .75rem;
  opacity: .75;
  border-radius: 999px;
  padding: .9rem;
  background-color: rgba(42,42,42,.06);
  transition: transform .15s ease, opacity .15s ease, background-color .15s ease, box-shadow .15s ease;
  z-index: 2;
}

#kontaktModal .km-close:hover{
  opacity: .95;
  background-color: rgba(42,42,42,.10);
  transform: translateY(-1px);
}

#kontaktModal .km-close:focus-visible{
  outline: none;
  box-shadow: 0 0 0 4px var(--km-focus, rgba(42,42,42,.14));
}

/* Body mit „Platz“ für Close-Button */
#kontaktModal .modal-body{
  padding: 1.25rem 1.25rem 1rem 1.25rem;
  padding-top: 2.25rem; /* Abstand, damit Close nicht in Text fällt */
}

#kontaktModalBody{
  color: var(--kontakt-ink, #2A2A2A);
  max-width: 54ch;
}

#kontaktModalBody p{
  margin: 0;
}

#kontaktModalBody p + p{
  margin-top: .35rem;
}

#kontaktModalBody p:first-child strong{
  display: block;
  margin: 0 0 .75rem 0;
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.15;
  font-size: clamp(1.35rem, 2vw, 1.7rem);
}

#kontaktModalBody p:nth-child(2){
  font-size: 1.05rem;
  line-height: 1.55;
  opacity: .92;
}

/* Footer ruhig, ohne Bootstrap-Rand */
#kontaktModal .km-footer{
  border: 0;
  padding: .75rem 1.25rem 1.25rem 1.25rem;
  justify-content: flex-start;
  gap: .75rem;
}

/* Backdrop cineastischer */
.modal-backdrop.show{
  opacity: .55;
}

/* Mobile */
@media (max-width: 420px){
  #kontaktModal .modal-content{
    border-radius: 14px;
  }
  #kontaktModal .modal-body{
    padding: 2.1rem 1rem 1rem 1rem;
  }
  #kontaktModal .km-footer{
    padding: .75rem 1rem 1rem 1rem;
  }
  #kontaktModal .km-close{
    top: .6rem;
    right: .6rem;
  }
}
