.photosPageMain{
  min-height:100vh;
  display:flex;
  justify-content:center;
  align-items:flex-start;
  padding:calc(var(--navH) + 38px) 0 75px;
  background:var(--surface--photo-stage, #5a2a8a);
}

#siteFooter.single2Section,
#siteFooter.single2Section > .single2FooterMain{
  background:var(--surface--photo-stage, #5a2a8a) !important;
}

html[data-color-scheme]:not([data-color-scheme="default"]) .photosPageMain,
html[data-color-scheme]:not([data-color-scheme="default"]) #siteFooter.single2Section,
html[data-color-scheme]:not([data-color-scheme="default"]) #siteFooter.single2Section > .single2FooterMain{
  background:var(--surface--scheme-stage-flat, var(--surface--photo-stage, #5a2a8a)) !important;
}

.photosFrame{
  min-height:0;
  padding:26px;
  margin-top:0;
  width:min(80vw, calc(100% - 150px));
  margin-left:auto;
  margin-right:auto;
  border-radius:34px;
  border:1px solid rgba(255,255,255,.12);
  background:var(--surface--photo-frame, linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.015)));
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.025),
    0 20px 56px rgba(0,0,0,.24) !important;
}

.photosFrame::before{
  background:none !important;
}

.photosFrame::after{
  background:var(--surface--photo-sheen,
    linear-gradient(90deg, rgba(22,78,129,.16) 0%, rgba(8,15,23,.08) 32%, rgba(8,15,23,.08) 68%, rgba(22,78,129,.16) 100%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01))) !important;
}

.photosContent{
  position:relative;
  z-index:2;
  width:min(92%, 1520px);
  margin-inline:auto;
  padding-bottom:44px;
}

.photosSectionIntro{
  width:min(1265px, 100%);
  margin:0 0 24px;
  color:rgba(255,255,255,.9);
  text-align:left;
  font-size:clamp(13px, 1.05vw, 18px);
  line-height:1.48;
  font-weight:400;
}

.photosSectionOutro{
  width:min(1265px, 100%);
  margin:24px 0 0;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:18px;
}

.photosSectionOutro .photosSectionIntro{
  margin:0;
}

.photosSectionSupport{
  width:min(1265px, 100%);
  display:flex;
  flex-direction:column;
  gap:14px;
}

.photosSectionSupportList{
  margin:0;
  padding-left:1.2em;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px 36px;
}

.photosSectionSupportList li{
  margin:0;
  color:rgba(255,255,255,.9);
  font-size:clamp(10px, 0.96vw, 16px);
  line-height:1.42;
  white-space:nowrap;
  letter-spacing:-.01em;
}

.photosSectionCta{
  text-decoration:none;
  padding:14px 24px;
  border-radius:999px;
  font-family:inherit;
  font-size:15px;
  font-weight:700;
  line-height:1.2;
  transition:transform .25s ease, background .25s ease, border-color .25s ease, color .25s ease;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  align-self:flex-start;
  margin-left:calc(50% + 28px);
  min-width:320px;
  letter-spacing:.01em;
  color:#ffffff;
  background:var(--menu-bar-bg) !important;
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 10px 26px rgba(0,0,0,.18);
}

.photosSectionCta:hover,
.photosSectionCta:focus-visible{
  transform:translateY(-1px);
  background:var(--menu-bar-bg) !important;
  border-color:rgba(255,255,255,.32);
}

.photosGalleryFrame{
  width:100%;
  margin:0 auto;
  padding:10px;
  border:2px solid rgba(255,255,255,.88);
  border-radius:14px;
  background:var(--surface--media-frame, linear-gradient(180deg, rgba(3,7,12,.96), rgba(4,8,14,.94)));
  box-shadow:0 24px 72px rgba(0,0,0,.62);
  overflow:hidden;
}

.photosTopRow{
  --photos-pane-h:auto;
  display:grid;
  grid-template-columns:minmax(0, 1fr) clamp(210px, 18vw, 285px);
  gap:14px;
  margin-top:0;
  align-items:start;
}

.photosMainPane,
.photoCategoryRail{
  min-width:0;
  min-height:0;
  height:var(--photos-pane-h);
  max-height:var(--photos-pane-h);
}

.photosMainPane{
  position:relative;
  border:1px solid rgba(255,255,255,.24);
  border-radius:14px;
  background:var(--surface--media-pane, rgba(4,7,12,.92));
  box-shadow:0 14px 38px rgba(0,0,0,.42);
  overflow:hidden;
}

.photoWall{
  height:100%;
  overflow-y:auto;
  overflow-x:hidden;
  background:#000;
  padding:6px;
  display:flex;
  flex-direction:column;
  gap:6px;
}

.photoRow{
  height:80px;
  display:flex;
  gap:6px;
}

.photoTile{
  margin:0;
  min-width:0;
  border:1px solid rgba(255,255,255,.14);
  overflow:hidden;
  background:#0b1220;
  cursor:pointer;
  padding:0;
  appearance:none;
}

