/* ===== QUICKNAV — scoped, does not modify any existing chrome ===== */
#qnav-trigger {
  position: fixed; top: 24px; left: 24px; z-index: 120;
  background: transparent; border: 0; padding: 8px 10px;
  display: flex; flex-direction: column; align-items: flex-start; gap: 8px;
  font-family: 'Inter', sans-serif; font-weight: 300;
  cursor: none;
}
#qnav-trigger .qnav-rules { display: flex; flex-direction: column; gap: 5px; }
#qnav-trigger .qnav-rules span {
  display: block; height: 1px; background: #1A1A1A; width: 26px;
  transition: width 0.45s cubic-bezier(.22,.61,.36,1), background 0.3s ease;
}
#qnav-trigger:hover .qnav-rules span:nth-child(1) { width: 32px; }
#qnav-trigger:hover .qnav-rules span:nth-child(2) { width: 22px; }
#qnav-trigger:hover .qnav-rules span:nth-child(3) { width: 32px; }
#qnav-trigger .qnav-label {
  font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: #4D4D4D;
  transition: color 0.3s ease;
}
body.qnav-dark-bg #qnav-trigger .qnav-rules span { background: rgba(242,237,228,0.85); }
body.qnav-dark-bg #qnav-trigger .qnav-label { color: rgba(242,237,228,0.7); }
body.qnav-locked #qnav-trigger { opacity: 0; pointer-events: none; transition: opacity 0.25s ease; }

#qnav-overlay {
  position: fixed; inset: 0; z-index: 110;
  background: #F2EDE4;
  opacity: 0; visibility: hidden;
  transition: opacity 0.4s ease, visibility 0s linear 0.4s;
  display: flex; align-items: stretch; justify-content: center;
  padding: 60px 60px;
  overflow-y: auto;
}
#qnav-overlay.open { opacity: 1; visibility: visible; transition: opacity 0.4s ease, visibility 0s linear; }

#qnav-overlay .qnav-frame {
  position: relative;
  border: 1px solid rgba(26,26,26,0.85);
  width: 100%; max-width: 1400px;
  padding: 76px 64px 36px;
  display: grid; grid-template-rows: auto 1fr auto;
  gap: 32px;
}
.qnav-corner {
  position: absolute; width: 22px; height: 22px; background: #F2EDE4;
  border: 1px solid rgba(26,26,26,0.85);
}
.qnav-corner.tl { top: -11px; left: -11px; border-right: none; border-bottom: none; }
.qnav-corner.tr { top: -11px; right: -11px; border-left: none; border-bottom: none; }
.qnav-corner.bl { bottom: -11px; left: -11px; border-right: none; border-top: none; }
.qnav-corner.br { bottom: -11px; right: -11px; border-left: none; border-top: none; }

.qnav-rail-v {
  position: absolute; transform-origin: 0 0;
  font-family: 'Inter', sans-serif; font-size: 11px;
  letter-spacing: 0.24em; text-transform: uppercase; color: #4D4D4D; white-space: nowrap;
}
.qnav-rail-v.left  { top: 56px; left: 18px;  transform: rotate(90deg) translate(0, -100%); }
.qnav-rail-v.right { top: 56px; right: 18px; transform: rotate(90deg) translate(0, 0); }

#qnav-close {
  position: absolute; top: 20px; right: 22px;
  background: transparent; border: 0;
  display: flex; flex-direction: column; align-items: flex-end; gap: 8px;
  cursor: none; padding: 4px; z-index: 2;
}
#qnav-close .qnav-x { display: block; width: 24px; height: 24px; position: relative; }
#qnav-close .qnav-x::before, #qnav-close .qnav-x::after {
  content: ''; position: absolute; top: 50%; left: 0; width: 100%; height: 1px;
  background: #1A1A1A; transition: transform 0.45s cubic-bezier(.22,.61,.36,1);
}
#qnav-close .qnav-x::before { transform: rotate(45deg); }
#qnav-close .qnav-x::after  { transform: rotate(-45deg); }
#qnav-close:hover .qnav-x::before { transform: rotate(225deg); }
#qnav-close:hover .qnav-x::after  { transform: rotate(135deg); }
#qnav-close .qnav-label {
  font-family: 'Inter', sans-serif; font-size: 11px; letter-spacing: 0.28em;
  text-transform: uppercase; color: #4D4D4D;
}

