/*
Theme Name: Arkhe Child
Template: arkhe
Version: 1.0
*/

body { font-family: "Noto Sans JP"; }

/* 親要素でflex指定 */
.reversebox {
 display: flex;
}

/* 幅600px以下は縦向き表示にする設定 */
@media screen and (max-width: 600px) {
 .reversebox {
  flex-direction: column;
 }
}

/* 子要素に縦向きの際の並び順を指定 */
@media (max-width: 600px) {
.order1 {
  order: 1;
}
.order2 {
  order: 2;
}
}


/*.bg_title {
	display: inline-block;
  position: relative;
  height: 75px;
  margin-right: 100px;
  padding: 1.5rem 2rem 0 2rem;
  word-break: break-all;
  color: #fff;
  background: #000;
}

.bg_title:after {
  position: absolute;
  top: 0;
  right: -55px;
  width: 0;
  height: 0;
  content: '';
  border-width: 75px 55px 0 0;
  border-style: solid;
  border-color: #000 transparent transparent transparent;
}

.bg_title01 {
	display: inline-block;
  position: relative;
  height: 75px;
  margin-right: 100px;
  padding: 1.5rem 2rem 0 2rem;
  word-break: break-all;
  color: #fff;
  background: #ffd400;
}

.bg_title01:after {
  position: absolute;
  top: 0;
  right: -55px;
  width: 0;
  height: 0;
  content: '';
  border-width: 75px 55px 0 0;
  border-style: solid;
  border-color: #ffd400 transparent transparent transparent;
}
*/

.fluid-box{
 width: 100vw;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    background-color: #ddd;
    padding: 40px;
}
.fluid-box-inner{
 margin: 0 auto;
 padding: 25px;
 background-color: #000;
}

h2{
font-size:1.4em !important;
}

/* LP web support */

/* ==============================
LP BASE
============================== */

.lp-section{
padding:100px 20px;
}

.lp-section h2{
text-align:center;
font-size:32px;
margin-bottom:10px;
}

/* ==============================
HERO
============================== */

.lp-hero{
background-image:url("https://images.unsplash.com/photo-1498050108023-c5249f4df085");
background-size:cover;
background-position:center;
padding:140px 20px;
text-align:center;
position:relative;
color:#fff;
}

.lp-hero:before{
content:"";
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
background:rgba(0,0,0,0.35);
}

.lp-hero-inner{
position:relative;
z-index:2;
max-width:900px;
margin:auto;
}

.lp-hero h1{
font-size:36px;
margin-bottom:20px;
}

.lp-hero-text{
font-size:18px;
}

.lp-btn{
background:#007b8a;
color:#fff;
padding:16px 40px;
border-radius:8px;
text-decoration:none;
display:inline-block;
margin-top:25px;
font-weight:bold;
}

.lp-hero{
opacity:1;
transform:none;
}

/* ==============================
TRUST
============================== */

.lp-trust{
background:#fff;
padding:40px 20px;
opacity:1;
transform:none;
}

.lp-trust-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:20px;
max-width:900px;
margin:0 auto;
text-align:center;
font-weight:bold;
}

/* ==============================
PROBLEM
============================== */

.lp-problem{
background:#f7f9fa;
padding:100px 20px;
text-align:center;
}

.lp-problem-grid{
display:grid;
grid-template-columns:repeat(2,1fr);
gap:20px;
max-width:800px;
margin:40px auto;
}

.lp-problem-box{
background:#fff;
padding:20px;
border-radius:10px;
box-shadow:0 5px 15px rgba(0,0,0,0.05);
}

/* ==============================
SERVICE
============================== */

.lp-service-grid{
display:grid;
grid-template-columns:repeat(2,1fr);
gap:40px;
max-width:1400px;
margin:0 auto;
}

.lp-service-box{
display:flex;
align-items:center;
justify-content:space-between;
gap:40px;
background:#fff;
padding:30px;
border-radius:12px;
box-shadow:0 5px 20px rgba(0,0,0,0.05);
}

.lp-service-text{
flex:1;
}

.lp-service-text h3{
margin-bottom:10px;
}

.lp-service-img{
flex:0 0 320px;
text-align:right;
}

.lp-service-img img{
width:100%;
max-width:100%;
height:auto;
border-radius:12px;
}

.lp-service-text ul{
list-style:none;
padding-left:0;
text-align:left;
}

.lp-service-text li{
position:relative;
padding-left:22px;
margin-bottom:8px;
}

