:root {
  --bg: #ece5d6;
  --bg-2: #e3dac6;
  --ink: #14110d;
  --ink-2: rgba(20,17,13,0.55);
  --ink-3: rgba(20,17,13,0.18);

  --ocean: #1a3a4a;
  --ocean-deep: #122a36;
  --land-light: #efd8a8;
  --land:        #e8d3a4;
  --land-shade:  #b89968;
  --land-deep:   #8d6f3f;

  --hot: #c44d2e;
  --hot-deep: #952f17;
  --hot-soft: rgba(196,77,46,0.18);

  --phi: 1.618;
  --u: 8px;
  --margin-x: clamp(28px, 6.18vw, 72px);
  --margin-y: clamp(28px, 3.82vw, 48px);
}
* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0; height: 100%;
  background:
    radial-gradient(1200px 800px at 50% 45%, var(--bg) 0%, var(--bg-2) 100%);
  color: var(--ink);
  font-family: "Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, system-ui, Roboto, sans-serif;
  font-feature-settings: "ss01", "ss02";
  overflow: hidden;
}
body { display: grid; place-items: center; }

.stage {
  width: 560px;
  height: 560px;
  position: relative;
}
.stage canvas, .stage svg {
  position: absolute;
  inset: 0;
  width: 560px;
  height: 560px;
}
#shadow { z-index: 0; }
#whirl  { z-index: 1; }
#globe  { z-index: 2; cursor: grab; touch-action: none; user-select: none; -webkit-user-select: none; }
#globe.dragging { cursor: grabbing; }
#pins   { z-index: 3; pointer-events: none; }
#pins .hit { pointer-events: auto; cursor: pointer; outline: none; }
#pins .hit:focus, #pins .hit:focus-visible { outline: none; }

.planet-title {
  position: absolute;
  inset: auto;
  left: 50%;
  top: -36px;
  transform: translateX(-50%);
  font-family: "Pretendard Variable", Pretendard, sans-serif;
  font-weight: 700;
  font-size: 22px;
  letter-spacing: 0.42em;
  color: var(--ink);
  opacity: 0;
  pointer-events: none;
  white-space: nowrap;
  z-index: 5;
  transition: opacity 600ms ease, transform 600ms ease;
  text-shadow: 0 1px 0 rgba(255,250,235,0.4);
}
.planet-title.show {
  opacity: 0.8;
  transform: translateX(-50%) translateY(2px);
}

.card {
  position: absolute;
  z-index: 6;
  background: var(--bg);
  border: 1.5px solid var(--ink);
  padding: 20px 22px 18px;
  width: max-content;
  min-width: 300px;
  transform-origin: bottom left;
  transform: translate(-50%, calc(-100% - 18px)) scale(0.96);
  opacity: 0;
  pointer-events: none;
  transition: opacity 220ms ease, transform 220ms ease;
  box-shadow: 4px 4px 0 var(--ink);
}
.card.open {
  opacity: 1;
  transform: translate(-50%, calc(-100% - 18px)) scale(1);
  pointer-events: auto;
}
.card .accent {
  position: absolute;
  left: 22px; right: 40px; top: 12px;
  height: 2px;
  background: var(--hot);
}
.card .eyebrow {
  margin-top: 10px;
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--hot-deep);
  margin-bottom: 8px;
  font-weight: 700;
}
.card .name {
  font-family: "Pretendard Variable", Pretendard, sans-serif;
  font-size: 30px;
  font-weight: 700;
  margin-bottom: 14px;
  letter-spacing: -0.025em;
  line-height: 1.05;
  white-space: nowrap;
  transition: color 160ms ease;
}
.card .name.has-url {
  cursor: pointer;
}
.card .name.has-url:hover {
  color: var(--hot);
}
.card .meta {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 6px 16px;
  font-size: 12px;
  color: var(--ink);
}
.card .meta dt { color: var(--ink-2); letter-spacing: 0.18em; font-size: 10px; font-weight: 600; text-transform: uppercase; align-self: center; }
.card .meta dd { margin: 0; font-variant-numeric: tabular-nums; font-weight: 600; font-size: 13px; }
.card .coords {
  margin-top: 10px;
  padding-top: 8px;
  border-top: 1px dashed var(--ink-2);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-2);
  font-variant-numeric: tabular-nums;
  opacity: 0.7;
}
.card .coords:empty { display: none; }
.card .url-hint {
  margin-top: 6px;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-2);
  opacity: 0.7;
}
.card .url-hint::before {
  content: '↗';
  margin-right: 5px;
}
.card .url-hint:empty { display: none; }
.card .pointer {
  position: absolute;
  left: 50%;
  bottom: -8px;
  width: 13px;
  height: 13px;
  background: var(--bg);
  border-right: 1.5px solid var(--ink);
  border-bottom: 1.5px solid var(--ink);
  transform: translateX(-50%) rotate(45deg);
}
.card .close {
  position: absolute;
  top: 8px;
  right: 12px;
  background: transparent;
  border: 0;
  font: inherit;
  font-size: 18px;
  color: var(--ink-2);
  cursor: pointer;
  padding: 2px 6px;
  line-height: 1;
}
.card .close:hover { color: var(--ink); }

.quicknav {
  position: fixed;
  left: 50%;
  bottom: calc(var(--margin-y) + 26px);
  transform: translateX(-50%);
  z-index: 10;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: center;
  gap: 6px 10px;
  max-width: min(880px, 86vw);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-2);
  font-weight: 600;
}
.qn-link {
  color: var(--ink);
  text-decoration: none;
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  padding: 2px 0;
  border-bottom: 1px solid transparent;
  transition: color 180ms ease, border-color 180ms ease;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: none;
  font-size: 12px;
}
.qn-link .qn-num {
  font-size: 9px;
  color: var(--hot-deep);
  letter-spacing: 0.18em;
  font-variant-numeric: tabular-nums;
}
.qn-link:hover,
.qn-link:focus-visible {
  outline: none;
  color: var(--hot-deep);
  border-bottom-color: var(--hot-deep);
}
.copyright {
  position: fixed;
  left: 50%;
  bottom: calc(var(--margin-y) - 8px);
  transform: translateX(-50%);
  z-index: 10;
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ink-2);
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  white-space: nowrap;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  cursor: pointer;
  transition: color 180ms ease, border-color 180ms ease;
}
.copyright-id {
  color: inherit;
}
.copyright:hover,
.copyright:focus-visible {
  outline: none;
  color: var(--hot-deep);
  border-bottom-color: var(--hot-deep);
}

@media (max-aspect-ratio: 1/1) {
  .quicknav {
    bottom: calc(var(--margin-y) + 52px);
    max-width: 92vw;
    gap: 4px 8px;
    font-size: 10px;
    letter-spacing: 0.12em;
  }
  .qn-link { font-size: 11px; gap: 4px; }
}

@media (max-aspect-ratio: 9/16) {
  .quicknav {
    bottom: calc(var(--margin-y) + 36px);
    gap: 3px 6px;
  }
  .qn-link { font-size: 10px; gap: 3px; padding: 1px 0; }
  .qn-num { display: none; }
}

.id-card {
  position: fixed;
  top: var(--margin-y);
  left: var(--margin-x);
  z-index: 10;
  display: flex;
  flex-direction: column;
  gap: 13px;
  max-width: 38.2vw;
}
.id-eyebrow {
  display: flex;
  align-items: center;
  gap: 13px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.id-eyebrow::before {
  content: "";
  width: 21px;
  height: 1px;
  background: var(--ink-3);
}
.id-eyebrow .dot {
  width: 5px;
  height: 5px;
  background: var(--hot);
  display: inline-block;
}
.id-dept {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--ink);
  line-height: 1.2;
  display: flex;
  align-items: baseline;
  gap: 13px;
}
.id-dept .tag {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.236em;
  color: var(--bg);
  background: var(--ink);
  padding: 3px 8px 2px;
  line-height: 1;
  transform: translateY(-2px);
}
.id-name {
  font-size: 68px;
  font-weight: 800;
  letter-spacing: -0.0382em;
  line-height: 0.92;
  color: var(--ink);
  margin: 0;
  display: flex;
  align-items: baseline;
  gap: 13px;
}
.id-name .accent {
  width: 8px;
  height: 8px;
  background: var(--hot);
  display: inline-block;
  transform: translateY(-8px);
  flex-shrink: 0;
}
.id-name-link {
  color: inherit;
  text-decoration: none;
  transition: color 0.15s ease;
}
.id-name-link:hover {
  color: var(--hot);
}
.id-meta {
  display: grid;
  grid-template-columns: auto auto;
  gap: 5px 21px;
  font-size: 11px;
  color: var(--ink-2);
  letter-spacing: 0.04em;
  align-items: center;
  padding-top: 8px;
  border-top: 1px solid var(--ink-3);
  width: fit-content;
  padding-right: 8px;
}
.id-meta dt {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.id-meta dd {
  margin: 0;
  font-weight: 600;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
}
.id-email {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px dashed var(--ink-3);
  cursor: pointer;
  transition: color 0.15s ease, border-color 0.15s ease;
}
.id-email:hover {
  color: var(--hot);
  border-bottom-color: var(--hot);
}
.id-email.copied {
  color: var(--hot);
  border-bottom-color: transparent;
}

.id-action {
  display: none;
  align-items: center;
  gap: 10px;
  padding-top: 8px;
  border-top: 1px dashed var(--ink-3);
  width: fit-content;
  color: var(--ink);
  text-decoration: none;
  font-size: 11px;
  letter-spacing: 0.04em;
  transition: color 180ms ease;
}
body[data-mode="earth"] .id-action--earth { display: inline-flex; }
body[data-mode="mars"] .id-action--mars { display: inline-flex; }
body[data-mode="mercury"] .id-action-group--mercury { display: inline-flex; }
body[data-mode="mercury"] .id-action--mercury { display: inline-flex; }
button.id-action {
  border: none;
  background: none;
  cursor: pointer;
  font-family: inherit;
}
.id-action .tag {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.236em;
  color: var(--bg);
  background: var(--ink);
  padding: 3px 8px 2px;
  line-height: 1;
  transition: background 180ms ease;
}
.id-action__label {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: -0.005em;
}
.id-action__arrow {
  font-size: 13px;
  color: var(--ink-2);
  line-height: 1;
  transition: transform 180ms ease, color 180ms ease;
}
.id-action:hover { color: var(--hot-deep); }
.id-action:hover .tag { background: var(--hot-deep); }
.id-action:hover .id-action__arrow {
  color: var(--hot-deep);
  transform: translate(2px, -2px);
}
.id-action:focus-visible {
  outline: 2px solid var(--hot);
  outline-offset: 4px;
}
.id-action-group--mercury {
  display: none;
  flex-direction: column;
  gap: 13px;
}

.nav {
  position: fixed;
  top: var(--margin-y);
  right: var(--margin-x);
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 13px;
  width: 356px;
  max-width: min(356px, calc(50vw - 296px - var(--margin-x)));
}
.nav-eyebrow {
  display: flex;
  align-items: center;
  gap: 13px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
  padding-right: 3px;
}
.nav-eyebrow::before {
  content: "";
  width: 21px;
  height: 1px;
  background: var(--ink-3);
}
.nav-eyebrow .dot {
  width: 5px;
  height: 5px;
  background: var(--hot);
  display: inline-block;
}
.nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  background: transparent;
  min-width: 0;
  width: 100%;
}
.nav-item {
  display: grid;
  grid-template-columns: 34px 1fr 21px;
  align-items: baseline;
  column-gap: 21px;
  padding: 21px 0;
  color: var(--ink);
  text-decoration: none;
  font-size: 11px;
  letter-spacing: 0.04em;
  cursor: pointer;
  border-bottom: 1px solid var(--ink-3);
  border-top: 0;
  border-left: 0;
  border-right: 0;
  background: transparent;
  width: 100%;
  text-align: left;
  font-family: inherit;
  transition: color 200ms ease, transform 200ms ease;
}
.nav-item:first-of-type { border-top: 1px solid var(--ink); }
.nav-item:last-of-type  { border-bottom: 1px solid var(--ink); }
.nav-item .num {
  font-size: 10px;
  font-weight: 600;
  color: var(--ink-2);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.12em;
  align-self: baseline;
}
.nav-item .label {
  font-family: "Pretendard Variable", Pretendard, sans-serif;
  font-size: 17px;
  letter-spacing: -0.018em;
  line-height: 1.2;
  font-weight: 700;
}
.nav-item .arrow {
  font-size: 13px;
  color: var(--ink-3);
  transition: transform 240ms cubic-bezier(.2,.7,.2,1), color 200ms ease;
  align-self: baseline;
  text-align: right;
}
.nav-item:hover,
.nav-item:focus-visible {
  outline: none;
  color: var(--hot-deep);
}
.nav-item:hover .arrow,
.nav-item:focus-visible .arrow {
  color: var(--hot-deep);
  transform: translateX(8px);
}
.nav-item:hover .num,
.nav-item:focus-visible .num {
  color: var(--hot-deep);
}
.nav-item.is-active {
  color: var(--hot-deep);
}
.nav-item.is-active .num,
.nav-item.is-active .arrow {
  color: var(--hot-deep);
}
.nav-item.is-active .arrow {
  transform: translateX(8px);
}
.nav-foot {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
  padding-right: 3px;
  font-variant-numeric: tabular-nums;
  margin-top: 8px;
}

