/* News / press — uses LP design tokens only */

.news-nav .nav-links a.is-active {
  color: var(--fg);
  background: var(--surface-hover);
}

.news-page {
  background: var(--bg);
  color: var(--fg);
}

.news-main {
  padding: calc(72px + var(--space-12)) 0 var(--space-16);
  min-height: 60vh;
}

.news-index-head {
  margin-bottom: var(--space-8);
}

.news-index-head .eyebrow {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-cap);
  text-transform: uppercase;
  color: var(--fg-subtle);
  margin-bottom: var(--space-3);
}

.news-index-head .h-section {
  margin-bottom: var(--space-4);
}

.news-filter {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-8);
}

.news-filter-btn {
  display: inline-flex;
  align-items: center;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-pill);
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--fg-muted);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  text-decoration: none;
  transition: background var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out);
}

.news-filter-btn:hover {
  background: var(--surface-hover);
  color: var(--fg);
}

.news-filter-btn.is-active {
  border-color: var(--brand);
  color: var(--fg);
  background: var(--chalk-100);
}

.news-grid {
  display: grid;
  gap: var(--space-4);
}

@media (min-width: 720px) {
  .news-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.news-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  transition: border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}

.news-card:hover {
  border-color: var(--border-strong);
  box-shadow: var(--shadow-sm);
}

.news-card-link {
  display: block;
  padding: var(--space-6);
  text-decoration: none;
  color: inherit;
  height: 100%;
}

.news-card-meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
  flex-wrap: wrap;
}

.news-pill {
  display: inline-flex;
  align-items: center;
  padding: 2px var(--space-3);
  border-radius: var(--radius-sm);
  background: var(--chalk-100);
  color: var(--fg-muted);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-wide);
}

.news-date {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-size: var(--fs-sm);
  color: var(--fg-subtle);
}

.news-card-title {
  font-family: var(--font-jp);
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-tight);
  line-height: var(--lh-snug);
  margin: 0 0 var(--space-3);
  color: var(--fg);
}

.news-card-excerpt {
  font-size: var(--fs-sm);
  color: var(--fg-muted);
  line-height: var(--lh-loose);
  margin: 0 0 var(--space-4);
}

.news-card-more {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--brand);
}

.news-card.is-hidden {
  display: none;
}

.news-empty {
  color: var(--fg-muted);
  padding: var(--space-8) 0;
}

/* Article */
.news-breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-sm);
  color: var(--fg-subtle);
  margin-bottom: var(--space-6);
}

.news-breadcrumb a {
  color: var(--fg-muted);
  text-decoration: none;
}

.news-breadcrumb a:hover {
  color: var(--fg);
}

.news-article-head {
  margin-bottom: var(--space-8);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--border);
}

.news-article-meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-bottom: var(--space-4);
}

.news-article-title {
  font-family: var(--font-jp);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-black);
  letter-spacing: var(--tracking-tight);
  line-height: var(--lh-tight);
  margin: 0;
}

@media (min-width: 720px) {
  .news-article-title {
    font-size: var(--fs-3xl);
  }
}

.news-article-dek {
  margin: var(--space-4) 0 0;
  font-size: var(--fs-md);
  color: var(--fg-muted);
  line-height: var(--lh-loose);
  max-width: 78ch;
}

.news-prose {
  max-width: 78ch;
  font-family: var(--font-jp);
  font-size: var(--fs-base);
  line-height: var(--lh-loose);
  color: var(--fg-muted);
}

.news-prose > *:first-child {
  margin-top: 0;
}

.news-prose h2 {
  font-family: var(--font-jp);
  font-size: var(--fs-xl);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-tight);
  color: var(--fg);
  margin: var(--space-10) 0 var(--space-4);
  line-height: var(--lh-snug);
}

.news-prose h3 {
  font-size: var(--fs-lg);
  font-weight: var(--fw-semibold);
  color: var(--fg);
  margin: var(--space-8) 0 var(--space-3);
}

.news-prose p {
  margin: 0 0 var(--space-4);
}

.news-prose ul,
.news-prose ol {
  margin: 0 0 var(--space-4);
  padding-left: var(--space-6);
}

.news-prose li {
  margin-bottom: var(--space-2);
}

