/*
Theme Name: Happy Hippo Turnierservice (v6)
Theme URI: https://happy-hippo-turnierservice.de/
Author: Nova (ChatGPT) – für Thomas
Description: v6: Slider über Customizer/Mediathek (bis 9 Bilder) + Termine-Schriftgrößen + Termin-Button-Größe + Editor-Zeilenabstand/Abstände.
Version: 6.0.1
Requires at least: 6.0
Tested up to: 6.5
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: happy-hippo-turnierservice
*/

/* =========
   Basis
   ========= */
:root{
  --hh-blue:#000066;
  --hh-white:#ffffff;
  --hh-text-soft: rgba(255,255,255,.85);

  --hh-card: rgba(255,255,255,.12);
  --hh-card-strong: rgba(255,255,255,.18);
  --hh-border: rgba(255,255,255,.18);

  --hh-radius: 18px;
  --hh-shadow: 0 10px 30px rgba(0,0,0,.18);

  --hh-max: 1200px;
  --hh-gap: 18px;

  --hh-logo-desktop: 560px;
  --hh-logo-mobile: 360px;
}

html{ box-sizing:border-box; }
*, *::before, *::after{ box-sizing:inherit; }

body{
  margin:0;
  background: var(--hh-blue);
  color: var(--hh-white);
  font-family: Arial, sans-serif;

  /* B) komfortabel wie News-Seiten – aber mit sicheren Grenzen */
  font-size: clamp(17px, 0.6vw + 14px, 24px);
  line-height: 1.7;
}

a{ color: var(--hh-white); }
a:focus-visible{ outline: 2px solid var(--hh-white); outline-offset: 2px; }

.hh-wrap{
  width: min(var(--hh-max), 100%);
  margin: 0 auto;
  padding: 18px 14px 30px;
}

/* Für lange Texte: Zeilen nicht zu lang */
.hh-content p,
.hh-content li{
  max-width: 75ch;
}

/* =========
   Typografie
   ========= */
h1,h2,h3,h4,h5,h6{
  margin: 0 0 0.6em 0;
  line-height: 1.15;
}

h1{ font-size: clamp(32px, 1.6vw + 18px, 54px); }
h2{ font-size: clamp(26px, 1.2vw + 16px, 40px); }
h3{ font-size: clamp(20px, 0.9vw + 14px, 30px); }

p{ margin: 0 0 1em 0; }

/* =========
   Header / Navigation
   ========= */
.hh-header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--hh-blue);
  border-bottom: 1px solid rgba(255,255,255,.15);
}

.hh-nav{
  width: min(var(--hh-max), 100%);
  margin: 0 auto;
  padding: 10px 14px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
}

.hh-skip-link{
  position: absolute;
  left: -9999px;
  top: auto;
  width: 1px; height: 1px;
  overflow: hidden;
}
.hh-skip-link:focus{
  left: 14px;
  top: 14px;
  width: auto; height: auto;
  padding: 10px 12px;
  background: rgba(255,255,255,.15);
  border-radius: 12px;
}

.hh-burger{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 46px;
  height: 46px;
  border: 1px solid rgba(255,255,255,.35);
  background: transparent;
  color: var(--hh-white);
  border-radius: 12px;
  cursor: pointer;
}

.hh-burger span[aria-hidden="true"]{
  display:block;
  width: 18px;
  height: 2px;
  background: var(--hh-white);
  position: relative;
}
.hh-burger span[aria-hidden="true"]::before,
.hh-burger span[aria-hidden="true"]::after{
  content:"";
  position:absolute;
  left:0;
  width: 18px;
  height: 2px;
  background: var(--hh-white);
}
.hh-burger span[aria-hidden="true"]::before{ top:-6px; }
.hh-burger span[aria-hidden="true"]::after{ top:6px; }

.hh-menu-wrap{
  display: flex;
  align-items: center;
  gap: 12px;
}

.hh-menu{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  gap: 12px;
  align-items:center;
  flex-wrap: wrap;
}
.hh-menu a{
  text-decoration:none;
  padding: 10px 8px;
  display:inline-block;
  border-radius: 10px;
}
.hh-menu a:hover{
  background: rgba(255,255,255,.10);
}