@media (max-width: 1280px) {
  .nav-item {
    grid-template-columns: 28px 1fr 18px;
    column-gap: 14px;
    padding: 17px 0;
  }
  .nav-item .label { font-size: 15px; }
}

@media (max-width: 1080px) {
  .nav-item {
    grid-template-columns: 24px 1fr 14px;
    column-gap: 10px;
    padding: 13px 0;
  }
  .nav-item .label { font-size: 13px; line-height: 1.2; }
  .nav-item .num { font-size: 9px; letter-spacing: 0.08em; }
  .nav-item .arrow { font-size: 11px; }
  .nav-eyebrow {
    font-size: 9px;
    letter-spacing: 0.28em;
    gap: 9px;
  }
  .nav-eyebrow::before { width: 14px; }
  .nav-foot { font-size: 9px; letter-spacing: 0.28em; }
}

@media (max-width: 880px) {
  .nav .nav-eyebrow { display: none; }
  .nav .nav-foot { display: none; }
  .nav-item {
    grid-template-columns: 20px 1fr 12px;
    column-gap: 8px;
    padding: 10px 0;
  }
  .nav-item .label { font-size: 11px; line-height: 1.18; }
  .nav-item .num { font-size: 8px; }
  .nav-item .arrow { font-size: 10px; }
}

@media (max-aspect-ratio: 1/2) {
  .nav { display: none; }
}

.viewport-hint {
  position: fixed;
  bottom: var(--margin-y);
  z-index: 10;
  display: none;
  flex-direction: column;
  gap: 8px;
  max-width: 280px;
  pointer-events: none;
}
.viewport-hint--left {
  left: var(--margin-x);
  align-items: flex-start;
  text-align: left;
}
.viewport-hint--right {
  right: var(--margin-x);
  align-items: flex-end;
  text-align: right;
}
.vh-eyebrow {
  display: flex;
  align-items: center;
  gap: 13px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.viewport-hint--left .vh-eyebrow::before {
  content: "";
  width: 21px;
  height: 1px;
  background: var(--ink-3);
}
.viewport-hint--right .vh-eyebrow::after {
  content: "";
  width: 21px;
  height: 1px;
  background: var(--ink-3);
}
.vh-eyebrow .dot {
  width: 5px;
  height: 5px;
  background: var(--hot);
  display: inline-block;
}
.vh-lead {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1.3;
  color: var(--ink);
}
.vh-sub {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--ink-2);
  line-height: 1.5;
}
.vh-keys {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 2px;
}
.vh-key {
  display: inline-block;
  padding: 4px 9px 3px;
  border: 1px solid var(--ink);
  background: var(--bg);
  font-family: "Pretendard Variable", Pretendard, sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  line-height: 1;
  box-shadow: 2px 2px 0 var(--ink);
}
.vh-plus {
  font-size: 10px;
  font-weight: 700;
  color: var(--ink-2);
}

@media (min-width: 1080px) and (min-aspect-ratio: 1/1) {
  .viewport-hint { display: flex; }
}

.ticket-overlay {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: none;
  place-items: center;
  padding: 24px;
}
.ticket-overlay.open { display: grid; }
.ticket-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(20, 17, 13, 0.34);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  opacity: 0;
  transition: opacity 240ms ease;
}
.ticket-overlay.open .ticket-backdrop { opacity: 1; }
.ticket-overlay.closing .ticket-backdrop {
  opacity: 0;
  transition-duration: 540ms;
}

.ticket {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 200px;
  width: min(720px, 92vw);
  max-height: 92vh;
  filter: drop-shadow(6px 6px 0 var(--ink));
  opacity: 0;
  transform: translateY(34px) scale(0.92);
  color: var(--ink);
  font-family: "Pretendard Variable", Pretendard, sans-serif;
  transform-origin: 50% 0;
}
.ticket-overlay.open .ticket {
  animation: ticketEnter 540ms cubic-bezier(.2,.78,.28,1.06) forwards;
}
.ticket-overlay.closing .ticket {
  animation: none;
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: none;
}

@keyframes ticketEnter {
  0% {
    opacity: 0;
    transform: translateY(34px) scale(0.92) rotate(-0.6deg);
    filter: drop-shadow(2px 2px 0 var(--ink));
  }
  55% {
    opacity: 1;
    transform: translateY(-3px) scale(1.012) rotate(0.15deg);
    filter: drop-shadow(8px 9px 0 var(--ink));
  }
  78% {
    transform: translateY(1px) scale(0.998) rotate(-0.05deg);
    filter: drop-shadow(5px 5px 0 var(--ink));
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1) rotate(0);
    filter: drop-shadow(6px 6px 0 var(--ink));
  }
}

.ticket-overlay.open .ticket__route,
.ticket-overlay.open .ticket__meta,
.ticket-overlay.open .ticket__foot,
.ticket-overlay.open .ticket__stub-meta,
.ticket-overlay.open .ticket__barcode {
  animation: ticketReveal 380ms cubic-bezier(.2,.7,.25,1) backwards;
}
.ticket-overlay.open .ticket__route       { animation-delay: 200ms; }
.ticket-overlay.open .ticket__meta        { animation-delay: 280ms; }
.ticket-overlay.open .ticket__foot        { animation-delay: 360ms; }
.ticket-overlay.open .ticket__stub-meta   { animation-delay: 240ms; }
.ticket-overlay.open .ticket__barcode     { animation-delay: 340ms; }

@keyframes ticketReveal {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  .ticket-overlay.open .ticket {
    animation: none;
    opacity: 1;
    transform: translateY(0) scale(1);
  }
  .ticket-overlay.open .ticket__route,
  .ticket-overlay.open .ticket__meta,
  .ticket-overlay.open .ticket__foot,
  .ticket-overlay.open .ticket__stub-meta,
  .ticket-overlay.open .ticket__barcode {
    animation: none;
    opacity: 1;
    transform: none;
  }
}

.ticket__half {
  background:
    repeating-linear-gradient(45deg, rgba(20,17,13,0.022) 0 1px, transparent 1px 4px),
    repeating-linear-gradient(-45deg, rgba(20,17,13,0.018) 0 1px, transparent 1px 5px),
    var(--bg);
  border: 1.5px solid var(--ink);
  padding: 22px 26px 18px;
  position: relative;
}
.ticket__half--main {
  border-right: 0;
  display: grid;
  grid-template-rows: auto auto auto auto;
  gap: 16px;
  min-width: 0;
}
.ticket__half--stub {
  border-left: 0;
  display: grid;
  grid-template-rows: auto auto auto auto;
  gap: 12px;
  padding: 22px 22px 16px;
}
.ticket__half--main::after {
  content: "";
  position: absolute;
  top: 14px;
  bottom: 14px;
  right: -1px;
  border-right: 2px dashed var(--ink-3);
  pointer-events: none;
  transition: opacity 100ms ease;
}
.ticket__half--main::before {
  content: "";
  position: absolute;
  top: 6px;
  right: -7px;
  width: 12px;
  height: 12px;
  background: radial-gradient(circle at center, transparent 0 4px, var(--bg) 4.5px);
  border-radius: 50%;
  z-index: 2;
  pointer-events: none;
}

.ticket__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}
.ticket__brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.ticket__dot {
  width: 7px;
  height: 7px;
  background: var(--hot);
  display: inline-block;
  flex-shrink: 0;
}
.ticket__dot--small {
  width: 5px;
  height: 5px;
}
.ticket__brand-text {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink);
}
.ticket__brand-sub {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.236em;
  text-transform: uppercase;
  color: var(--bg);
  background: var(--ink);
  padding: 3px 7px 2px;
  line-height: 1;
  transform: translateY(-1px);
}
.ticket__voyno {
  font-size: 10px;
  letter-spacing: 0.2em;
  color: var(--ink);
  text-transform: uppercase;
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  white-space: nowrap;
}
.ticket__voyno-label {
  margin-right: 6px;
  color: var(--ink-3);
}

.ticket__route {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(110px, 1.05fr) minmax(0, 1fr);
  align-items: end;
  gap: 14px;
  padding: 14px 0 16px;
  border-top: 1px solid var(--ink-3);
  border-bottom: 1px solid var(--ink-3);
}
.ticket__port {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
  cursor: pointer;
  border-radius: 4px;
  transition: opacity 180ms ease;
}
.ticket__port:hover { opacity: 0.6; }
.ticket__port--right { text-align: right; }
.ticket__sub {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ink-2);
  font-variant-numeric: tabular-nums;
}
.ticket__code {
  font-size: 38px;
  font-weight: 800;
  letter-spacing: -0.022em;
  line-height: 1;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  margin-top: 2px;
}
.ticket__city {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-top: 2px;
}
.ticket__path {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  align-self: center;
  padding-bottom: 4px;
}
.ticket__dist {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.24em;
  color: var(--hot-deep);
  font-variant-numeric: tabular-nums;
}
.ticket__line {
  position: relative;
  width: 100%;
  height: 1.5px;
  background: var(--ink);
}
.ticket__line::before,
.ticket__line::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 6px;
  height: 6px;
  border: 1.5px solid var(--ink);
  background: var(--bg);
  border-radius: 50%;
  transform: translate(-50%, -50%);
}
.ticket__line::before { left: 0; }
.ticket__line::after  { left: 100%; }
.ticket__icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: var(--bg);
  padding: 0 8px;
  font-size: 13px;
  color: var(--hot);
  line-height: 1;
}
.ticket__path-foot {
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 0.32em;
  color: var(--ink-3);
  text-transform: uppercase;
}

.ticket__meta {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto minmax(0, 1fr);
  gap: 9px 18px;
  margin: 0;
  padding: 2px 0 0;
  align-items: center;
}
.ticket__meta dt {
  margin: 0;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.ticket__meta dd {
  margin: 0;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -0.005em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ticket__foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--ink-3);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-2);
  font-weight: 600;
}
.ticket__serial-line {
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.16em;
  color: var(--ink);
  font-weight: 700;
}

.ticket__stub-head {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink);
}
.ticket__stub-meta {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 7px 14px;
  margin: 0;
  padding: 10px 0;
  border-top: 1px solid var(--ink-3);
  border-bottom: 1px solid var(--ink-3);
  align-items: center;
}
.ticket__stub-meta dt {
  margin: 0;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.ticket__stub-meta dd {
  margin: 0;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: -0.005em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  text-align: right;
}
.ticket__barcode {
  height: 42px;
  background-image: repeating-linear-gradient(
    to right,
    var(--ink) 0 2px, transparent 2px 4px,
    var(--ink) 4px 5px, transparent 5px 8px,
    var(--ink) 8px 11px, transparent 11px 13px,
    var(--ink) 13px 14px, transparent 14px 17px,
    var(--ink) 17px 19px, transparent 19px 21px
  );
  background-size: 21px 100%;
  border-top: 1px solid var(--ink-3);
  border-bottom: 1px solid var(--ink-3);
}
.ticket__stub-serial {
  font-size: 9px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-2);
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  text-align: center;
}

.ticket__close {
  position: absolute;
  top: 6px;
  right: 8px;
  background: transparent;
  border: 0;
  font: inherit;
  font-size: 22px;
  line-height: 1;
  color: var(--ink-2);
  cursor: pointer;
  padding: 4px 8px;
  z-index: 3;
  transition: color 180ms ease;
}
.ticket__close:hover { color: var(--hot-deep); }
.ticket__close:focus-visible {
  outline: 1.5px solid var(--ink);
  outline-offset: 2px;
  color: var(--ink);
}
.ticket-overlay.closing .ticket__close {
  opacity: 0;
  pointer-events: none;
  transition: opacity 80ms ease;
}