.photoTile:focus-visible{
  outline:2px solid rgba(255,255,255,.55);
  outline-offset:1px;
}

.photoTile.is-hidden{
  opacity:.58;
  position:relative;
}

.photoTile.is-hidden::after{
  content:"Hidden";
  position:absolute;
  right:6px;
  top:6px;
  padding:2px 7px;
  border-radius:999px;
  background:rgba(0,0,0,.78);
  border:1px solid rgba(255,255,255,.28);
  color:rgba(255,255,255,.92);
  font-size:10px;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
}

.photoTile img{
  display:block;
  width:100%;
  height:100%;
  object-fit:contain;
}

.photoWallEmpty{
  margin:24px;
  font-size:14px;
  color:rgba(255,255,255,.8);
}

.photoWall::-webkit-scrollbar{
  width:8px;
}

.photoWall::-webkit-scrollbar-thumb{
  border-radius:999px;
  background:rgba(255,255,255,.24);
}

.photoCategoryRail{
  border:1px solid rgba(255,255,255,.24);
  border-radius:14px;
  background:var(--surface--media-pane, rgba(6,10,16,.88));
  display:flex;
  flex-direction:column;
  overflow:hidden;
}

.photoCategoryRailHeading{
  margin:0;
  padding:10px 12px 8px;
  border-bottom:1px solid rgba(255,255,255,.22);
  font-size:23px;
  line-height:1.05;
  letter-spacing:.03em;
  text-align:center;
  color:rgba(255,255,255,.9);
}

.photoCategoryListFrame{
  position:relative;
  flex:1;
  min-height:0;
  overflow:hidden;
  padding-right:10px;
}

.photoCategoryList{
  height:100%;
  overflow-y:auto;
  overflow-x:hidden;
  padding:0 2px 0 8px;
  display:flex;
  flex-direction:column;
  gap:0;
  scrollbar-width:none;
  -ms-overflow-style:none;
}

.photoCategoryList::-webkit-scrollbar{
  width:0;
  height:0;
}

.photoCategoryScrollTrack{
  position:absolute;
  top:6px;
  bottom:6px;
  right:2px;
  width:6px;
  border-radius:999px;
  background:rgba(255,255,255,.18);
  pointer-events:auto;
  opacity:.55;
}

.photoCategoryScrollThumb{
  width:100%;
  height:36px;
  border-radius:999px;
  background:linear-gradient(180deg, #00d2ff, #00a7dd);
  box-shadow:0 0 0 1px rgba(255,255,255,.14);
  transform:translateY(0);
  cursor:grab;
  touch-action:none;
}

.photoCategoryScrollThumb.is-dragging{
  cursor:grabbing;
}

.photoCategoryItem{
  width:100%;
  border:none;
  border-bottom:1px solid rgba(255,255,255,.22);
  background:transparent;
  color:inherit;
  display:grid;
  grid-template-columns:minmax(92px, 140px) minmax(0, 1fr);
  align-items:center;
  gap:10px;
  text-align:left;
  cursor:pointer;
  padding:8px 0;
}

.photoCategoryItem:hover,
.photoCategoryItem:focus-visible{
  background:rgba(255,255,255,.04);
}

.photoCategoryItem.is-active{
  background:rgba(255,255,255,.07);
}

.photoCategoryThumbWrap{
  position:relative;
  display:block;
  width:100%;
  max-width:140px;
  margin-inline:0;
}

.photoCategoryThumb{
  display:block;
  width:100%;
  aspect-ratio:16 / 9;
  object-fit:cover;
  border:1px solid rgba(255,255,255,.18);
  background:#060910;
  transition:border-color .15s ease, box-shadow .15s ease;
}

.photoCategoryItemText{
  font-size:clamp(12px, .82vw, 15px);
  line-height:1.2;
  font-weight:700;
  color:rgba(255,255,255,.94);
}

.photoCategoryItem.is-active .photoCategoryThumb{
  border-color:rgba(56,189,248,.88);
  box-shadow:0 0 0 2px rgba(56,189,248,.35);
}


.photoLightbox{
  position:fixed;
  inset:0;
  z-index:160;
  display:grid;
  place-items:center;
  padding:0;
  background:rgba(0,0,0,.9);
  backdrop-filter:blur(3px);
}

.photoLightbox.is-hidden{
  display:none;
}

.photoLightboxDialog{
  width:min(1180px, 93vw);
  max-width:93vw;
  height:min(960px, calc(100vh - 18px));
  max-height:calc(100vh - 18px);
  overflow:hidden;
  position:relative;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.24);
  background:linear-gradient(180deg, rgba(3,7,12,.96), rgba(4,8,14,.94));
  box-shadow:0 24px 72px rgba(0,0,0,.62);
  padding:0;
  display:flex;
  flex-direction:column;
  transform:translateY(-22px);
  --photo-overlay-inset-x:0px;
  --photo-overlay-inset-y:0px;
  --photo-overlay-gap:14px;
  --photo-description-overlay-h:108px;
}

