/* =========================================================
   vb-theme-dark.css – Vectorbirds Tactical Dark Theme (CLEAN)
   TYPO3 12.4 + bootstrap_package / Pizpalue
   Version: V2.1 – 2026-02-11

   Inhalt:
   - Dark Canvas + Typo
   - Breadcrumb: dezent, grid-aligned
   - Kontaktformular (TYPO3 Form)
   - Google Maps Embed
   - Header/Navbar: Force Tactical Dark
   - USP (Textpic Above): Bilder zentrieren + skalieren
   - Footer: Tactical Dark (clean + stable, ohne Layout-Drift)
   ========================================================= */

/* =========================
   Root Variables
   ========================= */
:root{
  --vb-bg: #0B1020;
  --vb-surface: rgba(255,255,255,.04);
  --vb-border: rgba(255,255,255,.10);

  --vb-text: rgba(255,255,255,.88);
  --vb-text-muted: rgba(255,255,255,.66);

  /* Akzent bleibt als Link-Farbe */
  --vb-accent: #73be1f;
  --vb-accent-hover: #9BEA45;

  /* Footer */
  --vb-footer-bg: #171f33; /* alternativ: #232a3a */
}

/* =========================
   Canvas / Typography
   ========================= */
body{
  background: var(--vb-bg);
  color: var(--vb-text);
}

main, .bp-page-content{
  color: var(--vb-text);
}

p, li{
  color: var(--vb-text-muted);
  line-height: 1.65;
}

h1,h2,h3,h4{
  color: rgba(255,255,255,.94);
  letter-spacing: .01em;
}

/* Sections subtle */
.bp-page-content .section{ background: transparent; }
.bp-page-content .section:nth-of-type(even){ background: rgba(255,255,255,.02); }

/* =========================================================
   Breadcrumb – grid aligned + tactical
   ========================================================= */
nav.breadcrumb-section{
  padding-top: 18px !important;
  padding-bottom: 12px !important;
  background: transparent !important;
}

nav.breadcrumb-section > .container{
  display: flex;
  align-items: center;
}

nav.breadcrumb-section .breadcrumb{
  margin: 0 !important;
  background: rgba(255,255,255,.035) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 12px !important;
  padding: 10px 14px !important;
  box-shadow: 0 10px 22px rgba(0,0,0,.22) !important;
  backdrop-filter: blur(10px);
}

nav.breadcrumb-section .breadcrumb-item + .breadcrumb-item::before{
  color: rgba(255,255,255,.35) !important;
}

nav.breadcrumb-section .breadcrumb a{
  color: rgba(115,190,31,.92) !important;
  text-decoration: none !important;
}

nav.breadcrumb-section .breadcrumb a:hover{
  color: var(--vb-accent-hover) !important;
}

nav.breadcrumb-section .breadcrumb-item,
nav.breadcrumb-section .breadcrumb-item.active{
  color: rgba(255,255,255,.70) !important;
}

/* =========================================================
   Kontaktformular – Dark Theme Fix (TYPO3 Form Framework)
   ========================================================= */
.form-container {
  color: rgba(255,255,255,0.86);
}

.form-container h2 {
  color: rgba(255,255,255,0.92);
}

.form-container .form-label,
.form-container legend {
  color: rgba(255,255,255,0.78);
}

.form-container .required {
  color: rgba(255,255,255,0.70);
}

.form-container .form-control,
.form-container textarea.form-control,
.form-container select.form-control {
  background: rgba(255,255,255,0.045) !important;
  color: rgba(255,255,255,0.88) !important;
  border: 1px solid rgba(255,255,255,0.14) !important;
  border-radius: 10px;
  box-shadow: none !important;
}

.form-container .form-control::placeholder {
  color: rgba(255,255,255,0.45);
}

.form-container .form-control:focus {
  background: rgba(255,255,255,0.06) !important;
  border-color: rgba(255,255,255,0.22) !important;
  outline: none !important;
  box-shadow: 0 0 0 0.2rem rgba(255,255,255,0.06) !important;
}

