/* TGZ Mobile Optimization — app-achtige ervaring */

:root {
  --tgz-primary: #6EC1E4;
  --tgz-primary-dark: #4aa3cc;
  --tgz-accent: #61CE70;
  --tgz-purple: #7670A2;
  --tgz-dark: #54595F;
  --tgz-nav-height: 64px;
  --tgz-header-height: 70px;
  --safe-bottom: env(safe-area-inset-bottom, 0px);
}

/* ============================================
   GLOBAAL: Smooth scroll & touch optimalisatie
   ============================================ */
html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

* {
  -webkit-tap-highlight-color: rgba(110, 193, 228, 0.15);
  tap-highlight-color: rgba(110, 193, 228, 0.15);
}

/* Voorkom iOS zoom bij input focus */
@media screen and (max-width: 767px) {
  input, select, textarea {
    font-size: 16px !important;
  }
}

/* ============================================
   HEADER: Sticky app-achtige topbar op mobiel
   ============================================ */
@media screen and (max-width: 1199px) {
  #site-header-wrap #site-header {
    position: sticky !important;
    top: 0 !important;
    z-index: 1000 !important;
    background: #fff !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.10) !important;
    transition: box-shadow 0.25s ease !important;
  }

  body.admin-bar #site-header-wrap #site-header {
    top: 32px !important;
  }

  #site-header-wrap .site-header-main {
    min-height: var(--tgz-header-height) !important;
    padding: 0 16px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
  }

  /* Logo groter op mobiel */
  #site-header-wrap .site-branding {
    flex: 1 !important;
  }

  #site-header-wrap .site-branding img {
    max-height: 48px !important;
    width: auto !important;
  }

  /* Hamburger menu button — groter touch target */
  #main-menu-mobile .btn-nav-mobile {
    width: 48px !important;
    height: 48px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 10px !important;
    background: rgba(110, 193, 228, 0.10) !important;
    transition: background 0.2s !important;
  }

  #main-menu-mobile .btn-nav-mobile:active {
    background: rgba(110, 193, 228, 0.25) !important;
  }
}

/* ============================================
   SLIDE NAV (mobiel menu): App-achtige stijl
   ============================================ */
@media screen and (max-width: 1199px) {
  .slide-nav-wrapper {
    width: 85vw !important;
    max-width: 340px !important;
    border-radius: 0 !important;
    padding-top: calc(var(--tgz-header-height) + 8px) !important;
  }

  .slide-nav-wrapper ul.menu li a {
    padding: 14px 24px !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    border-bottom: 1px solid rgba(0,0,0,0.05) !important;
    min-height: 52px !important;
    display: flex !important;
    align-items: center !important;
    color: var(--tgz-dark) !important;
    transition: background 0.15s, color 0.15s !important;
  }

  .slide-nav-wrapper ul.menu li a:active,
  .slide-nav-wrapper ul.menu li a:hover {
    background: rgba(110, 193, 228, 0.10) !important;
    color: var(--tgz-primary-dark) !important;
  }

  /* Actieve pagina in menu */
  .slide-nav-wrapper ul.menu li.current-menu-item > a,
  .slide-nav-wrapper ul.menu li.current-page-ancestor > a {
    color: var(--tgz-primary-dark) !important;
    font-weight: 700 !important;
    border-left: 3px solid var(--tgz-primary) !important;
    padding-left: 21px !important;
  }
}

/* ============================================
   BOTTOM NAVIGATIE: App-achtige tab bar
   ============================================ */
#tgz-bottom-nav {
  display: none;
}