.ticket-overlay.closing .ticket__half--main::after,
.ticket-overlay.closing .ticket__half--main::before {
  opacity: 0;
}
.ticket-overlay.closing .ticket__half--main {
  border-right: 1.5px solid var(--ink);
  filter: drop-shadow(3px 3px 0 var(--ink));
  clip-path: polygon(
    0% 0%,
    calc(100% - 1px) 0%,
    100% 5%,
    calc(100% - 6px) 10%,
    calc(100% - 1px) 16%,
    calc(100% - 7px) 22%,
    100% 28%,
    calc(100% - 3px) 34%,
    calc(100% - 8px) 40%,
    calc(100% - 2px) 46%,
    100% 52%,
    calc(100% - 5px) 58%,
    calc(100% - 1px) 64%,
    calc(100% - 7px) 70%,
    100% 76%,
    calc(100% - 4px) 82%,
    calc(100% - 1px) 88%,
    calc(100% - 6px) 94%,
    100% 100%,
    0% 100%
  );
  animation: tearMain 720ms cubic-bezier(.55,.06,.7,.4) forwards;
}
.ticket-overlay.closing .ticket__half--stub {
  border-left: 1.5px solid var(--ink);
  filter: drop-shadow(3px 3px 0 var(--ink));
  clip-path: polygon(
    1px 0%,
    100% 0%,
    100% 100%,
    1px 100%,
    7px 95%,
    1px 89%,
    5px 83%,
    0% 77%,
    7px 71%,
    2px 65%,
    8px 59%,
    1px 53%,
    0% 47%,
    6px 41%,
    1px 35%,
    7px 29%,
    0% 23%,
    5px 17%,
    1px 11%,
    7px 5%,
    1px 0%
  );
  animation: tearStub 720ms cubic-bezier(.55,.06,.7,.4) forwards;
}
@keyframes tearMain {
  0%   { transform: translate(0, 0) rotate(0deg); opacity: 1; }
  8%   { transform: translate(-2px, 1px) rotate(-0.6deg); opacity: 1; }
  100% { transform: translate(-160px, 360px) rotate(-13deg); opacity: 0; }
}
@keyframes tearStub {
  0%   { transform: translate(0, 0) rotate(0deg); opacity: 1; }
  8%   { transform: translate(2px, 1px) rotate(0.8deg); opacity: 1; }
  100% { transform: translate(220px, 380px) rotate(18deg); opacity: 0; }
}

@media (prefers-reduced-motion: reduce) {
  .ticket-overlay.closing .ticket__half--main,
  .ticket-overlay.closing .ticket__half--stub {
    clip-path: none;
    animation: none;
    opacity: 0;
    transition: opacity 200ms ease;
  }
}

@media (max-width: 600px) {
  .ticket {
    grid-template-columns: minmax(0, 1fr) 140px;
    width: min(560px, 96vw);
  }
  .ticket__half { padding: 16px 16px 14px; }
  .ticket__half--stub { padding: 16px 14px 14px; }
  .ticket__code { font-size: 28px; }
  .ticket__route {
    grid-template-columns: minmax(0, 1fr) minmax(70px, 0.9fr) minmax(0, 1fr);
    gap: 8px;
    padding: 10px 0 12px;
  }
  .ticket__city { font-size: 10px; }
  .ticket__meta {
    grid-template-columns: auto minmax(0, 1fr);
    gap: 6px 12px;
  }
  .ticket__meta dd { font-size: 12px; }
  .ticket__stub-meta dd { font-size: 12px; }
}

.search-overlay {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: none;
  padding: clamp(48px, 9vh, 96px) 24px 24px;
}
.search-overlay.open { display: block; }
.search-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(20, 17, 13, 0.34);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  opacity: 0;
  transition: opacity 200ms ease;
}
.search-overlay.open .search-backdrop { opacity: 1; }

.search-panel {
  position: relative;
  margin: 0 auto;
  width: min(560px, 92vw);
  background:
    repeating-linear-gradient(45deg, rgba(20,17,13,0.022) 0 1px, transparent 1px 4px),
    repeating-linear-gradient(-45deg, rgba(20,17,13,0.018) 0 1px, transparent 1px 5px),
    var(--bg);
  border: 1.5px solid var(--ink);
  box-shadow: 4px 4px 0 var(--ink);
  padding: 16px 18px 14px;
  opacity: 0;
  transform: translateY(-8px) scale(0.98);
  transition: opacity 200ms ease, transform 220ms cubic-bezier(.2,.7,.2,1);
  color: var(--ink);
  font-family: "Pretendard Variable", Pretendard, sans-serif;
}
.search-overlay.open .search-panel {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.search-eyebrow {
  display: flex;
  align-items: center;
  gap: 13px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
  margin-bottom: 10px;
}
.search-eyebrow::before {
  content: "";
  width: 21px;
  height: 1px;
  background: var(--ink-3);
}
.search-eyebrow .dot {
  width: 5px;
  height: 5px;
  background: var(--hot);
  display: inline-block;
}

.search-input-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  border-bottom: 1.5px solid var(--ink);
  padding: 4px 0 8px;
}
.search-input-prefix {
  font-size: 18px;
  color: var(--hot-deep);
  line-height: 1;
  padding-bottom: 2px;
}
.search-input {
  flex: 1;
  background: transparent;
  border: 0;
  outline: 0;
  font: inherit;
  font-family: "Pretendard Variable", Pretendard, sans-serif;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--ink);
  padding: 4px 0;
  min-width: 0;
}
.search-input::placeholder {
  color: var(--ink-3);
  font-weight: 500;
  letter-spacing: 0;
}
.search-close {
  background: transparent;
  border: 0;
  font: inherit;
  font-size: 22px;
  line-height: 1;
  color: var(--ink-2);
  cursor: pointer;
  padding: 2px 6px;
  transition: color 180ms ease;
}
.search-close:hover,
.search-close:focus-visible { color: var(--hot-deep); outline: none; }

.search-hint {
  margin-top: 8px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.search-list {
  list-style: none;
  margin: 8px 0 0;
  padding: 0;
  max-height: min(50vh, 420px);
  overflow-y: auto;
}
.search-list::-webkit-scrollbar { width: 6px; }
.search-list::-webkit-scrollbar-thumb { background: var(--ink-3); }

.search-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  column-gap: 12px;
  padding: 10px 6px;
  border-top: 1px solid var(--ink-3);
  cursor: pointer;
  transition: background 120ms ease, color 120ms ease;
}
.search-item:first-child { border-top: 0; }
.search-item.is-active {
  background: var(--bg-2);
}
.search-item__planet {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.236em;
  text-transform: uppercase;
  color: var(--bg);
  background: var(--ink);
  padding: 3px 7px 2px;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  transition: background 120ms ease;
}
.search-item__planet--go {
  background: var(--hot-deep);
  letter-spacing: 0.32em;
}
.search-item.is-active .search-item__planet:not(.search-item__planet--go) {
  background: var(--hot-deep);
}
.search-item__main {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.search-item__name {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: color 120ms ease;
}
.search-item.is-active .search-item__name {
  color: var(--hot-deep);
}
.search-item__sub {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--ink-2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.search-item__coords {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--ink-2);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.search-item.is-active .search-item__coords {
  color: var(--hot-deep);
}

.search-empty {
  padding: 20px 6px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--ink-2);
  text-align: center;
}

@media (max-width: 600px) {
  .search-overlay { padding-top: clamp(32px, 6vh, 64px); }
  .search-panel { padding: 14px 14px 12px; }
  .search-input { font-size: 16px; }
  .search-item__name { font-size: 13px; }
  .search-item__coords { font-size: 9px; letter-spacing: 0.08em; }
}

.share-menu {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 300;
  min-width: 248px;
  padding: 12px 14px 10px;
  background:
    repeating-linear-gradient(45deg, rgba(20,17,13,0.022) 0 1px, transparent 1px 4px),
    repeating-linear-gradient(-45deg, rgba(20,17,13,0.018) 0 1px, transparent 1px 5px),
    var(--bg);
  border: 1.5px solid var(--ink);
  box-shadow: 4px 4px 0 var(--ink);
  color: var(--ink);
  font-family: "Pretendard Variable", Pretendard, sans-serif;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-6px) scale(0.98);
  transform-origin: top left;
  transition: opacity 160ms ease, transform 200ms cubic-bezier(.2,.7,.2,1);
}
.share-menu.open {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}
.share-menu__eyebrow {
  display: flex;
  align-items: center;
  gap: 13px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
  margin-bottom: 8px;
}
.share-menu__eyebrow::before {
  content: "";
  width: 21px;
  height: 1px;
  background: var(--ink-3);
}
.share-menu__eyebrow .dot {
  width: 5px;
  height: 5px;
  background: var(--hot);
  display: inline-block;
}
.share-menu__list {
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
}
.share-item {
  display: grid;
  grid-template-columns: 44px 1fr 18px;
  align-items: center;
  column-gap: 12px;
  padding: 10px 4px;
  background: transparent;
  border: 0;
  border-top: 1px solid var(--ink-3);
  cursor: pointer;
  font: inherit;
  font-family: inherit;
  text-align: left;
  color: var(--ink);
  transition: color 140ms ease;
}
.share-item:first-child { border-top: 0; }
.share-item:hover,
.share-item:focus-visible {
  outline: none;
  color: var(--hot-deep);
}
.share-item:hover .share-item__tag,
.share-item:focus-visible .share-item__tag {
  background: var(--hot-deep);
}
.share-item:hover .share-item__arrow,
.share-item:focus-visible .share-item__arrow {
  color: var(--hot-deep);
  transform: translateX(6px);
}
.share-item__tag {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.236em;
  text-transform: uppercase;
  color: var(--bg);
  background: var(--ink);
  padding: 3px 7px 2px;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  text-align: center;
  transition: background 140ms ease;
}
.share-item__label {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -0.005em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.share-item__arrow {
  font-size: 13px;
  color: var(--ink-3);
  text-align: right;
  font-variant-numeric: tabular-nums;
  transition: transform 220ms cubic-bezier(.2,.7,.2,1), color 140ms ease;
}
.share-item.is-copied,
.share-item.is-failed {
  color: var(--hot-deep);
}
.share-item.is-copied .share-item__tag,
.share-item.is-failed .share-item__tag {
  background: var(--hot-deep);
}
.share-item.is-copied .share-item__arrow,
.share-item.is-failed .share-item__arrow {
  color: var(--hot-deep);
}
.share-menu__hint {
  margin-top: 8px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
}

@media (max-width: 600px) {
  .share-menu { min-width: 220px; padding: 10px 12px 8px; }
  .share-item__label { font-size: 12px; }
}

.intro-overlay {
  position: fixed;
  inset: 0;
  z-index: 110;
  display: none;
  place-items: center;
  padding: 24px;
  --intro-fill-dur: 1500ms;
  --intro-fill-delay: 380ms;
  --intro-fill-ease: cubic-bezier(.42, .04, .2, 1);
}
.intro-overlay.open { display: grid; }

.intro-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(20, 17, 13, 0.34);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  opacity: 0;
  transition: opacity 240ms ease;
}
.intro-overlay.open .intro-backdrop { opacity: 1; }
.intro-overlay.closing .intro-backdrop {
  opacity: 0;
  transition-duration: 320ms;
}

.intro {
  position: relative;
  width: min(720px, 92vw);
  max-height: 92vh;
  overflow-y: auto;
  filter: drop-shadow(6px 6px 0 var(--ink));
  opacity: 0;
  transform: translateY(34px) scale(0.96);
  color: var(--ink);
  font-family: "Pretendard Variable", Pretendard, sans-serif;
  transform-origin: 50% 0;
}
.intro::-webkit-scrollbar { width: 6px; }
.intro::-webkit-scrollbar-thumb { background: var(--ink-3); }
.intro-overlay.open .intro {
  animation: introEnter 540ms cubic-bezier(.2, .78, .28, 1.06) forwards;
}
.intro-overlay.closing .intro {
  animation: introExit 320ms cubic-bezier(.4, 0, .7, .2) forwards;
}

@keyframes introEnter {
  0%   { opacity: 0; transform: translateY(34px) scale(0.94) rotate(-0.4deg);
         filter: drop-shadow(2px 2px 0 var(--ink)); }
  55%  { opacity: 1; transform: translateY(-3px) scale(1.008) rotate(0.1deg);
         filter: drop-shadow(8px 9px 0 var(--ink)); }
  100% { opacity: 1; transform: translateY(0) scale(1) rotate(0);
         filter: drop-shadow(6px 6px 0 var(--ink)); }
}
@keyframes introExit {
  to { opacity: 0; transform: translateY(20px) scale(0.96);
       filter: drop-shadow(2px 2px 0 var(--ink)); }
}

.intro__sheet {
  background:
    repeating-linear-gradient(45deg, rgba(20,17,13,0.022) 0 1px, transparent 1px 4px),
    repeating-linear-gradient(-45deg, rgba(20,17,13,0.018) 0 1px, transparent 1px 5px),
    var(--bg);
  border: 1.5px solid var(--ink);
  padding: 26px 30px 22px;
  display: grid;
  gap: 18px;
}

.intro__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}
.intro__brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.intro__dot {
  width: 7px; height: 7px;
  background: var(--hot);
  display: inline-block;
  flex-shrink: 0;
}
.intro__brand-text {
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.382em; text-transform: uppercase;
  color: var(--ink);
}
.intro__brand-sub {
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.236em; text-transform: uppercase;
  color: var(--bg);
  background: var(--ink);
  padding: 3px 7px 2px;
  line-height: 1;
  transform: translateY(-1px);
}
.intro__dossier {
  font-size: 10px;
  letter-spacing: 0.2em;
  color: var(--ink);
  text-transform: uppercase;
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  white-space: nowrap;
}
.intro__dossier-label {
  margin-right: 6px;
  color: var(--ink-3);
}

.intro__hero {
  display: grid;
  gap: 6px;
  padding: 6px 0 14px;
  border-bottom: 1px solid var(--ink-3);
}
.intro__greet {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.42em;
  text-transform: uppercase;
  color: var(--hot-deep);
}
.intro__name {
  margin: 0;
  font-size: clamp(34px, 5.6vw, 54px);
  font-weight: 800;
  letter-spacing: -0.028em;
  line-height: 0.96;
  color: var(--ink);
  cursor: pointer;
  transition: color 160ms ease;
}
.intro__name:hover {
  color: var(--hot);
}
.intro__sub {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--ink);
}
.intro__name-ko { letter-spacing: 0.18em; }
.intro__sep { color: var(--ink-3); }
.intro__dept { color: var(--ink-2); }

