/* --- Global Settings & Variables --- */
:root{
  --primary-color:#0052cc;
  --accent-color:#ff7f50;
  --text-dark:#343a40;
  --text-light:#6c757d;
  --bg-light-gray:#f8f9fa;
  --white:#ffffff;
  --border-color:#dee2e6;
  --font-family:'Noto Sans JP',sans-serif;
  --bg-flow: var(--bg-light-gray);
}

#PLATE{
    margin-right: auto!important;;
}

#MAIN section:nth-child(1){
	padding:0px!important;
}
#MAIN section:nth-child(2){
	padding:0px!important;
}

/* Reset */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:100%}
body{font-family:TazuganeGothicStdN-Light!important;line-height:1.8;color:var(--text-dark);background:var(--white);font-size:1rem}
.container{max-width:1100px;margin:0 auto;padding:0 16px}
section{padding:80px 0}
h1,h2,h3,h4{font-weight:700;line-height:1.5}
h2{/*font-size:2rem;*/font-size:18px;text-align:center;margin-bottom:30px}
p{margin-bottom:1rem}
.sp-only{display:none}
strong{font-weight:900}
.sp-br {display: none;}
.mobile-br {display: none;}

/* Main Header */
.main-header {
  background-color: var(--white);
  padding: 15px 0;
  border-bottom: 1px solid var(--border-color);
}

.header-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
  display: flex;
  align-items: center;
  gap: 15px;
}

.header-logo {
  height: 40px;
  width: auto;
}

.header-text {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--primary-color);
}

/* Buttons */
.btn{display:inline-block;padding:12px 28px;border-radius:50px;text-decoration:none;font-weight:700;transition:.3s;border:2px solid transparent;cursor:pointer;text-align:center;font-size:16px;}
.btn-main{background:var(--accent-color)!important;color:var(--white)!important;padding:18px 45px!important;/*font-size:1rem;*/font-size:16px;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;text-align:center;}
.btn-main:hover{background:#e66a3d;transform:translateY(-2px);box-shadow:0 4px 15px rgba(0,0,0,.1)}
.btn-sub{background:var(--white)!important;color:var(--accent-color)!important;border:2px solid var(--accent-color)!important;padding:13px 40px!important;font-size:16px!important;}
.btn-sub:hover{background:var(--accent-color)!important;color:var(--white)!important;font-size:16px!important;}

/* Hero */
/*
  新しいヒーローセクションでは、全幅の見出しの下に左右2カラムを配置します。
  左カラムにはダッシュボード画像、右カラムには説明文とCTAを設置し、ブランドロゴは上部に表示します。
*/
.hero {
  position: relative;
  min-height: 90vh;
  padding: 0px 16px 16px 16px; /* Adjusted padding to 16px all around */
  display: flex;
  align-items: center;
  background-image: url('/wp-content/themes/coresys/surimun/images/hero-background.gif');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  overflow: hidden;
}
.hero::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  /* うっすら白をかけて背景GIFの視認性を高める */
  background-color: rgba(255, 255, 255, 0.85);
  z-index: 0;
}
.hero-container {
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
  position: relative;
  z-index: 1;
}
.hero-brand {
  margin-bottom: 160px;
}

/* “塊”のスケール制御（最小/理想/最大） */
.brand-scale{
  font-size: clamp(12px, 3vw, 24px);
  display: inline-flex;
  align-items: center;
  gap: 1em;
}

/* 以降はすべて em で指定（brand-scale の font-size を基準に等倍で動く） */
.brand-scale .hero-logo{ height: 8em; width: auto; }
.brand-scale .header-text{ font-size: 1.6em; font-weight: 700; line-height: 1.3; }
.brand-scale .jiima-group{ display: inline-flex; align-items: center; gap: .6em; }
.brand-scale .jiima-icon{ height: 3em; width: auto; }
.brand-scale .jiima-text{ font-size: 1em; font-weight: 700; }
.text-jiima-block{ display: flex; flex-direction: column; gap: 0.5em; }

/* 既存の固定値は無効化 or 上書き */
.hero-logo{ height: auto; }
.jiima-icon{ height: auto; }
.hero-brand .header-text{ font-size: inherit; }
.hero h1 {
  font-size: 18px;
  font-weight: 900!important;
  line-height: 1.3;
  margin-bottom: 40px;
  text-align: center;
  color: var(--text-dark);
  background-color:transparent!important;
}
.hero-content-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0px;
  padding: 0 16px;
}
.hero-left {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
}
.hero-left p {
/*
  font-size: 1.2rem;
*/
  font-size: 16px;
  color: var(--text-dark);
  margin-bottom: 16px;
  line-height: 1.8;
}
.hero-left .btn {
  margin-top: 10px;
}