.photoLightboxClose{
  position:absolute;
  top:auto;
  bottom:14px;
  right:14px;
  left:auto;
  width:38px;
  height:38px;
  border:1px solid rgba(255,255,255,.42);
  border-radius:999px;
  background:rgba(0,0,0,.5);
  color:rgba(255,255,255,.96);
  font-size:26px;
  font-weight:300;
  line-height:1;
  display:grid;
  place-items:center;
  padding:0;
  cursor:pointer;
  z-index:14;
}

.photoLightboxFullscreen{
  position:absolute;
  right:14px;
  left:auto;
  top:14px;
  bottom:auto;
  width:38px;
  height:38px;
  border:1px solid rgba(255,255,255,.42);
  border-radius:999px;
  background:rgba(0,0,0,.5);
  color:rgba(255,255,255,.96);
  line-height:1;
  display:grid;
  place-items:center;
  cursor:pointer;
  z-index:6;
}

.photoLightboxFullscreen svg{
  width:16px;
  height:16px;
  display:block;
}

.photoLightboxFullscreen svg path,
.photoLightboxFullscreen svg line,
.photoLightboxFullscreen svg polyline{
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.photoLightboxFullscreen:hover{
  background:rgba(0,0,0,.5);
  border-color:rgba(255,255,255,.7);
}

.photoLightboxFullscreen.is-active{
  border-color:rgba(56,189,248,.88);
  box-shadow:0 0 0 2px rgba(56,189,248,.38);
}

.photoLightboxClose:hover{
  background:rgba(0,0,0,.5);
  border-color:rgba(255,255,255,.7);
}

#photoLightboxClose{
  right:14px !important;
  left:auto !important;
  top:auto !important;
  bottom:14px !important;
}

@media (max-width:900px){
  #photoLightboxClose{
    right:10px !important;
    left:auto !important;
    top:auto !important;
    bottom:10px !important;
  }
}

@media (max-width:720px){
  .photoLightboxDialog:fullscreen #photoLightboxFullscreen,
  .photoLightboxDialog:-webkit-full-screen #photoLightboxFullscreen{
    right:8px;
    left:auto;
    top:8px;
    bottom:auto;
  }

  #photoLightboxClose{
    right:8px !important;
    left:auto !important;
    top:auto !important;
    bottom:8px !important;
  }

  .photoLightboxClose{
    display:grid;
    top:auto;
    bottom:8px;
    right:8px;
    left:auto;
    z-index:12;
  }
}

.photoLightboxClose:focus-visible,
.photoLightboxNav:focus-visible,
.photoLightboxFullscreen:focus-visible{
  outline:2px solid rgba(255,255,255,.78);
  outline-offset:2px;
}

.photoLightboxStage{
  position:relative;
  width:100%;
  flex:1 1 auto;
  min-height:0;
  aspect-ratio:auto;
  margin:0;
  display:block;
  background:#000;
}

.photoLightboxNav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:40px;
  height:40px;
  border:1px solid rgba(255,255,255,.36);
  border-radius:999px;
  background:rgba(0,0,0,.5);
  color:rgba(255,255,255,.96);
  font-size:22px;
  line-height:1;
  cursor:pointer;
  z-index:5;
}

#photoLightboxPrev{
  left:14px;
}

#photoLightboxNext{
  right:14px;
}

.photoLightboxNav:hover{
  background:rgba(0,0,0,.5);
}

.photoLightboxMediaFrame{
  width:100%;
  height:100%;
  max-width:none;
  max-height:none;
  aspect-ratio:auto;
  border:none;
  background:#000;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  margin:0;
  padding:0;
  box-sizing:border-box;
  position:relative;
  user-select:none;
  -webkit-user-select:none;
  -webkit-touch-callout:none;
}

.photoLightbox--blurred-frame .photoLightboxBackdrop{
  position:absolute;
  inset:-7%;
  width:114%;
  height:114%;
  object-fit:cover;
  filter:blur(30px) brightness(.72) saturate(.98);
  transform:translateZ(0);
  opacity:1;
  z-index:1;
  pointer-events:none;
  user-select:none;
  -webkit-user-select:none;
  -webkit-user-drag:none;
  -webkit-touch-callout:none;
}

.photoLightbox--blurred-frame .photoLightboxMediaFrame::after{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.09);
  z-index:2;
  pointer-events:none;
}

.photoLightboxImagePreview,
.photoLightboxImage{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  background:#000;
  display:block;
  margin:0;
  pointer-events:none;
  user-select:none;
  -webkit-user-select:none;
  -webkit-user-drag:none;
  -webkit-touch-callout:none;
}

.photoLightboxImagePreview{
  z-index:2;
  opacity:1;
  transition:opacity .34s ease;
}

.photoLightboxImagePreview.is-hidden{
  opacity:0;
}

.photoLightboxImage{
  z-index:3;
  opacity:1;
  transition:opacity .34s ease;
}

