.elementor-48796 .elementor-element.elementor-element-e815baf{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-48796 .elementor-element.elementor-element-68f6f41{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-48796 .elementor-element.elementor-element-9658846{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-48796 .elementor-element.elementor-element-b82593a{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}/* Start custom CSS *//* ==========================================
   ベース変数（MUプラグインとトーン統一）
========================================== */
.twkm-ramen-archive-intro,
.twkm-ramen-archive-footer {
  --twkm-text: #3f312b;
  --twkm-sub: #7a6e69;
  --twkm-line: #f2e8e8;
  --twkm-bg: #ffffff;
  --twkm-soft: #fff7f7;
  --twkm-accent: #dc2626;
  --twkm-shadow: 0 8px 24px rgba(63, 49, 43, 0.06);
  --twkm-radius-lg: 32px;
  --twkm-radius-md: 24px;
  --twkm-max: 1100px;

  color: var(--twkm-text);
  font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  padding: 0 16px;
  box-sizing: border-box;
}

.twkm-ramen-archive-intro *,
.twkm-ramen-archive-footer * {
  box-sizing: border-box;
}

.twkm-ramen-archive-inner {
  max-width: var(--twkm-max);
  margin: 0 auto;
}

/* ==========================================
   ヒーローセクション（H1部分）
========================================== */
.twkm-ramen-hero {
  background: var(--twkm-soft);
  border-radius: var(--twkm-radius-lg);
  padding: 48px 40px;
  margin-bottom: 24px;
  text-align: center;
  position: relative;
  overflow: hidden;
  border: 1px solid var(--twkm-line);
}

.twkm-ramen-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at top right, #fff0f0 0%, transparent 60%),
    radial-gradient(circle at bottom left, #fdfaf9 0%, transparent 60%);
  z-index: 0;
}

.twkm-ramen-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(90deg, rgba(220, 38, 38, 0.04) 25%, transparent 25%, transparent 75%, rgba(220, 38, 38, 0.04) 75%),
    linear-gradient(rgba(220, 38, 38, 0.04) 25%, transparent 25%, transparent 75%, rgba(220, 38, 38, 0.04) 75%);
  background-size: 28px 28px;
  background-position: 0 0, 14px 14px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,0.16), transparent 60%);
  -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,0.16), transparent 60%);
  z-index: 0;
  pointer-events: none;
}

.twkm-ramen-hero-content {
  position: relative;
  z-index: 1;
}

.twkm-ramen-eyebrow {
  display: inline-block;
  margin: 0 0 12px;
  padding: 4px 12px;
  background: #fff;
  border-radius: 99px;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
  color: var(--twkm-accent);
  box-shadow: 0 2px 8px rgba(220, 38, 38, 0.10);
}

.twkm-ramen-title-main {
  margin: 0 0 16px;
  font-size: clamp(28px, 4vw, 36px);
  line-height: 1.4;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.twkm-ramen-lead {
  margin: 0 auto;
  max-width: 760px;
  font-size: 15px;
  line-height: 1.9;
  color: var(--twkm-sub);
  text-align: center;
}

/* ==========================================
   フッターボックス
========================================== */
.twkm-ramen-archive-footer {
  margin-top: 64px;
  margin-bottom: 64px;
}

.twkm-ramen-footer-box {
  background: var(--twkm-soft);
  border-radius: var(--twkm-radius-lg);
  padding: 48px;
  text-align: center;
  border: 1px solid var(--twkm-line);
}

.twkm-ramen-footer-box h2 {
  margin: 0 0 16px;
  font-size: 24px;
  font-weight: 800;
  line-height: 1.5;
}

.twkm-ramen-footer-box > p {
  margin: 0 auto 32px;
  max-width: 600px;
  font-size: 15px;
  line-height: 1.9;
  color: var(--twkm-sub);
}

.twkm-ramen-footer-action {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding-top: 32px;
  border-top: 1px dashed #fecaca;
}

.twkm-ramen-footer-action p {
  margin: 0;
  font-size: 14px;
  font-weight: 700;
  color: var(--twkm-text);
}

.twkm-btn-ramen {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 0 32px;
  background: #fff;
  border: 2px solid var(--twkm-accent);
  color: var(--twkm-accent);
  border-radius: 999px;
  font-size: 15px;
  font-weight: 800;
  text-decoration: none;
  transition: all 0.3s ease;
}

.twkm-btn-ramen:hover {
  background: var(--twkm-accent);
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(220, 38, 38, 0.2);
}

/* ==========================================
   レスポンシブ
========================================== */
@media (max-width: 767px) {
  .twkm-ramen-archive-intro,
  .twkm-ramen-archive-footer {
    padding: 0 12px;
  }

  .twkm-ramen-hero {
    padding: 32px 20px;
    border-radius: 24px;
    margin-bottom: 20px;
    text-align: left;
  }

  .twkm-ramen-eyebrow {
    margin-bottom: 10px;
  }

  .twkm-ramen-title-main {
    margin-bottom: 12px;
    font-size: 24px;
    text-align: left;
  }

  .twkm-ramen-lead {
    max-width: none;
    text-align: left;
    font-size: 14px;
    line-height: 1.8;
  }

  .twkm-ramen-footer-box {
    padding: 24px 20px;
    border-radius: 24px;
    text-align: left;
  }

  .twkm-ramen-footer-box h2 {
    font-size: 20px;
    text-align: left;
  }

  .twkm-ramen-footer-box > p {
    max-width: none;
    font-size: 14px;
    line-height: 1.8;
  }

  .twkm-ramen-footer-action {
    align-items: flex-start;
    padding-top: 24px;
  }

  .twkm-btn-ramen {
    width: 100%;
  }
}/* End custom CSS */