/* ===================================================================
  M-ZECライクなトーン＆六角マスク＆グラデUI（整理版）
  対象HTML: 直近メッセージの index.html
  保存先: assets/css/main.css
=================================================================== */

/* ========= Tokens ========= */
:root {
  /* 色設計（明るいブルー系） */
  --blue-1: #2a9df4;
  --blue-2: #1e88ff;
  --blue-3: #1665ff;
  --blue-4: #0f3fff;
  --ink: #0e255a;
  --ink-2: #1349a6;
  --accent: var(--blue-2);
  --bg: #f5f9ff;
  --paper: #ffffff;
  --muted: #6c7aa3;

  /* エフェクト */
  --shadow-1: 0 8px 22px rgba(0, 0, 0, .10);
  --shadow-2: 0 12px 34px rgba(0, 0, 0, .14);

  /* RADIUS・ギャップ */
  --radius: 14px;
  --gap: clamp(20px, 3.6vw, 48px);

  /* HERO位置（PC用） */
  --hero-inset-x: clamp(40px, 6vw, 120px);
  --hero-top: clamp(180px, 32vh, 42vh);
  --hero-width: min(720px, 56vw);
}

/* ========= Reset-lite ========= */
* {
  box-sizing: border-box
}

html,
body {
  height: 100%
}

body {
  margin: 0;
  font-family: "Hiragino Kaku Gothic ProN", "Noto Sans JP", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "メイリオ", Meiryo, sans-serif;
  color: var(--ink);
  background: linear-gradient(180deg, #e6f0ff 0%, #ffffff 70%);
  -webkit-font-smoothing: antialiased;
  line-height: 1.75;
}

a {
  color: inherit
}

a:hover {
  color: var(--blue-3);
}

/* ========= Layout helpers ========= */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 clamp(16px, 4vw, 32px)
}

.section {
  padding: clamp(40px, 8vh, 96px) 0
}

/* ========= Buttons ========= */
.btn {
  --h: 50px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .65em;
  height: var(--h);
  padding: 0 24px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 15px;
  text-decoration: none;
  border: 2px solid transparent;
  transition: .2s transform, .25s box-shadow, .25s background, .25s color, .25s border-color;
  box-shadow: var(--shadow-1);
  will-change: transform, box-shadow
}

.btn:active {
  transform: translateY(1px)
}

.btn--primary {
  color: #fff;
  background: linear-gradient(135deg, var(--blue-2) 0%, var(--blue-4) 100%);
}

.btn--primary:hover {
  filter: brightness(1.05);
  box-shadow: 0 12px 34px rgba(30, 136, 255, .22);
}

.btn--ghost {
  background: rgba(255, 255, 255, .85);
  color: var(--ink-2);
  border: 2px solid rgba(30, 136, 255, .28);
  backdrop-filter: blur(4px)
}

.btn--ghost:hover {
  background: #fff;
  border-color: rgba(30, 136, 255, .45);
}

/* ========= Topbar (ロゴのみ) ========= */
.topbar {
  position: absolute;
  inset: 0 auto auto 0;
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  z-index: 10
}

.brand--hero .brand-logo {
  height: 48px;
  filter: drop-shadow(0 2px 12px rgba(0, 0, 0, .25))
}

/* ========= Burger Menu ========= */
.nav__toggle {
  position: fixed;
  right: clamp(12px, 2vw, 20px);
  top: clamp(12px, 2vw, 20px);
  z-index: 10020;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--blue-2), var(--blue-3));
  color: #fff;
  display: grid;
  place-items: center;
  box-shadow: var(--shadow-1);
  border: 0;
  cursor: pointer;
}

.burger {
  position: relative;
  width: 26px;
  height: 16px;
  display: block
}

.burger i {
  position: absolute;
  left: 0;
  right: 0;
  height: 2px;
  background: #fff;
  border-radius: 2px;
  transition: .25s
}

.burger i:nth-child(1) {
  top: 0
}

.burger i:nth-child(2) {
  top: 7px
}

.burger i:nth-child(3) {
  top: 14px
}

details[open] .burger i:nth-child(1) {
  top: 7px;
  transform: rotate(45deg)
}

details[open] .burger i:nth-child(2) {
  opacity: 0
}

details[open] .burger i:nth-child(3) {
  top: 7px;
  transform: rotate(-45deg)
}

/* パネル */
.nav__sheet {
  display: none
}

details[open] .nav__sheet {
  display: block;
  position: fixed;
  inset: 0;
  z-index: 10010;
}

.nav__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10, 14, 40, .28);
  backdrop-filter: blur(4px)
}

.nav__panel {
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: min(360px, 86vw);
  background: var(--paper);
  padding: 28px 22px;
  box-shadow: -8px 0 28px rgba(0, 0, 0, .18)
}

.nav__list {
  list-style: none;
  margin: 0;
  padding: 0
}

.nav__link {
  display: block;
  padding: 16px 14px;
  border-bottom: 1px solid #e7eaf1;
  text-decoration: none;
  font-weight: 700
}

.nav__link:hover {
  background: #f6f7fb;
  color: var(--ink-2)
}

.nav__close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  border: 0;
  background: linear-gradient(135deg, var(--blue-2), var(--blue-3));
  color: #fff;
  box-shadow: var(--shadow-1)
}

/* ========= FV（フルスクリーンスライダー） ========= */
.fv {
  position: relative;
  min-height: 100svh;
  isolation: isolate;
  overflow: hidden;
  background: #f5f9ff;
  width: 100%;
  max-width: 100%;
}

.fv__inner {
  position: relative;
  width: 100%;
  max-width: 100%;
  min-height: 100svh;
  margin: 0;
  padding: 0;
}

/* スライダー */
.fv-slider {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.fv-slides {
  position: relative;
  width: 100%;
  height: 100svh;
}

.fv-slide {
  position: absolute;
  inset: 0;
  background: center/cover no-repeat;
  opacity: 0;
  transform: scale(1.05);
  transition: opacity 1.2s ease, transform 1.2s ease;
}

.fv-slide.is-active {
  opacity: 1;
  transform: scale(1);
}

.fv-slide.is-active .ken {
  animation: ken 15s ease-in-out both;
}

@keyframes ken {
  from {
    transform: scale(1);
  }

  to {
    transform: scale(1.08);
  }
}

/* コピー（PC） */
@media (min-width:901px) {
  .masthead .fv .fv__copy {
    position: absolute;
    left: var(--hero-inset-x);
    top: var(--hero-top);
    bottom: auto;
    width: var(--hero-width);
    transform: none;
    z-index: 3;
    isolation: isolate;
  }

  .masthead .fv .fv__title {
    margin: 0 0 12px;
    font-size: clamp(40px, 6vw, 50px);
    font-weight: 900;
    line-height: 1.12;
    word-break: keep-all;
    letter-spacing: .02em;
    background: linear-gradient(90deg, var(--blue-2) 0%, #b43a9a 55%, var(--blue-4) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    text-shadow: 0 3px 22px rgba(0, 0, 0, .10);
  }

  .masthead .fv .fv__lead {
    margin: 0 0 18px;
    font-size: clamp(14px, 1.3vw, 18px);
    line-height: 1.9;
    color: rgba(13, 37, 90, .86);
  }

  .masthead .fv .fv__copy .btn {
    margin-right: 10px;
  }
}

/* コピー（モバイル） */
@media (max-width: 900px) {
  .masthead .fv .fv__copy {
    position: absolute;
    top: auto;
    bottom: clamp(6vh, 12vh, 14vh);
    left: clamp(16px, 5vw, 24px);
    right: clamp(16px, 5vw, 24px);
    width: auto;
    transform: none;
    text-align: left;
    z-index: 3;
  }

  .masthead .fv .fv__title {
    font-size: clamp(24px, 6vw, 32px);
    line-height: 1.25;
    margin-bottom: 10px;
    background: linear-gradient(90deg, var(--blue-2) 0%, var(--blue-4) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
  }

  .masthead .fv .fv__lead {
    font-size: clamp(13px, 4vw, 16px);
    line-height: 1.7;
    margin-bottom: 18px;
    color: rgba(13, 37, 90, .9);
  }

  .masthead .fv .fv__copy .btn {
    margin-right: 8px;
  }
}

/* Scrollインジケータ（PC右端） */
.fv__scroll {
  position: absolute;
  right: calc(clamp(10px, 1.8vw, 20px) + env(safe-area-inset-right, 0px));
  top: 44%;
  transform: translateY(-50%) rotate(90deg);
  display: flex;
  gap: 12px;
  align-items: center;
  z-index: 3;
  color: rgba(15, 23, 85, .65);
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  pointer-events: none;
  opacity: .9;
}

.fv__scroll-line {
  width: clamp(72px, 8vw, 100px);
  height: 1.5px;
  background: linear-gradient(90deg, rgba(15, 23, 85, 0) 0%, rgba(15, 23, 85, .55) 100%);
}

@media (max-width: 1280px) {
  .fv__scroll {
    top: 46%;
  }
}

@media (max-width: 900px) {
  .fv__scroll {
    display: none;
  }
}

/* 右側サイド装飾 */
.fv__side {
  position: absolute;
  right: clamp(8px, 1.6vw, 20px);
  bottom: clamp(10px, 2vh, 24px);
  width: clamp(110px, 14vw, 220px);
  display: grid;
  grid-template-rows: auto auto;
  align-items: end;
  justify-items: center;
  gap: 14px;
  z-index: 50;
  pointer-events: none;
}

.fv__dash {
  position: absolute;
  right: 50%;
  bottom: calc(100% + 6px);
  width: 2px;
  height: 74%;
  background: repeating-linear-gradient(to bottom, rgba(19, 73, 166, .95) 0 18px, transparent 18px 36px);
  transform: translateX(50%);
  opacity: .75;
}

.fv__balloon {
  position: relative;
  width: clamp(120px, 16vw, 200px);
  background: #fff;
  border: 3px solid rgba(19, 73, 166, .85);
  border-radius: 18px;
  box-shadow: var(--shadow-1);
  padding: 12px 14px;
  pointer-events: auto;
  transform: translateY(-2px);
}

.fv__balloon p {
  margin: 0;
  text-align: center;
  color: var(--ink-2);
  font-weight: 800;
  line-height: 1.24;
  font-size: clamp(12px, 1.7vw, 16px);
}

.fv__balloon::after {
  content: "";
  position: absolute;
  right: 18%;
  bottom: -14px;
  width: 22px;
  height: 22px;
  background: #fff;
  border-right: 3px solid rgba(19, 73, 166, .85);
  border-bottom: 3px solid rgba(19, 73, 166, .85);
  transform: rotate(45deg);
  border-radius: 4px;
}

.fv__mascot {
  background: none;
  box-shadow: none;
  border: none;
  width: auto;
  height: auto;
  padding: 0;
  margin: 0;
  display: grid;
  place-items: center;
  overflow: visible;
}

.fv__mascot img {
  display: block;
  width: clamp(180px, 22vw, 320px);
  height: auto;
  max-width: 100%;
  object-fit: contain;
  background: transparent;
}

@media (max-width: 1280px) {
  .fv__side {
    right: clamp(6px, 2vw, 16px);
  }

  .fv__balloon {
    width: clamp(120px, 18vw, 180px);
  }
}

@media (max-width: 900px) {
  .fv__mascot img {
    width: clamp(140px, 46vw, 200px);
  }
}

/* ページャ */
.fv-pager {
  position: absolute;
  left: clamp(22px, 6vw, 120px);
  bottom: clamp(14px, 4vh, 28px);
  display: flex;
  gap: 8px;
  z-index: 3;
}

.fv-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(15, 23, 85, .25);
  border: 0;
  cursor: pointer;
}

.fv-dot.is-active {
  background: linear-gradient(90deg, var(--blue-2), var(--blue-4));
}

.fv-badge {
  position: absolute;
  right: clamp(14px, 2vw, 24px);
  bottom: clamp(14px, 3vh, 24px);
  z-index: 4;
  background: rgba(0, 0, 0, .45);
  color: #fff;
  padding: 6px 10px;
  border-radius: 10px;
  font-size: 12px;
  backdrop-filter: blur(4px);
  user-select: none;
  opacity: 0;
  transition: .2s;
}

.fv.is-paused .fv-badge {
  opacity: 1;
}

/* ========= 見出し（旗アイコン） ========= */
h2 {
  position: relative;
  margin: 0 0 16px;
  font-size: clamp(22px, 3.2vw, 28px);
  font-weight: 900;
  color: var(--ink);
}

h2::before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  margin-right: 10px;
  width: 14px;
  height: 10px;
  background: linear-gradient(135deg, var(--blue-2), var(--blue-4));
  clip-path: polygon(0 0, 100% 0, 70% 50%, 100% 100%, 0 100%);
  border-radius: 2px;
}

/* ========= Hexカード風の共通マスク ========= */
.hex-mask,
.about-grid .ph,
.works-grid .ph {
  clip-path: polygon(6% 0%, 94% 0%, 100% 50%, 94% 100%, 6% 100%, 0% 50%);
  overflow: hidden;
  border-radius: 0;
  box-shadow: 0 12px 32px rgba(22, 101, 255, .16);
  background: #e9eef7;
}

/* ========= About / Works ========= */
.about-grid,
.works-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gap);
  align-items: center;
}

.about-grid .ph {
  position: relative;
  z-index: 1;
  background: url('/assets/images/about-1.jpg') center/cover no-repeat;
}

.works-grid .ph {
  background: url('/assets/images/about-2.jpg') center/cover no-repeat;
}

.about-grid p,
.works-grid p {
  color: var(--muted);
}

@media (max-width:900px) {

  .about-grid,
  .works-grid {
    grid-template-columns: 1fr;
  }
}

/* ========= サービス ========= */
.svc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: clamp(14px, 2.2vw, 22px);
}

.svc {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  text-decoration: none;
  color: var(--ink);
  padding: 26px 18px;
  background: var(--paper);
  border: 0;
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
  position: relative;
  overflow: hidden;
  transition: .25s;
}

.svc::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--blue-2), var(--blue-3));
  transform: translateX(-100%);
  transition: .35s ease;
}

.svc:hover::before {
  transform: translateX(0);
}

.svc:hover {
  box-shadow: var(--shadow-2);
  transform: translateY(-2px);
}

.ico {
  width: 64px;
  height: 64px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  color: #fff;
  font-weight: 900;
  margin-bottom: 10px;
  background: linear-gradient(135deg, var(--blue-2), var(--blue-4));
}

/* ========= News ========= */
.news-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(14px, 2.2vw, 22px);
}

.news {
  background: var(--paper);
  box-shadow: var(--shadow-1);
  border-radius: var(--radius);
  overflow: hidden;
  cursor: pointer;
  transition: .25s;
}

.news:hover {
  box-shadow: var(--shadow-2);
  transform: translateY(-2px);
}

.news .thumb {
  aspect-ratio: 16/9;
  background: url('https://images.unsplash.com/photo-1504384308090-c894fdcc538d?w=1200&q=80') center/cover no-repeat;
}

.news time {
  display: block;
  padding: 14px 16px 6px;
  font-weight: 800;
  color: var(--blue-3);
}

.news h3 {
  padding: 0 16px 18px;
  margin: 0;
}

/* ========= Recruit ========= */
.recruit {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(20px, 4vw, 48px);
  align-items: center;
  background: linear-gradient(135deg, rgba(30, 136, 255, .07), rgba(22, 101, 255, .07));
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
  padding: clamp(28px, 5vw, 48px);
}

.recruit .ph {
  width: 100%;
  min-height: 280px;
  aspect-ratio: 4 / 3;
  background: url('/assets/images/recruit.png') center/cover no-repeat;
  clip-path: polygon(6% 0%, 94% 0%, 100% 50%, 94% 100%, 6% 100%, 0% 50%);
  box-shadow: 0 16px 40px rgba(30, 136, 255, .18);
  border: 0;
}

.recruit h2 {
  margin-bottom: 12px;
}

.recruit .note {
  margin-bottom: 18px;
  line-height: 1.9;
}

@media (max-width: 900px) {
  .recruit {
    grid-template-columns: 1fr;
  }

  .recruit .ph {
    min-height: 220px;
  }
}