.news-prose a {
  color: var(--brand);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.news-prose a:hover {
  color: var(--court-600);
}

.news-prose strong {
  color: var(--fg);
  font-weight: var(--fw-semibold);
}

.news-prose hr {
  border: none;
  border-top: 1px solid var(--border);
  margin: var(--space-10) 0;
}

.news-prose blockquote {
  margin: var(--space-6) 0;
  padding: var(--space-4) var(--space-5);
  border-left: 3px solid var(--accent);
  background: var(--bg-sunken);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  color: var(--fg);
}

.news-article-nav {
  display: grid;
  gap: var(--space-4);
  margin-top: var(--space-12);
  padding-top: var(--space-8);
  border-top: 1px solid var(--border);
}

@media (min-width: 720px) {
  .news-article-nav {
    grid-template-columns: 1fr 1fr;
  }
}

.news-article-nav-link {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-5);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
  text-decoration: none;
  transition: border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}

.news-article-nav-link:hover {
  border-color: var(--border-strong);
  box-shadow: var(--shadow-xs);
}

.news-article-nav-link .label {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-wide);
  color: var(--fg-subtle);
  text-transform: uppercase;
}

.news-article-nav-link .title {
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  color: var(--fg);
  line-height: var(--lh-snug);
}

.news-article-nav-link--next {
  text-align: right;
}

.news-back {
  margin-top: var(--space-8);
  font-size: var(--fs-sm);
}

.news-back a {
  color: var(--fg-muted);
  text-decoration: none;
  font-weight: var(--fw-semibold);
}

.news-back a:hover {
  color: var(--fg);
}

/* 参加方法 3ステップリスト */
.news-prose ol.news-steps {
  list-style: none;
  padding: 0;
  margin: var(--space-5) 0;
  counter-reset: news-step;
  display: grid;
  gap: var(--space-3);
}

.news-prose ol.news-steps > li {
  counter-increment: news-step;
  position: relative;
  padding: var(--space-4) var(--space-5) var(--space-4) calc(var(--space-5) + 36px);
  background: var(--bg-soft, #f7f8f6);
  border-radius: var(--radius-md, 12px);
  font-size: var(--fs-base);
  line-height: var(--lh-relaxed);
}

.news-prose ol.news-steps > li::before {
  content: counter(news-step);
  position: absolute;
  left: var(--space-4);
  top: var(--space-4);
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--court-500, #1c2b3a);
  color: #fff;
  border-radius: 50%;
  font-family: var(--font-num, var(--font-jp));
  font-weight: var(--fw-bold);
  font-size: 13px;
  letter-spacing: 0;
}

.news-prose .news-callout {
  margin: var(--space-5) 0;
  padding: var(--space-4) var(--space-5);
  border-left: 3px solid var(--court-300, #c4e030);
  background: rgba(196, 224, 48, 0.08);
  font-size: var(--fs-sm);
  color: var(--fg);
  border-radius: 0 var(--radius-sm, 6px) var(--radius-sm, 6px) 0;
}

/* β募集 申し込みCTAブロック */
.news-apply-cta {
  margin: var(--space-10) 0 var(--space-6);
  border-radius: var(--radius-lg, 16px);
  background: linear-gradient(180deg, #1c2b3a 0%, #243a4d 100%);
  color: #fff;
  overflow: hidden;
  position: relative;
}

.news-apply-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(800px 200px at 100% -10%, rgba(196, 224, 48, 0.18), transparent 60%),
    radial-gradient(600px 200px at -10% 110%, rgba(204, 74, 114, 0.14), transparent 60%);
  pointer-events: none;
}

.news-apply-cta-inner {
  position: relative;
  padding: var(--space-8) var(--space-7);
  display: grid;
  gap: var(--space-3);
}

.news-apply-eyebrow {
  margin: 0;
  font-size: 11px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--court-300, #c4e030);
}

.news-apply-title {
  margin: 0;
  font-size: var(--fs-2xl);
  line-height: var(--lh-tight);
  font-weight: var(--fw-bold);
}

.news-apply-lede {
  margin: 0;
  font-size: var(--fs-base);
  color: rgba(255, 255, 255, 0.78);
  line-height: var(--lh-relaxed);
}

.news-apply-actions {
  margin-top: var(--space-3);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.news-apply-note {
  margin: var(--space-3) 0 0;
  font-size: var(--fs-xs);
  color: rgba(255, 255, 255, 0.6);
}

.news-apply-note a {
  color: rgba(255, 255, 255, 0.85);
  text-decoration: underline;
  text-underline-offset: 2px;
}