.intro-timeline {
  display: grid;
  gap: 14px;
  cursor: pointer;
  user-select: none;
}
.intro-timeline:focus-visible {
  outline: 1.5px solid var(--ink);
  outline-offset: 4px;
}
.intro-timeline:hover .intro-timeline__track {
  background: rgba(20,17,13,0.28);
}
.intro-timeline__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
}
.intro-timeline__eyebrow {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.intro-timeline__range {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  color: var(--ink-3);
  font-variant-numeric: tabular-nums;
}

.intro-timeline__rail {
  position: relative;
  padding: 28px 12px 70px;
}

.intro-timeline__track {
  position: relative;
  height: 1.5px;
  background: var(--ink-3);
}
.intro-timeline__track::before,
.intro-timeline__track::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 6px; height: 6px;
  border: 1.5px solid var(--ink);
  background: var(--bg);
  border-radius: 50%;
  transform: translate(-50%, -50%);
}
.intro-timeline__track::before { left: 0; }
.intro-timeline__track::after  { left: 100%; }

.intro-timeline__fill {
  position: absolute;
  top: 0; bottom: 0; left: 0;
  right: 100%;
  background: var(--ink);
}
.intro-overlay.open .intro-timeline__fill {
  animation: introFillReveal var(--intro-fill-dur) var(--intro-fill-ease)
             var(--intro-fill-delay) forwards;
}
@keyframes introFillReveal {
  from { right: 100%; }
  to   { right: 0; }
}

.intro-timeline__stops {
  list-style: none;
  margin: 0;
  padding: 0;
  position: absolute;
  inset: 0 12px 0 12px;
  pointer-events: none;
}
.intro-stop {
  position: absolute;
  top: 28px;
  left: calc(var(--p) * 100%);
  transform: translateX(-50%);
  display: grid;
  gap: 4px;
  justify-items: center;
  text-align: center;
  min-width: 0;
}
.intro-stop__dot {
  width: 11px; height: 11px;
  border: 1.5px solid var(--ink);
  background: var(--bg);
  border-radius: 50%;
  display: block;
  margin-top: -5px;
  opacity: 0;
}
.intro-stop__year,
.intro-stop__label,
.intro-stop__sub {
  opacity: 0;
}
.intro-stop__year {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.04em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  margin-top: 6px;
}
.intro-stop__label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.236em;
  text-transform: uppercase;
  color: var(--hot-deep);
}
.intro-stop__sub {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--ink-2);
  line-height: 1.3;
  max-width: 110px;
  word-break: keep-all;
  overflow-wrap: break-word;
}
.intro-overlay.open .intro-stop__dot {
  animation: introStopPop 360ms cubic-bezier(.2, .8, .25, 1.25) forwards;
  animation-delay: calc(var(--intro-fill-delay) + var(--p) * var(--intro-fill-dur) - 60ms);
}
.intro-overlay.open .intro-stop__year {
  animation: introStopRise 320ms cubic-bezier(.2, .8, .25, 1) forwards;
  animation-delay: calc(var(--intro-fill-delay) + var(--p) * var(--intro-fill-dur) + 20ms);
}
.intro-overlay.open .intro-stop__label {
  animation: introStopRise 320ms cubic-bezier(.2, .8, .25, 1) forwards;
  animation-delay: calc(var(--intro-fill-delay) + var(--p) * var(--intro-fill-dur) + 80ms);
}
.intro-overlay.open .intro-stop__sub {
  animation: introStopRise 320ms cubic-bezier(.2, .8, .25, 1) forwards;
  animation-delay: calc(var(--intro-fill-delay) + var(--p) * var(--intro-fill-dur) + 140ms);
}
@keyframes introStopPop {
  from { opacity: 0; transform: scale(0.2); }
  60%  { opacity: 1; transform: scale(1.12); }
  to   { opacity: 1; transform: scale(1); }
}
@keyframes introStopRise {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.intro-stop.is-now .intro-stop__dot {
  background: var(--hot);
  border-color: var(--hot-deep);
  box-shadow: 0 0 0 3px var(--hot-soft);
}
.intro-stop.is-now .intro-stop__label { color: var(--hot-deep); }

.intro-stop[data-edge="start"] {
  transform: translateX(-6px);
  text-align: left;
  justify-items: start;
}
.intro-stop[data-edge="end"] {
  transform: translateX(calc(-100% + 6px));
  text-align: right;
  justify-items: end;
}

.intro__oneliner {
  margin: 0;
  padding: 14px 0 0;
  border-top: 1px solid var(--ink-3);
  font-size: 16px;
  font-weight: 700;
  letter-spacing: -0.012em;
  line-height: 1.4;
  color: var(--ink);
}
.intro__body {
  margin: 0;
  font-size: 12.5px;
  font-weight: 500;
  letter-spacing: 0.005em;
  line-height: 1.6;
  color: var(--ink-2);
}

.intro__main {
  position: relative;
  display: grid;
  gap: 18px;
  align-content: start;
  min-width: 0;
}

.intro__meta {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto minmax(0, 1fr);
  gap: 9px 18px;
  margin: 0;
  padding: 12px 0 0;
  border-top: 1px solid var(--ink-3);
  align-items: center;
}
.intro__meta dt {
  margin: 0;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.intro__meta dd {
  margin: 0;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -0.005em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.intro__stub {
  position: relative;
  display: grid;
  gap: 18px;
  align-content: start;
  min-width: 0;
}
.intro__barcode {
  display: none;
  height: 30px;
  background-image: repeating-linear-gradient(
    to right,
    var(--ink) 0 2px, transparent 2px 4px,
    var(--ink) 4px 5px, transparent 5px 8px,
    var(--ink) 8px 11px, transparent 11px 13px,
    var(--ink) 13px 14px, transparent 14px 17px,
    var(--ink) 17px 19px, transparent 19px 21px
  );
  background-size: 21px 100%;
  margin-top: 2px;
}

.intro__links {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.intro__link {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink);
  text-decoration: none;
  padding: 5px 7px;
  border: 1px solid var(--ink-3);
  transition: background 160ms ease, border-color 160ms ease, color 160ms ease;
}
.intro__link::after {
  content: "↗";
  font-size: 10px;
  letter-spacing: 0;
  opacity: 0.4;
  transition: opacity 160ms ease;
}
.intro__link:hover {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}
.intro__link:hover::after { opacity: 1; }

.intro__foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--ink-3);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-2);
  font-weight: 600;
}
.intro__serial-line {
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.16em;
  color: var(--ink);
  font-weight: 700;
}

.intro__close {
  position: absolute;
  top: 6px;
  right: 8px;
  background: transparent;
  border: 0;
  font: inherit;
  font-size: 22px;
  line-height: 1;
  color: var(--ink-2);
  cursor: pointer;
  padding: 4px 8px;
  z-index: 3;
  transition: color 180ms ease;
}
.intro__close:hover { color: var(--hot-deep); }
.intro__close:focus-visible {
  outline: 1.5px solid var(--ink);
  outline-offset: 2px;
  color: var(--ink);
}

@media (prefers-reduced-motion: reduce) {
  .intro-overlay.open .intro {
    animation: none;
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: drop-shadow(6px 6px 0 var(--ink));
  }
  .intro-overlay.open .intro-timeline__fill {
    animation: none;
    right: 0;
  }
  .intro-overlay.open .intro-stop__dot,
  .intro-overlay.open .intro-stop__year,
  .intro-overlay.open .intro-stop__label,
  .intro-overlay.open .intro-stop__sub {
    animation: none;
    opacity: 1;
    transform: none;
  }
}

@media (max-width: 600px) {
  .intro { width: min(560px, 96vw); }
  .intro__sheet { padding: 18px 18px 16px; }
  .intro__name { font-size: clamp(28px, 8vw, 42px); }
  .intro-timeline__rail { padding: 22px 10px 64px; }
  .intro-stop__sub { font-size: 9px; max-width: 78px; }
  .intro-stop__year { font-size: 10px; }
  .intro-stop__label { font-size: 8px; letter-spacing: 0.18em; }
  .intro__meta {
    grid-template-columns: auto minmax(0, 1fr);
    gap: 6px 12px;
  }
  .intro__meta dd { font-size: 12px; }
}

@media (min-width: 1080px) and (min-aspect-ratio: 1/1) {
  .intro { width: min(880px, 92vw); }
  .intro__sheet {
    grid-template-columns: minmax(0, 1fr) 240px;
    column-gap: 0;
    background: none;
    border: 0;
    padding: 0;
  }
  .intro__main {
    background:
      repeating-linear-gradient(45deg, rgba(20,17,13,0.022) 0 1px, transparent 1px 4px),
      repeating-linear-gradient(-45deg, rgba(20,17,13,0.018) 0 1px, transparent 1px 5px),
      var(--bg);
    border: 1.5px solid var(--ink);
    border-right: 0;
    padding: 26px 26px 22px 30px;
  }
  .intro__main::after {
    content: "";
    position: absolute;
    top: 6px;
    bottom: 6px;
    right: 0;
    border-right: 2px dashed var(--ink-3);
    pointer-events: none;
    transition: opacity 100ms ease;
  }
  .intro__stub {
    background:
      repeating-linear-gradient(45deg, rgba(20,17,13,0.022) 0 1px, transparent 1px 4px),
      repeating-linear-gradient(-45deg, rgba(20,17,13,0.018) 0 1px, transparent 1px 5px),
      var(--bg);
    border: 1.5px solid var(--ink);
    border-left: 0;
    padding: 26px 30px 22px 26px;
    gap: 14px;
  }
  .intro__stub::before,
  .intro__stub::after {
    content: "";
    position: absolute;
    left: 0;
    width: 11px;
    height: 11px;
    background: var(--bg);
    border: 1.5px solid var(--ink);
    border-radius: 50%;
    pointer-events: none;
    z-index: 2;
    transition: opacity 100ms ease;
  }
  .intro__stub::before { top: 0;     transform: translate(-50%, -50%); }
  .intro__stub::after  { bottom: 0;  transform: translate(-50%,  50%); }
  .intro__barcode { display: block; }
  .intro__meta {
    grid-template-columns: auto minmax(0, 1fr);
    gap: 8px 14px;
    padding-top: 0;
    border-top: 0;
  }
  .intro__meta dd {
    font-size: 12px;
    text-align: right;
    white-space: normal;
    line-height: 1.35;
  }
  .intro__foot {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
    padding-top: 0;
    border-top: 0;
  }

  .intro-overlay.closing .intro {
    animation: none;
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: none;
    overflow: visible;
  }
  .intro-overlay.closing .intro__close {
    opacity: 0;
    pointer-events: none;
    transition: opacity 80ms ease;
  }
  .intro-overlay.closing .intro__main::after,
  .intro-overlay.closing .intro__stub::before,
  .intro-overlay.closing .intro__stub::after {
    opacity: 0;
  }
  .intro-overlay.closing .intro__main {
    border-right: 1.5px solid var(--ink);
    filter: drop-shadow(3px 3px 0 var(--ink));
    clip-path: polygon(
      0% 0%,
      calc(100% - 1px) 0%,
      100% 5%,
      calc(100% - 6px) 10%,
      calc(100% - 1px) 16%,
      calc(100% - 7px) 22%,
      100% 28%,
      calc(100% - 3px) 34%,
      calc(100% - 8px) 40%,
      calc(100% - 2px) 46%,
      100% 52%,
      calc(100% - 5px) 58%,
      calc(100% - 1px) 64%,
      calc(100% - 7px) 70%,
      100% 76%,
      calc(100% - 4px) 82%,
      calc(100% - 1px) 88%,
      calc(100% - 6px) 94%,
      100% 100%,
      0% 100%
    );
    animation: tearMain 720ms cubic-bezier(.55,.06,.7,.4) forwards;
  }
  .intro-overlay.closing .intro__stub {
    border-left: 1.5px solid var(--ink);
    filter: drop-shadow(3px 3px 0 var(--ink));
    clip-path: polygon(
      1px 0%,
      100% 0%,
      100% 100%,
      1px 100%,
      7px 95%,
      1px 89%,
      5px 83%,
      0% 77%,
      7px 71%,
      2px 65%,
      8px 59%,
      1px 53%,
      0% 47%,
      6px 41%,
      1px 35%,
      7px 29%,
      0% 23%,
      5px 17%,
      1px 11%,
      7px 5%,
      1px 0%
    );
    animation: tearStub 720ms cubic-bezier(.55,.06,.7,.4) forwards;
  }
}

