@charset "UTF-8";

#mainColumn .okiTabMod {
  --accent: #DC0000;
  --border: #999;
  --bg: #f6f6f6;

  --tab-h: 64px;
  /* PC */
  --fs: 1.8rem;
  /* PC */

  margin: 0 0 30px;
}

/* tabs（下線はborderではなく疑似要素で1本） */
#mainColumn .okiTabMod__tabs {
  margin: 0;
  padding: 0;
  list-style: none;

  display: flex;
  align-items: stretch;
  width: 100%;

  gap: 4px;

  border-bottom: 0;
  position: relative;
}

/* gap非対応フォールバック */
@supports not (gap: 4px) {
  #mainColumn .okiTabMod__tab {
    margin-right: 4px;
  }

  #mainColumn .okiTabMod__tab:last-child {
    margin-right: 0;
  }
}

/* タブ列の下線（常にフラットな1本） */
#mainColumn .okiTabMod__tabs::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: var(--accent);
  pointer-events: none;
}

/* tab item */
#mainColumn .okiTabMod__tab {
  margin: 0;
  padding: 0;

  box-sizing: border-box;
  height: var(--tab-h);

  display: flex;
  align-items: center;

  border: 1px solid var(--border);
  border-bottom: 0;

  background: var(--bg);
  color: #1b1b1b;

  cursor: pointer;
  user-select: none;

  position: relative;
}

/* 幅（最大3つ想定） */
#mainColumn .okiTabMod--3 .okiTabMod__tab {
  width: 33.3333%;
}

#mainColumn .okiTabMod--2 .okiTabMod__tab {
  width: 50%;
}

#mainColumn .okiTabMod--1 .okiTabMod__tab {
  width: 100%;
}

/* タブ下線（ulの線と同じ位置に内側で重ねる） */
#mainColumn .okiTabMod__tab::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: var(--accent);
  pointer-events: none;
}

#mainColumn .okiTabMod__tab.is-active::after {
  background: #fff;
}

/* label */
#mainColumn .okiTabMod__tab>span {
  display: block;
  padding: 0 16px 0 34px;

  font-size: var(--fs);
  font-weight: 700;
  line-height: 1.2;

  position: relative;

  /* SPで文字がはみ出すのを防ぐ（横並び維持のため折返し許可） */
  white-space: normal;
  word-break: break-word;
}

/* 左矢印 */
#mainColumn .okiTabMod__tab>span::before {
  content: "";
  position: absolute;
  left: 18px;
  top: 50%;

  width: 8px;
  height: 8px;

  border-right: 1px solid var(--accent);
  border-bottom: 1px solid var(--accent);
  transform: translate(0, -50%) rotate(-45deg);
}

/* hover */
#mainColumn .okiTabMod__tab:hover>span {
  text-decoration: underline;
}

/* active */
#mainColumn .okiTabMod__tab.is-active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

#mainColumn .okiTabMod__tab.is-active>span::before {
  border-right-color: #fff;
  border-bottom-color: #fff;
}

/* panes */
#mainColumn .okiTabMod__panes {
  padding-top: 30px;
}

#mainColumn .okiTabMod__pane {
  display: none;
}

#mainColumn .okiTabMod__pane.is-active {
  display: block;
}

/* ================================
   Responsive：横並びは維持、文字サイズ等だけ調整
================================ */

/* タブが詰まる領域：フォント/高さ/余白を縮める */
@media (max-width: 1024px) {
  #mainColumn .okiTabMod {
    --fs: 1.6rem;
    --tab-h: 60px;
  }

  #mainColumn .okiTabMod__tab>span {
    padding-left: 30px;
    padding-right: 12px;
  }

  #mainColumn .okiTabMod__tab>span::before {
    left: 14px;
  }
}

@media (max-width: 767px) {
  #mainColumn .okiTabMod {
    --fs: 1.35rem;
    --tab-h: 56px;
  }

  #mainColumn .okiTabMod__tab>span {
    padding-left: 28px;
    padding-right: 10px;
    line-height: 1.15;
  }

  #mainColumn .okiTabMod__tab>span::before {
    left: 12px;
    width: 7px;
    height: 7px;
  }
}

/* 超小型：さらに少しだけ縮める */
@media (max-width: 375px) {
  #mainColumn .okiTabMod {
    --fs: 1.2rem;
    --tab-h: 54px;
  }

  #mainColumn .okiTabMod__tab>span {
    padding-left: 26px;
    padding-right: 8px;
  }

  #mainColumn .okiTabMod__tab>span::before {
    left: 11px;
    width: 6px;
    height: 6px;
  }
}