.photoLightbox--blurred-frame .photoLightboxImagePreview{
  z-index:3;
  background:transparent;
}

.photoLightbox--blurred-frame .photoLightboxImage{
  z-index:4;
  background:transparent;
}

.photoLightboxImage.is-loading{
  opacity:0;
}

.photoLightboxDialog:fullscreen,
.photoLightboxDialog:-webkit-full-screen{
  width:100vw;
  max-width:none;
  height:100vh;
  max-height:none;
  border-radius:0;
  border:none;
  box-shadow:none;
  transform:none;
  background:#000;
}

.photoLightboxDialog:fullscreen .photoLightboxStage,
.photoLightboxDialog:-webkit-full-screen .photoLightboxStage{
  flex:1 1 auto;
  height:100%;
  aspect-ratio:auto;
}

.photoLightboxDialog:fullscreen .photoLightboxDescriptionFrame,
.photoLightboxDialog:-webkit-full-screen .photoLightboxDescriptionFrame{
  display:none;
}


.photoLightboxDialog:fullscreen #photoLightboxFullscreen,
.photoLightboxDialog:-webkit-full-screen #photoLightboxFullscreen{
  display:grid !important;
  visibility:visible;
  opacity:1;
  right:14px;
  left:auto;
  bottom:14px;
}

.photoLightboxDialog:fullscreen .photoLightboxImagePreview,
.photoLightboxDialog:-webkit-full-screen .photoLightboxImagePreview,
.photoLightboxDialog:fullscreen .photoLightboxImage,
.photoLightboxDialog:-webkit-full-screen .photoLightboxImage{
  object-fit:contain;
  background:#000;
}

.photoLightbox--blurred-frame .photoLightboxDialog:fullscreen .photoLightboxImagePreview,
.photoLightbox--blurred-frame .photoLightboxDialog:-webkit-full-screen .photoLightboxImagePreview,
.photoLightbox--blurred-frame .photoLightboxDialog:fullscreen .photoLightboxImage,
.photoLightbox--blurred-frame .photoLightboxDialog:-webkit-full-screen .photoLightboxImage{
  background:transparent;
}

.photoLightboxImageCopyright{
  position:absolute;
  right:74px;
  bottom:18px;
  margin:0;
  padding:0;
  border:none;
  background:none;
  font-size:11px;
  line-height:1.2;
  font-weight:500;
  color:rgba(255,255,255,.92);
  text-shadow:0 1px 2px rgba(0,0,0,.78);
  z-index:6;
  pointer-events:none;
}

.photoLightboxDescriptionFrame{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  z-index:5;
  width:auto;
  border-top:none;
  background:none;
  backdrop-filter:none;
  padding:14px 20px 24px;
  height:var(--photo-description-overlay-h);
  min-height:var(--photo-description-overlay-h);
  max-height:var(--photo-description-overlay-h);
  box-sizing:border-box;
  display:flex;
  flex-direction:column;
  gap:4px;
  overflow:hidden;
  pointer-events:auto;
}

.photoLightboxDescriptionDisplay.is-scroll-cued::after{
  content:"... more";
  position:absolute;
  right:14px;
  bottom:0;
  padding-left:10px;
  font-size:11px;
  line-height:1.1;
  letter-spacing:.03em;
  font-weight:700;
  color:rgba(255,255,255,.92);
  background:linear-gradient(90deg, rgba(1,3,7,0), rgba(1,3,7,.96) 44%);
  text-shadow:0 1px 2px rgba(0,0,0,.75);
  pointer-events:none;
}

.photoLightboxDialog.is-edit-mode .photoLightboxDescriptionFrame{
  position:static;
  width:100%;
  border-top:1px solid rgba(255,255,255,.18);
  background:rgba(1,3,7,.94);
  backdrop-filter:none;
  padding:8px 12px;
  height:232px;
  min-height:232px;
  max-height:232px;
}

.photoLightboxDescriptionFrame h3{
  margin:0;
  font-size:22px;
  line-height:1.08;
  font-weight:800;
  color:rgba(255,255,255,.98);
  flex:0 0 auto;
  white-space:normal;
  display:-webkit-box;
  -webkit-line-clamp:1;
  -webkit-box-orient:vertical;
  overflow:hidden;
  text-overflow:ellipsis;
}

.photoLightboxDescriptionFrame p{
  margin:0;
  font-size:12.5px;
  line-height:1.34;
  color:rgba(255,255,255,.88);
}

.photoLightboxDescriptionDisplay{
  white-space:pre-line;
  flex:0 0 auto;
  line-height:1.34;
  min-height:calc(1.34em * 2);
  max-height:calc(1.34em * 2);
  overflow-y:hidden;
  position:relative;
  padding-right:4px;
  scrollbar-gutter:stable;
  scrollbar-width:auto;
  scrollbar-color:rgba(56,189,248,.92) rgba(56,189,248,.24);
}

.photoLightboxDescriptionDisplay.has-overflow{
  overflow-y:scroll;
}

