:root {
  --bg: #f6f2ea;
  --surface: #fffdf9;
  --surface-2: #fff8f0;
  --line: #e3dacd;
  --text: #4f4336;
  --muted: #6a5d50;
  --accent: #b85c4b;
  --accent-dark: #8f4539;
  --sage: #d8e3dc;
  --container: 1180px;
  --radius: 28px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
/*  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Yu Gothic", sans-serif; */
  font-family: "Noto Serif JP","Yu Mincho","Hiragino Mincho ProN", serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.8;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
.container { width: min(calc(100% - 32px), var(--container)); margin: 0 auto; }
.section { padding: 72px 0; }
.section-asa  { padding: 10px 0 72px; }
.section-muted { background: #f3ede4; }
.section-accent { background: linear-gradient(135deg, #f5eee4 0%, #ecf3ef 100%); }
.section-newsstrip { padding-top: 32px; }
.section-spacer { padding: 80px 0; }
.eyebrow { margin: 0 0 10px; font-size: 12px; letter-spacing: .18em; color: var(--accent); text-transform: uppercase; }
h1,h2,h3,p { margin-top: 0; }
.site-header {
  position: sticky; top: 0; z-index: 20;
  background: rgba(255,253,249,.92); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}
.header-inner { display:flex; align-items:center; justify-content:space-between; gap:20px; padding:18px 0; }
.site-title { display:block; font-size: 28px; font-weight: 700; }
.site-description { margin:4px 0 0; font-size: 13px; color: var(--muted); }
.site-nav { display:flex; align-items:center; gap:20px; }
.site-nav ul { display:flex; list-style:none; gap:18px; padding:0; margin:0; }
.menu-toggle { display:none; }
.button {
  display:inline-flex; align-items:center; justify-content:center;
  min-height: 48px; padding: 0 22px; border-radius: 999px; font-weight: 700;
  border: 1px solid transparent; transition: .2s ease;
}
.button:hover { transform: translateY(-1px); }
.button-primary { background: var(--accent); color: #fff; }
.button-secondary { background: rgba(255,250,244,.75); color: var(--text); border-color: #ccb8a0; }
.header-cta { margin-left: 8px; }
.hero { position: relative; }
.hero-slider { position: relative; }
.hero-slide {
  position: absolute; inset: 0; min-height: 680px;
  background-size: cover; background-position: center;
  opacity: 0; visibility: hidden; transition: opacity .6s ease;
}
.hero-slide.is-active { position: relative; opacity:1; visibility: visible; }
.hero-overlay {
  position:absolute; inset:0;
  background:
    radial-gradient(circle at 18% 22%, rgba(255,255,255,.35), transparent 28%),
    linear-gradient(to right, rgba(96,72,48,.58) 0%, rgba(96,72,48,.34) 38%, rgba(96,72,48,.14) 62%, rgba(96,72,48,.22) 100%);
}
.hero-content {
  position: relative; min-height: 680px; display:flex; flex-direction:column; justify-content:flex-end;
  padding-bottom: 84px; color: #fff;
}
.hero-subtitle {
  display:inline-flex; width: fit-content; margin-bottom: 18px; padding: 6px 14px;
  border-radius: 999px; background: rgba(255,255,255,.22); border: 1px solid rgba(255,255,255,.35);
  backdrop-filter: blur(8px);
}
.hero-title { max-width: 760px; font-size: clamp(36px, 6vw, 64px); line-height: 1.2; margin-bottom: 18px; }
.hero-text { max-width: 700px; font-size: 17px; color: rgba(255,255,255,.92); }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; margin-top: 28px; }
.hero-dots {
  position:absolute; left:0; right:0; bottom:32px; z-index: 2;
  display:flex; gap:10px;
}
.hero-dot { width: 12px; height: 12px; border-radius: 999px; border:none; background: rgba(255,255,255,.45); cursor:pointer; }
.hero-dot.is-active { width: 40px; background: var(--accent); }
.grid-2, .grid-3, .grid-4 { display:grid; gap:24px; }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.card, .single-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 28px;
  box-shadow: 0 10px 30px rgba(92,73,46,.05);
}
.soft-card { background: rgba(255,255,255,.75); }
.action-card { min-height: 240px; }
.text-link { font-weight: 700; color: var(--accent-dark); }
.news-list, .closure-list, .check-list { list-style:none; padding:0; margin:0; }
.news-list li + li, .closure-list li + li { margin-top: 14px; }
.news-list a { display:flex; flex-direction:column; gap:4px; padding-bottom: 14px; border-bottom:1px solid #f0e7db; }
.news-date, .meta { color: var(--muted); font-size: 14px; }
.badge {
  display:inline-flex; margin: 10px 0 14px; padding: 4px 10px;
  border-radius: 999px; background: #f3e2dc; color: var(--accent-dark); font-size: 13px; font-weight:700;
}
.paper-thumb { margin-bottom: 16px; overflow:hidden; border-radius: 18px; }
.paper-thumb img { width:100%; aspect-ratio: 4 / 3; object-fit: cover; }
.paper-links { display:flex; flex-wrap:wrap; gap:14px; margin-top: 16px; }
.area-block + .area-block { margin-top: 56px; }
.area-title { margin-bottom: 18px; font-size: 28px; }
.single-wrap { max-width: 900px; }
.single-thumb { margin: 18px 0 28px; overflow:hidden; border-radius: 22px; }
.single-thumb img { width:100%; }
.detail-list { margin: 0 0 24px; }
.detail-list div { display:grid; grid-template-columns: 140px 1fr; padding: 14px 0; border-bottom:1px solid #efe6da; }
.detail-list dt { font-weight: 700; }
.entry-content p + p { margin-top: 1em; }
.button-group { display:flex; gap:12px; flex-wrap:wrap; margin-top: 28px; }
.site-footer { background: #fbf8f2; border-top:1px solid var(--line); padding-top: 28px; }
.footer-grid { display:grid; grid-template-columns: 1fr auto; gap:24px; padding-bottom: 18px; }
.footer-title { font-size: 20px; font-weight:700; margin-bottom: 6px; }
.footer-text, .footer-copy { color: var(--muted); }
.footer-copy { padding: 12px 0 24px; border-top:1px solid #efe6da; }
@media (max-width: 960px) {
  .grid-3, .grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .hero-slide, .hero-content { min-height: 620px; }
  .site-nav { gap:14px; }
}
@media (max-width: 768px) {
  .menu-toggle {
    display:inline-flex; min-height: 42px; border-radius:999px; border:1px solid var(--line); background:#fff; padding:0 16px;
  }
  .site-nav {
    display:none; position:absolute; left:16px; right:16px; top:80px; flex-direction:column; align-items:flex-start;
    background:#fffdf9; border:1px solid var(--line); border-radius:24px; padding:18px;
  }
  .site-nav.is-open { display:flex; }
  .site-nav ul { flex-direction:column; width:100%; }
  .header-inner { position:relative; }
  .grid-2, .grid-3, .grid-4, .footer-grid { grid-template-columns: 1fr; }
  .hero-slide, .hero-content { min-height: 560px; }
  .hero-content { padding-bottom: 74px; }
  .hero-title { font-size: 34px; }
  .section { padding: 56px 0; }
  .card, .single-card { padding: 22px; }
  .detail-list div { grid-template-columns: 1fr; gap: 6px; }
}

.site-branding { display:flex; align-items:center; gap:14px; min-width:0; }
.site-brand-text { min-width:0; }
.site-logo img { max-height:56px; width:auto; }
.site-title { line-height:1.25; text-decoration:none; }
.hero-fallback { position:relative; min-height:680px; background-size:cover; background-position:center; }
.hero-fallback .hero-content { position:relative; }
.site-nav .menu { display:flex; list-style:none; gap:18px; padding:0; margin:0; }
.site-nav .menu li { list-style:none; }
.site-nav .menu a { color:var(--text); font-weight:500; }
.site-nav .menu a:hover { color:var(--accent-dark); }
@media (max-width: 768px) {
  .site-branding { align-items:flex-start; }
  .site-title { font-size:22px; }
  .site-nav .menu { flex-direction:column; width:100%; }
}

.lead { font-size: 16px; color: var(--muted); max-width: 760px; }
.asa-archive-hero { border-bottom: 1px solid var(--line); }
.asa-archive-hero__inner { display: grid; grid-template-columns: 1fr auto; gap: 24px; align-items: end; }
.asa-area-nav { display:flex; flex-wrap:wrap; gap:12px; margin-bottom:40px; }
.asa-area-chip {
  display:inline-flex; align-items:center; justify-content:center; min-height:44px; padding:0 18px;
  border:1px solid var(--line); border-radius:999px; background:var(--surface); font-weight:700; color:var(--accent-dark);
}
.asa-list-grid { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:24px; }
.asa-list-card__head { display:flex; align-items:flex-start; justify-content:space-between; gap:14px; margin-bottom:10px; }
.asa-list-card__head h3 { margin:0; font-size:24px; }
.compact-detail-list { margin-bottom: 18px; }
.compact-detail-list div { grid-template-columns: 110px 1fr; padding: 10px 0; }
.store-button-group .button { min-height: 42px; padding: 0 18px; }
.check-list li + li { margin-top: 8px; }
@media (max-width: 960px) {
  .asa-list-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .asa-archive-hero__inner { grid-template-columns: 1fr; align-items: start; }
}

.header-link { font-weight: 700; color: var(--accent-dark); }
.info-grid { display:grid; grid-template-columns: 1.15fr .85fr; gap:24px; }
.info-card { min-height: 250px; }
.section-head-inline { display:flex; align-items:end; justify-content:space-between; gap:24px; margin-bottom:24px; }
.refined-card { min-height: 220px; background: linear-gradient(180deg, #fffdf9 0%, #fff9f2 100%); }
.card h3 { margin-bottom: 10px; }
.split-feature { display:grid; grid-template-columns: .9fr 1.1fr; gap:32px; align-items:start; }
.split-feature-reverse { grid-template-columns: 1.05fr .95fr; }
.store-mini-grid { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap:20px; }
.compact-store-card { min-height: 100%; }
.card-kicker { margin: 0 0 10px; font-size: 12px; letter-spacing: .14em; color: var(--accent); text-transform: uppercase; }
.store-card-footer { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-top:14px; }
.horizontal-paper-card { display:flex; align-items:flex-start; justify-content:space-between; gap:18px; }
.paper-stack { display:grid; gap:18px; }
.paper-meta-wrap { min-width: 120px; text-align:right; }
.final-cta-card { display:flex; align-items:center; justify-content:space-between; gap:28px; background: linear-gradient(135deg, #f6efe6 0%, #edf4ef 100%); }
.final-cta-card h2 { margin-bottom: 8px; }
@media (max-width: 960px) {
  .info-grid, .split-feature, .split-feature-reverse, .store-mini-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .section-head-inline, .final-cta-card, .horizontal-paper-card { display:block; }
  .paper-meta-wrap { min-width: 0; text-align:left; margin-top: 12px; }
  .header-link { display:none; }
}

/* v6 refresh */
.header-inner{padding:16px 0;}
.site-title{font-size:30px;}
.site-nav{gap:28px;}
.menu-main{display:flex;list-style:none;gap:18px;padding:0;margin:0;}
.menu-utility{display:flex;align-items:center;gap:16px;}
.header-link{display:inline-flex;font-weight:700;color:var(--accent-dark);}
.hero-clean .hero-slide,.hero-clean .hero-fallback,.hero-clean .hero-content{min-height:620px;}
.hero-content-clean{justify-content:center;padding:110px 0 90px;color:#fff;}
.hero-panel{max-width:720px;padding:40px;border-radius:28px;background:rgba(91,70,48,.18);backdrop-filter:blur(10px);box-shadow:0 20px 45px rgba(68,50,32,.10);}
.hero-clean .hero-subtitle{background:rgba(255,255,255,.18);}
.section-overlap{padding-top:0;margin-top:-42px;position:relative;z-index:3;}
.top-summary-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;}
.top-summary-card{padding:30px;}
.compact-head h2{margin-bottom:0;}
.simple-list a{display:flex;gap:14px;align-items:flex-start;padding:12px 0;border-bottom:1px solid #eee3d5;}
.simple-list .news-date{min-width:86px;}
.compact-closure-list li{padding:12px 0;border-bottom:1px solid #eee3d5;}
.feature-band{display:grid;grid-template-columns:1.15fr .85fr;gap:28px;align-items:stretch;}
.feature-band__main{padding:34px 38px;border-radius:var(--radius);background:linear-gradient(135deg,#f8f2e9 0%,#eef3ee 100%);border:1px solid var(--line);}
.feature-band__main h2{font-size:34px;margin-bottom:12px;}
.feature-band__side{display:flex;flex-direction:column;justify-content:center;min-height:100%;}
.store-table-preview-wrap,.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:24px;background:#fff;box-shadow:0 10px 30px rgba(92,73,46,.04);}
.store-table{width:100%;border-collapse:collapse;min-width:760px;}
.store-table th,.store-table td{padding:14px 18px;border-bottom:1px solid #efe6da;text-align:left;vertical-align:top;line-height:1.7;}
.store-table thead th{background:#faf6ef;color:var(--accent-dark);font-size:16px;font-weight:700;}
.store-table tbody tr:hover{background:#fffaf5;}
.store-table-preview{min-width:0;}
.store-table-preview th:nth-child(2),.store-table-preview td:nth-child(2){width:42%;}
.badge-inline{margin:0 0 0 10px;vertical-align:middle;}
.paper-inline-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;}
.paper-inline-card{padding:26px;border-radius:24px;border:1px solid var(--line);background:#fff;box-shadow:0 10px 30px rgba(92,73,46,.04);}
.paper-inline-card h3{margin-bottom:8px;}
.asa-area-nav{position:sticky;top:88px;z-index:4;padding:14px 0 8px;background:linear-gradient(to bottom, rgba(249,246,240,.98), rgba(249,246,240,.85), rgba(249,246,240,0));}
.area-block + .area-block{margin-top:44px;}
@media (max-width: 960px){
  .top-summary-grid,.feature-band,.paper-inline-grid{grid-template-columns:1fr;}
}
@media (max-width: 768px){
  .site-nav{display:none;position:absolute;left:16px;right:16px;top:76px;flex-direction:column;align-items:flex-start;background:#fffdf9;border:1px solid var(--line);border-radius:24px;padding:18px;}
  .site-nav.is-open{display:flex;}
  .menu-main{flex-direction:column;width:100%;}
  .menu-utility{width:100%;flex-direction:column;align-items:flex-start;gap:12px;}
  .header-link{display:inline-flex;}
  .hero-clean .hero-slide,.hero-clean .hero-fallback,.hero-clean .hero-content{min-height:500px;}
  .hero-content-clean{padding:88px 0 60px;}
  .hero-panel{padding:28px 22px;}
  .section-overlap{margin-top:-24px;}
  .feature-band__main h2{font-size:28px;}
}

/* v8 top page refinement */
.top-hero-section{
  padding:40px 0 24px;
  background:linear-gradient(180deg,#fbf8f2 0%,#f6f1e9 100%);
}
.top-hero-grid{
  display:grid;
  grid-template-columns:minmax(0,0.92fr) minmax(0,1.08fr);
  gap:32px;
  align-items:stretch;
}
.top-hero-copy{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:18px 0;
}
.top-hero-copy h1{
  font-size:56px;
  line-height:1.18;
  margin-bottom:18px;
}
.top-hero-copy .lead{
  max-width:560px;
  font-size:17px;
  line-height:1.9;
}
.top-hero-actions{margin-top:30px;}
.top-hero-visual{
  padding:16px;
  background:#fff;
  box-shadow:0 16px 40px rgba(92,73,46,.06);
}
.hero-slider-clean{position:relative; min-height:560px; border-radius:22px; overflow:hidden;}
.hero-slide-clean{position:absolute; inset:0; opacity:0; transition:opacity .5s ease; background-size:cover; background-position:center;}
.hero-slide-clean.is-active{opacity:1; z-index:1;}
.hero-overlay-soft{background:linear-gradient(to top, rgba(53,40,28,.52) 0%, rgba(53,40,28,.18) 45%, rgba(53,40,28,.06) 100%);}
.hero-visual-caption{
  position:absolute;
  left:26px;
  right:26px;
  bottom:24px;
  z-index:2;
  padding:22px 24px;
  border-radius:20px;
  background:rgba(255,253,249,.84);
  backdrop-filter:blur(8px);
  color:var(--text);
}
.hero-visual-caption h2{margin:6px 0 10px; font-size:30px; line-height:1.3;}
.hero-visual-kicker{margin:0; font-size:12px; letter-spacing:.14em; color:var(--accent); text-transform:uppercase;}
.hero-dots-inside{position:absolute; right:18px; bottom:18px; z-index:3; display:flex; gap:10px;}
.hero-empty-state{display:grid; grid-template-columns:1.1fr .9fr; min-height:560px; overflow:hidden; border-radius:22px; background:#fffaf4;}
.hero-empty-state__image{background-size:cover; background-position:center; min-height:100%;}
.hero-empty-state__body{padding:34px; display:flex; flex-direction:column; justify-content:center;}
.section-tight-top{padding-top:24px;}
.quick-links-grid{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:22px;}
.quick-link-card{
  display:block;
  padding:28px;
  border:1px solid var(--line);
  border-radius:26px;
  background:#fff;
  box-shadow:0 10px 30px rgba(92,73,46,.04);
}
.quick-link-card h2{margin:0 0 10px; font-size:28px;}
.quick-link-card p{margin-bottom:14px; color:var(--muted);}
.section-light{background:#faf7f1;}
.info-panels-grid{display:grid; grid-template-columns:1.15fr .85fr; gap:24px;}
.info-panel{min-height:100%;}
.news-list-clean a{display:grid; grid-template-columns:110px 1fr; gap:18px; align-items:start; padding:14px 0; border-bottom:1px solid #efe6da;}
.closure-list-boxed li{
  padding:16px 18px;
  border:1px solid #efe6da;
  border-radius:16px;
  background:#fffdf9;
}
.closure-list-boxed li + li{margin-top:12px;}
.section-lead-narrow{max-width:640px; margin:8px 0 0;}
.table-wrap-hero{box-shadow:0 12px 32px rgba(92,73,46,.05);}
.paper-inline-grid-4{grid-template-columns:repeat(4,minmax(0,1fr));}
.paper-inline-card-clean{background:#fffdf9;}
.final-cta-card-clean{
  align-items:center;
  background:linear-gradient(135deg,#f7efe5 0%,#eef3ef 100%);
  border:1px solid var(--line);
}
@media (max-width: 1080px){
  .top-hero-grid,
  .info-panels-grid,
  .paper-inline-grid-4,
  .quick-links-grid{grid-template-columns:1fr 1fr;}
  .top-hero-grid{grid-template-columns:1fr;}
}
@media (max-width: 768px){
  .top-hero-section{padding:24px 0 8px;}
  .top-hero-copy h1{font-size:38px;}
  .top-hero-copy .lead{font-size:15px; line-height:1.8;}
  .hero-slider-clean,
  .hero-empty-state{min-height:420px;}
  .hero-empty-state{grid-template-columns:1fr;}
  .hero-empty-state__image{min-height:180px;}
  .hero-visual-caption{left:16px; right:16px; bottom:16px; padding:16px 18px;}
  .hero-visual-caption h2{font-size:22px;}
  .quick-links-grid,
  .info-panels-grid,
  .paper-inline-grid-4{grid-template-columns:1fr;}
  .news-list-clean a{grid-template-columns:1fr; gap:4px;}
}

/* v9 refinement */
.top-hero-v2{
  position:relative;
  background:#f7f2e9;
}
.hero-slider-v2,
.hero-fallback-v2{
  position:relative;
  min-height:560px;
}
.hero-slide-v2,
.hero-fallback-v2{
  position:relative;
  min-height:560px;
  background-size:cover;
  background-position:center center;
  overflow:hidden;
}
.hero-slide-v2:not(.is-active){display:none;}
.hero-slide-v2__overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(53,40,28,.70) 0%, rgba(53,40,28,.50) 36%, rgba(53,40,28,.18) 70%, rgba(53,40,28,.10) 100%);
}
.hero-slide-v2__inner{
  position:relative;
  z-index:2;
  display:flex;
  align-items:center;
  min-height:560px;
  padding-top:48px;
  padding-bottom:48px;
}
.hero-copy-v2{
  max-width:620px;
  color:#fff;
}
.hero-kicker-v2{
  display:inline-flex;
  margin:0 0 18px;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.15);
  color:#fff;
  font-size:12px;
  letter-spacing:.12em;
}
.hero-copy-v2 h1{
  margin:0 0 18px;
  color:#fff;
  font-size:60px;
  line-height:1.15;
}
.hero-copy-v2 p{
  max-width:540px;
  font-size:16px;
  line-height:1.9;
  color:rgba(255,255,255,.92);
}
.hero-actions-v2{margin-top:28px;}
.hero-dots-v2{
  position:absolute;
  left:50%;
  bottom:22px;
  transform:translateX(-50%);
  z-index:3;
  display:flex;
  gap:10px;
}
.section-top-info{padding-top:42px;}
.top-info-grid-v2{display:grid;grid-template-columns:1.05fr .95fr;gap:24px;}
.info-panel-v2{min-height:100%;}
.closure-months-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;}
.closure-month-card{
  padding:18px;
  border:1px solid #efe6da;
  border-radius:18px;
  background:#fffdf9;
}
.closure-month-card h3{margin:0 0 10px;font-size:20px;}
.closure-list-plain{margin:0;padding-left:18px;}
.closure-list-plain li{margin:0 0 8px;line-height:1.8;}
.muted-note{margin:0;color:var(--muted);}
.final-cta-card-compact{padding:30px 34px;}
@media (max-width: 960px){
  .top-info-grid-v2,
  .closure-months-grid{grid-template-columns:1fr;}
}
@media (max-width: 768px){
  .hero-slider-v2,
  .hero-fallback-v2,
  .hero-slide-v2,
  .hero-slide-v2__inner{min-height:440px;}
  .hero-copy-v2 h1{font-size:38px;}
  .hero-copy-v2 p{font-size:15px;line-height:1.8;}
  .hero-slide-v2__overlay{background:linear-gradient(180deg, rgba(53,40,28,.64) 0%, rgba(53,40,28,.38) 52%, rgba(53,40,28,.30) 100%);}  
}

/* v10 reference top page */
.top-hero-reference { position: relative; }
.hero-slider-reference { position: relative; }
.hero-slide-reference, .hero-fallback-reference {
  position: absolute; inset: 0; min-height: 540px; background-size: cover; background-position: center center;
  opacity: 0; visibility: hidden; transition: opacity .6s ease;
}
.hero-fallback-reference { position: relative; opacity: 1; visibility: visible; }
.hero-slide-reference.is-active { position: relative; opacity: 1; visibility: visible; }
.hero-slide-reference__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, rgba(22,18,13,.16) 0%, rgba(22,18,13,.22) 25%, rgba(22,18,13,.38) 100%);
}
.hero-slide-reference__inner {
  position: relative; min-height: 540px; display: flex; align-items: center; justify-content: center; text-align: center;
}
.hero-copy-reference { max-width: 780px; color: #fff; padding: 40px 20px; text-shadow: 0 2px 14px rgba(0,0,0,.28); }
.hero-kicker-reference { margin: 0 0 14px; font-size: 14px; letter-spacing: .12em; }
.hero-copy-reference h1 { font-size: clamp(38px, 5vw, 62px); line-height: 1.28; margin-bottom: 16px; font-weight: 500; }
.hero-copy-reference p { margin: 0 auto; max-width: 640px; font-size: 17px; line-height: 1.9; color: rgba(255,255,255,.92); }
.hero-actions-reference { margin-top: 26px; display: flex; justify-content: center; }
.hero-dots-reference { justify-content: center; bottom: 22px; }
.section-reference-info { padding: 54px 0 58px; }
.reference-info-grid { display: grid; grid-template-columns: 360px minmax(0,1fr); gap: 28px; align-items: start; }
.reference-panel { background: #fff; border: 1px solid var(--line); min-height: 260px; padding: 26px 28px; box-shadow: 0 10px 28px rgba(92,73,46,.04); }
.reference-panel h2 { font-size: 34px; line-height: 1.4; margin-bottom: 22px; font-weight: 500; color: #21304a; }
.reference-panel-closure { border-top: 3px solid #d23a35; }
.reference-panel-news { border-top: 3px solid #1d3f77; }
.reference-panel__body { border-top: 1px solid #ece3d6; padding-top: 22px; }
.reference-panel__footer { margin: 18px 0 0; text-align: right; }
.reference-closure-block + .reference-closure-block { margin-top: 18px; padding-top: 18px; border-top: 1px solid #f0e7db; }
.reference-closure-block h3 { margin-bottom: 12px; font-size: 18px; color: var(--muted); font-weight: 500; }
.reference-closure-list { list-style: none; padding: 0; margin: 0; }
.reference-closure-list li { font-size: 18px; font-weight: 700; color: var(--text); margin: 8px 0; }
.reference-news-list { list-style: none; padding: 0; margin: 0; }
.reference-news-list li + li { margin-top: 14px; }
.reference-news-list a { display: flex; gap: 18px; padding-bottom: 14px; border-bottom: 1px solid #f0e7db; }
.section-center-head { text-align: center; margin-bottom: 34px; }
.section-center-head h2 { font-size: 46px; line-height: 1.35; margin-bottom: 12px; color: #21304a; font-weight: 500; }
.section-center-lead { max-width: 760px; margin: 0 auto; color: var(--muted); }
.section-papers-reference { background: #fff; }
.paper-official-links { display: grid; grid-template-columns: repeat(5, minmax(0,1fr)); gap: 12px; }
.paper-official-link { display: flex; align-items: center; justify-content: center; min-height: 82px; padding: 14px 16px; text-align: center; background: #fffdf9; border: 1px solid #ece3d6; color: #54606e; font-weight: 500; }
.paper-official-link:hover { border-color: #ccb8a0; color: var(--accent-dark); }
.section-asa-guide-reference { background: #f7f3ec; }
.asa-guide-reference { text-align: center; padding-top: 6px; padding-bottom: 2px; }
.asa-guide-reference h2 { font-size: 42px; line-height: 1.4; margin-bottom: 14px; color: #21304a; font-weight: 500; }
.asa-guide-reference p { max-width: 760px; margin: 0 auto; color: var(--muted); }
.asa-guide-reference__actions { justify-content: center; margin-top: 26px; }
.button-squareish { border-radius: 0; min-width: 280px; background: transparent; border: 1px solid #73829a; color: #4b5b72; }
.button-squareish:hover { background: #fff; }
@media (max-width: 960px) {
  .reference-info-grid { grid-template-columns: 1fr; }
  .paper-official-links { grid-template-columns: repeat(3, minmax(0,1fr)); }
}
@media (max-width: 768px) {
  .hero-slide-reference, .hero-fallback-reference, .hero-slide-reference__inner { min-height: 430px; }
  .hero-copy-reference h1 { font-size: 34px; }
  .hero-copy-reference p { font-size: 15px; }
  .reference-panel { padding: 22px 20px; }
  .reference-panel h2 { font-size: 28px; }
  .section-center-head h2, .asa-guide-reference h2 { font-size: 30px; }
  .paper-official-links { grid-template-columns: 1fr 1fr; }
  .reference-news-list a { flex-direction: column; gap: 6px; }
}

/* v11 handled paper list */
.paper-archive-page { background: #fbf8f2; }
.paper-archive-head { margin-bottom: 28px; }
.paper-list { border-top: 1px solid var(--line); }
.paper-list-item {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) 220px 280px;
  gap: 24px;
  align-items: center;
  padding: 26px 0;
  border-bottom: 1px solid var(--line);
}
.paper-list-item__title { margin: 0 0 8px; font-size: 28px; line-height: 1.35; }
.paper-list-item__lead { margin: 0; color: var(--muted); }
.paper-list-item__meta {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin: 0;
}
.paper-list-item__meta div {
  padding: 12px 14px;
  border-radius: 16px;
  background: #fffdf9;
  border: 1px solid #eee4d7;
}
.paper-list-item__meta dt { font-size: 12px; color: var(--accent); letter-spacing: .08em; text-transform: uppercase; }
.paper-list-item__meta dd { margin: 6px 0 0; font-weight: 700; color: var(--text); }
.paper-list-item__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px 12px;
}
.paper-list-item__actions .button { min-height: 42px; padding: 0 18px; }
.paper-detail-hero { display: grid; grid-template-columns: minmax(0, 1fr) 280px; gap: 28px; align-items: start; }
.paper-detail-list { margin-top: 0; }
.paper-detail-list div { grid-template-columns: 90px 1fr; }
@media (max-width: 1080px) {
  .paper-list-item { grid-template-columns: minmax(0, 1fr) 200px; }
  .paper-list-item__actions { grid-column: 1 / -1; justify-content: flex-start; }
  .paper-detail-hero { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .paper-list-item {
    grid-template-columns: 1fr;
    gap: 16px;
    padding: 22px 0;
  }
  .paper-list-item__title { font-size: 24px; }
  .paper-list-item__meta { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .paper-list-item__actions { justify-content: flex-start; }
}
@media (max-width: 520px) {
  .paper-list-item__meta { grid-template-columns: 1fr; }
  .paper-list-item__actions .button,
  .paper-list-item__actions .text-link { width: 100%; justify-content: center; text-align: center; }
}

/* v12 handled paper list: one item per row */
.paper-table { border-top: 1px solid var(--line); }
.paper-table__row {
  display: grid;
  grid-template-columns: minmax(180px, 1.1fr) minmax(240px, 2fr) 110px 110px 180px;
  gap: 20px;
  align-items: center;
  padding: 22px 0;
  border-bottom: 1px solid var(--line);
}
.paper-table__row--head {
  padding: 14px 0;
  color: var(--muted);
  font-size: 13px;
  letter-spacing: .08em;
}
.paper-table__title { margin: 0; font-size: 22px; line-height: 1.4; }
.paper-table__lead { margin: 0; color: var(--muted); line-height: 1.9; }
.paper-table__value { font-weight: 700; color: var(--text); }
.paper-table__actions { display: flex; flex-wrap: wrap; gap: 8px 14px; justify-content: flex-end; }
.text-link-strong { font-weight: 700; }

@media (max-width: 1100px) {
  .paper-table__row {
    grid-template-columns: minmax(160px, 1fr) minmax(220px, 1.6fr) 100px 100px 160px;
    gap: 16px;
  }
}
@media (max-width: 768px) {
  .paper-table__head { display: none; }
  .paper-table__row {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 18px 0;
  }
  .paper-table__cell { display: block; }
  .paper-table__cell::before {
    content: attr(data-label);
    display: block;
    margin-bottom: 4px;
    font-size: 12px;
    letter-spacing: .08em;
    color: var(--accent);
  }
  .paper-table__cell--paper::before,
  .paper-table__cell--action::before { margin-bottom: 6px; }
  .paper-table__actions { justify-content: flex-start; }
}

/* v12 closure archive yearly input */
.closure-year-list { display: grid; gap: 24px; }
.closure-year-block__head { margin-bottom: 18px; }
.closure-year-block__head h2 { margin: 0 0 6px; }
.closure-year-block__head p { margin: 0; color: var(--muted); }

/* v13 paper categories */
.paper-category-block + .paper-category-block { margin-top: 44px; }
.paper-category-block__head { margin-bottom: 14px; }
.paper-category-block__head h2 { margin: 0; font-size: 28px; line-height: 1.4; }
.paper-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: #fffdf9;
}
.paper-table-real {
  width: 100%;
  min-width: 980px;
  border-collapse: collapse;
}
.paper-table-real th,
.paper-table-real td {
  padding: 18px 18px;
  border-bottom: 1px solid #efe6da;
  vertical-align: top;
  text-align: left;
}
.paper-table-real thead th {
  background: #faf6ef;
  color: var(--accent-dark);
  font-size: 16px;
  letter-spacing: .06em;
}
.paper-table-real tbody tr:last-child td { border-bottom: none; }
.paper-table-real__title { font-size: 18px; line-height: 1.45; color: var(--text); }
.paper-table-real__lead { color: var(--muted); line-height: 1.9; }
.paper-table-real__value { font-weight: 700; color: var(--text); white-space: nowrap; }
.paper-table-real__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  justify-content: flex-start;
}
.paper-table-real td:nth-child(1) { width: 24%; }
.paper-table-real td:nth-child(2) { width: 11.5%; }
.paper-table-real td:nth-child(3) { width: 12%; }
.paper-table-real td:nth-child(4) { width: 31.5%; }
.paper-table-real td:nth-child(5) { width: 21%; }

@media (max-width: 768px) {
  .paper-table-wrap {
    overflow: visible;
    border: none;
    background: transparent;
  }
  .paper-table-real,
  .paper-table-real thead,
  .paper-table-real tbody,
  .paper-table-real tr,
  .paper-table-real th,
  .paper-table-real td {
    display: block;
    width: 100%;
  }
  .paper-table-real td:nth-child(1),
  .paper-table-real td:nth-child(2),
  .paper-table-real td:nth-child(3),
  .paper-table-real td:nth-child(4),
  .paper-table-real td:nth-child(5) {
    width: 100%;
  }
  .paper-table-real {
    min-width: 0;
  }
  .paper-table-real thead {
    display: none;
  }
  .paper-table-real tr {
    margin-bottom: 16px;
    border: 1px solid var(--line);
    border-radius: 18px;
    background: #fffdf9;
    overflow: hidden;
  }
  .paper-table-real td {
    padding: 14px 16px;
    border-bottom: 1px solid #efe6da;
  }
  .paper-table-real td:last-child {
    border-bottom: none;
  }
  .paper-table-real td::before {
    content: attr(data-label);
    display: block;
    margin-bottom: 4px;
    font-size: 12px;
    letter-spacing: .08em;
    color: var(--accent);
  }
  .paper-table-real__title { font-size: 22px; }
  .paper-table-real__actions {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
}

.company-layout{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:40px;align-items:start;}
.company-panel{background:transparent;border:none;box-shadow:none;padding:0;}
.company-title{margin:0 0 20px;font-size:44px;line-height:1.3;color:var(--accent-dark);padding-bottom:14px;border-bottom:2px solid #d8c7e7;}
.company-copy{font-size:18px;color:var(--text);}
.company-copy p+ p{margin-top:1em;}
.company-table-wrap{margin-top:28px;}
.company-table{width:100%;border-collapse:collapse;background:var(--surface);border:2px solid #c9b2df;}
.company-table th,.company-table td{padding:14px 16px;border:1px solid #c9b2df;vertical-align:top;line-height:1.8;}
.company-table th{width:180px;background:#faf7fc;color:var(--accent-dark);text-align:left;font-weight:700;}
.company-note{margin-top:10px;text-align:right;color:var(--muted);}
.company-side{display:grid;gap:24px;}
.company-side-box{background:var(--surface);border:2px solid #d7c4e8;border-radius:18px;padding:22px;display:flex;align-items:center;justify-content:center;text-align:center;min-height:140px;}
.company-logo-text{font-size:54px;line-height:1;font-family:"Hiragino Mincho ProN","Yu Mincho",serif;color:#222;}
.company-nikkan-box{display:grid;gap:16px;justify-items:center;}
.company-nikkan-logo{display:inline-flex;align-items:center;justify-content:center;min-height:88px;width:100%;border:2px solid #8cc3f7;border-radius:12px;background:#fff;color:#1d8fe1;font-size:42px;font-weight:800;letter-spacing:-.04em;}
.company-nikkan-link{font-size:22px;line-height:1.7;color:#3d44cf;text-decoration:underline;}
@media (max-width:960px){.company-layout{grid-template-columns:1fr;}.company-side{grid-template-columns:1fr 1fr;}}
@media (max-width:768px){.company-page{padding-top:32px;}.company-title{font-size:32px;}.company-copy{font-size:16px;}.company-table th,.company-table td{display:block;width:auto;}.company-table tr{display:block;border-bottom:1px solid #c9b2df;}.company-table th{border-bottom:none;}.company-side{grid-template-columns:1fr;}.company-logo-text{font-size:44px;}.company-nikkan-logo{font-size:34px;}.company-nikkan-link{font-size:18px;}}

/* v15 side widgets */
.page-with-sidebar{
  display:grid;
  grid-template-columns:minmax(0,1fr) 300px;
  gap:40px;
  align-items:start;
}
.page-with-sidebar--no-sidebar,
.company-layout--no-sidebar{
  grid-template-columns:minmax(0,1fr);
}
.page-main-column{
  min-width:0;
}
.page-side-widgets{
  display:grid;
  gap:20px;
  position:sticky;
  top:108px;
}
.side-banner-widget{
  background:var(--surface);
  border:1px solid var(--line);
/*  border-radius:22px; */
  padding:8px 32px;
  box-shadow:0 10px 30px rgba(92,73,46,.04);
  overflow:hidden;
}
.side-banner-widget .widget-title{
  margin:0 0 12px;
  font-size:15px;
  color:var(--accent-dark);
}
.side-banner-widget p:last-child{margin-bottom:0;}
.side-banner-widget img{
  width:100%;
  height:auto;
  border-radius:12px;
}
.side-banner-widget a{
  color:inherit;
}
.paper-category-block + .paper-category-block{
  margin-top:32px;
}
@media (max-width: 960px){
  .page-with-sidebar,
  .company-layout{
    grid-template-columns:1fr;
  }
  .page-side-widgets{
    position:static;
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media (max-width: 768px){
  .page-side-widgets{
    grid-template-columns:1fr;
  }
}

.ward-block + .ward-block{margin-top:30px;}
.ward-title{
  margin:0 0 14px;
  padding:10px 16px;
  border-left:4px solid var(--accent);
  background:#faf6ef;
  color:var(--accent-dark);
  font-size:24px;
  line-height:1.4;
}
@media (max-width:768px){
  .ward-title{font-size:20px;padding:9px 14px;}
}

/* Contact Form 7 */
.section-contact-page { padding-top: 84px; padding-bottom: 96px; }
.single-wrap-contact { max-width: 980px; }
.contact-page-head { margin-bottom: 28px; }
.contact-page-head h1 { margin-bottom: 14px; line-height: 1.2; }
.contact-page-head .lead { max-width: 760px; }
.contact-card {
  padding: 42px;
  background: linear-gradient(180deg, #fffdf9 0%, #fffaf4 100%);
  border-radius: 32px;
}
.entry-content-contact p { margin: 0 0 18px; }
.entry-content-contact label {
  display: block;
  margin-bottom: 18px;
  font-weight: 700;
  color: var(--text);
}
.entry-content-contact .wpcf7-form-control-wrap {
  display: block;
  margin-top: 8px;
}
.entry-content-contact input[type="text"],
.entry-content-contact input[type="email"],
.entry-content-contact input[type="tel"],
.entry-content-contact input[type="url"],
.entry-content-contact input[type="number"],
.entry-content-contact textarea,
.entry-content-contact select {
  width: 100%;
  min-height: 56px;
  padding: 14px 16px;
  margin-bottom: 18px;
  border: 1px solid #d9cdbc;
  border-radius: 16px;
  background: #fff;
  color: var(--text);
  font-size: 16px;
  line-height: 1.6;
  transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
}
.entry-content-contact textarea {
  min-height: 220px;
  resize: vertical;
}
.entry-content-contact input:focus,
.entry-content-contact textarea:focus,
.entry-content-contact select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 4px rgba(184, 92, 75, 0.12);
  background: #fffdfa;
}
.entry-content-contact .wpcf7-not-valid-tip {
  margin-top: 8px;
  font-size: 13px;
  color: #b42318;
}
.entry-content-contact .wpcf7 form .wpcf7-response-output,
.entry-content-contact .wpcf7-response-output {
  margin: 24px 0 0;
  padding: 14px 18px;
  border-radius: 16px;
  border: 1px solid #e7d8c7;
  background: #fff8f1;
  color: var(--text);
}
.entry-content-contact .wpcf7-spinner {
  vertical-align: middle;
  margin-left: 10px;
}
.entry-content-contact input[type="submit"],
.entry-content-contact button,
.entry-content-contact .wpcf7-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 0 30px;
  border: 0;
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: .02em;
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease, background-color .2s ease;
  box-shadow: 0 10px 24px rgba(184, 92, 75, 0.18);
}
.entry-content-contact input[type="submit"]:hover,
.entry-content-contact button:hover,
.entry-content-contact .wpcf7-submit:hover {
  transform: translateY(-1px);
  background: var(--accent-dark);
}
.entry-content-contact .wpcf7 form.sent .wpcf7-response-output {
  background: #f1fbf4;
  border-color: #b7e1c0;
}
.entry-content-contact .wpcf7 form.invalid .wpcf7-response-output,
.entry-content-contact .wpcf7 form.failed .wpcf7-response-output,
.entry-content-contact .wpcf7 form.aborted .wpcf7-response-output {
  background: #fff5f4;
  border-color: #efc3bf;
}
@media (max-width: 768px) {
  .section-contact-page { padding-top: 56px; padding-bottom: 68px; }
  .contact-card { padding: 24px; border-radius: 24px; }
  .contact-page-head { margin-bottom: 20px; }
  .contact-page-head h1 { font-size: 34px; }
  .entry-content-contact input[type="text"],
  .entry-content-contact input[type="email"],
  .entry-content-contact input[type="tel"],
  .entry-content-contact input[type="url"],
  .entry-content-contact input[type="number"],
  .entry-content-contact textarea,
  .entry-content-contact select { font-size: 16px; }
}

/* v20 mobile hamburger menu - cleaned */
.menu-toggle {
  display: none;
  position: relative;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  min-height: 52px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #fffaf4;
  color: var(--text);
  cursor: pointer;
  flex: 0 0 52px;
}

.menu-toggle__lines {
  position: relative;
  display: block;
  width: 24px;
  height: 18px;
  margin: 0 auto;
}

.menu-toggle__lines span {
  position: absolute;
  left: 0;
  width: 24px;
  height: 2px;
  margin: 0;
  border-radius: 999px;
  background: var(--text);
  transform-origin: center;
  transition: transform .25s ease, opacity .25s ease, top .25s ease;
}

.menu-toggle__lines span:nth-child(1) { top: 0; }
.menu-toggle__lines span:nth-child(2) { top: 8px; }
.menu-toggle__lines span:nth-child(3) { top: 16px; }

.menu-toggle.is-open .menu-toggle__lines span:nth-child(1),
.menu-toggle[aria-expanded="true"] .menu-toggle__lines span:nth-child(1) {
  top: 8px;
  transform: rotate(45deg);
}

.menu-toggle.is-open .menu-toggle__lines span:nth-child(2),
.menu-toggle[aria-expanded="true"] .menu-toggle__lines span:nth-child(2) {
  opacity: 0;
}

.menu-toggle.is-open .menu-toggle__lines span:nth-child(3),
.menu-toggle[aria-expanded="true"] .menu-toggle__lines span:nth-child(3) {
  top: 8px;
  transform: rotate(-45deg);
}

@media (max-width: 768px) {
  .header-inner {
    position: relative;
    gap: 12px;
    min-height: 78px;
  }

  .site-branding {
    align-items: flex-start;
    min-width: 0;
  }

  .site-title {
    font-size: 24px;
    line-height: 1.25;
    max-width: calc(100vw - 120px);
  }

  .site-description {
    display: none;
  }

  .menu-toggle {
    display: inline-flex;
    z-index: 1201;
  }

  .site-nav {
    display: none;
    position: absolute;
    left: 16px;
    right: 16px;
    top: calc(100% + 10px);
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
    background: #fffdf9;
    border: 1px solid var(--line);
    border-radius: 28px;
    padding: 24px;
    box-shadow: 0 18px 40px rgba(92,73,46,.12);
    box-sizing: border-box;
    z-index: 1200;
  }

  .site-nav.is-open {
    display: flex;
  }

  .site-nav ul,
  .site-nav .menu,
  .site-nav .menu-main {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 0;
    margin: 0;
  }

  .site-nav li {
    width: 100%;
    list-style: none;
  }

  .site-nav li a,
  .site-nav .menu a,
  .site-nav .menu-main a {
    display: block;
    width: 100%;
    padding: 18px 0;
    border-bottom: 1px solid #efe6da;
    font-size: 16px;
    line-height: 1.6;
  }

  .site-nav li:last-child a,
  .site-nav .menu li:last-child a,
  .site-nav .menu-main li:last-child a {
    border-bottom: none;
  }

  .menu-utility {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
    padding-top: 6px;
  }

  .menu-utility .header-link {
    display: block;
    width: 100%;
    padding: 12px 0 18px;
    border-bottom: 1px solid #efe6da;
    color: var(--accent-dark);
    font-size: 16px;
    line-height: 1.6;
    text-align: left;
  }

  .menu-utility .button,
  .menu-utility .header-cta {
    display: flex;
    width: 100%;
    min-width: 0;
    min-height: 56px;
    justify-content: center;
    align-items: center;
    padding: 0 16px;
    margin: 0;
    box-sizing: border-box;
    font-size: 16px;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    border-radius: 999px;
    text-align: center;
  }

  body.menu-open {
    overflow: hidden;
  }
}

/* mobile paper table fixes */
.paper-table-real__title,
.paper-table-real__value,
.paper-table-real__actions a {
  word-break: keep-all;
  overflow-wrap: normal;
  line-break: strict;
}

@media (max-width: 768px) {
  .paper-table-real td::before {
    content: attr(data-label);
    display: block;
    margin-bottom: 4px;
    font-size: 12px;
    letter-spacing: .08em;
    color: var(--accent);
    white-space: nowrap;
  }

  .paper-table-real__title,
  .paper-table-real__value,
  .paper-table-real__actions a {
    white-space: nowrap;
  }

  .paper-table-real__title {
    font-size: 22px;
    line-height: 1.45;
  }

  .paper-table-real__actions {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 14px;
  }
}

/* hero transition enhancement */
.hero-slider,
.hero-slider-v2,
.hero-slider-reference,
.hero-slider-clean {
  position: relative;
  overflow: hidden;
}

.hero-slide,
.hero-slide-v2,
.hero-slide-reference,
.hero-slide-clean {
  transform: scale(1.05);
  transition: opacity 1s ease, transform 6s ease, visibility 1s ease;
  will-change: opacity, transform;
}

.hero-slide.is-active,
.hero-slide-v2.is-active,
.hero-slide-reference.is-active,
.hero-slide-clean.is-active {
  transform: scale(1);
}

.hero-slide.is-leaving,
.hero-slide-v2.is-leaving,
.hero-slide-reference.is-leaving,
.hero-slide-clean.is-leaving {
  opacity: 0;
  transform: scale(1.02);
}

.hero-content > *,
.hero-copy-v2 > *,
.hero-copy-reference > *,
.hero-visual-caption > * {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .8s ease, transform .8s cubic-bezier(.22,1,.36,1);
}

.hero-slide.is-active .hero-content > *,
.hero-slide-v2.is-active .hero-copy-v2 > *,
.hero-slide-reference.is-active .hero-copy-reference > *,
.hero-slide-clean.is-active .hero-visual-caption > * {
  opacity: 1;
  transform: translateY(0);
}

.hero-slide.is-active .hero-content > *:nth-child(1),
.hero-slide-v2.is-active .hero-copy-v2 > *:nth-child(1),
.hero-slide-reference.is-active .hero-copy-reference > *:nth-child(1),
.hero-slide-clean.is-active .hero-visual-caption > *:nth-child(1) { transition-delay: .16s; }
.hero-slide.is-active .hero-content > *:nth-child(2),
.hero-slide-v2.is-active .hero-copy-v2 > *:nth-child(2),
.hero-slide-reference.is-active .hero-copy-reference > *:nth-child(2),
.hero-slide-clean.is-active .hero-visual-caption > *:nth-child(2) { transition-delay: .30s; }
.hero-slide.is-active .hero-content > *:nth-child(3),
.hero-slide-v2.is-active .hero-copy-v2 > *:nth-child(3),
.hero-slide-reference.is-active .hero-copy-reference > *:nth-child(3),
.hero-slide-clean.is-active .hero-visual-caption > *:nth-child(3) { transition-delay: .44s; }
.hero-slide.is-active .hero-content > *:nth-child(4),
.hero-slide-v2.is-active .hero-copy-v2 > *:nth-child(4),
.hero-slide-reference.is-active .hero-copy-reference > *:nth-child(4),
.hero-slide-clean.is-active .hero-visual-caption > *:nth-child(4) { transition-delay: .58s; }

/* ===== IMPACT TOP PAGE ===== */
.top-hero-reference--impact {
  position: relative;
  background: linear-gradient(180deg, #ede6da 0%, #efe9df 100%);
}

.top-hero-reference--impact .hero-slide-reference,
.top-hero-reference--impact .hero-fallback-reference,
.top-hero-reference--impact .hero-slide-reference__inner {
  min-height: 560px;
}

.top-hero-reference--impact .hero-slide-reference__overlay {
  background:
    linear-gradient(90deg, rgba(20,18,16,.52) 0%, rgba(20,18,16,.34) 28%, rgba(20,18,16,.12) 58%, rgba(20,18,16,.10) 100%),
    linear-gradient(180deg, rgba(20,18,16,.04) 0%, rgba(20,18,16,.08) 30%, rgba(20,18,16,.26) 100%);
}

.hero-slide-reference__inner--impact {
  justify-content: flex-start;
  text-align: left;
  align-items: center;
}

.hero-copy-reference--panel {
  max-width: 560px;
  padding: 34px 36px;
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(39,34,30,.38) 0%, rgba(32,28,25,.28) 100%);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow:
    0 18px 42px rgba(0,0,0,.18),
    inset 0 1px 0 rgba(255,255,255,.05);
  backdrop-filter: blur(8px);
}

.top-hero-reference--impact .hero-kicker-reference {
  display: inline-flex;
  margin: 0 0 14px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.18);
  font-size: 10px;
  letter-spacing: .16em;
  color: rgba(255,255,255,.92);
}

.top-hero-reference--impact .hero-copy-reference h1 {
  margin: 0 0 14px;
  font-size: clamp(34px, 4.6vw, 58px);
  line-height: 1.14;
  font-weight: 700;
  letter-spacing: .01em;
  color: #fff;
  text-shadow: 0 5px 20px rgba(0,0,0,.22);
}

.top-hero-reference--impact .hero-copy-reference p {
  margin: 0;
  max-width: 820px;
  font-size: 14px;
  line-height: 1.85;
  color: rgba(255,255,255,.88);
}

.top-hero-reference--impact .hero-actions-reference {
  justify-content: flex-start;
  margin-top: 22px;
}

.top-hero-reference--impact .hero-actions-reference .button {
  min-width: 150px;
  min-height: 50px;
  box-shadow: 0 12px 26px rgba(0,0,0,.18);
}

.top-hero-reference--impact .hero-dots-reference {
  justify-content: center;
  bottom: 16px;
}

.section-reference-info--impact {
  padding-top: 34px;
  padding-bottom: 52px;
}

.reference-info-grid--impact {
  display: grid;
  grid-template-columns: 330px minmax(0, 1fr);
  gap: 28px;
  align-items: stretch;
}

.reference-panel--impact {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  padding: 34px 34px 26px;
  border-radius: 28px;
  border: 1px solid #e5dacd;
  background:
    linear-gradient(180deg, rgba(255,253,249,.98) 0%, rgba(255,248,241,.92) 100%);
  box-shadow:
    0 18px 42px rgba(92,73,46,.07),
    inset 0 1px 0 rgba(255,255,255,.7);
}

.reference-panel-closure.reference-panel--impact,
.reference-panel-news.reference-panel--impact {
  position: relative;
}

.reference-panel-closure.reference-panel--impact::before,
.reference-panel-news.reference-panel--impact::before {
  content: "";
  position: absolute;
  top: 0;
  left: 28px;
  right: 28px;
  height: 3px;
  border-radius: 999px;
}

.reference-panel-closure.reference-panel--impact::before {
  background: linear-gradient(90deg, #d87562 0%, #e7b19b 100%);
}

.reference-panel-news.reference-panel--impact::before {
  background: linear-gradient(90deg, #667ba0 0%, #8fa2c0 100%);
}

.reference-panel__head {
  margin-bottom: 22px;
}

.reference-panel__eyebrow {
  margin: 0 0 10px;
  font-size: 11px;
  line-height: 1;
  letter-spacing: .18em;
  color: #a68c75;
  text-transform: uppercase;
}

.reference-panel--impact h2 {
  margin: 0;
  font-size: 44px;
  line-height: 1.18;
  letter-spacing: .01em;
  font-weight: 500;
  color: #21304a;
}

.reference-panel--impact .reference-panel__body {
  flex: 1;
  border-top: 1px solid #efe4d8;
  padding-top: 22px;
}

.reference-closure-block--boxed {
  padding: 18px 20px;
  border-radius: 20px;
  background: linear-gradient(180deg, #fffdfa 0%, #fff8f2 100%);
  border: 1px solid #efe2d5;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.78);
}

.reference-closure-block--boxed + .reference-closure-block--boxed {
  margin-top: 14px;
}

.reference-closure-block--boxed h3 {
  margin-bottom: 10px;
  font-size: 16px;
  color: var(--muted);
}

.reference-closure-list li {
  margin: 6px 0;
  font-size: 17px;
  font-weight: 700;
}

.reference-news-list--impact li + li {
  margin-top: 0;
}

.reference-news-list--impact a {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 18px;
  align-items: start;
  padding: 18px 0;
  border-bottom: 1px solid #efe6da;
  transition: background-color .2s ease, padding-left .2s ease;
}

.reference-news-list--impact a:hover {
  background: rgba(184,92,75,.03);
  padding-left: 6px;
}

.reference-news-list--impact .news-date {
  color: #9a8d80;
}

.reference-news-list--impact li:last-child a {
  border-bottom: none;
}

.reference-panel--impact .reference-panel__footer {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid #efe4d8;
  text-align: right;
}

.section-home-cta-band--impact {
  padding-top: 10px;
  padding-bottom: 58px;
}

.home-cta-grid--impact {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 28px;
  align-items: stretch;
}

.home-cta-card--primary,
.home-cta-card--secondary {
  position: relative;
  overflow: hidden;
  min-height: 100%;
  padding: 42px 42px 38px;
  border-radius: 32px;
  box-shadow:
    0 20px 44px rgba(92,73,46,.07),
    inset 0 1px 0 rgba(255,255,255,.62);
}

.home-cta-card--primary {
  background: linear-gradient(180deg, #fdfaf4 0%, #f7f1e8 100%);
  border: 1px solid #e3d8ca;
}

.home-cta-card--secondary {
  background: linear-gradient(180deg, #fffaf5 0%, #fffdf9 100%);
  border: 1px solid #e7dccf;
}

.home-cta-card--primary h2,
.home-cta-card--secondary h2 {
  margin: 0 0 14px;
  line-height: 1.20;
  letter-spacing: .01em;
  font-weight: 500;
  color: #21304a;
}

.home-cta-card--primary h2 {
  font-size: 48px;
}

.home-cta-card--secondary h2 {
  font-size: 40px;
}

.home-cta-card--primary p:not(.eyebrow),
.home-cta-card--secondary p:not(.eyebrow) {
/*  max-width: 34em;    */
  color: var(--muted);
}

.home-cta-card__note {
  margin-top: 12px;
  font-size: 14px;
  color: #8b7c6e;
}

.home-cta-card__actions {
  margin-top: 28px;
}

.home-cta-card--primary .button-squareish {
  min-width: 290px;
  background: rgba(255,255,255,.70);
  border-color: #7d8da5;
  color: #42546c;
  box-shadow: 0 8px 18px rgba(70,84,108,.08);
}

.home-cta-card--secondary .button-primary {
  box-shadow: 0 14px 28px rgba(184,92,75,.20);
}

.section-papers-reference--impact {
  position: relative;
  padding-top: 72px;
  padding-bottom: 76px;
  background: linear-gradient(180deg, #fffdfb 0%, #fffaf5 100%);
}

.section-papers-reference--impact::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: min(100% - 64px, 1100px);
  height: 1px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, rgba(232,220,206,0) 0%, #e8ddcf 20%, #e8ddcf 80%, rgba(232,220,206,0) 100%);
}

.section-center-head--impact {
  margin-bottom: 38px;
  text-align: center;
}

.section-center-head--impact h2 {
  margin-bottom: 12px;
  font-size: 56px;
  line-height: 1.18;
  letter-spacing: .015em;
  font-weight: 500;
  color: #21304a;
}

.section-center-head--impact .eyebrow {
  color: #b59a83;
}

.section-center-head--impact .section-center-lead {
  max-width: 740px;
  margin: 0 auto;
  color: #7d7063;
}

.papers-reference-wrap--impact {
  max-width: 940px;
  padding: 40px 36px;
  border: 1px solid #ebe0d3;
  border-radius: 30px;
  background: linear-gradient(180deg, rgba(255,255,255,.86) 0%, rgba(255,251,246,.92) 100%);
  box-shadow:
    0 18px 42px rgba(92,73,46,.05),
    inset 0 1px 0 rgba(255,255,255,.78);
}

.paper-official-links--impact {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  max-width: 760px;
  margin: 0 auto;
}

.paper-official-link--impact {
  min-height: 98px;
  padding: 18px 16px;
  border-radius: 20px;
  border: 1px solid #e9ddcf;
  background: linear-gradient(180deg, #fffefa 0%, #fff8f1 100%);
  color: #49586a;
  font-size: 16px;
  font-weight: 700;
  box-shadow:
    0 10px 24px rgba(92,73,46,.04),
    inset 0 1px 0 rgba(255,255,255,.72);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.paper-official-link--impact:hover {
  transform: translateY(-2px);
  box-shadow:
    0 18px 34px rgba(92,73,46,.08),
    inset 0 1px 0 rgba(255,255,255,.78);
}

.papers-reference-actions {
  display: flex;
  justify-content: center;
  margin-top: 32px;
}

.papers-reference-actions .button {
  min-height: 52px;
  padding: 0 28px;
  background: rgba(255,255,255,.8);
}

@media (max-width: 1080px) {
  .home-cta-grid--impact {
    grid-template-columns: 1fr;
  }

  .home-cta-card--primary h2 {
    font-size: 42px;
  }

  .home-cta-card--secondary h2 {
    font-size: 36px;
  }
}

@media (max-width: 960px) {
  .reference-info-grid--impact {
    grid-template-columns: 1fr;
  }

  .paper-official-links--impact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .top-hero-reference--impact .hero-slide-reference,
  .top-hero-reference--impact .hero-fallback-reference,
  .top-hero-reference--impact .hero-slide-reference__inner {
    min-height: 460px;
  }

  .hero-copy-reference--panel {
    max-width: 100%;
    padding: 24px 20px;
    border-radius: 20px;
    background: rgba(36,33,29,.34);
  }

  .top-hero-reference--impact .hero-copy-reference h1 {
    font-size: 32px;
    line-height: 1.2;
  }

  .top-hero-reference--impact .hero-copy-reference p {
    font-size: 14px;
    line-height: 1.75;
  }

  .section-reference-info--impact {
    padding-top: 24px;
    padding-bottom: 38px;
  }

  .reference-panel--impact {
    padding: 24px 20px 20px;
    border-radius: 22px;
  }

  .reference-panel--impact h2 {
    font-size: 32px;
  }

  .reference-news-list--impact a {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .section-home-cta-band--impact {
    padding-top: 14px;
    padding-bottom: 40px;
  }

  .home-cta-card--primary,
  .home-cta-card--secondary {
    padding: 28px 22px 24px;
    border-radius: 24px;
  }

  .home-cta-card--primary h2,
  .home-cta-card--secondary h2 {
    font-size: 32px;
  }

  .home-cta-card__actions .button {
    width: 100%;
    justify-content: center;
    min-width: 0;
  }

  .section-papers-reference--impact {
    padding-top: 50px;
    padding-bottom: 56px;
  }

  .section-center-head--impact h2 {
    font-size: 34px;
  }

  .papers-reference-wrap--impact {
    padding: 26px 18px;
    border-radius: 22px;
  }

  .paper-official-links--impact {
    grid-template-columns: 1fr;
  }

  .paper-official-link--impact {
    min-height: 80px;
    border-radius: 16px;
  }

  .section-papers-reference--impact::before {
    width: calc(100% - 32px);
  }
}

/* ===== minimal diff: hero title smaller / remove CTA circle ===== */
.top-hero-reference--impact .hero-copy-reference h1 {
  font-size: clamp(30px, 4vw, 50px);
  line-height: 1.16;
}

.hero-copy-reference--panel {
  max-width: 520px;
}

.home-cta-card--primary::after {
  content: none;
}

.home-cta-card--primary p:not(.eyebrow),
.home-cta-card--primary .home-cta-card__note {
  line-height: 1.75;
}

@media (max-width: 768px) {
  .top-hero-reference--impact .hero-copy-reference h1 {
    font-size: 28px;
    line-height: 1.2;
  }

  .hero-copy-reference--panel {
    max-width: 100%;
  }
}

/* TOP page minimal diff
   - hero back to centered layout
   - remove dark glass panel look
   - make hero title smaller
   - reduce H2 sizes site-top only
   - remove decorative circle on ASA GUIDE card
*/

.top-hero-reference--impact .hero-slide-reference,
.top-hero-reference--impact .hero-fallback-reference,
.top-hero-reference--impact .hero-slide-reference__inner {
  min-height: 520px;
}

.top-hero-reference--impact .hero-slide-reference__overlay {
  background:
    linear-gradient(to bottom, rgba(20,18,16,.10) 0%, rgba(20,18,16,.16) 26%, rgba(20,18,16,.34) 100%),
    linear-gradient(to right, rgba(20,18,16,.14) 0%, rgba(20,18,16,.06) 45%, rgba(20,18,16,.12) 100%);
}

.hero-slide-reference__inner--impact {
  justify-content: center;
  text-align: center;
}

.hero-copy-reference--panel {
  max-width: 760px;
  padding: 26px 20px 72px;
  background: transparent;
  border: 0;
  box-shadow: none;
  backdrop-filter: none;
}

.top-hero-reference--impact .hero-kicker-reference {
  display: inline-flex;
  margin: 0 0 12px;
  padding: 5px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.18);
  font-size: 10px;
  letter-spacing: .14em;
  color: rgba(255,255,255,.92);
}

.top-hero-reference--impact .hero-copy-reference h1,
.top-hero-reference--impact .hero-copy-reference .hero-title-reference {
  margin: 0 0 12px;
  font-size: clamp(30px, 4.2vw, 46px);
  line-height: 1.18;
  letter-spacing: .01em;
  font-weight: 700;
  color: #fff;
  text-shadow: 0 4px 16px rgba(0,0,0,.22);
}

.top-hero-reference--impact .hero-copy-reference p:not(.hero-title-reference) {
  max-width: 820px;
  margin-left: auto;
  margin-right: auto;
  font-size: 14px;
  white-space: normal;
  line-height: 1.8;
  color: rgba(255,255,255,.90);
}

.top-hero-reference--impact .hero-actions-reference {
  justify-content: center;
  margin-top: 18px;
}

.top-hero-reference--impact .hero-actions-reference .button {
  min-width: 148px;
  min-height: 48px;
  box-shadow: 0 10px 22px rgba(0,0,0,.16);
}

.top-hero-reference--impact .hero-dots-reference {
  bottom: 14px;
}

.reference-panel--impact h2 {
  font-size: 32px;
  line-height: 1.24;
}

.home-cta-card--primary h2 {
  font-size: 34px;
  line-height: 1.24;
}

.home-cta-card--secondary h2 {
  font-size: 30px;
  line-height: 1.24;
}

.section-center-head--impact h2 {
  font-size: 40px;
  line-height: 1.2;
}

.home-cta-card--primary::after {
  content: none;
}

@media (max-width: 768px) {
  .top-hero-reference--impact .hero-slide-reference,
  .top-hero-reference--impact .hero-fallback-reference,
  .top-hero-reference--impact .hero-slide-reference__inner {
    min-height: 430px;
  }

  .hero-copy-reference--panel {
    max-width: 100%;
    padding: 24px 18px 66px;
  }

.top-hero-reference--impact .hero-copy-reference h1,
.top-hero-reference--impact .hero-copy-reference .hero-title-reference {
  font-size: 28px;
  line-height: 1.22;
}

.top-hero-reference--impact .hero-copy-reference p:not(.hero-title-reference) {
  font-size: 13px;
  line-height: 1.75;
}

  .reference-panel--impact h2 {
    font-size: 28px;
  }

  .home-cta-card--primary h2,
  .home-cta-card--secondary h2 {
    font-size: 28px;
  }

  .section-center-head--impact h2 {
    font-size: 30px;
  }
}

/* ========================================
   company page redesign fix
   他ページトーンに合わせる
======================================== */

.company-page {
/*  padding-top: 56px; */
}

.company-panel,
.company-panel-clean {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
}

.company-title,
.company-title-clean {
  margin: 0 0 22px;
  padding: 0 0 18px;
  border: 0;
  border-bottom: 1px solid #e8ddcf;
  font-size: clamp(34px, 5vw, 48px);
  line-height: 1.2;
  font-weight: 700;
  color: var(--text);
}

.company-copy,
.company-copy-clean {
  color: var(--text);
  font-size: 17px;
  line-height: 2;
}

.company-copy p + p,
.company-copy-clean p + p {
  margin-top: 1em;
}

.company-table-wrap,
.company-table-wrap-clean {
  margin-top: 30px;
}

.company-table,
.company-table-clean {
  width: 100%;
  border-collapse: collapse;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 0;
  overflow: hidden;
  box-shadow: 0 10px 28px rgba(92,73,46,.04);
}

.company-table th,
.company-table td,
.company-table-clean th,
.company-table-clean td {
  padding: 16px 18px;
  border: 1px solid #e9dfd2;
  vertical-align: top;
  line-height: 1.9;
  color: var(--text);
}

.company-table th,
.company-table-clean th {
  width: 180px;
  background: #faf6ef;
  color: var(--accent-dark);
  text-align: left;
  font-weight: 700;
}

.company-table td a,
.company-table-clean td a {
  color: var(--accent-dark);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.company-note,
.company-note-clean {
  margin-top: 12px;
  text-align: right;
  color: var(--muted);
  font-size: 14px;
}

.company-side,
.company-side-clean {
  gap: 20px;
}

.company-breadcrumb {
  display: none !important;
}

/* 旧デザインの紫系装飾を打ち消す */
.company-layout .company-table,
.company-layout .company-table th,
.company-layout .company-table td {
  border-color: #e9dfd2;
}

.company-layout .company-table th {
  background: #faf6ef;
  color: var(--accent-dark);
}

@media (max-width: 768px) {
  .company-page {
    padding-top: 36px;
  }

  .company-title,
  .company-title-clean {
    font-size: 32px;
    line-height: 1.3;
    margin-bottom: 18px;
    padding-bottom: 14px;
  }

  .company-copy,
  .company-copy-clean {
    font-size: 16px;
    line-height: 1.9;
  }

  .company-table,
  .company-table tbody,
  .company-table tr,
  .company-table th,
  .company-table td,
  .company-table-clean,
  .company-table-clean tbody,
  .company-table-clean tr,
  .company-table-clean th,
  .company-table-clean td {
    display: block;
    width: 100%;
  }

  .company-table tr + tr,
  .company-table-clean tr + tr {
    border-top: 1px solid #e9dfd2;
  }

  .company-table th,
  .company-table-clean th {
    border-bottom: none;
    background: #faf6ef;
    width: auto;
    padding-bottom: 8px;
  }

  .company-table td,
  .company-table-clean td {
    border-top: none;
    padding-top: 0;
  }

  .company-note,
  .company-note-clean {
    text-align: left;
    font-size: 13px;
  }
}

/* ========================================
   contact required badge redesign fix
======================================== */

.entry-content-contact label,
.contact-form-modern label {
  display: block;
  margin-bottom: 18px;
  font-weight: 700;
  color: var(--text);
}

/* class がある場合の必須バッジ */
.entry-content-contact .required,
.entry-content-contact .required-badge,
.contact-form-modern .required,
.contact-form-modern .required-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 8px;
  padding: 2px 9px;
  min-height: 22px;
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: .04em;
  vertical-align: middle;
  box-shadow: 0 4px 10px rgba(184, 92, 75, 0.16);
}

/* 必須テキストが small / em / strong 等で入っているケースも拾う */
.entry-content-contact label .required-text,
.entry-content-contact label small.required,
.entry-content-contact label em.required,
.entry-content-contact label strong.required,
.contact-form-modern label .required-text,
.contact-form-modern label small.required,
.contact-form-modern label em.required,
.contact-form-modern label strong.required {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 8px;
  padding: 2px 9px;
  min-height: 22px;
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  font-size: 11px;
  font-style: normal;
  font-weight: 700;
  line-height: 1;
  letter-spacing: .04em;
  vertical-align: middle;
  box-shadow: 0 4px 10px rgba(184, 92, 75, 0.16);
}

@media (max-width: 768px) {
  .entry-content-contact .required,
  .entry-content-contact .required-badge,
  .contact-form-modern .required,
  .contact-form-modern .required-badge,
  .entry-content-contact label .required-text,
  .entry-content-contact label small.required,
  .entry-content-contact label em.required,
  .entry-content-contact label strong.required,
  .contact-form-modern label .required-text,
  .contact-form-modern label small.required,
  .contact-form-modern label em.required,
  .contact-form-modern label strong.required {
    margin-left: 6px;
    padding: 2px 8px;
    font-size: 10px;
  }
}

/* ========================================
   TOP 取り扱い紙公式サイト 画像バナー化
======================================== */
.section-papers-reference--banner {
  padding-top: 64px;
  padding-bottom: 74px;
  background: linear-gradient(180deg, #fffdfb 0%, #fffaf5 100%);
}

.papers-banner-wrap {
  max-width: 1180px;
}

.papers-banner-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 28px 32px;
  margin-top: 8px;
}

.papers-banner-item {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 116px;
  padding: 24px 16px;
  background: #fff;
  border: 1px solid #d9d2c8;
  box-shadow: 0 6px 18px rgba(92, 73, 46, 0.04);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.papers-banner-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 24px rgba(92, 73, 46, 0.08);
  border-color: #c9b9a7;
}

.papers-banner-item img {
  display: block;
  width: 90%;
  height: auto;
  object-fit: contain;
}

@media (max-width: 768px) {

  .papers-banner-item img {
     width: 70%;
  }
}

.section-papers-reference--banner .section-center-head--impact h2 {
  font-size: 40px;
  line-height: 1.22;
}

.section-papers-reference--banner .section-center-lead {
  max-width: 680px;
  color: #7d7063;
}

.section-papers-reference--banner .papers-reference-actions {
  display: flex;
  justify-content: center;
  margin-top: 34px;
}

@media (max-width: 960px) {
  .papers-banner-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px 22px;
  }
}

@media (max-width: 768px) {
  .section-papers-reference--banner {
    padding-top: 48px;
    padding-bottom: 56px;
  }

  .papers-banner-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .papers-banner-item {
    min-height: 92px;
  }

  .section-papers-reference--banner .section-center-head--impact h2 {
    font-size: 30px;
  }
}

/* ========================================
   footer fine tuning
======================================== */
.site-footer {
  padding-top: 32px;
}

.site-footer .footer-grid {
  align-items: start;
  gap: 28px;
  padding-bottom: 22px;
}

.site-footer .footer-title {
  margin: 0 0 12px;
  font-size: 18px;
  line-height: 1.5;
  font-weight: 700;
  color: var(--text);
}

.site-footer .footer-text {
  margin: 0;
  font-size: 14px;
  line-height: 1.95;
  color: var(--muted);
}

.site-footer .footer-text + .footer-text {
  margin-top: 2px;
}

.site-footer .footer-copy {
  padding: 14px 0 24px;
  font-size: 13px;
  color: var(--muted);
}

.site-footer .menu,
.site-footer ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.site-footer .menu li + li,
.site-footer ul li + li {
  margin-top: 8px;
}

.site-footer .menu a,
.site-footer ul a {
  color: var(--muted);
  transition: color .2s ease;
}

.site-footer .menu a:hover,
.site-footer ul a:hover {
  color: var(--accent-dark);
}

@media (max-width: 768px) {
  .site-footer {
    padding-top: 26px;
  }

  .site-footer .footer-grid {
    gap: 16px;
    padding-bottom: 16px;
  }

  .site-footer .footer-title {
    margin-bottom: 8px;
    font-size: 17px;
  }

  .site-footer .footer-text {
    font-size: 13px;
    line-height: 1.85;
  }

  .site-footer .footer-copy {
    padding: 12px 0 20px;
    font-size: 12px;
  }
}

/* hero height +50px */
.top-hero-reference--impact .hero-slide-reference,
.top-hero-reference--impact .hero-fallback-reference,
.top-hero-reference--impact .hero-slide-reference__inner {
  min-height: 600px;
}

/* 取り扱い紙：月額だけ右揃え（PCのみ） */
@media (min-width: 769px) {
  .paper-table-real td[data-label="月額"] {
    text-align: right;
  }

  .paper-table-real td[data-label="月額"] .paper-table-real__value {
    display: inline-block;
    width: 100%;
    text-align: right;
  }
}

/* 取り扱い紙：リンク列の見え方調整 */
.paper-table-real td[data-label="リンク"] {
  white-space: normal;
}

.paper-table-real__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 12px;
  justify-content: flex-start;
}

.paper-table-real__actions .text-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0 10px;
  border: 1px solid #eadfd2;
  border-radius: 999px;
  background: #fffaf4;
  color: var(--accent-dark);
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  transition: background-color .2s ease, border-color .2s ease, transform .2s ease;
}

.paper-table-real__actions .text-link:hover {
  background: #fff;
  border-color: #d9c9b5;
  transform: translateY(-1px);
}

@media (max-width: 768px) {
  .paper-table-real__actions {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 10px;
  }

  .paper-table-real__actions .text-link {
    min-height: 30px;
    padding: 0 10px;
    font-size: 12px;
  }
}

/* ASA一覧：案内欄をタグ風ボタンに */
.store-table__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 10px;
  justify-content: flex-start;
}

.store-table__tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0 12px;
  border: 1px solid #e3d3c1;
  border-radius: 999px;
  background: #fffaf6;
  color: var(--accent-dark);
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
  transition: background-color .2s ease, border-color .2s ease, transform .2s ease;
}

.store-table__tag:hover {
  background: #fff;
  border-color: #d9c9b5;
  transform: translateY(-1px);
}

@media (max-width: 768px) {
  .store-table__actions {
    gap: 8px;
  }

  .store-table__tag {
    min-height: 30px;
    padding: 0 10px;
    font-size: 12px;
  }
}

/* ASA一覧：列幅固定（郵便番号追加後） */
.store-table {
  width: 100%;
  table-layout: fixed;
}

.store-table th,
.store-table td {
  word-break: break-word;
  overflow-wrap: anywhere;
}

.store-table th:nth-child(1),
.store-table td:nth-child(1) {
  width: 14%;
}

.store-table th:nth-child(2),
.store-table td:nth-child(2) {
  width: 10%;
}

.store-table th:nth-child(3),
.store-table td:nth-child(3) {
  width: 43%;
}

.store-table th:nth-child(4),
.store-table td:nth-child(4) {
  width: 13%;
}

.store-table th:nth-child(5),
.store-table td:nth-child(5) {
  width: 12%;
}

.store-table th:nth-child(6),
.store-table td:nth-child(6) {
  width: 8%;
}
/* ASA一覧：モバイル時は列固定を解除して横スクロール */
@media (max-width: 768px) {
  .store-table-wrap,
  .table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .store-table {
    width: 760px;
    min-width: 760px;
    table-layout: auto;
  }

  .store-table th,
  .store-table td {
    white-space: nowrap;
    word-break: normal;
    overflow-wrap: normal;
  }

  .store-table th:nth-child(1),
  .store-table td:nth-child(1),
  .store-table th:nth-child(2),
  .store-table td:nth-child(2),
  .store-table th:nth-child(3),
  .store-table td:nth-child(3),
  .store-table th:nth-child(4),
  .store-table td:nth-child(4),
  .store-table th:nth-child(5),
  .store-table td:nth-child(5),
  .store-table th:nth-child(6),
  .store-table td:nth-child(6) {
    width: auto;
  }
}

/* ASA一覧：モバイルでは HP / 地図 を1行にする */
@media (max-width: 768px) {
  .store-table__actions {
    flex-wrap: nowrap;
    gap: 6px;
  }

  .store-table__tag {
    min-width: 44px;
    padding: 0 8px;
    font-size: 11px;
  }
}

/* ASA一覧：HP / 地図 タグを少しだけ見やすく */
.store-table__tag {
  min-height: 34px;
  padding: 0 12px;
  font-size: 12px;
  border-color: #e3d3c1;
  background: #fffaf6;
}

.store-table__actions {
  gap: 8px 8px;
}

/* ASA一覧：エリアチップの余白調整 */
.asa-area-nav {
  gap: 12px 12px;
  margin-bottom: 48px;
}

.asa-area-chip {
  min-height: 46px;
  padding: 0 20px;
  font-size: 14px;
  line-height: 1;
}

@media (max-width: 768px) {
  .asa-area-nav {
    gap: 10px 10px;
    margin-bottom: 32px;
  }

  .asa-area-chip {
    min-height: 42px;
    padding: 0 16px;
    font-size: 13px;
  }
}

/* ASA一覧：導入文右側の ASA検索へ ボタン調整 */
.asa-archive-hero__inner {
  align-items: center;
  gap: 40px;
}

.asa-archive-hero__inner .button,
.asa-archive-hero__inner .button-primary {
  min-width: 140px;
  min-height: 50px;
  padding: 0 24px;
  box-shadow: 0 10px 24px rgba(184, 92, 75, 0.14);
}

@media (max-width: 768px) {
  .asa-archive-hero__inner {
    gap: 20px;
  }

  .asa-archive-hero__inner .button,
  .asa-archive-hero__inner .button-primary {
    min-width: 0;
    width: auto;
    min-height: 46px;
    padding: 0 18px;
  }
}

/* ASA一覧：エリアチップ上の案内文 */
.asa-area-note {
  margin: 0 0 14px;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.8;
}

@media (max-width: 768px) {
  .asa-area-note {
    margin-bottom: 12px;
    font-size: 14px;
    line-height: 1.75;
  }
}

/* ========================================
   page background unify
   固定ページ・一覧ページの地色を統一
======================================== */
.paper-archive-page,
.company-page,
.section-contact-page,
.section-asa {
  background: var(--bg);
}

.asa-archive-hero {
  background: var(--bg);
}

.page-with-sidebar,
.page-main-column,
.single-wrap-contact,
.company-layout {
  background: transparent;
}

/* お問い合わせカードだけはカード面を維持 */
.contact-card {
  background: linear-gradient(180deg, #fffdf9 0%, #fffaf4 100%);
}

/* ASA一覧：エリアチップのアンカー移動位置を補正 */
.area-block {
  scroll-margin-top: 230px;
}

@media (max-width: 768px) {
  .area-block {
    scroll-margin-top: 100px;
  }
}

/* ASA一覧：モバイルではエリアチップの重なりを防ぐ */
@media (max-width: 768px) {
  .asa-area-nav {
    position: static;
    top: auto;
    z-index: auto;
    background: transparent;
    padding: 0;
    margin-bottom: 20px;
    box-shadow: none;
  }

  .asa-area-nav__inner {
    overflow: visible;
  }
}

/* 会社案内：お問い合わせCTA */
.company-contact-cta {
  margin-top: 22px;
}

.company-contact-cta__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px 24px;
  padding: 20px 22px;
  border: 1px solid #e7dccf;
  border-radius: 22px;
  background: linear-gradient(180deg, #fffdf9 0%, #fffaf4 100%);
  box-shadow: 0 10px 24px rgba(92,73,46,.04);
}

.company-contact-cta__text {
  margin: 0;
  color: var(--muted);
  line-height: 1.9;
}

.company-contact-cta .button {
  flex: 0 0 auto;
  min-width: 190px;
}

@media (max-width: 768px) {
  .company-contact-cta__inner {
    flex-direction: column;
    align-items: stretch;
    padding: 18px;
  }

  .company-contact-cta .button {
    width: 100%;
    min-width: 0;
    justify-content: center;
  }
}

.news-list-card {
    padding: 0;
    overflow: hidden;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease, background-color 0.25s ease;
}

.news-list-card__link {
    display: block;
    height: 100%;
    padding: 32px;
    color: inherit;
    text-decoration: none;
}

.news-list-card__link h2 {
    transition: color 0.25s ease;
}

.news-list-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 40px rgba(67, 52, 38, 0.14);
    border-color: rgba(185, 84, 68, 0.35);
    background-color: #fffdf9;
}

.news-list-card:hover h2 {
    color: #b95444;
}



.site-title-heading {
    margin: 0;
    padding: 0;
    font: inherit;
    line-height: 1.4;
}

/* Thanks page
--------------------------------------------- */
.thanks-page {
  background: #f5f0e8;
}

.thanks-hero {
  padding: 96px 0 104px;
}

.thanks-box {
  max-width: 760px;
  margin: 0 auto;
  padding: 56px 64px;
  text-align: center;
  background: rgba(255, 255, 255, 0.86);
  border: 1px solid rgba(83, 66, 49, 0.12);
  border-radius: 24px;
  box-shadow: 0 22px 48px rgba(67, 52, 38, 0.08);
}

.thanks-box .eyebrow {
  margin: 0 0 18px;
  color: #b95444;
  font-size: 12px;
  letter-spacing: 0.22em;
  font-weight: 600;
}

.thanks-box h1 {
  margin: 0;
  color: #3f3329;
  font-size: 32px;
  line-height: 1.35;
  letter-spacing: 0.04em;
}

.thanks-lead {
  margin: 28px 0 0;
  color: #4b4036;
  font-size: 17px;
  line-height: 2;
  letter-spacing: 0.04em;
}

.thanks-message {
  margin: 34px auto 0;
  padding: 24px 28px;
  max-width: 560px;
  background: #fbf8f3;
  border: 1px solid rgba(83, 66, 49, 0.1);
  border-radius: 18px;
}

.thanks-message p {
  margin: 0;
  color: #6a5c50;
  font-size: 14px;
  line-height: 1.9;
}

.thanks-actions {
  display: flex;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 38px;
}

.thanks-actions .btn-primary,
.thanks-actions .btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 190px;
  padding: 14px 24px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 600;
  line-height: 1;
  text-decoration: none;
  transition: transform 0.25s ease, box-shadow 0.25s ease, background-color 0.25s ease, color 0.25s ease, border-color 0.25s ease;
}

.thanks-actions .btn-primary {
  color: #fff;
  background: #b95444;
  border: 1px solid #b95444;
  box-shadow: 0 12px 24px rgba(185, 84, 68, 0.18);
}

.thanks-actions .btn-outline {
  color: #705f52;
  background: #fff;
  border: 1px solid rgba(112, 95, 82, 0.28);
}

.thanks-actions .btn-primary:hover,
.thanks-actions .btn-outline:hover {
  transform: translateY(-2px);
}

.thanks-actions .btn-primary:hover {
  background: #a84b3d;
  border-color: #a84b3d;
  box-shadow: 0 16px 30px rgba(185, 84, 68, 0.24);
}

.thanks-actions .btn-outline:hover {
  color: #b95444;
  border-color: rgba(185, 84, 68, 0.42);
  box-shadow: 0 12px 24px rgba(67, 52, 38, 0.08);
}

@media (max-width: 767px) {
  .thanks-hero {
    padding: 56px 0 72px;
  }

  .thanks-box {
    padding: 40px 24px;
    border-radius: 20px;
  }

  .thanks-box h1 {
    font-size: 18px;
    letter-spacing: 0.05em;
  }

  .thanks-lead {
    font-size: 15px;
    line-height: 1.9;
  }

  .thanks-message {
    padding: 20px;
  }

  .thanks-actions {
    flex-direction: column;
    gap: 12px;
  }

  .thanks-actions .btn-primary,
  .thanks-actions .btn-outline {
    width: 100%;
  }
}