@keyframes tearMain {
  0%   { transform: translate(0, 0) rotate(0deg); opacity: 1; }
  8%   { transform: translate(-2px, 1px) rotate(-0.6deg); opacity: 1; }
  100% { transform: translate(-160px, 360px) rotate(-13deg); opacity: 0; }
}
@keyframes tearStub {
  0%   { transform: translate(0, 0) rotate(0deg); opacity: 1; }
  8%   { transform: translate(2px, 1px) rotate(0.8deg); opacity: 1; }
  100% { transform: translate(220px, 380px) rotate(18deg); opacity: 0; }
}

@media (min-width: 1080px) and (min-aspect-ratio: 1/1) and (prefers-reduced-motion: reduce) {
  .intro-overlay.closing .intro__main,
  .intro-overlay.closing .intro__stub {
    clip-path: none;
    animation: none;
    opacity: 0;
    transition: opacity 200ms ease;
  }
}

.passport-overlay {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: none;
  place-items: center;
  padding: 24px;
}
.passport-overlay.open { display: grid; }

.passport-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(20, 17, 13, 0.34);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  opacity: 0;
  transition: opacity 240ms ease;
}
.passport-overlay.open .passport-backdrop { opacity: 1; }
.passport-overlay.closing .passport-backdrop {
  opacity: 0;
  transition-duration: 540ms;
}

.passport {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 194px;
  width: min(680px, 92vw);
  max-height: 92vh;
  filter: drop-shadow(6px 6px 0 var(--ink));
  opacity: 0;
  transform: translateY(34px) scale(0.92);
  color: var(--ink);
  font-family: "Pretendard Variable", Pretendard, sans-serif;
  transform-origin: 50% 0;
}
.passport-overlay.open .passport {
  animation: ppEnter 540ms cubic-bezier(.2,.78,.28,1.06) forwards;
  will-change: transform, opacity;
}
.passport-overlay.closing .passport {
  animation: none;
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: none;
}

@keyframes ppEnter {
  0%   { opacity: 0; transform: translateY(34px) scale(0.92) rotate(-0.6deg); }
  55%  { opacity: 1; transform: translateY(-3px) scale(1.012) rotate(0.15deg); }
  78%  { transform: translateY(1px) scale(0.998) rotate(-0.05deg); }
  100% { opacity: 1; transform: translateY(0) scale(1) rotate(0); }
}

.passport-overlay.open .passport__bio,
.passport-overlay.open .passport__note,
.passport-overlay.open .passport__links,
.passport-overlay.open .passport__mrz {
  animation: ppReveal 380ms cubic-bezier(.2,.7,.25,1) backwards;
  will-change: transform, opacity;
}
.passport-overlay.open .passport__bio   { animation-delay: 200ms; }
.passport-overlay.open .passport__links { animation-delay: 270ms; }
.passport-overlay.open .passport__note  { animation-delay: 340ms; }
.passport-overlay.open .passport__mrz   { animation-delay: 400ms; }

@keyframes ppReveal {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.passport__half {
  background:
    repeating-linear-gradient(45deg, rgba(20,17,13,0.022) 0 1px, transparent 1px 4px),
    repeating-linear-gradient(-45deg, rgba(20,17,13,0.018) 0 1px, transparent 1px 5px),
    var(--bg);
  border: 1.5px solid var(--ink);
  padding: 22px 26px 18px;
  position: relative;
}

.passport__half--main {
  border-right: 0;
  display: grid;
  grid-template-rows: auto auto auto 1fr auto;
  gap: 14px;
  min-width: 0;
}

.passport__half--stamps {
  border-left: 0;
  display: grid;
  grid-template-rows: auto 1fr auto auto;
  gap: 12px;
  padding: 22px 18px 16px;
  overflow: hidden;
  transform-origin: left center;
  opacity: 0;
}
.passport-overlay.open .passport__half--stamps {
  animation: ppPageOpen 520ms cubic-bezier(.4, 0, .2, 1) 280ms forwards;
  will-change: transform, opacity;
}
@keyframes ppPageOpen {
  0%   { opacity: 0; transform: perspective(900px) rotateY(-78deg); }
  65%  { opacity: 1; transform: perspective(900px) rotateY(4deg); }
  100% { opacity: 1; transform: perspective(900px) rotateY(0deg); }
}

.passport__half--main::after {
  content: "";
  position: absolute;
  top: 14px; bottom: 14px; right: -1px;
  border-right: 2px dashed var(--ink-3);
  pointer-events: none;
  transition: opacity 100ms ease;
}
.passport__half--main::before {
  content: "";
  position: absolute;
  top: 6px; right: -7px;
  width: 12px; height: 12px;
  background: radial-gradient(circle at center, transparent 0 4px, var(--bg) 4.5px);
  border-radius: 50%;
  z-index: 2;
  pointer-events: none;
  transition: opacity 100ms ease;
}

.passport__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
}
.passport__brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.passport__dot {
  width: 7px; height: 7px;
  background: var(--hot);
  display: inline-block;
  flex-shrink: 0;
}
.passport__dot--small { width: 5px; height: 5px; }
.passport__brand-text {
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.382em; text-transform: uppercase;
  color: var(--ink);
}
.passport__brand-sub {
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.236em; text-transform: uppercase;
  color: var(--bg);
  background: var(--ink);
  padding: 3px 7px 2px;
  line-height: 1;
  transform: translateY(-1px);
}
.passport__docno {
  font-size: 10px; letter-spacing: 0.2em;
  color: var(--ink); text-transform: uppercase;
  font-variant-numeric: tabular-nums;
  font-weight: 700; white-space: nowrap;
}
.passport__docno-label { margin-right: 6px; color: var(--ink-3); }

.passport__bio {
  display: flex;
  gap: 18px;
  padding: 14px 0 16px;
  border-top: 1px solid var(--ink-3);
  border-bottom: 1px solid var(--ink-3);
}

.passport__photo {
  width: 74px; height: 92px;
  flex-shrink: 0;
  border: 1.5px solid var(--ink-3);
  overflow: hidden;
}
.passport__photo-img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

.passport__fields {
  flex: 1; min-width: 0;
  margin: 0; padding: 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 7px 14px;
  align-content: start;
}
.passport__fields dt {
  margin: 0;
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.382em; text-transform: uppercase;
  color: var(--ink-2);
}
.passport__fields dd {
  margin: 0;
  font-size: 13px; font-weight: 700;
  letter-spacing: -0.005em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.passport__note {
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 8px;
  padding-top: 2px;
  border-top: 1px solid var(--ink-3);
}
.passport__note-label {
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.382em; text-transform: uppercase;
  color: var(--ink-2);
}
.passport__note-text {
  margin: 0;
  font-size: 14px; font-weight: 500;
  letter-spacing: 0.005em; line-height: 1.8;
  color: var(--ink-2);
  align-self: center;
}

.passport__links {
  display: flex;
  gap: 8px;
}
.passport__link-block {
  flex: 1;
  border: 1.5px solid var(--ink-3);
  padding: 8px 10px 9px;
  text-decoration: none;
  display: grid;
  gap: 3px;
  transition: border-color 180ms ease;
}
.passport__link-block:hover { border-color: var(--hot); }
.passport__link-label {
  font-size: 8px; font-weight: 700;
  letter-spacing: 0.382em; text-transform: uppercase;
  color: var(--ink-2);
  transition: color 180ms ease;
}
.passport__link-url {
  font-size: 11px; font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--ink);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  transition: color 180ms ease;
}
.passport__link-block:hover .passport__link-url,
.passport__link-block:hover .passport__link-label { color: var(--hot); }

.passport__mrz {
  display: grid;
  gap: 3px;
  padding-top: 10px;
  border-top: 1px solid var(--ink-3);
  font-family: "Courier New", Courier, monospace;
  font-size: 9px; letter-spacing: 0.12em;
  color: var(--ink-2);
  overflow: hidden;
}
.passport__mrz-line { white-space: nowrap; }

.passport__stub-head {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.382em; text-transform: uppercase;
  color: var(--ink);
}

.passport__stamp-list {
  list-style: none;
  margin: 0;
  padding: 8px 0 4px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-self: start;
  border-top: 1px solid var(--ink-3);
  padding-top: 10px;
}

.pp-stamp {
  display: flex;
  justify-content: center;
  align-items: center;
}
.pp-stamp:nth-child(1) { --rot: -4deg; --tx:  5px; }
.pp-stamp:nth-child(2) { --rot:  3deg; --tx: -7px; }
.pp-stamp:nth-child(3) { --rot: -5deg; --tx:  8px; }
.pp-stamp:nth-child(4) { --rot:  2deg; --tx: -4px; }
.pp-stamp:nth-child(5) { --rot: -3deg; --tx:  6px; }

.pp-stamp { transform: rotate(var(--rot,0deg)) translateX(var(--tx,0px)); }

.passport-overlay.open .pp-stamp {
  animation: ppStamp 420ms cubic-bezier(.25,.46,.45,.94) backwards;
  will-change: transform, opacity;
}
.passport-overlay.open .pp-stamp:nth-child(1) { animation-delay:  800ms; }
.passport-overlay.open .pp-stamp:nth-child(2) { animation-delay:  930ms; }
.passport-overlay.open .pp-stamp:nth-child(3) { animation-delay: 1060ms; }
.passport-overlay.open .pp-stamp:nth-child(4) { animation-delay: 1190ms; }
.passport-overlay.open .pp-stamp:nth-child(5) { animation-delay: 1320ms; }

@keyframes ppStamp {
  0%  { opacity: 0;
        transform: rotate(var(--rot,0deg)) translateX(var(--tx,0px)) translateY(-22px) scale(1.12); }
  52% { opacity: 1;
        transform: rotate(var(--rot,0deg)) translateX(var(--tx,0px)) translateY(3px)   scale(0.95); }
  74% { transform: rotate(var(--rot,0deg)) translateX(var(--tx,0px)) translateY(-2px)  scale(1.01); }
  to  { opacity: 1;
        transform: rotate(var(--rot,0deg)) translateX(var(--tx,0px)) translateY(0)     scale(1); }
}

.pp-stamp__body {
  position: relative;
  border: 2.5px solid currentColor;
  border-radius: 2px;
  padding: 5px 12px 6px;
  text-align: center;
  display: grid;
  gap: 2px;
  opacity: 0.82;
  max-width: 148px;
}
.pp-stamp__body::before {
  content: "";
  position: absolute;
  inset: 3px;
  border: 1px solid currentColor;
  border-radius: 0;
  opacity: 0.4;
  pointer-events: none;
}

.pp-stamp--strategic-thinking { color: var(--hot); }
.pp-stamp--execution          { color: var(--ink); }

.pp-stamp__rank {
  font-size: 7.5px; font-weight: 700;
  letter-spacing: 0.3em; text-transform: uppercase;
  opacity: 0.55;
}
.pp-stamp__theme {
  font-size: 13px; font-weight: 800;
  letter-spacing: 0.05em; text-transform: uppercase;
  line-height: 1;
}
.pp-stamp__domain {
  font-size: 6.5px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  opacity: 0.6;
  line-height: 1.4;
}

.passport__barcode {
  height: 42px;
  background-image: repeating-linear-gradient(
    to right,
    var(--ink) 0 2px, transparent 2px 4px,
    var(--ink) 4px 5px, transparent 5px 8px,
    var(--ink) 8px 11px, transparent 11px 13px,
    var(--ink) 13px 14px, transparent 14px 17px,
    var(--ink) 17px 19px, transparent 19px 21px
  );
  background-size: 21px 100%;
  border-top: 1px solid var(--ink-3);
  border-bottom: 1px solid var(--ink-3);
}
.passport__stub-serial {
  font-size: 9px; letter-spacing: 0.28em;
  text-transform: uppercase; color: var(--ink-2);
  font-variant-numeric: tabular-nums;
  font-weight: 700; text-align: center;
}

.passport__close {
  position: absolute;
  top: 6px; right: 8px;
  background: transparent; border: 0;
  font: inherit; font-size: 22px;
  line-height: 1; color: var(--ink-2);
  cursor: pointer; padding: 4px 8px;
  z-index: 3;
  transition: color 180ms ease;
}
.passport__close:hover { color: var(--hot-deep); }
.passport__close:focus-visible {
  outline: 1.5px solid var(--ink);
  outline-offset: 2px; color: var(--ink);
}
.passport-overlay.closing .passport__close {
  opacity: 0; pointer-events: none;
  transition: opacity 80ms ease;
}