/* 右側はダッシュボード画像を配置 */
.hero-right {
  flex: 1;
  text-align: center;
}
.hero-right img {
  width: 100%;
  max-width: 500px;
  height: auto;
  margin: 0 auto;
}

/* Problem */
.problem{background:var(--bg-light-gray)}
.problem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;}
.problem-grid p{font-size:16px!important;}
.problem-card{background:var(--white);padding:16px;border-radius:8px;box-shadow:0 4px 15px rgba(0,0,0,.05);}
.problem-card-header{display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.problem-card img{
  /* アイコンサイズ統一：64pxの正方形 */
  width:64px;
  height:64px;
  margin-right:15px;
  object-fit:contain;
}
.problem-card h3{/*font-size:1.125rem;*/font-size:16px;font-weight:700;color:var(--primary-color);margin-bottom:0}
.problem-card p{text-align:center}

/* Declaration */
.solution-declaration {
  padding: 80px 0;
  background: var(--white);
  text-align: center;
}
.solution-declaration h2{/*font-size:clamp(1.2rem, 4vw, 2rem);*/font-size:18px;margin-bottom:16px}
.solution-declaration h2 .nowrap-line { white-space: nowrap; display: inline-block; }
.solution-declaration p{/*font-size:1.125rem;*/font-size:16px;max-width:800px;margin:0 auto!important;color:var(--text-light);float:none!important;}

/* How to solve */
.how-to-solve {
  /* background-color: var(--white); */
  background-color: #f7faff;;
  padding-top: 0;
  padding-bottom: 50px;
  counter-reset: solve-item-counter; /* Added */
}
.how-to-solve .solve-header {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 16px;
}
.how-to-solve .solve-logo {
  width: 200px;
  height: auto;
  margin: 16px;
}

.how-to-solve h2 {
  font-size: 2rem;
  margin-bottom: 0;
  text-align: center;
}
.how-to-solve .solve-intro {
  font-size: 1.1rem;
  color: var(--text-light);
  max-width: 800px;
  margin: 0 auto 16px;
  line-height: 1.8;
  text-align: center;
}
.solve-title-group {
  margin-bottom: 0px; /* Increased from 100px */
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
}
.how-to-solve .solve-main-title {
/*
  font-size: 1.75rem;
*/
  font-size:18px;
  color: var(--primary-color);
  font-weight: 700;
  margin-bottom: 0; /* Reset margin */
  display: inline-block; /* To respect parent's text-align */
}
.how-to-solve h2,
.how-to-solve h3 {
  line-height: 1.4;
}
.solve-item{
  display:flex;
  align-items:stretch;
  gap:50px;
  margin-bottom:50px;
  background-color: var(--white); /* Added */
  border: 1px solid var(--border-color); /* Added */
  border-radius: 8px; /* Added */
  padding: 40px; /* Added */
  position: relative; /* Added for numbering */
  box-shadow: 0 4px 15px rgba(0,0,0,.05); /* Added */
}
.solve-item:last-child{margin-bottom:0}
.solve-item.reverse{flex-direction:row-reverse}
.solve-text,.solve-visual{flex:1;display:flex;flex-direction:column;justify-content:center;}
.solve-visual img{width:100%;border-radius:8px;box-shadow:0 8px 25px rgba(0,0,0,.1)}
.solve-title { display: flex; align-items: center; margin-bottom: 1rem; }
.solve-text p{
	font-size:16px!important;
}

.solve-label-problem, .solve-label-solution {
  font-weight: 700;
  padding: 0.25em 0.75em;
  border-radius: 4px;
  margin-right: 1em;
  color: var(--white);
  flex-shrink: 0;
  font-size:16px!important;
}
.solve-label-problem { background-color: var(--text-light); }
.solve-label-solution { background-color: var(--primary-color); }
.solve-heading {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.6;
}
.solve-text ul{list-style:none;padding-left:0;margin-top:16px}
.solve-text li{font-weight:700;margin-bottom:10px;display:flex;align-items:center;font-size:16px!important;}
.solve-text li i{color:var(--primary-color);margin-right:10px;width:16px;text-align:center}

/* Step flow */
.step-flow{display:flex;flex-direction:column;gap:16px}
.step-card{background:var(--white);border-left:5px solid var(--primary-color);padding:16px;border-radius:8px;box-shadow:0 4px 15px rgba(0,0,0,.05);position:relative}
.step-card:not(:last-child)::after{content:'\f078';font-family:'Font Awesome 6 Free';font-weight:900;color:var(--primary-color);position:absolute;left:50%;bottom:-25px;transform:translateX(-50%);font-size:1.2rem}
.step-card-header { display: flex; align-items: center; gap: 0.8em; margin-bottom: 10px; }
.step-label{color:var(--primary-color);font-weight:700;font-size:18px!important;}
.step-title{/*font-size:1.5rem;*/font-size:18px;font-weight:900;}
.step-description{color:var(--text-light);font-size:.9rem}

/* Consulting */
/* セクション背景と余白 */
.consulting{
  background:#fff;
  padding-top:80px;
  padding-bottom:80px;
}
/* 3本柱のレイアウト */
.consulting-pillars{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:40px;
}
.consulting-pillars .pillar{
  background:var(--bg-light-gray);
  border:1px solid var(--border-color);
  border-radius:12px;
  padding:24px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
}
.pillar-header {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-bottom: 12px;
}
.consulting-pillars .pillar img{
  width:64px;
  height:64px;
  margin-bottom:0;
  flex-shrink:0;
}
.consulting-pillars .pillar h3{
/*
  font-size:1.2rem;
*/
  font-size:16px;
  margin-bottom:0;
  color:var(--text-dark);
  line-height:1.4;
}
.consulting-pillars .pillar ul{
  list-style:disc;
  margin-left:1em;
  padding-left:0;
  color:var(--text-dark);
}
.consulting-pillars .pillar li{
  margin-bottom:.4rem;
/*
  font-size:.95rem;
*/
  font-size:16px;
  line-height:1.5;
}
/* 補助バナー */
.consulting-note{
  display:flex;
  align-items:center;
  gap:16px;
  background:var(--white);
  border:1px dashed var(--border-color);
  border-radius:12px;
  padding:16px 16px;
  margin-top:30px;
  box-shadow:0 4px 15px rgba(0,0,0,.05);
}
.consulting-note img{
  width:64px;
  height:64px;
}
.consulting-note p{
  margin:0!important;
/*
  font-size:1rem;
*/
  font-size:16px;
  color:var(--text-dark);
  line-height:1.6;
}

/* Proof */
.proof{
  /* background:var(--bg-light-gray); */
  background:#f7faff;
  padding-top:100px;
  padding-bottom:100px;
}
/* 証言の横長ボックス */
.proof-boxes{
  display:flex;
  flex-direction:column;
  gap:30px;
  margin-bottom:80px;
}
.proof-boxes p{
	font-size:16px!important;
}

.proof-box{
  display:flex;
  align-items:flex-start;
  gap:16px;
  background:var(--white);
  border:1px solid var(--border-color);
  border-radius:12px;
  padding:24px;
  box-shadow:0 4px 15px rgba(0,0,0,.05);
}
.proof-image img{
  width:160px;
  height:116px;
  border-radius:12px;
  object-fit:cover;
  flex-shrink:0;
}
.proof-content h3{
/*
  font-size:1.25rem;
*/
  font-size:18px;
  color:var(--primary-color);
  margin-bottom:5px;
}
.proof-content .company-name{
  font-weight:700;
  color:var(--text-light);
  font-size:.875rem;
  margin-bottom:12px;
}
.proof-content p{
  margin-bottom:0.5rem;
  line-height:1.6;
}
.proof-points{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}
.proof-points p{
	font-size:16px;
}
.proof-point-card{
  background:var(--white);
  padding:16px;
  border-radius:8px;
  text-align:center;
  box-shadow:0 4px 15px rgba(0,0,0,.05);
}
.proof-point-card i{
  font-size:2.5rem;
  color:var(--accent-color);
  margin-bottom:15px;
}
.proof-point-icon {
  height: 2.5rem;
  margin-bottom: 8px;
  vertical-align: bottom;
  display:inline;
}

/* Pricing */
.pricing-intro {
  padding-bottom: 16px;
/*
  font-size:23.4px
*/
  font-size:18px;
}
.pricing-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-bottom:40px}
.pricing-card{border:2px solid var(--primary-color);border-radius:8px;padding:30px;text-align:center;position:relative;display:flex;flex-direction:column;transition:.3s}
.pricing-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px rgba(0,0,0,.1)}