/* ========= Footer ========= */
.footer {
  background: linear-gradient(180deg, #f0f6ff 0%, #eaf2ff 100%);
  margin-top: clamp(40px, 8vh, 80px);
  padding: clamp(36px, 6vw, 56px) 0 28px;
}

.footer-nav {
  display: flex;
  gap: clamp(12px, 2vw, 24px);
  flex-wrap: wrap;
  margin: 0 0 24px;
  justify-content: center;
}

.footer-nav a {
  font-weight: 700;
  text-decoration: none;
  font-size: clamp(13px, 1.4vw, 15px);
  padding: 4px 0;
  transition: color 0.2s ease;
}

.footer-nav a:hover {
  color: var(--blue-2);
}

.foot-flex {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 22px;
  align-items: center;
  padding-bottom: 22px;
  border-bottom: 1px solid #dfe5ef;
}

.tel {
  font-size: clamp(22px, 3.2vw, 30px);
  font-weight: 900;
  color: var(--blue-3);
}

/* フッターのコピーライト部分 */
.footer .container:last-child {
  padding-top: 20px;
}

.footer small {
  font-size: 13px;
}

/* レスポンシブ: タブレット */
@media (max-width: 900px) {
  .footer-nav {
    gap: 16px 20px;
  }
}

/* レスポンシブ: モバイル */
@media (max-width: 768px) {
  .footer {
    padding: 40px 0 24px;
  }

  .footer-nav {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px 16px;
    text-align: center;
    margin-bottom: 28px;
  }

  .footer-nav a {
    font-size: 14px;
    padding: 8px 4px;
    background: rgba(255, 255, 255, 0.5);
    border-radius: 8px;
    transition: background 0.2s ease, color 0.2s ease;
  }

  .footer-nav a:hover {
    background: rgba(255, 255, 255, 0.8);
  }

  .foot-flex {
    grid-template-columns: 1fr;
    text-align: center;
    gap: 16px;
  }

  .foot-flex>div:last-child {
    justify-self: center !important;
  }

  .tel {
    font-size: 24px;
  }

  .footer .note {
    font-size: 12px;
  }

  .footer .btn {
    width: 100%;
    max-width: 280px;
  }

  .footer .container:last-child {
    justify-content: center !important;
    padding-top: 16px;
  }

  .footer small {
    font-size: 12px;
  }
}

/* レスポンシブ: 小さいモバイル */
@media (max-width: 480px) {
  .footer-nav {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px 12px;
  }

  .footer-nav a {
    font-size: 13px;
    padding: 10px 4px;
  }

  .tel {
    font-size: 22px;
  }
}

/* ========= 細かな文字色 ========= */
.note {
  color: var(--muted);
}

/* ========= アクセシビリティ：スクリーンリーダー用 ========= */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ========= ユーティリティ ========= */
.br-md,
.br-sm {
  display: none;
}

@media (max-width:1100px) {
  .br-md {
    display: block;
  }
}

@media (max-width:560px) {
  .br-sm {
    display: block;
  }
}

/* ========= FV（フルスクリーンスライダー） ========= */
.fv {
  position: relative;
  min-height: 100svh;
  isolation: isolate;
  overflow: hidden;
  background: #f5f9ff;
}

.fv__inner {
  position: relative;
  width: 100%;
  min-height: 100svh;
  margin: 0 auto;
}

/* 左右の白い面取り - 非表示 */
.fv__deco {
  display: none;
}

/* スライダー */
.fv-slider {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.fv-slides {
  position: relative;
  width: 100%;
  height: 100svh;
}

.fv-slide {
  position: absolute;
  inset: 0;
  background: center/cover no-repeat;
  opacity: 0;
  transform: scale(1.05);
  transition: opacity 1.2s ease, transform 1.2s ease;
}

.fv-slide.is-active {
  opacity: 1;
  transform: scale(1);
}

.fv-slide.is-active .ken {
  animation: ken 15s ease-in-out both;
}

@keyframes ken {
  from {
    transform: scale(1);
  }

  to {
    transform: scale(1.08);
  }
}

.masthead .fv .fv__title {
  margin: 0 0 12px;
  font-size: clamp(40px, 6vw, 50px);
  font-weight: 900;
  line-height: 1.12;
  word-break: keep-all;
  letter-spacing: .02em;
  background: linear-gradient(90deg, var(--blue-2) 0%, var(--blue-3) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow: 0 3px 22px rgba(0, 0, 0, .10);
}

.masthead .fv .fv__copy {
  position: absolute;
  left: var(--hero-inset-x);
  top: calc(var(--hero-top) + 60px);
  /* ← ここを変更 */
  bottom: auto;
  width: var(--hero-width);
  transform: none;
  z-index: 3;
  isolation: isolate;
  background: rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(2px);
  padding: clamp(24px, 3vw, 36px);
  border-radius: var(--radius);
  box-shadow: none;
}

/* 右側サイド装飾 */
.fv__side {
  position: absolute;
  right: clamp(20px, 8vw, 100px);
  bottom: clamp(20px, 8vh, 80px);
  width: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  z-index: 50;
  pointer-events: none;
}

.fv__dash {
  display: none;
}

.fv__balloon {
  position: relative;
  width: auto;
  min-width: 140px;
  max-width: 220px;
  background: #fff;
  border: 3px solid rgba(19, 73, 166, .85);
  border-radius: 18px;
  box-shadow: 0 8px 22px rgba(0, 0, 0, .10);
  padding: 10px 14px;
  transform: translateY(4px);
  pointer-events: auto;
  order: 1;
  text-align: center;
}

.fv__balloon p {
  margin: 0;
  font-weight: 900;
  line-height: 1.25;
  color: #1349a6;
  font-size: clamp(11px, 1.4vw, 14px);
}

.fv__balloon::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -12px;
  width: 20px;
  height: 20px;
  background: #fff;
  border-right: 3px solid rgba(19, 73, 166, .85);
  border-bottom: 3px solid rgba(19, 73, 166, .85);
  transform: translateX(-50%) rotate(45deg);
  border-radius: 4px;
}

/* === Mascot balloon & name layout override === */
/* 縦並び：吹き出し → マスコット → キャラ名 */
.fv__side {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  /* 要素間の余白 */
}

/* 吹き出しを最上段にして上配置（既に上なら念のため順序指定） */
.fv__balloon {
  order: 1;
  margin-bottom: 6px;
  /* 風船と頭の間 */
}

/* マスコット本体を2段目 */
.fv__mascot {
  order: 2;
}

/* キャラクター名を3段目（白文字＋視認性アップ） */
.fv__mascot-name {
  order: 3;
  margin-top: 4px;
  font-weight: 900;
  font-size: clamp(12px, 1.8vw, 14px);
  color: #fff;
  /* ← 白文字 */
  text-shadow: 0 2px 8px rgba(0, 0, 0, .45);
  /* 背景に乗っても読めるように */
}

/* 吹き出しの三角（尾）は下向きセンターでマスコットに向ける */
.fv__balloon::after {
  left: 50%;
  right: auto;
  bottom: -14px;
  transform: translateX(-50%) rotate(45deg);
}

/* モバイルで少し詰める */
@media (max-width: 900px) {
  .fv__side {
    gap: 10px;
  }

  .fv__balloon {
    width: clamp(140px, 58vw, 220px);
  }

  .fv__mascot img {
    width: clamp(140px, 46vw, 200px);
  }
}

/* === Mascot & balloon: size down + avoid overlap with side deco === */

/* サイド全体を少し内側＆上に寄せる（装飾と離す） */
.fv__side {
  right: clamp(22px, 3.6vw, 48px);
  /* 右端からさらに内側へ */
  bottom: clamp(26px, 4.6vh, 52px);
  /* 下端から少し上げる */
  gap: 10px;
  /* 余白をやや詰める */
}

/* 風船をひと回り小さく */
.fv__balloon {
  width: clamp(120px, 14vw, 180px);
  /* 120-180pxの範囲で縮小 */
  padding: 10px 12px;
}

.fv__balloon p {
  font-size: clamp(11px, 1.4vw, 14px);
  line-height: 1.3;
}

/* 吹き出しの尾：中央下でマスコットに向ける（位置微調整） */
.fv__balloon::after {
  bottom: -12px;
  /* 尾の出幅を少し短く */
  right: auto;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
}

/* マスコットを少し小さく */
.fv__mascot img {
  width: clamp(150px, 18vw, 240px);
  /* 150-240pxに縮小レンジ */
}

/* キャラ名は小さめ＋読みやすさ維持（白のまま） */
.fv__mascot-name {
  font-size: clamp(11px, 1.6vw, 13px);
  margin-top: 2px;
  color: #fff;
  text-shadow: 0 2px 8px rgba(0, 0, 0, .45);
}

/* 縦の破線デコ（fv__dash）と干渉しないよう少しだけ上に逃がす */
.fv__dash {
  top: -110px;
  /* 既存よりさらに上へオフセット */
  height: 70px;
  /* 長さを短くして重なりを回避 */
  opacity: .7;
}

/* ==== Responsive fine-tune ==== */
@media (max-width: 1280px) {
  .fv__side {
    right: clamp(18px, 3vw, 34px);
    bottom: clamp(22px, 4vh, 40px);
  }

  .fv__balloon {
    width: clamp(120px, 16vw, 170px);
  }

  .fv__mascot img {
    width: clamp(140px, 22vw, 210px);
  }

  .fv__dash {
    top: -100px;
    height: 64px;
  }
}

@media (max-width: 900px) {

  /* モバイルはさらに一段階コンパクトに */
  .fv__side {
    right: clamp(14px, 5vw, 24px);
    bottom: clamp(20px, 8vh, 36px);
    gap: 8px;
  }

  .fv__balloon {
    width: auto;
    max-width: 200px;
    padding: 7px 11px;
    border-width: 2.5px;
  }

  .fv__balloon p {
    font-size: clamp(11px, 1.4vw, 14px);
  }

  .fv__mascot img {
    width: clamp(130px, 42vw, 190px);
  }

  .fv__dash {
    top: -90px;
    height: 56px;
  }
}

/* === Mascot area refinement: unified compact spacing === */
.fv__side {
  right: clamp(20px, 3vw, 40px);
  /* 少し内側に配置 */
  bottom: clamp(24px, 4vh, 48px);
  /* 少し上に上げる */
  gap: 6px;
  /* 全体の余白を詰めて統一感 */
}

/* 吹き出しサイズを少し小さくし、上との距離を短く */
.fv__balloon {
  width: clamp(120px, 14vw, 180px);
  padding: 8px 10px;
  border-width: 2.5px;
  margin-bottom: 2px;
  /* 吹き出しとマスコットの距離を詰める */
}

.fv__balloon p {
  font-size: clamp(11px, 1.3vw, 14px);
  line-height: 1.25;
}

.fv__balloon::after {
  bottom: -10px;
  /* 尾を短くして近づける */
  transform: translateX(-50%) rotate(45deg);
}

/* マスコットサイズをやや小さく調整 */
.fv__mascot img {
  width: clamp(140px, 18vw, 210px);
}

/* キャラ名：白文字＋余白を抑える */
.fv__mascot-name {
  margin-top: 0;
  font-size: clamp(11px, 1.4vw, 13px);
  color: #fff;
  font-weight: 800;
  text-shadow: 0 2px 8px rgba(0, 0, 0, .45);
}

/* 縦ライン（破線）と干渉しないよう位置調整 */
.fv__dash {
  top: -90px;
  height: 60px;
  opacity: .7;
}

/* モバイル時も統一感を保つ */
@media (max-width: 900px) {
  .fv__side {
    right: clamp(16px, 5vw, 24px);
    bottom: clamp(22px, 6vh, 36px);
    gap: 4px;
  }

  .fv__balloon {
    width: clamp(130px, 50vw, 170px);
    padding: 7px 9px;
  }

  .fv__balloon p {
    font-size: clamp(12px, 3.6vw, 13px);
  }

  .fv__mascot img {
    width: clamp(130px, 42vw, 180px);
  }

  .fv__dash {
    top: -80px;
    height: 52px;
  }
}

/* === Mascot area: slightly enlarged, unified spacing === */
.fv__side {
  right: clamp(22px, 3vw, 42px);
  bottom: clamp(22px, 4vh, 44px);
  gap: 8px;
  /* 少し広げる */
}

/* 吹き出しをひと回り大きく */
.fv__balloon {
  width: clamp(140px, 16vw, 200px);
  padding: 10px 12px;
  border-width: 3px;
  margin-bottom: 4px;
}

.fv__balloon p {
  font-size: clamp(12px, 1.5vw, 15px);
  line-height: 1.35;
}

.fv__balloon::after {
  bottom: -12px;
  transform: translateX(-50%) rotate(45deg);
}

/* マスコットをやや拡大 */
.fv__mascot img {
  width: clamp(160px, 20vw, 240px);
}

/* キャラ名を少し大きく＋視認性アップ */
.fv__mascot-name {
  margin-top: 2px;
  font-size: clamp(12px, 1.6vw, 14px);
  color: #fff;
  font-weight: 900;
  text-shadow: 0 2px 10px rgba(0, 0, 0, .5);
}

/* 破線デコを少し長く＆被らないように調整 */
.fv__dash {
  top: -100px;
  height: 68px;
  opacity: .75;
}

/* === モバイル時 === */
@media (max-width: 900px) {
  .fv__side {
    right: clamp(16px, 5vw, 24px);
    bottom: clamp(20px, 6vh, 36px);
    gap: 6px;
  }

  .fv__balloon {
    width: clamp(140px, 54vw, 190px);
    padding: 9px 11px;
  }

  .fv__balloon p {
    font-size: clamp(12px, 3.6vw, 14px);
  }

  .fv__mascot img {
    width: clamp(150px, 46vw, 200px);
  }

  .fv__dash {
    top: -90px;
    height: 60px;
  }
}

/* === Scroll indicator: right edge placement (no overlap) === */
.fv__scroll {
  right: clamp(18px, 2vw, 0px);
  /* 右端寄りに固定 */
  left: auto;
  /* 左位置解除 */
  top: 30%;
  /* やや中央下に配置して視認性を確保 */
  transform: translateY(-50%) rotate(90deg);
  color: rgba(15, 23, 85, .65);
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 10px;
  z-index: 5;
  /* マスコットより前、吹き出しより後ろ */
  opacity: .9;
  pointer-events: none;
}

.fv__scroll-line {
  width: clamp(72px, 8vw, 100px);
  height: 1.5px;
  background: linear-gradient(90deg, rgba(15, 23, 85, 0) 0%, rgba(15, 23, 85, .55) 100%);
}

/* モバイルでは非表示のまま */
@media (max-width: 900px) {
  .fv__scroll {
    display: none;
  }
}

/* =========================
 Tablet & Mobile only
 ※ PC(≥1280px)は変更しない
========================= */

/* ===== タブレット（900–1279px）===== */
@media (min-width:900px) and (max-width:1279px) {

  /* コピーカードの圧迫感を軽減（PCは触らない） */
  .masthead .fv .fv__copy {
    padding: clamp(18px, 2.6vw, 28px);
    background: rgba(255, 255, 255, .14);
    backdrop-filter: blur(4px);
    border-radius: 16px;
    box-shadow: 0 10px 32px rgba(15, 23, 85, .12);
  }

  .masthead .fv .fv__title {
    font-size: clamp(34px, 4.4vw, 44px);
    line-height: 1.14;
  }

  .masthead .fv .fv__lead {
    font-size: clamp(13px, 1.4vw, 16px);
    line-height: 1.8;
    max-width: 54ch;
  }

  .masthead .fv .fv__copy .btn {
    --h: 46px;
    padding: 0 20px;
    white-space: nowrap;
  }

  /* 右下：吹き出し・マスコットは少し内側＆上へ（被り回避） */
  .fv__side {
    right: clamp(18px, 3.2vw, 36px);
    bottom: clamp(24px, 6vh, 56px);
    gap: 8px;
  }

  .fv__balloon {
    width: clamp(150px, 22vw, 200px);
    padding: 10px 12px;
    margin-bottom: 4px;
  }

  .fv__balloon p {
    font-size: clamp(12px, 1.5vw, 15px);
    line-height: 1.35;
  }

  .fv__balloon::after {
    bottom: -12px;
    transform: translateX(-50%) rotate(45deg);
  }

  .fv__mascot img {
    width: clamp(170px, 22vw, 230px);
  }

  .fv__mascot-name {
    font-size: 13px;
    color: #fff;
    text-shadow: 0 2px 10px rgba(0, 0, 0, .5);
  }

  /* スクロールUI：右端固定、やや下（装飾と重ならない） */
  .fv__scroll {
    right: clamp(16px, 2.6vw, 26px);
    left: auto;
    top: 46%;
    transform: translateY(-50%) rotate(90deg);
  }

  /* ページャ：ボタンと干渉しない位置に */
  .fv-pager {
    left: clamp(16px, 5vw, 80px);
    bottom: clamp(10px, 3vh, 24px);
  }
}

/* ===== モバイル（≤899px）===== */
@media (max-width: 899px) {
  .masthead .fv .fv__copy {
    left: clamp(14px, 5vw, 24px);
    right: clamp(14px, 5vw, 24px);
    bottom: clamp(7vh, 12vh, 16vh);
    top: auto;
    padding: clamp(14px, 3.8vw, 20px);
    background: rgba(255, 255, 255, .14);
    backdrop-filter: blur(4px);
    border-radius: 16px;
    box-shadow: 0 10px 32px rgba(15, 23, 85, .12);
  }

  .masthead .fv .fv__title {
    font-size: clamp(26px, 7vw, 32px);
    line-height: 1.22;
    margin-bottom: 8px;
  }

  .masthead .fv .fv__lead {
    font-size: clamp(13px, 3.9vw, 15px);
    line-height: 1.7;
    margin-bottom: 14px;
  }

  .masthead .fv .fv__copy .btn {
    --h: 44px;
    padding: 0 18px;
    margin-right: 8px;
    white-space: nowrap;
  }

  /* 右下セットを非表示（別セクションで表示） */
  .fv__side {
    display: none;
  }

  .fv__balloon {
    width: clamp(130px, 54vw, 180px);
    padding: 8px 10px;
    margin-bottom: 4px;
  }

  .fv__balloon p {
    font-size: clamp(12px, 3.8vw, 14px);
    line-height: 1.35;
  }

  .fv__mascot img {
    width: clamp(140px, 46vw, 190px);
  }

  .fv__mascot-name {
    font-size: clamp(11px, 3.2vw, 12px);
    color: #fff;
    text-shadow: 0 2px 8px rgba(0, 0, 0, .45);
  }

  /* スクロールUIは非表示（誤タップ防止 & 画面密度最適化） */
  .fv__scroll {
    display: none;
  }

  /* ページャを左下寄せに */
  .fv-pager {
    left: clamp(12px, 6vw, 24px);
    bottom: clamp(8px, 4vh, 18px);
  }
}

/* ===== 極小端末（≤360px）===== */
@media (max-width: 360px) {
  .masthead .fv .fv__lead {
    display: none;
  }

  /* タイトルとCTAを優先 */
  .masthead .fv .fv__copy .btn {
    --h: 42px;
    padding: 0 16px;
  }

  .fv__balloon {
    width: min(70vw, 180px);
  }
}

/* =========================
 Responsive refinement (Tablet & Mobile only)
 ※ PC（1280px以上）は現状維持
========================= */

/* ===== タブレット（900–1279px）===== */
@media (min-width:900px) and (max-width:1279px) {
  .masthead .fv .fv__copy {
    padding: clamp(18px, 2.6vw, 28px);
    background: rgba(255, 255, 255, .14);
    backdrop-filter: blur(4px);
    border-radius: 16px;
    box-shadow: 0 10px 32px rgba(15, 23, 85, .12);
  }

  .masthead .fv .fv__title {
    font-size: clamp(34px, 4.4vw, 44px);
    line-height: 1.14;
  }

  .masthead .fv .fv__lead {
    font-size: clamp(13px, 1.4vw, 16px);
    line-height: 1.8;
    max-width: 54ch;
  }

  .masthead .fv .fv__copy .btn {
    --h: 46px;
    padding: 0 20px;
    white-space: nowrap;
  }

  /* 右下キャラ：やや上＆内側（コピーと干渉防止） */
  .fv__side {
    right: clamp(18px, 3.2vw, 36px);
    bottom: clamp(24px, 6vh, 56px);
    gap: 8px;
  }

  .fv__balloon {
    width: clamp(150px, 22vw, 200px);
    padding: 10px 12px;
  }

  .fv__balloon p {
    font-size: clamp(12px, 1.5vw, 15px);
    line-height: 1.35;
  }

  .fv__mascot img {
    width: clamp(170px, 22vw, 230px);
  }

  .fv__mascot-name {
    font-size: 13px;
    color: #fff;
    text-shadow: 0 2px 10px rgba(0, 0, 0, .5);
  }

  /* スクロールUIを右端に維持しつつ、マスコットと被らない高さに調整 */
  .fv__scroll {
    right: clamp(18px, 2vw, 28px);
    left: auto;
    top: 45%;
    transform: translateY(-50%) rotate(90deg);
  }
}

/* ===== モバイル（～899px）===== */
@media (max-width: 899px) {
  .masthead .fv .fv__copy {
    left: clamp(14px, 5vw, 24px);
    right: clamp(14px, 5vw, 24px);
    bottom: clamp(7vh, 12vh, 16vh);
    top: auto;
    padding: clamp(14px, 3.8vw, 20px);
    background: rgba(255, 255, 255, .14);
    backdrop-filter: blur(4px);
    border-radius: 16px;
    box-shadow: 0 10px 32px rgba(15, 23, 85, .12);
  }

  .masthead .fv .fv__title {
    font-size: clamp(26px, 7vw, 32px);
    line-height: 1.22;
    margin-bottom: 8px;
  }

  .masthead .fv .fv__lead {
    font-size: clamp(13px, 3.9vw, 15px);
    line-height: 1.7;
    margin-bottom: 14px;
  }

  .masthead .fv .fv__copy .btn {
    --h: 44px;
    padding: 0 18px;
    margin-right: 8px;
    white-space: nowrap;
  }

  /* マスコット＋吹き出し：よりコンパクト */
  .fv__side {
    right: clamp(10px, 5vw, 18px);
    bottom: clamp(16px, 9vh, 22vh);
    gap: 6px;
  }

  .fv__balloon {
    width: clamp(130px, 54vw, 180px);
    padding: 8px 10px;
  }

  .fv__balloon p {
    font-size: clamp(12px, 3.8vw, 14px);
    line-height: 1.35;
  }

  .fv__mascot img {
    width: clamp(140px, 46vw, 190px);
  }

  .fv__mascot-name {
    font-size: clamp(11px, 3.2vw, 12px);
    color: #fff;
    text-shadow: 0 2px 8px rgba(0, 0, 0, .45);
  }

  /* スクロールUIは非表示（スマホでは圧迫回避） */
  .fv__scroll {
    display: none;
  }

  /* ページャを左下寄せに */
  .fv-pager {
    left: clamp(12px, 6vw, 24px);
    bottom: clamp(8px, 4vh, 18px);
  }
}

/* ===== 極小端末（～360px）===== */
@media (max-width: 360px) {
  .masthead .fv .fv__lead {
    display: none;
  }

  .masthead .fv .fv__copy .btn {
    --h: 42px;
    padding: 0 16px;
  }

  .fv__balloon {
    width: min(70vw, 180px);
  }
}

/* ===== モバイル（～899px）===== */
@media (max-width: 899px) {
  .masthead .fv .fv__title {
    font-size: clamp(26px, 7vw, 32px);
    line-height: 1.22;
    margin-bottom: 8px;
  }

  .masthead .fv .fv__lead {
    font-size: clamp(13px, 3.9vw, 15px);
    line-height: 1.7;
    margin-bottom: 14px;
  }

  .masthead .fv .fv__copy .btn {
    --h: 44px;
    padding: 0 18px;
    margin-right: 8px;
    white-space: nowrap;
  }

  /* ▼▼▼ 変更箇所 ▼▼▼ */
  /* マスコット＋吹き出し：非表示にして視認性を優先 */


  /* 非表示にしたため、以下のルールは影響しませんが、そのままでOKです */
  .fv__balloon {
    width: auto;
    max-width: 200px;
    padding: 7px 11px;
    border-width: 2.5px;
  }

  .fv__balloon p {
    font-size: clamp(11px, 1.4vw, 14px);
  }

  .fv__mascot img {
    width: clamp(140px, 46vw, 190px);
  }

  .fv__mascot-name {
    font-size: clamp(11px, 3.2vw, 12px);
    color: #fff;
    text-shadow: 0 2px 8px rgba(0, 0, 0, .45);
  }

  /* ▲▲▲ 変更ここまで ▲▲▲ */


  /* スクロールUIは非表示（スマホでは圧迫回避） */
  .fv__scroll {
    display: none;
  }

  /* ページャを左下寄せに */
  .fv-pager {
    left: clamp(12px, 6vw, 24px);
    bottom: clamp(8px, 4vh, 18px);
  }
}

/* ===== Mascot: 下配置スタイル（スマホ/タブレット）===== */
@media (max-width: 899px) {

  /* 既存の display:none を打ち消す */


  /* ←既存想定 */
  .fv__side.is-below {
    position: static !important;
    display: flex !important;
    flex-direction: row;
    justify-content: center;
    align-items: flex-end;
    gap: 12px;
    width: min(680px, 92vw);
    margin: clamp(12px, 4vw, 20px) auto 0;
    padding: 10px 12px;
    pointer-events: auto;
    z-index: 1;
    /* FVより上でOK */
  }

  /* 吹き出し：横並び向けに少しコンパクト */
  .fv__balloon {
    width: auto;
    max-width: 60%;
    padding: 10px 12px;
    border-width: 2.5px;
  }

  .fv__balloon p {
    font-size: clamp(12px, 3.6vw, 14px);
    line-height: 1.35;
  }

  /* 尾は右寄り下向き（マスコット側） */
  .fv__balloon::after {
    left: auto;
    right: 12%;
    bottom: -10px;
    transform: rotate(45deg);
  }

  /* マスコット画像：やや大きめで横並びに合わせる */
  .fv__mascot img {
    width: clamp(120px, 34vw, 180px);
  }

  /* キャラ名は下配置でも視認性を維持 */
  .fv__mascot-name {
    margin-left: 6px;
    margin-bottom: 2px;
    font-size: clamp(11px, 3.2vw, 13px);
    color: #fff;
    text-shadow: 0 2px 8px rgba(0, 0, 0, .45);
  }

  /* 破線デコは非表示（下配置では不要） */
  .fv__dash {
    display: none !important;
  }
}

/* ===== Mascot: PC復帰時の保険 ===== */
@media (min-width: 900px) {
  .fv__side.is-below {
    display: none !important;
  }
}

/* ===== Responsive (～899px): 中央寄せ・縦並び ===== */
@media (max-width: 899px) {

  /* FV内で使う場合／.is-belowでFV直下へ出す場合の両対応 */
  .fv__side.is-below {
    position: absolute !important;
    right: clamp(10px, 4vw, 20px);
    bottom: clamp(10px, 4vh, 20px);
    display: flex !important;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: auto;
    margin: 0;
    pointer-events: none;
    z-index: 50;
  }

  /* 並び順：1) 吹き出し 2) マスコット 3) 名称 */
  .fv__balloon {
    order: 1;
    width: auto;
    max-width: 80%;
    padding: 10px 12px;
    border-width: 2.5px;
  }

  .fv__balloon p {
    font-size: clamp(12px, 3.6vw, 14px);
    line-height: 1.35;
  }

  .fv__balloon::after {
    left: 50%;
    right: auto;
    bottom: -10px;
    transform: translateX(-50%) rotate(45deg);
    /* ↓向きセンター */
  }

  .fv__mascot {
    order: 2;
  }

  .fv__mascot img {
    display: block;
    margin: 0 auto;
    width: clamp(140px, 40vw, 200px);
    height: auto;
    object-fit: contain;
  }

  .fv__mascot-name {
    order: 3;
    margin-top: 4px;
    font-weight: 900;
    font-size: clamp(11px, 3.2vw, 13px);
    color: #fff;
    text-shadow: 0 2px 8px rgba(0, 0, 0, .45);
    text-align: center;
  }

  /* 下配置では不要な装飾は隠す */
  .fv__dash {
    display: none !important;
  }

  .fv__scroll {
    display: none !important;
  }
}

/* ===== Responsive: マスコット名称の文字色を青に ===== */
@media (max-width: 899px) {
  .fv__mascot-name {
    color: #1349a6 !important;
    /* 青系（既存変数なら var(--ink-2) でもOK） */
    text-shadow: none;
    /* 背景が明るい場合は影を消して読みやすく */
  }
}

/* ===== Balloon text fix: 文字切れ防止（～899px） ===== */
@media (max-width: 899px) {
  .fv__balloon {
    width: auto;
    max-width: 200px;
    padding: 7px 11px;
    border-width: 2.5px;
  }

  .fv__balloon p {
    margin: 0;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: normal;
    line-height: 1.25;
    font-size: clamp(11px, 1.4vw, 14px);
  }

  /* 尾（▼）が当たらないよう微調整 */
  .fv__balloon::after {
    bottom: -12px;
    /* 尾を少し下へ */
  }
}

/* ===== PC側も念のため（任意。切れが出る場合のみ） ===== */
@media (min-width: 900px) {
  .fv__balloon {
    max-width: 520px;
    /* 右下オーバーレイでも伸びすぎ防止 */
    padding-bottom: 16px;
    /* 尾の分の余白を確保 */
  }

  .fv__balloon p {
    overflow-wrap: anywhere;
    word-break: normal;
    line-height: 1.4;
  }
}

/* ===== FVテキストのバランス最適化（～899px） ===== */
@media (max-width: 899px) {

  /* カード位置とサイズ */
  .masthead .fv .fv__copy {
    /* 画面左右の余白をやや広げ、カード幅を絞る */
    left: clamp(18px, 6vw, 28px);
    right: clamp(18px, 6vw, 28px);
    max-width: min(680px, 88vw);
    /* 少し下げて顔や被写体に被りにくく */
    bottom: clamp(10vh, 14vh, 18vh);
    top: auto;

    /* 背景の視認性を少しだけ上げる（強すぎない） */
    background: rgba(255, 255, 255, .18);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    box-shadow: 0 12px 36px rgba(15, 23, 85, .12);
    border-radius: 20px;
    padding: clamp(16px, 4.2vw, 22px);
  }

  /* 見出しを一段コンパクトに */
  .masthead .fv .fv__title {
    font-size: clamp(24px, 6.2vw, 30px);
    line-height: 1.18;
    letter-spacing: .01em;
    margin-bottom: 8px;
  }

  /* 本文は行長を短くして読みやすく（＝面積を抑える） */
  .masthead .fv .fv__lead {
    font-size: clamp(13px, 3.6vw, 15px);
    line-height: 1.75;
    max-width: 34ch;
    /* ← 行長を制御してカード幅を自然に縮める */
    margin-bottom: 14px;
  }

  /* ボタンは窮屈なら自動改行OKにし、サイズも少しだけ小さく */
  .masthead .fv .fv__copy .btn {
    --h: 44px;
    padding: 0 16px;
    margin-right: 8px;
    white-space: normal;
    /* ← テキスト長い場合も折り返し可 */
  }

  .masthead .fv .fv__copy .btn:last-child {
    margin-right: 0;
  }

  /* 画面がさらに背の低い端末では余白を詰める */
  @media (max-height: 680px) {
    .masthead .fv .fv__copy {
      bottom: clamp(8vh, 12vh, 14vh);
      padding: clamp(14px, 3.6vw, 18px);
    }

    .masthead .fv .fv__title {
      margin-bottom: 6px;
    }

    .masthead .fv .fv__lead {
      margin-bottom: 12px;
    }
  }
}

/* ===== 写真の被りをより減らすための微Vignette（任意） ===== */
/* テキストカードの背面だけほんのり明るくしてコントラスト確保（目立ち過ぎない） */
.fv::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
  /* 左下に淡い明度グラデを敷く（カード背面の読みやすさUP） */
  background: radial-gradient(60% 40% at 22% 70%,
      rgba(245, 249, 255, .26) 0%,
      rgba(245, 249, 255, .18) 40%,
      transparent 70%);
}

/* ===== FVテキスト：画面幅に拡張＆文字切れ防止（～899px） ===== */
@media (max-width: 899px) {
  .masthead .fv .fv__copy {
    /* 画面左右の余白だけ残して横幅を最大化 */
    left: clamp(10px, 4vw, 16px);
    right: clamp(10px, 4vw, 16px);
    max-width: 96vw;
    /* ほぼ全幅 */
    width: auto;
    bottom: clamp(9vh, 12vh, 16vh);
    padding: clamp(14px, 3.6vw, 20px);
    overflow: visible;
    /* テキストのはみ出し抑止 */
  }

  /* 見出し：自然改行＋切れ防止 */
  .masthead .fv .fv__title {
    font-size: clamp(24px, 6.2vw, 30px);
    line-height: 1.25;
    white-space: normal;
    word-break: keep-all;
    /* 日本語の不自然な分割を抑える */
    overflow-wrap: anywhere;
    /* それでも溢れそうなら安全に折返し */
    margin-bottom: 10px;
  }

  /* リード文：行長制限を解除して横幅に追従、切れ防止 */
  .masthead .fv .fv__lead {
    max-width: none;
    /* ← 34ch を解除して横幅に合わせる */
    font-size: clamp(13px, 3.6vw, 15px);
    line-height: 1.8;
    white-space: normal;
    word-break: break-word;
    overflow-wrap: anywhere;
    margin-bottom: 14px;
  }

  /* ボタン：折返しOK＋狭幅では詰まない */
  .masthead .fv .fv__copy .btn {
    --h: 44px;
    padding: 0 16px;
    white-space: normal;
    /* 長い文言でも改行可 */
    margin-right: 8px;
  }

  .masthead .fv .fv__copy .btn:last-child {
    margin-right: 0;
  }

  /* さらに狭い端末（幅≤380px）はボタンを縦積みにして詰まり回避 */
  @media (max-width: 380px) {
    .masthead .fv .fv__copy .btn {
      display: block;
      width: 100%;
      text-align: center;
      margin-right: 0;
    }

    .masthead .fv .fv__copy .btn+.btn {
      margin-top: 8px;
    }
  }
}

/* ===== FVテキスト：自然なボカシ（枠が見えない） ===== */
.masthead .fv .fv__copy {
  position: relative;
  background: transparent;
  /* ← 本体に色は付けない */
  box-shadow: none;
  /* ← 影の硬さも消す */
  border: 0;
}

/* ボケ本体を敷く（裏側にだけ適用） */
.masthead .fv .fv__copy::before {
  content: "";
  position: absolute;
  inset: -18px;
  /* ← 少し大きめに広げて縁を外へ */
  z-index: -1;
  /* ← テキストの裏に回す */
  border-radius: 28px;



  /* 縁をフェード＝“箱感”を消す（角丸にも追従） */
  -webkit-mask-image:
    radial-gradient(120% 120% at 50% 50%, #000 62%, rgba(0, 0, 0, 0) 100%);
  mask-image:
    radial-gradient(120% 120% at 50% 50%, #000 62%, rgba(0, 0, 0, 0) 100%);

  /* 微妙な光のにじみ（好みで調整/不要なら削除） */
  box-shadow: 0 18px 50px rgba(15, 23, 85, .10);
}

/* 端末が backdrop-filter 非対応のときのフォールバック */
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .masthead .fv .fv__copy::before {
    background: rgba(255, 255, 255, .28);
    /* 少しだけ不透明に */
    -webkit-mask-image: none;
    mask-image: none;
  }
}

/* ===== FVテキスト位置をレスポンシブ時もPCと同じ位置に戻す ===== */
@media (max-width: 899px) {
  .masthead .fv .fv__copy {
    position: absolute;
    top: auto;
    bottom: 8vh;
    /* ← PC時と同程度の下マージン */
    left: clamp(40px, 8vw, 80px);
    right: auto;
    transform: none;
    max-width: 620px;
    /* テキスト幅をPCと同程度に固定 */
    margin: 0;
  }

  /* 見出し・本文も自然な位置で折り返すよう調整 */
  .masthead .fv .fv__title,
  .masthead .fv .fv__lead {
    text-align: left;
    white-space: normal;
    word-break: keep-all;
    overflow-wrap: anywhere;
  }
}

/* ================================
 Services Page Add-on Styles
 (Header/Footerは触らない)
 ================================ */

/* 基本トークン（既存の :root があればそれを尊重） */
:root {
  --brand: #5B9BD5;
  /* 早田設備のブランドブルー（過去指示より） */
  --ink: #111;
  --muted: #6b7280;
  --line: #e5e7eb;
  --bg-soft: #f0f4f8;
  --shadow: 0 8px 24px rgba(0, 0, 0, .06);
  --radius: 16px;
}

.section--soft {
  background: var(--bg-soft);
}

.container--narrow {
  max-width: 880px;
  margin: 0 auto;
}

.t-center {
  text-align: center;
}

.btn-row {
  display: flex;
  gap: 12px;
  justify-content: center;
}

/* -----------------------------
 キービジュアル（上部帯）
------------------------------*/
.kv {
  padding: clamp(28px, 4.5vw, 60px) 0;
  background:
    radial-gradient(1200px 600px at 100% -10%, rgba(91, 155, 213, .12), transparent 60%),
    linear-gradient(180deg, #fff, #f9fbff);
  border-bottom: 1px solid var(--line);
}

.kv .breadcrumbs {
  font-size: 13px;
  color: var(--muted);
  display: flex;
  gap: 6px;
  align-items: center;
}

.kv .breadcrumbs a {
  color: var(--muted);
  text-decoration: none;
}

.kv .title {
  margin: 8px 0 6px;
  font-size: clamp(28px, 4.2vw, 40px);
  line-height: 1.2;
  letter-spacing: .01em;
}

.kv .note {
  color: #374151;
  max-width: 56ch;
}

/* -----------------------------
 見出し・テキスト
------------------------------*/
.section h2 {
  font-size: clamp(22px, 3.2vw, 28px);
  margin-bottom: 6px;
}

.section .sub {
  color: var(--muted);
  font-size: 14px;
}

.h2-slim {
  font-size: clamp(22px, 3.2vw, 28px);
  font-weight: 700;
  letter-spacing: .02em;
  margin-bottom: 20px;
}

/* -----------------------------
 2カラムグリッド（画像＋テキスト）
------------------------------*/
.grid-2 {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: clamp(16px, 3.5vw, 28px);
  align-items: start;
}

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

/* 画像プレースホルダー（.ph） */
.ph {
  aspect-ratio: 4 / 3;
  border: 1px dashed #cbd5e1;
  border-radius: var(--radius);
  display: grid;
  place-items: center;
  background:
    linear-gradient(135deg, rgba(91, 155, 213, .08), rgba(255, 255, 255, .9));
  color: #64748b;
  font-size: 14px;
}

.ph span {
  padding: 8px 10px;
}

/* -----------------------------
 カードグリッド（サービス／実績）
------------------------------*/
.card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(12px, 2.8vw, 24px);
}

@media (max-width: 960px) {
  .card-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .card-grid {
    grid-template-columns: 1fr;
  }
}

/* カード */
.card {
  display: block;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 14px;
  text-decoration: none;
  color: inherit;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.card:hover,
.card:focus-visible {
  transform: translateY(-2px);
  box-shadow: var(--shadow);
  border-color: rgba(91, 155, 213, .35);
  outline: none;
}

.card .thumb {
  aspect-ratio: 4 / 3;
  border-radius: calc(var(--radius) - 4px);
  background:
    linear-gradient(180deg, rgba(91, 155, 213, .15), rgba(91, 155, 213, .05));
  display: grid;
  place-items: end start;
  padding: 10px;
  position: relative;
  overflow: hidden;
}

.card .thumb::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(180px 120px at 100% 0, rgba(91, 155, 213, .18), transparent 60%);
}

.card .thumb span {
  background: #fff;
  border: 1px solid var(--line);
  color: #334155;
  font-size: 12px;
  padding: 4px 8px;
  border-radius: 999px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, .04);
}

.card h3 {
  font-size: 16px;
  margin: 10px 2px 2px;
  line-height: 1.5;
}

.card .meta {
  font-size: 12px;
  color: var(--muted);
}

/* 実績カード（article.card）内の time 表示 */
#works .card time.meta {
  display: block;
  margin-top: 8px;
}

