@media (min-width: 561px) and (max-width: 900px) {
  .s03 .grid,
  .moment-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 24px !important;
    align-items: start !important;
    min-height: auto !important;
  }

  .s03 .grid > .stack-num,
  .s03 .grid > .rv.d1,
  .s03 .grid > .rv.d2,
  .moment-grid > *,
  .moment-grid > :first-child,
  .moment-grid > .moment-prose,
  .moment-grid > .moment-side {
    grid-column: 1 !important;
    grid-row: auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .s03 .stack-num,
  .moment-grid .stack-num {
    width: auto !important;
    max-width: 100% !important;
    font-size: clamp(82px, 15vw, 122px) !important;
    line-height: 0.9 !important;
  }

  .s03 .stack-num .yr,
  .moment-grid .stack-num .yr {
    font-size: 0.4em !important;
    line-height: 1.05 !important;
  }

  .moment-side {
    position: static !important;
  }

  .s07 .armature {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    max-width: min(100%, 14ch) !important;
    margin: 0 auto !important;
    font-size: clamp(56px, 10vw, 92px) !important;
    line-height: 0.96 !important;
    white-space: normal !important;
    text-align: center !important;
    overflow-wrap: normal !important;
  }

  .s07 .armature .it {
    max-width: 100%;
  }

  .s07 .gallery {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 24px !important;
    min-height: auto !important;
  }

  .s07 .floats {
    position: relative !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 18px !important;
    height: auto !important;
  }

  .s07 .floats .float {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    width: auto !important;
    height: auto !important;
    min-width: 0 !important;
    transform: none !important;
  }

  .s07 .floats .float .img-wrap {
    min-height: 0 !important;
    aspect-ratio: 4 / 3 !important;
  }

  .s07 .floats .float .meta {
    min-width: 0 !important;
    gap: 8px !important;
  }

  .s07 .floats .float .meta .cap {
    white-space: normal !important;
    text-align: right !important;
  }

  .s04 .frame > div.bm-inline-grid-2col {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
    margin-bottom: 28px !important;
  }

  .s04 .num-row {
    gap: 22px !important;
  }

  .s04 .num-row .item {
    grid-template-columns: minmax(170px, 0.78fr) minmax(0, 1fr) !important;
    gap: 24px !important;
    align-items: start !important;
  }

  .s04 .num-row .item > *,
  .s04 .num-body {
    min-width: 0 !important;
  }

  .s04 .num-huge {
    font-size: clamp(68px, 11vw, 104px) !important;
    line-height: 0.88 !important;
    white-space: nowrap !important;
  }

  .s14 .hover-img {
    left: 50vw;
    top: 50vh;
    visibility: hidden;
  }

  .s14 .hover-img.on {
    visibility: visible;
  }

  .s12 .gal {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 20px !important;
    height: auto !important;
  }

  .s12 .gal .word {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    grid-column: 1 / -1 !important;
    margin: 0 0 8px !important;
    text-align: center !important;
    font-size: clamp(60px, 13vw, 96px) !important;
    white-space: normal !important;
  }

  .s12 .gal .piece {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    width: auto !important;
    height: auto !important;
    min-width: 0 !important;
    transform: none !important;
  }

  .s12 .gal .piece .inner {
    aspect-ratio: 4 / 3 !important;
  }

  .proj-frame,
  .proj-frame.rev {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto auto auto !important;
    gap: 24px !important;
    align-items: start !important;
    min-height: auto !important;
  }

  .proj-frame > .frame-head {
    grid-column: 1 !important;
    grid-row: 1 !important;
    margin-bottom: 0 !important;
  }

  .proj-frame > .pl,
  .proj-frame.rev > .pl {
    grid-column: 1 !important;
    grid-row: 2 !important;
    order: 0 !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  .proj-frame > div:not(.frame-head):not(.frame-foot):not(.pl) {
    grid-column: 1 !important;
    grid-row: 3 !important;
    min-width: 0 !important;
  }

  .proj-frame > .frame-foot {
    position: static !important;
    grid-column: 1 !important;
    grid-row: 4 !important;
    margin-top: 0 !important;
  }
}

@media (min-width: 901px) {
  .s03 .grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1.04fr) minmax(320px, 0.9fr) !important;
    grid-template-rows: auto auto !important;
    column-gap: clamp(44px, 5vw, 76px) !important;
    row-gap: clamp(18px, 2vw, 28px) !important;
    align-items: center !important;
    min-height: 72vh !important;
  }

  .s03 .grid > .stack-num {
    grid-column: 1 !important;
    grid-row: 1 !important;
    align-self: end !important;
    min-width: 0 !important;
  }

  .s03 .grid > .rv.d1 {
    grid-column: 1 !important;
    grid-row: 2 !important;
    align-self: start !important;
    min-width: 0 !important;
    max-width: 58ch !important;
  }

  .s03 .grid > .rv.d2 {
    grid-column: 2 !important;
    grid-row: 1 / span 2 !important;
    align-self: center !important;
    min-width: 0 !important;
  }

  .s03 .stack-num {
    width: auto !important;
    max-width: 100% !important;
    font-size: clamp(112px, 13.5vw, 210px) !important;
    line-height: 0.86 !important;
  }

  .s03 .stack-num .yr {
    font-size: 0.42em !important;
    line-height: 1.05 !important;
    overflow-wrap: anywhere !important;
  }

  .moment-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1.2fr) minmax(220px, 0.58fr) !important;
    grid-template-rows: auto auto !important;
    gap: clamp(42px, 4vw, 64px) !important;
    align-items: start !important;
    min-height: 70vh !important;
    padding-top: 4vh !important;
  }

  .moment-grid > :first-child {
    grid-column: 1 !important;
    grid-row: 1 !important;
    min-width: 0 !important;
  }

  .moment-grid > .moment-prose {
    grid-column: 1 !important;
    grid-row: 2 !important;
    min-width: 0 !important;
    max-width: 56ch !important;
  }

  .moment-grid > .moment-side {
    grid-column: 2 !important;
    grid-row: 1 / span 2 !important;
    min-width: 0 !important;
  }

  .moment-grid .stack-num {
    width: auto !important;
    max-width: 100% !important;
    font-size: clamp(104px, 12vw, 190px) !important;
    line-height: 0.86 !important;
  }

  .moment-grid .stack-num .yr {
    font-size: 0.22em !important;
    line-height: 1.05 !important;
    overflow-wrap: anywhere !important;
  }

  .moment-side {
    top: 100px !important;
  }

  .s07 .armature {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
    justify-self: center !important;
    width: min(100%, 12.5ch) !important;
    max-width: min(66vw, 960px) !important;
    margin: 0 !important;
    font-size: clamp(60px, 6vw, 112px) !important;
    line-height: 0.94 !important;
    white-space: normal !important;
    text-align: center !important;
    overflow-wrap: normal !important;
    z-index: 1 !important;
  }

  .s07 .armature .it {
    max-width: 100%;
  }

  .s07 .gallery {
    display: grid !important;
    grid-template-columns: minmax(170px, 0.72fr) minmax(360px, 1.1fr) minmax(170px, 0.72fr) !important;
    grid-template-rows: auto auto auto !important;
    gap: clamp(24px, 3vw, 46px) clamp(28px, 4vw, 62px) !important;
    align-items: center !important;
    min-height: auto !important;
    padding: clamp(8px, 1.5vw, 22px) 0 !important;
  }

  .s07 .floats {
    display: contents !important;
    position: static !important;
    height: auto !important;
  }

  .s07 .floats .float {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    width: 100% !important;
    max-width: clamp(230px, 22vw, 340px) !important;
    height: auto !important;
    min-width: 0 !important;
    transform: none !important;
    z-index: 2 !important;
  }

  .s07 .floats .float:nth-child(1) { grid-column: 1 !important; grid-row: 1 !important; align-self: end !important; justify-self: start !important; }
  .s07 .floats .float:nth-child(2) { grid-column: 3 !important; grid-row: 1 !important; align-self: end !important; justify-self: end !important; }
  .s07 .floats .float:nth-child(3) { grid-column: 1 !important; grid-row: 3 !important; align-self: start !important; justify-self: start !important; }
  .s07 .floats .float:nth-child(4) { grid-column: 3 !important; grid-row: 3 !important; align-self: start !important; justify-self: end !important; }

  .s07 .floats .float .img-wrap {
    min-height: 0 !important;
    aspect-ratio: 4 / 3 !important;
  }

  .s07 .floats .float .meta {
    min-width: 0 !important;
    gap: 8px !important;
  }

  .s07 .floats .float .meta .cap {
    white-space: normal !important;
    text-align: right !important;
  }

  .s14 .hover-img {
    left: 50vw;
    top: 50vh;
    visibility: hidden;
  }

  .s14 .hover-img.on {
    visibility: visible;
  }

  .s04 .num-row .item {
    grid-template-columns: minmax(210px, 0.74fr) minmax(280px, 1.06fr) !important;
    gap: clamp(32px, 4vw, 62px) !important;
    align-items: center !important;
  }

  .s04 .num-huge {
    max-width: 100% !important;
    font-size: clamp(78px, 8.8vw, 142px) !important;
    line-height: 0.88 !important;
    white-space: nowrap !important;
  }

  .s04 .num-row .item > *,
  .s04 .num-body,
  .s04 .num-body .body {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .s09-slide {
    grid-template-columns: minmax(230px, 0.68fr) minmax(0, 1fr) minmax(320px, 0.95fr) !important;
    gap: clamp(30px, 3vw, 46px) !important;
  }

  .s09-slide > * {
    min-width: 0 !important;
  }

  .s09-slide .bignum {
    max-width: 100% !important;
    font-size: clamp(92px, 9vw, 156px) !important;
    line-height: 0.88 !important;
    overflow-wrap: anywhere !important;
  }

  .s09-slide .bignum .it {
    max-width: 9.5ch !important;
    font-size: 0.34em !important;
    line-height: 1.02 !important;
    margin-top: 10px !important;
    overflow-wrap: anywhere !important;
  }

  .s09-slide .arc {
    max-width: 100% !important;
  }

  .s12 .gal {
    height: clamp(680px, 90vh, 920px) !important;
    min-height: 680px !important;
  }

  .s12 .gal .word {
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    z-index: 3 !important;
    font-size: clamp(96px, 11vw, 190px) !important;
    line-height: 0.9 !important;
  }

  .s12 .gal .piece {
    z-index: 2 !important;
  }

  .s12 .gal .piece:nth-child(2) { left: 2% !important; top: 1% !important; right: auto !important; bottom: auto !important; width: 21% !important; height: 31% !important; }
  .s12 .gal .piece:nth-child(3) { left: 30% !important; top: 0 !important; right: auto !important; bottom: auto !important; width: 21% !important; height: 30% !important; }
  .s12 .gal .piece:nth-child(4) { left: auto !important; top: 2% !important; right: 2% !important; bottom: auto !important; width: 21% !important; height: 31% !important; }
  .s12 .gal .piece:nth-child(5) { left: 4% !important; top: auto !important; right: auto !important; bottom: 0 !important; width: 20% !important; height: 32% !important; }
  .s12 .gal .piece:nth-child(6) { left: 39% !important; top: auto !important; right: auto !important; bottom: 0 !important; width: 22% !important; height: 31% !important; }
  .s12 .gal .piece:nth-child(7) { left: auto !important; top: auto !important; right: 4% !important; bottom: 0 !important; width: 22% !important; height: 34% !important; }
  .s12 .gal .piece:nth-child(8) { left: auto !important; top: 34% !important; right: 2% !important; bottom: auto !important; width: 20% !important; height: 28% !important; }

  .proj-frame,
  .proj-frame.rev {
    display: grid !important;
    grid-template-columns: minmax(0, 0.9fr) minmax(320px, 1fr) !important;
    grid-template-rows: auto minmax(0, 1fr) auto !important;
    column-gap: clamp(40px, 4vw, 72px) !important;
    row-gap: clamp(22px, 2vw, 32px) !important;
    align-items: center !important;
    min-height: 72vh !important;
  }

  .proj-frame > .frame-head {
    grid-column: 1 / -1 !important;
    grid-row: 1 !important;
    align-self: start !important;
    margin-bottom: 0 !important;
  }

  .proj-frame > div:not(.frame-head):not(.frame-foot):not(.pl) {
    grid-column: 1 !important;
    grid-row: 2 !important;
    align-self: center !important;
    min-width: 0 !important;
    max-width: 58ch !important;
  }

  .proj-frame > .pl {
    grid-column: 2 !important;
    grid-row: 2 !important;
    align-self: center !important;
    order: 0 !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  .proj-frame.rev > div:not(.frame-head):not(.frame-foot):not(.pl) {
    grid-column: 2 !important;
  }

  .proj-frame.rev > .pl {
    grid-column: 1 !important;
    order: 0 !important;
  }

  .proj-frame > .frame-foot {
    position: static !important;
    grid-column: 1 / -1 !important;
    grid-row: 3 !important;
    align-self: end !important;
    margin-top: 0 !important;
  }

  .proj-frame .ptitle {
    font-size: clamp(42px, 4.4vw, 74px) !important;
  }

  .s08 .frame {
    display: grid;
    grid-template-rows: auto auto 1fr auto;
    row-gap: clamp(24px, 3vw, 44px);
  }

  .s08 .frame-head {
    grid-row: 1;
    grid-column: 1 / -1;
    align-self: start;
    margin-bottom: 0;
  }

  .s08 .head {
    grid-row: 2;
    grid-column: 1 / -1;
    width: min(100%, 780px);
    justify-self: center;
    display: grid;
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 18px;
    margin: 0;
    text-align: center;
  }

  .s08 .big-title {
    max-width: 15ch;
    font-size: clamp(38px, 3.25vw, 62px);
    line-height: 1.02;
  }

  .s08 .head .body {
    max-width: 54ch;
    margin: 0;
  }

  .s08 .roles {
    grid-row: 3;
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(24px, 3vw, 40px);
    align-items: start;
  }

  .s08 .frame-foot {
    position: static;
    grid-row: 4;
    grid-column: 1 / -1;
    align-self: end;
    margin-top: 0;
  }

  .s08 .role {
    min-height: auto;
    padding: 18px 20px 22px;
    gap: 12px;
    background: transparent;
  }

  .s08 .role .mark {
    aspect-ratio: 16 / 10;
  }

  .s08 .role .name {
    font-size: 13px;
    line-height: 1.35;
  }

  .s08 .role .desc {
    max-width: 34ch;
    font-size: 15px;
    line-height: 1.55;
  }
}

@media (min-width: 1200px) {
  .s08 .frame {
    grid-template-columns: minmax(230px, 1fr) minmax(280px, 0.9fr) minmax(230px, 1fr);
    grid-template-rows: auto auto auto auto auto;
    column-gap: clamp(28px, 3vw, 58px);
    row-gap: clamp(26px, 3vw, 48px);
    align-items: start;
  }

  .s08 .frame-head {
    grid-column: 1 / -1;
    grid-row: 1;
  }

  .s08 .head {
    grid-column: 2;
    grid-row: 2 / span 2;
    align-self: center;
    width: min(100%, 430px);
    max-width: 430px;
    padding: clamp(8px, 1.2vw, 18px);
    background: transparent;
    box-shadow: none;
    z-index: 2;
  }

  .s08 .big-title {
    max-width: 12.5ch;
    font-size: clamp(36px, 2.75vw, 56px);
  }

  .s08 .head .body {
    max-width: 40ch;
  }

  .s08 .roles {
    display: contents;
  }

  .s08 .role {
    align-self: start;
  }

  .s08 .role:nth-child(1) { grid-column: 1; grid-row: 2; }
  .s08 .role:nth-child(2) { grid-column: 3; grid-row: 2; }
  .s08 .role:nth-child(3) { grid-column: 1; grid-row: 3; }
  .s08 .role:nth-child(4) { grid-column: 3; grid-row: 3; }
  .s08 .role:nth-child(5) { grid-column: 1; grid-row: 4; }
  .s08 .role:nth-child(6) { grid-column: 3; grid-row: 4; }
  .s08 .role:nth-child(7) { grid-column: 2; grid-row: 4; }

  .s08 .frame-foot {
    grid-column: 1 / -1;
    grid-row: 5;
  }
}

#qnav-overlay .qnav-frame,
.qnav-body,
.qnav-group,
.qnav-link {
  box-sizing: border-box !important;
  min-width: 0 !important;
}

.qnav-body {
  align-content: start !important;
}

.qnav-link {
  display: grid !important;
  grid-template-columns: 30px minmax(0, 1fr) !important;
  column-gap: 10px !important;
  align-items: start !important;
}

.qnav-link .qnav-mark {
  grid-column: 1 !important;
  grid-row: 1 / span 2 !important;
  margin-right: 0 !important;
  min-width: 0 !important;
}

.qnav-link .qnav-text,
.qnav-link .qnav-sub {
  grid-column: 2 !important;
  min-width: 0 !important;
  max-width: 100% !important;
}

.qnav-link .qnav-text {
  display: block !important;
  overflow-wrap: anywhere !important;
}

.qnav-link .qnav-sub {
  padding-left: 0 !important;
  overflow-wrap: anywhere !important;
}

.qnav-link.qnav-link-quiet {
  grid-template-columns: minmax(0, 1fr) !important;
}

.qnav-link.qnav-link-quiet .qnav-text,
.qnav-link.qnav-link-quiet .qnav-sub {
  grid-column: 1 !important;
}

@media (min-width: 1101px) {
  .qnav-body {
    grid-template-columns: minmax(190px, 0.7fr) minmax(430px, 1.55fr) minmax(250px, 0.85fr) !important;
    gap: clamp(34px, 4vw, 68px) !important;
  }

  .qnav-body .qnav-group:nth-child(2) {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 14px clamp(24px, 2.6vw, 38px) !important;
    align-content: start !important;
  }

  .qnav-body .qnav-group:nth-child(2) .qnav-group-label {
    grid-column: 1 / -1 !important;
  }
}

@media (min-width: 701px) and (max-width: 1100px) {
  #qnav-overlay {
    padding: 48px 28px 28px !important;
    overflow: hidden !important;
  }

  #qnav-overlay .qnav-frame {
    height: calc(100vh - 76px) !important;
    height: calc(100dvh - 76px) !important;
    min-height: 0 !important;
    padding: clamp(36px, 5vw, 48px) clamp(26px, 5vw, 44px) 28px !important;
    grid-template-rows: auto minmax(0, 1fr) auto !important;
    gap: 26px !important;
    overflow: hidden !important;
  }

  .qnav-body {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 32px 34px !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding-right: 6px !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .qnav-body .qnav-group:nth-child(1) {
    grid-column: 1 !important;
    grid-row: 1 !important;
  }

  .qnav-body .qnav-group:nth-child(3) {
    grid-column: 2 !important;
    grid-row: 1 !important;
  }

  .qnav-body .qnav-group:nth-child(2) {
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 14px 30px !important;
    align-content: start !important;
  }

  .qnav-body .qnav-group:nth-child(2) .qnav-group-label {
    grid-column: 1 / -1 !important;
  }

  .qnav-link .qnav-text {
    font-size: clamp(24px, 3.3vw, 32px) !important;
  }

  .qnav-link.qnav-link-quiet .qnav-text {
    font-size: clamp(20px, 2.6vw, 25px) !important;
  }

  .qnav-link .qnav-sub {
    line-height: 1.45 !important;
  }
}