.lp-service-text li:before{
content:"✓";
position:absolute;
left:0;
color:#007b8a;
font-weight:bold;
}

/* ==============================
REASON
============================== */

.lp-reason{
padding:100px 20px;
text-align:center;
background:#f9fafb;
}

.lp-reason-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;
max-width:1100px;
margin:40px auto;
}

.lp-reason-box{
background:#fff;
padding:30px;
border-radius:12px;
box-shadow:0 5px 20px rgba(0,0,0,0.05);
}

.lp-reason-box h3{
font-size:20px;
margin-bottom:10px;
color:#007b8a;
}

/* ==============================
COMPARE
============================== */

.lp-compare{
display:grid;
grid-template-columns:1fr 1fr;
gap:40px;
max-width:1100px;
margin:60px auto 0;
}

.lp-compare-box{
background:#fff;
padding:35px;
border-radius:14px;
box-shadow:0 10px 30px rgba(0,0,0,0.05);
text-align:left;
}

.lp-compare-box.good{
background:#e8f4f5;
}

.lp-compare-table{
width:100%;
max-width:1100px;
margin:40px auto;
border-collapse:collapse;
}

.lp-compare-table th{
background:#007b8a;
color:#fff;
padding:15px;
}

.lp-compare-table td{
border:1px solid #ddd;
padding:15px;
}

.lp-compare-title{
font-size:1.6em;
margin-bottom:10px;
text-align:center;
}

.lp-compare-sub{
text-align:center;
color:#666;
margin-bottom:50px;
}

.lp-point-box{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;
max-width:1100px;
margin:40px auto 60px;
}

.lp-point-item{
background:#fff;
padding:30px;
border-radius:12px;
box-shadow:0 5px 20px rgba(0,0,0,0.05);
}

.lp-point-item h3{
font-size:1.2em;
margin-bottom:10px;
}

.lp-point-item p{
font-size:0.9em;
line-height:1.6;
}

.lp-reason-title{
font-size:1.6em;
text-align:center;
margin-bottom:10px;
}

.lp-reason-lead{
text-align:center;
color:#666;
margin-bottom:25px;
}

.lp-reason-label{
display:block;
width:max-content;
margin:20px auto 40px;
background:#007b8a;
color:#fff;
padding:8px 18px;
border-radius:20px;
font-size:0.9em;
}

.lp-reason-label::after{
content:"▼";
display:block;
text-align:center;
font-size:0.8em;
margin-top:5px;
color:#fff;
}

.lp-section-label{
display:block;
width:max-content;
margin:30px auto 40px;
background:#007b8a;
color:#fff;
padding:8px 18px;
border-radius:20px;
font-size:0.9em;
}

@media(max-width:768px){

.lp-point-box{
grid-template-columns:1fr;
}

}

/* ==============================
PRICE
============================== */

.lp-price-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;
max-width:1000px;
margin:0 auto;
}

.lp-price-box{
border:2px solid #007b8a;
padding:30px;
border-radius:10px;
text-align:center;
background:#fff;
}

.lp-price-main{
transform:scale(1.05);
border:3px solid #007b8a;
}

.lp-price{
font-size:22px;
font-weight:bold;
color:#007b8a;
margin:10px 0;
}

/* ==============================
CASE
============================== */

.lp-case{
padding:100px 20px;
background:#f7f9fa;
text-align:center;
}

.lp-case-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;
max-width:1000px;
margin:0 auto;
}

.lp-case-box{
background:#fff;
padding:25px;
border-radius:10px;
box-shadow:0 6px 16px rgba(0,0,0,0.05);
}

.lp-case-result{
color:#007b8a;
font-weight:bold;
margin-top:10px;
}

/* ==============================
FAQ
============================== */

.lp-faq{
max-width:900px;
margin:0 auto;
padding:100px 20px;
}

.lp-faq h2{
text-align:center;
margin-bottom:60px;
}

.lp-faq-box{
background:#fff;
padding:30px;
margin-bottom:20px;
border-radius:10px;
box-shadow:0 5px 15px rgba(0,0,0,0.05);
}

.lp-faq-box h3{
margin-bottom:10px;
color:#007b8a;
}

/* ==============================
AREA
============================== */

.lp-area{
padding:80px 20px;
text-align:center;
}

.lp-area-city
{
margin-top:20px;
font-weight:bold;
color:#007b8a;
}

/* ==============================
CTA
============================== */