.photoLightboxDescriptionFrame.has-visible-scrollbar::before{
  content:"";
  position:absolute;
  right:6px;
  top:20px;
  bottom:24px;
  width:8px;
  border-radius:999px;
  background:rgba(56,189,248,.24);
  pointer-events:none;
}

.photoLightboxDescriptionFrame.has-visible-scrollbar .photoLightboxDescriptionDisplay{
  padding-right:14px;
}

.photoLightboxDescriptionDisplay::-webkit-scrollbar{
  width:9px;
}

.photoLightboxDescriptionDisplay::-webkit-scrollbar-track{
  background:rgba(56,189,248,.24);
  border-radius:999px;
}

.photoLightboxDescriptionDisplay::-webkit-scrollbar-thumb{
  background:rgba(56,189,248,.92);
  border-radius:999px;
}

.photoLightboxCounter{
  display:none;
}

@media (max-width:900px){
  .photoLightboxClose{
    top:10px;
    right:10px;
    left:auto;
    width:34px;
    height:34px;
    font-size:24px;
  }

  .photoLightboxFullscreen{
    right:10px;
    left:auto;
    bottom:10px;
    width:34px;
    height:34px;
  }

  .photoLightboxFullscreen svg{
    width:14px;
    height:14px;
  }

  .photoLightboxNav{
    width:36px;
    height:36px;
    font-size:20px;
  }

  #photoLightboxPrev{
    left:8px;
  }

  #photoLightboxNext{
    right:8px;
  }

  .photoLightboxDialog{
    width:min(1080px, 95vw);
    max-width:95vw;
    height:calc(100vh - 14px);
    max-height:calc(100vh - 14px);
    transform:translateY(-12px);
    --photo-overlay-gap:10px;
    --photo-description-overlay-h:86px;
  }

  .photoLightboxDescriptionFrame{
    padding:18px 12px 12px;
  }

  .photoLightboxDescriptionFrame h3{
    font-size:16px;
  }

  .photoLightboxDescriptionFrame p{
    font-size:11px;
    line-height:1.25;
  }

  .photoLightboxDescriptionDisplay{
    line-height:1.25;
    min-height:calc(1.25em * 2);
    max-height:calc(1.25em * 2);
  }

  .photoLightboxImageCopyright{
    font-size:10px;
    right:56px;
    bottom:12px;
  }

}

@media (max-width:720px){
  .photoLightboxDialog:fullscreen #photoLightboxFullscreen,
  .photoLightboxDialog:-webkit-full-screen #photoLightboxFullscreen{
    right:8px;
    left:auto;
    bottom:8px;
  }

  .photoLightbox{
    padding:0;
    place-items:start center;
  }

  .photoLightboxDialog{
    width:100vw;
    max-width:100vw;
    height:100vh;
    max-height:100vh;
    border-radius:0;
    border-left:none;
    border-right:none;
    transform:none;
  }

  .photoLightboxDescriptionFrame{
    border-left:none;
    border-right:none;
  }

  .photoLightboxClose{
    top:8px;
    right:8px;
    left:auto;
  }

  .photoLightboxFullscreen{
    right:8px;
    left:auto;
    bottom:8px;
  }

  #photoLightboxPrev{
    left:6px;
  }

  #photoLightboxNext{
    right:6px;
  }
}

.photosFooter{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin:12px 0 0;
}

.photosCopyright{
  display:block;
  margin:0;
  width:auto;
  text-align:left;
  font-size:13px;
  font-weight:400;
  letter-spacing:.02em;
  color:rgba(255,255,255,.96);
  text-shadow:0 2px 10px rgba(0,0,0,.75);
  position:fixed;
  left:12px;
  bottom:10px;
  z-index:140;
  pointer-events:none;
}

@media (max-width:1200px){
  .photosFrame{
    min-height:0;
  }

  .photosSectionIntro{
    width:min(980px, 96%);
    margin:0 0 16px;
    font-size:clamp(12px, 1.7vw, 16px);
    line-height:1.42;
  }

  .photosContent{
    width:100%;
  }

  .photosGalleryFrame{
    width:100%;
    padding:8px;
  }

  .photosTopRow{
    grid-template-columns:1fr;
    --photos-pane-h:auto;
  }

  .photosMainPane{
    height:clamp(340px, 56vw, 560px);
    max-height:none;
  }

  .photoCategoryRail{
    display:block;
    height:auto;
    max-height:none;
  }

  .photoCategoryRailHeading{
    display:none;
  }

  .photoCategoryListFrame{
    overflow:visible;
    padding-right:0;
  }

  .photoCategoryScrollTrack{
    display:none;
  }

  .photoCategoryList{
    height:auto;
    overflow:visible;
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(108px, 1fr));
    gap:8px;
    padding:4px;
  }

  .photoCategoryItem{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    gap:6px;
    padding:0;
    border:none;
    background:transparent;
  }

  .photoCategoryThumbWrap{
    width:100%;
    margin-inline:0;
  }

  .photoCategoryItemText{
    font-size:12px;
    text-align:center;
  }
}