.passport-overlay.closing .passport__half--main::after,
.passport-overlay.closing .passport__half--main::before { opacity: 0; }
.passport-overlay.closing .passport__half--main {
  border-right: 1.5px solid var(--ink);
  filter: drop-shadow(3px 3px 0 var(--ink));
  clip-path: polygon(
    0% 0%, calc(100% - 1px) 0%,
    100% 5%,   calc(100% - 6px) 10%, calc(100% - 1px) 16%,
    calc(100% - 7px) 22%, 100% 28%, calc(100% - 3px) 34%,
    calc(100% - 8px) 40%, calc(100% - 2px) 46%, 100% 52%,
    calc(100% - 5px) 58%, calc(100% - 1px) 64%, calc(100% - 7px) 70%,
    100% 76%,  calc(100% - 4px) 82%, calc(100% - 1px) 88%,
    calc(100% - 6px) 94%, 100% 100%, 0% 100%
  );
  animation: ppTearMain 720ms cubic-bezier(.55,.06,.7,.4) forwards;
}
.passport-overlay.closing .passport__half--stamps {
  border-left: 1.5px solid var(--ink);
  filter: drop-shadow(3px 3px 0 var(--ink));
  clip-path: polygon(
    1px 0%, 100% 0%, 100% 100%, 1px 100%,
    7px 95%, 1px 89%, 5px 83%, 0% 77%,
    7px 71%, 2px 65%, 8px 59%, 1px 53%,
    0% 47%, 6px 41%, 1px 35%, 7px 29%,
    0% 23%, 5px 17%, 1px 11%, 7px 5%, 1px 0%
  );
  animation: ppTearStamps 720ms cubic-bezier(.55,.06,.7,.4) forwards;
}
@keyframes ppTearMain {
  0%   { transform: translate(0,0) rotate(0deg); opacity: 1; }
  8%   { transform: translate(-2px,1px) rotate(-0.6deg); opacity: 1; }
  100% { transform: translate(-160px,360px) rotate(-13deg); opacity: 0; }
}
@keyframes ppTearStamps {
  0%   { transform: translate(0,0) rotate(0deg); opacity: 1; }
  8%   { transform: translate(2px,1px) rotate(0.8deg); opacity: 1; }
  100% { transform: translate(220px,380px) rotate(18deg); opacity: 0; }
}

@media (prefers-reduced-motion: reduce) {
  .passport-overlay.open .passport        { animation: none; opacity: 1; transform: none; }
  .passport-overlay.open .passport__bio,
  .passport-overlay.open .passport__note,
  .passport-overlay.open .passport__links,
  .passport-overlay.open .passport__mrz   { animation: none; opacity: 1; transform: none; }
  .passport-overlay.open .passport__half--stamps { animation: none; opacity: 1; transform: none; }
  .passport-overlay.open .pp-stamp        { animation: none; opacity: 1; transform: rotate(var(--rot,0deg)) translateX(var(--tx,0px)); }
  .passport-overlay.closing .passport__half--main,
  .passport-overlay.closing .passport__half--stamps {
    clip-path: none; animation: none;
    opacity: 0; transition: opacity 200ms ease;
  }
}

@media (max-width: 600px) {
  .passport {
    grid-template-columns: minmax(0, 1fr) 140px;
    width: min(560px, 96vw);
  }
  .passport__half { padding: 16px 16px 14px; }
  .passport__half--stamps { padding: 16px 12px 14px; }
  .passport__photo { width: 58px; height: 74px; }
  .passport__fields { gap: 5px 10px; }
  .passport__fields dd { font-size: 11px; }
  .pp-stamp__theme { font-size: 11px; }
  .pp-stamp__body { max-width: 114px; padding: 4px 9px 5px; }
}

.cert-overlay {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: none;
  place-items: center;
  padding: 24px;
}
.cert-overlay.open { display: grid; }

.cert-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(20, 17, 13, 0.34);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  opacity: 0;
  transition: opacity 240ms ease;
}
.cert-overlay.open .cert-backdrop { opacity: 1; }
.cert-overlay.closing .cert-backdrop {
  opacity: 0;
  transition-duration: 280ms;
}

.cert-sheet {
  position: relative;
  width: min(700px, 92vw);
  max-height: 92vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background:
    repeating-linear-gradient(45deg, rgba(20,17,13,0.022) 0 1px, transparent 1px 4px),
    repeating-linear-gradient(-45deg, rgba(20,17,13,0.018) 0 1px, transparent 1px 5px),
    var(--bg);
  border: 1.5px solid var(--ink);
  padding: 22px 26px 20px;
  filter: drop-shadow(6px 6px 0 var(--ink));
  opacity: 0;
  transform: translateY(34px) scale(0.93);
  color: var(--ink);
  font-family: "Pretendard Variable", Pretendard, sans-serif;
}
.cert-overlay.open .cert-sheet {
  animation: certEnter 500ms cubic-bezier(.2,.78,.28,1.06) forwards;
  will-change: transform, opacity;
}
.cert-overlay.closing .cert-sheet {
  animation: certLeave 280ms ease forwards;
  will-change: transform, opacity;
}

@keyframes certEnter {
  0%   { opacity: 0; transform: translateY(34px) scale(0.93) rotate(-0.4deg); }
  55%  { opacity: 1; transform: translateY(-3px) scale(1.01) rotate(0.1deg); }
  100% { opacity: 1; transform: translateY(0) scale(1) rotate(0); }
}
@keyframes certLeave {
  0%   { opacity: 1; transform: translateY(0) scale(1); }
  100% { opacity: 0; transform: translateY(16px) scale(0.95); }
}

.cert-sheet__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
  flex-shrink: 0;
}
.cert-sheet__brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.cert-sheet__dot {
  width: 7px;
  height: 7px;
  background: var(--hot);
  display: inline-block;
  flex-shrink: 0;
}
.cert-sheet__brand-text {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink);
}
.cert-sheet__brand-sub {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.236em;
  text-transform: uppercase;
  color: var(--bg);
  background: var(--ink);
  padding: 3px 7px 2px;
  line-height: 1;
}
.cert-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  border-top: 1px solid var(--ink-3);
  padding-top: 16px;
  overflow-y: auto;
  flex: 1;
  min-height: 0;
  scrollbar-width: thin;
  scrollbar-color: var(--ink-3) transparent;
}
.cert-grid::-webkit-scrollbar {
  width: 4px;
}
.cert-grid::-webkit-scrollbar-track {
  background: transparent;
}
.cert-grid::-webkit-scrollbar-thumb {
  background: var(--ink-3);
  border-radius: 0;
}
.cert-grid::-webkit-scrollbar-thumb:hover {
  background: var(--ink-2);
}

.cert-card {
  border: 1.5px solid var(--ink);
  padding: 14px 16px 14px;
  position: relative;
}
.cert-overlay.open .cert-card:nth-child(1)  { --cert-delay: 260ms; }
.cert-overlay.open .cert-card:nth-child(2)  { --cert-delay: 300ms; }
.cert-overlay.open .cert-card:nth-child(3)  { --cert-delay: 340ms; }
.cert-overlay.open .cert-card:nth-child(4)  { --cert-delay: 380ms; }
.cert-overlay.open .cert-card:nth-child(5)  { --cert-delay: 420ms; }
.cert-overlay.open .cert-card:nth-child(6)  { --cert-delay: 460ms; }
.cert-overlay.open .cert-card:nth-child(7)  { --cert-delay: 500ms; }
.cert-overlay.open .cert-card:nth-child(8)  { --cert-delay: 540ms; }
.cert-overlay.open .cert-card:nth-child(9)  { --cert-delay: 580ms; }
.cert-overlay.open .cert-card:nth-child(10) { --cert-delay: 620ms; }
.cert-overlay.open .cert-card:nth-child(11) { --cert-delay: 660ms; }
.cert-overlay.open .cert-card:nth-child(12) { --cert-delay: 700ms; }

.cert-card__inner {
  opacity: 0;
}
.cert-overlay.open .cert-card__inner {
  animation: certCardIn 380ms cubic-bezier(.2,.7,.25,1) both;
  animation-delay: var(--cert-delay, 260ms);
  will-change: transform, opacity;
}

@keyframes certCardIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.cert-card__skeleton {
  position: absolute;
  top: 14px;
  left: 16px;
  right: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  pointer-events: none;
}
.cert-overlay.open .cert-card__skeleton {
  animation: certSkOut 180ms ease both;
  animation-delay: var(--cert-delay, 260ms);
}

@keyframes certSkOut {
  from { opacity: 1; }
  to   { opacity: 0; }
}

@keyframes shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

.cert-sk__no,
.cert-sk__name,
.cert-sk__label,
.cert-sk__val {
  background: linear-gradient(
    90deg,
    var(--ink-3) 0%,
    rgba(20, 17, 13, 0.06) 50%,
    var(--ink-3) 100%
  );
  background-size: 200% 100%;
  animation: shimmer 1.6s ease-in-out infinite;
}
.cert-sk__no   { height: 8px;  width: 54%; }
.cert-sk__name { height: 17px; width: 78%; margin-bottom: 4px; }
.cert-sk__fields {
  display: grid;
  grid-template-columns: 28% 1fr;
  gap: 7px 10px;
  border-top: 1px solid var(--ink-3);
  padding-top: 10px;
}
.cert-sk__label { height: 7px; }
.cert-sk__val   { height: 7px; }

.cert-card::before {
  content: "";
  position: absolute;
  inset: 4px;
  border: 1px solid var(--ink-3);
  pointer-events: none;
}