.lp-cta
{
background:#f7f9fa;
padding:140px 20px;
text-align:center;
margin-top:80px;
}

.lp-cta h2
{
font-size:28px;
margin-bottom:20px;
}

.lp-cta p
{
margin-bottom:40px;
line-height:1.8;
}

.lp-contact-btn{
background:#007b8a;
color:#fff;
padding:16px 40px;
border-radius:10px;
text-decoration:none;
display:inline-block;
margin-top:20px;
font-weight:bold;
}

/* ==============================
FIXED CTA
============================== */

.lp-fixed-cta{
margin-top:40px;
text-align:center;
}

.lp-fixed-btn{
background:#007b8a;
color:#fff;
padding:14px 26px;
border-radius:30px;
text-decoration:none;
font-weight:bold;
box-shadow:0 5px 15px rgba(0,0,0,0.2);
}

/* ==============================
FADEIN
============================== */

.fadein{
opacity:0;
transform:translateY(40px);
transition:1s;
}

.fadein.is-active{
opacity:1;
transform:none;
}

/* ==============================
COMPARE SP
============================== */

.lp-compare-sp
{
display:none;
margin-top:30px;
}

.lp-compare-card
{
padding:20px;
border-radius:10px;
margin-bottom:20px;
}

.lp-compare-card h3
{
margin-bottom:15px;
}

.lp-compare-card ul
{
list-style:none;
padding:0;
}

.lp-compare-card li
{
padding:8px 0;
border-bottom:1px solid #eee;
}

.lp-compare-card.bad
{
background:#f7f7f7;
}

.lp-compare-card.good
{
background:#e8f6f7;
}

/* ==============================
SP
============================== */

@media(max-width:768px)
{

.lp-table
{
display:none;
}

.lp-compare-sp
{
display:block;
}

}

/* ==============================
RESPONSIVE
============================== */

@media(max-width:768px){
.lp-section h2,
.lp-cta h2,
.lp-reason h2,
.lp-compare h2,
.lp-faq h2,
.lp-area h2,
.lp-case h2,
.lp-problem h2
	{
font-size:1.4em;
margin-bottom:30px;
}

.lp-problem-grid{
grid-template-columns:1fr;
}

.lp-service-box{
flex-direction:column;
text-align:center;
}
	
.lp-service-grid{
grid-template-columns:1fr;
}

.lp-service-img{
flex:none;
text-align:center;
}

.lp-reason-grid{
grid-template-columns:1fr;
}

.lp-price-grid{
grid-template-columns:1fr;
}

.lp-reason, .lp-compare, .lp-case, .lp-faq, .lp-area, .lp-problem {
padding: 40px 20px;
}
	
.lp-case-grid{
grid-template-columns:1fr;
}

.lp-trust-grid{
grid-template-columns:1fr;
}

.lp-fixed-cta{
left:10px;
right:10px;
bottom:10px;
}

.lp-fixed-btn{
display:block;
text-align:center;
width:100%;
border-radius:10px;
}

.lp-section{
padding:60px 18px;
}

.lp-cta{
padding:60px 18px;
}

.lp-table thead{
display:none;
}

.lp-table,
.lp-table tbody,
.lp-table tr,
.lp-table td{
display:block;
width:100%;
}

.lp-table tr{
margin-bottom:20px;
background:#fff;
border-radius:10px;
overflow:hidden;
}

.lp-table td{
display:flex;
justify-content:space-between;
padding:14px 16px;
border-bottom:1px solid #eee;
}

.lp-table td:first-child{
font-weight:bold;
background:#f7f7f7;
}
	
.lp-service-box{
padding:30px 20px;
height:auto;
}
	
.lp-service-img{
height:auto;
}

.lp-service-img img{
height:auto;
}
	
.lp-service-img{
display:block;
}
}

/*  TOP  */

.gl-hero{
height:100vh;
display:flex;
align-items:center;
justify-content:center;
text-align:center;
background:url("/wp-content/uploads/hero.jpg") center/cover no-repeat;
color:#fff;
}

.gl-hero-inner{
max-width:900px;
padding:20px;
}

.gl-hero h1{
font-size:2.2em;
margin-bottom:20px;
}

.gl-hero p{
font-size:1.1em;
margin-bottom:30px;
}

.gl-top-hero{
padding:120px 20px;
text-align:center;
}

.gl-top-title{
font-size:2.2em;
margin-bottom:20px;
}