.form-container input[type="file"].form-control {
  background: rgba(255,255,255,0.03) !important;
  color: rgba(255,255,255,0.78) !important;
}

.form-container input[type="file"].form-control::file-selector-button {
  background: rgba(255,255,255,0.10);
  color: rgba(255,255,255,0.90);
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: 8px;
  padding: 8px 12px;
  margin-right: 12px;
  cursor: pointer;
}

.form-container input[type="file"].form-control::file-selector-button:hover {
  background: rgba(255,255,255,0.14);
  border-color: rgba(255,255,255,0.20);
}

.form-container fieldset.form-element-radio {
  background: rgba(255,255,255,0.03) !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  border-radius: 14px;
  padding: 14px 14px 8px;
}

.form-container fieldset.form-element-radio legend {
  padding: 0 6px;
  margin-bottom: 10px;
  color: rgba(255,255,255,0.78) !important;
}

.form-container .form-check {
  margin-top: 8px;
}

.form-container .form-check-wrapping-label {
  display: flex;
  gap: 10px;
  align-items: flex-start;
}

.form-container .form-check-input {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  background-color: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.22);
  box-shadow: none !important;
}

.form-container .form-check-input:checked {
  background-color: rgba(255,255,255,0.22);
  border-color: rgba(255,255,255,0.35);
}

.form-container .form-check-label {
  color: rgba(255,255,255,0.72) !important;
  line-height: 1.35;
}

.form-container .form-actions .btn.btn-primary {
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.92);
  border-radius: 12px;
  padding: 10px 18px;
}

.form-container .form-actions .btn.btn-primary:hover {
  background: rgba(255,255,255,0.16);
  border-color: rgba(255,255,255,0.22);
}

/* =========================================================
   Google Maps Embed: responsive + optisch passend
   ========================================================= */
.frame-type-html iframe[src*="google.com/maps"]{
  width: 100% !important;
  max-width: 100%;
  height: 420px;
  border: 1px solid rgba(255,255,255,0.10) !important;
  border-radius: 14px;
  overflow: hidden;
}

@media (max-width: 767px){
  .frame-type-html iframe[src*="google.com/maps"]{
    height: 320px;
  }
}

/* =========================================================
   Vectorbirds – Header/Navbar: Force Tactical Dark
   Fix for bootstrap_package merged.css overriding navbar bg
   ========================================================= */
#page-header.bp-page-header.navbar,
#page-header.bp-page-header.navbar.navbar-mainnavigation {
  background-color: #171f33 !important; /* alternativ: #232a3a */
}

#page-header.bp-page-header::before,
#page-header.bp-page-header::after,
#page-header.bp-page-header.navbar::before,
#page-header.bp-page-header.navbar::after {
  background-color: #171f33 !important; /* alternativ: #232a3a */
  opacity: 1 !important;
}

#page-header .container-mainnavigation,
#page-header .navbar-collapse {
  background-color: transparent !important;
}

#page-header .nav-link,
#page-header .navbar-brand {
  color: rgba(255,255,255,0.88) !important;
}

/* =========================================================
   VB USP (Textpic Above): Bilder zentrieren + größer + einheitlich
   ========================================================= */
.textpic.textpic-above .textpic-gallery {
  display: flex;
  justify-content: center;
}

.textpic.textpic-above .gallery-row {
  display: flex;
  justify-content: center;
  align-items: stretch;
  gap: 22px;
  margin: 0 auto 18px auto;
  width: 100%;
}

.textpic.textpic-above .gallery-item {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 120px;
}

.textpic.textpic-above figure.image {
  margin: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

.textpic.textpic-above figure.image img {
  display: block;
  height: 110px;
  width: auto;
  max-width: 220px;
  object-fit: contain;
  border-radius: 14px;
}

/* =========================================================
   VB Footer – Tactical Dark (clean + stable)
   ========================================================= */

/* Outer footer wrappers */
footer,
#page-footer,
.bp-page-footer,
.page-footer,
.footer,
.footer-section,
.section-footer{
  background: var(--vb-footer-bg) !important;
  background-image: none !important;
}

/* If footer is wrapped in frames/containers, keep background consistent */
#page-footer .frame,
#page-footer .frame-group-container,
#page-footer .frame-group-inner,
#page-footer .frame-container,
#page-footer .frame-inner{
  background: transparent !important;
  background-image: none !important;
}