@media (max-width:900px){
  .photosPageMain{
    padding:calc(var(--navH) + 24px) 0 24px;
  }

  .photosFrame{
    padding:18px;
    width:calc(100% - 36px);
    border-radius:24px;
  }

  .photosSectionIntro{
    font-size:clamp(12px, 2.3vw, 14px);
    margin-bottom:12px;
  }

  .photosContent{
    width:96%;
  }

  .photosSectionOutro{
    margin-top:18px;
    gap:14px;
  }

  .photosSectionSupport{
    gap:12px;
  }

  .photosSectionSupportList{
    grid-template-columns:minmax(0, 1fr);
    gap:8px;
  }

  .photosSectionCta{
    align-self:stretch;
    margin-left:0;
    min-width:0;
    width:100%;
  }

  .photosGalleryFrame{
    padding:6px;
  }

  .photosTopRow{
    gap:10px;
  }

  .photoWall{
    padding:6px;
    gap:6px;
  }

  .photoRow{
    height:68px;
    gap:6px;
  }

  .photoCategoryRail{
    height:auto;
  }

  .photoCategoryList{
    grid-template-columns:repeat(auto-fit, minmax(88px, 1fr));
    padding:3px;
    gap:4px;
  }

  .photoCategoryItemText{
    font-size:11px;
  }
}

@media (max-width:900px){
  .photosFooter{
    align-items:flex-start;
  }
}

@media (max-width:640px){
  .photosFooter{
    flex-direction:column;
    align-items:flex-start;
    gap:8px;
  }

  .photosFrame{
    padding:14px;
  }

  .photosMainPane{
    height:clamp(300px, 65vw, 430px);
  }

  .photoRow{
    height:58px;
  }

  .photoCategoryRail{
    height:auto;
  }
}

@media (max-width:1180px) and (orientation:landscape){
  .photosFrame{
    padding:0;
    margin-top:0;
  }

  .photosContent{
    width:100%;
    padding-bottom:12px;
  }

  .photosTopRow{
    gap:0;
  }

  .photosMainPane{
    border-left:2px solid #fff;
    border-right:2px solid #fff;
    box-shadow:none;
    height:clamp(280px, calc(100vh - var(--navH) - 140px), 500px);
  }

  .photoWall{
    padding:6px 0;
  }

  .photoCategoryRail{
    border-left:2px solid #fff;
    border-right:2px solid #fff;
  }

  .photoCategoryList{
    padding:4px 0;
  }
}


/* THS photos popup fullscreen placement/visibility override */
#photoLightboxFullscreen{
  right:14px !important;
  left:auto !important;
  top:14px !important;
  bottom:auto !important;
  display:grid !important;
}

.photoLightboxDialog:fullscreen #photoLightboxFullscreen,
.photoLightboxDialog:-webkit-full-screen #photoLightboxFullscreen{
  right:14px !important;
  left:auto !important;
  top:14px !important;
  bottom:auto !important;
  display:grid !important;
  visibility:visible !important;
  opacity:1 !important;
}

@media (max-width:900px){
  #photoLightboxFullscreen,
  .photoLightboxDialog:fullscreen #photoLightboxFullscreen,
  .photoLightboxDialog:-webkit-full-screen #photoLightboxFullscreen{
    right:10px !important;
    left:auto !important;
    top:10px !important;
    bottom:auto !important;
  }
}

@media (max-width:720px){
  #photoLightboxFullscreen,
  .photoLightboxDialog:fullscreen #photoLightboxFullscreen,
  .photoLightboxDialog:-webkit-full-screen #photoLightboxFullscreen{
    right:8px !important;
    left:auto !important;
    top:8px !important;
    bottom:auto !important;
  }
}

/* Inline gallery lightbox mode: keep popup inside gallery pane while selector stays visible. */
.photoLightbox.is-inline-pane{
  position:absolute;
  inset:0;
  z-index:14;
  display:block;
  padding:6px;
  background:rgba(0,0,0,.78);
  backdrop-filter:none;
}

.photoLightbox.is-inline-pane.is-hidden{
  display:none !important;
}

.photoLightbox.is-inline-pane .photoLightboxDialog{
  width:100%;
  max-width:none;
  height:100%;
  max-height:none;
  border-radius:8px;
  transform:none;
  box-shadow:none;
  --photo-description-overlay-h:94px;
}

.photoLightbox.is-inline-pane .photoLightboxStage{
  flex:1 1 auto;
  min-height:0;
  aspect-ratio:auto;
}

.photoLightbox.is-inline-pane .photoLightboxDescriptionFrame{
  padding:18px 14px 14px;
}

.photoLightbox.is-inline-pane .photoLightboxDialog.is-edit-mode .photoLightboxDescriptionFrame{
  padding:8px 12px;
  height:210px;
  min-height:210px;
  max-height:210px;
}