.cert-card__eyebrow {
  display: flex;
  align-items: baseline;
  gap: 6px;
  margin-bottom: 8px;
}
.cert-card__no-label {
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.cert-card__no {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--ink-2);
  font-variant-numeric: tabular-nums;
}
.cert-card__name {
  font-size: 15px;
  font-weight: 800;
  letter-spacing: -0.01em;
  line-height: 1.2;
  color: var(--ink);
  margin-bottom: 12px;
  transition: color 160ms ease;
}
.cert-card__name.has-url {
  cursor: pointer;
}
.cert-card__name.has-url:hover {
  color: var(--hot);
}
.cert-sheet__url-hint {
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-2);
  opacity: 0.7;
  flex-shrink: 0;
  text-align: right;
}
.cert-sheet__url-hint::before {
  content: '↗';
  margin-right: 5px;
}
.cert-card__fields {
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 5px 10px;
  border-top: 1px solid var(--ink-3);
  padding-top: 10px;
}
.cert-card__fields dt {
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.cert-card__fields dd {
  margin: 0;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}

.cert-sheet__mrz {
  margin-top: 16px;
  padding-top: 10px;
  flex-shrink: 0;
  border-top: 1px solid var(--ink-3);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 12px;
}
.cert-sheet__mrz-lines {
  font-family: "Courier New", Courier, monospace;
  font-size: 9px;
  letter-spacing: 0.12em;
  color: var(--ink-2);
  display: grid;
  gap: 3px;
}
.cert-sheet__mrz-lines div {
  white-space: nowrap;
  overflow: hidden;
}

.cert-sheet__close {
  position: absolute;
  top: 6px;
  right: 8px;
  background: transparent;
  border: 0;
  font: inherit;
  font-size: 22px;
  line-height: 1;
  color: var(--ink-2);
  cursor: pointer;
  padding: 4px 8px;
  z-index: 3;
  transition: color 180ms ease;
}
.cert-sheet__close:hover { color: var(--hot-deep); }
.cert-sheet__close:focus-visible {
  outline: 1.5px solid var(--ink);
  outline-offset: 2px;
  color: var(--ink);
}

@media (prefers-reduced-motion: reduce) {
  .cert-overlay.open .cert-sheet        { animation: none; opacity: 1; transform: none; }
  .cert-overlay.open .cert-card__inner  { animation: none; opacity: 1; transform: none; }
  .cert-overlay.open .cert-card__skeleton { animation: none; opacity: 0; }
  .cert-overlay.closing .cert-sheet     { animation: none; opacity: 0; }
}

@media (max-width: 520px) {
  .cert-grid { grid-template-columns: 1fr; }
  .cert-sheet { padding: 16px; }
}

.dream-card {
  position: fixed;
  bottom: var(--margin-y);
  left: var(--margin-x);
  z-index: 11;
  display: none;
  flex-direction: column;
  gap: 10px;
  width: fit-content;
  max-width: min(340px, 32vw);
}
@media (min-width: 1080px) and (min-aspect-ratio: 1/1) {
  body[data-mode="moon"] .dream-card--curricular,
  body[data-mode="mars"] .dream-card--extracurricular {
    display: flex;
  }
}
body[data-mode="moon"] .viewport-hint--left,
body[data-mode="mars"] .viewport-hint--left {
  display: none;
}

.dream-card__eyebrow {
  display: flex;
  align-items: center;
  gap: 13px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.dream-card__eyebrow::before {
  content: "";
  width: 21px;
  height: 1px;
  background: var(--ink-3);
}
.dream-card__eyebrow .dot {
  width: 5px;
  height: 5px;
  background: var(--hot);
  display: inline-block;
}

.dream-card__lead {
  display: flex;
  align-items: baseline;
  gap: 12px;
  line-height: 0.92;
}
.dream-card__accent {
  width: 8px;
  height: 8px;
  background: var(--hot);
  display: inline-block;
  transform: translateY(-2px);
  flex-shrink: 0;
  align-self: center;
}
.dream-card__goal {
  font-size: 44px;
  font-weight: 800;
  letter-spacing: -0.022em;
  color: var(--ink);
  line-height: 0.92;
  font-variant-numeric: tabular-nums;
}
.dream-card__realm {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--bg);
  background: var(--ink);
  padding: 3px 7px 2px;
  line-height: 1;
  align-self: center;
  transform: translateY(2px);
}

.dream-card__sub {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: -0.005em;
  color: var(--ink-2);
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.dream-card__action {
  appearance: none;
  border: none;
  background: none;
  font-family: inherit;
  color: var(--ink);
  cursor: pointer;
  padding: 8px 0 0;
  border-top: 1px dashed var(--ink-3);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  text-align: left;
  font-size: 11px;
  letter-spacing: 0.04em;
  transition: color 180ms ease;
}
.dream-card__action .tag {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.236em;
  color: var(--bg);
  background: var(--ink);
  padding: 3px 8px 2px;
  line-height: 1;
  flex-shrink: 0;
  transition: background 180ms ease;
}
.dream-card__action-label {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: -0.005em;
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dream-card__action-arrow {
  font-size: 13px;
  color: var(--ink-2);
  line-height: 1;
  transition: transform 180ms ease, color 180ms ease;
  flex-shrink: 0;
}
.dream-card__action:hover { color: var(--hot-deep); }
.dream-card__action:hover .tag { background: var(--hot-deep); }
.dream-card__action:hover .dream-card__action-arrow {
  color: var(--hot-deep);
  transform: translate(2px, -2px);
}
.dream-card__action:focus-visible {
  outline: 2px solid var(--hot);
  outline-offset: 4px;
}

@media (max-width: 1280px) {
  .dream-card__goal { font-size: 36px; }
  .dream-card { max-width: min(300px, 36vw); }
}
@media (max-width: 1080px) {
  .dream-card__goal { font-size: 30px; }
  .dream-card__eyebrow { font-size: 9px; letter-spacing: 0.28em; }
  .dream-card__sub { font-size: 10px; }
}
.dream-overlay {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: none;
  place-items: center;
  padding: 24px;
}
.dream-overlay.open { display: grid; }
.dream-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(20, 17, 13, 0.34);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  opacity: 0;
  transition: opacity 240ms ease;
}
.dream-overlay.open .dream-backdrop { opacity: 1; }
.dream-overlay.closing .dream-backdrop {
  opacity: 0;
  transition-duration: 540ms;
}

.dream {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 220px;
  width: min(760px, 92vw);
  max-height: 92vh;
  filter: drop-shadow(6px 6px 0 var(--ink));
  opacity: 0;
  transform: translateY(34px) scale(0.92);
  color: var(--ink);
  font-family: "Pretendard Variable", Pretendard, sans-serif;
  transform-origin: 50% 0;
}
.dream-overlay.open .dream {
  animation: dreamEnter 540ms cubic-bezier(.2,.78,.28,1.06) forwards;
}
.dream-overlay.closing .dream {
  animation: none;
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: none;
}

@keyframes dreamEnter {
  0% {
    opacity: 0;
    transform: translateY(34px) scale(0.92) rotate(-0.6deg);
    filter: drop-shadow(2px 2px 0 var(--ink));
  }
  55% {
    opacity: 1;
    transform: translateY(-3px) scale(1.012) rotate(0.15deg);
    filter: drop-shadow(8px 9px 0 var(--ink));
  }
  78% {
    transform: translateY(1px) scale(0.998) rotate(-0.05deg);
    filter: drop-shadow(5px 5px 0 var(--ink));
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1) rotate(0);
    filter: drop-shadow(6px 6px 0 var(--ink));
  }
}

.dream-overlay.open .dream__hero,
.dream-overlay.open .dream__meta,
.dream-overlay.open .dream__body,
.dream-overlay.open .dream__foot,
.dream-overlay.open .dream__stub-meta,
.dream-overlay.open .dream__pillars,
.dream-overlay.open .dream__barcode {
  animation: dreamReveal 380ms cubic-bezier(.2,.7,.25,1) backwards;
}
.dream-overlay.open .dream__hero      { animation-delay: 200ms; }
.dream-overlay.open .dream__meta      { animation-delay: 260ms; }
.dream-overlay.open .dream__body      { animation-delay: 320ms; }
.dream-overlay.open .dream__foot      { animation-delay: 380ms; }
.dream-overlay.open .dream__stub-meta { animation-delay: 240ms; }
.dream-overlay.open .dream__pillars   { animation-delay: 300ms; }
.dream-overlay.open .dream__barcode   { animation-delay: 360ms; }

@keyframes dreamReveal {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  .dream-overlay.open .dream {
    animation: none;
    opacity: 1;
    transform: translateY(0) scale(1);
  }
  .dream-overlay.open .dream__hero,
  .dream-overlay.open .dream__meta,
  .dream-overlay.open .dream__body,
  .dream-overlay.open .dream__foot,
  .dream-overlay.open .dream__stub-meta,
  .dream-overlay.open .dream__pillars,
  .dream-overlay.open .dream__barcode {
    animation: none;
    opacity: 1;
    transform: none;
  }
}

.dream__half {
  background:
    repeating-linear-gradient(45deg, rgba(20,17,13,0.022) 0 1px, transparent 1px 4px),
    repeating-linear-gradient(-45deg, rgba(20,17,13,0.018) 0 1px, transparent 1px 5px),
    var(--bg);
  border: 1.5px solid var(--ink);
  padding: 24px 28px 20px;
  position: relative;
}
.dream__half--main {
  border-right: 0;
  display: grid;
  grid-template-rows: auto auto auto auto auto;
  gap: 16px;
  min-width: 0;
}
.dream__half--stub {
  border-left: 0;
  display: grid;
  grid-template-rows: auto auto 1fr auto auto;
  gap: 12px;
  padding: 24px 22px 18px;
}
.dream__half--main::after {
  content: "";
  position: absolute;
  top: 14px;
  bottom: 14px;
  right: -1px;
  border-right: 2px dashed var(--ink-3);
  pointer-events: none;
  transition: opacity 100ms ease;
}
.dream__half--main::before {
  content: "";
  position: absolute;
  top: 6px;
  right: -7px;
  width: 12px;
  height: 12px;
  background: radial-gradient(circle at center, transparent 0 4px, var(--bg) 4.5px);
  border-radius: 50%;
  z-index: 2;
  pointer-events: none;
}

.dream__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}
.dream__brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.dream__dot {
  width: 7px;
  height: 7px;
  background: var(--hot);
  display: inline-block;
  flex-shrink: 0;
}
.dream__dot--small {
  width: 5px;
  height: 5px;
}
.dream__brand-text {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink);
}
.dream__brand-sub {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.236em;
  text-transform: uppercase;
  color: var(--bg);
  background: var(--ink);
  padding: 3px 7px 2px;
  line-height: 1;
  transform: translateY(-1px);
}
.dream__docno {
  font-size: 10px;
  letter-spacing: 0.2em;
  color: var(--ink);
  text-transform: uppercase;
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  white-space: nowrap;
}
.dream__docno-label {
  margin-right: 6px;
  color: var(--ink-3);
}

.dream__hero {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 18px 20px;
  padding: 14px 0 16px;
  border-top: 1px solid var(--ink-3);
  border-bottom: 1px solid var(--ink-3);
}
.dream__goal-block {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.dream__goal-label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.dream__goal {
  font-size: 56px;
  font-weight: 800;
  letter-spacing: -0.022em;
  line-height: 0.92;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  margin: 0;
  display: flex;
  align-items: baseline;
  gap: 10px;
}
.dream__goal-accent {
  width: 7px;
  height: 7px;
  background: var(--hot);
  display: inline-block;
  flex-shrink: 0;
  transform: translateY(-6px);
}
.dream__hero-text {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}
.dream__headline {
  font-size: 16px;
  font-weight: 800;
  letter-spacing: -0.005em;
  color: var(--ink);
  line-height: 1.25;
  margin: 0;
}
.dream__subline {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--ink-2);
  line-height: 1.4;
}

.dream__meta {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto minmax(0, 1fr);
  gap: 9px 18px;
  margin: 0;
  padding: 0;
  align-items: center;
}
.dream__meta dt {
  margin: 0;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.dream__meta dd {
  margin: 0;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -0.005em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dream__body {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--ink-3);
  max-height: 220px;
  overflow-y: auto;
  padding-right: 4px;
}
.dream__body p {
  margin: 0;
  font-size: 13px;
  font-weight: 500;
  line-height: 1.6;
  color: var(--ink);
  letter-spacing: -0.005em;
}
.dream__body p::first-letter {
  font-weight: 800;
}
.dream__body::-webkit-scrollbar {
  width: 6px;
}
.dream__body::-webkit-scrollbar-thumb {
  background: var(--ink-3);
}

.dream__foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--ink-3);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-2);
  font-weight: 600;
}
.dream__serial-line {
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.16em;
  color: var(--ink);
  font-weight: 700;
}

.dream__stub-head {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink);
}
.dream__stub-meta {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 7px 14px;
  margin: 0;
  padding: 10px 0;
  border-top: 1px solid var(--ink-3);
  border-bottom: 1px solid var(--ink-3);
  align-items: center;
}
.dream__stub-meta dt {
  margin: 0;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.dream__stub-meta dd {
  margin: 0;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: -0.005em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  text-align: right;
}

.dream__pillars {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.dream__pillars-eyebrow {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
  margin-bottom: 2px;
}
.dream__pillar {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 4px 8px;
}
.dream__pillar-code {
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 0.236em;
  color: var(--bg);
  background: var(--ink);
  padding: 2px 5px 1px;
  line-height: 1;
}
.dream__pillar-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: -0.005em;
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dream__pillar-level {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  color: var(--ink-2);
  font-variant-numeric: tabular-nums;
}
.dream__pillar-bar {
  grid-column: 1 / 4;
  height: 5px;
  background: var(--ink-3);
  border: 1px solid var(--ink-3);
  position: relative;
  overflow: hidden;
}
.dream__pillar-bar-fill {
  position: absolute;
  inset: 0;
  background: var(--ink);
  transform-origin: left center;
  transform: scaleX(var(--lvl, 0));
  transition: transform 480ms cubic-bezier(.2,.78,.28,1);
}
.dream-overlay.open .dream__pillar-bar-fill {
  transition-delay: 460ms;
}

.dream__progress {
  margin-top: 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.dream__progress-eyebrow {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.dream__progress-note {
  margin: 0;
  font-size: 9px;
  line-height: 1.5;
  color: var(--ink-2);
}
.dream__progress-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.dream__progress-item {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 3px 8px;
}
.dream__progress-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: -0.005em;
  color: var(--ink);
}
.dream__progress-value {
  font-size: 10px;
  font-weight: 700;
  color: var(--ink-2);
  font-variant-numeric: tabular-nums;
}
.dream__progress-bar {
  grid-column: 1 / 3;
  height: 5px;
  background: var(--ink-3);
  border: 1px solid var(--ink-3);
  position: relative;
  overflow: hidden;
}
.dream__progress-bar-fill {
  position: absolute;
  inset: 0;
  background: var(--ink);
  transform-origin: left center;
  transform: scaleX(var(--lvl, 0));
  transition: transform 480ms cubic-bezier(.2,.78,.28,1);
}
.dream-overlay.open .dream__progress-bar-fill {
  transition-delay: 520ms;
}

.dream__barcode {
  height: 42px;
  background-image: repeating-linear-gradient(
    to right,
    var(--ink) 0 2px, transparent 2px 4px,
    var(--ink) 4px 5px, transparent 5px 8px,
    var(--ink) 8px 11px, transparent 11px 13px,
    var(--ink) 13px 14px, transparent 14px 17px,
    var(--ink) 17px 19px, transparent 19px 21px
  );
  background-size: 21px 100%;
  border-top: 1px solid var(--ink-3);
  border-bottom: 1px solid var(--ink-3);
}
.dream__stub-serial {
  font-size: 9px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-2);
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  text-align: center;
}

.dream__close {
  position: absolute;
  top: 6px;
  right: 8px;
  background: transparent;
  border: 0;
  font: inherit;
  font-size: 22px;
  line-height: 1;
  color: var(--ink-2);
  cursor: pointer;
  padding: 4px 8px;
  z-index: 3;
  transition: color 180ms ease;
}
.dream__close:hover { color: var(--hot-deep); }
.dream__close:focus-visible {
  outline: 1.5px solid var(--ink);
  outline-offset: 2px;
  color: var(--ink);
}
.dream-overlay.closing .dream__close {
  opacity: 0;
  pointer-events: none;
  transition: opacity 80ms ease;
}

.dream-overlay.closing .dream__half--main::after,
.dream-overlay.closing .dream__half--main::before {
  opacity: 0;
}
.dream-overlay.closing .dream__half--main {
  border-right: 1.5px solid var(--ink);
  filter: drop-shadow(3px 3px 0 var(--ink));
  clip-path: polygon(
    0% 0%,
    calc(100% - 1px) 0%,
    100% 5%,
    calc(100% - 6px) 10%,
    calc(100% - 1px) 16%,
    calc(100% - 7px) 22%,
    100% 28%,
    calc(100% - 3px) 34%,
    calc(100% - 8px) 40%,
    calc(100% - 2px) 46%,
    100% 52%,
    calc(100% - 5px) 58%,
    calc(100% - 1px) 64%,
    calc(100% - 7px) 70%,
    100% 76%,
    calc(100% - 4px) 82%,
    calc(100% - 1px) 88%,
    calc(100% - 6px) 94%,
    100% 100%,
    0% 100%
  );
  animation: dreamTearMain 720ms cubic-bezier(.55,.06,.7,.4) forwards;
}
.dream-overlay.closing .dream__half--stub {
  border-left: 1.5px solid var(--ink);
  filter: drop-shadow(3px 3px 0 var(--ink));
  clip-path: polygon(
    1px 0%,
    100% 0%,
    100% 100%,
    1px 100%,
    7px 95%,
    1px 89%,
    5px 83%,
    0% 77%,
    7px 71%,
    2px 65%,
    8px 59%,
    1px 53%,
    0% 47%,
    6px 41%,
    1px 35%,
    7px 29%,
    0% 23%,
    5px 17%,
    1px 11%,
    7px 5%,
    1px 0%
  );
  animation: dreamTearStub 720ms cubic-bezier(.55,.06,.7,.4) forwards;
}
@keyframes dreamTearMain {
  0%   { transform: translate(0, 0) rotate(0deg); opacity: 1; }
  8%   { transform: translate(-2px, 1px) rotate(-0.6deg); opacity: 1; }
  100% { transform: translate(-160px, 360px) rotate(-13deg); opacity: 0; }
}
@keyframes dreamTearStub {
  0%   { transform: translate(0, 0) rotate(0deg); opacity: 1; }
  8%   { transform: translate(2px, 1px) rotate(0.8deg); opacity: 1; }
  100% { transform: translate(220px, 380px) rotate(18deg); opacity: 0; }
}

@media (prefers-reduced-motion: reduce) {
  .dream-overlay.closing .dream__half--main,
  .dream-overlay.closing .dream__half--stub {
    clip-path: none;
    animation: none;
    opacity: 0;
    transition: opacity 200ms ease;
  }
}

@media (max-width: 600px) {
  .dream {
    grid-template-columns: minmax(0, 1fr) 150px;
    width: min(560px, 96vw);
  }
  .dream__half { padding: 18px 18px 14px; }
  .dream__half--stub { padding: 18px 14px 14px; }
  .dream__goal { font-size: 42px; }
  .dream__hero {
    grid-template-columns: minmax(0, 1fr);
    gap: 10px;
    padding: 10px 0 12px;
  }
  .dream__headline { font-size: 14px; }
  .dream__meta {
    grid-template-columns: auto minmax(0, 1fr);
    gap: 6px 12px;
  }
  .dream__meta dd { font-size: 12px; }
  .dream__body {
    max-height: 180px;
  }
  .dream__body p { font-size: 12px; }
  .dream__stub-meta dd { font-size: 12px; }
}

.tl-overlay {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: none;
  background: var(--bg);
}
.tl-overlay.open { display: block; background: var(--bg-2); }
.tl-overlay.closing { pointer-events: none; }
.tl-overlay.closing .tl-frame {
  transform: scale(1);
  transition: none;
}

.tl-frame {
  position: relative;
  width: 100%;
  height: 100%;
  font-family: "Pretendard Variable", Pretendard, sans-serif;
  transform: scale(0.12);
  transition: transform 240ms ease;
}
.tl-overlay.content-visible .tl-frame {
  transform: scale(1);
  transition: transform 680ms cubic-bezier(0.34, 1.2, 0.64, 1);
}

.tl-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  padding: 22px 28px;
  z-index: 20;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: linear-gradient(to bottom, var(--bg-2) 55%, transparent);
  pointer-events: none;
}
.tl-header__brand {
  display: flex;
  align-items: center;
  gap: 10px;
}
.tl-header__dot {
  width: 7px;
  height: 7px;
  background: var(--hot);
  flex-shrink: 0;
}
.tl-header__title {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
}

.tl-mission {
  position: fixed;
  top: 54px;
  left: 28px;
  z-index: 20;
  display: flex;
  align-items: center;
  gap: 10px;
  pointer-events: none;
}
.tl-mission__label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--hot);
}
.tl-mission__text {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--ink-2);
}

