@charset "utf-8";

  body {
  font-family: "Roboto", Arial, sans-serif;
  font-size: 16px;
  }
.mainvisual .text-box h2 {
    font-size: 2.6em;
    line-height: 1.1;
}
.mainvisual .sub-text {
    font-size: 1em;
    width: 50vw;
}
.mainvisual .text-box {
    top: 5%;
}
.twb-arrow-title-sub {
    position: relative;
}
.twb-arrow-title-sub::after {
    bottom: -39px;
}
.twb-arrow-title-sub {
    margin-bottom: 3.5rem;
}
p:not([class]) {
    line-height: 1.8;
}
.conclusion-catch span {
    line-height: 1.2;
}
.pc-fix-banner04-text a {
    line-height: 1.2;
}
.pc-fix-banner04-text .text-small {
    line-height: 1.3;
    text-align: left;
}
.pc-fix-banner04-text p {
    line-height: 1.3;
    text-align: left;
}
.section-title02 {
    line-height: 1.2;
}
.tag-list-6c li a {
    font-size: 1.5rem;
    line-height: 1.2;
}
section.benefit-section .column-medium .onb-img-title {
    width: 100%;
}
section.validity-section .section-title01-frame::after {
    min-height: 40rem;
}
section.validity-section .section-title01-frame::before {
    min-height: 40rem;
}
.title-catch {
    font-size: 1.8rem;
    line-height: 1.2;
}
section.intro-section .sub-text {
    margin: 0 auto 3rem;
}
.center-img-catch {
    line-height: 1.2;
}
.section-title01 {
    line-height: 1.2;
}
.onb-listbox-area {
    margin: 3rem 0 5rem;
}
.tag-list-6c li {
    line-height: 1.2;
}
.onb-listbox-area {
    margin: 10rem 0 5rem;
}
.btn-internal a {
    line-height: 1.2;
}
.gnavi-list__link {
    line-height: 1.2;
}
.mainvisual.lower_mv {
    height: 15rem;
}
#low-page h1:not([class]) {
    line-height: 1.2;
}
.l-contents-banner02 a::before {
    content: 'Read More';
}
.contents-banner02-content {
    width: 60rem;
}
.section-title02-sub span {
    line-height: 1;
}
.twb-arrow-title {
    line-height: 1.2;
}


section.faq-container {
  max-width: 100rem;
  margin: 20px auto;
  padding: 2rem;
  margin-top: 10rem;
}
.faq-main-title {
  /* border-bottom: 2px solid #333; */
  padding-bottom: 10px;
  margin-bottom: 20px;
  font-weight: bold;
  font-size: 3rem;
  text-align: center;
}
.faq-details {
  border: 1px solid #e0e0e0;
  margin-bottom: 1.5rem;
  /* border-radius: 4px; */
}
.faq-summary {
  padding: 2rem 2rem;
  cursor: pointer;
  background-color: #f8f8f8;
  list-style: none; /* デフォルトの矢印を消す（Chrome/Edge） */
}
.faq-summary::-webkit-details-marker {
  display: none; /* デフォルトの矢印を消す（Safari） */
}
.faq-summary h4 {
  margin: 0;
  display: inline-block;
  /* font-size: 1.1rem; */
  font-size: 2rem;
  font-weight: bold;
}
.faq-content {
  padding: 20px;
  border-top: 1px solid #e0e0e0;
  line-height: 1.8;
  background-color: #fff;
}
.faq-content p {
  margin: 0 0 1em 0;
}
.faq-content p:last-child {
  margin-bottom: 0;
}
/* 開いている時に背景色を変える場合 */
.faq-details[open] .faq-summary {
  background-color: #eee;
}
.faq-content p {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.6rem;
    font-weight: 400;
    -webkit-text-size-adjust: 100%;
    line-height: 2;
    letter-spacing: 0.03em;
}
summary.faq-summary:hover {
    opacity: 0.5;
}
section.benefit-section .section-title02-frame {
    margin-bottom: 0rem;
}

.video-wrap {
  width: 100%;
  max-width: 100%;
  /* 横幅に合わせて高さを計算（16:9） */
  aspect-ratio: 16 / 9;
}

.video-wrap > iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

.btn-internal.down a {
	background: var(--site-color01) ;
}