.gl-top-sub{
margin-bottom:30px;
}

.gl-top-btn{
background:#007b8a;
color:#fff;
padding:14px 32px;
border-radius:6px;
text-decoration:none;
display:inline-block;
}

.gl-top-problem{
position:relative;
padding:120px 20px;
background:url("/design_blog/wp-content/uploads/2026/03/problem01.webp") center/cover no-repeat;
}

.gl-top-problem::before{
content:"";
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
background:rgba(0,0,0,0.45);
}

.gl-top-problem-inner{
position:relative;
max-width:1000px;
margin:0 auto;
text-align:center;
color:#fff;
}

.gl-top-problem-list{
display:grid;
grid-template-columns:repeat(2,1fr);
gap:20px;
margin-top:40px;
}

.gl-top-problem-item{
background:rgba(255,255,255,0.92);
padding:18px 24px;
border-radius:10px;
color:#333;
font-weight:500;
}

.gl-problem-grid{
display:grid;
grid-template-columns:repeat(2,1fr);
gap:20px;
max-width:900px;
margin:40px auto;
}

.gl-problem-item{
background:#fff;
padding:20px;
border-radius:8px;
}

.gl-top-support{
padding:120px 20px;
text-align:center;
}

.gl-top-services{
padding:120px 20px;
text-align:center;
}

.gl-service-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:40px;
max-width:1400px;
margin:0 auto;
padding:0 20px;
}

.gl-service-card{
display:flex;
gap:30px;
background:#fff;
padding:35px;
border-radius:14px;
box-shadow:0 10px 30px rgba(0,0,0,0.06);
align-items:center;
}

.gl-service-img{
flex:0 0 280px;
}

.gl-service-img img{
width:100%;
height:170px;
object-fit:cover;
border-radius:12px;
}

.gl-service-text{
flex:1;
display:flex;
flex-direction:column;
}

.gl-service-text h3{
font-size:1.5em;
margin-bottom:12px;
}

.gl-service-text p{
line-height:1.8;
margin-bottom:20px;
}

.gl-service-btn{
background:#007b8a;
color:#fff;
padding:8px 40px;
border-radius:8px;
text-decoration:none;
align-self:flex-end;
font-weight:600;
transition:0.2s;
}

.gl-service-btn:hover{
transform:translateY(-2px);
box-shadow:0 5px 15px rgba(0,0,0,0.15);
}


.gl-btn{
display:inline-block;
padding:10px 20px;
background:#007b8a;
color:#fff;
border-radius:6px;
text-decoration:none;
margin-top:10px;
}

.gl-top-reason{
padding:30px 20px;
text-align:center;
}

.gl-reason-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;
max-width:900px;
margin:40px auto;
}

.gl-reason-item{
background:#fff;
padding:30px;
border-radius:10px;
box-shadow:0 5px 20px rgba(0,0,0,0.05);
}

.gl-top-area{
padding:100px 20px;
text-align:center;
}

.gl-top-cta {
    padding: 120px 20px 160px;
    background: #f7f9fa;
    text-align: center;
    margin-bottom: 20px;
}

.gl-top-support h2, .gl-top-area h2{
	margin-bottom: 10px;
}

.gl-top-cta h2{
	margin-bottom: 30px;
}

.gl-flow{
padding:120px 20px;
background:#f7f9fa;
text-align:center;
}

.gl-flow-grid{
display:grid;
grid-template-columns:repeat(4,1fr);
gap:30px;
max-width:1100px;
margin:60px auto 0;
}

.gl-flow-step{
background:#fff;
padding:30px;
border-radius:12px;
box-shadow:0 8px 25px rgba(0,0,0,0.05);
}

.gl-flow-number{
font-size:1.4em;
font-weight:bold;
color:#007b8a;
margin-bottom:10px;
}

@media(max-width:768px){

.gl-problem-grid{
grid-template-columns:1fr;
}

.gl-service-grid{
grid-template-columns:1fr;
}

.gl-service-card{
flex-direction:column;
text-align:center;
}

.gl-service-img {
flex: 0 0 0px;
}
	
.gl-service-img{
width:100%;
}

.gl-service-img img{
height:180px;
}

.gl-service-btn{
align-self:center;
}

.gl-service-grid {
padding: 0;
}

.gl-service-text p {
    line-height: 1.8;
    margin-bottom: 20px;
    text-align: left;
}	

.gl-reason-grid{
grid-template-columns:1fr;
}

}