/* -----------------------------
 テル・案内
------------------------------*/
.tel {
  font-size: clamp(18px, 3.2vw, 22px);
  font-weight: 700;
  letter-spacing: .02em;
}

/* -----------------------------
 CTA バンド（法人セクションの下）
------------------------------*/
.cta-band {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: clamp(14px, 3vw, 24px);
  padding: clamp(16px, 3.4vw, 26px);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background:
    linear-gradient(180deg, #fff, #f7fbff);
}

.cta-band .ph {
  aspect-ratio: 16 / 9;
}

@media (max-width: 960px) {
  .cta-band {
    grid-template-columns: 1fr;
  }
}

/* -----------------------------
 ボタン（ページ内での軽い上書き）
------------------------------*/
.kv .btn {
  margin-top: 4px;
}

.btn.ghost {
  background: #fff;
  border: 1px solid var(--line);
  color: #111;
}

.btn.ghost:hover {
  border-color: rgba(91, 155, 213, .35);
}

/* -----------------------------
 施工フロー（ステップの縦タイムライン）
------------------------------*/
.flow-steps {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 14px;
  counter-reset: step;
}

.flow-step {
  position: relative;
  padding: 14px 14px 14px 56px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
}

.flow-step__number {
  position: absolute;
  left: 14px;
  top: 14px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: rgba(91, 155, 213, .12);
  color: #1f2a44;
  font-weight: 700;
}

.flow-step:not(:last-child)::after {
  content: "";
  position: absolute;
  left: 30px;
  top: calc(14px + 32px);
  width: 4px;
  bottom: -14px;
  background: linear-gradient(#e8eef6, #edf2f7);
  border-radius: 2px;
}

.flow-step__title {
  margin: 2px 0 4px;
  font-size: 16px;
}

.flow-step__text {
  margin: 0;
  color: #374151;
  font-size: 14px;
}

/* -----------------------------
 アクセシビリティ・モーション
------------------------------*/
@media (prefers-reduced-motion: reduce) {

  .card,
  .kv {
    transition: none !important;
  }
}

/* -----------------------------
 細かな余白調整
------------------------------*/
#sec-area .note {
  margin-bottom: 10px;
}

.section .grid-2.container {
  padding: 0;
}

/* ph を実画像に対応させる */
.ph {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  aspect-ratio: 4 / 3;
  /* 既定。必要に応じて個別上書き */
}

/* 16:9が良い箇所だけ個別指定（対応エリア地図、CTAなど） */
.ph.is-16x9 {
  aspect-ratio: 16 / 9;
}

.ph img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  /* 画像を端までフィット */
  object-position: center;
}