@media screen and (max-width: 767px) {
  #tgz-bottom-nav {
    display: flex !important;
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 9999 !important;
    background: #ffffff !important;
    border-top: 1px solid rgba(0,0,0,0.08) !important;
    box-shadow: 0 -4px 20px rgba(0,0,0,0.08) !important;
    padding-bottom: var(--safe-bottom) !important;
    height: calc(var(--tgz-nav-height) + var(--safe-bottom)) !important;
    align-items: stretch !important;
    justify-content: space-around !important;
  }

  #tgz-bottom-nav a {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 1 !important;
    gap: 4px !important;
    text-decoration: none !important;
    color: #aaa !important;
    font-size: 10px !important;
    font-weight: 500 !important;
    letter-spacing: 0.02em !important;
    padding: 8px 4px !important;
    transition: color 0.15s !important;
    -webkit-tap-highlight-color: transparent !important;
    position: relative !important;
  }

  #tgz-bottom-nav a:active {
    color: var(--tgz-primary-dark) !important;
    transform: scale(0.95) !important;
  }

  #tgz-bottom-nav a.active,
  #tgz-bottom-nav a.tgz-nav-active {
    color: var(--tgz-primary-dark) !important;
  }

  #tgz-bottom-nav a.active svg path,
  #tgz-bottom-nav a.tgz-nav-active svg path,
  #tgz-bottom-nav a.active svg rect,
  #tgz-bottom-nav a.tgz-nav-active svg rect {
    fill: var(--tgz-primary-dark) !important;
  }

  #tgz-bottom-nav svg {
    width: 24px !important;
    height: 24px !important;
    flex-shrink: 0 !important;
    transition: transform 0.15s !important;
  }

  #tgz-bottom-nav a:active svg {
    transform: scale(0.9) !important;
  }

  /* Ruimte onderaan body voor de bottom nav */
  body {
    padding-bottom: calc(var(--tgz-nav-height) + var(--safe-bottom)) !important;
  }

  /* Scroll-top button boven bottom nav */
  .scroll-top {
    bottom: calc(var(--tgz-nav-height) + var(--safe-bottom) + 16px) !important;
    right: 16px !important;
  }
}

/* ============================================
   KNOPPEN: Grotere touch targets, rounded
   ============================================ */
@media screen and (max-width: 767px) {
  .btn, button, input[type="submit"], input[type="button"],
  a.button, .wp-block-button__link,
  .elementor-button, .elementor-button-wrapper .elementor-button {
    min-height: 48px !important;
    padding: 12px 24px !important;
    border-radius: 12px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    letter-spacing: 0.02em !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: transform 0.12s, box-shadow 0.12s !important;
  }

  .btn:active, button:active, input[type="submit"]:active,
  .elementor-button:active {
    transform: scale(0.97) !important;
  }

  /* Primaire CTA knoppen */
  .elementor-button.elementor-size-sm,
  .elementor-button.elementor-size-md,
  .elementor-button.elementor-size-lg {
    min-height: 48px !important;
    padding: 12px 28px !important;
    border-radius: 12px !important;
  }
}

/* ============================================
   KAARTEN & SECTIES: Betere mobiele spacing
   ============================================ */
