:root {
      color-scheme: dark;
      --bg: #0b0a08;
      --paper: #17120d;
      --paper-soft: #211b13;
      --ink: #f6ead5;
      --muted: #e4cba3;
      --gold: #e2af58;
      --line: rgba(226, 175, 88, 0.42);
    }

    * {
      box-sizing: border-box;
    }

    body {
      margin: 0;
      background:
        radial-gradient(circle at 18% 0%, rgba(185, 66, 34, 0.28), transparent 34%),
        linear-gradient(180deg, #21110a, var(--bg) 42%);
      color: var(--ink);
      font-family: "Hiragino Mincho ProN", "Yu Mincho", "Hiragino Sans", serif;
    }

    a {
      color: inherit;
    }

    .ramen-shell {
      min-height: 100vh;
      border: 10px solid #0b0a08;
    }

    .topbar {
      display: grid;
      grid-template-columns: minmax(0, 1fr) minmax(280px, calc(2240px - 416px)) auto minmax(0, 1fr);
      align-items: stretch;
      border-bottom: 1px solid rgba(226, 175, 88, 0.45);
      background: rgba(12, 12, 10, 0.92);
    }

    .brand-mark {
      grid-column: 2;
      display: grid;
      grid-template-columns: auto 1fr;
      gap: 4px 16px;
      align-items: center;
      padding: 16px 22px;
      border-right: 1px solid rgba(226, 175, 88, 0.35);
      color: inherit;
      text-decoration: none;
    }

    .brand-stamp {
      grid-row: span 2;
      padding: 5px 10px;
      border-radius: 6px;
      background: #a9341b;
      color: #fff2dc;
      font-weight: 800;
      transform: rotate(-2deg);
    }

    .brand-mark strong {
      font-size: 2.1rem;
      line-height: 1;
      letter-spacing: 0;
    }

    .brand-mark small {
      color: #e0b36a;
      font-family: Georgia, serif;
      letter-spacing: 0.08em;
    }

    .nav-links {
      grid-column: 3;
      display: flex;
      align-items: stretch;
    }

    .nav-links a {
      display: grid;
      place-items: center;
      min-width: 104px;
      padding: 12px 14px;
      border-left: 1px solid rgba(226, 175, 88, 0.28);
      color: #e9d7b4;
      font-size: 0.9rem;
      font-weight: 700;
      text-decoration: none;
    }

    article {
      width: min(1120px, calc(100% - 40px));
      margin: 48px auto 0;
      padding: clamp(24px, 5vw, 56px);
      padding-bottom: clamp(18px, 3vw, 30px);
      border: 1px solid var(--line);
      background:
        linear-gradient(180deg, rgba(255, 246, 220, 0.08), transparent),
        rgba(16, 13, 9, 0.94);
      box-shadow: 0 24px 70px rgba(0, 0, 0, 0.36);
    }

    .article-breadcrumb {
      display: flex;
      flex-wrap: wrap;
      gap: 7px;
      align-items: center;
      margin: 0 0 18px;
      color: var(--gold);
      font-size: 0.82rem;
      font-weight: 800;
      letter-spacing: 0.04em;
      line-height: 1.7;
    }

    .article-breadcrumb a {
      color: var(--gold);
      text-decoration: none;
    }

    .article-breadcrumb a:hover {
      text-decoration: underline;
      text-underline-offset: 4px;
    }

    .article-breadcrumb span {
      color: var(--muted);
    }

    .article-breadcrumb span[aria-hidden="true"] {
      color: rgba(226, 175, 88, 0.58);
    }

    h1 {
      max-width: 12em;
      margin: 0;
      font-size: clamp(2.35rem, 7vw, 5.2rem);
      line-height: 1.08;
      letter-spacing: -0.04em;
    }

    header p:last-child,
    section {
      color: var(--muted);
      font-size: 1.06rem;
      line-height: 1.9;
    }

    header p:last-child {
      max-width: 48em;
      margin: 22px 0 0;
    }

    section {
      margin-top: 34px;
      padding-top: 28px;
      border-top: 1px solid rgba(226, 175, 88, 0.28);
    }

    .article-map-grid {
      display: grid;
      grid-template-columns: minmax(260px, 0.9fr) minmax(0, 1.35fr);
      gap: 24px;
      align-items: stretch;
      min-width: 0;
    }

    .basic-card,
    .static-map-card,
    .map-focus-button {
      border: 1px solid rgba(226, 175, 88, 0.34);
      background: rgba(246, 230, 190, 0.055);
    }

    .basic-card {
      min-width: 0;
      padding: 20px 22px;
      line-height: 1.58;
    }

    .map-side {
      display: grid;
      grid-template-rows: minmax(360px, 1fr) auto;
      gap: 12px;
      min-width: 0;
      min-height: 100%;
    }

    .static-map-card {
      position: relative;
      width: 100%;
      min-width: 0;
      min-height: 0;
      overflow: hidden;
      background: #0b0a08;
    }

    .static-map-card.is-fullscreen {
      position: fixed;
      inset: 0;
      z-index: 1200;
      width: 100vw;
      height: 100dvh;
      border: 0;
      border-radius: 0;
      background: #0b0a08;
    }

    .static-map {
      position: absolute;
      inset: 0;
    }

    .static-map-card::after {
      content: "";
      position: absolute;
      inset: 0;
      pointer-events: none;
      background:
        radial-gradient(circle at 50% 56%, transparent 38%, rgba(8, 6, 4, 0.12) 80%),
        linear-gradient(180deg, rgba(10, 7, 5, 0.02), rgba(10, 7, 5, 0.14));
      z-index: 2;
    }

    .map-focus-button {
      position: absolute;
      right: 18px;
      bottom: 18px;
      z-index: 3;
      display: inline-grid;
      min-height: 42px;
      max-width: calc(100% - 36px);
      place-items: center;
      padding: 0 16px;
      background: #b93621;
      color: #fff8e8;
      font: inherit;
      font-weight: 900;
      cursor: pointer;
      box-shadow: 0 16px 42px rgba(0, 0, 0, 0.28);
    }

    .static-map-card.is-fullscreen .map-focus-button {
      top: 18px;
      right: 18px;
      bottom: auto;
    }

    .map-focus-label-short {
      display: none;
    }

    .google-map-link {
      display: inline-grid;
      width: fit-content;
      max-width: 100%;
      min-height: 34px;
      margin-top: 8px;
      place-items: center;
      padding: 0 12px;
      border: 1px solid rgba(226, 175, 88, 0.34);
      color: var(--ink);
      text-decoration: none;
      font-size: 0.88rem;
      font-weight: 900;
      overflow-wrap: anywhere;
      text-align: center;
      transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
    }

    .google-map-link:hover {
      transform: translateY(-1px);
      border-color: rgba(226, 175, 88, 0.72);
      background: rgba(226, 175, 88, 0.1);
    }

    .external-links {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      align-items: center;
    }

    .external-link-button {
      display: inline-grid;
      width: fit-content;
      max-width: 100%;
      min-height: 34px;
      place-items: center;
      padding: 0 12px;
      border: 1px solid rgba(226, 175, 88, 0.34);
      color: var(--ink);
      text-decoration: none;
      font-size: 0.88rem;
      font-weight: 900;
      text-align: center;
      transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
    }

    .external-link-button:hover {
      transform: translateY(-1px);
      border-color: rgba(226, 175, 88, 0.72);
      background: rgba(226, 175, 88, 0.1);
    }

    .map-rating-card {
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto;
      gap: 8px 18px;
      align-items: center;
      min-width: 0;
      padding: 16px 18px;
      border: 1px solid rgba(226, 175, 88, 0.34);
      background:
        linear-gradient(135deg, rgba(226, 175, 88, 0.12), transparent),
        rgba(246, 230, 190, 0.055);
    }

    .map-rating-label {
      grid-column: 1 / -1;
      min-width: 0;
      color: var(--muted);
      font-size: 0.82rem;
      font-weight: 800;
      letter-spacing: 0.08em;
      overflow-wrap: anywhere;
    }

    .map-rating-stars {
      position: relative;
      display: inline-block;
      width: fit-content;
      max-width: 100%;
      min-width: 0;
      color: rgba(226, 175, 88, 0.22);
      font-size: clamp(1.65rem, 3.4vw, 3.1rem);
      letter-spacing: 0.08em;
      line-height: 1;
      white-space: nowrap;
    }

    .map-rating-stars-base {
      display: block;
    }

    .map-rating-stars-fill {
      position: absolute;
      display: block;
      inset: 0 auto 0 0;
      overflow: hidden;
      color: var(--gold);
      white-space: nowrap;
    }

    .map-rating-card strong {
      grid-column: 2;
      color: var(--ink);
      font-size: 2rem;
      line-height: 1;
    }

    .map-rating-card small {
      color: var(--muted);
      font-size: 0.78rem;
    }

    .ramen-map-popup .maplibregl-popup-content {
      border: 1px solid rgba(226, 175, 88, 0.7);
      background: rgba(17, 13, 8, 0.94);
      color: var(--ink);
      font-weight: 900;
      box-shadow: 0 18px 45px rgba(0, 0, 0, 0.35);
    }

    .ramen-map-popup .maplibregl-popup-tip {
      border-top-color: rgba(17, 13, 8, 0.94);
    }

    .maplibregl-ctrl-attrib {
      border: 1px solid rgba(226, 175, 88, 0.26);
      background: rgba(255, 248, 232, 0.82);
      font-size: 11px;
    }

    .maplibregl-ctrl-attrib.maplibregl-compact {
      min-height: 24px;
      min-width: 24px;
      padding: 0;
    }

    .maplibregl-ctrl-attrib.maplibregl-compact:not(.maplibregl-compact-show) .maplibregl-ctrl-attrib-inner {
      display: none;
    }

    .maplibregl-ctrl-attrib a {
      color: #1c160f;
    }

    .map-placeholder {
      display: grid;
      min-height: 100%;
      place-items: center;
      padding: 28px;
      color: var(--muted);
      text-align: center;
    }

    .writer-card {
      display: inline-grid;
      grid-template-columns: 48px auto;
      gap: 22px;
      align-items: center;
      margin-top: 24px;
      padding: 0;
      border: 0;
      background: transparent;
    }

    .article-body {
      color: var(--ink);
    }

    .article-body h2 {
      max-width: 13em;
      margin-bottom: 18px;
      font-size: clamp(2rem, 5vw, 3.8rem);
      line-height: 1.16;
      letter-spacing: -0.04em;
    }

    .article-writer-portrait {
      float: right;
      display: block;
      width: min(330px, 40%);
      margin: 0 0 28px 34px;
      padding: 14px;
      border: 1px solid rgba(226, 175, 88, 0.42);
      background:
        radial-gradient(circle at 50% 0%, rgba(226, 175, 88, 0.16), transparent 58%),
        rgba(246, 230, 190, 0.055);
      color: var(--gold);
      font-size: 0.78rem;
      font-weight: 900;
      letter-spacing: 0.08em;
      text-align: center;
      text-decoration: none;
      transform-origin: center top;
      transition:
        transform 180ms ease,
        border-color 180ms ease,
        background 180ms ease,
        box-shadow 180ms ease,
        filter 180ms ease;
      will-change: transform;
    }

    .article-writer-portrait:hover {
      transform: translateY(-4px) scale(1.025);
      border-color: rgba(250, 207, 132, 0.72);
      background:
        radial-gradient(circle at 50% 0%, rgba(226, 175, 88, 0.22), transparent 58%),
        rgba(246, 230, 190, 0.085);
      box-shadow: 0 22px 52px rgba(0, 0, 0, 0.3);
      filter: brightness(1.04);
    }

    .article-writer-portrait img {
      display: block;
      width: 100%;
      aspect-ratio: 1;
      object-fit: cover;
      border: 1px solid rgba(226, 175, 88, 0.44);
      border-radius: 18px;
      box-shadow: 0 12px 28px rgba(0, 0, 0, 0.24);
    }

    .article-writer-portrait strong {
      display: block;
      margin-top: 12px;
      color: var(--ink);
      font-size: 0.95rem;
      letter-spacing: 0.02em;
    }

    .article-writer-portrait .writer-portrait-date {
      display: block;
      margin-top: 4px;
      color: var(--muted);
      font-size: 0.74rem;
      letter-spacing: 0.04em;
    }

    .living-archive-card {
      clear: both;
      display: grid;
      gap: 14px;
      margin: 0 0 30px;
      padding: 22px 24px;
      border: 1px solid rgba(226, 175, 88, 0.3);
      background:
        radial-gradient(circle at 0% 0%, rgba(226, 175, 88, 0.12), transparent 34%),
        rgba(246, 230, 190, 0.06);
      box-shadow: 0 18px 44px rgba(20, 16, 10, 0.12);
    }

    .living-archive-card h2 {
      max-width: none;
      margin: 0;
      font-size: clamp(1.35rem, 2.2vw, 1.9rem);
      letter-spacing: -0.03em;
    }

    .living-archive-card > p:last-of-type {
      margin: 0;
      color: var(--muted);
      font-size: 0.98rem;
      line-height: 1.8;
    }

    .living-archive-meta {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 14px 18px;
      margin: 0;
    }

    .living-archive-meta div {
      padding-top: 10px;
      border-top: 1px solid rgba(226, 175, 88, 0.24);
    }

    .living-archive-meta dt {
      color: var(--muted);
      font-size: 0.78rem;
      font-weight: 800;
      letter-spacing: 0.08em;
    }

    .living-archive-meta dd {
      margin: 6px 0 0;
      color: var(--ink);
      font-size: 1rem;
      font-weight: 700;
    }

    .embedded-dummy-image {
      float: left;
      box-sizing: border-box;
      width: min(380px, 48%);
      margin: 12px 30px 22px 0;
      padding: 14px;
      overflow: hidden;
      border: 1px solid rgba(226, 175, 88, 0.34);
      background:
        radial-gradient(circle at 50% 0%, rgba(185, 66, 34, 0.16), transparent 56%),
        rgba(246, 230, 190, 0.055);
    }

    .article-visual-default {
      padding: 0;
    }

    .article-visual-embed {
      padding: 10px;
      position: relative;
    }

    .article-visual-embed iframe,
    .article-visual-embed blockquote,
    .article-visual-embed .instagram-media,
    .article-visual-embed .twitter-tweet {
      box-sizing: border-box !important;
      width: 100% !important;
      min-width: 0 !important;
      max-width: 100% !important;
      margin-right: 0 !important;
      margin-left: 0 !important;
      position: static !important;
    }

    @media (max-width: 520px) {
      .article-visual-embed[data-platform="instagram"] {
        --instagram-embed-scale: 0.86;
        width: min(326px, 100%);
        margin-right: auto;
        margin-left: auto;
        padding: 8px;
      }

      .article-visual-embed[data-platform="instagram"] iframe,
      .article-visual-embed[data-platform="instagram"] .instagram-media,
      .article-visual-embed[data-platform="instagram"] .instagram-media-rendered {
        width: calc(100% / var(--instagram-embed-scale)) !important;
        max-width: calc(100% / var(--instagram-embed-scale)) !important;
        transform: scale(var(--instagram-embed-scale));
        transform-origin: top left;
      }

      .article-visual-embed[data-platform="instagram"] iframe {
        margin-bottom: -76px !important;
      }

      .article-visual-embed {
        float: none;
        clear: both;
        width: min(326px, 100%);
        margin: 28px auto 0;
      }

      .article-banner.article-banner-mobile-mid {
        float: none;
        clear: both;
        justify-content: center;
        width: 100%;
        margin: 24px auto;
      }
    }

    .embedded-dummy-image img {
      display: block;
      width: 100%;
      height: auto;
      background: rgba(0, 0, 0, 0.2);
    }

    .embedded-dummy-image figcaption {
      margin: 0;
      padding: 10px 14px 12px;
      color: var(--gold);
      font-size: 0.78rem;
      font-weight: 800;
      letter-spacing: 0.08em;
    }

    .article-banner {
      display: grid;
      place-items: center;
      margin: 28px auto;
      clear: both;
    }

    .article-banner a {
      display: block;
      line-height: 0;
      transition: transform 180ms ease, filter 180ms ease;
    }

    .article-banner a:hover {
      transform: translateY(-2px);
      filter: brightness(1.06);
    }

    .article-banner img {
      display: block;
      border: 1px solid rgba(226, 175, 88, 0.38);
      box-shadow: 0 18px 48px rgba(0, 0, 0, 0.28);
    }

    .article-banner-rectangle img {
      width: 336px;
      height: 280px;
    }

    .article-banner-rectangle {
      float: right;
      place-items: end;
      clear: none;
      margin: 18px 0 24px 30px;
    }

    .article-banner-mobile-mid {
      float: left;
      place-items: start;
      clear: none;
      width: 320px;
      margin: 12px 30px 22px 0;
    }

    .article-banner-wide {
      margin: 38px auto 8px;
    }

    .article-banner-wide img {
      width: 728px;
      height: 90px;
    }

    .article-banner-mobile img {
      width: 320px;
      height: 100px;
    }

    .article-body p {
      margin: 0 0 18px;
      color: var(--muted);
      font-size: 1.08rem;
      line-height: 2.05;
    }

    .article-body .fact,
    .article-body .persona {
      box-decoration-break: clone;
      -webkit-box-decoration-break: clone;
      color: var(--muted);
      font-style: normal;
    }

    .heat-commentary {
      padding: 0;
      border-left: 0;
      background: transparent;
      color: var(--ink) !important;
    }

    .signals-panel {
      display: grid;
      grid-template-columns: minmax(0, 1fr) minmax(260px, 0.52fr);
      gap: 22px;
      align-items: stretch;
    }

    .signals-panel ul {
      margin: 0;
      padding-left: 1.4em;
    }

    .article-correction-card {
      display: grid;
      align-content: center;
      gap: 14px;
      padding: 18px;
      border: 1px solid rgba(226, 175, 88, 0.34);
      background:
        linear-gradient(135deg, rgba(185, 66, 34, 0.16), transparent 60%),
        rgba(246, 230, 190, 0.05);
    }

    .article-correction-card p {
      margin: 0;
      color: var(--muted);
      font-size: 0.92rem;
      line-height: 1.75;
    }

    .article-correction-card-header {
      display: flex;
      justify-content: space-between;
      gap: 14px;
      align-items: center;
    }

    .article-correction-button {
      display: inline-grid;
      min-height: 48px;
      place-items: center;
      padding: 0 18px;
      border: 1px solid rgba(250, 207, 132, 0.62);
      background: #a9341b;
      color: #fff2dc;
      font-weight: 900;
      line-height: 1.35;
      text-align: center;
      text-decoration: none;
      box-shadow: 0 14px 34px rgba(0, 0, 0, 0.24);
      transition:
        transform 180ms ease,
        filter 180ms ease,
        border-color 180ms ease;
    }

    .article-correction-button:hover {
      transform: translateY(-2px);
      filter: brightness(1.06);
      border-color: rgba(250, 207, 132, 0.9);
    }

    .article-history-link {
      display: inline-grid;
      min-height: 34px;
      place-items: center;
      padding: 0 12px;
      border: 1px solid rgba(250, 207, 132, 0.5);
      background: rgba(12, 10, 8, 0.52);
      color: #fff2dc;
      font-size: 0.82rem;
      font-weight: 900;
      letter-spacing: 0.08em;
      text-decoration: none;
      white-space: nowrap;
    }

    .article-contributors {
      border: 1px solid rgba(226, 175, 88, 0.34);
      background:
        radial-gradient(circle at 100% 0%, rgba(226, 175, 88, 0.12), transparent 48%),
        rgba(246, 230, 190, 0.045);
    }

    .article-contributors-heading {
      display: flex;
      gap: 16px;
      justify-content: space-between;
      align-items: start;
      margin-bottom: 16px;
    }

    .article-contributors-heading h2 {
      margin-bottom: 0;
    }

    .article-contributors-heading > span {
      color: var(--accent);
      font-weight: 900;
      white-space: nowrap;
    }

    .article-contributor-list {
      display: grid;
      gap: 12px;
      margin: 0;
      padding: 0;
      list-style: none;
    }

    .article-contributor-list li {
      display: grid;
      gap: 8px;
      padding: 14px;
      border: 1px solid rgba(226, 175, 88, 0.24);
      background: rgba(0, 0, 0, 0.18);
    }

    .article-contributor-list strong {
      color: var(--ink);
    }

    .article-contributor-list span {
      width: fit-content;
      padding: 3px 8px;
      border: 1px solid rgba(226, 175, 88, 0.3);
      color: var(--accent);
      font-size: 0.78rem;
      font-weight: 900;
      letter-spacing: 0.08em;
    }

    .article-contributor-list p,
    .article-contributors-empty {
      margin: 0;
      color: var(--muted);
      line-height: 1.75;
    }

    .article-contributor-list blockquote {
      margin: 0;
      padding-left: 12px;
      border-left: 3px solid rgba(226, 175, 88, 0.7);
      color: #f4d492;
      line-height: 1.65;
    }

    .article-body::after {
      content: "";
      display: block;
      clear: both;
    }

    .investigation-log {
      border: 1px dashed rgba(226, 175, 88, 0.44);
      background:
        linear-gradient(135deg, rgba(226, 175, 88, 0.08), transparent 42%),
        rgba(246, 230, 190, 0.035);
    }

    .investigation-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 14px;
    }

    .investigation-card {
      min-width: 0;
      padding: 16px;
      border: 1px solid rgba(226, 175, 88, 0.26);
      background: rgba(0, 0, 0, 0.16);
    }

    .investigation-card h3 {
      margin: 0 0 10px;
      color: var(--ink);
      font-size: 0.96rem;
    }

    .investigation-card p,
    .investigation-card li {
      color: var(--muted);
      font-size: 0.86rem;
      line-height: 1.7;
    }

    .investigation-card ol,
    .investigation-card ul {
      margin: 0;
      padding-left: 1.2em;
    }

    .investigation-card a {
      color: var(--gold);
      overflow-wrap: anywhere;
    }

    .investigation-card code {
      padding: 2px 5px;
      border: 1px solid rgba(226, 175, 88, 0.22);
      color: var(--ink);
      background: rgba(0, 0, 0, 0.22);
      white-space: normal;
    }

    .nearby-stores {
      contain: content;
    }

    .nearby-stores-header {
      display: flex;
      gap: 18px;
      align-items: end;
      justify-content: space-between;
      margin-bottom: 16px;
    }

    .nearby-stores-header p {
      margin: 0;
      color: var(--muted);
      font-size: 0.92rem;
      line-height: 1.7;
    }

    .nearby-stores-list {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 12px;
      margin: 0;
      padding: 0;
      list-style: none;
    }

    .nearby-stores-list li {
      position: relative;
      isolation: isolate;
      display: grid;
      gap: 6px;
      overflow: hidden;
      min-height: 138px;
      margin: 0;
      padding: 16px;
      border: 1px solid rgba(226, 175, 88, 0.3);
      background: rgba(246, 230, 190, 0.045);
    }

    .nearby-stores-list li::before {
      content: "";
      position: absolute;
      inset: 0;
      z-index: -2;
      background-image: var(--nearby-ramen-image);
      background-size: cover;
      background-position: center;
      filter: blur(1.6px) grayscale(0.16) sepia(0.22) saturate(0.9) brightness(0.82) contrast(1.08);
      transform: scale(1.03);
      opacity: 0.86;
    }

    .nearby-stores-list li::after {
      content: "";
      position: absolute;
      inset: 0;
      z-index: -1;
      background:
        linear-gradient(180deg, rgba(12, 9, 6, 0.18), rgba(12, 9, 6, 0.38)),
        radial-gradient(ellipse at 28% 28%, rgba(8, 6, 4, 0.72), rgba(8, 6, 4, 0.5) 42%, rgba(8, 6, 4, 0.18) 72%, transparent 100%),
        radial-gradient(circle at 0% 0%, rgba(185, 66, 34, 0.14), transparent 58%);
    }

    .nearby-stores-list a {
      color: var(--ink);
      font-size: 1.08rem;
      font-weight: 900;
      text-decoration: none;
      text-shadow: 0 1px 10px rgba(0, 0, 0, 0.96);
    }

    .nearby-stores-list span {
      color: var(--muted);
      font-size: 0.92rem;
      line-height: 1.5;
      text-shadow: 0 1px 9px rgba(0, 0, 0, 0.94);
    }

    .nearby-stores-list small {
      color: var(--gold);
      font-size: 0.78rem;
      font-weight: 800;
      letter-spacing: 0.06em;
      text-shadow: 0 1px 8px rgba(0, 0, 0, 0.95);
    }

    .writer-pickup-section {
      margin-top: 34px;
      padding: 24px;
      border: 1px solid rgba(226, 175, 88, 0.28);
      background:
        radial-gradient(circle at 12% 0%, rgba(185, 66, 34, 0.16), transparent 34%),
        rgba(246, 230, 190, 0.035);
    }

    .writer-pickup-heading {
      display: grid;
      gap: 8px;
      margin-bottom: 18px;
    }

    .writer-pickup-heading h2 {
      margin: 0;
      color: var(--ink);
      font-size: clamp(1.35rem, 2.5vw, 2rem);
      line-height: 1.2;
    }

    .writer-pickup-list {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 14px;
      margin: 0;
      padding: 0;
      list-style: none;
    }

    .writer-pickup-list li {
      position: relative;
      overflow: hidden;
      min-height: 180px;
      margin: 0;
      border: 1px solid rgba(226, 175, 88, 0.3);
      background: #120e09;
    }

    .writer-pickup-list li::before {
      content: "";
      position: absolute;
      inset: 0;
      background-image: var(--article-ramen-image);
      background-size: cover;
      background-position: center;
      filter: blur(1.6px) grayscale(0.16) sepia(0.22) saturate(0.9) brightness(0.82) contrast(1.08);
      opacity: 0.86;
      transform: scale(1.03);
    }

    .writer-pickup-list li::after {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(180deg, rgba(12, 9, 6, 0.16), rgba(12, 9, 6, 0.34)),
        radial-gradient(circle at 0% 0%, rgba(185, 66, 34, 0.14), transparent 58%);
    }

    .writer-pickup-list a {
      position: relative;
      z-index: 1;
      display: grid;
      gap: 10px;
      align-content: start;
      height: 100%;
      min-height: 180px;
      padding: 18px;
      color: inherit;
      text-decoration: none;
      transition: background 160ms ease, transform 160ms ease;
    }

    .writer-pickup-list a::before {
      content: "";
      position: absolute;
      z-index: -1;
      inset: 10px 10px auto 10px;
      height: min(118px, calc(100% - 20px));
      border-radius: 18px;
      background:
        radial-gradient(ellipse at 28% 26%, rgba(8, 6, 4, 0.82), rgba(8, 6, 4, 0.56) 48%, rgba(8, 6, 4, 0.16) 82%, transparent 100%);
      filter: blur(6px);
      pointer-events: none;
      transform: scale(1.02);
    }

    .writer-pickup-list a:hover {
      background: rgba(246, 230, 190, 0.055);
      transform: translateY(-2px);
    }

    .article-star-badge {
      position: absolute;
      top: 15px;
      right: 14px;
      z-index: 2;
      padding: 5px 9px;
      border: 1px solid rgba(255, 225, 152, 0.72);
      border-radius: 999px;
      background: rgba(15, 12, 8, 0.78);
      color: #ffe198;
      font-family: Georgia, serif;
      font-size: 0.82rem;
      font-style: normal;
      font-weight: 900;
      letter-spacing: 0.03em;
      line-height: 1;
      box-shadow: 0 8px 22px rgba(0, 0, 0, 0.42);
      text-shadow: 0 1px 8px rgba(0, 0, 0, 0.9);
    }

    .writer-pickup-list small {
      width: max-content;
      max-width: calc(100% - 82px);
      color: var(--gold);
      font-size: 0.72rem;
      font-weight: 900;
      letter-spacing: 0.1em;
      text-shadow: 0 1px 8px rgba(0, 0, 0, 0.95);
    }

    .writer-pickup-list strong {
      display: block;
      width: auto;
      max-width: 100%;
      color: var(--ink);
      font-size: 1.08rem;
      line-height: 1.55;
      white-space: normal;
      overflow-wrap: anywhere;
      text-shadow: 0 1px 10px rgba(0, 0, 0, 0.96);
    }

    .writer-pickup-list span {
      display: block;
      color: var(--muted);
      font-size: 0.9rem;
      line-height: 1.55;
      overflow: hidden;
      text-shadow: 0 1px 8px rgba(0, 0, 0, 0.95);
    }

    .site-footer {
      margin-top: 42px;
      padding-top: 26px;
      border-top: 1px solid rgba(226, 175, 88, 0.28);
    }

    .footer-browse-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
    }

    .footer-browse-band {
      margin: 0;
      padding: 22px;
      border: 1px solid rgba(226, 175, 88, 0.34);
      background:
        linear-gradient(180deg, rgba(255, 243, 215, 0.075), transparent),
        rgba(246, 230, 190, 0.035);
    }

    .footer-browse-band h2 {
      margin-bottom: 14px;
      font-size: 1.3rem;
      letter-spacing: 0;
    }

    .footer-tag-row {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
    }

    .footer-tag-row a {
      padding: 8px 12px;
      border: 1px solid rgba(226, 175, 88, 0.38);
      background: rgba(246, 228, 188, 0.08);
      color: var(--ink);
      font-weight: 800;
      text-decoration: none;
    }

    .footer-tag-row a:hover,
    .footer-policy-links a:hover {
      border-color: rgba(226, 175, 88, 0.72);
      color: #fff5de;
    }

    .footer-policy-links {
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      gap: 12px 22px;
      width: min(1120px, calc(100% - 40px));
      margin: 24px auto 48px;
      color: var(--muted);
      font-size: 0.9rem;
    }

    .footer-policy-links a {
      color: inherit;
      text-decoration: none;
      text-underline-offset: 4px;
    }

    .writer-card img {
      width: 48px;
      aspect-ratio: 1;
      object-fit: cover;
      border: 1px solid rgba(226, 175, 88, 0.44);
      border-radius: 10px;
      background: rgba(0, 0, 0, 0.24);
    }

    .writer-card h2 {
      margin-bottom: 6px;
    }

    .writer-title {
      margin: 0;
      color: var(--muted);
      font-size: 0.88rem;
      letter-spacing: 0;
    }

    .writer-catchphrase {
      margin: 2px 0 0;
      color: var(--ink);
      font-size: 0.95rem;
      font-weight: 800;
    }

    .writer-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 14px;
      padding: 0;
      list-style: none;
    }

    .writer-meta li {
      margin: 0;
      padding: 4px 9px;
      border: 1px solid rgba(226, 175, 88, 0.28);
      color: var(--gold);
      font-size: 0.78rem;
      font-weight: 800;
      letter-spacing: 0.08em;
    }

    h2 {
      margin: 0 0 16px;
      color: #f4d492;
      font-size: 1.45rem;
    }

    dl {
      display: grid;
      gap: 10px;
      margin: 0;
    }

    dl > div {
      display: grid;
      grid-template-columns: minmax(72px, 0.36fr) minmax(0, 1fr);
      gap: 14px;
      min-width: 0;
    }

    dt {
      color: #d8b77a;
      font-weight: 800;
    }

    dd {
      min-width: 0;
      margin: 0;
      overflow-wrap: anywhere;
    }

    .business-hours-day {
      color: #d8b77a;
      font-weight: 800;
      white-space: nowrap;
    }

    .business-hours-time {
      min-width: 0;
      color: var(--muted);
      line-height: 1.55;
    }

    li + li {
      margin-top: 10px;
    }

    @media (max-width: 900px) {
      .topbar {
        grid-template-columns: 1fr;
      }

      .brand-mark,
      .nav-links {
        grid-column: auto;
      }

      .brand-mark {
        border-right: 0;
      }

      .nav-links {
        overflow-x: auto;
        border-top: 1px solid rgba(226, 175, 88, 0.28);
      }

      .nav-links a {
        flex: 1 0 25%;
        min-width: 0;
        padding: 10px 6px;
        font-size: 0.82rem;
        white-space: nowrap;
      }

      .article-map-grid {
        grid-template-columns: 1fr;
      }

      .map-side {
        grid-template-rows: minmax(320px, 58vw) auto;
      }
    }

    @media (max-width: 720px) {
      .brand-mark {
        padding: 12px;
      }

      .brand-mark strong {
        font-size: 1.55rem;
        white-space: nowrap;
      }
    }

    @media (max-width: 760px) {
      .ramen-shell {
        border-width: 6px;
      }

      article {
        width: min(1120px, calc(100% - 16px));
        margin: 18px auto 0;
        padding: 18px 14px 24px;
      }

      header p:last-child {
        font-size: 0.94rem;
        line-height: 1.75;
      }

      .basic-card {
        padding: 17px 18px;
        font-size: 0.9rem;
        line-height: 1.5;
      }

      .basic-card h2 {
        font-size: 1.18rem;
      }

      dl {
        gap: 8px;
      }

      dl > div {
        grid-template-columns: minmax(58px, 0.34fr) minmax(0, 1fr);
        gap: 10px;
      }

      .map-side {
        grid-template-rows: minmax(150px, 28vw) auto;
      }

      .map-focus-label-long {
        display: none;
      }

      .map-focus-label-short {
        display: inline;
      }

      .ramen-map-fullscreen-open,
      .ramen-map-fullscreen-open body {
        overflow: hidden;
      }

      .static-map-card.is-fullscreen {
        inset: 0;
      }

      .writer-card {
        grid-template-columns: 48px auto;
      }

      .writer-card img {
        width: 48px;
      }

      .embedded-dummy-image {
        float: none;
        width: 100%;
        margin: 0 0 22px;
      }

      .article-writer-portrait {
        float: none;
        width: min(330px, 100%);
        margin: 0 auto 24px;
      }

      .article-writer-portrait img {
        aspect-ratio: 3 / 2;
        object-position: 50% 25% !important;
      }

      .living-archive-meta {
        grid-template-columns: 1fr;
      }

      .nearby-stores-header {
        display: grid;
      }

      .footer-browse-band {
        padding: 16px;
      }

      .footer-browse-band h2 {
        font-size: 1.08rem;
      }

      .footer-tag-row {
        gap: 7px;
      }

      .footer-tag-row a {
        padding: 6px 9px;
        font-size: 0.84rem;
        line-height: 1.25;
      }

      .investigation-grid {
        grid-template-columns: 1fr;
      }

      .article-banner {
        justify-content: start;
        overflow-x: auto;
        padding-bottom: 4px;
      }

      .article-banner-mobile {
        justify-content: center;
      }

      .article-banner-rectangle {
        float: none;
        margin: 24px 0;
      }

      .nearby-stores-list {
        grid-template-columns: 1fr;
      }

      .writer-pickup-section {
        padding: 16px;
      }

      .writer-pickup-list {
        grid-template-columns: 1fr;
      }

      .writer-pickup-list li {
        min-height: 120px;
      }

      .writer-pickup-list a {
        gap: 7px;
        min-height: 120px;
        padding: 14px;
        overflow: hidden;
      }

      .writer-pickup-list a::before {
        inset: 8px 8px auto 8px;
        height: min(90px, calc(100% - 16px));
      }

      .writer-pickup-list small {
        font-size: 0.68rem;
        line-height: 1.2;
      }

      .writer-pickup-list strong {
        font-size: 1rem;
        line-height: 1.35;
      }

      .writer-pickup-list span {
        display: -webkit-box;
        font-size: 0.84rem;
        line-height: 1.45;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
      }

      .signals-panel {
        grid-template-columns: 1fr;
      }

      .footer-browse-grid {
        grid-template-columns: 1fr;
      }
    }

    @media (max-width: 420px) {
      article {
        width: min(1120px, calc(100% - 8px));
        padding: 16px 10px 22px;
      }
    }