.tl-rail {
  position: fixed;
  left: 32px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 20;
  height: min(260px, 44vh);
}
.tl-rail__line {
  width: 1.5px;
  height: 100%;
  background: var(--ink-3);
  position: relative;
  overflow: visible;
}
.tl-rail__fill {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 0%;
  background: var(--hot);
  transition: height 560ms cubic-bezier(.42, .04, .2, 1);
}
.tl-rail__stops {
  list-style: none;
  margin: 0;
  padding: 0;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.tl-rail__stop {
  position: absolute;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 8px;
  height: 8px;
  border: 1.5px solid var(--ink-3);
  background: var(--bg-2);
  border-radius: 50%;
  cursor: pointer;
  transition: border-color 300ms, background 300ms, transform 300ms, box-shadow 300ms;
}
.tl-rail__stop.is-past {
  border-color: var(--hot);
  background: var(--hot);
}
.tl-rail__stop.is-active {
  border-color: var(--hot);
  background: var(--hot);
  transform: translate(-50%, -50%) scale(1.55);
  box-shadow: 0 0 0 4px var(--hot-soft);
}

.tl-dots {
  position: fixed;
  right: 32px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 20;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.tl-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--ink-3);
  border: 0;
  padding: 0;
  cursor: pointer;
  transition: background 280ms, transform 280ms;
  flex-shrink: 0;
}
.tl-dot.is-active {
  background: var(--hot);
  transform: scale(1.7);
}

.tl-close {
  position: fixed;
  top: 18px;
  right: 22px;
  z-index: 30;
  background: transparent;
  border: 1.5px solid var(--ink-3);
  color: var(--ink-2);
  font-family: inherit;
  font-size: 18px;
  line-height: 1;
  width: 36px;
  height: 36px;
  cursor: pointer;
  transition: border-color 180ms, color 180ms;
  display: grid;
  place-items: center;
}
.tl-close:hover {
  border-color: var(--hot);
  color: var(--ink);
}
.tl-close:focus-visible {
  outline: 1.5px solid var(--hot);
  outline-offset: 2px;
}

.tl-sections {
  height: 100vh;
  overflow-y: scroll;
  scroll-snap-type: y mandatory;
  scrollbar-width: none;
}
.tl-sections::-webkit-scrollbar { display: none; }

.tl-section {
  height: 100vh;
  scroll-snap-align: start;
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
  padding: 80px;
}

.tl-section__ghost {
  position: absolute;
  font-size: min(24vw, 300px);
  font-weight: 900;
  letter-spacing: -0.06em;
  right: -0.04em;
  bottom: -0.1em;
  line-height: 1;
  pointer-events: none;
  user-select: none;
  font-variant-numeric: tabular-nums;
  color: rgba(20,17,13,0.025);
  transition: color 500ms ease;
}
.tl-section.is-active .tl-section__ghost { color: rgba(20,17,13,0.045); }
.tl-section.is-now.is-active .tl-section__ghost { color: rgba(196,77,46,0.08); }

.tl-section__content {
  position: relative;
  z-index: 1;
  max-width: 580px;
  padding-left: clamp(28px, 6vw, 80px);
  display: grid;
  gap: 16px;
}

.tl-section__index {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-variant-numeric: tabular-nums;
}

.tl-section__code {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--hot);
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 360ms ease, transform 360ms cubic-bezier(.2, .8, .25, 1);
  will-change: opacity, transform;
}

.tl-section__year {
  font-size: min(14vw, 118px);
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 500ms ease, transform 500ms cubic-bezier(.2, .8, .25, 1);
  will-change: opacity, transform;
}
.tl-section.is-now .tl-section__year { color: var(--hot); }

.tl-section__divider {
  width: 0;
  height: 1.5px;
  background: var(--ink-3);
  transition: width 420ms cubic-bezier(.42, .04, .2, 1);
  will-change: width;
}

.tl-section__sub {
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.01em;
  line-height: 1.55;
  color: var(--ink-2);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 380ms ease, transform 380ms cubic-bezier(.2, .8, .25, 1);
  will-change: opacity, transform;
}

.tl-section.is-active .tl-section__code {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 60ms;
}
.tl-section.is-active .tl-section__year {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 160ms;
}
.tl-section.is-active .tl-section__divider {
  width: 48px;
  transition-delay: 40ms;
}
.tl-section.is-active .tl-section__sub {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 290ms;
}

.tl-counter {
  position: fixed;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 20;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  color: var(--ink-3);
  font-variant-numeric: tabular-nums;
  pointer-events: none;
  white-space: nowrap;
}
.tl-counter__current { color: var(--ink-2); }

.tl-nav {
  position: fixed;
  bottom: 22px;
  right: 76px;
  z-index: 20;
  display: flex;
  gap: 10px;
}
.tl-nav__btn {
  background: transparent;
  border: 1.5px solid var(--ink-3);
  color: var(--ink-2);
  font-family: "Pretendard Variable", Pretendard, sans-serif;
  width: 36px;
  height: 36px;
  font-size: 14px;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: border-color 180ms, color 180ms;
}
.tl-nav__btn:hover:not(:disabled) {
  border-color: var(--hot);
  color: var(--ink);
}
.tl-nav__btn:focus-visible {
  outline: 1.5px solid var(--hot);
  outline-offset: 2px;
}
.tl-nav__btn:disabled {
  opacity: 0.22;
  cursor: not-allowed;
}

.tl-cutout {
  position: absolute;
  top: 50%;
  right: clamp(60px, 11vw, 160px);
  transform: translateY(-50%) rotate(-4deg);
  width: clamp(200px, 22vw, 340px);
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  transition: opacity 620ms ease 120ms, transform 620ms cubic-bezier(.2,.8,.25,1) 120ms;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}
.tl-section.is-active .tl-cutout {
  opacity: 1;
  transform: translateY(-50%) rotate(-4deg) translateX(0);
}
.tl-cutout--unavailable { display: none; }

.tl-cutout__svg {
  width: 100%;
  height: auto;
  display: block;
  overflow: visible;
  filter: drop-shadow(6px 8px 0 rgba(20,17,13,0.18));
}

.tl-cutout__grat {
  fill: none;
  stroke: rgba(20,17,13,0.22);
  stroke-width: 0.55;
  vector-effect: non-scaling-stroke;
}

.tl-cutout__shadow {
  fill: var(--land-shade);
  transform: translate(3px, 3px);
}

.tl-cutout__fill {
  fill: var(--land);
}
.tl-cutout__stroke {
  fill: none;
  stroke: var(--ink);
  stroke-width: 1.6;
  stroke-linejoin: round;
  stroke-linecap: round;
  paint-order: stroke fill;
}

.tl-cutout__pin-halo {
  fill: var(--hot-soft);
}
.tl-cutout__pin-ring {
  fill: none;
  stroke: var(--ink);
  stroke-width: 1.2;
}
.tl-cutout__pin {
  fill: var(--hot);
}

.tl-cutout__tape {
  position: absolute;
  top: -8px;
  left: 50%;
  transform: translateX(-50%) rotate(-6deg);
  width: 78px;
  height: 18px;
  background:
    repeating-linear-gradient(45deg, rgba(255,255,255,0.18) 0 4px, rgba(255,255,255,0) 4px 8px),
    rgba(196, 77, 46, 0.35);
  border-left: 1px dashed rgba(20,17,13,0.25);
  border-right: 1px dashed rgba(20,17,13,0.25);
  z-index: 2;
}

.tl-cutout__tag {
  display: grid;
  gap: 4px;
  justify-items: center;
  text-align: center;
  padding: 8px 12px;
  background: var(--bg-2);
  border: 1px solid var(--ink-3);
  font-variant-numeric: tabular-nums;
  transform: rotate(2deg);
}
.tl-cutout__tag-eyebrow {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.tl-cutout__tag-coords {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  color: var(--ink);
}
.tl-cutout__tag-foot {
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 0.382em;
  text-transform: uppercase;
  color: var(--hot);
}

@media (max-width: 900px) {
  .tl-cutout {
    right: 24px;
    width: clamp(160px, 28vw, 240px);
  }
}
@media (max-width: 600px) {
  .tl-cutout {
    top: auto;
    bottom: 24px;
    right: 24px;
    transform: rotate(-4deg);
    width: 140px;
  }
  .tl-section.is-active .tl-cutout {
    transform: rotate(-4deg);
  }
}

@media (max-width: 600px) {
  .tl-section { padding: 70px 24px; }
  .tl-section__content { padding-left: 0; max-width: 100%; }
  .tl-section__year { font-size: min(20vw, 96px); }
  .tl-rail { display: none; }
  .tl-nav { right: 60px; bottom: 18px; }
  .tl-dots { right: 16px; }
}

@media (prefers-reduced-motion: reduce) {
  .tl-overlay { transition: none; }
  .tl-frame { transition: none; transform: none; }
  .tl-overlay.content-visible .tl-frame { transition: none; transform: none; }
  .tl-section__code,
  .tl-section__year,
  .tl-section__sub {
    transition: none;
  }
  .tl-section.is-active .tl-section__code,
  .tl-section.is-active .tl-section__year,
  .tl-section.is-active .tl-section__sub {
    opacity: 1;
    transform: none;
  }
  .tl-section.is-active .tl-section__divider { width: 48px; transition: none; }
  .tl-rail__fill { transition: none; }
}