.btn-internal.down a::after {
	content: "";
	position: absolute;
	right: 1rem;
	top: 50%;
	transform: translateY(-50%) rotate(90deg); /* 下向き矢印に変える */
	width: 1.2em;
	height: 1.2em;
	background: url("./img/arrow-01-wht-right.svg") no-repeat center / contain;
}

.onb-listbox-area.l-stack-small img {
    margin: 0 auto;
}

.btn-web a {
    border-radius: 7rem;
}

.btn-web::after {
    border-radius: 7rem;
}

.tag {
    background: #00a1f0;
    display: inline;
    padding: 1rem;
    margin-right: 0.4rem;
    font-weight: bold;
}

.tag-wrap {margin-top: 3rem;}


.btn-back button {
  background: var(--site-color01);
  color: #fff;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 700;
  display: block;
  text-align: center;
  padding: 18px 50px 18px 30px;
  position: relative;
  line-height: 1.4;
  border-radius: 50px;
  transition: all 0.3s ease;
  width: 100%;
  margin: 5rem auto;
  max-width: 33rem;
}


.btn-back button::after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background-color: #dfdfdf;
    border-width: 0 1px 1px 0;
    box-sizing: border-box;
    position: absolute;
    left: 0;
    bottom: 0;
    z-index: -1;
    transform: translate(0.8rem, 0.8rem);
    border-radius: 5rem;
}

.contact-txt p {
    text-align: center;
}

.only-en {
  display: none;
}
/* ============================================
   SELF-CONTAINED LP ROUGH
   Visual match to existing LP design
   ============================================ */
