/* VERSION: 2026-04-01 08:21 EDT (Added Transition Type and Dissolve Speed for banners) */
/* display.css VERSION: 2026-03-22 06:39 (tight spec: banner 300 + logo 150 = 450px total; no extra padding/gaps) */
/* display.css VERSION: 2026-03-15 06:06 -04:00 margin control restored + leaders bottom aligned */
/* display.css VERSION: 2026-03-07 full-font-controls-wiring */
:root{
  --bg: #0b0f14;
  --fg: #f2f5f8;
  --muted: rgba(242,245,248,.78);
  --accent: #79c3ff;
  --panel: rgba(255,255,255,.06);
  --scale: 1;
  --content-fit-scale: 1;
  
 --line-spacing: 1;
--radius: 18px;
  --banner-h: 320px;
  --footer-h: 120px;

  /* new runtime variables fed by display.html */
  --chrome-opacity: .06;

  --title-color: var(--fg);
  --title-font-family: Arial, sans-serif;
  --title-font-weight: 800;
  --title-text-decoration: none;
  --title-opacity: 1;
  --title-size-scale: 1;

  --dept-color: var(--fg);
  --dept-font-family: Arial, sans-serif;
  --dept-font-weight: 900;
  --dept-text-decoration: none;
  --dept-opacity: 1;
  --dept-size-scale: 1;

  --occupant-color: var(--fg);
  --occupant-font-family: Arial, sans-serif;
  --occupant-font-weight: 700;
  --occupant-text-decoration: none;
  --occupant-opacity: 1;
  --occupant-size-scale: 1;

  --occupant-title-color: var(--occupant-color);
  --occupant-title-font-family: Arial, sans-serif;
  --occupant-title-font-weight: 600;
  --occupant-title-text-decoration: none;
  --occupant-title-opacity: .78;
  --occupant-title-size-scale: 1;

  /* margin-control helpers */
  --content-arrow-slot: calc(44px * var(--scale) * var(--content-fit-scale));
  --dept-width-offset: calc(18px * var(--scale) * var(--content-fit-scale));
  --title-indent: calc(12px * var(--scale) * var(--content-fit-scale));
}

html, body {
  height: 100%;
  margin: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: Arial, sans-serif;
  font-size: calc(16px * var(--scale));
  overflow: hidden;
}

.signage .frame{
  height: 100vh;
  width: 100vw;
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  gap: calc(10px * var(--scale) * var(--content-fit-scale));
  padding: calc(20px * var(--scale));
  box-sizing: border-box;
  overflow: hidden;
}

.hdr{
  background: linear-gradient(
    180deg,
    rgba(255,255,255, calc(var(--chrome-opacity) + .04)),
    rgba(255,255,255, max(calc(var(--chrome-opacity) - .02), 0))
  );
  border-radius: var(--radius);
  padding: calc(18px * var(--scale) * var(--content-fit-scale));
  text-align: center;
}

.hdr-title{
  font-family: var(--title-font-family);
  font-weight: var(--title-font-weight);
  text-decoration: var(--title-text-decoration);
  opacity: var(--title-opacity);
  letter-spacing: .5px;
  font-size: calc(44px * var(--scale) * var(--title-size-scale));
  line-height: 1.05;
  color: var(--title-color);
}

.floors{
  display:flex;
  gap: calc(10px * var(--scale));
  justify-content: center;
  flex-wrap: wrap;
}

.floor-btn{
 border: 0;
 border-radius: 999px;
 padding: calc(10px * var(--scale)) calc(16px * var(--scale));
 background: color-mix(in srgb, var(--floor-btn-color) 16%, transparent);
 color: var(--floor-btn-color);
 font-family: var(--floor-btn-font-family);
 font-weight: var(--floor-btn-font-weight);
 text-decoration: var(--floor-btn-text-decoration);
 opacity: var(--floor-btn-opacity);
 font-size: calc(18px * var(--scale) * var(--floor-btn-size-scale));
 cursor: pointer;
}
.floor-btn.active{
 background: color-mix(in srgb, var(--floor-btn-color) 25%, transparent);
 outline: 2px solid color-mix(in srgb, var(--floor-btn-color) 55%, transparent);
}

.content{
  background: rgba(255,255,255, calc(var(--chrome-opacity) + .01));
  border-radius: var(--radius);
  padding: calc(18px * var(--scale));
  overflow: hidden;
  min-height: 0;
}
.content.scroll{ overflow-y: auto; overflow-x: hidden; }
.content.fit{ overflow: hidden; }
.pending-layout .content{ visibility: hidden; }

.directory{
  column-count: var(--cols);
  column-gap: calc(26px * var(--scale) * var(--content-fit-scale));
}