/* When the mobile menu is open, add a subtle dim / blur layer behind it */
body.hh-menu-open{
  overflow: hidden;
}
body.hh-menu-open::before{
  content:"";
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.18);
  z-index: 48;
}

@media (max-width: 920px){
  /* Floating / glass mobile menu (wie v5.4/v5.5 – ohne unscharfen Hintergrund) */
  .hh-menu-wrap{
    position: fixed;
    top: 76px;
    left: 16px;
    right: 16px;
    width: auto;
    max-width: 480px;
    margin: 0;
    background: rgba(24, 52, 150, .50);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: 0 10px 30px rgba(0,0,0,.35);
    border-radius: 20px;
    padding: 14px;
    max-height: calc(100vh - 110px);
    overflow: auto;
    backdrop-filter: blur(3.5px);
    -webkit-backdrop-filter: blur(3.5px);
    display: none;
  }
  body.hh-menu-open .hh-menu-wrap{ display: block; }

  /* In der mobilen Flyout-Ansicht soll das Menü als Liste (untereinander) erscheinen */
  .hh-menu{
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 0;
  }
  .hh-menu li{ width: 100%; }
  .hh-menu ul{ list-style: none; margin: 0; padding: 0; }

  /* Jeder Menüpunkt als “Card” wie bei den Termin-Kacheln */
  .hh-menu a{
    display: flex;
    align-items: center;
    width: 100%;
    padding: 16px 18px;
    margin: 10px 0;
    font-size: 1.12em;
    font-weight: 600;
    color: #fff;
    text-decoration: none;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 16px;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.06);
  }
  .hh-menu a:hover,
  .hh-menu a:focus-visible{
    background: rgba(255,255,255,.12);
  }
}


/* =========
   Logo
   ========= */
.hh-logo-wrap{
  background: var(--hh-blue);
  display:flex;
  justify-content:center;
  align-items:center;
  padding: 18px 0 8px;
}

.hh-logo-link{ display:inline-flex; align-items:center; line-height: 0; }
.hh-logo-img, .custom-logo{
  max-width: min(var(--hh-logo-desktop, 560px), 90vw);
  height: auto;
  display:block;
}

@media (max-width: 600px){
  .hh-logo-img, .custom-logo{ max-width: min(var(--hh-logo-mobile, 360px), 86vw); }
}

/* =========
   Content
   ========= */
.hh-content{
  width: min(var(--hh-max), 100%);
  margin: 0 auto;
  padding: 0 14px;
}

.hh-card{
  background: var(--hh-card);
  border: 1px solid var(--hh-border);
  border-radius: var(--hh-radius);
  box-shadow: var(--hh-shadow);
  padding: 16px 18px;
}

.hh-muted{ color: var(--hh-text-soft); }

/* =========
   Slider (Startseite)
   ========= */
.hh-slider{
  border-radius: var(--hh-radius);
  border: 1px solid rgba(255,255,255,.15);
  overflow: hidden;
  background: rgba(255,255,255,.06);
}

.hh-slider-frame{
  position: relative;
}

.hh-slide{
  margin:0;
  display:none;
}

.hh-slide.is-active{ display:block; }

.hh-slide img{
  width: 100%;
  height: auto;
  display: block;
}

/* =========
   Termine
   ========= */
/* Schriftgrößen für Termine (über Customizer) */
.hh-termine-free{ font-size: var(--hh-termine-font-open, 16px); }
.hh-termin-row{ font-size: var(--hh-termine-font-booked, 16px); }

.hh-termine-free.hh-card{
  background: var(--hh-card-strong);
  margin-bottom: 18px;
}

.hh-termine-list{
  display:flex;
  flex-direction:column;
  gap: 18px;
}

.hh-termin-row.hh-card{
  display:grid;
  grid-template-columns: 1.1fr 1fr 2fr;
  gap: 16px;
  align-items: center;
}

.hh-termin-date .hh-date{
  font-weight: 800;
  font-size: 1.05em;
}
.hh-termin-date .hh-ort{
  font-weight: 800;
  opacity: .95;
}

.hh-termin-desc{
  color: var(--hh-text-soft);
  font-weight: 700;
  line-height: 1.35;
  white-space: pre-line;
}

/* PNG Buttons */
.hh-termin-actions{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px 12px;
  justify-items: stretch;
}