.popular-badge{position:absolute;top:-15px;left:50%;transform:translateX(-50%);background:var(--primary-color);color:var(--white);padding:5px 15px;border-radius:50px;font-size:.875rem;font-weight:700}
.pricing-card h3{/*font-size:1.375rem;*/font-size:18px;margin-bottom:10px}
.pricing-card .plan-description{font-size:.875rem;color:var(--text-light);flex-grow:1}
.price{margin:16px 0;font-size:18px;}
.price-original{text-decoration:line-through;color:var(--text-light)}
.price-label{display:block;font-size:.875rem;margin-top:10px}
.price-final{/*font-size:2.25rem;*/font-size:18px;font-weight:900;color:var(--accent-color)}
.price-unit{font-size:1rem;font-weight:700}
.pricing-card .btn{margin-top:auto}

.pricing-notes {
  margin-top: 40px;
  font-size: 0.9rem;
  color: var(--text-light);
  text-align: left;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
  border-left: 3px solid var(--border-color);
  padding-left: 15px;
}
.pricing-notes p {
  margin-bottom: 0.5rem;
  text-indent: -1em;
  padding-left: 1em;
  float:none!important;
}
.pricing-notes .no-break-prefix {
  white-space: nowrap;
}
.pricing-notes p:last-child {
  margin-bottom: 0;
}

