/*! tailwindcss v4.1.14 | MIT License | https://tailwindcss.com */
/*!
Theme Name: nihonkogei
Theme URI: https://nihonkogei.com
Description: A theme for nihonkogei
Version: 0.1.0
Author: Yami
Author URI: https://kensakuai.com
Text Domain: nhkg
Requires at least: 6.8
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: LICENSE

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.

nihonkogei is based on _tw https://underscoretw.com/, (C) 2021-2025 Greg Sullivan
_tw is distributed under the terms of the GNU GPL v2 or later.

_tw is based on Underscores https://underscores.me/ and Varia https://github.com/Automattic/themes/tree/master/varia, (C) 2012-2025 Automattic, Inc.
Underscores and Varia are distributed under the terms of the GNU GPL v2 or later.
*/
@layer properties;
:root, :host {
  --font-sans: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
  --font-serif: "Shippori Mincho", "Hiragino Mincho ProN", serif;
  --font-mono: "JetBrains Mono", ui-monospace, monospace;
  --color-neutral-100: oklch(97% 0 0);
  --color-neutral-200: oklch(92.2% 0 0);
  --color-neutral-300: oklch(87% 0 0);
  --color-neutral-400: oklch(70.8% 0 0);
  --color-neutral-500: oklch(55.6% 0 0);
  --color-neutral-600: oklch(43.9% 0 0);
  --color-neutral-700: oklch(37.1% 0 0);
  --color-neutral-800: oklch(26.9% 0 0);
  --color-neutral-900: oklch(20.5% 0 0);
  --color-white: #fff;
  --spacing: 0.25rem;
  --text-3xl: 1.875rem;
  --text-3xl--line-height: calc(2.25 / 1.875);
  --font-weight-extrabold: 800;
  --default-transition-duration: 150ms;
  --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  --default-font-family: var(--font-sans);
  --default-mono-font-family: var(--font-mono);
  --color-background: var(--wp--preset--color--background);
  --color-foreground: var(--wp--preset--color--foreground);
  --color-primary: var(--wp--preset--color--primary);
  --color-sumi: #1a1a1a;
  --color-sumi-light: #2d2d2d;
  --color-shiro: #f7f5f0;
  --color-bengara: #8b2500;
  --color-ai: #264348;
  --color-ai-light: #3a5f66;
  --color-kincha: #c4a35a;
  --color-ishi: #6b6b6b;
  --color-ishi-light: #8c8c8c;
  --color-kinari: #ebe6dc;
  --color-washi: #f5f2eb;
  --container-content: var(--wp--style--global--content-size);
  --container-wide: var(--wp--style--global--wide-size);
  --font-display: "Shippori Mincho", "Hiragino Mincho ProN", "Yu Mincho", serif;
  --tw-prose-font-normal: 400;
  --tw-prose-font-medium: 500;
  --tw-prose-font-semibold: 600;
  --tw-prose-font-bold: 700;
  --tw-prose-font-extrabold: 800;
  --tw-prose-font-black: 900;
}
@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@300;400;500;700&display=swap');
*, ::after, ::before, ::backdrop, ::file-selector-button {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  border: 0 solid;
}
html, :host {
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  tab-size: 4;
  font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol', 'Noto Color Emoji');
  font-feature-settings: var(--default-font-feature-settings, normal);
  font-variation-settings: var(--default-font-variation-settings, normal);
  -webkit-tap-highlight-color: transparent;
}
hr {
  height: 0;
  color: inherit;
  border-top-width: 1px;
}
abbr:where([title]) {
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted;
}
h1, h2, h3, h4, h5, h6 {
  font-size: inherit;
  font-weight: inherit;
}
a {
  color: inherit;
  -webkit-text-decoration: inherit;
  text-decoration: inherit;
}
b, strong {
  font-weight: bolder;
}
code, kbd, samp, pre {
  font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace);
  font-feature-settings: var(--default-mono-font-feature-settings, normal);
  font-variation-settings: var(--default-mono-font-variation-settings, normal);
  font-size: 1em;
}
small {
  font-size: 80%;
}
sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sub {
  bottom: -0.25em;
}
sup {
  top: -0.5em;
}
table {
  text-indent: 0;
  border-color: inherit;
  border-collapse: collapse;
}
:-moz-focusring {
  outline: auto;
}
progress {
  vertical-align: baseline;
}
summary {
  display: list-item;
}
ol, ul, menu {
  list-style: none;
}
img, svg, video, canvas, audio, iframe, embed, object {
  display: block;
  vertical-align: middle;
}
img, video {
  max-width: 100%;
  height: auto;
}
button, input, select, optgroup, textarea, ::file-selector-button {
  font: inherit;
  font-feature-settings: inherit;
  font-variation-settings: inherit;
  letter-spacing: inherit;
  color: inherit;
  border-radius: 0;
  background-color: transparent;
  opacity: 1;
}
:where(select:is([multiple], [size])) optgroup {
  font-weight: bolder;
}
:where(select:is([multiple], [size])) optgroup option {
  padding-inline-start: 20px;
}
::file-selector-button {
  margin-inline-end: 4px;
}
::placeholder {
  opacity: 1;
}
@supports (not (-webkit-appearance: -apple-pay-button))  or (contain-intrinsic-size: 1px) {
  ::placeholder {
    color: currentcolor;
  }
  @supports (color: color-mix(in lab, red, red)) {
    ::placeholder {
      color: color-mix(in oklab, currentcolor 50%, transparent);
    }
  }
}
textarea {
  resize: vertical;
}
::-webkit-search-decoration {
  -webkit-appearance: none;
}
::-webkit-date-and-time-value {
  min-height: 1lh;
  text-align: inherit;
}
::-webkit-datetime-edit {
  display: inline-flex;
}
::-webkit-datetime-edit-fields-wrapper {
  padding: 0;
}
::-webkit-datetime-edit, ::-webkit-datetime-edit-year-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-minute-field, ::-webkit-datetime-edit-second-field, ::-webkit-datetime-edit-millisecond-field, ::-webkit-datetime-edit-meridiem-field {
  padding-block: 0;
}
::-webkit-calendar-picker-indicator {
  line-height: 1;
}
:-moz-ui-invalid {
  box-shadow: none;
}
button, input:where([type='button'], [type='reset'], [type='submit']), ::file-selector-button {
  appearance: button;
}
::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
  height: auto;
}
[hidden]:where(:not([hidden='until-found'])) {
  display: none !important;
}
body {
  background-color: var(--color-background);
  font-family: var(--font-sans);
  color: var(--color-foreground);
}
.nhkg-about-page {
  background: var(--color-shiro);
}
.nhkg-about-hero {
  position: relative;
  padding: 8rem 2rem 4rem;
  background: var(--color-kinari);
  overflow: hidden;
}
@media (min-width: 768px) {
  .nhkg-about-hero {
    padding: 10rem 2rem 5rem;
  }
}
.admin-bar .nhkg-about-hero {
  padding-top: calc(8rem + 32px);
}
@media (min-width: 768px) {
  .admin-bar .nhkg-about-hero {
    padding-top: calc(10rem + 32px);
  }
}
@media (max-width: 782px) {
  .admin-bar .nhkg-about-hero {
    padding-top: calc(8rem + 46px);
  }
}
.nhkg-about-hero__bg {
  position: absolute;
  inset: 0;
  color: var(--color-ishi);
  opacity: 0.05;
  pointer-events: none;
}
.nhkg-about-hero__bg svg {
  width: 100%;
  height: 100%;
}
.nhkg-about-hero__container {
  position: relative;
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-about-hero__content {
  max-width: 40rem;
}
.nhkg-about-hero__japanese-group {
  margin-bottom: 0.5rem;
}
.nhkg-about-hero__japanese {
  display: block;
  font-family: var(--font-display);
  font-size: 2.5rem;
  color: var(--color-kincha);
  opacity: 0.4;
  line-height: 1;
}
@media (min-width: 768px) {
  .nhkg-about-hero__japanese {
    font-size: 3.5rem;
  }
}
.nhkg-about-hero__romaji {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-ishi);
  opacity: 0.7;
  margin-top: 0.25rem;
}
.nhkg-about-hero__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0 0 1rem;
  line-height: 1.2;
}
.nhkg-about-hero__description {
  font-family: var(--font-sans);
  font-size: 1.125rem;
  line-height: 1.7;
  color: var(--color-ishi);
  margin: 0;
}
.nhkg-about-mission {
  padding: 5rem 2rem;
  background: var(--color-shiro);
}
@media (min-width: 768px) {
  .nhkg-about-mission {
    padding: 6rem 2rem;
  }
}
.nhkg-about-mission__container {
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-about-mission__grid {
  display: grid;
  gap: 3rem;
  align-items: center;
}
@media (min-width: 1024px) {
  .nhkg-about-mission__grid {
    grid-template-columns: 1fr 1fr;
    gap: 5rem;
  }
}
.nhkg-about-mission__heading {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0.5rem 0 1.5rem;
  line-height: 1.2;
}
.nhkg-about-mission__text p {
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.8;
  color: var(--color-ishi);
  margin: 0 0 1.25rem;
}
.nhkg-about-mission__text p:last-child {
  margin-bottom: 0;
}
.nhkg-about-mission__visual {
  position: relative;
}
.nhkg-about-mission__image {
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
  border-radius: 2px;
}
.nhkg-about-mission__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.nhkg-about-mission__kanji {
  position: absolute;
  top: -1rem;
  right: -1rem;
  font-family: var(--font-display);
  font-size: 6rem;
  color: var(--color-kinari);
  opacity: 0.5;
  line-height: 1;
  pointer-events: none;
}
@media (min-width: 768px) {
  .nhkg-about-mission__kanji {
    font-size: 8rem;
    top: -2rem;
    right: -2rem;
  }
}
.nhkg-about-values {
  padding: 5rem 2rem;
  background: var(--color-kinari);
}
@media (min-width: 768px) {
  .nhkg-about-values {
    padding: 6rem 2rem;
  }
}
.nhkg-about-values__container {
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-about-values__header {
  text-align: center;
  margin-bottom: 3rem;
}
.nhkg-about-values__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0.5rem 0 0;
  line-height: 1.2;
}
.nhkg-about-values__grid {
  display: grid;
  gap: 2rem;
}
@media (min-width: 768px) {
  .nhkg-about-values__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 2.5rem;
  }
}
.nhkg-about-value {
  background: var(--color-shiro);
  padding: 2rem;
  border-radius: 2px;
  text-align: center;
}
.nhkg-about-value__icon {
  color: var(--color-kincha);
  margin-bottom: 1.5rem;
}
.nhkg-about-value__icon svg {
  width: 48px;
  height: 48px;
  margin: 0 auto;
}
.nhkg-about-value__title {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0 0 0.75rem;
}
.nhkg-about-value__description {
  font-family: var(--font-sans);
  font-size: 0.9375rem;
  line-height: 1.7;
  color: var(--color-ishi);
  margin: 0;
}
.nhkg-about-kogei {
  padding: 5rem 2rem;
  background: var(--color-shiro);
}
@media (min-width: 768px) {
  .nhkg-about-kogei {
    padding: 6rem 2rem;
  }
}
.nhkg-about-kogei__container {
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-about-kogei__grid {
  display: grid;
  gap: 3rem;
  align-items: center;
}
@media (min-width: 1024px) {
  .nhkg-about-kogei__grid {
    grid-template-columns: 1fr 1fr;
    gap: 5rem;
  }
}
.nhkg-about-kogei__images {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.nhkg-about-kogei__image {
  position: relative;
  overflow: hidden;
  border-radius: 2px;
}
.nhkg-about-kogei__image--1 {
  aspect-ratio: 3/4;
}
.nhkg-about-kogei__image--2 {
  aspect-ratio: 3/4;
  margin-top: 2rem;
}
.nhkg-about-kogei__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.nhkg-about-kogei__heading {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0.5rem 0 1.5rem;
  line-height: 1.2;
}
.nhkg-about-kogei__text p {
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.8;
  color: var(--color-ishi);
  margin: 0 0 1.25rem;
}
.nhkg-about-kogei__stats {
  display: flex;
  gap: 3rem;
  margin-top: 2rem;
  padding-top: 2rem;
  border-top: 1px solid var(--color-kinari);
}
.nhkg-about-cta {
  padding: 5rem 2rem;
  background: var(--color-sumi);
}
@media (min-width: 768px) {
  .nhkg-about-cta {
    padding: 6rem 2rem;
  }
}
.nhkg-about-cta__container {
  max-width: 48rem;
  margin: 0 auto;
  text-align: center;
}
.nhkg-about-cta__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 500;
  color: var(--color-shiro);
  margin: 0 0 1rem;
  line-height: 1.2;
}
.nhkg-about-cta__description {
  font-family: var(--font-sans);
  font-size: 1.125rem;
  line-height: 1.7;
  color: var(--color-ishi-light);
  margin: 0 0 2rem;
}
.nhkg-about-cta__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
}
.nhkg-about-cta .nhkg-btn--primary {
  background: var(--color-shiro);
  color: var(--color-sumi);
}
.nhkg-about-cta .nhkg-btn--primary:hover {
  background: var(--color-kinari);
}
.nhkg-about-cta .nhkg-btn--secondary {
  color: var(--color-shiro);
  border-color: var(--color-ishi);
}
.nhkg-about-cta .nhkg-btn--secondary:hover {
  border-color: var(--color-shiro);
  background: rgba(255, 255, 255, 0.1);
}
.nhkg-artists-page {
  --artists-gap: 2rem;
}
@media (min-width: 768px) {
  .nhkg-artists-page {
    --artists-gap: 2.5rem;
  }
}
.nhkg-artists-hero {
  position: relative;
  padding: 6rem 1.5rem 4rem;
  background: var(--color-kinari);
  overflow: hidden;
}
.nhkg-artists-hero__bg {
  position: absolute;
  inset: 0;
  color: var(--color-sumi);
  opacity: 0.1;
}
.nhkg-artists-hero__bg svg {
  width: 100%;
  height: 100%;
}
.nhkg-artists-hero__container {
  position: relative;
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-artists-hero__content {
  text-align: center;
}
.nhkg-artists-hero__japanese-group {
  margin-bottom: 1rem;
}
.nhkg-artists-hero__japanese {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.5rem);
  color: var(--color-sumi);
  line-height: 1.2;
}
.nhkg-artists-hero__romaji {
  display: block;
  font-size: 0.875rem;
  color: var(--color-ishi);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-top: 0.25rem;
}
.nhkg-artists-hero__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0.5rem 0 1rem;
}
.nhkg-artists-hero__description {
  max-width: 40rem;
  margin: 0 auto;
  color: var(--color-ishi);
  font-size: 1.125rem;
  line-height: 1.6;
}
.nhkg-artists-filters {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--color-shiro);
  border-bottom: 1px solid color-mix(in srgb, #6b6b6b 20%, transparent);
}
@supports (color: color-mix(in lab, red, red)) {
  .nhkg-artists-filters {
    border-bottom: 1px solid color-mix(in srgb, var(--color-ishi) 20%, transparent);
  }
}
.nhkg-artists-filters {
  padding: 1rem 0;
}
.nhkg-artists-filters__container {
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
@media (min-width: 768px) {
  .nhkg-artists-filters__container {
    flex-direction: row;
    align-items: center;
    flex-wrap: wrap;
    gap: 1.5rem;
  }
}
.nhkg-artists-filters__group {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.nhkg-artists-filters__label {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-sumi);
  white-space: nowrap;
}
.nhkg-artists-filters__pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.nhkg-filter-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.375rem 0.875rem;
  font-size: 0.8125rem;
  color: var(--color-sumi);
  background: transparent;
  border: 1px solid var(--color-ishi);
  border-radius: 9999px;
  text-decoration: none;
  transition: all 0.2s var(--nhkg-easing, ease);
  cursor: pointer;
}
.nhkg-filter-pill:hover {
  background: color-mix(in srgb, #1a1a1a 5%, transparent);
}
@supports (color: color-mix(in lab, red, red)) {
  .nhkg-filter-pill:hover {
    background: color-mix(in srgb, var(--color-sumi) 5%, transparent);
  }
}
.nhkg-filter-pill:hover {
  border-color: var(--color-sumi);
}
.nhkg-filter-pill--active, .nhkg-filter-pill--region-active {
  background: var(--color-sumi);
  color: var(--color-shiro);
  border-color: var(--color-sumi);
}
.nhkg-filter-pill__japanese {
  display: none;
}
@media (min-width: 1024px) {
  .nhkg-filter-pill__japanese {
    display: inline;
    font-size: 0.75rem;
    opacity: 0.7;
  }
}
.nhkg-artists-filters__results {
  margin-left: auto;
}
.nhkg-artists-count {
  font-size: 0.875rem;
  color: var(--color-ishi);
}
.nhkg-artists-grid-section {
  padding: 3rem 1.5rem;
  background: var(--color-shiro);
}
.nhkg-artists-grid-section__container {
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-artists-grid {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: var(--artists-gap);
}
@media (min-width: 640px) {
  .nhkg-artists-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .nhkg-artists-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 1280px) {
  .nhkg-artists-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}
.nhkg-artist-card {
  position: relative;
  background: var(--color-shiro);
  border-radius: 0.5rem;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s var(--nhkg-easing, ease), box-shadow 0.3s var(--nhkg-easing, ease);
}
.nhkg-artist-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}
.nhkg-artist-card[data-hidden="true"] {
  display: none;
}
.nhkg-artist-card__link {
  display: block;
  text-decoration: none;
  color: inherit;
}
.nhkg-artist-card__image {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--color-kinari);
  overflow: hidden;
}
.nhkg-artist-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s var(--nhkg-easing, ease);
}
.nhkg-artist-card:hover .nhkg-artist-card__img {
  transform: scale(1.05);
}
.nhkg-artist-card__placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-ishi);
}
.nhkg-artist-card__placeholder svg {
  width: 3rem;
  height: 3rem;
}
.nhkg-artist-card__craft-badge {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  padding: 0.25rem 0.625rem;
  font-size: 0.6875rem;
  font-weight: 500;
  color: var(--color-shiro);
  background: var(--color-bengara);
  border-radius: 9999px;
}
.nhkg-artist-card__content {
  padding: 1rem;
}
.nhkg-artist-card__japanese {
  display: block;
  font-family: var(--font-display);
  font-size: 1.25rem;
  color: var(--color-sumi);
  margin-bottom: 0.25rem;
}
.nhkg-artist-card__name {
  font-size: 1rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0;
}
.nhkg-artist-card__romaji {
  display: block;
  font-size: 0.8125rem;
  color: var(--color-ishi);
  margin-top: 0.125rem;
}
.nhkg-artist-card__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.375rem;
  margin-top: 0.75rem;
}
.nhkg-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.1875rem 0.5rem;
  font-size: 0.6875rem;
  font-weight: 500;
  border-radius: 9999px;
}
.nhkg-badge--craft {
  background: var(--color-bengara);
  color: var(--color-shiro);
}
.nhkg-badge--region {
  background: var(--color-kincha);
  color: var(--color-shiro);
}
.nhkg-badge--status {
  background: color-mix(in srgb, #6b6b6b 20%, transparent);
}
@supports (color: color-mix(in lab, red, red)) {
  .nhkg-badge--status {
    background: color-mix(in srgb, var(--color-ishi) 20%, transparent);
  }
}
.nhkg-badge--status {
  color: var(--color-sumi);
}
.nhkg-badge--large {
  padding: 0.375rem 0.75rem;
  font-size: 0.8125rem;
}
.nhkg-badge--large .nhkg-badge__japanese {
  font-family: var(--font-display);
  font-size: 0.9375rem;
}
.nhkg-badge__japanese {
  display: none;
}
@media (min-width: 768px) {
  .nhkg-badge--large .nhkg-badge__japanese {
    display: inline;
  }
}
.nhkg-artists-empty {
  text-align: center;
  padding: 4rem 2rem;
}
.nhkg-artists-empty__icon {
  color: var(--color-ishi);
  margin-bottom: 1.5rem;
}
.nhkg-artists-empty__icon svg {
  width: 4rem;
  height: 4rem;
}
.nhkg-artists-empty h2 {
  font-size: 1.5rem;
  color: var(--color-sumi);
  margin-bottom: 0.5rem;
}
.nhkg-artists-empty p {
  color: var(--color-ishi);
  margin-bottom: 1.5rem;
}
.nhkg-artist-single {
  background: var(--color-shiro);
}
.nhkg-artist-hero {
  position: relative;
  padding: 6rem 1.5rem 4rem;
  background: var(--color-kinari);
  overflow: hidden;
}
.nhkg-artist-hero__bg {
  position: absolute;
  inset: 0;
  color: var(--color-sumi);
  opacity: 0.08;
}
.nhkg-artist-hero__container {
  position: relative;
  max-width: 64rem;
  margin: 0 auto;
}
.nhkg-artist-hero__main {
  text-align: center;
  margin-top: 2rem;
}
.nhkg-artist-hero__names {
  margin-bottom: 1.5rem;
}
.nhkg-artist-hero__japanese {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 6vw, 4rem);
  color: var(--color-sumi);
  line-height: 1.1;
  margin-bottom: 0.5rem;
}
.nhkg-artist-hero__title {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0;
}
.nhkg-artist-hero__romaji {
  display: block;
  font-size: 1rem;
  color: var(--color-ishi);
  margin-top: 0.25rem;
}
.nhkg-artist-hero__badges {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.75rem;
}
.nhkg-artist-hero__badges a {
  text-decoration: none;
}
.nhkg-artist-hero__image {
  margin-top: 3rem;
  border-radius: 0.5rem;
  overflow: hidden;
}
.nhkg-artist-hero__img {
  width: 100%;
  height: auto;
  display: block;
}
.nhkg-artist-bio {
  padding: 4rem 1.5rem;
  background: var(--color-shiro);
}
.nhkg-artist-bio__container {
  max-width: 48rem;
  margin: 0 auto;
}
.nhkg-artist-bio__header {
  margin-bottom: 2rem;
}
.nhkg-artist-bio__title {
  display: flex;
  align-items: baseline;
  gap: 1rem;
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0;
}
.nhkg-artist-bio__title-jp {
  font-size: 1.25rem;
  color: var(--color-ishi);
}
.nhkg-artist-bio__content {
  line-height: 1.8;
}
.nhkg-artist-works {
  padding: 4rem 1.5rem;
  background: var(--color-kinari);
}
.nhkg-artist-works__container {
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-artist-works__title {
  display: flex;
  align-items: baseline;
  gap: 1rem;
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0 0 2rem;
}
.nhkg-artist-works__title-jp {
  font-size: 1.25rem;
  color: var(--color-ishi);
}
.nhkg-artist-works__grid {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 1.5rem;
}
@media (min-width: 640px) {
  .nhkg-artist-works__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .nhkg-artist-works__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.nhkg-work-card {
  background: var(--color-shiro);
  border-radius: 0.5rem;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}
.nhkg-work-card__image {
  aspect-ratio: 1;
  overflow: hidden;
}
.nhkg-work-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.nhkg-work-card__placeholder {
  width: 100%;
  height: 100%;
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-kinari);
  color: var(--color-ishi);
}
.nhkg-work-card__placeholder svg {
  width: 3rem;
  height: 3rem;
}
.nhkg-work-card__content {
  padding: 1rem;
}
.nhkg-work-card__title {
  font-size: 1rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0 0 0.25rem;
}
.nhkg-work-card__exhibition {
  font-size: 0.8125rem;
  color: var(--color-ishi);
}
.nhkg-related-artists {
  padding: 4rem 1.5rem;
  background: var(--color-shiro);
  border-top: 1px solid color-mix(in srgb, #6b6b6b 20%, transparent);
}
@supports (color: color-mix(in lab, red, red)) {
  .nhkg-related-artists {
    border-top: 1px solid color-mix(in srgb, var(--color-ishi) 20%, transparent);
  }
}
.nhkg-related-artists__container {
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-related-artists__title {
  display: flex;
  align-items: baseline;
  gap: 1rem;
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0 0 2rem;
}
.nhkg-related-artists__title-jp {
  font-size: 1.25rem;
  color: var(--color-ishi);
}
.nhkg-related-artists__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}
@media (min-width: 640px) {
  .nhkg-related-artists__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
  }
}
@media (min-width: 1024px) {
  .nhkg-related-artists__grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
  }
}
@media (min-width: 1280px) {
  .nhkg-related-artists__grid {
    grid-template-columns: repeat(6, 1fr);
  }
}
.nhkg-related-artists__cta {
  text-align: center;
  margin-top: 2rem;
}
.nhkg-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  font-size: 0.9375rem;
  font-weight: 500;
  text-decoration: none;
  border-radius: 0.375rem;
  transition: all 0.2s var(--nhkg-easing, ease);
  cursor: pointer;
}
.nhkg-btn--primary {
  background: var(--color-sumi);
  color: var(--color-shiro);
  border: 1px solid var(--color-sumi);
}
.nhkg-btn--primary:hover {
  background: transparent;
  color: var(--color-sumi);
}
.nhkg-btn--outline {
  background: transparent;
  color: var(--color-sumi);
  border: 1px solid var(--color-sumi);
}
.nhkg-btn--outline:hover {
  background: var(--color-sumi);
  color: var(--color-shiro);
}
.nhkg-craft-gallery {
  padding: 4rem 0;
  background: var(--color-kinari);
}
.nhkg-craft-gallery__container {
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.5rem;
}
.nhkg-craft-gallery__header {
  text-align: center;
  margin-bottom: 2.5rem;
}
.nhkg-craft-gallery__title {
  font-size: 1.75rem;
  font-weight: 600;
  color: var(--color-sumi);
  margin-bottom: 0.75rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
}
.nhkg-craft-gallery__title-jp {
  font-size: 0.875rem;
  font-weight: 400;
  color: var(--color-ishi);
  letter-spacing: 0.1em;
}
.nhkg-craft-gallery__desc {
  color: var(--color-ishi);
  max-width: 40rem;
  margin: 0 auto;
}
.nhkg-craft-gallery__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
}
@media (min-width: 768px) {
  .nhkg-craft-gallery__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
  }
}
@media (min-width: 1024px) {
  .nhkg-craft-gallery__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.nhkg-craft-gallery__item {
  margin: 0;
  border-radius: 0.5rem;
  overflow: hidden;
  box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  animation: nhkg-gallery-fade-in 0.6s ease forwards;
  animation-delay: var(--delay, 0s);
  opacity: 0;
}
@keyframes nhkg-gallery-fade-in {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.nhkg-craft-gallery__item:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 25px -5px rgb(0 0 0 / 0.15);
}
.nhkg-craft-gallery__img {
  width: 100%;
  height: auto;
  aspect-ratio: 1;
  object-fit: cover;
  display: block;
}
.nhkg-artist-card__img--craft {
  filter: brightness(0.95);
  transition: filter 0.3s ease;
}
.nhkg-artist-card:hover .nhkg-artist-card__img--craft {
  filter: brightness(1);
}
.nhkg-artist-hero__img--craft {
  filter: brightness(0.9);
  object-fit: cover;
}
.nhkg-artist-card__img--placeholder, .nhkg-artist-hero__img--placeholder {
  object-fit: cover;
  object-position: center top;
}
.nhkg-artist-card__img--placeholder {
  filter: saturate(0.9);
  transition: filter 0.3s ease;
}
.nhkg-artist-card:hover .nhkg-artist-card__img--placeholder {
  filter: saturate(1);
}
.nhkg-artist-hero__img--placeholder {
  max-height: 400px;
  object-fit: contain;
}
.nhkg-region-archive {
  --artists-gap: 2rem;
}
@media (min-width: 768px) {
  .nhkg-region-archive {
    --artists-gap: 2.5rem;
  }
}
.nhkg-region-hero {
  position: relative;
  padding: 6rem 1.5rem 4rem;
  background: var(--color-kinari);
  overflow: hidden;
}
.nhkg-region-hero__bg {
  position: absolute;
  inset: 0;
  color: var(--color-sumi);
  opacity: 0.08;
}
.nhkg-region-hero__bg svg {
  width: 100%;
  height: 100%;
}
.nhkg-region-hero__container {
  position: relative;
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-region-hero__main {
  display: grid;
  gap: 3rem;
  align-items: center;
}
@media (min-width: 768px) {
  .nhkg-region-hero__main {
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
  }
}
.nhkg-region-hero__info {
  order: 2;
}
@media (min-width: 768px) {
  .nhkg-region-hero__info {
    order: 1;
  }
}
.nhkg-region-hero__japanese-group {
  margin-bottom: 1rem;
}
.nhkg-region-hero__japanese {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 6vw, 4rem);
  color: var(--color-sumi);
  line-height: 1.1;
  letter-spacing: 0.05em;
}
.nhkg-region-hero__romaji {
  display: block;
  font-size: 0.875rem;
  color: var(--color-ishi);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-top: 0.25rem;
}
.nhkg-region-hero__title {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 600;
  color: var(--color-sumi);
  margin-bottom: 1rem;
}
.nhkg-region-hero__description {
  color: var(--color-ishi);
  line-height: 1.7;
  margin-bottom: 1.5rem;
}
.nhkg-region-hero__stats {
  display: flex;
  gap: 1rem;
}
.nhkg-region-hero__count {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  background: var(--color-shiro);
  border-radius: 2rem;
  font-size: 0.875rem;
  color: var(--color-sumi);
  box-shadow: 0 1px 3px rgb(0 0 0 / 0.1);
}
.nhkg-japan-map {
  position: relative;
  order: 1;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: center;
}
@media (min-width: 768px) {
  .nhkg-japan-map {
    order: 2;
  }
}
.nhkg-japan-map__svg {
  width: 100%;
  max-width: 350px;
  height: auto;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .nhkg-japan-map__svg {
    max-width: 420px;
  }
}
@media (min-width: 1024px) {
  .nhkg-japan-map__svg {
    max-width: 500px;
  }
}
@media (min-width: 1280px) {
  .nhkg-japan-map__svg {
    max-width: 550px;
  }
}
.nhkg-pref-link {
  cursor: pointer;
  outline: none;
}
.nhkg-pref-link:focus .nhkg-pref {
  stroke: var(--color-sumi);
  stroke-width: 2;
}
.nhkg-pref {
  fill: #d4c9ba;
  stroke: var(--color-shiro);
  stroke-width: 1;
  transition: fill 0.25s ease, transform 0.2s ease;
}
.nhkg-pref:hover {
  fill: #a89888;
}
.nhkg-pref--active {
  fill: var(--color-aka, #8b4513) !important;
}
.nhkg-pref-link:hover .nhkg-pref--active {
  fill: var(--color-aka, #8b4513) !important;
}
@supports (color: color-mix(in lab, red, red)) {
  .nhkg-pref-link:hover .nhkg-pref--active {
    fill: color-mix(in srgb, var(--color-aka, #8b4513) 85%, black) !important;
  }
}
.nhkg-japan-map__labels {
  display: flex;
  flex-wrap: wrap;
  gap: 0.375rem;
  justify-content: center;
  margin-top: 0.5rem;
}
.nhkg-japan-map__label {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.625rem;
  font-size: 0.6875rem;
  color: var(--color-ishi);
  text-decoration: none;
  border-radius: 1rem;
  background: var(--color-shiro);
  border: 1px solid color-mix(in srgb, #6b6b6b 30%, transparent);
}
@supports (color: color-mix(in lab, red, red)) {
  .nhkg-japan-map__label {
    border: 1px solid color-mix(in srgb, var(--color-ishi) 30%, transparent);
  }
}
.nhkg-japan-map__label {
  transition: all 0.2s ease;
}
.nhkg-japan-map__label:hover {
  background: var(--color-sumi);
  color: var(--color-shiro);
  border-color: var(--color-sumi);
}
.nhkg-japan-map__label--active {
  background: var(--color-sumi);
  color: var(--color-shiro);
  border-color: var(--color-sumi);
}
.nhkg-japan-map__label--active:hover {
  background: var(--color-aka);
  border-color: var(--color-aka);
}
.nhkg-japan-map__label-name {
  font-weight: 500;
}
.nhkg-region-grid-header {
  text-align: center;
  margin-bottom: 2.5rem;
}
.nhkg-region-grid-header h2 {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--color-sumi);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
}
.nhkg-region-grid-header__jp {
  font-size: 0.875rem;
  font-weight: 400;
  color: var(--color-ishi);
  letter-spacing: 0.05em;
}
.nhkg-other-regions {
  padding: 4rem 1.5rem;
  background: var(--color-kinari);
}
.nhkg-other-regions__container {
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-other-regions__title {
  text-align: center;
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--color-sumi);
  margin-bottom: 2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
}
.nhkg-other-regions__title-jp {
  font-size: 0.875rem;
  font-weight: 400;
  color: var(--color-ishi);
  letter-spacing: 0.05em;
}
.nhkg-other-regions__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1rem;
}
@media (min-width: 768px) {
  .nhkg-other-regions__grid {
    grid-template-columns: repeat(4, 1fr);
  }
}
.nhkg-region-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1.5rem 1rem;
  background: var(--color-shiro);
  border-radius: 0.5rem;
  text-decoration: none;
  text-align: center;
  transition: all 0.3s ease;
  box-shadow: 0 1px 3px rgb(0 0 0 / 0.05);
  animation: fadeInUp 0.6s ease forwards;
  animation-delay: var(--delay, 0s);
  opacity: 0;
}
.nhkg-region-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 25px rgb(0 0 0 / 0.1);
}
.nhkg-region-card__japanese {
  font-family: var(--font-display);
  font-size: 1.75rem;
  color: var(--color-sumi);
  line-height: 1;
  margin-bottom: 0.5rem;
}
.nhkg-region-card__name {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin-bottom: 0.25rem;
}
.nhkg-region-card__count {
  font-size: 0.75rem;
  color: var(--color-ishi);
}
.nhkg-craft-archive {
  --artists-gap: 2rem;
}
@media (min-width: 768px) {
  .nhkg-craft-archive {
    --artists-gap: 2.5rem;
  }
}
.nhkg-craft-hero {
  position: relative;
  padding: 6rem 1.5rem 4rem;
  background: var(--color-kinari);
  overflow: hidden;
}
.nhkg-craft-hero__bg {
  position: absolute;
  inset: 0;
  color: var(--color-sumi);
  opacity: 0.08;
}
.nhkg-craft-hero__bg svg {
  width: 100%;
  height: 100%;
}
.nhkg-craft-hero__container {
  position: relative;
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-craft-hero__main {
  display: grid;
  gap: 3rem;
  align-items: center;
}
@media (min-width: 768px) {
  .nhkg-craft-hero__main {
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
  }
}
.nhkg-craft-hero__info {
  order: 2;
}
@media (min-width: 768px) {
  .nhkg-craft-hero__info {
    order: 1;
  }
}
.nhkg-craft-hero__japanese-group {
  margin-bottom: 1rem;
}
.nhkg-craft-hero__japanese {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 6vw, 4rem);
  color: var(--color-sumi);
  line-height: 1.1;
  letter-spacing: 0.05em;
}
.nhkg-craft-hero__romaji {
  display: block;
  font-size: 0.875rem;
  color: var(--color-ishi);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-top: 0.25rem;
}
.nhkg-craft-hero__title {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 600;
  color: var(--color-sumi);
  margin-bottom: 1rem;
}
.nhkg-craft-hero__description {
  color: var(--color-ishi);
  line-height: 1.7;
  margin-bottom: 1.5rem;
}
.nhkg-craft-hero__stats {
  display: flex;
  gap: 1rem;
}
.nhkg-craft-hero__count {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  background: var(--color-shiro);
  border-radius: 2rem;
  font-size: 0.875rem;
  color: var(--color-sumi);
  box-shadow: 0 1px 3px rgb(0 0 0 / 0.1);
}
.nhkg-craft-hero__gallery {
  order: 1;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}
@media (min-width: 768px) {
  .nhkg-craft-hero__gallery {
    order: 2;
  }
}
.nhkg-craft-hero__gallery-item {
  margin: 0;
  border-radius: 0.5rem;
  overflow: hidden;
  box-shadow: 0 4px 12px rgb(0 0 0 / 0.1);
  animation: fadeInUp 0.6s ease forwards;
  animation-delay: var(--delay, 0s);
  opacity: 0;
}
.nhkg-craft-hero__gallery-item:first-child {
  transform: rotate(-2deg);
}
.nhkg-craft-hero__gallery-item:last-child {
  transform: rotate(2deg);
  margin-top: 1.5rem;
}
.nhkg-craft-hero__gallery-img {
  width: 100%;
  height: auto;
  aspect-ratio: 1;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}
.nhkg-craft-hero__gallery-item:hover .nhkg-craft-hero__gallery-img {
  transform: scale(1.05);
}
.nhkg-other-crafts {
  padding: 4rem 1.5rem;
  background: var(--color-kinari);
}
.nhkg-other-crafts__container {
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-other-crafts__title {
  text-align: center;
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--color-sumi);
  margin-bottom: 2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
}
.nhkg-other-crafts__title-jp {
  font-size: 0.875rem;
  font-weight: 400;
  color: var(--color-ishi);
  letter-spacing: 0.05em;
}
.nhkg-other-crafts__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1rem;
}
@media (min-width: 768px) {
  .nhkg-other-crafts__grid {
    grid-template-columns: repeat(4, 1fr);
  }
}
.nhkg-craft-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1.5rem 1rem;
  background: var(--color-shiro);
  border-radius: 0.5rem;
  text-decoration: none;
  text-align: center;
  transition: all 0.3s ease;
  box-shadow: 0 1px 3px rgb(0 0 0 / 0.05);
  animation: fadeInUp 0.6s ease forwards;
  animation-delay: var(--delay, 0s);
  opacity: 0;
}
.nhkg-craft-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 25px rgb(0 0 0 / 0.1);
}
.nhkg-craft-card__japanese {
  font-family: var(--font-display);
  font-size: 1.75rem;
  color: var(--color-sumi);
  line-height: 1;
  margin-bottom: 0.5rem;
}
.nhkg-craft-card__name {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin-bottom: 0.25rem;
}
.nhkg-craft-card__count {
  font-size: 0.75rem;
  color: var(--color-ishi);
}
.nhkg-artist-intro {
  padding: 3rem 1.5rem;
  background: var(--color-shiro);
  border-bottom: 1px solid color-mix(in srgb, #6b6b6b 15%, transparent);
}
@supports (color: color-mix(in lab, red, red)) {
  .nhkg-artist-intro {
    border-bottom: 1px solid color-mix(in srgb, var(--color-ishi) 15%, transparent);
  }
}
.nhkg-artist-intro__container {
  max-width: 48rem;
  margin: 0 auto;
}
.nhkg-artist-intro__text {
  font-size: 1.125rem;
  line-height: 1.8;
  color: var(--color-sumi);
  margin: 0;
}
@media (min-width: 768px) {
  .nhkg-artist-intro {
    padding: 4rem 1.5rem;
  }
  .nhkg-artist-intro__text {
    font-size: 1.25rem;
  }
}
.nhkg-artist-craft-about {
  padding: 3rem 1.5rem;
  background: var(--color-kinari);
}
.nhkg-artist-craft-about__container {
  max-width: 48rem;
  margin: 0 auto;
}
.nhkg-artist-craft-about__header {
  margin-bottom: 1.5rem;
}
.nhkg-artist-craft-about__title {
  display: flex;
  align-items: baseline;
  gap: 1rem;
  flex-wrap: wrap;
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0;
}
.nhkg-artist-craft-about__title-jp {
  font-size: 1rem;
  font-weight: 400;
  color: var(--color-ishi);
}
.nhkg-artist-craft-about__content p {
  line-height: 1.8;
  color: var(--color-sumi);
  margin: 0;
}
@media (min-width: 768px) {
  .nhkg-artist-craft-about {
    padding: 4rem 1.5rem;
  }
  .nhkg-artist-craft-about__title {
    font-size: 1.75rem;
  }
}
.nhkg-artist-membership {
  padding: 3rem 1.5rem;
  background: var(--color-shiro);
  border-top: 1px solid color-mix(in srgb, #6b6b6b 15%, transparent);
}
@supports (color: color-mix(in lab, red, red)) {
  .nhkg-artist-membership {
    border-top: 1px solid color-mix(in srgb, var(--color-ishi) 15%, transparent);
  }
}
.nhkg-artist-membership__container {
  max-width: 48rem;
  margin: 0 auto;
}
.nhkg-artist-membership__header {
  margin-bottom: 1.5rem;
}
.nhkg-artist-membership__title {
  display: flex;
  align-items: baseline;
  gap: 1rem;
  flex-wrap: wrap;
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0;
}
.nhkg-artist-membership__title-jp {
  font-size: 1rem;
  font-weight: 400;
  color: var(--color-ishi);
}
.nhkg-artist-membership__content p {
  line-height: 1.8;
  color: var(--color-sumi);
  margin: 0;
}
@media (min-width: 768px) {
  .nhkg-artist-membership {
    padding: 4rem 1.5rem;
  }
  .nhkg-artist-membership__title {
    font-size: 1.75rem;
  }
}
.nhkg-blog-page {
  background: var(--color-shiro);
}
.nhkg-blog-hero {
  position: relative;
  padding: 8rem 2rem 4rem;
  background: var(--color-kinari);
  overflow: hidden;
}
@media (min-width: 768px) {
  .nhkg-blog-hero {
    padding: 10rem 2rem 5rem;
  }
}
.admin-bar .nhkg-blog-hero {
  padding-top: calc(8rem + 32px);
}
@media (min-width: 768px) {
  .admin-bar .nhkg-blog-hero {
    padding-top: calc(10rem + 32px);
  }
}
@media (max-width: 782px) {
  .admin-bar .nhkg-blog-hero {
    padding-top: calc(8rem + 46px);
  }
}
.nhkg-blog-hero__bg {
  position: absolute;
  inset: 0;
  color: var(--color-ishi);
  opacity: 0.08;
  pointer-events: none;
}
.nhkg-blog-hero__bg svg {
  width: 100%;
  height: 100%;
}
.nhkg-blog-hero__container {
  position: relative;
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-blog-hero__content {
  max-width: 40rem;
}
.nhkg-blog-hero__japanese-group {
  margin-bottom: 0.5rem;
}
.nhkg-blog-hero__japanese {
  display: block;
  font-family: var(--font-display);
  font-size: 3rem;
  color: var(--color-kincha);
  opacity: 0.4;
  line-height: 1;
}
@media (min-width: 768px) {
  .nhkg-blog-hero__japanese {
    font-size: 4rem;
  }
}
.nhkg-blog-hero__romaji {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-ishi);
  opacity: 0.7;
  margin-top: 0.25rem;
}
.nhkg-blog-hero__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0 0 1rem;
  line-height: 1.2;
}
.nhkg-blog-hero__description {
  font-family: var(--font-sans);
  font-size: 1.125rem;
  line-height: 1.7;
  color: var(--color-ishi);
  margin-bottom: 1.5rem;
}
.nhkg-blog-hero__meta {
  display: flex;
  gap: 1.5rem;
}
.nhkg-blog-hero__count {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-sumi);
  padding: 0.5rem 1rem;
  background: var(--color-shiro);
  border-radius: 2px;
}
.nhkg-blog-posts {
  padding: 4rem 2rem;
}
@media (min-width: 768px) {
  .nhkg-blog-posts {
    padding: 5rem 2rem;
  }
}
.nhkg-blog-posts__container {
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-blog-posts__filters {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 2.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--color-kinari);
}
.nhkg-blog-posts__filter-label {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--color-ishi);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.nhkg-blog-posts__filter-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.nhkg-blog-filter {
  display: inline-flex;
  align-items: center;
  padding: 0.5rem 1rem;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--color-ishi);
  background: var(--color-washi);
  border: 1px solid var(--color-kinari);
  border-radius: 2px;
  text-decoration: none;
  transition: all 0.3s var(--nhkg-easing);
}
.nhkg-blog-filter:hover {
  color: var(--color-sumi);
  border-color: var(--color-ishi-light);
}
.nhkg-blog-filter--active {
  color: var(--color-shiro);
  background: var(--color-sumi);
  border-color: var(--color-sumi);
}
.nhkg-blog-posts__grid {
  display: grid;
  gap: 2rem;
}
@media (min-width: 640px) {
  .nhkg-blog-posts__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .nhkg-blog-posts__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.nhkg-post-card__category {
  position: absolute;
  top: 1rem;
  left: 1rem;
  padding: 0.375rem 0.75rem;
  font-family: var(--font-sans);
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-shiro);
  background: var(--color-sumi);
  border-radius: 2px;
  z-index: 1;
}
.nhkg-blog-empty {
  text-align: center;
  padding: 4rem 2rem;
}
.nhkg-blog-empty__icon {
  color: var(--color-kinari);
  margin-bottom: 1.5rem;
}
.nhkg-blog-empty__icon svg {
  width: 80px;
  height: 80px;
  margin: 0 auto;
}
.nhkg-blog-empty h2 {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0 0 0.75rem;
}
.nhkg-blog-empty p {
  font-family: var(--font-sans);
  font-size: 1rem;
  color: var(--color-ishi);
  margin: 0 0 2rem;
}
.nhkg-category-page {
  background: var(--color-shiro);
}
.nhkg-cat-hero {
  position: relative;
  padding: 8rem 2rem 4rem;
  background: var(--color-kinari);
  overflow: hidden;
}
@media (min-width: 768px) {
  .nhkg-cat-hero {
    padding: 10rem 2rem 5rem;
  }
}
.nhkg-cat-hero--has-banner {
  min-height: 50vh;
  background: var(--color-sumi);
}
@media (min-width: 768px) {
  .nhkg-cat-hero--has-banner {
    min-height: 60vh;
  }
}
.nhkg-cat-hero__banner {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.nhkg-cat-hero__banner-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.nhkg-cat-hero__banner-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(	to top,	rgba(26, 26, 26, 0.9) 0%,	rgba(26, 26, 26, 0.6) 40%,	rgba(26, 26, 26, 0.3) 70%,	rgba(26, 26, 26, 0.2) 100%	);
}
.nhkg-cat-hero--has-banner .nhkg-cat-hero__bg {
  opacity: 0.05;
  z-index: 1;
}
.nhkg-cat-hero--has-banner .nhkg-cat-hero__container {
  z-index: 2;
}
.nhkg-cat-hero--has-banner .nhkg-cat-hero__japanese {
  color: var(--color-kincha);
  opacity: 0.6;
}
.nhkg-cat-hero--has-banner .nhkg-cat-hero__romaji {
  color: var(--color-ishi-light);
}
.nhkg-cat-hero--has-banner .nhkg-cat-hero__title {
  color: var(--color-shiro);
}
.nhkg-cat-hero--has-banner .nhkg-cat-hero__description {
  color: var(--color-ishi-light);
}
.nhkg-cat-hero--has-banner .nhkg-cat-hero__count {
  background: rgba(255, 255, 255, 0.1);
  color: var(--color-shiro);
}
.nhkg-cat-hero--has-banner .nhkg-breadcrumb a {
  color: var(--color-ishi-light);
}
.nhkg-cat-hero--has-banner .nhkg-breadcrumb a:hover {
  color: var(--color-shiro);
}
.nhkg-cat-hero--has-banner .nhkg-breadcrumb__sep {
  color: var(--color-ishi);
}
.nhkg-cat-hero--has-banner .nhkg-breadcrumb span[aria-current="page"] {
  color: var(--color-shiro);
}
.nhkg-cat-hero--has-banner .nhkg-cat-hero__decoration {
  color: var(--color-kincha);
  opacity: 0.15;
}
.admin-bar .nhkg-cat-hero {
  padding-top: calc(8rem + 32px);
}
@media (min-width: 768px) {
  .admin-bar .nhkg-cat-hero {
    padding-top: calc(10rem + 32px);
  }
}
@media (max-width: 782px) {
  .admin-bar .nhkg-cat-hero {
    padding-top: calc(8rem + 46px);
  }
}
.nhkg-cat-hero__bg {
  position: absolute;
  inset: 0;
  color: var(--color-ishi);
  opacity: 0.08;
  pointer-events: none;
}
.nhkg-cat-hero__bg svg {
  width: 100%;
  height: 100%;
}
.nhkg-cat-hero__container {
  position: relative;
  display: grid;
  gap: 3rem;
  max-width: 80rem;
  margin: 0 auto;
}
@media (min-width: 1024px) {
  .nhkg-cat-hero__container {
    grid-template-columns: 1fr auto;
    align-items: center;
  }
}
.nhkg-cat-hero__content {
  max-width: 40rem;
}
.nhkg-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  margin-bottom: 1.5rem;
}
.nhkg-breadcrumb a {
  color: var(--color-ishi);
  text-decoration: none;
  transition: color 0.3s var(--nhkg-easing);
}
.nhkg-breadcrumb a:hover {
  color: var(--color-bengara);
}
.nhkg-breadcrumb__sep {
  color: var(--color-ishi-light);
}
.nhkg-breadcrumb span[aria-current="page"] {
  color: var(--color-sumi);
  font-weight: 500;
}
.nhkg-cat-hero__japanese-group {
  margin-bottom: 0.5rem;
}
.nhkg-cat-hero__japanese {
  display: block;
  font-family: var(--font-display);
  font-size: 3rem;
  color: var(--color-kincha);
  opacity: 0.4;
  line-height: 1;
}
@media (min-width: 768px) {
  .nhkg-cat-hero__japanese {
    font-size: 4rem;
  }
}
.nhkg-cat-hero__romaji {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-ishi);
  opacity: 0.7;
  margin-top: 0.25rem;
}
.nhkg-cat-hero__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0 0 1rem;
  line-height: 1.2;
}
.nhkg-cat-hero__description {
  font-family: var(--font-sans);
  font-size: 1.125rem;
  line-height: 1.7;
  color: var(--color-ishi);
  margin-bottom: 1.5rem;
}
.nhkg-cat-hero__description p {
  margin: 0;
}
.nhkg-cat-hero__meta {
  display: flex;
  gap: 1.5rem;
}
.nhkg-cat-hero__count {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-sumi);
  padding: 0.5rem 1rem;
  background: var(--color-shiro);
  border-radius: 2px;
}
.nhkg-cat-hero__decoration {
  display: none;
  width: 150px;
  height: 150px;
  color: var(--color-kincha);
  opacity: 0.2;
}
@media (min-width: 1024px) {
  .nhkg-cat-hero__decoration {
    display: block;
  }
}
.nhkg-cat-posts {
  padding: 4rem 2rem;
}
@media (min-width: 768px) {
  .nhkg-cat-posts {
    padding: 5rem 2rem;
  }
}
.nhkg-cat-posts__container {
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-cat-posts__header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  margin-bottom: 2rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--color-kinari);
}
.nhkg-cat-posts__title {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0;
}
.nhkg-cat-posts__filters {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.nhkg-cat-posts__sort-label {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  color: var(--color-ishi);
}
.nhkg-cat-posts__sort {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  color: var(--color-sumi);
  padding: 0.375rem 0.75rem;
  background: var(--color-washi);
  border: 1px solid var(--color-kinari);
  border-radius: 2px;
  cursor: pointer;
  transition: border-color 0.3s var(--nhkg-easing);
}
.nhkg-cat-posts__sort:hover, .nhkg-cat-posts__sort:focus {
  border-color: var(--color-ishi-light);
  outline: none;
}
.nhkg-cat-posts__grid {
  display: grid;
  gap: 2rem;
}
@media (min-width: 640px) {
  .nhkg-cat-posts__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .nhkg-cat-posts__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.nhkg-post-card {
  background: var(--color-washi);
  border-radius: 2px;
  overflow: hidden;
  transition: transform 0.4s var(--nhkg-easing), box-shadow 0.4s var(--nhkg-easing);
}
.nhkg-post-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(26, 26, 26, 0.1);
}
.nhkg-post-card__link {
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
  color: inherit;
}
.nhkg-post-card__image {
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--color-kinari);
}
.nhkg-post-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--nhkg-easing);
}
.nhkg-post-card:hover .nhkg-post-card__img {
  transform: scale(1.05);
}
.nhkg-post-card__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: var(--color-ishi-light);
}
.nhkg-post-card__placeholder svg {
  width: 48px;
  height: 48px;
}
.nhkg-post-card__content {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 1.5rem;
}
.nhkg-post-card__meta {
  display: flex;
  gap: 1rem;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  color: var(--color-ishi);
  margin-bottom: 0.75rem;
}
.nhkg-post-card__title {
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 1.4;
  color: var(--color-sumi);
  margin: 0 0 0.75rem;
  transition: color 0.3s var(--nhkg-easing);
}
.nhkg-post-card:hover .nhkg-post-card__title {
  color: var(--color-bengara);
}
.nhkg-post-card__excerpt {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--color-ishi);
  margin: 0 0 1rem;
  flex: 1;
}
.nhkg-post-card__read-more {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-sumi);
  transition: color 0.3s var(--nhkg-easing);
  margin-top: auto;
}
.nhkg-post-card:hover .nhkg-post-card__read-more {
  color: var(--color-bengara);
}
.nhkg-post-card__read-more svg {
  width: 1rem;
  height: 1rem;
  transition: transform 0.3s var(--nhkg-easing);
}
.nhkg-post-card:hover .nhkg-post-card__read-more svg {
  transform: translateX(4px);
}
.nhkg-pagination {
  margin-top: 4rem;
  display: flex;
  justify-content: center;
}
.nhkg-pagination .nav-links {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.nhkg-pagination .nav-links > a, .nhkg-pagination .nav-links > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.5rem;
  height: 2.5rem;
  padding: 0 0.75rem;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--color-sumi);
  background: var(--color-washi);
  border: 1px solid var(--color-kinari);
  text-decoration: none;
  transition: all 0.3s var(--nhkg-easing);
}
.nhkg-pagination .nav-links > a:hover {
  background: var(--color-kinari);
  border-color: var(--color-ishi-light);
}
.nhkg-pagination .current {
  background: var(--color-sumi);
  border-color: var(--color-sumi);
  color: var(--color-shiro);
}
.nhkg-pagination .prev, .nhkg-pagination .next {
  gap: 0.5rem;
}
.nhkg-pagination .prev svg, .nhkg-pagination .next svg {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
}
.nhkg-cat-empty {
  text-align: center;
  padding: 4rem 2rem;
}
.nhkg-cat-empty__icon {
  color: var(--color-kinari);
  margin-bottom: 1.5rem;
}
.nhkg-cat-empty__icon svg {
  width: 80px;
  height: 80px;
}
.nhkg-cat-empty h2 {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0 0 0.75rem;
}
.nhkg-cat-empty p {
  font-family: var(--font-sans);
  font-size: 1rem;
  color: var(--color-ishi);
  margin: 0 0 2rem;
}
.nhkg-related-cats {
  padding: 4rem 2rem;
  background: var(--color-sumi);
}
@media (min-width: 768px) {
  .nhkg-related-cats {
    padding: 5rem 2rem;
  }
}
.nhkg-related-cats__container {
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-related-cats__title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--color-shiro);
  margin: 0 0 2rem;
  text-align: center;
}
.nhkg-related-cats__grid {
  display: grid;
  gap: 1rem;
}
@media (min-width: 640px) {
  .nhkg-related-cats__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .nhkg-related-cats__grid {
    grid-template-columns: repeat(4, 1fr);
  }
}
.nhkg-related-cat {
  display: flex;
  flex-direction: column;
  padding: 1.5rem;
  background: var(--color-sumi-light);
  text-decoration: none;
  transition: background 0.3s var(--nhkg-easing);
  position: relative;
}
.nhkg-related-cat:hover {
  background: #3a3a3a;
}
.nhkg-related-cat__japanese-group {
  margin-bottom: 0.5rem;
}
.nhkg-related-cat__japanese {
  display: block;
  font-family: var(--font-display);
  font-size: 2rem;
  color: var(--color-kincha);
  opacity: 0.4;
  line-height: 1;
  transition: opacity 0.3s var(--nhkg-easing);
}
.nhkg-related-cat__romaji {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-ishi-light);
  opacity: 0.5;
  margin-top: 0.125rem;
  transition: opacity 0.3s var(--nhkg-easing);
}
.nhkg-related-cat:hover .nhkg-related-cat__japanese {
  opacity: 0.6;
}
.nhkg-related-cat:hover .nhkg-related-cat__romaji {
  opacity: 0.7;
}
.nhkg-related-cat__name {
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: 500;
  color: var(--color-shiro);
  margin-bottom: 0.25rem;
}
.nhkg-related-cat__count {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  color: var(--color-ishi-light);
}
.nhkg-related-cat__arrow {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  width: 1rem;
  height: 1rem;
  color: var(--color-ishi-light);
  opacity: 0;
  transform: translateX(-4px);
  transition: all 0.3s var(--nhkg-easing);
}
.nhkg-related-cat:hover .nhkg-related-cat__arrow {
  opacity: 1;
  transform: translateX(0);
}
.nhkg-cat-content {
  padding: 4rem 2rem;
  background: var(--color-kinari);
}
@media (min-width: 768px) {
  .nhkg-cat-content {
    padding: 5rem 2rem;
  }
}
.nhkg-cat-content__container {
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-cat-content__inner {
  max-width: 48rem;
  margin: 0 auto;
}
.nhkg-cat-content__header {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 1rem;
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--color-ishi-light);
}
.nhkg-cat-content__title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0;
}
@media (min-width: 768px) {
  .nhkg-cat-content__title {
    font-size: 1.75rem;
  }
}
.nhkg-cat-content__japanese {
  font-family: var(--font-display);
  font-size: 1.5rem;
  color: var(--color-kincha);
  opacity: 0.5;
}
@media (min-width: 768px) {
  .nhkg-cat-content__japanese {
    font-size: 1.75rem;
  }
}
.nhkg-cat-content__body {
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.8;
  color: var(--color-sumi);
}
.nhkg-cat-content__body h2, .nhkg-cat-content__body h3, .nhkg-cat-content__body h4 {
  font-family: var(--font-display);
  font-weight: 500;
  color: var(--color-sumi);
  margin-top: 2rem;
  margin-bottom: 1rem;
}
.nhkg-cat-content__body h2 {
  font-size: 1.375rem;
}
.nhkg-cat-content__body h3 {
  font-size: 1.125rem;
}
.nhkg-cat-content__body p {
  margin-bottom: 1.25rem;
}
.nhkg-cat-content__body p:last-child {
  margin-bottom: 0;
}
.nhkg-cat-content__body ul, .nhkg-cat-content__body ol {
  margin-bottom: 1.25rem;
  padding-left: 1.5rem;
}
.nhkg-cat-content__body li {
  margin-bottom: 0.5rem;
}
.nhkg-cat-content__body a {
  color: var(--color-bengara);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color 0.3s var(--nhkg-easing);
}
.nhkg-cat-content__body a:hover {
  color: var(--color-sumi);
}
.nhkg-cat-content__body strong {
  font-weight: 600;
  color: var(--color-sumi);
}
.nhkg-cat-content__body em {
  font-style: italic;
}
.nhkg-cat-content__body blockquote {
  margin: 1.5rem 0;
  padding: 1rem 1.5rem;
  border-left: 3px solid var(--color-kincha);
  background: var(--color-washi);
  font-style: italic;
  color: var(--color-ishi);
}
.nhkg-cat-content__body blockquote p:last-child {
  margin-bottom: 0;
}
.page-title, .entry-title {
  margin-inline: auto;
  margin-bottom: calc(var(--spacing) * 6);
  max-width: var(--container-content);
  font-size: var(--text-3xl);
  line-height: var(--tw-leading, var(--text-3xl--line-height));
  --tw-font-weight: var(--font-weight-extrabold);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-neutral-900);
}
.entry-meta, .entry-footer, .post-navigation, #comments {
  margin-inline: auto;
  margin-bottom: calc(var(--spacing) * 6);
  max-width: var(--container-content);
}
.page-content > *, .entry-content > * {
  margin-inline: auto;
  max-width: var(--container-content);
}
.entry-content > .alignwide {
  max-width: var(--container-wide);
}
.entry-content > .alignfull {
  max-width: none;
}
.entry-content > .alignleft {
  float: left;
  margin-right: calc(var(--spacing) * 8);
}
.entry-content > .alignright {
  float: right;
  margin-left: calc(var(--spacing) * 8);
}
.nhkg-contact-page {
  background: var(--color-shiro);
}
.nhkg-contact-hero {
  position: relative;
  padding: 8rem 2rem 4rem;
  background: var(--color-kinari);
  overflow: hidden;
}
@media (min-width: 768px) {
  .nhkg-contact-hero {
    padding: 10rem 2rem 5rem;
  }
}
.admin-bar .nhkg-contact-hero {
  padding-top: calc(8rem + 32px);
}
@media (min-width: 768px) {
  .admin-bar .nhkg-contact-hero {
    padding-top: calc(10rem + 32px);
  }
}
@media (max-width: 782px) {
  .admin-bar .nhkg-contact-hero {
    padding-top: calc(8rem + 46px);
  }
}
.nhkg-contact-hero__bg {
  position: absolute;
  inset: 0;
  color: var(--color-ishi);
  opacity: 0.05;
  pointer-events: none;
}
.nhkg-contact-hero__bg svg {
  width: 100%;
  height: 100%;
}
.nhkg-contact-hero__container {
  position: relative;
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-contact-hero__content {
  max-width: 40rem;
}
.nhkg-contact-hero__japanese-group {
  margin-bottom: 0.5rem;
}
.nhkg-contact-hero__japanese {
  display: block;
  font-family: var(--font-display);
  font-size: 2.5rem;
  color: var(--color-kincha);
  opacity: 0.4;
  line-height: 1;
}
@media (min-width: 768px) {
  .nhkg-contact-hero__japanese {
    font-size: 3.5rem;
  }
}
.nhkg-contact-hero__romaji {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-ishi);
  opacity: 0.7;
  margin-top: 0.25rem;
}
.nhkg-contact-hero__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0 0 1rem;
  line-height: 1.2;
}
.nhkg-contact-hero__description {
  font-family: var(--font-sans);
  font-size: 1.125rem;
  line-height: 1.7;
  color: var(--color-ishi);
  margin: 0;
}
.nhkg-contact-content {
  padding: 5rem 2rem;
  background: var(--color-shiro);
}
@media (min-width: 768px) {
  .nhkg-contact-content {
    padding: 6rem 2rem;
  }
}
.nhkg-contact-content__container {
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-contact-content__grid {
  display: grid;
  gap: 3rem;
}
@media (min-width: 1024px) {
  .nhkg-contact-content__grid {
    grid-template-columns: 1fr 1.5fr;
    gap: 5rem;
  }
}
.nhkg-contact-info__inner {
  position: sticky;
  top: 6rem;
}
.nhkg-contact-info__section {
  margin-bottom: 2rem;
}
.nhkg-contact-info__heading {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0 0 1rem;
}
.nhkg-contact-info__label {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-ishi);
  margin: 0 0 0.5rem;
}
.nhkg-contact-info__text {
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.7;
  color: var(--color-ishi);
  margin: 0;
}
.nhkg-contact-info__text--small {
  font-size: 0.9375rem;
}
.nhkg-contact-info__link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-sans);
  font-size: 1rem;
  color: var(--color-sumi);
  text-decoration: none;
  transition: color 0.3s var(--nhkg-easing);
}
.nhkg-contact-info__link:hover {
  color: var(--color-bengara);
}
.nhkg-contact-info__link svg {
  width: 20px;
  height: 20px;
  color: var(--color-ishi);
}
.nhkg-contact-info__divider {
  height: 1px;
  background: var(--color-kinari);
  margin: 2rem 0;
}
.nhkg-contact-info__decoration {
  margin-top: 3rem;
  text-align: center;
  padding: 2rem;
  background: var(--color-kinari);
  border-radius: 2px;
}
.nhkg-contact-info__kanji {
  display: block;
  font-family: var(--font-display);
  font-size: 4rem;
  color: var(--color-bengara);
  line-height: 1;
  margin-bottom: 0.5rem;
}
.nhkg-contact-info__kanji-label {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-ishi);
}
.nhkg-contact-form__inner {
  background: var(--color-washi);
  padding: 2rem;
  border-radius: 2px;
}
@media (min-width: 768px) {
  .nhkg-contact-form__inner {
    padding: 3rem;
  }
}
.nhkg-contact-form__heading {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0 0 2rem;
}
.nhkg-contact-form__fallback {
  text-align: center;
  padding: 2rem;
  color: var(--color-ishi);
}
.nhkg-contact-form__fallback a {
  display: inline-block;
  margin-top: 1rem;
  color: var(--color-sumi);
  font-weight: 500;
}
.nhkg-contact-form .fluentform {
  font-family: var(--font-sans);
}
.nhkg-contact-form .ff-el-group {
  margin-bottom: 1.5rem;
}
.nhkg-contact-form .ff-el-input--label label, .nhkg-contact-form .ff-el-form-control label {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin-bottom: 0.5rem;
}
.nhkg-contact-form .ff-el-input--label .asterisk-right {
  color: var(--color-bengara);
}
.nhkg-contact-form .ff-el-form-control input[type="text"], .nhkg-contact-form .ff-el-form-control input[type="email"], .nhkg-contact-form .ff-el-form-control select, .nhkg-contact-form .ff-el-form-control textarea {
  width: 100%;
  padding: 0.875rem 1rem;
  font-family: var(--font-sans);
  font-size: 1rem;
  color: var(--color-sumi);
  background: var(--color-shiro);
  border: 1px solid var(--color-kinari);
  border-radius: 2px;
  transition: all 0.3s var(--nhkg-easing);
}
.nhkg-contact-form .ff-el-form-control input[type="text"]:focus, .nhkg-contact-form .ff-el-form-control input[type="email"]:focus, .nhkg-contact-form .ff-el-form-control select:focus, .nhkg-contact-form .ff-el-form-control textarea:focus {
  outline: none;
  border-color: var(--color-sumi);
  box-shadow: 0 0 0 3px rgba(26, 26, 26, 0.1);
}
.nhkg-contact-form .ff-el-form-control input::placeholder, .nhkg-contact-form .ff-el-form-control textarea::placeholder {
  color: var(--color-ishi-light);
}
.nhkg-contact-form .ff-el-form-control select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b6b6b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 2.5rem;
}
.nhkg-contact-form .ff-el-form-control textarea {
  min-height: 150px;
  resize: vertical;
}
.nhkg-contact-form .ff-name-field-wrapper {
  display: grid;
  gap: 1rem;
}
@media (min-width: 480px) {
  .nhkg-contact-form .ff-name-field-wrapper {
    grid-template-columns: 1fr 1fr;
  }
}
.nhkg-contact-form .ff-btn-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-width: 180px;
  padding: 1rem 2rem;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-shiro);
  background: var(--color-sumi);
  border: none;
  border-radius: 2px;
  cursor: pointer;
  transition: all 0.3s var(--nhkg-easing);
}
.nhkg-contact-form .ff-btn-submit:hover {
  background: var(--color-bengara);
  transform: translateY(-2px);
}
.nhkg-contact-form .ff-btn-submit:active {
  transform: translateY(0);
}
.nhkg-contact-form .ff-el-is-error .ff-el-form-control input, .nhkg-contact-form .ff-el-is-error .ff-el-form-control select, .nhkg-contact-form .ff-el-is-error .ff-el-form-control textarea {
  border-color: var(--color-bengara);
}
.nhkg-contact-form .error.text-danger {
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  color: var(--color-bengara);
  margin-top: 0.5rem;
}
.nhkg-contact-form .ff-message-success {
  padding: 1.5rem;
  background: var(--color-kinari);
  border-left: 3px solid var(--color-bengara);
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.7;
  color: var(--color-sumi);
}
.nhkg-contact-faq {
  padding: 5rem 2rem;
  background: var(--color-kinari);
}
@media (min-width: 768px) {
  .nhkg-contact-faq {
    padding: 6rem 2rem;
  }
}
.nhkg-contact-faq__container {
  max-width: 60rem;
  margin: 0 auto;
}
.nhkg-contact-faq__header {
  text-align: center;
  margin-bottom: 3rem;
}
.nhkg-contact-faq__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0.5rem 0 0;
  line-height: 1.2;
}
.nhkg-contact-faq__grid {
  display: grid;
  gap: 2rem;
}
@media (min-width: 768px) {
  .nhkg-contact-faq__grid {
    gap: 2.5rem;
  }
}
.nhkg-faq-item {
  background: var(--color-shiro);
  padding: 2rem;
  border-radius: 2px;
}
.nhkg-faq-item__question {
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0 0 0.75rem;
}
.nhkg-faq-item__answer {
  font-family: var(--font-sans);
  font-size: 0.9375rem;
  line-height: 1.7;
  color: var(--color-ishi);
  margin: 0;
}
:root {
  --nhkg-easing: cubic-bezier(0.4, 0, 0.2, 1);
  --nhkg-easing-scroll: cubic-bezier(0.22, 1, 0.36, 1);
}
@keyframes nhkg-petal-fall {
  0% {
    transform: translateY(-100px) translateX(0) rotate(0deg);
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  90% {
    opacity: 1;
  }
  100% {
    transform: translateY(calc(100vh + 100px)) translateX(var(--petal-drift, 50px)) rotate(var(--petal-rotate, 360deg));
    opacity: 0;
  }
}
@keyframes nhkg-petal-sway {
  0%, 100% {
    transform: translateX(0);
  }
  25% {
    transform: translateX(15px);
  }
  75% {
    transform: translateX(-15px);
  }
}
@keyframes nhkg-mist-drift {
  0% {
    transform: translateX(-5%) translateY(0);
    opacity: 0.3;
  }
  50% {
    opacity: 0.5;
  }
  100% {
    transform: translateX(5%) translateY(-2%);
    opacity: 0.3;
  }
}
@keyframes nhkg-mist-drift-reverse {
  0% {
    transform: translateX(3%) translateY(0);
    opacity: 0.2;
  }
  50% {
    opacity: 0.4;
  }
  100% {
    transform: translateX(-3%) translateY(2%);
    opacity: 0.2;
  }
}
@keyframes nhkg-ink-reveal {
  0% {
    opacity: 0;
    transform: scale(1.1);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes nhkg-title-reveal {
  0% {
    clip-path: inset(0 100% 0 0);
    opacity: 0;
  }
  100% {
    clip-path: inset(0 0% 0 0);
    opacity: 1;
  }
}
@keyframes nhkg-rise {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes nhkg-scroll-pulse {
  0%, 100% {
    transform: translateY(0);
    opacity: 1;
  }
  50% {
    transform: translateY(8px);
    opacity: 0.5;
  }
}
@keyframes nhkg-horizon-expand {
  0% {
    transform: scaleX(0);
  }
  100% {
    transform: scaleX(1);
  }
}
@keyframes nhkg-float {
  0%, 100% {
    transform: translateY(0) rotate(0deg);
  }
  50% {
    transform: translateY(-10px) rotate(2deg);
  }
}
@keyframes nhkg-float-reverse {
  0%, 100% {
    transform: translateY(0) rotate(0deg);
  }
  50% {
    transform: translateY(8px) rotate(-2deg);
  }
}
@keyframes nhkg-reveal-up {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes nhkg-pulse {
  0%, 100% {
    opacity: 0.4;
  }
  50% {
    opacity: 1;
  }
}
@keyframes nhkg-rotate-slow {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
.nhkg-reveal {
  opacity: 1;
  transform: none;
}
.nhkg-section-label {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-bengara);
  margin-bottom: 1rem;
}
.nhkg-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.875rem 1.75rem;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: all 0.3s var(--nhkg-easing);
}
.nhkg-btn--primary {
  background: var(--color-sumi);
  color: var(--color-shiro);
}
.nhkg-btn--primary:hover {
  background: var(--color-bengara);
  transform: translateY(-2px);
}
.nhkg-btn--secondary {
  background: var(--color-ai);
  color: var(--color-shiro);
}
.nhkg-btn--secondary:hover {
  background: var(--color-ai-light);
  transform: translateY(-2px);
}
.nhkg-btn--ghost {
  background: transparent;
  color: var(--color-sumi);
  border: 1px solid var(--color-ishi-light);
}
.nhkg-btn--ghost:hover {
  border-color: var(--color-sumi);
  background: var(--color-kinari);
}
.nhkg-btn__arrow {
  width: 1rem;
  height: 1rem;
  transition: transform 0.3s var(--nhkg-easing);
}
.nhkg-btn:hover .nhkg-btn__arrow {
  transform: translate(3px, -3px);
}
.nhkg-link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-sumi);
  text-decoration: none;
  transition: color 0.3s var(--nhkg-easing);
}
.nhkg-link-arrow:hover {
  color: var(--color-bengara);
}
.nhkg-link-arrow svg {
  width: 1rem;
  height: 1rem;
  transition: transform 0.3s var(--nhkg-easing);
}
.nhkg-link-arrow:hover svg {
  transform: translate(4px, -4px);
}
.nhkg-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  background: var(--color-shiro);
  transition: all 0.3s var(--nhkg-easing);
}
.admin-bar .nhkg-header {
  top: 32px;
}
@media screen and (max-width: 782px) {
  .admin-bar .nhkg-header {
    top: 46px;
  }
}
.nhkg-header__container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 80rem;
  margin: 0 auto;
  padding: 0.625rem 1.5rem;
  height: 3.5rem;
}
@media (min-width: 768px) {
  .nhkg-header__container {
    padding: 0.625rem 2rem;
  }
}
.nhkg-header__brand {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.nhkg-header__brand .custom-logo-link {
  display: flex;
  align-items: center;
  height: 2rem;
}
.nhkg-header__brand .custom-logo {
  width: auto;
  height: 2rem;
  max-height: 2rem;
  object-fit: contain;
}
.nhkg-header__title {
  margin: 0;
  font-size: 1rem;
  line-height: 1.2;
}
.nhkg-header__title a {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  text-decoration: none;
  color: var(--color-sumi);
}
.nhkg-header__title-jp {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 500;
  line-height: 1;
}
.nhkg-header__title-en {
  font-family: var(--font-sans);
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.7;
}
.nhkg-header__tagline {
  display: none;
  font-size: 0.625rem;
  color: var(--color-ishi);
  margin: 0;
}
.nhkg-header__brand .custom-logo-link + .nhkg-header__tagline {
  display: none;
}
.nhkg-nav {
  display: flex;
  align-items: center;
}
.nhkg-nav__toggle {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 0.375rem;
  background: none;
  border: none;
  cursor: pointer;
}
@media (min-width: 768px) {
  .nhkg-nav__toggle {
    display: none;
  }
}
.nhkg-nav__toggle-bar {
  width: 18px;
  height: 1.5px;
  background: var(--color-sumi);
  transition: all 0.3s var(--nhkg-easing);
}
.nhkg-nav__menu {
  display: none;
  list-style: none;
  margin: 0;
  padding: 0;
}
@media (min-width: 768px) {
  .nhkg-nav__menu {
    display: flex;
    gap: 1.5rem;
  }
}
.nhkg-nav__menu li {
  margin: 0;
  padding: 0;
}
.nhkg-nav__menu a {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--color-sumi);
  text-decoration: none;
  transition: color 0.3s var(--nhkg-easing);
}
.nhkg-nav__menu a:hover {
  color: var(--color-bengara);
}
.nhkg-header__search-toggle {
  padding: 0.375rem;
  background: none;
  border: none;
  cursor: pointer;
}
.nhkg-header__search-toggle svg {
  width: 16px;
  height: 16px;
  color: var(--color-sumi);
  transition: color 0.3s var(--nhkg-easing);
}
.nhkg-header__search-toggle:hover svg {
  color: var(--color-bengara);
}
.nhkg-header__line {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--color-kinari), transparent);
}
.nhkg-header.is-scrolled .nhkg-header__container {
  height: 3rem;
}
.nhkg-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-shiro);
  overflow: hidden;
  padding-top: 3.5rem;
}
.admin-bar .nhkg-hero {
  min-height: calc(100vh - 32px);
  padding-top: calc(3.5rem + 32px);
}
@media screen and (max-width: 782px) {
  .admin-bar .nhkg-hero {
    min-height: calc(100vh - 46px);
    padding-top: calc(3.5rem + 46px);
  }
}
.nhkg-hero__ink-wash {
  position: absolute;
  inset: 0;
  z-index: 0;
  background: radial-gradient(ellipse 80% 50% at 20% 80%, rgba(196, 163, 90, 0.08) 0%, transparent 60%),	radial-gradient(ellipse 60% 40% at 80% 20%, rgba(139, 37, 0, 0.05) 0%, transparent 50%),	radial-gradient(ellipse 100% 100% at 50% 50%, var(--color-shiro) 0%, var(--color-kinari) 100%);
}
.nhkg-hero__backdrop {
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
}
.nhkg-hero__backdrop-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.nhkg-hero__backdrop-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(247, 245, 240, 0.7) 0%, rgba(247, 245, 240, 0.5) 50%, rgba(247, 245, 240, 0.85) 100%),	linear-gradient(90deg, rgba(247, 245, 240, 0.9) 0%, transparent 40%, transparent 60%, rgba(247, 245, 240, 0.9) 100%);
}
.nhkg-hero__petals {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  overflow: hidden;
}
.nhkg-petal {
  position: absolute;
  top: -60px;
  opacity: 0;
  will-change: transform;
}
.nhkg-petal svg {
  width: 100%;
  height: 100%;
}
.nhkg-petal--1, .nhkg-petal--4, .nhkg-petal--7, .nhkg-petal--10 {
  color: #e8b4b8;
}
.nhkg-petal--2, .nhkg-petal--5, .nhkg-petal--8, .nhkg-petal--11 {
  color: #f5d0c5;
}
.nhkg-petal--3, .nhkg-petal--6, .nhkg-petal--9, .nhkg-petal--12 {
  color: #f2c4c4;
}
.nhkg-petal--1 {
  left: 8%;
  width: 16px;
  height: 16px;
  --petal-drift: 30px;
  --petal-rotate: 540deg;
  animation: nhkg-petal-fall 12s ease-in-out infinite;
  animation-delay: 0s;
}
.nhkg-petal--2 {
  left: 22%;
  width: 12px;
  height: 12px;
  --petal-drift: -25px;
  --petal-rotate: -360deg;
  animation: nhkg-petal-fall 15s ease-in-out infinite;
  animation-delay: 2s;
}
.nhkg-petal--3 {
  left: 35%;
  width: 14px;
  height: 14px;
  --petal-drift: 45px;
  --petal-rotate: 720deg;
  animation: nhkg-petal-fall 11s ease-in-out infinite;
  animation-delay: 4s;
}
.nhkg-petal--4 {
  left: 48%;
  width: 10px;
  height: 10px;
  --petal-drift: -20px;
  --petal-rotate: -540deg;
  animation: nhkg-petal-fall 14s ease-in-out infinite;
  animation-delay: 1s;
}
.nhkg-petal--5 {
  left: 58%;
  width: 18px;
  height: 18px;
  --petal-drift: 35px;
  --petal-rotate: 450deg;
  animation: nhkg-petal-fall 13s ease-in-out infinite;
  animation-delay: 6s;
}
.nhkg-petal--6 {
  left: 72%;
  width: 11px;
  height: 11px;
  --petal-drift: -40px;
  --petal-rotate: -720deg;
  animation: nhkg-petal-fall 16s ease-in-out infinite;
  animation-delay: 3s;
}
.nhkg-petal--7 {
  left: 85%;
  width: 15px;
  height: 15px;
  --petal-drift: 50px;
  --petal-rotate: 630deg;
  animation: nhkg-petal-fall 10s ease-in-out infinite;
  animation-delay: 5s;
}
.nhkg-petal--8 {
  left: 92%;
  width: 13px;
  height: 13px;
  --petal-drift: -35px;
  --petal-rotate: -450deg;
  animation: nhkg-petal-fall 14s ease-in-out infinite;
  animation-delay: 7s;
}
.nhkg-petal--9 {
  left: 15%;
  width: 9px;
  height: 9px;
  --petal-drift: 25px;
  --petal-rotate: 540deg;
  animation: nhkg-petal-fall 17s ease-in-out infinite;
  animation-delay: 8s;
}
.nhkg-petal--10 {
  left: 42%;
  width: 17px;
  height: 17px;
  --petal-drift: -45px;
  --petal-rotate: -630deg;
  animation: nhkg-petal-fall 12s ease-in-out infinite;
  animation-delay: 9s;
}
.nhkg-petal--11 {
  left: 65%;
  width: 8px;
  height: 8px;
  --petal-drift: 20px;
  --petal-rotate: 360deg;
  animation: nhkg-petal-fall 18s ease-in-out infinite;
  animation-delay: 10s;
}
.nhkg-petal--12 {
  left: 78%;
  width: 14px;
  height: 14px;
  --petal-drift: -30px;
  --petal-rotate: -540deg;
  animation: nhkg-petal-fall 11s ease-in-out infinite;
  animation-delay: 11s;
}
@media (max-width: 768px) {
  .nhkg-petal--4,	.nhkg-petal--6,	.nhkg-petal--8,	.nhkg-petal--10,	.nhkg-petal--12 {
    display: none;
  }
}
.nhkg-hero__mist {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  overflow: hidden;
}
.nhkg-hero__mist-layer {
  position: absolute;
  width: 200%;
  height: 40%;
}
.nhkg-hero__mist-layer--1 {
  bottom: 0;
  left: -50%;
  background: linear-gradient(	0deg,	rgba(247, 245, 240, 0.9) 0%,	rgba(247, 245, 240, 0.6) 30%,	rgba(247, 245, 240, 0) 100%	);
  animation: nhkg-mist-drift 25s ease-in-out infinite alternate;
}
.nhkg-hero__mist-layer--2 {
  top: 0;
  left: -25%;
  background: linear-gradient(	180deg,	rgba(247, 245, 240, 0.7) 0%,	rgba(247, 245, 240, 0.3) 40%,	rgba(247, 245, 240, 0) 100%	);
  animation: nhkg-mist-drift-reverse 30s ease-in-out infinite alternate;
}
.nhkg-hero__content {
  position: relative;
  z-index: 10;
  width: 100%;
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 2rem;
}
@media (min-width: 768px) {
  .nhkg-hero__content {
    padding: 0 4rem;
  }
}
.nhkg-hero__text {
  position: relative;
  max-width: 36rem;
}
.nhkg-hero__side-text {
  display: none;
}
@media (min-width: 1024px) {
  .nhkg-hero__side-text {
    display: block;
    position: absolute;
    left: -4rem;
    top: 50%;
    transform: translateY(-50%);
  }
  .nhkg-hero__side-kanji {
    writing-mode: vertical-rl;
    text-orientation: upright;
    font-family: var(--font-display);
    font-size: 0.875rem;
    letter-spacing: 0.4em;
    color: var(--color-ishi);
    opacity: 0.4;
  }
}
.nhkg-hero__eyebrow {
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-bengara);
  margin-bottom: 1.5rem;
}
.nhkg-hero__title {
  font-family: var(--font-display);
  font-size: clamp(2.75rem, 8vw, 5.5rem);
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--color-sumi);
  margin: 0 0 2rem;
}
.nhkg-hero__title-line {
  display: block;
  overflow: hidden;
  padding-bottom: 0.1em;
}
.nhkg-hero__title-line--3 {
  color: var(--color-bengara);
  font-size: 1.1em;
}
.nhkg-hero__subtitle {
  font-family: var(--font-sans);
  font-size: 1.0625rem;
  line-height: 1.8;
  color: var(--color-ishi);
  margin-bottom: 2.5rem;
  max-width: 28rem;
}
.nhkg-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}
.nhkg-hero__scroll {
  position: absolute;
  bottom: 3rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
}
.nhkg-hero__scroll-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-bengara);
  animation: nhkg-scroll-pulse 2s ease-in-out infinite;
}
.nhkg-hero__scroll span {
  font-family: var(--font-sans);
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-ishi);
}
@media (max-width: 768px) {
  .nhkg-hero__scroll {
    bottom: 2rem;
  }
}
.nhkg-hero__horizon {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(	90deg,	transparent 0%,	var(--color-kincha) 20%,	var(--color-bengara) 50%,	var(--color-kincha) 80%,	transparent 100%	);
}
.nhkg-romaji {
  font-family: var(--font-sans);
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  color: var(--color-ishi);
  text-transform: uppercase;
}
.nhkg-romaji--vertical {
  display: block;
  margin-top: 0.5rem;
}
.nhkg-philosophy {
  position: relative;
  padding: 8rem 2rem;
  background: var(--color-shiro);
}
@media (min-width: 768px) {
  .nhkg-philosophy {
    padding: 10rem 2rem;
  }
}
.nhkg-philosophy__container {
  display: grid;
  gap: 4rem;
  max-width: 80rem;
  margin: 0 auto;
}
@media (min-width: 1024px) {
  .nhkg-philosophy__container {
    grid-template-columns: 1fr 1fr;
    gap: 6rem;
    align-items: center;
  }
}
.nhkg-philosophy__heading {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 500;
  line-height: 1.2;
  color: var(--color-sumi);
  margin: 0 0 2rem;
}
.nhkg-philosophy__body {
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.8;
  color: var(--color-ishi);
}
.nhkg-philosophy__body p {
  margin: 0 0 1.5rem;
}
.nhkg-philosophy__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-top: 3rem;
  padding-top: 3rem;
  border-top: 1px solid var(--color-kinari);
}
.nhkg-stat {
  text-align: center;
}
@media (min-width: 768px) {
  .nhkg-stat {
    text-align: left;
  }
}
.nhkg-stat__number {
  display: block;
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 500;
  color: var(--color-bengara);
  margin-bottom: 0.25rem;
}
.nhkg-stat__label {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: var(--color-ishi);
}
.nhkg-philosophy__visual {
  position: relative;
}
.nhkg-philosophy__kanji {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: 2rem;
}
.nhkg-kanji-group {
  display: flex;
  gap: 0.5rem;
}
.nhkg-kanji {
  font-family: var(--font-display);
  color: var(--color-kinari);
}
.nhkg-kanji--large {
  font-size: 6rem;
  line-height: 1;
}
@media (min-width: 768px) {
  .nhkg-kanji--large {
    font-size: 8rem;
  }
}
.nhkg-philosophy__kanji .nhkg-romaji--vertical {
  font-size: 0.75rem;
  color: var(--color-ishi-light);
  margin-top: 0.25rem;
}
.nhkg-philosophy__images {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.nhkg-philosophy__image {
  position: relative;
  overflow: hidden;
}
.nhkg-philosophy__image--1 {
  grid-column: 1 / -1;
  aspect-ratio: 16 / 10;
}
.nhkg-philosophy__image--2, .nhkg-philosophy__image--3 {
  aspect-ratio: 1;
}
.nhkg-philosophy__image-inner {
  width: 100%;
  height: 100%;
}
.nhkg-philosophy__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--nhkg-easing);
}
.nhkg-philosophy__image:hover .nhkg-philosophy__img {
  transform: scale(1.05);
}
.nhkg-philosophy__image-inner-wrapper {
  width: 100%;
  height: 100%;
  background: var(--color-kinari);
  transition: transform 0.6s var(--nhkg-easing);
}
.nhkg-philosophy__image:hover .nhkg-philosophy__image-inner {
  transform: scale(1.05);
}
.nhkg-philosophy__image-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: var(--color-ishi-light);
}
.nhkg-philosophy__image-placeholder svg {
  width: 40px;
  height: 40px;
}
.nhkg-philosophy__float {
  position: absolute;
  color: var(--color-kincha);
  opacity: 0.2;
  pointer-events: none;
}
.nhkg-philosophy__float--1 {
  bottom: -20%;
  right: -10%;
  width: 150px;
  animation: nhkg-float 15s ease-in-out infinite;
}
.nhkg-philosophy__line {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 80rem;
  padding: 0 2rem;
  color: var(--color-kinari);
}
.nhkg-philosophy__line svg {
  width: 100%;
  height: 2px;
}
.nhkg-categories {
  padding: 8rem 2rem;
  background: var(--color-sumi);
}
@media (min-width: 768px) {
  .nhkg-categories {
    padding: 10rem 2rem;
  }
}
.nhkg-categories__header {
  max-width: 80rem;
  margin: 0 auto 4rem;
  text-align: center;
}
.nhkg-categories .nhkg-section-label {
  color: var(--color-kincha);
}
.nhkg-categories__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 500;
  color: var(--color-shiro);
  margin: 0 0 1rem;
}
.nhkg-categories__intro {
  font-family: var(--font-sans);
  font-size: 1.125rem;
  color: var(--color-ishi-light);
  max-width: 36rem;
  margin: 0 auto;
}
.nhkg-categories__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1px;
  max-width: 80rem;
  margin: 0 auto;
  background: var(--color-sumi-light);
}
@media (min-width: 768px) {
  .nhkg-categories__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .nhkg-categories__grid {
    grid-template-columns: repeat(4, 1fr);
  }
}
.nhkg-category {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: 300px;
  padding: 2rem;
  background: var(--color-sumi);
  text-decoration: none;
  overflow: hidden;
  transition: all 0.5s var(--nhkg-easing);
}
@media (min-width: 768px) {
  .nhkg-category {
    min-height: 380px;
  }
}
.nhkg-category:hover {
  transform: scale(1.02);
}
.nhkg-category__image {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.nhkg-category__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.7s var(--nhkg-easing), filter 0.5s var(--nhkg-easing);
  filter: grayscale(30%) brightness(0.7);
}
.nhkg-category:hover .nhkg-category__img {
  transform: scale(1.08);
  filter: grayscale(0%) brightness(0.8);
}
.nhkg-category__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(	to top,	rgba(26, 26, 26, 0.95) 0%,	rgba(26, 26, 26, 0.8) 30%,	rgba(26, 26, 26, 0.4) 60%,	rgba(26, 26, 26, 0.2) 100%	);
  transition: background 0.5s var(--nhkg-easing);
}
.nhkg-category:hover .nhkg-category__overlay {
  background: linear-gradient(	to top,	rgba(26, 26, 26, 0.9) 0%,	rgba(26, 26, 26, 0.6) 30%,	rgba(26, 26, 26, 0.3) 60%,	rgba(26, 26, 26, 0.15) 100%	);
}
.nhkg-category__content {
  position: relative;
  z-index: 2;
}
.nhkg-category__japanese-group {
  margin-bottom: 0.5rem;
}
.nhkg-category__japanese {
  display: block;
  font-family: var(--font-display);
  font-size: 2.5rem;
  color: var(--color-kinari);
  opacity: 0.3;
  transition: all 0.4s var(--nhkg-easing);
  line-height: 1.1;
}
.nhkg-category__romaji {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-ishi-light);
  opacity: 0.6;
  margin-top: 0.25rem;
  transition: all 0.4s var(--nhkg-easing);
}
.nhkg-category:hover .nhkg-category__japanese {
  opacity: 0.5;
  transform: translateY(-4px);
}
.nhkg-category:hover .nhkg-category__romaji {
  opacity: 0.8;
  transform: translateY(-2px);
}
.nhkg-category__title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--color-shiro);
  margin: 0 0 0.75rem;
  transition: color 0.3s var(--nhkg-easing);
}
.nhkg-category:hover .nhkg-category__title {
  color: var(--color-kincha);
}
.nhkg-category__description {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--color-ishi-light);
  margin: 0 0 1rem;
}
.nhkg-category__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-ishi-light);
  transition: color 0.3s var(--nhkg-easing);
}
.nhkg-category:hover .nhkg-category__cta {
  color: var(--color-kincha);
}
.nhkg-category__cta svg {
  width: 1rem;
  height: 1rem;
  transition: transform 0.3s var(--nhkg-easing);
}
.nhkg-category:hover .nhkg-category__cta svg {
  transform: translateX(4px);
}
.nhkg-category__corner {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 40px;
  height: 40px;
  color: rgba(255, 255, 255, 0.2);
  z-index: 2;
  transition: color 0.4s var(--nhkg-easing);
}
.nhkg-category:hover .nhkg-category__corner {
  color: var(--color-kincha);
}
.nhkg-categories__footer {
  max-width: 80rem;
  margin: 4rem auto 0;
  text-align: center;
}
.nhkg-categories__footer .nhkg-link-arrow {
  color: var(--color-shiro);
}
.nhkg-categories__footer .nhkg-link-arrow:hover {
  color: var(--color-kincha);
}
.nhkg-articles {
  position: relative;
  padding: 8rem 2rem;
  background: var(--color-shiro);
}
@media (min-width: 768px) {
  .nhkg-articles {
    padding: 10rem 2rem;
  }
}
.nhkg-articles__header {
  display: grid;
  gap: 2rem;
  max-width: 80rem;
  margin: 0 auto 4rem;
}
@media (min-width: 768px) {
  .nhkg-articles__header {
    grid-template-columns: 1fr 1fr;
    align-items: end;
  }
}
.nhkg-articles__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0;
}
.nhkg-articles__header-side {
  text-align: left;
}
@media (min-width: 768px) {
  .nhkg-articles__header-side {
    text-align: right;
  }
}
.nhkg-articles__header-side p {
  font-family: var(--font-sans);
  font-size: 1rem;
  color: var(--color-ishi);
  margin: 0 0 1rem;
  max-width: 24rem;
}
@media (min-width: 768px) {
  .nhkg-articles__header-side p {
    margin-left: auto;
  }
}
.nhkg-articles__grid {
  display: grid;
  gap: 1.5rem;
  max-width: 80rem;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .nhkg-articles__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .nhkg-articles__grid {
    grid-template-columns: 1.5fr 1fr 1fr;
    grid-template-rows: auto auto;
  }
}
.nhkg-article {
  position: relative;
  background: var(--color-washi);
  border-radius: 2px;
  overflow: hidden;
  transition: transform 0.4s var(--nhkg-easing), box-shadow 0.4s var(--nhkg-easing);
}
.nhkg-article:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(26, 26, 26, 0.1);
}
.nhkg-article--featured {
  grid-row: span 2;
}
@media (min-width: 768px) {
  .nhkg-article--featured {
    grid-column: 1;
  }
}
.nhkg-article__link {
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
  color: inherit;
}
.nhkg-article__image {
  position: relative;
  overflow: hidden;
}
.nhkg-article--featured .nhkg-article__image {
  flex: 1;
  min-height: 300px;
}
.nhkg-article:not(.nhkg-article--featured) .nhkg-article__image {
  height: 180px;
}
.nhkg-article__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--nhkg-easing);
}
.nhkg-article:hover .nhkg-article__img {
  transform: scale(1.05);
}
.nhkg-article__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background: var(--color-kinari);
  color: var(--color-ishi-light);
}
.nhkg-article__placeholder svg {
  width: 48px;
  height: 48px;
}
.nhkg-article__category {
  position: absolute;
  top: 1rem;
  left: 1rem;
  padding: 0.375rem 0.75rem;
  font-family: var(--font-sans);
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  background: var(--color-shiro);
  color: var(--color-sumi);
}
.nhkg-article__content {
  padding: 1.5rem;
}
.nhkg-article--featured .nhkg-article__content {
  padding: 2rem;
}
.nhkg-article__meta {
  display: flex;
  gap: 1rem;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  color: var(--color-ishi);
  margin-bottom: 0.75rem;
}
.nhkg-article__title {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 1.3;
  color: var(--color-sumi);
  margin: 0 0 0.75rem;
  transition: color 0.3s var(--nhkg-easing);
}
.nhkg-article--featured .nhkg-article__title {
  font-size: 1.5rem;
}
.nhkg-article:hover .nhkg-article__title {
  color: var(--color-bengara);
}
.nhkg-article__excerpt {
  font-family: var(--font-sans);
  font-size: 0.9375rem;
  line-height: 1.6;
  color: var(--color-ishi);
  margin: 0 0 1rem;
}
.nhkg-article__read-more {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-sumi);
  transition: color 0.3s var(--nhkg-easing);
}
.nhkg-article:hover .nhkg-article__read-more {
  color: var(--color-bengara);
}
.nhkg-article__read-more svg {
  width: 1rem;
  height: 1rem;
  transition: transform 0.3s var(--nhkg-easing);
}
.nhkg-article:hover .nhkg-article__read-more svg {
  transform: translateX(4px);
}
.nhkg-articles__empty {
  max-width: 40rem;
  margin: 0 auto;
  padding: 4rem 2rem;
  text-align: center;
}
.nhkg-articles__empty-icon {
  color: var(--color-kinari);
  margin-bottom: 1.5rem;
}
.nhkg-articles__empty-icon svg {
  width: 64px;
  height: 64px;
}
.nhkg-articles__empty p {
  font-family: var(--font-sans);
  font-size: 1rem;
  color: var(--color-ishi);
  margin: 0;
}
.nhkg-articles__decoration {
  position: absolute;
  top: 10%;
  right: 5%;
  width: 120px;
  height: 120px;
  color: var(--color-kinari);
  opacity: 0.5;
  pointer-events: none;
  animation: nhkg-rotate-slow 120s linear infinite;
}
.nhkg-slider {
  position: relative;
  padding: 6rem 0;
  background: var(--color-kinari);
  overflow: hidden;
}
@media (min-width: 768px) {
  .nhkg-slider {
    padding: 8rem 0;
  }
}
.nhkg-slider__container {
  position: relative;
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 2rem;
}
.nhkg-slider__track {
  position: relative;
  overflow: hidden;
}
.nhkg-slider__slide {
  display: none;
  opacity: 0;
}
.nhkg-slider__slide--active {
  display: block;
  opacity: 1;
}
.nhkg-slider__slide--enter-right {
  animation: nhkg-slide-in-right 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}