/* 旧プレースホルダー文字を残しても表示されないように */
.ph span {
  position: absolute;
  inset: 0;
  display: none;
}

/* =======================
 Header: 左ロゴ / 右上FAB
 ======================= */
.header {
  background: transparent;
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  min-height: 64px;
}

.brand-logo {
  height: 28px;
  /* スクショ程度のサイズ感 */
  width: auto;
  display: block;
}

@media (min-width: 960px) {
  .brand-logo {
    height: 32px;
  }
}

/* 右上の丸ボタン（FAB） */
.nav__toggle.fab {
  position: fixed;
  /* 画面右上に固定 */
  right: clamp(14px, 2vw, 24px);
  top: clamp(10px, 1.8vw, 18px);
  z-index: 2000;
  width: 56px;
  height: 56px;
  /* 直径 */
  border-radius: 999px;
  background: #1e66ff;
  /* ブランド寄りの青 */
  box-shadow: 0 8px 24px rgba(0, 0, 0, .18);
  display: grid;
  place-items: center;
  cursor: pointer;
  border: none;
}

/* ハンバーガー線 */
.nav__toggle.fab .burger {
  display: inline-grid;
  gap: 6px;
}

.nav__toggle.fab .burger i {
  display: block;
  width: 26px;
  height: 2px;
  background: #fff;
  border-radius: 2px;
}

/* 開いた時の見た目（任意：少し淡く） */
.menu[open] .nav__toggle.fab {
  background: #2968ff;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .25);
}

/* indexのヒーロー等が被らないよう、ヘッダー周辺の重なり調整 */
.header {
  position: relative;
  z-index: 100;
}

.kv,
.section {
  isolation: isolate;
}

/* シート側は既存スタイルを活用（必要なら最小限） */
.nav__sheet {
  position: fixed;
  inset: 0;
  z-index: 1999;
}

.nav__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, .35);
}

.nav__panel {
  position: absolute;
  right: 0;
  top: 0;
  height: 100%;
  width: min(86vw, 420px);
  background: #fff;
  box-shadow: -8px 0 24px rgba(0, 0, 0, .12);
  padding: 20px 20px 28px;
  overflow: auto;
}

.nav__close {
  border: none;
  font-size: 22px;
  padding: 6px;
}

.nav__list {
  list-style: none;
  margin: 12px 0 0;
  padding: 0;
  display: grid;
  gap: 12px;
}

.nav__link {
  display: block;
  padding: 12px 10px;
  border-radius: 10px;
  text-decoration: none;
  color: #111;
}

.nav__link:hover {
  background: #f5f7fb;
}

/* ==== Bigger header logo (all pages) ==== */
.header .brand-logo {
  height: 40px;
  /* SP～タブレット */
  width: auto;
}

@media (min-width: 960px) {
  .header .brand-logo {
    height: 56px;
    /* PC */
  }
}

/* ヘッダーの高さをロゴに合わせて確保 */
.header .topbar {
  min-height: 72px;
  /* SP */
}

@media (min-width: 960px) {
  .header .topbar {
    min-height: 84px;
  }

  /* PC */
}

/* 余白が窮屈なら（任意） */
.header .brand {
  display: flex;
  align-items: center;
  padding: 6px 0;
}

/* 右上の丸いバーガー（FAB）の縦位置を微調整（任意） */
.nav__toggle.fab {
  top: 14px;
}

@media (min-width: 960px) {
  .nav__toggle.fab {
    top: 16px;
  }
}

/* ===== 3本線 ↔ ✕ の両方向アニメーション ===== */
.nav__toggle.fab .burger {
  position: relative;
  width: 26px;
  height: 20px;
  display: inline-block;
  cursor: pointer;
}