.btn-toggle{display:block;margin:40px auto;background:var(--bg-light-gray);color:var(--text-dark);border-color:var(--border-color)}
.btn-toggle:hover{background:var(--border-color)}
.all-plans-container{max-height:0;overflow:hidden;transition:max-height .5s ease-out}
.all-plans-container.show{max-height:1000px;overflow-x:auto;margin-top:40px}
.styled-table{width:100%;min-width:800px;border-collapse:collapse;font-size:.875rem;border:1px solid var(--border-color);box-shadow:0 4px 15px rgba(0,0,0,.05)}
.styled-table th,.styled-table td{padding:12px 15px;border:1px solid var(--border-color);text-align:center;white-space:nowrap}
.styled-table thead tr{background:var(--primary-color);color:var(--white)}
.styled-table tbody tr{background:var(--white)}
.competitor-comparison{margin-top:100px}
.competitor-comparison h3{text-align:center;margin-bottom:30px;font-size:1.5rem}
.competitor-comparison .advantage{font-weight:700;color:var(--accent-color)}
/* 比較表のタグラインを洗練されたカード風に */
.comparison-caption{
  display:block;
  background-color: var(--white);
  border-left:4px solid var(--primary-color);
  border-radius:6px;
  padding:24px;
  margin-top:30px;
  font-size:1.1rem;
  line-height:1.8;
  color:var(--text-dark);
  box-shadow:0 4px 15px rgba(0,0,0,0.05);
  text-align:left;
}
/* 強調文の色を統一 */
.comparison-caption .advantage{
  color: var(--accent-color);
  font-weight: 700;
}

/* Flow */
.flow{
  background: var(--bg-flow);
  padding: 80px 0;
  border-top: 1px solid var(--border-color);
  margin-top: 60px;
}
.flow-steps{
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.flow-step{
  text-align: center;
  width: 22%;
}
.flow-step .step-number{
  font-weight: 900;
  color: var(--primary-color);
/*
  font-size: 1.125rem;
*/
 font-size:18px;
  margin-bottom: 0px;
}
.flow-step i{
/*
  font-size: 2.5rem;
*/
 font-size:18px;
  color: var(--primary-color);
  margin: 10px 0;
}
.flow-step h4{
/*
  font-size: 1.125rem;
*/
  font-size:18px!important;
  margin-bottom: 5px;
  color: var(--text-dark);
}
.flow-step p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--text-light);
  line-height: 1.6;
}
.flow-step-arrow{
  align-self: center;
  font-size: 1.5rem;
  color: var(--border-color);
  transform: translateY(15px);
}

