@charset "UTF-8";
/*:::::::::::::::::::::::::::::::
	option-service
    common.css
::::::::::::::::::::::::::::::::*/
body {
  font-size: var(--font-body);
}
main *,
:after,
:before {
  box-sizing: border-box;
}
img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}
:where(ul, ol, dl, dt, dd) {
  margin: 0;
  padding: 0;
  list-style: none;
}
:where(figure) {
  border: none;
  margin: 0;
}
:where(p) {
  line-height: 1.7;
}
:where(summary) {
  display: block;
  cursor: pointer;
}
:where(a, button) {
  text-decoration: none;
  opacity: 1;
  transition: opacity 0.4s ease;
}
@media (any-hover: hover) {
  a:hover,
  button:hover {
    text-decoration: none;
    opacity: 0.7;
    transition: all 0.4s ease;
  }
}
:root {
  /* 共通 font-family */
  --font-awesome: FontAwesome;

  /* 共通 width */
  --inner-base: min(95%, 1200px);
  --inner-wide: min(95%, 1800px);

  /* 共通 color */
  --color-point: #ff4f37;
  --color-white: #fff;
  --color-black: #333;
  --color-transparent: transparent;

  /* レスポンシブ-余白（Min 500px ～ Max 1200px）：var(--space-**)で呼び出せるように変数化 */
  --space-2xs: 0.3125rem;
  --space-xs: 0.625rem; /* 10px */
  --space-sm: clamp(1.15rem, 1.079rem + 0.23vw, 1.25rem); /* 20px */
  --space-md: clamp(1.25rem, 0.804rem + 1.43vw, 1.875rem);
  --space-slg: clamp(1.875rem, 0.982rem + 2.86vw, 3.125rem);
  --space-lg: clamp(2.5rem, 1.161rem + 4.29vw, 4.375rem);
  --space-2lg: clamp(4rem, 1.054rem + 9.43vw, 8.125rem);
  --space-minus-sm: calc(var(--space-sm) * -1);
  --space-minus-md: calc(var(--space-md) * -1);
  --space-minus-slg: calc(var(--space-slg) * -1);

  /* レスポンシブ-flex/grid gap：var(--global-gap)で呼び出せるように変数化
  もっと広げたい場合は calc(var(--global-gap) * 2)などで調整*/
  --global-gap: clamp(0.5rem, 1vw, 1rem);

  /* レスポンシブ-font（Min 500px ～ Max 1200px）：var(--font-**)で呼び出せるように変数化 */
  --font-xs: 0.625rem;
  --font-sm: clamp(0.688rem, 0.644rem + 0.14vw, 0.75rem);
  --font-body: 0.875rem;
  --font-base: clamp(0.875rem, 0.786rem + 0.29vw, 1rem);
  --font-md: clamp(0.88rem, 0.651rem + 0.73vw, 1.2rem);
  --font-slg: clamp(1.2rem, 0.914rem + 0.91vw, 1.6rem);
  --font-lg: clamp(1.3rem, 0.943rem + 1.14vw, 1.8rem);
  --font-xlg: clamp(2rem, 0.364rem + 5.45vw, 5rem);

  /* 大き目のline-height var(--lh-lg)で呼び出せるように変数化 */
  --lh-lg: 1.8;

  /* よく使う角丸 var(--radius-**)で呼び出せるように変数化 */
  --radius-md: 10px;
  --radius-lg: 20px;
  --radius-circle: 9999px;

  /* 共通 component 数値 */
  --cta-btn-size: min(90%, 25em);
  --pill-width: 15em;
}
/* common - layout
---------------------------------- */
.cmn_sp-only {
  display: none;
}
/* 2カラム */
.cmn_grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
/* 3カラム */
.cmn_grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}
.cmn_inner-base {
  width: var(--inner-base);
  margin-inline: auto;
}
.cmn_inner-wide {
  width: var(--inner-wide);
  margin-inline: auto;
}
/* common - heading
---------------------------------- */
/* h2 */
.cmn_title-section {
  margin-bottom: var(--space-slg);
  font-size: var(--font-lg);
  font-weight: 800;
  line-height: var(--lh-lg);
}
.cmn_title-section::after {
  --icon-width: 70px;
  --icon-height: 5px;
  content: "";
  display: block;
  width: var(--icon-width);
  height: var(--icon-height);
  margin-top: var(--space-sm);
  background: linear-gradient(to right, var(--color-main) 80%, var(--color-point) 20%);
}
/* h3・中サイズのメインカラーの見出し */
.cmn_title-sub {
  font-size: var(--font-slg);
  font-weight: 600;
  color: var(--color-main);
}
/* h4・少し大きいサイズのメインカラーのテキスト */
.cmn_text-emphasis {
  font-size: var(--font-md);
  font-weight: 600;
  color: var(--color-main);
}
/* h4・少し大きいサイズのポイントカラーのテキスト */
.cmn_text-emphasis-point {
  font-size: var(--font-md);
  font-weight: 600;
  color: var(--color-point);
}
/* common - button & link
---------------------------------- */
/* CTA */
.cmn_btn-cta {
  gap: var(--space-sm) calc(var(--global-gap) * 4);
}
.cmn_btn-cta-primary,
.cmn_btn-cta-secondary {
  display: block;
  width: var(--cta-btn-size);
  margin-top: var(--space-slg);
  padding-block: 1em;
  background-color: var(--color-point);
  border: solid 2px var(--color-point);
  border-radius: var(--radius-circle);
  font-size: var(--font-base);
  font-weight: 500;
  text-align: center;
  color: var(--color-white);
}
.cmn_btn-cta-secondary:hover {
  background-color: var(--color-white);
  color: var(--color-point);
  opacity: 1;
}
.cmn_btn-cta-primary {
  background-color: var(--color-white);
  color: var(--color-point);
}
.cmn_btn-cta-primary:hover {
  background-color: var(--color-point);
  color: var(--color-white);
  opacity: 1;
}
/* common - component
---------------------------------- */
/* オプションサービスタイトル部分 */
.cmn_page-header {
  padding-block: var(--space-lg) var(--space-slg);
}
.cmn_page-header-logo {
  width: clamp(180px, 36vw, 350px);
}
/* ぺージ内ナビ */
.cmn_page-link {
  padding-block: var(--space-xs);
  background-color: var(--color-main);
}
.cmn_page-link-list {
  --link-list-width: 1200px;
  width: var(--link-list-width);
  align-items: center;
}
.cmn_page-link-item {
  --list-columns: 9;
  flex-basis: calc(100% / var(--list-columns));
  text-align: center;
}
.cmn_page-link-item > a {
  color: var(--color-white);
}
.cmn_page-link-list .cmn_btn-cta {
  --cta-btn-size: 90%;
  margin-right: 0;
  margin-top: 0;
  padding-block: 0.5em;
}
.cmn_page-link-list .cmn_btn-cta:hover {
  color: var(--color-white);
}
/* 数字カウンター */
.cmn_counter-reset {
  counter-reset: section;
}
.cmn_counter-num::before {
  counter-increment: section;
  content: counter(section) ". ";
}
/* ✔マーク付きメインカラーの少し大きめ太字テキスト */
.cmn_check-mark {
  --check-mark-gap: 0.2em;
  margin-top: var(--space-sm);
  font-size: var(--font-base);
  font-weight: 600;
  text-align: left;
  color: var(--color-main);
}
.cmn_check-mark::before {
  content: url(../img/common/icon_check.webp);
  display: inline-block;
  margin-right: var(--check-mark-gap);
  vertical-align: middle;
  transform: scale(0.8);
}
/* ●マーク付きテキスト */
.cmn_circle-mark {
  --circle-mark-gap: 0.4em;
  --circle-mark-indent: 1.2em;
  padding-left: var(--circle-mark-indent);
  text-indent: calc(var(--circle-mark-indent) * -1);
  text-align: left;
}
.cmn_circle-mark::before {
  margin-right: var(--circle-mark-gap);
  content: "●";
  color: var(--color-sub);
}
/* ドーナツ大きい背景 */
.cmn_bg-donut {
  --donut-size: 90%;
  --donut-ring-width: 1500px;
  --donut-offset-x: -63%;
  position: relative;
  overflow: hidden;
}
.cmn_bg-donut::after {
  content: "";
  position: absolute;
  top: var(--space-slg);
  left: 50%;
  transform: translateX(var(--donut-offset-x));
  aspect-ratio: 1 / 1;
  height: var(--donut-size);
  border-radius: 50%;
  border: var(--donut-ring-width) solid var(--color-bg);
  pointer-events: none;
  z-index: -1;
}
/* 背景 ＋ 左端文字 ※親要素にposition:relative;必須 */
.cmn_bg-text {
  --bg-offset-y: -0.18em;
  position: absolute;
  left: 0;
  top: 0;
  transform: translateY(var(--bg-offset-y));
  font-size: var(--font-xlg);
  font-weight: 900;
  line-height: 1;
}
/* リストカード共通 */
:is(.cmn_card, .cmn_card-line, .cmn_card-bg) {
  padding: var(--space-md);
  border-radius: var(--radius-md);
  background-color: var(--color-white);
}
:where(.cmn_card, .cmn_card-line, .cmn_card-bg) {
  text-align: center;
}
/* 角丸の枠線リストカード */
.cmn_card-line {
  border: solid 1px var(--color-sub);
}
/* 背景付きリストカード */
.cmn_card-bg {
  padding-block: var(--space-xs);
  background-color: var(--color-bg);
}
/* 文字を囲うカプセル型装飾 */
.cmn_pill {
  display: inline-block;
  padding: 0.5em 2em;
  background-color: var(--color-main);
  border-radius: var(--radius-circle);
  text-align: center;
  font-weight: 500;
  color: var(--color-white);
}
/* 開閉アコーディオン */
.cmn_accordion {
  position: relative;
}
.cmn_accordion summary {
  position: relative;
  padding: 0.6em;
}
.cmn_accordion summary::after {
  position: absolute;
  top: 50%;
  right: var(--space-xs);
  transform: translateY(-50%);
  font-family: var(--font-awesome);
  content: "\f078";
  transition: transform 0.6s ease;
}
.cmn_accordion details[open] summary::after {
  transform: rotate(180deg) translateY(50%);
}
.cmn_accordion details[open] > :not(summary) {
  animation: accordion 0.6s ease;
}
@keyframes accordion {
  0% {
    opacity: 0;
    transform: translateY(-10px);
  }
  100% {
    opacity: 1;
    transform: none;
  }
}
/* common - space htmlへ直書き用
---------------------------------- */
/* margin */
.cmn_mt-xs {
  margin-top: var(--space-xs);
}
.cmn_mt-sm {
  margin-top: var(--space-sm);
}
.cmn_mt-md {
  margin-top: var(--space-md);
}
.cmn_mt-slg {
  margin-top: var(--space-slg);
}
.cmn_mt-lg {
  margin-top: var(--space-lg);
}
.cmn_mt-2lg {
  margin-top: var(--space-2lg);
}
/* padding */
.cmn_pt-xs {
  padding-top: var(--space-xs);
}
.cmn_pt-sm {
  padding-top: var(--space-sm);
}
.cmn_pt-md {
  padding-top: var(--space-md);
}
.cmn_pt-slg {
  padding-top: var(--space-slg);
}
.cmn_pt-lg {
  padding-top: var(--space-lg);
}
.cmn_pt-2lg {
  padding-top: var(--space-2lg);
}
/* gap */
.cmn_gap {
  gap: var(--global-gap);
}
/* common - color htmlへ直書き用
---------------------------------- */
.cmn_color-main {
  color: var(--color-main);
}
.cmn_color-sub {
  color: var(--color-sub);
}
.cmn_color-point {
  color: var(--color-point);
}
/* common - font htmlへ直書き用
---------------------------------- */
.cmn_font-sm {
  font-size: var(--font-sm);
}
.cmn_font-base {
  font-size: var(--font-base);
}
/* 対象カメラincludeの中身 - 上書きcss
---------------------------------- */
#MBproduct_content {
  padding-inline: 0;
}
#MBproduct_content .series_logo,
#MBproduct_content .recommend_only,
#MBproduct_content .MB-secula_area {
  display: none;
}
.MBproduct_list {
  justify-content: flex-start;
  gap: var(--global-gap);
}
.MBproduct_list li {
  --list--columns: 6;
  flex: 0 1 calc((100% / var(--list--columns)) - var(--global-gap));
  margin-bottom: 0;
  padding-block: var(--space-sm);
  background-color: var(--color-white);
  border: 0.2em solid var(--color-bg);
  border-radius: var(--radius-md);
}
.MBproduct_list li .link_list {
  width: 100%;
  margin-top: var(--space-sm);
  padding-inline: var(--space-xs);
  text-align: left;
}
.MBproduct_list li img {
  width: clamp(90px, 32vw, 160px);
}
.MBproduct_list li img.dome {
  max-width: 140px;
  padding: 10px 0;
}
.MBproduct_list li .link_list a {
  display: block;
  font-size: var(--font-sm);
}
.MBproduct_list li .link_list a:hover {
  text-decoration: underline;
}
.MBproduct_list li .link_list a:first-of-type {
  font-size: var(--font-md);
}
.MBproduct_list .link_list-note {
  display: inline-block;
}
/*
  768px～
:::::::::::::::::::::::::::::::::::::: */
@media (max-width: 768px) {
  .cmn_grid-3 {
    grid-template-columns: repeat(2, 1fr);
  }
  .cmn_page-link-list {
    --link-list-width: 98%;
  }
  /* 対象カメラincludeの中身 - 上書きcss
---------------------------------- */
  .MBproduct_list {
    justify-content: center;
  }
  .MBproduct_list li {
    --list--columns: 2;
  }
  .MBproduct_list li .link_list a {
    margin-bottom: var(--space-xs);
  }
}
/*
  500px～
:::::::::::::::::::::::::::::::::::::: */
@media (max-width: 500px) {
  .cmn_sp-only {
    display: block;
  }
  :is(.cmn_grid-2, .cmn_grid-3) {
    grid-template-columns: 1fr;
  }
  .cmn_bg-donut::after {
    top: var(--space-minus-md);
  }
  .cmn_page-link {
    padding-block: 0;
    background-color: transparent;
  }
  .cmn_page-link-list {
    --list-item-gap: 0.05em;
    --link-list-width: 100%;
    gap: var(--list-item-gap);
  }
  .cmn_page-link-item {
    --list-columns: 3;
    flex-basis: calc((100% / var(--list-columns)) - var(--list-item-gap));
    padding-block: var(--space-xs);
    background-color: var(--color-main);
  }
  .cmn_page-link-item:last-child {
    background-color: var(--color-point);
  }
  .cmn_page-link-list .cmn_btn-cta {
    padding-block: 0;
    border-radius: 0;
  }
  /* 対象カメラincludeの中身 - 上書きcss
---------------------------------- */
  .MBproduct_list {
    justify-content: flex-start;
  }
}