.hh-linkbtn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #ffffff;
  border-radius: 10px;
  /* Höhe/Größe per Customizer steuerbar (v6) */
  min-height: var(--hh-termin-btn-height, 34px);
  padding: 0 10px;
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: 0 6px 14px rgba(0,0,0,0.12);
  transition: transform .12s ease, box-shadow .12s ease;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
}

.hh-linkbtn:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(0,0,0,0.16);
}

.hh-linkbtn img{
  display:block;
  /* Icon-Höhe per Customizer steuerbar (v6) */
  height: var(--hh-termin-btn-icon, clamp(24px, 0.9vw + 18px, 34px));
  width: auto;
  max-width: 100%;
}

.hh-linkbtn.is-disabled{
  opacity: 0.45;
  filter: grayscale(1);
  cursor: not-allowed;
  pointer-events: none;
}

/* Responsive Termine */
@media (max-width: 980px){
  .hh-termin-row.hh-card{
    grid-template-columns: 1fr;
    align-items: start;
  }
  .hh-termin-actions{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-items: stretch;
  }
  .hh-linkbtn{
    justify-content: center;
    width: 100%;
  }
}

/* =========
   Kontaktformular
   ========= */
.hh-form{ max-width: 980px; margin: 24px auto 0; }
.hh-form-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.hh-field-full{ grid-column: 1 / -1; }

.hh-field label{ display:block; margin-bottom: 6px; font-weight: 800; }
.hh-field input,
.hh-field textarea{
  width: 100%;
  padding: 12px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.45);
  background: rgba(255,255,255,.08);
  color: #fff;
  font: inherit;
}

.hh-field input:focus-visible,
.hh-field textarea:focus-visible{
  outline: 2px solid rgba(255,255,255,.85);
  outline-offset: 2px;
}

.hh-form-actions{
  display:flex;
  align-items:center;
  gap: 16px;
  margin-top: 16px;
  flex-wrap: wrap;
}

.hh-btn{
  padding: 12px 18px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.75);
  background: rgba(255,255,255,.12);
  color: #fff;
  cursor: pointer;
  font-weight: 800;
}

.hh-btn:hover{ background: rgba(255,255,255,.18); }

.hh-alert{
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.4);
  margin: 16px 0;
}
.hh-alert-success{ background: rgba(255,255,255,.10); }
.hh-alert-error{ background: rgba(255,0,0,.15); border-color: rgba(255,255,255,.6); }

@media (max-width: 720px){
  .hh-form-grid{ grid-template-columns: 1fr; }
}

/* Honeypot (Spam-Schutz): unsichtbar */
.hh-hp{ position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; }

/* =========
   Footer
   ========= */
.hh-footer{
  border-top: 1px solid rgba(255,255,255,.15);
  padding: 20px 14px 28px;
}

.hh-footer-inner{
  width: min(var(--hh-max), 100%);
  margin: 0 auto;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap: 12px;
}

.hh-footer-links{
  display:flex;
  gap: 16px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  text-align:center;
}

.hh-social{
  display:flex;
  gap: 10px;
  align-items:center;
  justify-content:center;
}

.hh-social a{
  width: 44px;
  height: 44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border: 1px solid rgba(255,255,255,.4);
  border-radius: 999px;
  text-decoration:none;
}

.hh-social a:hover{ background: rgba(255,255,255,.10); }

.hh-icon{ width: 22px; height: 22px; fill: currentColor; }

/* Gutenberg helpers */
.wp-block-image img{ border-radius: 12px; }
.wp-block-columns{ gap: var(--hh-gap); }


/* =========
   Über Uns / Service – schöne 3-Spalten Optik (trotz dynamischem Editor)
   ========= */
.hh-cols3{
  gap: 16px;
  max-width: var(--hh-max);
  margin-left: auto;
  margin-right: auto;
}

.hh-cols3 .wp-block-column{
  text-align: center;
}

.hh-cols3 .wp-block-image img{
  width: 100%;
  max-width: 260px;
  aspect-ratio: 3/4;
  object-fit: cover;
  margin-left: auto;
  margin-right: auto;
}

.hh-cols3 h2{
  margin-top: 12px;
  margin-bottom: 10px;
}

.hh-service-cols .wp-block-column{
  text-align: center;
}

.hh-service-cols ul{
  text-align: left;
  display: inline-block;
  margin: 10px auto 0;
}