.nav__toggle.fab .burger i {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background: #fff;
  border-radius: 2px;
  transition:
    transform 0.35s cubic-bezier(0.4, 0, 0.2, 1),
    opacity 0.25s ease,
    top 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

/* 通常時の位置 */
.nav__toggle.fab .burger i:nth-child(1) {
  top: 0;
}

.nav__toggle.fab .burger i:nth-child(2) {
  top: 9px;
}

.nav__toggle.fab .burger i:nth-child(3) {
  top: 18px;
}

/* open 時のアニメーション（✕） */
.menu[open] .nav__toggle.fab .burger i:nth-child(1) {
  top: 9px;
  transform: rotate(45deg);
}

.menu[open] .nav__toggle.fab .burger i:nth-child(2) {
  opacity: 0;
  transform: translateX(-10px);
}

.menu[open] .nav__toggle.fab .burger i:nth-child(3) {
  top: 9px;
  transform: rotate(-45deg);
}

/* =========================================================
   【統一デザインパターン】ページ共通スタイル
   会社案内・事業内容などで使用
========================================================= */

/* ---------------------------------------------------------
   ページ全体背景（共通）
--------------------------------------------------------- */
.page-company,
.page-service {
  background:
    radial-gradient(circle at top left, rgba(40, 116, 252, 0.06), transparent 55%),
    radial-gradient(circle at bottom right, rgba(9, 132, 227, 0.06), transparent 50%),
    #f7f9fc;
}

/* ---------------------------------------------------------
   セクション背景パターン（共通）
--------------------------------------------------------- */
.page-company .section,
.page-service .section {
  padding-block: clamp(56px, 7vw, 88px);
}

/* デフォルト：透明（地の背景を見せる） */
.page-company .section--panel,
.page-service .section--panel {
  background: transparent;
}

/* ふんわりホワイト系 - より明確に */
.page-company .section--alt,
.page-service .section--alt {
  background: linear-gradient(180deg, #f8fbff 0%, #e8f2ff 100%);
  border-top: 1px solid rgba(30, 136, 255, 0.08);
  border-bottom: 1px solid rgba(30, 136, 255, 0.08);
}

/* やさしい淡ブルー - より濃く */
.page-company .section--soft,
.page-service .section--soft {
  background: linear-gradient(180deg, #e8f0ff 0%, #dce8ff 100%);
  border-top: 1px solid rgba(30, 136, 255, 0.12);
  border-bottom: 1px solid rgba(30, 136, 255, 0.12);
}

/* CTA用（少しタイトな余白） */
.page-company .section--cta,
.page-service .section--cta {
  padding-block: clamp(48px, 6vw, 72px);
  background: transparent;
}

/* コンテナの左右余白を統一 */
.page-company .section .container,
.page-service .section .container,
.page-company section .container,
.page-service section .container {
  padding-inline: clamp(18px, 5vw, 60px);
  margin-inline: auto;
  max-width: 1200px;
  box-sizing: border-box;
}

/* =========================================================
   【統一デザインパターン】ページ共通スタイル
   Company / Service / Portfolio 共通
========================================================= */

/* ---------------------------------------------------------
   ページ全体背景（共通）
--------------------------------------------------------- */
.is-index,
.page-company,
.page-service,
.page-portfolio,
.page-contact,
.page-news {
  background: #ffffff;
}

/* ---------------------------------------------------------
   セクション背景パターン（共通）
--------------------------------------------------------- */
.page-company .section,
.page-service .section,
.page-portfolio .section,
.page-contact .section,
.page-news .section {
  padding-block: clamp(56px, 7vw, 88px);
}

/* デフォルト：透明（地の背景を見せる） */
.page-company .section--panel,
.page-service .section--panel,
.page-portfolio .section--panel,
.page-contact .section--panel,
.page-news .section--panel {
  background: transparent;
}

/* ふんわりホワイト系 - より明確に */
.page-company .section--alt,
.page-service .section--alt,
.page-portfolio .section--alt,
.page-contact .section--alt,
.page-news .section--alt {
  background: linear-gradient(180deg, #f8fbff 0%, #e8f2ff 100%);
  border-top: 1px solid rgba(30, 136, 255, 0.08);
  border-bottom: 1px solid rgba(30, 136, 255, 0.08);
}

/* やさしい淡ブルー - より濃く */
.page-company .section--soft,
.page-service .section--soft,
.page-portfolio .section--soft,
.page-contact .section--soft,
.page-news .section--soft {
  background: linear-gradient(180deg, #e8f0ff 0%, #dce8ff 100%);
  border-top: 1px solid rgba(30, 136, 255, 0.12);
  border-bottom: 1px solid rgba(30, 136, 255, 0.12);
}

/* CTA用（少しタイトな余白） */
.page-company .section--cta,
.page-service .section--cta,
.page-portfolio .section--cta,
.page-contact .section--cta,
.page-news .section--cta {
  padding-block: clamp(48px, 6vw, 72px);
  background: transparent;
}

/* コンテナの左右余白を統一 */
.page-company .section .container,
.page-service .section .container,
.page-portfolio .section .container,
.page-contact .section .container,
.page-company section .container,
.page-service section .container,
.page-portfolio section .container,
.page-contact section .container,
.page-news .section .container,
.page-news section .container {
  padding-inline: clamp(18px, 5vw, 60px);
  margin-inline: auto;
  max-width: 1200px;
  box-sizing: border-box;
}

/* ---------------------------------------------------------
   統一KVデザイン（Company / Service / Portfolio共通）
--------------------------------------------------------- */
.kv--company,
.kv--service,
.kv--portfolio,
.kv--contact,
.kv--news {
  --left-max: 560px;
  --gutter-x: clamp(20px, 4vw, 48px);
  --top-pad: clamp(72px, 9vw, 140px);
  --bottom-pad: clamp(48px, 7vw, 110px);
  position: relative;
  min-height: 620px;
  background: #fff;
  isolation: isolate;
}

.kv--company .kv__inner,
.kv--service .kv__inner,
.kv--portfolio .kv__inner,
.kv--contact .kv__inner,
.kv--news .kv__inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: var(--top-pad) var(--gutter-x) var(--bottom-pad);
  position: relative;
  z-index: 2;
}

.kv--company .kv__body,
.kv--service .kv__body,
.kv--portfolio .kv__body,
.kv--contact .kv__body,
.kv--news .kv__body {
  width: min(var(--left-max), 52vw);
}

/* 見出し統一デザイン */
.kv--company .kv__title,
.kv--service .kv__title,
.kv--portfolio .kv__title,
.kv--contact .kv__title,
.kv--news .kv__title {
  margin: 0 0 clamp(18px, 2vw, 28px);
  line-height: 1.15;
}

.kv--company .kv__title .jp,
.kv--service .kv__title .jp,
.kv--portfolio .kv__title .jp,
.kv--contact .kv__title .jp,
.kv--news .kv__title .jp {
  display: block;
  font-weight: 900;
  font-size: clamp(34px, 6vw, 56px);
  letter-spacing: .02em;
  color: #14286b;
}

.kv--company .kv__title .en,
.kv--service .kv__title .en,
.kv--portfolio .kv__title .en,
.kv--contact .kv__title .en,
.kv--news .kv__title .en {
  display: block;
  margin-top: 6px;
  font-weight: 800;
  font-size: clamp(20px, 3.6vw, 36px);
  letter-spacing: .06em;
  background: linear-gradient(90deg, #2a9df4 0%, #b43a9a 55%, #0f3fff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* 本文統一 */
.kv--company .kv__lead,
.kv--service .kv__lead,
.kv--portfolio .kv__lead,
.kv--contact .kv__lead,
.kv--company .kv__intro,
.kv--service .kv__intro,
.kv--portfolio .kv__intro,
.kv--contact .kv__intro,
.kv--news .kv__lead,
.kv--news .kv__intro {
  margin: 0;
  color: #14286b;
  font-weight: 700;
  font-size: clamp(15px, 1.6vw, 18px);
  line-height: 2.2;
  letter-spacing: .03em;
  max-width: 640px;
}

/* 右全面写真（統一斜めカット） */
.kv--company .kv__media,
.kv--service .kv__media,
.kv--portfolio .kv__media,
.kv--contact .kv__media,
.kv--news .kv__media {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 30%;
  background: var(--kv-img) center/cover no-repeat;
  z-index: 1;
  clip-path: polygon(58% 0, 100% 0, 100% 100%, 42% 100%);
}

/* 左側を白でなじませて可読性UP */
.kv--company .kv__media::before,
.kv--service .kv__media::before,
.kv--portfolio .kv__media::before,
.kv--contact .kv__media::before,
.kv--news .kv__media::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(255, 255, 255, .9) 0%, rgba(255, 255, 255, 0) 18%);
  pointer-events: none;
}

/* マスコット＆吹き出し統一配置 */
.kv--company .kv__mascot,
.kv--service .kv__mascot,
.kv--portfolio .kv__mascot,
.kv--contact .kv__mascot,
.kv--news .kv__mascot {
  position: absolute;
  z-index: 3;
  right: clamp(26%, 30vw, 35%);
  bottom: clamp(42px, 7vw, 84px);
  transform: translateX(18%);
  width: clamp(120px, 15vw, 200px);
  aspect-ratio: 1/1;
  display: grid;
  justify-items: center;
  gap: 10px;
  pointer-events: none;
}

.kv--company .kv__mascot img,
.kv--service .kv__mascot img,
.kv--portfolio .kv__mascot img,
.kv--contact .kv__mascot img,
.kv--news .kv__mascot img {
  width: 100%;
  height: auto;
  display: block;
}

.kv--company .kv__balloon,
.kv--service .kv__balloon,
.kv--portfolio .kv__balloon,
.kv--contact .kv__balloon,
.kv--news .kv__balloon {
  position: relative;
  pointer-events: auto;
  background: #fff;
  border: 3px solid rgba(19, 73, 166, .85);
  border-radius: 18px;
  box-shadow: 0 8px 22px rgba(0, 0, 0, .10);
  padding: 10px 14px;
  transform: translateY(4px);
  text-align: center;
}

.kv--company .kv__balloon p,
.kv--service .kv__balloon p,
.kv--portfolio .kv__balloon p,
.kv--contact .kv__balloon p,
.kv--news .kv__balloon p {
  margin: 0;
  font-weight: 900;
  line-height: 1.25;
  color: #1349a6;
  font-size: clamp(11px, 1.4vw, 14px);
}

.kv--company .kv__balloon::after,
.kv--service .kv__balloon::after,
.kv--portfolio .kv__balloon::after,
.kv--contact .kv__balloon::after,
.kv--news .kv__balloon::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -12px;
  width: 20px;
  height: 20px;
  background: #fff;
  border-right: 3px solid rgba(19, 73, 166, .85);
  border-bottom: 3px solid rgba(19, 73, 166, .85);
  transform: translateX(-50%) rotate(45deg);
  border-radius: 4px;
}

/* SP時の改行表示 */
.sp-br {
  display: none;
}

/* ---------------------------------------------------------
   KV レスポンシブ統一（タブレット〜スマホ）
--------------------------------------------------------- */
@media (max-width:768px) {
  .sp-br {
    display: inline;
  }

  .kv--company,
  .kv--service,
  .kv--portfolio,
  .kv--contact,
  .kv--news {
    --sp-safe: 58vw;
    min-height: min(88vh, 760px);
  }

  .kv--company .kv__inner,
  .kv--service .kv__inner,
  .kv--portfolio .kv__inner,
  .kv--contact .kv__inner,
  .kv--news .kv__inner {
    padding: clamp(56px, 10vw, 80px) clamp(7vw, 8vw, 28px) clamp(32px, 9vw, 56px);
    max-width: 100%;
  }

  .kv--company .kv__body,
  .kv--service .kv__body,
  .kv--portfolio .kv__body,
  .kv--contact .kv__body,
  .kv--news .kv__body {
    width: 100%;
    max-width: var(--sp-safe);
  }

  .kv--company .kv__media,
  .kv--service .kv__media,
  .kv--portfolio .kv__media,
  .kv--contact .kv__media,
  .kv--news .kv__media {
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-size: cover;
    background-position: 62% 40%;
    clip-path: polygon(62% 0, 100% 0, 100% 100%, 38% 100%);
  }

  .kv--company .kv__media::before,
  .kv--service .kv__media::before,
  .kv--portfolio .kv__media::before,
  .kv--contact .kv__media::before,
  .kv--news .kv__media::before {
    background: linear-gradient(90deg,
        rgba(255, 255, 255, 0.96) 0%,
        rgba(255, 255, 255, 0.88) 16%,
        rgba(255, 255, 255, 0.00) 36%);
  }

  /* マスコット：ボタン直下へ */
  .kv--company .kv__mascot,
  .kv--service .kv__mascot,
  .kv--portfolio .kv__mascot,
  .kv--contact .kv__mascot,
  .kv--news .kv__mascot {
    position: relative;
    left: 0;
    margin-top: clamp(0px, 1.5vw, 6px);
    margin-left: clamp(10px, 6vw, 40px);
    width: clamp(100px, 28vw, 155px);
    transform: none;
    z-index: 2;
    display: flex;
    flex-direction: column;
  }

  .kv--company .kv__balloon,
  .kv--service .kv__balloon,
  .kv--portfolio .kv__balloon,
  .kv--contact .kv__balloon,
  .kv--news .kv__balloon {
    padding: 7px 11px;
    border-width: 2.5px;
  }

  .kv--company .kv__balloon::after,
  .kv--service .kv__balloon::after,
  .kv--portfolio .kv__balloon::after,
  .kv--contact .kv__balloon::after,
  .kv--news .kv__balloon::after {
    left: 30%;
    bottom: -10px;
    width: 16px;
    height: 16px;
  }
}

@media (max-width:375px) {

  .kv--company .kv__media,
  .kv--service .kv__media,
  .kv--portfolio .kv__media,
  .kv--contact .kv__media,
  .kv--news .kv__media {
    clip-path: polygon(66% 0, 100% 0, 100% 100%, 34% 100%);
    background-position: 60% 42%;
  }
}

/* ---------------------------------------------------------
   統一セクション見出しデザイン
--------------------------------------------------------- */
.sec-head {
  margin-bottom: clamp(16px, 2.4vw, 22px);
}

.sec-head__label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #2455b3;
  background: rgba(36, 85, 179, 0.06);
}

.sec-head__label::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: linear-gradient(135deg, #2a9df4, #b43a9a);
}

.sec-head__title {
  margin: 10px 0 0;
  font-size: clamp(22px, 2.4vw, 28px);
  letter-spacing: 0.08em;
  color: #14286b;
  position: relative;
  display: inline-block;
}


.sec-head--center {
  text-align: center;
}

.sec-head--center .sec-head__title::after {
  left: 50%;
  transform: translateX(-50%);
}

/* ---------------------------------------------------------
   統一2カラムレイアウト
--------------------------------------------------------- */
.section__inner {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: clamp(28px, 4vw, 40px);
  align-items: center;
}

.section__inner--reverse {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
}

@media (max-width: 900px) {

  .section__inner,
  .section__inner--reverse {
    grid-template-columns: 1fr;
  }

  .section__image {
    order: -1;
  }

  /* Companyページの代表挨拶セクション特有の調整 */
  .page-company .section__inner--reverse .section__image {
    order: 2;
    /* 画像を下に */
    width: 60%;
    /* サイズを小さく */
    margin: 32px auto 0;
    /* 中央寄せと上マージン */
  }
}

/* カード風背景（代表挨拶・沿革など） */
.section--panel .section__inner {
  background: #ffffff;
  border-radius: 22px;
  box-shadow: 0 18px 50px rgba(15, 35, 80, 0.08);
  padding: clamp(24px, 4vw, 32px);
}

@media (max-width: 900px) {
  .section--panel .section__inner {
    padding: clamp(20px, 4vw, 24px);
  }
}

/* ---------------------------------------------------------
   統一写真枠
--------------------------------------------------------- */
.ph {
  width: 100%;
  display: block;
  overflow: hidden;
  border-radius: 18px;
  background: #ffffff;
  box-shadow: 0 14px 34px rgba(0, 0, 0, .06);
}

.ph.is-4x3 {
  aspect-ratio: 4 / 3;
}

.ph.is-16x9 {
  aspect-ratio: 16 / 9;
}

.ph img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border-radius: inherit;
}

/* プレースホルダー（実装前） */
.ph span {
  display: grid;
  place-items: center;
  color: #64748b;
  font-size: 14px;
  background: linear-gradient(135deg, rgba(91, 155, 213, .08), rgba(255, 255, 255, .9));
  height: 100%;
}

/* =========================================================
   【統一見出しデザイン】全ページ共通
========================================================= */

/* ---------------------------------------------------------
   ページタイトル（h1 - KV内の大見出し）
--------------------------------------------------------- */
.kv__title {
  margin: 0 0 clamp(18px, 2vw, 28px);
  line-height: 1.15;
}

.kv__title .jp {
  display: block;
  font-weight: 900;
  font-size: clamp(34px, 6vw, 56px);
  letter-spacing: .02em;
  color: #14286b;
  text-shadow: 0 2px 8px rgba(20, 40, 107, .08);
}

.kv__title .en {
  display: block;
  margin-top: 6px;
  font-weight: 800;
  font-size: clamp(20px, 3.6vw, 36px);
  letter-spacing: .06em;
  text-transform: uppercase;
  background: linear-gradient(90deg, #2a9df4 0%, #b43a9a 55%, #0f3fff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* ---------------------------------------------------------
   セクション見出し（h2 - 大セクションの見出し）
--------------------------------------------------------- */
.page-company h2,
.page-service h2,
.page-portfolio h2,
.page-company .sec-head__title,
.page-service .sec-head__title,
.page-portfolio .sec-head__title {
  margin: 10px 0 0;
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 900;
  letter-spacing: 0.08em;
  color: #14286b;
  position: relative;
  display: inline-block;
  line-height: 1.3;
}



/* 見出しの上に付くラベル（Message, Profile など） */
.sec-head__label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #2455b3;
  background: linear-gradient(135deg, #f3f6ff 0%, #eaf1ff 100%);
  box-shadow: 0 4px 12px rgba(27, 69, 174, 0.12);
  margin-bottom: 12px;
}

/* ラベルの左側のドット */
.sec-head__label::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: radial-gradient(circle at 30% 30%, #ffffff 0%, #4b9bff 40%, #b93aa2 100%);
  box-shadow: 0 2px 8px rgba(75, 155, 255, 0.3);
}

/* 見出しブロック全体 */
.sec-head {
  margin-bottom: clamp(18px, 2.6vw, 26px);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.sec-head--center {
  text-align: center;
  align-items: center;
}

/* ---------------------------------------------------------
   中見出し（h3 - セクション内の小見出し）
--------------------------------------------------------- */
.page-company h3,
.page-service h3,
.page-portfolio h3 {
  margin: clamp(24px, 3vw, 32px) 0 clamp(10px, 1.4vw, 14px);
  font-size: clamp(18px, 2.2vw, 22px);
  font-weight: 800;
  color: #ffffff;
  letter-spacing: 0.04em;
  line-height: 1.4;
  position: relative;
  padding-left: 16px;
}

/* 最初のh3は上マージンなし */
.page-company h3:first-child,
.page-service h3:first-child,
.page-portfolio h3:first-child {
  margin-top: 0;
}

/* カード内やボックス内のh3は装飾なし */
.card h3,
.svc h3,
.policy-list h3,
.flow-step h3 {
  margin: 0;
  padding-left: 0;
  font-size: clamp(16px, 2vw, 18px);
  font-weight: 800;
  color: #14286b;
}

.card h3::before,
.svc h3::before,
.policy-list h3::before,
.flow-step h3::before {
  display: none;
}

/* ---------------------------------------------------------
   小見出し（h4 - さらに細かい見出し）
--------------------------------------------------------- */
.page-company h4,
.page-service h4,
.page-portfolio h4 {
  margin: clamp(18px, 2.4vw, 24px) 0 clamp(8px, 1.2vw, 12px);
  font-size: clamp(16px, 1.8vw, 18px);
  font-weight: 700;
  color: #1f56b3;
  letter-spacing: 0.03em;
  line-height: 1.5;
}

/* ---------------------------------------------------------
   センター寄せ見出し用クラス
--------------------------------------------------------- */
.h2-center,
.h2-slim {
  text-align: center;
  margin-bottom: clamp(20px, 2.8vw, 32px);
  padding-left: 0;
}

.h2-center::before,
.h2-slim::before {
  display: none;
}

.h2-center::after,
.h2-slim::after {
  left: 50%;
  transform: translateX(-50%);
}

/* ---------------------------------------------------------
   レスポンシブ調整
--------------------------------------------------------- */
@media (max-width: 768px) {

  /* h2の下線を短く */
  .page-company h2::after,
  .page-service h2::after,
  .page-portfolio h2::after,
  .page-company .sec-head__title::after,
  .page-service .sec-head__title::after,
  .page-portfolio .sec-head__title::after,
  .page-news h2::after,
  .page-news .sec-head__title::after {
    width: 48px;
    height: 2.5px;
    bottom: -6px;
  }

  /* h3の左バーを細く */
  .page-company h3::before,
  .page-service h3::before,
  .page-portfolio h3::before,
  .page-news h3::before {
    width: 3px;
    height: 1em;
  }

  /* ラベルを小さく */
  .sec-head__label {
    padding: 4px 10px;
    font-size: 10px;
    gap: 6px;
  }

  .sec-head__label::before {
    width: 6px;
    height: 6px;
  }
}

/* ---------------------------------------------------------
   特定セクションの見出し調整
--------------------------------------------------------- */

/* 会社概要テーブル見出しは装飾なし */
.info-table h2,
.info-table h3 {
  padding-left: 0;
}

.info-table h2::before,
.info-table h3::before {
  display: none;
}

/* CTAバンド内の見出し */
.cta-band h2,
.cta-band h3 {
  padding-left: 0;
  margin: 8px 0;
}

.cta-band h2::before,
.cta-band h3::before {
  display: none;
}

.cta-band h2::after,
.cta-band h3::after {
  display: none;
}

/* ---------------------------------------------------------
   Utility Classes for Responsive Display
--------------------------------------------------------- */
.u-hidden-mobile {
  display: block;
}

.u-hidden-desktop {
  display: none;
}

@media (max-width: 899px) {
  .u-hidden-mobile {
    display: none !important;
  }

  .u-hidden-desktop {
    display: block !important;
  }
}

/* ---------------------------------------------------------
   Mobile Mascot Section
--------------------------------------------------------- */
.mobile-mascot-section {
  background: #fff;
  padding: 0;
  margin: 0;
}

/* ========= Sub Page Specifics (Solid Color Separation) ========= */
body.page-sub {
  background-color: #ffffff;
}

/* 
   パターンではなく「色面のコントラスト」で区切りを明確化
   - 白背景: #ffffff
   - ソフト背景: #eef6ff (爽やかな薄いブルー)
   - 代替背景: #f4f7fa (落ち着いたグレーブルー)
*/

/* デフォルトのセクション（白背景） */
.page-sub .section:not(.section--soft):not(.section--alt):not(.kv) {
  background-color: #ffffff;
  border-bottom: 1px solid #e2e8f0;
}

/* ソフト背景（明確なブルー系） */
.page-sub .section--soft {
  background-color: #eef6ff;
  /* 色味を少し強めて視認性を向上 */
  background-image: none;
  border-top: 1px solid #dbeafe;
  border-bottom: 1px solid #dbeafe;
}

/* 代替背景（明確なグレー系） */
.page-sub .section--alt {
  background-color: #f1f5f9;
  /* 白との差がわかるグレー */
  background-image: none;
  border-top: 1px solid #e2e8f0;
  border-bottom: 1px solid #e2e8f0;
}

/* KV下の境界線 */
.page-sub .kv {
  border-bottom: 1px solid #e2e8f0;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.03);
  position: relative;
  z-index: 2;
}

/* コンテンツのメリハリを高めるための微調整 */
.page-sub .section h2 {
  position: relative;
  display: inline-block;
}

/* =========================================
   FVテキスト背景完全削除（PC・レスポンシブ共通）
   ※既存の設定を上書きして背景を消去します
========================================= */

/* 1. コンテナの背景・影・ガラス効果・枠線をすべて無効化 */
.masthead .fv .fv__copy {
  background: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  box-shadow: none !important;
  border: none !important;
  border-radius: 0 !important;

  /* 背景がなくなるため、内側の余白も削除してスッキリさせる */
  padding: 0 !important;

  /* アニメーションや変形もリセット */
  animation: none !important;
  transform: none !important;
}

/* 2. 擬似要素（ボカシ演出用）を非表示 */
.masthead .fv .fv__copy::before {
  display: none !important;
  content: none !important;
}

/* 3. タブレット・スマホ時も強制的に背景なし */
@media (max-width: 1279px) {
  .masthead .fv .fv__copy {
    background: none !important;
    backdrop-filter: none !important;
    box-shadow: none !important;
    border: none !important;
    padding: 0 !important;

    /* 位置調整（背景がないので少し画面端に寄せてもOK） */
    width: auto !important;
    max-width: none !important;
    margin-left: clamp(16px, 5vw, 40px) !important;
    margin-right: clamp(16px, 5vw, 40px) !important;
  }
}

/* 4. 背景が消えるため、文字の視認性を確保（白フチ追加） */
.masthead .fv .fv__title {
  /* 濃い青色 */
  color: #0e255a !important;

  /* 強めの白い縁取り（影）をつけて写真の上でも読めるように */
  text-shadow:
    3px 3px 0 #fff, -3px -3px 0 #fff,
    -3px 3px 0 #fff, 3px -3px 0 #fff,
    0 4px 10px rgba(0, 0, 0, 0.2) !important;
}

.masthead .fv .fv__lead {
  color: #0e255a !important;
  font-weight: 700 !important;

  /* リード文にも白フチを追加 */
  text-shadow:
    2px 2px 0 #fff, -2px -2px 0 #fff,
    -2px 2px 0 #fff, 2px -2px 0 #fff !important;

  /* 以前の最大幅制限などを解除 */
  max-width: none !important;
}

/* =========================================================
   Recruit Banner - Pop & Energetic Refresh
   明るく元気で、応募したくなるデザイン
========================================================= */

/* --- コンテナ（背景・ベース） --- */
.cta-band--company {
  /* 鮮やかな青〜水色のグラデーションで「希望」や「青空」をイメージ */
  background: linear-gradient(135deg, #1e88ff 0%, #40c9ff 100%);

  /* 勢いを感じさせる斜めストライプのパターンを薄く重ねる */
  background-image:
    repeating-linear-gradient(45deg,
      rgba(255, 255, 255, 0.1),
      rgba(255, 255, 255, 0.1) 10px,
      transparent 10px,
      transparent 20px),
    linear-gradient(135deg, #1e88ff 0%, #40c9ff 100%);

  border-radius: 32px;
  /* 丸みを強くして親しみやすく */
  padding: 60px;
  overflow: visible;
  /* 装飾がはみ出しても良いように */
  position: relative;
  box-shadow: 0 20px 50px rgba(30, 136, 255, 0.25);
  /* ふんわりした青い影 */
  border: 4px solid #fff;
  /* 白い縁取りでポップに */

  /* フレックスボックスで横並び調整 */
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
}

/* モバイル対応 */
@media (max-width: 768px) {
  .cta-band--company {
    flex-direction: column-reverse;
    /* 画像を上に、テキストを下に */
    padding: 40px 24px;
    text-align: center;
  }
}

/* --- テキストエリア --- */
.cta-band__body {
  flex: 1;
  z-index: 2;
  position: relative;
}

/* 「Recruit」ラベル（ステッカー風） */
.cta-band__body .sec-head__label {
  display: inline-block;
  background: #fff;
  color: #1e88ff;
  font-weight: 900;
  font-size: 14px;
  letter-spacing: 0.1em;
  padding: 6px 16px;
  border-radius: 4px 12px 4px 12px;
  /* 変形角丸 */
  transform: rotate(-3deg);
  /* 少し傾ける */
  box-shadow: 3px 3px 0 rgba(0, 0, 0, 0.1);
  margin-bottom: 20px;
  border: none;
  /* 既存スタイル打消し */
}

/* メイン見出し「正社員募集中」 */
.cta-band__body h2 {
  font-size: clamp(32px, 5vw, 48px);
  /* 大きく！ */
  color: #fff;
  font-weight: 900;
  line-height: 1.2;
  margin-bottom: 16px;
  text-shadow: 2px 2px 0 #0e255a;
  /* 濃い青の影で文字をくっきりさせる */
  letter-spacing: 0.05em;
}

/* サブテキスト（リード文） */
.cta-band__body .note {
  font-size: 16px;
  color: #e0f2ff;
  /* 完全な白より少し青みがかった白 */
  font-weight: 700;
  margin-bottom: 32px;
  line-height: 1.8;
}

/* --- 応募ボタン（ビタミンカラーで強調） --- */
.cta-band__body .btn--primary {
  /* 青の背景で目立つ「黄色〜オレンジ」を採用 */
  background: #ffcc00;
  color: #0e255a !important;
  /* 文字色は濃紺で見やすく */
  border: 3px solid #fff;
  box-shadow: 0 6px 0 #d4a000;
  /* 立体的な影 */

  font-size: 20px;
  padding: 18px 60px;
  border-radius: 50px;
  width: auto;

  /* ワクワクするような動き */
  animation: pulse-btn 2s infinite;
}

/* ボタンのホバー時 */
.cta-band__body .btn--primary:hover {
  background: #ffdb4d;
  transform: translateY(4px);
  /* 押した動き */
  box-shadow: 0 2px 0 #d4a000;
  color: #0e255a !important;
  opacity: 1;
}

@keyframes pulse-btn {
  0% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.05);
  }

  100% {
    transform: scale(1);
  }
}

/* --- 画像エリア（ポラロイド写真風） --- */
.cta-band--company .ph {
  flex: 0 0 45%;
  max-width: 400px;
  border-radius: 0 !important;
  /* HTMLのインラインスタイルを打ち消す場合 */
  overflow: visible !important;
  background: transparent;

  /* 写真風の装飾 */
  transform: rotate(3deg);
  /* 右に傾ける */
  transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.cta-band--company .ph img {
  border-radius: 12px;
  border: 8px solid #fff;
  /* 白い太枠 */
  box-shadow:
    0 10px 20px rgba(0, 0, 0, 0.15),
    0 2px 6px rgba(0, 0, 0, 0.1);
  background: #fff;
  width: 100%;
  height: auto;
  display: block;
}

/* 画像ホバー時 */
.cta-band--company:hover .ph {
  transform: rotate(0deg) scale(1.02);
  /* まっすぐに戻って少し拡大 */
}

/* --- 装飾パーツ（キラキラ） --- */
.cta-band--company::after {
  content: "✨";
  position: absolute;
  top: 30px;
  right: 40%;
  font-size: 40px;
  color: #fff;
  text-shadow: 0 0 10px rgba(255, 255, 255, 0.8);
  animation: sparkle 2s infinite alternate;
  pointer-events: none;
}

@keyframes sparkle {
  0% {
    opacity: 0.4;
    transform: scale(0.8) rotate(0deg);
  }

  100% {
    opacity: 1;
    transform: scale(1.2) rotate(20deg);
  }
}

/* モバイル調整 */
@media (max-width: 768px) {
  .cta-band__body h2 {
    font-size: 28px;
  }

  .cta-band--company .ph {
    width: 100%;
    max-width: 300px;
    transform: rotate(-2deg);
    margin-bottom: 20px;
  }

  .cta-band__body .btn--primary {
    width: 100%;
    /* スマホではボタンを幅いっぱいに */
    padding: 16px;
  }

  .cta-band--company::after {
    top: 10px;
    right: 10px;
  }
}

/* =========================================================
   Recruit Section - Full Width Background / Center Content
   背景だけ画面いっぱい、中身はコンテナ内（元の位置）
========================================================= */

.cta-band--company {
  /* --- 1. 要素自体の配置設定（中身の位置） --- */
  /* これで中身はコンテナ幅（元の位置）に収まります */
  width: 100%;
  margin: 0;

  /* 上下の余白（セクションとしての高さ確保） */
  padding: 60px 0;

  /* --- 2. 背景・枠線のリセット --- */
  /* 本体は透明にして、背景は疑似要素に任せる */
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;

  /* --- 3. 背景を突き抜けさせるための準備 --- */
  position: relative;
  /* 重要：背景がコンテナからはみ出しても消えないようにする */
  overflow: visible !important;

  /* --- Flexboxレイアウトの維持 --- */
  /* PCでは横並び、スマホでは縦並び */
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
}

/* --- 4. 画面いっぱいの背景（ここが主役） --- */
.cta-band--company::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;

  /* 画面中央（要素の中央）を基準に、画面幅(100vw)で配置 */
  left: 50%;
  width: 100vw;
  transform: translateX(-50%);

  /* --- デザイン定義（青いグラデーション） --- */
  background: linear-gradient(135deg, #1e88ff 0%, #40c9ff 100%);
  background-image:
    repeating-linear-gradient(45deg,
      rgba(255, 255, 255, 0.1),
      rgba(255, 255, 255, 0.1) 10px,
      transparent 10px,
      transparent 20px),
    linear-gradient(135deg, #1e88ff 0%, #40c9ff 100%);

  z-index: -1;
  /* 文字の下に敷く */
  box-shadow: 0 10px 40px rgba(30, 136, 255, 0.2);
}

/* --- モバイル対応 --- */
@media (max-width: 768px) {
  .cta-band--company {
    flex-direction: column-reverse;
    /* 画像を上に */
    text-align: center;
    padding: 40px 0;
    /* 上下余白 */
  }
}

/* --- 装飾パーツ（キラキラ）の位置微調整 --- */
/* コンテナ（コンテンツエリア）を基準に配置されるようになります */
.cta-band--company::after {
  top: 10px;
  right: -20px;
  /* コンテナの少し外側 */
}

.cta-band--company::before {
  /* 注：::beforeは背景に使ってしまったので、キラキラ用にもう一つ要素が必要ですが、
       CSSの仕様上、::beforeと::afterの2つしか使えません。
       今回は「背景」で1つ使うため、片方のキラキラ(黄色い方)は諦めるか、
       HTML側に装飾用の空spanを追加する必要があります。
       
       ここでは、白いキラキラ(::after)だけを残します。
    */
}

/* =========================================================
   横スクロール防止（100vw使用時のズレ解消）
   これをCSSの一番上に追加してください
========================================================= */

body {
  overflow-x: hidden;
  /* 横方向のはみ出しを隠す */
  width: 100%;
}

/* =========================================================
   Recruit CTA (統一デザイン版)
   対象: .section--cta 内の .cta-band--company のみ
   ※このブロックはCSSの最下部に置く
========================================================= */

/* セクション全体：余白と区切りを他セクションに合わせる */
.page-company .section--cta,
.page-service .section--cta,
.page-portfolio .section--cta,
.page-sub .section--cta {
  padding-block: clamp(56px, 7vw, 88px);
}

/* CTA本体：レイアウトはそのまま、背景は全幅に */
.section--cta .cta-band--company {
  position: relative;
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(18px, 3vw, 34px);
  align-items: center;

  /* 他と同じ“カード感” */
  padding: clamp(22px, 3.6vw, 34px);
  border-radius: 22px;
  box-shadow: var(--shadow-2);
  border: 1px solid rgba(30, 136, 255, .14);

  /* 本体は透明（背景は::beforeで全幅） */
  background: transparent !important;
  overflow: visible !important;
}

/* 全幅背景：派手すぎない統一グラデ（青系） */
.section--cta .cta-band--company::before {
  content: "";
  position: absolute;
  inset: 0;

  /* 画面いっぱいに伸ばす */
  left: 50%;
  width: 100vw;
  transform: translateX(-50%);

  /* “他要素と同じ青トーン”に寄せる */
  background:
    radial-gradient(900px 380px at 10% 20%, rgba(255, 255, 255, .35), transparent 60%),
    radial-gradient(700px 320px at 80% 70%, rgba(255, 255, 255, .18), transparent 60%),
    linear-gradient(135deg, rgba(42, 157, 244, .92) 0%, rgba(15, 63, 255, .92) 100%);
  z-index: -1;

  /* 少しだけ立体感 */
  box-shadow: 0 16px 50px rgba(30, 136, 255, .18);
}

/* ラベル：他セクションのタグと同じ仕様（白ラベルに統一） */
.section--cta .cta-band__body .sec-head__label {
  display: inline-flex;
  width: fit-content;
  padding: 6px 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .95);
  border: 2px solid rgba(255, 255, 255, .9);
  color: #1349a6;
  font-weight: 900;
  letter-spacing: .14em;
  box-shadow: 3px 3px 0 rgba(0, 0, 0, .10);
  margin-bottom: 14px;
}

/* 見出し：他ページのh2設計に寄せる（白 + 影控えめ） */
.section--cta .cta-band__body h2 {
  margin: 0 0 10px;
  color: #fff;
  font-weight: 900;
  font-size: clamp(28px, 4vw, 40px);
  letter-spacing: .04em;
  line-height: 1.2;
  text-shadow: 0 10px 28px rgba(0, 0, 0, .18);
}

/* 説明文：白に寄せつつ可読性 */
.section--cta .cta-band__body .note {
  margin: 0 0 18px;
  color: rgba(255, 255, 255, .92);
  font-weight: 700;
  line-height: 1.85;
  max-width: 54ch;
}

/* ボタン：サイト共通の btn--primary に合わせる（黄色は撤退） */
.section--cta .cta-band__body .btn--primary {
  background: linear-gradient(135deg, #ffffff 0%, #f2f7ff 100%) !important;
  color: #1349a6 !important;
  border: 2px solid rgba(255, 255, 255, .9) !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, .14) !important;
  animation: none !important;
}

.section--cta .cta-band__body .btn--primary:hover {
  transform: translateY(-1px);
  filter: brightness(1.02);
  box-shadow: 0 14px 34px rgba(0, 0, 0, .18) !important;
}

/* 画像：統一の .ph 枠に合わせる（回転・ポラロイド・インラインを無効） */
.section--cta .cta-band--company .ph {
  transform: none !important;
  border-radius: 18px !important;
  overflow: hidden !important;
  box-shadow: 0 14px 34px rgba(0, 0, 0, .16);
  border: 1px solid rgba(255, 255, 255, .35);
  background: rgba(255, 255, 255, .15);
}

.section--cta .cta-band--company .ph img {
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* レスポンシブ：他セクションと同じ積み方 */
@media (max-width: 900px) {
  .section--cta .cta-band--company {
    grid-template-columns: 1fr;
    text-align: left;
  }

  .section--cta .cta-band--company .ph {
    order: -1;
    max-width: 520px;
    margin-inline: auto;
  }

  .section--cta .cta-band__body .btn--primary {
    width: 100%;
  }
}

/* 横スクロール保険（100vw背景用） */
html,
body {
  overflow-x: hidden;
}

/* =========================================================
   Recruit Button - Unification
   採用ボタンを全体の「ポップスタイル」に統一
========================================================= */

.cta-band__body .btn--primary {
  /* 他のボタン(Aboutなど)と全く同じスタイル定義 */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 16px 48px;
  /* 大きめのパディング */

  background: #fff !important;
  /* 白背景 */
  color: #1e88ff !important;
  /* 青文字 */
  border: 3px solid #1e88ff !important;
  /* 青い太枠 */
  border-radius: 50px;
  /* 丸いカプセル型 */

  /* 共通のポップな影（水色） */
  box-shadow: 4px 4px 0 #bce0fd !important;

  /* 以前の黄色ボタンなどの設定をリセット */
  animation: none !important;
  width: auto !important;
  font-size: 18px !important;
  font-weight: 900 !important;

  transition: all 0.2s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

/* ホバー時の挙動：青く反転して沈む（共通の動き） */
.cta-band__body .btn--primary:hover {
  background: #1e88ff !important;
  /* 青背景 */
  color: #fff !important;
  /* 白文字 */
  box-shadow: 0 0 0 #bce0fd !important;
  /* 影を消す */
  transform: translate(4px, 4px) !important;
  /* その分沈む */
  opacity: 1;
  text-decoration: none;
}

/* =========================================================
   Recruit Banner Layout (match screenshot)
   対象：.section--cta 内の .cta-band--company
========================================================= */

/* セクション自体は背景を持たせない（中のctaで全幅背景を作る） */
.page-company .section--cta {
  padding-block: clamp(56px, 7vw, 92px);
}

/* 2カラム本体 */
.page-company .section--cta .cta-band--company {
  position: relative;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  align-items: center;
  gap: clamp(28px, 4vw, 56px);

  /* 中身の余白（コンテナ内で整える） */
  padding: clamp(34px, 5vw, 56px);
  border-radius: 28px;

  /* 文字が載るので前面にする */
  z-index: 1;
  overflow: hidden;
}

/* 全幅グラデ背景（スクショの雰囲気） */
.page-company .section--cta .cta-band--company::before {
  content: "";
  position: absolute;
  inset: 0;
  left: 50%;
  width: 100vw;
  transform: translateX(-50%);
  z-index: -1;

  background: linear-gradient(135deg, #8cc6ff 0%, #2f66ff 55%, #1140ff 100%);
}

/* 左カラム：文字色を白に */
.page-company .section--cta .cta-band__body {
  color: #fff;
  max-width: 520px;
}

/* RECRUITピル（小ラベル） */
.page-company .section--cta .cta-band__body .sec-head__label {
  display: inline-flex;
  align-items: center;
  gap: 10px;

  padding: 10px 18px;
  border-radius: 999px;

  background: rgba(255, 255, 255, 0.92);
  color: #1140ff;
  border: 1px solid rgba(255, 255, 255, 0.85);

  font-weight: 900;
  letter-spacing: .14em;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.14);
  margin: 0 0 18px;
}

/* 左の小ドット */
.page-company .section--cta .cta-band__body .sec-head__label::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: radial-gradient(circle at 30% 30%, #fff 0%, #6aa6ff 35%, #1140ff 100%);
  box-shadow: 0 4px 14px rgba(17, 64, 255, .35);
}

/* 見出し（大きく・太く） */
.page-company .section--cta .cta-band__body h2 {
  margin: 0 0 14px;
  font-size: clamp(36px, 5vw, 56px);
  font-weight: 900;
  letter-spacing: .06em;
  line-height: 1.15;
  text-shadow: 0 18px 40px rgba(0, 0, 0, .18);
}

/* 説明文（白寄り） */
.page-company .section--cta .cta-band__body .note {
  margin: 0 0 26px;
  color: rgba(255, 255, 255, 0.92);
  font-weight: 700;
  line-height: 1.9;
  font-size: 16px;
  max-width: 46ch;
}

/* CTAボタン（白カプセル） */
.page-company .section--cta .cta-band__body .btn--primary {
  background: #fff !important;
  color: #1140ff !important;
  border: 0 !important;
  box-shadow: 0 18px 44px rgba(0, 0, 0, .18) !important;

  height: 64px;
  padding: 0 42px;
  border-radius: 999px;
  font-size: 18px;
  font-weight: 900;
  animation: none !important;
}

.page-company .section--cta .cta-band__body .btn--primary:hover {
  transform: translateY(-1px);
  filter: brightness(0.98);
}

/* 右の写真カード（角丸＋影） */
.page-company .section--cta .cta-band--company .ph {
  border-radius: 26px;
  overflow: hidden;
  background: rgba(255, 255, 255, .18);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.22);
  border: 1px solid rgba(255, 255, 255, .28);

  /* スクショのサイズ感に寄せる */
  max-width: 720px;
  justify-self: end;
}

.page-company .section--cta .cta-band--company .ph img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* モバイル：縦積み（画像→テキストの順にしたいなら order を入れ替え） */
@media (max-width: 900px) {
  .page-company .section--cta .cta-band--company {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 28px 20px;
  }

  .page-company .section--cta .cta-band--company .ph {
    justify-self: center;
    width: 100%;
    max-width: 520px;
  }

  .page-company .section--cta .cta-band__body {
    max-width: none;
  }

  .page-company .section--cta .cta-band__body .btn--primary {
    width: 100%;
  }
}

/* 100vw背景使用時の横スクロール保険 */
html,
body {
  overflow-x: hidden;
}

/* =========================================================
   Recruit Teaser (Unified with site sections)
========================================================= */
.recruit-teaser__lead {
  margin: 10px 0 12px;
  font-weight: 900;
  font-size: clamp(18px, 2.2vw, 22px);
  color: var(--ink);
  line-height: 1.4;
}

.recruit-teaser__actions {
  margin-top: 18px;
}

/* モバイルで画像を上に（他セクションと同じ積み方） */
@media (max-width: 900px) {
  .recruit-teaser .recruit-teaser__media {
    order: -1;
  }

  .recruit-teaser .btn {
    width: 100%;
    justify-content: center;
  }
}

/* =========================================================
   Recruit Teaser (main.css only / unified)
========================================================= */
.recruit-teaser .sec-head__label {
  /* company.css の上書きを受けても統一されるように“採用だけ”固定 */
  display: inline-flex;
  width: fit-content;
  padding: 6px 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .95);
  border: 2px solid rgba(30, 136, 255, .28);
  color: var(--ink-2);
  font-weight: 900;
  letter-spacing: .14em;
  box-shadow: var(--shadow-1);
  margin-bottom: 14px;
}

.recruit-teaser .sec-head__title {
  margin: 0 0 10px;
  font-weight: 900;
  letter-spacing: .06em;
  color: var(--ink);
}

.recruit-teaser__lead {
  margin: 6px 0 10px;
  font-weight: 900;
  font-size: clamp(18px, 2.2vw, 22px);
  color: var(--ink);
  line-height: 1.45;
}

.recruit-teaser__note {
  max-width: 56ch;
  line-height: 1.9;
}

.recruit-teaser__actions {
  margin-top: 18px;
}

.recruit-teaser__media {
  /* 画像を少しだけ“採用らしく”立たせる（他セクションと同トーン） */
  box-shadow: 0 18px 46px rgba(15, 35, 80, .10);
}

@media (max-width: 900px) {
  .recruit-teaser .recruit-teaser__media {
    order: -1;
  }

  .recruit-teaser .btn {
    width: 100%;
    justify-content: center;
  }
}

/* =========================================================
   Recruit Teaser – main.css 完結仕様
========================================================= */
.recruit-teaser {
  background: linear-gradient(180deg,
      #ffffff 0%,
      #f4f8ff 100%);
}

.recruit-teaser .section__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 72px);
  align-items: center;

  background: #ffffff;
  border-radius: 40px;
  padding: clamp(32px, 6vw, 72px);

  box-shadow:
    0 30px 80px rgba(30, 136, 255, .08),
    inset 0 0 0 3px #eaf2ff;
}

/* ---------- 左側 ---------- */
.recruit-teaser .sec-head__label {
  display: inline-flex;
  align-items: center;
  gap: 8px;

  padding: 6px 16px;
  border-radius: 999px;

  font-size: 13px;
  font-weight: 800;
  letter-spacing: .18em;

  color: #1e88ff;
  background: #ffffff;
  border: 2px solid #cfe2ff;
}

.recruit-teaser .sec-head__title {
  margin: 14px 0 22px;
  font-size: clamp(26px, 3vw, 34px);
  font-weight: 900;
  letter-spacing: .08em;
  color: #0e255a;
}

.recruit-teaser__lead {
  font-size: clamp(18px, 2vw, 22px);
  font-weight: 800;
  line-height: 1.6;
  margin-bottom: 16px;
  color: #0e255a;
}

.recruit-teaser__text {
  font-size: 15px;
  line-height: 1.9;
  color: #6c7aa3;
  max-width: 42em;
}

/* ---------- ボタン ---------- */
.recruit-teaser__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  margin-top: 32px;
  padding: 18px 48px;

  font-size: 16px;
  font-weight: 800;
  color: #ffffff;
  text-decoration: none;

  border-radius: 999px;
  background: linear-gradient(135deg, #2a9df4, #0f3fff);

  box-shadow:
    0 18px 40px rgba(30, 136, 255, .35);
  transition: transform .25s, box-shadow .25s;
}

.recruit-teaser__btn:hover {
  transform: translateY(-2px);
  box-shadow:
    0 26px 60px rgba(30, 136, 255, .45);
}

/* ---------- 右側画像 ---------- */
.recruit-teaser__image img {
  width: 100%;
  height: auto;
  display: block;

  border-radius: 28px;
  box-shadow: 0 24px 60px rgba(0, 0, 0, .18);
}

/* ---------- モバイル ---------- */
@media (max-width: 900px) {
  .recruit-teaser .section__inner {
    grid-template-columns: 1fr;
  }

  .recruit-teaser__image {
    order: -1;
  }

  .recruit-teaser__btn {
    width: 100%;
  }
}

/* =========================================================
   Recruit Section Design Unification (Final)
   採用セクションを他のセクション（代表挨拶・沿革など）と完全統一
========================================================= */

/* 採用セクション全体：背景を無し（他セクションと同じ） */
.recruit-teaser {
  background: none !important;
}

/* 内側のパネル：他セクションと同じ白いカードデザイン */
.recruit-teaser .section__inner {
  background: #ffffff;
  border-radius: 22px;
  box-shadow: 0 18px 50px rgba(15, 35, 80, 0.08);
  padding: clamp(24px, 4vw, 32px);

  /* レイアウト：2カラム（他のsection--panelと同じ） */
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 48px);
  align-items: center;
}

/* 見出しブロック：他セクションと統一 */
.recruit-teaser .sec-head {
  margin-bottom: 18px;
}

/* RECRUITラベル：他セクションと同じタグスタイル */
.recruit-teaser .sec-head__label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;

  padding: 6px 16px;
  border-radius: 999px;

  background: #fff;
  color: #1e88ff;
  border: 2px solid #1e88ff;

  font-weight: 900;
  font-size: 12px;
  letter-spacing: .14em;

  box-shadow: 3px 3px 0 #bce0fd;
  margin: 0 0 12px 0;
  line-height: 1.1;
  white-space: nowrap;
}

/* タイトル：他セクションと統一 */
.recruit-teaser .sec-head__title {
  margin: 0 0 10px;
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 900;
  letter-spacing: .06em;
  color: #14286b;
  line-height: 1.3;

  /* 波線装飾：他の見出しと同じ */
  display: inline-block;
  position: relative;
  padding-bottom: 10px;
}

.recruit-teaser .sec-head__title::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 6px;
  bottom: -10px;
  background: url('data:image/svg+xml;charset=utf8,%3Csvg viewBox="0 0 20 4" xmlns="http://www.w3.org/2000/svg"%3E%3Cpath d="M0 4 C5 4 5 0 10 0 C15 0 15 4 20 4" stroke="%232a9df4" stroke-width="2" fill="none"/%3E%3C/svg%3E') repeat-x;
  background-size: 20px 6px;
  opacity: 0.6;
}

/* リードテキスト：他セクションと統一 */
.recruit-teaser__lead {
  margin: 10px 0 12px;
  font-weight: 900;
  font-size: clamp(18px, 2.2vw, 22px);
  color: #14286b;
  line-height: 1.5;
}

/* 説明文：他セクションと統一 */
.recruit-teaser__note {
  color: #344056;
  font-size: 14px;
  line-height: 1.9;
  max-width: 56ch;
}

/* ボタンエリア */
.recruit-teaser__actions {
  margin-top: 20px;
}

/* ボタン：他セクションと統一 */
.recruit-teaser .btn--primary {
  background: linear-gradient(135deg, #2a9df4, #0f3fff);
  color: #fff;
  border: none;
  padding: 14px 28px;
  border-radius: 100px;
  font-weight: 700;
  font-size: 15px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  box-shadow: 0 8px 22px rgba(30, 136, 255, .18);
  transition: all .25s ease;
}

.recruit-teaser .btn--primary:hover {
  opacity: .9;
  box-shadow: 0 12px 34px rgba(30, 136, 255, .28);
  transform: translateY(-1px);
}

.recruit-teaser .btn--primary:active {
  transform: translateY(0);
}

/* 画像：他セクションと統一（ポラロイド風の装飾） */
.recruit-teaser__media {
  position: relative;
  background: #fff;
  border-radius: 18px;
  padding: 12px;
  box-shadow: 0 18px 46px rgba(15, 35, 80, .10);
  transition: transform .3s ease;
}

.recruit-teaser__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 12px;
  display: block;
}

.recruit-teaser .section__inner:hover .recruit-teaser__media {
  transform: rotate(-1deg) scale(1.02);
}

/* モバイル対応 */
@media (max-width: 900px) {
  .recruit-teaser .section__inner {
    grid-template-columns: 1fr;
    padding: clamp(20px, 4vw, 24px);
  }

  .recruit-teaser__media {
    order: -1;
  }

  .recruit-teaser .btn--primary {
    width: 100%;
    justify-content: center;
  }

  .recruit-teaser .sec-head__title::after {
    width: 100%;
  }
}

@media (max-width: 768px) {
  .recruit-teaser .sec-head__label {
    padding: 6px 14px;
    font-size: 11px;
    letter-spacing: .12em;
    box-shadow: 2px 2px 0 #bce0fd;
  }

  .recruit-teaser__lead {
    font-size: 16px;
  }

  .recruit-teaser__note {
    font-size: 13px;
  }
}

/* =========================================================
   Remove Wavy Line Decoration from All Headings
   すべての見出しから波線装飾を削除
========================================================= */

/* すべてのh2見出しの波線を無効化 */
h2::after,
h2[id^="sec-"]::after,
.sec-head__title::after,
.page-company h2::after,
.page-company .sec-head__title::after,
.recruit-teaser .sec-head__title::after {
  display: none !important;
}

/* 波線用の余白をリセット */
h2,
h2[id^="sec-"],
.sec-head__title,
.page-company h2,
.page-company .sec-head__title,
.recruit-teaser .sec-head__title {
  padding-bottom: 0 !important;
}

/* =========================================================
   CTA Section Unification (Services & Portfolio)
   設備工事のご相談・ご依頼セクションを統一デザインに
========================================================= */

/* CTAセクション全体：背景なし */
.section--cta {
  background: none !important;
}

/* CTAバンド：白いカードデザイン（他のセクションと統一） */
.cta-band--works {
  background: #ffffff;
  border-radius: 22px;
  box-shadow: 0 18px 50px rgba(15, 35, 80, 0.08);
  padding: clamp(24px, 4vw, 32px);

  /* レイアウト：2カラム */
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 48px);
  align-items: center;
}