/* Contact */
.contact{background:var(--primary-color);color:var(--white);padding:80px 0}
.contact h2,.contact p{text-align:center;color:var(--white)}
.contact p{max-width:800px;margin-left:auto;margin-right:auto;margin-bottom:40px}
.contact-form{max-width:600px;margin:0 auto;background:var(--white);padding:40px;border-radius:8px;color:var(--text-dark)}
.form-group{margin-bottom:16px}
.form-group label{display:block;margin-bottom:5px;font-weight:700}
.form-group input[type="text"],.form-group input[type="email"]{width:100%;padding:12px;border-radius:5px;border:1px solid var(--border-color);font-size:1rem}
.checkbox-group{display:flex;flex-wrap:wrap;gap:15px}
.checkbox-group label{display:flex;align-items:center;gap:5px;font-weight:400}
.contact-form .btn-main{width:100%;font-size:1.125rem}

/* Footer */
footer{background:var(--text-dark);color:var(--white);padding:16px 0;text-align:center;font-size:.875rem}

/* FAQ セクションのデザイン */
.faq {
  background: var(--white); /* Changed to white for better contrast */
  padding: 80px 0;
}

.faq-container {
  max-width: 800px;
  margin: 0 auto;
}

.faq-item {
  background: var(--white);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  margin-bottom: 10px;
}

.faq-item summary {
  font-weight: 700;
/*
  font-size: 1.1rem;
*/
  font-size:18px;
  cursor: pointer;
  padding: 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  list-style: none; /* Remove default marker */
  width: 100%;
}

.faq-item summary::-webkit-details-marker {
  display: none; /* Hide default marker for Chrome/Safari */
}

.faq-item summary:hover {
  color: var(--primary-color);
  font-size:18px!important;
}

.faq-item summary::after {
  content: '\f054'; /* Font Awesome chevron-right */
  font-family: 'Font Awesome 6 Free';
  font-weight: 900;
  color: var(--primary-color);
  transition: transform 0.2s ease-in-out;
  font-size: 0.9rem;
  margin-left: 1rem;
}

.faq-item[open] > summary::after {
  transform: rotate(90deg);
}

.faq-content {
  padding: 0 16px 16px 16px;
  color: var(--text-light);
  line-height: 1.8;
}

.faq-content p {
  margin: 0!important;
  font-size:16px!important;
  float:none!important;
}