*{margin:0;padding:0;box-sizing:border-box}
html{font-size:62.5%}
body{font-family:'Roboto','Noto Sans JP',sans-serif;font-size:1.6rem;color:#333;background:#fff;line-height:1.8;letter-spacing:.03em}
img{max-width:100%;height:auto;vertical-align:bottom}
a{color:#333;text-decoration:none;transition:opacity .3s}
a:hover{opacity:.7}

/* === COLORS (matching existing LP) === */
:root{
  --blue:#00A1F0;
  --blue-dark:#2069F6;
  --orange:#ea4c25;
  --orange-light:#FF9839;
  --dark:#333;
  --gray-bg:#f4f4f4;
  --gray-light:#f8f8f8;
  --marker:#ffddb4;
  --green:#25D366;
}

/* === UTILITY === */
.l-center{max-width:100rem;margin:0 auto;padding:0 2.4rem}
.marker{font-weight:700;background-color:var(--marker);text-shadow:none}
.caption{margin-top:.8em;color:#999;font-size:1.2rem;line-height:1.3;text-align:center;margin-bottom:2rem}
.pc_br{display:inline}
.sp_br{display:none}

/* === BUTTONS (existing LP style: pill + offset shadow) === */
.btn-pill{display:block;max-width:46rem;width:100%;margin:2rem auto;position:relative;z-index:5}
.btn-pill a,.btn-pill button{display:block;width:100%;padding:1.8rem 3rem;color:#fff;font-weight:700;font-size:1.6rem;line-height:1.5;text-align:center;text-decoration:none;border-radius:5rem;position:relative;z-index:1;transform:translate(0,0);transition:transform .3s;border:none;cursor:pointer}
.btn-pill::after{content:"";display:block;width:100%;height:100%;position:absolute;left:0;bottom:0;z-index:-1;transform:translate(.8rem,.8rem);border-radius:5rem}
.btn-pill:hover a,.btn-pill:hover button{transform:translate(.8rem,.8rem)}
/* Orange CTA */
.btn-orange a,.btn-orange button{background:var(--orange)}
.btn-orange::after{background-color:#b83a1c}
/* Blue CTA */
.btn-blue a{background:var(--blue-dark)}
.btn-blue::after{background-color:#003fb8}
/* Sky CTA (scroll down) */
.btn-sky a{background:var(--blue)}
.btn-sky::after{background-color:#dfdfdf}
/* Green WA */
.btn-green a{background:var(--green);display:flex;align-items:center;justify-content:center;gap:.8rem}
.btn-green::after{background-color:#1a9e4d}
.btn-green svg{width:2rem;height:2rem;fill:#fff;flex-shrink:0}

/* === TAGS (matching existing blue tags) === */
.tag{background:var(--blue);display:inline-block;padding:.6rem 1.2rem;margin:.3rem;font-weight:700;color:#fff;font-size:1.3rem;border-radius:2px}

/* ========================================
   HERO (matches existing: white bg, left text, right image area)
   ======================================== */
.hero{position:relative;overflow:hidden;padding:4rem 0 3rem;background:#fff;background: url(img/mv.png) no-repeat bottom center;background-size: cover;}
/* Orange diagonal decoration (right side) */
.hero::before{content:'';position:absolute;top:-10%;right:-5%;width:55%;height:120%;transform:skewX(-8deg);z-index:0;opacity:.08}
.hero::after{content:'';position:absolute;top:5%;right:2%;width:45%;height:90%;transform:skewX(-6deg);z-index:0;opacity:.06}
.hero-inner{position:relative;z-index:1;display:flex;align-items:center;gap:4rem}
.hero-text{flex:1;min-width:0}
.hero-image{width:42%;flex-shrink:0;position:relative}
.hero-image-placeholder{background:linear-gradient(135deg,#f0f0f0,#e0e0e0);border-radius:8px;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;color:#999;font-size:1.4rem;font-weight:700;position:relative;overflow:hidden;border:2px solid #eee}
.hero-image-placeholder::before{content:'';position:absolute;top:0;left:0;width:100%;height:4px;background:var(--orange)}

.hero-logo{margin-bottom:1.6rem}
.hero-logo img{max-width:24rem}
.hero-sponsor{font-size:1.1rem;color:#999;margin-bottom:.8rem}
.hero h1{font-size:3.2rem;font-weight:900;line-height:1.15;color:#333;margin-bottom:2rem}
.hero h1 .hl{color:var(--orange)}

/* KPI cards */
.kpi-row{display:flex;gap:1.4rem;margin:2.4rem 0}
.kpi-card{flex:1;background:rgba(0,161,240,.06);border-radius:6px;padding:1.8rem 1rem;text-align:center}
.kpi-val{font-size:3.2rem;font-weight:900;color:var(--orange);line-height:1.1}
.kpi-val sup{font-size:.5em}
.kpi-label{font-size:1.2rem;color:#555;margin-top:.3rem;font-weight: bold;}

.hero .sub-text{font-size:1.5rem;color:#555;line-height:1.8;margin-bottom:2rem}
.hero .tag-wrap{margin:1.6rem 0}

/* Hero CTA row */
.hero-ctas{display:flex;gap:1.4rem;flex-wrap:wrap;margin:2.4rem 0}
.hero-ctas .btn-pill{margin:0;max-width:28rem}

.trust-row{display:flex;gap:2rem;flex-wrap:wrap;font-size:1.2rem;font-weight:700;color:#666;margin-top:1.6rem}
.trust-row span{display:flex;align-items:center;gap:.4rem}
.trust-row span::before{content:"◆";font-size:.6rem;color:var(--orange)}

.hero-note{font-size:1rem;color:#aaa;line-height:1.5;margin-top:2rem}
.hero-scroll{margin-top:2rem}

/* ========================================
   SECTION HEADER (dark bg bar — existing pattern)
   ======================================== */
.sec-header{background:var(--dark);color:#fff;padding:5rem 2.4rem;text-align:center;position:relative;background: url(img/feature01.jpg) no-repeat center center;background-size: cover;}
.sec-header::before{content:'';position:absolute;inset:0;background:linear-gradient(-45deg,#2a2a2a 25%,#333 25%,#333 50%,#2a2a2a 50%,#2a2a2a 75%,#333 75%);background-size:20rem 20rem;opacity:.3}
.sec-header-inner{position:relative;z-index:1}
.sec-tag{display:inline-block;font-size:1.4rem;font-weight:700;color: #ffffff;background-color: #ea4c25;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1rem;padding: 1rem;}
.sec-header h2{font-size:clamp(2.4rem,3.5vw,3.6rem);font-weight:900;line-height:1.2;margin-bottom:1.4rem}
.sec-header p{font-size:1.5rem;color:#f5f5f5;max-width:68rem;margin:0 auto;line-height:1.7}

/* ========================================
   EX-CONTENTS (01, 02, 03 blocks)
   ======================================== */
.ex-list {
  display: grid;
  gap: 28px;
}

.ex-list,
.ex-list * {
  box-sizing: border-box;
}

.ex-block {
  position: relative;
  display: grid;
  grid-template-columns: 92px 1fr;
  background: #fff;
  border: 1px solid #e8edf3;
  overflow: hidden;
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.06);
}

.ex-block::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0) 55%, rgba(0, 161, 240, 0.03) 100%);
}

.ex-num {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 28px 10px;
  background: linear-gradient(180deg, #ea4c25 0%, #d8431e 100%);
}

.ex-num span {
  display: inline-block;
  font-size: clamp(2.4rem, 2vw, 3rem);
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.04em;
  color: #fff;
}

.ex-body {
  padding: clamp(24px, 3vw, 34px);
}

.ex-heading {
  margin-bottom: 18px;
  padding-bottom: 18px;
  border-bottom: 1px solid #edf2f7;
}

.ex-title {
  margin: 0;
  font-size: clamp(2rem, 2.4vw, 2.6rem);
  line-height: 1.2;
  font-weight: 800;
  letter-spacing: 0.01em;
  color: #1f2937;
}

.ex-subtitle {
  margin-top: 8px;
  font-size: 1.5rem;
  line-height: 1.6;
  font-weight: 700;
  color: #ea4c25;
}

.ex-panel {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  column-gap: 12px;
  padding: 6px 0px;
  margin-bottom: 14px;
  border: 1px solid transparent;
}

.ex-panel p {
  margin: 0;
  font-size: 1.6rem;
  line-height: 1.5;
  font-weight: 700;
  color: #1f2937;
}

.cost-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 32px;
  padding: 0 14px;
  white-space: nowrap;
  background: #fff;
  font-size: 1.2rem;
  font-weight: 800;
  line-height: 1;
}

.cost-tag--x {
  color: #fff;
  background: #ea4c25;
}

.cost-tag--ok {
  color: #fff;
  background: #00a1f0;
}

.ex-text {
  margin: 0 0 16px;
  font-size: 1.5rem;
  line-height: 1.95;
  color: #596474;
}

.ex-text:last-of-type {
  margin-bottom: 0;
}

/* ========================================
   CONCLUSION BOX (existing summary pattern)
   ======================================== */
.conclusion{background:#333;border-radius:0;padding:3.2rem;margin:4rem 0;text-align:center}
.conclusion-label{display:inline-block;background:var(--orange);color:#fff;font-size:1.4rem;font-weight:700;padding:.4rem 1.6rem;margin-bottom:1.4rem}
.conclusion h3{font-size:2.2rem;font-weight:900;color:#eee;line-height:1.4;margin-bottom:1.2rem}
.conclusion p{font-size:1.5rem;color:#eee;line-height:1.7}

/* ========================================
   PRODUCT SECTION (existing benefit-section pattern)
   ======================================== */
.products{padding:6rem 0;background:var(--gray-bg)}
.sec-title-center{text-align:center;margin-bottom:4rem}
.sec-title-center .sub{font-size:1.6rem;font-weight:700;color:var(--orange);letter-spacing:.1em;display:block;margin-bottom:.6rem}
.sec-title-center h2{font-size:clamp(2.4rem,3.5vw,3.2rem);font-weight:900;line-height:1.2}

.product-card{background:#fff;margin-bottom:4rem;overflow:hidden}
.product-card-header{background:var(--dark);padding:2rem 2.4rem;text-align: center;}
.product-card-header .label{
    margin-bottom: var(--s1);
    padding: 1.2rem;
    color: #fff;
    background: var(--site-color04);
    font-size: 1.8rem;
    line-height: 1;
    /* border-bottom: 5px solid #cf2e2e; */
    display: flex;
    justify-content: center;
    align-items: center;
    display: inline-block;
    font-weight: bold;
}
.product-card-header h3{font-size:2.4rem;font-weight:900;color:#fff;margin-top:.4rem;line-height:1.2}
.product-card-img{background:#eee;display:flex;align-items:center;justify-content:center;overflow:hidden;max-width: 75%;margin: 0 auto;}
.product-card-img img{width:100%;display:block}
.product-card-body{padding:2.4rem}
.product-card-body p{font-size:1.5rem;color:#555;line-height:1.7;margin-bottom:1.6rem}

/* Tag list (orange bg box with tags) */
.taglist-box{background:#efefef;padding:2rem;border-radius:0;margin:1.6rem 0}
.taglist-box h4{font-size:1.5rem;font-weight:700;text-align:center;margin-bottom:1rem}
.taglist{display:flex;gap:.8rem;flex-wrap:wrap;justify-content:center;list-style:none}
.taglist li{background:#fff;border:1px solid #eee;border-radius:4px;padding:.8rem 1.4rem;font-size:1.3rem;color:#555;text-align:center;line-height:1.3}

/* Spec table */
.spec-table{width:100%;border-collapse:collapse;margin:1.6rem 0}
.spec-table th{background:var(--dark);color:#fff;padding:1.2rem 1.6rem;font-weight:700;text-align:left;font-size:1.4rem;border:1px solid #555}
.spec-table td{padding:.8rem 1.6rem;border:1px solid #ccc;font-size:1.4rem}

/* Implementation list */
.impl-list{background:#fff;border:1px solid #eee;border-radius:0;padding:2rem 2.4rem;margin:1.6rem 0}
.impl-list h4{font-size:1.5rem;font-weight:700;margin-bottom:1rem}
.impl-list ul{list-style:none}
.impl-list li{font-size:1.4rem;color:#555;padding:.6rem 0 .6rem 2rem;border-bottom:1px solid #f0f0f0;position:relative;line-height:1.5}
.impl-list li::before{content:"▸";position:absolute;left:0;color:var(--orange);font-weight:700}

/* ========================================
   PROCESS STEPS
   ======================================== */
.process{padding:6rem 0;background:var(--dark);color:#fff}
.process h2{font-size:2.8rem;font-weight:900;text-align:center;margin-bottom:.6rem}
.process>div>p{text-align:center;color:#fff;font-size:1.4rem;margin-bottom:4rem}
.steps-row{display:flex;position:relative}
.steps-row::before{content:'';position:absolute;top:4rem;left:12%;right:12%;height:2px;background:linear-gradient(90deg,var(--orange),var(--blue),var(--orange));z-index:0}
.step{flex:1;text-align:center;position:relative;z-index:1}
.step-circle{width:8rem;height:8rem;border-radius:50%;background:#eee;border:3px solid var(--orange);display:flex;align-items:center;justify-content:center;margin:0 auto 1.2rem;font-size:2.8rem;font-weight:900;color:var(--orange)}
.step h4{font-size:1.4rem;font-weight:700;margin-bottom:.3rem;line-height: 1.2;}
.step p{font-size:1.1rem;color:#f5f5f5;padding:0 .6rem;line-height:1.3}
.process-badge{text-align:center;margin-top:3.6rem}
.process-badge span{display:inline-flex;align-items:center;gap:.8rem;background:#eee;border:1px solid var(--orange);border-radius:3rem;padding:1rem 2.4rem;font-size:1.5rem;font-weight:700;color:var(--orange)}

/* ========================================
   INCENTIVES
   ======================================== */
.incentives{padding:6rem 0;background:var(--gray-bg)}
.incentive-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:3rem}
.incentive-card{background:#fff;padding:2.8rem 2.4rem;border:1px solid #eee;border-top:4px solid var(--blue)}
.incentive-card .flag{font-size:2.8rem;margin-bottom:.8rem;display:block}
.incentive-card h3{font-size:2rem;font-weight:900;margin-bottom:1.2rem}
.incentive-card ul{list-style:none}
.incentive-card li{font-size:1.4rem;color:#555;padding:0;border-bottom:1px solid #f0f0f0;display:flex;align-items:flex-start;gap:.8rem;line-height:1.45}
.incentive-card li::before{content:"✓";color:#27ae60;font-weight:700;flex-shrink:0}
.incentive-note{text-align:center;margin-top:2.4rem;font-size:1.4rem;color:#666;font-style:italic}

/* ========================================
   CTA / FORM
   ======================================== */
.cta-section{padding:6rem 0;background:linear-gradient(160deg,#1a2d44,#0c1623)}
.cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:4.8rem;align-items:start}
.cta-text{color:#fff}
.cta-text h2{font-size:2.8rem;font-weight:900;line-height:1.2;margin-bottom:1.2rem}
.cta-text>p{font-size:1.5rem;color:#8a9bb5;margin-bottom:2rem;line-height:1.7}
.cta-list{list-style:none;margin-bottom:2rem}
.cta-list li{font-size:1.4rem;color:#ddd;padding:.7rem 0;display:flex;align-items:center;gap:1rem}
.cta-list li::before{content:"✓";font-weight:700;color:var(--orange);width:2.2rem;height:2.2rem;background:rgba(234,76,37,.12);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.2rem}
.form-box{background:#ffffff;border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:0rem 1rem}
.form-box h3{font-size:2rem;font-weight:900;color:#fff;margin-bottom:2rem}
.fg{margin-bottom:1.4rem}
.fg label{display:block;font-size:1.2rem;font-weight:700;color:#8a9bb5;margin-bottom:.4rem;letter-spacing:.03em}
.fg input,.fg select{width:100%;padding:1rem 1.4rem;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:4px;color:#eee;font-size:1.4rem;font-family:inherit}
.fg input:focus,.fg select:focus{outline:none;border-color:var(--orange)}
.fg select option{background:#1a2d44;color:#eee}
.form-submit{width:100%;padding:1.6rem;margin-top:.8rem;background:var(--orange);color:#fff;font-size:1.6rem;font-weight:700;border:none;border-radius:5rem;cursor:pointer;transition:opacity .3s}
.form-submit:hover{opacity:.85}

/* ========================================
   FAQ (existing details pattern)
   ======================================== */
.faq-section{max-width:100rem;margin:4rem auto;padding:2rem 2.4rem}
.faq-main-title{font-size:2.8rem;font-weight:900;text-align:center;margin-bottom:3rem}
.faq-item{border:1px solid #e0e0e0;margin-bottom:1.2rem}
.faq-item summary{padding:1.8rem 2rem;cursor:pointer;background:var(--gray-light);list-style:none;display:flex;justify-content:space-between;align-items:center;font-size:1.6rem;font-weight:700;line-height:1.4;transition:background .2s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:2.2rem;color:var(--orange);flex-shrink:0;margin-left:1rem;transition:transform .3s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item[open] summary{background:#eee}
.faq-item .faq-body{padding:2rem;border-top:1px solid #e0e0e0;font-size:1.4rem;color:#555;line-height:1.8}
.faq-item .faq-body p{margin-bottom:.8rem}
.faq-item .faq-body ul{margin:.8rem 0 .8rem 2rem;list-style:disc}
.faq-item .faq-body li{margin-bottom:.4rem}

/* ========================================
   FOOTER
   ======================================== */
.footer{padding:4rem 0;background:var(--gray-light);border-top:1px solid #eee;text-align:center}
.footer p{font-size:1.2rem;color:#999;line-height:1.6}
.footer a{color:#666}

/* ========================================
   WHATSAPP FLOATING
   ======================================== */
.wa-float{position:fixed;bottom:2rem;right:2rem;width:5.6rem;height:5.6rem;background:var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(37,211,102,.4);z-index:1000;animation:waPulse 2s infinite}
.wa-float:hover{opacity:1;transform:scale(1.08);box-shadow:0 6px 24px rgba(37,211,102,.6)}
.wa-float svg{width:2.8rem;height:2.8rem;fill:#fff}
@keyframes waPulse{0%,100%{box-shadow:0 4px 16px rgba(37,211,102,.4)}50%{box-shadow:0 4px 28px rgba(37,211,102,.7)}}

/* ========================================
   RESPONSIVE
   ======================================== */
@media(max-width:768px){
  html{font-size:2.6666666667vw}
  .hero-inner{flex-direction:column}
  .hero-image{width:100%;order:-1}
  .hero h1{font-size:2.4rem}
  .kpi-row{flex-direction:column}
  .hero-ctas{flex-direction:column}
  .hero-ctas .btn-pill{max-width:100%}
  .ex-block{flex-direction:column}
  .ex-num{flex:none;padding:1.2rem;flex-direction:row;justify-content:flex-start;gap:1rem}
  .incentive-grid{grid-template-columns:1fr}
  .cta-grid{grid-template-columns:1fr}
  .steps-row{flex-direction:column;gap:2rem}
  .steps-row::before{display:none}
  .trust-row{flex-direction:column;gap:.4rem}
  .pc_br{display:none}.sp_br{display:inline}
  .product-card-header h3{font-size:1.8rem}
}

/*----------------------------------------------------
    PCサイトcss
----------------------------------------------------*/
@media screen and (min-width: 768px) {

.image-wrap {
  display: flex;
  gap: 20px;

  align-items: flex-start;
  flex-wrap: wrap; 
  margin: 20px 0;
}

.image-wrap figure {
  text-align: center;
  max-width: 300px;
}

.image-wrap img {
  width: 100%; 
  height: auto;
  border-radius: 4px;
}

}


/*----------------------------------------------------
    SPサイトcss
----------------------------------------------------*/
@media screen and (max-width: 767px) {
/*/////////////SP用のCSSをここに作成してください。/////////////*/
/*/////////////必ず中括弧の中に作成してください。/////////////*/
section.faq-container {
    margin-top: 4rem;
}

.faq-summary h4 {
    font-size: 1.6rem;
    line-height: 1.4;
}

.faq-main-title {
    font-size: 2.4rem;
}

.faq-summary {
    padding: 1.5rem 2rem;
}
.faq-content p {
    font-size: 1.4rem;
}
	
.pc-fix-banner04 {
    display: block;
    width: 100%;
    bottom: 0;
    text-align: center;
}
.l-stack-small {
    margin: 0 auto;
}
.pc-fix-banner04-color2.pc-fix-banner04-text {
    display: none;
}
.footer-copyright {
    padding-bottom: 100px;
}

section.intro-section {
    margin-top: 22rem;
}	

.tag {
    display: inline-block;
    margin: 0.4rem;
}	

.l-center.top {
    margin-top: 23rem;
}
	
.ex-panel {
    display: block;
}
	
	
}






/*
---------------------------------------------

    Translate Press settings

*/

html[lang="en"], html[lang="en-US"] {

	
.tag.invisible {
    display: none;
}		
	
	
	
}		
	
	
	
	
html[lang^="en"] .only-en {
  display: block;
  background: #fff;
}	
	
html[lang^="en"] .only-jp {
  display: none;
}	
	
	
	/*----------------------------------------------------
    SPサイトcss
----------------------------------------------------*/
@media screen and (max-width: 767px) {
/*/////////////SP用のCSSをここに作成してください。/////////////*/
/*/////////////必ず中括弧の中に作成してください。/////////////*/

section.index-section {
    margin: 6rem auto -4rem;
}

.tag.invisible {
    display: none;
}	

}

	
	
	
	
	
	
	
	
  }

/*----------------------------------------------------
    共通css
----------------------------------------------------*/

h2 a, h3 a, h4 a, h5 a, .caption a {
    pointer-events: none !important;
    background-image: none !important;
    text-decoration: none !important;
}
h2 a:after, h3 a:after, h4 a:after, h5 a:after {
    display: none !important;
}
#contents .btn-internal a {
    display: none;
}
#contents .btn-internal.down a {
    display: block;
}
#contents .btn-internal.up a {
    display: block;
}
.blind {
    display: none;
}


/*----------------------------------------------------
    PCサイトcss
----------------------------------------------------*/
@media screen and (min-width: 600px) {
/*/////////////PC用のCSSをここに作成してください。/////////////*/



}/*////////////////////PC用CSSここまで///////////////////*/



/*----------------------------------------------------
    SPサイトcss
----------------------------------------------------*/
@media screen and (max-width: 599px) {
/*/////////////SP用のCSSをここに作成してください。/////////////*/

section.hero.show {
    background: url(https://www.pla-mirai.net/twinscrew-extruder/wp/wp-content/themes/sd-1/img/mv.png);
    background-size: 100%;
    background-repeat: no-repeat;
    margin-top: 3rem;
}

.hero-logo img {
    max-width: 70%;
    margin-bottom: 2rem;
}

.header-title {
    line-height: 1.3;
}

.l-center {
    padding: 0 1.5rem;
}

}/*////////////////////SP用CSSここまで///////////////////*/