/* DAAB shared mobile / touch / cross-browser enhancements */

/* Nav height, safe-area, and touch tokens: css/daab-tokens.css (via daab-common.css) */

@media (max-width: 1180px) {:root{
    --daab-nav-height: 72px;
  }
}html{
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}body{
  padding-left: var(--daab-safe-left);
  padding-right: var(--daab-safe-right);
}html.daab-scroll-lock,
body.daab-scroll-lock{
  overscroll-behavior: none;
}body.daab-scroll-lock{
  overflow: hidden !important;
  touch-action: none;
}/* Fixed chrome + safe-area (heights synced in daab-mobile.js) */
body:not(.daab-gateway) > .nav-strip,
.nav-strip{
  padding-top: var(--daab-safe-top);
}.nav-inner{
  padding-left: max(10px, var(--daab-safe-left)) !important;
  padding-right: max(10px, var(--daab-safe-right)) !important;
}

/* Touch / tablet: tap-to-open dropdown when hover is unavailable */
@media (hover: none), (pointer: coarse) {.nav-dropdown.open .nav-dropdown-panel{
    display: flex !important;
  }.nav-dropdown-toggle{
    touch-action: manipulation;
  }
}.nav-search-btn,
.mobile-menu-toggle,
.search-close-btn,
.btn-clear,
.page-btn,
.sel-clear{
  touch-action: manipulation;
}

@media (max-width: 1180px) {.nav-search-btn{
    min-height: var(--daab-touch-min);
    padding: 10px 12px !important;
  }
}

/* iOS: prevent focus zoom on form controls */
@media (max-width: 1180px) {input,
  select,
  textarea,
  #search-input{
    font-size: max(16px, 1em);
  }
}/* Site search overlay — phones & tablets */
#search-overlay{
  padding-top: max(72px, calc(10vh + var(--daab-safe-top))) !important;
  padding-left: max(12px, var(--daab-safe-left)) !important;
  padding-right: max(12px, var(--daab-safe-right)) !important;
  padding-bottom: max(16px, var(--daab-safe-bottom)) !important;
  overscroll-behavior: contain;
}#search-overlay.open{
  -webkit-overflow-scrolling: touch;
}.search-modal{
  max-height: min(88dvh, calc(100dvh - 96px)) !important;
  display: flex !important;
  flex-direction: column !important;
}.search-results{
  max-height: min(50dvh, 420px) !important;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}

@media (max-width: 760px) {#search-overlay{
    align-items: stretch !important;
    padding-top: max(64px, calc(8px + var(--daab-safe-top))) !important;
  }.search-modal{
    width: 100% !important;
    max-width: 100% !important;
    border-radius: 20px 20px 0 0 !important;
    margin-top: auto;
    max-height: min(92dvh, calc(100dvh - 56px)) !important;
  }.search-input-row{
    padding: 0 16px !important;
  }.search-hint{
    display: none;
  }.sri-desc{
    white-space: normal;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }
}

/* Shared hero / panel patterns (index & catalogue pages) */
@media (max-width: 760px) {.hero-wrap,
  .hero-inner{
    padding-left: max(16px, var(--daab-safe-left)) !important;
    padding-right: max(16px, var(--daab-safe-right)) !important;
  }.panel-title{
    white-space: normal !important;
  }.hero-actions{
    flex-direction: column;
    align-items: stretch;
  }.hero-actions .btn{
    width: 100%;
  }.intro-card{
    padding: 20px 18px !important;
  }.cards-grid{
    grid-template-columns: 1fr !important;
    grid-template-rows: auto !important;
  }.join-banner{
    padding: 24px 18px !important;
    text-align: center;
  }.join-banner .btn{
    width: 100%;
  }
}

@media (max-width: 480px) {.hero h1,
  .hero-inner h1{
    font-size: clamp(18.2px, 5.95vw, 25.2px) !important;
    overflow-wrap: anywhere;
  }.hero-text,
  .hero-sub,
  .hero .panel-copy{
    font-size: 14px !important;
  }
}

/* Landscape phones: compact sticky chrome */
@media (max-width: 1180px) and (max-height: 500px) and (orientation: landscape) {.nav-inner{
    min-height: 52px !important;
    padding-top: 4px !important;
    padding-bottom: 4px !important;
  }.nav-menu{
    max-height: min(68dvh, calc(100dvh - var(--daab-nav-height, 52px) - 12px)) !important;
  }#search-overlay{
    padding-top: max(48px, var(--daab-safe-top)) !important;
  }
}/* Horizontal table scroll — visual affordance */
.table-scroll{
  scrollbar-width: thin;
  overscroll-behavior-x: contain;
  -webkit-overflow-scrolling: touch;
}

@media (max-width: 760px) {.table-scroll{
    margin: 0 -4px;
    padding-bottom: 4px;
  }.pagination{
    flex-wrap: wrap;
    gap: 8px;
    padding: 14px 12px !important;
  }.page-btn{
    min-height: var(--daab-touch-min);
    min-width: var(--daab-touch-min);
  }
}/* Foundation / activities lightbox */
.lightbox{
  padding: max(16px, var(--daab-safe-top)) max(16px, var(--daab-safe-right))
    max(16px, var(--daab-safe-bottom)) max(16px, var(--daab-safe-left)) !important;
  overscroll-behavior: contain;
}.lightbox img{
  max-height: min(85dvh, 90vh) !important;
  object-fit: contain;
}.lightbox-close{
  top: max(12px, var(--daab-safe-top)) !important;
  right: max(12px, var(--daab-safe-right)) !important;
  min-width: var(--daab-touch-min);
  min-height: var(--daab-touch-min);
}

/* Activities: avoid double-sticky header stack */
@media (max-width: 900px) {.page-hero{
    position: relative !important;
    top: auto !important;
  }.news-card{
    scroll-margin-top: calc(var(--daab-nav-height) + 1.5rem);
  }.content-wrap{
    padding-left: max(16px, var(--daab-safe-left));
    padding-right: max(16px, var(--daab-safe-right));
  }
}

/* Cross-page layout: prevent flex/grid overflow on narrow viewports */
.main,
.shell,
.content-grid,
.main-col,
.hero-inner,
.hero-copy,
.cards-grid > .card,
.cards-grid > .person-card,
.page-card{
  min-width: 0;
}

/* Long copy, URLs, and subtitles */
main .prose,
main .pf-profile-article,
.page-hero-subtitle,
.card-desc,
.card-name,
.source-links a,
.daab-breadcrumbs-current{
  overflow-wrap: anywhere;
  word-break: break-word;
}

.daab-breadcrumbs-list{
  row-gap: 6px;
}

main iframe,
main video,
main embed,
main object{
  max-width: 100%;
}

@media (max-width: 1180px) {
  .daab-prominent-figure-page .nav-person-link{
    min-height: var(--daab-touch-min);
  }

  .daab-prominent-figure-page .info-val{
    overflow-wrap: anywhere;
  }
}

@media (max-width: 760px) {
  .daab-prominent-figure-page .section-title{
    flex-wrap: wrap;
  }

  .daab-prominent-figure-page .quote-text{
    font-size: clamp(15px, 4.2vw, 18px);
  }

  .daab-prominent-figure-page .quote-block{
    padding: 22px 18px;
  }

  .toolbar .search-wrap{
    flex: 1 1 100%;
    min-width: 0;
  }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {html{
    scroll-behavior: auto;
  }.btn:hover,
  .page-card:hover,
  .card:hover,
  .news-card:hover{
    transform: none !important;
  }
}