@media screen and (max-width: 767px) {
  .elementor-section .elementor-container {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .elementor-section-boxed > .elementor-container {
    max-width: 100% !important;
  }

  /* Kaart-achtige elementen */
  .elementor-widget-wrap {
    border-radius: 0 !important;
  }

  /* Service/team kaarten */
  .elementor-widget-image-box .elementor-image-box-wrapper,
  .elementor-widget-icon-box .elementor-icon-box-wrapper {
    padding: 20px 16px !important;
    border-radius: 16px !important;
    background: #fff !important;
    box-shadow: 0 2px 16px rgba(0,0,0,0.07) !important;
    transition: transform 0.2s, box-shadow 0.2s !important;
  }

  .elementor-widget-image-box .elementor-image-box-wrapper:active,
  .elementor-widget-icon-box .elementor-icon-box-wrapper:active {
    transform: scale(0.98) !important;
    box-shadow: 0 1px 8px rgba(0,0,0,0.10) !important;
  }

  /* Tekst leesbaarder op mobiel */
  .elementor-widget-text-editor p,
  .elementor-text-editor p,
  p {
    line-height: 1.7 !important;
  }

  h1, .elementor-heading-title.elementor-size-xxl {
    font-size: clamp(24px, 7vw, 38px) !important;
    line-height: 1.2 !important;
  }

  h2, .elementor-heading-title.elementor-size-xl {
    font-size: clamp(20px, 5.5vw, 30px) !important;
    line-height: 1.25 !important;
  }

  h3, .elementor-heading-title.elementor-size-large {
    font-size: clamp(17px, 4.5vw, 24px) !important;
  }
}

/* ============================================
   FORMULIEREN: App-achtige input stijlen
   ============================================ */
@media screen and (max-width: 767px) {
  input[type="text"],
  input[type="email"],
  input[type="tel"],
  input[type="password"],
  input[type="number"],
  input[type="search"],
  select,
  textarea {
    border-radius: 10px !important;
    border: 1.5px solid #e0e0e0 !important;
    padding: 14px 16px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    background: #fafafa !important;
    transition: border-color 0.2s, box-shadow 0.2s !important;
    appearance: none !important;
    -webkit-appearance: none !important;
  }

  input[type="text"]:focus,
  input[type="email"]:focus,
  input[type="tel"]:focus,
  textarea:focus {
    border-color: var(--tgz-primary) !important;
    box-shadow: 0 0 0 3px rgba(110, 193, 228, 0.20) !important;
    background: #fff !important;
    outline: none !important;
  }

  .gform_wrapper .gfield {
    margin-bottom: 16px !important;
  }

  .gform_footer input[type="submit"],
  .gform_footer button {
    width: 100% !important;
    max-width: 100% !important;
    background: var(--tgz-primary) !important;
    border: none !important;
    color: #fff !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    min-height: 54px !important;
    border-radius: 12px !important;
    box-shadow: 0 4px 16px rgba(110, 193, 228, 0.40) !important;
  }
}

/* ============================================
   AFBEELDINGEN: Responsive & crisp
   ============================================ */
@media screen and (max-width: 767px) {
  img {
    max-width: 100% !important;
    height: auto !important;
  }

  .elementor-widget-image img {
    border-radius: 12px !important;
  }
}

/* ============================================
   HERO SECTIE: Betere weergave op mobiel
   ============================================ */
@media screen and (max-width: 767px) {
  .elementor-section.elementor-section-height-full,
  section[data-settings*="height-full"] {
    min-height: 85vh !important;
    max-height: none !important;
  }

  /* Geen video achtergrond op mobiel = sneller */
  .elementor-bg-video-container {
    display: none !important;
  }
}

/* ============================================
   FOOTER: Compacter op mobiel
   ============================================ */
@media screen and (max-width: 767px) {
  #colophon .footer-inner,
  footer .footer-inner {
    padding: 32px 16px !important;
  }

  footer .widget_nav_menu ul {
    columns: 2 !important;
  }
}

/* ============================================
   SCROLL TOP BUTTON: Groter & zichtbaarder
   ============================================ */
.scroll-top {
  width: 48px !important;
  height: 48px !important;
  border-radius: 14px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--tgz-primary) !important;
  box-shadow: 0 4px 16px rgba(110, 193, 228, 0.40) !important;
  transition: transform 0.2s, box-shadow 0.2s !important;
}

.scroll-top:active {
  transform: scale(0.93) !important;
}

/* ============================================
   LOADING INDICATOR: App-achtig
   ============================================ */
@media screen and (max-width: 767px) {
  .page-loading {
    background: #fff !important;
  }

  .page-loading .loader {
    border-top-color: var(--tgz-primary) !important;
  }
}

/* ============================================
   WHATSAPP KNOP: Boven bottom nav plaatsen
   ============================================ */
@media screen and (max-width: 767px) {
  .ht-ctc-chat,
  #ht-ctc-chat,
  [class*="ht-ctc-chat"],
  [class*="ht_ctc_chat"] {
    bottom: calc(var(--tgz-nav-height) + var(--safe-bottom) + 12px) !important;
  }
}

/* ============================================
   ACCESSIBILITY: Focus stijlen voor touch
   ============================================ */
@media (pointer: coarse) {
  a:focus, button:focus, input:focus, select:focus, textarea:focus {
    outline: 2px solid var(--tgz-primary) !important;
    outline-offset: 2px !important;
  }
}

/* ============================================
   GEKLEURDE KOLOMMEN (sectie 38ef4d4):
   Hulp in uw taal / Telefonisch Advies / Rapportcijfer / Kwaliteit
   — witte icon-box kaart NIET toepassen; kolomachtergrond tonen
     zodat witte titels leesbaar blijven op paars/roze achtergrond
   ============================================ */
@media screen and (max-width: 767px) {
  .elementor-element-38ef4d4 .elementor-icon-box-wrapper {
    background: transparent !important;
    box-shadow: none !important;
    border-radius: 0 !important;
  }
}

/* ============================================
   ANIMATIES: Vertraag op low-motion voorkeur
   ============================================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ============================================
   EXTRA: Tablet tweaks (768–1199px)
   ============================================ */
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .elementor-section .elementor-container {
    padding-left: 24px !important;
    padding-right: 24px !important;
  }

  h1, .elementor-heading-title.elementor-size-xxl {
    font-size: clamp(28px, 4vw, 44px) !important;
  }
}