.dept{
  break-inside: avoid;
  background: rgba(255,255,255, calc(var(--chrome-opacity) + .005));
  border: 1px solid rgba(255,255,255,.07);
  border-radius: calc(14px * var(--scale) * var(--content-fit-scale));
  padding: calc(14px * var(--scale) * var(--content-fit-scale));
  margin: 0 0 calc(14px * var(--scale) * var(--content-fit-scale) * var(--line-spacing)) 0;
}

.dept-name{
  text-align: var(--dept-align);
  font-family: var(--dept-font-family);
  font-weight: var(--dept-font-weight);
  text-decoration: var(--dept-text-decoration);
  opacity: var(--dept-opacity);
  font-size: calc(26px * var(--scale) * var(--content-fit-scale) * var(--dept-size-scale));
  width: min(
    calc(var(--person-line-width, 100%) + var(--dept-width-offset)),
    calc(var(--person-line-max-width, 100%) + var(--dept-width-offset))
  );
  max-width: 100%;
  margin: 0 auto calc(10px * var(--scale) * var(--content-fit-scale) * var(--line-spacing)) auto;
  border-bottom: 1px solid rgba(255,255,255,.10);
  padding-bottom: calc(8px * var(--scale) * var(--content-fit-scale) * var(--line-spacing));
  color: var(--dept-color);
}

.dept-people{
  display: grid;
  gap: calc(8px * var(--scale) * var(--content-fit-scale) * var(--line-spacing));
  justify-items: stretch;
}

.center-departments .dept-name{
  text-align: center;
}

.center-departments .dept-people{
  justify-items: center;
}

.center-departments .person{
  position: relative;
  display: block;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto;
  padding-left: 0;
}