.nhkg-slider__slide--enter-left {
  animation: nhkg-slide-in-left 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}
.nhkg-slider__slide--exit-left {
  animation: nhkg-slide-out-left 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}
.nhkg-slider__slide--exit-right {
  animation: nhkg-slide-out-right 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}
@keyframes nhkg-slide-in-right {
  from {
    opacity: 0;
    transform: translateX(60px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes nhkg-slide-in-left {
  from {
    opacity: 0;
    transform: translateX(-60px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes nhkg-slide-out-left {
  from {
    opacity: 1;
    transform: translateX(0);
  }
  to {
    opacity: 0;
    transform: translateX(-60px);
  }
}
@keyframes nhkg-slide-out-right {
  from {
    opacity: 1;
    transform: translateX(0);
  }
  to {
    opacity: 0;
    transform: translateX(60px);
  }
}
.nhkg-slider__content {
  display: grid;
  gap: 2rem;
  align-items: center;
}
@media (min-width: 768px) {
  .nhkg-slider__content {
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
  }
}
@media (min-width: 1024px) {
  .nhkg-slider__content {
    grid-template-columns: 1fr 1.2fr;
    gap: 5rem;
  }
}
.nhkg-slider__info {
  order: 2;
}
@media (min-width: 768px) {
  .nhkg-slider__info {
    order: 1;
  }
}
.nhkg-slider__kanji-group {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}
.nhkg-slider__kanji {
  font-family: var(--font-display);
  font-size: 4rem;
  font-weight: 400;
  color: var(--color-bengara);
  line-height: 1;
}
@media (min-width: 768px) {
  .nhkg-slider__kanji {
    font-size: 5rem;
  }
}
.nhkg-slider__romaji {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-ishi);
}
.nhkg-slider__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0 0 1rem;
  line-height: 1.2;
}
.nhkg-slider__description {
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.8;
  color: var(--color-ishi);
  margin: 0 0 1.5rem;
  max-width: 28rem;
}
.nhkg-slider__meta {
  display: flex;
  gap: 2rem;
  margin-bottom: 2rem;
}
@media (min-width: 768px) {
  .nhkg-slider__meta {
    gap: 3rem;
  }
}
.nhkg-slider__meta-item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.nhkg-slider__meta-label {
  font-family: var(--font-sans);
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-ishi);
}
.nhkg-slider__meta-value {
  font-family: var(--font-display);
  font-size: 1rem;
  color: var(--color-sumi);
}
.nhkg-slider__visual {
  order: 1;
}
@media (min-width: 768px) {
  .nhkg-slider__visual {
    order: 2;
  }
}
.nhkg-slider__image-frame {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--color-shiro);
  box-shadow: 0 8px 40px rgba(26, 26, 26, 0.12);
  overflow: hidden;
}
.nhkg-slider__image-frame::before {
  content: '';
  position: absolute;
  inset: 0.5rem;
  border: 1px solid rgba(255, 255, 255, 0.5);
  pointer-events: none;
  z-index: 1;
}
.nhkg-slider__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.nhkg-slider__slide--active .nhkg-slider__img {
  transform: scale(1);
}
.nhkg-slider__slide:hover .nhkg-slider__img {
  transform: scale(1.03);
}
.nhkg-slider__nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 2.5rem;
}
@media (min-width: 768px) {
  .nhkg-slider__nav {
    margin-top: 3rem;
    gap: 1.5rem;
  }
}
.nhkg-slider__arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: var(--color-shiro);
  border: 1px solid var(--color-ishi-light);
  border-radius: 50%;
  color: var(--color-sumi);
  cursor: pointer;
  transition: all 0.3s var(--nhkg-easing);
}
.nhkg-slider__arrow:hover {
  background: var(--color-sumi);
  border-color: var(--color-sumi);
  color: var(--color-shiro);
}
.nhkg-slider__arrow:focus-visible {
  outline: 2px solid var(--color-bengara);
  outline-offset: 2px;
}
.nhkg-slider__arrow svg {
  width: 20px;
  height: 20px;
}
.nhkg-slider__dots {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
@media (min-width: 768px) {
  .nhkg-slider__dots {
    gap: 0.75rem;
  }
}
.nhkg-slider__dot {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: transparent;
  border: 1px solid var(--color-ishi-light);
  border-radius: 4px;
  color: var(--color-ishi);
  cursor: pointer;
  transition: all 0.3s var(--nhkg-easing);
}
@media (min-width: 768px) {
  .nhkg-slider__dot {
    width: 44px;
    height: 44px;
  }
}
.nhkg-slider__dot:hover {
  border-color: var(--color-sumi);
  color: var(--color-sumi);
}
.nhkg-slider__dot--active {
  background: var(--color-sumi);
  border-color: var(--color-sumi);
  color: var(--color-shiro);
}
.nhkg-slider__dot:focus-visible {
  outline: 2px solid var(--color-bengara);
  outline-offset: 2px;
}
.nhkg-slider__dot-label {
  font-family: var(--font-display);
  font-size: 1rem;
  line-height: 1;
}
@media (min-width: 768px) {
  .nhkg-slider__dot-label {
    font-size: 1.25rem;
  }
}
.nhkg-slider__progress {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: rgba(107, 107, 107, 0.2);
}
.nhkg-slider__progress-bar {
  height: 100%;
  width: 0;
  background: var(--color-bengara);
}
.nhkg-newsletter {
  position: relative;
  padding: 6rem 2rem;
  background: var(--color-shiro);
}
@media (min-width: 768px) {
  .nhkg-newsletter {
    padding: 8rem 2rem;
  }
}
.nhkg-newsletter__border {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 80rem;
  padding: 0 2rem;
  color: var(--color-kinari);
}
.nhkg-newsletter__border svg {
  width: 100%;
  height: 4px;
}
.nhkg-newsletter__container {
  display: grid;
  gap: 3rem;
  max-width: 60rem;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .nhkg-newsletter__container {
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
  }
}
.nhkg-newsletter__icon {
  color: var(--color-bengara);
  margin-bottom: 1rem;
}
.nhkg-newsletter__icon svg {
  width: 48px;
  height: 48px;
}
.nhkg-newsletter__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw, 2.25rem);
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0 0 1rem;
}
.nhkg-newsletter__description {
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.7;
  color: var(--color-ishi);
  margin: 0;
}
.nhkg-newsletter__form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
@media (min-width: 480px) {
  .nhkg-newsletter__form {
    flex-direction: row;
  }
}
.nhkg-newsletter__input-group {
  flex: 1;
}
.nhkg-newsletter__label {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}
.nhkg-newsletter__input {
  width: 100%;
  padding: 1rem 1.25rem;
  font-family: var(--font-sans);
  font-size: 1rem;
  color: var(--color-sumi);
  background: var(--color-washi);
  border: 1px solid var(--color-kinari);
  border-radius: 0;
  transition: all 0.3s var(--nhkg-easing);
}
.nhkg-newsletter__input::placeholder {
  color: var(--color-ishi-light);
}
.nhkg-newsletter__input:focus {
  outline: none;
  border-color: var(--color-sumi);
  background: var(--color-shiro);
}
.nhkg-newsletter__submit {
  flex-shrink: 0;
}
.nhkg-newsletter__privacy {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  color: var(--color-ishi);
  margin: 0.5rem 0 0;
}
.nhkg-newsletter__privacy a {
  color: var(--color-sumi);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.nhkg-newsletter__privacy a:hover {
  color: var(--color-bengara);
}
.nhkg-newsletter__decoration {
  position: absolute;
  bottom: 10%;
  right: 10%;
  width: 100px;
  height: 100px;
  color: var(--color-kinari);
  pointer-events: none;
  animation: nhkg-rotate-slow 60s linear infinite reverse;
}
.nhkg-newsletter__kanji {
  position: absolute;
  top: 20%;
  left: 5%;
  font-family: var(--font-display);
  font-size: 8rem;
  color: var(--color-kinari);
  opacity: 0.3;
  pointer-events: none;
  line-height: 1;
}
.nhkg-footer {
  position: relative;
  background: var(--color-sumi);
  color: var(--color-shiro);
}
.nhkg-footer__border {
  color: var(--color-sumi-light);
}
.nhkg-footer__border svg {
  width: 100%;
  height: 2px;
}
.nhkg-footer__container {
  max-width: 80rem;
  margin: 0 auto;
  padding: 5rem 2rem 3rem;
}
.nhkg-footer__grid {
  display: grid;
  gap: 3rem;
}
@media (min-width: 768px) {
  .nhkg-footer__grid {
    grid-template-columns: 1.5fr 2fr;
    gap: 4rem;
  }
}
.nhkg-footer__logo {
  display: inline-flex;
  align-items: baseline;
  gap: 0.75rem;
  text-decoration: none;
  color: var(--color-shiro);
  margin-bottom: 1rem;
}
.nhkg-footer__logo-kanji {
  font-family: var(--font-display);
  font-size: 2rem;
  color: var(--color-kincha);
}
.nhkg-footer__logo-text {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.nhkg-footer__tagline {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--color-ishi-light);
  margin: 0 0 1.5rem;
  max-width: 20rem;
}
.nhkg-footer__social {
  display: flex;
  gap: 1rem;
}
.nhkg-footer__social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  color: var(--color-ishi-light);
  border: 1px solid var(--color-sumi-light);
  transition: all 0.3s var(--nhkg-easing);
}
.nhkg-footer__social-link:hover {
  color: var(--color-shiro);
  border-color: var(--color-kincha);
  background: var(--color-sumi-light);
}
.nhkg-footer__social-link svg {
  width: 18px;
  height: 18px;
}
.nhkg-footer__nav {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}
.nhkg-footer__heading {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-kincha);
  margin: 0 0 1.25rem;
}
.nhkg-footer__links {
  list-style: none;
  margin: 0;
  padding: 0;
}
.nhkg-footer__links li {
  margin-bottom: 0.75rem;
}
.nhkg-footer__links a {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--color-ishi-light);
  text-decoration: none;
  transition: color 0.3s var(--nhkg-easing);
}
.nhkg-footer__links a:hover {
  color: var(--color-shiro);
}
.nhkg-footer__bottom {
  border-top: 1px solid var(--color-sumi-light);
}
.nhkg-footer__bottom-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  max-width: 80rem;
  margin: 0 auto;
  padding: 1.5rem 2rem;
}
.nhkg-footer__copyright {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  color: var(--color-ishi);
  margin: 0;
}
.nhkg-footer__legal {
  display: flex;
  gap: 1.5rem;
}
.nhkg-footer__legal a {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  color: var(--color-ishi);
  text-decoration: none;
  transition: color 0.3s var(--nhkg-easing);
}
.nhkg-footer__legal a:hover {
  color: var(--color-shiro);
}
.nhkg-footer__to-top {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  color: var(--color-ishi);
  border: 1px solid var(--color-sumi-light);
  transition: all 0.3s var(--nhkg-easing);
}
.nhkg-footer__to-top:hover {
  color: var(--color-shiro);
  border-color: var(--color-kincha);
  background: var(--color-sumi-light);
}
.nhkg-footer__to-top svg {
  width: 16px;
  height: 16px;
}
.nhkg-footer__decoration {
  position: absolute;
  bottom: 20%;
  right: 5%;
  pointer-events: none;
}
.nhkg-footer__kanji {
  font-family: var(--font-display);
  font-size: 12rem;
  color: var(--color-sumi-light);
  opacity: 0.3;
  line-height: 1;
}
.nhkg-homepage {
  overflow-x: hidden;
}
body:not(.home) #content {
  padding-top: 4rem;
}
html {
  scroll-behavior: smooth;
}
.nhkg-hero {
  z-index: 1;
}
.nhkg-philosophy, .nhkg-articles, .nhkg-newsletter {
  z-index: 2;
}
.nhkg-categories, .nhkg-seasonal {
  z-index: 3;
}
.nhkg-header.is-scrolled {
  box-shadow: 0 2px 20px rgba(26, 26, 26, 0.06);
}
.nhkg-header.is-hidden {
  transform: translateY(-100%);
}
@media (max-width: 767px) {
  .nhkg-nav__menu {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2rem;
    background: var(--color-shiro);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-20px);
    transition: all 0.4s var(--nhkg-easing);
    z-index: 90;
  }
  .admin-bar .nhkg-nav__menu {
    top: 46px;
  }
  .nhkg-nav__menu.is-open {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }
  .nhkg-nav__menu li {
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.4s var(--nhkg-easing);
  }
  .nhkg-nav__menu.is-open li {
    opacity: 1;
    transform: translateY(0);
  }
  .nhkg-nav__menu.is-open li:nth-child(1) {
    transition-delay: 0.1s;
  }
  .nhkg-nav__menu.is-open li:nth-child(2) {
    transition-delay: 0.15s;
  }
  .nhkg-nav__menu.is-open li:nth-child(3) {
    transition-delay: 0.2s;
  }
  .nhkg-nav__menu.is-open li:nth-child(4) {
    transition-delay: 0.25s;
  }
  .nhkg-nav__menu.is-open li:nth-child(5) {
    transition-delay: 0.3s;
  }
  .nhkg-nav__menu.is-open li:nth-child(6) {
    transition-delay: 0.35s;
  }
  .nhkg-nav__menu a {
    font-size: 1.5rem;
    font-family: var(--font-display);
  }
  .nhkg-nav__toggle {
    position: relative;
    z-index: 100;
  }
  .nhkg-nav__toggle[aria-expanded="true"] .nhkg-nav__toggle-bar:nth-child(1) {
    transform: translateY(6px) rotate(45deg);
  }
  .nhkg-nav__toggle[aria-expanded="true"] .nhkg-nav__toggle-bar:nth-child(2) {
    opacity: 0;
  }
  .nhkg-nav__toggle[aria-expanded="true"] .nhkg-nav__toggle-bar:nth-child(3) {
    transform: translateY(-6px) rotate(-45deg);
  }
  body.menu-open {
    overflow: hidden;
  }
}
.nhkg-category.is-dimmed {
  opacity: 0.5;
}
.nhkg-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.nhkg-btn.is-success {
  background: var(--color-ai);
}
.nhkg-newsletter__submit.is-success {
  background: #22c55e;
}
.nhkg-btn:focus-visible, .nhkg-link-arrow:focus-visible, .nhkg-category:focus-visible, .nhkg-article__link:focus-visible {
  outline: 2px solid var(--color-bengara);
  outline-offset: 2px;
}
.nhkg-newsletter__input:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--color-bengara);
}
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
@media (prefers-reduced-motion: reduce) {
  *,	*::before,	*::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  .nhkg-hero__wave,	.nhkg-hero__cloud,	.nhkg-hero__mon,	.nhkg-philosophy__float,	.nhkg-seasonal__icon,	.nhkg-articles__decoration,	.nhkg-newsletter__decoration {
    animation: none !important;
  }
  html {
    scroll-behavior: auto;
  }
}
.nhkg-search-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 15vh;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.nhkg-search-overlay.is-open {
  opacity: 1;
  visibility: visible;
}
.nhkg-search-overlay__backdrop {
  position: absolute;
  inset: 0;
  background: color-mix(in srgb, #1a1a1a 85%, transparent);
}
@supports (color: color-mix(in lab, red, red)) {
  .nhkg-search-overlay__backdrop {
    background: color-mix(in srgb, var(--color-sumi) 85%, transparent);
  }
}
.nhkg-search-overlay__backdrop {
  backdrop-filter: blur(8px);
}
.nhkg-search-overlay__container {
  position: relative;
  width: 100%;
  max-width: 600px;
  padding: 2rem;
  transform: translateY(-20px);
  transition: transform 0.3s ease;
}
.nhkg-search-overlay.is-open .nhkg-search-overlay__container {
  transform: translateY(0);
}
.nhkg-search-overlay__close {
  position: absolute;
  top: 0;
  right: 0;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  color: var(--color-shiro);
  cursor: pointer;
  opacity: 0.7;
  transition: opacity 0.2s ease;
}
.nhkg-search-overlay__close:hover {
  opacity: 1;
}
.nhkg-search-overlay__close svg {
  width: 24px;
  height: 24px;
}
.nhkg-search-form__label {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1rem;
  color: var(--color-shiro);
  font-family: var(--font-display);
  font-size: 1.25rem;
}
.nhkg-search-form__label-jp {
  font-size: 1.5rem;
  opacity: 0.5;
}
.nhkg-search-form__input-wrapper {
  position: relative;
  display: flex;
  align-items: stretch;
}
.nhkg-search-form__input {
  flex: 1;
  height: 60px;
  padding: 0 1.5rem;
  font-family: var(--font-sans);
  font-size: 1.125rem;
  color: var(--color-sumi);
  background: var(--color-shiro);
  border: 2px solid transparent;
  border-radius: 0.5rem 0 0 0.5rem;
  outline: none;
  transition: border-color 0.2s ease;
}
.nhkg-search-form__input:focus {
  border-color: var(--color-aka);
}
.nhkg-search-form__input::placeholder {
  color: var(--color-ishi);
}
.nhkg-search-form__submit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  background: var(--color-aka);
  border: none;
  border-radius: 0 0.5rem 0.5rem 0;
  color: var(--color-shiro);
  cursor: pointer;
  transition: background-color 0.2s ease;
}
.nhkg-search-form__submit:hover {
  background: var(--color-aka);
}
@supports (color: color-mix(in lab, red, red)) {
  .nhkg-search-form__submit:hover {
    background: color-mix(in srgb, var(--color-aka) 85%, black);
  }
}
.nhkg-search-form__submit svg {
  width: 24px;
  height: 24px;
}
.nhkg-search-form__hint {
  margin-top: 0.75rem;
  font-size: 0.875rem;
  color: var(--color-ishi-light);
  text-align: center;
}
.nhkg-search-overlay__quick-links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.5rem 1rem;
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid color-mix(in srgb, #f7f5f0 20%, transparent);
}
@supports (color: color-mix(in lab, red, red)) {
  .nhkg-search-overlay__quick-links {
    border-top: 1px solid color-mix(in srgb, var(--color-shiro) 20%, transparent);
  }
}
.nhkg-search-overlay__quick-label {
  font-size: 0.875rem;
  color: var(--color-ishi-light);
}
.nhkg-search-overlay__quick-links a {
  font-size: 0.875rem;
  color: var(--color-shiro);
  text-decoration: none;
  opacity: 0.8;
  transition: opacity 0.2s ease;
}
.nhkg-search-overlay__quick-links a:hover {
  opacity: 1;
  text-decoration: underline;
}
body.search-open {
  overflow: hidden;
}
.nhkg-search-hero {
  padding: 3rem 1.5rem 2rem;
  background: var(--color-kinari);
}
.nhkg-search-hero__container {
  max-width: 800px;
  margin: 0 auto;
}
.nhkg-search-hero__content {
  margin: 2rem 0;
  text-align: center;
}
.nhkg-search-hero__japanese {
  display: block;
  font-size: 1rem;
  color: var(--color-ishi);
  margin-bottom: 0.5rem;
}
.nhkg-search-hero__title {
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0 0 0.5rem;
}
.nhkg-search-hero__query {
  color: var(--color-aka);
}
.nhkg-search-hero__count {
  font-size: 1rem;
  color: var(--color-ishi);
  margin: 0;
}
.nhkg-search-hero__form {
  margin-top: 1.5rem;
}
.nhkg-search-hero__input-wrapper {
  display: flex;
  max-width: 500px;
  margin: 0 auto;
}
.nhkg-search-hero__input {
  flex: 1;
  height: 48px;
  padding: 0 1rem;
  font-family: var(--font-sans);
  font-size: 1rem;
  color: var(--color-sumi);
  background: var(--color-shiro);
  border: 1px solid var(--color-ishi-light);
  border-right: none;
  border-radius: 0.375rem 0 0 0.375rem;
  outline: none;
}
.nhkg-search-hero__input:focus {
  border-color: var(--color-aka);
}
.nhkg-search-hero__submit {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0 1.25rem;
  font-family: var(--font-sans);
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--color-shiro);
  background: var(--color-sumi);
  border: none;
  border-radius: 0 0.375rem 0.375rem 0;
  cursor: pointer;
  transition: background-color 0.2s ease;
}
.nhkg-search-hero__submit:hover {
  background: color-mix(in srgb, #1a1a1a 85%, white);
}
@supports (color: color-mix(in lab, red, red)) {
  .nhkg-search-hero__submit:hover {
    background: color-mix(in srgb, var(--color-sumi) 85%, white);
  }
}
.nhkg-search-hero__submit svg {
  width: 18px;
  height: 18px;
}
@media (min-width: 768px) {
  .nhkg-search-hero {
    padding: 4rem 2rem 3rem;
  }
  .nhkg-search-hero__title {
    font-size: 2.25rem;
  }
}
.nhkg-search-content {
  padding: 3rem 1.5rem;
  background: var(--color-shiro);
}
.nhkg-search-content__container {
  max-width: 900px;
  margin: 0 auto;
}
.nhkg-search-list {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.nhkg-search-item {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 1rem;
  padding: 1.5rem;
  background: var(--color-washi);
  border-radius: 0.5rem;
  transition: box-shadow 0.2s ease;
}
.nhkg-search-item:hover {
  box-shadow: 0 4px 20px color-mix(in srgb, #1a1a1a 10%, transparent);
}
@supports (color: color-mix(in lab, red, red)) {
  .nhkg-search-item:hover {
    box-shadow: 0 4px 20px color-mix(in srgb, var(--color-sumi) 10%, transparent);
  }
}
.nhkg-search-item__image {
  width: 80px;
  height: 80px;
  border-radius: 0.375rem;
  overflow: hidden;
  flex-shrink: 0;
}
.nhkg-search-item__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.nhkg-search-item__image--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-kinari);
  color: var(--color-ishi);
}
.nhkg-search-item__image--placeholder svg {
  width: 32px;
  height: 32px;
}
.nhkg-search-item__content {
  min-width: 0;
}
.nhkg-search-item__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}
.nhkg-search-item__type {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-aka);
  background: var(--color-aka);
}
@supports (color: color-mix(in lab, red, red)) {
  .nhkg-search-item__type {
    background: color-mix(in srgb, var(--color-aka) 10%, transparent);
  }
}
.nhkg-search-item__type {
  padding: 0.125rem 0.5rem;
  border-radius: 0.25rem;
}
.nhkg-search-item__info {
  font-size: 0.8125rem;
  color: var(--color-ishi);
}
.nhkg-search-item__title {
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: 500;
  margin: 0 0 0.25rem;
  line-height: 1.3;
}
.nhkg-search-item__title a {
  color: var(--color-sumi);
  text-decoration: none;
}
.nhkg-search-item__title a:hover {
  color: var(--color-aka);
}
.nhkg-search-item__title-jp {
  display: block;
  font-size: 0.875rem;
  font-weight: 400;
  color: var(--color-ishi);
  margin-top: 0.125rem;
}
.nhkg-search-item__excerpt {
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--color-ishi);
  margin: 0.5rem 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.nhkg-search-item__link {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-sumi);
  text-decoration: none;
  margin-top: 0.5rem;
}
.nhkg-search-item__link:hover {
  color: var(--color-aka);
}
.nhkg-search-item__link svg {
  width: 16px;
  height: 16px;
  transition: transform 0.2s ease;
}
.nhkg-search-item__link:hover svg {
  transform: translateX(4px);
}
@media (min-width: 640px) {
  .nhkg-search-item {
    grid-template-columns: 120px 1fr;
    gap: 1.5rem;
    padding: 2rem;
  }
  .nhkg-search-item__image {
    width: 120px;
    height: 120px;
  }
  .nhkg-search-item__title {
    font-size: 1.25rem;
  }
}
.nhkg-search-empty {
  text-align: center;
  padding: 4rem 2rem;
}
.nhkg-search-empty__icon {
  color: var(--color-kinari);
  margin-bottom: 1.5rem;
}
.nhkg-search-empty__icon svg {
  width: 80px;
  height: 80px;
}
.nhkg-search-empty h2 {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0 0 0.75rem;
}
.nhkg-search-empty > p {
  font-size: 1rem;
  color: var(--color-ishi);
  margin: 0 0 2rem;
  max-width: 400px;
  margin-left: auto;
  margin-right: auto;
}
.nhkg-search-empty__suggestions {
  text-align: left;
  max-width: 320px;
  margin: 0 auto 2rem;
  padding: 1.5rem;
  background: var(--color-washi);
  border-radius: 0.5rem;
}
.nhkg-search-empty__suggestions h3 {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-sumi);
  margin: 0 0 0.75rem;
}
.nhkg-search-empty__suggestions ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.nhkg-search-empty__suggestions li {
  position: relative;
  padding-left: 1.25rem;
  font-size: 0.875rem;
  color: var(--color-ishi);
  margin-bottom: 0.5rem;
}
.nhkg-search-empty__suggestions li::before {
  content: '•';
  position: absolute;
  left: 0;
  color: var(--color-aka);
}
.nhkg-search-empty__links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
}
.nhkg-single-post {
  background: var(--color-shiro);
}
.nhkg-post-hero {
  position: relative;
  min-height: 60vh;
  display: flex;
  align-items: flex-end;
  padding: 6rem 2rem 4rem;
  background: var(--color-sumi);
  overflow: hidden;
}
@media (min-width: 768px) {
  .nhkg-post-hero {
    min-height: 70vh;
    padding: 8rem 2rem 5rem;
  }
}
.admin-bar .nhkg-post-hero {
  padding-top: calc(6rem + 32px);
}
@media (min-width: 768px) {
  .admin-bar .nhkg-post-hero {
    padding-top: calc(8rem + 32px);
  }
}
@media (max-width: 782px) {
  .admin-bar .nhkg-post-hero {
    padding-top: calc(6rem + 46px);
  }
}
.nhkg-post-hero__bg {
  position: absolute;
  inset: 0;
  color: var(--color-ishi);
  opacity: 0.08;
  pointer-events: none;
  z-index: 1;
}
.nhkg-post-hero__bg svg {
  width: 100%;
  height: 100%;
}
.nhkg-post-hero__image {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.nhkg-post-hero__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.nhkg-post-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(	to top,	rgba(26, 26, 26, 0.95) 0%,	rgba(26, 26, 26, 0.7) 40%,	rgba(26, 26, 26, 0.4) 70%,	rgba(26, 26, 26, 0.2) 100%	);
}
.nhkg-post-hero__container {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 2rem;
  max-width: 80rem;
  margin: 0 auto;
  width: 100%;
}
@media (min-width: 1024px) {
  .nhkg-post-hero__container {
    grid-template-columns: 1fr auto;
    align-items: flex-end;
  }
}
.nhkg-post-hero__content {
  max-width: 50rem;
}
.nhkg-post-hero .nhkg-breadcrumb a {
  color: var(--color-ishi-light);
}
.nhkg-post-hero .nhkg-breadcrumb a:hover {
  color: var(--color-shiro);
}
.nhkg-post-hero .nhkg-breadcrumb__sep {
  color: var(--color-ishi);
}
.nhkg-post-hero .nhkg-breadcrumb span[aria-current="page"] {
  color: var(--color-shiro);
}
.nhkg-post-hero__category {
  display: inline-flex;
  flex-direction: column;
  margin-bottom: 1rem;
}
.nhkg-post-hero__category-japanese {
  font-family: var(--font-display);
  font-size: 2rem;
  color: var(--color-kincha);
  opacity: 0.5;
  line-height: 1;
}
@media (min-width: 768px) {
  .nhkg-post-hero__category-japanese {
    font-size: 2.5rem;
  }
}
.nhkg-post-hero__category-romaji {
  font-family: var(--font-sans);
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-ishi-light);
  opacity: 0.7;
  margin-top: 0.25rem;
}
.nhkg-post-hero__category-name {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-kincha);
  margin-top: 0.5rem;
}
.nhkg-post-hero__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 4vw, 3rem);
  font-weight: 500;
  color: var(--color-shiro);
  margin: 0 0 1rem;
  line-height: 1.2;
}
.nhkg-post-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--color-ishi-light);
}
.nhkg-post-hero__reading-time {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.nhkg-post-hero__decoration {
  display: none;
  width: 100px;
  height: 100px;
  color: var(--color-kincha);
  opacity: 0.2;
}
@media (min-width: 1024px) {
  .nhkg-post-hero__decoration {
    display: block;
  }
}
.nhkg-article-body {
  padding: 4rem 2rem;
}
@media (min-width: 768px) {
  .nhkg-article-body {
    padding: 5rem 2rem;
  }
}
.nhkg-article-body__container {
  max-width: 50rem;
  margin: 0 auto;
}
.nhkg-prose {
  font-family: var(--font-serif);
  font-size: 1.125rem;
  line-height: 1.8;
  color: var(--color-sumi);
}
.nhkg-prose p {
  margin-bottom: 1.5rem;
}
.nhkg-prose h2 {
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 3rem 0 1.5rem;
  line-height: 1.3;
}
.nhkg-prose h3 {
  font-family: var(--font-display);
  font-size: 1.375rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 2.5rem 0 1rem;
  line-height: 1.4;
}
.nhkg-prose h4 {
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 2rem 0 0.75rem;
}
.nhkg-prose a {
  color: var(--color-bengara);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color 0.3s var(--nhkg-easing);
}
.nhkg-prose a:hover {
  color: var(--color-sumi);
}
.nhkg-prose blockquote {
  position: relative;
  margin: 2rem 0;
  padding: 1.5rem 2rem;
  background: var(--color-kinari);
  border-left: 3px solid var(--color-bengara);
  font-style: italic;
}
.nhkg-prose blockquote p:last-child {
  margin-bottom: 0;
}
.nhkg-prose ul, .nhkg-prose ol {
  margin: 1.5rem 0;
  padding-left: 1.5rem;
}
.nhkg-prose li {
  margin-bottom: 0.5rem;
}
.nhkg-prose img {
  max-width: 100%;
  height: auto;
  margin: 2rem 0;
  border-radius: 2px;
}
.nhkg-prose figure {
  margin: 2rem 0;
}
.nhkg-prose figcaption {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--color-ishi);
  text-align: center;
  margin-top: 0.75rem;
}
.nhkg-page-links {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 2rem;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--color-ishi);
}
.nhkg-page-links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  height: 2rem;
  padding: 0 0.5rem;
  background: var(--color-washi);
  border: 1px solid var(--color-kinari);
  color: var(--color-sumi);
  text-decoration: none;
  transition: all 0.3s var(--nhkg-easing);
}
.nhkg-page-links a:hover {
  background: var(--color-kinari);
  border-color: var(--color-ishi-light);
}
.nhkg-article-tags {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid var(--color-kinari);
}
.nhkg-article-tags__label {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-ishi);
}
.nhkg-article-tags__list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.nhkg-article-tag {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  color: var(--color-sumi);
  padding: 0.375rem 0.75rem;
  background: var(--color-kinari);
  text-decoration: none;
  transition: all 0.3s var(--nhkg-easing);
}
.nhkg-article-tag:hover {
  background: var(--color-sumi);
  color: var(--color-shiro);
}
.nhkg-author-card {
  margin-top: 4rem;
}
.nhkg-author-card__inner {
  display: grid;
  gap: 1.5rem;
  padding: 2rem;
  background: var(--color-kinari);
  border-radius: 2px;
}
@media (min-width: 640px) {
  .nhkg-author-card__inner {
    grid-template-columns: auto 1fr auto;
    align-items: start;
    gap: 2rem;
  }
}
.nhkg-author-card__avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--color-washi);
}
.nhkg-author-card__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.nhkg-author-card__info {
  min-width: 0;
}
.nhkg-author-card__label {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-ishi);
  margin-bottom: 0.25rem;
}
.nhkg-author-card__name {
  display: block;
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 500;
  color: var(--color-sumi);
}
.nhkg-author-card__bio {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--color-ishi);
  margin: 0.5rem 0 0;
}
.nhkg-author-card__date {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  text-align: left;
}
@media (min-width: 640px) {
  .nhkg-author-card__date {
    text-align: right;
  }
}
.nhkg-author-card__date-label {
  font-family: var(--font-sans);
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-ishi);
}
.nhkg-author-card__date time {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--color-sumi);
}
.nhkg-author-card__updated {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  color: var(--color-ishi);
  margin-top: 0.25rem;
}
.nhkg-related-posts {
  padding: 4rem 2rem;
  background: var(--color-washi);
}
@media (min-width: 768px) {
  .nhkg-related-posts {
    padding: 5rem 2rem;
  }
}
.nhkg-related-posts__container {
  max-width: 80rem;
  margin: 0 auto;
}
.nhkg-related-posts__header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  margin-bottom: 2rem;
}
.nhkg-related-posts__title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--color-sumi);
  margin: 0;
}
.nhkg-related-posts__title span {
  color: var(--color-bengara);
}
.nhkg-related-posts__grid {
  display: grid;
  gap: 2rem;
}
@media (min-width: 640px) {
  .nhkg-related-posts__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .nhkg-related-posts__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.nhkg-link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-sumi);
  text-decoration: none;
  transition: color 0.3s var(--nhkg-easing);
}
.nhkg-link-arrow:hover {
  color: var(--color-bengara);
}
.nhkg-link-arrow svg {
  width: 1.25rem;
  height: 1.25rem;
  transition: transform 0.3s var(--nhkg-easing);
}
.nhkg-link-arrow:hover svg {
  transform: translateX(4px);
}
.visible {
  visibility: visible;
}
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip-path: inset(50%);
  white-space: nowrap;
  border-width: 0;
}
.container {
  width: 100%;
}
@media (width >= 40rem) {
  .container {
    max-width: 40rem;
  }
}
@media (width >= 48rem) {
  .container {
    max-width: 48rem;
  }
}
@media (width >= 64rem) {
  .container {
    max-width: 64rem;
  }
}
@media (width >= 80rem) {
  .container {
    max-width: 80rem;
  }
}
@media (width >= 96rem) {
  .container {
    max-width: 96rem;
  }
}
.prose {
  --tw-prose-body: var(--color-foreground);
  --tw-prose-headings: var(--color-foreground);
  --tw-prose-lead: var(--color-foreground);
  --tw-prose-links: var(--color-primary);
  --tw-prose-bold: var(--color-foreground);
  --tw-prose-counters: var(--color-foreground);
  --tw-prose-bullets: var(--color-foreground);
  --tw-prose-hr: var(--color-foreground);
  --tw-prose-quotes: var(--color-foreground);
  --tw-prose-quote-borders: var(--color-primary);
  --tw-prose-captions: var(--color-foreground);
  --tw-prose-kbd: var(--color-foreground);
  --tw-prose-kbd-shadows: var(--color-foreground);
  --tw-prose-code: var(--color-foreground);
  --tw-prose-pre-code: var(--color-background);
  --tw-prose-pre-bg: var(--color-foreground);
  --tw-prose-th-borders: var(--color-foreground);
  --tw-prose-td-borders: var(--color-foreground);
  --tw-prose-invert-body: var(--color-background);
  --tw-prose-invert-headings: var(--color-background);
  --tw-prose-invert-lead: var(--color-background);
  --tw-prose-invert-links: var(--color-primary);
  --tw-prose-invert-bold: var(--color-background);
  --tw-prose-invert-counters: var(--color-background);
  --tw-prose-invert-bullets: var(--color-background);
  --tw-prose-invert-hr: var(--color-background);
  --tw-prose-invert-quotes: var(--color-background);
  --tw-prose-invert-quote-borders: var(--color-primary);
  --tw-prose-invert-captions: var(--color-background);
  --tw-prose-invert-kbd: var(--color-background);
  --tw-prose-invert-kbd-shadows: var(--color-background);
  --tw-prose-invert-code: var(--color-background);
  --tw-prose-invert-pre-code: var(--color-foreground);
  --tw-prose-invert-pre-bg: var(--color-background);
  --tw-prose-invert-th-borders: var(--color-background);
  --tw-prose-invert-td-borders: var(--color-background);
  font-size: 1rem;
  line-height: 1.75;
  color: var(--tw-prose-body);
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(p) {
  margin-top: 1.25em;
  margin-bottom: 1.25em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where([class~='lead'],[class~='is-style-lead']) {
  color: var(--tw-prose-lead);
  font-size: 1.25em;
  line-height: 1.6;
  margin-top: 1.2em;
  margin-bottom: 1.2em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(a) {
  color: var(--tw-prose-links);
  text-decoration: underline;
  font-weight: var(--tw-prose-font-medium);
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(strong) {
  color: var(--tw-prose-bold);
  font-weight: var(--tw-prose-font-semibold);
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(a strong) {
  color: inherit;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(blockquote strong) {
  color: inherit;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(thead th strong) {
  color: inherit;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(ol) {
  list-style-type: decimal;
  margin-top: 1.25em;
  margin-bottom: 1.25em;
  padding-left: 1.625em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(ol[type='A']) {
  list-style-type: upper-alpha;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(ol[type='a']) {
  list-style-type: lower-alpha;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(ol[type='A' s]) {
  list-style-type: upper-alpha;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(ol[type='a' s]) {
  list-style-type: lower-alpha;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(ol[type='I']) {
  list-style-type: upper-roman;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(ol[type='i']) {
  list-style-type: lower-roman;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(ol[type='I' s]) {
  list-style-type: upper-roman;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(ol[type='i' s]) {
  list-style-type: lower-roman;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(ol[type='1']) {
  list-style-type: decimal;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(ul) {
  list-style-type: disc;
  margin-top: 1.25em;
  margin-bottom: 1.25em;
  padding-left: 1.625em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(ol > li)::marker {
  font-weight: var(--tw-prose-font-normal);
  color: var(--tw-prose-counters);
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(ul > li)::marker {
  color: var(--tw-prose-bullets);
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(dt) {
  color: var(--tw-prose-headings);
  font-weight: var(--tw-prose-font-semibold);
  margin-top: 1.25em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(hr) {
  border-color: var(--tw-prose-hr);
  border-top-width: 1px;
  margin-top: 3em;
  margin-bottom: 3em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(blockquote) {
  font-weight: var(--tw-prose-font-medium);
  font-style: italic;
  color: var(--tw-prose-quotes);
  border-left-width: 0.25rem;
  border-left-color: var(--tw-prose-quote-borders);
  quotes: '\201C''\201D''\2018''\2019';
  margin-top: 1.6em;
  margin-bottom: 1.6em;
  padding-left: 1em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(blockquote p:first-of-type)::before {
  content: open-quote;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(blockquote p:last-of-type)::after {
  content: close-quote;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(blockquote > cite) {
  color: var(--tw-prose-body);
  font-style: normal;
  font-weight: var(--tw-prose-font-normal);
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(blockquote > cite::before) {
  content: '\2014';
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(h1) {
  color: var(--tw-prose-headings);
  font-weight: var(--tw-prose-font-extrabold);
  font-size: 2.25em;
  margin-top: 0;
  margin-bottom: 0.8888889em;
  line-height: 1.1111111;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(h1 strong) {
  font-weight: var(--tw-prose-font-black);
  color: inherit;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(h2) {
  color: var(--tw-prose-headings);
  font-weight: var(--tw-prose-font-bold);
  font-size: 1.5em;
  margin-top: 2em;
  margin-bottom: 1em;
  line-height: 1.3333333;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(h2 strong) {
  font-weight: var(--tw-prose-font-extrabold);
  color: inherit;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(h3) {
  color: var(--tw-prose-headings);
  font-weight: var(--tw-prose-font-semibold);
  font-size: 1.25em;
  margin-top: 1.6em;
  margin-bottom: 0.6em;
  line-height: 1.6;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(h3 strong) {
  font-weight: var(--tw-prose-font-bold);
  color: inherit;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(h4) {
  color: var(--tw-prose-headings);
  font-weight: var(--tw-prose-font-semibold);
  margin-top: 1.5em;
  margin-bottom: 0.5em;
  line-height: 1.5;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(h4 strong) {
  font-weight: var(--tw-prose-font-bold);
  color: inherit;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(img) {
  margin-top: 2em;
  margin-bottom: 2em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(picture) {
  display: block;
  margin-top: 2em;
  margin-bottom: 2em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(kbd) {
  font-weight: var(--tw-prose-font-medium);
  font-family: inherit;
  color: var(--tw-prose-kbd);
  box-shadow: 0 0 0 1px var(--tw-prose-kbd-shadows), 0 3px 0 var(--tw-prose-kbd-shadows);
}
@supports (color: color-mix(in lab, red, red)) {
  :is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(kbd) {
    box-shadow: 0 0 0 1px color-mix(in oklab, var(--tw-prose-kbd-shadows) 10%, transparent), 0 3px 0 color-mix(in oklab, var(--tw-prose-kbd-shadows) 10%, transparent);
  }
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(kbd) {
  font-size: 0.875em;
  border-radius: 0.3125rem;
  padding-top: 0.1875em;
  padding-right: 0.375em;
  padding-bottom: 0.1875em;
  padding-left: 0.375em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(code) {
  color: var(--tw-prose-code);
  font-weight: var(--tw-prose-font-semibold);
  font-size: 0.875em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(code)::before,:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(code)::after {
  content: '`';
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(a code) {
  color: inherit;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(h1 code) {
  color: inherit;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(h2 code) {
  color: inherit;
  font-size: 0.875em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(h3 code) {
  color: inherit;
  font-size: 0.9em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(h4 code) {
  color: inherit;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(blockquote code) {
  color: inherit;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(thead th code) {
  color: inherit;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(pre) {
  color: var(--tw-prose-pre-code);
  background-color: var(--tw-prose-pre-bg);
  overflow-x: auto;
  font-weight: var(--tw-prose-font-normal);
  font-size: 0.875em;
  line-height: 1.7142857;
  margin-top: 1.7142857em;
  margin-bottom: 1.7142857em;
  border-radius: 0.375rem;
  padding-top: 0.8571429em;
  padding-right: 1.1428571em;
  padding-bottom: 0.8571429em;
  padding-left: 1.1428571em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(pre code) {
  background-color: transparent;
  border-width: 0;
  border-radius: 0;
  padding: 0;
  font-weight: inherit;
  color: inherit;
  font-size: inherit;
  font-family: inherit;
  line-height: inherit;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(pre code)::before {
  content: none;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(pre code)::after {
  content: none;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(table) {
  width: 100%;
  table-layout: auto;
  text-align: left;
  margin-top: 2em;
  margin-bottom: 2em;
  font-size: 0.875em;
  line-height: 1.7142857;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(table.has-fixed-layout) {
  table-layout: fixed;
  width: 100%;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(thead) {
  border-bottom-width: 1px;
  border-bottom-color: var(--tw-prose-th-borders);
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(thead th) {
  color: var(--tw-prose-headings);
  font-weight: var(--tw-prose-font-semibold);
  vertical-align: bottom;
  padding-right: 0.5714286em;
  padding-bottom: 0.5714286em;
  padding-left: 0.5714286em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(tbody tr) {
  border-bottom-width: 1px;
  border-bottom-color: var(--tw-prose-td-borders);
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(tbody tr:last-child) {
  border-bottom-width: 0;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(tbody td) {
  vertical-align: baseline;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(tfoot) {
  border-top-width: 1px;
  border-top-color: var(--tw-prose-th-borders);
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(tfoot td) {
  vertical-align: top;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(figure > *) {
  margin-top: 0;
  margin-bottom: 0;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(figcaption) {
  color: var(--tw-prose-captions);
  font-size: 0.875em;
  line-height: 1.4285714;
  margin-top: 0.8571429em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(picture > img) {
  margin-top: 0;
  margin-bottom: 0;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(video) {
  margin-top: 2em;
  margin-bottom: 2em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(li) {
  margin-top: 0.5em;
  margin-bottom: 0.5em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(ol > li) {
  padding-left: 0.375em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(ul > li) {
  padding-left: 0.375em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(.prose > ul > li p) {
  margin-top: 0.75em;
  margin-bottom: 0.75em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(.prose > ul > li > *:first-child) {
  margin-top: 1.25em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(.prose > ul > li > *:last-child) {
  margin-bottom: 1.25em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(.prose > ol > li > *:first-child) {
  margin-top: 1.25em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(.prose > ol > li > *:last-child) {
  margin-bottom: 1.25em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(ul ul,ul ol,ol ul,ol ol) {
  margin-top: 0.75em;
  margin-bottom: 0.75em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(dl) {
  margin-top: 1.25em;
  margin-bottom: 1.25em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(dd) {
  margin-top: 0.5em;
  padding-left: 1.625em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(hr + *) {
  margin-top: 0;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(h2 + *) {
  margin-top: 0;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(h3 + *) {
  margin-top: 0;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(h4 + *) {
  margin-top: 0;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(thead th:first-child) {
  padding-left: 0;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(thead th:last-child) {
  padding-right: 0;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(tbody td,tfoot td) {
  padding-top: 0.5714286em;
  padding-right: 0.5714286em;
  padding-bottom: 0.5714286em;
  padding-left: 0.5714286em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(tbody td:first-child,tfoot td:first-child) {
  padding-left: 0;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(tbody td:last-child,tfoot td:last-child) {
  padding-right: 0;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(figure) {
  margin-top: 2em;
  margin-bottom: 2em;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(.prose > :first-child) {
  margin-top: 0;
}
:is(.prose :not(:where([class~='not-prose'],[class~='not-prose'] *))):where(.prose > :last-child) {
  margin-bottom: 0;
}
.prose .wp-block-table td,.prose .wp-block-table th {
  border: 0;
}
.prose .wp-block-table thead,.prose .wp-block-table tfoot {
  border-color: var(--tw-prose-th-borders);
}
.prose .wp-block-table thead {
  border-bottom-width: 1px;
}
.prose .wp-block-table tfoot {
  border-top-width: 1px;
}
.block {
  display: block;
}
.contents {
  display: contents;
}
.grid {
  display: grid;
}
.max-w-none {
  max-width: none;
}
.transform {
  transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,);
}
.shadow {
  --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
  box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
}
.filter {
  filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,);
}
.transition {
  transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter, display, content-visibility, overlay, pointer-events;
  transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
  transition-duration: var(--tw-duration, var(--default-transition-duration));
}
.prose-neutral {
  --tw-prose-body: var(--color-neutral-700);
  --tw-prose-headings: var(--color-neutral-900);
  --tw-prose-lead: var(--color-neutral-600);
  --tw-prose-links: var(--color-neutral-900);
  --tw-prose-bold: var(--color-neutral-900);
  --tw-prose-counters: var(--color-neutral-500);
  --tw-prose-bullets: var(--color-neutral-300);
  --tw-prose-hr: var(--color-neutral-200);
  --tw-prose-quotes: var(--color-neutral-900);
  --tw-prose-quote-borders: var(--color-neutral-200);
  --tw-prose-captions: var(--color-neutral-500);
  --tw-prose-kbd: var(--color-neutral-900);
  --tw-prose-kbd-shadows: var(--color-neutral-900);
  --tw-prose-code: var(--color-neutral-900);
  --tw-prose-pre-code: var(--color-neutral-200);
  --tw-prose-pre-bg: var(--color-neutral-800);
  --tw-prose-th-borders: var(--color-neutral-300);
  --tw-prose-td-borders: var(--color-neutral-200);
  --tw-prose-invert-body: var(--color-neutral-300);
  --tw-prose-invert-headings: var(--color-white);
  --tw-prose-invert-lead: var(--color-neutral-400);
  --tw-prose-invert-links: var(--color-white);
  --tw-prose-invert-bold: var(--color-white);
  --tw-prose-invert-counters: var(--color-neutral-400);
  --tw-prose-invert-bullets: var(--color-neutral-600);
  --tw-prose-invert-hr: var(--color-neutral-700);
  --tw-prose-invert-quotes: var(--color-neutral-100);
  --tw-prose-invert-quote-borders: var(--color-neutral-700);
  --tw-prose-invert-captions: var(--color-neutral-400);
  --tw-prose-invert-kbd: var(--color-white);
  --tw-prose-invert-kbd-shadows: var(--color-white);
  --tw-prose-invert-code: var(--color-white);
  --tw-prose-invert-pre-code: var(--color-neutral-300);
  --tw-prose-invert-pre-bg: rgb(0 0 0 / 50%);
  --tw-prose-invert-th-borders: var(--color-neutral-600);
  --tw-prose-invert-td-borders: var(--color-neutral-700);
}
.prose-a\:text-primary :is(a):not(:where([class~='not-prose'],[class~='not-prose'] *)) {
  color: var(--color-primary);
}
@property --tw-font-weight {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-x {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-y {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-z {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-x {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-y {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-inset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-ring-inset {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-offset-width {
  syntax: "<length>";
  inherits: false;
  initial-value: 0px;
}
@property --tw-ring-offset-color {
  syntax: "*";
  inherits: false;
  initial-value: #fff;
}
@property --tw-ring-offset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-sepia {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-drop-shadow-size {
  syntax: "*";
  inherits: false;
}
@layer properties {
  @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))) {
    *, ::before, ::after, ::backdrop {
      --tw-font-weight: initial;
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-shadow: 0 0 #0000;
      --tw-shadow-color: initial;
      --tw-shadow-alpha: 100%;
      --tw-inset-shadow: 0 0 #0000;
      --tw-inset-shadow-color: initial;
      --tw-inset-shadow-alpha: 100%;
      --tw-ring-color: initial;
      --tw-ring-shadow: 0 0 #0000;
      --tw-inset-ring-color: initial;
      --tw-inset-ring-shadow: 0 0 #0000;
      --tw-ring-inset: initial;
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-offset-shadow: 0 0 #0000;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
    }
  }
}
