:root { --bg:#ffffff; --text:#111827; --muted:#6b7280; --border:#e5e7eb; --accent:#f97316; --accent-soft:#fff7ed; }
* { box-sizing:border-box; }
body { margin:0; background:var(--bg); color:var(--text); font:18px/1.74 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif; }
.wrap { max-width:940px; margin:0 auto; padding:40px 20px 72px; }
.crumbs { font-size:14px; color:var(--muted); margin-bottom:18px; }
.crumbs a { color:inherit; text-decoration:none; }
h1 { font-size:42px; line-height:1.15; margin:0 0 18px; letter-spacing:-0.02em; }
h2 { font-size:28px; line-height:1.25; margin:40px 0 14px; letter-spacing:-0.01em; }
p { margin:0 0 18px; }
a { color:var(--accent); text-decoration-thickness:1px; text-underline-offset:2px; }
.meta { font-size:15px; color:var(--muted); margin:0 0 10px; }
.lang-switch { font-size:14px; color:var(--muted); margin:0 0 26px; }
.lang-switch a { color:inherit; }
.intro { max-width:760px; }
.group { margin-top:36px; }
.cards { display:grid; grid-template-columns:1fr; gap:14px; margin:18px 0 0; }
.card { border:1px solid var(--border); border-radius:16px; padding:16px 18px; background:#fff; }
.card-top { display:flex; flex-wrap:wrap; gap:8px; align-items:center; margin-bottom:8px; }
.badge { display:inline-flex; align-items:center; min-height:24px; padding:4px 10px; border-radius:999px; background:var(--accent-soft); color:#9a3412; font-size:12px; font-weight:600; letter-spacing:.02em; }
.date { font-size:13px; color:var(--muted); }
.card h3 { font-size:23px; line-height:1.34; margin:0 0 8px; }
.card p { color:#374151; margin:0 0 14px; font-size:16px; }
.card .more { display:inline-flex; align-items:center; gap:6px; font-size:15px; font-weight:600; text-decoration:none; }
.note { background:var(--accent-soft); border:1px solid #fed7aa; border-radius:14px; padding:16px 18px; margin:26px 0; }
.contact-card { border:1px solid var(--border); border-radius:16px; padding:18px; margin-top:28px; }
.empty { border:1px dashed var(--border); border-radius:16px; padding:18px; color:var(--muted); }
@media (max-width: 720px) {
  body { font-size:17px; }
  .wrap { padding-top:28px; }
  h1 { font-size:34px; }
  h2 { font-size:25px; }
  .card h3 { font-size:20px; }
}

.card-media { overflow: hidden; border-radius: 14px; margin: 0 0 14px; }
.card-media img { display:block; width:100%; max-height:420px; object-fit:cover; border-radius:14px; }
.card-media video { display:block; width:100%; max-height:420px; border-radius:14px; background:#000; }
.card-media-audio { padding-top: 4px; }
.card-media audio { width:100%; }


.card h3 a { color:inherit; text-decoration:none; }
.card h3 a:hover { text-decoration:underline; text-decoration-color:var(--accent); }
.card-actions { display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
.card .more-secondary { color:var(--muted); font-size:14px; }
.blog-post { max-width:820px; }
.news-article .hero-media { margin:22px 0 24px; overflow:hidden; border-radius:22px; border:1px solid var(--border); background:#fff; }
.news-article .hero-media img { display:block; width:100%; height:auto; }
.news-article .hero-media video { display:block; width:100%; max-height:560px; background:#000; }
.news-article .hero-media.audio { padding:16px; }
.news-article .hero-media audio { width:100%; }
.news-article .article-meta { display:flex; flex-wrap:wrap; gap:8px 12px; align-items:center; margin:0 0 12px; }
.news-article .article-body { font-size:18px; color:#1f2937; }
.news-article .article-body p { margin:0 0 18px; }
.news-article .cta-row { display:flex; flex-wrap:wrap; gap:12px; margin:28px 0 0; }
.news-article .cta-button { display:inline-flex; align-items:center; justify-content:center; min-height:44px; padding:12px 18px; border-radius:999px; background:var(--accent); color:#fff; text-decoration:none; font-weight:700; }
.news-article .cta-button:hover { opacity:.93; }
.news-article .cta-link { display:inline-flex; align-items:center; min-height:44px; color:var(--accent); text-decoration:none; font-weight:600; }
.news-article .news-home-link { margin-top:26px; padding-top:22px; border-top:1px solid var(--border); }
@media (max-width: 720px) {
  .news-article .cta-row { flex-direction:column; align-items:flex-start; }
  .news-article .cta-button, .news-article .cta-link { width:auto; }
}

/* ORI_NEWS_SOCIAL_PATCH_20260419 */
.news-social-line {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--border);
}
.news-social-label {
  font-size: 13px;
  font-weight: 700;
  color: var(--muted);
}
.news-social-btn {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 34px;
  padding: 7px 12px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: #fff;
  color: var(--text);
  font: 600 14px/1.2 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  cursor: pointer;
}
.news-social-btn:hover,
.news-social-btn:focus-visible {
  background: #f8fafc;
  outline: none;
  border-color: #d1d5db;
}
.news-social-primary {
  background: var(--text);
  border-color: var(--text);
  color: #fff;
}
.news-social-primary:hover,
.news-social-primary:focus-visible {
  background: #1f2937;
  border-color: #1f2937;
}
.news-like-btn { min-width: 58px; }
.news-like-heart { font-size: 15px; line-height: 1; }
.news-like-btn.is-liked {
  border-color: #fecdd3;
  background: #fff1f2;
  color: #be123c;
}
.news-like-btn[disabled] {
  opacity: .68;
  cursor: wait;
}
@media (max-width: 720px) {
  .card-actions { gap: 10px; }
  .news-social-line { gap: 7px; }
  .news-social-btn { min-height: 36px; }
}