/* Kill overlays from merged.css (purely visual, no layout impact) */
footer, #page-footer, .bp-page-footer{
  position: relative;
}

footer::before, footer::after,
#page-footer::before, #page-footer::after,
.bp-page-footer::before, .bp-page-footer::after{
  position: absolute !important;
  inset: 0 !important;
  content: "" !important;
  background: var(--vb-footer-bg) !important;
  background-image: none !important;
  opacity: 1 !important;
  pointer-events: none !important;
  z-index: 0 !important;
}

footer > *, #page-footer > *, .bp-page-footer > *{
  position: relative;
  z-index: 1;
}

/* Main footer top section: Navigation | Contact */
.footer-menu-section{
  background: transparent !important;
  background-image: none !important;

  max-width: 1280px;
  margin: 0 auto;
  padding: 48px 24px;

  /* layout */
  display: grid !important;
  grid-template-columns: 1fr 360px; /* right contact column */
  gap: 48px;
  align-items: start;

  /* reset theme oddities */
  float: none !important;
  text-align: left !important;
}

.footer-menu-section .footer-navigation,
.footer-menu-section .footer-contact{
  float: none !important;
  text-align: left !important;
  min-width: 0;
}

/* Navigation: 1st level as grid columns */
.footer-navigation-list{
  list-style: none;
  margin: 0;
  padding: 0;
}

.footer-navigation-list-level-1{
  display: grid;
  grid-template-columns: repeat(3, minmax(180px, 1fr));
  gap: 18px 44px;
}

.footer-navigation-item-level-2{
  margin-top: 8px;
}

/* Contact typography */
.footer-contact-headline{
  margin-bottom: 12px;
  color: rgba(255,255,255,0.92) !important;
}

.footer-contact,
.footer-contact p,
.footer-contact a,
.footer-menu-section a,
.footer-info-section a,
.footer-menu-section,
.footer-info-section{
  color: rgba(255,255,255,0.88) !important;
}

.footer-menu-section a:hover,
.footer-info-section a:hover{
  color: var(--vb-accent-hover) !important;
}

/* Footer info section: meta, language, copyright, socials */
.footer-info-section{
  background: transparent !important;
  border-top: 1px solid rgba(255,255,255,0.10) !important;

  max-width: 1280px;
  margin: 0 auto;
  padding: 22px 24px 32px;
}

/* Align meta/lang/copyright nicer (centered stack like your screenshot) */
.footer-info-section{
  text-align: center;
}

.footer-info-section .meta-menu,
.footer-info-section .language-menu{
  list-style: none;
  margin: 0;
  padding: 0;
}

.footer-info-section .meta-menu{
  display: inline-flex;
  gap: 22px;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 14px;
}

.footer-info-section .language-menu{
  display: inline-flex;
  gap: 18px;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 14px;
}

.footer-sociallinks .bootstrappackageicon{
  color: rgba(255,255,255,0.88) !important;
}
.footer-sociallinks a:hover .bootstrappackageicon{
  color: var(--vb-accent-hover) !important;
}

/* Responsive */
@media (max-width: 1200px){
  .footer-navigation-list-level-1{
    grid-template-columns: repeat(2, minmax(180px, 1fr));
  }
}

@media (max-width: 992px){
  .footer-menu-section{
    grid-template-columns: 1fr !important;
  }
  .footer-navigation-list-level-1{
    grid-template-columns: repeat(2, minmax(180px, 1fr));
  }
}

@media (max-width: 576px){
  .footer-menu-section{
    padding: 36px 18px;
  }
  .footer-info-section{
    padding: 18px 18px 26px;
  }
  .footer-navigation-list-level-1{
    grid-template-columns: 1fr;
  }
}