/* 左側のテキストエリア */
.cta-band--works .cta-band__body {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* 見出し：他セクションと統一 */
.cta-band--works h2 {
  margin: 0 0 12px;
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 900;
  letter-spacing: .06em;
  color: #14286b;
  line-height: 1.3;
}

/* 説明文：他セクションと統一 */
.cta-band--works .note {
  color: #344056;
  font-size: 14px;
  line-height: 1.9;
  margin: 0 0 8px;
}

/* ボタンエリア */
.cta-band--works .cta-band__actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 12px;
}

/* プライマリボタン：他セクションと統一 */
.cta-band--works .btn--primary {
  background: linear-gradient(135deg, #2a9df4, #0f3fff);
  color: #fff;
  border: none;
  padding: 14px 28px;
  border-radius: 100px;
  font-weight: 700;
  font-size: 15px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  box-shadow: 0 8px 22px rgba(30, 136, 255, .18);
  transition: all .25s ease;
}

.cta-band--works .btn--primary:hover {
  opacity: .9;
  box-shadow: 0 12px 34px rgba(30, 136, 255, .28);
  transform: translateY(-1px);
}

.cta-band--works .btn--primary:active {
  transform: translateY(0);
}

/* ゴーストボタン：統一デザイン */
.cta-band--works .btn.ghost {
  background: #fff;
  color: #1f56b3;
  border: 2px solid #1f56b3;
  padding: 12px 24px;
  border-radius: 100px;
  font-weight: 700;
  font-size: 15px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all .25s ease;
}

.cta-band--works .btn.ghost:hover {
  background: #1f56b3;
  color: #fff;
  transform: translateY(-1px);
}

/* 右側の画像：他セクションと統一（ポラロイド風） */
.cta-band--works .ph {
  position: relative;
  background: #fff;
  border-radius: 18px;
  padding: 12px;
  box-shadow: 0 18px 46px rgba(15, 35, 80, .10);
  transition: transform .3s ease;
}

.cta-band--works .ph img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 12px;
  display: block;
}