@media (min-width: 561px) and (max-width: 900px) {
  .s08 .frame {
    display: grid !important;
    grid-template-rows: auto auto auto auto !important;
    gap: 28px !important;
  }

  .s08 .frame-head,
  .s08 .head,
  .s08 .roles,
  .s08 .frame-foot {
    grid-column: 1 !important;
    position: static !important;
  }

  .s08 .frame-head { grid-row: 1 !important; margin-bottom: 0 !important; }
  .s08 .head { grid-row: 2 !important; margin: 0 !important; }
  .s08 .roles { grid-row: 3 !important; }
  .s08 .frame-foot { grid-row: 4 !important; margin-top: 0 !important; }

  .s08 .head {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    align-items: start !important;
    padding: 0 0 22px !important;
    border-bottom: 1px solid rgba(26, 26, 26, 0.22) !important;
    text-align: left !important;
  }

  .s08 .big-title {
    font-size: clamp(38px, 7vw, 58px) !important;
    max-width: 18ch !important;
  }

  .s08 .head .body {
    max-width: 58ch !important;
    margin: 0 !important;
  }

  .s08 .roles {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 20px !important;
  }

  .s08 .roles > .role {
    grid-column: auto !important;
    grid-row: auto !important;
    min-width: 0 !important;
    min-height: auto !important;
    padding: 16px !important;
  }

  .s08 .role .mark {
    aspect-ratio: 16 / 10 !important;
  }

  .s09-pin,
  .s09-stage,
  .s09-frame {
    height: auto !important;
  }

  .s09-stage {
    position: relative !important;
    display: block !important;
    padding: 0 !important;
  }

  .s09-frame {
    padding: 34px 32px 38px !important;
    overflow: visible !important;
  }

  .s09-slide {
    position: relative !important;
    inset: auto !important;
    width: auto !important;
    max-width: 100% !important;
    display: grid !important;
    grid-template-columns: minmax(120px, 0.48fr) minmax(0, 1fr) !important;
    grid-template-rows: auto auto !important;
    gap: 20px 28px !important;
    align-items: end !important;
    opacity: 1 !important;
    margin-bottom: 34px !important;
  }

  .s09-slide .bignum {
    grid-column: 1 !important;
    grid-row: 1 !important;
    font-size: clamp(78px, 13vw, 118px) !important;
    line-height: 0.86 !important;
    margin: 0 !important;
    overflow-wrap: anywhere !important;
  }

  .s09-slide .bignum .it {
    font-size: 0.32em !important;
    line-height: 1.02 !important;
    margin-top: 8px !important;
  }

  .s09-slide > div:nth-child(2) {
    grid-column: 2 !important;
    grid-row: 1 !important;
    min-width: 0 !important;
  }

  .s09-slide .arc {
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
    height: auto !important;
    min-height: 0 !important;
    aspect-ratio: 16 / 9 !important;
  }

  .s09-progress,
  .s09-count {
    display: none !important;
  }

  .s15-frame .frame > div.bm-inline-grid-2col {
    grid-template-columns: minmax(0, 0.95fr) minmax(280px, 0.82fr) !important;
    gap: 32px !important;
    align-items: end !important;
    margin-bottom: 24px !important;
    padding-bottom: 20px !important;
    border-bottom: 1px solid rgba(26, 26, 26, 0.28) !important;
  }

  .s15-frame .frame > div.bm-inline-grid-2col > .serif {
    font-size: clamp(40px, 7vw, 66px) !important;
    max-width: 12ch !important;
  }

  .s15-frame .frame > div.bm-inline-grid-2col > .body {
    max-width: 44ch !important;
    justify-self: end !important;
  }
}