.center-departments .person > div{
  width: fit-content;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.center-departments .person-line{
  display: inline-flex;
  justify-content: flex-start;
  align-items: baseline;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto;
  gap: 10ch;
  text-align: center;
}

.center-departments .person-name,
.center-departments .person-room{
  flex: 0 0 auto;
}

.center-departments .arrow{
  position: absolute;
  right: calc(100% + 1ch);
  top: 0;
}

.center-departments .arrow.spacer{
  opacity: 0;
  pointer-events: none;
}

.center-departments .person-title{
  margin-left: 0;
  padding-left: 0;
  max-width: 100%;
  text-align: center;
}

.center-departments.use-leaders .person-line{
  gap: 0;
  align-items: flex-end;
}

.center-departments.use-leaders .person-leader{
  display: block;
  flex: 0 0 10ch;
  min-width: 10ch;
}

.person{
  display: grid;
  grid-template-columns: auto 1fr;
  gap: calc(10px * var(--scale));
  align-items: start;
  width: min(
    calc(var(--person-line-width, 100%) + var(--content-arrow-slot)),
    calc(var(--person-line-max-width, 100%) + var(--content-arrow-slot))
  );
  max-width: 100%;
  margin: 0 auto;
  padding: calc(6px * var(--scale) * var(--content-fit-scale) * var(--line-spacing)) 0;
}

.person > div{
  width: calc(100% - var(--content-arrow-slot));
  max-width: calc(100% - var(--content-arrow-slot));
}

.arrow{
  width: calc(34px * var(--scale) * var(--content-fit-scale));
  min-width: calc(34px * var(--scale) * var(--content-fit-scale));
  height: calc(34px * var(--scale) * var(--content-fit-scale));
  border-radius: calc(12px * var(--content-fit-scale));
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: var(--accent);
  font-weight: 900;
  font-size: calc(20px * var(--scale) * var(--content-fit-scale) * var(--occupant-size-scale) * 1.3);
  cursor: pointer;
  line-height: 1;
  justify-self: start;
}

.arrow.spacer{
  opacity: 0;
  pointer-events: none;
  border-color: transparent;
  background: transparent;
}

.person-line{
  display:flex;
  gap: calc(10px * var(--scale));
  justify-content: space-between;
  align-items: baseline;
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

.person-leader {
  display: none;
}

.use-leaders .person-line{
  display:flex;
  align-items: flex-end;
  gap: calc(8px * var(--scale));
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

.use-leaders .person-leader {
  display: block;
  flex: 1 1 auto;
  align-self: flex-end;
  border-bottom: 2px dotted;
  border-bottom-color: color-mix(in srgb, var(--occupant-color) 70%, transparent);
  transform: none;
  margin-bottom: 0;
}

.use-leaders .person-name{
  flex: 0 1 auto;
  min-width: 0;
}

.use-leaders .person-room{
  flex: 0 0 auto;
  min-width: var(--person-room-min-width);
  text-align: right;
}

.person-name{
  flex: 1 1 auto;
  min-width: 0;
  font-family: var(--occupant-font-family);
  font-weight: var(--occupant-font-weight);
  text-decoration: var(--occupant-text-decoration);
  opacity: var(--occupant-opacity);
  font-size: calc(20px * var(--scale) * var(--content-fit-scale) * var(--occupant-size-scale));
  color: var(--occupant-color);
}

.person-room{
  flex: 0 0 auto;
  font-family: var(--occupant-font-family);
  font-weight: var(--occupant-font-weight);
  text-decoration: var(--occupant-text-decoration);
  opacity: var(--occupant-opacity);
  font-size: calc(18px * var(--scale) * var(--content-fit-scale) * var(--occupant-size-scale));
  color: var(--occupant-color);
  white-space: nowrap;
}

.person-title{
  margin-left: 0;
  margin-top: calc(2px * var(--scale) * var(--content-fit-scale) * var(--line-spacing));
  padding-left: var(--title-indent);
  max-width: calc(100% - var(--title-indent));
  font-family: var(--occupant-title-font-family);
  font-weight: var(--occupant-title-font-weight);
  text-decoration: var(--occupant-title-text-decoration);
  opacity: var(--occupant-title-opacity);
  font-size: calc(16px * var(--scale) * var(--content-fit-scale) * var(--occupant-title-size-scale));
  color: var(--occupant-title-color);
}

.bottom-stack{
  display: grid;
  gap: calc(10px * var(--scale));
  min-height: 0;
  align-self: end;
  margin-top: auto;
}

.bottom-stack.has-banners{
  gap: 0;
  grid-template-rows: var(--banner-h) var(--footer-h);
  height: calc(var(--banner-h) + var(--footer-h));
}

.bottom-stack.no-banners{
  grid-template-rows: var(--footer-h);
  height: var(--footer-h);
  gap: 0;
}

.banner-band{
  height: var(--banner-h);
  background: var(--bg);
  border-radius: var(--radius);
  box-sizing: border-box;
 padding: 0;
  box-sizing: border-box;
  overflow: hidden;
}

.banner-viewport{
  height: var(--banner-h);
  width: 100%;
  overflow: hidden;
  border-radius: calc(12px * var(--scale));
  background: var(--bg);
}

.banner-strip{
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.banner-slide{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  z-index: 1;
  display:flex;
  justify-content:center;
  align-items:center;
  padding: 0;
  box-sizing: border-box;
  transform: translateX(0);
}

.banner-link{
  display:flex;
  height: 100%;
  width: 100%;
  justify-content:center;
  align-items:center;
  text-decoration: none;
}

.banner-link.nohref{
  cursor: default;
}

.banner-media{
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border-radius: calc(10px * var(--scale));
}

.ftr{
  box-sizing: border-box;
  height: var(--footer-h);
  padding-top: 15px;
  padding-bottom: 0;
  display:flex;
  justify-content:center;
  align-items:center;
}

.logo{
  max-height: 150px;
  max-width: 80%;
  object-fit: contain;
  filter: drop-shadow(0 6px 18px rgba(0,0,0,.45));
}

.modal{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.65);
  display:none;
  justify-content:center;
  align-items:center;
  padding: calc(24px * var(--scale));
}

.modal.show{ display:flex; }

.modal-card{
  width: min(900px, 92vw);
  background: rgba(20,26,34,.96);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: calc(18px * var(--scale));
  padding: calc(18px * var(--scale));
  box-shadow: 0 18px 60px rgba(0,0,0,.55);
  position: relative;
}

.modal-x{
  position:absolute;
  top: calc(10px * var(--scale));
  right: calc(10px * var(--scale));
  border: 0;
  background: rgba(255,255,255,.08);
  color: var(--fg);
  border-radius: 12px;
  width: calc(44px * var(--scale));
  height: calc(44px * var(--scale));
  font-size: calc(22px * var(--scale));
  cursor:pointer;
}

.modal-body{
  display:grid;
  grid-template-columns: auto 1fr;
  gap: calc(16px * var(--scale));
  align-items:center;
}

.modal-photo{
  display: none;
  width: calc(220px * var(--scale));
  height: calc(220px * var(--scale));
  border-radius: calc(16px * var(--scale));
  object-fit: cover;
  border: 1px solid rgba(255,255,255,.14);
}

.modal-name{
  font-weight: 900;
  font-size: calc(36px * var(--scale));
}

.modal-title{
  margin-top: calc(8px * var(--scale));
  font-weight: 700;
  font-size: calc(22px * var(--scale));
  color: var(--muted);
}