@media (max-width:900px){
  .photoLightbox.is-inline-pane{
    padding:4px;
  }

  .photoLightbox.is-inline-pane .photoLightboxDescriptionFrame{
    padding:16px 12px 12px;
  }

  .photoLightbox.is-inline-pane .photoLightboxDialog.is-edit-mode .photoLightboxDescriptionFrame{
    padding:7px 10px 8px;
    height:188px;
    min-height:188px;
    max-height:188px;
  }
}

@media (max-width:1024px), ((max-height:500px) and (orientation:landscape)){
  .photosPageMain{
    padding:calc(var(--navH) + 18px) 0 18px;
  }

  .photosFrame{
    width:100%;
    padding:18px 0 28px;
    border-radius:0;
    border-left:none;
    border-right:none;
  }

  .photosContent{
    width:100%;
  }

  .photosGalleryFrame{
    width:100vw;
    max-width:100vw;
    margin-left:calc(50% - 50vw);
    padding:0;
    border-radius:0;
    border-left:none;
    border-right:none;
  }

  .photosTopRow{
    gap:0;
  }

  .photosMainPane,
  .photoCategoryRail{
    border-left:none;
    border-right:none;
    border-radius:0;
    box-shadow:none;
  }

  .photoWall{
    padding:6px 0;
  }

  .photoCategoryList{
    padding:4px 0;
  }

  .photosSectionIntro,
  .photosSectionOutro,
  .photosSectionSupport{
    width:min(100% - 24px, var(--single2-prose-width));
    margin-left:auto;
    margin-right:auto;
  }

  .photoLightbox.is-inline-pane{
    position:fixed;
    inset:0;
    padding:0;
    z-index:160;
  }

  .photoLightbox.is-inline-pane .photoLightboxDialog{
    width:100vw;
    max-width:100vw;
    height:100vh;
    max-height:100vh;
    border-radius:0;
    border:none;
  }

  .photoLightbox.is-inline-pane .photoLightboxDescriptionFrame{
    border-left:none;
    border-right:none;
  }
}

/* Responsive pass 2: photos density and category usability */
@media (max-width:1180px){
  .photosPageMain .single2SectionTitleDeck{
    width:min(100% - 28px, 1100px);
  }

  .photosPageMain .single2SectionTitle{
    font-size:clamp(34px, 5.8vw, 60px);
  }

  .photosSectionSupportList{
    grid-template-columns:minmax(0, 1fr);
    gap:10px 0;
  }

  .photosSectionCta{
    margin-left:0;
    align-self:flex-start;
  }
}

@media (max-width:900px){
  .photosTopRow{
    grid-template-columns:minmax(0, 1fr);
    gap:0;
  }

  .photoCategoryRail{
    order:2;
    height:auto;
    max-height:none;
    border-top:1px solid rgba(255,255,255,.18);
  }

  .photoCategoryRailHeading{
    font-size:18px;
    padding:10px 12px;
  }

  .photoCategoryListFrame{
    padding-right:0;
  }

  .photoCategoryScrollTrack{
    display:none;
  }

  .photoCategoryList{
    display:grid;
    grid-auto-flow:column;
    grid-template-columns:none;
    grid-template-rows:1fr;
    grid-auto-columns:minmax(102px, 120px);
    gap:8px;
    overflow-x:auto;
    overflow-y:hidden;
    padding:8px;
  }

  .photoCategoryItem{
    grid-template-columns:1fr;
    gap:6px;
    padding:0;
    border-right:1px solid rgba(255,255,255,.18);
    border-bottom:none;
    padding-right:8px;
  }

  .photoCategoryThumbWrap{
    max-width:none;
  }

  .photoCategoryItemText{
    text-align:center;
    font-size:12px;
  }
}

@media (max-width:767px){
  .photosPageMain .single2SectionTitle{
    font-size:clamp(28px, 8vw, 42px);
  }

  .photosFrame{
    padding:14px 0 20px;
  }

  .photosContent{
    padding-bottom:24px;
  }

  .photosSectionIntro,
  .photosSectionOutro,
  .photosSectionSupport{
    width:min(100% - 16px, var(--single2-prose-width));
  }

  .photosSectionIntro{
    font-size:14px;
    line-height:1.55;
  }

  .photosSectionCta{
    width:100%;
    min-width:0;
    justify-content:center;
  }

  .photoRow{
    height:68px;
    gap:4px;
  }

  .photoWall{
    gap:4px;
    padding:4px 0;
  }

  .photoCategoryList{
    grid-auto-columns:minmax(88px, 104px);
    gap:6px;
    padding:6px;
  }
}

@media (max-width:767px) and (orientation:portrait){
  .photoCategoryList{
    grid-template-columns:none;
    grid-template-rows:repeat(2, minmax(0, auto));
    grid-auto-flow:column;
    grid-auto-columns:minmax(84px, 98px);
    gap:6px;
    padding:6px;
  }

  .photoCategoryItem{
    width:auto;
    min-width:0;
  }
}