@media (min-width: 901px) {
  .s08 .frame {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto auto auto !important;
    row-gap: clamp(28px, 3vw, 42px) !important;
    align-items: start !important;
  }

  .s08 .frame-head {
    grid-column: 1 !important;
    grid-row: 1 !important;
    margin-bottom: 0 !important;
  }

  .s08 .head {
    grid-column: 1 !important;
    grid-row: 2 !important;
    width: 100% !important;
    max-width: 100% !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 0.58fr) !important;
    gap: clamp(28px, 3vw, 52px) !important;
    align-items: start !important;
    justify-items: stretch !important;
    margin: 0 !important;
    padding: 0 0 clamp(18px, 2vw, 28px) !important;
    text-align: left !important;
    border-bottom: 1px solid rgba(26, 26, 26, 0.22) !important;
  }

  .s08 .big-title {
    max-width: 20ch !important;
    font-size: clamp(40px, 3.6vw, 66px) !important;
    line-height: 1.02 !important;
  }

  .s08 .head .body {
    max-width: 42ch !important;
    margin: 0 !important;
    justify-self: end !important;
    padding-top: 0.35em !important;
  }

  .s08 .roles {
    grid-column: 1 !important;
    grid-row: 3 !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: clamp(22px, 2.5vw, 34px) !important;
    align-items: stretch !important;
  }

  .s08 .roles > .role {
    grid-column: auto !important;
    grid-row: auto !important;
    min-width: 0 !important;
    min-height: auto !important;
    padding: 18px 20px 22px !important;
    gap: 12px !important;
  }

  .s08 .role .mark {
    aspect-ratio: 16 / 10 !important;
  }

  .s08 .role .desc {
    max-width: 38ch !important;
  }

  .s08 .frame-foot {
    position: static !important;
    grid-column: 1 !important;
    grid-row: 4 !important;
    margin-top: 0 !important;
  }

  .s09-frame {
    padding: clamp(38px, 4vw, 56px) clamp(42px, 5vw, 70px) !important;
  }

  .s09-slide {
    inset: clamp(38px, 4vw, 56px) clamp(42px, 5vw, 70px) !important;
    grid-template-columns: minmax(260px, 0.82fr) minmax(300px, 1fr) minmax(290px, 0.9fr) !important;
    gap: clamp(34px, 3.4vw, 56px) !important;
    align-items: center !important;
  }

  .s09-slide .bignum {
    font-size: clamp(108px, 10.4vw, 182px) !important;
    line-height: 0.84 !important;
  }

  .s09-slide .bignum .it {
    max-width: 11ch !important;
    font-size: 0.31em !important;
    line-height: 1.04 !important;
    margin-top: 12px !important;
  }

  .s09-slide > div:nth-child(2) {
    min-width: 0 !important;
    max-width: 50ch !important;
  }

  .s09-slide h2 {
    font-size: clamp(34px, 3.6vw, 60px) !important;
  }

  .s09-slide .arc {
    width: 100% !important;
    max-width: 100% !important;
    height: clamp(340px, 52vh, 560px) !important;
  }

  .s12 .gal {
    height: clamp(700px, 92vh, 980px) !important;
    min-height: 700px !important;
  }

  .s12 .gal .word {
    z-index: 3 !important;
    font-size: clamp(100px, 10.5vw, 184px) !important;
  }

  .s12 .gal .piece {
    transform: none !important;
    transform-origin: center !important;
  }

  .s12 .gal .piece:hover {
    transform: translateY(-5px) !important;
  }

  .s12 .gal .piece:nth-child(2) { left: 3% !important; top: 3% !important; right: auto !important; bottom: auto !important; width: 20% !important; height: 30% !important; }
  .s12 .gal .piece:nth-child(3) { left: 28% !important; top: 1% !important; right: auto !important; bottom: auto !important; width: 20% !important; height: 28% !important; transform: rotate(-1.2deg) !important; }
  .s12 .gal .piece:nth-child(4) { left: auto !important; top: 4% !important; right: 3% !important; bottom: auto !important; width: 21% !important; height: 30% !important; }
  .s12 .gal .piece:nth-child(5) { left: 5% !important; top: auto !important; right: auto !important; bottom: 3% !important; width: 20% !important; height: 31% !important; }
  .s12 .gal .piece:nth-child(6) { left: 32% !important; top: auto !important; right: auto !important; bottom: 0 !important; width: 21% !important; height: 30% !important; transform: rotate(1.1deg) !important; }
  .s12 .gal .piece:nth-child(7) { left: auto !important; top: auto !important; right: 5% !important; bottom: 3% !important; width: 22% !important; height: 33% !important; }
  .s12 .gal .piece:nth-child(8) { left: auto !important; top: 36% !important; right: 2% !important; bottom: auto !important; width: 18% !important; height: 25% !important; }

  .s12 .gal .piece:nth-child(3):hover { transform: translateY(-5px) rotate(-1.2deg) !important; }
  .s12 .gal .piece:nth-child(6):hover { transform: translateY(-5px) rotate(1.1deg) !important; }

  .s15-frame .frame > div.bm-inline-grid-2col {
    grid-template-columns: minmax(0, 0.92fr) minmax(320px, 0.72fr) !important;
    gap: clamp(34px, 4vw, 72px) !important;
    align-items: end !important;
    margin-bottom: clamp(22px, 2.4vw, 36px) !important;
    padding-bottom: clamp(18px, 2vw, 30px) !important;
    border-bottom: 1px solid rgba(26, 26, 26, 0.3) !important;
  }

  .s15-frame .frame > div.bm-inline-grid-2col > .serif {
    font-size: clamp(42px, 4.8vw, 82px) !important;
    max-width: 12ch !important;
  }

  .s15-frame .frame > div.bm-inline-grid-2col > .body {
    max-width: 46ch !important;
    justify-self: end !important;
    padding-left: clamp(18px, 2vw, 30px) !important;
    border-left: 1px solid rgba(26, 26, 26, 0.24) !important;
  }

  .s15-frame .map-stage {
    min-height: clamp(560px, 72vh, 780px) !important;
    padding-top: clamp(6px, 1vw, 16px) !important;
  }
}