/*--------------------------------------------------------------------
  以前の subscription_block そのまま移植⇒申込更新後削除
:::::::::::::::::::::::::::::::::::::: */
.btn a {
  display: block;
  width: 100%;
  font-weight: 500;
  text-decoration: none;
}
.hover_switch {
  position: relative;
}
.hover_switch .icon {
  position: absolute;
  width: auto;
  height: auto;
}
.hover_switch:hover .icon:nth-of-type(2) {
  opacity: 0;
}
.list_deco li {
  margin-bottom: 7px;
  padding-left: 1em;
  text-indent: -1.3em;
}
.list_deco li::before {
  content: "●";
  padding-right: 7px;
  color: #b9c7db;
}
.text-indent {
  padding-left: 1em;
  text-indent: -1em;
}
.align-l {
  text-align: left !important;
}
/* 重要事項説明書 */
.subscription_block .list_deco li {
  margin-bottom: 20px;
}
.subscription_block .text-indent {
  margin-bottom: 10px;
}
.subscription_block .pdf_dw {
  margin: 50px 0;
  text-align: center;
}
.subscription_block .pdf_dw img {
  max-width: 25px;
  margin-right: 10px;
  vertical-align: bottom;
}
.subscription_block .pdf_dw a {
  font-size: 130%;
  font-weight: 600;
  color: #44546a;
  text-decoration: underline;
}
.subscription_block .pdf_dw a:hover {
  text-decoration: none;
}
/* お申込みリンク群 */
.subscription_links {
  text-align: center;
}
.subscription_links .flex_between {
  align-items: stretch;
}
.subscription_links dl {
  margin-bottom: 30px;
  padding: 30px 35px;
}
.subscription_links dt {
  margin-bottom: 25px;
  font-size: 150%;
  font-weight: 600;
}
.subscription_links dd small {
  display: block;
  margin-top: 10px;
}
.subscription_links .orange_link {
  background-color: #ffe1d3;
}
.subscription_links .orange_link .flex_between dd {
  flex: 0 0 48%;
  font-weight: 500;
}
.subscription_links .orange_link dt {
  color: #f1510c;
}
.subscription_links .orange_link dd .text {
  padding-left: 85px;
}
.subscription_links .orange_link dd small {
  font-weight: 400;
}
.subscription_links a {
  border-radius: 10px;
  color: #fff;
  text-decoration: none;
}
.subscription_links a p {
  font-size: 130%;
  line-height: 2;
  font-weight: 500;
}
.subscription_links a p small {
  font-size: 78%;
  font-weight: normal;
  line-height: 1.6;
}
.subscription_links .orange_link a {
  padding: 30px;
  background-color: #f1510c;
  border: solid 3px #f1510c;
}
.subscription_links .orange_link a:hover {
  background-color: #fff;
  color: #f1510c;
  opacity: 1;
}
.subscription_links .orange_link.frame_type {
  flex: 0 0 48%;
}
.subscription_links .orange_link.frame_type a {
  padding: 36px 28px;
  background-color: #fff;
  border: solid 3px #f1510c;
  font-weight: 600;
  font-size: 110%;
  color: #f1510c;
}
.subscription_links .orange_link.frame_type a:hover {
  background-color: #f1510c;
  color: #fff;
}
.subscription_links .navy_link {
  flex: 0 0 48%;
  padding-bottom: 15px;
  background-color: #dce4ef;
}
.subscription_links .navy_link dt {
  color: #44546a;
}
.subscription_links .navy_link dd {
  margin-bottom: 20px;
}
.subscription_links .navy_link a {
  padding: 19px 0;
  background-color: #44546a;
  border: solid 3px #44546a;
  font-size: 110%;
}
.subscription_links .navy_link a:hover {
  background-color: #fff;
  color: #44546a;
  opacity: 1;
}
.other_links {
  gap: 0 50px;
}
.other_links a {
  position: relative;
  max-width: 330px;
  margin: 20px 0;
  padding: 13px 0;
  border: solid 1px #44546a;
  border-radius: 25px;
  text-align: center;
  font-weight: 600;
  text-decoration: none;
  color: #44546a;
}
.other_links a::after {
  font-family: "FontAwesome";
  content: "\f105";
  position: absolute;
  right: 8px;
}
.other_links a:hover {
  background-color: #44546a;
  color: #fff;
  opacity: 1;
}
@media screen and (max-width: 480px) {
  .subscription_links .flex_between {
    display: block;
  }
  .subscription_links .orange_link a {
    padding: 20px;
    margin-bottom: 10px;
  }
  .subscription_links .orange_link dd .icon {
    max-height: 30px;
  }
  .subscription_links .orange_link dd .text {
    padding-left: 50px;
  }
}