/* Responsive */
@media (max-width:992px){
  /* ヒーローセクションのレイアウト調整 */
  .hero {
    padding: 16px 16px; /* Adjusted padding-top for mobile */
  }
  .hero-content-row {
    flex-direction: column;
    align-items: center;
    gap: 30px;
  }
  .hero-left, .hero-right {
    width: 100%;
    text-align: center;
  }
  .hero-left {
    align-items: center;
  }
  .hero-right {
    align-items: center;
  }
  .hero-right p {
    text-align: center;
  }
  .cta-buttons {
    justify-content: center;
  }
  .solve-item,.solve-item.reverse{flex-direction:column;gap:0}
  .solve-visual{margin-top:30px;width:100%}
  .testimonials{grid-template-columns:1fr}
  .proof-points{grid-template-columns:1fr}

  .pricing-cards {
    display: flex;
    overflow-x: auto;
    white-space: nowrap;
    gap: 16px;
    padding-bottom: 16px;
    padding-top: 16px; /* Badge fix */
    margin-bottom: 16px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .pricing-cards::-webkit-scrollbar {
    display: none;
  }
  .pricing-cards .pricing-card {
    flex: 0 0 80%;
    min-width: 280px;
  }

  .proof-point-card{margin-bottom:10px}
  .flow-steps{flex-direction:column;align-items:stretch;gap:0px}
  .flow-step{
    width:100%;
    margin-bottom:0;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 16px;
    background: var(--white);
    box-shadow: 0 4px 15px rgba(0,0,0,.05);
  }
  .flow-step-arrow{
    transform:rotate(90deg);
    align-self: center;
    color: var(--text-light);
    margin: 0;
  }
  .consulting-pillars{grid-template-columns:1fr}
}
@media (max-width:768px){
  .mobile-br {display: initial;}
  .sp-only{display:block}
  .pc-br {display: none;}
  .sp-br {display: initial;}
  .hero h1{font-size:1.3rem}
  .hero h2{font-size:1.2rem}

  /* Mobile Heading Font Size Adjustments */
  h2 { font-size: 1.2rem; }
  h3 { font-size: 1.1rem; }
  h4 { font-size: 1.0rem; }

  .hero-brand .header-text {
    font-size: 1.0rem;
  }

  .solve-title-group {
    display: flex;
    align-items: center;
    /* gap: 4px; */
    margin-bottom: 10px;
    text-align: left;
  }
  .solve-title-group .solve-logo {
    width: 80px;
    flex-shrink: 0;
  }
  .step-card {
    padding: 10px;
  }
  .step-label,
  .step-title {
    font-size: 1.05rem;
  }

  .problem-card-header {
    justify-content: flex-start;
    margin-bottom: 0px;
  }

  

  .problem-grid{grid-template-columns:1fr}
  .testimonial-card{flex-direction:column;align-items:center;text-align:center}
  .step-card:not(:last-child)::after{bottom:-28px}

  .proof-box {
    flex-direction: column;
    padding: 24px;
    gap: 1rem;
  }
  .proof-content {
    display: contents;
  }
  .proof-box h3 {
    order: 1;
    margin: 0;
  }
  .proof-box .company-name {
    order: 2;
    margin: 0;
  }
  .proof-image {
    order: 3;
    margin: 0;
    width: 100%;
  }
  .proof-image img {
      width: 100%;
      height: auto;
      border-radius: 12px;
  }
  .proof-content p:last-child {
    order: 4;
    margin: 0;
  }

  .proof-point-card {
    display: grid;
    grid-template-columns: auto 1fr; /* icon and content */
    grid-template-rows: auto auto; /* heading and paragraph */
    gap: 0 15px; /* row gap 0, column gap 15px */
    align-items: center;
    text-align: left; /* Ensure text is left-aligned */
  }
  .proof-point-card > i,
  .proof-point-card > img {
      grid-row: 1 / 3; /* span both rows */
      margin-bottom: 0; /* remove default margin */
  }
  .proof-point-card > h4 {
      grid-column: 2;
      grid-row: 1;
      margin: 0;
  }
  .proof-point-card > p {
      grid-column: 2;
      grid-row: 2;
      margin: 0;
  }

  .flow-step {
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 15px;
    text-align: left;
  }
  .flow-step .step-number {
    white-space: nowrap;
  }
  .flow-step-text h4,
  .flow-step-text p {
    margin: 0;
  }
  .flow-step-text h4 {
    margin-bottom: 5px;
  }

  .pricing-intro {
    font-size: 1rem;
  }

  .header-text { /* Added for mobile font size */
    font-size: 1rem;
  }

  .solution-declaration h2 {
    font-size: 1.3rem;
  }
  .how-to-solve .solve-main-title {
    font-size: 1.1rem;
  }
  .solve-label-problem, .solve-label-solution {
    font-size: 1rem;
  }

  .solve-heading {
    font-size: 1.05rem;
  }

  .hero-brand {
    margin-bottom: 80px;
  }
  .hero-logo {
    height: 100px;
  }
  .jiima-text {
    font-size: 0.9rem;
  }
  .hero-left p {
    font-size: 1rem;
  }
  .btn-main {
    min-width: 280px;
    padding: 10px;
  }
  .problem-card {
    padding: 10px;
  }
  .problem-grid {
    gap: 15px
  }
  .solution-declaration p {
    font-size: 1rem;
  }
  .solve-title-group {
    gap: 0;
  }
  .solve-item {
    padding: 12px;
  }
  .proof-content h3 {
    font-size: 1.15rem;
  }

  .how-to-solve .solve-logo {
    margin: 10px;
  }

}


/* New Competitor Table Styles */
/* 読みやすい比較テーブルスタイル */
.competitor-table thead th {
  background-color: #f8f9fa;
  color: var(--text-dark);
  font-weight: 700;
}
/* すりむん列だけ少し強調した色使い */
.competitor-table th.surimun-col {
  background-color: #e7f1ff;
  color: var(--primary-color);
  font-weight: 900;
}
/* 左端の機能列は太字 & 背景を揃える */
.competitor-table th:first-child,
.competitor-table td:first-child {
  text-align: left;
  background-color: #f8f9fa;
  font-weight: 700;
  position: sticky;
  left: 0;
  z-index: 1;
}

/* すりむん列のデータセルも強調色 */
.competitor-table td.surimun-col {
  font-weight: 900;
  color: var(--primary-color);
}

/* PC Font Size Overrides */
@media (min-width: 992px) {
  .brand-scale .header-text {
    font-size: 1.8rem;
  }
  .brand-scale .jiima-text {
/*
    font-size: 1.3rem;
*/
    font-size: 18px;
  }
}
#contact{
	display:none;
}
h3{
	background-color:transparent!important;
}
h4{
	font-size:16px!important;
}

#MAIN {
	min-height:auto!important;
}
.Style_global-footer__heYVR{
	top:0px!important;
}