/* Keep standalone photos rounded frame aligned with 95% hero width on narrow screens. */
@media (max-width:1180px){
  .photosFrame{
    width:min(95vw, 1400px) !important;
    margin-left:auto !important;
    margin-right:auto !important;
  }
}

/* Hide photo lightbox fullscreen icon on phone-sized narrow views; keep close button available. */
@media (max-width:900px) and (orientation:portrait), (max-height:500px) and (orientation:landscape){
  .photoLightboxFullscreen,
  #photoLightboxFullscreen,
  .photoLightboxDialog:fullscreen #photoLightboxFullscreen,
  .photoLightboxDialog:-webkit-full-screen #photoLightboxFullscreen{
    display:none !important;
    visibility:hidden !important;
    opacity:0 !important;
    pointer-events:none !important;
  }
}

/* Fullscreen lightbox pass: center media and keep top-right controls reachable. */
.photoLightboxDialog:fullscreen,
.photoLightboxDialog:-webkit-full-screen{
  height:100dvh !important;
  max-height:100dvh !important;
}

.photoLightboxDialog:fullscreen .photoLightboxStage,
.photoLightboxDialog:-webkit-full-screen .photoLightboxStage{
  display:grid;
  place-items:center;
  height:100dvh;
}

.photoLightboxDialog:fullscreen #photoLightboxClose,
.photoLightboxDialog:-webkit-full-screen #photoLightboxClose{
  top:calc(env(safe-area-inset-top, 0px) + 10px) !important;
  right:calc(env(safe-area-inset-right, 0px) + 10px) !important;
  left:auto !important;
  bottom:auto !important;
  z-index:40 !important;
}

.photoLightboxDialog:fullscreen #photoLightboxFullscreen,
.photoLightboxDialog:-webkit-full-screen #photoLightboxFullscreen{
  top:calc(env(safe-area-inset-top, 0px) + 10px) !important;
  right:calc(env(safe-area-inset-right, 0px) + 58px) !important;
  left:auto !important;
  bottom:auto !important;
  display:grid !important;
  visibility:visible !important;
  opacity:1 !important;
  pointer-events:auto !important;
  z-index:40 !important;
}

@media (max-width:900px) and (orientation:portrait), (max-height:500px) and (orientation:landscape){
  .photoLightboxFullscreen,
  #photoLightboxFullscreen{
    display:grid !important;
    visibility:visible !important;
    opacity:1 !important;
    pointer-events:auto !important;
  }

  .photoLightboxDialog:fullscreen #photoLightboxClose,
  .photoLightboxDialog:-webkit-full-screen #photoLightboxClose{
    top:calc(env(safe-area-inset-top, 0px) + 8px) !important;
    right:calc(env(safe-area-inset-right, 0px) + 8px) !important;
  }

  .photoLightboxDialog:fullscreen #photoLightboxFullscreen,
  .photoLightboxDialog:-webkit-full-screen #photoLightboxFullscreen{
    top:calc(env(safe-area-inset-top, 0px) + 8px) !important;
    right:calc(env(safe-area-inset-right, 0px) + 52px) !important;
  }
}

@media (max-height:500px) and (orientation:landscape) and (max-width:1180px){
  .photosMainPane{
    height:85dvh !important;
    max-height:85dvh !important;
  }

  .photoWall{
    padding:4px 0 !important;
    gap:4px !important;
  }

  .photoRow{
    height:56px !important;
    gap:4px !important;
  }

  .photoCategoryRail{
    height:auto !important;
    max-height:none !important;
  }

  .photoCategoryRailHeading{
    display:none !important;
  }

  .photoCategoryListFrame{
    overflow:visible !important;
    padding-right:0 !important;
  }

  .photoCategoryScrollTrack{
    display:none !important;
  }

  .photoCategoryList{
    height:auto !important;
    overflow:visible !important;
    display:flex !important;
    flex-direction:row !important;
    flex-wrap:nowrap !important;
    gap:4px !important;
    padding:4px !important;
  }

  .photoCategoryItem{
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:4px !important;
    padding:0 !important;
    border:none !important;
    background:transparent !important;
    flex:1 1 0 !important;
    min-width:0 !important;
  }

  .photoCategoryThumbWrap{
    width:100% !important;
    max-width:80px !important;
    margin-inline:auto !important;
  }

  .photoCategoryItemText{
    font-size:11px !important;
    line-height:1.05 !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
    text-align:center !important;
  }
}

/* Keep standalone photos.html aligned with the indextwo photo gallery geometry. */
@media (max-width:1024px){
  .photosFrame{
    padding:18px !important;
    border-radius:24px !important;
    border-left:1px solid rgba(255,255,255,.12) !important;
    border-right:1px solid rgba(255,255,255,.12) !important;
  }

  .photosContent,
  .photosGalleryFrame{
    width:100% !important;
  }

  .photosGalleryFrame{
    max-width:100% !important;
    margin-left:auto !important;
    margin-right:auto !important;
    padding:8px !important;
    border:2px solid rgba(255,255,255,.88) !important;
    border-radius:14px !important;
  }
}