@media (min-width: 1200px) {
  .s08 .roles {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 560px) {
  html,
  body {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden !important;
  }

  @supports (overflow: clip) {
    html,
    body {
      overflow-x: clip !important;
    }
  }

  body {
    font-size: 14px;
    line-height: 1.62;
    overflow-x: hidden;
  }

  .prog,
  .prog-num,
  .rail-v,
  .frame-corner {
    display: none !important;
  }

  section.sheet,
  .s16 {
    padding: calc(62px + env(safe-area-inset-top, 0px)) 8px 10px !important;
    min-height: auto !important;
  }

  .frame,
  .frame.tall,
  .frame.short,
  .s16 .frame,
  .proj-frame,
  .s09-frame {
    min-height: auto !important;
    padding: 16px 12px 22px !important;
  }

  .frame-head {
    gap: 8px !important;
    margin-bottom: 20px !important;
  }

  .frame-head .left,
  .frame-head .right,
  .proj-frame .head,
  .s16 .close-head {
    width: 100% !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
  }

  .caps,
  .caps.tight,
  .close-meta,
  .qnav-meta,
  .qnav-group-label,
  .qnav-foot {
    font-size: 10px !important;
    line-height: 1.4 !important;
    letter-spacing: 0.16em !important;
  }

  .pill {
    padding: 5px 10px !important;
    font-size: 10px !important;
    letter-spacing: 0.14em !important;
    line-height: 1.35 !important;
  }

  .body,
  .proj-frame .pbody,
  .s08 .role .desc,
  .s14 .row .nt {
    max-width: 100% !important;
    font-size: 14px !important;
    line-height: 1.62 !important;
  }

  .lede {
    max-width: 100% !important;
    font-size: 17px !important;
    line-height: 1.45 !important;
  }

  .caption {
    max-width: 100% !important;
    font-size: 12.5px !important;
    line-height: 1.5 !important;
  }

  .frame-foot {
    width: 100% !important;
    max-width: 100% !important;
    font-size: 10px !important;
    line-height: 1.45 !important;
    letter-spacing: 0.16em !important;
    overflow: hidden !important;
  }

  .frame-foot > :first-child,
  .qnav-foot > :first-child {
    max-width: 100% !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
  }

  .frame-foot .sig,
  .frame-foot .footer-logo-link,
  .qnav-foot .footer-logo-link {
    white-space: nowrap !important;
  }

  .s01 .stage {
    min-height: 50vh !important;
    height: auto !important;
    margin-top: 14px !important;
  }

  [data-sec="01"] .stage {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
    min-height: auto !important;
    height: auto !important;
    margin-top: 14px !important;
  }

  [data-sec="01"] .title-block,
  [data-sec="01"] .hero-plate {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  [data-sec="01"] .title {
    max-width: 100% !important;
    font-size: clamp(42px, 15vw, 64px) !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
    overflow-wrap: anywhere !important;
  }

  [data-sec="01"] .hero-plate .arc {
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    aspect-ratio: 4 / 3 !important;
  }

  .s01 .video-frame {
    width: min(88vw, 300px) !important;
    padding: 5px !important;
  }

  .s01 .mono-word {
    max-width: calc(100vw - 48px) !important;
    font-size: clamp(42px, 13vw, 68px) !important;
    white-space: normal !important;
  }

  .s02 .composition,
  .s03 .grid,
  .s04 .num-row .item,
  .s05 .concept-head,
  .s08 .head,
  .s14 .row,
  .s16 .close-body,
  .bm-inline-grid-2col,
  .bm-inline-grid-3col {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  .season-cells,
  .season-cell {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .s02 .lede-line {
    max-width: 100% !important;
    font-size: clamp(28px, 9vw, 42px) !important;
  }

  .s03 .stack-num {
    width: auto !important;
    max-width: 100% !important;
    font-size: clamp(64px, 18vw, 96px) !important;
  }

  .moment-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 18px !important;
    min-height: auto !important;
    padding-top: 0 !important;
  }

  .moment-grid > *,
  .moment-grid > :first-child,
  .moment-grid > .moment-prose,
  .moment-grid > .moment-side {
    grid-column: 1 !important;
    grid-row: auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .moment-grid .stack-num {
    width: auto !important;
    max-width: 100% !important;
    font-size: clamp(58px, 18vw, 92px) !important;
    line-height: 0.9 !important;
  }

  .moment-grid .stack-num .yr {
    font-size: 0.34em !important;
    line-height: 1.05 !important;
    margin-top: 8px !important;
  }

  .moment-side {
    position: static !important;
  }

  .s04 .num-row {
    gap: 20px !important;
  }

  .s04 .num-row .item {
    grid-template-columns: 1fr !important;
    padding: 22px 0 !important;
    gap: 12px !important;
    align-items: start !important;
  }

  .s04 .num-row .item > *,
  .s04 .num-body,
  .s04 .num-body .body {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .s04 .num-huge {
    font-size: clamp(56px, 18vw, 86px) !important;
    line-height: 0.88 !important;
    white-space: nowrap !important;
  }

  .s05 .duet {
    padding: 3vh 0 !important;
  }

  .s05 .duet .line,
  .s05 .duet .amp {
    font-size: clamp(38px, 12vw, 58px) !important;
  }

  .s05 .three-up,
  .s08 .roles,
  .s10 .score,
  .s12 .gal {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  .s06 .video-wide,
  .s11 .bg,
  .proj-frame .pl,
  .s07 .floats .float .img-wrap,
  .s12 .gal .piece {
    padding: 5px !important;
  }

  .s07 .gallery {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    min-height: auto !important;
  }

  .s07 .armature {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    max-width: calc(100vw - 48px) !important;
    margin: 0 auto 8px !important;
    margin-bottom: 16px !important;
    font-size: clamp(34px, 10vw, 52px) !important;
    line-height: 0.98 !important;
    white-space: normal !important;
    text-align: center !important;
  }

  .s07 .floats {
    position: relative !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    height: auto !important;
  }

  .s07 .floats .float {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    width: auto !important;
    height: auto !important;
    min-width: 0 !important;
    transform: none !important;
  }

  .s07 .floats .float .meta {
    gap: 8px !important;
    font-size: 10px !important;
    letter-spacing: 0.14em !important;
  }

  .s07 .floats .float .meta .rail {
    display: none !important;
  }

  .s07 .floats .float .img-wrap {
    min-height: 160px !important;
    aspect-ratio: 4 / 3 !important;
  }

  .s08 .big-title {
    font-size: clamp(32px, 10vw, 50px) !important;
  }

  .s08 .role {
    min-height: auto !important;
    padding: 14px !important;
    gap: 10px !important;
  }

  .s08 .role .name {
    font-size: 11px !important;
    letter-spacing: 0.14em !important;
  }

  .s09-pin,
  .s09-stage,
  .s09-frame {
    height: auto !important;
  }

  .s09-stage {
    display: block !important;
    padding: 0 !important;
  }

  .s09-slide {
    width: auto !important;
    max-width: 100% !important;
    gap: 12px !important;
    margin-bottom: 28px !important;
  }

  .s09-slide .bignum {
    font-size: clamp(44px, 13vw, 62px) !important;
    line-height: 0.9 !important;
    margin: 0 0 8px !important;
  }

  .s09-slide .bignum .it {
    display: block !important;
    font-size: 0.36em !important;
    line-height: 1.05 !important;
    margin-top: 8px !important;
  }

  .s09-slide h2 {
    font-size: clamp(26px, 8.5vw, 38px) !important;
    margin-bottom: 12px !important;
  }

  .s09-slide .arc {
    height: auto !important;
    min-height: 160px !important;
    aspect-ratio: 4 / 3 !important;
  }

  .s10 .score {
    margin-top: 22px !important;
  }

  .s10 .score > div {
    padding: 20px 12px 22px !important;
  }

  .s10 .score .n {
    font-size: 34px !important;
  }

  .s10 .score .reg {
    font-size: 20px !important;
  }

  .s11 .comp {
    min-height: auto !important;
    padding: 16px 0 !important;
  }

  .s11 .word {
    max-width: calc(100vw - 48px) !important;
    font-size: clamp(40px, 12vw, 62px) !important;
  }

  .s12 .gal {
    display: grid !important;
    height: auto !important;
    align-items: start !important;
    box-sizing: border-box !important;
  }

  .s12 .gal .word {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    grid-column: 1 / -1 !important;
    margin: 0 0 2px !important;
    text-align: center !important;
    font-size: clamp(36px, 12vw, 54px) !important;
    white-space: normal !important;
  }

  .s12 .gal .piece {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    width: 100% !important;
    min-width: 0 !important;
    height: auto !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    transform: none !important;
    box-sizing: border-box !important;
  }

  .s12 .gal .piece .inner {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 16 / 11 !important;
    flex: 0 0 auto !important;
    box-sizing: border-box !important;
  }

  .s12 .gal .piece .pname {
    position: relative !important;
    z-index: 1 !important;
    padding: 0 2px !important;
    background: var(--parchment) !important;
    font-size: 16px !important;
    line-height: 1.2 !important;
    opacity: 1 !important;
    transform: none !important;
    white-space: normal !important;
  }

  .proj-frame {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto auto auto !important;
    align-items: start !important;
    min-height: auto !important;
    margin-bottom: 20px !important;
    gap: 18px !important;
  }

  .proj-frame.rev {
    grid-template-columns: 1fr !important;
  }

  .proj-frame > .frame-head {
    grid-column: 1 !important;
    grid-row: 1 !important;
    margin-bottom: 0 !important;
  }

  .proj-frame > .pl,
  .proj-frame.rev > .pl {
    grid-column: 1 !important;
    grid-row: 2 !important;
    order: 0 !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  .proj-frame > div:not(.frame-head):not(.frame-foot):not(.pl) {
    grid-column: 1 !important;
    grid-row: 3 !important;
    min-width: 0 !important;
  }

  .proj-frame > .frame-foot {
    position: static !important;
    grid-column: 1 !important;
    grid-row: 4 !important;
    margin-top: 0 !important;
  }

  .proj-frame .ptitle {
    margin-bottom: 18px !important;
    font-size: clamp(30px, 10vw, 46px) !important;
  }

  .proj-frame .enter {
    width: 100% !important;
    justify-content: center !important;
    margin-top: 24px !important;
    padding: 11px 12px !important;
    font-size: 11px !important;
    letter-spacing: 0.14em !important;
  }

  .proj-frame .pl {
    aspect-ratio: 4 / 3 !important;
  }

  .s14 .row {
    padding: 20px 0 !important;
  }

  .s14 .row .nm {
    font-size: clamp(24px, 8vw, 34px) !important;
  }

  .s14 .row .rl {
    font-size: 10px !important;
    letter-spacing: 0.14em !important;
  }

  .s14 .frame > div.bm-inline-grid-any {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  .s14 .frame > div.bm-inline-grid-any > * {
    min-width: 0 !important;
    max-width: 100% !important;
    justify-self: start !important;
  }

  .s15-frame .map-stage {
    display: block !important;
    min-height: auto !important;
  }

  .map-svg {
    width: 100% !important;
    height: auto !important;
  }

  .map-marker .lbl {
    display: none !important;
  }

  .s16 .close-body {
    padding: 32px 0 18px !important;
    gap: 26px !important;
  }

  .s16 .close-quote {
    max-width: 100% !important;
    font-size: clamp(30px, 10vw, 44px) !important;
  }

  .s16 .lockup {
    gap: 12px !important;
  }

  .s16 .lockup .mark {
    white-space: normal !important;
    font-size: clamp(32px, 10vw, 44px) !important;
  }

  #qnav-trigger {
    top: calc(10px + env(safe-area-inset-top, 0px)) !important;
    left: calc(10px + env(safe-area-inset-left, 0px)) !important;
    width: 48px !important;
    height: 48px !important;
    min-width: 48px !important;
    min-height: 48px !important;
    padding: 0 !important;
    display: grid !important;
    place-items: center !important;
    border: 1px solid rgba(26, 26, 26, 0.16) !important;
    border-radius: 14px !important;
    background: linear-gradient(180deg, rgba(242, 237, 228, 0.95) 0%, rgba(235, 228, 216, 0.92) 100%) !important;
    box-shadow: 0 10px 24px rgba(26, 26, 26, 0.12) !important;
    -webkit-backdrop-filter: blur(10px) !important;
    backdrop-filter: blur(10px) !important;
    cursor: pointer !important;
    touch-action: manipulation !important;
  }

  body.qnav-dark-bg #qnav-trigger {
    border-color: rgba(242, 237, 228, 0.18) !important;
    background: linear-gradient(180deg, rgba(26, 26, 26, 0.74) 0%, rgba(26, 26, 26, 0.64) 100%) !important;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.28) !important;
  }

  #qnav-trigger .qnav-label {
    display: none !important;
  }

  #qnav-trigger .qnav-rules {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;
    width: 20px !important;
    margin: 0 auto !important;
  }

  #qnav-trigger .qnav-rules span {
    width: 18px !important;
    margin: 0 auto !important;
  }

  #qnav-trigger .qnav-rules span:nth-child(2) {
    width: 14px !important;
  }

  #qnav-trigger:hover .qnav-rules span:nth-child(1),
  #qnav-trigger:hover .qnav-rules span:nth-child(3) {
    width: 18px !important;
  }

  #qnav-trigger:hover .qnav-rules span:nth-child(2) {
    width: 14px !important;
  }

  #qnav-overlay {
    padding: 36px 8px 12px !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
    align-items: flex-start !important;
  }

  #qnav-overlay .qnav-frame {
    width: 100% !important;
    max-width: 100% !important;
    height: calc(100vh - 48px) !important;
    height: calc(100dvh - 48px) !important;
    max-height: calc(100vh - 48px) !important;
    max-height: calc(100dvh - 48px) !important;
    min-height: 0 !important;
    padding: 28px 14px 16px !important;
    gap: 18px !important;
    grid-template-rows: auto minmax(0, 1fr) auto !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
  }

  #qnav-close {
    top: 10px !important;
    right: 12px !important;
    min-width: 44px !important;
    min-height: 44px !important;
    cursor: pointer !important;
    touch-action: manipulation !important;
  }

  .qnav-head {
    padding-right: 58px !important;
  }

  .qnav-body,
  .qnav-group {
    gap: 14px !important;
    min-width: 0 !important;
  }

  .qnav-body {
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding-right: 4px !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .qnav-link {
    display: grid !important;
    grid-template-columns: 24px minmax(0, 1fr) !important;
    column-gap: 8px !important;
    padding: 5px 0 !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-wrap: anywhere !important;
  }

  .qnav-link.qnav-link-quiet {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .qnav-link .qnav-mark {
    grid-column: 1 !important;
    grid-row: 1 / span 2 !important;
    margin-right: 8px !important;
    padding-top: 5px !important;
    font-size: 10px !important;
  }

  .qnav-link .qnav-text {
    grid-column: 2 !important;
    font-size: clamp(22px, 8vw, 28px) !important;
    max-width: 100% !important;
    overflow-wrap: anywhere !important;
  }

  .qnav-link .qnav-sub {
    grid-column: 2 !important;
    font-size: 11px !important;
    line-height: 1.45 !important;
    max-width: 100% !important;
    overflow-wrap: anywhere !important;
  }

  .qnav-link.qnav-link-quiet .qnav-text,
  .qnav-link.qnav-link-quiet .qnav-sub {
    grid-column: 1 !important;
  }
}

@media (max-width: 560px) {
  .s08 .frame {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto auto auto !important;
    gap: 18px !important;
  }

  .s08 .frame-head,
  .s08 .head,
  .s08 .roles,
  .s08 .frame-foot {
    grid-column: 1 !important;
    position: static !important;
  }

  .s08 .frame-head { grid-row: 1 !important; margin-bottom: 0 !important; }
  .s08 .head { grid-row: 2 !important; }
  .s08 .roles { grid-row: 3 !important; }
  .s08 .frame-foot { grid-row: 4 !important; margin-top: 0 !important; }

  .s08 .head {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    margin: 0 !important;
    padding-bottom: 16px !important;
    border-bottom: 1px solid rgba(26, 26, 26, 0.22) !important;
    text-align: left !important;
  }

  .s08 .head .body {
    margin: 0 !important;
    max-width: 100% !important;
  }

  .s08 .roles {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  .s08 .roles > .role {
    grid-column: auto !important;
    grid-row: auto !important;
  }

  .s09-slide {
    position: relative !important;
    inset: auto !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    opacity: 1 !important;
  }

  .s09-slide .bignum {
    font-size: clamp(54px, 16vw, 78px) !important;
    line-height: 0.86 !important;
  }

  .s09-slide .bignum .it {
    font-size: 0.34em !important;
    line-height: 1.04 !important;
  }

  .s09-slide > div:nth-child(2),
  .s09-slide .arc {
    grid-column: 1 !important;
    min-width: 0 !important;
  }

  .s15-frame .frame > div.bm-inline-grid-2col {
    gap: 12px !important;
    margin-bottom: 18px !important;
    padding-bottom: 16px !important;
    border-bottom: 1px solid rgba(26, 26, 26, 0.24) !important;
  }

  .s15-frame .frame > div.bm-inline-grid-2col > .serif {
    font-size: clamp(32px, 11vw, 48px) !important;
    max-width: 12ch !important;
  }

  .s15-frame .frame > div.bm-inline-grid-2col > .body {
    max-width: 100% !important;
  }

  .s15-frame .map-stage {
    padding-top: 8px !important;
  }
}

#qnav-trigger,
#qnav-trigger *,
#qnav-close,
#qnav-close *,
#qnav-overlay a,
#qnav-overlay button,
.qnav-link,
.qnav-link * {
  cursor: pointer !important;
}

#qnav-overlay,
#qnav-overlay .qnav-frame,
.qnav-head,
.qnav-body,
.qnav-group,
.qnav-foot,
.qnav-meta,
.qnav-group-label,
.qnav-rail-v {
  cursor: default !important;
}

.qnav-rail-v {
  top: clamp(52px, 5vh, 70px) !important;
  bottom: clamp(52px, 6vh, 80px) !important;
  width: 12px !important;
  max-height: calc(100% - 112px) !important;
  writing-mode: vertical-rl !important;
  text-orientation: mixed !important;
  line-height: 1 !important;
  overflow: hidden !important;
  pointer-events: none !important;
}

.qnav-rail-v.left {
  left: clamp(10px, 1.2vw, 18px) !important;
  transform: none !important;
}

.qnav-rail-v.right {
  right: clamp(10px, 1.2vw, 18px) !important;
  transform: none !important;
}

@media (min-width: 701px) and (max-width: 1100px) {
  .qnav-rail-v {
    display: block !important;
    top: 48px !important;
    bottom: 48px !important;
    max-height: calc(100% - 96px) !important;
    font-size: 10px !important;
    letter-spacing: 0.16em !important;
  }

  .qnav-rail-v.left { left: 8px !important; }
  .qnav-rail-v.right { right: 8px !important; }
}

@media (max-width: 700px) {
  .qnav-rail-v {
    display: none !important;
  }
}

@media (min-width: 561px) and (max-width: 900px) {
  [data-sec="01"] .stage {
    grid-template-columns: minmax(0, 1fr) !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
  }

  [data-sec="01"] .stage > *,
  [data-sec="01"] .title-block,
  [data-sec="01"] .hero-plate,
  [data-sec="01"] .hero-plate .arc,
  [data-sec="01"] .hero-plate img {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  [data-sec="01"] .title {
    max-width: 100% !important;
    overflow-wrap: anywhere !important;
  }

  [data-sec="01"] .hero-plate .tag {
    left: 12px !important;
    right: 12px !important;
    max-width: calc(100% - 24px) !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
  }

  .s04 .num-row .item {
    grid-template-columns: minmax(0, 0.56fr) minmax(0, 1fr) !important;
    gap: clamp(24px, 4vw, 36px) !important;
    align-items: start !important;
  }

  .s04 .num-row .item > :first-child {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .s04 .num-huge {
    font-size: clamp(58px, 9.2vw, 84px) !important;
    line-height: 0.88 !important;
    letter-spacing: -0.01em !important;
    white-space: nowrap !important;
  }

  .s04 .num-huge .suf {
    font-size: 0.4em !important;
  }

  .s04 .num-row .item > :first-child .caps {
    max-width: 17ch !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
    line-height: 1.35 !important;
  }

  .s08 .frame-head {
    display: grid !important;
    grid-template-columns: 1fr auto !important;
    gap: 16px !important;
    align-items: start !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid rgba(26, 26, 26, 0.18) !important;
  }

  .s08 .head {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    padding-top: 0 !important;
    padding-bottom: 20px !important;
    border-bottom: 1px solid rgba(26, 26, 26, 0.24) !important;
  }

  .s08 .big-title {
    max-width: 16ch !important;
  }

  .s08 .head .body {
    max-width: 58ch !important;
    justify-self: start !important;
  }
}

@media (min-width: 901px) {
  .s04 .num-row .item {
    grid-template-columns: minmax(0, 0.48fr) minmax(0, 1fr) !important;
    gap: clamp(52px, 5.4vw, 92px) !important;
    align-items: start !important;
  }

  .s04 .num-row .item > :first-child {
    min-width: 0 !important;
    max-width: 300px !important;
    justify-self: start !important;
  }

  .s04 .num-huge {
    font-size: clamp(70px, 6.8vw, 118px) !important;
    line-height: 0.88 !important;
    letter-spacing: -0.012em !important;
    white-space: nowrap !important;
  }

  .s04 .num-huge .suf {
    font-size: 0.4em !important;
  }

  .s04 .num-row .item > :first-child .caps {
    max-width: 18ch !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
    line-height: 1.35 !important;
  }

  .s04 .num-body {
    justify-self: start !important;
  }

  .s08 .frame-head {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: clamp(24px, 3vw, 48px) !important;
    align-items: start !important;
    padding-bottom: clamp(10px, 1vw, 16px) !important;
    border-bottom: 1px solid rgba(26, 26, 26, 0.18) !important;
  }

  .s08 .head {
    grid-template-columns: minmax(0, 0.88fr) minmax(320px, 0.5fr) !important;
    gap: clamp(42px, 5vw, 86px) !important;
    align-items: start !important;
    padding-top: clamp(8px, 1vw, 16px) !important;
    padding-bottom: clamp(24px, 2.4vw, 36px) !important;
  }

  .s08 .big-title {
    max-width: 16ch !important;
    font-size: clamp(42px, 3.6vw, 66px) !important;
  }

  .s08 .head .body {
    max-width: 40ch !important;
    justify-self: end !important;
    align-self: start !important;
    padding-left: clamp(18px, 2vw, 30px) !important;
    border-left: 1px solid rgba(26, 26, 26, 0.24) !important;
  }
}

@media (min-width: 901px) and (max-width: 1199px) {
  [data-sec="01"] .stage {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .s01 .mono-word {
    max-width: 100% !important;
    font-size: clamp(104px, 14vw, 188px) !important;
  }

  .s09-slide {
    grid-template-columns: minmax(220px, 0.72fr) minmax(260px, 1fr) minmax(240px, 0.82fr) !important;
    gap: clamp(24px, 2.4vw, 32px) !important;
  }

  .s09-slide .bignum {
    font-size: clamp(96px, 9.4vw, 126px) !important;
  }

  .s09-slide .arc {
    height: clamp(310px, 48vh, 500px) !important;
  }
}

@media (max-width: 560px) {
  .s01 .video-frame {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .s11 .comp {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-rows: auto !important;
    place-items: center !important;
    min-height: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 18px 0 !important;
    overflow: visible !important;
  }

  .s11 .bg,
  .s11 .word {
    grid-column: 1 !important;
    grid-row: 1 !important;
  }

  .s11 .bg {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: clamp(120px, 36vw, 156px) !important;
    aspect-ratio: 16 / 7 !important;
  }

  .s11 .word {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    z-index: 2 !important;
    width: calc(100% - 28px) !important;
    max-width: calc(100% - 28px) !important;
    padding: 0 4px !important;
    text-align: center !important;
    font-size: clamp(32px, 11vw, 46px) !important;
    line-height: 0.96 !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  .s12 .gal .piece {
    overflow: visible !important;
    padding: 6px 6px 9px !important;
    background: var(--parchment) !important;
  }

  .s12 .gal .piece .inner {
    position: relative !important;
    z-index: 1 !important;
  }

  .s12 .gal .piece .pname {
    position: static !important;
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 8px 0 0 !important;
    padding: 7px 2px 1px !important;
    z-index: 2 !important;
    background: var(--parchment) !important;
    color: var(--ink) !important;
    opacity: 1 !important;
    transform: none !important;
    font-size: clamp(15px, 4.7vw, 18px) !important;
    line-height: 1.18 !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
    pointer-events: auto !important;
  }

  .s04 .num-row .item > :first-child .caps {
    max-width: 100% !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
    line-height: 1.35 !important;
  }

  .s08 .frame-head {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    padding-bottom: 10px !important;
    border-bottom: 1px solid rgba(26, 26, 26, 0.16) !important;
  }
}

@media (max-width: 700px) {
  .frame-foot .footer-logo-link,
  .qnav-foot .footer-logo-link {
    max-width: 100% !important;
  }

  .frame-foot .footer-logo-img,
  .qnav-foot .footer-logo-img {
    width: min(320px, 82vw) !important;
    max-height: 100px !important;
  }

  .s16 .frame-foot,
  .s-final .frame-foot {
    position: static !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    align-items: start !important;
    margin-top: 28px !important;
    padding-top: 16px !important;
    border-top: 1px solid rgba(242, 237, 228, 0.22) !important;
    overflow: visible !important;
  }

  .s16 .frame-foot .footer-logo-link,
  .s-final .frame-foot .footer-logo-link {
    justify-self: start !important;
  }

  .s16 .frame-foot .footer-logo-img,
  .s-final .frame-foot .footer-logo-img {
    width: min(260px, 78vw) !important;
    max-height: 82px !important;
  }

  .s-final .body-wrap {
    min-height: auto !important;
    padding-bottom: 28px !important;
  }
}

@media (max-width: 380px) {
  body {
    font-size: 13.5px !important;
  }

  section.sheet,
  .s16 {
    padding: calc(62px + env(safe-area-inset-top, 0px)) 6px 8px !important;
  }

  .frame,
  .frame.tall,
  .frame.short,
  .s16 .frame,
  .proj-frame,
  .s09-frame {
    padding: 14px 10px 20px !important;
  }

  .s07 .floats .float .img-wrap,
  .s09-slide .arc {
    min-height: 140px !important;
  }

  .s12 .gal .piece .inner {
    aspect-ratio: 4 / 3 !important;
  }

  .frame-foot {
    font-size: 10px !important;
    letter-spacing: 0.14em !important;
  }
}
