.elementor-5295 .elementor-element.elementor-element-24f1f7f{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-5295 .elementor-element.elementor-element-15f6f83{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-5295 .elementor-element.elementor-element-fcb01ba{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-5295 .elementor-element.elementor-element-d0212ab{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-5295 .elementor-element.elementor-element-7fd93be{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-5295 .elementor-element.elementor-element-7ff7d1f{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-5295 .elementor-element.elementor-element-3e85571{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-5295 .elementor-element.elementor-element-81e5954{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-5295 .elementor-element.elementor-element-5bb9c3e{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-5295 .elementor-element.elementor-element-ce54981{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-5295 .elementor-element.elementor-element-2496bc8{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-5295 .elementor-element.elementor-element-68b10b8{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-5295 .elementor-element.elementor-element-78645a9{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-5295 .elementor-element.elementor-element-e24cc20{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-5295 .elementor-element.elementor-element-ebb57c2{--display:flex;--flex-direction:row;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:space-between;--align-items:center;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-5295 .elementor-element.elementor-element-ea08c44{width:100%;max-width:100%;margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-5295 .elementor-element.elementor-element-ea08c44.elementor-element{--align-self:flex-start;}.elementor-5295 .elementor-element.elementor-element-90cf88d{width:100%;max-width:100%;margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-5295 .elementor-element.elementor-element-90cf88d.elementor-element{--align-self:flex-start;}@media(max-width:1024px){.elementor-5295 .elementor-element.elementor-element-ebb57c2{--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}}/* Start custom CSS for html, class: .elementor-element-15f6f83 */.sapo-hero {
  background:
    radial-gradient(circle at 82% 36%, rgba(245,130,32,.14), transparent 24%),
    linear-gradient(135deg, #061f46 0%, #0a3478 100%);
  color: #fff;
  padding: 72px 24px 78px;
  font-family: "Noto Sans JP", sans-serif;
  overflow: hidden;
}

.sapo-hero__inner {
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: 44px;
  align-items: center;
}

.sapo-hero__badge {
  display: inline-block;
  margin: 0 0 22px;
  padding: 7px 18px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.35);
  background: rgba(255,255,255,.06);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.4;
}

.sapo-hero h1 {
  margin: 0 0 22px;
  color: #fff;
  font-size: clamp(42px, 4.2vw, 56px);
  line-height: 1.25;
  font-weight: 900;
  letter-spacing: -0.035em;
}

.sapo-hero h1 span {
  color: #f58220;
}

.sapo-hero__lead {
  max-width: 600px;
  margin: 0 0 30px;
  color: rgba(255,255,255,.92);
  font-size: 16.5px;
  line-height: 1.9;
  font-weight: 600;
}

.sapo-hero__buttons {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.sapo-hero__btn {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 58px;
  padding: 0 32px;
  border-radius: 999px;
  text-decoration: none;
  font-size: 16px;
  font-weight: 900;
  transition:
    transform .22s ease,
    box-shadow .22s ease,
    background .22s ease,
    color .22s ease;
  cursor: pointer;
}

.sapo-hero__btn span {
  position: relative;
  z-index: 2;
}

.sapo-hero__btn--primary {
  min-width: 282px;
  background: linear-gradient(135deg, #ff9b35 0%, #f58220 68%, #e87505 100%);
  color: #fff;
  box-shadow:
    0 12px 26px rgba(245,130,32,.34),
    inset 0 1px 0 rgba(255,255,255,.32);
}

.sapo-hero__btn--primary::after {
  content: "→";
  position: relative;
  z-index: 2;
  margin-left: 12px;
  font-size: 21px;
  transition: transform .22s ease;
}

.sapo-hero__btn--primary::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    120deg,
    transparent 0%,
    transparent 35%,
    rgba(255,255,255,.38) 48%,
    transparent 62%,
    transparent 100%
  );
  transform: translateX(-120%);
  z-index: 1;
}

.sapo-hero__btn--primary:hover {
  transform: translateY(-3px);
  box-shadow:
    0 18px 36px rgba(245,130,32,.44),
    inset 0 1px 0 rgba(255,255,255,.36);
}

.sapo-hero__btn--primary:hover::after {
  transform: translateX(4px);
}

.sapo-hero__btn--primary:hover::before {
  animation: sapoShine .75s ease;
}

.sapo-hero__btn--secondary {
  min-width: 190px;
  background: #fff;
  color: #07356f;
  box-shadow: 0 10px 22px rgba(0,0,0,.12);
}

.sapo-hero__btn--secondary::after {
  content: "›";
  margin-left: 10px;
  font-size: 24px;
  line-height: 1;
  color: #f58220;
  transition: transform .22s ease;
}

.sapo-hero__btn--secondary:hover {
  transform: translateY(-3px);
  background: #f6f8fb;
  box-shadow: 0 14px 28px rgba(0,0,0,.18);
}

.sapo-hero__btn--secondary:hover::after {
  transform: translateX(4px);
}

.sapo-hero__btn.is-clicked {
  transform: scale(.96);
}

.sapo-hero__note {
  margin: 18px 0 0;
  font-size: 13px;
  color: rgba(255,255,255,.72);
}

.sapo-hero__visual {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.sapo-hero__visual img {
  display: block;
  width: 100%;
  max-width: 600px;
  height: auto;
  filter: drop-shadow(0 22px 34px rgba(0,0,0,.22));
}

@keyframes sapoShine {
  0% {
    transform: translateX(-120%);
  }
  100% {
    transform: translateX(120%);
  }
}

@media (max-width: 980px) {
  .sapo-hero {
    padding: 64px 20px 70px;
  }

  .sapo-hero__inner {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .sapo-hero h1 {
    font-size: 42px;
  }

  .sapo-hero__lead br {
    display: none;
  }

  .sapo-hero__visual {
    justify-content: center;
  }

  .sapo-hero__visual img {
    max-width: 620px;
  }
}

@media (max-width: 600px) {
  .sapo-hero {
    padding: 46px 20px 56px;
  }

  .sapo-hero__badge {
    font-size: 12.5px;
    padding: 6px 14px;
    margin-bottom: 18px;
  }

  .sapo-hero h1 {
    font-size: 32px;
    line-height: 1.34;
    letter-spacing: -0.02em;
  }

  .sapo-hero__lead {
    font-size: 15px;
    line-height: 1.85;
    margin-bottom: 26px;
  }

  .sapo-hero__buttons {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }

  .sapo-hero__btn {
    width: 100%;
    min-height: 56px;
    font-size: 15px;
  }

  .sapo-hero__visual img {
    max-width: 112%;
    margin-top: 8px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-d0212ab */.sapo-stats {
  width: 100%;
  background: #f6f8fb;
  padding: 0 0 56px;
  font-family: "Noto Sans JP", sans-serif;
}

.sapo-stats__inner {
  width: 100%;
  margin: -34px 0 0;
  position: relative;
  z-index: 5;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: #fff;
  box-shadow: 0 18px 42px rgba(7, 53, 111, .1);
  overflow: hidden;
}

.sapo-stats__item {
  position: relative;
  text-align: center;
  padding: 30px 16px 28px;
}

.sapo-stats__item:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 28px;
  right: 0;
  width: 1px;
  height: calc(100% - 56px);
  background: #dce5f0;
}

.sapo-stats__icon {
  width: 48px;
  height: 48px;
  margin: 0 auto 8px;
  color: #07356f;
}

.sapo-stats__icon svg {
  width: 100%;
  height: 100%;
  fill: none;
  stroke: currentColor;
  stroke-width: 4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.sapo-stats__label {
  margin: 0 0 2px;
  color: #07356f;
  font-size: 15px;
  font-weight: 900;
  line-height: 1.4;
}

.sapo-stats__number {
  color: #f58220;
  font-size: 46px;
  line-height: 1;
  font-weight: 900;
  letter-spacing: -0.035em;
}

.sapo-stats__number span {
  font-size: .6em;
  margin-left: 2px;
}

.sapo-stats__text {
  margin: 8px 0 0;
  color: #1e2a3a;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.45;
}

/* タブレット */
@media (max-width: 900px) {
  .sapo-stats {
    padding-bottom: 42px;
  }

  .sapo-stats__inner {
    grid-template-columns: repeat(2, 1fr);
    margin-top: -18px;
  }

  .sapo-stats__item {
    padding: 24px 12px 22px;
  }

  .sapo-stats__item:nth-child(1),
  .sapo-stats__item:nth-child(2) {
    border-bottom: 1px solid #dce5f0;
  }

  .sapo-stats__item:nth-child(2)::after {
    display: none;
  }

  .sapo-stats__icon {
    width: 42px;
    height: 42px;
    margin-bottom: 6px;
  }

  .sapo-stats__label {
    font-size: 14px;
  }

  .sapo-stats__number {
    font-size: 40px;
  }

  .sapo-stats__text {
    margin-top: 6px;
    font-size: 13px;
  }
}

/* スマホ：横並びコンパクト型 */
@media (max-width:560px){

.sapo-stats{
    padding:12px 12px 30px;
}

.sapo-stats__inner{
    margin:0;
    display:grid;
    grid-template-columns:1fr 1fr;
    background:#fff;
    box-shadow:none;
}

.sapo-stats__item{
    display:grid;
    grid-template-columns:40px 1fr;
    grid-template-areas:
    "label label"
    "icon number"
    "text text";
    align-items:center;
    column-gap:10px;
    row-gap:2px;

    text-align:center;

    padding:18px 12px;
    min-height:auto;

    border-bottom:1px solid #dfe7f1;
}

.sapo-stats__item:nth-child(odd){
    border-right:1px solid #dfe7f1;
}

.sapo-stats__item::after{
    display:none!important;
}

.sapo-stats__icon{
    grid-area:icon;
    width:34px;
    height:34px;
    margin:0;
    justify-self:end;
}

.sapo-stats__body{
    display:contents;
}

.sapo-stats__label{
    grid-area:label;
    font-size:12px;
    line-height:1.3;
    margin:0 0 2px;
    font-weight:900;
}

.sapo-stats__number{
    grid-area:number;
    justify-self:start;

    font-size:34px;
    line-height:1;
    margin:0;

    color:#f58220;
}

.sapo-stats__number span{
    font-size:.58em;
}

.sapo-stats__text{
    grid-area:text;

    margin-top:4px;

    font-size:11px;
    line-height:1.35;

    font-weight:700;
}
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-7ff7d1f */.sapo-problem {
  background: #f6f8fb;
  padding: 70px 24px 44px;
  font-family: "Noto Sans JP", sans-serif;
}

.sapo-problem__inner {
  max-width: 1180px;
  margin: 0 auto;
}

.sapo-problem__heading {
  text-align: center;
  margin-bottom: 34px;
}

.sapo-problem__heading p {
  margin: 0 0 8px;
  color: #f58220;
  font-size: 15px;
  font-weight: 900;
  letter-spacing: .22em;
}

.sapo-problem__heading h2 {
  margin: 0;
  color: #07356f;
  font-size: clamp(28px, 3.2vw, 42px);
  line-height: 1.35;
  font-weight: 900;
  letter-spacing: -0.03em;
}

.sapo-problem__heading h2 span {
  color: #f58220;
}

.sapo-problem__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

.sapo-problem__card {
  display: grid;
  grid-template-columns: 86px 1fr;
  gap: 20px;
  align-items: center;
  min-height: 150px;
  background: linear-gradient(135deg, #ffffff 0%, #f9fbff 100%);
  border: 1px solid #e6edf5;
  border-radius: 20px;
  padding: 26px 26px;
  box-shadow: 0 12px 30px rgba(7, 53, 111, .07);
}

.sapo-problem__icon {
  width: 76px;
  height: 76px;
  border-radius: 18px;
  background: #fff3e8;
  color: #07356f;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sapo-problem__icon svg {
  width: 48px;
  height: 48px;
  fill: none;
  stroke: currentColor;
  stroke-width: 4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.sapo-problem__body h3 {
  margin: 0 0 8px;
  color: #07356f;
  font-size: 21px;
  line-height: 1.35;
  font-weight: 900;
}

.sapo-problem__body p {
  margin: 0;
  color: #344054;
  font-size: 14.5px;
  line-height: 1.75;
  font-weight: 700;
}

.sapo-problem__arrow {
  display: flex;
  justify-content: center;
  margin-top: 28px;
}

.sapo-problem__arrow span {
  width: 32px;
  height: 32px;
  border-right: 6px solid #07356f;
  border-bottom: 6px solid #07356f;
  transform: rotate(45deg);
  border-radius: 3px;
}

/* タブレット */
@media (max-width: 980px) {
  .sapo-problem {
    padding: 56px 20px 38px;
  }

  .sapo-problem__grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .sapo-problem__card {
    min-height: auto;
    grid-template-columns: 76px 1fr;
    padding: 22px 24px;
  }

  .sapo-problem__icon {
    width: 68px;
    height: 68px;
  }

  .sapo-problem__icon svg {
    width: 42px;
    height: 42px;
  }
}

/* スマホ */
@media (max-width: 560px) {
  .sapo-problem {
    padding: 42px 16px 32px;
  }

  .sapo-problem__heading {
    margin-bottom: 24px;
  }

  .sapo-problem__heading p {
    font-size: 12px;
    letter-spacing: .18em;
  }

  .sapo-problem__heading h2 {
    font-size: 26px;
  }

  .sapo-problem__card {
    grid-template-columns: 54px 1fr;
    gap: 14px;
    border-radius: 16px;
    padding: 16px 16px;
  }

  .sapo-problem__icon {
    width: 52px;
    height: 52px;
    border-radius: 14px;
  }

  .sapo-problem__icon svg {
    width: 32px;
    height: 32px;
    stroke-width: 4.2;
  }

  .sapo-problem__body h3 {
    font-size: 17px;
    margin-bottom: 4px;
  }

  .sapo-problem__body p {
    font-size: 12.5px;
    line-height: 1.55;
  }

  .sapo-problem__arrow {
    margin-top: 20px;
  }

  .sapo-problem__arrow span {
    width: 24px;
    height: 24px;
    border-right-width: 5px;
    border-bottom-width: 5px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-81e5954 */.sapo-services {
  position: relative;
  background:
    radial-gradient(circle at 8% 12%, rgba(245,130,32,.08), transparent 24%),
    linear-gradient(180deg, #ffffff 0%, #f6f8fb 100%);
  padding: 72px 24px 82px;
  font-family: "Noto Sans JP", sans-serif;
  overflow: hidden;
}

.sapo-services__inner {
  max-width: 1180px;
  margin: 0 auto;
}

.sapo-services__heading {
  text-align: center;
  margin-bottom: 38px;
}

.sapo-services__heading p {
  margin: 0 0 8px;
  color: #f58220;
  font-size: 15px;
  font-weight: 900;
  letter-spacing: .22em;
}

.sapo-services__heading h2 {
  margin: 0;
  color: #07356f;
  font-size: clamp(28px, 3.2vw, 40px);
  line-height: 1.35;
  font-weight: 900;
  letter-spacing: -0.03em;
}

.sapo-services__heading h2 span {
  color: #f58220;
}

.sapo-services__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

.sapo-services__card {
  position: relative;
  min-height: 240px;
  padding: 30px 28px 28px;
  background: rgba(255,255,255,.92);
  border: 1px solid #e4ecf5;
  border-radius: 22px;
  box-shadow: 0 14px 36px rgba(7, 53, 111, .07);
  overflow: hidden;
  transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}

.sapo-services__card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(245,130,32,.12), transparent 38%),
    linear-gradient(315deg, rgba(7,53,111,.08), transparent 34%);
  opacity: 0;
  transition: opacity .24s ease;
}

.sapo-services__card::after {
  content: "";
  position: absolute;
  left: 28px;
  bottom: 24px;
  width: 54px;
  height: 3px;
  border-radius: 999px;
  background: #f58220;
}

.sapo-services__card:hover {
  transform: translateY(-6px);
  border-color: rgba(245,130,32,.45);
  box-shadow: 0 20px 46px rgba(7, 53, 111, .13);
}

.sapo-services__card:hover::before {
  opacity: 1;
}

.sapo-services__top,
.sapo-services__card h3,
.sapo-services__card p {
  position: relative;
  z-index: 2;
}

.sapo-services__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 22px;
}

.sapo-services__icon {
  width: 56px;
  height: 56px;
  color: #07356f;
}

.sapo-services__icon svg {
  width: 100%;
  height: 100%;
  fill: none;
  stroke: currentColor;
  stroke-width: 4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.sapo-services__num {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 999px;
  background: #fff3e8;
  color: #f58220;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .06em;
}

.sapo-services__card h3 {
  margin: 0 0 12px;
  color: #07356f;
  font-size: 22px;
  line-height: 1.45;
  font-weight: 900;
  letter-spacing: -0.02em;
}

.sapo-services__card p {
  margin: 0;
  padding-bottom: 26px;
  color: #344054;
  font-size: 14.5px;
  line-height: 1.8;
  font-weight: 700;
}

/* タブレット */
@media (max-width: 980px) {
  .sapo-services {
    padding: 58px 20px 64px;
  }

  .sapo-services__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
  }

  .sapo-services__card {
    min-height: 220px;
  }
}

/* スマホ */
@media (max-width: 560px) {
  .sapo-services {
    padding: 44px 14px 52px;
  }

  .sapo-services__heading {
    margin-bottom: 26px;
  }

  .sapo-services__heading p {
    font-size: 12px;
    letter-spacing: .18em;
  }

  .sapo-services__heading h2 {
    font-size: 26px;
  }

  .sapo-services__grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .sapo-services__card {
    min-height: auto;
    border-radius: 18px;
    padding: 20px 18px 22px;
  }

  .sapo-services__top {
    margin-bottom: 12px;
  }

  .sapo-services__icon {
    width: 42px;
    height: 42px;
  }

  .sapo-services__num {
    font-size: 11px;
    padding: 5px 10px;
  }

  .sapo-services__card h3 {
    font-size: 18px;
    margin-bottom: 7px;
  }

  .sapo-services__card p {
    font-size: 13px;
    line-height: 1.65;
    padding-bottom: 18px;
  }

  .sapo-services__card::after {
    left: 18px;
    bottom: 16px;
    width: 44px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-ce54981 */.sapo-works {
  position: relative;
  background: linear-gradient(135deg, #061f46 0%, #0a3478 100%);
  padding: 74px 24px 84px;
  font-family: "Noto Sans JP", sans-serif;
  color: #fff;
  overflow: hidden;
}

.sapo-works::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 88% 18%, rgba(245,130,32,.18), transparent 24%),
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: auto, 44px 44px, 44px 44px;
  pointer-events: none;
}

.sapo-works__inner {
  position: relative;
  z-index: 2;
  max-width: 1180px;
  margin: 0 auto;
}

.sapo-works__head {
  margin-bottom: 34px;
}

.sapo-works__head p {
  margin: 0 0 8px;
  color: #f58220;
  font-size: 15px;
  font-weight: 900;
  letter-spacing: .18em;
}

.sapo-works__head h2 {
  margin: 0 0 10px;
  color: #fff;
  font-size: clamp(30px, 3.3vw, 42px);
  line-height: 1.35;
  font-weight: 900;
  letter-spacing: -0.03em;
}

.sapo-works__head span {
  color: rgba(255,255,255,.82);
  font-size: 15px;
  line-height: 1.8;
  font-weight: 600;
}

.sapo-works__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.sapo-works__card {
  background: #fff;
  color: #07356f;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 18px 42px rgba(0,0,0,.24);
  transition: transform .24s ease, box-shadow .24s ease;
}

.sapo-works__card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 54px rgba(0,0,0,.3);
}

.sapo-works__image {
  position: relative;
  height: 190px;
  background: #e8edf5;
  overflow: hidden;
}

.sapo-works__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sapo-works__image span {
  position: absolute;
  left: 14px;
  top: 14px;
  display: inline-block;
  padding: 6px 13px;
  border-radius: 999px;
  background: rgba(255,255,255,.94);
  color: #07356f;
  font-size: 12px;
  font-weight: 900;
}

.sapo-works__body {
  padding: 22px 22px 24px;
}

.sapo-works__area {
  margin: 0 0 8px;
  color: #f58220;
  font-size: 12px;
  font-weight: 900;
}

.sapo-works__body h3 {
  margin: 0 0 10px;
  color: #07356f;
  font-size: 20px;
  line-height: 1.45;
  font-weight: 900;
}

.sapo-works__text {
  margin: 0;
  color: #344054;
  font-size: 14px;
  line-height: 1.75;
  font-weight: 700;
}

.sapo-works__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}

.sapo-works__tags span {
  display: inline-flex;
  align-items: center;
  padding: 6px 11px;
  border-radius: 999px;
  background: #eef4fb;
  color: #07356f;
  font-size: 12px;
  font-weight: 800;
}

/* CTA */
.sapo-works__cta {
  position: relative;
  margin-top: 38px;
  padding: 26px 30px;
  border-radius: 24px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.14), rgba(255,255,255,.06)),
    rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.2);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  overflow: hidden;
  box-shadow: 0 18px 42px rgba(0,0,0,.18);
}

.sapo-works__cta::before {
  content: "";
  position: absolute;
  right: -70px;
  top: -90px;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background: rgba(245,130,32,.18);
}

.sapo-works__cta-text {
  position: relative;
  z-index: 2;
}

.sapo-works__cta-text span {
  display: inline-block;
  margin-bottom: 8px;
  color: #f58220;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .18em;
}

.sapo-works__cta-text p {
  margin: 0 0 6px;
  color: #fff;
  font-size: 20px;
  line-height: 1.5;
  font-weight: 900;
}

.sapo-works__cta-text small {
  color: rgba(255,255,255,.78);
  font-size: 13px;
  line-height: 1.7;
  font-weight: 700;
}

.sapo-works__btn {
  position: relative;
  z-index: 2;
  isolation: isolate;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 250px;
  min-height: 58px;
  padding: 0 54px 0 30px;
  border-radius: 999px;
  background: linear-gradient(135deg, #ff9b35 0%, #f58220 68%, #e87505 100%);
  color: #fff;
  text-decoration: none;
  font-size: 16px;
  font-weight: 900;
  box-shadow:
    0 14px 30px rgba(245,130,32,.34),
    inset 0 1px 0 rgba(255,255,255,.35);
  transition: transform .22s ease, box-shadow .22s ease;
}

.sapo-works__btn span {
  position: relative;
  z-index: 2;
}

.sapo-works__btn::after {
  content: "→";
  position: absolute;
  z-index: 2;
  right: 26px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 22px;
  transition: transform .22s ease;
}

.sapo-works__btn::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    120deg,
    transparent 0%,
    transparent 35%,
    rgba(255,255,255,.42) 48%,
    transparent 62%,
    transparent 100%
  );
  transform: translateX(-120%);
}

.sapo-works__btn:hover {
  transform: translateY(-3px);
  box-shadow:
    0 20px 40px rgba(245,130,32,.44),
    inset 0 1px 0 rgba(255,255,255,.4);
}

.sapo-works__btn:hover::before {
  animation: sapoWorksShine .75s ease;
}

.sapo-works__btn:hover::after {
  transform: translate(5px, -50%);
}

.sapo-works__btn.is-clicked {
  transform: scale(.96);
}

@keyframes sapoWorksShine {
  0% {
    transform: translateX(-120%);
  }
  100% {
    transform: translateX(120%);
  }
}

@media (max-width: 980px) {
  .sapo-works {
    padding: 58px 20px 66px;
  }

  .sapo-works__grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .sapo-works__card {
    display: grid;
    grid-template-columns: 42% 58%;
  }

  .sapo-works__image {
    height: 100%;
    min-height: 230px;
  }

  .sapo-works__cta {
    align-items: flex-start;
  }
}

@media (max-width: 560px) {
  .sapo-works {
    padding: 46px 14px 52px;
  }

  .sapo-works__head {
    text-align: center;
    margin-bottom: 24px;
  }

  .sapo-works__head p {
    font-size: 12px;
  }

  .sapo-works__head h2 {
    font-size: 26px;
  }

  .sapo-works__head span {
    font-size: 13px;
  }

  .sapo-works__card {
    display: block;
    border-radius: 16px;
  }

  .sapo-works__image {
    height: 150px;
    min-height: 0;
  }

  .sapo-works__body {
    padding: 18px 18px 20px;
  }

  .sapo-works__body h3 {
    font-size: 18px;
  }

  .sapo-works__text {
    font-size: 12.5px;
  }

  .sapo-works__tags span {
    font-size: 11px;
    padding: 5px 9px;
  }

  .sapo-works__cta {
    margin-top: 24px;
    padding: 22px 18px;
    display: block;
    text-align: center;
    border-radius: 18px;
  }

  .sapo-works__cta-text p {
    font-size: 17px;
    line-height: 1.6;
  }

  .sapo-works__cta-text small {
    display: block;
    font-size: 12.5px;
    margin-bottom: 16px;
  }

  .sapo-works__btn {
    width: 100%;
    min-width: 0;
    min-height: 56px;
    padding: 0 46px 0 22px;
    font-size: 15px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-68b10b8 */.sapo-seo {
  position: relative;
  background:
    radial-gradient(circle at 12% 18%, rgba(245,130,32,.08), transparent 24%),
    linear-gradient(180deg, #ffffff 0%, #f6f8fb 100%);
  padding: 78px 24px 86px;
  font-family: "Noto Sans JP", sans-serif;
  overflow: hidden;
}

.sapo-seo__inner {
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.08fr .92fr;
  gap: 52px;
  align-items: center;
}

.sapo-seo__label {
  margin: 0 0 10px;
  color: #f58220;
  font-size: 15px;
  font-weight: 900;
  letter-spacing: .18em;
}

.sapo-seo h2 {
  margin: 0 0 20px;
  color: #07356f;
  font-size: clamp(30px, 3.4vw, 44px);
  line-height: 1.45;
  font-weight: 900;
  letter-spacing: -0.035em;
}

.sapo-seo h2 span {
  color: #f58220;
}

.sapo-seo__lead {
  max-width: 680px;
  margin: 0 0 30px;
  color: #344054;
  font-size: 16px;
  line-height: 1.95;
  font-weight: 700;
}

.sapo-seo__points {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}

.sapo-seo__point {
  display: grid;
  grid-template-columns: 52px 1fr;
  gap: 14px;
  align-items: flex-start;
  padding: 18px;
  background: #fff;
  border: 1px solid #e2eaf4;
  border-radius: 18px;
  box-shadow: 0 10px 28px rgba(7, 53, 111, .06);
}

.sapo-seo__point-icon {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: #fff3e8;
  color: #07356f;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sapo-seo__point-icon svg {
  width: 30px;
  height: 30px;
  fill: none;
  stroke: currentColor;
  stroke-width: 4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.sapo-seo__point h3 {
  margin: 0 0 5px;
  color: #07356f;
  font-size: 16px;
  line-height: 1.45;
  font-weight: 900;
}

.sapo-seo__point p {
  margin: 0;
  color: #475467;
  font-size: 12.5px;
  line-height: 1.65;
  font-weight: 700;
}

.sapo-seo__keyword-box {
  position: relative;
  background: #fff;
  border: 1px solid #e2eaf4;
  border-radius: 28px;
  padding: 38px 36px;
  box-shadow: 0 22px 56px rgba(7, 53, 111, .12);
  overflow: hidden;
}

.sapo-seo__keyword-box::before {
  content: "";
  position: absolute;
  right: -70px;
  top: -70px;
  width: 190px;
  height: 190px;
  border-radius: 50%;
  background: rgba(245,130,32,.12);
}

.sapo-seo__keyword-icon {
  position: relative;
  z-index: 2;
  width: 64px;
  height: 64px;
  margin-bottom: 22px;
  color: #07356f;
}

.sapo-seo__keyword-icon svg {
  width: 100%;
  height: 100%;
  fill: none;
  stroke: currentColor;
  stroke-width: 4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.sapo-seo__keyword-box h3 {
  position: relative;
  z-index: 2;
  margin: 0 0 10px;
  color: #07356f;
  font-size: 24px;
  line-height: 1.45;
  font-weight: 900;
}

.sapo-seo__keyword-box p {
  position: relative;
  z-index: 2;
  margin: 0 0 22px;
  color: #475467;
  font-size: 14px;
  line-height: 1.75;
  font-weight: 700;
}

.sapo-seo__keyword-box ul {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.sapo-seo__keyword-box li {
  position: relative;
  padding: 14px 16px 14px 20px;
  background: #f6f8fb;
  border-radius: 12px;
  color: #07356f;
  font-size: 15px;
  font-weight: 900;
  overflow: hidden;
}

.sapo-seo__keyword-box li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 5px;
  height: 100%;
  background: #f58220;
}

/* タブレット */
@media (max-width: 980px) {
  .sapo-seo {
    padding: 62px 20px 68px;
  }

  .sapo-seo__inner {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .sapo-seo__lead {
    max-width: 100%;
  }
}

/* スマホ */
@media (max-width: 560px) {
  .sapo-seo {
    padding: 46px 14px 52px;
  }

  .sapo-seo__content {
    text-align: center;
  }

  .sapo-seo__label {
    font-size: 12px;
  }

  .sapo-seo h2 {
    font-size: 26px;
  }

  .sapo-seo h2 br {
    display: none;
  }

  .sapo-seo__lead {
    font-size: 13px;
    line-height: 1.8;
    margin-bottom: 24px;
    text-align: left;
  }

  .sapo-seo__points {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .sapo-seo__point {
    grid-template-columns: 44px 1fr;
    gap: 12px;
    padding: 14px;
    text-align: left;
    border-radius: 16px;
  }

  .sapo-seo__point-icon {
    width: 42px;
    height: 42px;
  }

  .sapo-seo__point-icon svg {
    width: 26px;
    height: 26px;
  }

  .sapo-seo__point h3 {
    font-size: 14px;
  }

  .sapo-seo__point p {
    font-size: 11.5px;
  }

  .sapo-seo__keyword-box {
    border-radius: 20px;
    padding: 26px 20px;
  }

  .sapo-seo__keyword-icon {
    width: 48px;
    height: 48px;
    margin-bottom: 16px;
  }

  .sapo-seo__keyword-box h3 {
    font-size: 19px;
  }

  .sapo-seo__keyword-box p {
    font-size: 12.5px;
  }

  .sapo-seo__keyword-box li {
    font-size: 13px;
    padding: 12px 14px 12px 18px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-e24cc20 */.sapo-faq {
  position: relative;
  background:
    radial-gradient(circle at 5% 8%, rgba(7,53,111,.06) 0 1px, transparent 2px),
    radial-gradient(circle at 95% 92%, rgba(7,53,111,.06) 0 1px, transparent 2px),
    linear-gradient(180deg, #ffffff 0%, #f6f8fb 100%);
  background-size: 18px 18px, 18px 18px, auto;
  padding: 76px 24px 86px;
  font-family: "Noto Sans JP", sans-serif;
}

.sapo-faq__inner {
  max-width: 1180px;
  margin: 0 auto;
}

.sapo-faq__head {
  text-align: center;
  margin-bottom: 38px;
}

.sapo-faq__head p {
  margin: 0 0 8px;
  color: #f58220;
  font-size: 16px;
  font-weight: 900;
  letter-spacing: .18em;
}

.sapo-faq__head h2 {
  margin: 0 0 10px;
  color: #07356f;
  font-size: clamp(32px, 3.6vw, 48px);
  line-height: 1.3;
  font-weight: 900;
  letter-spacing: -0.035em;
}

.sapo-faq__head span {
  color: #344054;
  font-size: 15px;
  line-height: 1.8;
  font-weight: 700;
}

.sapo-faq__head::after {
  content: "";
  display: block;
  width: 54px;
  height: 3px;
  background: #f58220;
  border-radius: 999px;
  margin: 20px auto 0;
}

.sapo-faq__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.sapo-faq__card {
  background: #fff;
  border: 1px solid #e3ebf5;
  border-radius: 16px;
  padding: 26px 26px 28px;
  box-shadow: 0 12px 32px rgba(7,53,111,.07);
  transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}

.sapo-faq__card:hover {
  transform: translateY(-5px);
  border-color: rgba(245,130,32,.45);
  box-shadow: 0 20px 42px rgba(7,53,111,.12);
}

.sapo-faq__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
}

.sapo-faq__q {
  color: #f58220;
  font-size: 26px;
  line-height: 1;
  font-weight: 900;
}

.sapo-faq__icon {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: #f1f5fa;
  color: #07356f;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sapo-faq__icon svg {
  width: 32px;
  height: 32px;
  fill: none;
  stroke: currentColor;
  stroke-width: 4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.sapo-faq__card h3 {
  min-height: 64px;
  margin: 0 0 18px;
  color: #07356f;
  font-size: 19px;
  line-height: 1.55;
  font-weight: 900;
}

.sapo-faq__card h3::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background: #dfe7f1;
  margin-top: 18px;
}

.sapo-faq__card p {
  margin: 0;
  color: #344054;
  font-size: 14px;
  line-height: 1.85;
  font-weight: 700;
}

.sapo-faq__card p strong {
  color: #f58220;
}

.sapo-faq__cta {
  margin-top: 24px;
  background: #fff;
  border: 1px solid #e3ebf5;
  border-radius: 16px;
  padding: 28px 36px;
  display: grid;
  grid-template-columns: 72px 1fr auto;
  gap: 24px;
  align-items: center;
  box-shadow: 0 16px 40px rgba(7,53,111,.08);
}

.sapo-faq__cta-icon {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: #fff3e8;
  color: #f58220;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sapo-faq__cta-icon svg {
  width: 38px;
  height: 38px;
  fill: none;
  stroke: currentColor;
  stroke-width: 4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.sapo-faq__cta-text h3 {
  margin: 0 0 6px;
  color: #07356f;
  font-size: 21px;
  line-height: 1.45;
  font-weight: 900;
}

.sapo-faq__cta-text p {
  margin: 0;
  color: #344054;
  font-size: 14px;
  font-weight: 700;
}

.sapo-faq__btn {
  position: relative;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 250px;
  min-height: 58px;
  padding: 0 54px 0 30px;
  border-radius: 999px;
  background: linear-gradient(135deg, #ff9b35 0%, #f58220 68%, #e87505 100%);
  color: #fff;
  text-decoration: none;
  font-size: 16px;
  font-weight: 900;
  box-shadow: 0 14px 30px rgba(245,130,32,.28);
  transition: transform .22s ease, box-shadow .22s ease;
}

.sapo-faq__btn::after {
  content: "→";
  position: absolute;
  right: 26px;
  font-size: 22px;
  transition: transform .22s ease;
}

.sapo-faq__btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 20px 40px rgba(245,130,32,.38);
}

.sapo-faq__btn:hover::after {
  transform: translateX(5px);
}

@media (max-width: 980px) {
  .sapo-faq {
    padding: 60px 20px 68px;
  }

  .sapo-faq__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .sapo-faq__cta {
    grid-template-columns: 64px 1fr;
  }

  .sapo-faq__btn {
    grid-column: 1 / -1;
    width: 100%;
  }
}

@media (max-width: 560px) {
  .sapo-faq {
    padding: 46px 14px 54px;
  }

  .sapo-faq__head {
    margin-bottom: 26px;
  }

  .sapo-faq__head p {
    font-size: 12px;
  }

  .sapo-faq__head h2 {
    font-size: 30px;
  }

  .sapo-faq__head span {
    font-size: 12.5px;
  }

  .sapo-faq__grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .sapo-faq__card {
    padding: 20px 18px 22px;
    border-radius: 14px;
  }

  .sapo-faq__top {
    margin-bottom: 12px;
  }

  .sapo-faq__q {
    font-size: 22px;
  }

  .sapo-faq__icon {
    width: 46px;
    height: 46px;
  }

  .sapo-faq__icon svg {
    width: 26px;
    height: 26px;
  }

  .sapo-faq__card h3 {
    min-height: auto;
    font-size: 16px;
    margin-bottom: 14px;
  }

  .sapo-faq__card h3::after {
    margin-top: 14px;
  }

  .sapo-faq__card p {
    font-size: 12.5px;
    line-height: 1.75;
  }

  .sapo-faq__cta {
    margin-top: 18px;
    padding: 22px 18px;
    grid-template-columns: 1fr;
    gap: 14px;
    text-align: center;
  }

  .sapo-faq__cta-icon {
    margin: 0 auto;
    width: 58px;
    height: 58px;
  }

  .sapo-faq__cta-icon svg {
    width: 32px;
    height: 32px;
  }

  .sapo-faq__cta-text h3 {
    font-size: 17px;
  }

  .sapo-faq__cta-text p {
    font-size: 12.5px;
    line-height: 1.7;
  }

  .sapo-faq__btn {
    width: 100%;
    min-width: 0;
    min-height: 56px;
    font-size: 15px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-ea08c44 */.elementor-5295 .elementor-element.elementor-element-ea08c44 {
  flex: 0 0 58% !important;
  max-width: 58% !important;
}

.elementor-5295 .elementor-element.elementor-element-ea08c44 .sapo-final-cta__content {
  width: 100%;
}

.elementor-5295 .elementor-element.elementor-element-ea08c44 .sapo-final-cta__eyebrow {
  color: #f58220;
  font-size: 16px;
  font-weight: 800;
  margin: 0 0 20px;
  letter-spacing: .08em;
}

.elementor-5295 .elementor-element.elementor-element-ea08c44 .sapo-final-cta__title {
  color: #fff;
  font-size: clamp(36px, 3.8vw, 52px);
  line-height: 1.3;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 0 0 24px;
}

.elementor-5295 .elementor-element.elementor-element-ea08c44 .sapo-final-cta__lead {
  color: rgba(255,255,255,.88);
  font-size: 16px;
  line-height: 1.9;
  font-weight: 600;
  margin: 0 0 40px;
}

.elementor-5295 .elementor-element.elementor-element-ea08c44 .sapo-final-cta__benefits {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 14px;
}

.elementor-5295 .elementor-element.elementor-element-ea08c44 .sapo-final-cta__benefit {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 18px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 14px;
  backdrop-filter: blur(10px);
  transition: .3s;
}

.elementor-5295 .elementor-element.elementor-element-ea08c44 .sapo-final-cta__benefit:hover {
  transform: translateY(-4px);
  background: rgba(255,255,255,.14);
}

.elementor-5295 .elementor-element.elementor-element-ea08c44 .sapo-final-cta__benefit i {
  color: #f58220;
  font-size: 20px;
  width: 24px;
  text-align: center;
  flex: 0 0 24px;
}

.elementor-5295 .elementor-element.elementor-element-ea08c44 .sapo-final-cta__benefit span {
  color: #fff;
  font-size: 15px;
  line-height: 1.45;
  font-weight: 700;
}

@media (max-width: 1024px) {
  .elementor-5295 .elementor-element.elementor-element-ea08c44 {
    flex: 0 0 100% !important;
    max-width: 100% !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  .elementor-5295 .elementor-element.elementor-element-ea08c44 .sapo-final-cta__title {
    font-size: 40px;
  }

  .elementor-5295 .elementor-element.elementor-element-ea08c44 .sapo-final-cta__lead {
    font-size: 15px;
  }
}

@media (max-width: 767px) {
  .elementor-5295 .elementor-element.elementor-element-ea08c44 .sapo-final-cta__eyebrow {
    font-size: 13px;
    margin-bottom: 14px;
  }

  .elementor-5295 .elementor-element.elementor-element-ea08c44 .sapo-final-cta__title {
    font-size: 30px;
    margin-bottom: 16px;
  }

  .elementor-5295 .elementor-element.elementor-element-ea08c44 .sapo-final-cta__lead {
    font-size: 14px;
    margin-bottom: 28px;
  }

  .elementor-5295 .elementor-element.elementor-element-ea08c44 .sapo-final-cta__benefit {
    flex-direction: column;
    text-align: center;
    padding: 14px 10px;
    gap: 8px;
  }

  .elementor-5295 .elementor-element.elementor-element-ea08c44 .sapo-final-cta__benefit i {
    font-size: 18px;
  }

  .elementor-5295 .elementor-element.elementor-element-ea08c44 .sapo-final-cta__benefit span {
    font-size: 13px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-90cf88d */.elementor-5295 .elementor-element.elementor-element-90cf88d {
  flex: 0 0 calc(42% - 60px) !important;
  max-width: calc(42% - 60px) !important;
  min-width: 380px !important;
  background: #fff !important;
  padding: 44px 46px !important;
  border-radius: 28px !important;
  box-shadow: 0 28px 70px rgba(0,0,0,.22) !important;
}

.elementor-5295 .elementor-element.elementor-element-90cf88d:before {
  content: "無料相談・お問い合わせフォーム" !important;
  display: block !important;
  color: #08245a !important;
  font-size: 26px !important;
  line-height: 1.35 !important;
  font-weight: 800 !important;
  text-align: center !important;
  margin: 0 0 10px !important;
}

.elementor-5295 .elementor-element.elementor-element-90cf88d:after {
  content: "ご相談内容をお聞かせください。担当者よりご連絡いたします。" !important;
  display: block !important;
  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.8 !important;
  font-weight: 600 !important;
  text-align: center !important;
  margin: 0 0 30px !important;
}

.elementor-5295 .elementor-element.elementor-element-90cf88d label {
  color: #08245a !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  margin-bottom: 6px !important;
  display: block !important;
}

.elementor-5295 .elementor-element.elementor-element-90cf88d .required {
  color: #f58220 !important;
  margin-left: 4px !important;
}

.elementor-5295 .elementor-element.elementor-element-90cf88d .cta-form__field {
  margin-bottom: 16px !important;
}

.elementor-5295 .elementor-element.elementor-element-90cf88d .cta-form__field input,
.elementor-5295 .elementor-element.elementor-element-90cf88d .cta-form__field textarea {
  width: 100% !important;
  border: 2px solid #e2e8f0 !important;
  border-radius: 14px !important;
  background: #f8fafc !important;
  padding: 16px 18px !important;
  color: #08245a !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  font-family: inherit !important;
  transition: .25s !important;
  outline: none !important;
}

.elementor-5295 .elementor-element.elementor-element-90cf88d .cta-form__field textarea {
  min-height: 150px !important;
  resize: vertical !important;
}

.elementor-5295 .elementor-element.elementor-element-90cf88d .cta-form__field input:focus,
.elementor-5295 .elementor-element.elementor-element-90cf88d .cta-form__field textarea:focus {
  border-color: #f58220 !important;
  background: #fff !important;
  box-shadow: 0 0 0 4px rgba(245,130,32,.14) !important;
}

.elementor-5295 .elementor-element.elementor-element-90cf88d .cta-form__field--acceptance {
  color: #475569 !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  line-height: 1.7 !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}

.elementor-5295 .elementor-element.elementor-element-90cf88d .cta-form__field--acceptance input {
  width: 16px !important;
  height: 16px !important;
  padding: 0 !important;
  accent-color: #f58220 !important;
  flex: 0 0 16px !important;
}

.elementor-5295 .elementor-element.elementor-element-90cf88d .cta-form__field--acceptance a {
  color: #08245a !important;
  font-weight: 800 !important;
  text-decoration: underline !important;
  text-underline-offset: 3px !important;
}

.elementor-5295 .elementor-element.elementor-element-90cf88d .cta-form__submit input[type="submit"] {
  width: 100% !important;
  min-height: 68px !important;
  border: none !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, #ffab4d 0%, #f58220 100%) !important;
  color: #fff !important;
  font-size: 20px !important;
  font-weight: 800 !important;
  box-shadow: 0 16px 36px rgba(245,130,32,.35) !important;
  transition: all .35s ease !important;
  cursor: pointer !important;
}

.elementor-5295 .elementor-element.elementor-element-90cf88d .cta-form__submit input[type="submit"]:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 24px 50px rgba(245,130,32,.45) !important;
  background: linear-gradient(135deg, #f59e35 0%, #e06a00 100%) !important;
}

@media (max-width: 1024px) {
  .elementor-5295 .elementor-element.elementor-element-90cf88d {
    flex: 0 0 100% !important;
    max-width: 100% !important;
    width: 100% !important;
    min-width: 0 !important;
    padding: 36px 34px !important;
  }
}

@media (max-width: 767px) {
  .elementor-5295 .elementor-element.elementor-element-90cf88d {
    padding: 24px 18px !important;
    border-radius: 20px !important;
  }

  .elementor-5295 .elementor-element.elementor-element-90cf88d:before {
    content: "無料相談フォーム" !important;
    font-size: 22px !important;
  }

  .elementor-5295 .elementor-element.elementor-element-90cf88d .cta-form__submit input[type="submit"] {
    min-height: 62px !important;
    font-size: 18px !important;
  }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-ebb57c2 */.elementor-5295 .elementor-element.elementor-element-ebb57c2 {
  background:
    radial-gradient(circle at 85% 15%, rgba(245,130,32,.14), transparent 26%),
    linear-gradient(135deg,#08245a 0%,#0d2f73 100%);
  padding: 90px 60px;
  overflow: hidden;
  position: relative;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 60px !important;
  flex-wrap: wrap !important;
}

.elementor-5295 .elementor-element.elementor-element-ebb57c2:before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events: none;
}

@media (max-width: 1024px) {
  .elementor-5295 .elementor-element.elementor-element-ebb57c2 {
    padding: 70px 40px;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 48px !important;
  }
}

@media (max-width: 767px) {
  .elementor-5295 .elementor-element.elementor-element-ebb57c2 {
    padding: 54px 20px;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 40px !important;
  }
}/* End custom CSS */