.qnav-head {
  display: flex; justify-content: space-between; align-items: center; gap: 24px;
  padding: 0 96px 8px 0;
}
.qnav-meta {
  font-family: 'Inter', sans-serif; font-size: 12px; letter-spacing: 0.24em;
  text-transform: uppercase; color: #4D4D4D;
}

.qnav-body {
  display: grid; grid-template-columns: 0.85fr 1.4fr 1fr; gap: 56px; align-items: start;
}

.qnav-group { display: flex; flex-direction: column; gap: 18px; }
.qnav-group-label {
  font-family: 'Inter', sans-serif; font-size: 11px; letter-spacing: 0.26em;
  text-transform: uppercase; color: #4D4D4D;
  padding-bottom: 12px; border-bottom: 1px solid rgba(26,26,26,0.4);
}

.qnav-link {
  font-family: 'Cormorant Garamond', Georgia, serif; font-weight: 300;
  color: #1A1A1A; text-decoration: none;
  display: block; padding: 8px 0;
  transition: transform 0.45s cubic-bezier(.22,.61,.36,1);
  position: relative;
}
.qnav-link:hover { transform: translateX(10px); }
.qnav-link .it { font-style: italic; color: #8B4A2E; }
.qnav-link .qnav-mark {
  display: inline-block; font-family: 'Inter', sans-serif; font-weight: 300;
  font-size: 12px; letter-spacing: 0.18em; color: #4D4D4D;
  vertical-align: top; margin-right: 12px; padding-top: 8px; text-transform: lowercase;
}
.qnav-link .qnav-text {
  font-size: clamp(28px, 2.6vw, 38px); line-height: 1.04; letter-spacing: -0.005em;
  display: inline-block;
}
.qnav-link .qnav-sub {
  display: block; margin-top: 4px; padding-left: 28px;
  font-family: 'Inter', sans-serif; font-weight: 300;
  font-size: 12px; letter-spacing: 0.04em; color: #4D4D4D; text-transform: lowercase;
}
.qnav-link.qnav-link-quiet .qnav-text { font-size: clamp(20px, 1.8vw, 26px); color: #4D4D4D; }
.qnav-link.qnav-link-quiet .qnav-sub  { padding-left: 0; }

.qnav-foot {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 16px; border-top: 1px solid rgba(26,26,26,0.4);
  font-family: 'Inter', sans-serif; font-size: 11px; letter-spacing: 0.24em;
  text-transform: uppercase; color: #4D4D4D;
}
@media (max-width: 1100px) {
  .qnav-body { grid-template-columns: 1fr; gap: 40px; }
}
@media (max-width: 700px) {
  #qnav-overlay { padding: 48px 16px; }
  #qnav-overlay .qnav-frame { padding: 72px 24px 36px; }
  .qnav-rail-v { display: none; }
  .qnav-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    padding-right: 72px;
  }
}

body.qnav-locked { overflow: hidden; }

@media (max-width: 700px) {
  section.sheet { padding: 16px 12px; }
  .frame, .s16 .frame { padding: 22px 16px 28px; min-height: auto; }
  .frame.tall, .frame.short { min-height: auto; }
  .frame-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 28px;
  }
  .frame-head .left, .frame-head .right {
    width: 100%;
    flex-wrap: wrap;
    gap: 10px;
  }
  .frame-head .right { justify-content: flex-start; }
  .frame-head .bar { display: none; }
  .frame-foot {
    position: static;
    margin-top: 20px;
    padding-top: 12px;
    border-top: 1px solid rgba(26,26,26,0.24);
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .frame-foot > :first-child,
  .qnav-foot > :first-child {
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
  }
  .frame-foot .sig,
  .frame-foot .footer-logo-link,
  .qnav-foot .footer-logo-link { white-space: nowrap; }
  .s16 .frame-foot { border-top-color: rgba(242,237,228,0.22); }
  .pill {
    max-width: 100%;
    white-space: normal;
    line-height: 1.35;
    text-align: left;
  }
  .body, .lede, .caption, .s08 .role .desc, .proj-frame .pbody, .s14 .row .nt { max-width: 100%; }
  .s01 .stage { height: auto; min-height: 60vh; margin-top: 24px; }
  .s01 .mono-word {
    font-size: clamp(54px, 16vw, 92px);
    max-width: calc(100vw - 72px);
    white-space: normal;
    text-align: center;
  }
  .s07 .gallery { min-height: auto; }
  .s07 .armature {
    position: relative;
    left: auto;
    top: auto;
    transform: none;
    margin: 0 auto 24px;
    font-size: clamp(40px, 11vw, 78px);
    max-width: calc(100vw - 72px);
    white-space: normal;
    text-align: center;
  }
  .s07 .floats {
    height: auto;
    display: grid;
    gap: 18px;
  }
  .s07 .floats .float {
    position: relative;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    width: auto !important;
    height: auto !important;
    transform: none !important;
  }
  .s07 .floats .float .img-wrap { min-height: 220px; }
  .s07 .date-meta { position: static; margin-top: 12px; }
  .s09-pin { height: auto; }
  .s09-stage {
    position: relative;
    height: auto;
    display: block;
    padding: 0;
  }
  .s09-frame {
    height: auto;
    padding: 22px 16px 28px;
    overflow: visible;
  }
  .s09-slide {
    position: relative;
    inset: auto !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    width: auto !important;
    max-width: 100%;
    display: grid;
    opacity: 1;
    margin-bottom: 24px;
  }
  .s09-slide .bignum {
    font-size: clamp(68px, 12vw, 90px) !important;
    line-height: 0.88;
    margin: 0 0 10px;
  }
  .s09-slide .bignum .it {
    display: block;
    font-size: 0.34em !important;
    line-height: 1.05;
    margin-top: 10px;
  }
  .s09-slide:last-child { margin-bottom: 0; }
  .s09-progress, .s09-count { display: none; }
  .s10 .score { grid-template-columns: 1fr; }
  .s11 .comp { min-height: auto; padding: 20px 0; }
  .s11 .word {
    position: relative;
    left: auto;
    top: auto;
    transform: none;
    margin: 0 auto 16px;
    font-size: clamp(48px, 14vw, 86px);
    max-width: calc(100vw - 72px);
    text-align: center;
  }
  .s11 .bg { width: 100%; }
  .s12 .gal .piece .pname {
    position: relative;
    opacity: 1;
    transform: none;
    margin-top: 0;
    padding: 0 2px;
    background: var(--parchment);
    white-space: normal;
    z-index: 1;
  }
  .s12 .gal { align-items: start; }
  .s12 .gal .word {
    grid-column: 1 / -1;
    margin-bottom: 4px;
  }
  .s12 .gal .piece {
    display: flex;
    flex-direction: column;
    gap: 10px;
    height: auto !important;
  }
  .s12 .gal .piece .inner {
    width: 100%;
    height: auto !important;
    aspect-ratio: 4 / 5;
    flex: 0 0 auto;
  }
  .proj-frame {
    padding: 22px 16px 28px;
    min-height: auto;
    gap: 24px;
  }
  .proj-frame .head { flex-wrap: wrap; }
  .proj-frame .ptitle { font-size: clamp(34px, 11vw, 58px); }
  .s14 .hover-img { display: none; }
  .s15-frame .map-stage { min-height: auto; }
  .map-svg { width: 100%; height: auto; }
  .map-marker .lbl {
    max-width: 120px;
    white-space: normal;
  }
  .bm-inline-grid-2col {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }
  .bm-inline-flex-space-between {
    flex-wrap: wrap !important;
    gap: 10px !important;
  }
  #qnav-overlay { padding: 42px 10px 18px; }
  #qnav-overlay .qnav-frame { padding: 32px 18px 20px; gap: 24px; }
  .qnav-head, .qnav-foot {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .qnav-link .qnav-text { font-size: clamp(24px, 8vw, 32px); }
  .qnav-link .qnav-sub { padding-left: 0; }
}
