@charset "UTF-8";
/* --- Variables --- */
/* --- Table --- */
/* --- MV & CTA Parts Colors --- */
/*form*/
/* --- Breakpoints --- */
/* --- Mixins --- */
@keyframes shine-animation {
  0% {
    left: -100%;
  }
  20% {
    left: 150%;
  }
  100% {
    left: 150%;
  }
}
/*! destyle.css v4.0.1 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Remove default margin and padding */
* {
  margin: 0;
  padding: 0;
}

/* Lists (remove bullets) */
ul,
ol {
  list-style: none;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

/* Body setup */
body {
  min-height: 100vh;
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
}
body.is-fixed {
  overflow: hidden;
}

/* Images and Media */
img,
picture,
svg,
video,
canvas {
  display: block;
  max-width: 100%;
}

/* Audio and Video without controls */
audio:not([controls]) {
  display: none;
  height: 0;
}

/* Anchors (links) */
a {
  text-decoration: none;
  color: inherit;
}

/* Buttons and Inputs */
button,
input,
select,
textarea {
  background-color: transparent;
  border: none;
  border-radius: 0;
  outline: none;
  appearance: auto;
}

button {
  cursor: pointer;
  color: inherit;
}

/* Tables */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* Text adjustments */
fieldset {
  border: none;
}

/* Accessibility: Remove animations for people who prefer reduced motion */
@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
/* Utilities */
.l-container {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 20px;
}

@media (min-width: 1025px) {
  .u-hidden-pc {
    display: none !important;
  }
}

@media (max-width: 767px) {
  .u-hidden-sp {
    display: none !important;
  }
}

.u-text-blue {
  color: #292c61;
}

.u-text-bold {
  font-weight: 700;
}

.u-text-center {
  text-align: center;
}

/* Headings */
.c-heading-lv2 {
  font-size: 2rem;
  color: #292c61;
  text-align: center;
  margin-bottom: 40px;
  font-weight: 700;
}
@media (max-width: 767px) {
  .c-heading-lv2 {
    font-size: 1.5rem;
    margin-bottom: 24px;
  }
}

.c-heading-lv3 {
  font-size: 1.5rem;
  color: #333;
  text-align: center;
  margin-bottom: 30px;
  font-weight: 700;
}

/* Base */
/* --- Base --- */
body.is-fixed {
  overflow: hidden; /* ドロワー開閉時に背面固定 */
}

* {
  font-family: "Noto Sans JP", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", Arial, Helvetica, Verdana, sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}

/* --- link --- */
a {
  color: #2794c8;
  text-decoration: none;
  border-bottom: 1px solid #2794c8;
  transition: all 0.3s;
}
a:hover {
  color: #77afe0;
  border-bottom-color: transparent;
  opacity: 0.8;
}

/* --- Header & Hamburger --- */
.l-header {
  width: 100%;
  min-height: 100px;
  height: auto;
  display: flex;
  align-items: center;
  background: rgba(255, 255, 255, 0.5);
  backdrop-filter: blur(5px);
  transition: background-color 0.3s ease;
  border-top: 4px solid #1f5ba9;
  position: fixed;
  top: 0;
  z-index: 1000;
  padding: 0 0 0 20px;
}
@media (max-width: 767px) {
  .l-header {
    min-height: 64px;
  }
}
.l-header__inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-sizing: border-box;
}
.l-header__logo img {
  width: 400px;
  height: auto;
}
@media (max-width: 767px) {
  .l-header__logo img {
    width: 80%;
    height: auto;
  }
}
.l-header__actions {
  display: flex;
  gap: 10px;
}
.l-header__menu-trigger {
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  appearance: none;
  width: 40px;
  height: 40px;
  position: relative;
  cursor: pointer;
}
.l-header__menu-trigger span {
  position: absolute;
  right: 20px;
  width: 30px;
  height: 2px;
  background: #292c61;
  transition: 0.3s;
}
.l-header__menu-trigger span:nth-child(1) {
  top: 5px;
}
.l-header__menu-trigger span:nth-child(2) {
  opacity: 0;
}
.l-header__menu-trigger span:nth-child(3) {
  top: 17px;
}
.l-header__menu-trigger.is-active span:nth-child(1) {
  transform: translateY(6px) rotate(45deg);
}
.l-header__menu-trigger.is-active span:nth-child(2) {
  opacity: 0;
}
.l-header__menu-trigger.is-active span:nth-child(3) {
  transform: translateY(-6px) rotate(-45deg);
}
.l-header__menu-trigger small {
  position: absolute;
  bottom: 2px;
  right: 5px;
  transform: translateX(-50%);
  font-size: 10px;
  font-weight: bold;
  color: #292c61;
}

/* スクロール後 */
.l-header.is-scrolled {
  background: rgb(255, 255, 255);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

/* --- Drawer Menu --- */
.l-drawer {
  position: fixed;
  top: 60px;
  right: -100%;
  width: 100%;
  height: calc(100vh - 60px);
  background: #fff;
  transition: 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  padding: 40px 20px;
  overflow-y: auto;
  z-index: 999;
}
@media (min-width: 768px) and (max-width: 1024px) {
  .l-drawer {
    top: 94px;
  }
}
.l-drawer.is-active {
  right: 0;
}
.l-drawer__nav {
  list-style: none;
  padding: 0;
  margin: 0 0 40px;
}
.l-drawer__nav li {
  border-bottom: 1px solid #eee;
}
.l-drawer__nav li a {
  display: block;
  padding: 15px 10px;
  text-decoration: none;
  color: #333;
  font-weight: 700;
  transition: 0.3s;
}
.l-drawer__nav li a.is-current {
  color: #292c61;
  border-left: 4px solid #292c61;
  padding-left: 15px;
  background: #f9fbff;
}
.l-drawer__cta {
  display: flex;
  flex-direction: column;
  gap: 15px;
}
.l-drawer__cta .c-btn {
  width: 100%;
  justify-content: center;
}

/* ユーティリティ：デバイス別非表示 */
@media (min-width: 1025px) {
  .u-hidden-pc {
    display: none !important;
  }
}

@media (min-width: 768px) and (max-width: 1024px) {
  .u-hidden-tab {
    display: none !important;
  }
}

@media (max-width: 767px) {
  .u-hidden-sp {
    display: none !important;
  }
}

/* ユーティリティ：特定デバイスのみ表示 */
.u-visible-pc {
  display: none !important;
}
@media (min-width: 1025px) {
  .u-visible-pc {
    display: block !important;
  }
}

.u-visible-tab {
  display: none !important;
}
@media (min-width: 768px) and (max-width: 1024px) {
  .u-visible-tab {
    display: block !important;
  }
}

.u-visible-sp {
  display: none !important;
}
@media (max-width: 767px) {
  .u-visible-sp {
    display: block !important;
  }
}

.c-btn-header {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 50px;
  padding: 0 15px;
  border-radius: 6px;
  font-size: 14px;
  font-weight: bold;
  border: 2px solid #fff;
}
.c-btn-header::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 10px;
  margin-right: 8px;
  background-color: currentColor;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}
.c-btn-header--dl {
  background-color: #ddd;
  color: #333;
}
.c-btn-header--dl:hover {
  background: linear-gradient(90deg, #ffffff, #ebebeb);
  color: #292c61;
  border: 2px solid #fff;
  box-shadow: 0 0 10px 2px #fff;
}
.c-btn-header--dl::before {
  color: #292c61;
}
.c-btn-header--est {
  background-color: #dd7201;
  color: #fff;
}
.c-btn-header--est:hover {
  background: linear-gradient(90deg, #fcd595, #f1942a);
  color: #b35300;
  border: 2px solid #fff;
  box-shadow: 0 0 10px 2px #fff;
}
.c-btn-header--est:hover::before {
  color: #b35300;
}
.c-btn-header--est::before {
  color: #fcd595;
}

/* Hero */
.p-hero {
  background: url("../img/bg-noise-gray.jpg") repeat center center;
  background-color: #eef6fa; /* Fallback */
  margin: 0;
  padding: 0;
  /*text-align: center;*/
}
.p-hero__content {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
.p-hero__content-inner {
  width: 100%;
  max-width: 800px;
}
.p-hero__catch {
  margin-bottom: 23px;
}
.p-hero__catch-main {
  display: block;
  font-size: 2.5rem;
  font-weight: 900;
  color: #292c61;
}
@media (max-width: 767px) {
  .p-hero__catch-main {
    font-size: 2rem;
  }
}
.p-hero__catch-sub {
  display: block;
  font-size: 1.2rem;
  margin-top: 10px;
}
@media (max-width: 767px) {
  .p-hero__catch-sub {
    font-size: 1rem;
  }
}
.p-hero__lead {
  font-weight: 700;
  margin-bottom: 10px;
  text-align: center;
  font-size: 30px;
  color: #292c61;
}
@media (max-width: 767px) {
  .p-hero__lead {
    font-size: 14px;
  }
}
.p-hero__logo img {
  width: 340px;
  display: block;
  margin: 10px auto 13px auto;
}
@media (max-width: 767px) {
  .p-hero__logo img {
    width: 50%;
    margin: 10px 0 13px 25px;
  }
}
.p-hero__desc {
  margin-bottom: 40px;
  font-weight: 500;
  text-align: center;
  font-size: 21px;
}
@media (max-width: 767px) {
  .p-hero__desc {
    font-size: 15px;
    text-align: left;
    padding-left: 2rem;
    width: 60%;
    margin-bottom: 17px;
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .p-hero__desc {
    font-size: 20px;
    text-align: center;
    padding-left: 2rem;
    width: 100%;
    margin-bottom: 19px;
  }
}
.p-hero__photoPC {
  background-image: url("../img/bg-hero.jpg");
  background-repeat: no-repeat;
  background-position: top right;
  background-size: contain;
  padding: 10vh 0 6vh 0;
}
@media (max-width: 767px) {
  .p-hero__photoPC {
    background-size: 120%;
    background-position: 35% 65%;
    background-image: url("../img/bg-hero-sp.png");
    padding: 5.5vh 0 4vh 0;
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .p-hero__photoPC {
    background-size: 100%;
    background-position: 0% 65%;
    background-image: url("../img/bg-hero-tab.png");
    padding: 7.5vh 0 4vh 0;
  }
}

/*ひし形見出し*/
.mv-headline {
  position: relative;
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  padding: 50px 0px;
  overflow: hidden;
}
@media (max-width: 767px) {
  .mv-headline {
    padding: 40px 15px 15px 15px;
    width: 96%;
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .mv-headline {
    padding: 40px 15px 15px 15px;
    width: 96%;
  }
}
.mv-headline .headline-container {
  position: relative;
  max-width: 1000px;
  margin: 0 0 0 2vw;
  display: flex;
  justify-content: center;
}
.mv-headline .headline-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.95);
  transform: skewX(-15deg);
  z-index: 1;
  background-image: url("../img/bg-noise-circle.png");
  background-repeat: no-repeat;
  background-position: 125% 45%;
  background-size: 50%;
}
@media (max-width: 767px) {
  .mv-headline .headline-bg {
    transform: skewX(-5deg);
    background-position: 10% 50%;
    background-size: 250%;
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .mv-headline .headline-bg {
    transform: skewX(-7deg);
    background-position: 10% 50%;
    background-size: 250%;
  }
}
.mv-headline .headline-content {
  position: relative;
  z-index: 2;
  padding: 15px 20px 15px 25px;
  text-align: left;
}
@media (max-width: 767px) {
  .mv-headline .headline-content {
    padding: 15px;
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .mv-headline .headline-content {
    padding: 15px;
  }
}
.mv-headline .headline-content .main-copy {
  font-size: 57px;
  font-weight: 700;
  margin-bottom: 0px;
  line-height: 1.1;
}
@media (max-width: 767px) {
  .mv-headline .headline-content .main-copy {
    font-size: 33px;
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .mv-headline .headline-content .main-copy {
    font-size: 40px;
  }
}
.mv-headline .headline-content .main-copy .accent {
  color: #3a9372;
  display: inline-block;
  font-style: italic !important;
}
.mv-headline .headline-content .main-copy .accent-middle {
  font-size: 38px;
  display: inline-block;
  margin-right: 0.2rem;
  margin-left: 0.2rem;
  color: #292c61;
  font-style: italic !important;
}
@media (max-width: 767px) {
  .mv-headline .headline-content .main-copy .accent-middle {
    font-size: 24px;
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .mv-headline .headline-content .main-copy .accent-middle {
    font-size: 27px;
  }
}
.mv-headline .headline-content .main-copy .highlight {
  color: #292c61;
  white-space: nowrap;
  font-style: italic !important;
}
@media (max-width: 767px) {
  .mv-headline .headline-content .main-copy .highlight {
    display: block;
    text-align: right;
  }
}
.mv-headline .headline-content .sub-copy {
  font-size: 25px;
  font-weight: bold;
  color: #333;
  margin-top: 10px;
  font-style: italic !important;
}
@media (max-width: 767px) {
  .mv-headline .headline-content .sub-copy {
    display: block;
    text-align: right;
    font-size: 15px;
  }
}
.mv-headline .headline-content .sub-copy .sub-copy-accent {
  font-size: 38px;
  font-style: italic !important;
}
@media (max-width: 767px) {
  .mv-headline .headline-content .sub-copy .sub-copy-accent {
    font-size: 18px;
  }
}

/*mv-CTA*/
@keyframes shine-animation {
  0% {
    left: -100%;
  }
  20% {
    left: 150%;
  }
  100% {
    left: 150%;
  }
}
.cta-container {
  display: flex;
  gap: 20px;
  justify-content: center;
  align-items: center;
  flex-direction: row;
}
@media (max-width: 767px) {
  .cta-container {
    flex-direction: column;
    gap: 10px;
  }
}
.cta-container .btn {
  display: inline-flex;
  align-items: center;
  padding: 10px 35px 10px 25px;
  border-radius: 50px;
  font-size: 24px;
  font-weight: bold;
  text-decoration: none;
  color: #333;
  transition: transform 0.2s ease;
  border: 2px solid white;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
  font-style: italic;
}
.cta-container .btn img, .cta-container .btn .icon {
  width: 35px;
  margin-right: 10px;
}
@media (max-width: 767px) {
  .cta-container .btn {
    font-size: 18px;
    width: 80%;
    padding: 5px 25px 5px 30px;
  }
}
.cta-container .btn:hover {
  transform: translateY(-3px) scale(1.05);
  box-shadow: 0 6px 15px rgba(0, 0, 0, 0.1);
  opacity: 1 !important;
}
.cta-container .btn.btn-download {
  background-color: #ddd;
  position: relative;
  overflow: hidden;
}
.cta-container .btn.btn-download::after {
  content: "";
  position: absolute;
  top: -50%;
  left: -100%;
  width: 40%;
  height: 200%;
  background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.6) 50%, rgba(255, 255, 255, 0) 100%);
  transform: rotate(30deg);
  animation: shine-animation 4s infinite 0s;
}
.cta-container .btn.btn-estimate {
  background: linear-gradient(90deg, #fcd595, #f1942a);
  position: relative;
  overflow: hidden;
}
.cta-container .btn.btn-estimate::after {
  content: "";
  position: absolute;
  top: -50%;
  left: -100%;
  width: 40%;
  height: 200%;
  background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.6) 50%, rgba(255, 255, 255, 0) 100%);
  transform: rotate(30deg);
  animation: shine-animation 4s infinite 0.5s;
}

/* Utilities */
.l-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px;
  width: 100%;
}

@media (min-width: 1025px) {
  .u-hidden-pc {
    display: none !important;
  }
}

@media (max-width: 768px) {
  .u-hidden-sp {
    display: none !important;
  }
}
.u-text-blue {
  color: #292c61;
}

.u-text-bold {
  font-weight: 700;
}

.u-text-center {
  text-align: center;
}

/* Components */
.c-heading-lv2 {
  font-size: 35px;
  color: #333;
  text-align: center;
  font-weight: 700;
  background: url("../img/bg-tl-noise-circle.png") no-repeat center center;
  background-size: 10%;
  margin: 0 0 20px;
  padding: 30px 0;
}
@media (max-width: 767px) {
  .c-heading-lv2 {
    font-size: 20px;
    margin-bottom: 14px;
    padding: 6px 0;
    background-size: 15%;
  }
}

.c-heading-lv3 {
  text-align: center;
  padding: 20px 0;
}
@media (max-width: 767px) {
  .c-heading-lv3 {
    padding: 10px 0 0;
  }
}
.c-heading-lv3__text {
  font-size: 35px;
  font-weight: 700;
  color: #333;
  margin-bottom: 15px;
  letter-spacing: 0.05em;
}
@media (max-width: 767px) {
  .c-heading-lv3__text {
    font-size: 20px;
    margin-bottom: 7px;
  }
}
.c-heading-lv3::after {
  content: "";
  display: block;
  width: 40px;
  height: 4px;
  background-color: #77afe0;
  margin: 0 auto;
  border-radius: 2px;
}

.c-heading-lv4 {
  text-align: center;
  padding: 20px 0;
}
@media (max-width: 767px) {
  .c-heading-lv4 {
    padding: 10px 0 0;
  }
}
.c-heading-lv4__text {
  font-size: 35px;
  font-weight: 700;
  color: #1f5ba9;
  margin-bottom: 15px;
  letter-spacing: 0.05em;
}
@media (max-width: 767px) {
  .c-heading-lv4__text {
    font-size: 20px;
    margin-bottom: 7px;
  }
}
.c-heading-lv4::after {
  content: "";
  display: block;
  width: 40px;
  height: 4px;
  background-color: #77afe0;
  margin: 0 auto;
  border-radius: 2px;
}

.c-btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  height: 50px;
  padding: 0 30px;
  border-radius: 25px;
  font-weight: 700;
  font-size: 1rem;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1);
}
.c-btn--white {
  background: #fff;
  color: #292c61;
  border: 2px solid #292c61;
}
.c-btn--orange {
  background: linear-gradient(to bottom, #f3bb5b, #f39c12);
  color: #fff;
}
.c-btn--header-dl {
  background: #fff;
  color: #292c61;
  border: 1px solid #ccc;
  height: 40px;
  font-size: 0.9rem;
  margin-right: 10px;
}
.c-btn--header-est {
  background: #dd7201;
  color: #fff;
  height: 40px;
  font-size: 0.9rem;
}
.c-btn::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-right: 8px;
  background-size: contain;
  background-repeat: no-repeat;
}
.c-btn--icon-dl::before {
  background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg%20fill%3D%22%2323639e%22...%3C%2Fsvg%3E"); /* Placeholder for icon */
  background-color: #ccc; /* Icon placeholder */
}

.c-cta-group {
  display: flex;
  justify-content: center;
  gap: 20px;
  flex-direction: row;
  padding: 20px;
}
@media (max-width: 767px) {
  .c-cta-group {
    flex-direction: column;
    align-items: stretch;
    padding: 10px;
  }
}
.c-cta-group--col {
  gap: 20px;
}
@media (max-width: 767px) {
  .c-cta-group--col {
    gap: 10px;
  }
}

/* Section Common */
.p-section {
  padding: 30px 0 70px 0;
}
@media (max-width: 767px) {
  .p-section {
    padding: 20px 0 50px 0;
  }
}

/* Threats */
.p-threats {
  background: url("../img/bg-noise-blue.jpg") repeat center center;
  background-size: 10%;
}
.p-threats__grid {
  display: flex;
  gap: 50px;
}
@media (max-width: 767px) {
  .p-threats__grid {
    flex-direction: column;
    gap: 25px;
  }
}
.p-threats__item {
  background: #fff;
  padding: 30px;
  flex: 1;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);
}
@media (max-width: 767px) {
  .p-threats__item {
    padding: 12px 18px;
  }
}
.p-threats__title {
  font-size: 19px;
  margin-bottom: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  color: #292c61;
  font-weight: bold;
  flex-wrap: wrap;
}
@media (max-width: 767px) {
  .p-threats__title {
    font-size: 13px;
  }
}
.p-threats__title .u-icon-warn {
  width: 35px;
  height: auto;
}
@media (max-width: 767px) {
  .p-threats__title .u-icon-warn {
    width: 20px;
    height: auto;
  }
}
.p-threats__title .u-text-bold {
  font-size: 24px;
  display: inline-block;
  margin-bottom: 3px;
}
@media (max-width: 767px) {
  .p-threats__title .u-text-bold {
    font-size: 17px;
    margin-bottom: 2px;
  }
}
.p-threats__text {
  font-size: 18px;
}
@media (max-width: 767px) {
  .p-threats__text {
    font-size: 13px;
  }
}
.p-threats__img {
  margin-bottom: 15px;
}
.p-threats__img img {
  width: 100%;
}

/* Worries */
.p-worries__list {
  display: flex;
  flex-direction: column;
  gap: 50px;
}
@media (max-width: 767px) {
  .p-worries__list {
    gap: 30px;
  }
}
.p-worries__item {
  display: flex;
  align-items: center;
  gap: 40px;
  flex-direction: row-reverse;
}
@media (max-width: 767px) {
  .p-worries__item {
    flex-direction: column-reverse;
    gap: 10px;
    padding: 15px;
    background: #f5f5f5;
    box-shadow: 0 10px 15px -10px rgba(0, 0, 0, 0.1);
    border: 2px solid #ddd;
  }
}
.p-worries__text-area {
  flex: 1.6;
  font-size: 18px;
}
@media (max-width: 767px) {
  .p-worries__text-area {
    font-size: 14px;
    width: 100%;
  }
}
.p-worries__img {
  flex: 1;
}
.p-worries__title {
  font-size: 25px;
  color: #292c61;
  margin: 0 0 10px;
  font-style: italic;
  font-weight: bold;
  border-bottom: 6px solid #d6edf8;
}
@media (max-width: 767px) {
  .p-worries__title {
    font-size: 19px;
    text-align: center;
    border-bottom: 4px solid #d6edf8;
  }
}

.c-list-dot li {
  position: relative;
  padding-left: 0.8em;
  margin-bottom: 0.5em;
  font-size: 18px;
}
@media (max-width: 767px) {
  .c-list-dot li {
    font-size: 14px;
  }
}
.c-list-dot li::before {
  content: "•";
  position: absolute;
  left: 0;
  color: #666;
}

/*対策の有無テーブル*/
.worries-table {
  font-size: 18px;
  /* 対策あり行 */
  /* 対策なし行の強調スタイル */
  /* --- レスポンシブ対応 --- */
  /*ファイアウォールのテーブル*/
}
@media (max-width: 767px) {
  .worries-table {
    font-size: 14px;
  }
}
.worries-table .table-container {
  width: 100%;
  margin: 60px 0 0;
  border-collapse: collapse;
  border: 1px solid #ddd;
}
@media (max-width: 767px) {
  .worries-table .table-container {
    margin: 30px 0 0;
  }
}
.worries-table .table-header {
  display: grid;
  grid-template-columns: 1.15fr 1.5fr 1.1fr;
  background-color: #292c61;
  color: white;
  font-weight: bold;
  text-align: center;
}
.worries-table .table-header div {
  padding: 15px;
  border-right: 1px solid rgba(255, 255, 255, 0.2);
}
.worries-table .table-row {
  display: grid;
  grid-template-columns: 1.15fr 1.5fr 1.1fr;
  border-bottom: 1px solid #ddd;
}
.worries-table .row-safe {
  background-color: #fff;
}
.worries-table .safe-title {
  font-size: 20px;
  white-space: nowrap;
  padding-top: 10px;
}
@media (min-width: 768px) and (max-width: 1024px) {
  .worries-table .safe-title {
    white-space: normal;
  }
}
.worries-table .safe-title img {
  width: 85px;
  height: auto;
  display: inline;
  vertical-align: middle;
  margin: -10px 5px 0 0;
}
@media (min-width: 768px) and (max-width: 1024px) {
  .worries-table .safe-title img {
    width: 45px;
  }
}
.worries-table .row-risk {
  background-color: #f5f5f5;
  color: #670000;
}
.worries-table .lisk-title {
  font-size: 20px;
  white-space: nowrap;
  padding-top: 10px;
}
.worries-table .lisk-title img {
  width: 85px;
  height: auto;
  display: inline;
  vertical-align: middle;
  margin: -10px 5px 0 0;
}
@media (min-width: 768px) and (max-width: 1024px) {
  .worries-table .lisk-title img {
    width: 45px;
  }
}
.worries-table .table-cell {
  padding: 20px;
  border-right: 1px solid #ddd;
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
}
.worries-table .table-cell:last-child {
  border-right: none;
}
.worries-table .status-cell {
  align-items: center;
  text-align: center;
  font-weight: bold;
}
.worries-table .status-icon img {
  width: 80px;
  height: auto;
  margin-right: 10px;
}
.worries-table .effect-list {
  margin: 0;
  padding-left: 20px;
  list-style-type: "・";
}
.worries-table .effect-list li {
  padding-left: 5px;
  margin-bottom: 5px;
}
@media (max-width: 767px) {
  .worries-table {
    /* ラベルの色分け */
  }
  .worries-table .table-container {
    border: 1px solid #fff;
  }
  .worries-table .table-header {
    display: none;
  }
  .worries-table .table-row {
    display: block;
    margin-bottom: 25px;
  }
  .worries-table .row-safe {
    border: 2px solid #292c61;
    background: #d6edf8;
  }
  .worries-table .row-risk {
    border: 2px solid #dd7201;
    background: #f5f5f5;
  }
  .worries-table .safe-title {
    font-size: 17px;
    white-space: nowrap;
    padding-top: 10px;
  }
  .worries-table .safe-title img {
    width: 55px;
    height: auto;
    display: inline;
    vertical-align: middle;
    margin: -10px 5px 0 0;
  }
  .worries-table .lisk-title {
    font-size: 17px;
    white-space: nowrap;
    padding-top: 10px;
  }
  .worries-table .lisk-title img {
    width: 55px;
    height: auto;
    display: inline;
    vertical-align: middle;
    margin: -10px 5px 0 0;
  }
  .worries-table .table-cell {
    border-right: none;
    border-bottom: 1px solid #ccc;
    flex-direction: column;
    padding-bottom: 8px;
  }
  .worries-table .status-cell::before {
    content: attr(data-label) !important;
    background: #292c61 !important;
    color: #fff !important;
    border-radius: 20px !important;
    width: 100% !important;
    font-size: 15px !important;
    padding: 4px 10px !important;
    border: 0 !important;
  }
  .worries-table .table-cell::before {
    content: attr(data-label);
    font-weight: bold;
    font-size: 14px;
    padding: 4px 10px;
    margin-bottom: 8px;
    display: block;
    background: #fff;
    border-radius: 5px;
    border: 1px solid #ccc;
  }
  .worries-table .row-safe .table-cell::before {
    color: #292c61;
  }
  .worries-table .row-risk .table-cell::before {
    color: #670000;
  }
}
.worries-table .syubihani, .worries-table .img-sample {
  display: block;
}
.worries-table .img-sample img {
  margin-top: 10px;
}

/* CTA Banner */
.p-cta-banner {
  /*background: linear-gradient(135deg, $c-secondary, $c-primary);*/
  background: url("../img/bg-cta-middle.png") no-repeat center center;
  background-size: 100%;
  background-size: cover;
  color: #fff;
  padding: 50px 0;
  text-align: center;
}
@media (max-width: 767px) {
  .p-cta-banner {
    padding: 30px 0;
  }
}
.p-cta-banner__text {
  font-size: 30px;
  margin-bottom: 30px;
  font-weight: 500;
  font-style: italic;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
}
@media (max-width: 767px) {
  .p-cta-banner__text {
    font-size: 16px;
    margin-bottom: 15px;
  }
}

.p-cta-banner-end {
  background: url("../img/bg-cta-end.png") no-repeat center center !important;
}
.p-cta-banner-end__text-large {
  font-size: 40px;
}
@media (max-width: 767px) {
  .p-cta-banner-end__text-large {
    font-size: 20px;
  }
}
.p-cta-banner-end .cta-btn-box p {
  color: #333;
}

/* What is */
.p-whatis__lead {
  font-size: 18px;
  padding: 0;
}
.p-whatis__lead strong {
  font-weight: bold;
  color: #292c61;
}
@media (max-width: 767px) {
  .p-whatis__lead {
    font-size: 14px;
  }
}
.p-whatis__diagram {
  margin: 40px 0 70px 0;
  text-align: center;
}
@media (max-width: 767px) {
  .p-whatis__diagram {
    margin: 20px 0;
  }
}
.p-whatis__diagram img {
  width: 90%;
  display: inline;
}
@media (max-width: 767px) {
  .p-whatis__diagram img {
    width: 100%;
  }
}
.p-whatis__diagram img.diagram-pinchout {
  display: none;
}
@media (max-width: 767px) {
  .p-whatis__diagram img.diagram-pinchout {
    display: block;
    width: 55%;
    height: auto;
    margin: 0 auto 0 auto;
  }
}

.p-merit-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 767px) {
  .p-merit-grid {
    grid-template-columns: 1fr;
  }
}

.p-merit-box {
  background: #f5f5f5;
  padding: 10px;
  text-align: center;
  border-radius: 8px;
  border: 2px solid #e3e3e3;
}
@media (max-width: 767px) {
  .p-merit-box {
    display: flex;
    flex-direction: row;
    text-align: left;
  }
}
.p-merit-box__icon img {
  width: 120px;
  height: auto;
  display: inline;
}
@media (max-width: 767px) {
  .p-merit-box__icon img {
    width: 80px;
    margin-right: 5px;
  }
}
.p-merit-box__text {
  font-size: 17px;
  line-height: 1.5;
  margin-bottom: 10px;
}
@media (max-width: 767px) {
  .p-merit-box__text {
    font-size: 14px;
    margin-bottom: 0px;
  }
}
.p-merit-box__text strong {
  color: #292c61;
  font-weight: bold;
  font-size: 20px;
  display: inline-block;
  margin-bottom: 10px;
}
@media (max-width: 767px) {
  .p-merit-box__text strong {
    font-size: 16px;
    margin-bottom: 5px;
  }
}

.p-firewall {
  padding-top: 0 !important;
}
.p-firewall__lead {
  font-size: 18px;
  padding: 0;
}
.p-firewall__lead strong {
  font-weight: bold;
  color: #292c61;
}
@media (max-width: 767px) {
  .p-firewall__lead {
    font-size: 14px;
  }
}
.p-firewall__note {
  font-size: 18px;
  padding: 15px 0 0;
}
.p-firewall__note strong {
  font-weight: bold;
  color: #292c61;
}
@media (max-width: 767px) {
  .p-firewall__note {
    font-size: 14px;
    padding: 5px 0 0;
  }
}

/* WAF vs Firewall */
.p-fw-compare {
  display: flex;
  border: 2px solid #292c61;
  border-radius: 8px;
  overflow: hidden;
  margin: 40px 0;
}
@media (max-width: 767px) {
  .p-fw-compare {
    flex-direction: column;
  }
}
.p-fw-compare__col {
  flex: 1;
}
.p-fw-compare__col--waf {
  border-right: 2px solid #292c61;
}
@media (max-width: 767px) {
  .p-fw-compare__col--waf {
    border-right: none;
    border-bottom: 2px solid #292c61;
  }
}
.p-fw-compare__col--fw {
  background: #f9f9f9;
}
.p-fw-compare__col--fw .p-fw-compare__head {
  background: #666;
}
.p-fw-compare__head {
  background: #292c61;
  color: #fff;
  text-align: center;
  padding: 10px;
  font-weight: 700;
  font-size: 1.2rem;
}
.p-fw-compare__body {
  padding: 20px;
}
.p-fw-compare__body dl {
  margin-bottom: 20px;
}
.p-fw-compare__body dl dt {
  font-weight: 700;
  margin-bottom: 5px;
  color: #292c61;
  border-left: 4px solid #292c61;
  padding-left: 10px;
}
.p-fw-compare__body dl dd {
  margin-bottom: 15px;
  font-size: 0.9rem;
  padding-left: 14px;
}
.p-fw-compare__img {
  text-align: center;
}
.p-fw-compare__img img {
  border-radius: 4px;
}

/*なぜScutumなのか*/
.p-reason {
  background-image: url("../img/bg-noise-circle.png");
  background-repeat: no-repeat;
  background-position: 80% 0%;
  background-size: 50%;
  background-color: #d6edf8;
  /*見出し*/
  /*見出し下のアイキャッチ-ビジネスマン*/
}
.p-reason__lead {
  font-size: 18px;
  padding: 0;
}
.p-reason__lead strong {
  font-weight: bold;
  color: #292c61;
}
@media (max-width: 767px) {
  .p-reason__lead {
    font-size: 14px;
  }
}
.p-reason .section-catch {
  width: 100%;
  padding: 30px 0px 30px 0;
  text-align: center;
}
@media (max-width: 767px) {
  .p-reason .section-catch {
    padding: 10px 0px 15px 0;
  }
}
@media (max-width: 767px) {
  .p-reason .section-catch .catch-content {
    text-align: center;
  }
}
.p-reason .section-catch .catch-sub {
  font-size: 22px;
  font-weight: 700;
  color: #333;
  margin-bottom: 10px;
  letter-spacing: 0.05em;
}
@media (max-width: 767px) {
  .p-reason .section-catch .catch-sub {
    font-size: 17px;
  }
}
.p-reason .section-catch .catch-main {
  display: flex;
  flex-direction: row;
  justify-content: center;
  gap: 5px;
  font-size: 40px;
  font-weight: bold;
  color: #1f5ba9;
  margin: 0;
}
@media (max-width: 767px) {
  .p-reason .section-catch .catch-main {
    font-size: 25px;
  }
}
.p-reason .section-catch .catch-main::before {
  content: "";
  display: inline-block;
  width: 60px;
  height: 60px;
  background: url("../img/ico/ico-shield.svg") no-repeat center/contain;
}
@media (max-width: 767px) {
  .p-reason .section-catch .catch-main::before {
    width: 40px;
    height: 40px;
  }
}
.p-reason .problem-solution {
  max-width: 1000px;
  margin: 0 auto;
  font-family: "sans-serif";
}
.p-reason .problem-solution .problem-container {
  display: grid;
  grid-template-columns: 1fr 300px;
  align-items: center;
  padding: 20px;
  background-color: #fff;
}
@media (max-width: 767px) {
  .p-reason .problem-solution .problem-container {
    grid-template-columns: 1fr;
  }
}
.p-reason .problem-solution .problem-text h3 {
  color: #333;
  font-size: 22px;
  margin-bottom: 20px;
  font-weight: bold;
}
@media (max-width: 767px) {
  .p-reason .problem-solution .problem-text h3 {
    font-size: 18px;
    margin-bottom: 10px;
  }
}
.p-reason .problem-solution .problem-text ul {
  list-style: none;
  padding: 0;
}
@media (max-width: 767px) {
  .p-reason .problem-solution .problem-text ul {
    margin-bottom: 10px;
  }
}
.p-reason .problem-solution .problem-text ul li {
  position: relative;
  padding-left: 18px;
  margin-bottom: 5px;
  color: #555;
  font-size: 18px;
}
@media (max-width: 767px) {
  .p-reason .problem-solution .problem-text ul li {
    font-size: 16px;
  }
}
.p-reason .problem-solution .problem-text ul li::before {
  content: "・";
  color: #666;
  position: absolute;
  left: 0;
  font-size: 18px;
}
.p-reason .problem-solution .problem-image img {
  width: 100%;
  height: auto;
}
.p-reason .problem-solution .solution-banner {
  background: linear-gradient(180deg, #41aee6 0%, #6cb1d8 100%);
  color: #fff;
  padding: 30px 0;
  position: relative;
  text-align: center;
}
@media (max-width: 767px) {
  .p-reason .problem-solution .solution-banner {
    padding: 14px 0;
  }
}
.p-reason .problem-solution .solution-banner::after {
  content: "";
  position: absolute;
  top: -1px;
  left: 50%;
  transform: translateX(-50%);
  border-left: 25px solid transparent;
  border-right: 25px solid transparent;
  border-top: 20px solid #fff;
  z-index: 10;
}
.p-reason .problem-solution .solution-content {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 15px;
}
@media (max-width: 767px) {
  .p-reason .problem-solution .solution-content {
    flex-direction: column;
    gap: 5px;
  }
}
.p-reason .problem-solution .solution-content .logo {
  width: 25%;
  height: auto;
  margin-bottom: 10px;
}
@media (max-width: 767px) {
  .p-reason .problem-solution .solution-content .logo {
    width: 70%;
    margin-bottom: 0px;
  }
}
.p-reason .problem-solution .solution-content .catchphrase {
  font-size: 32px;
  font-weight: bold;
  margin: 0;
}
@media (max-width: 767px) {
  .p-reason .problem-solution .solution-content .catchphrase {
    font-size: 27px;
  }
}

/*実績*/
.casestudy {
  background-image: none;
}
.casestudy__lead {
  margin-bottom: 5px;
  font-size: 18px;
}
.casestudy__lead strong {
  font-weight: bold;
  font-size: 22px;
}
@media (max-width: 767px) {
  .casestudy__lead strong {
    font-size: 14px;
  }
}
@media (max-width: 767px) {
  .casestudy__lead {
    font-size: 17px;
  }
}
.casestudy__photo {
  display: block;
  margin: 25px 0 0;
}
.casestudy .results {
  margin-bottom: 50px;
  box-shadow: 0 10px 15px -10px rgba(0, 0, 0, 0.1);
}
@media (max-width: 767px) {
  .casestudy .results {
    margin-bottom: 25px;
  }
}
.casestudy .results__card {
  margin: 0 auto;
  background: #fff;
  border-radius: 8px; /* 角丸 */
  margin-top: 40px;
  padding: 30px;
  border: 2px solid #ddd;
}
@media (max-width: 767px) {
  .casestudy .results__card {
    padding: 12px 20px 16px 20px;
  }
}
.casestudy .results__card-inner {
  display: flex;
  align-items: flex-start;
  gap: 30px;
}
@media (max-width: 767px) {
  .casestudy .results__card-inner {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 15px;
  }
}
.casestudy .results__badge {
  flex-shrink: 0;
  width: 130px;
  height: auto;
}
@media (max-width: 767px) {
  .casestudy .results__badge {
    width: 70px;
    height: auto;
  }
}
.casestudy .results__list {
  margin: 0;
}
.casestudy .results__item {
  margin-bottom: 20px;
}
.casestudy .results__item:last-child {
  margin-bottom: 0;
}
.casestudy .results__item dt {
  font-weight: bold;
  color: #1f5ba9;
  margin-bottom: 4px;
  font-size: 18px;
}
@media (max-width: 767px) {
  .casestudy .results__item dt {
    font-size: 15px;
  }
}
.casestudy .results__item dd {
  margin-left: 0;
  font-size: 16px;
  color: #333;
  line-height: 1.6;
}
@media (max-width: 767px) {
  .casestudy .results__item dd {
    text-align: left;
    font-size: 14px;
  }
}

/*圧倒的な検知性能（高度なAI型WAFエンジン）～運用・管理の負担軽減*/
.p-feature {
  padding: 50px 0;
}
@media (max-width: 767px) {
  .p-feature {
    padding: 30px 0;
  }
}
.p-feature__lead ul {
  list-style: none;
  padding: 0;
}
@media (max-width: 767px) {
  .p-feature__lead ul {
    padding: 15px 0;
  }
}
.p-feature__lead ul li {
  position: relative;
  padding-left: 18px;
  margin-bottom: 5px;
  font-size: 18px;
}
.p-feature__lead ul li strong {
  font-weight: bold;
  font-size: 22px;
}
@media (max-width: 767px) {
  .p-feature__lead ul li strong {
    font-size: 14px;
  }
}
@media (max-width: 767px) {
  .p-feature__lead ul li {
    font-size: 17px;
  }
}
.p-feature__lead ul li::before {
  content: "・";
  color: #666;
  position: absolute;
  left: 0;
  font-size: 20px;
}
@media (max-width: 767px) {
  .p-feature__lead ul li::before {
    font-size: 17px;
  }
}
.p-feature__graph {
  background: #fff;
  border: 2px solid #ccc;
  margin: 40px 0;
}
@media (max-width: 767px) {
  .p-feature__graph {
    margin: 12px 0 40px 0;
  }
}
.p-feature__graph-title {
  background: #1f5ba9;
  padding: 12px;
  text-align: center;
  font-weight: bold;
  color: #fff;
  font-size: 20px;
}
@media (max-width: 767px) {
  .p-feature__graph-title {
    font-size: 15px;
  }
}
.p-feature__graph-content {
  padding: 12px 24px;
  font-size: 17px;
}
@media (max-width: 767px) {
  .p-feature__graph-content {
    padding: 6px 12px;
    font-size: 14px;
  }
}
.p-feature__graph-sub-title {
  color: #1f5ba9;
  font-weight: bold;
  font-size: 20px;
  padding-bottom: 7px;
  border-bottom: 3px solid #e7e7e7;
}
@media (max-width: 767px) {
  .p-feature__graph-sub-title {
    font-size: 17px;
  }
}
.p-feature__graph-sub-text {
  color: #555;
  padding: 15px 0;
}
.p-feature__graph-note {
  padding: 5px;
  font-size: 13px;
  text-align: right;
}
@media (max-width: 767px) {
  .p-feature__graph-note {
    font-size: 11px;
  }
}
.p-feature__grid4 {
  padding-top: 35px;
  margin-bottom: 50px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
@media (max-width: 767px) {
  .p-feature__grid4 {
    grid-template-columns: 1fr;
    padding-top: 5px;
    margin-bottom: 25px;
    gap: 10px;
  }
}
.p-feature__grid4 .p-card-icon {
  background: #fff;
  padding: 10px;
  border-radius: 8px;
  border: 2px solid #e3e3e3;
  display: flex;
}
@media (max-width: 767px) {
  .p-feature__grid4 .p-card-icon {
    display: flex;
    flex-direction: row;
  }
}
.p-feature__grid4 .p-card-icon__icon-image {
  width: 100px;
  height: auto;
  margin-right: 5px;
}
@media (max-width: 767px) {
  .p-feature__grid4 .p-card-icon__icon-image {
    width: 80px;
  }
}
.p-feature__grid4 .p-card-icon__text {
  font-size: 17px;
  line-height: 1.5;
  margin-bottom: 10px;
}
@media (max-width: 767px) {
  .p-feature__grid4 .p-card-icon__text {
    font-size: 14px;
    margin-bottom: 0px;
  }
}
.p-feature__grid4 .p-card-icon__text strong {
  color: #292c61;
  font-weight: bold;
  font-size: 20px;
  display: inline-block;
  margin-top: 10px;
  margin-bottom: 5px;
}
@media (max-width: 767px) {
  .p-feature__grid4 .p-card-icon__text strong {
    font-size: 16px;
    margin-bottom: 5px;
  }
}

/* Pricing / Campaign */
.p-pricing {
  background: #d6edf8;
  text-align: center;
  position: relative;
}
.p-pricing__top-title {
  color: #fff;
  font-size: 30px;
  margin-bottom: 30px;
  position: absolute;
  top: -35px;
  left: 50%;
  transform: translateX(-50%);
  font-weight: bold;
  background: #1f5ba9;
  padding: 8px 40px;
  white-space: nowrap;
}
@media (max-width: 767px) {
  .p-pricing__top-title {
    font-size: 20px;
    padding: 8px 25px;
    top: -25px;
  }
}
.p-pricing__box {
  background: #fff;
  padding: 50px 30px;
  box-shadow: 0 5px 20px rgba(0, 0, 0, 0.05);
}
@media (max-width: 767px) {
  .p-pricing__box {
    padding: 40px 15px 15px;
  }
}
.p-pricing__lead {
  background: #f5f5f5;
  padding: 10px;
  color: #1f5ba9;
  font-weight: 600;
  font-size: 20px;
}
@media (max-width: 767px) {
  .p-pricing__lead {
    font-size: 14px;
  }
}
.p-pricing__lead strong {
  font-size: 32px;
}
@media (max-width: 767px) {
  .p-pricing__lead strong {
    font-size: 20px;
  }
}

.p-campaign {
  background: #fdf2dc;
  border: 3px solid #f7d9be;
  padding: 0px;
  margin: 40px 0;
}
@media (max-width: 767px) {
  .p-campaign {
    margin: 20px 0;
  }
}
.p-campaign__head {
  background: #fbe3b4 url("../img/bg-campaign.jpg") no-repeat top left;
  background-size: contain;
  padding: 20px;
}
@media (max-width: 767px) {
  .p-campaign__head {
    background-size: cover;
  }
}
.p-campaign__sub-title {
  font-size: 23px;
  margin-bottom: 18px;
  font-weight: bold;
}
@media (max-width: 767px) {
  .p-campaign__sub-title {
    font-size: 16px;
    margin-bottom: 10px;
  }
}
.p-campaign__title {
  color: #bc610f;
  font-weight: bold;
}
.p-campaign__title strong {
  display: inline-block;
  border: 2px solid #bc610f;
  background: #fff;
  padding: 10px 20px;
  margin-right: 15px;
  font-size: 46px;
}
@media (max-width: 767px) {
  .p-campaign__title strong {
    padding: 5px 10px;
    font-size: 24px;
    display: block;
  }
}
.p-campaign__title span {
  font-size: 46px;
}
@media (max-width: 767px) {
  .p-campaign__title span {
    font-size: 21px;
  }
}

.price-sub-title {
  display: inline-block;
  font-weight: bold;
  font-size: 22px;
  padding: 0 6px 6px;
  margin-bottom: 10px;
  border-bottom: 5px solid #fad48c;
}
@media (max-width: 767px) {
  .price-sub-title {
    font-size: 18px;
  }
}

.price-sub-text {
  font-size: 18px;
  padding: 4px 4px 14px;
}
@media (max-width: 767px) {
  .price-sub-text {
    font-size: 14px;
  }
}

@media (min-width: 768px) and (max-width: 1024px) {
  .p-table-wrap {
    padding-top: 30px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}
@media (max-width: 767px) {
  .p-table-wrap {
    padding-top: 30px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}

.c-compare-table {
  width: 100%;
  min-width: 900px;
  border-collapse: collapse;
  /* Last row active border fix */
}
.c-compare-table__logo {
  width: 250px;
  height: auto;
  margin: 0 auto;
}
@media (max-width: 767px) {
  .c-compare-table__logo {
    width: 110px;
  }
}
.c-compare-table__logo img {
  margin: 0 50px;
}
@media (max-width: 767px) {
  .c-compare-table__logo img {
    margin: 0;
  }
}
.c-compare-table th, .c-compare-table td {
  border: 1px solid #ccc;
  padding: 15px;
  text-align: center;
  vertical-align: middle;
  background-color: #fff;
  font-size: 18px;
}
@media (max-width: 767px) {
  .c-compare-table th, .c-compare-table td {
    font-size: 14px;
  }
}
.c-compare-table thead th {
  background: #f0f0f0;
}
.c-compare-table thead th.is-active {
  background: #fff;
  border-top: 8px solid #2794c8;
  border-left: 8px solid #2794c8;
  border-right: 8px solid #2794c8;
  position: relative;
}
.c-compare-table thead th .c-icon-label {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  gap: 10px;
}
.c-compare-table thead th .c-icon-label__icon {
  flex-shrink: 0;
  width: 50px;
  height: auto;
}
.c-compare-table thead th .c-icon-label__text {
  text-align: left;
  font-size: 17px;
  font-weight: bold;
  color: #444;
}
@media (max-width: 767px) {
  .c-compare-table thead th .c-icon-label__text {
    font-size: 14px;
  }
}
.c-compare-table .c-compare-thead-title {
  background: #1f5ba9;
  color: #fff;
}
.c-compare-table tbody th {
  background: #ACCAF6;
  color: #1f5ba9;
  font-weight: 700;
  width: 200px;
}
@media (max-width: 767px) {
  .c-compare-table tbody th {
    width: auto;
  }
}
.c-compare-table tbody td {
  text-align: left;
  font-size: 16px;
}
@media (max-width: 767px) {
  .c-compare-table tbody td {
    font-size: 13px;
  }
}
.c-compare-table tbody td.is-active {
  background: #fdfdfd;
  border-left: 8px solid #2794c8;
  border-right: 8px solid #2794c8;
  color: #333;
  font-weight: 700;
}
.c-compare-table tbody .ico-mark {
  flex-shrink: 0;
  width: 60px;
  height: auto;
  display: block;
  padding: 0;
  margin: 0 auto 5px auto;
}
@media (max-width: 767px) {
  .c-compare-table tbody .ico-mark {
    width: 40px;
  }
}
.c-compare-table tbody .ico-mark-double {
  flex-shrink: 0;
  width: 140px;
  height: auto;
  display: block;
  padding: 0;
  margin: 0 auto 5px auto;
}
@media (max-width: 767px) {
  .c-compare-table tbody .ico-mark-double {
    width: 80px;
  }
}
.c-compare-table tbody tr:last-child td.is-active {
  border-bottom: 8px solid #2794c8;
}
.c-compare-table .u-mark-circle {
  color: red;
  font-size: 1.5rem;
}
.c-compare-table .u-mark-triangle {
  color: orange;
  font-size: 1.5rem;
}
.c-compare-table .u-mark-cross {
  color: blue;
  font-size: 1.5rem;
}

/* Footer */
.l-footer {
  background: linear-gradient(90deg, #2c89c5, #214187);
  padding: 40px 0 20px;
  text-align: center;
}
.l-footer__logo {
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 15px;
}
.l-footer__logo img {
  width: 160px;
  margin-bottom: 15px;
}
@media (max-width: 767px) {
  .l-footer__logo img {
    width: 100px;
  }
}
.l-footer__logo span {
  font-size: 15px;
  color: #fff;
}
@media (max-width: 767px) {
  .l-footer__logo span {
    font-size: 13px;
  }
}
.l-footer__copy {
  font-size: 15px;
  color: #fff;
}
@media (max-width: 767px) {
  .l-footer__copy {
    font-size: 13px;
  }
}

/*ピンチアウト*/
.pinchout {
  display: none;
}
@media (max-width: 767px) {
  .pinchout {
    display: block;
    width: 55%;
    height: auto;
    margin: 0 auto 20px auto;
  }
}

/*左右にスライド*/
.side-scroll {
  display: none;
}
@media (max-width: 767px) {
  .side-scroll {
    display: block;
    width: 70%;
    height: auto;
    margin: 20px auto 0 auto;
  }
}

/*ベーシックなテキストと写真のレイアウト*/
.photoLayout {
  display: flex;
  flex-direction: row;
  gap: 40px;
  margin: 30px 0;
  padding: 0px;
  /* テキストエリア */
  /* 画像エリア */
}
@media (max-width: 767px) {
  .photoLayout {
    margin: 10px 0;
    gap: 0px;
  }
}
.photoLayout__text-content {
  flex: 1.6;
  text-align: left;
}
@media (max-width: 767px) {
  .photoLayout__text-content {
    order: 2;
  }
}
.photoLayout__image-content {
  flex: 1;
}
.photoLayout__image-content img {
  width: 100%;
  height: auto;
  display: block;
}
@media (max-width: 767px) {
  .photoLayout__image-content {
    order: 2;
  }
}
@media (max-width: 767px) {
  .photoLayout {
    flex-direction: column;
    text-align: left;
    gap: 0px;
  }
}

/*ベーシックなリスト*/
ul.ul-dot {
  list-style: none;
  margin: 0;
  padding: 0;
}
@media (max-width: 767px) {
  ul.ul-dot {
    padding: 15px 0;
  }
}
ul.ul-dot li {
  position: relative;
  padding-left: 18px;
  margin-bottom: 5px;
  font-size: 18px;
}
@media (max-width: 767px) {
  ul.ul-dot li {
    font-size: 14px;
  }
}
ul.ul-dot li::before {
  content: "・";
  color: #666;
  position: absolute;
  left: 0;
  font-size: 18px;
}
@media (max-width: 767px) {
  ul.ul-dot li::before {
    font-size: 14px;
  }
}
ul.ul-dot li strong {
  font-weight: bold;
  font-size: 20px;
}
@media (max-width: 767px) {
  ul.ul-dot li strong {
    font-size: 14px;
  }
}

.cta-container-border {
  display: flex;
  gap: 20px;
  justify-content: center;
  align-items: center;
  flex-direction: row;
  padding: 20px;
}
@media (max-width: 767px) {
  .cta-container-border {
    flex-direction: column;
    align-items: stretch;
    padding: 10px;
    gap: 10px;
  }
}
.cta-container-border .cta-btn-box {
  background: #fff;
  padding: 20px;
  border: 1px solid #ccc;
  border-radius: 8px;
  text-align: center;
  flex: 1;
}
.cta-container-border .cta-btn-box p {
  font-size: 20px;
  margin-bottom: 10px;
}
@media (max-width: 767px) {
  .cta-container-border .cta-btn-box p {
    font-size: 14px;
  }
}
.cta-container-border .cta-btn-box a {
  width: 100%;
}
.cta-container-border .btn {
  display: inline-flex;
  align-items: center;
  text-align: center;
  padding: 10px 35px 10px 25px;
  border-radius: 50px;
  font-size: 24px;
  font-weight: bold;
  text-decoration: none;
  color: #333;
  transition: transform 0.2s ease;
  border: 2px solid white;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
  font-style: italic;
  justify-content: center;
}
.cta-container-border .btn img, .cta-container-border .btn .icon {
  width: 40px;
  margin-right: 10px;
}
@media (max-width: 767px) {
  .cta-container-border .btn img, .cta-container-border .btn .icon {
    width: 30px;
    margin-right: 5px;
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .cta-container-border .btn img, .cta-container-border .btn .icon {
    width: 30px;
    margin-right: 5px;
  }
}
@media (max-width: 767px) {
  .cta-container-border .btn {
    font-size: 15px;
    padding: 5px 15px;
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .cta-container-border .btn {
    font-size: 22px;
    padding: 15px 10px;
  }
}
.cta-container-border .btn:hover {
  transform: translateY(-3px) scale(1.05);
  box-shadow: 0 6px 15px rgba(0, 0, 0, 0.1);
  opacity: 1 !important;
}
.cta-container-border .btn.btn-download {
  background-color: #ddd;
  position: relative;
  overflow: hidden;
}
.cta-container-border .btn.btn-download::after {
  content: "";
  position: absolute;
  top: -50%;
  left: -100%;
  width: 40%;
  height: 200%;
  background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.6) 50%, rgba(255, 255, 255, 0) 100%);
  transform: rotate(30deg);
  animation: shine-animation 4s infinite 0s;
}
.cta-container-border .btn.btn-estimate {
  background: linear-gradient(90deg, #fcd595, #f1942a);
  position: relative;
  overflow: hidden;
}
.cta-container-border .btn.btn-estimate::after {
  content: "";
  position: absolute;
  top: -50%;
  left: -100%;
  width: 40%;
  height: 200%;
  background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.6) 50%, rgba(255, 255, 255, 0) 100%);
  transform: rotate(30deg);
  animation: shine-animation 4s infinite 0.5s;
}

/* 帯全体のコンテナ（青い背景部分） */
.banner-section {
  background-color: #1f5ba9; /* 全体の青色 */
  width: 100%;
  padding: 0;
  overflow: hidden; /* 斜め部分のはみ出し防止 */
  display: flex;
  justify-content: center;
  align-items: center;
  box-shadow: 0 -10px 8px -8px rgba(0, 0, 0, 0.1);
}

/* 中央の白い斜めエリア */
.banner-inner {
  background: linear-gradient(to bottom, #E8ECF7, #DCDDE9);
  width: 90%;
  max-width: 1000px;
  padding: 30px 60px;
  position: relative;
  /* clip-pathで左右を斜めにカット */
  clip-path: polygon(5% 0, 100% 0, 95% 100%, 0% 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  box-shadow: 0 -10px 8px -8px rgba(0, 0, 0, 0.5);
}
@media (max-width: 767px) {
  .banner-inner {
    width: 95%;
    gap: 10px;
    padding: 20px 30px;
    clip-path: polygon(3% 0, 100% 0, 97% 100%, 0% 100%);
    text-align: center;
  }
}

/* ロゴ部分） */
.banner-logo {
  width: 60px;
  height: auto;
}
@media (max-width: 767px) {
  .banner-logo {
    width: 50px;
  }
}

/* テキスト部分 */
.banner-text {
  color: #1a53a1; /* テキストの青色 */
  font-size: 16px;
  font-weight: bold;
  line-height: 1.6;
  margin: 0;
}
@media (max-width: 767px) {
  .banner-text {
    font-size: 13px;
    text-align: left;
  }
}

/* p-option */
.p-option {
  text-align: center;
  position: relative;
  padding-top: 40px;
}
.p-option__top-title {
  color: #fff;
  font-size: 20px;
  margin-bottom: 30px;
  position: absolute;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  font-weight: bold;
  background: #444;
  padding: 5px 25px;
  white-space: nowrap;
}
@media (max-width: 767px) {
  .p-option__top-title {
    top: 20px;
    font-size: 16px;
    padding: 4px 15px;
  }
}
.p-option__box {
  background: #f5f5f5;
  border: 3px solid #ddd;
  padding: 0px 20px 0px 30px;
}
@media (max-width: 767px) {
  .p-option__box {
    padding: 14px 18px 10px 18px;
  }
}
.p-option .option-sub-title {
  display: inline-block;
  font-weight: bold;
  font-size: 20px;
  padding-bottom: 6px;
  margin-bottom: 10px;
  border-bottom: 5px solid #ddd;
}
@media (max-width: 767px) {
  .p-option .option-sub-title {
    font-size: 18px;
  }
}
.p-option .option-sub-text {
  font-size: 18px;
}
@media (max-width: 767px) {
  .p-option .option-sub-text {
    font-size: 14px;
    margin-bottom: 14px;
  }
}

/*お見積り*/
#form {
  background: url("../img/bg-noise-gray.jpg") repeat center center;
  background-color: #eef6fa; /* Fallback */
}

.form-wrapper {
  max-width: 900px;
  width: 90%;
  margin: 120px auto 80px auto;
  background: #fff;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.08);
  overflow: hidden;
}
@media (max-width: 767px) {
  .form-wrapper {
    margin: 80px auto 40px auto;
    padding-bottom: 20px;
  }
}

.form-header {
  background-color: #1f5ba9;
  color: #fff;
  padding: 30px;
  text-align: center;
}
@media (max-width: 767px) {
  .form-header {
    padding: 15px;
  }
}
.form-header__title {
  font-size: 26px;
}
@media (max-width: 767px) {
  .form-header__title {
    font-size: 16px;
  }
}

.form-body {
  padding: 40px;
}
@media (max-width: 767px) {
  .form-body {
    padding: 10px;
  }
}

/* --- ステップナビゲーション --- */
.step-indicator {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 30px 40px 10px;
  background: #fff;
  max-width: 500px;
  margin: 0 auto;
}

.step {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  flex: 1;
}

.step:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 21px;
  left: 50%;
  width: 100%;
  height: 2px;
  background-color: #ddd;
  z-index: 1;
}
@media (max-width: 767px) {
  .step:not(:last-child)::after {
    top: 17px;
  }
}

.step-number {
  width: 45px;
  height: 45px;
  border-radius: 50%;
  background-color: #fff;
  border: 2px solid #ddd;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  font-size: 0.9rem;
  color: #1f5ba9;
  position: relative;
  z-index: 2;
  margin-bottom: 8px;
}
@media (max-width: 767px) {
  .step-number {
    width: 37px;
    height: 37px;
  }
}

.step-label {
  font-size: 0.8rem;
  font-weight: 600;
  color: #1f5ba9;
}

.step.active .step-number {
  background-color: #1f5ba9;
  border-color: #1f5ba9;
  color: #fff;
}

.step.active .step-label {
  color: #1f5ba9;
}

.step.active:not(:last-child)::after {
  background-color: #1f5ba9;
}

.form-group {
  margin-bottom: 24px;
  position: relative;
}
@media (max-width: 767px) {
  .form-group {
    margin-bottom: 20px;
  }
}

.label-row {
  display: flex;
  align-items: center;
  margin-bottom: 8px;
}

.form-label {
  font-weight: 600;
  font-size: 0.95rem;
}

.required-badge {
  background: #c10000;
  color: white;
  font-size: 0.7rem;
  padding: 2px 6px;
  border-radius: 4px;
  margin-left: 8px;
}

.input-flex {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 767px) {
  .input-flex {
    grid-template-columns: 1fr;
    gap: 0px;
  }
}

input[type=text], input[type=email], input[type=tel], textarea, select {
  width: 100%;
  padding: 14px;
  border: 1px solid #ddd;
  border-radius: 8px;
  font-size: 1rem;
  transition: all 0.2s ease;
  background: #fcfcfc;
}

input:focus, textarea:focus, select:focus {
  outline: none;
  border-color: #2794c8;
  background: #fff;
  box-shadow: 0 0 0 4px rgba(137, 211, 112, 0.15);
}

.option-box {
  background: #f8fafc;
  padding: 20px;
  border-radius: 10px;
  border: 1px solid #ddd;
  display: flex;
  gap: 20px;
  margin-top: 0.35rem;
}
@media (max-width: 767px) {
  .option-box {
    flex-direction: column;
    gap: 10px;
  }
}

.option-box input{
  margin-right: 0.5em;
}
.option-box label{
  margin-right: 1em;
}
.label-row input[name="tel[tel1]"]{
  width: 100px;
}
.label-row input[name="tel[tel2]"]{
  width: 100px;
}
.label-row input[name="tel[tel3]"]{
  width: 100px;
}
.radio-item {
  display: flex;
  align-items: center;
  cursor: pointer;
  font-size: 0.95rem;
}

.radio-item input {
  margin-right: 8px;
  width: 18px;
  height: 18px;
  accent-color: #2794c8;
}

/* --- 新規：打消し線風の区切りデザイン --- */
.custom-divider {
  display: flex;
  align-items: center;
  margin: 50px 0 30px;
  font-size: 17px;
  font-weight: bold;
  color: #1f5ba9;
}
@media (max-width: 767px) {
  .custom-divider {
    font-size: 15px;
  }
}

.custom-divider::before,
.custom-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background-color: #ddd;
}

.custom-divider::before {
  margin-right: 20px;
}

.custom-divider::after {
  margin-left: 20px;
}

/* --- エラー表示 --- */
.error-msg {
  color: #c10000;
  font-size: 0.8rem;
  margin-top: 5px;
}

.invalid input, .invalid select {
  border-color: #c10000;
  background-color: #fff8f8;
}

.invalid .error-msg {
  display: block;
}

.conditional-error {
  display: none;
  background: #fff8f8;
  border: 1px solid #c10000;
  color: #c10000;
  padding: 15px;
  border-radius: 8px;
  margin-bottom: 20px;
  text-align: center;
  font-weight: bold;
  font-size: 0.95rem;
}

.is-conditional-invalid .conditional-error {
  display: block;
}

/* --- プライバシー・送信ボタン等 --- */
.privacy-policy-scroll-box {
  height: 250px;
  overflow-y: scroll;
  border: 1px solid #ddd;
  background-color: #fcfcfc;
  padding: 20px;
  border-radius: 8px;
  font-size: 0.9rem;
  margin: 10px 0 20px;
}

.privacy-policy-scroll-box p{
  margin-bottom: 1em;
}

.privacy-policy-scroll-box .ol01 {
    counter-reset: item;
    list-style-type: none;
    padding-left: 0;
}
.privacy-policy-scroll-box .ol01 > li {
    padding-left: 2.5rem;
    text-indent: -1rem;
    margin-bottom: 1em;
}
.privacy-policy-scroll-box .ol01 > li:before {
    counter-increment: item;
    content: counter(item) ".";
    padding-right: 0.5em;
    font-weight: bold;
}

.privacy-policy-scroll-box .purpose {
  margin-top: 2rem;
  margin-bottom: 2rem;
}

.privacy-policy-scroll-box dl {
  line-height: 2.14;
  margin-top: 3rem;
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 1em;
}

.privacy-policy-scroll-box dl dt{
  width: 15rem;
  font-weight: bold;
}

.privacy-policy-scroll-box dl dd{
  width: calc(100% - 15rem);
}

.privacy-agreement-area {
  background: #fffbeb;
  border: 1px dashed #f59e0b;
  padding: 20px;
  border-radius: 12px;
  text-align: center;
}

.checkbox-label {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  font-weight: bold;
}

.checkbox-label input {
  width: 22px;
  height: 22px;
  margin-right: 12px;
  accent-color: #2794c8;
}

.submit-area {
  text-align: center;
  margin-top: 30px;
}

.submit-area input[name="button[forward]"] {
  background-color: #1f5ba9;
  color: white;
  padding: 18px 80px;
  margin-right: 20px;
  border: none;
  border-radius: 50px;
  font-size: 1.1rem;
  font-weight: bold;
  cursor: pointer;
  transition: all 0.3s ease;
  box-shadow: 0 4px 15px rgba(44, 90, 148, 0.3);
}
.submit-area input[type="reset"],
.submit-area input[name="button[return]"] {
  background-color: #c1c3c7;
  color: black;
  padding: 18px 80px;
  border: none;
  border-radius: 50px;
  font-size: 1.1rem;
  font-weight: bold;
  cursor: pointer;
  transition: all 0.3s ease;
  box-shadow: 0 4px 15px rgba(44, 90, 148, 0.3);
}
@media (max-width: 767px) {
  .submit-area input[type="submit"] {
    width: 100%;
    padding: 18px;
    margin-bottom: 10px;
    margin-right: 0;
  }
}

.btn-submit:disabled {
  background-color: #ddd;
  color: #94a3b8;
  cursor: not-allowed;
  box-shadow: none;
}

.form-section-title {
  background-color: #f5f5f5;
  color: #1f5ba9;
  display: flex;
  align-items: center;
  padding: 12px 16px;
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 20px;
}
@media (max-width: 767px) {
  .form-section-title {
    font-size: 15px;
  }
}
.form-section-title::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 1.4em;
  background-color: #2794c8;
  margin-right: 12px;
  border-radius: 2px;
}

.input-area-inner {
  padding: 0 15px;
}

.branch-input-area-inner {
  border: 2px solid #D2DAED;
  background: #fff;
  margin: 0 0 30px;
  padding: 0;
}
.branch-input-area-inner .form-section-title {
  background-color: #D2DAED;
  color: #1f5ba9;
}
.branch-input-area-inner .form-section-title::before {
  background-color: #1f5ba9;
  height: 2.2em;
}
.branch-input-area-inner__inner {
  padding: 0 15px;
}