.cta-band--works:hover .ph {
  transform: rotate(-1deg) scale(1.02);
}

/* モバイル対応 */
@media (max-width: 900px) {
  .cta-band--works {
    grid-template-columns: 1fr;
    padding: clamp(20px, 4vw, 24px);
  }

  .cta-band--works .ph {
    order: -1;
  }

  .cta-band--works .cta-band__actions {
    flex-direction: column;
    gap: 10px;
  }

  .cta-band--works .btn--primary,
  .cta-band--works .btn.ghost {
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 768px) {
  .cta-band--works h2 {
    font-size: 22px;
  }

  .cta-band--works .note {
    font-size: 13px;
  }
}

/* =========================================================
   CTA Section - Portfolio Style (Blue Gradient Background)
   添付デザインに基づくCTAセクションの統一スタイル
========================================================= */

/* 既存のCTAスタイルを上書き */
.section--cta {
  background: linear-gradient(135deg, #2a9df4 0%, #1e88ff 50%, #0f3fff 100%) !important;
  position: relative;
  overflow: hidden;
}

/* 斜めストライプパターン */
.section--cta::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: repeating-linear-gradient(45deg,
      rgba(255, 255, 255, 0.03) 0px,
      rgba(255, 255, 255, 0.03) 10px,
      transparent 10px,
      transparent 20px);
  pointer-events: none;
}

/* CTAバンド：透明背景に変更（青いグラデーション背景を活かす） */
.cta-band--works {
  background: transparent !important;
  box-shadow: none !important;
  padding: clamp(40px, 6vw, 80px) clamp(24px, 4vw, 40px) !important;

  /* レイアウト：2カラム */
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 80px);
  align-items: center;
  position: relative;
  z-index: 1;
}

/* 左側のテキストエリア */
.cta-band--works .cta-band__body {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* 見出し：白色で大きく */
.cta-band--works h2 {
  margin: 0 0 16px;
  font-size: clamp(28px, 4vw, 42px);
  font-weight: 900;
  letter-spacing: .08em;
  color: #ffffff !important;
  line-height: 1.4;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

/* 説明文：白色 */
.cta-band--works .note {
  color: #ffffff !important;
  font-size: clamp(14px, 1.6vw, 16px);
  line-height: 2;
  margin: 0 0 12px;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
}

/* ボタンエリア */
.cta-band--works .cta-band__actions {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 16px;
}

/* プライマリボタン：白背景に青文字 */
.cta-band--works .btn--primary {
  background: #ffffff !important;
  color: #1e88ff !important;
  border: none;
  padding: 16px 32px;
  border-radius: 100px;
  font-weight: 700;
  font-size: 16px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
  transition: all .25s ease;
}

.cta-band--works .btn--primary:hover {
  background: #f0f7ff !important;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.2);
  transform: translateY(-2px);
}

.cta-band--works .btn--primary:active {
  transform: translateY(0);
}

/* ゴーストボタン：白枠に白文字 */
.cta-band--works .btn.ghost {
  background: transparent !important;
  color: #ffffff !important;
  border: 2px solid #ffffff;
  padding: 14px 30px;
  border-radius: 100px;
  font-weight: 700;
  font-size: 16px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all .25s ease;
}

.cta-band--works .btn.ghost:hover {
  background: rgba(255, 255, 255, 0.15) !important;
  transform: translateY(-2px);
}

/* 右側の画像：二重枠のポラロイド風デザイン */
.cta-band--works .ph {
  position: relative;
  background: #ffffff;
  border-radius: 24px;
  padding: 16px;
  box-shadow:
    0 0 0 8px rgba(255, 255, 255, 0.3),
    0 20px 60px rgba(0, 0, 0, 0.25);
  transition: transform .3s ease;
}

.cta-band--works .ph img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 16px;
  display: block;
}

.cta-band--works:hover .ph {
  transform: rotate(-1deg) scale(1.03);
}

/* モバイル対応 */
@media (max-width: 900px) {
  .cta-band--works {
    grid-template-columns: 1fr;
    padding: clamp(32px, 6vw, 48px) clamp(20px, 4vw, 24px) !important;
    gap: 32px;
  }

  .cta-band--works .ph {
    order: -1;
    max-width: 500px;
    margin: 0 auto;
  }

  .cta-band--works .cta-band__actions {
    flex-direction: column;
    gap: 12px;
  }

  .cta-band--works .btn--primary,
  .cta-band--works .btn.ghost {
    width: 100%;
    justify-content: center;
    padding: 14px 24px;
  }
}

@media (max-width: 768px) {
  .cta-band--works h2 {
    font-size: 24px;
    margin-bottom: 12px;
  }

  .cta-band--works .note {
    font-size: 14px;
    line-height: 1.9;
  }

  .cta-band--works .btn--primary,
  .cta-band--works .btn.ghost {
    font-size: 15px;
  }
}

/* =========================================================
   CTA Section - Services Page Style (White Border Frame)
   servicesページのデザインに統一（白い枠線付き）
========================================================= */

/* コンテナに白い枠線を追加 */
.section--cta .container {
  position: relative;
  z-index: 1;
}

/* CTAバンド：白い枠線で囲む */
.cta-band--works {
  border: 3px solid rgba(255, 255, 255, 0.4) !important;
  border-radius: 32px !important;
  padding: clamp(48px, 7vw, 80px) clamp(32px, 5vw, 60px) !important;
  backdrop-filter: blur(10px);
}

/* 「お電話で相談する」ボタンに黄色/オレンジの枠線を追加 */
.cta-band--works .btn.ghost {
  background: transparent !important;
  color: #ffffff !important;
  border: 3px solid #fbbf24 !important;
  padding: 14px 30px;
  border-radius: 100px;
  font-weight: 700;
  font-size: 16px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all .25s ease;
  box-shadow: 0 4px 12px rgba(251, 191, 36, 0.3);
}

.cta-band--works .btn.ghost:hover {
  background: rgba(251, 191, 36, 0.1) !important;
  border-color: #f59e0b !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(251, 191, 36, 0.4);
}

/* 矢印アイコン付きボタン用（オプション） */
.cta-band--works .btn--primary::after,
.cta-band--works .btn.ghost::after {
  content: "→";
  margin-left: 4px;
  transition: transform .25s ease;
}

.cta-band--works .btn--primary:hover::after,
.cta-band--works .btn.ghost:hover::after {
  transform: translateX(4px);
}

/* モバイル対応の調整 */
@media (max-width: 900px) {
  .cta-band--works {
    border-width: 2px !important;
    border-radius: 24px !important;
    padding: clamp(36px, 6vw, 48px) clamp(24px, 4vw, 32px) !important;
  }
}

@media (max-width: 768px) {
  .cta-band--works .btn.ghost {
    border-width: 2px !important;
  }
}

/* =========================================================
   CTA Section - Revert to Portfolio Style (Simple Blue Gradient)
   servicesページ用のスタイルを削除してportfolioデザインに統一
========================================================= */

/* 白い枠線を削除 */
.cta-band--works {
  border: none !important;
  border-radius: 0 !important;
}

/* 「お電話で相談する」ボタンを元のシンプルな白枠に戻す */
.cta-band--works .btn.ghost {
  background: transparent !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
  padding: 14px 30px;
  border-radius: 100px;
  font-weight: 700;
  font-size: 16px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all .25s ease;
  box-shadow: none !important;
}

.cta-band--works .btn.ghost:hover {
  background: rgba(255, 255, 255, 0.15) !important;
  border-color: #ffffff !important;
  transform: translateY(-2px);
  box-shadow: none !important;
}

/* 矢印アイコンを削除 */
.cta-band--works .btn--primary::after,
.cta-band--works .btn.ghost::after {
  content: none !important;
}

/* =========================================================
   CTA Section - Unified Design for All Pages
   全ページ統一：CTAセクションの完全統一スタイル
========================================================= */

/* セクション全体のリセット */
.section--cta {
  background: none !important;
  padding: 0 !important;
  overflow: hidden;
}

.section--cta .container {
  padding: 0;
  max-width: 100%;
}

/* CTAバンド：全画面背景版 */
.cta-band--works {
  width: 100%;
  padding: 60px clamp(24px, 4vw, 40px) !important;

  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  margin-top: 0 !important;

  position: relative;
  overflow: visible !important;

  /* レイアウト */
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 40px !important;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

/* 全画面背景（疑似要素） */
.cta-band--works::before {
  display: block !important;
  content: "" !important;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 100vw;
  transform: translateX(-50%);
  z-index: -1;

  /* 青グラデーション＋ストライプ */
  background: linear-gradient(135deg, #1e88ff 0%, #40c9ff 100%);
  background-image:
    repeating-linear-gradient(45deg, rgba(255, 255, 255, 0.1) 0, rgba(255, 255, 255, 0.1) 10px, transparent 10px, transparent 20px),
    linear-gradient(135deg, #1e88ff 0%, #40c9ff 100%);
  box-shadow: 0 10px 40px rgba(30, 136, 255, 0.2);
}

/* テキストエリア */
.cta-band--works .cta-band__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* テキスト色調整 */
.cta-band--works h2,
.cta-band--works h3,
.cta-band--works .note {
  color: #fff !important;
  text-shadow: 1px 1px 0 rgba(0, 0, 0, 0.1);
  background: none !important;
  -webkit-text-fill-color: initial !important;
}

.cta-band--works h2,
.cta-band--works h3 {
  font-size: clamp(28px, 4vw, 40px) !important;
  margin: 0 0 16px !important;
  font-weight: 900 !important;
  letter-spacing: .06em;
  line-height: 1.4;
}

.cta-band--works .note {
  font-size: clamp(14px, 1.6vw, 16px) !important;
  line-height: 2;
  margin: 0 0 8px;
}

/* 画像エリア */
.cta-band--works .ph {
  flex: 0 0 auto !important;
  width: clamp(300px, 35vw, 450px) !important;
  background: #fff !important;
  border-radius: 24px !important;
  padding: 16px !important;
  box-shadow:
    0 0 0 8px rgba(255, 255, 255, 0.3),
    0 20px 60px rgba(0, 0, 0, 0.25) !important;
  border: none !important;
  transform: rotate(-2deg) !important;
  transition: transform .3s ease;
  aspect-ratio: auto;
}

.cta-band--works .ph img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 16px !important;
  display: block;
}

/* 画像ホバー */
.cta-band--works:hover .ph {
  transform: rotate(0deg) scale(1.02) !important;
}

/* --- アクションボタンエリア --- */
.cta-band--works .cta-band__actions {
  display: flex !important;
  gap: 16px !important;
  flex-wrap: wrap !important;
  margin-top: clamp(20px, 3vw, 32px) !important;
}

/* メインボタン（黄色） */
.cta-band--works .btn--primary,
.cta-band--works .cta-band__actions .btn--primary {
  background: #ffcc00 !important;
  color: #0e255a !important;
  border: 3px solid #fff !important;
  box-shadow: 0 6px 0 #d4a000 !important;
  border-radius: 50px !important;
  padding: 16px 40px !important;
  font-size: 18px !important;
  font-weight: 900 !important;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all .25s ease;
  animation: pulse-btn 2s infinite;
}

.cta-band--works .btn--primary:hover,
.cta-band--works .cta-band__actions .btn--primary:hover {
  background: #ffdb4d !important;
  transform: translateY(4px) !important;
  box-shadow: 0 2px 0 #d4a000 !important;
  opacity: 1 !important;
}

.cta-band--works .btn--primary:active,
.cta-band--works .cta-band__actions .btn--primary:active {
  transform: translateY(6px) !important;
  box-shadow: 0 0 0 #d4a000 !important;
}

/* サブボタン（白ゴースト・電話） */
.cta-band--works .btn.ghost,
.cta-band--works .cta-band__actions .btn.ghost {
  background: transparent !important;
  color: #fff !important;
  border: 2px solid #fff !important;
  box-shadow: none !important;
  border-radius: 50px !important;
  padding: 16px 32px !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all .25s ease;
}

.cta-band--works .btn.ghost:hover,
.cta-band--works .cta-band__actions .btn.ghost:hover {
  background: #fff !important;
  color: #1e88ff !important;
  transform: translateY(-2px) !important;
}

.cta-band--works .btn.ghost:active,
.cta-band--works .cta-band__actions .btn.ghost:active {
  transform: translateY(0) !important;
}

/* 鼓動アニメーション */
@keyframes pulse-btn {
  0% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.05);
  }

  100% {
    transform: scale(1);
  }
}

/* CTAモバイル調整 */
@media (max-width: 900px) {
  .cta-band--works {
    flex-direction: column-reverse !important;
    text-align: center !important;
    padding: 40px clamp(20px, 4vw, 24px) !important;
  }

  .cta-band--works .ph {
    width: 80% !important;
    margin-bottom: 20px;
  }

  .cta-band--works .cta-band__actions {
    justify-content: center;
    flex-direction: column;
    gap: 12px !important;
  }

  .cta-band--works .btn--primary,
  .cta-band--works .cta-band__actions .btn--primary,
  .cta-band--works .btn.ghost,
  .cta-band--works .cta-band__actions .btn.ghost {
    width: 100%;
    max-width: 400px;
  }
}

@media (max-width: 768px) {

  .cta-band--works h2,
  .cta-band--works h3 {
    font-size: 24px !important;
  }

  .cta-band--works .note {
    font-size: 14px !important;
    line-height: 1.9;
  }

  .cta-band--works .btn--primary,
  .cta-band--works .cta-band__actions .btn--primary {
    padding: 14px 32px !important;
    font-size: 16px !important;
  }

  .cta-band--works .btn.ghost,
  .cta-band--works .cta-band__actions .btn.ghost {
    padding: 14px 28px !important;
    font-size: 15px !important;
  }
}

/* 矢印などの余計な要素を削除 */
.cta-band--works .btn--primary::after,
.cta-band--works .btn.ghost::after,
.cta-band--works .cta-band__actions .btn--primary::after,
.cta-band--works .cta-band__actions .btn.ghost::after {
  content: none !important;
  display: none !important;
}

/* =========================================================
   CTA Section Override - Force Apply Unified Design
   services.cssとportfolio.cssの汎用.cta-bandを強制上書き
========================================================= */

/* 詳細度を上げて確実に適用 */
.section--cta .container .cta-band.cta-band--works {
  /* 背景・ボーダーをリセット */
  background: transparent !important;
  border: none !important;
  border-left: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;

  /* レイアウト */
  display: flex !important;
  grid-template-columns: initial !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 40px !important;

  /* パディング・マージン */
  padding: 60px clamp(24px, 4vw, 40px) !important;
  margin-top: 0 !important;

  /* ポジション */
  position: relative !important;
  overflow: visible !important;

  /* テキストカラー */
  color: #fff !important;
}

/* 疑似要素の強制表示 */
.section--cta .container .cta-band.cta-band--works::before {
  display: block !important;
  content: "" !important;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 100vw;
  transform: translateX(-50%);
  z-index: -1;

  background: linear-gradient(135deg, #1e88ff 0%, #40c9ff 100%);
  background-image:
    repeating-linear-gradient(45deg, rgba(255, 255, 255, 0.1) 0, rgba(255, 255, 255, 0.1) 10px, transparent 10px, transparent 20px),
    linear-gradient(135deg, #1e88ff 0%, #40c9ff 100%);
  box-shadow: 0 10px 40px rgba(30, 136, 255, 0.2);
}

/* 装飾的な疑似要素を削除 */
.section--cta .container .cta-band.cta-band--works::after {
  display: none !important;
  content: none !important;
}

/* テキスト要素 */
.section--cta .cta-band.cta-band--works h2,
.section--cta .cta-band.cta-band--works h3,
.section--cta .cta-band.cta-band--works .note {
  color: #fff !important;
  text-shadow: 1px 1px 0 rgba(0, 0, 0, 0.1) !important;
  background: none !important;
  -webkit-text-fill-color: initial !important;
}

/* 画像 */
.section--cta .cta-band.cta-band--works .ph {
  flex: 0 0 auto !important;
  width: clamp(300px, 35vw, 450px) !important;
  background: #fff !important;
  border-radius: 24px !important;
  padding: 16px !important;
  box-shadow:
    0 0 0 8px rgba(255, 255, 255, 0.3),
    0 20px 60px rgba(0, 0, 0, 0.25) !important;
  border: 1px solid transparent !important;
  transform: rotate(-2deg) !important;
  transition: transform .3s ease;
}

/* ボタン */
.section--cta .cta-band.cta-band--works .btn--primary,
.section--cta .cta-band.cta-band--works .cta-band__actions .btn--primary {
  background: #ffcc00 !important;
  color: #0e255a !important;
  border: 3px solid #fff !important;
  box-shadow: 0 6px 0 #d4a000 !important;
  border-radius: 50px !important;
  padding: 16px 40px !important;
  font-size: 18px !important;
  font-weight: 900 !important;
  animation: pulse-btn 2s infinite !important;
}

.section--cta .cta-band.cta-band--works .btn.ghost,
.section--cta .cta-band.cta-band--works .cta-band__actions .btn.ghost {
  background: transparent !important;
  color: #fff !important;
  border: 2px solid #fff !important;
  box-shadow: none !important;
  border-radius: 50px !important;
  padding: 16px 32px !important;
  font-size: 16px !important;
  font-weight: 700 !important;
}

/* モバイル */
@media (max-width: 900px) {
  .section--cta .container .cta-band.cta-band--works {
    flex-direction: column-reverse !important;
    text-align: center !important;
  }
}

/* =========================================================
   CTA Section - Ultimate Override for Mobile
   レスポンシブ時の青背景を確実に表示
========================================================= */

@media (max-width: 900px) {

  body .section--cta .container .cta-band.cta-band--works,
  body .section--cta .cta-band.cta-band--works {
    background: transparent !important;
    border: none !important;
    border-left: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    flex-direction: column-reverse !important;
    text-align: center !important;
    padding: 40px clamp(20px, 4vw, 24px) !important;
  }

  body .section--cta .container .cta-band.cta-band--works::before,
  body .section--cta .cta-band.cta-band--works::before {
    display: block !important;
    content: "" !important;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    width: 100vw;
    transform: translateX(-50%);
    z-index: -1;
    background: linear-gradient(135deg, #1e88ff 0%, #40c9ff 100%) !important;
    background-image:
      repeating-linear-gradient(45deg, rgba(255, 255, 255, 0.1) 0, rgba(255, 255, 255, 0.1) 10px, transparent 10px, transparent 20px),
      linear-gradient(135deg, #1e88ff 0%, #40c9ff 100%) !important;
    box-shadow: 0 10px 40px rgba(30, 136, 255, 0.2);
  }

  body .section--cta .cta-band.cta-band--works h2,
  body .section--cta .cta-band.cta-band--works h3,
  body .section--cta .cta-band.cta-band--works .note {
    color: #fff !important;
  }
}

@media (max-width: 768px) {

  body .section--cta .container .cta-band.cta-band--works,
  body .section--cta .cta-band.cta-band--works {
    background: transparent !important;
    border: none !important;
    padding: 32px clamp(16px, 4vw, 20px) !important;
  }

  body .section--cta .container .cta-band.cta-band--works::before,
  body .section--cta .cta-band.cta-band--works::before {
    display: block !important;
  }

  body .section--cta .cta-band.cta-band--works h2,
  body .section--cta .cta-band.cta-band--works h3 {
    font-size: 24px !important;
    color: #fff !important;
  }

  body .section--cta .cta-band.cta-band--works .note {
    font-size: 14px !important;
    color: #fff !important;
  }
}

@media (max-width: 600px) {

  body .section--cta .container .cta-band.cta-band--works,
  body .section--cta .cta-band.cta-band--works {
    background: transparent !important;
    padding: 28px 16px !important;
  }

  body .section--cta .container .cta-band.cta-band--works::before,
  body .section--cta .cta-band.cta-band--works::before {
    display: block !important;
  }

  body .section--cta .cta-band.cta-band--works h2,
  body .section--cta .cta-band.cta-band--works h3,
  body .section--cta .cta-band.cta-band--works .note {
    color: #fff !important;
  }
}